From 43c3ee5445bf1cafc4e63f0e01a45c8e58d81ac8 Mon Sep 17 00:00:00 2001 From: Flavio De Stefano Date: Fri, 10 Apr 2015 12:48:16 +0200 Subject: [PATCH] AWS.phar no more --- aeria.php | 4 +- classes/AeriaSES.php | 8 +- metadata.json | 2 +- vendor/aws.phar | Bin 8637413 -> 0 bytes .../aws/Aws/AutoScaling/AutoScalingClient.php | 108 + .../Aws/AutoScaling/Enum/LifecycleState.php | 31 + .../Enum/ScalingActivityStatusCode.php | 34 + .../Exception/AlreadyExistsException.php | 22 + .../Exception/AutoScalingException.php | 24 + .../Exception/InvalidNextTokenException.php | 22 + .../Exception/LimitExceededException.php | 22 + .../Exception/ResourceInUseException.php | 22 + .../ScalingActivityInProgressException.php | 22 + .../Resources/autoscaling-2011-01-01.php | 3223 +++ .../CloudFormation/CloudFormationClient.php | 77 + .../Aws/CloudFormation/Enum/Capability.php | 27 + .../aws/Aws/CloudFormation/Enum/OnFailure.php | 29 + .../CloudFormation/Enum/ResourceStatus.php | 35 + .../Aws/CloudFormation/Enum/StackStatus.php | 42 + .../Exception/AlreadyExistsException.php | 22 + .../Exception/CloudFormationException.php | 24 + .../InsufficientCapabilitiesException.php | 22 + .../Exception/LimitExceededException.php | 22 + .../Resources/cloudformation-2010-05-15.php | 1312 ++ .../aws/Aws/CloudFront/CloudFrontClient.php | 234 + .../Aws/CloudFront/CloudFrontSignature.php | 61 + .../CloudFront/Enum/GeoRestrictionType.php | 29 + .../aws/Aws/CloudFront/Enum/ItemSelection.php | 29 + vendor/aws/Aws/CloudFront/Enum/Method.php | 33 + .../CloudFront/Enum/OriginProtocolPolicy.php | 28 + vendor/aws/Aws/CloudFront/Enum/PriceClass.php | 29 + .../Aws/CloudFront/Enum/SSLSupportMethod.php | 28 + .../CloudFront/Enum/ViewerProtocolPolicy.php | 29 + .../Exception/AccessDeniedException.php | 22 + .../Exception/BatchTooLargeException.php | 22 + .../Exception/CNAMEAlreadyExistsException.php | 22 + .../Exception/CloudFrontException.php | 24 + ...inAccessIdentityAlreadyExistsException.php | 22 + ...rontOriginAccessIdentityInUseException.php | 22 + .../DistributionAlreadyExistsException.php | 22 + .../DistributionNotDisabledException.php | 22 + .../Aws/CloudFront/Exception/Exception.php | 24 + .../Exception/IllegalUpdateException.php | 22 + .../InconsistentQuantitiesException.php | 22 + .../Exception/InvalidArgumentException.php | 22 + .../InvalidDefaultRootObjectException.php | 22 + .../Exception/InvalidErrorCodeException.php | 22 + .../InvalidForwardCookiesException.php | 22 + ...nvalidGeoRestrictionParameterException.php | 22 + .../InvalidIfMatchVersionException.php | 22 + .../InvalidLocationCodeException.php | 22 + .../InvalidOriginAccessIdentityException.php | 22 + .../Exception/InvalidOriginException.php | 22 + .../InvalidRelativePathException.php | 22 + .../InvalidRequiredProtocolException.php | 22 + .../InvalidResponseCodeException.php | 22 + .../InvalidViewerCertificateException.php | 22 + .../Exception/MissingBodyException.php | 22 + ...loudFrontOriginAccessIdentityException.php | 22 + .../Exception/NoSuchDistributionException.php | 22 + .../Exception/NoSuchInvalidationException.php | 22 + .../Exception/NoSuchOriginException.php | 22 + .../NoSuchStreamingDistributionException.php | 22 + .../Exception/PreconditionFailedException.php | 22 + ...mingDistributionAlreadyExistsException.php | 22 + ...eamingDistributionNotDisabledException.php | 22 + .../TooManyCacheBehaviorsException.php | 22 + .../TooManyCertificatesException.php | 22 + ...udFrontOriginAccessIdentitiesException.php | 22 + ...TooManyCookieNamesInWhiteListException.php | 22 + .../TooManyDistributionCNAMEsException.php | 22 + .../TooManyDistributionsException.php | 22 + ...ooManyInvalidationsInProgressException.php | 22 + .../Exception/TooManyOriginsException.php | 22 + ...nyStreamingDistributionCNAMEsException.php | 22 + ...TooManyStreamingDistributionsException.php | 22 + .../TooManyTrustedSignersException.php | 22 + .../TrustedSignerDoesNotExistException.php | 22 + .../Resources/cloudfront-2012-05-05.php | 4609 +++++ .../Resources/cloudfront-2014-05-31.php | 5482 ++++++ .../Resources/cloudfront-2014-10-21.php | 5739 ++++++ .../Resources/cloudfront-2014-11-06.php | 5744 ++++++ vendor/aws/Aws/CloudHsm/CloudHsmClient.php | 73 + .../CloudHsm/Exception/CloudHsmException.php | 24 + .../Resources/cloudhsm-2014-05-30.php | 1178 ++ .../aws/Aws/CloudSearch/CloudSearchClient.php | 105 + .../Aws/CloudSearch/Enum/IndexFieldType.php | 38 + .../aws/Aws/CloudSearch/Enum/OptionState.php | 30 + .../CloudSearch/Enum/SearchInstanceType.php | 30 + .../CloudSearch/Enum/SourceDataFunction.php | 29 + .../CloudSearch/Exception/BaseException.php | 22 + .../Exception/CloudSearchException.php | 24 + .../Exception/InternalException.php | 22 + .../Exception/InvalidTypeException.php | 22 + .../Exception/LimitExceededException.php | 22 + .../Exception/ResourceNotFoundException.php | 22 + .../Resources/cloudsearch-2011-02-01.php | 2346 +++ .../Resources/cloudsearch-2013-01-01.php | 3497 ++++ .../CloudSearchDomainClient.php | 54 + .../CloudSearchDomainClientBuilder.php | 122 + .../Exception/CloudSearchDomainException.php | 10 + .../cloudsearchdomain-2013-01-01.php | 311 + .../aws/Aws/CloudTrail/CloudTrailClient.php | 65 + .../Exception/CloudTrailException.php | 24 + .../InsufficientS3BucketPolicyException.php | 22 + .../InsufficientSnsTopicPolicyException.php | 22 + .../Exception/InternalErrorException.php | 22 + .../InvalidS3BucketNameException.php | 22 + .../Exception/InvalidS3PrefixException.php | 22 + .../InvalidSnsTopicNameException.php | 22 + .../Exception/InvalidTrailNameException.php | 22 + ...MaximumNumberOfTrailsExceededException.php | 22 + .../S3BucketDoesNotExistException.php | 22 + .../Exception/TrailAlreadyExistsException.php | 22 + .../Exception/TrailNotFoundException.php | 22 + .../Exception/TrailNotProvidedException.php | 22 + vendor/aws/Aws/CloudTrail/LogFileIterator.php | 266 + vendor/aws/Aws/CloudTrail/LogFileReader.php | 56 + .../aws/Aws/CloudTrail/LogRecordIterator.php | 180 + .../Resources/cloudtrail-2013-11-01.php | 752 + .../aws/Aws/CloudWatch/CloudWatchClient.php | 70 + .../CloudWatch/Enum/ComparisonOperator.php | 30 + .../Aws/CloudWatch/Enum/HistoryItemType.php | 29 + vendor/aws/Aws/CloudWatch/Enum/StateValue.php | 29 + vendor/aws/Aws/CloudWatch/Enum/Statistic.php | 31 + vendor/aws/Aws/CloudWatch/Enum/Unit.php | 53 + .../Exception/CloudWatchException.php | 24 + .../Exception/InternalServiceException.php | 22 + .../Exception/InvalidFormatException.php | 22 + .../Exception/InvalidNextTokenException.php | 22 + .../InvalidParameterCombinationException.php | 22 + .../InvalidParameterValueException.php | 22 + .../Exception/LimitExceededException.php | 22 + .../MissingRequiredParameterException.php | 22 + .../Exception/ResourceNotFoundException.php | 22 + .../Resources/cloudwatch-2010-08-01.php | 1251 ++ .../CloudWatchLogs/CloudWatchLogsClient.php | 58 + .../Exception/CloudWatchLogsException.php | 10 + .../Resources/cloudwatchlogs-2014-03-28.php | 1122 ++ .../aws/Aws/CodeDeploy/CodeDeployClient.php | 90 + .../Exception/CodeDeployException.php | 10 + .../Resources/codedeploy-2014-10-06.php | 3071 +++ .../CognitoIdentity/CognitoIdentityClient.php | 83 + .../Exception/CognitoIdentityException.php | 10 + .../Resources/cognitoidentity-2014-06-30.php | 1486 ++ .../aws/Aws/CognitoSync/CognitoSyncClient.php | 59 + .../Exception/CognitoSyncException.php | 10 + .../Resources/cognitosync-2014-06-30.php | 1293 ++ vendor/aws/Aws/Common/Aws.php | 106 + .../aws/Aws/Common/Client/AbstractClient.php | 283 + .../Aws/Common/Client/AwsClientInterface.php | 118 + .../aws/Aws/Common/Client/ClientBuilder.php | 526 + .../aws/Aws/Common/Client/DefaultClient.php | 67 + .../Client/ExpiredCredentialsChecker.php | 80 + .../Common/Client/ThrottlingErrorChecker.php | 75 + .../Aws/Common/Client/UploadBodyListener.php | 95 + .../Aws/Common/Client/UserAgentListener.php | 61 + .../Aws/Common/Command/AwsQueryVisitor.php | 117 + vendor/aws/Aws/Common/Command/JsonCommand.php | 47 + .../aws/Aws/Common/Command/QueryCommand.php | 53 + .../Command/XmlResponseLocationVisitor.php | 74 + .../AbstractCredentialsDecorator.php | 136 + .../AbstractRefreshableCredentials.php | 76 + .../Credentials/CacheableCredentials.php | 73 + .../Aws/Common/Credentials/Credentials.php | 337 + .../Credentials/CredentialsInterface.php | 96 + .../Common/Credentials/NullCredentials.php | 68 + .../RefreshableInstanceProfileCredentials.php | 59 + vendor/aws/Aws/Common/Enum.php | 55 + vendor/aws/Aws/Common/Enum/ClientOptions.php | 162 + vendor/aws/Aws/Common/Enum/DateFormat.php | 31 + vendor/aws/Aws/Common/Enum/Region.php | 63 + vendor/aws/Aws/Common/Enum/Size.php | 53 + vendor/aws/Aws/Common/Enum/Time.php | 46 + vendor/aws/Aws/Common/Enum/UaString.php | 55 + .../Exception/AwsExceptionInterface.php | 30 + .../Exception/BadMethodCallException.php | 22 + .../Aws/Common/Exception/DomainException.php | 22 + .../Exception/ExceptionFactoryInterface.php | 36 + .../Common/Exception/ExceptionListener.php | 59 + .../InstanceProfileCredentialsException.php | 50 + .../Exception/InvalidArgumentException.php | 22 + .../Aws/Common/Exception/LogicException.php | 22 + .../Exception/MultipartUploadException.php | 55 + .../Exception/NamespaceExceptionFactory.php | 103 + .../Common/Exception/OutOfBoundsException.php | 22 + .../Common/Exception/OverflowException.php | 22 + .../Parser/AbstractJsonExceptionParser.php | 66 + .../Parser/DefaultXmlExceptionParser.php | 100 + .../Parser/ExceptionParserInterface.php | 42 + .../Parser/JsonQueryExceptionParser.php | 41 + .../Parser/JsonRestExceptionParser.php | 48 + .../RequiredExtensionNotLoadedException.php | 22 + .../Aws/Common/Exception/RuntimeException.php | 22 + .../Exception/ServiceResponseException.php | 221 + .../Common/Exception/TransferException.php | 24 + .../Exception/UnexpectedValueException.php | 22 + vendor/aws/Aws/Common/Facade/Facade.php | 69 + .../aws/Aws/Common/Facade/FacadeInterface.php | 34 + .../aws/Aws/Common/Facade/facade-classes.php | 283 + vendor/aws/Aws/Common/Hash/ChunkHash.php | 87 + .../Aws/Common/Hash/ChunkHashInterface.php | 52 + vendor/aws/Aws/Common/Hash/HashUtils.php | 76 + vendor/aws/Aws/Common/Hash/TreeHash.php | 195 + vendor/aws/Aws/Common/HostNameUtils.php | 85 + .../InstanceMetadataClient.php | 102 + .../Waiter/ServiceAvailable.php | 50 + .../Common/Iterator/AwsResourceIterator.php | 169 + .../Iterator/AwsResourceIteratorFactory.php | 106 + .../MultipartUpload/AbstractTransfer.php | 270 + .../MultipartUpload/AbstractTransferState.php | 164 + .../MultipartUpload/AbstractUploadBuilder.php | 148 + .../MultipartUpload/AbstractUploadId.php | 89 + .../MultipartUpload/AbstractUploadPart.php | 101 + .../MultipartUpload/TransferInterface.php | 66 + .../TransferStateInterface.php | 92 + .../MultipartUpload/UploadIdInterface.php | 39 + .../MultipartUpload/UploadPartInterface.php | 46 + .../aws/Aws/Common/Resources/aws-config.php | 326 + .../Aws/Common/Resources/public-endpoints.php | 79 + .../aws/Aws/Common/Resources/sdk1-config.php | 138 + .../aws/Aws/Common/RulesEndpointProvider.php | 67 + .../Common/Signature/AbstractSignature.php | 44 + .../Signature/EndpointSignatureInterface.php | 42 + .../Common/Signature/SignatureInterface.php | 52 + .../Common/Signature/SignatureListener.php | 83 + .../aws/Aws/Common/Signature/SignatureV2.php | 109 + .../Aws/Common/Signature/SignatureV3Https.php | 52 + .../aws/Aws/Common/Signature/SignatureV4.php | 470 + .../Common/Waiter/AbstractResourceWaiter.php | 53 + .../aws/Aws/Common/Waiter/AbstractWaiter.php | 146 + .../aws/Aws/Common/Waiter/CallableWaiter.php | 82 + .../Common/Waiter/CompositeWaiterFactory.php | 90 + .../Common/Waiter/ConfigResourceWaiter.php | 225 + .../Common/Waiter/ResourceWaiterInterface.php | 34 + .../Aws/Common/Waiter/WaiterClassFactory.php | 106 + vendor/aws/Aws/Common/Waiter/WaiterConfig.php | 67 + .../Aws/Common/Waiter/WaiterConfigFactory.php | 98 + .../Common/Waiter/WaiterFactoryInterface.php | 41 + .../aws/Aws/Common/Waiter/WaiterInterface.php | 60 + .../Aws/ConfigService/ConfigServiceClient.php | 69 + .../Exception/ConfigServiceException.php | 10 + .../Resources/configservice-2014-11-12.php | 830 + .../Aws/DataPipeline/DataPipelineClient.php | 83 + .../aws/Aws/DataPipeline/Enum/WorkStatus.php | 29 + .../Exception/DataPipelineException.php | 24 + .../InternalServiceErrorException.php | 22 + .../Exception/InvalidRequestException.php | 22 + .../Exception/PipelineDeletedException.php | 22 + .../Exception/PipelineNotFoundException.php | 22 + .../Exception/TaskNotFoundException.php | 22 + .../Resources/datapipeline-2012-10-29.php | 1899 ++ .../Aws/DirectConnect/DirectConnectClient.php | 82 + .../DirectConnect/Enum/ConnectionState.php | 34 + .../DirectConnect/Enum/InterconnectState.php | 32 + .../aws/Aws/DirectConnect/Enum/StepState.php | 28 + .../Enum/VirtualInterfaceState.php | 33 + .../DirectConnectClientException.php | 22 + .../Exception/DirectConnectException.php | 24 + .../DirectConnectServerException.php | 22 + .../Resources/directconnect-2012-10-25.php | 1394 ++ vendor/aws/Aws/DynamoDb/Crc32ErrorChecker.php | 66 + vendor/aws/Aws/DynamoDb/DynamoDbClient.php | 196 + vendor/aws/Aws/DynamoDb/DynamoDbCommand.php | 100 + .../aws/Aws/DynamoDb/Enum/AttributeAction.php | 29 + .../aws/Aws/DynamoDb/Enum/AttributeType.php | 29 + .../Aws/DynamoDb/Enum/ComparisonOperator.php | 39 + vendor/aws/Aws/DynamoDb/Enum/IndexStatus.php | 30 + vendor/aws/Aws/DynamoDb/Enum/KeyType.php | 28 + .../aws/Aws/DynamoDb/Enum/ProjectionType.php | 29 + .../DynamoDb/Enum/ReturnConsumedCapacity.php | 29 + .../Enum/ReturnItemCollectionMetrics.php | 28 + vendor/aws/Aws/DynamoDb/Enum/ReturnValue.php | 31 + .../Aws/DynamoDb/Enum/ScalarAttributeType.php | 29 + vendor/aws/Aws/DynamoDb/Enum/Select.php | 30 + vendor/aws/Aws/DynamoDb/Enum/TableStatus.php | 30 + vendor/aws/Aws/DynamoDb/Enum/Type.php | 41 + .../Exception/AccessDeniedException.php | 22 + .../ConditionalCheckFailedException.php | 22 + .../DynamoDb/Exception/DynamoDbException.php | 24 + .../IncompleteSignatureException.php | 22 + .../Exception/InternalFailureException.php | 22 + .../InternalServerErrorException.php | 22 + ...emCollectionSizeLimitExceededException.php | 22 + .../Exception/LimitExceededException.php | 22 + .../MissingAuthenticationTokenException.php | 22 + ...ProvisionedThroughputExceededException.php | 22 + .../Exception/ResourceInUseException.php | 22 + .../Exception/ResourceNotFoundException.php | 22 + .../Exception/ServiceUnavailableException.php | 22 + .../Exception/ThrottlingException.php | 22 + .../UnprocessedWriteRequestsException.php | 78 + .../Exception/UnrecognizedClientException.php | 22 + .../Exception/ValidationException.php | 22 + .../Aws/DynamoDb/Iterator/ItemIterator.php | 119 + .../Aws/DynamoDb/Iterator/ScanIterator.php | 57 + vendor/aws/Aws/DynamoDb/Marshaler.php | 173 + vendor/aws/Aws/DynamoDb/Model/Attribute.php | 248 + .../BatchRequest/AbstractWriteRequest.php | 36 + .../Model/BatchRequest/DeleteRequest.php | 94 + .../Model/BatchRequest/PutRequest.php | 100 + .../Model/BatchRequest/UnprocessedRequest.php | 48 + .../Model/BatchRequest/WriteRequestBatch.php | 120 + .../WriteRequestBatchTransfer.php | 252 + .../BatchRequest/WriteRequestInterface.php | 32 + vendor/aws/Aws/DynamoDb/Model/Item.php | 261 + .../Resources/dynamodb-2011-12-05.php | 3546 ++++ .../Resources/dynamodb-2012-08-10.php | 499 + .../AbstractLockingStrategy.php | 129 + .../LockingStrategyFactory.php | 85 + .../LockingStrategyFactoryInterface.php | 36 + .../LockingStrategyInterface.php | 52 + .../LockingStrategy/NullLockingStrategy.php | 65 + .../PessimisticLockingStrategy.php | 118 + .../Aws/DynamoDb/Session/SessionHandler.php | 460 + .../DynamoDb/Session/SessionHandlerConfig.php | 86 + .../Session/SessionHandlerInterface.php | 20 + vendor/aws/Aws/Ec2/CopySnapshotListener.php | 83 + vendor/aws/Aws/Ec2/Ec2Client.php | 269 + vendor/aws/Aws/Ec2/Enum/ContainerFormat.php | 27 + vendor/aws/Aws/Ec2/Enum/DiskImageFormat.php | 29 + vendor/aws/Aws/Ec2/Enum/DomainType.php | 28 + vendor/aws/Aws/Ec2/Enum/ExportEnvironment.php | 29 + vendor/aws/Aws/Ec2/Enum/HypervisorType.php | 28 + vendor/aws/Aws/Ec2/Enum/ImageState.php | 28 + .../Aws/Ec2/Enum/InstanceAttributeName.php | 38 + vendor/aws/Aws/Ec2/Enum/InstanceStateName.php | 32 + vendor/aws/Aws/Ec2/Enum/InstanceType.php | 64 + .../aws/Aws/Ec2/Enum/PlacementGroupState.php | 30 + vendor/aws/Aws/Ec2/Enum/PlacementStrategy.php | 27 + vendor/aws/Aws/Ec2/Enum/ResourceType.php | 43 + vendor/aws/Aws/Ec2/Enum/RouteOrigin.php | 29 + vendor/aws/Aws/Ec2/Enum/RuleAction.php | 28 + .../Aws/Ec2/Enum/SnapshotAttributeName.php | 28 + vendor/aws/Aws/Ec2/Enum/SnapshotState.php | 29 + vendor/aws/Aws/Ec2/Enum/SpotInstanceType.php | 28 + .../aws/Aws/Ec2/Enum/VirtualizationType.php | 28 + .../Aws/Ec2/Enum/VolumeAttachmentState.php | 30 + .../aws/Aws/Ec2/Enum/VolumeAttributeName.php | 28 + vendor/aws/Aws/Ec2/Enum/VolumeState.php | 32 + vendor/aws/Aws/Ec2/Enum/VolumeType.php | 28 + vendor/aws/Aws/Ec2/Enum/VpcAttributeName.php | 28 + vendor/aws/Aws/Ec2/Exception/Ec2Exception.php | 24 + .../Iterator/DescribeInstancesIterator.php | 48 + .../aws/Aws/Ec2/Resources/ec2-2014-06-15.php | 15844 +++++++++++++++ .../aws/Aws/Ec2/Resources/ec2-2014-09-01.php | 15873 +++++++++++++++ .../aws/Aws/Ec2/Resources/ec2-2014-10-01.php | 16338 ++++++++++++++++ vendor/aws/Aws/Ecs/EcsClient.php | 84 + vendor/aws/Aws/Ecs/Exception/EcsException.php | 9 + .../aws/Aws/Ecs/Resources/ecs-2014-11-13.php | 3257 +++ .../aws/Aws/ElastiCache/ElastiCacheClient.php | 104 + .../aws/Aws/ElastiCache/Enum/SourceType.php | 30 + .../AuthorizationAlreadyExistsException.php | 22 + .../AuthorizationNotFoundException.php | 22 + .../CacheClusterAlreadyExistsException.php | 22 + .../CacheClusterNotFoundException.php | 22 + ...heParameterGroupAlreadyExistsException.php | 22 + .../CacheParameterGroupNotFoundException.php | 22 + ...heParameterGroupQuotaExceededException.php | 22 + ...cheSecurityGroupAlreadyExistsException.php | 22 + .../CacheSecurityGroupNotFoundException.php | 22 + ...cheSecurityGroupQuotaExceededException.php | 22 + ...CacheSubnetGroupAlreadyExistsException.php | 22 + .../CacheSubnetGroupInUseException.php | 22 + .../CacheSubnetGroupNotFoundException.php | 22 + ...CacheSubnetGroupQuotaExceededException.php | 22 + .../CacheSubnetQuotaExceededException.php | 22 + ...usterQuotaForCustomerExceededException.php | 22 + .../Exception/ElastiCacheException.php | 24 + ...ufficientCacheClusterCapacityException.php | 22 + .../InvalidCacheClusterStateException.php | 22 + ...validCacheParameterGroupStateException.php | 22 + ...nvalidCacheSecurityGroupStateException.php | 22 + .../InvalidParameterCombinationException.php | 22 + .../InvalidParameterValueException.php | 22 + .../InvalidReplicationGroupStateException.php | 22 + .../Exception/InvalidSubnetException.php | 22 + .../InvalidVPCNetworkStateException.php | 22 + .../NodeQuotaForClusterExceededException.php | 22 + .../NodeQuotaForCustomerExceededException.php | 22 + ...ReplicationGroupAlreadyExistsException.php | 22 + .../ReplicationGroupNotFoundException.php | 22 + ...eservedCacheNodeAlreadyExistsException.php | 22 + .../ReservedCacheNodeNotFoundException.php | 22 + ...eservedCacheNodeQuotaExceededException.php | 22 + ...vedCacheNodesOfferingNotFoundException.php | 22 + .../Exception/SubnetInUseException.php | 22 + .../Resources/elasticache-2014-07-15.php | 3730 ++++ .../Resources/elasticache-2014-09-30.php | 3884 ++++ .../Resources/elasticache-2015-02-02.php | 4099 ++++ .../ElasticBeanstalkClient.php | 93 + .../Enum/ConfigurationDeploymentStatus.php | 29 + .../Enum/ConfigurationOptionValueType.php | 28 + .../Enum/EnvironmentHealth.php | 30 + .../Enum/EnvironmentInfoType.php | 27 + .../Enum/EnvironmentStatus.php | 31 + .../ElasticBeanstalk/Enum/EventSeverity.php | 32 + .../Enum/ValidationSeverity.php | 28 + .../Exception/ElasticBeanstalkException.php | 24 + .../InsufficientPrivilegesException.php | 22 + .../OperationInProgressException.php | 22 + .../S3LocationNotInServiceRegionException.php | 22 + .../S3SubscriptionRequiredException.php | 22 + .../SourceBundleDeletionException.php | 22 + .../TooManyApplicationVersionsException.php | 22 + .../TooManyApplicationsException.php | 22 + .../Exception/TooManyBucketsException.php | 22 + ...TooManyConfigurationTemplatesException.php | 22 + .../TooManyEnvironmentsException.php | 22 + .../Resources/elasticbeanstalk-2010-12-01.php | 2460 +++ .../ElasticLoadBalancingClient.php | 87 + .../AccessPointNotFoundException.php | 22 + .../CertificateNotFoundException.php | 22 + .../DuplicateAccessPointNameException.php | 22 + .../Exception/DuplicateListenerException.php | 22 + .../DuplicatePolicyNameException.php | 22 + .../ElasticLoadBalancingException.php | 24 + .../InvalidConfigurationRequestException.php | 22 + .../Exception/InvalidEndPointException.php | 22 + .../Exception/InvalidSchemeException.php | 22 + .../InvalidSecurityGroupException.php | 22 + .../Exception/InvalidSubnetException.php | 22 + .../Exception/ListenerNotFoundException.php | 22 + ...LoadBalancerAttributeNotFoundException.php | 22 + .../Exception/PolicyNotFoundException.php | 22 + .../Exception/PolicyTypeNotFoundException.php | 22 + .../Exception/SubnetNotFoundException.php | 22 + .../TooManyAccessPointsException.php | 22 + .../Exception/TooManyPoliciesException.php | 22 + .../elasticloadbalancing-2012-06-01.php | 2299 +++ .../ElasticTranscoderClient.php | 78 + .../Exception/AccessDeniedException.php | 22 + .../Exception/ElasticTranscoderException.php | 24 + .../IncompatibleVersionException.php | 22 + .../Exception/InternalServiceException.php | 22 + .../Exception/LimitExceededException.php | 22 + .../Exception/ResourceInUseException.php | 22 + .../Exception/ResourceNotFoundException.php | 22 + .../Exception/ValidationException.php | 22 + .../elastictranscoder-2012-09-25.php | 6047 ++++++ vendor/aws/Aws/Emr/EmrClient.php | 80 + vendor/aws/Aws/Emr/Enum/ActionOnFailure.php | 30 + vendor/aws/Aws/Emr/Enum/ClusterState.php | 33 + .../Emr/Enum/ClusterStateChangeReasonCode.php | 33 + .../aws/Aws/Emr/Enum/InstanceGroupState.php | 36 + .../InstanceGroupStateChangeReasonCode.php | 30 + vendor/aws/Aws/Emr/Enum/InstanceGroupType.php | 29 + vendor/aws/Aws/Emr/Enum/InstanceRoleType.php | 29 + vendor/aws/Aws/Emr/Enum/InstanceState.php | 31 + .../Enum/InstanceStateChangeReasonCode.php | 31 + .../Aws/Emr/Enum/JobFlowExecutionState.php | 34 + vendor/aws/Aws/Emr/Enum/MarketType.php | 28 + .../aws/Aws/Emr/Enum/StepExecutionState.php | 33 + vendor/aws/Aws/Emr/Enum/StepState.php | 32 + .../Emr/Enum/StepStateChangeReasonCode.php | 27 + vendor/aws/Aws/Emr/Exception/EmrException.php | 24 + .../InternalServerErrorException.php | 22 + .../Emr/Exception/InternalServerException.php | 22 + .../Emr/Exception/InvalidRequestException.php | 22 + .../aws/Aws/Emr/Resources/emr-2009-03-31.php | 2161 ++ vendor/aws/Aws/Glacier/Enum/Action.php | 29 + vendor/aws/Aws/Glacier/Enum/ActionCode.php | 28 + vendor/aws/Aws/Glacier/Enum/StatusCode.php | 29 + .../Glacier/Exception/GlacierException.php | 24 + .../InvalidParameterValueException.php | 22 + .../Exception/LimitExceededException.php | 22 + .../MissingParameterValueException.php | 22 + .../Exception/RequestTimeoutException.php | 22 + .../Exception/ResourceNotFoundException.php | 22 + .../Exception/ServiceUnavailableException.php | 22 + vendor/aws/Aws/Glacier/GlacierClient.php | 106 + .../aws/Aws/Glacier/GlacierUploadListener.php | 63 + .../MultipartUpload/AbstractTransfer.php | 105 + .../MultipartUpload/ParallelTransfer.php | 75 + .../Model/MultipartUpload/SerialTransfer.php | 52 + .../Model/MultipartUpload/TransferState.php | 79 + .../Model/MultipartUpload/UploadBuilder.php | 218 + .../Model/MultipartUpload/UploadId.php | 35 + .../Model/MultipartUpload/UploadPart.php | 110 + .../MultipartUpload/UploadPartContext.php | 138 + .../MultipartUpload/UploadPartGenerator.php | 279 + .../Glacier/Resources/glacier-2012-06-01.php | 1588 ++ .../aws/Aws/Iam/Enum/AssignmentStatusType.php | 29 + vendor/aws/Aws/Iam/Enum/StatusType.php | 28 + .../Iam/Exception/DeleteConflictException.php | 22 + .../DuplicateCertificateException.php | 22 + .../EntityAlreadyExistsException.php | 22 + ...EntityTemporarilyUnmodifiableException.php | 22 + vendor/aws/Aws/Iam/Exception/IamException.php | 24 + .../InvalidAuthenticationCodeException.php | 22 + .../Exception/InvalidCertificateException.php | 22 + .../Iam/Exception/InvalidInputException.php | 22 + .../Exception/InvalidUserTypeException.php | 22 + .../Exception/KeyPairMismatchException.php | 22 + .../Iam/Exception/LimitExceededException.php | 22 + .../MalformedCertificateException.php | 22 + .../MalformedPolicyDocumentException.php | 22 + .../Iam/Exception/NoSuchEntityException.php | 22 + .../PasswordPolicyViolationException.php | 22 + vendor/aws/Aws/Iam/IamClient.php | 176 + .../aws/Aws/Iam/Resources/iam-2010-05-08.php | 7301 +++++++ vendor/aws/Aws/ImportExport/Enum/JobType.php | 28 + .../Exception/BucketPermissionException.php | 22 + .../Exception/CanceledJobIdException.php | 22 + .../Exception/ExpiredJobIdException.php | 22 + .../Exception/ImportExportException.php | 24 + .../Exception/InvalidAccessKeyIdException.php | 22 + .../Exception/InvalidAddressException.php | 22 + .../Exception/InvalidCustomsException.php | 22 + .../Exception/InvalidFileSystemException.php | 22 + .../Exception/InvalidJobIdException.php | 22 + .../InvalidManifestFieldException.php | 22 + .../Exception/InvalidParameterException.php | 22 + .../Exception/MalformedManifestException.php | 22 + .../Exception/MissingCustomsException.php | 22 + .../MissingManifestFieldException.php | 22 + .../Exception/MissingParameterException.php | 22 + .../Exception/MultipleRegionsException.php | 22 + .../Exception/NoSuchBucketException.php | 22 + .../UnableToCancelJobIdException.php | 22 + .../Aws/ImportExport/ImportExportClient.php | 70 + .../Aws/ImportExport/JobManifestListener.php | 51 + .../Resources/importexport-2010-06-01.php | 774 + .../Aws/Kinesis/Enum/ShardIteratorType.php | 30 + vendor/aws/Aws/Kinesis/Enum/StreamStatus.php | 30 + .../Exception/ExpiredIteratorException.php | 22 + .../Exception/InvalidArgumentException.php | 22 + .../Kinesis/Exception/KinesisException.php | 24 + .../Exception/LimitExceededException.php | 22 + ...ProvisionedThroughputExceededException.php | 22 + .../Exception/ResourceInUseException.php | 22 + .../Exception/ResourceNotFoundException.php | 22 + vendor/aws/Aws/Kinesis/KinesisClient.php | 82 + .../Kinesis/Resources/kinesis-2013-12-02.php | 1015 + vendor/aws/Aws/Kms/Exception/KmsException.php | 10 + vendor/aws/Aws/Kms/KmsClient.php | 83 + .../aws/Aws/Kms/Resources/kms-2014-11-01.php | 1951 ++ .../Aws/Lambda/Exception/LambdaException.php | 10 + vendor/aws/Aws/Lambda/LambdaClient.php | 78 + .../Lambda/Resources/lambda-2014-11-11.php | 742 + .../Lambda/Resources/lambda-2015-03-31.php | 1057 + .../Exception/MachineLearningException.php | 10 + .../MachineLearning/MachineLearningClient.php | 74 + .../PredictEndpointListener.php | 35 + .../Resources/machinelearning-2014-12-12.php | 2548 +++ vendor/aws/Aws/OpsWorks/Enum/AppType.php | 31 + vendor/aws/Aws/OpsWorks/Enum/Architecture.php | 28 + .../aws/Aws/OpsWorks/Enum/AutoScalingType.php | 28 + .../OpsWorks/Enum/DeploymentCommandName.php | 36 + vendor/aws/Aws/OpsWorks/Enum/LayerType.php | 35 + .../aws/Aws/OpsWorks/Enum/PermissionLevel.php | 30 + .../aws/Aws/OpsWorks/Enum/RootDeviceType.php | 28 + vendor/aws/Aws/OpsWorks/Enum/SourceType.php | 30 + .../OpsWorks/Exception/OpsWorksException.php | 24 + .../Exception/ResourceNotFoundException.php | 22 + .../Exception/ValidationException.php | 22 + vendor/aws/Aws/OpsWorks/OpsWorksClient.php | 137 + .../Resources/opsworks-2013-02-18.php | 5495 ++++++ vendor/aws/Aws/Rds/Enum/ApplyMethod.php | 28 + vendor/aws/Aws/Rds/Enum/SourceType.php | 30 + .../AuthorizationAlreadyExistsException.php | 22 + .../AuthorizationNotFoundException.php | 22 + .../AuthorizationQuotaExceededException.php | 22 + .../DBInstanceAlreadyExistsException.php | 22 + .../Exception/DBInstanceNotFoundException.php | 22 + ...DBParameterGroupAlreadyExistsException.php | 22 + .../DBParameterGroupNotFoundException.php | 22 + ...DBParameterGroupQuotaExceededException.php | 22 + .../DBSecurityGroupAlreadyExistsException.php | 22 + .../DBSecurityGroupNotFoundException.php | 22 + .../DBSecurityGroupNotSupportedException.php | 22 + .../DBSecurityGroupQuotaExceededException.php | 22 + .../DBSnapshotAlreadyExistsException.php | 22 + .../Exception/DBSnapshotNotFoundException.php | 22 + .../DBSubnetGroupAlreadyExistsException.php | 22 + ...netGroupDoesNotCoverEnoughAZsException.php | 22 + .../DBSubnetGroupNotAllowedException.php | 22 + .../DBSubnetGroupNotFoundException.php | 22 + .../DBSubnetGroupQuotaExceededException.php | 22 + .../DBSubnetQuotaExceededException.php | 22 + .../DBUpgradeDependencyFailureException.php | 22 + ...ventSubscriptionQuotaExceededException.php | 22 + .../InstanceQuotaExceededException.php | 22 + ...nsufficientDBInstanceCapacityException.php | 22 + .../InvalidDBInstanceStateException.php | 22 + .../InvalidDBParameterGroupStateException.php | 22 + .../InvalidDBSecurityGroupStateException.php | 22 + .../InvalidDBSnapshotStateException.php | 22 + .../InvalidDBSubnetGroupException.php | 22 + .../InvalidDBSubnetGroupStateException.php | 22 + .../InvalidDBSubnetStateException.php | 22 + ...InvalidEventSubscriptionStateException.php | 22 + .../InvalidOptionGroupStateException.php | 22 + .../Rds/Exception/InvalidRestoreException.php | 22 + .../Rds/Exception/InvalidSubnetException.php | 22 + .../InvalidVPCNetworkStateException.php | 22 + .../OptionGroupAlreadyExistsException.php | 22 + .../OptionGroupNotFoundException.php | 22 + .../OptionGroupQuotaExceededException.php | 22 + .../PointInTimeRestoreNotEnabledException.php | 22 + ...ovisionedIopsNotAvailableInAZException.php | 22 + vendor/aws/Aws/Rds/Exception/RdsException.php | 24 + ...servedDBInstanceAlreadyExistsException.php | 22 + .../ReservedDBInstanceNotFoundException.php | 22 + ...servedDBInstanceQuotaExceededException.php | 22 + ...edDBInstancesOfferingNotFoundException.php | 22 + .../Exception/SNSInvalidTopicException.php | 22 + .../Exception/SNSNoAuthorizationException.php | 22 + .../SNSTopicArnNotFoundException.php | 22 + .../SnapshotQuotaExceededException.php | 22 + .../Rds/Exception/SourceNotFoundException.php | 22 + .../StorageQuotaExceededException.php | 22 + .../Exception/SubnetAlreadyInUseException.php | 22 + .../SubscriptionAlreadyExistException.php | 22 + .../SubscriptionCategoryNotFoundException.php | 22 + .../SubscriptionNotFoundException.php | 22 + vendor/aws/Aws/Rds/RdsClient.php | 132 + .../aws/Aws/Rds/Resources/rds-2013-09-09.php | 5676 ++++++ .../aws/Aws/Rds/Resources/rds-2014-09-01.php | 6155 ++++++ .../aws/Aws/Rds/Resources/rds-2014-10-31.php | 6479 ++++++ vendor/aws/Aws/Redshift/Enum/SourceType.php | 30 + .../AccessToSnapshotDeniedException.php | 22 + .../AuthorizationAlreadyExistsException.php | 22 + .../AuthorizationNotFoundException.php | 22 + .../AuthorizationQuotaExceededException.php | 22 + .../Exception/BucketNotFoundException.php | 22 + .../ClusterAlreadyExistsException.php | 22 + .../Exception/ClusterNotFoundException.php | 22 + ...erParameterGroupAlreadyExistsException.php | 22 + ...ClusterParameterGroupNotFoundException.php | 22 + ...erParameterGroupQuotaExceededException.php | 22 + .../ClusterQuotaExceededException.php | 22 + ...terSecurityGroupAlreadyExistsException.php | 22 + .../ClusterSecurityGroupNotFoundException.php | 22 + ...terSecurityGroupQuotaExceededException.php | 22 + .../ClusterSnapshotAlreadyExistsException.php | 22 + .../ClusterSnapshotNotFoundException.php | 22 + .../ClusterSnapshotQuotaExceededException.php | 22 + ...usterSubnetGroupAlreadyExistsException.php | 22 + .../ClusterSubnetGroupNotFoundException.php | 22 + ...usterSubnetGroupQuotaExceededException.php | 22 + .../ClusterSubnetQuotaExceededException.php | 22 + .../CopyToRegionDisabledException.php | 22 + ...ventSubscriptionQuotaExceededException.php | 22 + ...lientCertificateAlreadyExistsException.php | 22 + .../HsmClientCertificateNotFoundException.php | 22 + ...lientCertificateQuotaExceededException.php | 22 + ...HsmConfigurationAlreadyExistsException.php | 22 + .../HsmConfigurationNotFoundException.php | 22 + ...HsmConfigurationQuotaExceededException.php | 22 + .../IncompatibleOrderableOptionsException.php | 22 + .../InsufficientClusterCapacityException.php | 22 + ...sufficientS3BucketPolicyFaultException.php | 22 + ...lidClusterParameterGroupStateException.php | 22 + ...alidClusterSecurityGroupStateException.php | 22 + .../InvalidClusterSnapshotStateException.php | 22 + .../InvalidClusterStateException.php | 22 + ...nvalidClusterSubnetGroupStateException.php | 22 + .../InvalidClusterSubnetStateException.php | 22 + .../Exception/InvalidElasticIpException.php | 22 + ...alidHsmClientCertificateStateException.php | 22 + .../InvalidHsmConfigurationStateException.php | 22 + .../Exception/InvalidRestoreException.php | 22 + .../InvalidS3BucketNameFaultException.php | 22 + .../InvalidS3KeyPrefixFaultException.php | 22 + .../Exception/InvalidSubnetException.php | 22 + .../InvalidVPCNetworkStateException.php | 22 + ...fNodesPerClusterLimitExceededException.php | 22 + .../NumberOfNodesQuotaExceededException.php | 22 + .../Redshift/Exception/RedshiftException.php | 24 + .../ReservedNodeAlreadyExistsException.php | 22 + .../ReservedNodeNotFoundException.php | 22 + .../ReservedNodeOfferingNotFoundException.php | 22 + .../ReservedNodeQuotaExceededException.php | 22 + .../Exception/ResizeNotFoundException.php | 22 + .../Exception/SNSInvalidTopicException.php | 22 + .../Exception/SNSNoAuthorizationException.php | 22 + .../SNSTopicArnNotFoundException.php | 22 + .../SnapshotCopyAlreadyDisabledException.php | 22 + .../SnapshotCopyAlreadyEnabledException.php | 22 + .../SnapshotCopyDisabledException.php | 22 + .../Exception/SourceNotFoundException.php | 22 + .../Exception/SubnetAlreadyInUseException.php | 22 + .../SubscriptionAlreadyExistException.php | 22 + .../SubscriptionCategoryNotFoundException.php | 22 + .../SubscriptionEventIdNotFoundException.php | 22 + .../SubscriptionNotFoundException.php | 22 + .../SubscriptionSeverityNotFoundException.php | 22 + .../UnauthorizedOperationException.php | 22 + .../UnknownSnapshotCopyRegionException.php | 22 + .../Exception/UnsupportedOptionException.php | 22 + vendor/aws/Aws/Redshift/RedshiftClient.php | 129 + .../Resources/redshift-2012-12-01.php | 5593 ++++++ vendor/aws/Aws/Route53/Enum/Action.php | 29 + .../aws/Aws/Route53/Enum/HealthCheckType.php | 31 + vendor/aws/Aws/Route53/Enum/RecordType.php | 36 + .../Enum/ResourceRecordSetFailover.php | 28 + vendor/aws/Aws/Route53/Enum/Status.php | 28 + .../DelegationSetNotAvailableException.php | 22 + .../HealthCheckAlreadyExistsException.php | 22 + .../Exception/HealthCheckInUseException.php | 22 + .../HostedZoneAlreadyExistsException.php | 22 + .../Exception/HostedZoneNotEmptyException.php | 22 + .../IncompatibleVersionException.php | 22 + .../Exception/InvalidChangeBatchException.php | 22 + .../Exception/InvalidDomainNameException.php | 22 + .../Exception/InvalidInputException.php | 22 + .../Exception/NoSuchChangeException.php | 22 + .../Exception/NoSuchHealthCheckException.php | 22 + .../Exception/NoSuchHostedZoneException.php | 22 + .../PriorRequestNotCompleteException.php | 22 + .../Route53/Exception/Route53Exception.php | 24 + .../TooManyHealthChecksException.php | 22 + .../Exception/TooManyHostedZonesException.php | 22 + .../Route53/Resources/route53-2013-04-01.php | 2833 +++ vendor/aws/Aws/Route53/Route53Client.php | 124 + .../Exception/Route53DomainsException.php | 10 + .../Resources/route53domains-2014-05-15.php | 2130 ++ .../Route53Domains/Route53DomainsClient.php | 48 + vendor/aws/Aws/S3/AcpListener.php | 75 + vendor/aws/Aws/S3/BucketStyleListener.php | 89 + vendor/aws/Aws/S3/Command/S3Command.php | 65 + vendor/aws/Aws/S3/Enum/CannedAcl.php | 32 + vendor/aws/Aws/S3/Enum/EncodingType.php | 27 + vendor/aws/Aws/S3/Enum/Event.php | 27 + vendor/aws/Aws/S3/Enum/GranteeType.php | 29 + vendor/aws/Aws/S3/Enum/Group.php | 29 + vendor/aws/Aws/S3/Enum/MFADelete.php | 28 + vendor/aws/Aws/S3/Enum/MetadataDirective.php | 28 + vendor/aws/Aws/S3/Enum/Payer.php | 28 + vendor/aws/Aws/S3/Enum/Permission.php | 31 + vendor/aws/Aws/S3/Enum/Protocol.php | 28 + .../aws/Aws/S3/Enum/ServerSideEncryption.php | 27 + vendor/aws/Aws/S3/Enum/Status.php | 28 + vendor/aws/Aws/S3/Enum/Storage.php | 29 + vendor/aws/Aws/S3/Enum/StorageClass.php | 28 + .../S3/Exception/AccessDeniedException.php | 22 + .../S3/Exception/AccountProblemException.php | 22 + .../AmbiguousGrantByEmailAddressException.php | 22 + .../Aws/S3/Exception/BadDigestException.php | 22 + .../BucketAlreadyExistsException.php | 22 + .../BucketAlreadyOwnedByYouException.php | 22 + .../S3/Exception/BucketNotEmptyException.php | 22 + .../CredentialsNotSupportedException.php | 22 + ...rossLocationLoggingProhibitedException.php | 22 + .../DeleteMultipleObjectsException.php | 48 + .../S3/Exception/EntityTooLargeException.php | 22 + .../S3/Exception/EntityTooSmallException.php | 22 + .../S3/Exception/ExpiredTokenException.php | 22 + ...llegalVersioningConfigurationException.php | 22 + .../S3/Exception/IncompleteBodyException.php | 22 + ...ectNumberOfFilesInPostRequestException.php | 22 + .../Exception/InlineDataTooLargeException.php | 22 + .../S3/Exception/InternalErrorException.php | 22 + .../Exception/InvalidAccessKeyIdException.php | 22 + .../InvalidAddressingHeaderException.php | 22 + .../S3/Exception/InvalidArgumentException.php | 22 + .../Exception/InvalidBucketNameException.php | 22 + .../Exception/InvalidBucketStateException.php | 22 + .../S3/Exception/InvalidDigestException.php | 22 + .../InvalidLocationConstraintException.php | 22 + .../Aws/S3/Exception/InvalidPartException.php | 22 + .../Exception/InvalidPartOrderException.php | 22 + .../S3/Exception/InvalidPayerException.php | 22 + .../InvalidPolicyDocumentException.php | 22 + .../S3/Exception/InvalidRangeException.php | 22 + .../S3/Exception/InvalidRequestException.php | 22 + .../Exception/InvalidSOAPRequestException.php | 22 + .../S3/Exception/InvalidSecurityException.php | 22 + .../InvalidStorageClassException.php | 22 + .../S3/Exception/InvalidTagErrorException.php | 23 + ...InvalidTargetBucketForLoggingException.php | 22 + .../S3/Exception/InvalidTokenException.php | 22 + .../Aws/S3/Exception/InvalidURIException.php | 22 + .../Aws/S3/Exception/KeyTooLongException.php | 22 + .../Exception/MalformedACLErrorException.php | 22 + .../MalformedPOSTRequestException.php | 22 + .../S3/Exception/MalformedXMLException.php | 22 + .../MaxMessageLengthExceededException.php | 22 + ...ostPreDataLengthExceededErrorException.php | 22 + .../Exception/MetadataTooLargeException.php | 22 + .../Exception/MethodNotAllowedException.php | 22 + .../Exception/MissingAttachmentException.php | 22 + .../MissingContentLengthException.php | 22 + .../MissingRequestBodyErrorException.php | 22 + .../MissingSecurityElementException.php | 22 + .../MissingSecurityHeaderException.php | 22 + .../NoLoggingStatusForKeyException.php | 22 + .../S3/Exception/NoSuchBucketException.php | 22 + .../Exception/NoSuchBucketPolicyException.php | 22 + .../NoSuchCORSConfigurationException.php | 22 + .../Aws/S3/Exception/NoSuchKeyException.php | 22 + .../NoSuchLifecycleConfigurationException.php | 22 + .../Exception/NoSuchTagSetErrorException.php | 22 + .../S3/Exception/NoSuchUploadException.php | 22 + .../S3/Exception/NoSuchVersionException.php | 22 + .../NoSuchWebsiteConfigurationException.php | 22 + .../S3/Exception/NotImplementedException.php | 22 + .../Aws/S3/Exception/NotSignedUpException.php | 22 + .../NotSuchBucketPolicyException.php | 22 + ...bjectAlreadyInActiveTierErrorException.php | 22 + .../ObjectNotInActiveTierErrorException.php | 22 + .../Exception/OperationAbortedException.php | 22 + .../S3/Exception/Parser/S3ExceptionParser.php | 72 + .../Exception/PermanentRedirectException.php | 22 + .../Exception/PreconditionFailedException.php | 22 + .../Aws/S3/Exception/RedirectException.php | 22 + .../RequestIsNotMultiPartContentException.php | 22 + .../RequestTimeTooSkewedException.php | 22 + .../S3/Exception/RequestTimeoutException.php | 22 + .../RequestTorrentOfBucketErrorException.php | 22 + vendor/aws/Aws/S3/Exception/S3Exception.php | 24 + .../Exception/ServiceUnavailableException.php | 22 + .../SignatureDoesNotMatchException.php | 22 + .../Aws/S3/Exception/SlowDownException.php | 22 + .../Exception/TemporaryRedirectException.php | 22 + .../TokenRefreshRequiredException.php | 22 + .../S3/Exception/TooManyBucketsException.php | 22 + .../Exception/UnexpectedContentException.php | 22 + ...resolvableGrantByEmailAddressException.php | 22 + .../UserKeyMustBeSpecifiedException.php | 22 + .../Aws/S3/Iterator/ListBucketsIterator.php | 48 + .../Iterator/ListMultipartUploadsIterator.php | 46 + .../Iterator/ListObjectVersionsIterator.php | 48 + .../Aws/S3/Iterator/ListObjectsIterator.php | 68 + .../aws/Aws/S3/Iterator/OpendirIterator.php | 86 + vendor/aws/Aws/S3/Model/Acp.php | 243 + vendor/aws/Aws/S3/Model/AcpBuilder.php | 134 + vendor/aws/Aws/S3/Model/ClearBucket.php | 189 + .../aws/Aws/S3/Model/DeleteObjectsBatch.php | 87 + .../Aws/S3/Model/DeleteObjectsTransfer.php | 133 + vendor/aws/Aws/S3/Model/Grant.php | 139 + vendor/aws/Aws/S3/Model/Grantee.php | 245 + .../MultipartUpload/AbstractTransfer.php | 103 + .../MultipartUpload/ParallelTransfer.php | 124 + .../Model/MultipartUpload/SerialTransfer.php | 86 + .../Model/MultipartUpload/TransferState.php | 41 + .../Model/MultipartUpload/UploadBuilder.php | 297 + .../Aws/S3/Model/MultipartUpload/UploadId.php | 35 + .../S3/Model/MultipartUpload/UploadPart.php | 74 + vendor/aws/Aws/S3/Model/PostObject.php | 275 + vendor/aws/Aws/S3/Resources/s3-2006-03-01.php | 5287 +++++ vendor/aws/Aws/S3/ResumableDownload.php | 176 + vendor/aws/Aws/S3/S3Client.php | 685 + vendor/aws/Aws/S3/S3Md5Listener.php | 73 + vendor/aws/Aws/S3/S3Signature.php | 266 + vendor/aws/Aws/S3/S3SignatureInterface.php | 24 + vendor/aws/Aws/S3/S3SignatureV4.php | 60 + vendor/aws/Aws/S3/SocketTimeoutChecker.php | 71 + vendor/aws/Aws/S3/SseCpkListener.php | 68 + vendor/aws/Aws/S3/StreamWrapper.php | 892 + vendor/aws/Aws/S3/Sync/AbstractSync.php | 127 + .../aws/Aws/S3/Sync/AbstractSyncBuilder.php | 435 + .../aws/Aws/S3/Sync/ChangedFilesIterator.php | 130 + vendor/aws/Aws/S3/Sync/DownloadSync.php | 95 + .../aws/Aws/S3/Sync/DownloadSyncBuilder.php | 129 + .../S3/Sync/FilenameConverterInterface.php | 32 + vendor/aws/Aws/S3/Sync/KeyConverter.php | 67 + vendor/aws/Aws/S3/Sync/UploadSync.php | 86 + vendor/aws/Aws/S3/Sync/UploadSyncBuilder.php | 190 + vendor/aws/Aws/Ses/Enum/IdentityType.php | 28 + vendor/aws/Aws/Ses/Enum/MailboxSimulator.php | 32 + vendor/aws/Aws/Ses/Enum/NotificationType.php | 28 + .../aws/Aws/Ses/Enum/VerificationStatus.php | 31 + .../Exception/MessageRejectedException.php | 22 + vendor/aws/Aws/Ses/Exception/SesException.php | 24 + .../aws/Aws/Ses/Resources/ses-2010-12-01.php | 937 + vendor/aws/Aws/Ses/SesClient.php | 77 + .../AttributeDoesNotExistException.php | 22 + .../Exception/DuplicateItemNameException.php | 22 + .../Exception/InvalidNextTokenException.php | 22 + .../InvalidNumberPredicatesException.php | 22 + .../InvalidNumberValueTestsException.php | 22 + .../InvalidParameterValueException.php | 22 + .../InvalidQueryExpressionException.php | 22 + .../Exception/MissingParameterException.php | 22 + .../Exception/NoSuchDomainException.php | 22 + ...umberDomainAttributesExceededException.php | 22 + .../NumberDomainBytesExceededException.php | 22 + .../NumberDomainsExceededException.php | 22 + .../NumberItemAttributesExceededException.php | 22 + ...erSubmittedAttributesExceededException.php | 22 + .../NumberSubmittedItemsExceededException.php | 22 + .../Exception/RequestTimeoutException.php | 22 + .../SimpleDb/Exception/SimpleDbException.php | 24 + .../TooManyRequestedAttributesException.php | 22 + .../Resources/simpledb-2009-04-15.php | 854 + vendor/aws/Aws/SimpleDb/SimpleDbClient.php | 67 + .../Exception/AuthorizationErrorException.php | 22 + .../Exception/EndpointDisabledException.php | 22 + .../Sns/Exception/InternalErrorException.php | 22 + .../Exception/InvalidParameterException.php | 22 + .../Aws/Sns/Exception/NotFoundException.php | 22 + .../PlatformApplicationDisabledException.php | 22 + vendor/aws/Aws/Sns/Exception/SnsException.php | 24 + .../SubscriptionLimitExceededException.php | 22 + .../Exception/TopicLimitExceededException.php | 22 + ...otGetPublicKeyFromCertificateException.php | 24 + ...ificateFromUnrecognizedSourceException.php | 24 + .../InvalidMessageSignatureException.php | 24 + .../SnsMessageValidatorException.php | 24 + .../aws/Aws/Sns/MessageValidator/Message.php | 150 + .../Sns/MessageValidator/MessageValidator.php | 114 + .../aws/Aws/Sns/Resources/sns-2010-03-31.php | 1740 ++ vendor/aws/Aws/Sns/SnsClient.php | 85 + vendor/aws/Aws/Sqs/Enum/MessageAttribute.php | 31 + vendor/aws/Aws/Sqs/Enum/QueueAttribute.php | 40 + vendor/aws/Aws/Sqs/Exception/SqsException.php | 24 + vendor/aws/Aws/Sqs/Md5ValidatorListener.php | 54 + vendor/aws/Aws/Sqs/QueueUrlListener.php | 52 + .../aws/Aws/Sqs/Resources/sqs-2012-11-05.php | 1370 ++ vendor/aws/Aws/Sqs/SqsClient.php | 96 + vendor/aws/Aws/Ssm/Exception/SsmException.php | 24 + .../aws/Aws/Ssm/Resources/ssm-2014-11-06.php | 973 + vendor/aws/Aws/Ssm/SsmClient.php | 69 + .../Aws/StorageGateway/Enum/BandwidthType.php | 29 + .../Enum/DiskAllocationType.php | 31 + .../aws/Aws/StorageGateway/Enum/ErrorCode.php | 87 + .../Aws/StorageGateway/Enum/GatewayState.php | 28 + .../StorageGateway/Enum/GatewayTimezone.php | 57 + .../Aws/StorageGateway/Enum/GatewayType.php | 28 + .../Aws/StorageGateway/Enum/VolumeStatus.php | 36 + .../Aws/StorageGateway/Enum/VolumeType.php | 28 + .../InternalServerErrorException.php | 22 + .../InvalidGatewayRequestException.php | 22 + .../Exception/StorageGatewayException.php | 24 + .../Resources/storagegateway-2013-06-30.php | 3479 ++++ .../StorageGateway/StorageGatewayClient.php | 116 + .../Sts/Exception/ExpiredTokenException.php | 22 + .../IDPCommunicationErrorException.php | 22 + .../Exception/IDPRejectedClaimException.php | 22 + .../IncompleteSignatureException.php | 22 + .../Exception/InternalFailureException.php | 22 + .../Sts/Exception/InvalidActionException.php | 22 + .../InvalidAuthorizationMessageException.php | 22 + .../InvalidClientTokenIdException.php | 22 + .../InvalidIdentityTokenException.php | 22 + .../InvalidParameterCombinationException.php | 22 + .../InvalidParameterValueException.php | 22 + .../InvalidQueryParameterException.php | 22 + .../MalformedPolicyDocumentException.php | 22 + .../MalformedQueryStringException.php | 22 + .../Sts/Exception/MissingActionException.php | 22 + .../MissingAuthenticationTokenException.php | 22 + .../Exception/MissingParameterException.php | 22 + .../Sts/Exception/OptInRequiredException.php | 22 + .../PackedPolicyTooLargeException.php | 22 + .../Sts/Exception/RequestExpiredException.php | 23 + .../Exception/ServiceUnavailableException.php | 22 + vendor/aws/Aws/Sts/Exception/StsException.php | 24 + .../Aws/Sts/Exception/ThrottlingException.php | 22 + .../aws/Aws/Sts/Resources/sts-2011-06-15.php | 657 + vendor/aws/Aws/Sts/StsClient.php | 115 + .../CaseCreationLimitExceededException.php | 22 + .../Exception/CaseIdNotFoundException.php | 22 + .../InternalServerErrorException.php | 22 + .../Support/Exception/SupportException.php | 24 + .../Support/Resources/support-2013-04-15.php | 1256 ++ vendor/aws/Aws/Support/SupportClient.php | 78 + .../Aws/Swf/Enum/ActivityTaskTimeoutType.php | 30 + vendor/aws/Aws/Swf/Enum/ChildPolicy.php | 29 + vendor/aws/Aws/Swf/Enum/CloseStatus.php | 32 + .../Aws/Swf/Enum/DecisionTaskTimeoutType.php | 27 + vendor/aws/Aws/Swf/Enum/DecisionType.php | 38 + vendor/aws/Aws/Swf/Enum/EventType.php | 73 + vendor/aws/Aws/Swf/Enum/ExecutionStatus.php | 28 + .../aws/Aws/Swf/Enum/RegistrationStatus.php | 28 + .../Swf/Enum/WorkflowExecutionTimeoutType.php | 27 + .../Exception/DefaultUndefinedException.php | 22 + .../DomainAlreadyExistsException.php | 22 + .../Exception/DomainDeprecatedException.php | 22 + .../Swf/Exception/LimitExceededException.php | 22 + .../OperationNotPermittedException.php | 22 + vendor/aws/Aws/Swf/Exception/SwfException.php | 24 + .../Exception/TypeAlreadyExistsException.php | 22 + .../Swf/Exception/TypeDeprecatedException.php | 22 + .../Exception/UnknownResourceException.php | 22 + ...rkflowExecutionAlreadyStartedException.php | 22 + .../aws/Aws/Swf/Resources/swf-2012-01-25.php | 5367 +++++ vendor/aws/Aws/Swf/SwfClient.php | 95 + .../Exception/WorkSpacesException.php | 10 + .../Resources/workspaces-2015-04-08.php | 679 + .../aws/Aws/WorkSpaces/WorkSpacesClient.php | 51 + vendor/aws/CHANGELOG.md | 896 + vendor/aws/Doctrine/Common/Cache/ApcCache.php | 106 + .../aws/Doctrine/Common/Cache/ArrayCache.php | 94 + vendor/aws/Doctrine/Common/Cache/Cache.php | 112 + .../Doctrine/Common/Cache/CacheProvider.php | 277 + .../aws/Doctrine/Common/Cache/ChainCache.php | 147 + .../Doctrine/Common/Cache/ClearableCache.php | 37 + .../Doctrine/Common/Cache/CouchbaseCache.php | 121 + .../aws/Doctrine/Common/Cache/FileCache.php | 223 + .../Doctrine/Common/Cache/FilesystemCache.php | 111 + .../Doctrine/Common/Cache/FlushableCache.php | 37 + .../Doctrine/Common/Cache/MemcacheCache.php | 121 + .../Doctrine/Common/Cache/MemcachedCache.php | 132 + .../Doctrine/Common/Cache/MongoDBCache.php | 191 + .../Doctrine/Common/Cache/MultiGetCache.php | 39 + .../Doctrine/Common/Cache/PhpFileCache.php | 109 + .../aws/Doctrine/Common/Cache/PredisCache.php | 97 + .../aws/Doctrine/Common/Cache/RedisCache.php | 134 + .../aws/Doctrine/Common/Cache/RiakCache.php | 250 + .../Doctrine/Common/Cache/SQLite3Cache.php | 219 + vendor/aws/Doctrine/Common/Cache/Version.php | 25 + .../Doctrine/Common/Cache/WinCacheCache.php | 91 + .../aws/Doctrine/Common/Cache/XcacheCache.php | 112 + .../Doctrine/Common/Cache/ZendDataCache.php | 83 + .../Guzzle/Batch/AbstractBatchDecorator.php | 66 + vendor/aws/Guzzle/Batch/Batch.php | 92 + vendor/aws/Guzzle/Batch/BatchBuilder.php | 199 + .../aws/Guzzle/Batch/BatchClosureDivisor.php | 39 + .../aws/Guzzle/Batch/BatchClosureTransfer.php | 40 + .../aws/Guzzle/Batch/BatchCommandTransfer.php | 75 + .../Guzzle/Batch/BatchDivisorInterface.php | 18 + vendor/aws/Guzzle/Batch/BatchInterface.php | 32 + .../aws/Guzzle/Batch/BatchRequestTransfer.php | 65 + vendor/aws/Guzzle/Batch/BatchSizeDivisor.php | 47 + .../Guzzle/Batch/BatchTransferInterface.php | 16 + .../Exception/BatchTransferException.php | 90 + .../Guzzle/Batch/ExceptionBufferingBatch.php | 50 + vendor/aws/Guzzle/Batch/FlushingBatch.php | 60 + vendor/aws/Guzzle/Batch/HistoryBatch.php | 39 + vendor/aws/Guzzle/Batch/NotifyingBatch.php | 38 + .../aws/Guzzle/Cache/AbstractCacheAdapter.php | 21 + .../aws/Guzzle/Cache/CacheAdapterFactory.php | 117 + .../Guzzle/Cache/CacheAdapterInterface.php | 55 + .../aws/Guzzle/Cache/ClosureCacheAdapter.php | 57 + .../aws/Guzzle/Cache/DoctrineCacheAdapter.php | 41 + vendor/aws/Guzzle/Cache/NullCacheAdapter.php | 31 + vendor/aws/Guzzle/Cache/Zf1CacheAdapter.php | 44 + vendor/aws/Guzzle/Cache/Zf2CacheAdapter.php | 41 + .../Guzzle/Common/AbstractHasDispatcher.php | 49 + vendor/aws/Guzzle/Common/Collection.php | 403 + vendor/aws/Guzzle/Common/Event.php | 52 + .../Exception/BadMethodCallException.php | 5 + .../Common/Exception/ExceptionCollection.php | 108 + .../Common/Exception/GuzzleException.php | 8 + .../Exception/InvalidArgumentException.php | 5 + .../Common/Exception/RuntimeException.php | 5 + .../Exception/UnexpectedValueException.php | 5 + .../aws/Guzzle/Common/FromConfigInterface.php | 18 + .../Guzzle/Common/HasDispatcherInterface.php | 54 + vendor/aws/Guzzle/Common/ToArrayInterface.php | 16 + vendor/aws/Guzzle/Common/Version.php | 29 + .../Http/AbstractEntityBodyDecorator.php | 221 + vendor/aws/Guzzle/Http/CachingEntityBody.php | 229 + vendor/aws/Guzzle/Http/Client.php | 524 + vendor/aws/Guzzle/Http/ClientInterface.php | 223 + vendor/aws/Guzzle/Http/Curl/CurlHandle.php | 464 + vendor/aws/Guzzle/Http/Curl/CurlMulti.php | 423 + .../Guzzle/Http/Curl/CurlMultiInterface.php | 58 + .../aws/Guzzle/Http/Curl/CurlMultiProxy.php | 150 + vendor/aws/Guzzle/Http/Curl/CurlVersion.php | 66 + .../aws/Guzzle/Http/Curl/RequestMediator.php | 147 + vendor/aws/Guzzle/Http/EntityBody.php | 201 + .../aws/Guzzle/Http/EntityBodyInterface.php | 73 + .../Http/Exception/BadResponseException.php | 69 + .../ClientErrorResponseException.php | 8 + .../CouldNotRewindStreamException.php | 7 + .../Guzzle/Http/Exception/CurlException.php | 101 + .../Guzzle/Http/Exception/HttpException.php | 10 + .../Http/Exception/MultiTransferException.php | 145 + .../Http/Exception/RequestException.php | 39 + .../ServerErrorResponseException.php | 8 + .../Exception/TooManyRedirectsException.php | 5 + .../aws/Guzzle/Http/IoEmittingEntityBody.php | 83 + .../Guzzle/Http/Message/AbstractMessage.php | 220 + .../Http/Message/EntityEnclosingRequest.php | 247 + .../EntityEnclosingRequestInterface.php | 137 + vendor/aws/Guzzle/Http/Message/Header.php | 182 + .../Http/Message/Header/CacheControl.php | 121 + .../Http/Message/Header/HeaderCollection.php | 108 + .../Http/Message/Header/HeaderFactory.php | 26 + .../Message/Header/HeaderFactoryInterface.php | 19 + .../Http/Message/Header/HeaderInterface.php | 83 + .../aws/Guzzle/Http/Message/Header/Link.php | 93 + .../Guzzle/Http/Message/MessageInterface.php | 102 + vendor/aws/Guzzle/Http/Message/PostFile.php | 124 + .../Guzzle/Http/Message/PostFileInterface.php | 83 + vendor/aws/Guzzle/Http/Message/Request.php | 638 + .../Guzzle/Http/Message/RequestFactory.php | 359 + .../Http/Message/RequestFactoryInterface.php | 105 + .../Guzzle/Http/Message/RequestInterface.php | 318 + vendor/aws/Guzzle/Http/Message/Response.php | 968 + vendor/aws/Guzzle/Http/Mimetypes.php | 962 + .../Http/QueryAggregator/CommaAggregator.php | 20 + .../QueryAggregator/DuplicateAggregator.php | 22 + .../Http/QueryAggregator/PhpAggregator.php | 27 + .../QueryAggregatorInterface.php | 22 + vendor/aws/Guzzle/Http/QueryString.php | 297 + .../aws/Guzzle/Http/ReadLimitEntityBody.php | 122 + vendor/aws/Guzzle/Http/RedirectPlugin.php | 250 + vendor/aws/Guzzle/Http/Resources/cacert.pem | 3870 ++++ vendor/aws/Guzzle/Http/StaticClient.php | 157 + vendor/aws/Guzzle/Http/Url.php | 554 + vendor/aws/Guzzle/Inflection/Inflector.php | 38 + .../Guzzle/Inflection/InflectorInterface.php | 27 + .../Guzzle/Inflection/MemoizingInflector.php | 70 + .../Inflection/PreComputedInflector.php | 59 + vendor/aws/Guzzle/Iterator/AppendIterator.php | 19 + .../aws/Guzzle/Iterator/ChunkedIterator.php | 56 + vendor/aws/Guzzle/Iterator/FilterIterator.php | 36 + vendor/aws/Guzzle/Iterator/MapIterator.php | 34 + .../Guzzle/Iterator/MethodProxyIterator.php | 27 + vendor/aws/Guzzle/Log/AbstractLogAdapter.php | 16 + vendor/aws/Guzzle/Log/ArrayLogAdapter.php | 34 + vendor/aws/Guzzle/Log/ClosureLogAdapter.php | 23 + vendor/aws/Guzzle/Log/LogAdapterInterface.php | 18 + vendor/aws/Guzzle/Log/MessageFormatter.php | 179 + vendor/aws/Guzzle/Log/MonologLogAdapter.php | 34 + vendor/aws/Guzzle/Log/PsrLogAdapter.php | 36 + vendor/aws/Guzzle/Log/Zf1LogAdapter.php | 24 + vendor/aws/Guzzle/Log/Zf2LogAdapter.php | 21 + .../aws/Guzzle/Parser/Cookie/CookieParser.php | 131 + .../Parser/Cookie/CookieParserInterface.php | 33 + .../Parser/Message/AbstractMessageParser.php | 58 + .../Guzzle/Parser/Message/MessageParser.php | 110 + .../Parser/Message/MessageParserInterface.php | 27 + .../Parser/Message/PeclHttpMessageParser.php | 48 + vendor/aws/Guzzle/Parser/ParserRegistry.php | 75 + .../Parser/UriTemplate/PeclUriTemplate.php | 26 + .../Guzzle/Parser/UriTemplate/UriTemplate.php | 254 + .../UriTemplate/UriTemplateInterface.php | 21 + vendor/aws/Guzzle/Parser/Url/UrlParser.php | 48 + .../Guzzle/Parser/Url/UrlParserInterface.php | 19 + .../aws/Guzzle/Plugin/Async/AsyncPlugin.php | 84 + .../Backoff/AbstractBackoffStrategy.php | 91 + .../AbstractErrorCodeBackoffStrategy.php | 40 + .../Guzzle/Plugin/Backoff/BackoffLogger.php | 76 + .../Guzzle/Plugin/Backoff/BackoffPlugin.php | 126 + .../Backoff/BackoffStrategyInterface.php | 30 + .../Backoff/CallbackBackoffStrategy.php | 47 + .../Backoff/ConstantBackoffStrategy.php | 34 + .../Plugin/Backoff/CurlBackoffStrategy.php | 28 + .../Backoff/ExponentialBackoffStrategy.php | 25 + .../Plugin/Backoff/HttpBackoffStrategy.php | 30 + .../Plugin/Backoff/LinearBackoffStrategy.php | 36 + .../Backoff/ReasonPhraseBackoffStrategy.php | 25 + .../Backoff/TruncatedBackoffStrategy.php | 36 + .../Cache/CacheKeyProviderInterface.php | 11 + .../aws/Guzzle/Plugin/Cache/CachePlugin.php | 353 + .../Plugin/Cache/CacheStorageInterface.php | 43 + .../Plugin/Cache/CallbackCanCacheStrategy.php | 53 + .../Cache/CanCacheStrategyInterface.php | 30 + .../Plugin/Cache/DefaultCacheKeyProvider.php | 46 + .../Plugin/Cache/DefaultCacheStorage.php | 266 + .../Plugin/Cache/DefaultCanCacheStrategy.php | 32 + .../Plugin/Cache/DefaultRevalidation.php | 174 + .../Guzzle/Plugin/Cache/DenyRevalidation.php | 19 + .../Plugin/Cache/RevalidationInterface.php | 32 + .../Guzzle/Plugin/Cache/SkipRevalidation.php | 19 + vendor/aws/Guzzle/Plugin/Cookie/Cookie.php | 538 + .../Cookie/CookieJar/ArrayCookieJar.php | 237 + .../Cookie/CookieJar/CookieJarInterface.php | 85 + .../Plugin/Cookie/CookieJar/FileCookieJar.php | 65 + .../aws/Guzzle/Plugin/Cookie/CookiePlugin.php | 70 + .../Exception/InvalidCookieException.php | 7 + .../Guzzle/Plugin/CurlAuth/CurlAuthPlugin.php | 46 + .../ErrorResponseExceptionInterface.php | 22 + .../ErrorResponse/ErrorResponsePlugin.php | 72 + .../Exception/ErrorResponseException.php | 7 + .../Guzzle/Plugin/History/HistoryPlugin.php | 163 + vendor/aws/Guzzle/Plugin/Log/LogPlugin.php | 161 + .../Plugin/Md5/CommandContentMd5Plugin.php | 57 + .../Guzzle/Plugin/Md5/Md5ValidatorPlugin.php | 88 + vendor/aws/Guzzle/Plugin/Mock/MockPlugin.php | 245 + .../aws/Guzzle/Plugin/Oauth/OauthPlugin.php | 306 + .../Guzzle/Service/AbstractConfigLoader.php | 177 + .../Guzzle/Service/Builder/ServiceBuilder.php | 189 + .../Builder/ServiceBuilderInterface.php | 40 + .../Service/Builder/ServiceBuilderLoader.php | 89 + .../Guzzle/Service/CachingConfigLoader.php | 46 + vendor/aws/Guzzle/Service/Client.php | 297 + vendor/aws/Guzzle/Service/ClientInterface.php | 68 + .../Service/Command/AbstractCommand.php | 390 + .../Guzzle/Service/Command/ClosureCommand.php | 41 + .../Service/Command/CommandInterface.php | 128 + .../Command/CreateResponseClassEvent.php | 32 + .../Command/DefaultRequestSerializer.php | 169 + .../Service/Command/DefaultResponseParser.php | 55 + .../Service/Command/Factory/AliasFactory.php | 39 + .../Command/Factory/CompositeFactory.php | 154 + .../Command/Factory/ConcreteClassFactory.php | 47 + .../Command/Factory/FactoryInterface.php | 21 + .../Service/Command/Factory/MapFactory.php | 27 + .../Factory/ServiceDescriptionFactory.php | 71 + .../Request/AbstractRequestVisitor.php | 69 + .../LocationVisitor/Request/BodyVisitor.php | 58 + .../LocationVisitor/Request/HeaderVisitor.php | 44 + .../LocationVisitor/Request/JsonVisitor.php | 63 + .../Request/PostFieldVisitor.php | 18 + .../Request/PostFileVisitor.php | 24 + .../LocationVisitor/Request/QueryVisitor.php | 18 + .../Request/RequestVisitorInterface.php | 31 + .../Request/ResponseBodyVisitor.php | 18 + .../LocationVisitor/Request/XmlVisitor.php | 252 + .../Response/AbstractResponseVisitor.php | 26 + .../LocationVisitor/Response/BodyVisitor.php | 23 + .../Response/HeaderVisitor.php | 50 + .../LocationVisitor/Response/JsonVisitor.php | 93 + .../Response/ReasonPhraseVisitor.php | 23 + .../Response/ResponseVisitorInterface.php | 46 + .../Response/StatusCodeVisitor.php | 23 + .../LocationVisitor/Response/XmlVisitor.php | 151 + .../LocationVisitor/VisitorFlyweight.php | 138 + .../Service/Command/OperationCommand.php | 89 + .../Command/OperationResponseParser.php | 195 + .../Command/RequestSerializerInterface.php | 21 + .../Command/ResponseClassInterface.php | 18 + .../Command/ResponseParserInterface.php | 18 + .../Guzzle/Service/ConfigLoaderInterface.php | 22 + .../Guzzle/Service/Description/Operation.php | 547 + .../Description/OperationInterface.php | 159 + .../Guzzle/Service/Description/Parameter.php | 925 + .../Service/Description/SchemaFormatter.php | 156 + .../Service/Description/SchemaValidator.php | 291 + .../Description/ServiceDescription.php | 271 + .../ServiceDescriptionInterface.php | 106 + .../Description/ServiceDescriptionLoader.php | 64 + .../Description/ValidatorInterface.php | 28 + .../Service/Exception/CommandException.php | 7 + .../Exception/CommandTransferException.php | 119 + .../Exception/DescriptionBuilderException.php | 7 + .../InconsistentClientTransferException.php | 38 + .../Exception/ResponseClassException.php | 9 + .../Exception/ServiceBuilderException.php | 7 + .../Exception/ServiceNotFoundException.php | 5 + .../Service/Exception/ValidationException.php | 30 + .../AbstractResourceIteratorFactory.php | 37 + .../CompositeResourceIteratorFactory.php | 67 + .../Resource/MapResourceIteratorFactory.php | 34 + vendor/aws/Guzzle/Service/Resource/Model.php | 64 + .../Service/Resource/ResourceIterator.php | 254 + .../Resource/ResourceIteratorApplyBatched.php | 111 + .../Resource/ResourceIteratorClassFactory.php | 60 + .../ResourceIteratorFactoryInterface.php | 30 + .../Resource/ResourceIteratorInterface.php | 61 + .../Guzzle/Stream/PhpStreamRequestFactory.php | 284 + vendor/aws/Guzzle/Stream/Stream.php | 289 + vendor/aws/Guzzle/Stream/StreamInterface.php | 218 + .../Stream/StreamRequestFactoryInterface.php | 24 + vendor/aws/LICENSE.md | 141 + vendor/aws/Monolog/ErrorHandler.php | 208 + .../Monolog/Formatter/ChromePHPFormatter.php | 79 + .../Monolog/Formatter/ElasticaFormatter.php | 87 + .../Monolog/Formatter/FlowdockFormatter.php | 104 + .../Monolog/Formatter/FormatterInterface.php | 36 + .../Formatter/GelfMessageFormatter.php | 111 + .../aws/Monolog/Formatter/HtmlFormatter.php | 140 + .../aws/Monolog/Formatter/JsonFormatter.php | 116 + .../aws/Monolog/Formatter/LineFormatter.php | 159 + .../aws/Monolog/Formatter/LogglyFormatter.php | 47 + .../Monolog/Formatter/LogstashFormatter.php | 165 + .../Monolog/Formatter/MongoDBFormatter.php | 105 + .../Monolog/Formatter/NormalizerFormatter.php | 150 + .../aws/Monolog/Formatter/ScalarFormatter.php | 48 + .../Monolog/Formatter/WildfireFormatter.php | 113 + .../aws/Monolog/Handler/AbstractHandler.php | 184 + .../Handler/AbstractProcessingHandler.php | 66 + .../Monolog/Handler/AbstractSyslogHandler.php | 92 + vendor/aws/Monolog/Handler/AmqpHandler.php | 98 + .../Monolog/Handler/BrowserConsoleHandler.php | 184 + vendor/aws/Monolog/Handler/BufferHandler.php | 117 + .../aws/Monolog/Handler/ChromePHPHandler.php | 204 + vendor/aws/Monolog/Handler/CouchDBHandler.php | 72 + vendor/aws/Monolog/Handler/CubeHandler.php | 145 + .../Handler/DoctrineCouchDBHandler.php | 45 + .../aws/Monolog/Handler/DynamoDbHandler.php | 89 + .../Monolog/Handler/ElasticSearchHandler.php | 128 + .../aws/Monolog/Handler/ErrorLogHandler.php | 82 + .../Monolog/Handler/ExceptionTestHandler.php | 34 + vendor/aws/Monolog/Handler/FilterHandler.php | 140 + .../ActivationStrategyInterface.php | 28 + .../ChannelLevelActivationStrategy.php | 59 + .../ErrorLevelActivationStrategy.php | 34 + .../Monolog/Handler/FingersCrossedHandler.php | 150 + vendor/aws/Monolog/Handler/FirePHPHandler.php | 195 + .../aws/Monolog/Handler/FleepHookHandler.php | 126 + .../aws/Monolog/Handler/FlowdockHandler.php | 103 + vendor/aws/Monolog/Handler/GelfHandler.php | 72 + vendor/aws/Monolog/Handler/GroupHandler.php | 80 + .../aws/Monolog/Handler/HandlerInterface.php | 90 + vendor/aws/Monolog/Handler/HipChatHandler.php | 306 + .../aws/Monolog/Handler/LogEntriesHandler.php | 55 + vendor/aws/Monolog/Handler/LogglyHandler.php | 98 + vendor/aws/Monolog/Handler/MailHandler.php | 55 + .../aws/Monolog/Handler/MandrillHandler.php | 69 + .../Handler/MissingExtensionException.php | 21 + vendor/aws/Monolog/Handler/MongoDBHandler.php | 55 + .../Monolog/Handler/NativeMailerHandler.php | 176 + .../aws/Monolog/Handler/NewRelicHandler.php | 176 + vendor/aws/Monolog/Handler/NullHandler.php | 45 + vendor/aws/Monolog/Handler/PsrHandler.php | 56 + .../aws/Monolog/Handler/PushoverHandler.php | 172 + vendor/aws/Monolog/Handler/RavenHandler.php | 187 + vendor/aws/Monolog/Handler/RedisHandler.php | 58 + vendor/aws/Monolog/Handler/RollbarHandler.php | 73 + .../Monolog/Handler/RotatingFileHandler.php | 153 + .../aws/Monolog/Handler/SamplingHandler.php | 82 + vendor/aws/Monolog/Handler/SlackHandler.php | 280 + vendor/aws/Monolog/Handler/SocketHandler.php | 284 + vendor/aws/Monolog/Handler/StreamHandler.php | 104 + .../Monolog/Handler/SwiftMailerHandler.php | 87 + vendor/aws/Monolog/Handler/SyslogHandler.php | 67 + .../Monolog/Handler/SyslogUdp/UdpSocket.php | 46 + .../aws/Monolog/Handler/SyslogUdpHandler.php | 80 + vendor/aws/Monolog/Handler/TestHandler.php | 140 + .../Handler/WhatFailureGroupHandler.php | 57 + .../Monolog/Handler/ZendMonitorHandler.php | 95 + vendor/aws/Monolog/Logger.php | 615 + vendor/aws/Monolog/Processor/GitProcessor.php | 64 + .../Processor/IntrospectionProcessor.php | 82 + .../Processor/MemoryPeakUsageProcessor.php | 40 + .../aws/Monolog/Processor/MemoryProcessor.php | 63 + .../Processor/MemoryUsageProcessor.php | 40 + .../Monolog/Processor/ProcessIdProcessor.php | 31 + .../Processor/PsrLogMessageProcessor.php | 48 + vendor/aws/Monolog/Processor/TagProcessor.php | 34 + vendor/aws/Monolog/Processor/UidProcessor.php | 38 + vendor/aws/Monolog/Processor/WebProcessor.php | 105 + vendor/aws/Monolog/Registry.php | 134 + vendor/aws/NOTICE.md | 112 + vendor/aws/Psr/Log/AbstractLogger.php | 120 + .../aws/Psr/Log/InvalidArgumentException.php | 7 + vendor/aws/Psr/Log/LogLevel.php | 18 + vendor/aws/Psr/Log/LoggerAwareInterface.php | 17 + vendor/aws/Psr/Log/LoggerAwareTrait.php | 22 + vendor/aws/Psr/Log/LoggerInterface.php | 114 + vendor/aws/Psr/Log/LoggerTrait.php | 131 + vendor/aws/Psr/Log/NullLogger.php | 27 + .../aws/Psr/Log/Test/LoggerInterfaceTest.php | 116 + vendor/aws/README.md | 185 + .../ContainerAwareEventDispatcher.php | 202 + .../Debug/TraceableEventDispatcher.php | 320 + .../TraceableEventDispatcherInterface.php | 34 + .../EventDispatcher/Debug/WrappedListener.php | 71 + .../RegisterListenersPass.php | 110 + .../Component/EventDispatcher/Event.php | 130 + .../EventDispatcher/EventDispatcher.php | 185 + .../EventDispatcherInterface.php | 96 + .../EventSubscriberInterface.php | 50 + .../EventDispatcher/GenericEvent.php | 186 + .../ImmutableEventDispatcher.php | 93 + .../Symfony/Component/EventDispatcher/LICENSE | 19 + .../Tests/AbstractEventDispatcherTest.php | 369 + .../ContainerAwareEventDispatcherTest.php | 249 + .../Debug/TraceableEventDispatcherTest.php | 185 + .../RegisterListenersPassTest.php | 200 + .../Tests/EventDispatcherTest.php | 22 + .../EventDispatcher/Tests/EventTest.php | 100 + .../Tests/GenericEventTest.php | 139 + .../Tests/ImmutableEventDispatcherTest.php | 105 + vendor/aws/aws-autoloader.php | 1344 ++ 1353 files changed, 288811 insertions(+), 4 deletions(-) delete mode 100755 vendor/aws.phar create mode 100644 vendor/aws/Aws/AutoScaling/AutoScalingClient.php create mode 100644 vendor/aws/Aws/AutoScaling/Enum/LifecycleState.php create mode 100644 vendor/aws/Aws/AutoScaling/Enum/ScalingActivityStatusCode.php create mode 100644 vendor/aws/Aws/AutoScaling/Exception/AlreadyExistsException.php create mode 100644 vendor/aws/Aws/AutoScaling/Exception/AutoScalingException.php create mode 100644 vendor/aws/Aws/AutoScaling/Exception/InvalidNextTokenException.php create mode 100644 vendor/aws/Aws/AutoScaling/Exception/LimitExceededException.php create mode 100644 vendor/aws/Aws/AutoScaling/Exception/ResourceInUseException.php create mode 100644 vendor/aws/Aws/AutoScaling/Exception/ScalingActivityInProgressException.php create mode 100644 vendor/aws/Aws/AutoScaling/Resources/autoscaling-2011-01-01.php create mode 100644 vendor/aws/Aws/CloudFormation/CloudFormationClient.php create mode 100644 vendor/aws/Aws/CloudFormation/Enum/Capability.php create mode 100644 vendor/aws/Aws/CloudFormation/Enum/OnFailure.php create mode 100644 vendor/aws/Aws/CloudFormation/Enum/ResourceStatus.php create mode 100644 vendor/aws/Aws/CloudFormation/Enum/StackStatus.php create mode 100644 vendor/aws/Aws/CloudFormation/Exception/AlreadyExistsException.php create mode 100644 vendor/aws/Aws/CloudFormation/Exception/CloudFormationException.php create mode 100644 vendor/aws/Aws/CloudFormation/Exception/InsufficientCapabilitiesException.php create mode 100644 vendor/aws/Aws/CloudFormation/Exception/LimitExceededException.php create mode 100644 vendor/aws/Aws/CloudFormation/Resources/cloudformation-2010-05-15.php create mode 100644 vendor/aws/Aws/CloudFront/CloudFrontClient.php create mode 100644 vendor/aws/Aws/CloudFront/CloudFrontSignature.php create mode 100644 vendor/aws/Aws/CloudFront/Enum/GeoRestrictionType.php create mode 100644 vendor/aws/Aws/CloudFront/Enum/ItemSelection.php create mode 100644 vendor/aws/Aws/CloudFront/Enum/Method.php create mode 100644 vendor/aws/Aws/CloudFront/Enum/OriginProtocolPolicy.php create mode 100644 vendor/aws/Aws/CloudFront/Enum/PriceClass.php create mode 100644 vendor/aws/Aws/CloudFront/Enum/SSLSupportMethod.php create mode 100644 vendor/aws/Aws/CloudFront/Enum/ViewerProtocolPolicy.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/AccessDeniedException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/BatchTooLargeException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/CNAMEAlreadyExistsException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/CloudFrontException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/CloudFrontOriginAccessIdentityAlreadyExistsException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/CloudFrontOriginAccessIdentityInUseException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/DistributionAlreadyExistsException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/DistributionNotDisabledException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/Exception.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/IllegalUpdateException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/InconsistentQuantitiesException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/InvalidArgumentException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/InvalidDefaultRootObjectException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/InvalidErrorCodeException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/InvalidForwardCookiesException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/InvalidGeoRestrictionParameterException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/InvalidIfMatchVersionException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/InvalidLocationCodeException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/InvalidOriginAccessIdentityException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/InvalidOriginException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/InvalidRelativePathException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/InvalidRequiredProtocolException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/InvalidResponseCodeException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/InvalidViewerCertificateException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/MissingBodyException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/NoSuchCloudFrontOriginAccessIdentityException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/NoSuchDistributionException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/NoSuchInvalidationException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/NoSuchOriginException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/NoSuchStreamingDistributionException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/PreconditionFailedException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/StreamingDistributionAlreadyExistsException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/StreamingDistributionNotDisabledException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/TooManyCacheBehaviorsException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/TooManyCertificatesException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/TooManyCloudFrontOriginAccessIdentitiesException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/TooManyCookieNamesInWhiteListException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/TooManyDistributionCNAMEsException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/TooManyDistributionsException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/TooManyInvalidationsInProgressException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/TooManyOriginsException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/TooManyStreamingDistributionCNAMEsException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/TooManyStreamingDistributionsException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/TooManyTrustedSignersException.php create mode 100644 vendor/aws/Aws/CloudFront/Exception/TrustedSignerDoesNotExistException.php create mode 100644 vendor/aws/Aws/CloudFront/Resources/cloudfront-2012-05-05.php create mode 100644 vendor/aws/Aws/CloudFront/Resources/cloudfront-2014-05-31.php create mode 100644 vendor/aws/Aws/CloudFront/Resources/cloudfront-2014-10-21.php create mode 100644 vendor/aws/Aws/CloudFront/Resources/cloudfront-2014-11-06.php create mode 100644 vendor/aws/Aws/CloudHsm/CloudHsmClient.php create mode 100644 vendor/aws/Aws/CloudHsm/Exception/CloudHsmException.php create mode 100644 vendor/aws/Aws/CloudHsm/Resources/cloudhsm-2014-05-30.php create mode 100644 vendor/aws/Aws/CloudSearch/CloudSearchClient.php create mode 100644 vendor/aws/Aws/CloudSearch/Enum/IndexFieldType.php create mode 100644 vendor/aws/Aws/CloudSearch/Enum/OptionState.php create mode 100644 vendor/aws/Aws/CloudSearch/Enum/SearchInstanceType.php create mode 100644 vendor/aws/Aws/CloudSearch/Enum/SourceDataFunction.php create mode 100644 vendor/aws/Aws/CloudSearch/Exception/BaseException.php create mode 100644 vendor/aws/Aws/CloudSearch/Exception/CloudSearchException.php create mode 100644 vendor/aws/Aws/CloudSearch/Exception/InternalException.php create mode 100644 vendor/aws/Aws/CloudSearch/Exception/InvalidTypeException.php create mode 100644 vendor/aws/Aws/CloudSearch/Exception/LimitExceededException.php create mode 100644 vendor/aws/Aws/CloudSearch/Exception/ResourceNotFoundException.php create mode 100644 vendor/aws/Aws/CloudSearch/Resources/cloudsearch-2011-02-01.php create mode 100644 vendor/aws/Aws/CloudSearch/Resources/cloudsearch-2013-01-01.php create mode 100644 vendor/aws/Aws/CloudSearchDomain/CloudSearchDomainClient.php create mode 100644 vendor/aws/Aws/CloudSearchDomain/CloudSearchDomainClientBuilder.php create mode 100644 vendor/aws/Aws/CloudSearchDomain/Exception/CloudSearchDomainException.php create mode 100644 vendor/aws/Aws/CloudSearchDomain/Resources/cloudsearchdomain-2013-01-01.php create mode 100644 vendor/aws/Aws/CloudTrail/CloudTrailClient.php create mode 100644 vendor/aws/Aws/CloudTrail/Exception/CloudTrailException.php create mode 100644 vendor/aws/Aws/CloudTrail/Exception/InsufficientS3BucketPolicyException.php create mode 100644 vendor/aws/Aws/CloudTrail/Exception/InsufficientSnsTopicPolicyException.php create mode 100644 vendor/aws/Aws/CloudTrail/Exception/InternalErrorException.php create mode 100644 vendor/aws/Aws/CloudTrail/Exception/InvalidS3BucketNameException.php create mode 100644 vendor/aws/Aws/CloudTrail/Exception/InvalidS3PrefixException.php create mode 100644 vendor/aws/Aws/CloudTrail/Exception/InvalidSnsTopicNameException.php create mode 100644 vendor/aws/Aws/CloudTrail/Exception/InvalidTrailNameException.php create mode 100644 vendor/aws/Aws/CloudTrail/Exception/MaximumNumberOfTrailsExceededException.php create mode 100644 vendor/aws/Aws/CloudTrail/Exception/S3BucketDoesNotExistException.php create mode 100644 vendor/aws/Aws/CloudTrail/Exception/TrailAlreadyExistsException.php create mode 100644 vendor/aws/Aws/CloudTrail/Exception/TrailNotFoundException.php create mode 100644 vendor/aws/Aws/CloudTrail/Exception/TrailNotProvidedException.php create mode 100644 vendor/aws/Aws/CloudTrail/LogFileIterator.php create mode 100644 vendor/aws/Aws/CloudTrail/LogFileReader.php create mode 100644 vendor/aws/Aws/CloudTrail/LogRecordIterator.php create mode 100644 vendor/aws/Aws/CloudTrail/Resources/cloudtrail-2013-11-01.php create mode 100644 vendor/aws/Aws/CloudWatch/CloudWatchClient.php create mode 100644 vendor/aws/Aws/CloudWatch/Enum/ComparisonOperator.php create mode 100644 vendor/aws/Aws/CloudWatch/Enum/HistoryItemType.php create mode 100644 vendor/aws/Aws/CloudWatch/Enum/StateValue.php create mode 100644 vendor/aws/Aws/CloudWatch/Enum/Statistic.php create mode 100644 vendor/aws/Aws/CloudWatch/Enum/Unit.php create mode 100644 vendor/aws/Aws/CloudWatch/Exception/CloudWatchException.php create mode 100644 vendor/aws/Aws/CloudWatch/Exception/InternalServiceException.php create mode 100644 vendor/aws/Aws/CloudWatch/Exception/InvalidFormatException.php create mode 100644 vendor/aws/Aws/CloudWatch/Exception/InvalidNextTokenException.php create mode 100644 vendor/aws/Aws/CloudWatch/Exception/InvalidParameterCombinationException.php create mode 100644 vendor/aws/Aws/CloudWatch/Exception/InvalidParameterValueException.php create mode 100644 vendor/aws/Aws/CloudWatch/Exception/LimitExceededException.php create mode 100644 vendor/aws/Aws/CloudWatch/Exception/MissingRequiredParameterException.php create mode 100644 vendor/aws/Aws/CloudWatch/Exception/ResourceNotFoundException.php create mode 100644 vendor/aws/Aws/CloudWatch/Resources/cloudwatch-2010-08-01.php create mode 100644 vendor/aws/Aws/CloudWatchLogs/CloudWatchLogsClient.php create mode 100644 vendor/aws/Aws/CloudWatchLogs/Exception/CloudWatchLogsException.php create mode 100644 vendor/aws/Aws/CloudWatchLogs/Resources/cloudwatchlogs-2014-03-28.php create mode 100644 vendor/aws/Aws/CodeDeploy/CodeDeployClient.php create mode 100644 vendor/aws/Aws/CodeDeploy/Exception/CodeDeployException.php create mode 100644 vendor/aws/Aws/CodeDeploy/Resources/codedeploy-2014-10-06.php create mode 100644 vendor/aws/Aws/CognitoIdentity/CognitoIdentityClient.php create mode 100644 vendor/aws/Aws/CognitoIdentity/Exception/CognitoIdentityException.php create mode 100644 vendor/aws/Aws/CognitoIdentity/Resources/cognitoidentity-2014-06-30.php create mode 100644 vendor/aws/Aws/CognitoSync/CognitoSyncClient.php create mode 100644 vendor/aws/Aws/CognitoSync/Exception/CognitoSyncException.php create mode 100644 vendor/aws/Aws/CognitoSync/Resources/cognitosync-2014-06-30.php create mode 100644 vendor/aws/Aws/Common/Aws.php create mode 100644 vendor/aws/Aws/Common/Client/AbstractClient.php create mode 100644 vendor/aws/Aws/Common/Client/AwsClientInterface.php create mode 100644 vendor/aws/Aws/Common/Client/ClientBuilder.php create mode 100644 vendor/aws/Aws/Common/Client/DefaultClient.php create mode 100644 vendor/aws/Aws/Common/Client/ExpiredCredentialsChecker.php create mode 100644 vendor/aws/Aws/Common/Client/ThrottlingErrorChecker.php create mode 100644 vendor/aws/Aws/Common/Client/UploadBodyListener.php create mode 100644 vendor/aws/Aws/Common/Client/UserAgentListener.php create mode 100644 vendor/aws/Aws/Common/Command/AwsQueryVisitor.php create mode 100644 vendor/aws/Aws/Common/Command/JsonCommand.php create mode 100644 vendor/aws/Aws/Common/Command/QueryCommand.php create mode 100644 vendor/aws/Aws/Common/Command/XmlResponseLocationVisitor.php create mode 100644 vendor/aws/Aws/Common/Credentials/AbstractCredentialsDecorator.php create mode 100644 vendor/aws/Aws/Common/Credentials/AbstractRefreshableCredentials.php create mode 100644 vendor/aws/Aws/Common/Credentials/CacheableCredentials.php create mode 100644 vendor/aws/Aws/Common/Credentials/Credentials.php create mode 100644 vendor/aws/Aws/Common/Credentials/CredentialsInterface.php create mode 100644 vendor/aws/Aws/Common/Credentials/NullCredentials.php create mode 100644 vendor/aws/Aws/Common/Credentials/RefreshableInstanceProfileCredentials.php create mode 100644 vendor/aws/Aws/Common/Enum.php create mode 100644 vendor/aws/Aws/Common/Enum/ClientOptions.php create mode 100644 vendor/aws/Aws/Common/Enum/DateFormat.php create mode 100644 vendor/aws/Aws/Common/Enum/Region.php create mode 100644 vendor/aws/Aws/Common/Enum/Size.php create mode 100644 vendor/aws/Aws/Common/Enum/Time.php create mode 100644 vendor/aws/Aws/Common/Enum/UaString.php create mode 100644 vendor/aws/Aws/Common/Exception/AwsExceptionInterface.php create mode 100644 vendor/aws/Aws/Common/Exception/BadMethodCallException.php create mode 100644 vendor/aws/Aws/Common/Exception/DomainException.php create mode 100644 vendor/aws/Aws/Common/Exception/ExceptionFactoryInterface.php create mode 100644 vendor/aws/Aws/Common/Exception/ExceptionListener.php create mode 100644 vendor/aws/Aws/Common/Exception/InstanceProfileCredentialsException.php create mode 100644 vendor/aws/Aws/Common/Exception/InvalidArgumentException.php create mode 100644 vendor/aws/Aws/Common/Exception/LogicException.php create mode 100644 vendor/aws/Aws/Common/Exception/MultipartUploadException.php create mode 100644 vendor/aws/Aws/Common/Exception/NamespaceExceptionFactory.php create mode 100644 vendor/aws/Aws/Common/Exception/OutOfBoundsException.php create mode 100644 vendor/aws/Aws/Common/Exception/OverflowException.php create mode 100644 vendor/aws/Aws/Common/Exception/Parser/AbstractJsonExceptionParser.php create mode 100644 vendor/aws/Aws/Common/Exception/Parser/DefaultXmlExceptionParser.php create mode 100644 vendor/aws/Aws/Common/Exception/Parser/ExceptionParserInterface.php create mode 100644 vendor/aws/Aws/Common/Exception/Parser/JsonQueryExceptionParser.php create mode 100644 vendor/aws/Aws/Common/Exception/Parser/JsonRestExceptionParser.php create mode 100644 vendor/aws/Aws/Common/Exception/RequiredExtensionNotLoadedException.php create mode 100644 vendor/aws/Aws/Common/Exception/RuntimeException.php create mode 100644 vendor/aws/Aws/Common/Exception/ServiceResponseException.php create mode 100644 vendor/aws/Aws/Common/Exception/TransferException.php create mode 100644 vendor/aws/Aws/Common/Exception/UnexpectedValueException.php create mode 100644 vendor/aws/Aws/Common/Facade/Facade.php create mode 100644 vendor/aws/Aws/Common/Facade/FacadeInterface.php create mode 100644 vendor/aws/Aws/Common/Facade/facade-classes.php create mode 100644 vendor/aws/Aws/Common/Hash/ChunkHash.php create mode 100644 vendor/aws/Aws/Common/Hash/ChunkHashInterface.php create mode 100644 vendor/aws/Aws/Common/Hash/HashUtils.php create mode 100644 vendor/aws/Aws/Common/Hash/TreeHash.php create mode 100644 vendor/aws/Aws/Common/HostNameUtils.php create mode 100644 vendor/aws/Aws/Common/InstanceMetadata/InstanceMetadataClient.php create mode 100644 vendor/aws/Aws/Common/InstanceMetadata/Waiter/ServiceAvailable.php create mode 100644 vendor/aws/Aws/Common/Iterator/AwsResourceIterator.php create mode 100644 vendor/aws/Aws/Common/Iterator/AwsResourceIteratorFactory.php create mode 100644 vendor/aws/Aws/Common/Model/MultipartUpload/AbstractTransfer.php create mode 100644 vendor/aws/Aws/Common/Model/MultipartUpload/AbstractTransferState.php create mode 100644 vendor/aws/Aws/Common/Model/MultipartUpload/AbstractUploadBuilder.php create mode 100644 vendor/aws/Aws/Common/Model/MultipartUpload/AbstractUploadId.php create mode 100644 vendor/aws/Aws/Common/Model/MultipartUpload/AbstractUploadPart.php create mode 100644 vendor/aws/Aws/Common/Model/MultipartUpload/TransferInterface.php create mode 100644 vendor/aws/Aws/Common/Model/MultipartUpload/TransferStateInterface.php create mode 100644 vendor/aws/Aws/Common/Model/MultipartUpload/UploadIdInterface.php create mode 100644 vendor/aws/Aws/Common/Model/MultipartUpload/UploadPartInterface.php create mode 100644 vendor/aws/Aws/Common/Resources/aws-config.php create mode 100644 vendor/aws/Aws/Common/Resources/public-endpoints.php create mode 100644 vendor/aws/Aws/Common/Resources/sdk1-config.php create mode 100644 vendor/aws/Aws/Common/RulesEndpointProvider.php create mode 100644 vendor/aws/Aws/Common/Signature/AbstractSignature.php create mode 100644 vendor/aws/Aws/Common/Signature/EndpointSignatureInterface.php create mode 100644 vendor/aws/Aws/Common/Signature/SignatureInterface.php create mode 100644 vendor/aws/Aws/Common/Signature/SignatureListener.php create mode 100644 vendor/aws/Aws/Common/Signature/SignatureV2.php create mode 100644 vendor/aws/Aws/Common/Signature/SignatureV3Https.php create mode 100644 vendor/aws/Aws/Common/Signature/SignatureV4.php create mode 100644 vendor/aws/Aws/Common/Waiter/AbstractResourceWaiter.php create mode 100644 vendor/aws/Aws/Common/Waiter/AbstractWaiter.php create mode 100644 vendor/aws/Aws/Common/Waiter/CallableWaiter.php create mode 100644 vendor/aws/Aws/Common/Waiter/CompositeWaiterFactory.php create mode 100644 vendor/aws/Aws/Common/Waiter/ConfigResourceWaiter.php create mode 100644 vendor/aws/Aws/Common/Waiter/ResourceWaiterInterface.php create mode 100644 vendor/aws/Aws/Common/Waiter/WaiterClassFactory.php create mode 100644 vendor/aws/Aws/Common/Waiter/WaiterConfig.php create mode 100644 vendor/aws/Aws/Common/Waiter/WaiterConfigFactory.php create mode 100644 vendor/aws/Aws/Common/Waiter/WaiterFactoryInterface.php create mode 100644 vendor/aws/Aws/Common/Waiter/WaiterInterface.php create mode 100644 vendor/aws/Aws/ConfigService/ConfigServiceClient.php create mode 100644 vendor/aws/Aws/ConfigService/Exception/ConfigServiceException.php create mode 100644 vendor/aws/Aws/ConfigService/Resources/configservice-2014-11-12.php create mode 100644 vendor/aws/Aws/DataPipeline/DataPipelineClient.php create mode 100644 vendor/aws/Aws/DataPipeline/Enum/WorkStatus.php create mode 100644 vendor/aws/Aws/DataPipeline/Exception/DataPipelineException.php create mode 100644 vendor/aws/Aws/DataPipeline/Exception/InternalServiceErrorException.php create mode 100644 vendor/aws/Aws/DataPipeline/Exception/InvalidRequestException.php create mode 100644 vendor/aws/Aws/DataPipeline/Exception/PipelineDeletedException.php create mode 100644 vendor/aws/Aws/DataPipeline/Exception/PipelineNotFoundException.php create mode 100644 vendor/aws/Aws/DataPipeline/Exception/TaskNotFoundException.php create mode 100644 vendor/aws/Aws/DataPipeline/Resources/datapipeline-2012-10-29.php create mode 100644 vendor/aws/Aws/DirectConnect/DirectConnectClient.php create mode 100644 vendor/aws/Aws/DirectConnect/Enum/ConnectionState.php create mode 100644 vendor/aws/Aws/DirectConnect/Enum/InterconnectState.php create mode 100644 vendor/aws/Aws/DirectConnect/Enum/StepState.php create mode 100644 vendor/aws/Aws/DirectConnect/Enum/VirtualInterfaceState.php create mode 100644 vendor/aws/Aws/DirectConnect/Exception/DirectConnectClientException.php create mode 100644 vendor/aws/Aws/DirectConnect/Exception/DirectConnectException.php create mode 100644 vendor/aws/Aws/DirectConnect/Exception/DirectConnectServerException.php create mode 100644 vendor/aws/Aws/DirectConnect/Resources/directconnect-2012-10-25.php create mode 100644 vendor/aws/Aws/DynamoDb/Crc32ErrorChecker.php create mode 100644 vendor/aws/Aws/DynamoDb/DynamoDbClient.php create mode 100644 vendor/aws/Aws/DynamoDb/DynamoDbCommand.php create mode 100644 vendor/aws/Aws/DynamoDb/Enum/AttributeAction.php create mode 100644 vendor/aws/Aws/DynamoDb/Enum/AttributeType.php create mode 100644 vendor/aws/Aws/DynamoDb/Enum/ComparisonOperator.php create mode 100644 vendor/aws/Aws/DynamoDb/Enum/IndexStatus.php create mode 100644 vendor/aws/Aws/DynamoDb/Enum/KeyType.php create mode 100644 vendor/aws/Aws/DynamoDb/Enum/ProjectionType.php create mode 100644 vendor/aws/Aws/DynamoDb/Enum/ReturnConsumedCapacity.php create mode 100644 vendor/aws/Aws/DynamoDb/Enum/ReturnItemCollectionMetrics.php create mode 100644 vendor/aws/Aws/DynamoDb/Enum/ReturnValue.php create mode 100644 vendor/aws/Aws/DynamoDb/Enum/ScalarAttributeType.php create mode 100644 vendor/aws/Aws/DynamoDb/Enum/Select.php create mode 100644 vendor/aws/Aws/DynamoDb/Enum/TableStatus.php create mode 100644 vendor/aws/Aws/DynamoDb/Enum/Type.php create mode 100644 vendor/aws/Aws/DynamoDb/Exception/AccessDeniedException.php create mode 100644 vendor/aws/Aws/DynamoDb/Exception/ConditionalCheckFailedException.php create mode 100644 vendor/aws/Aws/DynamoDb/Exception/DynamoDbException.php create mode 100644 vendor/aws/Aws/DynamoDb/Exception/IncompleteSignatureException.php create mode 100644 vendor/aws/Aws/DynamoDb/Exception/InternalFailureException.php create mode 100644 vendor/aws/Aws/DynamoDb/Exception/InternalServerErrorException.php create mode 100644 vendor/aws/Aws/DynamoDb/Exception/ItemCollectionSizeLimitExceededException.php create mode 100644 vendor/aws/Aws/DynamoDb/Exception/LimitExceededException.php create mode 100644 vendor/aws/Aws/DynamoDb/Exception/MissingAuthenticationTokenException.php create mode 100644 vendor/aws/Aws/DynamoDb/Exception/ProvisionedThroughputExceededException.php create mode 100644 vendor/aws/Aws/DynamoDb/Exception/ResourceInUseException.php create mode 100644 vendor/aws/Aws/DynamoDb/Exception/ResourceNotFoundException.php create mode 100644 vendor/aws/Aws/DynamoDb/Exception/ServiceUnavailableException.php create mode 100644 vendor/aws/Aws/DynamoDb/Exception/ThrottlingException.php create mode 100644 vendor/aws/Aws/DynamoDb/Exception/UnprocessedWriteRequestsException.php create mode 100644 vendor/aws/Aws/DynamoDb/Exception/UnrecognizedClientException.php create mode 100644 vendor/aws/Aws/DynamoDb/Exception/ValidationException.php create mode 100644 vendor/aws/Aws/DynamoDb/Iterator/ItemIterator.php create mode 100644 vendor/aws/Aws/DynamoDb/Iterator/ScanIterator.php create mode 100644 vendor/aws/Aws/DynamoDb/Marshaler.php create mode 100644 vendor/aws/Aws/DynamoDb/Model/Attribute.php create mode 100644 vendor/aws/Aws/DynamoDb/Model/BatchRequest/AbstractWriteRequest.php create mode 100644 vendor/aws/Aws/DynamoDb/Model/BatchRequest/DeleteRequest.php create mode 100644 vendor/aws/Aws/DynamoDb/Model/BatchRequest/PutRequest.php create mode 100644 vendor/aws/Aws/DynamoDb/Model/BatchRequest/UnprocessedRequest.php create mode 100644 vendor/aws/Aws/DynamoDb/Model/BatchRequest/WriteRequestBatch.php create mode 100644 vendor/aws/Aws/DynamoDb/Model/BatchRequest/WriteRequestBatchTransfer.php create mode 100644 vendor/aws/Aws/DynamoDb/Model/BatchRequest/WriteRequestInterface.php create mode 100644 vendor/aws/Aws/DynamoDb/Model/Item.php create mode 100644 vendor/aws/Aws/DynamoDb/Resources/dynamodb-2011-12-05.php create mode 100644 vendor/aws/Aws/DynamoDb/Resources/dynamodb-2012-08-10.php create mode 100644 vendor/aws/Aws/DynamoDb/Session/LockingStrategy/AbstractLockingStrategy.php create mode 100644 vendor/aws/Aws/DynamoDb/Session/LockingStrategy/LockingStrategyFactory.php create mode 100644 vendor/aws/Aws/DynamoDb/Session/LockingStrategy/LockingStrategyFactoryInterface.php create mode 100644 vendor/aws/Aws/DynamoDb/Session/LockingStrategy/LockingStrategyInterface.php create mode 100644 vendor/aws/Aws/DynamoDb/Session/LockingStrategy/NullLockingStrategy.php create mode 100644 vendor/aws/Aws/DynamoDb/Session/LockingStrategy/PessimisticLockingStrategy.php create mode 100644 vendor/aws/Aws/DynamoDb/Session/SessionHandler.php create mode 100644 vendor/aws/Aws/DynamoDb/Session/SessionHandlerConfig.php create mode 100644 vendor/aws/Aws/DynamoDb/Session/SessionHandlerInterface.php create mode 100644 vendor/aws/Aws/Ec2/CopySnapshotListener.php create mode 100644 vendor/aws/Aws/Ec2/Ec2Client.php create mode 100644 vendor/aws/Aws/Ec2/Enum/ContainerFormat.php create mode 100644 vendor/aws/Aws/Ec2/Enum/DiskImageFormat.php create mode 100644 vendor/aws/Aws/Ec2/Enum/DomainType.php create mode 100644 vendor/aws/Aws/Ec2/Enum/ExportEnvironment.php create mode 100644 vendor/aws/Aws/Ec2/Enum/HypervisorType.php create mode 100644 vendor/aws/Aws/Ec2/Enum/ImageState.php create mode 100644 vendor/aws/Aws/Ec2/Enum/InstanceAttributeName.php create mode 100644 vendor/aws/Aws/Ec2/Enum/InstanceStateName.php create mode 100644 vendor/aws/Aws/Ec2/Enum/InstanceType.php create mode 100644 vendor/aws/Aws/Ec2/Enum/PlacementGroupState.php create mode 100644 vendor/aws/Aws/Ec2/Enum/PlacementStrategy.php create mode 100644 vendor/aws/Aws/Ec2/Enum/ResourceType.php create mode 100644 vendor/aws/Aws/Ec2/Enum/RouteOrigin.php create mode 100644 vendor/aws/Aws/Ec2/Enum/RuleAction.php create mode 100644 vendor/aws/Aws/Ec2/Enum/SnapshotAttributeName.php create mode 100644 vendor/aws/Aws/Ec2/Enum/SnapshotState.php create mode 100644 vendor/aws/Aws/Ec2/Enum/SpotInstanceType.php create mode 100644 vendor/aws/Aws/Ec2/Enum/VirtualizationType.php create mode 100644 vendor/aws/Aws/Ec2/Enum/VolumeAttachmentState.php create mode 100644 vendor/aws/Aws/Ec2/Enum/VolumeAttributeName.php create mode 100644 vendor/aws/Aws/Ec2/Enum/VolumeState.php create mode 100644 vendor/aws/Aws/Ec2/Enum/VolumeType.php create mode 100644 vendor/aws/Aws/Ec2/Enum/VpcAttributeName.php create mode 100644 vendor/aws/Aws/Ec2/Exception/Ec2Exception.php create mode 100644 vendor/aws/Aws/Ec2/Iterator/DescribeInstancesIterator.php create mode 100644 vendor/aws/Aws/Ec2/Resources/ec2-2014-06-15.php create mode 100644 vendor/aws/Aws/Ec2/Resources/ec2-2014-09-01.php create mode 100644 vendor/aws/Aws/Ec2/Resources/ec2-2014-10-01.php create mode 100644 vendor/aws/Aws/Ecs/EcsClient.php create mode 100644 vendor/aws/Aws/Ecs/Exception/EcsException.php create mode 100644 vendor/aws/Aws/Ecs/Resources/ecs-2014-11-13.php create mode 100644 vendor/aws/Aws/ElastiCache/ElastiCacheClient.php create mode 100644 vendor/aws/Aws/ElastiCache/Enum/SourceType.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/AuthorizationAlreadyExistsException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/AuthorizationNotFoundException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/CacheClusterAlreadyExistsException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/CacheClusterNotFoundException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/CacheParameterGroupAlreadyExistsException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/CacheParameterGroupNotFoundException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/CacheParameterGroupQuotaExceededException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/CacheSecurityGroupAlreadyExistsException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/CacheSecurityGroupNotFoundException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/CacheSecurityGroupQuotaExceededException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/CacheSubnetGroupAlreadyExistsException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/CacheSubnetGroupInUseException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/CacheSubnetGroupNotFoundException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/CacheSubnetGroupQuotaExceededException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/CacheSubnetQuotaExceededException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/ClusterQuotaForCustomerExceededException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/ElastiCacheException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/InsufficientCacheClusterCapacityException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/InvalidCacheClusterStateException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/InvalidCacheParameterGroupStateException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/InvalidCacheSecurityGroupStateException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/InvalidParameterCombinationException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/InvalidParameterValueException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/InvalidReplicationGroupStateException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/InvalidSubnetException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/InvalidVPCNetworkStateException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/NodeQuotaForClusterExceededException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/NodeQuotaForCustomerExceededException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/ReplicationGroupAlreadyExistsException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/ReplicationGroupNotFoundException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/ReservedCacheNodeAlreadyExistsException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/ReservedCacheNodeNotFoundException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/ReservedCacheNodeQuotaExceededException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/ReservedCacheNodesOfferingNotFoundException.php create mode 100644 vendor/aws/Aws/ElastiCache/Exception/SubnetInUseException.php create mode 100644 vendor/aws/Aws/ElastiCache/Resources/elasticache-2014-07-15.php create mode 100644 vendor/aws/Aws/ElastiCache/Resources/elasticache-2014-09-30.php create mode 100644 vendor/aws/Aws/ElastiCache/Resources/elasticache-2015-02-02.php create mode 100644 vendor/aws/Aws/ElasticBeanstalk/ElasticBeanstalkClient.php create mode 100644 vendor/aws/Aws/ElasticBeanstalk/Enum/ConfigurationDeploymentStatus.php create mode 100644 vendor/aws/Aws/ElasticBeanstalk/Enum/ConfigurationOptionValueType.php create mode 100644 vendor/aws/Aws/ElasticBeanstalk/Enum/EnvironmentHealth.php create mode 100644 vendor/aws/Aws/ElasticBeanstalk/Enum/EnvironmentInfoType.php create mode 100644 vendor/aws/Aws/ElasticBeanstalk/Enum/EnvironmentStatus.php create mode 100644 vendor/aws/Aws/ElasticBeanstalk/Enum/EventSeverity.php create mode 100644 vendor/aws/Aws/ElasticBeanstalk/Enum/ValidationSeverity.php create mode 100644 vendor/aws/Aws/ElasticBeanstalk/Exception/ElasticBeanstalkException.php create mode 100644 vendor/aws/Aws/ElasticBeanstalk/Exception/InsufficientPrivilegesException.php create mode 100644 vendor/aws/Aws/ElasticBeanstalk/Exception/OperationInProgressException.php create mode 100644 vendor/aws/Aws/ElasticBeanstalk/Exception/S3LocationNotInServiceRegionException.php create mode 100644 vendor/aws/Aws/ElasticBeanstalk/Exception/S3SubscriptionRequiredException.php create mode 100644 vendor/aws/Aws/ElasticBeanstalk/Exception/SourceBundleDeletionException.php create mode 100644 vendor/aws/Aws/ElasticBeanstalk/Exception/TooManyApplicationVersionsException.php create mode 100644 vendor/aws/Aws/ElasticBeanstalk/Exception/TooManyApplicationsException.php create mode 100644 vendor/aws/Aws/ElasticBeanstalk/Exception/TooManyBucketsException.php create mode 100644 vendor/aws/Aws/ElasticBeanstalk/Exception/TooManyConfigurationTemplatesException.php create mode 100644 vendor/aws/Aws/ElasticBeanstalk/Exception/TooManyEnvironmentsException.php create mode 100644 vendor/aws/Aws/ElasticBeanstalk/Resources/elasticbeanstalk-2010-12-01.php create mode 100644 vendor/aws/Aws/ElasticLoadBalancing/ElasticLoadBalancingClient.php create mode 100644 vendor/aws/Aws/ElasticLoadBalancing/Exception/AccessPointNotFoundException.php create mode 100644 vendor/aws/Aws/ElasticLoadBalancing/Exception/CertificateNotFoundException.php create mode 100644 vendor/aws/Aws/ElasticLoadBalancing/Exception/DuplicateAccessPointNameException.php create mode 100644 vendor/aws/Aws/ElasticLoadBalancing/Exception/DuplicateListenerException.php create mode 100644 vendor/aws/Aws/ElasticLoadBalancing/Exception/DuplicatePolicyNameException.php create mode 100644 vendor/aws/Aws/ElasticLoadBalancing/Exception/ElasticLoadBalancingException.php create mode 100644 vendor/aws/Aws/ElasticLoadBalancing/Exception/InvalidConfigurationRequestException.php create mode 100644 vendor/aws/Aws/ElasticLoadBalancing/Exception/InvalidEndPointException.php create mode 100644 vendor/aws/Aws/ElasticLoadBalancing/Exception/InvalidSchemeException.php create mode 100644 vendor/aws/Aws/ElasticLoadBalancing/Exception/InvalidSecurityGroupException.php create mode 100644 vendor/aws/Aws/ElasticLoadBalancing/Exception/InvalidSubnetException.php create mode 100644 vendor/aws/Aws/ElasticLoadBalancing/Exception/ListenerNotFoundException.php create mode 100644 vendor/aws/Aws/ElasticLoadBalancing/Exception/LoadBalancerAttributeNotFoundException.php create mode 100644 vendor/aws/Aws/ElasticLoadBalancing/Exception/PolicyNotFoundException.php create mode 100644 vendor/aws/Aws/ElasticLoadBalancing/Exception/PolicyTypeNotFoundException.php create mode 100644 vendor/aws/Aws/ElasticLoadBalancing/Exception/SubnetNotFoundException.php create mode 100644 vendor/aws/Aws/ElasticLoadBalancing/Exception/TooManyAccessPointsException.php create mode 100644 vendor/aws/Aws/ElasticLoadBalancing/Exception/TooManyPoliciesException.php create mode 100644 vendor/aws/Aws/ElasticLoadBalancing/Resources/elasticloadbalancing-2012-06-01.php create mode 100644 vendor/aws/Aws/ElasticTranscoder/ElasticTranscoderClient.php create mode 100644 vendor/aws/Aws/ElasticTranscoder/Exception/AccessDeniedException.php create mode 100644 vendor/aws/Aws/ElasticTranscoder/Exception/ElasticTranscoderException.php create mode 100644 vendor/aws/Aws/ElasticTranscoder/Exception/IncompatibleVersionException.php create mode 100644 vendor/aws/Aws/ElasticTranscoder/Exception/InternalServiceException.php create mode 100644 vendor/aws/Aws/ElasticTranscoder/Exception/LimitExceededException.php create mode 100644 vendor/aws/Aws/ElasticTranscoder/Exception/ResourceInUseException.php create mode 100644 vendor/aws/Aws/ElasticTranscoder/Exception/ResourceNotFoundException.php create mode 100644 vendor/aws/Aws/ElasticTranscoder/Exception/ValidationException.php create mode 100644 vendor/aws/Aws/ElasticTranscoder/Resources/elastictranscoder-2012-09-25.php create mode 100644 vendor/aws/Aws/Emr/EmrClient.php create mode 100644 vendor/aws/Aws/Emr/Enum/ActionOnFailure.php create mode 100644 vendor/aws/Aws/Emr/Enum/ClusterState.php create mode 100644 vendor/aws/Aws/Emr/Enum/ClusterStateChangeReasonCode.php create mode 100644 vendor/aws/Aws/Emr/Enum/InstanceGroupState.php create mode 100644 vendor/aws/Aws/Emr/Enum/InstanceGroupStateChangeReasonCode.php create mode 100644 vendor/aws/Aws/Emr/Enum/InstanceGroupType.php create mode 100644 vendor/aws/Aws/Emr/Enum/InstanceRoleType.php create mode 100644 vendor/aws/Aws/Emr/Enum/InstanceState.php create mode 100644 vendor/aws/Aws/Emr/Enum/InstanceStateChangeReasonCode.php create mode 100644 vendor/aws/Aws/Emr/Enum/JobFlowExecutionState.php create mode 100644 vendor/aws/Aws/Emr/Enum/MarketType.php create mode 100644 vendor/aws/Aws/Emr/Enum/StepExecutionState.php create mode 100644 vendor/aws/Aws/Emr/Enum/StepState.php create mode 100644 vendor/aws/Aws/Emr/Enum/StepStateChangeReasonCode.php create mode 100644 vendor/aws/Aws/Emr/Exception/EmrException.php create mode 100644 vendor/aws/Aws/Emr/Exception/InternalServerErrorException.php create mode 100644 vendor/aws/Aws/Emr/Exception/InternalServerException.php create mode 100644 vendor/aws/Aws/Emr/Exception/InvalidRequestException.php create mode 100644 vendor/aws/Aws/Emr/Resources/emr-2009-03-31.php create mode 100644 vendor/aws/Aws/Glacier/Enum/Action.php create mode 100644 vendor/aws/Aws/Glacier/Enum/ActionCode.php create mode 100644 vendor/aws/Aws/Glacier/Enum/StatusCode.php create mode 100644 vendor/aws/Aws/Glacier/Exception/GlacierException.php create mode 100644 vendor/aws/Aws/Glacier/Exception/InvalidParameterValueException.php create mode 100644 vendor/aws/Aws/Glacier/Exception/LimitExceededException.php create mode 100644 vendor/aws/Aws/Glacier/Exception/MissingParameterValueException.php create mode 100644 vendor/aws/Aws/Glacier/Exception/RequestTimeoutException.php create mode 100644 vendor/aws/Aws/Glacier/Exception/ResourceNotFoundException.php create mode 100644 vendor/aws/Aws/Glacier/Exception/ServiceUnavailableException.php create mode 100644 vendor/aws/Aws/Glacier/GlacierClient.php create mode 100644 vendor/aws/Aws/Glacier/GlacierUploadListener.php create mode 100644 vendor/aws/Aws/Glacier/Model/MultipartUpload/AbstractTransfer.php create mode 100644 vendor/aws/Aws/Glacier/Model/MultipartUpload/ParallelTransfer.php create mode 100644 vendor/aws/Aws/Glacier/Model/MultipartUpload/SerialTransfer.php create mode 100644 vendor/aws/Aws/Glacier/Model/MultipartUpload/TransferState.php create mode 100644 vendor/aws/Aws/Glacier/Model/MultipartUpload/UploadBuilder.php create mode 100644 vendor/aws/Aws/Glacier/Model/MultipartUpload/UploadId.php create mode 100644 vendor/aws/Aws/Glacier/Model/MultipartUpload/UploadPart.php create mode 100644 vendor/aws/Aws/Glacier/Model/MultipartUpload/UploadPartContext.php create mode 100644 vendor/aws/Aws/Glacier/Model/MultipartUpload/UploadPartGenerator.php create mode 100644 vendor/aws/Aws/Glacier/Resources/glacier-2012-06-01.php create mode 100644 vendor/aws/Aws/Iam/Enum/AssignmentStatusType.php create mode 100644 vendor/aws/Aws/Iam/Enum/StatusType.php create mode 100644 vendor/aws/Aws/Iam/Exception/DeleteConflictException.php create mode 100644 vendor/aws/Aws/Iam/Exception/DuplicateCertificateException.php create mode 100644 vendor/aws/Aws/Iam/Exception/EntityAlreadyExistsException.php create mode 100644 vendor/aws/Aws/Iam/Exception/EntityTemporarilyUnmodifiableException.php create mode 100644 vendor/aws/Aws/Iam/Exception/IamException.php create mode 100644 vendor/aws/Aws/Iam/Exception/InvalidAuthenticationCodeException.php create mode 100644 vendor/aws/Aws/Iam/Exception/InvalidCertificateException.php create mode 100644 vendor/aws/Aws/Iam/Exception/InvalidInputException.php create mode 100644 vendor/aws/Aws/Iam/Exception/InvalidUserTypeException.php create mode 100644 vendor/aws/Aws/Iam/Exception/KeyPairMismatchException.php create mode 100644 vendor/aws/Aws/Iam/Exception/LimitExceededException.php create mode 100644 vendor/aws/Aws/Iam/Exception/MalformedCertificateException.php create mode 100644 vendor/aws/Aws/Iam/Exception/MalformedPolicyDocumentException.php create mode 100644 vendor/aws/Aws/Iam/Exception/NoSuchEntityException.php create mode 100644 vendor/aws/Aws/Iam/Exception/PasswordPolicyViolationException.php create mode 100644 vendor/aws/Aws/Iam/IamClient.php create mode 100644 vendor/aws/Aws/Iam/Resources/iam-2010-05-08.php create mode 100644 vendor/aws/Aws/ImportExport/Enum/JobType.php create mode 100644 vendor/aws/Aws/ImportExport/Exception/BucketPermissionException.php create mode 100644 vendor/aws/Aws/ImportExport/Exception/CanceledJobIdException.php create mode 100644 vendor/aws/Aws/ImportExport/Exception/ExpiredJobIdException.php create mode 100644 vendor/aws/Aws/ImportExport/Exception/ImportExportException.php create mode 100644 vendor/aws/Aws/ImportExport/Exception/InvalidAccessKeyIdException.php create mode 100644 vendor/aws/Aws/ImportExport/Exception/InvalidAddressException.php create mode 100644 vendor/aws/Aws/ImportExport/Exception/InvalidCustomsException.php create mode 100644 vendor/aws/Aws/ImportExport/Exception/InvalidFileSystemException.php create mode 100644 vendor/aws/Aws/ImportExport/Exception/InvalidJobIdException.php create mode 100644 vendor/aws/Aws/ImportExport/Exception/InvalidManifestFieldException.php create mode 100644 vendor/aws/Aws/ImportExport/Exception/InvalidParameterException.php create mode 100644 vendor/aws/Aws/ImportExport/Exception/MalformedManifestException.php create mode 100644 vendor/aws/Aws/ImportExport/Exception/MissingCustomsException.php create mode 100644 vendor/aws/Aws/ImportExport/Exception/MissingManifestFieldException.php create mode 100644 vendor/aws/Aws/ImportExport/Exception/MissingParameterException.php create mode 100644 vendor/aws/Aws/ImportExport/Exception/MultipleRegionsException.php create mode 100644 vendor/aws/Aws/ImportExport/Exception/NoSuchBucketException.php create mode 100644 vendor/aws/Aws/ImportExport/Exception/UnableToCancelJobIdException.php create mode 100644 vendor/aws/Aws/ImportExport/ImportExportClient.php create mode 100644 vendor/aws/Aws/ImportExport/JobManifestListener.php create mode 100644 vendor/aws/Aws/ImportExport/Resources/importexport-2010-06-01.php create mode 100644 vendor/aws/Aws/Kinesis/Enum/ShardIteratorType.php create mode 100644 vendor/aws/Aws/Kinesis/Enum/StreamStatus.php create mode 100644 vendor/aws/Aws/Kinesis/Exception/ExpiredIteratorException.php create mode 100644 vendor/aws/Aws/Kinesis/Exception/InvalidArgumentException.php create mode 100644 vendor/aws/Aws/Kinesis/Exception/KinesisException.php create mode 100644 vendor/aws/Aws/Kinesis/Exception/LimitExceededException.php create mode 100644 vendor/aws/Aws/Kinesis/Exception/ProvisionedThroughputExceededException.php create mode 100644 vendor/aws/Aws/Kinesis/Exception/ResourceInUseException.php create mode 100644 vendor/aws/Aws/Kinesis/Exception/ResourceNotFoundException.php create mode 100644 vendor/aws/Aws/Kinesis/KinesisClient.php create mode 100644 vendor/aws/Aws/Kinesis/Resources/kinesis-2013-12-02.php create mode 100644 vendor/aws/Aws/Kms/Exception/KmsException.php create mode 100644 vendor/aws/Aws/Kms/KmsClient.php create mode 100644 vendor/aws/Aws/Kms/Resources/kms-2014-11-01.php create mode 100644 vendor/aws/Aws/Lambda/Exception/LambdaException.php create mode 100644 vendor/aws/Aws/Lambda/LambdaClient.php create mode 100644 vendor/aws/Aws/Lambda/Resources/lambda-2014-11-11.php create mode 100644 vendor/aws/Aws/Lambda/Resources/lambda-2015-03-31.php create mode 100644 vendor/aws/Aws/MachineLearning/Exception/MachineLearningException.php create mode 100644 vendor/aws/Aws/MachineLearning/MachineLearningClient.php create mode 100644 vendor/aws/Aws/MachineLearning/PredictEndpointListener.php create mode 100644 vendor/aws/Aws/MachineLearning/Resources/machinelearning-2014-12-12.php create mode 100644 vendor/aws/Aws/OpsWorks/Enum/AppType.php create mode 100644 vendor/aws/Aws/OpsWorks/Enum/Architecture.php create mode 100644 vendor/aws/Aws/OpsWorks/Enum/AutoScalingType.php create mode 100644 vendor/aws/Aws/OpsWorks/Enum/DeploymentCommandName.php create mode 100644 vendor/aws/Aws/OpsWorks/Enum/LayerType.php create mode 100644 vendor/aws/Aws/OpsWorks/Enum/PermissionLevel.php create mode 100644 vendor/aws/Aws/OpsWorks/Enum/RootDeviceType.php create mode 100644 vendor/aws/Aws/OpsWorks/Enum/SourceType.php create mode 100644 vendor/aws/Aws/OpsWorks/Exception/OpsWorksException.php create mode 100644 vendor/aws/Aws/OpsWorks/Exception/ResourceNotFoundException.php create mode 100644 vendor/aws/Aws/OpsWorks/Exception/ValidationException.php create mode 100644 vendor/aws/Aws/OpsWorks/OpsWorksClient.php create mode 100644 vendor/aws/Aws/OpsWorks/Resources/opsworks-2013-02-18.php create mode 100644 vendor/aws/Aws/Rds/Enum/ApplyMethod.php create mode 100644 vendor/aws/Aws/Rds/Enum/SourceType.php create mode 100644 vendor/aws/Aws/Rds/Exception/AuthorizationAlreadyExistsException.php create mode 100644 vendor/aws/Aws/Rds/Exception/AuthorizationNotFoundException.php create mode 100644 vendor/aws/Aws/Rds/Exception/AuthorizationQuotaExceededException.php create mode 100644 vendor/aws/Aws/Rds/Exception/DBInstanceAlreadyExistsException.php create mode 100644 vendor/aws/Aws/Rds/Exception/DBInstanceNotFoundException.php create mode 100644 vendor/aws/Aws/Rds/Exception/DBParameterGroupAlreadyExistsException.php create mode 100644 vendor/aws/Aws/Rds/Exception/DBParameterGroupNotFoundException.php create mode 100644 vendor/aws/Aws/Rds/Exception/DBParameterGroupQuotaExceededException.php create mode 100644 vendor/aws/Aws/Rds/Exception/DBSecurityGroupAlreadyExistsException.php create mode 100644 vendor/aws/Aws/Rds/Exception/DBSecurityGroupNotFoundException.php create mode 100644 vendor/aws/Aws/Rds/Exception/DBSecurityGroupNotSupportedException.php create mode 100644 vendor/aws/Aws/Rds/Exception/DBSecurityGroupQuotaExceededException.php create mode 100644 vendor/aws/Aws/Rds/Exception/DBSnapshotAlreadyExistsException.php create mode 100644 vendor/aws/Aws/Rds/Exception/DBSnapshotNotFoundException.php create mode 100644 vendor/aws/Aws/Rds/Exception/DBSubnetGroupAlreadyExistsException.php create mode 100644 vendor/aws/Aws/Rds/Exception/DBSubnetGroupDoesNotCoverEnoughAZsException.php create mode 100644 vendor/aws/Aws/Rds/Exception/DBSubnetGroupNotAllowedException.php create mode 100644 vendor/aws/Aws/Rds/Exception/DBSubnetGroupNotFoundException.php create mode 100644 vendor/aws/Aws/Rds/Exception/DBSubnetGroupQuotaExceededException.php create mode 100644 vendor/aws/Aws/Rds/Exception/DBSubnetQuotaExceededException.php create mode 100644 vendor/aws/Aws/Rds/Exception/DBUpgradeDependencyFailureException.php create mode 100644 vendor/aws/Aws/Rds/Exception/EventSubscriptionQuotaExceededException.php create mode 100644 vendor/aws/Aws/Rds/Exception/InstanceQuotaExceededException.php create mode 100644 vendor/aws/Aws/Rds/Exception/InsufficientDBInstanceCapacityException.php create mode 100644 vendor/aws/Aws/Rds/Exception/InvalidDBInstanceStateException.php create mode 100644 vendor/aws/Aws/Rds/Exception/InvalidDBParameterGroupStateException.php create mode 100644 vendor/aws/Aws/Rds/Exception/InvalidDBSecurityGroupStateException.php create mode 100644 vendor/aws/Aws/Rds/Exception/InvalidDBSnapshotStateException.php create mode 100644 vendor/aws/Aws/Rds/Exception/InvalidDBSubnetGroupException.php create mode 100644 vendor/aws/Aws/Rds/Exception/InvalidDBSubnetGroupStateException.php create mode 100644 vendor/aws/Aws/Rds/Exception/InvalidDBSubnetStateException.php create mode 100644 vendor/aws/Aws/Rds/Exception/InvalidEventSubscriptionStateException.php create mode 100644 vendor/aws/Aws/Rds/Exception/InvalidOptionGroupStateException.php create mode 100644 vendor/aws/Aws/Rds/Exception/InvalidRestoreException.php create mode 100644 vendor/aws/Aws/Rds/Exception/InvalidSubnetException.php create mode 100644 vendor/aws/Aws/Rds/Exception/InvalidVPCNetworkStateException.php create mode 100644 vendor/aws/Aws/Rds/Exception/OptionGroupAlreadyExistsException.php create mode 100644 vendor/aws/Aws/Rds/Exception/OptionGroupNotFoundException.php create mode 100644 vendor/aws/Aws/Rds/Exception/OptionGroupQuotaExceededException.php create mode 100644 vendor/aws/Aws/Rds/Exception/PointInTimeRestoreNotEnabledException.php create mode 100644 vendor/aws/Aws/Rds/Exception/ProvisionedIopsNotAvailableInAZException.php create mode 100644 vendor/aws/Aws/Rds/Exception/RdsException.php create mode 100644 vendor/aws/Aws/Rds/Exception/ReservedDBInstanceAlreadyExistsException.php create mode 100644 vendor/aws/Aws/Rds/Exception/ReservedDBInstanceNotFoundException.php create mode 100644 vendor/aws/Aws/Rds/Exception/ReservedDBInstanceQuotaExceededException.php create mode 100644 vendor/aws/Aws/Rds/Exception/ReservedDBInstancesOfferingNotFoundException.php create mode 100644 vendor/aws/Aws/Rds/Exception/SNSInvalidTopicException.php create mode 100644 vendor/aws/Aws/Rds/Exception/SNSNoAuthorizationException.php create mode 100644 vendor/aws/Aws/Rds/Exception/SNSTopicArnNotFoundException.php create mode 100644 vendor/aws/Aws/Rds/Exception/SnapshotQuotaExceededException.php create mode 100644 vendor/aws/Aws/Rds/Exception/SourceNotFoundException.php create mode 100644 vendor/aws/Aws/Rds/Exception/StorageQuotaExceededException.php create mode 100644 vendor/aws/Aws/Rds/Exception/SubnetAlreadyInUseException.php create mode 100644 vendor/aws/Aws/Rds/Exception/SubscriptionAlreadyExistException.php create mode 100644 vendor/aws/Aws/Rds/Exception/SubscriptionCategoryNotFoundException.php create mode 100644 vendor/aws/Aws/Rds/Exception/SubscriptionNotFoundException.php create mode 100644 vendor/aws/Aws/Rds/RdsClient.php create mode 100644 vendor/aws/Aws/Rds/Resources/rds-2013-09-09.php create mode 100644 vendor/aws/Aws/Rds/Resources/rds-2014-09-01.php create mode 100644 vendor/aws/Aws/Rds/Resources/rds-2014-10-31.php create mode 100644 vendor/aws/Aws/Redshift/Enum/SourceType.php create mode 100644 vendor/aws/Aws/Redshift/Exception/AccessToSnapshotDeniedException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/AuthorizationAlreadyExistsException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/AuthorizationNotFoundException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/AuthorizationQuotaExceededException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/BucketNotFoundException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/ClusterAlreadyExistsException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/ClusterNotFoundException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/ClusterParameterGroupAlreadyExistsException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/ClusterParameterGroupNotFoundException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/ClusterParameterGroupQuotaExceededException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/ClusterQuotaExceededException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/ClusterSecurityGroupAlreadyExistsException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/ClusterSecurityGroupNotFoundException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/ClusterSecurityGroupQuotaExceededException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/ClusterSnapshotAlreadyExistsException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/ClusterSnapshotNotFoundException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/ClusterSnapshotQuotaExceededException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/ClusterSubnetGroupAlreadyExistsException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/ClusterSubnetGroupNotFoundException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/ClusterSubnetGroupQuotaExceededException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/ClusterSubnetQuotaExceededException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/CopyToRegionDisabledException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/EventSubscriptionQuotaExceededException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/HsmClientCertificateAlreadyExistsException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/HsmClientCertificateNotFoundException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/HsmClientCertificateQuotaExceededException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/HsmConfigurationAlreadyExistsException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/HsmConfigurationNotFoundException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/HsmConfigurationQuotaExceededException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/IncompatibleOrderableOptionsException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/InsufficientClusterCapacityException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/InsufficientS3BucketPolicyFaultException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/InvalidClusterParameterGroupStateException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/InvalidClusterSecurityGroupStateException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/InvalidClusterSnapshotStateException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/InvalidClusterStateException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/InvalidClusterSubnetGroupStateException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/InvalidClusterSubnetStateException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/InvalidElasticIpException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/InvalidHsmClientCertificateStateException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/InvalidHsmConfigurationStateException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/InvalidRestoreException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/InvalidS3BucketNameFaultException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/InvalidS3KeyPrefixFaultException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/InvalidSubnetException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/InvalidVPCNetworkStateException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/NumberOfNodesPerClusterLimitExceededException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/NumberOfNodesQuotaExceededException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/RedshiftException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/ReservedNodeAlreadyExistsException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/ReservedNodeNotFoundException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/ReservedNodeOfferingNotFoundException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/ReservedNodeQuotaExceededException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/ResizeNotFoundException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/SNSInvalidTopicException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/SNSNoAuthorizationException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/SNSTopicArnNotFoundException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/SnapshotCopyAlreadyDisabledException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/SnapshotCopyAlreadyEnabledException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/SnapshotCopyDisabledException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/SourceNotFoundException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/SubnetAlreadyInUseException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/SubscriptionAlreadyExistException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/SubscriptionCategoryNotFoundException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/SubscriptionEventIdNotFoundException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/SubscriptionNotFoundException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/SubscriptionSeverityNotFoundException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/UnauthorizedOperationException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/UnknownSnapshotCopyRegionException.php create mode 100644 vendor/aws/Aws/Redshift/Exception/UnsupportedOptionException.php create mode 100644 vendor/aws/Aws/Redshift/RedshiftClient.php create mode 100644 vendor/aws/Aws/Redshift/Resources/redshift-2012-12-01.php create mode 100644 vendor/aws/Aws/Route53/Enum/Action.php create mode 100644 vendor/aws/Aws/Route53/Enum/HealthCheckType.php create mode 100644 vendor/aws/Aws/Route53/Enum/RecordType.php create mode 100644 vendor/aws/Aws/Route53/Enum/ResourceRecordSetFailover.php create mode 100644 vendor/aws/Aws/Route53/Enum/Status.php create mode 100644 vendor/aws/Aws/Route53/Exception/DelegationSetNotAvailableException.php create mode 100644 vendor/aws/Aws/Route53/Exception/HealthCheckAlreadyExistsException.php create mode 100644 vendor/aws/Aws/Route53/Exception/HealthCheckInUseException.php create mode 100644 vendor/aws/Aws/Route53/Exception/HostedZoneAlreadyExistsException.php create mode 100644 vendor/aws/Aws/Route53/Exception/HostedZoneNotEmptyException.php create mode 100644 vendor/aws/Aws/Route53/Exception/IncompatibleVersionException.php create mode 100644 vendor/aws/Aws/Route53/Exception/InvalidChangeBatchException.php create mode 100644 vendor/aws/Aws/Route53/Exception/InvalidDomainNameException.php create mode 100644 vendor/aws/Aws/Route53/Exception/InvalidInputException.php create mode 100644 vendor/aws/Aws/Route53/Exception/NoSuchChangeException.php create mode 100644 vendor/aws/Aws/Route53/Exception/NoSuchHealthCheckException.php create mode 100644 vendor/aws/Aws/Route53/Exception/NoSuchHostedZoneException.php create mode 100644 vendor/aws/Aws/Route53/Exception/PriorRequestNotCompleteException.php create mode 100644 vendor/aws/Aws/Route53/Exception/Route53Exception.php create mode 100644 vendor/aws/Aws/Route53/Exception/TooManyHealthChecksException.php create mode 100644 vendor/aws/Aws/Route53/Exception/TooManyHostedZonesException.php create mode 100644 vendor/aws/Aws/Route53/Resources/route53-2013-04-01.php create mode 100644 vendor/aws/Aws/Route53/Route53Client.php create mode 100644 vendor/aws/Aws/Route53Domains/Exception/Route53DomainsException.php create mode 100644 vendor/aws/Aws/Route53Domains/Resources/route53domains-2014-05-15.php create mode 100644 vendor/aws/Aws/Route53Domains/Route53DomainsClient.php create mode 100644 vendor/aws/Aws/S3/AcpListener.php create mode 100644 vendor/aws/Aws/S3/BucketStyleListener.php create mode 100644 vendor/aws/Aws/S3/Command/S3Command.php create mode 100644 vendor/aws/Aws/S3/Enum/CannedAcl.php create mode 100644 vendor/aws/Aws/S3/Enum/EncodingType.php create mode 100644 vendor/aws/Aws/S3/Enum/Event.php create mode 100644 vendor/aws/Aws/S3/Enum/GranteeType.php create mode 100644 vendor/aws/Aws/S3/Enum/Group.php create mode 100644 vendor/aws/Aws/S3/Enum/MFADelete.php create mode 100644 vendor/aws/Aws/S3/Enum/MetadataDirective.php create mode 100644 vendor/aws/Aws/S3/Enum/Payer.php create mode 100644 vendor/aws/Aws/S3/Enum/Permission.php create mode 100644 vendor/aws/Aws/S3/Enum/Protocol.php create mode 100644 vendor/aws/Aws/S3/Enum/ServerSideEncryption.php create mode 100644 vendor/aws/Aws/S3/Enum/Status.php create mode 100644 vendor/aws/Aws/S3/Enum/Storage.php create mode 100644 vendor/aws/Aws/S3/Enum/StorageClass.php create mode 100644 vendor/aws/Aws/S3/Exception/AccessDeniedException.php create mode 100644 vendor/aws/Aws/S3/Exception/AccountProblemException.php create mode 100644 vendor/aws/Aws/S3/Exception/AmbiguousGrantByEmailAddressException.php create mode 100644 vendor/aws/Aws/S3/Exception/BadDigestException.php create mode 100644 vendor/aws/Aws/S3/Exception/BucketAlreadyExistsException.php create mode 100644 vendor/aws/Aws/S3/Exception/BucketAlreadyOwnedByYouException.php create mode 100644 vendor/aws/Aws/S3/Exception/BucketNotEmptyException.php create mode 100644 vendor/aws/Aws/S3/Exception/CredentialsNotSupportedException.php create mode 100644 vendor/aws/Aws/S3/Exception/CrossLocationLoggingProhibitedException.php create mode 100644 vendor/aws/Aws/S3/Exception/DeleteMultipleObjectsException.php create mode 100644 vendor/aws/Aws/S3/Exception/EntityTooLargeException.php create mode 100644 vendor/aws/Aws/S3/Exception/EntityTooSmallException.php create mode 100644 vendor/aws/Aws/S3/Exception/ExpiredTokenException.php create mode 100644 vendor/aws/Aws/S3/Exception/IllegalVersioningConfigurationException.php create mode 100644 vendor/aws/Aws/S3/Exception/IncompleteBodyException.php create mode 100644 vendor/aws/Aws/S3/Exception/IncorrectNumberOfFilesInPostRequestException.php create mode 100644 vendor/aws/Aws/S3/Exception/InlineDataTooLargeException.php create mode 100644 vendor/aws/Aws/S3/Exception/InternalErrorException.php create mode 100644 vendor/aws/Aws/S3/Exception/InvalidAccessKeyIdException.php create mode 100644 vendor/aws/Aws/S3/Exception/InvalidAddressingHeaderException.php create mode 100644 vendor/aws/Aws/S3/Exception/InvalidArgumentException.php create mode 100644 vendor/aws/Aws/S3/Exception/InvalidBucketNameException.php create mode 100644 vendor/aws/Aws/S3/Exception/InvalidBucketStateException.php create mode 100644 vendor/aws/Aws/S3/Exception/InvalidDigestException.php create mode 100644 vendor/aws/Aws/S3/Exception/InvalidLocationConstraintException.php create mode 100644 vendor/aws/Aws/S3/Exception/InvalidPartException.php create mode 100644 vendor/aws/Aws/S3/Exception/InvalidPartOrderException.php create mode 100644 vendor/aws/Aws/S3/Exception/InvalidPayerException.php create mode 100644 vendor/aws/Aws/S3/Exception/InvalidPolicyDocumentException.php create mode 100644 vendor/aws/Aws/S3/Exception/InvalidRangeException.php create mode 100644 vendor/aws/Aws/S3/Exception/InvalidRequestException.php create mode 100644 vendor/aws/Aws/S3/Exception/InvalidSOAPRequestException.php create mode 100644 vendor/aws/Aws/S3/Exception/InvalidSecurityException.php create mode 100644 vendor/aws/Aws/S3/Exception/InvalidStorageClassException.php create mode 100644 vendor/aws/Aws/S3/Exception/InvalidTagErrorException.php create mode 100644 vendor/aws/Aws/S3/Exception/InvalidTargetBucketForLoggingException.php create mode 100644 vendor/aws/Aws/S3/Exception/InvalidTokenException.php create mode 100644 vendor/aws/Aws/S3/Exception/InvalidURIException.php create mode 100644 vendor/aws/Aws/S3/Exception/KeyTooLongException.php create mode 100644 vendor/aws/Aws/S3/Exception/MalformedACLErrorException.php create mode 100644 vendor/aws/Aws/S3/Exception/MalformedPOSTRequestException.php create mode 100644 vendor/aws/Aws/S3/Exception/MalformedXMLException.php create mode 100644 vendor/aws/Aws/S3/Exception/MaxMessageLengthExceededException.php create mode 100644 vendor/aws/Aws/S3/Exception/MaxPostPreDataLengthExceededErrorException.php create mode 100644 vendor/aws/Aws/S3/Exception/MetadataTooLargeException.php create mode 100644 vendor/aws/Aws/S3/Exception/MethodNotAllowedException.php create mode 100644 vendor/aws/Aws/S3/Exception/MissingAttachmentException.php create mode 100644 vendor/aws/Aws/S3/Exception/MissingContentLengthException.php create mode 100644 vendor/aws/Aws/S3/Exception/MissingRequestBodyErrorException.php create mode 100644 vendor/aws/Aws/S3/Exception/MissingSecurityElementException.php create mode 100644 vendor/aws/Aws/S3/Exception/MissingSecurityHeaderException.php create mode 100644 vendor/aws/Aws/S3/Exception/NoLoggingStatusForKeyException.php create mode 100644 vendor/aws/Aws/S3/Exception/NoSuchBucketException.php create mode 100644 vendor/aws/Aws/S3/Exception/NoSuchBucketPolicyException.php create mode 100644 vendor/aws/Aws/S3/Exception/NoSuchCORSConfigurationException.php create mode 100644 vendor/aws/Aws/S3/Exception/NoSuchKeyException.php create mode 100644 vendor/aws/Aws/S3/Exception/NoSuchLifecycleConfigurationException.php create mode 100644 vendor/aws/Aws/S3/Exception/NoSuchTagSetErrorException.php create mode 100644 vendor/aws/Aws/S3/Exception/NoSuchUploadException.php create mode 100644 vendor/aws/Aws/S3/Exception/NoSuchVersionException.php create mode 100644 vendor/aws/Aws/S3/Exception/NoSuchWebsiteConfigurationException.php create mode 100644 vendor/aws/Aws/S3/Exception/NotImplementedException.php create mode 100644 vendor/aws/Aws/S3/Exception/NotSignedUpException.php create mode 100644 vendor/aws/Aws/S3/Exception/NotSuchBucketPolicyException.php create mode 100644 vendor/aws/Aws/S3/Exception/ObjectAlreadyInActiveTierErrorException.php create mode 100644 vendor/aws/Aws/S3/Exception/ObjectNotInActiveTierErrorException.php create mode 100644 vendor/aws/Aws/S3/Exception/OperationAbortedException.php create mode 100644 vendor/aws/Aws/S3/Exception/Parser/S3ExceptionParser.php create mode 100644 vendor/aws/Aws/S3/Exception/PermanentRedirectException.php create mode 100644 vendor/aws/Aws/S3/Exception/PreconditionFailedException.php create mode 100644 vendor/aws/Aws/S3/Exception/RedirectException.php create mode 100644 vendor/aws/Aws/S3/Exception/RequestIsNotMultiPartContentException.php create mode 100644 vendor/aws/Aws/S3/Exception/RequestTimeTooSkewedException.php create mode 100644 vendor/aws/Aws/S3/Exception/RequestTimeoutException.php create mode 100644 vendor/aws/Aws/S3/Exception/RequestTorrentOfBucketErrorException.php create mode 100644 vendor/aws/Aws/S3/Exception/S3Exception.php create mode 100644 vendor/aws/Aws/S3/Exception/ServiceUnavailableException.php create mode 100644 vendor/aws/Aws/S3/Exception/SignatureDoesNotMatchException.php create mode 100644 vendor/aws/Aws/S3/Exception/SlowDownException.php create mode 100644 vendor/aws/Aws/S3/Exception/TemporaryRedirectException.php create mode 100644 vendor/aws/Aws/S3/Exception/TokenRefreshRequiredException.php create mode 100644 vendor/aws/Aws/S3/Exception/TooManyBucketsException.php create mode 100644 vendor/aws/Aws/S3/Exception/UnexpectedContentException.php create mode 100644 vendor/aws/Aws/S3/Exception/UnresolvableGrantByEmailAddressException.php create mode 100644 vendor/aws/Aws/S3/Exception/UserKeyMustBeSpecifiedException.php create mode 100644 vendor/aws/Aws/S3/Iterator/ListBucketsIterator.php create mode 100644 vendor/aws/Aws/S3/Iterator/ListMultipartUploadsIterator.php create mode 100644 vendor/aws/Aws/S3/Iterator/ListObjectVersionsIterator.php create mode 100644 vendor/aws/Aws/S3/Iterator/ListObjectsIterator.php create mode 100644 vendor/aws/Aws/S3/Iterator/OpendirIterator.php create mode 100644 vendor/aws/Aws/S3/Model/Acp.php create mode 100644 vendor/aws/Aws/S3/Model/AcpBuilder.php create mode 100644 vendor/aws/Aws/S3/Model/ClearBucket.php create mode 100644 vendor/aws/Aws/S3/Model/DeleteObjectsBatch.php create mode 100644 vendor/aws/Aws/S3/Model/DeleteObjectsTransfer.php create mode 100644 vendor/aws/Aws/S3/Model/Grant.php create mode 100644 vendor/aws/Aws/S3/Model/Grantee.php create mode 100644 vendor/aws/Aws/S3/Model/MultipartUpload/AbstractTransfer.php create mode 100644 vendor/aws/Aws/S3/Model/MultipartUpload/ParallelTransfer.php create mode 100644 vendor/aws/Aws/S3/Model/MultipartUpload/SerialTransfer.php create mode 100644 vendor/aws/Aws/S3/Model/MultipartUpload/TransferState.php create mode 100644 vendor/aws/Aws/S3/Model/MultipartUpload/UploadBuilder.php create mode 100644 vendor/aws/Aws/S3/Model/MultipartUpload/UploadId.php create mode 100644 vendor/aws/Aws/S3/Model/MultipartUpload/UploadPart.php create mode 100644 vendor/aws/Aws/S3/Model/PostObject.php create mode 100644 vendor/aws/Aws/S3/Resources/s3-2006-03-01.php create mode 100644 vendor/aws/Aws/S3/ResumableDownload.php create mode 100644 vendor/aws/Aws/S3/S3Client.php create mode 100644 vendor/aws/Aws/S3/S3Md5Listener.php create mode 100644 vendor/aws/Aws/S3/S3Signature.php create mode 100644 vendor/aws/Aws/S3/S3SignatureInterface.php create mode 100644 vendor/aws/Aws/S3/S3SignatureV4.php create mode 100644 vendor/aws/Aws/S3/SocketTimeoutChecker.php create mode 100644 vendor/aws/Aws/S3/SseCpkListener.php create mode 100644 vendor/aws/Aws/S3/StreamWrapper.php create mode 100644 vendor/aws/Aws/S3/Sync/AbstractSync.php create mode 100644 vendor/aws/Aws/S3/Sync/AbstractSyncBuilder.php create mode 100644 vendor/aws/Aws/S3/Sync/ChangedFilesIterator.php create mode 100644 vendor/aws/Aws/S3/Sync/DownloadSync.php create mode 100644 vendor/aws/Aws/S3/Sync/DownloadSyncBuilder.php create mode 100644 vendor/aws/Aws/S3/Sync/FilenameConverterInterface.php create mode 100644 vendor/aws/Aws/S3/Sync/KeyConverter.php create mode 100644 vendor/aws/Aws/S3/Sync/UploadSync.php create mode 100644 vendor/aws/Aws/S3/Sync/UploadSyncBuilder.php create mode 100644 vendor/aws/Aws/Ses/Enum/IdentityType.php create mode 100644 vendor/aws/Aws/Ses/Enum/MailboxSimulator.php create mode 100644 vendor/aws/Aws/Ses/Enum/NotificationType.php create mode 100644 vendor/aws/Aws/Ses/Enum/VerificationStatus.php create mode 100644 vendor/aws/Aws/Ses/Exception/MessageRejectedException.php create mode 100644 vendor/aws/Aws/Ses/Exception/SesException.php create mode 100644 vendor/aws/Aws/Ses/Resources/ses-2010-12-01.php create mode 100644 vendor/aws/Aws/Ses/SesClient.php create mode 100644 vendor/aws/Aws/SimpleDb/Exception/AttributeDoesNotExistException.php create mode 100644 vendor/aws/Aws/SimpleDb/Exception/DuplicateItemNameException.php create mode 100644 vendor/aws/Aws/SimpleDb/Exception/InvalidNextTokenException.php create mode 100644 vendor/aws/Aws/SimpleDb/Exception/InvalidNumberPredicatesException.php create mode 100644 vendor/aws/Aws/SimpleDb/Exception/InvalidNumberValueTestsException.php create mode 100644 vendor/aws/Aws/SimpleDb/Exception/InvalidParameterValueException.php create mode 100644 vendor/aws/Aws/SimpleDb/Exception/InvalidQueryExpressionException.php create mode 100644 vendor/aws/Aws/SimpleDb/Exception/MissingParameterException.php create mode 100644 vendor/aws/Aws/SimpleDb/Exception/NoSuchDomainException.php create mode 100644 vendor/aws/Aws/SimpleDb/Exception/NumberDomainAttributesExceededException.php create mode 100644 vendor/aws/Aws/SimpleDb/Exception/NumberDomainBytesExceededException.php create mode 100644 vendor/aws/Aws/SimpleDb/Exception/NumberDomainsExceededException.php create mode 100644 vendor/aws/Aws/SimpleDb/Exception/NumberItemAttributesExceededException.php create mode 100644 vendor/aws/Aws/SimpleDb/Exception/NumberSubmittedAttributesExceededException.php create mode 100644 vendor/aws/Aws/SimpleDb/Exception/NumberSubmittedItemsExceededException.php create mode 100644 vendor/aws/Aws/SimpleDb/Exception/RequestTimeoutException.php create mode 100644 vendor/aws/Aws/SimpleDb/Exception/SimpleDbException.php create mode 100644 vendor/aws/Aws/SimpleDb/Exception/TooManyRequestedAttributesException.php create mode 100644 vendor/aws/Aws/SimpleDb/Resources/simpledb-2009-04-15.php create mode 100644 vendor/aws/Aws/SimpleDb/SimpleDbClient.php create mode 100644 vendor/aws/Aws/Sns/Exception/AuthorizationErrorException.php create mode 100644 vendor/aws/Aws/Sns/Exception/EndpointDisabledException.php create mode 100644 vendor/aws/Aws/Sns/Exception/InternalErrorException.php create mode 100644 vendor/aws/Aws/Sns/Exception/InvalidParameterException.php create mode 100644 vendor/aws/Aws/Sns/Exception/NotFoundException.php create mode 100644 vendor/aws/Aws/Sns/Exception/PlatformApplicationDisabledException.php create mode 100644 vendor/aws/Aws/Sns/Exception/SnsException.php create mode 100644 vendor/aws/Aws/Sns/Exception/SubscriptionLimitExceededException.php create mode 100644 vendor/aws/Aws/Sns/Exception/TopicLimitExceededException.php create mode 100644 vendor/aws/Aws/Sns/MessageValidator/Exception/CannotGetPublicKeyFromCertificateException.php create mode 100644 vendor/aws/Aws/Sns/MessageValidator/Exception/CertificateFromUnrecognizedSourceException.php create mode 100644 vendor/aws/Aws/Sns/MessageValidator/Exception/InvalidMessageSignatureException.php create mode 100644 vendor/aws/Aws/Sns/MessageValidator/Exception/SnsMessageValidatorException.php create mode 100644 vendor/aws/Aws/Sns/MessageValidator/Message.php create mode 100644 vendor/aws/Aws/Sns/MessageValidator/MessageValidator.php create mode 100644 vendor/aws/Aws/Sns/Resources/sns-2010-03-31.php create mode 100644 vendor/aws/Aws/Sns/SnsClient.php create mode 100644 vendor/aws/Aws/Sqs/Enum/MessageAttribute.php create mode 100644 vendor/aws/Aws/Sqs/Enum/QueueAttribute.php create mode 100644 vendor/aws/Aws/Sqs/Exception/SqsException.php create mode 100644 vendor/aws/Aws/Sqs/Md5ValidatorListener.php create mode 100644 vendor/aws/Aws/Sqs/QueueUrlListener.php create mode 100644 vendor/aws/Aws/Sqs/Resources/sqs-2012-11-05.php create mode 100644 vendor/aws/Aws/Sqs/SqsClient.php create mode 100644 vendor/aws/Aws/Ssm/Exception/SsmException.php create mode 100644 vendor/aws/Aws/Ssm/Resources/ssm-2014-11-06.php create mode 100644 vendor/aws/Aws/Ssm/SsmClient.php create mode 100644 vendor/aws/Aws/StorageGateway/Enum/BandwidthType.php create mode 100644 vendor/aws/Aws/StorageGateway/Enum/DiskAllocationType.php create mode 100644 vendor/aws/Aws/StorageGateway/Enum/ErrorCode.php create mode 100644 vendor/aws/Aws/StorageGateway/Enum/GatewayState.php create mode 100644 vendor/aws/Aws/StorageGateway/Enum/GatewayTimezone.php create mode 100644 vendor/aws/Aws/StorageGateway/Enum/GatewayType.php create mode 100644 vendor/aws/Aws/StorageGateway/Enum/VolumeStatus.php create mode 100644 vendor/aws/Aws/StorageGateway/Enum/VolumeType.php create mode 100644 vendor/aws/Aws/StorageGateway/Exception/InternalServerErrorException.php create mode 100644 vendor/aws/Aws/StorageGateway/Exception/InvalidGatewayRequestException.php create mode 100644 vendor/aws/Aws/StorageGateway/Exception/StorageGatewayException.php create mode 100644 vendor/aws/Aws/StorageGateway/Resources/storagegateway-2013-06-30.php create mode 100644 vendor/aws/Aws/StorageGateway/StorageGatewayClient.php create mode 100644 vendor/aws/Aws/Sts/Exception/ExpiredTokenException.php create mode 100644 vendor/aws/Aws/Sts/Exception/IDPCommunicationErrorException.php create mode 100644 vendor/aws/Aws/Sts/Exception/IDPRejectedClaimException.php create mode 100644 vendor/aws/Aws/Sts/Exception/IncompleteSignatureException.php create mode 100644 vendor/aws/Aws/Sts/Exception/InternalFailureException.php create mode 100644 vendor/aws/Aws/Sts/Exception/InvalidActionException.php create mode 100644 vendor/aws/Aws/Sts/Exception/InvalidAuthorizationMessageException.php create mode 100644 vendor/aws/Aws/Sts/Exception/InvalidClientTokenIdException.php create mode 100644 vendor/aws/Aws/Sts/Exception/InvalidIdentityTokenException.php create mode 100644 vendor/aws/Aws/Sts/Exception/InvalidParameterCombinationException.php create mode 100644 vendor/aws/Aws/Sts/Exception/InvalidParameterValueException.php create mode 100644 vendor/aws/Aws/Sts/Exception/InvalidQueryParameterException.php create mode 100644 vendor/aws/Aws/Sts/Exception/MalformedPolicyDocumentException.php create mode 100644 vendor/aws/Aws/Sts/Exception/MalformedQueryStringException.php create mode 100644 vendor/aws/Aws/Sts/Exception/MissingActionException.php create mode 100644 vendor/aws/Aws/Sts/Exception/MissingAuthenticationTokenException.php create mode 100644 vendor/aws/Aws/Sts/Exception/MissingParameterException.php create mode 100644 vendor/aws/Aws/Sts/Exception/OptInRequiredException.php create mode 100644 vendor/aws/Aws/Sts/Exception/PackedPolicyTooLargeException.php create mode 100644 vendor/aws/Aws/Sts/Exception/RequestExpiredException.php create mode 100644 vendor/aws/Aws/Sts/Exception/ServiceUnavailableException.php create mode 100644 vendor/aws/Aws/Sts/Exception/StsException.php create mode 100644 vendor/aws/Aws/Sts/Exception/ThrottlingException.php create mode 100644 vendor/aws/Aws/Sts/Resources/sts-2011-06-15.php create mode 100644 vendor/aws/Aws/Sts/StsClient.php create mode 100644 vendor/aws/Aws/Support/Exception/CaseCreationLimitExceededException.php create mode 100644 vendor/aws/Aws/Support/Exception/CaseIdNotFoundException.php create mode 100644 vendor/aws/Aws/Support/Exception/InternalServerErrorException.php create mode 100644 vendor/aws/Aws/Support/Exception/SupportException.php create mode 100644 vendor/aws/Aws/Support/Resources/support-2013-04-15.php create mode 100644 vendor/aws/Aws/Support/SupportClient.php create mode 100644 vendor/aws/Aws/Swf/Enum/ActivityTaskTimeoutType.php create mode 100644 vendor/aws/Aws/Swf/Enum/ChildPolicy.php create mode 100644 vendor/aws/Aws/Swf/Enum/CloseStatus.php create mode 100644 vendor/aws/Aws/Swf/Enum/DecisionTaskTimeoutType.php create mode 100644 vendor/aws/Aws/Swf/Enum/DecisionType.php create mode 100644 vendor/aws/Aws/Swf/Enum/EventType.php create mode 100644 vendor/aws/Aws/Swf/Enum/ExecutionStatus.php create mode 100644 vendor/aws/Aws/Swf/Enum/RegistrationStatus.php create mode 100644 vendor/aws/Aws/Swf/Enum/WorkflowExecutionTimeoutType.php create mode 100644 vendor/aws/Aws/Swf/Exception/DefaultUndefinedException.php create mode 100644 vendor/aws/Aws/Swf/Exception/DomainAlreadyExistsException.php create mode 100644 vendor/aws/Aws/Swf/Exception/DomainDeprecatedException.php create mode 100644 vendor/aws/Aws/Swf/Exception/LimitExceededException.php create mode 100644 vendor/aws/Aws/Swf/Exception/OperationNotPermittedException.php create mode 100644 vendor/aws/Aws/Swf/Exception/SwfException.php create mode 100644 vendor/aws/Aws/Swf/Exception/TypeAlreadyExistsException.php create mode 100644 vendor/aws/Aws/Swf/Exception/TypeDeprecatedException.php create mode 100644 vendor/aws/Aws/Swf/Exception/UnknownResourceException.php create mode 100644 vendor/aws/Aws/Swf/Exception/WorkflowExecutionAlreadyStartedException.php create mode 100644 vendor/aws/Aws/Swf/Resources/swf-2012-01-25.php create mode 100644 vendor/aws/Aws/Swf/SwfClient.php create mode 100644 vendor/aws/Aws/WorkSpaces/Exception/WorkSpacesException.php create mode 100644 vendor/aws/Aws/WorkSpaces/Resources/workspaces-2015-04-08.php create mode 100644 vendor/aws/Aws/WorkSpaces/WorkSpacesClient.php create mode 100644 vendor/aws/CHANGELOG.md create mode 100644 vendor/aws/Doctrine/Common/Cache/ApcCache.php create mode 100644 vendor/aws/Doctrine/Common/Cache/ArrayCache.php create mode 100644 vendor/aws/Doctrine/Common/Cache/Cache.php create mode 100644 vendor/aws/Doctrine/Common/Cache/CacheProvider.php create mode 100644 vendor/aws/Doctrine/Common/Cache/ChainCache.php create mode 100644 vendor/aws/Doctrine/Common/Cache/ClearableCache.php create mode 100644 vendor/aws/Doctrine/Common/Cache/CouchbaseCache.php create mode 100644 vendor/aws/Doctrine/Common/Cache/FileCache.php create mode 100644 vendor/aws/Doctrine/Common/Cache/FilesystemCache.php create mode 100644 vendor/aws/Doctrine/Common/Cache/FlushableCache.php create mode 100644 vendor/aws/Doctrine/Common/Cache/MemcacheCache.php create mode 100644 vendor/aws/Doctrine/Common/Cache/MemcachedCache.php create mode 100644 vendor/aws/Doctrine/Common/Cache/MongoDBCache.php create mode 100644 vendor/aws/Doctrine/Common/Cache/MultiGetCache.php create mode 100644 vendor/aws/Doctrine/Common/Cache/PhpFileCache.php create mode 100644 vendor/aws/Doctrine/Common/Cache/PredisCache.php create mode 100644 vendor/aws/Doctrine/Common/Cache/RedisCache.php create mode 100644 vendor/aws/Doctrine/Common/Cache/RiakCache.php create mode 100644 vendor/aws/Doctrine/Common/Cache/SQLite3Cache.php create mode 100644 vendor/aws/Doctrine/Common/Cache/Version.php create mode 100644 vendor/aws/Doctrine/Common/Cache/WinCacheCache.php create mode 100644 vendor/aws/Doctrine/Common/Cache/XcacheCache.php create mode 100644 vendor/aws/Doctrine/Common/Cache/ZendDataCache.php create mode 100644 vendor/aws/Guzzle/Batch/AbstractBatchDecorator.php create mode 100644 vendor/aws/Guzzle/Batch/Batch.php create mode 100644 vendor/aws/Guzzle/Batch/BatchBuilder.php create mode 100644 vendor/aws/Guzzle/Batch/BatchClosureDivisor.php create mode 100644 vendor/aws/Guzzle/Batch/BatchClosureTransfer.php create mode 100644 vendor/aws/Guzzle/Batch/BatchCommandTransfer.php create mode 100644 vendor/aws/Guzzle/Batch/BatchDivisorInterface.php create mode 100644 vendor/aws/Guzzle/Batch/BatchInterface.php create mode 100644 vendor/aws/Guzzle/Batch/BatchRequestTransfer.php create mode 100644 vendor/aws/Guzzle/Batch/BatchSizeDivisor.php create mode 100644 vendor/aws/Guzzle/Batch/BatchTransferInterface.php create mode 100644 vendor/aws/Guzzle/Batch/Exception/BatchTransferException.php create mode 100644 vendor/aws/Guzzle/Batch/ExceptionBufferingBatch.php create mode 100644 vendor/aws/Guzzle/Batch/FlushingBatch.php create mode 100644 vendor/aws/Guzzle/Batch/HistoryBatch.php create mode 100644 vendor/aws/Guzzle/Batch/NotifyingBatch.php create mode 100644 vendor/aws/Guzzle/Cache/AbstractCacheAdapter.php create mode 100644 vendor/aws/Guzzle/Cache/CacheAdapterFactory.php create mode 100644 vendor/aws/Guzzle/Cache/CacheAdapterInterface.php create mode 100644 vendor/aws/Guzzle/Cache/ClosureCacheAdapter.php create mode 100644 vendor/aws/Guzzle/Cache/DoctrineCacheAdapter.php create mode 100644 vendor/aws/Guzzle/Cache/NullCacheAdapter.php create mode 100644 vendor/aws/Guzzle/Cache/Zf1CacheAdapter.php create mode 100644 vendor/aws/Guzzle/Cache/Zf2CacheAdapter.php create mode 100644 vendor/aws/Guzzle/Common/AbstractHasDispatcher.php create mode 100644 vendor/aws/Guzzle/Common/Collection.php create mode 100644 vendor/aws/Guzzle/Common/Event.php create mode 100644 vendor/aws/Guzzle/Common/Exception/BadMethodCallException.php create mode 100644 vendor/aws/Guzzle/Common/Exception/ExceptionCollection.php create mode 100644 vendor/aws/Guzzle/Common/Exception/GuzzleException.php create mode 100644 vendor/aws/Guzzle/Common/Exception/InvalidArgumentException.php create mode 100644 vendor/aws/Guzzle/Common/Exception/RuntimeException.php create mode 100644 vendor/aws/Guzzle/Common/Exception/UnexpectedValueException.php create mode 100644 vendor/aws/Guzzle/Common/FromConfigInterface.php create mode 100644 vendor/aws/Guzzle/Common/HasDispatcherInterface.php create mode 100644 vendor/aws/Guzzle/Common/ToArrayInterface.php create mode 100644 vendor/aws/Guzzle/Common/Version.php create mode 100644 vendor/aws/Guzzle/Http/AbstractEntityBodyDecorator.php create mode 100644 vendor/aws/Guzzle/Http/CachingEntityBody.php create mode 100644 vendor/aws/Guzzle/Http/Client.php create mode 100644 vendor/aws/Guzzle/Http/ClientInterface.php create mode 100644 vendor/aws/Guzzle/Http/Curl/CurlHandle.php create mode 100644 vendor/aws/Guzzle/Http/Curl/CurlMulti.php create mode 100644 vendor/aws/Guzzle/Http/Curl/CurlMultiInterface.php create mode 100644 vendor/aws/Guzzle/Http/Curl/CurlMultiProxy.php create mode 100644 vendor/aws/Guzzle/Http/Curl/CurlVersion.php create mode 100644 vendor/aws/Guzzle/Http/Curl/RequestMediator.php create mode 100644 vendor/aws/Guzzle/Http/EntityBody.php create mode 100644 vendor/aws/Guzzle/Http/EntityBodyInterface.php create mode 100644 vendor/aws/Guzzle/Http/Exception/BadResponseException.php create mode 100644 vendor/aws/Guzzle/Http/Exception/ClientErrorResponseException.php create mode 100644 vendor/aws/Guzzle/Http/Exception/CouldNotRewindStreamException.php create mode 100644 vendor/aws/Guzzle/Http/Exception/CurlException.php create mode 100644 vendor/aws/Guzzle/Http/Exception/HttpException.php create mode 100644 vendor/aws/Guzzle/Http/Exception/MultiTransferException.php create mode 100644 vendor/aws/Guzzle/Http/Exception/RequestException.php create mode 100644 vendor/aws/Guzzle/Http/Exception/ServerErrorResponseException.php create mode 100644 vendor/aws/Guzzle/Http/Exception/TooManyRedirectsException.php create mode 100644 vendor/aws/Guzzle/Http/IoEmittingEntityBody.php create mode 100644 vendor/aws/Guzzle/Http/Message/AbstractMessage.php create mode 100644 vendor/aws/Guzzle/Http/Message/EntityEnclosingRequest.php create mode 100644 vendor/aws/Guzzle/Http/Message/EntityEnclosingRequestInterface.php create mode 100644 vendor/aws/Guzzle/Http/Message/Header.php create mode 100644 vendor/aws/Guzzle/Http/Message/Header/CacheControl.php create mode 100644 vendor/aws/Guzzle/Http/Message/Header/HeaderCollection.php create mode 100644 vendor/aws/Guzzle/Http/Message/Header/HeaderFactory.php create mode 100644 vendor/aws/Guzzle/Http/Message/Header/HeaderFactoryInterface.php create mode 100644 vendor/aws/Guzzle/Http/Message/Header/HeaderInterface.php create mode 100644 vendor/aws/Guzzle/Http/Message/Header/Link.php create mode 100644 vendor/aws/Guzzle/Http/Message/MessageInterface.php create mode 100644 vendor/aws/Guzzle/Http/Message/PostFile.php create mode 100644 vendor/aws/Guzzle/Http/Message/PostFileInterface.php create mode 100644 vendor/aws/Guzzle/Http/Message/Request.php create mode 100644 vendor/aws/Guzzle/Http/Message/RequestFactory.php create mode 100644 vendor/aws/Guzzle/Http/Message/RequestFactoryInterface.php create mode 100644 vendor/aws/Guzzle/Http/Message/RequestInterface.php create mode 100644 vendor/aws/Guzzle/Http/Message/Response.php create mode 100644 vendor/aws/Guzzle/Http/Mimetypes.php create mode 100644 vendor/aws/Guzzle/Http/QueryAggregator/CommaAggregator.php create mode 100644 vendor/aws/Guzzle/Http/QueryAggregator/DuplicateAggregator.php create mode 100644 vendor/aws/Guzzle/Http/QueryAggregator/PhpAggregator.php create mode 100644 vendor/aws/Guzzle/Http/QueryAggregator/QueryAggregatorInterface.php create mode 100644 vendor/aws/Guzzle/Http/QueryString.php create mode 100644 vendor/aws/Guzzle/Http/ReadLimitEntityBody.php create mode 100644 vendor/aws/Guzzle/Http/RedirectPlugin.php create mode 100644 vendor/aws/Guzzle/Http/Resources/cacert.pem create mode 100644 vendor/aws/Guzzle/Http/StaticClient.php create mode 100644 vendor/aws/Guzzle/Http/Url.php create mode 100644 vendor/aws/Guzzle/Inflection/Inflector.php create mode 100644 vendor/aws/Guzzle/Inflection/InflectorInterface.php create mode 100644 vendor/aws/Guzzle/Inflection/MemoizingInflector.php create mode 100644 vendor/aws/Guzzle/Inflection/PreComputedInflector.php create mode 100644 vendor/aws/Guzzle/Iterator/AppendIterator.php create mode 100644 vendor/aws/Guzzle/Iterator/ChunkedIterator.php create mode 100644 vendor/aws/Guzzle/Iterator/FilterIterator.php create mode 100644 vendor/aws/Guzzle/Iterator/MapIterator.php create mode 100644 vendor/aws/Guzzle/Iterator/MethodProxyIterator.php create mode 100644 vendor/aws/Guzzle/Log/AbstractLogAdapter.php create mode 100644 vendor/aws/Guzzle/Log/ArrayLogAdapter.php create mode 100644 vendor/aws/Guzzle/Log/ClosureLogAdapter.php create mode 100644 vendor/aws/Guzzle/Log/LogAdapterInterface.php create mode 100644 vendor/aws/Guzzle/Log/MessageFormatter.php create mode 100644 vendor/aws/Guzzle/Log/MonologLogAdapter.php create mode 100644 vendor/aws/Guzzle/Log/PsrLogAdapter.php create mode 100644 vendor/aws/Guzzle/Log/Zf1LogAdapter.php create mode 100644 vendor/aws/Guzzle/Log/Zf2LogAdapter.php create mode 100644 vendor/aws/Guzzle/Parser/Cookie/CookieParser.php create mode 100644 vendor/aws/Guzzle/Parser/Cookie/CookieParserInterface.php create mode 100644 vendor/aws/Guzzle/Parser/Message/AbstractMessageParser.php create mode 100644 vendor/aws/Guzzle/Parser/Message/MessageParser.php create mode 100644 vendor/aws/Guzzle/Parser/Message/MessageParserInterface.php create mode 100644 vendor/aws/Guzzle/Parser/Message/PeclHttpMessageParser.php create mode 100644 vendor/aws/Guzzle/Parser/ParserRegistry.php create mode 100644 vendor/aws/Guzzle/Parser/UriTemplate/PeclUriTemplate.php create mode 100644 vendor/aws/Guzzle/Parser/UriTemplate/UriTemplate.php create mode 100644 vendor/aws/Guzzle/Parser/UriTemplate/UriTemplateInterface.php create mode 100644 vendor/aws/Guzzle/Parser/Url/UrlParser.php create mode 100644 vendor/aws/Guzzle/Parser/Url/UrlParserInterface.php create mode 100644 vendor/aws/Guzzle/Plugin/Async/AsyncPlugin.php create mode 100644 vendor/aws/Guzzle/Plugin/Backoff/AbstractBackoffStrategy.php create mode 100644 vendor/aws/Guzzle/Plugin/Backoff/AbstractErrorCodeBackoffStrategy.php create mode 100644 vendor/aws/Guzzle/Plugin/Backoff/BackoffLogger.php create mode 100644 vendor/aws/Guzzle/Plugin/Backoff/BackoffPlugin.php create mode 100644 vendor/aws/Guzzle/Plugin/Backoff/BackoffStrategyInterface.php create mode 100644 vendor/aws/Guzzle/Plugin/Backoff/CallbackBackoffStrategy.php create mode 100644 vendor/aws/Guzzle/Plugin/Backoff/ConstantBackoffStrategy.php create mode 100644 vendor/aws/Guzzle/Plugin/Backoff/CurlBackoffStrategy.php create mode 100644 vendor/aws/Guzzle/Plugin/Backoff/ExponentialBackoffStrategy.php create mode 100644 vendor/aws/Guzzle/Plugin/Backoff/HttpBackoffStrategy.php create mode 100644 vendor/aws/Guzzle/Plugin/Backoff/LinearBackoffStrategy.php create mode 100644 vendor/aws/Guzzle/Plugin/Backoff/ReasonPhraseBackoffStrategy.php create mode 100644 vendor/aws/Guzzle/Plugin/Backoff/TruncatedBackoffStrategy.php create mode 100644 vendor/aws/Guzzle/Plugin/Cache/CacheKeyProviderInterface.php create mode 100644 vendor/aws/Guzzle/Plugin/Cache/CachePlugin.php create mode 100644 vendor/aws/Guzzle/Plugin/Cache/CacheStorageInterface.php create mode 100644 vendor/aws/Guzzle/Plugin/Cache/CallbackCanCacheStrategy.php create mode 100644 vendor/aws/Guzzle/Plugin/Cache/CanCacheStrategyInterface.php create mode 100644 vendor/aws/Guzzle/Plugin/Cache/DefaultCacheKeyProvider.php create mode 100644 vendor/aws/Guzzle/Plugin/Cache/DefaultCacheStorage.php create mode 100644 vendor/aws/Guzzle/Plugin/Cache/DefaultCanCacheStrategy.php create mode 100644 vendor/aws/Guzzle/Plugin/Cache/DefaultRevalidation.php create mode 100644 vendor/aws/Guzzle/Plugin/Cache/DenyRevalidation.php create mode 100644 vendor/aws/Guzzle/Plugin/Cache/RevalidationInterface.php create mode 100644 vendor/aws/Guzzle/Plugin/Cache/SkipRevalidation.php create mode 100644 vendor/aws/Guzzle/Plugin/Cookie/Cookie.php create mode 100644 vendor/aws/Guzzle/Plugin/Cookie/CookieJar/ArrayCookieJar.php create mode 100644 vendor/aws/Guzzle/Plugin/Cookie/CookieJar/CookieJarInterface.php create mode 100644 vendor/aws/Guzzle/Plugin/Cookie/CookieJar/FileCookieJar.php create mode 100644 vendor/aws/Guzzle/Plugin/Cookie/CookiePlugin.php create mode 100644 vendor/aws/Guzzle/Plugin/Cookie/Exception/InvalidCookieException.php create mode 100644 vendor/aws/Guzzle/Plugin/CurlAuth/CurlAuthPlugin.php create mode 100644 vendor/aws/Guzzle/Plugin/ErrorResponse/ErrorResponseExceptionInterface.php create mode 100644 vendor/aws/Guzzle/Plugin/ErrorResponse/ErrorResponsePlugin.php create mode 100644 vendor/aws/Guzzle/Plugin/ErrorResponse/Exception/ErrorResponseException.php create mode 100644 vendor/aws/Guzzle/Plugin/History/HistoryPlugin.php create mode 100644 vendor/aws/Guzzle/Plugin/Log/LogPlugin.php create mode 100644 vendor/aws/Guzzle/Plugin/Md5/CommandContentMd5Plugin.php create mode 100644 vendor/aws/Guzzle/Plugin/Md5/Md5ValidatorPlugin.php create mode 100644 vendor/aws/Guzzle/Plugin/Mock/MockPlugin.php create mode 100644 vendor/aws/Guzzle/Plugin/Oauth/OauthPlugin.php create mode 100644 vendor/aws/Guzzle/Service/AbstractConfigLoader.php create mode 100644 vendor/aws/Guzzle/Service/Builder/ServiceBuilder.php create mode 100644 vendor/aws/Guzzle/Service/Builder/ServiceBuilderInterface.php create mode 100644 vendor/aws/Guzzle/Service/Builder/ServiceBuilderLoader.php create mode 100644 vendor/aws/Guzzle/Service/CachingConfigLoader.php create mode 100644 vendor/aws/Guzzle/Service/Client.php create mode 100644 vendor/aws/Guzzle/Service/ClientInterface.php create mode 100644 vendor/aws/Guzzle/Service/Command/AbstractCommand.php create mode 100644 vendor/aws/Guzzle/Service/Command/ClosureCommand.php create mode 100644 vendor/aws/Guzzle/Service/Command/CommandInterface.php create mode 100644 vendor/aws/Guzzle/Service/Command/CreateResponseClassEvent.php create mode 100644 vendor/aws/Guzzle/Service/Command/DefaultRequestSerializer.php create mode 100644 vendor/aws/Guzzle/Service/Command/DefaultResponseParser.php create mode 100644 vendor/aws/Guzzle/Service/Command/Factory/AliasFactory.php create mode 100644 vendor/aws/Guzzle/Service/Command/Factory/CompositeFactory.php create mode 100644 vendor/aws/Guzzle/Service/Command/Factory/ConcreteClassFactory.php create mode 100644 vendor/aws/Guzzle/Service/Command/Factory/FactoryInterface.php create mode 100644 vendor/aws/Guzzle/Service/Command/Factory/MapFactory.php create mode 100644 vendor/aws/Guzzle/Service/Command/Factory/ServiceDescriptionFactory.php create mode 100644 vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/AbstractRequestVisitor.php create mode 100644 vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/BodyVisitor.php create mode 100644 vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/HeaderVisitor.php create mode 100644 vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/JsonVisitor.php create mode 100644 vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/PostFieldVisitor.php create mode 100644 vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/PostFileVisitor.php create mode 100644 vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/QueryVisitor.php create mode 100644 vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/RequestVisitorInterface.php create mode 100644 vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/ResponseBodyVisitor.php create mode 100644 vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/XmlVisitor.php create mode 100644 vendor/aws/Guzzle/Service/Command/LocationVisitor/Response/AbstractResponseVisitor.php create mode 100644 vendor/aws/Guzzle/Service/Command/LocationVisitor/Response/BodyVisitor.php create mode 100644 vendor/aws/Guzzle/Service/Command/LocationVisitor/Response/HeaderVisitor.php create mode 100644 vendor/aws/Guzzle/Service/Command/LocationVisitor/Response/JsonVisitor.php create mode 100644 vendor/aws/Guzzle/Service/Command/LocationVisitor/Response/ReasonPhraseVisitor.php create mode 100644 vendor/aws/Guzzle/Service/Command/LocationVisitor/Response/ResponseVisitorInterface.php create mode 100644 vendor/aws/Guzzle/Service/Command/LocationVisitor/Response/StatusCodeVisitor.php create mode 100644 vendor/aws/Guzzle/Service/Command/LocationVisitor/Response/XmlVisitor.php create mode 100644 vendor/aws/Guzzle/Service/Command/LocationVisitor/VisitorFlyweight.php create mode 100644 vendor/aws/Guzzle/Service/Command/OperationCommand.php create mode 100644 vendor/aws/Guzzle/Service/Command/OperationResponseParser.php create mode 100644 vendor/aws/Guzzle/Service/Command/RequestSerializerInterface.php create mode 100644 vendor/aws/Guzzle/Service/Command/ResponseClassInterface.php create mode 100644 vendor/aws/Guzzle/Service/Command/ResponseParserInterface.php create mode 100644 vendor/aws/Guzzle/Service/ConfigLoaderInterface.php create mode 100644 vendor/aws/Guzzle/Service/Description/Operation.php create mode 100644 vendor/aws/Guzzle/Service/Description/OperationInterface.php create mode 100644 vendor/aws/Guzzle/Service/Description/Parameter.php create mode 100644 vendor/aws/Guzzle/Service/Description/SchemaFormatter.php create mode 100644 vendor/aws/Guzzle/Service/Description/SchemaValidator.php create mode 100644 vendor/aws/Guzzle/Service/Description/ServiceDescription.php create mode 100644 vendor/aws/Guzzle/Service/Description/ServiceDescriptionInterface.php create mode 100644 vendor/aws/Guzzle/Service/Description/ServiceDescriptionLoader.php create mode 100644 vendor/aws/Guzzle/Service/Description/ValidatorInterface.php create mode 100644 vendor/aws/Guzzle/Service/Exception/CommandException.php create mode 100644 vendor/aws/Guzzle/Service/Exception/CommandTransferException.php create mode 100644 vendor/aws/Guzzle/Service/Exception/DescriptionBuilderException.php create mode 100644 vendor/aws/Guzzle/Service/Exception/InconsistentClientTransferException.php create mode 100644 vendor/aws/Guzzle/Service/Exception/ResponseClassException.php create mode 100644 vendor/aws/Guzzle/Service/Exception/ServiceBuilderException.php create mode 100644 vendor/aws/Guzzle/Service/Exception/ServiceNotFoundException.php create mode 100644 vendor/aws/Guzzle/Service/Exception/ValidationException.php create mode 100644 vendor/aws/Guzzle/Service/Resource/AbstractResourceIteratorFactory.php create mode 100644 vendor/aws/Guzzle/Service/Resource/CompositeResourceIteratorFactory.php create mode 100644 vendor/aws/Guzzle/Service/Resource/MapResourceIteratorFactory.php create mode 100644 vendor/aws/Guzzle/Service/Resource/Model.php create mode 100644 vendor/aws/Guzzle/Service/Resource/ResourceIterator.php create mode 100644 vendor/aws/Guzzle/Service/Resource/ResourceIteratorApplyBatched.php create mode 100644 vendor/aws/Guzzle/Service/Resource/ResourceIteratorClassFactory.php create mode 100644 vendor/aws/Guzzle/Service/Resource/ResourceIteratorFactoryInterface.php create mode 100644 vendor/aws/Guzzle/Service/Resource/ResourceIteratorInterface.php create mode 100644 vendor/aws/Guzzle/Stream/PhpStreamRequestFactory.php create mode 100644 vendor/aws/Guzzle/Stream/Stream.php create mode 100644 vendor/aws/Guzzle/Stream/StreamInterface.php create mode 100644 vendor/aws/Guzzle/Stream/StreamRequestFactoryInterface.php create mode 100644 vendor/aws/LICENSE.md create mode 100644 vendor/aws/Monolog/ErrorHandler.php create mode 100644 vendor/aws/Monolog/Formatter/ChromePHPFormatter.php create mode 100644 vendor/aws/Monolog/Formatter/ElasticaFormatter.php create mode 100644 vendor/aws/Monolog/Formatter/FlowdockFormatter.php create mode 100644 vendor/aws/Monolog/Formatter/FormatterInterface.php create mode 100644 vendor/aws/Monolog/Formatter/GelfMessageFormatter.php create mode 100644 vendor/aws/Monolog/Formatter/HtmlFormatter.php create mode 100644 vendor/aws/Monolog/Formatter/JsonFormatter.php create mode 100644 vendor/aws/Monolog/Formatter/LineFormatter.php create mode 100644 vendor/aws/Monolog/Formatter/LogglyFormatter.php create mode 100644 vendor/aws/Monolog/Formatter/LogstashFormatter.php create mode 100644 vendor/aws/Monolog/Formatter/MongoDBFormatter.php create mode 100644 vendor/aws/Monolog/Formatter/NormalizerFormatter.php create mode 100644 vendor/aws/Monolog/Formatter/ScalarFormatter.php create mode 100644 vendor/aws/Monolog/Formatter/WildfireFormatter.php create mode 100644 vendor/aws/Monolog/Handler/AbstractHandler.php create mode 100644 vendor/aws/Monolog/Handler/AbstractProcessingHandler.php create mode 100644 vendor/aws/Monolog/Handler/AbstractSyslogHandler.php create mode 100644 vendor/aws/Monolog/Handler/AmqpHandler.php create mode 100644 vendor/aws/Monolog/Handler/BrowserConsoleHandler.php create mode 100644 vendor/aws/Monolog/Handler/BufferHandler.php create mode 100644 vendor/aws/Monolog/Handler/ChromePHPHandler.php create mode 100644 vendor/aws/Monolog/Handler/CouchDBHandler.php create mode 100644 vendor/aws/Monolog/Handler/CubeHandler.php create mode 100644 vendor/aws/Monolog/Handler/DoctrineCouchDBHandler.php create mode 100644 vendor/aws/Monolog/Handler/DynamoDbHandler.php create mode 100644 vendor/aws/Monolog/Handler/ElasticSearchHandler.php create mode 100644 vendor/aws/Monolog/Handler/ErrorLogHandler.php create mode 100644 vendor/aws/Monolog/Handler/ExceptionTestHandler.php create mode 100644 vendor/aws/Monolog/Handler/FilterHandler.php create mode 100644 vendor/aws/Monolog/Handler/FingersCrossed/ActivationStrategyInterface.php create mode 100644 vendor/aws/Monolog/Handler/FingersCrossed/ChannelLevelActivationStrategy.php create mode 100644 vendor/aws/Monolog/Handler/FingersCrossed/ErrorLevelActivationStrategy.php create mode 100644 vendor/aws/Monolog/Handler/FingersCrossedHandler.php create mode 100644 vendor/aws/Monolog/Handler/FirePHPHandler.php create mode 100644 vendor/aws/Monolog/Handler/FleepHookHandler.php create mode 100644 vendor/aws/Monolog/Handler/FlowdockHandler.php create mode 100644 vendor/aws/Monolog/Handler/GelfHandler.php create mode 100644 vendor/aws/Monolog/Handler/GroupHandler.php create mode 100644 vendor/aws/Monolog/Handler/HandlerInterface.php create mode 100644 vendor/aws/Monolog/Handler/HipChatHandler.php create mode 100644 vendor/aws/Monolog/Handler/LogEntriesHandler.php create mode 100644 vendor/aws/Monolog/Handler/LogglyHandler.php create mode 100644 vendor/aws/Monolog/Handler/MailHandler.php create mode 100644 vendor/aws/Monolog/Handler/MandrillHandler.php create mode 100644 vendor/aws/Monolog/Handler/MissingExtensionException.php create mode 100644 vendor/aws/Monolog/Handler/MongoDBHandler.php create mode 100644 vendor/aws/Monolog/Handler/NativeMailerHandler.php create mode 100644 vendor/aws/Monolog/Handler/NewRelicHandler.php create mode 100644 vendor/aws/Monolog/Handler/NullHandler.php create mode 100644 vendor/aws/Monolog/Handler/PsrHandler.php create mode 100644 vendor/aws/Monolog/Handler/PushoverHandler.php create mode 100644 vendor/aws/Monolog/Handler/RavenHandler.php create mode 100644 vendor/aws/Monolog/Handler/RedisHandler.php create mode 100644 vendor/aws/Monolog/Handler/RollbarHandler.php create mode 100644 vendor/aws/Monolog/Handler/RotatingFileHandler.php create mode 100644 vendor/aws/Monolog/Handler/SamplingHandler.php create mode 100644 vendor/aws/Monolog/Handler/SlackHandler.php create mode 100644 vendor/aws/Monolog/Handler/SocketHandler.php create mode 100644 vendor/aws/Monolog/Handler/StreamHandler.php create mode 100644 vendor/aws/Monolog/Handler/SwiftMailerHandler.php create mode 100644 vendor/aws/Monolog/Handler/SyslogHandler.php create mode 100644 vendor/aws/Monolog/Handler/SyslogUdp/UdpSocket.php create mode 100644 vendor/aws/Monolog/Handler/SyslogUdpHandler.php create mode 100644 vendor/aws/Monolog/Handler/TestHandler.php create mode 100644 vendor/aws/Monolog/Handler/WhatFailureGroupHandler.php create mode 100644 vendor/aws/Monolog/Handler/ZendMonitorHandler.php create mode 100644 vendor/aws/Monolog/Logger.php create mode 100644 vendor/aws/Monolog/Processor/GitProcessor.php create mode 100644 vendor/aws/Monolog/Processor/IntrospectionProcessor.php create mode 100644 vendor/aws/Monolog/Processor/MemoryPeakUsageProcessor.php create mode 100644 vendor/aws/Monolog/Processor/MemoryProcessor.php create mode 100644 vendor/aws/Monolog/Processor/MemoryUsageProcessor.php create mode 100644 vendor/aws/Monolog/Processor/ProcessIdProcessor.php create mode 100644 vendor/aws/Monolog/Processor/PsrLogMessageProcessor.php create mode 100644 vendor/aws/Monolog/Processor/TagProcessor.php create mode 100644 vendor/aws/Monolog/Processor/UidProcessor.php create mode 100644 vendor/aws/Monolog/Processor/WebProcessor.php create mode 100644 vendor/aws/Monolog/Registry.php create mode 100644 vendor/aws/NOTICE.md create mode 100644 vendor/aws/Psr/Log/AbstractLogger.php create mode 100644 vendor/aws/Psr/Log/InvalidArgumentException.php create mode 100644 vendor/aws/Psr/Log/LogLevel.php create mode 100644 vendor/aws/Psr/Log/LoggerAwareInterface.php create mode 100644 vendor/aws/Psr/Log/LoggerAwareTrait.php create mode 100644 vendor/aws/Psr/Log/LoggerInterface.php create mode 100644 vendor/aws/Psr/Log/LoggerTrait.php create mode 100644 vendor/aws/Psr/Log/NullLogger.php create mode 100644 vendor/aws/Psr/Log/Test/LoggerInterfaceTest.php create mode 100644 vendor/aws/README.md create mode 100644 vendor/aws/Symfony/Component/EventDispatcher/ContainerAwareEventDispatcher.php create mode 100644 vendor/aws/Symfony/Component/EventDispatcher/Debug/TraceableEventDispatcher.php create mode 100644 vendor/aws/Symfony/Component/EventDispatcher/Debug/TraceableEventDispatcherInterface.php create mode 100644 vendor/aws/Symfony/Component/EventDispatcher/Debug/WrappedListener.php create mode 100644 vendor/aws/Symfony/Component/EventDispatcher/DependencyInjection/RegisterListenersPass.php create mode 100644 vendor/aws/Symfony/Component/EventDispatcher/Event.php create mode 100644 vendor/aws/Symfony/Component/EventDispatcher/EventDispatcher.php create mode 100644 vendor/aws/Symfony/Component/EventDispatcher/EventDispatcherInterface.php create mode 100644 vendor/aws/Symfony/Component/EventDispatcher/EventSubscriberInterface.php create mode 100644 vendor/aws/Symfony/Component/EventDispatcher/GenericEvent.php create mode 100644 vendor/aws/Symfony/Component/EventDispatcher/ImmutableEventDispatcher.php create mode 100644 vendor/aws/Symfony/Component/EventDispatcher/LICENSE create mode 100644 vendor/aws/Symfony/Component/EventDispatcher/Tests/AbstractEventDispatcherTest.php create mode 100644 vendor/aws/Symfony/Component/EventDispatcher/Tests/ContainerAwareEventDispatcherTest.php create mode 100644 vendor/aws/Symfony/Component/EventDispatcher/Tests/Debug/TraceableEventDispatcherTest.php create mode 100644 vendor/aws/Symfony/Component/EventDispatcher/Tests/DependencyInjection/RegisterListenersPassTest.php create mode 100644 vendor/aws/Symfony/Component/EventDispatcher/Tests/EventDispatcherTest.php create mode 100644 vendor/aws/Symfony/Component/EventDispatcher/Tests/EventTest.php create mode 100644 vendor/aws/Symfony/Component/EventDispatcher/Tests/GenericEventTest.php create mode 100644 vendor/aws/Symfony/Component/EventDispatcher/Tests/ImmutableEventDispatcherTest.php create mode 100644 vendor/aws/aws-autoloader.php diff --git a/aeria.php b/aeria.php index 7187728..d0ab53d 100755 --- a/aeria.php +++ b/aeria.php @@ -5,14 +5,14 @@ * Author: Caffeina Srl * Author URI: http://caffeina.co * Plugin URI: https://github.com/CaffeinaLab/aeria - * Version: 1.5.1 + * Version: 1.5.2 */ // Exit if accessed directly if( false === defined('ABSPATH') ) exit; // The Framework version -define('AERIA','1.5.1'); +define('AERIA','1.5.2'); // Store whether or not we're in the admin if( false === defined('IS_ADMIN') ) define( 'IS_ADMIN', is_admin() ); diff --git a/classes/AeriaSES.php b/classes/AeriaSES.php index ff1f30a..361d577 100755 --- a/classes/AeriaSES.php +++ b/classes/AeriaSES.php @@ -1,11 +1,14 @@ phpmailer = $phpmailer; } + public function Send() { // Build the raw email $this->phpmailer->preSend(); @@ -23,20 +26,23 @@ public function Send() { } } } + class AeriaSES { public static $client = null; public static $config = []; + public static function init($key, $secret, $region) { + require __DIR__.'/../vendor/aws/aws-autoloader.php'; static::$config = array( 'key' => $key, 'secret' => $secret, 'region' => $region ); } + public static function enable() { add_action('phpmailer_init', function(&$phpmailer) { if (static::$client == null) { - require __DIR__.'/../vendor/aws.phar'; static::$client = Aws\Ses\SesClient::factory(static::$config); } $phpmailer = new SesClientProxyForPHPMailer($phpmailer); diff --git a/metadata.json b/metadata.json index 0c89161..fa428d3 100755 --- a/metadata.json +++ b/metadata.json @@ -3,7 +3,7 @@ "slug": "aeria", "homepage": "http://labs.caffeina.co/tech/aeria", "download_url": "https://github.com/CaffeinaLab/aeria/archive/master.zip", - "version": "1.5.1", + "version": "1.5.2", "requires": "3.5", "tested": "4.0", "last_updated": "2015-03-17 12:30:00", diff --git a/vendor/aws.phar b/vendor/aws.phar deleted file mode 100755 index 036aa8f9ffdde1f5e21ca23d8e6438df9432d788..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 8637413 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 z sX+$@2VoLbN0JvE<~+Nbs)@Plv-Zu>!S?3bbx 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

`2O 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
^QqD`d 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

E*s(?hLi61 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

joa6 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 z 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 UKmXf%|II)A!#_NJ_~haL4+d6IH~;_u diff --git a/vendor/aws/Aws/AutoScaling/AutoScalingClient.php b/vendor/aws/Aws/AutoScaling/AutoScalingClient.php new file mode 100644 index 0000000..499109f --- /dev/null +++ b/vendor/aws/Aws/AutoScaling/AutoScalingClient.php @@ -0,0 +1,108 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/autoscaling-%s.php' + )) + ->build(); + } +} diff --git a/vendor/aws/Aws/AutoScaling/Enum/LifecycleState.php b/vendor/aws/Aws/AutoScaling/Enum/LifecycleState.php new file mode 100644 index 0000000..439a02f --- /dev/null +++ b/vendor/aws/Aws/AutoScaling/Enum/LifecycleState.php @@ -0,0 +1,31 @@ + '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, + ), + ), + ), + 'CompleteLifecycleAction' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CompleteLifecycleAction', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'LifecycleHookName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'AutoScalingGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + 'LifecycleActionToken' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 36, + 'maxLength' => 36, + ), + 'LifecycleActionResult' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + ), + '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' => 'You already have an Auto Scaling group or launch configuration with this name.', + 'class' => 'AlreadyExistsException', + ), + array( + 'reason' => 'The limit for the number of Auto Scaling groups or launch configurations 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', + ), + ), + 'ClassicLinkVPCId' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'ClassicLinkVPCSecurityGroups' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'ClassicLinkVPCSecurityGroups.member', + 'items' => array( + 'name' => 'XmlStringMaxLen255', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + ), + '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' => 16384, + ), + 'VolumeType' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'DeleteOnTermination' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'Iops' => array( + 'type' => 'numeric', + 'minimum' => 100, + 'maximum' => 30000, + ), + ), + ), + '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', + ), + 'PlacementTenancy' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 64, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'You already have an Auto Scaling group or launch configuration with this name.', + 'class' => 'AlreadyExistsException', + ), + array( + 'reason' => 'The limit for the number of Auto Scaling groups or launch configurations 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 limit for the number of Auto Scaling groups or launch configurations has already been reached.', + 'class' => 'LimitExceededException', + ), + array( + 'reason' => 'You already have an Auto Scaling group or launch configuration with this name.', + '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' => 'The Auto Scaling group can\'t be deleted because there are scaling activities in progress.', + 'class' => 'ScalingActivityInProgressException', + ), + array( + 'reason' => 'The Auto Scaling group or launch configuration can\'t be deleted because it is in use.', + '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' => 'The Auto Scaling group or launch configuration can\'t be deleted because it is in use.', + 'class' => 'ResourceInUseException', + ), + ), + ), + 'DeleteLifecycleHook' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteLifecycleHook', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'LifecycleHookName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'AutoScalingGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + ), + ), + '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', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The NextToken value is not valid.', + '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', + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The NextToken value is not valid.', + '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', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The NextToken value is not valid.', + 'class' => 'InvalidNextTokenException', + ), + ), + ), + 'DescribeLifecycleHookTypes' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DescribeLifecycleHookTypesAnswer', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeLifecycleHookTypes', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + ), + ), + 'DescribeLifecycleHooks' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DescribeLifecycleHooksAnswer', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeLifecycleHooks', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'AutoScalingGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + 'LifecycleHookNames' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'LifecycleHookNames.member', + 'items' => array( + 'name' => 'AsciiStringMaxLen255', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + ), + ), + ), + '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', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The NextToken value is not valid.', + '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', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The NextToken value is not valid.', + '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', + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The NextToken value is not valid.', + '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', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The NextToken value is not valid.', + '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', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The NextToken value is not valid.', + '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', + ), + ), + ), + 'DetachInstances' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DetachInstancesAnswer', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DetachInstances', + ), + '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, + ), + 'ShouldDecrementDesiredCapacity' => array( + 'required' => true, + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + ), + ), + '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, + ), + ), + ), + 'EnterStandby' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EnterStandbyAnswer', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'EnterStandby', + ), + '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, + ), + 'ShouldDecrementDesiredCapacity' => array( + 'required' => true, + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + ), + ), + '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' => 'The Auto Scaling group can\'t be deleted because there are scaling activities in progress.', + 'class' => 'ScalingActivityInProgressException', + ), + ), + ), + 'ExitStandby' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ExitStandbyAnswer', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ExitStandby', + ), + '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, + ), + ), + ), + 'PutLifecycleHook' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'PutLifecycleHook', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'LifecycleHookName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'AutoScalingGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + 'LifecycleTransition' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'RoleARN' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + 'NotificationTargetARN' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + 'NotificationMetadata' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1023, + ), + 'HeartbeatTimeout' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'DefaultResult' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The limit for the number of Auto Scaling groups or launch configurations has already been reached.', + 'class' => 'LimitExceededException', + ), + ), + ), + '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 limit for the number of Auto Scaling groups or launch configurations 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 limit for the number of Auto Scaling groups or launch configurations 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' => 'You already have an Auto Scaling group or launch configuration with this name.', + 'class' => 'AlreadyExistsException', + ), + array( + 'reason' => 'The limit for the number of Auto Scaling groups or launch configurations has already been reached.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'RecordLifecycleActionHeartbeat' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'RecordLifecycleActionHeartbeat', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'LifecycleHookName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'AutoScalingGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + 'LifecycleActionToken' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 36, + 'maxLength' => 36, + ), + ), + ), + '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' => 'The Auto Scaling group can\'t be deleted because there are scaling activities in progress.', + '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' => 'The Auto Scaling group can\'t be deleted because there are scaling activities in progress.', + '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' => 'The Auto Scaling group can\'t be deleted because there are scaling activities in progress.', + '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', + ), + ), + 'ClassicLinkVPCId' => array( + 'type' => 'string', + ), + 'ClassicLinkVPCSecurityGroups' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'XmlStringMaxLen255', + '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', + ), + 'PlacementTenancy' => array( + 'type' => 'string', + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'DescribeLifecycleHookTypesAnswer' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'LifecycleHookTypes' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'XmlStringMaxLen255', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + ), + ), + 'DescribeLifecycleHooksAnswer' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'LifecycleHooks' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'LifecycleHook', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'LifecycleHookName' => array( + 'type' => 'string', + ), + 'AutoScalingGroupName' => array( + 'type' => 'string', + ), + 'LifecycleTransition' => array( + 'type' => 'string', + ), + 'NotificationTargetARN' => array( + 'type' => 'string', + ), + 'RoleARN' => array( + 'type' => 'string', + ), + 'NotificationMetadata' => array( + 'type' => 'string', + ), + 'HeartbeatTimeout' => array( + 'type' => 'numeric', + ), + 'GlobalTimeout' => array( + 'type' => 'numeric', + ), + 'DefaultResult' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + ), + 'DetachInstancesAnswer' => 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', + ), + ), + ), + ), + ), + ), + 'EnterStandbyAnswer' => 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', + ), + ), + ), + ), + ), + ), + 'ExitStandbyAnswer' => 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', + ), + ), + ), + ), + ), + ), + '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( + 'DescribeAutoScalingGroups' => array( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'limit_key' => 'MaxRecords', + 'result_key' => 'AutoScalingGroups', + ), + 'DescribeAutoScalingInstances' => array( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'limit_key' => 'MaxRecords', + 'result_key' => 'AutoScalingInstances', + ), + 'DescribeLaunchConfigurations' => array( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'limit_key' => 'MaxRecords', + 'result_key' => 'LaunchConfigurations', + ), + 'DescribeNotificationConfigurations' => array( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'limit_key' => 'MaxRecords', + 'result_key' => 'NotificationConfigurations', + ), + 'DescribePolicies' => array( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'limit_key' => 'MaxRecords', + 'result_key' => 'ScalingPolicies', + ), + 'DescribeScalingActivities' => array( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'limit_key' => 'MaxRecords', + 'result_key' => 'Activities', + ), + 'DescribeScheduledActions' => array( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'limit_key' => 'MaxRecords', + 'result_key' => 'ScheduledUpdateGroupActions', + ), + 'DescribeTags' => array( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'limit_key' => 'MaxRecords', + 'result_key' => 'Tags', + ), + ), +); diff --git a/vendor/aws/Aws/CloudFormation/CloudFormationClient.php b/vendor/aws/Aws/CloudFormation/CloudFormationClient.php new file mode 100644 index 0000000..df983f9 --- /dev/null +++ b/vendor/aws/Aws/CloudFormation/CloudFormationClient.php @@ -0,0 +1,77 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/cloudformation-%s.php' + )) + ->build(); + } +} diff --git a/vendor/aws/Aws/CloudFormation/Enum/Capability.php b/vendor/aws/Aws/CloudFormation/Enum/Capability.php new file mode 100644 index 0000000..a89a4d8 --- /dev/null +++ b/vendor/aws/Aws/CloudFormation/Enum/Capability.php @@ -0,0 +1,27 @@ + '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', + ), + 'UsePreviousValue' => array( + 'type' => 'boolean', + 'format' => 'boolean-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', + ), + 'UsePreviousValue' => array( + 'type' => 'boolean', + 'format' => 'boolean-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', + ), + ), + ), + 'GetTemplateSummary' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'GetTemplateSummaryOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'GetTemplateSummary', + ), + '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, + ), + 'StackName' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + ), + ), + ), + '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, + ), + ), + ), + 'SignalResource' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'SignalResource', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-15', + ), + 'StackName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + ), + 'LogicalResourceId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'UniqueId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'Status' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + ), + '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, + ), + 'UsePreviousTemplate' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + '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', + ), + 'UsePreviousValue' => array( + 'type' => 'boolean', + 'format' => 'boolean-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, + ), + 'NotificationARNs' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'NotificationARNs.member', + 'maxItems' => 5, + 'items' => array( + 'name' => 'NotificationARN', + 'type' => 'string', + ), + ), + ), + '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', + ), + 'UsePreviousValue' => array( + 'type' => 'boolean', + ), + ), + ), + ), + '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', + ), + ), + ), + 'GetTemplateSummaryOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Parameters' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'ParameterDeclaration', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'ParameterKey' => array( + 'type' => 'string', + ), + 'DefaultValue' => array( + 'type' => 'string', + ), + 'ParameterType' => 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', + ), + 'Version' => 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( + 'DescribeStackEvents' => array( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'result_key' => 'StackEvents', + ), + 'DescribeStackResources' => array( + 'result_key' => 'StackResources', + ), + 'DescribeStacks' => array( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'result_key' => 'Stacks', + ), + 'ListStackResources' => array( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'result_key' => 'StackResourceSummaries', + ), + 'ListStacks' => array( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'result_key' => 'StackSummaries', + ), + ), +); diff --git a/vendor/aws/Aws/CloudFront/CloudFrontClient.php b/vendor/aws/Aws/CloudFront/CloudFrontClient.php new file mode 100644 index 0000000..031cf04 --- /dev/null +++ b/vendor/aws/Aws/CloudFront/CloudFrontClient.php @@ -0,0 +1,234 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/cloudfront-%s.php', + )) + ->setExceptionParser(new DefaultXmlExceptionParser()) + ->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'], '/\\'); + if (isset($parts['query'])) { + $resource .= "?{$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 + ); + } +} diff --git a/vendor/aws/Aws/CloudFront/CloudFrontSignature.php b/vendor/aws/Aws/CloudFront/CloudFrontSignature.php new file mode 100644 index 0000000..dcc6482 --- /dev/null +++ b/vendor/aws/Aws/CloudFront/CloudFrontSignature.php @@ -0,0 +1,61 @@ +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)); + } +} diff --git a/vendor/aws/Aws/CloudFront/Enum/GeoRestrictionType.php b/vendor/aws/Aws/CloudFront/Enum/GeoRestrictionType.php new file mode 100644 index 0000000..a9c3361 --- /dev/null +++ b/vendor/aws/Aws/CloudFront/Enum/GeoRestrictionType.php @@ -0,0 +1,29 @@ + '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', + ), + ), + ), + ), + 'iterators' => array( + 'ListCloudFrontOriginAccessIdentities' => array( + 'input_token' => 'Marker', + 'output_token' => 'NextMarker', + 'more_results' => 'IsTruncated', + 'result_key' => 'Items', + ), + 'ListDistributions' => array( + 'input_token' => 'Marker', + 'output_token' => 'NextMarker', + 'more_results' => 'IsTruncated', + 'result_key' => 'Items', + ), + 'ListInvalidations' => array( + 'input_token' => 'Marker', + 'output_token' => 'NextMarker', + 'more_results' => 'IsTruncated', + 'result_key' => 'Items', + ), + 'ListStreamingDistributions' => array( + 'input_token' => 'Marker', + 'output_token' => 'NextMarker', + 'more_results' => 'IsTruncated', + 'result_key' => 'Items', + ), + ), + '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', + ), + ), +); diff --git a/vendor/aws/Aws/CloudFront/Resources/cloudfront-2014-05-31.php b/vendor/aws/Aws/CloudFront/Resources/cloudfront-2014-05-31.php new file mode 100644 index 0000000..5d51b12 --- /dev/null +++ b/vendor/aws/Aws/CloudFront/Resources/cloudfront-2014-05-31.php @@ -0,0 +1,5482 @@ + '2014-05-31', + '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' => '/2014-05-31/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/2014-05-31/', + ), + ), + ), + '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' => '/2014-05-31/distribution', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'CreateDistributionResult', + 'responseType' => 'model', + 'data' => array( + 'xmlRoot' => array( + 'name' => 'DistributionConfig', + 'namespaces' => array( + 'http://cloudfront.amazonaws.com/doc/2014-05-31/', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + 'format' => 'boolean-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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + 'format' => 'boolean-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', + ), + 'SSLSupportMethod' => array( + 'type' => '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( + 'class' => 'TooManyHeadersInForwardedValuesException', + ), + array( + 'class' => 'InvalidHeadersForS3OriginException', + ), + 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' => '/2014-05-31/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/2014-05-31/', + ), + ), + ), + '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' => '/2014-05-31/streaming-distribution', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'CreateStreamingDistributionResult', + 'responseType' => 'model', + 'data' => array( + 'xmlRoot' => array( + 'name' => 'StreamingDistributionConfig', + 'namespaces' => array( + 'http://cloudfront.amazonaws.com/doc/2014-05-31/', + ), + ), + ), + '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' => '/2014-05-31/origin-access-identity/cloudfront/{Id}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'DeleteCloudFrontOriginAccessIdentity2014_05_31Output', + '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' => '/2014-05-31/distribution/{Id}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'DeleteDistribution2014_05_31Output', + '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' => '/2014-05-31/streaming-distribution/{Id}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'DeleteStreamingDistribution2014_05_31Output', + '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' => '/2014-05-31/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' => '/2014-05-31/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' => '/2014-05-31/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' => '/2014-05-31/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' => '/2014-05-31/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' => '/2014-05-31/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' => '/2014-05-31/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' => '/2014-05-31/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' => '/2014-05-31/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' => '/2014-05-31/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' => '/2014-05-31/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' => '/2014-05-31/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/2014-05-31/', + ), + ), + ), + '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' => '/2014-05-31/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/2014-05-31/', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + 'format' => 'boolean-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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + 'format' => 'boolean-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', + ), + 'SSLSupportMethod' => array( + 'type' => '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( + 'class' => 'TooManyHeadersInForwardedValuesException', + ), + array( + 'class' => 'InvalidHeadersForS3OriginException', + ), + 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' => '/2014-05-31/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/2014-05-31/', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + ), + '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', + ), + 'SSLSupportMethod' => array( + 'type' => 'string', + ), + ), + ), + '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', + ), + ), + ), + 'DeleteCloudFrontOriginAccessIdentity2014_05_31Output' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'DeleteDistribution2014_05_31Output' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'DeleteStreamingDistribution2014_05_31Output' => 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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + ), + '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', + ), + 'SSLSupportMethod' => array( + 'type' => 'string', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + ), + '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', + ), + 'SSLSupportMethod' => array( + 'type' => 'string', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + ), + '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', + ), + 'SSLSupportMethod' => array( + 'type' => 'string', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + ), + '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', + ), + 'SSLSupportMethod' => array( + 'type' => 'string', + ), + ), + ), + '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', + ), + ), + ), + ), + 'iterators' => array( + 'ListCloudFrontOriginAccessIdentities' => array( + 'input_token' => 'Marker', + 'output_token' => 'NextMarker', + 'limit_key' => 'MaxItems', + 'more_results' => 'IsTruncated', + 'result_key' => 'Items', + ), + 'ListDistributions' => array( + 'input_token' => 'Marker', + 'output_token' => 'NextMarker', + 'limit_key' => 'MaxItems', + 'more_results' => 'IsTruncated', + 'result_key' => 'Items', + ), + 'ListInvalidations' => array( + 'input_token' => 'Marker', + 'output_token' => 'NextMarker', + 'limit_key' => 'MaxItems', + 'more_results' => 'IsTruncated', + 'result_key' => 'Items', + ), + 'ListStreamingDistributions' => array( + 'input_token' => 'Marker', + 'output_token' => 'NextMarker', + 'limit_key' => 'MaxItems', + 'more_results' => 'IsTruncated', + 'result_key' => 'Items', + ), + ), + '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', + ), + ), +); diff --git a/vendor/aws/Aws/CloudFront/Resources/cloudfront-2014-10-21.php b/vendor/aws/Aws/CloudFront/Resources/cloudfront-2014-10-21.php new file mode 100644 index 0000000..5c4a7a0 --- /dev/null +++ b/vendor/aws/Aws/CloudFront/Resources/cloudfront-2014-10-21.php @@ -0,0 +1,5739 @@ + '2014-10-21', + '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' => '/2014-10-21/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/2014-10-21/', + ), + ), + ), + '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' => '/2014-10-21/distribution', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'CreateDistributionResult', + 'responseType' => 'model', + 'data' => array( + 'xmlRoot' => array( + 'name' => 'DistributionConfig', + 'namespaces' => array( + 'http://cloudfront.amazonaws.com/doc/2014-10-21/', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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( + 'required' => true, + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + ), + ), + 'CachedMethods' => array( + 'type' => 'object', + 'properties' => array( + 'Quantity' => array( + 'required' => true, + 'type' => 'numeric', + ), + 'Items' => array( + 'required' => true, + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + 'format' => 'boolean-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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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( + 'required' => true, + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + ), + ), + 'CachedMethods' => array( + 'type' => 'object', + 'properties' => array( + 'Quantity' => array( + 'required' => true, + 'type' => 'numeric', + ), + 'Items' => array( + 'required' => true, + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + 'format' => 'boolean-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', + ), + 'SSLSupportMethod' => array( + 'type' => 'string', + ), + 'MinimumProtocolVersion' => array( + 'type' => '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( + 'class' => 'TooManyHeadersInForwardedValuesException', + ), + array( + 'class' => 'InvalidHeadersForS3OriginException', + ), + 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', + ), + array( + 'reason' => 'You cannot specify SSLv3 as the minimum protocol version if you only want to support only clients that Support Server Name Indication (SNI).', + 'class' => 'InvalidProtocolSettingsException', + ), + ), + ), + 'CreateInvalidation' => array( + 'httpMethod' => 'POST', + 'uri' => '/2014-10-21/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/2014-10-21/', + ), + ), + ), + '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' => '/2014-10-21/streaming-distribution', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'CreateStreamingDistributionResult', + 'responseType' => 'model', + 'data' => array( + 'xmlRoot' => array( + 'name' => 'StreamingDistributionConfig', + 'namespaces' => array( + 'http://cloudfront.amazonaws.com/doc/2014-10-21/', + ), + ), + ), + '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' => '/2014-10-21/origin-access-identity/cloudfront/{Id}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'DeleteCloudFrontOriginAccessIdentity2014_10_21Output', + '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' => '/2014-10-21/distribution/{Id}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'DeleteDistribution2014_10_21Output', + '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' => '/2014-10-21/streaming-distribution/{Id}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'DeleteStreamingDistribution2014_10_21Output', + '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' => '/2014-10-21/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' => '/2014-10-21/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' => '/2014-10-21/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' => '/2014-10-21/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' => '/2014-10-21/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' => '/2014-10-21/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' => '/2014-10-21/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' => '/2014-10-21/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' => '/2014-10-21/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' => '/2014-10-21/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' => '/2014-10-21/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' => '/2014-10-21/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/2014-10-21/', + ), + ), + ), + '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' => '/2014-10-21/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/2014-10-21/', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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( + 'required' => true, + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + ), + ), + 'CachedMethods' => array( + 'type' => 'object', + 'properties' => array( + 'Quantity' => array( + 'required' => true, + 'type' => 'numeric', + ), + 'Items' => array( + 'required' => true, + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + 'format' => 'boolean-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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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( + 'required' => true, + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + ), + ), + 'CachedMethods' => array( + 'type' => 'object', + 'properties' => array( + 'Quantity' => array( + 'required' => true, + 'type' => 'numeric', + ), + 'Items' => array( + 'required' => true, + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + 'format' => 'boolean-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', + ), + 'SSLSupportMethod' => array( + 'type' => 'string', + ), + 'MinimumProtocolVersion' => array( + 'type' => '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( + 'class' => 'TooManyHeadersInForwardedValuesException', + ), + array( + 'class' => 'InvalidHeadersForS3OriginException', + ), + 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' => '/2014-10-21/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/2014-10-21/', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + 'CachedMethods' => array( + 'type' => 'object', + 'properties' => array( + 'Quantity' => array( + 'type' => 'numeric', + ), + 'Items' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + 'sentAs' => 'Method', + ), + ), + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + 'CachedMethods' => array( + 'type' => 'object', + 'properties' => array( + 'Quantity' => array( + 'type' => 'numeric', + ), + 'Items' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + 'sentAs' => 'Method', + ), + ), + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + ), + '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', + ), + 'SSLSupportMethod' => array( + 'type' => 'string', + ), + 'MinimumProtocolVersion' => array( + 'type' => 'string', + ), + ), + ), + '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', + ), + ), + ), + 'DeleteCloudFrontOriginAccessIdentity2014_10_21Output' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'DeleteDistribution2014_10_21Output' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'DeleteStreamingDistribution2014_10_21Output' => 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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + 'CachedMethods' => array( + 'type' => 'object', + 'properties' => array( + 'Quantity' => array( + 'type' => 'numeric', + ), + 'Items' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + 'sentAs' => 'Method', + ), + ), + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + 'CachedMethods' => array( + 'type' => 'object', + 'properties' => array( + 'Quantity' => array( + 'type' => 'numeric', + ), + 'Items' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + 'sentAs' => 'Method', + ), + ), + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + ), + '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', + ), + 'SSLSupportMethod' => array( + 'type' => 'string', + ), + 'MinimumProtocolVersion' => array( + 'type' => 'string', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + 'CachedMethods' => array( + 'type' => 'object', + 'properties' => array( + 'Quantity' => array( + 'type' => 'numeric', + ), + 'Items' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + 'sentAs' => 'Method', + ), + ), + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + 'CachedMethods' => array( + 'type' => 'object', + 'properties' => array( + 'Quantity' => array( + 'type' => 'numeric', + ), + 'Items' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + 'sentAs' => 'Method', + ), + ), + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + ), + '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', + ), + 'SSLSupportMethod' => array( + 'type' => 'string', + ), + 'MinimumProtocolVersion' => array( + 'type' => 'string', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + 'CachedMethods' => array( + 'type' => 'object', + 'properties' => array( + 'Quantity' => array( + 'type' => 'numeric', + ), + 'Items' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + 'sentAs' => 'Method', + ), + ), + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + 'CachedMethods' => array( + 'type' => 'object', + 'properties' => array( + 'Quantity' => array( + 'type' => 'numeric', + ), + 'Items' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + 'sentAs' => 'Method', + ), + ), + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + ), + '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', + ), + 'SSLSupportMethod' => array( + 'type' => 'string', + ), + 'MinimumProtocolVersion' => array( + 'type' => 'string', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + 'CachedMethods' => array( + 'type' => 'object', + 'properties' => array( + 'Quantity' => array( + 'type' => 'numeric', + ), + 'Items' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + 'sentAs' => 'Method', + ), + ), + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + 'CachedMethods' => array( + 'type' => 'object', + 'properties' => array( + 'Quantity' => array( + 'type' => 'numeric', + ), + 'Items' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + 'sentAs' => 'Method', + ), + ), + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + ), + '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', + ), + 'SSLSupportMethod' => array( + 'type' => 'string', + ), + 'MinimumProtocolVersion' => array( + 'type' => 'string', + ), + ), + ), + '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', + ), + ), + ), + ), + 'iterators' => array( + 'ListCloudFrontOriginAccessIdentities' => array( + 'input_token' => 'Marker', + 'output_token' => 'NextMarker', + 'limit_key' => 'MaxItems', + 'more_results' => 'IsTruncated', + 'result_key' => 'Items', + ), + 'ListDistributions' => array( + 'input_token' => 'Marker', + 'output_token' => 'NextMarker', + 'limit_key' => 'MaxItems', + 'more_results' => 'IsTruncated', + 'result_key' => 'Items', + ), + 'ListInvalidations' => array( + 'input_token' => 'Marker', + 'output_token' => 'NextMarker', + 'limit_key' => 'MaxItems', + 'more_results' => 'IsTruncated', + 'result_key' => 'Items', + ), + 'ListStreamingDistributions' => array( + 'input_token' => 'Marker', + 'output_token' => 'NextMarker', + 'limit_key' => 'MaxItems', + 'more_results' => 'IsTruncated', + 'result_key' => 'Items', + ), + ), + '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', + ), + ), +); diff --git a/vendor/aws/Aws/CloudFront/Resources/cloudfront-2014-11-06.php b/vendor/aws/Aws/CloudFront/Resources/cloudfront-2014-11-06.php new file mode 100644 index 0000000..06699ce --- /dev/null +++ b/vendor/aws/Aws/CloudFront/Resources/cloudfront-2014-11-06.php @@ -0,0 +1,5744 @@ + '2014-11-06', + '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' => '/2014-11-06/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/2014-11-06/', + ), + ), + ), + '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' => '/2014-11-06/distribution', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'CreateDistributionResult', + 'responseType' => 'model', + 'data' => array( + 'xmlRoot' => array( + 'name' => 'DistributionConfig', + 'namespaces' => array( + 'http://cloudfront.amazonaws.com/doc/2014-11-06/', + ), + ), + ), + 'parameters' => array( + 'CallerReference' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'xml', + ), + 'Aliases' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Quantity' => array( + 'required' => true, + 'type' => 'numeric', + ), + 'Items' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'CNAME', + 'type' => 'string', + ), + ), + ), + ), + 'DefaultRootObject' => array( + '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', + ), + 'OriginPath' => array( + '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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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( + 'required' => true, + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + ), + ), + 'CachedMethods' => array( + 'type' => 'object', + 'properties' => array( + 'Quantity' => array( + 'required' => true, + 'type' => 'numeric', + ), + 'Items' => array( + 'required' => true, + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + 'CacheBehaviors' => array( + '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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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( + 'required' => true, + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + ), + ), + 'CachedMethods' => array( + 'type' => 'object', + 'properties' => array( + 'Quantity' => array( + 'required' => true, + 'type' => 'numeric', + ), + 'Items' => array( + 'required' => true, + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + 'format' => 'boolean-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( + '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( + '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', + ), + 'SSLSupportMethod' => array( + 'type' => 'string', + ), + 'MinimumProtocolVersion' => array( + 'type' => '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( + 'class' => 'TooManyHeadersInForwardedValuesException', + ), + array( + 'class' => 'InvalidHeadersForS3OriginException', + ), + 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', + ), + array( + 'reason' => 'You cannot specify SSLv3 as the minimum protocol version if you only want to support only clients that Support Server Name Indication (SNI).', + 'class' => 'InvalidProtocolSettingsException', + ), + ), + ), + 'CreateInvalidation' => array( + 'httpMethod' => 'POST', + 'uri' => '/2014-11-06/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/2014-11-06/', + ), + ), + ), + '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' => '/2014-11-06/streaming-distribution', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'CreateStreamingDistributionResult', + 'responseType' => 'model', + 'data' => array( + 'xmlRoot' => array( + 'name' => 'StreamingDistributionConfig', + 'namespaces' => array( + 'http://cloudfront.amazonaws.com/doc/2014-11-06/', + ), + ), + ), + '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( + '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( + '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( + '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' => '/2014-11-06/origin-access-identity/cloudfront/{Id}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'DeleteCloudFrontOriginAccessIdentity2014_11_06Output', + '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' => '/2014-11-06/distribution/{Id}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'DeleteDistribution2014_11_06Output', + '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' => '/2014-11-06/streaming-distribution/{Id}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'DeleteStreamingDistribution2014_11_06Output', + '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' => '/2014-11-06/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' => '/2014-11-06/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' => '/2014-11-06/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' => '/2014-11-06/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' => '/2014-11-06/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' => '/2014-11-06/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' => '/2014-11-06/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' => '/2014-11-06/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' => '/2014-11-06/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' => '/2014-11-06/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' => '/2014-11-06/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' => '/2014-11-06/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/2014-11-06/', + ), + ), + ), + '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' => '/2014-11-06/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/2014-11-06/', + ), + ), + ), + 'parameters' => array( + 'CallerReference' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'xml', + ), + 'Aliases' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Quantity' => array( + 'required' => true, + 'type' => 'numeric', + ), + 'Items' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'CNAME', + 'type' => 'string', + ), + ), + ), + ), + 'DefaultRootObject' => array( + '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', + ), + 'OriginPath' => array( + '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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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( + 'required' => true, + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + ), + ), + 'CachedMethods' => array( + 'type' => 'object', + 'properties' => array( + 'Quantity' => array( + 'required' => true, + 'type' => 'numeric', + ), + 'Items' => array( + 'required' => true, + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + 'CacheBehaviors' => array( + '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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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( + 'required' => true, + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + ), + ), + 'CachedMethods' => array( + 'type' => 'object', + 'properties' => array( + 'Quantity' => array( + 'required' => true, + 'type' => 'numeric', + ), + 'Items' => array( + 'required' => true, + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + 'format' => 'boolean-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( + '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( + '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', + ), + 'SSLSupportMethod' => array( + 'type' => 'string', + ), + 'MinimumProtocolVersion' => array( + 'type' => '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( + 'class' => 'TooManyHeadersInForwardedValuesException', + ), + array( + 'class' => 'InvalidHeadersForS3OriginException', + ), + 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' => '/2014-11-06/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/2014-11-06/', + ), + ), + ), + '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( + '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( + '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( + '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', + ), + 'OriginPath' => 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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + 'CachedMethods' => array( + 'type' => 'object', + 'properties' => array( + 'Quantity' => array( + 'type' => 'numeric', + ), + 'Items' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + 'sentAs' => 'Method', + ), + ), + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + 'CachedMethods' => array( + 'type' => 'object', + 'properties' => array( + 'Quantity' => array( + 'type' => 'numeric', + ), + 'Items' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + 'sentAs' => 'Method', + ), + ), + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + ), + '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', + ), + 'SSLSupportMethod' => array( + 'type' => 'string', + ), + 'MinimumProtocolVersion' => array( + 'type' => 'string', + ), + ), + ), + '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', + ), + ), + ), + 'DeleteCloudFrontOriginAccessIdentity2014_11_06Output' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'DeleteDistribution2014_11_06Output' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'DeleteStreamingDistribution2014_11_06Output' => 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', + ), + 'OriginPath' => 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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + 'CachedMethods' => array( + 'type' => 'object', + 'properties' => array( + 'Quantity' => array( + 'type' => 'numeric', + ), + 'Items' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + 'sentAs' => 'Method', + ), + ), + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + 'CachedMethods' => array( + 'type' => 'object', + 'properties' => array( + 'Quantity' => array( + 'type' => 'numeric', + ), + 'Items' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + 'sentAs' => 'Method', + ), + ), + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + ), + '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', + ), + 'SSLSupportMethod' => array( + 'type' => 'string', + ), + 'MinimumProtocolVersion' => array( + 'type' => 'string', + ), + ), + ), + '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', + ), + 'OriginPath' => 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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + 'CachedMethods' => array( + 'type' => 'object', + 'properties' => array( + 'Quantity' => array( + 'type' => 'numeric', + ), + 'Items' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + 'sentAs' => 'Method', + ), + ), + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + 'CachedMethods' => array( + 'type' => 'object', + 'properties' => array( + 'Quantity' => array( + 'type' => 'numeric', + ), + 'Items' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + 'sentAs' => 'Method', + ), + ), + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + ), + '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', + ), + 'SSLSupportMethod' => array( + 'type' => 'string', + ), + 'MinimumProtocolVersion' => array( + 'type' => 'string', + ), + ), + ), + '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', + ), + 'OriginPath' => 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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + 'CachedMethods' => array( + 'type' => 'object', + 'properties' => array( + 'Quantity' => array( + 'type' => 'numeric', + ), + 'Items' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + 'sentAs' => 'Method', + ), + ), + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + 'CachedMethods' => array( + 'type' => 'object', + 'properties' => array( + 'Quantity' => array( + 'type' => 'numeric', + ), + 'Items' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + 'sentAs' => 'Method', + ), + ), + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + ), + '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', + ), + 'SSLSupportMethod' => array( + 'type' => 'string', + ), + 'MinimumProtocolVersion' => array( + 'type' => 'string', + ), + ), + ), + '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', + ), + 'OriginPath' => 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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + 'CachedMethods' => array( + 'type' => 'object', + 'properties' => array( + 'Quantity' => array( + 'type' => 'numeric', + ), + 'Items' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + 'sentAs' => 'Method', + ), + ), + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + 'Headers' => 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', + ), + ), + 'CachedMethods' => array( + 'type' => 'object', + 'properties' => array( + 'Quantity' => array( + 'type' => 'numeric', + ), + 'Items' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Method', + 'type' => 'string', + 'sentAs' => 'Method', + ), + ), + ), + ), + ), + ), + 'SmoothStreaming' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + ), + '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', + ), + 'SSLSupportMethod' => array( + 'type' => 'string', + ), + 'MinimumProtocolVersion' => array( + 'type' => 'string', + ), + ), + ), + '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', + ), + ), + ), + ), + 'iterators' => array( + 'ListCloudFrontOriginAccessIdentities' => array( + 'input_token' => 'Marker', + 'output_token' => 'CloudFrontOriginAccessIdentityList/NextMarker', + 'limit_key' => 'MaxItems', + 'more_results' => 'CloudFrontOriginAccessIdentityList/IsTruncated', + 'result_key' => 'CloudFrontOriginAccessIdentityList/Items', + ), + 'ListDistributions' => array( + 'input_token' => 'Marker', + 'output_token' => 'DistributionList/NextMarker', + 'limit_key' => 'MaxItems', + 'more_results' => 'DistributionList/IsTruncated', + 'result_key' => 'DistributionList/Items', + ), + 'ListInvalidations' => array( + 'input_token' => 'Marker', + 'output_token' => 'InvalidationList/NextMarker', + 'limit_key' => 'MaxItems', + 'more_results' => 'InvalidationList/IsTruncated', + 'result_key' => 'InvalidationList/Items', + ), + 'ListStreamingDistributions' => array( + 'input_token' => 'Marker', + 'output_token' => 'StreamingDistributionList/NextMarker', + 'limit_key' => 'MaxItems', + 'more_results' => 'StreamingDistributionList/IsTruncated', + 'result_key' => 'StreamingDistributionList/Items', + ), + ), + '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', + ), + ), +); diff --git a/vendor/aws/Aws/CloudHsm/CloudHsmClient.php b/vendor/aws/Aws/CloudHsm/CloudHsmClient.php new file mode 100644 index 0000000..cb36ceb --- /dev/null +++ b/vendor/aws/Aws/CloudHsm/CloudHsmClient.php @@ -0,0 +1,73 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/cloudhsm-%s.php' + )) + ->build(); + } +} diff --git a/vendor/aws/Aws/CloudHsm/Exception/CloudHsmException.php b/vendor/aws/Aws/CloudHsm/Exception/CloudHsmException.php new file mode 100644 index 0000000..6640c67 --- /dev/null +++ b/vendor/aws/Aws/CloudHsm/Exception/CloudHsmException.php @@ -0,0 +1,24 @@ + '2014-05-30', + 'endpointPrefix' => 'cloudhsm', + 'serviceFullName' => 'Amazon CloudHSM', + 'serviceAbbreviation' => 'CloudHSM', + 'serviceType' => 'json', + 'targetPrefix' => 'cloudhsm.', + 'signatureVersion' => 'v4', + 'namespace' => 'CloudHsm', + 'operations' => array( + 'CreateHapg' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'CreateHapgResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'cloudhsm.CreateHapg', + ), + 'Label' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that an exception occurred in the AWS CloudHSM service.', + 'class' => 'CloudHsmServiceException', + ), + array( + 'reason' => 'Indicates that an internal error occurred.', + 'class' => 'CloudHsmInternalException', + ), + array( + 'reason' => 'Indicates that one or more of the request parameters are not valid.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'CreateHsm' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'CreateHsmResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'cloudhsm.CreateHsm', + ), + 'SubnetId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'SshKey' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'EniIp' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'IamRoleArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'ExternalId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'SubscriptionType' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'ClientToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'SyslogIp' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that an exception occurred in the AWS CloudHSM service.', + 'class' => 'CloudHsmServiceException', + ), + array( + 'reason' => 'Indicates that an internal error occurred.', + 'class' => 'CloudHsmInternalException', + ), + array( + 'reason' => 'Indicates that one or more of the request parameters are not valid.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'CreateLunaClient' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'CreateLunaClientResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'cloudhsm.CreateLunaClient', + ), + 'Label' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Certificate' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 600, + 'maxLength' => 2400, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that an exception occurred in the AWS CloudHSM service.', + 'class' => 'CloudHsmServiceException', + ), + array( + 'reason' => 'Indicates that an internal error occurred.', + 'class' => 'CloudHsmInternalException', + ), + array( + 'reason' => 'Indicates that one or more of the request parameters are not valid.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'DeleteHapg' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DeleteHapgResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'cloudhsm.DeleteHapg', + ), + 'HapgArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that an exception occurred in the AWS CloudHSM service.', + 'class' => 'CloudHsmServiceException', + ), + array( + 'reason' => 'Indicates that an internal error occurred.', + 'class' => 'CloudHsmInternalException', + ), + array( + 'reason' => 'Indicates that one or more of the request parameters are not valid.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'DeleteHsm' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DeleteHsmResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'cloudhsm.DeleteHsm', + ), + 'HsmArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that an exception occurred in the AWS CloudHSM service.', + 'class' => 'CloudHsmServiceException', + ), + array( + 'reason' => 'Indicates that an internal error occurred.', + 'class' => 'CloudHsmInternalException', + ), + array( + 'reason' => 'Indicates that one or more of the request parameters are not valid.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'DeleteLunaClient' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DeleteLunaClientResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'cloudhsm.DeleteLunaClient', + ), + 'ClientArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that an exception occurred in the AWS CloudHSM service.', + 'class' => 'CloudHsmServiceException', + ), + array( + 'reason' => 'Indicates that an internal error occurred.', + 'class' => 'CloudHsmInternalException', + ), + array( + 'reason' => 'Indicates that one or more of the request parameters are not valid.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'DescribeHapg' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeHapgResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'cloudhsm.DescribeHapg', + ), + 'HapgArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that an exception occurred in the AWS CloudHSM service.', + 'class' => 'CloudHsmServiceException', + ), + array( + 'reason' => 'Indicates that an internal error occurred.', + 'class' => 'CloudHsmInternalException', + ), + array( + 'reason' => 'Indicates that one or more of the request parameters are not valid.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'DescribeHsm' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeHsmResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'cloudhsm.DescribeHsm', + ), + 'HsmArn' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'HsmSerialNumber' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that an exception occurred in the AWS CloudHSM service.', + 'class' => 'CloudHsmServiceException', + ), + array( + 'reason' => 'Indicates that an internal error occurred.', + 'class' => 'CloudHsmInternalException', + ), + array( + 'reason' => 'Indicates that one or more of the request parameters are not valid.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'DescribeLunaClient' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeLunaClientResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'cloudhsm.DescribeLunaClient', + ), + 'ClientArn' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'CertificateFingerprint' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that an exception occurred in the AWS CloudHSM service.', + 'class' => 'CloudHsmServiceException', + ), + array( + 'reason' => 'Indicates that an internal error occurred.', + 'class' => 'CloudHsmInternalException', + ), + array( + 'reason' => 'Indicates that one or more of the request parameters are not valid.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'GetConfig' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GetConfigResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'cloudhsm.GetConfig', + ), + 'ClientArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'ClientVersion' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'HapgList' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'HapgArn', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that an exception occurred in the AWS CloudHSM service.', + 'class' => 'CloudHsmServiceException', + ), + array( + 'reason' => 'Indicates that an internal error occurred.', + 'class' => 'CloudHsmInternalException', + ), + array( + 'reason' => 'Indicates that one or more of the request parameters are not valid.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'ListAvailableZones' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListAvailableZonesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'cloudhsm.ListAvailableZones', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that an exception occurred in the AWS CloudHSM service.', + 'class' => 'CloudHsmServiceException', + ), + array( + 'reason' => 'Indicates that an internal error occurred.', + 'class' => 'CloudHsmInternalException', + ), + array( + 'reason' => 'Indicates that one or more of the request parameters are not valid.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'ListHapgs' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListHapgsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'cloudhsm.ListHapgs', + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that an exception occurred in the AWS CloudHSM service.', + 'class' => 'CloudHsmServiceException', + ), + array( + 'reason' => 'Indicates that an internal error occurred.', + 'class' => 'CloudHsmInternalException', + ), + array( + 'reason' => 'Indicates that one or more of the request parameters are not valid.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'ListHsms' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListHsmsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'cloudhsm.ListHsms', + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that an exception occurred in the AWS CloudHSM service.', + 'class' => 'CloudHsmServiceException', + ), + array( + 'reason' => 'Indicates that an internal error occurred.', + 'class' => 'CloudHsmInternalException', + ), + array( + 'reason' => 'Indicates that one or more of the request parameters are not valid.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'ListLunaClients' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListLunaClientsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'cloudhsm.ListLunaClients', + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that an exception occurred in the AWS CloudHSM service.', + 'class' => 'CloudHsmServiceException', + ), + array( + 'reason' => 'Indicates that an internal error occurred.', + 'class' => 'CloudHsmInternalException', + ), + array( + 'reason' => 'Indicates that one or more of the request parameters are not valid.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'ModifyHapg' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ModifyHapgResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'cloudhsm.ModifyHapg', + ), + 'HapgArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'Label' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'PartitionSerialList' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'PartitionSerial', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that an exception occurred in the AWS CloudHSM service.', + 'class' => 'CloudHsmServiceException', + ), + array( + 'reason' => 'Indicates that an internal error occurred.', + 'class' => 'CloudHsmInternalException', + ), + array( + 'reason' => 'Indicates that one or more of the request parameters are not valid.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'ModifyHsm' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ModifyHsmResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'cloudhsm.ModifyHsm', + ), + 'HsmArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'SubnetId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'EniIp' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'IamRoleArn' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'ExternalId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'SyslogIp' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that an exception occurred in the AWS CloudHSM service.', + 'class' => 'CloudHsmServiceException', + ), + array( + 'reason' => 'Indicates that an internal error occurred.', + 'class' => 'CloudHsmInternalException', + ), + array( + 'reason' => 'Indicates that one or more of the request parameters are not valid.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'ModifyLunaClient' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ModifyLunaClientResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'cloudhsm.ModifyLunaClient', + ), + 'ClientArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'Certificate' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 600, + 'maxLength' => 2400, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that an exception occurred in the AWS CloudHSM service.', + 'class' => 'CloudHsmServiceException', + ), + ), + ), + ), + 'models' => array( + 'CreateHapgResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'HapgArn' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'CreateHsmResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'HsmArn' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'CreateLunaClientResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ClientArn' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DeleteHapgResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Status' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DeleteHsmResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Status' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DeleteLunaClientResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Status' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DescribeHapgResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'HapgArn' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'HapgSerial' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'HsmsLastActionFailed' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'HsmArn', + 'type' => 'string', + ), + ), + 'HsmsPendingDeletion' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'HsmArn', + 'type' => 'string', + ), + ), + 'HsmsPendingRegistration' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'HsmArn', + 'type' => 'string', + ), + ), + 'Label' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'LastModifiedTimestamp' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'PartitionSerialList' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'PartitionSerial', + 'type' => 'string', + ), + ), + 'State' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DescribeHsmResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'HsmArn' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Status' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'StatusDetails' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'AvailabilityZone' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'EniId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'EniIp' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'SubscriptionType' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'SubscriptionStartDate' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'SubscriptionEndDate' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'VpcId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'SubnetId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'IamRoleArn' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'SerialNumber' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'VendorName' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'HsmType' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'SoftwareVersion' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'SshPublicKey' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'SshKeyLastUpdated' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'ServerCertUri' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'ServerCertLastUpdated' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Partitions' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'PartitionArn', + 'type' => 'string', + ), + ), + ), + ), + 'DescribeLunaClientResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ClientArn' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Certificate' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'CertificateFingerprint' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'LastModifiedTimestamp' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Label' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'GetConfigResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ConfigType' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'ConfigFile' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'ConfigCred' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListAvailableZonesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'AZList' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'AZ', + 'type' => 'string', + ), + ), + ), + ), + 'ListHapgsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'HapgList' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'HapgArn', + 'type' => 'string', + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListHsmsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'HsmList' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'HsmArn', + 'type' => 'string', + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListLunaClientsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ClientList' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'ClientArn', + 'type' => 'string', + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ModifyHapgResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'HapgArn' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ModifyHsmResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'HsmArn' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ModifyLunaClientResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ClientArn' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + ), +); diff --git a/vendor/aws/Aws/CloudSearch/CloudSearchClient.php b/vendor/aws/Aws/CloudSearch/CloudSearchClient.php new file mode 100644 index 0000000..e55dea9 --- /dev/null +++ b/vendor/aws/Aws/CloudSearch/CloudSearchClient.php @@ -0,0 +1,105 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/cloudsearch-%s.php' + )) + ->build(); + } + + /** + * Create a CloudSearchDomainClient for a particular domain to do searching + * and document uploads. + * + * @param string $domainName Name of the domain for which to create a domain client. + * @param array $config Config options for the CloudSearchDomainClient + * + * @return CloudSearchDomainClient + * @link http://docs.aws.amazon.com/aws-sdk-php/v2/guide/configuration.html#client-configuration-options + */ + public function getDomainClient($domainName, array $config = array()) + { + // Determine the Domain client's endpoint + $config['endpoint'] = $this->describeDomains(array( + 'DomainNames' => array($domainName) + ))->getPath('DomainStatusList/0/SearchService/Endpoint'); + + return CloudSearchDomainClient::factory($config); + } +} diff --git a/vendor/aws/Aws/CloudSearch/Enum/IndexFieldType.php b/vendor/aws/Aws/CloudSearch/Enum/IndexFieldType.php new file mode 100644 index 0000000..048b6e1 --- /dev/null +++ b/vendor/aws/Aws/CloudSearch/Enum/IndexFieldType.php @@ -0,0 +1,38 @@ + '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( + 'DescribeDomains' => array( + 'result_key' => 'DomainStatusList', + ), + 'DescribeIndexFields' => array( + 'result_key' => 'IndexFields', + ), + 'DescribeRankExpressions' => array( + 'result_key' => 'RankExpressions', + ), + ), +); diff --git a/vendor/aws/Aws/CloudSearch/Resources/cloudsearch-2013-01-01.php b/vendor/aws/Aws/CloudSearch/Resources/cloudsearch-2013-01-01.php new file mode 100644 index 0000000..601e811 --- /dev/null +++ b/vendor/aws/Aws/CloudSearch/Resources/cloudsearch-2013-01-01.php @@ -0,0 +1,3497 @@ + '2013-01-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-northeast-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'cloudsearch.ap-northeast-1.amazonaws.com', + ), + 'ap-southeast-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'cloudsearch.ap-southeast-1.amazonaws.com', + ), + 'ap-southeast-2' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'cloudsearch.ap-southeast-2.amazonaws.com', + ), + 'sa-east-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'cloudsearch.sa-east-1.amazonaws.com', + ), + ), + 'operations' => array( + 'BuildSuggesters' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'BuildSuggestersResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'BuildSuggesters', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2013-01-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', + ), + ), + ), + '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' => '2013-01-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', + ), + ), + ), + 'DefineAnalysisScheme' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DefineAnalysisSchemeResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DefineAnalysisScheme', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2013-01-01', + ), + 'DomainName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 3, + 'maxLength' => 28, + ), + 'AnalysisScheme' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'aws.query', + 'properties' => array( + 'AnalysisSchemeName' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'AnalysisSchemeLanguage' => array( + 'required' => true, + 'type' => 'string', + ), + 'AnalysisOptions' => array( + 'type' => 'object', + 'properties' => array( + 'Synonyms' => array( + 'type' => 'string', + ), + 'Stopwords' => array( + 'type' => 'string', + ), + 'StemmingDictionary' => array( + 'type' => 'string', + ), + 'JapaneseTokenizationDictionary' => array( + 'type' => 'string', + ), + 'AlgorithmicStemming' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + 'DefineExpression' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DefineExpressionResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DefineExpression', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2013-01-01', + ), + 'DomainName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 3, + 'maxLength' => 28, + ), + 'Expression' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'aws.query', + 'properties' => array( + 'ExpressionName' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'ExpressionValue' => 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', + ), + ), + ), + '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' => '2013-01-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', + ), + 'IntOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'numeric', + ), + 'SourceField' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'SortEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + 'DoubleOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'numeric', + ), + 'SourceField' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'SortEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + 'LiteralOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'string', + 'maxLength' => 1024, + ), + 'SourceField' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'SortEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + 'TextOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'string', + 'maxLength' => 1024, + ), + 'SourceField' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'SortEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'HighlightEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'AnalysisScheme' => array( + 'type' => 'string', + ), + ), + ), + 'DateOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'string', + 'maxLength' => 1024, + ), + 'SourceField' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'SortEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + 'LatLonOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'string', + 'maxLength' => 1024, + ), + 'SourceField' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'SortEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + 'IntArrayOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'numeric', + ), + 'SourceFields' => array( + 'type' => 'string', + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + 'DoubleArrayOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'numeric', + ), + 'SourceFields' => array( + 'type' => 'string', + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + 'LiteralArrayOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'string', + 'maxLength' => 1024, + ), + 'SourceFields' => array( + 'type' => 'string', + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + 'TextArrayOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'string', + 'maxLength' => 1024, + ), + 'SourceFields' => array( + 'type' => 'string', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'HighlightEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'AnalysisScheme' => array( + 'type' => 'string', + ), + ), + ), + 'DateArrayOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'string', + 'maxLength' => 1024, + ), + 'SourceFields' => array( + 'type' => 'string', + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + 'DefineSuggester' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DefineSuggesterResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DefineSuggester', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2013-01-01', + ), + 'DomainName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 3, + 'maxLength' => 28, + ), + 'Suggester' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'aws.query', + 'properties' => array( + 'SuggesterName' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'DocumentSuggesterOptions' => array( + 'required' => true, + 'type' => 'object', + 'properties' => array( + 'SourceField' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'FuzzyMatching' => array( + 'type' => 'string', + ), + 'SortExpression' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + 'DeleteAnalysisScheme' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DeleteAnalysisSchemeResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteAnalysisScheme', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2013-01-01', + ), + 'DomainName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 3, + 'maxLength' => 28, + ), + 'AnalysisSchemeName' => 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', + ), + ), + ), + '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' => '2013-01-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', + ), + ), + ), + 'DeleteExpression' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DeleteExpressionResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteExpression', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2013-01-01', + ), + 'DomainName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 3, + 'maxLength' => 28, + ), + 'ExpressionName' => 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', + ), + ), + ), + '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' => '2013-01-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', + ), + ), + ), + 'DeleteSuggester' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DeleteSuggesterResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteSuggester', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2013-01-01', + ), + 'DomainName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 3, + 'maxLength' => 28, + ), + 'SuggesterName' => 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', + ), + ), + ), + 'DescribeAnalysisSchemes' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DescribeAnalysisSchemesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeAnalysisSchemes', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2013-01-01', + ), + 'DomainName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 3, + 'maxLength' => 28, + ), + 'AnalysisSchemeNames' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'AnalysisSchemeNames.member', + 'items' => array( + 'name' => 'StandardName', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 64, + ), + ), + 'Deployed' => array( + 'type' => 'boolean', + 'format' => 'boolean-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 attempted to reference a resource that does not exist.', + 'class' => 'ResourceNotFoundException', + ), + ), + ), + 'DescribeAvailabilityOptions' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DescribeAvailabilityOptionsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeAvailabilityOptions', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2013-01-01', + ), + 'DomainName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 3, + 'maxLength' => 28, + ), + 'Deployed' => array( + 'type' => 'boolean', + 'format' => 'boolean-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', + ), + array( + 'reason' => 'The request was rejected because it attempted an operation which is not enabled.', + 'class' => 'DisabledOperationException', + ), + ), + ), + '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' => '2013-01-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', + ), + ), + ), + 'DescribeExpressions' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DescribeExpressionsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeExpressions', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2013-01-01', + ), + 'DomainName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 3, + 'maxLength' => 28, + ), + 'ExpressionNames' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'ExpressionNames.member', + 'items' => array( + 'name' => 'StandardName', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 64, + ), + ), + 'Deployed' => array( + 'type' => 'boolean', + 'format' => 'boolean-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 attempted to reference a resource that does not exist.', + 'class' => 'ResourceNotFoundException', + ), + ), + ), + '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' => '2013-01-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' => 'DynamicFieldName', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 64, + ), + ), + 'Deployed' => array( + 'type' => 'boolean', + 'format' => 'boolean-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 attempted to reference a resource that does not exist.', + 'class' => 'ResourceNotFoundException', + ), + ), + ), + 'DescribeScalingParameters' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DescribeScalingParametersResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeScalingParameters', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2013-01-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', + ), + ), + ), + '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' => '2013-01-01', + ), + 'DomainName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 3, + 'maxLength' => 28, + ), + 'Deployed' => array( + 'type' => 'boolean', + 'format' => 'boolean-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 attempted to reference a resource that does not exist.', + 'class' => 'ResourceNotFoundException', + ), + ), + ), + 'DescribeSuggesters' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DescribeSuggestersResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeSuggesters', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2013-01-01', + ), + 'DomainName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 3, + 'maxLength' => 28, + ), + 'SuggesterNames' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'SuggesterNames.member', + 'items' => array( + 'name' => 'StandardName', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 64, + ), + ), + 'Deployed' => array( + 'type' => 'boolean', + 'format' => 'boolean-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 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' => '2013-01-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', + ), + ), + ), + 'ListDomainNames' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListDomainNamesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListDomainNames', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2013-01-01', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error occurred while processing the request.', + 'class' => 'BaseException', + ), + ), + ), + 'UpdateAvailabilityOptions' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'UpdateAvailabilityOptionsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'UpdateAvailabilityOptions', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2013-01-01', + ), + 'DomainName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 3, + 'maxLength' => 28, + ), + 'MultiAZ' => array( + 'required' => true, + 'type' => 'boolean', + 'format' => 'boolean-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', + ), + array( + 'reason' => 'The request was rejected because it attempted an operation which is not enabled.', + 'class' => 'DisabledOperationException', + ), + ), + ), + 'UpdateScalingParameters' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'UpdateScalingParametersResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'UpdateScalingParameters', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2013-01-01', + ), + 'DomainName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 3, + 'maxLength' => 28, + ), + 'ScalingParameters' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'aws.query', + 'properties' => array( + 'DesiredInstanceType' => array( + 'type' => 'string', + ), + 'DesiredReplicationCount' => array( + 'type' => 'numeric', + ), + 'DesiredPartitionCount' => array( + 'type' => 'numeric', + ), + ), + ), + ), + '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', + ), + ), + ), + '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' => '2013-01-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', + ), + ), + ), + ), + 'models' => array( + 'BuildSuggestersResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'FieldNames' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'FieldName', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + ), + ), + 'CreateDomainResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'DomainStatus' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'DomainId' => array( + 'type' => 'string', + ), + 'DomainName' => array( + 'type' => 'string', + ), + 'ARN' => array( + 'type' => 'string', + ), + 'Created' => array( + 'type' => 'boolean', + ), + 'Deleted' => array( + 'type' => 'boolean', + ), + 'DocService' => array( + 'type' => 'object', + 'properties' => array( + 'Endpoint' => array( + 'type' => 'string', + ), + ), + ), + 'SearchService' => array( + 'type' => 'object', + 'properties' => array( + 'Endpoint' => array( + 'type' => 'string', + ), + ), + ), + 'RequiresIndexDocuments' => array( + 'type' => 'boolean', + ), + 'Processing' => array( + 'type' => 'boolean', + ), + 'SearchInstanceType' => array( + 'type' => 'string', + ), + 'SearchPartitionCount' => array( + 'type' => 'numeric', + ), + 'SearchInstanceCount' => array( + 'type' => 'numeric', + ), + 'Limits' => array( + 'type' => 'object', + 'properties' => array( + 'MaximumReplicationCount' => array( + 'type' => 'numeric', + ), + 'MaximumPartitionCount' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + ), + 'DefineAnalysisSchemeResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'AnalysisScheme' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Options' => array( + 'type' => 'object', + 'properties' => array( + 'AnalysisSchemeName' => array( + 'type' => 'string', + ), + 'AnalysisSchemeLanguage' => array( + 'type' => 'string', + ), + 'AnalysisOptions' => array( + 'type' => 'object', + 'properties' => array( + 'Synonyms' => array( + 'type' => 'string', + ), + 'Stopwords' => array( + 'type' => 'string', + ), + 'StemmingDictionary' => array( + 'type' => 'string', + ), + 'JapaneseTokenizationDictionary' => array( + 'type' => 'string', + ), + 'AlgorithmicStemming' => 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', + ), + ), + ), + ), + ), + ), + ), + 'DefineExpressionResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Expression' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Options' => array( + 'type' => 'object', + 'properties' => array( + 'ExpressionName' => array( + 'type' => 'string', + ), + 'ExpressionValue' => 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', + ), + ), + ), + ), + ), + ), + ), + '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', + ), + 'IntOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'numeric', + ), + 'SourceField' => array( + 'type' => 'string', + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + 'SortEnabled' => array( + 'type' => 'boolean', + ), + ), + ), + 'DoubleOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'numeric', + ), + 'SourceField' => array( + 'type' => 'string', + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + 'SortEnabled' => array( + 'type' => 'boolean', + ), + ), + ), + 'LiteralOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'string', + ), + 'SourceField' => array( + 'type' => 'string', + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + 'SortEnabled' => array( + 'type' => 'boolean', + ), + ), + ), + 'TextOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'string', + ), + 'SourceField' => array( + 'type' => 'string', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + 'SortEnabled' => array( + 'type' => 'boolean', + ), + 'HighlightEnabled' => array( + 'type' => 'boolean', + ), + 'AnalysisScheme' => array( + 'type' => 'string', + ), + ), + ), + 'DateOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'string', + ), + 'SourceField' => array( + 'type' => 'string', + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + 'SortEnabled' => array( + 'type' => 'boolean', + ), + ), + ), + 'LatLonOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'string', + ), + 'SourceField' => array( + 'type' => 'string', + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + 'SortEnabled' => array( + 'type' => 'boolean', + ), + ), + ), + 'IntArrayOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'numeric', + ), + 'SourceFields' => array( + 'type' => 'string', + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + ), + ), + 'DoubleArrayOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'numeric', + ), + 'SourceFields' => array( + 'type' => 'string', + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + ), + ), + 'LiteralArrayOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'string', + ), + 'SourceFields' => array( + 'type' => 'string', + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + ), + ), + 'TextArrayOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'string', + ), + 'SourceFields' => array( + 'type' => 'string', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + 'HighlightEnabled' => array( + 'type' => 'boolean', + ), + 'AnalysisScheme' => array( + 'type' => 'string', + ), + ), + ), + 'DateArrayOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'string', + ), + 'SourceFields' => array( + 'type' => 'string', + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + ), + 'DefineSuggesterResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Suggester' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Options' => array( + 'type' => 'object', + 'properties' => array( + 'SuggesterName' => array( + 'type' => 'string', + ), + 'DocumentSuggesterOptions' => array( + 'type' => 'object', + 'properties' => array( + 'SourceField' => array( + 'type' => 'string', + ), + 'FuzzyMatching' => array( + 'type' => 'string', + ), + 'SortExpression' => 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', + ), + ), + ), + ), + ), + ), + ), + 'DeleteAnalysisSchemeResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'AnalysisScheme' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Options' => array( + 'type' => 'object', + 'properties' => array( + 'AnalysisSchemeName' => array( + 'type' => 'string', + ), + 'AnalysisSchemeLanguage' => array( + 'type' => 'string', + ), + 'AnalysisOptions' => array( + 'type' => 'object', + 'properties' => array( + 'Synonyms' => array( + 'type' => 'string', + ), + 'Stopwords' => array( + 'type' => 'string', + ), + 'StemmingDictionary' => array( + 'type' => 'string', + ), + 'JapaneseTokenizationDictionary' => array( + 'type' => 'string', + ), + 'AlgorithmicStemming' => 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', + ), + 'ARN' => array( + 'type' => 'string', + ), + 'Created' => array( + 'type' => 'boolean', + ), + 'Deleted' => array( + 'type' => 'boolean', + ), + 'DocService' => array( + 'type' => 'object', + 'properties' => array( + 'Endpoint' => array( + 'type' => 'string', + ), + ), + ), + 'SearchService' => array( + 'type' => 'object', + 'properties' => array( + 'Endpoint' => array( + 'type' => 'string', + ), + ), + ), + 'RequiresIndexDocuments' => array( + 'type' => 'boolean', + ), + 'Processing' => array( + 'type' => 'boolean', + ), + 'SearchInstanceType' => array( + 'type' => 'string', + ), + 'SearchPartitionCount' => array( + 'type' => 'numeric', + ), + 'SearchInstanceCount' => array( + 'type' => 'numeric', + ), + 'Limits' => array( + 'type' => 'object', + 'properties' => array( + 'MaximumReplicationCount' => array( + 'type' => 'numeric', + ), + 'MaximumPartitionCount' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + ), + 'DeleteExpressionResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Expression' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Options' => array( + 'type' => 'object', + 'properties' => array( + 'ExpressionName' => array( + 'type' => 'string', + ), + 'ExpressionValue' => 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', + ), + ), + ), + ), + ), + ), + ), + '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', + ), + 'IntOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'numeric', + ), + 'SourceField' => array( + 'type' => 'string', + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + 'SortEnabled' => array( + 'type' => 'boolean', + ), + ), + ), + 'DoubleOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'numeric', + ), + 'SourceField' => array( + 'type' => 'string', + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + 'SortEnabled' => array( + 'type' => 'boolean', + ), + ), + ), + 'LiteralOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'string', + ), + 'SourceField' => array( + 'type' => 'string', + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + 'SortEnabled' => array( + 'type' => 'boolean', + ), + ), + ), + 'TextOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'string', + ), + 'SourceField' => array( + 'type' => 'string', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + 'SortEnabled' => array( + 'type' => 'boolean', + ), + 'HighlightEnabled' => array( + 'type' => 'boolean', + ), + 'AnalysisScheme' => array( + 'type' => 'string', + ), + ), + ), + 'DateOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'string', + ), + 'SourceField' => array( + 'type' => 'string', + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + 'SortEnabled' => array( + 'type' => 'boolean', + ), + ), + ), + 'LatLonOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'string', + ), + 'SourceField' => array( + 'type' => 'string', + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + 'SortEnabled' => array( + 'type' => 'boolean', + ), + ), + ), + 'IntArrayOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'numeric', + ), + 'SourceFields' => array( + 'type' => 'string', + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + ), + ), + 'DoubleArrayOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'numeric', + ), + 'SourceFields' => array( + 'type' => 'string', + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + ), + ), + 'LiteralArrayOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'string', + ), + 'SourceFields' => array( + 'type' => 'string', + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + ), + ), + 'TextArrayOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'string', + ), + 'SourceFields' => array( + 'type' => 'string', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + 'HighlightEnabled' => array( + 'type' => 'boolean', + ), + 'AnalysisScheme' => array( + 'type' => 'string', + ), + ), + ), + 'DateArrayOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'string', + ), + 'SourceFields' => array( + 'type' => 'string', + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + ), + 'DeleteSuggesterResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Suggester' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Options' => array( + 'type' => 'object', + 'properties' => array( + 'SuggesterName' => array( + 'type' => 'string', + ), + 'DocumentSuggesterOptions' => array( + 'type' => 'object', + 'properties' => array( + 'SourceField' => array( + 'type' => 'string', + ), + 'FuzzyMatching' => array( + 'type' => 'string', + ), + 'SortExpression' => 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', + ), + ), + ), + ), + ), + ), + ), + 'DescribeAnalysisSchemesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'AnalysisSchemes' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'AnalysisSchemeStatus', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Options' => array( + 'type' => 'object', + 'properties' => array( + 'AnalysisSchemeName' => array( + 'type' => 'string', + ), + 'AnalysisSchemeLanguage' => array( + 'type' => 'string', + ), + 'AnalysisOptions' => array( + 'type' => 'object', + 'properties' => array( + 'Synonyms' => array( + 'type' => 'string', + ), + 'Stopwords' => array( + 'type' => 'string', + ), + 'StemmingDictionary' => array( + 'type' => 'string', + ), + 'JapaneseTokenizationDictionary' => array( + 'type' => 'string', + ), + 'AlgorithmicStemming' => 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', + ), + ), + ), + ), + ), + ), + ), + ), + 'DescribeAvailabilityOptionsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'AvailabilityOptions' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Options' => array( + 'type' => 'boolean', + ), + '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', + ), + 'ARN' => array( + 'type' => 'string', + ), + 'Created' => array( + 'type' => 'boolean', + ), + 'Deleted' => array( + 'type' => 'boolean', + ), + 'DocService' => array( + 'type' => 'object', + 'properties' => array( + 'Endpoint' => array( + 'type' => 'string', + ), + ), + ), + 'SearchService' => array( + 'type' => 'object', + 'properties' => array( + 'Endpoint' => array( + 'type' => 'string', + ), + ), + ), + 'RequiresIndexDocuments' => array( + 'type' => 'boolean', + ), + 'Processing' => array( + 'type' => 'boolean', + ), + 'SearchInstanceType' => array( + 'type' => 'string', + ), + 'SearchPartitionCount' => array( + 'type' => 'numeric', + ), + 'SearchInstanceCount' => array( + 'type' => 'numeric', + ), + 'Limits' => array( + 'type' => 'object', + 'properties' => array( + 'MaximumReplicationCount' => array( + 'type' => 'numeric', + ), + 'MaximumPartitionCount' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + ), + ), + 'DescribeExpressionsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Expressions' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'ExpressionStatus', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Options' => array( + 'type' => 'object', + 'properties' => array( + 'ExpressionName' => array( + 'type' => 'string', + ), + 'ExpressionValue' => 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', + ), + ), + ), + ), + ), + ), + ), + ), + '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', + ), + 'IntOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'numeric', + ), + 'SourceField' => array( + 'type' => 'string', + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + 'SortEnabled' => array( + 'type' => 'boolean', + ), + ), + ), + 'DoubleOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'numeric', + ), + 'SourceField' => array( + 'type' => 'string', + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + 'SortEnabled' => array( + 'type' => 'boolean', + ), + ), + ), + 'LiteralOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'string', + ), + 'SourceField' => array( + 'type' => 'string', + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + 'SortEnabled' => array( + 'type' => 'boolean', + ), + ), + ), + 'TextOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'string', + ), + 'SourceField' => array( + 'type' => 'string', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + 'SortEnabled' => array( + 'type' => 'boolean', + ), + 'HighlightEnabled' => array( + 'type' => 'boolean', + ), + 'AnalysisScheme' => array( + 'type' => 'string', + ), + ), + ), + 'DateOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'string', + ), + 'SourceField' => array( + 'type' => 'string', + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + 'SortEnabled' => array( + 'type' => 'boolean', + ), + ), + ), + 'LatLonOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'string', + ), + 'SourceField' => array( + 'type' => 'string', + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + 'SortEnabled' => array( + 'type' => 'boolean', + ), + ), + ), + 'IntArrayOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'numeric', + ), + 'SourceFields' => array( + 'type' => 'string', + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + ), + ), + 'DoubleArrayOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'numeric', + ), + 'SourceFields' => array( + 'type' => 'string', + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + ), + ), + 'LiteralArrayOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'string', + ), + 'SourceFields' => array( + 'type' => 'string', + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + ), + ), + 'TextArrayOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'string', + ), + 'SourceFields' => array( + 'type' => 'string', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + 'HighlightEnabled' => array( + 'type' => 'boolean', + ), + 'AnalysisScheme' => array( + 'type' => 'string', + ), + ), + ), + 'DateArrayOptions' => array( + 'type' => 'object', + 'properties' => array( + 'DefaultValue' => array( + 'type' => 'string', + ), + 'SourceFields' => array( + 'type' => 'string', + ), + 'FacetEnabled' => array( + 'type' => 'boolean', + ), + 'SearchEnabled' => array( + 'type' => 'boolean', + ), + 'ReturnEnabled' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + ), + ), + 'DescribeScalingParametersResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ScalingParameters' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Options' => array( + 'type' => 'object', + 'properties' => array( + 'DesiredInstanceType' => array( + 'type' => 'string', + ), + 'DesiredReplicationCount' => array( + 'type' => 'numeric', + ), + 'DesiredPartitionCount' => array( + 'type' => 'numeric', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + ), + 'DescribeSuggestersResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Suggesters' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'SuggesterStatus', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Options' => array( + 'type' => 'object', + 'properties' => array( + 'SuggesterName' => array( + 'type' => 'string', + ), + 'DocumentSuggesterOptions' => array( + 'type' => 'object', + 'properties' => array( + 'SourceField' => array( + 'type' => 'string', + ), + 'FuzzyMatching' => array( + 'type' => 'string', + ), + 'SortExpression' => 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', + ), + ), + ), + ), + 'ListDomainNamesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'DomainNames' => 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, + ), + ), + ), + 'UpdateAvailabilityOptionsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'AvailabilityOptions' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Options' => array( + 'type' => 'boolean', + ), + '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', + ), + ), + ), + ), + ), + ), + ), + 'UpdateScalingParametersResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ScalingParameters' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Options' => array( + 'type' => 'object', + 'properties' => array( + 'DesiredInstanceType' => array( + 'type' => 'string', + ), + 'DesiredReplicationCount' => array( + 'type' => 'numeric', + ), + 'DesiredPartitionCount' => array( + 'type' => 'numeric', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + ), + ), + 'iterators' => array( + 'DescribeAnalysisSchemes' => array( + 'result_key' => 'AnalysisSchemes', + ), + 'DescribeDomains' => array( + 'result_key' => 'DomainStatusList', + ), + 'DescribeExpressions' => array( + 'result_key' => 'Expressions', + ), + 'DescribeIndexFields' => array( + 'result_key' => 'IndexFields', + ), + 'DescribeSuggesters' => array( + 'result_key' => 'Suggesters', + ), + ), +); diff --git a/vendor/aws/Aws/CloudSearchDomain/CloudSearchDomainClient.php b/vendor/aws/Aws/CloudSearchDomain/CloudSearchDomainClient.php new file mode 100644 index 0000000..31296a7 --- /dev/null +++ b/vendor/aws/Aws/CloudSearchDomain/CloudSearchDomainClient.php @@ -0,0 +1,54 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/cloudsearchdomain-%s.php' + )) + ->build(); + } + + /** + * @internal + * @throws BadMethodCallException Do not call this method. + */ + public function setRegion($region) + { + throw new BadMethodCallException('You cannot change the region of a CloudSearchDomain client.'); + } +} diff --git a/vendor/aws/Aws/CloudSearchDomain/CloudSearchDomainClientBuilder.php b/vendor/aws/Aws/CloudSearchDomain/CloudSearchDomainClientBuilder.php new file mode 100644 index 0000000..9de513c --- /dev/null +++ b/vendor/aws/Aws/CloudSearchDomain/CloudSearchDomainClientBuilder.php @@ -0,0 +1,122 @@ + 'https', + ); + + public function build() + { + // Resolve configuration + $config = Collection::fromConfig( + $this->config, + array_merge(self::$commonConfigDefaults, $this->configDefaults), + $this->configRequirements + ); + + $endpoint = $config['endpoint'] ?: $config[Options::BASE_URL]; + + // Make sure endpoint is correctly set + if (!$endpoint) { + throw new InvalidArgumentException('You must provide the endpoint for the CloudSearch domain.'); + } + + if (strpos($endpoint, 'http') !== 0) { + $endpoint = $config[Options::SCHEME] . '://' . $endpoint; + $config['endpoint'] = $endpoint; + $config[Options::BASE_URL] = $endpoint; + } + + // Determine the region from the endpoint + $endpoint = Url::factory($endpoint); + list(,$region) = explode('.', $endpoint->getHost()); + $config[Options::REGION] = $config[Options::SIGNATURE_REGION] = $region; + + // Create dependencies + $exceptionParser = new JsonQueryExceptionParser(); + $description = ServiceDescription::factory(sprintf( + $config->get(Options::SERVICE_DESCRIPTION), + $config->get(Options::VERSION) + )); + $signature = $this->getSignature($description, $config); + $credentials = $this->getCredentials($config); + + // 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($exceptionParser, + // Retry failed requests due to transient network or cURL problems + new CurlBackoffStrategy(null, + // Retry failed requests with 500-level responses + new HttpBackoffStrategy(array(500, 503, 504, 509), + new ExponentialBackoffStrategy() + ) + ) + ) + ) + ); + $config->set(Options::BACKOFF, $backoff); + } + if ($backoff) { + $this->addBackoffLogger($backoff, $config); + } + + // Create client + $client = new CloudSearchDomainClient($credentials, $signature, $config); + $client->setDescription($description); + + // Add exception marshaling so that more descriptive exception are thrown + $client->addSubscriber(new ExceptionListener(new NamespaceExceptionFactory( + $exceptionParser, + __NAMESPACE__ . '\\Exception', + __NAMESPACE__ . '\\Exception\\CloudSearchDomainException' + ))); + + // 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' + ); + + // 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; + } +} diff --git a/vendor/aws/Aws/CloudSearchDomain/Exception/CloudSearchDomainException.php b/vendor/aws/Aws/CloudSearchDomain/Exception/CloudSearchDomainException.php new file mode 100644 index 0000000..009a001 --- /dev/null +++ b/vendor/aws/Aws/CloudSearchDomain/Exception/CloudSearchDomainException.php @@ -0,0 +1,10 @@ + '2013-01-01', + 'endpointPrefix' => 'cloudsearchdomain', + 'serviceFullName' => 'Amazon CloudSearch Domain', + 'serviceType' => 'rest-json', + 'signatureVersion' => 'v4', + 'signingName' => 'cloudsearch', + 'namespace' => 'CloudSearchDomain', + 'operations' => array( + 'Search' => array( + 'httpMethod' => 'GET', + 'uri' => '/2013-01-01/search?format=sdk&pretty=true', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'SearchResponse', + 'responseType' => 'model', + 'parameters' => array( + 'cursor' => array( + 'type' => 'string', + 'location' => 'query', + ), + 'expr' => array( + 'type' => 'string', + 'location' => 'query', + ), + 'facet' => array( + 'type' => 'string', + 'location' => 'query', + ), + 'filterQuery' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'fq', + ), + 'highlight' => array( + 'type' => 'string', + 'location' => 'query', + ), + 'partial' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'query', + ), + 'query' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'q', + ), + 'queryOptions' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'q.options', + ), + 'queryParser' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'q.parser', + ), + 'return' => array( + 'type' => 'string', + 'location' => 'query', + ), + 'size' => array( + 'type' => 'numeric', + 'location' => 'query', + ), + 'sort' => array( + 'type' => 'string', + 'location' => 'query', + ), + 'start' => array( + 'type' => 'numeric', + 'location' => 'query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Information about any problems encountered while processing a search request.', + 'class' => 'SearchException', + ), + ), + ), + 'Suggest' => array( + 'httpMethod' => 'GET', + 'uri' => '/2013-01-01/suggest?format=sdk&pretty=true', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'SuggestResponse', + 'responseType' => 'model', + 'parameters' => array( + 'query' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'q', + ), + 'suggester' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'query', + ), + 'size' => array( + 'type' => 'numeric', + 'location' => 'query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Information about any problems encountered while processing a search request.', + 'class' => 'SearchException', + ), + ), + ), + 'UploadDocuments' => array( + 'httpMethod' => 'POST', + 'uri' => '/2013-01-01/documents/batch?format=sdk', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'UploadDocumentsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'documents' => array( + 'required' => true, + 'type' => array( + 'string', + 'object', + ), + 'location' => 'body', + ), + 'contentType' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'Content-Type', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Information about any problems encountered while processing an upload request.', + 'class' => 'DocumentServiceException', + ), + ), + ), + ), + 'models' => array( + 'SearchResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'status' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'timems' => array( + 'type' => 'numeric', + ), + 'rid' => array( + 'type' => 'string', + ), + ), + ), + 'hits' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'found' => array( + 'type' => 'numeric', + ), + 'start' => array( + 'type' => 'numeric', + ), + 'cursor' => array( + 'type' => 'string', + ), + 'hit' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Hit', + 'type' => 'object', + 'properties' => array( + 'id' => array( + 'type' => 'string', + ), + 'fields' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + ), + 'highlights' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'facets' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'buckets' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Bucket', + 'type' => 'object', + 'properties' => array( + 'value' => array( + 'type' => 'string', + ), + 'count' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'SuggestResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'status' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'timems' => array( + 'type' => 'numeric', + ), + 'rid' => array( + 'type' => 'string', + ), + ), + ), + 'suggest' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'query' => array( + 'type' => 'string', + ), + 'found' => array( + 'type' => 'numeric', + ), + 'suggestions' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'SuggestionMatch', + 'type' => 'object', + 'properties' => array( + 'suggestion' => array( + 'type' => 'string', + ), + 'score' => array( + 'type' => 'numeric', + ), + 'id' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'UploadDocumentsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'status' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'adds' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'deletes' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'warnings' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'DocumentServiceWarning', + 'type' => 'object', + 'properties' => array( + 'message' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), +); diff --git a/vendor/aws/Aws/CloudTrail/CloudTrailClient.php b/vendor/aws/Aws/CloudTrail/CloudTrailClient.php new file mode 100644 index 0000000..61075c0 --- /dev/null +++ b/vendor/aws/Aws/CloudTrail/CloudTrailClient.php @@ -0,0 +1,65 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/cloudtrail-%s.php' + )) + ->setExceptionParser(new JsonQueryExceptionParser()) + ->build(); + } +} diff --git a/vendor/aws/Aws/CloudTrail/Exception/CloudTrailException.php b/vendor/aws/Aws/CloudTrail/Exception/CloudTrailException.php new file mode 100644 index 0000000..e197599 --- /dev/null +++ b/vendor/aws/Aws/CloudTrail/Exception/CloudTrailException.php @@ -0,0 +1,24 @@ +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; + } +} diff --git a/vendor/aws/Aws/CloudTrail/LogFileReader.php b/vendor/aws/Aws/CloudTrail/LogFileReader.php new file mode 100644 index 0000000..de5173f --- /dev/null +++ b/vendor/aws/Aws/CloudTrail/LogFileReader.php @@ -0,0 +1,56 @@ +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(); + } + } +} diff --git a/vendor/aws/Aws/CloudTrail/LogRecordIterator.php b/vendor/aws/Aws/CloudTrail/LogRecordIterator.php new file mode 100644 index 0000000..d66cf59 --- /dev/null +++ b/vendor/aws/Aws/CloudTrail/LogRecordIterator.php @@ -0,0 +1,180 @@ + $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; + } +} diff --git a/vendor/aws/Aws/CloudTrail/Resources/cloudtrail-2013-11-01.php b/vendor/aws/Aws/CloudTrail/Resources/cloudtrail-2013-11-01.php new file mode 100644 index 0000000..b354503 --- /dev/null +++ b/vendor/aws/Aws/CloudTrail/Resources/cloudtrail-2013-11-01.php @@ -0,0 +1,752 @@ + '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( + 'ap-northeast-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'cloudtrail.ap-northeast-1.amazonaws.com', + ), + 'ap-southeast-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'cloudtrail.ap-southeast-1.amazonaws.com', + ), + 'ap-southeast-2' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'cloudtrail.ap-southeast-2.amazonaws.com', + ), + 'eu-west-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'cloudtrail.eu-west-1.amazonaws.com', + ), + 'us-east-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'cloudtrail.us-east-1.amazonaws.com', + ), + 'us-west-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'cloudtrail.us-west-1.amazonaws.com', + ), + 'us-west-2' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'cloudtrail.us-west-2.amazonaws.com', + ), + 'sa-east-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'cloudtrail.sa-east-1.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( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'S3BucketName' => array( + 'required' => true, + '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', + ), + 'CloudWatchLogsLogGroupArn' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'CloudWatchLogsRoleArn' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + '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 the provided CloudWatch log group is not valid.', + 'class' => 'InvalidCloudWatchLogsLogGroupArnException', + ), + array( + 'reason' => 'This exception is thrown when the provided role is not valid.', + 'class' => 'InvalidCloudWatchLogsRoleArnException', + ), + array( + 'reason' => 'Cannot set a CloudWatch Logs delivery for this region.', + 'class' => 'CloudWatchLogsDeliveryUnavailableException', + ), + ), + ), + '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', + ), + ), + ), + 'LookupEvents' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'LookupEventsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + '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.LookupEvents', + ), + 'LookupAttributes' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'LookupAttribute', + 'type' => 'object', + 'properties' => array( + 'AttributeKey' => array( + 'required' => true, + 'type' => 'string', + ), + 'AttributeValue' => array( + 'required' => true, + 'type' => 'string', + ), + ), + ), + ), + 'StartTime' => array( + 'type' => array( + 'object', + 'string', + 'integer', + ), + 'format' => 'date-time', + 'location' => 'json', + ), + 'EndTime' => array( + 'type' => array( + 'object', + 'string', + 'integer', + ), + 'format' => 'date-time', + 'location' => 'json', + ), + 'MaxResults' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 50, + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Occurs when an invalid lookup attribute is specified.', + 'class' => 'InvalidLookupAttributesException', + ), + array( + 'reason' => 'Occurs if the timestamp values are invalid. Either the start time occurs after the end time or the time range is outside the range of possible values.', + 'class' => 'InvalidTimeRangeException', + ), + array( + 'reason' => 'This exception is thrown if the limit specified is invalid.', + 'class' => 'InvalidMaxResultsException', + ), + array( + 'reason' => 'Invalid token or token that was previously used in a request with different parameters. This exception is thrown if the token is invalid.', + 'class' => 'InvalidNextTokenException', + ), + ), + ), + '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( + 'required' => true, + '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', + ), + 'CloudWatchLogsLogGroupArn' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'CloudWatchLogsRoleArn' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + '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 the provided CloudWatch log group is not valid.', + 'class' => 'InvalidCloudWatchLogsLogGroupArnException', + ), + array( + 'reason' => 'This exception is thrown when the provided role is not valid.', + 'class' => 'InvalidCloudWatchLogsRoleArnException', + ), + array( + 'reason' => 'Cannot set a CloudWatch Logs delivery for this region.', + 'class' => 'CloudWatchLogsDeliveryUnavailableException', + ), + ), + ), + ), + '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', + ), + 'CloudWatchLogsLogGroupArn' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'CloudWatchLogsRoleArn' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + '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', + ), + 'CloudWatchLogsLogGroupArn' => array( + 'type' => 'string', + ), + 'CloudWatchLogsRoleArn' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + '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', + ), + 'LatestCloudWatchLogsDeliveryError' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'LatestCloudWatchLogsDeliveryTime' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'LookupEventsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Events' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Event', + 'type' => 'object', + 'properties' => array( + 'EventId' => array( + 'type' => 'string', + ), + 'EventName' => array( + 'type' => 'string', + ), + 'EventTime' => array( + 'type' => 'string', + ), + 'Username' => array( + 'type' => 'string', + ), + 'Resources' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Resource', + 'type' => 'object', + 'properties' => array( + 'ResourceType' => array( + 'type' => 'string', + ), + 'ResourceName' => array( + 'type' => 'string', + ), + ), + ), + ), + 'CloudTrailEvent' => array( + 'type' => 'string', + ), + ), + ), + ), + 'NextToken' => 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', + ), + 'CloudWatchLogsLogGroupArn' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'CloudWatchLogsRoleArn' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + ), + 'iterators' => array( + 'DescribeTrails' => array( + 'result_key' => 'trailList', + ), + ), +); diff --git a/vendor/aws/Aws/CloudWatch/CloudWatchClient.php b/vendor/aws/Aws/CloudWatch/CloudWatchClient.php new file mode 100644 index 0000000..c33e540 --- /dev/null +++ b/vendor/aws/Aws/CloudWatch/CloudWatchClient.php @@ -0,0 +1,70 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/cloudwatch-%s.php' + )) + ->build(); + } +} diff --git a/vendor/aws/Aws/CloudWatch/Enum/ComparisonOperator.php b/vendor/aws/Aws/CloudWatch/Enum/ComparisonOperator.php new file mode 100644 index 0000000..61dc947 --- /dev/null +++ b/vendor/aws/Aws/CloudWatch/Enum/ComparisonOperator.php @@ -0,0 +1,30 @@ + '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( + 'DescribeAlarmHistory' => array( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'limit_key' => 'MaxRecords', + 'result_key' => 'AlarmHistoryItems', + ), + 'DescribeAlarms' => array( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'limit_key' => 'MaxRecords', + 'result_key' => 'MetricAlarms', + ), + 'DescribeAlarmsForMetric' => array( + 'result_key' => 'MetricAlarms', + ), + 'ListMetrics' => array( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'result_key' => 'Metrics', + ), + ), +); diff --git a/vendor/aws/Aws/CloudWatchLogs/CloudWatchLogsClient.php b/vendor/aws/Aws/CloudWatchLogs/CloudWatchLogsClient.php new file mode 100644 index 0000000..99ca993 --- /dev/null +++ b/vendor/aws/Aws/CloudWatchLogs/CloudWatchLogsClient.php @@ -0,0 +1,58 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/cloudwatchlogs-%s.php' + )) + ->setExceptionParser(new JsonQueryExceptionParser()) + ->build(); + } +} diff --git a/vendor/aws/Aws/CloudWatchLogs/Exception/CloudWatchLogsException.php b/vendor/aws/Aws/CloudWatchLogs/Exception/CloudWatchLogsException.php new file mode 100644 index 0000000..d49bc9d --- /dev/null +++ b/vendor/aws/Aws/CloudWatchLogs/Exception/CloudWatchLogsException.php @@ -0,0 +1,10 @@ + '2014-03-28', + 'endpointPrefix' => 'logs', + 'serviceFullName' => 'Amazon CloudWatch Logs', + 'serviceType' => 'json', + 'jsonVersion' => '1.1', + 'targetPrefix' => 'Logs_20140328.', + 'signatureVersion' => 'v4', + 'namespace' => 'CloudWatchLogs', + 'regions' => array( + 'us-east-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'logs.us-east-1.amazonaws.com', + ), + ), + 'operations' => array( + 'CreateLogGroup' => 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' => 'Logs_20140328.CreateLogGroup', + ), + 'logGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 512, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Returned if the specified resource already exists.', + 'class' => 'ResourceAlreadyExistsException', + ), + array( + 'reason' => 'Returned if you have reached the maximum number of resources that can be created.', + 'class' => 'LimitExceededException', + ), + array( + 'reason' => 'Returned if multiple requests to update the same resource were in conflict.', + 'class' => 'OperationAbortedException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + 'CreateLogStream' => 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' => 'Logs_20140328.CreateLogStream', + ), + 'logGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 512, + ), + 'logStreamName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 512, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Returned if the specified resource already exists.', + 'class' => 'ResourceAlreadyExistsException', + ), + array( + 'reason' => 'Returned if the specified resource does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + 'DeleteLogGroup' => 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' => 'Logs_20140328.DeleteLogGroup', + ), + 'logGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 512, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Returned if the specified resource does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Returned if multiple requests to update the same resource were in conflict.', + 'class' => 'OperationAbortedException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + 'DeleteLogStream' => 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' => 'Logs_20140328.DeleteLogStream', + ), + 'logGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 512, + ), + 'logStreamName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 512, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Returned if the specified resource does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Returned if multiple requests to update the same resource were in conflict.', + 'class' => 'OperationAbortedException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + 'DeleteMetricFilter' => 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' => 'Logs_20140328.DeleteMetricFilter', + ), + 'logGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 512, + ), + 'filterName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 512, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Returned if the specified resource does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Returned if multiple requests to update the same resource were in conflict.', + 'class' => 'OperationAbortedException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + 'DeleteRetentionPolicy' => 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' => 'Logs_20140328.DeleteRetentionPolicy', + ), + 'logGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 512, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Returned if the specified resource does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Returned if multiple requests to update the same resource were in conflict.', + 'class' => 'OperationAbortedException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + 'DescribeLogGroups' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeLogGroupsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'Logs_20140328.DescribeLogGroups', + ), + 'logGroupNamePrefix' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 512, + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + ), + 'limit' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 50, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + 'DescribeLogStreams' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeLogStreamsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'Logs_20140328.DescribeLogStreams', + ), + 'logGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 512, + ), + 'logStreamNamePrefix' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 512, + ), + 'orderBy' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'descending' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + ), + 'limit' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 50, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Returned if the specified resource does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + 'DescribeMetricFilters' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeMetricFiltersResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'Logs_20140328.DescribeMetricFilters', + ), + 'logGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 512, + ), + 'filterNamePrefix' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 512, + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + ), + 'limit' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 50, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Returned if the specified resource does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + 'GetLogEvents' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GetLogEventsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'Logs_20140328.GetLogEvents', + ), + 'logGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 512, + ), + 'logStreamName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 512, + ), + 'startTime' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'endTime' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + ), + 'limit' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 10000, + ), + 'startFromHead' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Returned if the specified resource does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + 'PutLogEvents' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'PutLogEventsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'Logs_20140328.PutLogEvents', + ), + 'logGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 512, + ), + 'logStreamName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 512, + ), + 'logEvents' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'minItems' => 1, + 'maxItems' => 10000, + 'items' => array( + 'name' => 'InputLogEvent', + 'type' => 'object', + 'properties' => array( + 'timestamp' => array( + 'required' => true, + 'type' => 'numeric', + ), + 'message' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + ), + ), + ), + ), + 'sequenceToken' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterException', + ), + array( + 'class' => 'InvalidSequenceTokenException', + ), + array( + 'class' => 'DataAlreadyAcceptedException', + ), + array( + 'reason' => 'Returned if the specified resource does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Returned if multiple requests to update the same resource were in conflict.', + 'class' => 'OperationAbortedException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + 'PutMetricFilter' => 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' => 'Logs_20140328.PutMetricFilter', + ), + 'logGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 512, + ), + 'filterName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 512, + ), + 'filterPattern' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 512, + ), + 'metricTransformations' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'minItems' => 1, + 'maxItems' => 1, + 'items' => array( + 'name' => 'MetricTransformation', + 'type' => 'object', + 'properties' => array( + 'metricName' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 255, + ), + 'metricNamespace' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 255, + ), + 'metricValue' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 100, + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Returned if the specified resource does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Returned if multiple requests to update the same resource were in conflict.', + 'class' => 'OperationAbortedException', + ), + array( + 'reason' => 'Returned if you have reached the maximum number of resources that can be created.', + 'class' => 'LimitExceededException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + 'PutRetentionPolicy' => 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' => 'Logs_20140328.PutRetentionPolicy', + ), + 'logGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 512, + ), + 'retentionInDays' => array( + 'required' => true, + 'type' => 'numeric', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Returned if the specified resource does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Returned if multiple requests to update the same resource were in conflict.', + 'class' => 'OperationAbortedException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + 'TestMetricFilter' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'TestMetricFilterResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'Logs_20140328.TestMetricFilter', + ), + 'filterPattern' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 512, + ), + 'logEventMessages' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'minItems' => 1, + 'maxItems' => 50, + 'items' => array( + 'name' => 'EventMessage', + 'type' => 'string', + 'minLength' => 1, + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + ), + 'models' => array( + 'EmptyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + ), + 'DescribeLogGroupsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'logGroups' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'LogGroup', + 'type' => 'object', + 'properties' => array( + 'logGroupName' => array( + 'type' => 'string', + ), + 'creationTime' => array( + 'type' => 'numeric', + ), + 'retentionInDays' => array( + 'type' => 'numeric', + ), + 'metricFilterCount' => array( + 'type' => 'numeric', + ), + 'arn' => array( + 'type' => 'string', + ), + 'storedBytes' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DescribeLogStreamsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'logStreams' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'LogStream', + 'type' => 'object', + 'properties' => array( + 'logStreamName' => array( + 'type' => 'string', + ), + 'creationTime' => array( + 'type' => 'numeric', + ), + 'firstEventTimestamp' => array( + 'type' => 'numeric', + ), + 'lastEventTimestamp' => array( + 'type' => 'numeric', + ), + 'lastIngestionTime' => array( + 'type' => 'numeric', + ), + 'uploadSequenceToken' => array( + 'type' => 'string', + ), + 'arn' => array( + 'type' => 'string', + ), + 'storedBytes' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DescribeMetricFiltersResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'metricFilters' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'MetricFilter', + 'type' => 'object', + 'properties' => array( + 'filterName' => array( + 'type' => 'string', + ), + 'filterPattern' => array( + 'type' => 'string', + ), + 'metricTransformations' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'MetricTransformation', + 'type' => 'object', + 'properties' => array( + 'metricName' => array( + 'type' => 'string', + ), + 'metricNamespace' => array( + 'type' => 'string', + ), + 'metricValue' => array( + 'type' => 'string', + ), + ), + ), + ), + 'creationTime' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'GetLogEventsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'events' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'OutputLogEvent', + 'type' => 'object', + 'properties' => array( + 'timestamp' => array( + 'type' => 'numeric', + ), + 'message' => array( + 'type' => 'string', + ), + 'ingestionTime' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'nextForwardToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'nextBackwardToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'PutLogEventsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'nextSequenceToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'rejectedLogEventsInfo' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'tooNewLogEventStartIndex' => array( + 'type' => 'numeric', + ), + 'tooOldLogEventEndIndex' => array( + 'type' => 'numeric', + ), + 'expiredLogEventEndIndex' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + 'TestMetricFilterResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'matches' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'MetricFilterMatchRecord', + 'type' => 'object', + 'properties' => array( + 'eventNumber' => array( + 'type' => 'numeric', + ), + 'eventMessage' => array( + 'type' => 'string', + ), + 'extractedValues' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'iterators' => array( + 'DescribeLogGroups' => array( + 'input_token' => 'nextToken', + 'output_token' => 'nextToken', + 'limit_key' => 'limit', + 'result_key' => 'logGroups', + ), + 'DescribeLogStreams' => array( + 'input_token' => 'nextToken', + 'output_token' => 'nextToken', + 'limit_key' => 'limit', + 'result_key' => 'logStreams', + ), + 'DescribeMetricFilters' => array( + 'input_token' => 'nextToken', + 'output_token' => 'nextToken', + 'limit_key' => 'limit', + 'result_key' => 'metricFilters', + ), + 'GetLogEvents' => array( + 'input_token' => 'nextToken', + 'output_token' => 'nextForwardToken', + 'limit_key' => 'limit', + 'result_key' => 'events', + ), + ), +); diff --git a/vendor/aws/Aws/CodeDeploy/CodeDeployClient.php b/vendor/aws/Aws/CodeDeploy/CodeDeployClient.php new file mode 100644 index 0000000..1a9ddcb --- /dev/null +++ b/vendor/aws/Aws/CodeDeploy/CodeDeployClient.php @@ -0,0 +1,90 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/codedeploy-%s.php' + )) + ->setExceptionParser(new JsonQueryExceptionParser) + ->build(); + } +} diff --git a/vendor/aws/Aws/CodeDeploy/Exception/CodeDeployException.php b/vendor/aws/Aws/CodeDeploy/Exception/CodeDeployException.php new file mode 100644 index 0000000..349af93 --- /dev/null +++ b/vendor/aws/Aws/CodeDeploy/Exception/CodeDeployException.php @@ -0,0 +1,10 @@ + '2014-10-06', + 'endpointPrefix' => 'codedeploy', + 'serviceFullName' => 'AWS CodeDeploy', + 'serviceAbbreviation' => 'CodeDeploy', + 'serviceType' => 'json', + 'jsonVersion' => '1.1', + 'targetPrefix' => 'CodeDeploy_20141006.', + 'timestampFormat' => 'unixTimestamp', + 'signatureVersion' => 'v4', + 'namespace' => 'CodeDeploy', + 'operations' => array( + 'AddTagsToOnPremisesInstances' => 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' => 'CodeDeploy_20141006.AddTagsToOnPremisesInstances', + ), + 'tags' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + ), + ), + ), + 'instanceNames' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'InstanceName', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An on-premises instance name was not specified.', + 'class' => 'InstanceNameRequiredException', + ), + array( + 'reason' => 'A tag was not specified.', + 'class' => 'TagRequiredException', + ), + array( + 'reason' => 'The specified tag was specified in an invalid format.', + 'class' => 'InvalidTagException', + ), + array( + 'reason' => 'The maximum allowed number of tags was exceeded.', + 'class' => 'TagLimitExceededException', + ), + array( + 'reason' => 'The maximum number of allowed on-premises instances in a single call was exceeded.', + 'class' => 'InstanceLimitExceededException', + ), + array( + 'reason' => 'The specified on-premises instance is not registered.', + 'class' => 'InstanceNotRegisteredException', + ), + ), + ), + 'BatchGetApplications' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'BatchGetApplicationsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'CodeDeploy_20141006.BatchGetApplications', + ), + 'applicationNames' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'ApplicationName', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 100, + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The minimum number of required application names was not specified.', + 'class' => 'ApplicationNameRequiredException', + ), + array( + 'reason' => 'The application name was specified in an invalid format.', + 'class' => 'InvalidApplicationNameException', + ), + array( + 'reason' => 'The application does not exist with the applicable IAM user or AWS account.', + 'class' => 'ApplicationDoesNotExistException', + ), + ), + ), + 'BatchGetDeployments' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'BatchGetDeploymentsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'CodeDeploy_20141006.BatchGetDeployments', + ), + 'deploymentIds' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'DeploymentId', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'At least one deployment ID must be specified.', + 'class' => 'DeploymentIdRequiredException', + ), + array( + 'reason' => 'At least one of the deployment IDs was specified in an invalid format.', + 'class' => 'InvalidDeploymentIdException', + ), + ), + ), + 'BatchGetOnPremisesInstances' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'BatchGetOnPremisesInstancesOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'CodeDeploy_20141006.BatchGetOnPremisesInstances', + ), + 'instanceNames' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'InstanceName', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An on-premises instance name was not specified.', + 'class' => 'InstanceNameRequiredException', + ), + array( + 'reason' => 'The specified on-premises instance name was specified in an invalid format.', + 'class' => 'InvalidInstanceNameException', + ), + ), + ), + 'CreateApplication' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'CreateApplicationOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'CodeDeploy_20141006.CreateApplication', + ), + 'applicationName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 100, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The minimum number of required application names was not specified.', + 'class' => 'ApplicationNameRequiredException', + ), + array( + 'reason' => 'The application name was specified in an invalid format.', + 'class' => 'InvalidApplicationNameException', + ), + array( + 'reason' => 'An application with the specified name already exists with the applicable IAM user or AWS account.', + 'class' => 'ApplicationAlreadyExistsException', + ), + array( + 'reason' => 'More applications were attempted to be created than were allowed.', + 'class' => 'ApplicationLimitExceededException', + ), + ), + ), + 'CreateDeployment' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'CreateDeploymentOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'CodeDeploy_20141006.CreateDeployment', + ), + 'applicationName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 100, + ), + 'deploymentGroupName' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 100, + ), + 'revision' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'revisionType' => array( + 'type' => 'string', + ), + 's3Location' => array( + 'type' => 'object', + 'properties' => array( + 'bucket' => array( + 'type' => 'string', + ), + 'key' => array( + 'type' => 'string', + ), + 'bundleType' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + 'eTag' => array( + 'type' => 'string', + ), + ), + ), + 'gitHubLocation' => array( + 'type' => 'object', + 'properties' => array( + 'repository' => array( + 'type' => 'string', + ), + 'commitId' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'deploymentConfigName' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 100, + ), + 'description' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'ignoreApplicationStopFailures' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The minimum number of required application names was not specified.', + 'class' => 'ApplicationNameRequiredException', + ), + array( + 'reason' => 'The application name was specified in an invalid format.', + 'class' => 'InvalidApplicationNameException', + ), + array( + 'reason' => 'The application does not exist with the applicable IAM user or AWS account.', + 'class' => 'ApplicationDoesNotExistException', + ), + array( + 'reason' => 'The deployment group name was not specified.', + 'class' => 'DeploymentGroupNameRequiredException', + ), + array( + 'reason' => 'The deployment group name was specified in an invalid format.', + 'class' => 'InvalidDeploymentGroupNameException', + ), + array( + 'reason' => 'The named deployment group does not exist with the applicable IAM user or AWS account.', + 'class' => 'DeploymentGroupDoesNotExistException', + ), + array( + 'reason' => 'The revision ID was not specified.', + 'class' => 'RevisionRequiredException', + ), + array( + 'reason' => 'The revision was specified in an invalid format.', + 'class' => 'InvalidRevisionException', + ), + array( + 'reason' => 'The deployment configuration name was specified in an invalid format.', + 'class' => 'InvalidDeploymentConfigNameException', + ), + array( + 'reason' => 'The deployment configuration does not exist with the applicable IAM user or AWS account.', + 'class' => 'DeploymentConfigDoesNotExistException', + ), + array( + 'reason' => 'The description that was provided is too long.', + 'class' => 'DescriptionTooLongException', + ), + array( + 'reason' => 'The number of allowed deployments was exceeded.', + 'class' => 'DeploymentLimitExceededException', + ), + ), + ), + 'CreateDeploymentConfig' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'CreateDeploymentConfigOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'CodeDeploy_20141006.CreateDeploymentConfig', + ), + 'deploymentConfigName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 100, + ), + 'minimumHealthyHosts' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + '' => array( + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The deployment configuration name was specified in an invalid format.', + 'class' => 'InvalidDeploymentConfigNameException', + ), + array( + 'reason' => 'The deployment configuration name was not specified.', + 'class' => 'DeploymentConfigNameRequiredException', + ), + array( + 'reason' => 'A deployment configuration with the specified name already exists with the applicable IAM user or AWS account.', + 'class' => 'DeploymentConfigAlreadyExistsException', + ), + array( + 'reason' => 'The minimum healthy instances value was specified in an invalid format.', + 'class' => 'InvalidMinimumHealthyHostValueException', + ), + array( + 'reason' => 'The deployment configurations limit was exceeded.', + 'class' => 'DeploymentConfigLimitExceededException', + ), + ), + ), + 'CreateDeploymentGroup' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'CreateDeploymentGroupOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'CodeDeploy_20141006.CreateDeploymentGroup', + ), + 'applicationName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 100, + ), + 'deploymentGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 100, + ), + 'deploymentConfigName' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 100, + ), + 'ec2TagFilters' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'EC2TagFilter', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + 'Type' => array( + 'type' => 'string', + ), + ), + ), + ), + 'onPremisesInstanceTagFilters' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'TagFilter', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + 'Type' => array( + 'type' => 'string', + ), + ), + ), + ), + 'autoScalingGroups' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'AutoScalingGroupName', + 'type' => 'string', + ), + ), + 'serviceRoleArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The minimum number of required application names was not specified.', + 'class' => 'ApplicationNameRequiredException', + ), + array( + 'reason' => 'The application name was specified in an invalid format.', + 'class' => 'InvalidApplicationNameException', + ), + array( + 'reason' => 'The application does not exist with the applicable IAM user or AWS account.', + 'class' => 'ApplicationDoesNotExistException', + ), + array( + 'reason' => 'The deployment group name was not specified.', + 'class' => 'DeploymentGroupNameRequiredException', + ), + array( + 'reason' => 'The deployment group name was specified in an invalid format.', + 'class' => 'InvalidDeploymentGroupNameException', + ), + array( + 'reason' => 'A deployment group with the specified name already exists with the applicable IAM user or AWS account.', + 'class' => 'DeploymentGroupAlreadyExistsException', + ), + array( + 'reason' => 'The tag was specified in an invalid format.', + 'class' => 'InvalidEC2TagException', + ), + array( + 'reason' => 'The specified tag was specified in an invalid format.', + 'class' => 'InvalidTagException', + ), + array( + 'reason' => 'The Auto Scaling group was specified in an invalid format or does not exist.', + 'class' => 'InvalidAutoScalingGroupException', + ), + array( + 'reason' => 'The deployment configuration name was specified in an invalid format.', + 'class' => 'InvalidDeploymentConfigNameException', + ), + array( + 'reason' => 'The deployment configuration does not exist with the applicable IAM user or AWS account.', + 'class' => 'DeploymentConfigDoesNotExistException', + ), + array( + 'reason' => 'The role ID was not specified.', + 'class' => 'RoleRequiredException', + ), + array( + 'reason' => 'The service role ARN was specified in an invalid format. Or, if an Auto Scaling group was specified, the specified service role does not grant the appropriate permissions to Auto Scaling.', + 'class' => 'InvalidRoleException', + ), + array( + 'reason' => 'The deployment groups limit was exceeded.', + 'class' => 'DeploymentGroupLimitExceededException', + ), + ), + ), + 'DeleteApplication' => 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' => 'CodeDeploy_20141006.DeleteApplication', + ), + 'applicationName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 100, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The minimum number of required application names was not specified.', + 'class' => 'ApplicationNameRequiredException', + ), + array( + 'reason' => 'The application name was specified in an invalid format.', + 'class' => 'InvalidApplicationNameException', + ), + ), + ), + 'DeleteDeploymentConfig' => 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' => 'CodeDeploy_20141006.DeleteDeploymentConfig', + ), + 'deploymentConfigName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 100, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The deployment configuration name was specified in an invalid format.', + 'class' => 'InvalidDeploymentConfigNameException', + ), + array( + 'reason' => 'The deployment configuration name was not specified.', + 'class' => 'DeploymentConfigNameRequiredException', + ), + array( + 'reason' => 'The deployment configuration is still in use.', + 'class' => 'DeploymentConfigInUseException', + ), + array( + 'reason' => 'An invalid operation was detected.', + 'class' => 'InvalidOperationException', + ), + ), + ), + 'DeleteDeploymentGroup' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DeleteDeploymentGroupOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'CodeDeploy_20141006.DeleteDeploymentGroup', + ), + 'applicationName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 100, + ), + 'deploymentGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 100, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The minimum number of required application names was not specified.', + 'class' => 'ApplicationNameRequiredException', + ), + array( + 'reason' => 'The application name was specified in an invalid format.', + 'class' => 'InvalidApplicationNameException', + ), + array( + 'reason' => 'The deployment group name was not specified.', + 'class' => 'DeploymentGroupNameRequiredException', + ), + array( + 'reason' => 'The deployment group name was specified in an invalid format.', + 'class' => 'InvalidDeploymentGroupNameException', + ), + array( + 'reason' => 'The service role ARN was specified in an invalid format. Or, if an Auto Scaling group was specified, the specified service role does not grant the appropriate permissions to Auto Scaling.', + 'class' => 'InvalidRoleException', + ), + ), + ), + 'DeregisterOnPremisesInstance' => 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' => 'CodeDeploy_20141006.DeregisterOnPremisesInstance', + ), + 'instanceName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An on-premises instance name was not specified.', + 'class' => 'InstanceNameRequiredException', + ), + array( + 'reason' => 'The specified on-premises instance name was specified in an invalid format.', + 'class' => 'InvalidInstanceNameException', + ), + ), + ), + 'GetApplication' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GetApplicationOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'CodeDeploy_20141006.GetApplication', + ), + 'applicationName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 100, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The minimum number of required application names was not specified.', + 'class' => 'ApplicationNameRequiredException', + ), + array( + 'reason' => 'The application name was specified in an invalid format.', + 'class' => 'InvalidApplicationNameException', + ), + array( + 'reason' => 'The application does not exist with the applicable IAM user or AWS account.', + 'class' => 'ApplicationDoesNotExistException', + ), + ), + ), + 'GetApplicationRevision' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GetApplicationRevisionOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'CodeDeploy_20141006.GetApplicationRevision', + ), + 'applicationName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 100, + ), + 'revision' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'revisionType' => array( + 'type' => 'string', + ), + 's3Location' => array( + 'type' => 'object', + 'properties' => array( + 'bucket' => array( + 'type' => 'string', + ), + 'key' => array( + 'type' => 'string', + ), + 'bundleType' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + 'eTag' => array( + 'type' => 'string', + ), + ), + ), + 'gitHubLocation' => array( + 'type' => 'object', + 'properties' => array( + 'repository' => array( + 'type' => 'string', + ), + 'commitId' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The application does not exist with the applicable IAM user or AWS account.', + 'class' => 'ApplicationDoesNotExistException', + ), + array( + 'reason' => 'The minimum number of required application names was not specified.', + 'class' => 'ApplicationNameRequiredException', + ), + array( + 'reason' => 'The application name was specified in an invalid format.', + 'class' => 'InvalidApplicationNameException', + ), + array( + 'reason' => 'The named revision does not exist with the applicable IAM user or AWS account.', + 'class' => 'RevisionDoesNotExistException', + ), + array( + 'reason' => 'The revision ID was not specified.', + 'class' => 'RevisionRequiredException', + ), + array( + 'reason' => 'The revision was specified in an invalid format.', + 'class' => 'InvalidRevisionException', + ), + ), + ), + 'GetDeployment' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GetDeploymentOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'CodeDeploy_20141006.GetDeployment', + ), + 'deploymentId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'At least one deployment ID must be specified.', + 'class' => 'DeploymentIdRequiredException', + ), + array( + 'reason' => 'At least one of the deployment IDs was specified in an invalid format.', + 'class' => 'InvalidDeploymentIdException', + ), + array( + 'reason' => 'The deployment does not exist with the applicable IAM user or AWS account.', + 'class' => 'DeploymentDoesNotExistException', + ), + ), + ), + 'GetDeploymentConfig' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GetDeploymentConfigOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'CodeDeploy_20141006.GetDeploymentConfig', + ), + 'deploymentConfigName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 100, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The deployment configuration name was specified in an invalid format.', + 'class' => 'InvalidDeploymentConfigNameException', + ), + array( + 'reason' => 'The deployment configuration name was not specified.', + 'class' => 'DeploymentConfigNameRequiredException', + ), + array( + 'reason' => 'The deployment configuration does not exist with the applicable IAM user or AWS account.', + 'class' => 'DeploymentConfigDoesNotExistException', + ), + ), + ), + 'GetDeploymentGroup' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GetDeploymentGroupOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'CodeDeploy_20141006.GetDeploymentGroup', + ), + 'applicationName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 100, + ), + 'deploymentGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 100, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The minimum number of required application names was not specified.', + 'class' => 'ApplicationNameRequiredException', + ), + array( + 'reason' => 'The application name was specified in an invalid format.', + 'class' => 'InvalidApplicationNameException', + ), + array( + 'reason' => 'The application does not exist with the applicable IAM user or AWS account.', + 'class' => 'ApplicationDoesNotExistException', + ), + array( + 'reason' => 'The deployment group name was not specified.', + 'class' => 'DeploymentGroupNameRequiredException', + ), + array( + 'reason' => 'The deployment group name was specified in an invalid format.', + 'class' => 'InvalidDeploymentGroupNameException', + ), + array( + 'reason' => 'The named deployment group does not exist with the applicable IAM user or AWS account.', + 'class' => 'DeploymentGroupDoesNotExistException', + ), + ), + ), + 'GetDeploymentInstance' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GetDeploymentInstanceOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'CodeDeploy_20141006.GetDeploymentInstance', + ), + 'deploymentId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'instanceId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'At least one deployment ID must be specified.', + 'class' => 'DeploymentIdRequiredException', + ), + array( + 'reason' => 'The deployment does not exist with the applicable IAM user or AWS account.', + 'class' => 'DeploymentDoesNotExistException', + ), + array( + 'reason' => 'The instance ID was not specified.', + 'class' => 'InstanceIdRequiredException', + ), + array( + 'reason' => 'At least one of the deployment IDs was specified in an invalid format.', + 'class' => 'InvalidDeploymentIdException', + ), + array( + 'reason' => 'The specified instance does not exist in the deployment group.', + 'class' => 'InstanceDoesNotExistException', + ), + ), + ), + 'GetOnPremisesInstance' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GetOnPremisesInstanceOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'CodeDeploy_20141006.GetOnPremisesInstance', + ), + 'instanceName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An on-premises instance name was not specified.', + 'class' => 'InstanceNameRequiredException', + ), + array( + 'reason' => 'The specified on-premises instance is not registered.', + 'class' => 'InstanceNotRegisteredException', + ), + array( + 'reason' => 'The specified on-premises instance name was specified in an invalid format.', + 'class' => 'InvalidInstanceNameException', + ), + ), + ), + 'ListApplicationRevisions' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListApplicationRevisionsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'CodeDeploy_20141006.ListApplicationRevisions', + ), + 'applicationName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 100, + ), + 'sortBy' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'sortOrder' => array( + 'type' => 'string', + 'location' => 'json', + ), + 's3Bucket' => array( + 'type' => 'string', + 'location' => 'json', + ), + 's3KeyPrefix' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'deployed' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The application does not exist with the applicable IAM user or AWS account.', + 'class' => 'ApplicationDoesNotExistException', + ), + array( + 'reason' => 'The minimum number of required application names was not specified.', + 'class' => 'ApplicationNameRequiredException', + ), + array( + 'reason' => 'The application name was specified in an invalid format.', + 'class' => 'InvalidApplicationNameException', + ), + array( + 'reason' => 'The column name to sort by is either not present or was specified in an invalid format.', + 'class' => 'InvalidSortByException', + ), + array( + 'reason' => 'The sort order was specified in an invalid format.', + 'class' => 'InvalidSortOrderException', + ), + array( + 'reason' => 'The bucket name either doesn\'t exist or was specified in an invalid format.', + 'class' => 'InvalidBucketNameFilterException', + ), + array( + 'reason' => 'The specified key prefix filter was specified in an invalid format.', + 'class' => 'InvalidKeyPrefixFilterException', + ), + array( + 'reason' => 'A bucket name is required but was not provided.', + 'class' => 'BucketNameFilterRequiredException', + ), + array( + 'reason' => 'The deployed state filter was specified in an invalid format.', + 'class' => 'InvalidDeployedStateFilterException', + ), + array( + 'reason' => 'The next token was specified in an invalid format.', + 'class' => 'InvalidNextTokenException', + ), + ), + ), + 'ListApplications' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListApplicationsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'CodeDeploy_20141006.ListApplications', + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The next token was specified in an invalid format.', + 'class' => 'InvalidNextTokenException', + ), + ), + ), + 'ListDeploymentConfigs' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListDeploymentConfigsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'CodeDeploy_20141006.ListDeploymentConfigs', + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The next token was specified in an invalid format.', + 'class' => 'InvalidNextTokenException', + ), + ), + ), + 'ListDeploymentGroups' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListDeploymentGroupsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'CodeDeploy_20141006.ListDeploymentGroups', + ), + 'applicationName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 100, + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The minimum number of required application names was not specified.', + 'class' => 'ApplicationNameRequiredException', + ), + array( + 'reason' => 'The application name was specified in an invalid format.', + 'class' => 'InvalidApplicationNameException', + ), + array( + 'reason' => 'The application does not exist with the applicable IAM user or AWS account.', + 'class' => 'ApplicationDoesNotExistException', + ), + array( + 'reason' => 'The next token was specified in an invalid format.', + 'class' => 'InvalidNextTokenException', + ), + ), + ), + 'ListDeploymentInstances' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListDeploymentInstancesOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'CodeDeploy_20141006.ListDeploymentInstances', + ), + 'deploymentId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'instanceStatusFilter' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'InstanceStatus', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'At least one deployment ID must be specified.', + 'class' => 'DeploymentIdRequiredException', + ), + array( + 'reason' => 'The deployment does not exist with the applicable IAM user or AWS account.', + 'class' => 'DeploymentDoesNotExistException', + ), + array( + 'reason' => 'The specified deployment has not started.', + 'class' => 'DeploymentNotStartedException', + ), + array( + 'reason' => 'The next token was specified in an invalid format.', + 'class' => 'InvalidNextTokenException', + ), + array( + 'reason' => 'At least one of the deployment IDs was specified in an invalid format.', + 'class' => 'InvalidDeploymentIdException', + ), + array( + 'reason' => 'The specified instance status does not exist.', + 'class' => 'InvalidInstanceStatusException', + ), + ), + ), + 'ListDeployments' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListDeploymentsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'CodeDeploy_20141006.ListDeployments', + ), + 'applicationName' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 100, + ), + 'deploymentGroupName' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 100, + ), + 'includeOnlyStatuses' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'DeploymentStatus', + 'type' => 'string', + ), + ), + 'createTimeRange' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'start' => array( + 'type' => array( + 'object', + 'string', + 'integer', + ), + 'format' => 'timestamp', + ), + 'end' => array( + 'type' => array( + 'object', + 'string', + 'integer', + ), + 'format' => 'timestamp', + ), + ), + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The minimum number of required application names was not specified.', + 'class' => 'ApplicationNameRequiredException', + ), + array( + 'reason' => 'The application name was specified in an invalid format.', + 'class' => 'InvalidApplicationNameException', + ), + array( + 'reason' => 'The application does not exist with the applicable IAM user or AWS account.', + 'class' => 'ApplicationDoesNotExistException', + ), + array( + 'reason' => 'The deployment group name was specified in an invalid format.', + 'class' => 'InvalidDeploymentGroupNameException', + ), + array( + 'reason' => 'The named deployment group does not exist with the applicable IAM user or AWS account.', + 'class' => 'DeploymentGroupDoesNotExistException', + ), + array( + 'reason' => 'The deployment group name was not specified.', + 'class' => 'DeploymentGroupNameRequiredException', + ), + array( + 'reason' => 'The specified time range was specified in an invalid format.', + 'class' => 'InvalidTimeRangeException', + ), + array( + 'reason' => 'The specified deployment status doesn\'t exist or cannot be determined.', + 'class' => 'InvalidDeploymentStatusException', + ), + array( + 'reason' => 'The next token was specified in an invalid format.', + 'class' => 'InvalidNextTokenException', + ), + ), + ), + 'ListOnPremisesInstances' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListOnPremisesInstancesOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'CodeDeploy_20141006.ListOnPremisesInstances', + ), + 'registrationStatus' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'tagFilters' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'TagFilter', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + 'Type' => array( + 'type' => 'string', + ), + ), + ), + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The registration status was specified in an invalid format.', + 'class' => 'InvalidRegistrationStatusException', + ), + array( + 'reason' => 'The specified tag filter was specified in an invalid format.', + 'class' => 'InvalidTagFilterException', + ), + array( + 'reason' => 'The next token was specified in an invalid format.', + 'class' => 'InvalidNextTokenException', + ), + ), + ), + 'RegisterApplicationRevision' => 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' => 'CodeDeploy_20141006.RegisterApplicationRevision', + ), + 'applicationName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 100, + ), + 'description' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'revision' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'revisionType' => array( + 'type' => 'string', + ), + 's3Location' => array( + 'type' => 'object', + 'properties' => array( + 'bucket' => array( + 'type' => 'string', + ), + 'key' => array( + 'type' => 'string', + ), + 'bundleType' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + 'eTag' => array( + 'type' => 'string', + ), + ), + ), + 'gitHubLocation' => array( + 'type' => 'object', + 'properties' => array( + 'repository' => array( + 'type' => 'string', + ), + 'commitId' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The application does not exist with the applicable IAM user or AWS account.', + 'class' => 'ApplicationDoesNotExistException', + ), + array( + 'reason' => 'The minimum number of required application names was not specified.', + 'class' => 'ApplicationNameRequiredException', + ), + array( + 'reason' => 'The application name was specified in an invalid format.', + 'class' => 'InvalidApplicationNameException', + ), + array( + 'reason' => 'The description that was provided is too long.', + 'class' => 'DescriptionTooLongException', + ), + array( + 'reason' => 'The revision ID was not specified.', + 'class' => 'RevisionRequiredException', + ), + array( + 'reason' => 'The revision was specified in an invalid format.', + 'class' => 'InvalidRevisionException', + ), + ), + ), + 'RegisterOnPremisesInstance' => 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' => 'CodeDeploy_20141006.RegisterOnPremisesInstance', + ), + 'instanceName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'iamUserArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified on-premises instance name is already registered.', + 'class' => 'InstanceNameAlreadyRegisteredException', + ), + array( + 'reason' => 'The specified IAM user ARN is already registered with an on-premises instance.', + 'class' => 'IamUserArnAlreadyRegisteredException', + ), + array( + 'reason' => 'An on-premises instance name was not specified.', + 'class' => 'InstanceNameRequiredException', + ), + array( + 'reason' => 'An IAM user ARN was not specified.', + 'class' => 'IamUserArnRequiredException', + ), + array( + 'reason' => 'The specified on-premises instance name was specified in an invalid format.', + 'class' => 'InvalidInstanceNameException', + ), + array( + 'reason' => 'The IAM user ARN was specified in an invalid format.', + 'class' => 'InvalidIamUserArnException', + ), + ), + ), + 'RemoveTagsFromOnPremisesInstances' => 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' => 'CodeDeploy_20141006.RemoveTagsFromOnPremisesInstances', + ), + 'tags' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + ), + ), + ), + 'instanceNames' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'InstanceName', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An on-premises instance name was not specified.', + 'class' => 'InstanceNameRequiredException', + ), + array( + 'reason' => 'A tag was not specified.', + 'class' => 'TagRequiredException', + ), + array( + 'reason' => 'The specified tag was specified in an invalid format.', + 'class' => 'InvalidTagException', + ), + array( + 'reason' => 'The maximum allowed number of tags was exceeded.', + 'class' => 'TagLimitExceededException', + ), + array( + 'reason' => 'The maximum number of allowed on-premises instances in a single call was exceeded.', + 'class' => 'InstanceLimitExceededException', + ), + array( + 'reason' => 'The specified on-premises instance is not registered.', + 'class' => 'InstanceNotRegisteredException', + ), + ), + ), + 'StopDeployment' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'StopDeploymentOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'CodeDeploy_20141006.StopDeployment', + ), + 'deploymentId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'At least one deployment ID must be specified.', + 'class' => 'DeploymentIdRequiredException', + ), + array( + 'reason' => 'The deployment does not exist with the applicable IAM user or AWS account.', + 'class' => 'DeploymentDoesNotExistException', + ), + array( + 'reason' => 'The deployment is already completed.', + 'class' => 'DeploymentAlreadyCompletedException', + ), + array( + 'reason' => 'At least one of the deployment IDs was specified in an invalid format.', + 'class' => 'InvalidDeploymentIdException', + ), + ), + ), + 'UpdateApplication' => 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' => 'CodeDeploy_20141006.UpdateApplication', + ), + 'applicationName' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 100, + ), + 'newApplicationName' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 100, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The minimum number of required application names was not specified.', + 'class' => 'ApplicationNameRequiredException', + ), + array( + 'reason' => 'The application name was specified in an invalid format.', + 'class' => 'InvalidApplicationNameException', + ), + array( + 'reason' => 'An application with the specified name already exists with the applicable IAM user or AWS account.', + 'class' => 'ApplicationAlreadyExistsException', + ), + array( + 'reason' => 'The application does not exist with the applicable IAM user or AWS account.', + 'class' => 'ApplicationDoesNotExistException', + ), + ), + ), + 'UpdateDeploymentGroup' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'UpdateDeploymentGroupOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'CodeDeploy_20141006.UpdateDeploymentGroup', + ), + 'applicationName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 100, + ), + 'currentDeploymentGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 100, + ), + 'newDeploymentGroupName' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 100, + ), + 'deploymentConfigName' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 100, + ), + 'ec2TagFilters' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'EC2TagFilter', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + 'Type' => array( + 'type' => 'string', + ), + ), + ), + ), + 'onPremisesInstanceTagFilters' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'TagFilter', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + 'Type' => array( + 'type' => 'string', + ), + ), + ), + ), + 'autoScalingGroups' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'AutoScalingGroupName', + 'type' => 'string', + ), + ), + 'serviceRoleArn' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The minimum number of required application names was not specified.', + 'class' => 'ApplicationNameRequiredException', + ), + array( + 'reason' => 'The application name was specified in an invalid format.', + 'class' => 'InvalidApplicationNameException', + ), + array( + 'reason' => 'The application does not exist with the applicable IAM user or AWS account.', + 'class' => 'ApplicationDoesNotExistException', + ), + array( + 'reason' => 'The deployment group name was specified in an invalid format.', + 'class' => 'InvalidDeploymentGroupNameException', + ), + array( + 'reason' => 'A deployment group with the specified name already exists with the applicable IAM user or AWS account.', + 'class' => 'DeploymentGroupAlreadyExistsException', + ), + array( + 'reason' => 'The deployment group name was not specified.', + 'class' => 'DeploymentGroupNameRequiredException', + ), + array( + 'reason' => 'The named deployment group does not exist with the applicable IAM user or AWS account.', + 'class' => 'DeploymentGroupDoesNotExistException', + ), + array( + 'reason' => 'The tag was specified in an invalid format.', + 'class' => 'InvalidEC2TagException', + ), + array( + 'reason' => 'The specified tag was specified in an invalid format.', + 'class' => 'InvalidTagException', + ), + array( + 'reason' => 'The Auto Scaling group was specified in an invalid format or does not exist.', + 'class' => 'InvalidAutoScalingGroupException', + ), + array( + 'reason' => 'The deployment configuration name was specified in an invalid format.', + 'class' => 'InvalidDeploymentConfigNameException', + ), + array( + 'reason' => 'The deployment configuration does not exist with the applicable IAM user or AWS account.', + 'class' => 'DeploymentConfigDoesNotExistException', + ), + array( + 'reason' => 'The service role ARN was specified in an invalid format. Or, if an Auto Scaling group was specified, the specified service role does not grant the appropriate permissions to Auto Scaling.', + 'class' => 'InvalidRoleException', + ), + ), + ), + ), + 'models' => array( + 'EmptyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + ), + 'BatchGetApplicationsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'applicationsInfo' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'ApplicationInfo', + 'type' => 'object', + 'properties' => array( + 'applicationId' => array( + 'type' => 'string', + ), + 'applicationName' => array( + 'type' => 'string', + ), + 'createTime' => array( + 'type' => 'string', + ), + 'linkedToGitHub' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + ), + 'BatchGetDeploymentsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'deploymentsInfo' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'DeploymentInfo', + 'type' => 'object', + 'properties' => array( + 'applicationName' => array( + 'type' => 'string', + ), + 'deploymentGroupName' => array( + 'type' => 'string', + ), + 'deploymentConfigName' => array( + 'type' => 'string', + ), + 'deploymentId' => array( + 'type' => 'string', + ), + 'revision' => array( + 'type' => 'object', + 'properties' => array( + 'revisionType' => array( + 'type' => 'string', + ), + 's3Location' => array( + 'type' => 'object', + 'properties' => array( + 'bucket' => array( + 'type' => 'string', + ), + 'key' => array( + 'type' => 'string', + ), + 'bundleType' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + 'eTag' => array( + 'type' => 'string', + ), + ), + ), + 'gitHubLocation' => array( + 'type' => 'object', + 'properties' => array( + 'repository' => array( + 'type' => 'string', + ), + 'commitId' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'status' => array( + 'type' => 'string', + ), + 'errorInformation' => array( + 'type' => 'object', + 'properties' => array( + 'code' => array( + 'type' => 'string', + ), + 'message' => array( + 'type' => 'string', + ), + ), + ), + 'createTime' => array( + 'type' => 'string', + ), + 'startTime' => array( + 'type' => 'string', + ), + 'completeTime' => array( + 'type' => 'string', + ), + 'deploymentOverview' => array( + 'type' => 'object', + 'properties' => array( + 'Pending' => array( + 'type' => 'numeric', + ), + 'InProgress' => array( + 'type' => 'numeric', + ), + 'Succeeded' => array( + 'type' => 'numeric', + ), + 'Failed' => array( + 'type' => 'numeric', + ), + 'Skipped' => array( + 'type' => 'numeric', + ), + ), + ), + 'description' => array( + 'type' => 'string', + ), + 'creator' => array( + 'type' => 'string', + ), + 'ignoreApplicationStopFailures' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + ), + 'BatchGetOnPremisesInstancesOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'instanceInfos' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'InstanceInfo', + 'type' => 'object', + 'properties' => array( + 'instanceName' => array( + 'type' => 'string', + ), + 'iamUserArn' => array( + 'type' => 'string', + ), + 'instanceArn' => array( + 'type' => 'string', + ), + 'registerTime' => array( + 'type' => 'string', + ), + 'deregisterTime' => array( + 'type' => 'string', + ), + 'tags' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'CreateApplicationOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'applicationId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'CreateDeploymentOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'deploymentId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'CreateDeploymentConfigOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'deploymentConfigId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'CreateDeploymentGroupOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'deploymentGroupId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DeleteDeploymentGroupOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'hooksNotCleanedUp' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'AutoScalingGroup', + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'hook' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'GetApplicationOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'application' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'applicationId' => array( + 'type' => 'string', + ), + 'applicationName' => array( + 'type' => 'string', + ), + 'createTime' => array( + 'type' => 'string', + ), + 'linkedToGitHub' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + 'GetApplicationRevisionOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'applicationName' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'revision' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'revisionType' => array( + 'type' => 'string', + ), + 's3Location' => array( + 'type' => 'object', + 'properties' => array( + 'bucket' => array( + 'type' => 'string', + ), + 'key' => array( + 'type' => 'string', + ), + 'bundleType' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + 'eTag' => array( + 'type' => 'string', + ), + ), + ), + 'gitHubLocation' => array( + 'type' => 'object', + 'properties' => array( + 'repository' => array( + 'type' => 'string', + ), + 'commitId' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'revisionInfo' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'description' => array( + 'type' => 'string', + ), + 'deploymentGroups' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'DeploymentGroupName', + 'type' => 'string', + ), + ), + 'firstUsedTime' => array( + 'type' => 'string', + ), + 'lastUsedTime' => array( + 'type' => 'string', + ), + 'registerTime' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'GetDeploymentOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'deploymentInfo' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'applicationName' => array( + 'type' => 'string', + ), + 'deploymentGroupName' => array( + 'type' => 'string', + ), + 'deploymentConfigName' => array( + 'type' => 'string', + ), + 'deploymentId' => array( + 'type' => 'string', + ), + 'revision' => array( + 'type' => 'object', + 'properties' => array( + 'revisionType' => array( + 'type' => 'string', + ), + 's3Location' => array( + 'type' => 'object', + 'properties' => array( + 'bucket' => array( + 'type' => 'string', + ), + 'key' => array( + 'type' => 'string', + ), + 'bundleType' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + 'eTag' => array( + 'type' => 'string', + ), + ), + ), + 'gitHubLocation' => array( + 'type' => 'object', + 'properties' => array( + 'repository' => array( + 'type' => 'string', + ), + 'commitId' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'status' => array( + 'type' => 'string', + ), + 'errorInformation' => array( + 'type' => 'object', + 'properties' => array( + 'code' => array( + 'type' => 'string', + ), + 'message' => array( + 'type' => 'string', + ), + ), + ), + 'createTime' => array( + 'type' => 'string', + ), + 'startTime' => array( + 'type' => 'string', + ), + 'completeTime' => array( + 'type' => 'string', + ), + 'deploymentOverview' => array( + 'type' => 'object', + 'properties' => array( + 'Pending' => array( + 'type' => 'numeric', + ), + 'InProgress' => array( + 'type' => 'numeric', + ), + 'Succeeded' => array( + 'type' => 'numeric', + ), + 'Failed' => array( + 'type' => 'numeric', + ), + 'Skipped' => array( + 'type' => 'numeric', + ), + ), + ), + 'description' => array( + 'type' => 'string', + ), + 'creator' => array( + 'type' => 'string', + ), + 'ignoreApplicationStopFailures' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + 'GetDeploymentConfigOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'deploymentConfigInfo' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'deploymentConfigId' => array( + 'type' => 'string', + ), + 'deploymentConfigName' => array( + 'type' => 'string', + ), + 'minimumHealthyHosts' => array( + 'type' => 'object', + 'properties' => array( + '' => array( + ), + ), + ), + 'createTime' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'GetDeploymentGroupOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'deploymentGroupInfo' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'applicationName' => array( + 'type' => 'string', + ), + 'deploymentGroupId' => array( + 'type' => 'string', + ), + 'deploymentGroupName' => array( + 'type' => 'string', + ), + 'deploymentConfigName' => array( + 'type' => 'string', + ), + 'ec2TagFilters' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'EC2TagFilter', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + 'Type' => array( + 'type' => 'string', + ), + ), + ), + ), + 'onPremisesInstanceTagFilters' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'TagFilter', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + 'Type' => array( + 'type' => 'string', + ), + ), + ), + ), + 'autoScalingGroups' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AutoScalingGroup', + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'hook' => array( + 'type' => 'string', + ), + ), + ), + ), + 'serviceRoleArn' => array( + 'type' => 'string', + ), + 'targetRevision' => array( + 'type' => 'object', + 'properties' => array( + 'revisionType' => array( + 'type' => 'string', + ), + 's3Location' => array( + 'type' => 'object', + 'properties' => array( + 'bucket' => array( + 'type' => 'string', + ), + 'key' => array( + 'type' => 'string', + ), + 'bundleType' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + 'eTag' => array( + 'type' => 'string', + ), + ), + ), + 'gitHubLocation' => array( + 'type' => 'object', + 'properties' => array( + 'repository' => array( + 'type' => 'string', + ), + 'commitId' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'GetDeploymentInstanceOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'instanceSummary' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'deploymentId' => array( + 'type' => 'string', + ), + 'instanceId' => array( + 'type' => 'string', + ), + 'status' => array( + 'type' => 'string', + ), + 'lastUpdatedAt' => array( + 'type' => 'string', + ), + 'lifecycleEvents' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'LifecycleEvent', + 'type' => 'object', + 'properties' => array( + 'lifecycleEventName' => array( + 'type' => 'string', + ), + 'diagnostics' => array( + 'type' => 'object', + 'properties' => array( + 'errorCode' => array( + 'type' => 'string', + ), + 'scriptName' => array( + 'type' => 'string', + ), + 'message' => array( + 'type' => 'string', + ), + 'logTail' => array( + 'type' => 'string', + ), + ), + ), + 'startTime' => array( + 'type' => 'string', + ), + 'endTime' => array( + 'type' => 'string', + ), + 'status' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'GetOnPremisesInstanceOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'instanceInfo' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'instanceName' => array( + 'type' => 'string', + ), + 'iamUserArn' => array( + 'type' => 'string', + ), + 'instanceArn' => array( + 'type' => 'string', + ), + 'registerTime' => array( + 'type' => 'string', + ), + 'deregisterTime' => array( + 'type' => 'string', + ), + 'tags' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'ListApplicationRevisionsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'revisions' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'RevisionLocation', + 'type' => 'object', + 'properties' => array( + 'revisionType' => array( + 'type' => 'string', + ), + 's3Location' => array( + 'type' => 'object', + 'properties' => array( + 'bucket' => array( + 'type' => 'string', + ), + 'key' => array( + 'type' => 'string', + ), + 'bundleType' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + 'eTag' => array( + 'type' => 'string', + ), + ), + ), + 'gitHubLocation' => array( + 'type' => 'object', + 'properties' => array( + 'repository' => array( + 'type' => 'string', + ), + 'commitId' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListApplicationsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'applications' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'ApplicationName', + 'type' => 'string', + ), + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListDeploymentConfigsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'deploymentConfigsList' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'DeploymentConfigName', + 'type' => 'string', + ), + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListDeploymentGroupsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'applicationName' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'deploymentGroups' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'DeploymentGroupName', + 'type' => 'string', + ), + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListDeploymentInstancesOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'instancesList' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'InstanceId', + 'type' => 'string', + ), + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListDeploymentsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'deployments' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'DeploymentId', + 'type' => 'string', + ), + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListOnPremisesInstancesOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'instanceNames' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'InstanceName', + 'type' => 'string', + ), + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'StopDeploymentOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'status' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'statusMessage' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'UpdateDeploymentGroupOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'hooksNotCleanedUp' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'AutoScalingGroup', + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'hook' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), +); diff --git a/vendor/aws/Aws/CognitoIdentity/CognitoIdentityClient.php b/vendor/aws/Aws/CognitoIdentity/CognitoIdentityClient.php new file mode 100644 index 0000000..d27b779 --- /dev/null +++ b/vendor/aws/Aws/CognitoIdentity/CognitoIdentityClient.php @@ -0,0 +1,83 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/cognitoidentity-%s.php', + )) + ->setExceptionParser(new JsonQueryExceptionParser) + ->build(); + + // Attach a listener to prevent some requests from being signed + $client->getEventDispatcher()->addListener('command.before_send', function (Event $event) { + /** @var AbstractCommand $command */ + $command = $event['command']; + if (in_array($command->getName(), array('GetId', 'GetOpenIdToken', 'UnlinkIdentity'))) { + /** @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; + } +} diff --git a/vendor/aws/Aws/CognitoIdentity/Exception/CognitoIdentityException.php b/vendor/aws/Aws/CognitoIdentity/Exception/CognitoIdentityException.php new file mode 100644 index 0000000..145be67 --- /dev/null +++ b/vendor/aws/Aws/CognitoIdentity/Exception/CognitoIdentityException.php @@ -0,0 +1,10 @@ + '2014-06-30', + 'endpointPrefix' => 'cognito-identity', + 'serviceFullName' => 'Amazon Cognito Identity', + 'serviceType' => 'json', + 'jsonVersion' => '1.1', + 'targetPrefix' => 'AWSCognitoIdentityService.', + 'signatureVersion' => 'v4', + 'namespace' => 'CognitoIdentity', + 'operations' => array( + 'CreateIdentityPool' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'IdentityPool', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AWSCognitoIdentityService.CreateIdentityPool', + ), + 'IdentityPoolName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'AllowUnauthenticatedIdentities' => array( + 'required' => true, + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + 'SupportedLoginProviders' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 128, + 'data' => array( + 'shape_name' => 'IdentityProviderName', + 'key_pattern' => '/[\\w._-]+/', + ), + ), + ), + 'DeveloperProviderName' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'OpenIdConnectProviderARNs' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'ARNString', + 'type' => 'string', + 'minLength' => 20, + 'maxLength' => 2048, + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown for missing or bad input parameter(s).', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown when a user tries to use a login which is already linked to another account.', + 'class' => 'ResourceConflictException', + ), + array( + 'reason' => 'Thrown when a request is throttled.', + 'class' => 'TooManyRequestsException', + ), + array( + 'reason' => 'Thrown when the service encounters an error during processing the request.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Thrown when the total number of user pools has exceeded a preset limit.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'DeleteIdentityPool' => 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' => 'AWSCognitoIdentityService.DeleteIdentityPool', + ), + 'IdentityPoolId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 50, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown for missing or bad input parameter(s).', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Thrown when the requested resource (for example, a dataset or record) does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown when a request is throttled.', + 'class' => 'TooManyRequestsException', + ), + array( + 'reason' => 'Thrown when the service encounters an error during processing the request.', + 'class' => 'InternalErrorException', + ), + ), + ), + 'DescribeIdentity' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'IdentityDescription', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AWSCognitoIdentityService.DescribeIdentity', + ), + 'IdentityId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 50, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown for missing or bad input parameter(s).', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Thrown when the requested resource (for example, a dataset or record) does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown when a request is throttled.', + 'class' => 'TooManyRequestsException', + ), + array( + 'reason' => 'Thrown when the service encounters an error during processing the request.', + 'class' => 'InternalErrorException', + ), + ), + ), + 'DescribeIdentityPool' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'IdentityPool', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AWSCognitoIdentityService.DescribeIdentityPool', + ), + 'IdentityPoolId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 50, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown for missing or bad input parameter(s).', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Thrown when the requested resource (for example, a dataset or record) does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown when a request is throttled.', + 'class' => 'TooManyRequestsException', + ), + array( + 'reason' => 'Thrown when the service encounters an error during processing the request.', + 'class' => 'InternalErrorException', + ), + ), + ), + 'GetCredentialsForIdentity' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GetCredentialsForIdentityResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AWSCognitoIdentityService.GetCredentialsForIdentity', + ), + 'IdentityId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 50, + ), + 'Logins' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 2048, + 'data' => array( + 'shape_name' => 'IdentityProviderName', + 'key_pattern' => '/[\\w._-]+/', + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown for missing or bad input parameter(s).', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Thrown when the requested resource (for example, a dataset or record) does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown when a user tries to use a login which is already linked to another account.', + 'class' => 'ResourceConflictException', + ), + array( + 'reason' => 'Thrown when a request is throttled.', + 'class' => 'TooManyRequestsException', + ), + array( + 'reason' => 'Thrown if the identity pool has no role associated for the given auth type (auth/unauth) or if the AssumeRole fails.', + 'class' => 'InvalidIdentityPoolConfigurationException', + ), + array( + 'reason' => 'Thrown when the service encounters an error during processing the request.', + 'class' => 'InternalErrorException', + ), + ), + ), + 'GetId' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GetIdResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AWSCognitoIdentityService.GetId', + ), + 'AccountId' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 15, + ), + 'IdentityPoolId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 50, + ), + 'Logins' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 2048, + 'data' => array( + 'shape_name' => 'IdentityProviderName', + 'key_pattern' => '/[\\w._-]+/', + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown for missing or bad input parameter(s).', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Thrown when the requested resource (for example, a dataset or record) does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown when a user tries to use a login which is already linked to another account.', + 'class' => 'ResourceConflictException', + ), + array( + 'reason' => 'Thrown when a request is throttled.', + 'class' => 'TooManyRequestsException', + ), + array( + 'reason' => 'Thrown when the service encounters an error during processing the request.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Thrown when the total number of user pools has exceeded a preset limit.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'GetIdentityPoolRoles' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GetIdentityPoolRolesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AWSCognitoIdentityService.GetIdentityPoolRoles', + ), + 'IdentityPoolId' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 50, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown for missing or bad input parameter(s).', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Thrown when the requested resource (for example, a dataset or record) does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown when a user tries to use a login which is already linked to another account.', + 'class' => 'ResourceConflictException', + ), + array( + 'reason' => 'Thrown when a request is throttled.', + 'class' => 'TooManyRequestsException', + ), + array( + 'reason' => 'Thrown when the service encounters an error during processing the request.', + 'class' => 'InternalErrorException', + ), + ), + ), + 'GetOpenIdToken' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GetOpenIdTokenResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AWSCognitoIdentityService.GetOpenIdToken', + ), + 'IdentityId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 50, + ), + 'Logins' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 2048, + 'data' => array( + 'shape_name' => 'IdentityProviderName', + 'key_pattern' => '/[\\w._-]+/', + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown for missing or bad input parameter(s).', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Thrown when the requested resource (for example, a dataset or record) does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown when a user tries to use a login which is already linked to another account.', + 'class' => 'ResourceConflictException', + ), + array( + 'reason' => 'Thrown when a request is throttled.', + 'class' => 'TooManyRequestsException', + ), + array( + 'reason' => 'Thrown when the service encounters an error during processing the request.', + 'class' => 'InternalErrorException', + ), + ), + ), + 'GetOpenIdTokenForDeveloperIdentity' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GetOpenIdTokenForDeveloperIdentityResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AWSCognitoIdentityService.GetOpenIdTokenForDeveloperIdentity', + ), + 'IdentityPoolId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 50, + ), + 'IdentityId' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 50, + ), + 'Logins' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 2048, + 'data' => array( + 'shape_name' => 'IdentityProviderName', + 'key_pattern' => '/[\\w._-]+/', + ), + ), + ), + 'TokenDuration' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 86400, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown for missing or bad input parameter(s).', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Thrown when the requested resource (for example, a dataset or record) does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown when a user tries to use a login which is already linked to another account.', + 'class' => 'ResourceConflictException', + ), + array( + 'reason' => 'Thrown when a request is throttled.', + 'class' => 'TooManyRequestsException', + ), + array( + 'reason' => 'Thrown when the service encounters an error during processing the request.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'The provided developer user identifier is already registered with Cognito under a different identity ID.', + 'class' => 'DeveloperUserAlreadyRegisteredException', + ), + ), + ), + 'ListIdentities' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListIdentitiesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AWSCognitoIdentityService.ListIdentities', + ), + 'IdentityPoolId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 50, + ), + 'MaxResults' => array( + 'required' => true, + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 60, + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown for missing or bad input parameter(s).', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Thrown when the requested resource (for example, a dataset or record) does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown when a request is throttled.', + 'class' => 'TooManyRequestsException', + ), + array( + 'reason' => 'Thrown when the service encounters an error during processing the request.', + 'class' => 'InternalErrorException', + ), + ), + ), + 'ListIdentityPools' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListIdentityPoolsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AWSCognitoIdentityService.ListIdentityPools', + ), + 'MaxResults' => array( + 'required' => true, + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 60, + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown for missing or bad input parameter(s).', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown when a request is throttled.', + 'class' => 'TooManyRequestsException', + ), + array( + 'reason' => 'Thrown when the service encounters an error during processing the request.', + 'class' => 'InternalErrorException', + ), + ), + ), + 'LookupDeveloperIdentity' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'LookupDeveloperIdentityResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AWSCognitoIdentityService.LookupDeveloperIdentity', + ), + 'IdentityPoolId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 50, + ), + 'IdentityId' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 50, + ), + 'DeveloperUserIdentifier' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 1024, + ), + 'MaxResults' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 60, + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown for missing or bad input parameter(s).', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Thrown when the requested resource (for example, a dataset or record) does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown when a user tries to use a login which is already linked to another account.', + 'class' => 'ResourceConflictException', + ), + array( + 'reason' => 'Thrown when a request is throttled.', + 'class' => 'TooManyRequestsException', + ), + array( + 'reason' => 'Thrown when the service encounters an error during processing the request.', + 'class' => 'InternalErrorException', + ), + ), + ), + 'MergeDeveloperIdentities' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'MergeDeveloperIdentitiesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AWSCognitoIdentityService.MergeDeveloperIdentities', + ), + 'SourceUserIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 1024, + ), + 'DestinationUserIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 1024, + ), + 'DeveloperProviderName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'IdentityPoolId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 50, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown for missing or bad input parameter(s).', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Thrown when the requested resource (for example, a dataset or record) does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown when a user tries to use a login which is already linked to another account.', + 'class' => 'ResourceConflictException', + ), + array( + 'reason' => 'Thrown when a request is throttled.', + 'class' => 'TooManyRequestsException', + ), + array( + 'reason' => 'Thrown when the service encounters an error during processing the request.', + 'class' => 'InternalErrorException', + ), + ), + ), + 'SetIdentityPoolRoles' => 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' => 'AWSCognitoIdentityService.SetIdentityPoolRoles', + ), + 'IdentityPoolId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 50, + ), + 'Roles' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'string', + 'minLength' => 20, + 'maxLength' => 2048, + 'data' => array( + 'shape_name' => 'RoleType', + 'key_pattern' => '/(un)?authenticated/', + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown for missing or bad input parameter(s).', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Thrown when the requested resource (for example, a dataset or record) does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown when a user tries to use a login which is already linked to another account.', + 'class' => 'ResourceConflictException', + ), + array( + 'reason' => 'Thrown when a request is throttled.', + 'class' => 'TooManyRequestsException', + ), + array( + 'reason' => 'Thrown when the service encounters an error during processing the request.', + 'class' => 'InternalErrorException', + ), + ), + ), + 'UnlinkDeveloperIdentity' => 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' => 'AWSCognitoIdentityService.UnlinkDeveloperIdentity', + ), + 'IdentityId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 50, + ), + 'IdentityPoolId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 50, + ), + 'DeveloperProviderName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'DeveloperUserIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 1024, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown for missing or bad input parameter(s).', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Thrown when the requested resource (for example, a dataset or record) does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown when a user tries to use a login which is already linked to another account.', + 'class' => 'ResourceConflictException', + ), + array( + 'reason' => 'Thrown when a request is throttled.', + 'class' => 'TooManyRequestsException', + ), + array( + 'reason' => 'Thrown when the service encounters an error during processing the request.', + 'class' => 'InternalErrorException', + ), + ), + ), + 'UnlinkIdentity' => 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' => 'AWSCognitoIdentityService.UnlinkIdentity', + ), + 'IdentityId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 50, + ), + 'Logins' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 2048, + 'data' => array( + 'shape_name' => 'IdentityProviderName', + 'key_pattern' => '/[\\w._-]+/', + ), + ), + ), + 'LoginsToRemove' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'IdentityProviderName', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown for missing or bad input parameter(s).', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Thrown when the requested resource (for example, a dataset or record) does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown when a user tries to use a login which is already linked to another account.', + 'class' => 'ResourceConflictException', + ), + array( + 'reason' => 'Thrown when a request is throttled.', + 'class' => 'TooManyRequestsException', + ), + array( + 'reason' => 'Thrown when the service encounters an error during processing the request.', + 'class' => 'InternalErrorException', + ), + ), + ), + 'UpdateIdentityPool' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'IdentityPool', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AWSCognitoIdentityService.UpdateIdentityPool', + ), + 'IdentityPoolId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 50, + ), + 'IdentityPoolName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'AllowUnauthenticatedIdentities' => array( + 'required' => true, + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + 'SupportedLoginProviders' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 128, + 'data' => array( + 'shape_name' => 'IdentityProviderName', + 'key_pattern' => '/[\\w._-]+/', + ), + ), + ), + 'DeveloperProviderName' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'OpenIdConnectProviderARNs' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'ARNString', + 'type' => 'string', + 'minLength' => 20, + 'maxLength' => 2048, + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown for missing or bad input parameter(s).', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Thrown when the requested resource (for example, a dataset or record) does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown when a user tries to use a login which is already linked to another account.', + 'class' => 'ResourceConflictException', + ), + array( + 'reason' => 'Thrown when a request is throttled.', + 'class' => 'TooManyRequestsException', + ), + array( + 'reason' => 'Thrown when the service encounters an error during processing the request.', + 'class' => 'InternalErrorException', + ), + ), + ), + ), + 'models' => array( + 'IdentityPool' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'IdentityPoolId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'IdentityPoolName' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'AllowUnauthenticatedIdentities' => array( + 'type' => 'boolean', + 'location' => 'json', + ), + 'SupportedLoginProviders' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'string', + ), + ), + 'DeveloperProviderName' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'OpenIdConnectProviderARNs' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'ARNString', + 'type' => 'string', + ), + ), + ), + ), + 'EmptyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + ), + 'IdentityDescription' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'IdentityId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Logins' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'IdentityProviderName', + 'type' => 'string', + ), + ), + 'CreationDate' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'LastModifiedDate' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'GetCredentialsForIdentityResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'IdentityId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Credentials' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'AccessKeyId' => array( + 'type' => 'string', + ), + 'SecretKey' => array( + 'type' => 'string', + ), + 'SessionToken' => array( + 'type' => 'string', + ), + 'Expiration' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'GetIdResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'IdentityId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'GetIdentityPoolRolesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'IdentityPoolId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Roles' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'string', + ), + ), + ), + ), + 'GetOpenIdTokenResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'IdentityId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Token' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'GetOpenIdTokenForDeveloperIdentityResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'IdentityId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Token' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListIdentitiesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'IdentityPoolId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Identities' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'IdentityDescription', + 'type' => 'object', + 'properties' => array( + 'IdentityId' => array( + 'type' => 'string', + ), + 'Logins' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'IdentityProviderName', + 'type' => 'string', + ), + ), + 'CreationDate' => array( + 'type' => 'string', + ), + 'LastModifiedDate' => array( + 'type' => 'string', + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListIdentityPoolsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'IdentityPools' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'IdentityPoolShortDescription', + 'type' => 'object', + 'properties' => array( + 'IdentityPoolId' => array( + 'type' => 'string', + ), + 'IdentityPoolName' => array( + 'type' => 'string', + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'LookupDeveloperIdentityResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'IdentityId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'DeveloperUserIdentifierList' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'DeveloperUserIdentifier', + 'type' => 'string', + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'MergeDeveloperIdentitiesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'IdentityId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + ), +); diff --git a/vendor/aws/Aws/CognitoSync/CognitoSyncClient.php b/vendor/aws/Aws/CognitoSync/CognitoSyncClient.php new file mode 100644 index 0000000..0bba8a6 --- /dev/null +++ b/vendor/aws/Aws/CognitoSync/CognitoSyncClient.php @@ -0,0 +1,59 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/cognitosync-%s.php', + )) + ->setExceptionParser(new JsonRestExceptionParser) + ->build(); + } +} diff --git a/vendor/aws/Aws/CognitoSync/Exception/CognitoSyncException.php b/vendor/aws/Aws/CognitoSync/Exception/CognitoSyncException.php new file mode 100644 index 0000000..f968a91 --- /dev/null +++ b/vendor/aws/Aws/CognitoSync/Exception/CognitoSyncException.php @@ -0,0 +1,10 @@ + '2014-06-30', + 'endpointPrefix' => 'cognito-sync', + 'serviceFullName' => 'Amazon Cognito Sync', + 'serviceType' => 'rest-json', + 'jsonVersion' => '1.1', + 'signatureVersion' => 'v4', + 'namespace' => 'CognitoSync', + 'operations' => array( + 'BulkPublish' => array( + 'httpMethod' => 'POST', + 'uri' => '/identitypools/{IdentityPoolId}/bulkpublish', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'BulkPublishResponse', + 'responseType' => 'model', + 'parameters' => array( + 'IdentityPoolId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 50, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown when a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Thrown if the resource doesn\'t exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'An exception thrown when there is an IN_PROGRESS bulk publish operation for the given identity pool.', + 'class' => 'DuplicateRequestException', + ), + array( + 'reason' => 'An exception thrown when a bulk publish operation is requested less than 24 hours after a previous bulk publish operation completed successfully.', + 'class' => 'AlreadyStreamedException', + ), + ), + ), + 'DeleteDataset' => array( + 'httpMethod' => 'DELETE', + 'uri' => '/identitypools/{IdentityPoolId}/identities/{IdentityId}/datasets/{DatasetName}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'DeleteDatasetResponse', + 'responseType' => 'model', + 'parameters' => array( + 'IdentityPoolId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 50, + ), + 'IdentityId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 50, + ), + 'DatasetName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown when a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Thrown if the resource doesn\'t exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Thrown if the request is throttled.', + 'class' => 'TooManyRequestsException', + ), + ), + ), + 'DescribeDataset' => array( + 'httpMethod' => 'GET', + 'uri' => '/identitypools/{IdentityPoolId}/identities/{IdentityId}/datasets/{DatasetName}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'DescribeDatasetResponse', + 'responseType' => 'model', + 'parameters' => array( + 'IdentityPoolId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 50, + ), + 'IdentityId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 50, + ), + 'DatasetName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown when a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Thrown if the resource doesn\'t exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Thrown if the request is throttled.', + 'class' => 'TooManyRequestsException', + ), + ), + ), + 'DescribeIdentityPoolUsage' => array( + 'httpMethod' => 'GET', + 'uri' => '/identitypools/{IdentityPoolId}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'DescribeIdentityPoolUsageResponse', + 'responseType' => 'model', + 'parameters' => array( + 'IdentityPoolId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 50, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown when a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Thrown if the resource doesn\'t exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Thrown if the request is throttled.', + 'class' => 'TooManyRequestsException', + ), + ), + ), + 'DescribeIdentityUsage' => array( + 'httpMethod' => 'GET', + 'uri' => '/identitypools/{IdentityPoolId}/identities/{IdentityId}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'DescribeIdentityUsageResponse', + 'responseType' => 'model', + 'parameters' => array( + 'IdentityPoolId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 50, + ), + 'IdentityId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 50, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown when a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Thrown if the resource doesn\'t exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Thrown if the request is throttled.', + 'class' => 'TooManyRequestsException', + ), + ), + ), + 'GetBulkPublishDetails' => array( + 'httpMethod' => 'POST', + 'uri' => '/identitypools/{IdentityPoolId}/getBulkPublishDetails', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'GetBulkPublishDetailsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'IdentityPoolId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 50, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown when a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Thrown if the resource doesn\'t exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + ), + ), + 'GetIdentityPoolConfiguration' => array( + 'httpMethod' => 'GET', + 'uri' => '/identitypools/{IdentityPoolId}/configuration', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'GetIdentityPoolConfigurationResponse', + 'responseType' => 'model', + 'parameters' => array( + 'IdentityPoolId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 50, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown when a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Thrown if the resource doesn\'t exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Thrown if the request is throttled.', + 'class' => 'TooManyRequestsException', + ), + ), + ), + 'ListDatasets' => array( + 'httpMethod' => 'GET', + 'uri' => '/identitypools/{IdentityPoolId}/identities/{IdentityId}/datasets', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'ListDatasetsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'IdentityPoolId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 50, + ), + 'IdentityId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 50, + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'nextToken', + ), + 'MaxResults' => array( + 'type' => 'numeric', + 'location' => 'query', + 'sentAs' => 'maxResults', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown when a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Thrown if the request is throttled.', + 'class' => 'TooManyRequestsException', + ), + ), + ), + 'ListIdentityPoolUsage' => array( + 'httpMethod' => 'GET', + 'uri' => '/identitypools', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'ListIdentityPoolUsageResponse', + 'responseType' => 'model', + 'parameters' => array( + 'NextToken' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'nextToken', + ), + 'MaxResults' => array( + 'type' => 'numeric', + 'location' => 'query', + 'sentAs' => 'maxResults', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown when a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Thrown if the request is throttled.', + 'class' => 'TooManyRequestsException', + ), + ), + ), + 'ListRecords' => array( + 'httpMethod' => 'GET', + 'uri' => '/identitypools/{IdentityPoolId}/identities/{IdentityId}/datasets/{DatasetName}/records', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'ListRecordsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'IdentityPoolId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 50, + ), + 'IdentityId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 50, + ), + 'DatasetName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'LastSyncCount' => array( + 'type' => 'numeric', + 'location' => 'query', + 'sentAs' => 'lastSyncCount', + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'nextToken', + ), + 'MaxResults' => array( + 'type' => 'numeric', + 'location' => 'query', + 'sentAs' => 'maxResults', + ), + 'SyncSessionToken' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'syncSessionToken', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown when a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown if the request is throttled.', + 'class' => 'TooManyRequestsException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + ), + ), + 'RegisterDevice' => array( + 'httpMethod' => 'POST', + 'uri' => '/identitypools/{IdentityPoolId}/identity/{IdentityId}/device', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'RegisterDeviceResponse', + 'responseType' => 'model', + 'parameters' => array( + 'IdentityPoolId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 50, + ), + 'IdentityId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 50, + ), + 'Platform' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'Token' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown when a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Thrown if the resource doesn\'t exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'class' => 'InvalidConfigurationException', + ), + array( + 'reason' => 'Thrown if the request is throttled.', + 'class' => 'TooManyRequestsException', + ), + ), + ), + 'SetIdentityPoolConfiguration' => array( + 'httpMethod' => 'POST', + 'uri' => '/identitypools/{IdentityPoolId}/configuration', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'SetIdentityPoolConfigurationResponse', + 'responseType' => 'model', + 'parameters' => array( + 'IdentityPoolId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 50, + ), + 'PushSync' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'ApplicationArns' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ApplicationArn', + 'type' => 'string', + ), + ), + 'RoleArn' => array( + 'type' => 'string', + 'minLength' => 20, + 'maxLength' => 2048, + ), + ), + ), + 'CognitoStreams' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'StreamName' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'RoleArn' => array( + 'type' => 'string', + 'minLength' => 20, + 'maxLength' => 2048, + ), + 'StreamingStatus' => array( + 'type' => 'string', + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown when a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Thrown if the resource doesn\'t exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Thrown if the request is throttled.', + 'class' => 'TooManyRequestsException', + ), + ), + ), + 'SubscribeToDataset' => array( + 'httpMethod' => 'POST', + 'uri' => '/identitypools/{IdentityPoolId}/identities/{IdentityId}/datasets/{DatasetName}/subscriptions/{DeviceId}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'IdentityPoolId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 50, + ), + 'IdentityId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 50, + ), + 'DatasetName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'DeviceId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 256, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown when a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Thrown if the resource doesn\'t exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'class' => 'InvalidConfigurationException', + ), + array( + 'reason' => 'Thrown if the request is throttled.', + 'class' => 'TooManyRequestsException', + ), + ), + ), + 'UnsubscribeFromDataset' => array( + 'httpMethod' => 'DELETE', + 'uri' => '/identitypools/{IdentityPoolId}/identities/{IdentityId}/datasets/{DatasetName}/subscriptions/{DeviceId}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'IdentityPoolId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 50, + ), + 'IdentityId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 50, + ), + 'DatasetName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'DeviceId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 256, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown when a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Thrown if the resource doesn\'t exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'class' => 'InvalidConfigurationException', + ), + array( + 'reason' => 'Thrown if the request is throttled.', + 'class' => 'TooManyRequestsException', + ), + ), + ), + 'UpdateRecords' => array( + 'httpMethod' => 'POST', + 'uri' => '/identitypools/{IdentityPoolId}/identities/{IdentityId}/datasets/{DatasetName}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'UpdateRecordsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'IdentityPoolId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 50, + ), + 'IdentityId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 50, + ), + 'DatasetName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'DeviceId' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'RecordPatches' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'RecordPatch', + 'type' => 'object', + 'properties' => array( + 'Op' => array( + 'required' => true, + 'type' => 'string', + ), + 'Key' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 1024, + ), + 'Value' => array( + 'type' => 'string', + 'maxLength' => 1048575, + ), + 'SyncCount' => array( + 'required' => true, + 'type' => 'numeric', + ), + 'DeviceLastModifiedDate' => array( + 'type' => array( + 'object', + 'string', + 'integer', + ), + 'format' => 'date-time', + ), + ), + ), + ), + 'SyncSessionToken' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'ClientContext' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-Client-Context', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Thrown when a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Thrown when the limit on the number of objects or operations has been exceeded.', + 'class' => 'LimitExceededException', + ), + array( + 'reason' => 'Thrown when a user is not authorized to access the requested resource.', + 'class' => 'NotAuthorizedException', + ), + array( + 'reason' => 'Thrown if the resource doesn\'t exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Thrown if an update can\'t be applied because the resource was changed by another call and this would result in a conflict.', + 'class' => 'ResourceConflictException', + ), + array( + 'reason' => 'Thrown if the request is throttled.', + 'class' => 'TooManyRequestsException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + ), + ), + ), + 'models' => array( + 'BulkPublishResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'IdentityPoolId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DeleteDatasetResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Dataset' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'IdentityId' => array( + 'type' => 'string', + ), + 'DatasetName' => array( + 'type' => 'string', + ), + 'CreationDate' => array( + 'type' => 'string', + ), + 'LastModifiedDate' => array( + 'type' => 'string', + ), + 'LastModifiedBy' => array( + 'type' => 'string', + ), + 'DataStorage' => array( + 'type' => 'numeric', + ), + 'NumRecords' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + 'DescribeDatasetResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Dataset' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'IdentityId' => array( + 'type' => 'string', + ), + 'DatasetName' => array( + 'type' => 'string', + ), + 'CreationDate' => array( + 'type' => 'string', + ), + 'LastModifiedDate' => array( + 'type' => 'string', + ), + 'LastModifiedBy' => array( + 'type' => 'string', + ), + 'DataStorage' => array( + 'type' => 'numeric', + ), + 'NumRecords' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + 'DescribeIdentityPoolUsageResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'IdentityPoolUsage' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'IdentityPoolId' => array( + 'type' => 'string', + ), + 'SyncSessionsCount' => array( + 'type' => 'numeric', + ), + 'DataStorage' => array( + 'type' => 'numeric', + ), + 'LastModifiedDate' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'DescribeIdentityUsageResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'IdentityUsage' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'IdentityId' => array( + 'type' => 'string', + ), + 'IdentityPoolId' => array( + 'type' => 'string', + ), + 'LastModifiedDate' => array( + 'type' => 'string', + ), + 'DatasetCount' => array( + 'type' => 'numeric', + ), + 'DataStorage' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + 'GetBulkPublishDetailsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'IdentityPoolId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'BulkPublishStartTime' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'BulkPublishCompleteTime' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'BulkPublishStatus' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'FailureMessage' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'GetIdentityPoolConfigurationResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'IdentityPoolId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'PushSync' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'ApplicationArns' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ApplicationArn', + 'type' => 'string', + ), + ), + 'RoleArn' => array( + 'type' => 'string', + ), + ), + ), + 'CognitoStreams' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'StreamName' => array( + 'type' => 'string', + ), + 'RoleArn' => array( + 'type' => 'string', + ), + 'StreamingStatus' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'ListDatasetsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Datasets' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Dataset', + 'type' => 'object', + 'properties' => array( + 'IdentityId' => array( + 'type' => 'string', + ), + 'DatasetName' => array( + 'type' => 'string', + ), + 'CreationDate' => array( + 'type' => 'string', + ), + 'LastModifiedDate' => array( + 'type' => 'string', + ), + 'LastModifiedBy' => array( + 'type' => 'string', + ), + 'DataStorage' => array( + 'type' => 'numeric', + ), + 'NumRecords' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'Count' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListIdentityPoolUsageResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'IdentityPoolUsages' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'IdentityPoolUsage', + 'type' => 'object', + 'properties' => array( + 'IdentityPoolId' => array( + 'type' => 'string', + ), + 'SyncSessionsCount' => array( + 'type' => 'numeric', + ), + 'DataStorage' => array( + 'type' => 'numeric', + ), + 'LastModifiedDate' => array( + 'type' => 'string', + ), + ), + ), + ), + 'MaxResults' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'Count' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListRecordsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Records' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Record', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + 'SyncCount' => array( + 'type' => 'numeric', + ), + 'LastModifiedDate' => array( + 'type' => 'string', + ), + 'LastModifiedBy' => array( + 'type' => 'string', + ), + 'DeviceLastModifiedDate' => array( + 'type' => 'string', + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Count' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'DatasetSyncCount' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'LastModifiedBy' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'MergedDatasetNames' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + 'DatasetExists' => array( + 'type' => 'boolean', + 'location' => 'json', + ), + 'DatasetDeletedAfterRequestedSyncCount' => array( + 'type' => 'boolean', + 'location' => 'json', + ), + 'SyncSessionToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'RegisterDeviceResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'DeviceId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'SetIdentityPoolConfigurationResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'IdentityPoolId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'PushSync' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'ApplicationArns' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ApplicationArn', + 'type' => 'string', + ), + ), + 'RoleArn' => array( + 'type' => 'string', + ), + ), + ), + 'CognitoStreams' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'StreamName' => array( + 'type' => 'string', + ), + 'RoleArn' => array( + 'type' => 'string', + ), + 'StreamingStatus' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'EmptyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + ), + 'UpdateRecordsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Records' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Record', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + 'SyncCount' => array( + 'type' => 'numeric', + ), + 'LastModifiedDate' => array( + 'type' => 'string', + ), + 'LastModifiedBy' => array( + 'type' => 'string', + ), + 'DeviceLastModifiedDate' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), +); diff --git a/vendor/aws/Aws/Common/Aws.php b/vendor/aws/Aws/Common/Aws.php new file mode 100644 index 0000000..55dd7aa --- /dev/null +++ b/vendor/aws/Aws/Common/Aws.php @@ -0,0 +1,106 @@ +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 + * @deprecated "Facades" are being removed in version 3.0 of the SDK. + */ + public function enableFacades($namespace = null) + { + Facade::mountFacades($this, $namespace); + + return $this; + } +} diff --git a/vendor/aws/Aws/Common/Client/AbstractClient.php b/vendor/aws/Aws/Common/Client/AbstractClient.php new file mode 100644 index 0000000..b5aa698 --- /dev/null +++ b/vendor/aws/Aws/Common/Client/AbstractClient.php @@ -0,0 +1,283 @@ +get(Options::BASE_URL), $config); + $this->credentials = $credentials; + $this->signature = $signature; + $this->aggregator = new DuplicateAggregator(); + + // 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 + * @deprecated This function will no longer be updated to work with new regions. + */ + public static function getEndpoint(ServiceDescriptionInterface $description, $region, $scheme) + { + try { + $service = $description->getData('endpointPrefix'); + $provider = RulesEndpointProvider::fromDefaults(); + $result = $provider(array( + 'service' => $service, + 'region' => $region, + 'scheme' => $scheme + )); + return $result['endpoint']; + } catch (\InvalidArgumentException $e) { + throw new InvalidArgumentException($e->getMessage(), 0, $e); + } + } + + public function getCredentials() + { + return $this->credentials; + } + + 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; + } + + public function getSignature() + { + return $this->signature; + } + + public function getRegions() + { + return $this->serviceDescription->getData('regions'); + } + + public function getRegion() + { + return $this->getConfig(Options::REGION); + } + + public function setRegion($region) + { + $config = $this->getConfig(); + $formerRegion = $config->get(Options::REGION); + $global = $this->serviceDescription->getData('globalEndpoint'); + $provider = $config->get('endpoint_provider'); + + if (!$provider) { + throw new \RuntimeException('No endpoint provider configured'); + } + + // Only change the region if the service does not have a global endpoint + if (!$global || $this->serviceDescription->getData('namespace') === 'S3') { + + $endpoint = call_user_func( + $provider, + array( + 'scheme' => $config->get(Options::SCHEME), + 'region' => $region, + 'service' => $config->get(Options::SERVICE) + ) + ); + + $this->setBaseUrl($endpoint['endpoint']); + $config->set(Options::BASE_URL, $endpoint['endpoint']); + $config->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; + } + + public function waitUntil($waiter, array $input = array()) + { + $this->getWaiter($waiter, $input)->wait(); + + return $this; + } + + public function getWaiter($waiter, array $input = array()) + { + return $this->getWaiterFactory()->build($waiter) + ->setClient($this) + ->setConfig($input); + } + + public function setWaiterFactory(WaiterFactoryInterface $waiterFactory) + { + $this->waiterFactory = $waiterFactory; + + return $this; + } + + 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; + } + + 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; + } + } + + /** + * Ensures that the duplicate query string aggregator is used so that + * query string values are sent over the wire as foo=bar&foo=baz. + * {@inheritdoc} + */ + public function createRequest( + $method = 'GET', + $uri = null, + $headers = null, + $body = null, + array $options = array() + ) { + $request = parent::createRequest($method, $uri, $headers, $body, $options); + $request->getQuery()->setAggregator($this->aggregator); + return $request; + } +} diff --git a/vendor/aws/Aws/Common/Client/AwsClientInterface.php b/vendor/aws/Aws/Common/Client/AwsClientInterface.php new file mode 100644 index 0000000..4c0579f --- /dev/null +++ b/vendor/aws/Aws/Common/Client/AwsClientInterface.php @@ -0,0 +1,118 @@ + '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(); + + /** @var string */ + private $clientClass; + + /** @var string */ + private $serviceName; + + /** + * 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; + + // Determine service and class name + $this->clientClass = 'Aws\Common\Client\DefaultClient'; + + if ($this->clientNamespace) { + $this->serviceName = substr($this->clientNamespace, strrpos($this->clientNamespace, '\\') + 1); + $this->clientClass = $this->clientNamespace . '\\' . $this->serviceName . 'Client'; + } + } + + /** + * 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) + ); + + if ($config[Options::VERSION] === 'latest') { + $config[Options::VERSION] = constant("{$this->clientClass}::LATEST_API_VERSION"); + } + + if (!isset($config['endpoint_provider'])) { + $config['endpoint_provider'] = RulesEndpointProvider::fromDefaults(); + } + + // Resolve the endpoint, signature, and credentials + $description = $this->updateConfigFromDescription($config); + $signature = $this->getSignature($description, $config); + $credentials = $this->getCredentials($config); + $this->extractHttpConfig($config); + + // Resolve exception parser + if (!$this->exceptionParser) { + $this->exceptionParser = new DefaultXmlExceptionParser(); + } + + // Resolve backoff strategy + $backoff = $config->get(Options::BACKOFF); + if ($backoff === null) { + $backoff = $this->createDefaultBackoff(); + $config->set(Options::BACKOFF, $backoff); + } + + if ($backoff) { + $this->addBackoffLogger($backoff, $config); + } + + /** @var $client AwsClientInterface */ + $client = new $this->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\\{$this->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); + } + + $this->handleRegion($config); + $this->handleEndpoint($config); + + 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; + } + + protected function getCredentials(Collection $config) + { + $credentials = $config->get(Options::CREDENTIALS); + + if (is_array($credentials)) { + $credentials = Credentials::factory($credentials); + } elseif ($credentials === false) { + $credentials = new NullCredentials(); + } elseif (!$credentials instanceof CredentialsInterface) { + $credentials = Credentials::factory($config); + } + + return $credentials; + } + + private function handleRegion(Collection $config) + { + // Make sure a valid region is set + $region = $config[Options::REGION]; + $description = $config[Options::SERVICE_DESCRIPTION]; + $global = $description->getData('globalEndpoint'); + + if (!$global && !$region) { + throw new InvalidArgumentException( + 'A region is required when using ' . $description->getData('serviceFullName') + ); + } elseif ($global && !$region) { + $config[Options::REGION] = 'us-east-1'; + } + } + + private function handleEndpoint(Collection $config) + { + // Alias "endpoint" with "base_url" for forwards compatibility. + if ($config['endpoint']) { + $config[Options::BASE_URL] = $config['endpoint']; + return; + } + + if ($config[Options::BASE_URL]) { + return; + } + + $endpoint = call_user_func( + $config['endpoint_provider'], + array( + 'scheme' => $config[Options::SCHEME], + 'region' => $config[Options::REGION], + 'service' => $config[Options::SERVICE] + ) + ); + + $config[Options::BASE_URL] = $endpoint['endpoint']; + + // Set a signature if one was not explicitly provided. + if (!$config->hasKey(Options::SIGNATURE) + && isset($endpoint['signatureVersion']) + ) { + $config->set(Options::SIGNATURE, $endpoint['signatureVersion']); + } + + // The the signing region if endpoint rule specifies one. + if (isset($endpoint['credentialScope'])) { + $scope = $endpoint['credentialScope']; + if (isset($scope['region'])) { + $config->set(Options::SIGNATURE_REGION, $scope['region']); + } + } + } + + private function createDefaultBackoff() + { + return 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 due to transient network or cURL problems + new CurlBackoffStrategy(null, + // Retry failed requests with 500-level responses + new HttpBackoffStrategy(array(500, 503, 509), + // Retry requests that failed due to expired credentials + new ExpiredCredentialsChecker($this->exceptionParser, + new ExponentialBackoffStrategy() + ) + ) + ) + ) + ) + ); + } + + private function extractHttpConfig(Collection $config) + { + $http = $config['http']; + + if (!is_array($http)) { + return; + } + + if (isset($http['verify'])) { + $config[Options::SSL_CERT] = $http['verify']; + } + } +} diff --git a/vendor/aws/Aws/Common/Client/DefaultClient.php b/vendor/aws/Aws/Common/Client/DefaultClient.php new file mode 100644 index 0000000..277f088 --- /dev/null +++ b/vendor/aws/Aws/Common/Client/DefaultClient.php @@ -0,0 +1,67 @@ +setConfig($config) + ->setConfigDefaults(array(Options::SCHEME => 'https')) + ->build(); + } +} diff --git a/vendor/aws/Aws/Common/Client/ExpiredCredentialsChecker.php b/vendor/aws/Aws/Common/Client/ExpiredCredentialsChecker.php new file mode 100644 index 0000000..d20f7f8 --- /dev/null +++ b/vendor/aws/Aws/Common/Client/ExpiredCredentialsChecker.php @@ -0,0 +1,80 @@ + 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; + } + } +} diff --git a/vendor/aws/Aws/Common/Client/ThrottlingErrorChecker.php b/vendor/aws/Aws/Common/Client/ThrottlingErrorChecker.php new file mode 100644 index 0000000..a35cbcb --- /dev/null +++ b/vendor/aws/Aws/Common/Client/ThrottlingErrorChecker.php @@ -0,0 +1,75 @@ + 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; + } + } +} diff --git a/vendor/aws/Aws/Common/Client/UploadBodyListener.php b/vendor/aws/Aws/Common/Client/UploadBodyListener.php new file mode 100644 index 0000000..a99d2fa --- /dev/null +++ b/vendor/aws/Aws/Common/Client/UploadBodyListener.php @@ -0,0 +1,95 @@ +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."); + } + } + } +} diff --git a/vendor/aws/Aws/Common/Client/UserAgentListener.php b/vendor/aws/Aws/Common/Client/UserAgentListener.php new file mode 100644 index 0000000..cc7e312 --- /dev/null +++ b/vendor/aws/Aws/Common/Client/UserAgentListener.php @@ -0,0 +1,61 @@ + '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); + } + } +} diff --git a/vendor/aws/Aws/Common/Command/AwsQueryVisitor.php b/vendor/aws/Aws/Common/Command/AwsQueryVisitor.php new file mode 100644 index 0000000..dceaafa --- /dev/null +++ b/vendor/aws/Aws/Common/Command/AwsQueryVisitor.php @@ -0,0 +1,117 @@ +fqname = $command->getName(); + $query = array(); + $this->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) + { + static $serializeEmpty = array( + 'SetLoadBalancerPoliciesForBackendServer' => 1, + 'SetLoadBalancerPoliciesOfListener' => 1, + 'UpdateStack' => 1 + ); + + // For BC, serialize empty lists for specific operations + if (!$value) { + if (isset($serializeEmpty[$this->fqname])) { + $query[$prefix] = ''; + } + return; + } + + $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); + } + } + } +} diff --git a/vendor/aws/Aws/Common/Command/JsonCommand.php b/vendor/aws/Aws/Common/Command/JsonCommand.php new file mode 100644 index 0000000..15ad593 --- /dev/null +++ b/vendor/aws/Aws/Common/Command/JsonCommand.php @@ -0,0 +1,47 @@ +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); + } +} diff --git a/vendor/aws/Aws/Common/Command/QueryCommand.php b/vendor/aws/Aws/Common/Command/QueryCommand.php new file mode 100644 index 0000000..63eb8e8 --- /dev/null +++ b/vendor/aws/Aws/Common/Command/QueryCommand.php @@ -0,0 +1,53 @@ +getRequestSerializer()->addVisitor('aws.query', self::$queryVisitor); + $this->getResponseParser()->addVisitor('xml', self::$xmlVisitor); + } +} diff --git a/vendor/aws/Aws/Common/Command/XmlResponseLocationVisitor.php b/vendor/aws/Aws/Common/Command/XmlResponseLocationVisitor.php new file mode 100644 index 0000000..ad229fd --- /dev/null +++ b/vendor/aws/Aws/Common/Command/XmlResponseLocationVisitor.php @@ -0,0 +1,74 @@ +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; + } +} diff --git a/vendor/aws/Aws/Common/Credentials/AbstractCredentialsDecorator.php b/vendor/aws/Aws/Common/Credentials/AbstractCredentialsDecorator.php new file mode 100644 index 0000000..b3a1df9 --- /dev/null +++ b/vendor/aws/Aws/Common/Credentials/AbstractCredentialsDecorator.php @@ -0,0 +1,136 @@ +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; + } +} diff --git a/vendor/aws/Aws/Common/Credentials/AbstractRefreshableCredentials.php b/vendor/aws/Aws/Common/Credentials/AbstractRefreshableCredentials.php new file mode 100644 index 0000000..235bf9d --- /dev/null +++ b/vendor/aws/Aws/Common/Credentials/AbstractRefreshableCredentials.php @@ -0,0 +1,76 @@ +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(); +} diff --git a/vendor/aws/Aws/Common/Credentials/CacheableCredentials.php b/vendor/aws/Aws/Common/Credentials/CacheableCredentials.php new file mode 100644 index 0000000..fbebf78 --- /dev/null +++ b/vendor/aws/Aws/Common/Credentials/CacheableCredentials.php @@ -0,0 +1,73 @@ +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()); + } + } + } +} diff --git a/vendor/aws/Aws/Common/Credentials/Credentials.php b/vendor/aws/Aws/Common/Credentials/Credentials.php new file mode 100644 index 0000000..73b8ffa --- /dev/null +++ b/vendor/aws/Aws/Common/Credentials/Credentials.php @@ -0,0 +1,337 @@ + null, + Options::SECRET => null, + Options::TOKEN => null, + Options::TOKEN_TTD => null, + Options::PROFILE => 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]) { + $credentials = self::createFromEnvironment($config); + // 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) { + $credentials = self::createCache($credentials, $cache, $cacheKey); + } + + return $credentials; + } + + /** + * Create credentials from the credentials ini file in the HOME directory. + * + * @param string|null $profile Pass a specific profile to use. If no + * profile is specified we will attempt to use + * the value specified in the AWS_PROFILE + * environment variable. If AWS_PROFILE is not + * set, the "default" profile is used. + * @param string|null $filename Pass a string to specify the location of the + * credentials files. If null is passed, the + * SDK will attempt to find the configuration + * file at in your HOME directory at + * ~/.aws/credentials. + * @return CredentialsInterface + * @throws \RuntimeException if the file cannot be found, if the file is + * invalid, or if the profile is invalid. + */ + public static function fromIni($profile = null, $filename = null) + { + if (!$filename) { + $filename = self::getHomeDir() . '/.aws/credentials'; + } + + if (!$profile) { + $profile = self::getEnvVar(self::ENV_PROFILE) ?: 'default'; + } + + if (!file_exists($filename) || !($data = parse_ini_file($filename, true))) { + throw new \RuntimeException("Invalid AWS credentials file: {$filename}."); + } + + if (empty($data[$profile])) { + throw new \RuntimeException("Invalid AWS credentials profile {$profile} in {$filename}."); + } + + return new self( + $data[$profile]['aws_access_key_id'], + $data[$profile]['aws_secret_access_key'], + isset($data[$profile]['aws_security_token']) + ? $data[$profile]['aws_security_token'] + : null + ); + } + + /** + * 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; + } + + public function serialize() + { + return json_encode(array( + Options::KEY => $this->key, + Options::SECRET => $this->secret, + Options::TOKEN => $this->token, + Options::TOKEN_TTD => $this->ttd + )); + } + + 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]; + } + + public function getAccessKeyId() + { + return $this->key; + } + + public function getSecretKey() + { + return $this->secret; + } + + public function getSecurityToken() + { + return $this->token; + } + + public function getExpiration() + { + return $this->ttd; + } + + public function isExpired() + { + return $this->ttd !== null && time() >= $this->ttd; + } + + public function setAccessKeyId($key) + { + $this->key = $key; + + return $this; + } + + public function setSecretKey($secret) + { + $this->secret = $secret; + + return $this; + } + + public function setSecurityToken($token) + { + $this->token = $token; + + return $this; + } + + public function setExpiration($timestamp) + { + $this->ttd = $timestamp; + + return $this; + } + + /** + * When no keys are provided, attempt to create them based on the + * environment or instance profile credentials. + * + * @param array|Collection $config + * + * @return CredentialsInterface + */ + private static function createFromEnvironment($config) + { + // Get key and secret from ENV variables + $envKey = self::getEnvVar(self::ENV_KEY); + if (!($envSecret = self::getEnvVar(self::ENV_SECRET))) { + // Use AWS_SECRET_ACCESS_KEY if AWS_SECRET_KEY was not set. + $envSecret = self::getEnvVar(self::ENV_SECRET_ACCESS_KEY); + } + + // Use credentials from the environment variables if available + if ($envKey && $envSecret) { + return new static($envKey, $envSecret); + } + + // Use credentials from the ini file in HOME directory if available + $home = self::getHomeDir(); + if ($home && file_exists("{$home}/.aws/credentials")) { + return self::fromIni($config[Options::PROFILE], "{$home}/.aws/credentials"); + } + + // Use instance profile credentials (available on EC2 instances) + return new RefreshableInstanceProfileCredentials( + new static('', '', '', 1), + $config[Options::CREDENTIALS_CLIENT] + ); + } + + private static function createCache(CredentialsInterface $credentials, $cache, $cacheKey) + { + 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 + return new CacheableCredentials($credentials, $cache, $cacheKey); + } + + private static function getHomeDir() + { + // On Linux/Unix-like systems, use the HOME environment variable + if ($homeDir = self::getEnvVar('HOME')) { + return $homeDir; + } + + // Get the HOMEDRIVE and HOMEPATH values for Windows hosts + $homeDrive = self::getEnvVar('HOMEDRIVE'); + $homePath = self::getEnvVar('HOMEPATH'); + + return ($homeDrive && $homePath) ? $homeDrive . $homePath : null; + } + + /** + * Fetches the value of an environment variable by checking $_SERVER and getenv(). + * + * @param string $var Name of the environment variable + * + * @return mixed|null + */ + private static function getEnvVar($var) + { + return isset($_SERVER[$var]) ? $_SERVER[$var] : getenv($var); + } +} diff --git a/vendor/aws/Aws/Common/Credentials/CredentialsInterface.php b/vendor/aws/Aws/Common/Credentials/CredentialsInterface.php new file mode 100644 index 0000000..dd43037 --- /dev/null +++ b/vendor/aws/Aws/Common/Credentials/CredentialsInterface.php @@ -0,0 +1,96 @@ +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()); + } +} diff --git a/vendor/aws/Aws/Common/Enum.php b/vendor/aws/Aws/Common/Enum.php new file mode 100644 index 0000000..7f4d356 --- /dev/null +++ b/vendor/aws/Aws/Common/Enum.php @@ -0,0 +1,55 @@ +getConstants(); + } + + return self::$cache[$class]; + } +} diff --git a/vendor/aws/Aws/Common/Enum/ClientOptions.php b/vendor/aws/Aws/Common/Enum/ClientOptions.php new file mode 100644 index 0000000..4048cfc --- /dev/null +++ b/vendor/aws/Aws/Common/Enum/ClientOptions.php @@ -0,0 +1,162 @@ +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; + } +} diff --git a/vendor/aws/Aws/Common/Exception/InstanceProfileCredentialsException.php b/vendor/aws/Aws/Common/Exception/InstanceProfileCredentialsException.php new file mode 100644 index 0000000..fb1dcf1 --- /dev/null +++ b/vendor/aws/Aws/Common/Exception/InstanceProfileCredentialsException.php @@ -0,0 +1,50 @@ +statusCode = $code; + } + + /** + * Get the error response code from the service + * + * @return string|null + */ + public function getStatusCode() + { + return $this->statusCode; + } +} diff --git a/vendor/aws/Aws/Common/Exception/InvalidArgumentException.php b/vendor/aws/Aws/Common/Exception/InvalidArgumentException.php new file mode 100644 index 0000000..4360a00 --- /dev/null +++ b/vendor/aws/Aws/Common/Exception/InvalidArgumentException.php @@ -0,0 +1,22 @@ +getMessage(), + 0, + $exception + ); + + $this->state = $state; + } + + /** + * Get the state of the transfer + * + * @return TransferStateInterface + */ + public function getState() + { + return $this->state; + } +} diff --git a/vendor/aws/Aws/Common/Exception/NamespaceExceptionFactory.php b/vendor/aws/Aws/Common/Exception/NamespaceExceptionFactory.php new file mode 100644 index 0000000..6489069 --- /dev/null +++ b/vendor/aws/Aws/Common/Exception/NamespaceExceptionFactory.php @@ -0,0 +1,103 @@ +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; + } +} diff --git a/vendor/aws/Aws/Common/Exception/OutOfBoundsException.php b/vendor/aws/Aws/Common/Exception/OutOfBoundsException.php new file mode 100644 index 0000000..6738c0c --- /dev/null +++ b/vendor/aws/Aws/Common/Exception/OutOfBoundsException.php @@ -0,0 +1,22 @@ + 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); +} diff --git a/vendor/aws/Aws/Common/Exception/Parser/DefaultXmlExceptionParser.php b/vendor/aws/Aws/Common/Exception/Parser/DefaultXmlExceptionParser.php new file mode 100644 index 0000000..a9fda69 --- /dev/null +++ b/vendor/aws/Aws/Common/Exception/Parser/DefaultXmlExceptionParser.php @@ -0,0 +1,100 @@ + 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]; + } + } +} diff --git a/vendor/aws/Aws/Common/Exception/Parser/ExceptionParserInterface.php b/vendor/aws/Aws/Common/Exception/Parser/ExceptionParserInterface.php new file mode 100644 index 0000000..1b25d96 --- /dev/null +++ b/vendor/aws/Aws/Common/Exception/Parser/ExceptionParserInterface.php @@ -0,0 +1,42 @@ +getHeader('x-amzn-ErrorType')) { + $data['code'] = substr($code, 0, strpos($code, ':')); + } + + return $data; + } +} diff --git a/vendor/aws/Aws/Common/Exception/RequiredExtensionNotLoadedException.php b/vendor/aws/Aws/Common/Exception/RequiredExtensionNotLoadedException.php new file mode 100644 index 0000000..c4a072c --- /dev/null +++ b/vendor/aws/Aws/Common/Exception/RequiredExtensionNotLoadedException.php @@ -0,0 +1,22 @@ +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; + } + + /** + * Get the request ID of the error. This value is only present if a + * response was received, and is not present in the event of a networking + * error. + * + * Same as `getRequestId()` method, but matches the interface for SDKv3. + * + * @return string|null Returns null if no response was received + */ + public function getAwsRequestId() + { + return $this->requestId; + } + + /** + * Get the AWS error type. + * + * Same as `getExceptionType()` method, but matches the interface for SDKv3. + * + * @return string|null Returns null if no response was received + */ + public function getAwsErrorType() + { + return $this->exceptionType; + } + + /** + * Get the AWS error code. + * + * Same as `getExceptionCode()` method, but matches the interface for SDKv3. + * + * @return string|null Returns null if no response was received + */ + public function getAwsErrorCode() + { + return $this->exceptionCode; + } +} diff --git a/vendor/aws/Aws/Common/Exception/TransferException.php b/vendor/aws/Aws/Common/Exception/TransferException.php new file mode 100644 index 0000000..47aa80d --- /dev/null +++ b/vendor/aws/Aws/Common/Exception/TransferException.php @@ -0,0 +1,24 @@ +getConfig() as $service) { + if (isset($service['alias'], $service['class'])) { + $facadeClass = __NAMESPACE__ . '\\' . $service['alias']; + $facadeAlias = ltrim($targetNamespace . '\\' . $service['alias'], '\\'); + if (!class_exists($facadeAlias) && class_exists($facadeClass)) { + // @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); + } +} diff --git a/vendor/aws/Aws/Common/Facade/FacadeInterface.php b/vendor/aws/Aws/Common/Facade/FacadeInterface.php new file mode 100644 index 0000000..c00c32d --- /dev/null +++ b/vendor/aws/Aws/Common/Facade/FacadeInterface.php @@ -0,0 +1,34 @@ +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); + } + } +} diff --git a/vendor/aws/Aws/Common/Hash/ChunkHashInterface.php b/vendor/aws/Aws/Common/Hash/ChunkHashInterface.php new file mode 100644 index 0000000..5fcf9a5 --- /dev/null +++ b/vendor/aws/Aws/Common/Hash/ChunkHashInterface.php @@ -0,0 +1,52 @@ +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; + } +} diff --git a/vendor/aws/Aws/Common/HostNameUtils.php b/vendor/aws/Aws/Common/HostNameUtils.php new file mode 100644 index 0000000..4b791aa --- /dev/null +++ b/vendor/aws/Aws/Common/HostNameUtils.php @@ -0,0 +1,85 @@ +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]; + } +} diff --git a/vendor/aws/Aws/Common/InstanceMetadata/InstanceMetadataClient.php b/vendor/aws/Aws/Common/InstanceMetadata/InstanceMetadataClient.php new file mode 100644 index 0000000..229be15 --- /dev/null +++ b/vendor/aws/Aws/Common/InstanceMetadata/InstanceMetadataClient.php @@ -0,0 +1,102 @@ + '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']) + ); + } +} diff --git a/vendor/aws/Aws/Common/InstanceMetadata/Waiter/ServiceAvailable.php b/vendor/aws/Aws/Common/InstanceMetadata/Waiter/ServiceAvailable.php new file mode 100644 index 0000000..ac305c3 --- /dev/null +++ b/vendor/aws/Aws/Common/InstanceMetadata/Waiter/ServiceAvailable.php @@ -0,0 +1,50 @@ +client->get(); + try { + $request->getCurlOptions()->set(CURLOPT_CONNECTTIMEOUT, 10) + ->set(CURLOPT_TIMEOUT, 10); + $request->send(); + + return true; + } catch (CurlException $e) { + return false; + } + } +} diff --git a/vendor/aws/Aws/Common/Iterator/AwsResourceIterator.php b/vendor/aws/Aws/Common/Iterator/AwsResourceIterator.php new file mode 100644 index 0000000..cdd8119 --- /dev/null +++ b/vendor/aws/Aws/Common/Iterator/AwsResourceIterator.php @@ -0,0 +1,169 @@ +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; + } + + protected function prepareRequest() + { + // Get the limit parameter key to set + $limitKey = $this->get('limit_key'); + if ($limitKey && ($limit = $this->command->get($limitKey))) { + $pageSize = $this->calculatePageSize(); + + // If the limit of the command is different than the pageSize of the iterator, use the smaller value + if ($limit && $pageSize) { + $realLimit = min($limit, $pageSize); + $this->command->set($limitKey, $realLimit); + } + } + } + + protected function handleResults(Model $result) + { + $results = array(); + + // Get the result key that contains the results + if ($resultKey = $this->get('result_key')) { + $results = $this->getValueFromResult($result, $resultKey) ?: array(); + } + + return $results; + } + + protected function applyNextToken() + { + // Get the token parameter key to set + if ($tokenParam = $this->get('input_token')) { + // 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); + } + } + } + + protected function determineNextToken(Model $result) + { + $this->nextToken = null; + + // If the value of "more_results" is true or there is no "more_results" to check, then try to get the next token + $moreKey = $this->get('more_results'); + if ($moreKey === null || $this->getValueFromResult($result, $moreKey)) { + // Get the token key to check + if ($tokenKey = $this->get('output_token')) { + // Get the next token's value. Works with multi-value tokens + if (is_array($tokenKey)) { + $this->nextToken = array(); + foreach ($tokenKey as $key) { + $this->nextToken[] = $this->getValueFromResult($result, $key); + } + } else { + $this->nextToken = $this->getValueFromResult($result, $tokenKey); + } + } + } + } + + /** + * Extracts the value from the result using Collection::getPath. Also adds some additional logic for keys that need + * to access n-1 indexes (e.g., ImportExport, Kinesis). The n-1 logic only works for the known cases. We will switch + * to a jmespath implementation in the future to cover all cases + * + * @param Model $result + * @param string $key + * + * @return mixed|null + */ + protected function getValueFromResult(Model $result, $key) + { + // Special handling for keys that need to access n-1 indexes + if (strpos($key, '#') !== false) { + $keyParts = explode('#', $key, 2); + $items = $result->getPath(trim($keyParts[0], '/')); + if ($items && is_array($items)) { + $index = count($items) - 1; + $key = strtr($key, array('#' => $index)); + } + } + + // Get the value + return $result->getPath($key); + } +} diff --git a/vendor/aws/Aws/Common/Iterator/AwsResourceIteratorFactory.php b/vendor/aws/Aws/Common/Iterator/AwsResourceIteratorFactory.php new file mode 100644 index 0000000..ce668a2 --- /dev/null +++ b/vendor/aws/Aws/Common/Iterator/AwsResourceIteratorFactory.php @@ -0,0 +1,106 @@ + null, + 'output_token' => null, + 'limit_key' => null, + 'result_key' => null, + 'more_results' => null, + ); + + /** + * @var array Legacy configuration options mapped to their new names + */ + private static $legacyConfigOptions = array( + 'token_param' => 'input_token', + 'token_key' => 'output_token', + 'limit_param' => 'limit_key', + 'more_key' => 'more_results', + ); + + /** + * @var array Iterator configuration for each iterable operation + */ + protected $config; + + /** + * @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 + */ + public function __construct(array $config, ResourceIteratorFactoryInterface $primaryIteratorFactory = null) + { + $this->primaryIteratorFactory = $primaryIteratorFactory; + $this->config = array(); + foreach ($config as $name => $operation) { + $this->config[$name] = $operation + self::$defaultIteratorConfig; + } + } + + public function build(CommandInterface $command, array $options = array()) + { + // Get the configuration data for the command + $commandName = $command->getName(); + $commandSupported = isset($this->config[$commandName]); + $options = $this->translateLegacyConfigOptions($options); + $options += $commandSupported ? $this->config[$commandName] : array(); + + // Instantiate the iterator using the primary factory (if one was provided) + if ($this->primaryIteratorFactory && $this->primaryIteratorFactory->canBuild($command)) { + $iterator = $this->primaryIteratorFactory->build($command, $options); + } elseif (!$commandSupported) { + throw new InvalidArgumentException("Iterator was not found for {$commandName}."); + } else { + // Instantiate a generic AWS resource iterator + $iterator = new AwsResourceIterator($command, $options); + } + + return $iterator; + } + + public function canBuild(CommandInterface $command) + { + if ($this->primaryIteratorFactory) { + return $this->primaryIteratorFactory->canBuild($command); + } else { + return isset($this->config[$command->getName()]); + } + } + + /** + * @param array $config The config for a single operation + * + * @return array The modified config with legacy options translated + */ + private function translateLegacyConfigOptions($config) + { + foreach (self::$legacyConfigOptions as $legacyOption => $newOption) { + if (isset($config[$legacyOption])) { + $config[$newOption] = $config[$legacyOption]; + unset($config[$legacyOption]); + } + } + + return $config; + } +} diff --git a/vendor/aws/Aws/Common/Model/MultipartUpload/AbstractTransfer.php b/vendor/aws/Aws/Common/Model/MultipartUpload/AbstractTransfer.php new file mode 100644 index 0000000..751b558 --- /dev/null +++ b/vendor/aws/Aws/Common/Model/MultipartUpload/AbstractTransfer.php @@ -0,0 +1,270 @@ +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(); +} diff --git a/vendor/aws/Aws/Common/Model/MultipartUpload/AbstractTransferState.php b/vendor/aws/Aws/Common/Model/MultipartUpload/AbstractTransferState.php new file mode 100644 index 0000000..06d6c84 --- /dev/null +++ b/vendor/aws/Aws/Common/Model/MultipartUpload/AbstractTransferState.php @@ -0,0 +1,164 @@ +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."); + } + } + } +} diff --git a/vendor/aws/Aws/Common/Model/MultipartUpload/AbstractUploadBuilder.php b/vendor/aws/Aws/Common/Model/MultipartUpload/AbstractUploadBuilder.php new file mode 100644 index 0000000..8690d5c --- /dev/null +++ b/vendor/aws/Aws/Common/Model/MultipartUpload/AbstractUploadBuilder.php @@ -0,0 +1,148 @@ +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 $this + */ + 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 $this + * @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 $this + */ + 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(); +} diff --git a/vendor/aws/Aws/Common/Model/MultipartUpload/AbstractUploadId.php b/vendor/aws/Aws/Common/Model/MultipartUpload/AbstractUploadId.php new file mode 100644 index 0000000..da79521 --- /dev/null +++ b/vendor/aws/Aws/Common/Model/MultipartUpload/AbstractUploadId.php @@ -0,0 +1,89 @@ +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."); + } + } + } +} diff --git a/vendor/aws/Aws/Common/Model/MultipartUpload/AbstractUploadPart.php b/vendor/aws/Aws/Common/Model/MultipartUpload/AbstractUploadPart.php new file mode 100644 index 0000000..1cf4c6d --- /dev/null +++ b/vendor/aws/Aws/Common/Model/MultipartUpload/AbstractUploadPart.php @@ -0,0 +1,101 @@ +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."); + } + } + } +} diff --git a/vendor/aws/Aws/Common/Model/MultipartUpload/TransferInterface.php b/vendor/aws/Aws/Common/Model/MultipartUpload/TransferInterface.php new file mode 100644 index 0000000..1fc1ae9 --- /dev/null +++ b/vendor/aws/Aws/Common/Model/MultipartUpload/TransferInterface.php @@ -0,0 +1,66 @@ + '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' + ) + ), + + 'cloudhsm' => array( + 'alias' => 'CloudHsm', + 'extends' => 'default_settings', + 'class' => 'Aws\CloudHsm\CloudHsmClient' + ), + + 'cloudsearch' => array( + 'alias' => 'CloudSearch', + 'extends' => 'default_settings', + 'class' => 'Aws\CloudSearch\CloudSearchClient' + ), + + 'cloudsearch_20110201' => array( + 'extends' => 'cloudsearch', + 'params' => array( + 'version' => '2011-02-01' + ) + ), + + 'cloudsearchdomain' => array( + 'alias' => 'CloudSearchDomain', + 'extends' => 'default_settings', + 'class' => 'Aws\CloudSearchDomain\CloudSearchDomainClient' + ), + + 'cloudtrail' => array( + 'alias' => 'CloudTrail', + 'extends' => 'default_settings', + 'class' => 'Aws\CloudTrail\CloudTrailClient' + ), + + 'cloudwatch' => array( + 'alias' => 'CloudWatch', + 'extends' => 'default_settings', + 'class' => 'Aws\CloudWatch\CloudWatchClient' + ), + + 'cloudwatchlogs' => array( + 'alias' => 'CloudWatchLogs', + 'extends' => 'default_settings', + 'class' => 'Aws\CloudWatchLogs\CloudWatchLogsClient' + ), + + 'cognito-identity' => array( + 'alias' => 'CognitoIdentity', + 'extends' => 'default_settings', + 'class' => 'Aws\CognitoIdentity\CognitoIdentityClient' + ), + + 'cognitoidentity' => array('extends' => 'cognito-identity'), + + 'cognito-sync' => array( + 'alias' => 'CognitoSync', + 'extends' => 'default_settings', + 'class' => 'Aws\CognitoSync\CognitoSyncClient' + ), + + 'cognitosync' => array('extends' => 'cognito-sync'), + + 'codedeploy' => array( + 'alias' => 'CodeDeploy', + 'extends' => 'default_settings', + 'class' => 'Aws\CodeDeploy\CodeDeployClient' + ), + + 'config' => array( + 'alias' => 'ConfigService', + 'extends' => 'default_settings', + 'class' => 'Aws\ConfigService\ConfigServiceClient' + ), + + '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' + ), + + 'ecs' => array( + 'alias' => 'Ecs', + 'extends' => 'default_settings', + 'class' => 'Aws\Ecs\EcsClient' + ), + + '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' + ), + + 'kms' => array( + 'alias' => 'Kms', + 'extends' => 'default_settings', + 'class' => 'Aws\Kms\KmsClient' + ), + + 'lambda' => array( + 'alias' => 'Lambda', + 'extends' => 'default_settings', + 'class' => 'Aws\Lambda\LambdaClient' + ), + + 'iam' => array( + 'alias' => 'Iam', + 'extends' => 'default_settings', + 'class' => 'Aws\Iam\IamClient' + ), + + 'importexport' => array( + 'alias' => 'ImportExport', + 'extends' => 'default_settings', + 'class' => 'Aws\ImportExport\ImportExportClient' + ), + + 'machinelearning' => array( + 'alias' => 'MachineLearning', + 'extends' => 'default_settings', + 'class' => 'Aws\MachineLearning\MachineLearningClient' + ), + + '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' + ), + + 'route53domains' => array( + 'alias' => 'Route53Domains', + 'extends' => 'default_settings', + 'class' => 'Aws\Route53Domains\Route53DomainsClient' + ), + + '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' + ), + + 'ssm' => array( + 'alias' => 'Ssm', + 'extends' => 'default_settings', + 'class' => 'Aws\Ssm\SsmClient' + ), + + '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' + ), + + 'workspaces' => array( + 'alias' => 'WorkSpaces', + 'extends' => 'default_settings', + 'class' => 'Aws\WorkSpaces\WorkSpacesClient' + ), + ) +); diff --git a/vendor/aws/Aws/Common/Resources/public-endpoints.php b/vendor/aws/Aws/Common/Resources/public-endpoints.php new file mode 100644 index 0000000..d939f1f --- /dev/null +++ b/vendor/aws/Aws/Common/Resources/public-endpoints.php @@ -0,0 +1,79 @@ + 2, + 'endpoints' => array( + '*/*' => array( + 'endpoint' => '{service}.{region}.amazonaws.com' + ), + 'cn-north-1/*' => array( + 'endpoint' => '{service}.{region}.amazonaws.com.cn', + 'signatureVersion' => 'v4' + ), + 'us-gov-west-1/iam' => array( + 'endpoint' => 'iam.us-gov.amazonaws.com' + ), + 'us-gov-west-1/sts' => array( + 'endpoint' => 'sts.us-gov-west-1.amazonaws.com' + ), + 'us-gov-west-1/s3' => array( + 'endpoint' => 's3-{region}.amazonaws.com' + ), + '*/cloudfront' => array( + 'endpoint' => 'cloudfront.amazonaws.com', + 'credentialScope' => array( + 'region' => 'us-east-1' + ) + ), + '*/iam' => array( + 'endpoint' => 'iam.amazonaws.com', + 'credentialScope' => array( + 'region' => 'us-east-1' + ) + ), + '*/importexport' => array( + 'endpoint' => 'importexport.amazonaws.com', + 'credentialScope' => array( + 'region' => 'us-east-1' + ) + ), + '*/route53' => array( + 'endpoint' => 'route53.amazonaws.com', + 'credentialScope' => array( + 'region' => 'us-east-1' + ) + ), + '*/sts' => array( + 'endpoint' => 'sts.amazonaws.com', + 'credentialScope' => array( + 'region' => 'us-east-1' + ) + ), + 'us-east-1/sdb' => array( + 'endpoint' => 'sdb.amazonaws.com' + ), + 'us-east-1/s3' => array( + 'endpoint' => 's3.amazonaws.com' + ), + 'us-west-1/s3' => array( + 'endpoint' => 's3-{region}.amazonaws.com' + ), + 'us-west-2/s3' => array( + 'endpoint' => 's3-{region}.amazonaws.com' + ), + 'eu-west-1/s3' => array( + 'endpoint' => 's3-{region}.amazonaws.com' + ), + 'ap-southeast-1/s3' => array( + 'endpoint' => 's3-{region}.amazonaws.com' + ), + 'ap-southeast-2/s3' => array( + 'endpoint' => 's3-{region}.amazonaws.com' + ), + 'ap-northeast-1/s3' => array( + 'endpoint' => 's3-{region}.amazonaws.com' + ), + 'sa-east-1/s3' => array( + 'endpoint' => 's3-{region}.amazonaws.com' + ) + ) +); diff --git a/vendor/aws/Aws/Common/Resources/sdk1-config.php b/vendor/aws/Aws/Common/Resources/sdk1-config.php new file mode 100644 index 0000000..a5121ab --- /dev/null +++ b/vendor/aws/Aws/Common/Resources/sdk1-config.php @@ -0,0 +1,138 @@ + 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' + ) + ) +); diff --git a/vendor/aws/Aws/Common/RulesEndpointProvider.php b/vendor/aws/Aws/Common/RulesEndpointProvider.php new file mode 100644 index 0000000..ec57cb8 --- /dev/null +++ b/vendor/aws/Aws/Common/RulesEndpointProvider.php @@ -0,0 +1,67 @@ +patterns = $patterns; + } + + /** + * Creates and returns the default RulesEndpointProvider based on the + * public rule sets. + * + * @return self + */ + public static function fromDefaults() + { + return new self(require __DIR__ . '/Resources/public-endpoints.php'); + } + + public function __invoke(array $args = array()) + { + if (!isset($args['service'])) { + throw new \InvalidArgumentException('Requires a "service" value'); + } + + if (!isset($args['region'])) { + throw new \InvalidArgumentException('Requires a "region" value'); + } + + foreach ($this->getKeys($args['region'], $args['service']) as $key) { + if (isset($this->patterns['endpoints'][$key])) { + return $this->expand($this->patterns['endpoints'][$key], $args); + } + } + + throw new \RuntimeException('Could not resolve endpoint'); + } + + private function expand(array $config, array $args) + { + $scheme = isset($args['scheme']) ? $args['scheme'] : 'https'; + $config['endpoint'] = $scheme . '://' . str_replace( + array('{service}', '{region}'), + array($args['service'], $args['region']), + $config['endpoint'] + ); + + return $config; + } + + private function getKeys($region, $service) + { + return array("$region/$service", "$region/*", "*/$service", "*/*"); + } +} diff --git a/vendor/aws/Aws/Common/Signature/AbstractSignature.php b/vendor/aws/Aws/Common/Signature/AbstractSignature.php new file mode 100644 index 0000000..2d25d87 --- /dev/null +++ b/vendor/aws/Aws/Common/Signature/AbstractSignature.php @@ -0,0 +1,44 @@ +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) + { + if(!$this->credentials instanceof NullCredentials) { + $this->signature->signRequest($event['request'], $this->credentials); + } + } +} diff --git a/vendor/aws/Aws/Common/Signature/SignatureV2.php b/vendor/aws/Aws/Common/Signature/SignatureV2.php new file mode 100644 index 0000000..c900287 --- /dev/null +++ b/vendor/aws/Aws/Common/Signature/SignatureV2.php @@ -0,0 +1,109 @@ +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); + } +} diff --git a/vendor/aws/Aws/Common/Signature/SignatureV3Https.php b/vendor/aws/Aws/Common/Signature/SignatureV3Https.php new file mode 100644 index 0000000..be0514e --- /dev/null +++ b/vendor/aws/Aws/Common/Signature/SignatureV3Https.php @@ -0,0 +1,52 @@ +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)); + } +} diff --git a/vendor/aws/Aws/Common/Signature/SignatureV4.php b/vendor/aws/Aws/Common/Signature/SignatureV4.php new file mode 100644 index 0000000..8d136f7 --- /dev/null +++ b/vendor/aws/Aws/Common/Signature/SignatureV4.php @@ -0,0 +1,470 @@ +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 = $this->createScope($shortDate, $region, $service); + $payload = $this->getPayload($request); + $signingContext = $this->createSigningContext($request, $payload); + $signingContext['string_to_sign'] = $this->createStringToSign( + $longDate, + $credentialScope, + $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); + } + + public function createPresignedUrl( + RequestInterface $request, + CredentialsInterface $credentials, + $expires + ) { + $request = $this->createPresignedRequest($request, $credentials); + $query = $request->getQuery(); + $httpDate = gmdate(DateFormat::ISO8601, $this->getTimestamp()); + $shortDate = substr($httpDate, 0, 8); + $scope = $this->createScope( + $shortDate, + $this->regionName, + $this->serviceName + ); + $this->addQueryValues($scope, $request, $credentials, $expires); + $payload = $this->getPresignedPayload($request); + $context = $this->createSigningContext($request, $payload); + $stringToSign = $this->createStringToSign( + $httpDate, + $scope, + $context['canonical_request'] + ); + $key = $this->getSigningKey( + $shortDate, + $this->regionName, + $this->serviceName, + $credentials->getSecretKey() + ); + $query['X-Amz-Signature'] = hash_hmac('sha256', $stringToSign, $key); + + return $request->getUrl(); + } + + /** + * Converts a POST request to a GET request by moving POST fields into the + * query string. + * + * Useful for pre-signing query protocol requests. + * + * @param EntityEnclosingRequestInterface $request Request to clone + * + * @return RequestInterface + * @throws \InvalidArgumentException if the method is not POST + */ + public static function convertPostToGet(EntityEnclosingRequestInterface $request) + { + if ($request->getMethod() !== 'POST') { + throw new \InvalidArgumentException('Expected a POST request but ' + . 'received a ' . $request->getMethod() . ' request.'); + } + + $cloned = RequestFactory::getInstance() + ->cloneRequestWithMethod($request, 'GET'); + + // Move POST fields to the query if they are present + foreach ($request->getPostFields() as $name => $value) { + $cloned->getQuery()->set($name, $value); + } + + return $cloned; + } + + /** + * Get the payload part of a signature from a request. + * + * @param RequestInterface $request + * + * @return string + */ + protected function getPayload(RequestInterface $request) + { + // Calculate the request signature payload + if ($request->hasHeader('x-amz-content-sha256')) { + // Handle streaming operations (e.g. Glacier.UploadArchive) + return (string) $request->getHeader('x-amz-content-sha256'); + } + + if ($request instanceof EntityEnclosingRequestInterface) { + if ($request->getMethod() == 'POST' && count($request->getPostFields())) { + return hash('sha256', (string) $request->getPostFields()); + } elseif ($body = $request->getBody()) { + return Stream::getHash($request->getBody(), 'sha256'); + } + } + + return self::DEFAULT_PAYLOAD; + } + + /** + * Get the payload of a request for use with pre-signed URLs. + * + * @param RequestInterface $request + * + * @return string + */ + protected function getPresignedPayload(RequestInterface $request) + { + return $this->getPayload($request); + } + + protected function createCanonicalizedPath(RequestInterface $request) + { + $doubleEncoded = rawurlencode(ltrim($request->getPath(), '/')); + + return '/' . str_replace('%2F', '/', $doubleEncoded); + } + + private function createStringToSign($longDate, $credentialScope, $creq) + { + return "AWS4-HMAC-SHA256\n{$longDate}\n{$credentialScope}\n" + . hash('sha256', $creq); + } + + private function createPresignedRequest( + RequestInterface $request, + CredentialsInterface $credentials + ) { + $sr = RequestFactory::getInstance()->cloneRequestWithMethod($request, 'GET'); + + // Move POST fields to the query if they are present + if ($request instanceof EntityEnclosingRequestInterface) { + foreach ($request->getPostFields() as $name => $value) { + $sr->getQuery()->set($name, $value); + } + } + + // Make sure to handle temporary credentials + if ($token = $credentials->getSecurityToken()) { + $sr->setHeader('X-Amz-Security-Token', $token); + $sr->getQuery()->set('X-Amz-Security-Token', $token); + } + + $this->moveHeadersToQuery($sr); + + return $sr; + } + + /** + * 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 + */ + private function createSigningContext(RequestInterface $request, $payload) + { + $signable = array( + 'host' => true, + 'date' => true, + 'content-md5' => true + ); + + // Normalize the path as required by SigV4 and ensure it's absolute + $canon = $request->getMethod() . "\n" + . $this->createCanonicalizedPath($request) . "\n" + . $this->getCanonicalizedQueryString($request) . "\n"; + + $canonHeaders = array(); + + foreach ($request->getHeaders()->getAll() as $key => $values) { + $key = strtolower($key); + if (isset($signable[$key]) || substr($key, 0, 6) === 'x-amz-') { + $values = $values->toArray(); + if (count($values) == 1) { + $values = $values[0]; + } else { + sort($values); + $values = implode(',', $values); + } + $canonHeaders[$key] = $key . ':' . preg_replace('/\s+/', ' ', $values); + } + } + + ksort($canonHeaders); + $signedHeadersString = implode(';', array_keys($canonHeaders)); + $canon .= implode("\n", $canonHeaders) . "\n\n" + . $signedHeadersString . "\n" + . $payload; + + return array( + 'canonical_request' => $canon, + 'signed_headers' => $signedHeadersString + ); + } + + /** + * 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 + */ + private 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 === 0) { + $values = array('0'); + } elseif (!$values) { + $values = array(''); + } + + foreach ((array) $values as $value) { + if ($value === QueryString::BLANK) { + $value = ''; + } + $qs .= rawurlencode($key) . '=' . rawurlencode($value) . '&'; + } + } + + return substr($qs, 0, -1); + } + + 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 a ' + . 'signature version 4 presigned URL must be less than one ' + . 'week'); + } + + return $duration; + } + + private function createScope($shortDate, $region, $service) + { + return $shortDate + . '/' . $region + . '/' . $service + . '/aws4_request'; + } + + private function addQueryValues( + $scope, + RequestInterface $request, + CredentialsInterface $credentials, + $expires + ) { + $credential = $credentials->getAccessKeyId() . '/' . $scope; + + // 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-Date', gmdate('Ymd\THis\Z', $this->getTimestamp())) + ->set('X-Amz-SignedHeaders', 'Host') + ->set('X-Amz-Expires', $this->convertExpires($expires)); + } + + private function moveHeadersToQuery(RequestInterface $request) + { + $query = $request->getQuery(); + + foreach ($request->getHeaders() as $name => $header) { + if (substr($name, 0, 5) == 'x-amz') { + $query[$header->getName()] = (string) $header; + } + if ($name !== 'host') { + $request->removeHeader($name); + } + } + } +} diff --git a/vendor/aws/Aws/Common/Waiter/AbstractResourceWaiter.php b/vendor/aws/Aws/Common/Waiter/AbstractResourceWaiter.php new file mode 100644 index 0000000..5334848 --- /dev/null +++ b/vendor/aws/Aws/Common/Waiter/AbstractResourceWaiter.php @@ -0,0 +1,53 @@ +client = $client; + + return $this; + } + + /** + * {@inheritdoc} + */ + public function wait() + { + if (!$this->client) { + throw new RuntimeException('No client has been specified on the waiter'); + } + + parent::wait(); + } +} diff --git a/vendor/aws/Aws/Common/Waiter/AbstractWaiter.php b/vendor/aws/Aws/Common/Waiter/AbstractWaiter.php new file mode 100644 index 0000000..09dbea1 --- /dev/null +++ b/vendor/aws/Aws/Common/Waiter/AbstractWaiter.php @@ -0,0 +1,146 @@ +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(); +} diff --git a/vendor/aws/Aws/Common/Waiter/CallableWaiter.php b/vendor/aws/Aws/Common/Waiter/CallableWaiter.php new file mode 100644 index 0000000..a205e06 --- /dev/null +++ b/vendor/aws/Aws/Common/Waiter/CallableWaiter.php @@ -0,0 +1,82 @@ +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); + } +} diff --git a/vendor/aws/Aws/Common/Waiter/CompositeWaiterFactory.php b/vendor/aws/Aws/Common/Waiter/CompositeWaiterFactory.php new file mode 100644 index 0000000..5278e49 --- /dev/null +++ b/vendor/aws/Aws/Common/Waiter/CompositeWaiterFactory.php @@ -0,0 +1,90 @@ +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; + } +} diff --git a/vendor/aws/Aws/Common/Waiter/ConfigResourceWaiter.php b/vendor/aws/Aws/Common/Waiter/ConfigResourceWaiter.php new file mode 100644 index 0000000..8ef0577 --- /dev/null +++ b/vendor/aws/Aws/Common/Waiter/ConfigResourceWaiter.php @@ -0,0 +1,225 @@ +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; + } +} diff --git a/vendor/aws/Aws/Common/Waiter/ResourceWaiterInterface.php b/vendor/aws/Aws/Common/Waiter/ResourceWaiterInterface.php new file mode 100644 index 0000000..07cf41d --- /dev/null +++ b/vendor/aws/Aws/Common/Waiter/ResourceWaiterInterface.php @@ -0,0 +1,34 @@ + 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; + } +} diff --git a/vendor/aws/Aws/Common/Waiter/WaiterConfig.php b/vendor/aws/Aws/Common/Waiter/WaiterConfig.php new file mode 100644 index 0000000..7c10f5a --- /dev/null +++ b/vendor/aws/Aws/Common/Waiter/WaiterConfig.php @@ -0,0 +1,67 @@ +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]); + } + } + } +} diff --git a/vendor/aws/Aws/Common/Waiter/WaiterConfigFactory.php b/vendor/aws/Aws/Common/Waiter/WaiterConfigFactory.php new file mode 100644 index 0000000..cb92149 --- /dev/null +++ b/vendor/aws/Aws/Common/Waiter/WaiterConfigFactory.php @@ -0,0 +1,98 @@ +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; + } +} diff --git a/vendor/aws/Aws/Common/Waiter/WaiterFactoryInterface.php b/vendor/aws/Aws/Common/Waiter/WaiterFactoryInterface.php new file mode 100644 index 0000000..b9bf0f4 --- /dev/null +++ b/vendor/aws/Aws/Common/Waiter/WaiterFactoryInterface.php @@ -0,0 +1,41 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/configservice-%s.php' + )) + ->setExceptionParser(new JsonQueryExceptionParser()) + ->build(); + } +} diff --git a/vendor/aws/Aws/ConfigService/Exception/ConfigServiceException.php b/vendor/aws/Aws/ConfigService/Exception/ConfigServiceException.php new file mode 100644 index 0000000..b91ae2b --- /dev/null +++ b/vendor/aws/Aws/ConfigService/Exception/ConfigServiceException.php @@ -0,0 +1,10 @@ + '2014-11-12', + 'endpointPrefix' => 'config', + 'serviceFullName' => 'AWS Config', + 'serviceAbbreviation' => 'Config Service', + 'serviceType' => 'json', + 'jsonVersion' => '1.1', + 'targetPrefix' => 'StarlingDoveService.', + 'signatureVersion' => 'v4', + 'namespace' => 'ConfigService', + 'operations' => array( + 'DeleteDeliveryChannel' => 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' => 'StarlingDoveService.DeleteDeliveryChannel', + ), + 'DeliveryChannelName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'You have specified a delivery channel that does not exist.', + 'class' => 'NoSuchDeliveryChannelException', + ), + array( + 'reason' => 'You cannot delete the delivery channel you specified because the configuration recorder is running.', + 'class' => 'LastDeliveryChannelDeleteFailedException', + ), + ), + ), + 'DeliverConfigSnapshot' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DeliverConfigSnapshotResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StarlingDoveService.DeliverConfigSnapshot', + ), + 'deliveryChannelName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'You have specified a delivery channel that does not exist.', + 'class' => 'NoSuchDeliveryChannelException', + ), + array( + 'reason' => 'There are no configuration recorders available to provide the role needed to describe your resources.', + 'class' => 'NoAvailableConfigurationRecorderException', + ), + array( + 'reason' => 'There is no configuration recorder running.', + 'class' => 'NoRunningConfigurationRecorderException', + ), + ), + ), + 'DescribeConfigurationRecorderStatus' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeConfigurationRecorderStatusResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StarlingDoveService.DescribeConfigurationRecorderStatus', + ), + 'ConfigurationRecorderNames' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'RecorderName', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'You have specified a configuration recorder that does not exist.', + 'class' => 'NoSuchConfigurationRecorderException', + ), + ), + ), + 'DescribeConfigurationRecorders' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeConfigurationRecordersResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StarlingDoveService.DescribeConfigurationRecorders', + ), + 'ConfigurationRecorderNames' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'RecorderName', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'You have specified a configuration recorder that does not exist.', + 'class' => 'NoSuchConfigurationRecorderException', + ), + ), + ), + 'DescribeDeliveryChannelStatus' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeDeliveryChannelStatusResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StarlingDoveService.DescribeDeliveryChannelStatus', + ), + 'DeliveryChannelNames' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'ChannelName', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'You have specified a delivery channel that does not exist.', + 'class' => 'NoSuchDeliveryChannelException', + ), + ), + ), + 'DescribeDeliveryChannels' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeDeliveryChannelsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StarlingDoveService.DescribeDeliveryChannels', + ), + 'DeliveryChannelNames' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'ChannelName', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'You have specified a delivery channel that does not exist.', + 'class' => 'NoSuchDeliveryChannelException', + ), + ), + ), + 'GetResourceConfigHistory' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GetResourceConfigHistoryResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StarlingDoveService.GetResourceConfigHistory', + ), + 'resourceType' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'resourceId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'laterTime' => array( + 'type' => array( + 'object', + 'string', + 'integer', + ), + 'format' => 'date-time', + 'location' => 'json', + ), + 'earlierTime' => array( + 'type' => array( + 'object', + 'string', + 'integer', + ), + 'format' => 'date-time', + 'location' => 'json', + ), + 'chronologicalOrder' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'limit' => array( + 'type' => 'numeric', + 'location' => 'json', + 'maximum' => 100, + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The requested action is not valid.', + 'class' => 'ValidationException', + ), + array( + 'reason' => 'The specified time range is not valid. The earlier time is not chronologically before the later time.', + 'class' => 'InvalidTimeRangeException', + ), + array( + 'reason' => 'You have reached the limit on the pagination.', + 'class' => 'InvalidLimitException', + ), + array( + 'reason' => 'The specified nextToken for pagination is not valid.', + 'class' => 'InvalidNextTokenException', + ), + array( + 'reason' => 'There are no configuration recorders available to provide the role needed to describe your resources.', + 'class' => 'NoAvailableConfigurationRecorderException', + ), + array( + 'reason' => 'You have specified a resource that is either unknown or has not been discovered.', + 'class' => 'ResourceNotDiscoveredException', + ), + ), + ), + 'PutConfigurationRecorder' => 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' => 'StarlingDoveService.PutConfigurationRecorder', + ), + 'ConfigurationRecorder' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'name' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'roleARN' => array( + 'type' => 'string', + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'You have reached the limit on the number of recorders you can create.', + 'class' => 'MaxNumberOfConfigurationRecordersExceededException', + ), + array( + 'reason' => 'You have provided a configuration recorder name that is not valid.', + 'class' => 'InvalidConfigurationRecorderNameException', + ), + array( + 'reason' => 'You have provided a null or empty role ARN.', + 'class' => 'InvalidRoleException', + ), + ), + ), + 'PutDeliveryChannel' => 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' => 'StarlingDoveService.PutDeliveryChannel', + ), + 'DeliveryChannel' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'name' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + 's3BucketName' => array( + 'type' => 'string', + ), + 's3KeyPrefix' => array( + 'type' => 'string', + ), + 'snsTopicARN' => array( + 'type' => 'string', + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'You have reached the limit on the number of delivery channels you can create.', + 'class' => 'MaxNumberOfDeliveryChannelsExceededException', + ), + array( + 'reason' => 'There are no configuration recorders available to provide the role needed to describe your resources.', + 'class' => 'NoAvailableConfigurationRecorderException', + ), + array( + 'reason' => 'The specified delivery channel name is not valid.', + 'class' => 'InvalidDeliveryChannelNameException', + ), + array( + 'reason' => 'The specified Amazon S3 bucket does not exist.', + 'class' => 'NoSuchBucketException', + ), + array( + 'reason' => 'The specified Amazon S3 key prefix is not valid.', + 'class' => 'InvalidS3KeyPrefixException', + ), + array( + 'reason' => 'The specified Amazon SNS topic does not exist.', + 'class' => 'InvalidSNSTopicARNException', + ), + array( + 'reason' => 'Your Amazon S3 bucket policy does not permit AWS Config to write to it.', + 'class' => 'InsufficientDeliveryPolicyException', + ), + ), + ), + 'StartConfigurationRecorder' => 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' => 'StarlingDoveService.StartConfigurationRecorder', + ), + 'ConfigurationRecorderName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'You have specified a configuration recorder that does not exist.', + 'class' => 'NoSuchConfigurationRecorderException', + ), + array( + 'reason' => 'There is no delivery channel available to record configurations.', + 'class' => 'NoAvailableDeliveryChannelException', + ), + ), + ), + 'StopConfigurationRecorder' => 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' => 'StarlingDoveService.StopConfigurationRecorder', + ), + 'ConfigurationRecorderName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'You have specified a configuration recorder that does not exist.', + 'class' => 'NoSuchConfigurationRecorderException', + ), + ), + ), + ), + 'models' => array( + 'EmptyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + ), + 'DeliverConfigSnapshotResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'configSnapshotId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DescribeConfigurationRecorderStatusResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ConfigurationRecordersStatus' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'ConfigurationRecorderStatus', + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'lastStartTime' => array( + 'type' => 'string', + ), + 'lastStopTime' => array( + 'type' => 'string', + ), + 'recording' => array( + 'type' => 'boolean', + ), + 'lastStatus' => array( + 'type' => 'string', + ), + 'lastErrorCode' => array( + 'type' => 'string', + ), + 'lastErrorMessage' => array( + 'type' => 'string', + ), + 'lastStatusChangeTime' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'DescribeConfigurationRecordersResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ConfigurationRecorders' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'ConfigurationRecorder', + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'roleARN' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'DescribeDeliveryChannelStatusResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'DeliveryChannelsStatus' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'DeliveryChannelStatus', + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'configSnapshotDeliveryInfo' => array( + 'type' => 'object', + 'properties' => array( + 'lastStatus' => array( + 'type' => 'string', + ), + 'lastErrorCode' => array( + 'type' => 'string', + ), + 'lastErrorMessage' => array( + 'type' => 'string', + ), + 'lastAttemptTime' => array( + 'type' => 'string', + ), + 'lastSuccessfulTime' => array( + 'type' => 'string', + ), + ), + ), + 'configHistoryDeliveryInfo' => array( + 'type' => 'object', + 'properties' => array( + 'lastStatus' => array( + 'type' => 'string', + ), + 'lastErrorCode' => array( + 'type' => 'string', + ), + 'lastErrorMessage' => array( + 'type' => 'string', + ), + 'lastAttemptTime' => array( + 'type' => 'string', + ), + 'lastSuccessfulTime' => array( + 'type' => 'string', + ), + ), + ), + 'configStreamDeliveryInfo' => array( + 'type' => 'object', + 'properties' => array( + 'lastStatus' => array( + 'type' => 'string', + ), + 'lastErrorCode' => array( + 'type' => 'string', + ), + 'lastErrorMessage' => array( + 'type' => 'string', + ), + 'lastStatusChangeTime' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'DescribeDeliveryChannelsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'DeliveryChannels' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'DeliveryChannel', + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 's3BucketName' => array( + 'type' => 'string', + ), + 's3KeyPrefix' => array( + 'type' => 'string', + ), + 'snsTopicARN' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'GetResourceConfigHistoryResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'configurationItems' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'ConfigurationItem', + 'type' => 'object', + 'properties' => array( + 'version' => array( + 'type' => 'string', + ), + 'accountId' => array( + 'type' => 'string', + ), + 'configurationItemCaptureTime' => array( + 'type' => 'string', + ), + 'configurationItemStatus' => array( + 'type' => 'string', + ), + 'configurationStateId' => array( + 'type' => 'string', + ), + 'configurationItemMD5Hash' => array( + 'type' => 'string', + ), + 'arn' => array( + 'type' => 'string', + ), + 'resourceType' => array( + 'type' => 'string', + ), + 'resourceId' => array( + 'type' => 'string', + ), + 'availabilityZone' => array( + 'type' => 'string', + ), + 'resourceCreationTime' => array( + 'type' => 'string', + ), + 'tags' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'string', + ), + ), + 'relatedEvents' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'RelatedEvent', + 'type' => 'string', + ), + ), + 'relationships' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Relationship', + 'type' => 'object', + 'properties' => array( + 'resourceType' => array( + 'type' => 'string', + ), + 'resourceId' => array( + 'type' => 'string', + ), + 'relationshipName' => array( + 'type' => 'string', + ), + ), + ), + ), + 'configuration' => array( + 'type' => 'string', + ), + ), + ), + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + ), +); diff --git a/vendor/aws/Aws/DataPipeline/DataPipelineClient.php b/vendor/aws/Aws/DataPipeline/DataPipelineClient.php new file mode 100644 index 0000000..c21cea7 --- /dev/null +++ b/vendor/aws/Aws/DataPipeline/DataPipelineClient.php @@ -0,0 +1,83 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/datapipeline-%s.php' + )) + ->setExceptionParser(new JsonQueryExceptionParser()) + ->build(); + + return $client; + } +} diff --git a/vendor/aws/Aws/DataPipeline/Enum/WorkStatus.php b/vendor/aws/Aws/DataPipeline/Enum/WorkStatus.php new file mode 100644 index 0000000..70231f5 --- /dev/null +++ b/vendor/aws/Aws/DataPipeline/Enum/WorkStatus.php @@ -0,0 +1,29 @@ + '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', + ), + 'us-west-2' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'datapipeline.us-west-2.amazonaws.com', + ), + 'eu-west-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'datapipeline.eu-west-1.amazonaws.com', + ), + 'ap-southeast-2' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'datapipeline.ap-southeast-2.amazonaws.com', + ), + 'ap-northeast-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'datapipeline.ap-northeast-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, + ), + 'parameterValues' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'ParameterValue', + 'type' => 'object', + 'properties' => array( + 'id' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'stringValue' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 10240, + ), + ), + ), + ), + 'startTimestamp' => array( + 'type' => array( + 'object', + 'string', + 'integer', + ), + 'format' => 'date-time', + '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', + ), + ), + ), + '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' => 'DataPipeline.AddTags', + ), + 'pipelineId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 1024, + ), + 'tags' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'maxItems' => 10, + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'properties' => array( + 'key' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'value' => array( + 'required' => true, + 'type' => 'string', + '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', + ), + ), + ), + '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, + ), + 'tags' => array( + 'type' => 'array', + 'location' => 'json', + 'maxItems' => 10, + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'properties' => array( + 'key' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'value' => array( + 'required' => true, + 'type' => 'string', + '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', + ), + ), + ), + 'DeactivatePipeline' => 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.DeactivatePipeline', + ), + 'pipelineId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 1024, + ), + 'cancelActive' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + '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', + ), + ), + ), + '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, + ), + ), + ), + ), + ), + ), + ), + 'parameterObjects' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'ParameterObject', + 'type' => 'object', + 'properties' => array( + 'id' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'attributes' => array( + 'required' => true, + 'type' => 'array', + 'items' => array( + 'name' => 'ParameterAttribute', + 'type' => 'object', + 'properties' => array( + 'key' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'stringValue' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 10240, + ), + ), + ), + ), + ), + ), + ), + 'parameterValues' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'ParameterValue', + 'type' => 'object', + 'properties' => array( + 'id' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'stringValue' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 10240, + ), + ), + ), + ), + ), + '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', + ), + ), + ), + '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' => 'DataPipeline.RemoveTags', + ), + 'pipelineId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 1024, + ), + 'tagKeys' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'string', + '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 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', + ), + ), + ), + '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, + ), + 'fields' => array( + 'type' => 'array', + 'location' => 'json', + '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 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, + ), + ), + ), + ), + ), + ), + ), + 'parameterObjects' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'ParameterObject', + 'type' => 'object', + 'properties' => array( + 'id' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'attributes' => array( + 'required' => true, + 'type' => 'array', + 'items' => array( + 'name' => 'ParameterAttribute', + 'type' => 'object', + 'properties' => array( + 'key' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'stringValue' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 10240, + ), + ), + ), + ), + ), + ), + ), + 'parameterValues' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'ParameterValue', + 'type' => 'object', + 'properties' => array( + 'id' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'stringValue' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 10240, + ), + ), + ), + ), + ), + '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', + ), + 'tags' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'properties' => array( + 'key' => array( + 'type' => 'string', + ), + 'value' => 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', + ), + ), + ), + ), + ), + ), + ), + 'parameterObjects' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'ParameterObject', + 'type' => 'object', + 'properties' => array( + 'id' => array( + 'type' => 'string', + ), + 'attributes' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ParameterAttribute', + 'type' => 'object', + 'properties' => array( + 'key' => array( + 'type' => 'string', + ), + 'stringValue' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'parameterValues' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'ParameterValue', + 'type' => 'object', + 'properties' => array( + 'id' => array( + 'type' => 'string', + ), + 'stringValue' => 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', + ), + ), + ), + ), + 'iterators' => array( + 'ListPipelines' => array( + 'input_token' => 'marker', + 'output_token' => 'marker', + 'more_results' => 'hasMoreResults', + 'result_key' => 'pipelineIdList', + ), + 'DescribeObjects' => array( + 'input_token' => 'marker', + 'output_token' => 'marker', + 'more_results' => 'hasMoreResults', + 'result_key' => 'pipelineObjects', + ), + 'DescribePipelines' => array( + 'result_key' => 'pipelineDescriptionList', + ), + 'QueryObjects' => array( + 'input_token' => 'marker', + 'output_token' => 'marker', + 'more_results' => 'hasMoreResults', + 'limit_key' => 'limit', + 'result_key' => 'ids', + ), + ), +); diff --git a/vendor/aws/Aws/DirectConnect/DirectConnectClient.php b/vendor/aws/Aws/DirectConnect/DirectConnectClient.php new file mode 100644 index 0000000..fab45ce --- /dev/null +++ b/vendor/aws/Aws/DirectConnect/DirectConnectClient.php @@ -0,0 +1,82 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/directconnect-%s.php' + )) + ->setExceptionParser(new JsonQueryExceptionParser()) + ->build(); + } +} diff --git a/vendor/aws/Aws/DirectConnect/Enum/ConnectionState.php b/vendor/aws/Aws/DirectConnect/Enum/ConnectionState.php new file mode 100644 index 0000000..fdd48a4 --- /dev/null +++ b/vendor/aws/Aws/DirectConnect/Enum/ConnectionState.php @@ -0,0 +1,34 @@ + '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', + ), + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'iterators' => array( + 'DescribeConnections' => array( + 'result_key' => 'connections', + ), + 'DescribeConnectionsOnInterconnect' => array( + 'result_key' => 'connections', + ), + 'DescribeInterconnects' => array( + 'result_key' => 'interconnects', + ), + 'DescribeLocations' => array( + 'result_key' => 'locations', + ), + 'DescribeVirtualGateways' => array( + 'result_key' => 'virtualGateways', + ), + 'DescribeVirtualInterfaces' => array( + 'result_key' => 'virtualInterfaces', + ), + ), +); diff --git a/vendor/aws/Aws/DynamoDb/Crc32ErrorChecker.php b/vendor/aws/Aws/DynamoDb/Crc32ErrorChecker.php new file mode 100644 index 0000000..914eda2 --- /dev/null +++ b/vendor/aws/Aws/DynamoDb/Crc32ErrorChecker.php @@ -0,0 +1,66 @@ +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; + } + } + } +} diff --git a/vendor/aws/Aws/DynamoDb/DynamoDbClient.php b/vendor/aws/Aws/DynamoDb/DynamoDbClient.php new file mode 100644 index 0000000..0ad1bcb --- /dev/null +++ b/vendor/aws/Aws/DynamoDb/DynamoDbClient.php @@ -0,0 +1,196 @@ +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) + ->build(); + } + + /** + * Create an Amazon DynamoDB specific backoff plugin + * + * @param JsonQueryExceptionParser $exceptionParser + * + * @return BackoffPlugin + */ + private static function createBackoffPlugin(JsonQueryExceptionParser $exceptionParser) + { + return new BackoffPlugin( + // Retry requests (even if successful) if the CRC32 header is does not match the CRC32 of the response + new Crc32ErrorChecker( + // Retry failed requests up to 11 times instead of the normal 3 + new TruncatedBackoffStrategy(11, + // Retry failed requests with 400-level responses due to throttling + new ThrottlingErrorChecker($exceptionParser, + // Retry failed requests with 500-level responses + new HttpBackoffStrategy(null, + // Retry failed requests due to transient network or cURL problems + new CurlBackoffStrategy(null, + new ExpiredCredentialsChecker($exceptionParser, + // Use the custom retry delay method instead of default exponential backoff + new CallbackBackoffStrategy(__CLASS__ . '::calculateRetryDelay', false) + ) + ) + ) + ) + ) + ) + ); + } + + /** + * 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. + * @deprecated The new DynamoDB document model, including the new types + * (L, M, BOOL, NULL), is not supported by this method. + */ + 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. + * @deprecated The new DynamoDB document model, including the new types + * (L, M, BOOL, NULL), is not supported by this method. + */ + 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; + } +} diff --git a/vendor/aws/Aws/DynamoDb/DynamoDbCommand.php b/vendor/aws/Aws/DynamoDb/DynamoDbCommand.php new file mode 100644 index 0000000..f4ef75f --- /dev/null +++ b/vendor/aws/Aws/DynamoDb/DynamoDbCommand.php @@ -0,0 +1,100 @@ +result as $key => $value) { + $this->result[$key] = self::unmarshalAttributes($value); + } + } + } + + /** + * Recursively searches for N/NS/B/BS values within the given value and + * marshals them (e.g., base64_encode) into a DynamoDB compatible format. + * + * @param mixed $value + * + * @return mixed + */ + public static function marshalAttributes($value) + { + if (is_array($value)) { + array_walk($value, ($fn = function(&$v, $k) use (&$fn) { + if ($k === 'N' && (is_int($v) || is_float($v))) { + $v = strval($v); + } elseif ($k === 'NS' && is_array($v) && isset($v[0])) { + $v = array_map('strval', $v); + } elseif ($k === 'B' && is_string($v)) { + $v = base64_encode($v); + } elseif ($k === 'BS' && is_array($v) && isset($v[0])) { + $v = array_map('base64_encode', $v); + } elseif (is_array($v)) { + array_walk($v, $fn); + } + })); + } + + return $value; + } + + /** + * Recursively searches for B/BS values within the given value and + * decodes them into their original string format. + * + * @param mixed $value + * + * @return mixed + */ + public static function unmarshalAttributes($value) + { + if (is_array($value)) { + array_walk($value, ($fn = function(&$v, $k) use (&$fn) { + if ($k === 'B' && is_string($v)) { + $v = base64_decode($v); + } elseif ($k === 'BS' && is_array($v) && isset($v[0])) { + $v = array_map('base64_decode', $v); + } elseif (is_array($v)) { + array_walk($v, $fn); + } + })); + } + + return $value; + } +} diff --git a/vendor/aws/Aws/DynamoDb/Enum/AttributeAction.php b/vendor/aws/Aws/DynamoDb/Enum/AttributeAction.php new file mode 100644 index 0000000..a0f1d2f --- /dev/null +++ b/vendor/aws/Aws/DynamoDb/Enum/AttributeAction.php @@ -0,0 +1,29 @@ +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); + } +} diff --git a/vendor/aws/Aws/DynamoDb/Exception/UnrecognizedClientException.php b/vendor/aws/Aws/DynamoDb/Exception/UnrecognizedClientException.php new file mode 100644 index 0000000..04d9d93 --- /dev/null +++ b/vendor/aws/Aws/DynamoDb/Exception/UnrecognizedClientException.php @@ -0,0 +1,22 @@ +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; + } +} diff --git a/vendor/aws/Aws/DynamoDb/Iterator/ScanIterator.php b/vendor/aws/Aws/DynamoDb/Iterator/ScanIterator.php new file mode 100644 index 0000000..e227ad9 --- /dev/null +++ b/vendor/aws/Aws/DynamoDb/Iterator/ScanIterator.php @@ -0,0 +1,57 @@ +scannedCount; + } + + /** + * {@inheritdoc} + */ + protected function handleResults(Model $result) + { + $this->scannedCount += (int) $result->get('ScannedCount'); + + return parent::handleResults($result); + } +} diff --git a/vendor/aws/Aws/DynamoDb/Marshaler.php b/vendor/aws/Aws/DynamoDb/Marshaler.php new file mode 100644 index 0000000..a516aa3 --- /dev/null +++ b/vendor/aws/Aws/DynamoDb/Marshaler.php @@ -0,0 +1,173 @@ +marshalValue($data)); + } + + /** + * Marshal a native PHP array of data to a new array that is formatted in + * the proper parameter structure required by DynamoDB operations. + * + * @param array|\stdClass $item An associative array of data. + * + * @return array + */ + public function marshalItem($item) + { + return current($this->marshalValue($item)); + } + + /** + * Marshal a native PHP value into an array that is formatted in the proper + * parameter structure required by DynamoDB operations. + * + * @param mixed $value A scalar, array, or stdClass value. + * + * @return array Formatted like `array(TYPE => VALUE)`. + * @throws \UnexpectedValueException if the value cannot be marshaled. + */ + public function marshalValue($value) + { + $type = gettype($value); + if ($type === 'string' && $value !== '') { + $type = 'S'; + } elseif ($type === 'integer' || $type === 'double') { + $type = 'N'; + $value = (string) $value; + } elseif ($type === 'boolean') { + $type = 'BOOL'; + } elseif ($type === 'NULL') { + $type = 'NULL'; + $value = true; + } elseif ($type === 'array' + || $value instanceof \Traversable + || $value instanceof \stdClass + ) { + $type = $value instanceof \stdClass ? 'M' : 'L'; + $data = array(); + $expectedIndex = -1; + foreach ($value as $k => $v) { + $data[$k] = $this->marshalValue($v); + if ($type === 'L' && (!is_int($k) || $k != ++$expectedIndex)) { + $type = 'M'; + } + } + $value = $data; + } else { + $type = $type === 'object' ? get_class($value) : $type; + throw new \UnexpectedValueException('Marshaling error: ' . ($value + ? "encountered unexpected type \"{$type}\"." + : 'encountered empty value.' + )); + } + + return array($type => $value); + } + + /** + * Unmarshal a document (item) from a DynamoDB operation result into a JSON + * document string. + * + * @param array $data Item/document from a DynamoDB result. + * @param int $jsonEncodeFlags Flags to use with `json_encode()`. + * + * @return string + */ + public function unmarshalJson(array $data, $jsonEncodeFlags = 0) + { + return json_encode( + $this->unmarshalValue(array('M' => $data), true), + $jsonEncodeFlags + ); + } + + /** + * Unmarshal an item from a DynamoDB operation result into a native PHP + * array. If you set $mapAsObject to true, then a stdClass value will be + * returned instead. + * + * @param array $data Item from a DynamoDB result. + * + * @return array|\stdClass + */ + public function unmarshalItem(array $data) + { + return $this->unmarshalValue(array('M' => $data)); + } + + /** + * Unmarshal a value from a DynamoDB operation result into a native PHP + * value. Will return a scalar, array, or (if you set $mapAsObject to true) + * stdClass value. + * + * @param array $value Value from a DynamoDB result. + * @param bool $mapAsObject Whether maps should be represented as stdClass. + * + * @return mixed + * @throws \UnexpectedValueException + */ + public function unmarshalValue(array $value, $mapAsObject = false) + { + list($type, $value) = each($value); + switch ($type) { + case 'S': + case 'SS': + case 'B': + case 'BS': + case 'BOOL': + return $value; + case 'NULL': + return null; + case 'N': + // Use type coercion to unmarshal numbers to int/float. + return $value + 0; + case 'NS': + foreach ($value as &$v) { + $v += 0; + } + return $value; + case 'M': + if ($mapAsObject) { + $data = new \stdClass; + foreach ($value as $k => $v) { + $data->$k = $this->unmarshalValue($v, $mapAsObject); + } + return $data; + } + // Else, unmarshal M the same way as L. + case 'L': + foreach ($value as &$v) { + $v = $this->unmarshalValue($v, $mapAsObject); + } + return $value; + } + + throw new \UnexpectedValueException("Unexpected type: {$type}."); + } +} diff --git a/vendor/aws/Aws/DynamoDb/Model/Attribute.php b/vendor/aws/Aws/DynamoDb/Model/Attribute.php new file mode 100644 index 0000000..14a403e --- /dev/null +++ b/vendor/aws/Aws/DynamoDb/Model/Attribute.php @@ -0,0 +1,248 @@ + 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(); + } +} diff --git a/vendor/aws/Aws/DynamoDb/Model/BatchRequest/AbstractWriteRequest.php b/vendor/aws/Aws/DynamoDb/Model/BatchRequest/AbstractWriteRequest.php new file mode 100644 index 0000000..3589816 --- /dev/null +++ b/vendor/aws/Aws/DynamoDb/Model/BatchRequest/AbstractWriteRequest.php @@ -0,0 +1,36 @@ +tableName; + } +} diff --git a/vendor/aws/Aws/DynamoDb/Model/BatchRequest/DeleteRequest.php b/vendor/aws/Aws/DynamoDb/Model/BatchRequest/DeleteRequest.php new file mode 100644 index 0000000..f01cedc --- /dev/null +++ b/vendor/aws/Aws/DynamoDb/Model/BatchRequest/DeleteRequest.php @@ -0,0 +1,94 @@ +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; + } +} diff --git a/vendor/aws/Aws/DynamoDb/Model/BatchRequest/PutRequest.php b/vendor/aws/Aws/DynamoDb/Model/BatchRequest/PutRequest.php new file mode 100644 index 0000000..adbd345 --- /dev/null +++ b/vendor/aws/Aws/DynamoDb/Model/BatchRequest/PutRequest.php @@ -0,0 +1,100 @@ +getName() !== 'PutItem') { + throw new InvalidArgumentException(); + } + + // Get relevant data for a PutRequest + $table = $command->get('TableName'); + $item = $command->get('Item'); + + // Return an instantiated PutRequest object + return new PutRequest($item, $table); + } + + /** + * Constructs a new put request + * + * @param array|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, $tableName = null) + { + if ($item instanceof Item) { + $this->item = $item->toArray(); + $this->tableName = $tableName ?: $item->getTableName(); + } elseif (is_array($item)) { + $this->item = $item; + $this->tableName = $tableName; + } else { + throw new InvalidArgumentException('The item must be an array or an Item object.'); + } + + 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)); + } + + /** + * Get the item + * + * @return Item + */ + public function getItem() + { + return new Item($this->item); + } +} diff --git a/vendor/aws/Aws/DynamoDb/Model/BatchRequest/UnprocessedRequest.php b/vendor/aws/Aws/DynamoDb/Model/BatchRequest/UnprocessedRequest.php new file mode 100644 index 0000000..4519630 --- /dev/null +++ b/vendor/aws/Aws/DynamoDb/Model/BatchRequest/UnprocessedRequest.php @@ -0,0 +1,48 @@ +data = $data; + $this->tableName = $tableName; + } + + /** + * The parameter form of the request + * + * @return array + */ + public function toArray() + { + return $this->data; + } +} diff --git a/vendor/aws/Aws/DynamoDb/Model/BatchRequest/WriteRequestBatch.php b/vendor/aws/Aws/DynamoDb/Model/BatchRequest/WriteRequestBatch.php new file mode 100644 index 0000000..859e49a --- /dev/null +++ b/vendor/aws/Aws/DynamoDb/Model/BatchRequest/WriteRequestBatch.php @@ -0,0 +1,120 @@ +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 you 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; + } +} diff --git a/vendor/aws/Aws/DynamoDb/Model/BatchRequest/WriteRequestBatchTransfer.php b/vendor/aws/Aws/DynamoDb/Model/BatchRequest/WriteRequestBatchTransfer.php new file mode 100644 index 0000000..2be496d --- /dev/null +++ b/vendor/aws/Aws/DynamoDb/Model/BatchRequest/WriteRequestBatchTransfer.php @@ -0,0 +1,252 @@ +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; + } + + // Prepare an array of commands to be sent in parallel from the batch + $commands = $this->prepareCommandsForBatchedItems($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) { + $request = $e->getRequest(); + if ($e->getStatusCode() === 413) { + $this->retryLargeRequest($request, $unprocessedRequests); + } elseif ($e->getExceptionCode() === 'ProvisionedThroughputExceededException') { + $this->handleUnprocessedRequestsAfterException($request, $unprocessedRequests); + } else { + $unhandledExceptions->add($e); + } + } else { + $unhandledExceptions->add($e); + } + } + + // If there were unhandled exceptions, throw them + if (count($unhandledExceptions)) { + throw $unhandledExceptions; + } + } + } + + /** + * Prepares an array of BatchWriteItem command objects for a given batch of items + * + * @param array $batch A batch of write requests + * + * @return array + */ + protected function prepareCommandsForBatchedItems(array $batch) + { + $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 + )); + } + + return $commands; + } + + /** + * 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 = $this->extractItemsFromRequestObject($request); + + // 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); + } + } + } + + /** + * Handles unprocessed items if the entire batch was rejected due to exceeding the provisioned throughput + * + * @param EntityEnclosingRequestInterface $request The failed request + * @param UnprocessedWriteRequestsException $unprocessedRequests Collection of unprocessed items + */ + protected function handleUnprocessedRequestsAfterException( + EntityEnclosingRequestInterface $request, + UnprocessedWriteRequestsException $unprocessedRequests + ) { + $items = $this->extractItemsFromRequestObject($request); + foreach ($items as $request) { + $unprocessedRequests->addItem($request); + } + } + + /** + * 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; + } + + + /** + * Helper method to extract the items from a request object for a BatchWriteItem operation + * + * @param EntityEnclosingRequestInterface $request + * + * @return array + */ + private function extractItemsFromRequestObject(EntityEnclosingRequestInterface $request) + { + $items = json_decode((string) $request->getBody(), true); + return $this->convertResultsToUnprocessedRequests($items['RequestItems'] ?: array()); + } +} diff --git a/vendor/aws/Aws/DynamoDb/Model/BatchRequest/WriteRequestInterface.php b/vendor/aws/Aws/DynamoDb/Model/BatchRequest/WriteRequestInterface.php new file mode 100644 index 0000000..70503e2 --- /dev/null +++ b/vendor/aws/Aws/DynamoDb/Model/BatchRequest/WriteRequestInterface.php @@ -0,0 +1,32 @@ +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]); + } +} diff --git a/vendor/aws/Aws/DynamoDb/Resources/dynamodb-2011-12-05.php b/vendor/aws/Aws/DynamoDb/Resources/dynamodb-2011-12-05.php new file mode 100644 index 0000000..1c1d216 --- /dev/null +++ b/vendor/aws/Aws/DynamoDb/Resources/dynamodb-2011-12-05.php @@ -0,0 +1,3546 @@ + '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', + ), + ), + ), + ), + ), + ), + 'iterators' => array( + 'BatchGetItem' => array( + 'input_token' => 'RequestItems', + 'output_token' => 'UnprocessedKeys', + 'result_key' => 'Responses/*', + ), + 'ListTables' => array( + 'input_token' => 'ExclusiveStartTableName', + 'output_token' => 'LastEvaluatedTableName', + 'result_key' => 'TableNames', + ), + 'Query' => array( + 'input_token' => 'ExclusiveStartKey', + 'output_token' => 'LastEvaluatedKey', + 'result_key' => 'Items', + ), + 'Scan' => array( + 'input_token' => 'ExclusiveStartKey', + 'output_token' => 'LastEvaluatedKey', + 'result_key' => 'Items', + ), + ), + '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', + ), + ), +); diff --git a/vendor/aws/Aws/DynamoDb/Resources/dynamodb-2012-08-10.php b/vendor/aws/Aws/DynamoDb/Resources/dynamodb-2012-08-10.php new file mode 100644 index 0000000..d57752f --- /dev/null +++ b/vendor/aws/Aws/DynamoDb/Resources/dynamodb-2012-08-10.php @@ -0,0 +1,499 @@ + '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\\DynamoDb\\DynamoDbCommand', + 'responseClass' => 'JsonOutput', + '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', + ), + ), + 'additionalParameters' => array( + 'location' => 'json', + 'filters' => array( + 'Aws\DynamoDb\DynamoDbCommand::marshalAttributes', + ), + ), + ), + 'BatchWriteItem' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\DynamoDb\\DynamoDbCommand', + 'responseClass' => 'JsonOutput', + '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', + ), + ), + 'additionalParameters' => array( + 'location' => 'json', + 'filters' => array( + 'Aws\DynamoDb\DynamoDbCommand::marshalAttributes', + ), + ), + ), + 'CreateTable' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\DynamoDb\\DynamoDbCommand', + 'responseClass' => 'JsonOutput', + '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', + ), + ), + 'additionalParameters' => array( + 'location' => 'json', + ), + ), + 'DeleteItem' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\DynamoDb\\DynamoDbCommand', + 'responseClass' => 'JsonOutput', + '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', + ), + ), + 'additionalParameters' => array( + 'location' => 'json', + 'filters' => array( + 'Aws\DynamoDb\DynamoDbCommand::marshalAttributes', + ), + ), + ), + 'DeleteTable' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\DynamoDb\\DynamoDbCommand', + 'responseClass' => 'JsonOutput', + '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', + ), + ), + 'additionalParameters' => array( + 'location' => 'json', + ), + ), + 'DescribeTable' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\DynamoDb\\DynamoDbCommand', + 'responseClass' => 'JsonOutput', + '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', + ), + ), + 'additionalParameters' => array( + 'location' => 'json', + ), + ), + 'GetItem' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\DynamoDb\\DynamoDbCommand', + 'responseClass' => 'JsonOutput', + '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', + ), + ), + 'additionalParameters' => array( + 'location' => 'json', + 'filters' => array( + 'Aws\DynamoDb\DynamoDbCommand::marshalAttributes', + ), + ), + ), + 'ListTables' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\DynamoDb\\DynamoDbCommand', + 'responseClass' => 'JsonOutput', + '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', + ), + ), + 'additionalParameters' => array( + 'location' => 'json', + ), + ), + 'PutItem' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\DynamoDb\\DynamoDbCommand', + 'responseClass' => 'JsonOutput', + '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', + ), + ), + 'additionalParameters' => array( + 'location' => 'json', + 'filters' => array( + 'Aws\DynamoDb\DynamoDbCommand::marshalAttributes', + ), + ), + ), + 'Query' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\DynamoDb\\DynamoDbCommand', + 'responseClass' => 'JsonOutput', + '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', + ), + ), + 'additionalParameters' => array( + 'location' => 'json', + 'filters' => array( + 'Aws\DynamoDb\DynamoDbCommand::marshalAttributes', + ), + ), + ), + 'Scan' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\DynamoDb\\DynamoDbCommand', + 'responseClass' => 'JsonOutput', + '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', + ), + ), + 'additionalParameters' => array( + 'location' => 'json', + 'filters' => array( + 'Aws\DynamoDb\DynamoDbCommand::marshalAttributes', + ), + ), + ), + 'UpdateItem' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\DynamoDb\\DynamoDbCommand', + 'responseClass' => 'JsonOutput', + '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', + ), + ), + 'additionalParameters' => array( + 'location' => 'json', + 'filters' => array( + 'Aws\DynamoDb\DynamoDbCommand::marshalAttributes', + ), + ), + ), + 'UpdateTable' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\DynamoDb\\DynamoDbCommand', + 'responseClass' => 'JsonOutput', + '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', + ), + ), + 'additionalParameters' => array( + 'location' => 'json', + ), + ), + ), + 'models' => array( + 'JsonOutput' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'location' => 'json', + ) + ), + ), + 'iterators' => array( + 'BatchGetItem' => array( + 'input_token' => 'RequestItems', + 'output_token' => 'UnprocessedKeys', + 'result_key' => 'Responses/*', + ), + 'ListTables' => array( + 'input_token' => 'ExclusiveStartTableName', + 'output_token' => 'LastEvaluatedTableName', + 'limit_key' => 'Limit', + 'result_key' => 'TableNames', + ), + 'Query' => array( + 'input_token' => 'ExclusiveStartKey', + 'output_token' => 'LastEvaluatedKey', + 'limit_key' => 'Limit', + 'result_key' => 'Items', + ), + 'Scan' => array( + 'input_token' => 'ExclusiveStartKey', + 'output_token' => 'LastEvaluatedKey', + 'limit_key' => 'Limit', + 'result_key' => 'Items', + ), + ), + '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', + ), + ), +); diff --git a/vendor/aws/Aws/DynamoDb/Session/LockingStrategy/AbstractLockingStrategy.php b/vendor/aws/Aws/DynamoDb/Session/LockingStrategy/AbstractLockingStrategy.php new file mode 100644 index 0000000..7db4ade --- /dev/null +++ b/vendor/aws/Aws/DynamoDb/Session/LockingStrategy/AbstractLockingStrategy.php @@ -0,0 +1,129 @@ +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(); +} diff --git a/vendor/aws/Aws/DynamoDb/Session/LockingStrategy/LockingStrategyFactory.php b/vendor/aws/Aws/DynamoDb/Session/LockingStrategy/LockingStrategyFactory.php new file mode 100644 index 0000000..5d0093b --- /dev/null +++ b/vendor/aws/Aws/DynamoDb/Session/LockingStrategy/LockingStrategyFactory.php @@ -0,0 +1,85 @@ +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); + } +} diff --git a/vendor/aws/Aws/DynamoDb/Session/LockingStrategy/LockingStrategyFactoryInterface.php b/vendor/aws/Aws/DynamoDb/Session/LockingStrategy/LockingStrategyFactoryInterface.php new file mode 100644 index 0000000..0834ee3 --- /dev/null +++ b/vendor/aws/Aws/DynamoDb/Session/LockingStrategy/LockingStrategyFactoryInterface.php @@ -0,0 +1,36 @@ +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 + } +} diff --git a/vendor/aws/Aws/DynamoDb/Session/LockingStrategy/PessimisticLockingStrategy.php b/vendor/aws/Aws/DynamoDb/Session/LockingStrategy/PessimisticLockingStrategy.php new file mode 100644 index 0000000..e7c3895 --- /dev/null +++ b/vendor/aws/Aws/DynamoDb/Session/LockingStrategy/PessimisticLockingStrategy.php @@ -0,0 +1,118 @@ +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 + } +} diff --git a/vendor/aws/Aws/DynamoDb/Session/SessionHandler.php b/vendor/aws/Aws/DynamoDb/Session/SessionHandler.php new file mode 100644 index 0000000..da0cc8e --- /dev/null +++ b/vendor/aws/Aws/DynamoDb/Session/SessionHandler.php @@ -0,0 +1,460 @@ +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, '_'); + } +} diff --git a/vendor/aws/Aws/DynamoDb/Session/SessionHandlerConfig.php b/vendor/aws/Aws/DynamoDb/Session/SessionHandlerConfig.php new file mode 100644 index 0000000..e27288f --- /dev/null +++ b/vendor/aws/Aws/DynamoDb/Session/SessionHandlerConfig.php @@ -0,0 +1,86 @@ +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; + } +} diff --git a/vendor/aws/Aws/DynamoDb/Session/SessionHandlerInterface.php b/vendor/aws/Aws/DynamoDb/Session/SessionHandlerInterface.php new file mode 100644 index 0000000..7710fd0 --- /dev/null +++ b/vendor/aws/Aws/DynamoDb/Session/SessionHandlerInterface.php @@ -0,0 +1,20 @@ += 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); + } +} diff --git a/vendor/aws/Aws/Ec2/CopySnapshotListener.php b/vendor/aws/Aws/Ec2/CopySnapshotListener.php new file mode 100644 index 0000000..440904a --- /dev/null +++ b/vendor/aws/Aws/Ec2/CopySnapshotListener.php @@ -0,0 +1,83 @@ + 'onCommandBeforePrepare'); + } + + public function onCommandBeforePrepare(Event $event) + { + /** @var $command \Guzzle\Service\Command\CommandInterface */ + $command = $event['command']; + + if ($command->getName() !== 'CopySnapshot') { + return; + } elseif ($command['__internal']) { + // Prevent infinite recursion when adding the presigned URL + unset($command['__internal']); + return; + } + + /** @var $client \Aws\Common\Client\AwsClientInterface */ + $client = $command->getClient(); + $presignedUrl = $this->createPresignedUrl($client, $command); + $command['DestinationRegion'] = $client->getRegion(); + $command['PresignedUrl'] = $presignedUrl; + } + + private function createPresignedUrl( + AwsClientInterface $client, + CommandInterface $command + ) { + // Create a temporary client used to generate the presigned URL + $newClient = Ec2Client::factory(array( + 'region' => $command['SourceRegion'], + 'signature' => 'v4', + 'key' => $client->getCredentials()->getAccessKeyId(), + 'secret' => $client->getCredentials()->getSecretKey() + )); + + $preCommand = $newClient->getCommand( + 'CopySnapshot', + $command->toArray() + ); + + $preCommand['__internal'] = true; + /** @var \Guzzle\Http\Message\EntityEnclosingRequest $preRequest */ + $preRequest = $preCommand->prepare(); + + return $newClient->getSignature()->createPresignedUrl( + SignatureV4::convertPostToGet($preRequest), + $newClient->getCredentials(), + '+1 hour' + ); + } +} diff --git a/vendor/aws/Aws/Ec2/Ec2Client.php b/vendor/aws/Aws/Ec2/Ec2Client.php new file mode 100644 index 0000000..61b9c81 --- /dev/null +++ b/vendor/aws/Aws/Ec2/Ec2Client.php @@ -0,0 +1,269 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/ec2-%s.php' + )) + ->build(); + + $client->addSubscriber(new CopySnapshotListener()); + + return $client; + } +} diff --git a/vendor/aws/Aws/Ec2/Enum/ContainerFormat.php b/vendor/aws/Aws/Ec2/Enum/ContainerFormat.php new file mode 100644 index 0000000..422be1f --- /dev/null +++ b/vendor/aws/Aws/Ec2/Enum/ContainerFormat.php @@ -0,0 +1,27 @@ +get('Reservations') as $reservation) { + foreach ($reservation['Instances'] as $instance) { + $instance['Reservation'] = $reservation; + unset($instance['Reservation']['Instances']); + $instances[] = $instance; + } + } + + return $instances; + } +} diff --git a/vendor/aws/Aws/Ec2/Resources/ec2-2014-06-15.php b/vendor/aws/Aws/Ec2/Resources/ec2-2014-06-15.php new file mode 100644 index 0000000..036ae56 --- /dev/null +++ b/vendor/aws/Aws/Ec2/Resources/ec2-2014-06-15.php @@ -0,0 +1,15844 @@ + '2014-06-15', + 'endpointPrefix' => 'ec2', + 'serviceFullName' => 'Amazon Elastic Compute Cloud', + 'serviceAbbreviation' => 'Amazon EC2', + 'serviceType' => 'query', + 'signatureVersion' => 'v4', + '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( + 'AcceptVpcPeeringConnection' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'AcceptVpcPeeringConnectionResult', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'AcceptVpcPeeringConnection', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-06-15', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'VpcPeeringConnectionId' => array( + 'type' => 'string', + '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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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', + ), + 'DestinationRegion' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'PresignedUrl' => 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' => '2014-06-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' => '2014-06-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' => '2014-06-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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + '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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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', + ), + 'VpcPeeringConnectionId' => 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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + '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' => '2014-06-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', + ), + ), + ), + 'CreateVpcPeeringConnection' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'CreateVpcPeeringConnectionResult', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateVpcPeeringConnection', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-06-15', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'VpcId' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'PeerVpcId' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'PeerOwnerId' => 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' => '2014-06-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' => '2014-06-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' => '2014-06-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', + ), + ), + ), + '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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-15', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'VpcId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + ), + 'DeleteVpcPeeringConnection' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DeleteVpcPeeringConnectionResult', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteVpcPeeringConnection', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-06-15', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'VpcPeeringConnectionId' => 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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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', + ), + ), + ), + ), + ), + ), + ), + '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' => '2014-06-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' => '2014-06-15', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'NetworkInterfaceId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Attribute' => 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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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', + ), + ), + ), + 'DescribeVpcPeeringConnections' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DescribeVpcPeeringConnectionsResult', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeVpcPeeringConnections', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-06-15', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'VpcPeeringConnectionIds' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'VpcPeeringConnectionId', + 'items' => array( + 'name' => 'VpcPeeringConnectionId', + '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', + ), + ), + ), + ), + ), + ), + ), + '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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-15', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'AvailabilityZone' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Image' => array( + 'required' => true, + '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( + 'required' => true, + '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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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', + ), + ), + ), + ), + ), + ), + ), + ), + 'ModifySubnetAttribute' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ModifySubnetAttribute', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-06-15', + ), + 'SubnetId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MapPublicIpOnLaunch' => array( + 'type' => 'object', + 'location' => 'aws.query', + 'properties' => array( + 'Value' => array( + 'type' => 'boolean', + 'format' => 'boolean-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' => '2014-06-15', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'VolumeId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'AutoEnableIO' => array( + 'type' => 'object', + 'location' => 'aws.query', + 'properties' => array( + 'Value' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + ), + ), + '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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-15', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'ImageLocation' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Name' => array( + 'required' => true, + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + 'NoDevice' => array( + 'type' => 'string', + ), + ), + ), + ), + 'VirtualizationType' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SriovNetSupport' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + ), + 'RejectVpcPeeringConnection' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'RejectVpcPeeringConnectionResult', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'RejectVpcPeeringConnection', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-06-15', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'VpcPeeringConnectionId' => array( + 'required' => true, + '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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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', + ), + 'VpcPeeringConnectionId' => 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' => '2014-06-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' => '2014-06-15', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'Instances' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'InstanceId', + 'items' => array( + 'name' => 'InstanceId', + 'type' => 'string', + ), + ), + 'Status' => array( + 'required' => true, + '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( + 'required' => true, + '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' => '2014-06-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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + '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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + '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', + ), + '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', + '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', + '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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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' => '2014-06-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( + 'AcceptVpcPeeringConnectionResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'VpcPeeringConnection' => array( + 'type' => 'object', + 'location' => 'xml', + 'sentAs' => 'vpcPeeringConnection', + 'properties' => array( + 'AccepterVpcInfo' => array( + 'type' => 'object', + 'sentAs' => 'accepterVpcInfo', + 'properties' => array( + 'CidrBlock' => array( + 'type' => 'string', + 'sentAs' => 'cidrBlock', + ), + 'OwnerId' => array( + 'type' => 'string', + 'sentAs' => 'ownerId', + ), + 'VpcId' => array( + 'type' => 'string', + 'sentAs' => 'vpcId', + ), + ), + ), + 'ExpirationTime' => array( + 'type' => 'string', + 'sentAs' => 'expirationTime', + ), + 'RequesterVpcInfo' => array( + 'type' => 'object', + 'sentAs' => 'requesterVpcInfo', + 'properties' => array( + 'CidrBlock' => array( + 'type' => 'string', + 'sentAs' => 'cidrBlock', + ), + 'OwnerId' => array( + 'type' => 'string', + 'sentAs' => 'ownerId', + ), + 'VpcId' => array( + 'type' => 'string', + 'sentAs' => 'vpcId', + ), + ), + ), + 'Status' => array( + 'type' => 'object', + 'sentAs' => 'status', + 'properties' => array( + 'Code' => array( + 'type' => 'string', + 'sentAs' => 'code', + ), + 'Message' => array( + 'type' => 'string', + 'sentAs' => 'message', + ), + ), + ), + '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', + ), + ), + ), + ), + 'VpcPeeringConnectionId' => array( + 'type' => 'string', + 'sentAs' => 'vpcPeeringConnectionId', + ), + ), + ), + ), + ), + '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', + ), + ), + ), + 'EmptyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + ), + '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', + ), + 'PublicDnsName' => array( + 'type' => 'string', + 'sentAs' => 'publicDnsName', + ), + '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', + ), + 'PublicDnsName' => array( + 'type' => 'string', + 'sentAs' => 'publicDnsName', + ), + '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', + ), + 'VpcPeeringConnectionId' => array( + 'type' => 'string', + 'sentAs' => 'vpcPeeringConnectionId', + ), + 'State' => array( + 'type' => 'string', + 'sentAs' => 'state', + ), + 'Origin' => array( + 'type' => 'string', + 'sentAs' => 'origin', + ), + ), + ), + ), + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'location' => 'xml', + 'sentAs' => 'encrypted', + ), + ), + ), + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'location' => 'xml', + 'sentAs' => 'encrypted', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + 'CreateVpcPeeringConnectionResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'VpcPeeringConnection' => array( + 'type' => 'object', + 'location' => 'xml', + 'sentAs' => 'vpcPeeringConnection', + 'properties' => array( + 'AccepterVpcInfo' => array( + 'type' => 'object', + 'sentAs' => 'accepterVpcInfo', + 'properties' => array( + 'CidrBlock' => array( + 'type' => 'string', + 'sentAs' => 'cidrBlock', + ), + 'OwnerId' => array( + 'type' => 'string', + 'sentAs' => 'ownerId', + ), + 'VpcId' => array( + 'type' => 'string', + 'sentAs' => 'vpcId', + ), + ), + ), + 'ExpirationTime' => array( + 'type' => 'string', + 'sentAs' => 'expirationTime', + ), + 'RequesterVpcInfo' => array( + 'type' => 'object', + 'sentAs' => 'requesterVpcInfo', + 'properties' => array( + 'CidrBlock' => array( + 'type' => 'string', + 'sentAs' => 'cidrBlock', + ), + 'OwnerId' => array( + 'type' => 'string', + 'sentAs' => 'ownerId', + ), + 'VpcId' => array( + 'type' => 'string', + 'sentAs' => 'vpcId', + ), + ), + ), + 'Status' => array( + 'type' => 'object', + 'sentAs' => 'status', + 'properties' => array( + 'Code' => array( + 'type' => 'string', + 'sentAs' => 'code', + ), + 'Message' => array( + 'type' => 'string', + 'sentAs' => 'message', + ), + ), + ), + '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', + ), + ), + ), + ), + 'VpcPeeringConnectionId' => array( + 'type' => 'string', + 'sentAs' => 'vpcPeeringConnectionId', + ), + ), + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + ), + ), + 'DeleteVpcPeeringConnectionResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Return' => array( + 'type' => 'boolean', + 'location' => 'xml', + 'sentAs' => 'return', + ), + ), + ), + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'sentAs' => 'encrypted', + ), + ), + ), + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'sentAs' => 'encrypted', + ), + ), + ), + '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', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + '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', + ), + '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', + ), + ), + ), + ), + ), + ), + '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', + ), + 'PublicDnsName' => array( + 'type' => 'string', + 'sentAs' => 'publicDnsName', + ), + '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', + ), + 'PublicDnsName' => array( + 'type' => 'string', + 'sentAs' => 'publicDnsName', + ), + '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', + ), + 'VpcPeeringConnectionId' => array( + 'type' => 'string', + 'sentAs' => 'vpcPeeringConnectionId', + ), + 'State' => array( + 'type' => 'string', + 'sentAs' => 'state', + ), + 'Origin' => array( + 'type' => 'string', + 'sentAs' => 'origin', + ), + ), + ), + ), + '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', + ), + ), + ), + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'sentAs' => 'encrypted', + ), + ), + ), + ), + ), + ), + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'sentAs' => 'encrypted', + ), + ), + ), + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'sentAs' => 'encrypted', + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + ), + ), + 'DescribeVpcPeeringConnectionsResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'VpcPeeringConnections' => array( + 'type' => 'array', + 'location' => 'xml', + 'sentAs' => 'vpcPeeringConnectionSet', + 'items' => array( + 'name' => 'item', + 'type' => 'object', + 'sentAs' => 'item', + 'properties' => array( + 'AccepterVpcInfo' => array( + 'type' => 'object', + 'sentAs' => 'accepterVpcInfo', + 'properties' => array( + 'CidrBlock' => array( + 'type' => 'string', + 'sentAs' => 'cidrBlock', + ), + 'OwnerId' => array( + 'type' => 'string', + 'sentAs' => 'ownerId', + ), + 'VpcId' => array( + 'type' => 'string', + 'sentAs' => 'vpcId', + ), + ), + ), + 'ExpirationTime' => array( + 'type' => 'string', + 'sentAs' => 'expirationTime', + ), + 'RequesterVpcInfo' => array( + 'type' => 'object', + 'sentAs' => 'requesterVpcInfo', + 'properties' => array( + 'CidrBlock' => array( + 'type' => 'string', + 'sentAs' => 'cidrBlock', + ), + 'OwnerId' => array( + 'type' => 'string', + 'sentAs' => 'ownerId', + ), + 'VpcId' => array( + 'type' => 'string', + 'sentAs' => 'vpcId', + ), + ), + ), + 'Status' => array( + 'type' => 'object', + 'sentAs' => 'status', + 'properties' => array( + 'Code' => array( + 'type' => 'string', + 'sentAs' => 'code', + ), + 'Message' => array( + 'type' => 'string', + 'sentAs' => 'message', + ), + ), + ), + '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', + ), + ), + ), + ), + 'VpcPeeringConnectionId' => array( + 'type' => 'string', + 'sentAs' => 'vpcPeeringConnectionId', + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + 'RejectVpcPeeringConnectionResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Return' => array( + 'type' => 'boolean', + 'location' => 'xml', + 'sentAs' => 'return', + ), + ), + ), + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'sentAs' => 'encrypted', + ), + ), + ), + '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', + ), + '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( + '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( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'limit_key' => 'MaxResults', + 'result_key' => 'InstanceStatuses', + ), + 'DescribeInstances' => array( + 'result_key' => 'Reservations', + ), + 'DescribeInternetGateways' => array( + 'result_key' => 'InternetGateways', + ), + 'DescribeKeyPairs' => array( + 'result_key' => 'KeyPairs', + ), + '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', + ), + 'DescribeReservedInstancesOfferings' => array( + 'input_token' => 'NextToken', + 'output_token' => '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( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'limit_key' => 'MaxResults', + 'result_key' => 'SpotPriceHistory', + ), + 'DescribeSubnets' => array( + 'result_key' => 'Subnets', + ), + 'DescribeTags' => array( + 'result_key' => 'Tags', + ), + 'DescribeVolumeStatus' => array( + 'input_token' => 'NextToken', + 'output_token' => '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', + ), + ), +); diff --git a/vendor/aws/Aws/Ec2/Resources/ec2-2014-09-01.php b/vendor/aws/Aws/Ec2/Resources/ec2-2014-09-01.php new file mode 100644 index 0000000..62360e4 --- /dev/null +++ b/vendor/aws/Aws/Ec2/Resources/ec2-2014-09-01.php @@ -0,0 +1,15873 @@ + '2014-09-01', + 'endpointPrefix' => 'ec2', + 'serviceFullName' => 'Amazon Elastic Compute Cloud', + 'serviceAbbreviation' => 'Amazon EC2', + 'serviceType' => 'query', + 'signatureVersion' => 'v4', + '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( + 'AcceptVpcPeeringConnection' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'AcceptVpcPeeringConnectionResult', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'AcceptVpcPeeringConnection', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-09-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'VpcPeeringConnectionId' => array( + 'type' => 'string', + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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', + ), + 'DestinationRegion' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'PresignedUrl' => 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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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', + ), + 'VpcPeeringConnectionId' => 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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + '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' => '2014-09-01', + ), + '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', + ), + ), + ), + 'CreateVpcPeeringConnection' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'CreateVpcPeeringConnectionResult', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateVpcPeeringConnection', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-09-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'VpcId' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'PeerVpcId' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'PeerOwnerId' => 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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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', + ), + ), + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'VpcId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + ), + 'DeleteVpcPeeringConnection' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DeleteVpcPeeringConnectionResult', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteVpcPeeringConnection', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-09-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'VpcPeeringConnectionId' => 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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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', + ), + ), + ), + ), + ), + ), + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'NetworkInterfaceId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Attribute' => 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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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', + ), + ), + ), + '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' => '2014-09-01', + ), + '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', + ), + ), + ), + 'DescribeVpcPeeringConnections' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DescribeVpcPeeringConnectionsResult', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeVpcPeeringConnections', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-09-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'VpcPeeringConnectionIds' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'VpcPeeringConnectionId', + 'items' => array( + 'name' => 'VpcPeeringConnectionId', + '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', + ), + ), + ), + ), + ), + ), + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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', + ), + ), + 'GroupIds' => array( + 'type' => 'array', + 'sentAs' => 'GroupId', + 'items' => array( + 'name' => 'GroupId', + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'AvailabilityZone' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Image' => array( + 'required' => true, + '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( + 'required' => true, + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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', + ), + ), + ), + ), + ), + ), + ), + ), + 'ModifySubnetAttribute' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ModifySubnetAttribute', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-09-01', + ), + 'SubnetId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MapPublicIpOnLaunch' => array( + 'type' => 'object', + 'location' => 'aws.query', + 'properties' => array( + 'Value' => array( + 'type' => 'boolean', + 'format' => 'boolean-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' => '2014-09-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'VolumeId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'AutoEnableIO' => array( + 'type' => 'object', + 'location' => 'aws.query', + 'properties' => array( + 'Value' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + ), + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'ImageLocation' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Name' => array( + 'required' => true, + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + 'NoDevice' => array( + 'type' => 'string', + ), + ), + ), + ), + 'VirtualizationType' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SriovNetSupport' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + ), + 'RejectVpcPeeringConnection' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'RejectVpcPeeringConnectionResult', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'RejectVpcPeeringConnection', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-09-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'VpcPeeringConnectionId' => array( + 'required' => true, + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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', + ), + 'VpcPeeringConnectionId' => 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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'Instances' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'InstanceId', + 'items' => array( + 'name' => 'InstanceId', + 'type' => 'string', + ), + ), + 'Status' => array( + 'required' => true, + '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( + 'required' => true, + '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' => '2014-09-01', + ), + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + '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', + ), + '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', + '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', + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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( + 'AcceptVpcPeeringConnectionResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'VpcPeeringConnection' => array( + 'type' => 'object', + 'location' => 'xml', + 'sentAs' => 'vpcPeeringConnection', + 'properties' => array( + 'AccepterVpcInfo' => array( + 'type' => 'object', + 'sentAs' => 'accepterVpcInfo', + 'properties' => array( + 'CidrBlock' => array( + 'type' => 'string', + 'sentAs' => 'cidrBlock', + ), + 'OwnerId' => array( + 'type' => 'string', + 'sentAs' => 'ownerId', + ), + 'VpcId' => array( + 'type' => 'string', + 'sentAs' => 'vpcId', + ), + ), + ), + 'ExpirationTime' => array( + 'type' => 'string', + 'sentAs' => 'expirationTime', + ), + 'RequesterVpcInfo' => array( + 'type' => 'object', + 'sentAs' => 'requesterVpcInfo', + 'properties' => array( + 'CidrBlock' => array( + 'type' => 'string', + 'sentAs' => 'cidrBlock', + ), + 'OwnerId' => array( + 'type' => 'string', + 'sentAs' => 'ownerId', + ), + 'VpcId' => array( + 'type' => 'string', + 'sentAs' => 'vpcId', + ), + ), + ), + 'Status' => array( + 'type' => 'object', + 'sentAs' => 'status', + 'properties' => array( + 'Code' => array( + 'type' => 'string', + 'sentAs' => 'code', + ), + 'Message' => array( + 'type' => 'string', + 'sentAs' => 'message', + ), + ), + ), + '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', + ), + ), + ), + ), + 'VpcPeeringConnectionId' => array( + 'type' => 'string', + 'sentAs' => 'vpcPeeringConnectionId', + ), + ), + ), + ), + ), + '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', + ), + ), + ), + 'EmptyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + ), + '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', + ), + 'PublicDnsName' => array( + 'type' => 'string', + 'sentAs' => 'publicDnsName', + ), + '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', + ), + 'PublicDnsName' => array( + 'type' => 'string', + 'sentAs' => 'publicDnsName', + ), + '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', + ), + 'VpcPeeringConnectionId' => array( + 'type' => 'string', + 'sentAs' => 'vpcPeeringConnectionId', + ), + 'State' => array( + 'type' => 'string', + 'sentAs' => 'state', + ), + 'Origin' => array( + 'type' => 'string', + 'sentAs' => 'origin', + ), + ), + ), + ), + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'location' => 'xml', + 'sentAs' => 'encrypted', + ), + ), + ), + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'location' => 'xml', + 'sentAs' => 'encrypted', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + 'CreateVpcPeeringConnectionResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'VpcPeeringConnection' => array( + 'type' => 'object', + 'location' => 'xml', + 'sentAs' => 'vpcPeeringConnection', + 'properties' => array( + 'AccepterVpcInfo' => array( + 'type' => 'object', + 'sentAs' => 'accepterVpcInfo', + 'properties' => array( + 'CidrBlock' => array( + 'type' => 'string', + 'sentAs' => 'cidrBlock', + ), + 'OwnerId' => array( + 'type' => 'string', + 'sentAs' => 'ownerId', + ), + 'VpcId' => array( + 'type' => 'string', + 'sentAs' => 'vpcId', + ), + ), + ), + 'ExpirationTime' => array( + 'type' => 'string', + 'sentAs' => 'expirationTime', + ), + 'RequesterVpcInfo' => array( + 'type' => 'object', + 'sentAs' => 'requesterVpcInfo', + 'properties' => array( + 'CidrBlock' => array( + 'type' => 'string', + 'sentAs' => 'cidrBlock', + ), + 'OwnerId' => array( + 'type' => 'string', + 'sentAs' => 'ownerId', + ), + 'VpcId' => array( + 'type' => 'string', + 'sentAs' => 'vpcId', + ), + ), + ), + 'Status' => array( + 'type' => 'object', + 'sentAs' => 'status', + 'properties' => array( + 'Code' => array( + 'type' => 'string', + 'sentAs' => 'code', + ), + 'Message' => array( + 'type' => 'string', + 'sentAs' => 'message', + ), + ), + ), + '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', + ), + ), + ), + ), + 'VpcPeeringConnectionId' => array( + 'type' => 'string', + 'sentAs' => 'vpcPeeringConnectionId', + ), + ), + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + ), + ), + 'DeleteVpcPeeringConnectionResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Return' => array( + 'type' => 'boolean', + 'location' => 'xml', + 'sentAs' => 'return', + ), + ), + ), + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'sentAs' => 'encrypted', + ), + ), + ), + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'sentAs' => 'encrypted', + ), + ), + ), + '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', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + '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', + ), + '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', + ), + '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', + ), + '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', + ), + ), + ), + ), + ), + ), + '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', + ), + 'PublicDnsName' => array( + 'type' => 'string', + 'sentAs' => 'publicDnsName', + ), + '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', + ), + 'PublicDnsName' => array( + 'type' => 'string', + 'sentAs' => 'publicDnsName', + ), + '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', + ), + 'VpcPeeringConnectionId' => array( + 'type' => 'string', + 'sentAs' => 'vpcPeeringConnectionId', + ), + 'State' => array( + 'type' => 'string', + 'sentAs' => 'state', + ), + 'Origin' => array( + 'type' => 'string', + 'sentAs' => 'origin', + ), + ), + ), + ), + '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', + ), + ), + ), + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'sentAs' => 'encrypted', + ), + ), + ), + ), + ), + ), + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'sentAs' => 'encrypted', + ), + ), + ), + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'sentAs' => 'encrypted', + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'xml', + 'sentAs' => 'nextToken', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + 'DescribeVpcPeeringConnectionsResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'VpcPeeringConnections' => array( + 'type' => 'array', + 'location' => 'xml', + 'sentAs' => 'vpcPeeringConnectionSet', + 'items' => array( + 'name' => 'item', + 'type' => 'object', + 'sentAs' => 'item', + 'properties' => array( + 'AccepterVpcInfo' => array( + 'type' => 'object', + 'sentAs' => 'accepterVpcInfo', + 'properties' => array( + 'CidrBlock' => array( + 'type' => 'string', + 'sentAs' => 'cidrBlock', + ), + 'OwnerId' => array( + 'type' => 'string', + 'sentAs' => 'ownerId', + ), + 'VpcId' => array( + 'type' => 'string', + 'sentAs' => 'vpcId', + ), + ), + ), + 'ExpirationTime' => array( + 'type' => 'string', + 'sentAs' => 'expirationTime', + ), + 'RequesterVpcInfo' => array( + 'type' => 'object', + 'sentAs' => 'requesterVpcInfo', + 'properties' => array( + 'CidrBlock' => array( + 'type' => 'string', + 'sentAs' => 'cidrBlock', + ), + 'OwnerId' => array( + 'type' => 'string', + 'sentAs' => 'ownerId', + ), + 'VpcId' => array( + 'type' => 'string', + 'sentAs' => 'vpcId', + ), + ), + ), + 'Status' => array( + 'type' => 'object', + 'sentAs' => 'status', + 'properties' => array( + 'Code' => array( + 'type' => 'string', + 'sentAs' => 'code', + ), + 'Message' => array( + 'type' => 'string', + 'sentAs' => 'message', + ), + ), + ), + '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', + ), + ), + ), + ), + 'VpcPeeringConnectionId' => array( + 'type' => 'string', + 'sentAs' => 'vpcPeeringConnectionId', + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + 'RejectVpcPeeringConnectionResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Return' => array( + 'type' => 'boolean', + 'location' => 'xml', + 'sentAs' => 'return', + ), + ), + ), + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'sentAs' => 'encrypted', + ), + ), + ), + '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', + ), + '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', + ), + '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', + ), + '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( + '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( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'limit_key' => 'MaxResults', + 'result_key' => 'InstanceStatuses', + ), + 'DescribeInstances' => array( + 'result_key' => 'Reservations', + ), + 'DescribeInternetGateways' => array( + 'result_key' => 'InternetGateways', + ), + 'DescribeKeyPairs' => array( + 'result_key' => 'KeyPairs', + ), + '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', + ), + 'DescribeReservedInstancesOfferings' => array( + 'input_token' => 'NextToken', + 'output_token' => '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( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'limit_key' => 'MaxResults', + 'result_key' => 'SpotPriceHistory', + ), + 'DescribeSubnets' => array( + 'result_key' => 'Subnets', + ), + 'DescribeTags' => array( + 'result_key' => 'Tags', + ), + 'DescribeVolumeStatus' => array( + 'input_token' => 'NextToken', + 'output_token' => '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', + ), + ), +); diff --git a/vendor/aws/Aws/Ec2/Resources/ec2-2014-10-01.php b/vendor/aws/Aws/Ec2/Resources/ec2-2014-10-01.php new file mode 100644 index 0000000..1403567 --- /dev/null +++ b/vendor/aws/Aws/Ec2/Resources/ec2-2014-10-01.php @@ -0,0 +1,16338 @@ + '2014-10-01', + 'endpointPrefix' => 'ec2', + 'serviceFullName' => 'Amazon Elastic Compute Cloud', + 'serviceAbbreviation' => 'Amazon EC2', + 'serviceType' => 'query', + 'signatureVersion' => 'v4', + '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( + 'AcceptVpcPeeringConnection' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'AcceptVpcPeeringConnectionResult', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'AcceptVpcPeeringConnection', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-10-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'VpcPeeringConnectionId' => array( + 'type' => 'string', + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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', + ), + ), + ), + 'AttachClassicLinkVpc' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'AttachClassicLinkVpcResult', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'AttachClassicLinkVpc', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-10-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'InstanceId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'VpcId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Groups' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'SecurityGroupId', + 'items' => array( + 'name' => 'SecurityGroupId', + 'type' => 'string', + ), + ), + ), + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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', + ), + 'DestinationRegion' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'PresignedUrl' => 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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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', + ), + 'VpcPeeringConnectionId' => 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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'KmsKeyId' => array( + 'type' => 'string', + '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' => '2014-10-01', + ), + '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', + ), + ), + ), + 'CreateVpcPeeringConnection' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'CreateVpcPeeringConnectionResult', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateVpcPeeringConnection', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-10-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'VpcId' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'PeerVpcId' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'PeerOwnerId' => 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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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', + ), + ), + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'VpcId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + ), + 'DeleteVpcPeeringConnection' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DeleteVpcPeeringConnectionResult', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteVpcPeeringConnection', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-10-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'VpcPeeringConnectionId' => 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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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', + ), + ), + ), + ), + ), + ), + ), + 'DescribeClassicLinkInstances' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DescribeClassicLinkInstancesResult', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeClassicLinkInstances', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-10-01', + ), + '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', + ), + ), + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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', + ), + ), + ), + ), + ), + ), + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'NetworkInterfaceId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Attribute' => 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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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', + ), + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MaxResults' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + ), + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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', + ), + ), + ), + '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' => '2014-10-01', + ), + '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', + ), + ), + ), + 'DescribeVpcClassicLink' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DescribeVpcClassicLinkResult', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeVpcClassicLink', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-10-01', + ), + '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', + ), + ), + ), + ), + ), + ), + ), + 'DescribeVpcPeeringConnections' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DescribeVpcPeeringConnectionsResult', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeVpcPeeringConnections', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-10-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'VpcPeeringConnectionIds' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'VpcPeeringConnectionId', + 'items' => array( + 'name' => 'VpcPeeringConnectionId', + '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', + ), + ), + ), + ), + ), + ), + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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', + ), + ), + ), + ), + ), + ), + ), + 'DetachClassicLinkVpc' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DetachClassicLinkVpcResult', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DetachClassicLinkVpc', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-10-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'InstanceId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'VpcId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + 'RouteTableId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'GatewayId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + ), + 'DisableVpcClassicLink' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DisableVpcClassicLinkResult', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DisableVpcClassicLink', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-10-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'VpcId' => 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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'VolumeId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + ), + 'EnableVpcClassicLink' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EnableVpcClassicLinkResult', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'EnableVpcClassicLink', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-10-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'VpcId' => 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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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', + ), + ), + 'GroupIds' => array( + 'type' => 'array', + 'sentAs' => 'GroupId', + 'items' => array( + 'name' => 'GroupId', + 'type' => 'string', + ), + ), + 'AdditionalInfo' => array( + 'type' => 'string', + ), + 'UserData' => array( + 'type' => 'object', + 'properties' => array( + 'Data' => 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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'AvailabilityZone' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Image' => array( + 'required' => true, + '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( + 'required' => true, + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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', + ), + ), + ), + ), + ), + ), + ), + ), + 'ModifySubnetAttribute' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ModifySubnetAttribute', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-10-01', + ), + 'SubnetId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MapPublicIpOnLaunch' => array( + 'type' => 'object', + 'location' => 'aws.query', + 'properties' => array( + 'Value' => array( + 'type' => 'boolean', + 'format' => 'boolean-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' => '2014-10-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'VolumeId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'AutoEnableIO' => array( + 'type' => 'object', + 'location' => 'aws.query', + 'properties' => array( + 'Value' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + ), + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'ImageLocation' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Name' => array( + 'required' => true, + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + 'NoDevice' => array( + 'type' => 'string', + ), + ), + ), + ), + 'VirtualizationType' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SriovNetSupport' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + ), + 'RejectVpcPeeringConnection' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'RejectVpcPeeringConnectionResult', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'RejectVpcPeeringConnection', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-10-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'VpcPeeringConnectionId' => array( + 'required' => true, + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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', + ), + 'VpcPeeringConnectionId' => 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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'Instances' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'InstanceId', + 'items' => array( + 'name' => 'InstanceId', + 'type' => 'string', + ), + ), + 'Status' => array( + 'required' => true, + '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( + 'required' => true, + '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' => '2014-10-01', + ), + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + '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', + ), + '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', + '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', + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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' => '2014-10-01', + ), + '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( + 'AcceptVpcPeeringConnectionResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'VpcPeeringConnection' => array( + 'type' => 'object', + 'location' => 'xml', + 'sentAs' => 'vpcPeeringConnection', + 'properties' => array( + 'AccepterVpcInfo' => array( + 'type' => 'object', + 'sentAs' => 'accepterVpcInfo', + 'properties' => array( + 'CidrBlock' => array( + 'type' => 'string', + 'sentAs' => 'cidrBlock', + ), + 'OwnerId' => array( + 'type' => 'string', + 'sentAs' => 'ownerId', + ), + 'VpcId' => array( + 'type' => 'string', + 'sentAs' => 'vpcId', + ), + ), + ), + 'ExpirationTime' => array( + 'type' => 'string', + 'sentAs' => 'expirationTime', + ), + 'RequesterVpcInfo' => array( + 'type' => 'object', + 'sentAs' => 'requesterVpcInfo', + 'properties' => array( + 'CidrBlock' => array( + 'type' => 'string', + 'sentAs' => 'cidrBlock', + ), + 'OwnerId' => array( + 'type' => 'string', + 'sentAs' => 'ownerId', + ), + 'VpcId' => array( + 'type' => 'string', + 'sentAs' => 'vpcId', + ), + ), + ), + 'Status' => array( + 'type' => 'object', + 'sentAs' => 'status', + 'properties' => array( + 'Code' => array( + 'type' => 'string', + 'sentAs' => 'code', + ), + 'Message' => array( + 'type' => 'string', + 'sentAs' => 'message', + ), + ), + ), + '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', + ), + ), + ), + ), + 'VpcPeeringConnectionId' => array( + 'type' => 'string', + 'sentAs' => 'vpcPeeringConnectionId', + ), + ), + ), + ), + ), + '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', + ), + ), + ), + 'EmptyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + ), + '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', + ), + ), + ), + 'AttachClassicLinkVpcResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Return' => array( + 'type' => 'boolean', + 'location' => 'xml', + 'sentAs' => 'return', + ), + ), + ), + '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', + ), + 'PublicDnsName' => array( + 'type' => 'string', + 'sentAs' => 'publicDnsName', + ), + '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', + ), + 'PublicDnsName' => array( + 'type' => 'string', + 'sentAs' => 'publicDnsName', + ), + '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', + ), + 'VpcPeeringConnectionId' => array( + 'type' => 'string', + 'sentAs' => 'vpcPeeringConnectionId', + ), + 'State' => array( + 'type' => 'string', + 'sentAs' => 'state', + ), + 'Origin' => array( + 'type' => 'string', + 'sentAs' => 'origin', + ), + ), + ), + ), + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'location' => 'xml', + 'sentAs' => 'encrypted', + ), + 'KmsKeyId' => array( + 'type' => 'string', + 'location' => 'xml', + 'sentAs' => 'kmsKeyId', + ), + ), + ), + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'location' => 'xml', + 'sentAs' => 'encrypted', + ), + 'KmsKeyId' => array( + 'type' => 'string', + 'location' => 'xml', + 'sentAs' => 'kmsKeyId', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + 'CreateVpcPeeringConnectionResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'VpcPeeringConnection' => array( + 'type' => 'object', + 'location' => 'xml', + 'sentAs' => 'vpcPeeringConnection', + 'properties' => array( + 'AccepterVpcInfo' => array( + 'type' => 'object', + 'sentAs' => 'accepterVpcInfo', + 'properties' => array( + 'CidrBlock' => array( + 'type' => 'string', + 'sentAs' => 'cidrBlock', + ), + 'OwnerId' => array( + 'type' => 'string', + 'sentAs' => 'ownerId', + ), + 'VpcId' => array( + 'type' => 'string', + 'sentAs' => 'vpcId', + ), + ), + ), + 'ExpirationTime' => array( + 'type' => 'string', + 'sentAs' => 'expirationTime', + ), + 'RequesterVpcInfo' => array( + 'type' => 'object', + 'sentAs' => 'requesterVpcInfo', + 'properties' => array( + 'CidrBlock' => array( + 'type' => 'string', + 'sentAs' => 'cidrBlock', + ), + 'OwnerId' => array( + 'type' => 'string', + 'sentAs' => 'ownerId', + ), + 'VpcId' => array( + 'type' => 'string', + 'sentAs' => 'vpcId', + ), + ), + ), + 'Status' => array( + 'type' => 'object', + 'sentAs' => 'status', + 'properties' => array( + 'Code' => array( + 'type' => 'string', + 'sentAs' => 'code', + ), + 'Message' => array( + 'type' => 'string', + 'sentAs' => 'message', + ), + ), + ), + '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', + ), + ), + ), + ), + 'VpcPeeringConnectionId' => array( + 'type' => 'string', + 'sentAs' => 'vpcPeeringConnectionId', + ), + ), + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + ), + ), + 'DeleteVpcPeeringConnectionResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Return' => array( + 'type' => 'boolean', + 'location' => 'xml', + 'sentAs' => 'return', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + ), + ), + 'DescribeClassicLinkInstancesResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Instances' => array( + 'type' => 'array', + 'location' => 'xml', + 'sentAs' => 'instancesSet', + 'items' => array( + 'name' => 'item', + 'type' => 'object', + 'sentAs' => 'item', + 'properties' => array( + 'InstanceId' => array( + 'type' => 'string', + 'sentAs' => 'instanceId', + ), + 'VpcId' => array( + 'type' => 'string', + 'sentAs' => 'vpcId', + ), + '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', + ), + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'xml', + 'sentAs' => 'nextToken', + ), + ), + ), + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'sentAs' => 'encrypted', + ), + ), + ), + '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', + ), + 'CreationDate' => array( + 'type' => 'string', + 'sentAs' => 'creationDate', + ), + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'sentAs' => 'encrypted', + ), + ), + ), + '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', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + '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', + ), + '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', + ), + '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', + ), + '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', + ), + ), + ), + ), + ), + ), + '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', + ), + 'PublicDnsName' => array( + 'type' => 'string', + 'sentAs' => 'publicDnsName', + ), + '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', + ), + 'PublicDnsName' => array( + 'type' => 'string', + 'sentAs' => 'publicDnsName', + ), + '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', + ), + 'VpcPeeringConnectionId' => array( + 'type' => 'string', + 'sentAs' => 'vpcPeeringConnectionId', + ), + 'State' => array( + 'type' => 'string', + 'sentAs' => 'state', + ), + 'Origin' => array( + 'type' => 'string', + 'sentAs' => 'origin', + ), + ), + ), + ), + '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', + ), + ), + ), + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'sentAs' => 'encrypted', + ), + 'KmsKeyId' => array( + 'type' => 'string', + 'sentAs' => 'kmsKeyId', + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'xml', + 'sentAs' => 'nextToken', + ), + ), + ), + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'sentAs' => 'encrypted', + ), + ), + ), + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'sentAs' => 'encrypted', + ), + 'KmsKeyId' => array( + 'type' => 'string', + 'sentAs' => 'kmsKeyId', + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'xml', + 'sentAs' => 'nextToken', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + 'DescribeVpcClassicLinkResult' => 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', + ), + 'ClassicLinkEnabled' => array( + 'type' => 'boolean', + 'sentAs' => 'classicLinkEnabled', + ), + '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', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'DescribeVpcPeeringConnectionsResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'VpcPeeringConnections' => array( + 'type' => 'array', + 'location' => 'xml', + 'sentAs' => 'vpcPeeringConnectionSet', + 'items' => array( + 'name' => 'item', + 'type' => 'object', + 'sentAs' => 'item', + 'properties' => array( + 'AccepterVpcInfo' => array( + 'type' => 'object', + 'sentAs' => 'accepterVpcInfo', + 'properties' => array( + 'CidrBlock' => array( + 'type' => 'string', + 'sentAs' => 'cidrBlock', + ), + 'OwnerId' => array( + 'type' => 'string', + 'sentAs' => 'ownerId', + ), + 'VpcId' => array( + 'type' => 'string', + 'sentAs' => 'vpcId', + ), + ), + ), + 'ExpirationTime' => array( + 'type' => 'string', + 'sentAs' => 'expirationTime', + ), + 'RequesterVpcInfo' => array( + 'type' => 'object', + 'sentAs' => 'requesterVpcInfo', + 'properties' => array( + 'CidrBlock' => array( + 'type' => 'string', + 'sentAs' => 'cidrBlock', + ), + 'OwnerId' => array( + 'type' => 'string', + 'sentAs' => 'ownerId', + ), + 'VpcId' => array( + 'type' => 'string', + 'sentAs' => 'vpcId', + ), + ), + ), + 'Status' => array( + 'type' => 'object', + 'sentAs' => 'status', + 'properties' => array( + 'Code' => array( + 'type' => 'string', + 'sentAs' => 'code', + ), + 'Message' => array( + 'type' => 'string', + 'sentAs' => 'message', + ), + ), + ), + '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', + ), + ), + ), + ), + 'VpcPeeringConnectionId' => array( + 'type' => 'string', + 'sentAs' => 'vpcPeeringConnectionId', + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'DetachClassicLinkVpcResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Return' => array( + 'type' => 'boolean', + 'location' => 'xml', + 'sentAs' => 'return', + ), + ), + ), + 'DisableVpcClassicLinkResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Return' => array( + 'type' => 'boolean', + 'location' => 'xml', + 'sentAs' => 'return', + ), + ), + ), + 'EnableVpcClassicLinkResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Return' => array( + 'type' => 'boolean', + 'location' => 'xml', + 'sentAs' => 'return', + ), + ), + ), + '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', + ), + ), + ), + 'RejectVpcPeeringConnectionResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Return' => array( + 'type' => 'boolean', + 'location' => 'xml', + 'sentAs' => 'return', + ), + ), + ), + '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', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'sentAs' => 'encrypted', + ), + ), + ), + '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', + ), + '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', + ), + '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', + ), + '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( + '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( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'limit_key' => 'MaxResults', + 'result_key' => 'InstanceStatuses', + ), + 'DescribeInstances' => array( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'limit_key' => 'MaxResults', + 'result_key' => 'Reservations', + ), + 'DescribeInternetGateways' => array( + 'result_key' => 'InternetGateways', + ), + 'DescribeKeyPairs' => array( + 'result_key' => 'KeyPairs', + ), + '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', + ), + 'DescribeReservedInstancesOfferings' => array( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'limit_key' => 'MaxResults', + 'result_key' => 'ReservedInstancesOfferings', + ), + 'DescribeRouteTables' => array( + 'result_key' => 'RouteTables', + ), + 'DescribeSecurityGroups' => array( + 'result_key' => 'SecurityGroups', + ), + 'DescribeSnapshots' => array( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'limit_key' => 'MaxResults', + 'result_key' => 'Snapshots', + ), + 'DescribeSpotInstanceRequests' => array( + 'result_key' => 'SpotInstanceRequests', + ), + 'DescribeSpotPriceHistory' => array( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'limit_key' => 'MaxResults', + 'result_key' => 'SpotPriceHistory', + ), + 'DescribeSubnets' => array( + 'result_key' => 'Subnets', + ), + 'DescribeTags' => array( + 'result_key' => 'Tags', + ), + 'DescribeVolumeStatus' => array( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'limit_key' => 'MaxResults', + 'result_key' => 'VolumeStatuses', + ), + 'DescribeVolumes' => array( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'limit_key' => 'MaxResults', + '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', + ), + ), +); diff --git a/vendor/aws/Aws/Ecs/EcsClient.php b/vendor/aws/Aws/Ecs/EcsClient.php new file mode 100644 index 0000000..aab47b6 --- /dev/null +++ b/vendor/aws/Aws/Ecs/EcsClient.php @@ -0,0 +1,84 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/ecs-%s.php' + )) + ->setExceptionParser(new JsonQueryExceptionParser()) + ->build(); + } +} diff --git a/vendor/aws/Aws/Ecs/Exception/EcsException.php b/vendor/aws/Aws/Ecs/Exception/EcsException.php new file mode 100644 index 0000000..aed77d7 --- /dev/null +++ b/vendor/aws/Aws/Ecs/Exception/EcsException.php @@ -0,0 +1,9 @@ + '2014-11-13', + 'endpointPrefix' => 'ecs', + 'serviceFullName' => 'Amazon EC2 Container Service', + 'serviceAbbreviation' => 'Amazon ECS', + 'serviceType' => 'json', + 'jsonVersion' => '1.1', + 'targetPrefix' => 'AmazonEC2ContainerServiceV20141113.', + 'signatureVersion' => 'v4', + 'namespace' => 'Ecs', + 'operations' => array( + 'CreateCluster' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'CreateClusterResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonEC2ContainerServiceV20141113.CreateCluster', + ), + 'clusterName' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'These errors are usually caused by a server-side issue.', + 'class' => 'ServerException', + ), + array( + 'reason' => 'These errors are usually caused by something the client did, such as use an action or resource on behalf of a user that doesn\'t have permission to use the action or resource, or specify an identifier that is not valid.', + 'class' => 'ClientException', + ), + ), + ), + 'CreateService' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'CreateServiceResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonEC2ContainerServiceV20141113.CreateService', + ), + 'cluster' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'serviceName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'taskDefinition' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'loadBalancers' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'LoadBalancer', + 'type' => 'object', + 'properties' => array( + 'loadBalancerName' => array( + 'type' => 'string', + ), + 'containerName' => array( + 'type' => 'string', + ), + 'containerPort' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'desiredCount' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'clientToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'role' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'These errors are usually caused by a server-side issue.', + 'class' => 'ServerException', + ), + array( + 'reason' => 'These errors are usually caused by something the client did, such as use an action or resource on behalf of a user that doesn\'t have permission to use the action or resource, or specify an identifier that is not valid.', + 'class' => 'ClientException', + ), + ), + ), + 'DeleteCluster' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DeleteClusterResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonEC2ContainerServiceV20141113.DeleteCluster', + ), + 'cluster' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'These errors are usually caused by a server-side issue.', + 'class' => 'ServerException', + ), + array( + 'reason' => 'These errors are usually caused by something the client did, such as use an action or resource on behalf of a user that doesn\'t have permission to use the action or resource, or specify an identifier that is not valid.', + 'class' => 'ClientException', + ), + ), + ), + 'DeleteService' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DeleteServiceResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonEC2ContainerServiceV20141113.DeleteService', + ), + 'cluster' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'service' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'These errors are usually caused by a server-side issue.', + 'class' => 'ServerException', + ), + array( + 'reason' => 'These errors are usually caused by something the client did, such as use an action or resource on behalf of a user that doesn\'t have permission to use the action or resource, or specify an identifier that is not valid.', + 'class' => 'ClientException', + ), + ), + ), + 'DeregisterContainerInstance' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DeregisterContainerInstanceResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonEC2ContainerServiceV20141113.DeregisterContainerInstance', + ), + 'cluster' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'containerInstance' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'force' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'These errors are usually caused by a server-side issue.', + 'class' => 'ServerException', + ), + array( + 'reason' => 'These errors are usually caused by something the client did, such as use an action or resource on behalf of a user that doesn\'t have permission to use the action or resource, or specify an identifier that is not valid.', + 'class' => 'ClientException', + ), + ), + ), + 'DeregisterTaskDefinition' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DeregisterTaskDefinitionResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonEC2ContainerServiceV20141113.DeregisterTaskDefinition', + ), + 'taskDefinition' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'These errors are usually caused by a server-side issue.', + 'class' => 'ServerException', + ), + array( + 'reason' => 'These errors are usually caused by something the client did, such as use an action or resource on behalf of a user that doesn\'t have permission to use the action or resource, or specify an identifier that is not valid.', + 'class' => 'ClientException', + ), + ), + ), + 'DescribeClusters' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeClustersResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonEC2ContainerServiceV20141113.DescribeClusters', + ), + 'clusters' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'These errors are usually caused by a server-side issue.', + 'class' => 'ServerException', + ), + array( + 'reason' => 'These errors are usually caused by something the client did, such as use an action or resource on behalf of a user that doesn\'t have permission to use the action or resource, or specify an identifier that is not valid.', + 'class' => 'ClientException', + ), + ), + ), + 'DescribeContainerInstances' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeContainerInstancesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonEC2ContainerServiceV20141113.DescribeContainerInstances', + ), + 'cluster' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'containerInstances' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'These errors are usually caused by a server-side issue.', + 'class' => 'ServerException', + ), + array( + 'reason' => 'These errors are usually caused by something the client did, such as use an action or resource on behalf of a user that doesn\'t have permission to use the action or resource, or specify an identifier that is not valid.', + 'class' => 'ClientException', + ), + ), + ), + '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' => 'AmazonEC2ContainerServiceV20141113.DescribeServices', + ), + 'cluster' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'services' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'These errors are usually caused by a server-side issue.', + 'class' => 'ServerException', + ), + array( + 'reason' => 'These errors are usually caused by something the client did, such as use an action or resource on behalf of a user that doesn\'t have permission to use the action or resource, or specify an identifier that is not valid.', + 'class' => 'ClientException', + ), + ), + ), + 'DescribeTaskDefinition' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeTaskDefinitionResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonEC2ContainerServiceV20141113.DescribeTaskDefinition', + ), + 'taskDefinition' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'These errors are usually caused by a server-side issue.', + 'class' => 'ServerException', + ), + array( + 'reason' => 'These errors are usually caused by something the client did, such as use an action or resource on behalf of a user that doesn\'t have permission to use the action or resource, or specify an identifier that is not valid.', + 'class' => 'ClientException', + ), + ), + ), + 'DescribeTasks' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeTasksResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonEC2ContainerServiceV20141113.DescribeTasks', + ), + 'cluster' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'tasks' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'These errors are usually caused by a server-side issue.', + 'class' => 'ServerException', + ), + array( + 'reason' => 'These errors are usually caused by something the client did, such as use an action or resource on behalf of a user that doesn\'t have permission to use the action or resource, or specify an identifier that is not valid.', + 'class' => 'ClientException', + ), + ), + ), + 'DiscoverPollEndpoint' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DiscoverPollEndpointResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonEC2ContainerServiceV20141113.DiscoverPollEndpoint', + ), + 'containerInstance' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'cluster' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'These errors are usually caused by a server-side issue.', + 'class' => 'ServerException', + ), + array( + 'reason' => 'These errors are usually caused by something the client did, such as use an action or resource on behalf of a user that doesn\'t have permission to use the action or resource, or specify an identifier that is not valid.', + 'class' => 'ClientException', + ), + ), + ), + 'ListClusters' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListClustersResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonEC2ContainerServiceV20141113.ListClusters', + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'maxResults' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'These errors are usually caused by a server-side issue.', + 'class' => 'ServerException', + ), + array( + 'reason' => 'These errors are usually caused by something the client did, such as use an action or resource on behalf of a user that doesn\'t have permission to use the action or resource, or specify an identifier that is not valid.', + 'class' => 'ClientException', + ), + ), + ), + 'ListContainerInstances' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListContainerInstancesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonEC2ContainerServiceV20141113.ListContainerInstances', + ), + 'cluster' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'maxResults' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'These errors are usually caused by a server-side issue.', + 'class' => 'ServerException', + ), + array( + 'reason' => 'These errors are usually caused by something the client did, such as use an action or resource on behalf of a user that doesn\'t have permission to use the action or resource, or specify an identifier that is not valid.', + 'class' => 'ClientException', + ), + ), + ), + 'ListServices' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListServicesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonEC2ContainerServiceV20141113.ListServices', + ), + 'cluster' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'maxResults' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'These errors are usually caused by a server-side issue.', + 'class' => 'ServerException', + ), + array( + 'reason' => 'These errors are usually caused by something the client did, such as use an action or resource on behalf of a user that doesn\'t have permission to use the action or resource, or specify an identifier that is not valid.', + 'class' => 'ClientException', + ), + ), + ), + 'ListTaskDefinitionFamilies' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListTaskDefinitionFamiliesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonEC2ContainerServiceV20141113.ListTaskDefinitionFamilies', + ), + 'familyPrefix' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'maxResults' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'These errors are usually caused by a server-side issue.', + 'class' => 'ServerException', + ), + array( + 'reason' => 'These errors are usually caused by something the client did, such as use an action or resource on behalf of a user that doesn\'t have permission to use the action or resource, or specify an identifier that is not valid.', + 'class' => 'ClientException', + ), + ), + ), + 'ListTaskDefinitions' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListTaskDefinitionsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonEC2ContainerServiceV20141113.ListTaskDefinitions', + ), + 'familyPrefix' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'maxResults' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'These errors are usually caused by a server-side issue.', + 'class' => 'ServerException', + ), + array( + 'reason' => 'These errors are usually caused by something the client did, such as use an action or resource on behalf of a user that doesn\'t have permission to use the action or resource, or specify an identifier that is not valid.', + 'class' => 'ClientException', + ), + ), + ), + 'ListTasks' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListTasksResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonEC2ContainerServiceV20141113.ListTasks', + ), + 'cluster' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'containerInstance' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'family' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'maxResults' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'startedBy' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'serviceName' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'These errors are usually caused by a server-side issue.', + 'class' => 'ServerException', + ), + array( + 'reason' => 'These errors are usually caused by something the client did, such as use an action or resource on behalf of a user that doesn\'t have permission to use the action or resource, or specify an identifier that is not valid.', + 'class' => 'ClientException', + ), + ), + ), + 'RegisterContainerInstance' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'RegisterContainerInstanceResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonEC2ContainerServiceV20141113.RegisterContainerInstance', + ), + 'cluster' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'instanceIdentityDocument' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'instanceIdentityDocumentSignature' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'totalResources' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Resource', + 'type' => 'object', + 'properties' => array( + '' => array( + ), + ), + ), + ), + 'versionInfo' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'agentVersion' => array( + 'type' => 'string', + ), + 'agentHash' => array( + 'type' => 'string', + ), + 'dockerVersion' => array( + 'type' => 'string', + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'These errors are usually caused by a server-side issue.', + 'class' => 'ServerException', + ), + array( + 'reason' => 'These errors are usually caused by something the client did, such as use an action or resource on behalf of a user that doesn\'t have permission to use the action or resource, or specify an identifier that is not valid.', + 'class' => 'ClientException', + ), + ), + ), + 'RegisterTaskDefinition' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'RegisterTaskDefinitionResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonEC2ContainerServiceV20141113.RegisterTaskDefinition', + ), + 'family' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'containerDefinitions' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'ContainerDefinition', + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'image' => array( + 'type' => 'string', + ), + 'cpu' => array( + 'type' => 'numeric', + ), + 'memory' => array( + 'type' => 'numeric', + ), + 'links' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + 'portMappings' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'PortMapping', + 'type' => 'object', + 'properties' => array( + 'containerPort' => array( + 'type' => 'numeric', + ), + 'hostPort' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'essential' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'entryPoint' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + 'command' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + 'environment' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'KeyValuePair', + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'value' => array( + 'type' => 'string', + ), + ), + ), + ), + 'mountPoints' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'MountPoint', + 'type' => 'object', + 'properties' => array( + 'sourceVolume' => array( + 'type' => 'string', + ), + 'containerPath' => array( + 'type' => 'string', + ), + 'readOnly' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + ), + 'volumesFrom' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'VolumeFrom', + 'type' => 'object', + 'properties' => array( + 'sourceContainer' => array( + 'type' => 'string', + ), + 'readOnly' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + ), + ), + ), + ), + 'volumes' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Volume', + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'host' => array( + 'type' => 'object', + 'properties' => array( + 'sourcePath' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'These errors are usually caused by a server-side issue.', + 'class' => 'ServerException', + ), + array( + 'reason' => 'These errors are usually caused by something the client did, such as use an action or resource on behalf of a user that doesn\'t have permission to use the action or resource, or specify an identifier that is not valid.', + 'class' => 'ClientException', + ), + ), + ), + 'RunTask' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'RunTaskResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonEC2ContainerServiceV20141113.RunTask', + ), + 'cluster' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'taskDefinition' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'overrides' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'containerOverrides' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ContainerOverride', + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'command' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'count' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'startedBy' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'These errors are usually caused by a server-side issue.', + 'class' => 'ServerException', + ), + array( + 'reason' => 'These errors are usually caused by something the client did, such as use an action or resource on behalf of a user that doesn\'t have permission to use the action or resource, or specify an identifier that is not valid.', + 'class' => 'ClientException', + ), + ), + ), + 'StartTask' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'StartTaskResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonEC2ContainerServiceV20141113.StartTask', + ), + 'cluster' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'taskDefinition' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'overrides' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'containerOverrides' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ContainerOverride', + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'command' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'containerInstances' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + 'startedBy' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'These errors are usually caused by a server-side issue.', + 'class' => 'ServerException', + ), + array( + 'reason' => 'These errors are usually caused by something the client did, such as use an action or resource on behalf of a user that doesn\'t have permission to use the action or resource, or specify an identifier that is not valid.', + 'class' => 'ClientException', + ), + ), + ), + 'StopTask' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'StopTaskResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonEC2ContainerServiceV20141113.StopTask', + ), + 'cluster' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'task' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'These errors are usually caused by a server-side issue.', + 'class' => 'ServerException', + ), + array( + 'reason' => 'These errors are usually caused by something the client did, such as use an action or resource on behalf of a user that doesn\'t have permission to use the action or resource, or specify an identifier that is not valid.', + 'class' => 'ClientException', + ), + ), + ), + 'SubmitContainerStateChange' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'SubmitContainerStateChangeResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonEC2ContainerServiceV20141113.SubmitContainerStateChange', + ), + 'cluster' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'task' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'containerName' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'status' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'exitCode' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'reason' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'networkBindings' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'NetworkBinding', + 'type' => 'object', + 'properties' => array( + 'bindIP' => array( + 'type' => 'string', + ), + 'containerPort' => array( + 'type' => 'numeric', + ), + 'hostPort' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'These errors are usually caused by a server-side issue.', + 'class' => 'ServerException', + ), + array( + 'reason' => 'These errors are usually caused by something the client did, such as use an action or resource on behalf of a user that doesn\'t have permission to use the action or resource, or specify an identifier that is not valid.', + 'class' => 'ClientException', + ), + ), + ), + 'SubmitTaskStateChange' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'SubmitTaskStateChangeResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonEC2ContainerServiceV20141113.SubmitTaskStateChange', + ), + 'cluster' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'task' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'status' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'reason' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'These errors are usually caused by a server-side issue.', + 'class' => 'ServerException', + ), + array( + 'reason' => 'These errors are usually caused by something the client did, such as use an action or resource on behalf of a user that doesn\'t have permission to use the action or resource, or specify an identifier that is not valid.', + 'class' => 'ClientException', + ), + ), + ), + 'UpdateService' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'UpdateServiceResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonEC2ContainerServiceV20141113.UpdateService', + ), + 'cluster' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'service' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'desiredCount' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'taskDefinition' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'These errors are usually caused by a server-side issue.', + 'class' => 'ServerException', + ), + array( + 'reason' => 'These errors are usually caused by something the client did, such as use an action or resource on behalf of a user that doesn\'t have permission to use the action or resource, or specify an identifier that is not valid.', + 'class' => 'ClientException', + ), + ), + ), + ), + 'models' => array( + 'CreateClusterResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'cluster' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'clusterArn' => array( + 'type' => 'string', + ), + 'clusterName' => array( + 'type' => 'string', + ), + 'status' => array( + 'type' => 'string', + ), + 'registeredContainerInstancesCount' => array( + 'type' => 'numeric', + ), + 'runningTasksCount' => array( + 'type' => 'numeric', + ), + 'pendingTasksCount' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + 'CreateServiceResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'service' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'serviceArn' => array( + 'type' => 'string', + ), + 'serviceName' => array( + 'type' => 'string', + ), + 'clusterArn' => array( + 'type' => 'string', + ), + 'loadBalancers' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'LoadBalancer', + 'type' => 'object', + 'properties' => array( + 'loadBalancerName' => array( + 'type' => 'string', + ), + 'containerName' => array( + 'type' => 'string', + ), + 'containerPort' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'status' => array( + 'type' => 'string', + ), + 'desiredCount' => array( + 'type' => 'numeric', + ), + 'runningCount' => array( + 'type' => 'numeric', + ), + 'pendingCount' => array( + 'type' => 'numeric', + ), + 'taskDefinition' => array( + 'type' => 'string', + ), + 'deployments' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Deployment', + 'type' => 'object', + 'properties' => array( + 'id' => array( + 'type' => 'string', + ), + 'status' => array( + 'type' => 'string', + ), + 'taskDefinition' => array( + 'type' => 'string', + ), + 'desiredCount' => array( + 'type' => 'numeric', + ), + 'pendingCount' => array( + 'type' => 'numeric', + ), + 'runningCount' => array( + 'type' => 'numeric', + ), + 'createdAt' => array( + 'type' => 'string', + ), + 'updatedAt' => array( + 'type' => 'string', + ), + ), + ), + ), + 'roleArn' => array( + 'type' => 'string', + ), + 'events' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ServiceEvent', + 'type' => 'object', + 'properties' => array( + 'id' => array( + 'type' => 'string', + ), + 'createdAt' => array( + 'type' => 'string', + ), + 'message' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'DeleteClusterResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'cluster' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'clusterArn' => array( + 'type' => 'string', + ), + 'clusterName' => array( + 'type' => 'string', + ), + 'status' => array( + 'type' => 'string', + ), + 'registeredContainerInstancesCount' => array( + 'type' => 'numeric', + ), + 'runningTasksCount' => array( + 'type' => 'numeric', + ), + 'pendingTasksCount' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + 'DeleteServiceResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'service' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'serviceArn' => array( + 'type' => 'string', + ), + 'serviceName' => array( + 'type' => 'string', + ), + 'clusterArn' => array( + 'type' => 'string', + ), + 'loadBalancers' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'LoadBalancer', + 'type' => 'object', + 'properties' => array( + 'loadBalancerName' => array( + 'type' => 'string', + ), + 'containerName' => array( + 'type' => 'string', + ), + 'containerPort' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'status' => array( + 'type' => 'string', + ), + 'desiredCount' => array( + 'type' => 'numeric', + ), + 'runningCount' => array( + 'type' => 'numeric', + ), + 'pendingCount' => array( + 'type' => 'numeric', + ), + 'taskDefinition' => array( + 'type' => 'string', + ), + 'deployments' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Deployment', + 'type' => 'object', + 'properties' => array( + 'id' => array( + 'type' => 'string', + ), + 'status' => array( + 'type' => 'string', + ), + 'taskDefinition' => array( + 'type' => 'string', + ), + 'desiredCount' => array( + 'type' => 'numeric', + ), + 'pendingCount' => array( + 'type' => 'numeric', + ), + 'runningCount' => array( + 'type' => 'numeric', + ), + 'createdAt' => array( + 'type' => 'string', + ), + 'updatedAt' => array( + 'type' => 'string', + ), + ), + ), + ), + 'roleArn' => array( + 'type' => 'string', + ), + 'events' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ServiceEvent', + 'type' => 'object', + 'properties' => array( + 'id' => array( + 'type' => 'string', + ), + 'createdAt' => array( + 'type' => 'string', + ), + 'message' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'DeregisterContainerInstanceResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'containerInstance' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'containerInstanceArn' => array( + 'type' => 'string', + ), + 'ec2InstanceId' => array( + 'type' => 'string', + ), + 'remainingResources' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Resource', + 'type' => 'object', + 'properties' => array( + '' => array( + ), + ), + ), + ), + 'registeredResources' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Resource', + 'type' => 'object', + 'properties' => array( + '' => array( + ), + ), + ), + ), + 'status' => array( + 'type' => 'string', + ), + 'agentConnected' => array( + 'type' => 'boolean', + ), + 'runningTasksCount' => array( + 'type' => 'numeric', + ), + 'pendingTasksCount' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + 'DeregisterTaskDefinitionResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'taskDefinition' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'taskDefinitionArn' => array( + 'type' => 'string', + ), + 'containerDefinitions' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ContainerDefinition', + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'image' => array( + 'type' => 'string', + ), + 'cpu' => array( + 'type' => 'numeric', + ), + 'memory' => array( + 'type' => 'numeric', + ), + 'links' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + 'portMappings' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'PortMapping', + 'type' => 'object', + 'properties' => array( + 'containerPort' => array( + 'type' => 'numeric', + ), + 'hostPort' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'essential' => array( + 'type' => 'boolean', + ), + 'entryPoint' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + 'command' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + 'environment' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'KeyValuePair', + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'value' => array( + 'type' => 'string', + ), + ), + ), + ), + 'mountPoints' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'MountPoint', + 'type' => 'object', + 'properties' => array( + 'sourceVolume' => array( + 'type' => 'string', + ), + 'containerPath' => array( + 'type' => 'string', + ), + 'readOnly' => array( + 'type' => 'boolean', + ), + ), + ), + ), + 'volumesFrom' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'VolumeFrom', + 'type' => 'object', + 'properties' => array( + 'sourceContainer' => array( + 'type' => 'string', + ), + 'readOnly' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + ), + ), + 'family' => array( + 'type' => 'string', + ), + 'revision' => array( + 'type' => 'numeric', + ), + 'volumes' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Volume', + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'host' => array( + 'type' => 'object', + 'properties' => array( + 'sourcePath' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'DescribeClustersResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'clusters' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Cluster', + 'type' => 'object', + 'properties' => array( + 'clusterArn' => array( + 'type' => 'string', + ), + 'clusterName' => array( + 'type' => 'string', + ), + 'status' => array( + 'type' => 'string', + ), + 'registeredContainerInstancesCount' => array( + 'type' => 'numeric', + ), + 'runningTasksCount' => array( + 'type' => 'numeric', + ), + 'pendingTasksCount' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'failures' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Failure', + 'type' => 'object', + 'properties' => array( + 'arn' => array( + 'type' => 'string', + ), + 'reason' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'DescribeContainerInstancesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'containerInstances' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'ContainerInstance', + 'type' => 'object', + 'properties' => array( + 'containerInstanceArn' => array( + 'type' => 'string', + ), + 'ec2InstanceId' => array( + 'type' => 'string', + ), + 'remainingResources' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Resource', + 'type' => 'object', + 'properties' => array( + '' => array( + ), + ), + ), + ), + 'registeredResources' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Resource', + 'type' => 'object', + 'properties' => array( + '' => array( + ), + ), + ), + ), + 'status' => array( + 'type' => 'string', + ), + 'agentConnected' => array( + 'type' => 'boolean', + ), + 'runningTasksCount' => array( + 'type' => 'numeric', + ), + 'pendingTasksCount' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'failures' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Failure', + 'type' => 'object', + 'properties' => array( + 'arn' => array( + 'type' => 'string', + ), + 'reason' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'DescribeServicesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'services' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Service', + 'type' => 'object', + 'properties' => array( + 'serviceArn' => array( + 'type' => 'string', + ), + 'serviceName' => array( + 'type' => 'string', + ), + 'clusterArn' => array( + 'type' => 'string', + ), + 'loadBalancers' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'LoadBalancer', + 'type' => 'object', + 'properties' => array( + 'loadBalancerName' => array( + 'type' => 'string', + ), + 'containerName' => array( + 'type' => 'string', + ), + 'containerPort' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'status' => array( + 'type' => 'string', + ), + 'desiredCount' => array( + 'type' => 'numeric', + ), + 'runningCount' => array( + 'type' => 'numeric', + ), + 'pendingCount' => array( + 'type' => 'numeric', + ), + 'taskDefinition' => array( + 'type' => 'string', + ), + 'deployments' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Deployment', + 'type' => 'object', + 'properties' => array( + 'id' => array( + 'type' => 'string', + ), + 'status' => array( + 'type' => 'string', + ), + 'taskDefinition' => array( + 'type' => 'string', + ), + 'desiredCount' => array( + 'type' => 'numeric', + ), + 'pendingCount' => array( + 'type' => 'numeric', + ), + 'runningCount' => array( + 'type' => 'numeric', + ), + 'createdAt' => array( + 'type' => 'string', + ), + 'updatedAt' => array( + 'type' => 'string', + ), + ), + ), + ), + 'roleArn' => array( + 'type' => 'string', + ), + 'events' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ServiceEvent', + 'type' => 'object', + 'properties' => array( + 'id' => array( + 'type' => 'string', + ), + 'createdAt' => array( + 'type' => 'string', + ), + 'message' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'failures' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Failure', + 'type' => 'object', + 'properties' => array( + 'arn' => array( + 'type' => 'string', + ), + 'reason' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'DescribeTaskDefinitionResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'taskDefinition' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'taskDefinitionArn' => array( + 'type' => 'string', + ), + 'containerDefinitions' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ContainerDefinition', + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'image' => array( + 'type' => 'string', + ), + 'cpu' => array( + 'type' => 'numeric', + ), + 'memory' => array( + 'type' => 'numeric', + ), + 'links' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + 'portMappings' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'PortMapping', + 'type' => 'object', + 'properties' => array( + 'containerPort' => array( + 'type' => 'numeric', + ), + 'hostPort' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'essential' => array( + 'type' => 'boolean', + ), + 'entryPoint' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + 'command' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + 'environment' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'KeyValuePair', + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'value' => array( + 'type' => 'string', + ), + ), + ), + ), + 'mountPoints' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'MountPoint', + 'type' => 'object', + 'properties' => array( + 'sourceVolume' => array( + 'type' => 'string', + ), + 'containerPath' => array( + 'type' => 'string', + ), + 'readOnly' => array( + 'type' => 'boolean', + ), + ), + ), + ), + 'volumesFrom' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'VolumeFrom', + 'type' => 'object', + 'properties' => array( + 'sourceContainer' => array( + 'type' => 'string', + ), + 'readOnly' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + ), + ), + 'family' => array( + 'type' => 'string', + ), + 'revision' => array( + 'type' => 'numeric', + ), + 'volumes' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Volume', + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'host' => array( + 'type' => 'object', + 'properties' => array( + 'sourcePath' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'DescribeTasksResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'tasks' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Task', + 'type' => 'object', + 'properties' => array( + 'taskArn' => array( + 'type' => 'string', + ), + 'clusterArn' => array( + 'type' => 'string', + ), + 'taskDefinitionArn' => array( + 'type' => 'string', + ), + 'containerInstanceArn' => array( + 'type' => 'string', + ), + 'overrides' => array( + 'type' => 'object', + 'properties' => array( + 'containerOverrides' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ContainerOverride', + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'command' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'lastStatus' => array( + 'type' => 'string', + ), + 'desiredStatus' => array( + 'type' => 'string', + ), + 'containers' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Container', + 'type' => 'object', + 'properties' => array( + 'containerArn' => array( + 'type' => 'string', + ), + 'taskArn' => array( + 'type' => 'string', + ), + 'name' => array( + 'type' => 'string', + ), + 'lastStatus' => array( + 'type' => 'string', + ), + 'exitCode' => array( + 'type' => 'numeric', + ), + 'reason' => array( + 'type' => 'string', + ), + 'networkBindings' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NetworkBinding', + 'type' => 'object', + 'properties' => array( + 'bindIP' => array( + 'type' => 'string', + ), + 'containerPort' => array( + 'type' => 'numeric', + ), + 'hostPort' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + ), + 'startedBy' => array( + 'type' => 'string', + ), + ), + ), + ), + 'failures' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Failure', + 'type' => 'object', + 'properties' => array( + 'arn' => array( + 'type' => 'string', + ), + 'reason' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'DiscoverPollEndpointResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'endpoint' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListClustersResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'clusterArns' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListContainerInstancesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'containerInstanceArns' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListServicesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'serviceArns' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListTaskDefinitionFamiliesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'families' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListTaskDefinitionsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'taskDefinitionArns' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListTasksResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'taskArns' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'RegisterContainerInstanceResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'containerInstance' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'containerInstanceArn' => array( + 'type' => 'string', + ), + 'ec2InstanceId' => array( + 'type' => 'string', + ), + 'remainingResources' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Resource', + 'type' => 'object', + 'properties' => array( + '' => array( + ), + ), + ), + ), + 'registeredResources' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Resource', + 'type' => 'object', + 'properties' => array( + '' => array( + ), + ), + ), + ), + 'status' => array( + 'type' => 'string', + ), + 'agentConnected' => array( + 'type' => 'boolean', + ), + 'runningTasksCount' => array( + 'type' => 'numeric', + ), + 'pendingTasksCount' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + 'RegisterTaskDefinitionResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'taskDefinition' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'taskDefinitionArn' => array( + 'type' => 'string', + ), + 'containerDefinitions' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ContainerDefinition', + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'image' => array( + 'type' => 'string', + ), + 'cpu' => array( + 'type' => 'numeric', + ), + 'memory' => array( + 'type' => 'numeric', + ), + 'links' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + 'portMappings' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'PortMapping', + 'type' => 'object', + 'properties' => array( + 'containerPort' => array( + 'type' => 'numeric', + ), + 'hostPort' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'essential' => array( + 'type' => 'boolean', + ), + 'entryPoint' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + 'command' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + 'environment' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'KeyValuePair', + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'value' => array( + 'type' => 'string', + ), + ), + ), + ), + 'mountPoints' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'MountPoint', + 'type' => 'object', + 'properties' => array( + 'sourceVolume' => array( + 'type' => 'string', + ), + 'containerPath' => array( + 'type' => 'string', + ), + 'readOnly' => array( + 'type' => 'boolean', + ), + ), + ), + ), + 'volumesFrom' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'VolumeFrom', + 'type' => 'object', + 'properties' => array( + 'sourceContainer' => array( + 'type' => 'string', + ), + 'readOnly' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + ), + ), + 'family' => array( + 'type' => 'string', + ), + 'revision' => array( + 'type' => 'numeric', + ), + 'volumes' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Volume', + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'host' => array( + 'type' => 'object', + 'properties' => array( + 'sourcePath' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'RunTaskResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'tasks' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Task', + 'type' => 'object', + 'properties' => array( + 'taskArn' => array( + 'type' => 'string', + ), + 'clusterArn' => array( + 'type' => 'string', + ), + 'taskDefinitionArn' => array( + 'type' => 'string', + ), + 'containerInstanceArn' => array( + 'type' => 'string', + ), + 'overrides' => array( + 'type' => 'object', + 'properties' => array( + 'containerOverrides' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ContainerOverride', + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'command' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'lastStatus' => array( + 'type' => 'string', + ), + 'desiredStatus' => array( + 'type' => 'string', + ), + 'containers' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Container', + 'type' => 'object', + 'properties' => array( + 'containerArn' => array( + 'type' => 'string', + ), + 'taskArn' => array( + 'type' => 'string', + ), + 'name' => array( + 'type' => 'string', + ), + 'lastStatus' => array( + 'type' => 'string', + ), + 'exitCode' => array( + 'type' => 'numeric', + ), + 'reason' => array( + 'type' => 'string', + ), + 'networkBindings' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NetworkBinding', + 'type' => 'object', + 'properties' => array( + 'bindIP' => array( + 'type' => 'string', + ), + 'containerPort' => array( + 'type' => 'numeric', + ), + 'hostPort' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + ), + 'startedBy' => array( + 'type' => 'string', + ), + ), + ), + ), + 'failures' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Failure', + 'type' => 'object', + 'properties' => array( + 'arn' => array( + 'type' => 'string', + ), + 'reason' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'StartTaskResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'tasks' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Task', + 'type' => 'object', + 'properties' => array( + 'taskArn' => array( + 'type' => 'string', + ), + 'clusterArn' => array( + 'type' => 'string', + ), + 'taskDefinitionArn' => array( + 'type' => 'string', + ), + 'containerInstanceArn' => array( + 'type' => 'string', + ), + 'overrides' => array( + 'type' => 'object', + 'properties' => array( + 'containerOverrides' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ContainerOverride', + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'command' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'lastStatus' => array( + 'type' => 'string', + ), + 'desiredStatus' => array( + 'type' => 'string', + ), + 'containers' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Container', + 'type' => 'object', + 'properties' => array( + 'containerArn' => array( + 'type' => 'string', + ), + 'taskArn' => array( + 'type' => 'string', + ), + 'name' => array( + 'type' => 'string', + ), + 'lastStatus' => array( + 'type' => 'string', + ), + 'exitCode' => array( + 'type' => 'numeric', + ), + 'reason' => array( + 'type' => 'string', + ), + 'networkBindings' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NetworkBinding', + 'type' => 'object', + 'properties' => array( + 'bindIP' => array( + 'type' => 'string', + ), + 'containerPort' => array( + 'type' => 'numeric', + ), + 'hostPort' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + ), + 'startedBy' => array( + 'type' => 'string', + ), + ), + ), + ), + 'failures' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Failure', + 'type' => 'object', + 'properties' => array( + 'arn' => array( + 'type' => 'string', + ), + 'reason' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'StopTaskResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'task' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'taskArn' => array( + 'type' => 'string', + ), + 'clusterArn' => array( + 'type' => 'string', + ), + 'taskDefinitionArn' => array( + 'type' => 'string', + ), + 'containerInstanceArn' => array( + 'type' => 'string', + ), + 'overrides' => array( + 'type' => 'object', + 'properties' => array( + 'containerOverrides' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ContainerOverride', + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'command' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'lastStatus' => array( + 'type' => 'string', + ), + 'desiredStatus' => array( + 'type' => 'string', + ), + 'containers' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Container', + 'type' => 'object', + 'properties' => array( + 'containerArn' => array( + 'type' => 'string', + ), + 'taskArn' => array( + 'type' => 'string', + ), + 'name' => array( + 'type' => 'string', + ), + 'lastStatus' => array( + 'type' => 'string', + ), + 'exitCode' => array( + 'type' => 'numeric', + ), + 'reason' => array( + 'type' => 'string', + ), + 'networkBindings' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NetworkBinding', + 'type' => 'object', + 'properties' => array( + 'bindIP' => array( + 'type' => 'string', + ), + 'containerPort' => array( + 'type' => 'numeric', + ), + 'hostPort' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + ), + 'startedBy' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'SubmitContainerStateChangeResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'acknowledgment' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'SubmitTaskStateChangeResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'acknowledgment' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'UpdateServiceResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'service' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'serviceArn' => array( + 'type' => 'string', + ), + 'serviceName' => array( + 'type' => 'string', + ), + 'clusterArn' => array( + 'type' => 'string', + ), + 'loadBalancers' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'LoadBalancer', + 'type' => 'object', + 'properties' => array( + 'loadBalancerName' => array( + 'type' => 'string', + ), + 'containerName' => array( + 'type' => 'string', + ), + 'containerPort' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'status' => array( + 'type' => 'string', + ), + 'desiredCount' => array( + 'type' => 'numeric', + ), + 'runningCount' => array( + 'type' => 'numeric', + ), + 'pendingCount' => array( + 'type' => 'numeric', + ), + 'taskDefinition' => array( + 'type' => 'string', + ), + 'deployments' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Deployment', + 'type' => 'object', + 'properties' => array( + 'id' => array( + 'type' => 'string', + ), + 'status' => array( + 'type' => 'string', + ), + 'taskDefinition' => array( + 'type' => 'string', + ), + 'desiredCount' => array( + 'type' => 'numeric', + ), + 'pendingCount' => array( + 'type' => 'numeric', + ), + 'runningCount' => array( + 'type' => 'numeric', + ), + 'createdAt' => array( + 'type' => 'string', + ), + 'updatedAt' => array( + 'type' => 'string', + ), + ), + ), + ), + 'roleArn' => array( + 'type' => 'string', + ), + 'events' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ServiceEvent', + 'type' => 'object', + 'properties' => array( + 'id' => array( + 'type' => 'string', + ), + 'createdAt' => array( + 'type' => 'string', + ), + 'message' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + ), +); diff --git a/vendor/aws/Aws/ElastiCache/ElastiCacheClient.php b/vendor/aws/Aws/ElastiCache/ElastiCacheClient.php new file mode 100644 index 0000000..bb4d098 --- /dev/null +++ b/vendor/aws/Aws/ElastiCache/ElastiCacheClient.php @@ -0,0 +1,104 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/elasticache-%s.php' + )) + ->build(); + } +} diff --git a/vendor/aws/Aws/ElastiCache/Enum/SourceType.php b/vendor/aws/Aws/ElastiCache/Enum/SourceType.php new file mode 100644 index 0000000..f5c841b --- /dev/null +++ b/vendor/aws/Aws/ElastiCache/Enum/SourceType.php @@ -0,0 +1,30 @@ + '2014-07-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', + ), + 'sa-east-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'elasticache.sa-east-1.amazonaws.com', + ), + 'cn-north-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'elasticache.cn-north-1.amazonaws.com.cn', + ), + ), + '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' => '2014-07-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', + ), + ), + ), + 'CopySnapshot' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'SnapshotWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CopySnapshot', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-07-15', + ), + 'SourceSnapshotName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TargetSnapshotName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'You already have a snapshot with the given name.', + 'class' => 'SnapshotAlreadyExistsException', + ), + array( + 'reason' => 'The requested snapshot name does not refer to an existing snapshot.', + 'class' => 'SnapshotNotFoundException', + ), + array( + 'reason' => 'The request cannot be processed because it would exceed the maximum number of snapshots.', + 'class' => 'SnapshotQuotaExceededException', + ), + array( + 'reason' => 'The current state of the snapshot does not allow the requested action to occur.', + 'class' => 'InvalidSnapshotStateException', + ), + 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' => '2014-07-15', + ), + 'CacheClusterId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'ReplicationGroupId' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'NumCacheNodes' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'CacheNodeType' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Engine' => array( + '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', + ), + ), + 'SnapshotName' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'AZMode' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'PreferredAvailabilityZone' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'PreferredAvailabilityZones' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'PreferredAvailabilityZones.member', + 'items' => array( + 'name' => 'PreferredAvailabilityZone', + 'type' => 'string', + ), + ), + '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', + ), + 'SnapshotRetentionLimit' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'SnapshotWindow' => 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' => 'You already have 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' => '2014-07-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' => '2014-07-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' => '2014-07-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' => '2014-07-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', + ), + ), + ), + 'CreateSnapshot' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'SnapshotWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateSnapshot', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-07-15', + ), + 'CacheClusterId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SnapshotName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'You already have a snapshot with the given name.', + 'class' => 'SnapshotAlreadyExistsException', + ), + 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 request cannot be processed because it would exceed the maximum number of snapshots.', + 'class' => 'SnapshotQuotaExceededException', + ), + array( + 'reason' => 'You attempted one of the following actions: Creating a snapshot of a Redis cache cluster running on a a t1.micro cache node. Creating a snapshot of a cache cluster that is running Memcached rather than Redis. Neither of these are supported by ElastiCache.', + 'class' => 'SnapshotFeatureNotSupportedException', + ), + array( + 'reason' => 'Two or more incompatible parameters were specified.', + 'class' => 'InvalidParameterCombinationException', + ), + array( + 'reason' => 'The value for a parameter is invalid.', + 'class' => 'InvalidParameterValueException', + ), + ), + ), + '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' => '2014-07-15', + ), + 'CacheClusterId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'FinalSnapshotIdentifier' => array( + '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' => 'You already have a snapshot with the given name.', + 'class' => 'SnapshotAlreadyExistsException', + ), + array( + 'reason' => 'You attempted one of the following actions: Creating a snapshot of a Redis cache cluster running on a a t1.micro cache node. Creating a snapshot of a cache cluster that is running Memcached rather than Redis. Neither of these are supported by ElastiCache.', + 'class' => 'SnapshotFeatureNotSupportedException', + ), + array( + 'reason' => 'The request cannot be processed because it would exceed the maximum number of snapshots.', + 'class' => 'SnapshotQuotaExceededException', + ), + 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' => '2014-07-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' => '2014-07-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' => '2014-07-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' => '2014-07-15', + ), + 'ReplicationGroupId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'RetainPrimaryCluster' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'FinalSnapshotIdentifier' => 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' => 'You already have a snapshot with the given name.', + 'class' => 'SnapshotAlreadyExistsException', + ), + array( + 'reason' => 'You attempted one of the following actions: Creating a snapshot of a Redis cache cluster running on a a t1.micro cache node. Creating a snapshot of a cache cluster that is running Memcached rather than Redis. Neither of these are supported by ElastiCache.', + 'class' => 'SnapshotFeatureNotSupportedException', + ), + array( + 'reason' => 'The request cannot be processed because it would exceed the maximum number of snapshots.', + 'class' => 'SnapshotQuotaExceededException', + ), + array( + 'reason' => 'The value for a parameter is invalid.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'reason' => 'Two or more incompatible parameters were specified.', + 'class' => 'InvalidParameterCombinationException', + ), + ), + ), + 'DeleteSnapshot' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'SnapshotWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteSnapshot', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-07-15', + ), + 'SnapshotName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The requested snapshot name does not refer to an existing snapshot.', + 'class' => 'SnapshotNotFoundException', + ), + array( + 'reason' => 'The current state of the snapshot does not allow the requested action to occur.', + 'class' => 'InvalidSnapshotStateException', + ), + 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' => '2014-07-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' => '2014-07-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' => '2014-07-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' => '2014-07-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' => '2014-07-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' => '2014-07-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' => '2014-07-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' => '2014-07-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' => '2014-07-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' => '2014-07-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' => '2014-07-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', + ), + ), + ), + 'DescribeSnapshots' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DescribeSnapshotsListMessage', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeSnapshots', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-07-15', + ), + 'CacheClusterId' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SnapshotName' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SnapshotSource' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MaxRecords' => array( + 'type' => 'numeric', + '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 snapshot name does not refer to an existing snapshot.', + 'class' => 'SnapshotNotFoundException', + ), + 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' => '2014-07-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', + ), + 'SnapshotRetentionLimit' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'SnapshotWindow' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'AZMode' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'NewAvailabilityZones' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'NewAvailabilityZones.member', + 'items' => array( + 'name' => 'PreferredAvailabilityZone', + 'type' => 'string', + ), + ), + ), + '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 node type is not available in the specified Availability Zone.', + 'class' => 'InsufficientCacheClusterCapacityException', + ), + 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' => '2014-07-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' => '2014-07-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' => '2014-07-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', + ), + 'SnapshotRetentionLimit' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'SnapshotWindow' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SnapshottingClusterId' => 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' => '2014-07-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' => 'You already have 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' => '2014-07-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' => '2014-07-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' => '2014-07-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', + ), + ), + ), + ), + ), + ), + ), + ), + 'SnapshotWrapper' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Snapshot' => array( + 'type' => 'object', + 'location' => 'xml', + 'data' => array( + 'wrapper' => true, + ), + 'properties' => array( + 'SnapshotName' => array( + 'type' => 'string', + ), + 'CacheClusterId' => array( + 'type' => 'string', + ), + 'SnapshotStatus' => array( + 'type' => 'string', + ), + 'SnapshotSource' => array( + 'type' => 'string', + ), + 'CacheNodeType' => array( + 'type' => 'string', + ), + 'Engine' => array( + 'type' => 'string', + ), + 'EngineVersion' => array( + 'type' => 'string', + ), + 'NumCacheNodes' => array( + 'type' => 'numeric', + ), + 'PreferredAvailabilityZone' => array( + 'type' => 'string', + ), + 'CacheClusterCreateTime' => array( + 'type' => 'string', + ), + 'PreferredMaintenanceWindow' => array( + 'type' => 'string', + ), + 'TopicArn' => array( + 'type' => 'string', + ), + 'Port' => array( + 'type' => 'numeric', + ), + 'CacheParameterGroupName' => array( + 'type' => 'string', + ), + 'CacheSubnetGroupName' => array( + 'type' => 'string', + ), + 'VpcId' => array( + 'type' => 'string', + ), + 'AutoMinorVersionUpgrade' => array( + 'type' => 'boolean', + ), + 'SnapshotRetentionLimit' => array( + 'type' => 'numeric', + ), + 'SnapshotWindow' => array( + 'type' => 'string', + ), + 'NodeSnapshots' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NodeSnapshot', + 'type' => 'object', + 'sentAs' => 'NodeSnapshot', + 'properties' => array( + 'CacheNodeId' => array( + 'type' => 'string', + ), + 'CacheSize' => array( + 'type' => 'string', + ), + 'CacheNodeCreateTime' => array( + 'type' => 'string', + ), + 'SnapshotCreateTime' => 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', + ), + 'CustomerAvailabilityZone' => 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', + ), + 'SnapshotRetentionLimit' => array( + 'type' => 'numeric', + ), + 'SnapshotWindow' => 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', + ), + ), + ), + ), + ), + ), + ), + 'SnapshottingClusterId' => 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', + ), + 'CustomerAvailabilityZone' => 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', + ), + 'SnapshotRetentionLimit' => array( + 'type' => 'numeric', + ), + 'SnapshotWindow' => 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', + ), + ), + ), + ), + ), + ), + ), + 'SnapshottingClusterId' => 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', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'DescribeSnapshotsListMessage' => 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( + 'SnapshotName' => array( + 'type' => 'string', + ), + 'CacheClusterId' => array( + 'type' => 'string', + ), + 'SnapshotStatus' => array( + 'type' => 'string', + ), + 'SnapshotSource' => array( + 'type' => 'string', + ), + 'CacheNodeType' => array( + 'type' => 'string', + ), + 'Engine' => array( + 'type' => 'string', + ), + 'EngineVersion' => array( + 'type' => 'string', + ), + 'NumCacheNodes' => array( + 'type' => 'numeric', + ), + 'PreferredAvailabilityZone' => array( + 'type' => 'string', + ), + 'CacheClusterCreateTime' => array( + 'type' => 'string', + ), + 'PreferredMaintenanceWindow' => array( + 'type' => 'string', + ), + 'TopicArn' => array( + 'type' => 'string', + ), + 'Port' => array( + 'type' => 'numeric', + ), + 'CacheParameterGroupName' => array( + 'type' => 'string', + ), + 'CacheSubnetGroupName' => array( + 'type' => 'string', + ), + 'VpcId' => array( + 'type' => 'string', + ), + 'AutoMinorVersionUpgrade' => array( + 'type' => 'boolean', + ), + 'SnapshotRetentionLimit' => array( + 'type' => 'numeric', + ), + 'SnapshotWindow' => array( + 'type' => 'string', + ), + 'NodeSnapshots' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NodeSnapshot', + 'type' => 'object', + 'sentAs' => 'NodeSnapshot', + 'properties' => array( + 'CacheNodeId' => array( + 'type' => 'string', + ), + 'CacheSize' => array( + 'type' => 'string', + ), + 'CacheNodeCreateTime' => array( + 'type' => 'string', + ), + 'SnapshotCreateTime' => 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( + 'DescribeCacheClusters' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'CacheClusters', + ), + 'DescribeCacheEngineVersions' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'CacheEngineVersions', + ), + 'DescribeCacheParameterGroups' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'CacheParameterGroups', + ), + 'DescribeCacheParameters' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'Parameters', + ), + 'DescribeCacheSecurityGroups' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'CacheSecurityGroups', + ), + 'DescribeCacheSubnetGroups' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'CacheSubnetGroups', + ), + 'DescribeEngineDefaultParameters' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'Parameters', + ), + 'DescribeEvents' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'Events', + ), + 'DescribeReservedCacheNodes' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'ReservedCacheNodes', + ), + 'DescribeReservedCacheNodesOfferings' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'ReservedCacheNodesOfferings', + ), + 'DescribeReplicationGroups' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'ReplicationGroups', + ), + 'DescribeSnapshots' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'Snapshots', + ), + ), +); diff --git a/vendor/aws/Aws/ElastiCache/Resources/elasticache-2014-09-30.php b/vendor/aws/Aws/ElastiCache/Resources/elasticache-2014-09-30.php new file mode 100644 index 0000000..8993b76 --- /dev/null +++ b/vendor/aws/Aws/ElastiCache/Resources/elasticache-2014-09-30.php @@ -0,0 +1,3884 @@ + '2014-09-30', + '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', + ), + 'sa-east-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'elasticache.sa-east-1.amazonaws.com', + ), + 'cn-north-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'elasticache.cn-north-1.amazonaws.com.cn', + ), + ), + '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' => '2014-09-30', + ), + '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', + ), + ), + ), + 'CopySnapshot' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'SnapshotWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CopySnapshot', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-09-30', + ), + 'SourceSnapshotName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TargetSnapshotName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'You already have a snapshot with the given name.', + 'class' => 'SnapshotAlreadyExistsException', + ), + array( + 'reason' => 'The requested snapshot name does not refer to an existing snapshot.', + 'class' => 'SnapshotNotFoundException', + ), + array( + 'reason' => 'The request cannot be processed because it would exceed the maximum number of snapshots.', + 'class' => 'SnapshotQuotaExceededException', + ), + array( + 'reason' => 'The current state of the snapshot does not allow the requested action to occur.', + 'class' => 'InvalidSnapshotStateException', + ), + 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' => '2014-09-30', + ), + 'CacheClusterId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'ReplicationGroupId' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'AZMode' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'PreferredAvailabilityZone' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'PreferredAvailabilityZones' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'PreferredAvailabilityZones.member', + 'items' => array( + 'name' => 'PreferredAvailabilityZone', + 'type' => 'string', + ), + ), + 'NumCacheNodes' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'CacheNodeType' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Engine' => array( + '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', + ), + ), + 'SnapshotName' => 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', + ), + 'SnapshotRetentionLimit' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'SnapshotWindow' => 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' => 'You already have 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' => '2014-09-30', + ), + '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' => '2014-09-30', + ), + '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' => '2014-09-30', + ), + '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' => '2014-09-30', + ), + 'ReplicationGroupId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'ReplicationGroupDescription' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'PrimaryClusterId' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'AutomaticFailoverEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'NumCacheClusters' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'PreferredCacheClusterAZs' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'PreferredCacheClusterAZs.member', + 'items' => array( + 'name' => 'AvailabilityZone', + 'type' => 'string', + ), + ), + 'CacheNodeType' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Engine' => array( + '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', + ), + ), + 'SnapshotName' => 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', + ), + 'SnapshotRetentionLimit' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'SnapshotWindow' => array( + '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 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', + ), + ), + ), + 'CreateSnapshot' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'SnapshotWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateSnapshot', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-09-30', + ), + 'CacheClusterId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SnapshotName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'You already have a snapshot with the given name.', + 'class' => 'SnapshotAlreadyExistsException', + ), + 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 request cannot be processed because it would exceed the maximum number of snapshots.', + 'class' => 'SnapshotQuotaExceededException', + ), + array( + 'reason' => 'You attempted one of the following actions: Creating a snapshot of a Redis cache cluster running on a t1.micro cache node. Creating a snapshot of a cache cluster that is running Memcached rather than Redis. Neither of these are supported by ElastiCache.', + 'class' => 'SnapshotFeatureNotSupportedException', + ), + array( + 'reason' => 'Two or more incompatible parameters were specified.', + 'class' => 'InvalidParameterCombinationException', + ), + array( + 'reason' => 'The value for a parameter is invalid.', + 'class' => 'InvalidParameterValueException', + ), + ), + ), + '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' => '2014-09-30', + ), + 'CacheClusterId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'FinalSnapshotIdentifier' => array( + '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' => 'You already have a snapshot with the given name.', + 'class' => 'SnapshotAlreadyExistsException', + ), + array( + 'reason' => 'You attempted one of the following actions: Creating a snapshot of a Redis cache cluster running on a t1.micro cache node. Creating a snapshot of a cache cluster that is running Memcached rather than Redis. Neither of these are supported by ElastiCache.', + 'class' => 'SnapshotFeatureNotSupportedException', + ), + array( + 'reason' => 'The request cannot be processed because it would exceed the maximum number of snapshots.', + 'class' => 'SnapshotQuotaExceededException', + ), + 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' => '2014-09-30', + ), + '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' => '2014-09-30', + ), + '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' => '2014-09-30', + ), + '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' => '2014-09-30', + ), + 'ReplicationGroupId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'RetainPrimaryCluster' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'FinalSnapshotIdentifier' => 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' => 'You already have a snapshot with the given name.', + 'class' => 'SnapshotAlreadyExistsException', + ), + array( + 'reason' => 'You attempted one of the following actions: Creating a snapshot of a Redis cache cluster running on a t1.micro cache node. Creating a snapshot of a cache cluster that is running Memcached rather than Redis. Neither of these are supported by ElastiCache.', + 'class' => 'SnapshotFeatureNotSupportedException', + ), + array( + 'reason' => 'The request cannot be processed because it would exceed the maximum number of snapshots.', + 'class' => 'SnapshotQuotaExceededException', + ), + array( + 'reason' => 'The value for a parameter is invalid.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'reason' => 'Two or more incompatible parameters were specified.', + 'class' => 'InvalidParameterCombinationException', + ), + ), + ), + 'DeleteSnapshot' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'SnapshotWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteSnapshot', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-09-30', + ), + 'SnapshotName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The requested snapshot name does not refer to an existing snapshot.', + 'class' => 'SnapshotNotFoundException', + ), + array( + 'reason' => 'The current state of the snapshot does not allow the requested action to occur.', + 'class' => 'InvalidSnapshotStateException', + ), + 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' => '2014-09-30', + ), + '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' => '2014-09-30', + ), + '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' => '2014-09-30', + ), + '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' => '2014-09-30', + ), + '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' => '2014-09-30', + ), + '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' => '2014-09-30', + ), + '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' => '2014-09-30', + ), + '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' => '2014-09-30', + ), + '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' => '2014-09-30', + ), + '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' => '2014-09-30', + ), + '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' => '2014-09-30', + ), + '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', + ), + ), + ), + 'DescribeSnapshots' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DescribeSnapshotsListMessage', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeSnapshots', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-09-30', + ), + 'CacheClusterId' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SnapshotName' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SnapshotSource' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MaxRecords' => array( + 'type' => 'numeric', + '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 snapshot name does not refer to an existing snapshot.', + 'class' => 'SnapshotNotFoundException', + ), + 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' => '2014-09-30', + ), + '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', + ), + ), + 'AZMode' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'NewAvailabilityZones' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'NewAvailabilityZones.member', + 'items' => array( + 'name' => 'PreferredAvailabilityZone', + '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', + ), + 'SnapshotRetentionLimit' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'SnapshotWindow' => array( + 'type' => '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 node type is not available in the specified Availability Zone.', + 'class' => 'InsufficientCacheClusterCapacityException', + ), + 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' => '2014-09-30', + ), + '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' => '2014-09-30', + ), + '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' => '2014-09-30', + ), + 'ReplicationGroupId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'ReplicationGroupDescription' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'PrimaryClusterId' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SnapshottingClusterId' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'AutomaticFailoverEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-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', + ), + 'SnapshotRetentionLimit' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'SnapshotWindow' => 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 node type is not available in the specified Availability Zone.', + 'class' => 'InsufficientCacheClusterCapacityException', + ), + 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', + ), + ), + ), + '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' => '2014-09-30', + ), + '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' => 'You already have 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' => '2014-09-30', + ), + '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' => '2014-09-30', + ), + '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' => '2014-09-30', + ), + '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', + ), + ), + ), + ), + ), + ), + ), + ), + 'SnapshotWrapper' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Snapshot' => array( + 'type' => 'object', + 'location' => 'xml', + 'data' => array( + 'wrapper' => true, + ), + 'properties' => array( + 'SnapshotName' => array( + 'type' => 'string', + ), + 'CacheClusterId' => array( + 'type' => 'string', + ), + 'SnapshotStatus' => array( + 'type' => 'string', + ), + 'SnapshotSource' => array( + 'type' => 'string', + ), + 'CacheNodeType' => array( + 'type' => 'string', + ), + 'Engine' => array( + 'type' => 'string', + ), + 'EngineVersion' => array( + 'type' => 'string', + ), + 'NumCacheNodes' => array( + 'type' => 'numeric', + ), + 'PreferredAvailabilityZone' => array( + 'type' => 'string', + ), + 'CacheClusterCreateTime' => array( + 'type' => 'string', + ), + 'PreferredMaintenanceWindow' => array( + 'type' => 'string', + ), + 'TopicArn' => array( + 'type' => 'string', + ), + 'Port' => array( + 'type' => 'numeric', + ), + 'CacheParameterGroupName' => array( + 'type' => 'string', + ), + 'CacheSubnetGroupName' => array( + 'type' => 'string', + ), + 'VpcId' => array( + 'type' => 'string', + ), + 'AutoMinorVersionUpgrade' => array( + 'type' => 'boolean', + ), + 'SnapshotRetentionLimit' => array( + 'type' => 'numeric', + ), + 'SnapshotWindow' => array( + 'type' => 'string', + ), + 'NodeSnapshots' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NodeSnapshot', + 'type' => 'object', + 'sentAs' => 'NodeSnapshot', + 'properties' => array( + 'CacheNodeId' => array( + 'type' => 'string', + ), + 'CacheSize' => array( + 'type' => 'string', + ), + 'CacheNodeCreateTime' => array( + 'type' => 'string', + ), + 'SnapshotCreateTime' => 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', + ), + 'CustomerAvailabilityZone' => 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', + ), + 'SnapshotRetentionLimit' => array( + 'type' => 'numeric', + ), + 'SnapshotWindow' => 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', + ), + 'AutomaticFailoverStatus' => 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', + ), + ), + ), + ), + ), + ), + ), + 'SnapshottingClusterId' => array( + 'type' => 'string', + ), + 'AutomaticFailover' => 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', + ), + 'CustomerAvailabilityZone' => 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', + ), + 'SnapshotRetentionLimit' => array( + 'type' => 'numeric', + ), + 'SnapshotWindow' => 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', + ), + 'AutomaticFailoverStatus' => 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', + ), + ), + ), + ), + ), + ), + ), + 'SnapshottingClusterId' => array( + 'type' => 'string', + ), + 'AutomaticFailover' => 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', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'DescribeSnapshotsListMessage' => 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( + 'SnapshotName' => array( + 'type' => 'string', + ), + 'CacheClusterId' => array( + 'type' => 'string', + ), + 'SnapshotStatus' => array( + 'type' => 'string', + ), + 'SnapshotSource' => array( + 'type' => 'string', + ), + 'CacheNodeType' => array( + 'type' => 'string', + ), + 'Engine' => array( + 'type' => 'string', + ), + 'EngineVersion' => array( + 'type' => 'string', + ), + 'NumCacheNodes' => array( + 'type' => 'numeric', + ), + 'PreferredAvailabilityZone' => array( + 'type' => 'string', + ), + 'CacheClusterCreateTime' => array( + 'type' => 'string', + ), + 'PreferredMaintenanceWindow' => array( + 'type' => 'string', + ), + 'TopicArn' => array( + 'type' => 'string', + ), + 'Port' => array( + 'type' => 'numeric', + ), + 'CacheParameterGroupName' => array( + 'type' => 'string', + ), + 'CacheSubnetGroupName' => array( + 'type' => 'string', + ), + 'VpcId' => array( + 'type' => 'string', + ), + 'AutoMinorVersionUpgrade' => array( + 'type' => 'boolean', + ), + 'SnapshotRetentionLimit' => array( + 'type' => 'numeric', + ), + 'SnapshotWindow' => array( + 'type' => 'string', + ), + 'NodeSnapshots' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NodeSnapshot', + 'type' => 'object', + 'sentAs' => 'NodeSnapshot', + 'properties' => array( + 'CacheNodeId' => array( + 'type' => 'string', + ), + 'CacheSize' => array( + 'type' => 'string', + ), + 'CacheNodeCreateTime' => array( + 'type' => 'string', + ), + 'SnapshotCreateTime' => 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( + 'DescribeCacheClusters' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'CacheClusters', + ), + 'DescribeCacheEngineVersions' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'CacheEngineVersions', + ), + 'DescribeCacheParameterGroups' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'CacheParameterGroups', + ), + 'DescribeCacheParameters' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'Parameters', + ), + 'DescribeCacheSecurityGroups' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'CacheSecurityGroups', + ), + 'DescribeCacheSubnetGroups' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'CacheSubnetGroups', + ), + 'DescribeEngineDefaultParameters' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'Parameters', + ), + 'DescribeEvents' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'Events', + ), + 'DescribeReservedCacheNodes' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'ReservedCacheNodes', + ), + 'DescribeReservedCacheNodesOfferings' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'ReservedCacheNodesOfferings', + ), + 'DescribeReplicationGroups' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'ReplicationGroups', + ), + 'DescribeSnapshots' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'Snapshots', + ), + ), +); diff --git a/vendor/aws/Aws/ElastiCache/Resources/elasticache-2015-02-02.php b/vendor/aws/Aws/ElastiCache/Resources/elasticache-2015-02-02.php new file mode 100644 index 0000000..6af8559 --- /dev/null +++ b/vendor/aws/Aws/ElastiCache/Resources/elasticache-2015-02-02.php @@ -0,0 +1,4099 @@ + '2015-02-02', + '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', + ), + 'sa-east-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'elasticache.sa-east-1.amazonaws.com', + ), + 'cn-north-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'elasticache.cn-north-1.amazonaws.com.cn', + ), + ), + 'operations' => array( + 'AddTagsToResource' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'TagListMessage', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'AddTagsToResource', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2015-02-02', + ), + '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' => 'The requested cache cluster ID does not refer to an existing cache cluster.', + 'class' => 'CacheClusterNotFoundException', + ), + array( + 'reason' => 'The requested snapshot name does not refer to an existing snapshot.', + 'class' => 'SnapshotNotFoundException', + ), + array( + 'reason' => 'The request cannot be processed because it would cause the resource to have more than the allowed number of tags. The maximum number of tags permitted on a resource is 10.', + 'class' => 'TagQuotaPerResourceExceededException', + ), + array( + 'reason' => 'The requested Amazon Resource Name (ARN) does not refer to an existing resource.', + 'class' => 'InvalidARNException', + ), + ), + ), + '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' => '2015-02-02', + ), + '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', + ), + ), + ), + 'CopySnapshot' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'SnapshotWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CopySnapshot', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2015-02-02', + ), + 'SourceSnapshotName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TargetSnapshotName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'You already have a snapshot with the given name.', + 'class' => 'SnapshotAlreadyExistsException', + ), + array( + 'reason' => 'The requested snapshot name does not refer to an existing snapshot.', + 'class' => 'SnapshotNotFoundException', + ), + array( + 'reason' => 'The request cannot be processed because it would exceed the maximum number of snapshots.', + 'class' => 'SnapshotQuotaExceededException', + ), + array( + 'reason' => 'The current state of the snapshot does not allow the requested action to occur.', + 'class' => 'InvalidSnapshotStateException', + ), + 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' => '2015-02-02', + ), + 'CacheClusterId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'ReplicationGroupId' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'AZMode' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'PreferredAvailabilityZone' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'PreferredAvailabilityZones' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'PreferredAvailabilityZones.member', + 'items' => array( + 'name' => 'PreferredAvailabilityZone', + 'type' => 'string', + ), + ), + 'NumCacheNodes' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'CacheNodeType' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Engine' => array( + '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', + ), + ), + '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', + ), + ), + ), + ), + 'SnapshotArns' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'SnapshotArns.member', + 'items' => array( + 'name' => 'SnapshotArn', + 'type' => 'string', + ), + ), + 'SnapshotName' => 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', + ), + 'SnapshotRetentionLimit' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'SnapshotWindow' => 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' => 'You already have 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 request cannot be processed because it would cause the resource to have more than the allowed number of tags. The maximum number of tags permitted on a resource is 10.', + 'class' => 'TagQuotaPerResourceExceededException', + ), + 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' => '2015-02-02', + ), + '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' => '2015-02-02', + ), + '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' => '2015-02-02', + ), + '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' => '2015-02-02', + ), + 'ReplicationGroupId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'ReplicationGroupDescription' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'PrimaryClusterId' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'AutomaticFailoverEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'NumCacheClusters' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'PreferredCacheClusterAZs' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'PreferredCacheClusterAZs.member', + 'items' => array( + 'name' => 'AvailabilityZone', + 'type' => 'string', + ), + ), + 'CacheNodeType' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Engine' => array( + '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', + ), + ), + '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', + ), + ), + ), + ), + 'SnapshotArns' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'SnapshotArns.member', + 'items' => array( + 'name' => 'SnapshotArn', + 'type' => 'string', + ), + ), + 'SnapshotName' => 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', + ), + 'SnapshotRetentionLimit' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'SnapshotWindow' => array( + '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 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 request cannot be processed because it would cause the resource to have more than the allowed number of tags. The maximum number of tags permitted on a resource is 10.', + 'class' => 'TagQuotaPerResourceExceededException', + ), + array( + 'reason' => 'The value for a parameter is invalid.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'reason' => 'Two or more incompatible parameters were specified.', + 'class' => 'InvalidParameterCombinationException', + ), + ), + ), + 'CreateSnapshot' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'SnapshotWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateSnapshot', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2015-02-02', + ), + 'CacheClusterId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SnapshotName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'You already have a snapshot with the given name.', + 'class' => 'SnapshotAlreadyExistsException', + ), + 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 request cannot be processed because it would exceed the maximum number of snapshots.', + 'class' => 'SnapshotQuotaExceededException', + ), + array( + 'reason' => 'You attempted one of the following actions: Creating a snapshot of a Redis cache cluster running on a t1.micro cache node. Creating a snapshot of a cache cluster that is running Memcached rather than Redis. Neither of these are supported by ElastiCache.', + 'class' => 'SnapshotFeatureNotSupportedException', + ), + array( + 'reason' => 'Two or more incompatible parameters were specified.', + 'class' => 'InvalidParameterCombinationException', + ), + array( + 'reason' => 'The value for a parameter is invalid.', + 'class' => 'InvalidParameterValueException', + ), + ), + ), + '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' => '2015-02-02', + ), + 'CacheClusterId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'FinalSnapshotIdentifier' => array( + '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' => 'You already have a snapshot with the given name.', + 'class' => 'SnapshotAlreadyExistsException', + ), + array( + 'reason' => 'You attempted one of the following actions: Creating a snapshot of a Redis cache cluster running on a t1.micro cache node. Creating a snapshot of a cache cluster that is running Memcached rather than Redis. Neither of these are supported by ElastiCache.', + 'class' => 'SnapshotFeatureNotSupportedException', + ), + array( + 'reason' => 'The request cannot be processed because it would exceed the maximum number of snapshots.', + 'class' => 'SnapshotQuotaExceededException', + ), + 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' => '2015-02-02', + ), + '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' => '2015-02-02', + ), + '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' => '2015-02-02', + ), + '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' => '2015-02-02', + ), + 'ReplicationGroupId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'RetainPrimaryCluster' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'FinalSnapshotIdentifier' => 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' => 'You already have a snapshot with the given name.', + 'class' => 'SnapshotAlreadyExistsException', + ), + array( + 'reason' => 'You attempted one of the following actions: Creating a snapshot of a Redis cache cluster running on a t1.micro cache node. Creating a snapshot of a cache cluster that is running Memcached rather than Redis. Neither of these are supported by ElastiCache.', + 'class' => 'SnapshotFeatureNotSupportedException', + ), + array( + 'reason' => 'The request cannot be processed because it would exceed the maximum number of snapshots.', + 'class' => 'SnapshotQuotaExceededException', + ), + array( + 'reason' => 'The value for a parameter is invalid.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'reason' => 'Two or more incompatible parameters were specified.', + 'class' => 'InvalidParameterCombinationException', + ), + ), + ), + 'DeleteSnapshot' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'SnapshotWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteSnapshot', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2015-02-02', + ), + 'SnapshotName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The requested snapshot name does not refer to an existing snapshot.', + 'class' => 'SnapshotNotFoundException', + ), + array( + 'reason' => 'The current state of the snapshot does not allow the requested action to occur.', + 'class' => 'InvalidSnapshotStateException', + ), + 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' => '2015-02-02', + ), + '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' => '2015-02-02', + ), + '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' => '2015-02-02', + ), + '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' => '2015-02-02', + ), + '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' => '2015-02-02', + ), + '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' => '2015-02-02', + ), + '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' => '2015-02-02', + ), + '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' => '2015-02-02', + ), + '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' => '2015-02-02', + ), + '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' => '2015-02-02', + ), + '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' => '2015-02-02', + ), + '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', + ), + ), + ), + 'DescribeSnapshots' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DescribeSnapshotsListMessage', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeSnapshots', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2015-02-02', + ), + 'CacheClusterId' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SnapshotName' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SnapshotSource' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MaxRecords' => array( + 'type' => 'numeric', + '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 snapshot name does not refer to an existing snapshot.', + 'class' => 'SnapshotNotFoundException', + ), + array( + 'reason' => 'The value for a parameter is invalid.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'reason' => 'Two or more incompatible parameters were specified.', + 'class' => 'InvalidParameterCombinationException', + ), + ), + ), + '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' => '2015-02-02', + ), + 'ResourceName' => 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 snapshot name does not refer to an existing snapshot.', + 'class' => 'SnapshotNotFoundException', + ), + array( + 'reason' => 'The requested Amazon Resource Name (ARN) does not refer to an existing resource.', + 'class' => 'InvalidARNException', + ), + ), + ), + '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' => '2015-02-02', + ), + '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', + ), + ), + 'AZMode' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'NewAvailabilityZones' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'NewAvailabilityZones.member', + 'items' => array( + 'name' => 'PreferredAvailabilityZone', + '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', + ), + 'SnapshotRetentionLimit' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'SnapshotWindow' => array( + 'type' => '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 node type is not available in the specified Availability Zone.', + 'class' => 'InsufficientCacheClusterCapacityException', + ), + 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' => '2015-02-02', + ), + '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' => '2015-02-02', + ), + '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' => '2015-02-02', + ), + 'ReplicationGroupId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'ReplicationGroupDescription' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'PrimaryClusterId' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SnapshottingClusterId' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'AutomaticFailoverEnabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-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', + ), + 'SnapshotRetentionLimit' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'SnapshotWindow' => 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 node type is not available in the specified Availability Zone.', + 'class' => 'InsufficientCacheClusterCapacityException', + ), + 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', + ), + ), + ), + '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' => '2015-02-02', + ), + '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' => 'You already have 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' => '2015-02-02', + ), + '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', + ), + ), + ), + 'RemoveTagsFromResource' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'TagListMessage', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'RemoveTagsFromResource', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2015-02-02', + ), + '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' => 'The requested cache cluster ID does not refer to an existing cache cluster.', + 'class' => 'CacheClusterNotFoundException', + ), + array( + 'reason' => 'The requested snapshot name does not refer to an existing snapshot.', + 'class' => 'SnapshotNotFoundException', + ), + array( + 'reason' => 'The requested Amazon Resource Name (ARN) does not refer to an existing resource.', + 'class' => 'InvalidARNException', + ), + array( + 'reason' => 'The requested tag was not found on this resource.', + 'class' => 'TagNotFoundException', + ), + ), + ), + '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' => '2015-02-02', + ), + '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' => '2015-02-02', + ), + '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( + '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', + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + ), + ), + 'SnapshotWrapper' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Snapshot' => array( + 'type' => 'object', + 'location' => 'xml', + 'data' => array( + 'wrapper' => true, + ), + 'properties' => array( + 'SnapshotName' => array( + 'type' => 'string', + ), + 'CacheClusterId' => array( + 'type' => 'string', + ), + 'SnapshotStatus' => array( + 'type' => 'string', + ), + 'SnapshotSource' => array( + 'type' => 'string', + ), + 'CacheNodeType' => array( + 'type' => 'string', + ), + 'Engine' => array( + 'type' => 'string', + ), + 'EngineVersion' => array( + 'type' => 'string', + ), + 'NumCacheNodes' => array( + 'type' => 'numeric', + ), + 'PreferredAvailabilityZone' => array( + 'type' => 'string', + ), + 'CacheClusterCreateTime' => array( + 'type' => 'string', + ), + 'PreferredMaintenanceWindow' => array( + 'type' => 'string', + ), + 'TopicArn' => array( + 'type' => 'string', + ), + 'Port' => array( + 'type' => 'numeric', + ), + 'CacheParameterGroupName' => array( + 'type' => 'string', + ), + 'CacheSubnetGroupName' => array( + 'type' => 'string', + ), + 'VpcId' => array( + 'type' => 'string', + ), + 'AutoMinorVersionUpgrade' => array( + 'type' => 'boolean', + ), + 'SnapshotRetentionLimit' => array( + 'type' => 'numeric', + ), + 'SnapshotWindow' => array( + 'type' => 'string', + ), + 'NodeSnapshots' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NodeSnapshot', + 'type' => 'object', + 'sentAs' => 'NodeSnapshot', + 'properties' => array( + 'CacheNodeId' => array( + 'type' => 'string', + ), + 'CacheSize' => array( + 'type' => 'string', + ), + 'CacheNodeCreateTime' => array( + 'type' => 'string', + ), + 'SnapshotCreateTime' => 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', + ), + 'CustomerAvailabilityZone' => 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', + ), + 'SnapshotRetentionLimit' => array( + 'type' => 'numeric', + ), + 'SnapshotWindow' => 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', + ), + 'AutomaticFailoverStatus' => 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', + ), + ), + ), + ), + ), + ), + ), + 'SnapshottingClusterId' => array( + 'type' => 'string', + ), + 'AutomaticFailover' => 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', + ), + 'CustomerAvailabilityZone' => 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', + ), + 'SnapshotRetentionLimit' => array( + 'type' => 'numeric', + ), + 'SnapshotWindow' => 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', + ), + 'AutomaticFailoverStatus' => 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', + ), + ), + ), + ), + ), + ), + ), + 'SnapshottingClusterId' => array( + 'type' => 'string', + ), + 'AutomaticFailover' => 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', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'DescribeSnapshotsListMessage' => 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( + 'SnapshotName' => array( + 'type' => 'string', + ), + 'CacheClusterId' => array( + 'type' => 'string', + ), + 'SnapshotStatus' => array( + 'type' => 'string', + ), + 'SnapshotSource' => array( + 'type' => 'string', + ), + 'CacheNodeType' => array( + 'type' => 'string', + ), + 'Engine' => array( + 'type' => 'string', + ), + 'EngineVersion' => array( + 'type' => 'string', + ), + 'NumCacheNodes' => array( + 'type' => 'numeric', + ), + 'PreferredAvailabilityZone' => array( + 'type' => 'string', + ), + 'CacheClusterCreateTime' => array( + 'type' => 'string', + ), + 'PreferredMaintenanceWindow' => array( + 'type' => 'string', + ), + 'TopicArn' => array( + 'type' => 'string', + ), + 'Port' => array( + 'type' => 'numeric', + ), + 'CacheParameterGroupName' => array( + 'type' => 'string', + ), + 'CacheSubnetGroupName' => array( + 'type' => 'string', + ), + 'VpcId' => array( + 'type' => 'string', + ), + 'AutoMinorVersionUpgrade' => array( + 'type' => 'boolean', + ), + 'SnapshotRetentionLimit' => array( + 'type' => 'numeric', + ), + 'SnapshotWindow' => array( + 'type' => 'string', + ), + 'NodeSnapshots' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NodeSnapshot', + 'type' => 'object', + 'sentAs' => 'NodeSnapshot', + 'properties' => array( + 'CacheNodeId' => array( + 'type' => 'string', + ), + 'CacheSize' => array( + 'type' => 'string', + ), + 'CacheNodeCreateTime' => array( + 'type' => 'string', + ), + 'SnapshotCreateTime' => 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( + 'DescribeCacheClusters' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'CacheClusters', + ), + 'DescribeCacheEngineVersions' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'CacheEngineVersions', + ), + 'DescribeCacheParameterGroups' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'CacheParameterGroups', + ), + 'DescribeCacheParameters' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'Parameters', + ), + 'DescribeCacheSecurityGroups' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'CacheSecurityGroups', + ), + 'DescribeCacheSubnetGroups' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'CacheSubnetGroups', + ), + 'DescribeEngineDefaultParameters' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'Parameters', + ), + 'DescribeEvents' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'Events', + ), + 'DescribeReservedCacheNodes' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'ReservedCacheNodes', + ), + 'DescribeReservedCacheNodesOfferings' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'ReservedCacheNodesOfferings', + ), + 'DescribeReplicationGroups' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'ReplicationGroups', + ), + 'DescribeSnapshots' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'Snapshots', + ), + ), +); diff --git a/vendor/aws/Aws/ElasticBeanstalk/ElasticBeanstalkClient.php b/vendor/aws/Aws/ElasticBeanstalk/ElasticBeanstalkClient.php new file mode 100644 index 0000000..11845d1 --- /dev/null +++ b/vendor/aws/Aws/ElasticBeanstalk/ElasticBeanstalkClient.php @@ -0,0 +1,93 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/elasticbeanstalk-%s.php' + )) + ->build(); + } +} diff --git a/vendor/aws/Aws/ElasticBeanstalk/Enum/ConfigurationDeploymentStatus.php b/vendor/aws/Aws/ElasticBeanstalk/Enum/ConfigurationDeploymentStatus.php new file mode 100644 index 0000000..5d67ed1 --- /dev/null +++ b/vendor/aws/Aws/ElasticBeanstalk/Enum/ConfigurationDeploymentStatus.php @@ -0,0 +1,29 @@ + '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( + 'AbortEnvironmentUpdate' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'AbortEnvironmentUpdate', + ), + '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', + ), + ), + ), + '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', + ), + ), + ), + 'Tags' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Tags.member', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'Value' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + ), + ), + ), + '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, + ), + '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' => '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( + 'EmptyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + ), + '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', + ), + 'AbortableOperationInProgress' => array( + 'type' => 'boolean', + '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', + ), + ), + ), + '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', + ), + 'AbortableOperationInProgress' => array( + 'type' => 'boolean', + ), + '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( + 'DescribeApplicationVersions' => array( + 'result_key' => 'ApplicationVersions', + ), + 'DescribeApplications' => array( + 'result_key' => 'Applications', + ), + 'DescribeConfigurationOptions' => array( + 'result_key' => 'Options', + ), + 'DescribeEnvironments' => array( + 'result_key' => 'Environments', + ), + 'DescribeEvents' => array( + 'input_token' => 'NextToken', + 'output_token' => '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', + ), + ), + ), +); diff --git a/vendor/aws/Aws/ElasticLoadBalancing/ElasticLoadBalancingClient.php b/vendor/aws/Aws/ElasticLoadBalancing/ElasticLoadBalancingClient.php new file mode 100644 index 0000000..0ae30fc --- /dev/null +++ b/vendor/aws/Aws/ElasticLoadBalancing/ElasticLoadBalancingClient.php @@ -0,0 +1,87 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/elasticloadbalancing-%s.php' + )) + ->build(); + } +} diff --git a/vendor/aws/Aws/ElasticLoadBalancing/Exception/AccessPointNotFoundException.php b/vendor/aws/Aws/ElasticLoadBalancing/Exception/AccessPointNotFoundException.php new file mode 100644 index 0000000..8c94d39 --- /dev/null +++ b/vendor/aws/Aws/ElasticLoadBalancing/Exception/AccessPointNotFoundException.php @@ -0,0 +1,22 @@ + '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( + 'AddTags' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'AddTags', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-06-01', + ), + 'LoadBalancerNames' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'LoadBalancerNames.member', + 'items' => array( + 'name' => 'AccessPointName', + 'type' => 'string', + ), + ), + 'Tags' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Tags.member', + 'minItems' => 1, + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'Value' => array( + 'type' => 'string', + 'maxLength' => 256, + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified load balancer could not be found.', + 'class' => 'AccessPointNotFoundException', + ), + array( + 'reason' => 'The quota for the number of tags that can be assigned to a load balancer has been reached.', + 'class' => 'TooManyTagsException', + ), + array( + 'reason' => 'The same tag key specified multiple times.', + 'class' => 'DuplicateTagKeysException', + ), + ), + ), + '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', + ), + 'Tags' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Tags.member', + 'minItems' => 1, + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'Value' => array( + 'type' => 'string', + 'maxLength' => 256, + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The 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', + ), + array( + 'reason' => 'The quota for the number of tags that can be assigned to a load balancer has been reached.', + 'class' => 'TooManyTagsException', + ), + array( + 'reason' => 'The same tag key specified multiple times.', + 'class' => 'DuplicateTagKeysException', + ), + ), + ), + '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', + ), + 'PageSize' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + 'minimum' => 1, + 'maximum' => 400, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified load balancer could not be found.', + 'class' => 'AccessPointNotFoundException', + ), + ), + ), + 'DescribeTags' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DescribeTagsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeTags', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-06-01', + ), + 'LoadBalancerNames' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'LoadBalancerNames.member', + 'minItems' => 1, + 'maxItems' => 20, + 'items' => array( + 'name' => 'AccessPointName', + 'type' => 'string', + ), + ), + ), + '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' => 'ModifyLoadBalancerAttributesOutput', + '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', + ), + ), + ), + 'AccessLog' => array( + 'type' => 'object', + 'properties' => array( + 'Enabled' => array( + 'required' => true, + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'S3BucketName' => array( + 'type' => 'string', + ), + 'EmitInterval' => array( + 'type' => 'numeric', + ), + 'S3BucketPrefix' => array( + 'type' => 'string', + ), + ), + ), + 'ConnectionDraining' => array( + 'type' => 'object', + 'properties' => array( + 'Enabled' => array( + 'required' => true, + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'Timeout' => array( + 'type' => 'numeric', + ), + ), + ), + 'ConnectionSettings' => array( + 'type' => 'object', + 'properties' => array( + 'IdleTimeout' => array( + 'required' => true, + 'type' => 'numeric', + 'minimum' => 1, + 'maximum' => 3600, + ), + ), + ), + 'AdditionalAttributes' => array( + 'type' => 'array', + 'sentAs' => 'AdditionalAttributes.member', + 'items' => array( + 'name' => 'AdditionalAttribute', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => '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', + ), + ), + ), + 'RemoveTags' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'RemoveTags', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-06-01', + ), + 'LoadBalancerNames' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'LoadBalancerNames.member', + 'items' => array( + 'name' => 'AccessPointName', + 'type' => 'string', + ), + ), + 'Tags' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Tags.member', + 'minItems' => 1, + 'items' => array( + 'name' => 'TagKeyOnly', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified load balancer could not be found.', + 'class' => 'AccessPointNotFoundException', + ), + ), + ), + '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( + 'EmptyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + ), + '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', + ), + ), + ), + ), + ), + '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', + ), + ), + ), + 'AccessLog' => array( + 'type' => 'object', + 'properties' => array( + 'Enabled' => array( + 'type' => 'boolean', + ), + 'S3BucketName' => array( + 'type' => 'string', + ), + 'EmitInterval' => array( + 'type' => 'numeric', + ), + 'S3BucketPrefix' => array( + 'type' => 'string', + ), + ), + ), + 'ConnectionDraining' => array( + 'type' => 'object', + 'properties' => array( + 'Enabled' => array( + 'type' => 'boolean', + ), + 'Timeout' => array( + 'type' => 'numeric', + ), + ), + ), + 'ConnectionSettings' => array( + 'type' => 'object', + 'properties' => array( + 'IdleTimeout' => array( + 'type' => 'numeric', + ), + ), + ), + 'AdditionalAttributes' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AdditionalAttribute', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + 'DescribeTagsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'TagDescriptions' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'TagDescription', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'LoadBalancerName' => 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', + ), + ), + ), + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + ), + 'ModifyLoadBalancerAttributesOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'LoadBalancerName' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'LoadBalancerAttributes' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'CrossZoneLoadBalancing' => array( + 'type' => 'object', + 'properties' => array( + 'Enabled' => array( + 'type' => 'boolean', + ), + ), + ), + 'AccessLog' => array( + 'type' => 'object', + 'properties' => array( + 'Enabled' => array( + 'type' => 'boolean', + ), + 'S3BucketName' => array( + 'type' => 'string', + ), + 'EmitInterval' => array( + 'type' => 'numeric', + ), + 'S3BucketPrefix' => array( + 'type' => 'string', + ), + ), + ), + 'ConnectionDraining' => array( + 'type' => 'object', + 'properties' => array( + 'Enabled' => array( + 'type' => 'boolean', + ), + 'Timeout' => array( + 'type' => 'numeric', + ), + ), + ), + 'ConnectionSettings' => array( + 'type' => 'object', + 'properties' => array( + 'IdleTimeout' => array( + 'type' => 'numeric', + ), + ), + ), + 'AdditionalAttributes' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AdditionalAttribute', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + '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( + 'DescribeInstanceHealth' => array( + 'result_key' => 'InstanceStates', + ), + 'DescribeLoadBalancerPolicies' => array( + 'result_key' => 'PolicyDescriptions', + ), + 'DescribeLoadBalancerPolicyTypes' => array( + 'result_key' => 'PolicyTypeDescriptions', + ), + 'DescribeLoadBalancers' => array( + 'input_token' => 'Marker', + 'output_token' => 'NextMarker', + 'result_key' => 'LoadBalancerDescriptions', + ), + 'DescribeTags' => array( + 'result_key' => 'TagDescriptions', + ), + ), +); diff --git a/vendor/aws/Aws/ElasticTranscoder/ElasticTranscoderClient.php b/vendor/aws/Aws/ElasticTranscoder/ElasticTranscoderClient.php new file mode 100644 index 0000000..95c8de1 --- /dev/null +++ b/vendor/aws/Aws/ElasticTranscoder/ElasticTranscoderClient.php @@ -0,0 +1,78 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/elastictranscoder-%s.php' + )) + ->setExceptionParser(new JsonRestExceptionParser()) + ->build(); + } +} diff --git a/vendor/aws/Aws/ElasticTranscoder/Exception/AccessDeniedException.php b/vendor/aws/Aws/ElasticTranscoder/Exception/AccessDeniedException.php new file mode 100644 index 0000000..bdba28f --- /dev/null +++ b/vendor/aws/Aws/ElasticTranscoder/Exception/AccessDeniedException.php @@ -0,0 +1,22 @@ + '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', + ), + ), + '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( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'Input' => array( + 'required' => true, + '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', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + ), + ), + 'DetectedProperties' => array( + 'type' => 'object', + 'properties' => array( + 'Width' => array( + 'type' => 'numeric', + ), + 'Height' => array( + 'type' => 'numeric', + ), + 'FrameRate' => array( + 'type' => 'string', + ), + 'FileSize' => array( + 'type' => 'numeric', + ), + 'DurationMillis' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + 'Output' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'ThumbnailPattern' => array( + 'type' => 'string', + ), + 'ThumbnailEncryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + ), + ), + '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, + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + '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', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + ), + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + 'Captions' => array( + 'type' => 'object', + 'properties' => array( + 'MergePolicy' => array( + 'type' => 'string', + ), + 'CaptionSources' => array( + 'type' => 'array', + 'maxItems' => 20, + 'items' => array( + 'name' => 'CaptionSource', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'Language' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'TimeOffset' => array( + 'type' => 'string', + ), + 'Label' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 40, + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + ), + ), + ), + ), + ), + 'CaptionFormats' => array( + 'type' => 'array', + 'maxItems' => 4, + 'items' => array( + 'name' => 'CaptionFormat', + 'type' => 'object', + 'properties' => array( + 'Format' => array( + 'type' => 'string', + ), + 'Pattern' => array( + 'type' => 'string', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + ), + ), + ), + ), + ), + ), + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + ), + ), + ), + ), + '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', + ), + 'ThumbnailEncryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + ), + ), + '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, + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + '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', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + ), + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + 'Captions' => array( + 'type' => 'object', + 'properties' => array( + 'MergePolicy' => array( + 'type' => 'string', + ), + 'CaptionSources' => array( + 'type' => 'array', + 'maxItems' => 20, + 'items' => array( + 'name' => 'CaptionSource', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'Language' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'TimeOffset' => array( + 'type' => 'string', + ), + 'Label' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 40, + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + ), + ), + ), + ), + ), + 'CaptionFormats' => array( + 'type' => 'array', + 'maxItems' => 4, + 'items' => array( + 'name' => 'CaptionFormat', + 'type' => 'object', + 'properties' => array( + 'Format' => array( + 'type' => 'string', + ), + 'Pattern' => array( + 'type' => 'string', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + ), + ), + ), + ), + ), + ), + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + ), + ), + ), + ), + ), + '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, + ), + ), + 'HlsContentProtection' => array( + 'type' => 'object', + 'properties' => array( + 'Method' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'LicenseAcquisitionUrl' => array( + 'type' => 'string', + 'maxLength' => 512, + ), + 'KeyStoragePolicy' => array( + 'type' => 'string', + ), + ), + ), + 'PlayReadyDrm' => array( + 'type' => 'object', + 'properties' => array( + 'Format' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'KeyId' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'LicenseAcquisitionUrl' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 512, + ), + ), + ), + ), + ), + ), + 'UserMetadata' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'string', + 'data' => array( + 'shape_name' => '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' => '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( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 40, + ), + 'InputBucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'OutputBucket' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Role' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'AwsKmsKeyArn' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 255, + ), + '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( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 40, + ), + 'Description' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 255, + ), + 'Container' => array( + 'required' => true, + '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( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'InputBucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'OutputBucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'Topics' => array( + 'required' => true, + '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', + ), + 'AwsKmsKeyArn' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 255, + ), + '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( + 'required' => true, + '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( + 'required' => true, + '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', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + ), + ), + 'DetectedProperties' => array( + 'type' => 'object', + 'properties' => array( + 'Width' => array( + 'type' => 'numeric', + ), + 'Height' => array( + 'type' => 'numeric', + ), + 'FrameRate' => array( + 'type' => 'string', + ), + 'FileSize' => array( + 'type' => 'numeric', + ), + 'DurationMillis' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + 'Output' => array( + 'type' => 'object', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'ThumbnailPattern' => array( + 'type' => 'string', + ), + 'ThumbnailEncryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => 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', + ), + 'FrameRate' => array( + 'type' => 'string', + ), + 'FileSize' => array( + 'type' => 'numeric', + ), + 'DurationMillis' => array( + 'type' => 'numeric', + ), + 'Watermarks' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'JobWatermark', + 'type' => 'object', + 'properties' => array( + 'PresetWatermarkId' => array( + 'type' => 'string', + ), + 'InputKey' => array( + 'type' => 'string', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => 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', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => 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', + ), + ), + ), + ), + ), + ), + 'Captions' => array( + 'type' => 'object', + 'properties' => array( + 'MergePolicy' => array( + 'type' => 'string', + ), + 'CaptionSources' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'CaptionSource', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Language' => array( + 'type' => 'string', + ), + 'TimeOffset' => array( + 'type' => 'string', + ), + 'Label' => array( + 'type' => 'string', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'CaptionFormats' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'CaptionFormat', + 'type' => 'object', + 'properties' => array( + 'Format' => array( + 'type' => 'string', + ), + 'Pattern' => array( + 'type' => 'string', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + ), + ), + 'AppliedColorSpaceConversion' => 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', + ), + 'ThumbnailEncryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => 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', + ), + 'FrameRate' => array( + 'type' => 'string', + ), + 'FileSize' => array( + 'type' => 'numeric', + ), + 'DurationMillis' => array( + 'type' => 'numeric', + ), + 'Watermarks' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'JobWatermark', + 'type' => 'object', + 'properties' => array( + 'PresetWatermarkId' => array( + 'type' => 'string', + ), + 'InputKey' => array( + 'type' => 'string', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => 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', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => 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', + ), + ), + ), + ), + ), + ), + 'Captions' => array( + 'type' => 'object', + 'properties' => array( + 'MergePolicy' => array( + 'type' => 'string', + ), + 'CaptionSources' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'CaptionSource', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Language' => array( + 'type' => 'string', + ), + 'TimeOffset' => array( + 'type' => 'string', + ), + 'Label' => array( + 'type' => 'string', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'CaptionFormats' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'CaptionFormat', + 'type' => 'object', + 'properties' => array( + 'Format' => array( + 'type' => 'string', + ), + 'Pattern' => array( + 'type' => 'string', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + ), + ), + 'AppliedColorSpaceConversion' => 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', + ), + ), + 'HlsContentProtection' => array( + 'type' => 'object', + 'properties' => array( + 'Method' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + 'LicenseAcquisitionUrl' => array( + 'type' => 'string', + ), + 'KeyStoragePolicy' => array( + 'type' => 'string', + ), + ), + ), + 'PlayReadyDrm' => array( + 'type' => 'object', + 'properties' => array( + 'Format' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'KeyId' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + 'LicenseAcquisitionUrl' => array( + 'type' => 'string', + ), + ), + ), + 'Status' => array( + 'type' => 'string', + ), + 'StatusDetail' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Status' => array( + 'type' => 'string', + ), + 'UserMetadata' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'string', + ), + ), + 'Timing' => array( + 'type' => 'object', + 'properties' => array( + 'SubmitTimeMillis' => array( + 'type' => 'numeric', + ), + 'StartTimeMillis' => array( + 'type' => 'numeric', + ), + 'FinishTimeMillis' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + ), + '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', + ), + 'AwsKmsKeyArn' => 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', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'Warnings' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Warning', + 'type' => 'object', + 'properties' => array( + 'Code' => array( + 'type' => 'string', + ), + 'Message' => array( + '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', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + ), + ), + 'DetectedProperties' => array( + 'type' => 'object', + 'properties' => array( + 'Width' => array( + 'type' => 'numeric', + ), + 'Height' => array( + 'type' => 'numeric', + ), + 'FrameRate' => array( + 'type' => 'string', + ), + 'FileSize' => array( + 'type' => 'numeric', + ), + 'DurationMillis' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + 'Output' => array( + 'type' => 'object', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'ThumbnailPattern' => array( + 'type' => 'string', + ), + 'ThumbnailEncryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => 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', + ), + 'FrameRate' => array( + 'type' => 'string', + ), + 'FileSize' => array( + 'type' => 'numeric', + ), + 'DurationMillis' => array( + 'type' => 'numeric', + ), + 'Watermarks' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'JobWatermark', + 'type' => 'object', + 'properties' => array( + 'PresetWatermarkId' => array( + 'type' => 'string', + ), + 'InputKey' => array( + 'type' => 'string', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => 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', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => 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', + ), + ), + ), + ), + ), + ), + 'Captions' => array( + 'type' => 'object', + 'properties' => array( + 'MergePolicy' => array( + 'type' => 'string', + ), + 'CaptionSources' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'CaptionSource', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Language' => array( + 'type' => 'string', + ), + 'TimeOffset' => array( + 'type' => 'string', + ), + 'Label' => array( + 'type' => 'string', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'CaptionFormats' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'CaptionFormat', + 'type' => 'object', + 'properties' => array( + 'Format' => array( + 'type' => 'string', + ), + 'Pattern' => array( + 'type' => 'string', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + ), + ), + 'AppliedColorSpaceConversion' => 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', + ), + 'ThumbnailEncryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => 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', + ), + 'FrameRate' => array( + 'type' => 'string', + ), + 'FileSize' => array( + 'type' => 'numeric', + ), + 'DurationMillis' => array( + 'type' => 'numeric', + ), + 'Watermarks' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'JobWatermark', + 'type' => 'object', + 'properties' => array( + 'PresetWatermarkId' => array( + 'type' => 'string', + ), + 'InputKey' => array( + 'type' => 'string', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => 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', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => 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', + ), + ), + ), + ), + ), + ), + 'Captions' => array( + 'type' => 'object', + 'properties' => array( + 'MergePolicy' => array( + 'type' => 'string', + ), + 'CaptionSources' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'CaptionSource', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Language' => array( + 'type' => 'string', + ), + 'TimeOffset' => array( + 'type' => 'string', + ), + 'Label' => array( + 'type' => 'string', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'CaptionFormats' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'CaptionFormat', + 'type' => 'object', + 'properties' => array( + 'Format' => array( + 'type' => 'string', + ), + 'Pattern' => array( + 'type' => 'string', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + ), + ), + 'AppliedColorSpaceConversion' => 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', + ), + ), + 'HlsContentProtection' => array( + 'type' => 'object', + 'properties' => array( + 'Method' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + 'LicenseAcquisitionUrl' => array( + 'type' => 'string', + ), + 'KeyStoragePolicy' => array( + 'type' => 'string', + ), + ), + ), + 'PlayReadyDrm' => array( + 'type' => 'object', + 'properties' => array( + 'Format' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'KeyId' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + 'LicenseAcquisitionUrl' => array( + 'type' => 'string', + ), + ), + ), + 'Status' => array( + 'type' => 'string', + ), + 'StatusDetail' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Status' => array( + 'type' => 'string', + ), + 'UserMetadata' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'string', + ), + ), + 'Timing' => array( + 'type' => 'object', + 'properties' => array( + 'SubmitTimeMillis' => array( + 'type' => 'numeric', + ), + 'StartTimeMillis' => array( + 'type' => 'numeric', + ), + 'FinishTimeMillis' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + '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', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + ), + ), + 'DetectedProperties' => array( + 'type' => 'object', + 'properties' => array( + 'Width' => array( + 'type' => 'numeric', + ), + 'Height' => array( + 'type' => 'numeric', + ), + 'FrameRate' => array( + 'type' => 'string', + ), + 'FileSize' => array( + 'type' => 'numeric', + ), + 'DurationMillis' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + 'Output' => array( + 'type' => 'object', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'ThumbnailPattern' => array( + 'type' => 'string', + ), + 'ThumbnailEncryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => 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', + ), + 'FrameRate' => array( + 'type' => 'string', + ), + 'FileSize' => array( + 'type' => 'numeric', + ), + 'DurationMillis' => array( + 'type' => 'numeric', + ), + 'Watermarks' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'JobWatermark', + 'type' => 'object', + 'properties' => array( + 'PresetWatermarkId' => array( + 'type' => 'string', + ), + 'InputKey' => array( + 'type' => 'string', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => 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', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => 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', + ), + ), + ), + ), + ), + ), + 'Captions' => array( + 'type' => 'object', + 'properties' => array( + 'MergePolicy' => array( + 'type' => 'string', + ), + 'CaptionSources' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'CaptionSource', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Language' => array( + 'type' => 'string', + ), + 'TimeOffset' => array( + 'type' => 'string', + ), + 'Label' => array( + 'type' => 'string', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'CaptionFormats' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'CaptionFormat', + 'type' => 'object', + 'properties' => array( + 'Format' => array( + 'type' => 'string', + ), + 'Pattern' => array( + 'type' => 'string', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + ), + ), + 'AppliedColorSpaceConversion' => 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', + ), + 'ThumbnailEncryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => 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', + ), + 'FrameRate' => array( + 'type' => 'string', + ), + 'FileSize' => array( + 'type' => 'numeric', + ), + 'DurationMillis' => array( + 'type' => 'numeric', + ), + 'Watermarks' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'JobWatermark', + 'type' => 'object', + 'properties' => array( + 'PresetWatermarkId' => array( + 'type' => 'string', + ), + 'InputKey' => array( + 'type' => 'string', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => 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', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => 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', + ), + ), + ), + ), + ), + ), + 'Captions' => array( + 'type' => 'object', + 'properties' => array( + 'MergePolicy' => array( + 'type' => 'string', + ), + 'CaptionSources' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'CaptionSource', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Language' => array( + 'type' => 'string', + ), + 'TimeOffset' => array( + 'type' => 'string', + ), + 'Label' => array( + 'type' => 'string', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'CaptionFormats' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'CaptionFormat', + 'type' => 'object', + 'properties' => array( + 'Format' => array( + 'type' => 'string', + ), + 'Pattern' => array( + 'type' => 'string', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + ), + ), + 'AppliedColorSpaceConversion' => 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', + ), + ), + 'HlsContentProtection' => array( + 'type' => 'object', + 'properties' => array( + 'Method' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + 'LicenseAcquisitionUrl' => array( + 'type' => 'string', + ), + 'KeyStoragePolicy' => array( + 'type' => 'string', + ), + ), + ), + 'PlayReadyDrm' => array( + 'type' => 'object', + 'properties' => array( + 'Format' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'KeyId' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + 'LicenseAcquisitionUrl' => array( + 'type' => 'string', + ), + ), + ), + 'Status' => array( + 'type' => 'string', + ), + 'StatusDetail' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Status' => array( + 'type' => 'string', + ), + 'UserMetadata' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'string', + ), + ), + 'Timing' => array( + 'type' => 'object', + 'properties' => array( + 'SubmitTimeMillis' => array( + 'type' => 'numeric', + ), + 'StartTimeMillis' => array( + 'type' => 'numeric', + ), + 'FinishTimeMillis' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + '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', + ), + 'AwsKmsKeyArn' => 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', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + ), + ), + 'DetectedProperties' => array( + 'type' => 'object', + 'properties' => array( + 'Width' => array( + 'type' => 'numeric', + ), + 'Height' => array( + 'type' => 'numeric', + ), + 'FrameRate' => array( + 'type' => 'string', + ), + 'FileSize' => array( + 'type' => 'numeric', + ), + 'DurationMillis' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + 'Output' => array( + 'type' => 'object', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'ThumbnailPattern' => array( + 'type' => 'string', + ), + 'ThumbnailEncryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => 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', + ), + 'FrameRate' => array( + 'type' => 'string', + ), + 'FileSize' => array( + 'type' => 'numeric', + ), + 'DurationMillis' => array( + 'type' => 'numeric', + ), + 'Watermarks' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'JobWatermark', + 'type' => 'object', + 'properties' => array( + 'PresetWatermarkId' => array( + 'type' => 'string', + ), + 'InputKey' => array( + 'type' => 'string', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => 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', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => 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', + ), + ), + ), + ), + ), + ), + 'Captions' => array( + 'type' => 'object', + 'properties' => array( + 'MergePolicy' => array( + 'type' => 'string', + ), + 'CaptionSources' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'CaptionSource', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Language' => array( + 'type' => 'string', + ), + 'TimeOffset' => array( + 'type' => 'string', + ), + 'Label' => array( + 'type' => 'string', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'CaptionFormats' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'CaptionFormat', + 'type' => 'object', + 'properties' => array( + 'Format' => array( + 'type' => 'string', + ), + 'Pattern' => array( + 'type' => 'string', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + ), + ), + 'AppliedColorSpaceConversion' => 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', + ), + 'ThumbnailEncryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => 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', + ), + 'FrameRate' => array( + 'type' => 'string', + ), + 'FileSize' => array( + 'type' => 'numeric', + ), + 'DurationMillis' => array( + 'type' => 'numeric', + ), + 'Watermarks' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'JobWatermark', + 'type' => 'object', + 'properties' => array( + 'PresetWatermarkId' => array( + 'type' => 'string', + ), + 'InputKey' => array( + 'type' => 'string', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => 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', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => 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', + ), + ), + ), + ), + ), + ), + 'Captions' => array( + 'type' => 'object', + 'properties' => array( + 'MergePolicy' => array( + 'type' => 'string', + ), + 'CaptionSources' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'CaptionSource', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Language' => array( + 'type' => 'string', + ), + 'TimeOffset' => array( + 'type' => 'string', + ), + 'Label' => array( + 'type' => 'string', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'CaptionFormats' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'CaptionFormat', + 'type' => 'object', + 'properties' => array( + 'Format' => array( + 'type' => 'string', + ), + 'Pattern' => array( + 'type' => 'string', + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'Encryption' => array( + 'type' => 'object', + 'properties' => array( + 'Mode' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + ), + ), + 'AppliedColorSpaceConversion' => 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', + ), + ), + 'HlsContentProtection' => array( + 'type' => 'object', + 'properties' => array( + 'Method' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + 'LicenseAcquisitionUrl' => array( + 'type' => 'string', + ), + 'KeyStoragePolicy' => array( + 'type' => 'string', + ), + ), + ), + 'PlayReadyDrm' => array( + 'type' => 'object', + 'properties' => array( + 'Format' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'KeyMd5' => array( + 'type' => 'string', + ), + 'KeyId' => array( + 'type' => 'string', + ), + 'InitializationVector' => array( + 'type' => 'string', + ), + 'LicenseAcquisitionUrl' => array( + 'type' => 'string', + ), + ), + ), + 'Status' => array( + 'type' => 'string', + ), + 'StatusDetail' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Status' => array( + 'type' => 'string', + ), + 'UserMetadata' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'string', + ), + ), + 'Timing' => array( + 'type' => 'object', + 'properties' => array( + 'SubmitTimeMillis' => array( + 'type' => 'numeric', + ), + 'StartTimeMillis' => array( + 'type' => 'numeric', + ), + 'FinishTimeMillis' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + ), + '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', + ), + 'AwsKmsKeyArn' => 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', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'Warnings' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Warning', + 'type' => 'object', + 'properties' => array( + 'Code' => array( + 'type' => 'string', + ), + 'Message' => array( + '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', + ), + 'AwsKmsKeyArn' => 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', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'Warnings' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Warning', + 'type' => 'object', + 'properties' => array( + 'Code' => array( + 'type' => 'string', + ), + 'Message' => array( + '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', + ), + 'AwsKmsKeyArn' => 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', + ), + 'AwsKmsKeyArn' => 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( + 'ListJobsByPipeline' => array( + 'input_token' => 'PageToken', + 'output_token' => 'NextPageToken', + 'result_key' => 'Jobs', + ), + 'ListJobsByStatus' => array( + 'input_token' => 'PageToken', + 'output_token' => 'NextPageToken', + 'result_key' => 'Jobs', + ), + 'ListPipelines' => array( + 'input_token' => 'PageToken', + 'output_token' => 'NextPageToken', + 'result_key' => 'Pipelines', + ), + 'ListPresets' => array( + 'input_token' => 'PageToken', + 'output_token' => 'NextPageToken', + 'result_key' => 'Presets', + ), + ), +); diff --git a/vendor/aws/Aws/Emr/EmrClient.php b/vendor/aws/Aws/Emr/EmrClient.php new file mode 100644 index 0000000..f8c3d5a --- /dev/null +++ b/vendor/aws/Aws/Emr/EmrClient.php @@ -0,0 +1,80 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/emr-%s.php' + )) + ->setExceptionParser(new JsonQueryExceptionParser()) + ->build(); + } +} diff --git a/vendor/aws/Aws/Emr/Enum/ActionOnFailure.php b/vendor/aws/Aws/Emr/Enum/ActionOnFailure.php new file mode 100644 index 0000000..f1f8ecf --- /dev/null +++ b/vendor/aws/Aws/Emr/Enum/ActionOnFailure.php @@ -0,0 +1,30 @@ + '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( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'Tags' => array( + 'required' => true, + '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( + 'required' => true, + '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( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'StepId' => array( + 'required' => true, + '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( + 'required' => true, + '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( + 'required' => true, + '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( + 'required' => true, + '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( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'StepStates' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'StepState', + 'type' => 'string', + ), + ), + 'StepIds' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'XmlString', + 'type' => 'string', + 'maxLength' => 10280, + ), + ), + '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( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'TagKeys' => array( + 'required' => true, + '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, + ), + 'EmrManagedMasterSecurityGroup' => array( + 'type' => 'string', + 'maxLength' => 256, + ), + 'EmrManagedSlaveSecurityGroup' => array( + 'type' => 'string', + 'maxLength' => 256, + ), + 'AdditionalMasterSecurityGroups' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'XmlStringMaxLen256', + 'type' => 'string', + 'maxLength' => 256, + ), + ), + 'AdditionalSlaveSecurityGroups' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'XmlStringMaxLen256', + '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, + ), + 'ServiceRole' => 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', + ), + 'EmrManagedMasterSecurityGroup' => array( + 'type' => 'string', + ), + 'EmrManagedSlaveSecurityGroup' => array( + 'type' => 'string', + ), + 'AdditionalMasterSecurityGroups' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + 'AdditionalSlaveSecurityGroups' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'String', + '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', + ), + ), + ), + ), + 'ServiceRole' => array( + 'type' => 'string', + ), + 'NormalizedInstanceHours' => array( + 'type' => 'numeric', + ), + 'MasterPublicDnsName' => 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', + ), + 'ServiceRole' => 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', + ), + ), + ), + ), + ), + 'NormalizedInstanceHours' => array( + 'type' => 'numeric', + ), + ), + ), + ), + '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', + ), + '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', + ), + ), + ), + ), + ), + ), + ), + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'RunJobFlowOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'JobFlowId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + ), + 'iterators' => array( + 'DescribeJobFlows' => array( + 'result_key' => 'JobFlows', + ), + 'ListBootstrapActions' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'result_key' => 'BootstrapActions', + ), + 'ListClusters' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'result_key' => 'Clusters', + ), + 'ListInstanceGroups' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'result_key' => 'InstanceGroups', + ), + 'ListInstances' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'result_key' => 'Instances', + ), + 'ListSteps' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'result_key' => 'Steps', + ), + ), +); diff --git a/vendor/aws/Aws/Glacier/Enum/Action.php b/vendor/aws/Aws/Glacier/Enum/Action.php new file mode 100644 index 0000000..00ec7a8 --- /dev/null +++ b/vendor/aws/Aws/Glacier/Enum/Action.php @@ -0,0 +1,29 @@ +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()) + ->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; + } +} diff --git a/vendor/aws/Aws/Glacier/GlacierUploadListener.php b/vendor/aws/Aws/Glacier/GlacierUploadListener.php new file mode 100644 index 0000000..2e95cdd --- /dev/null +++ b/vendor/aws/Aws/Glacier/GlacierUploadListener.php @@ -0,0 +1,63 @@ + 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); + } + } +} diff --git a/vendor/aws/Aws/Glacier/Model/MultipartUpload/AbstractTransfer.php b/vendor/aws/Aws/Glacier/Model/MultipartUpload/AbstractTransfer.php new file mode 100644 index 0000000..d7b1a74 --- /dev/null +++ b/vendor/aws/Aws/Glacier/Model/MultipartUpload/AbstractTransfer.php @@ -0,0 +1,105 @@ +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; + } +} diff --git a/vendor/aws/Aws/Glacier/Model/MultipartUpload/ParallelTransfer.php b/vendor/aws/Aws/Glacier/Model/MultipartUpload/ParallelTransfer.php new file mode 100644 index 0000000..8f6c0e0 --- /dev/null +++ b/vendor/aws/Aws/Glacier/Model/MultipartUpload/ParallelTransfer.php @@ -0,0 +1,75 @@ +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)); + } + } + } +} diff --git a/vendor/aws/Aws/Glacier/Model/MultipartUpload/SerialTransfer.php b/vendor/aws/Aws/Glacier/Model/MultipartUpload/SerialTransfer.php new file mode 100644 index 0000000..f23dfb1 --- /dev/null +++ b/vendor/aws/Aws/Glacier/Model/MultipartUpload/SerialTransfer.php @@ -0,0 +1,52 @@ +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); + } + } +} diff --git a/vendor/aws/Aws/Glacier/Model/MultipartUpload/TransferState.php b/vendor/aws/Aws/Glacier/Model/MultipartUpload/TransferState.php new file mode 100644 index 0000000..1d8e6a5 --- /dev/null +++ b/vendor/aws/Aws/Glacier/Model/MultipartUpload/TransferState.php @@ -0,0 +1,79 @@ +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 $this + */ + public function setPartGenerator(UploadPartGenerator $partGenerator) + { + $this->partGenerator = $partGenerator; + + return $this; + } + + /** + * @return UploadPartGenerator Glacier upload helper object + */ + public function getPartGenerator() + { + return $this->partGenerator; + } +} diff --git a/vendor/aws/Aws/Glacier/Model/MultipartUpload/UploadBuilder.php b/vendor/aws/Aws/Glacier/Model/MultipartUpload/UploadBuilder.php new file mode 100644 index 0000000..91ab0cf --- /dev/null +++ b/vendor/aws/Aws/Glacier/Model/MultipartUpload/UploadBuilder.php @@ -0,0 +1,218 @@ +accountId = $accountId; + + return $this; + } + + /** + * Set the vault name to upload the part to + * + * @param string $vaultName Name of the vault + * + * @return $this + */ + public function setVaultName($vaultName) + { + $this->vaultName = $vaultName; + + return $this; + } + + /** + * Set the upload part size + * + * @param int $partSize Upload part size + * + * @return $this + */ + public function setPartSize($partSize) + { + $this->partSize = (int) $partSize; + + return $this; + } + + /** + * Set the archive description + * + * @param string $archiveDescription Archive description + * + * @return $this + */ + 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 $this + */ + 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 $this + */ + 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; + } +} diff --git a/vendor/aws/Aws/Glacier/Model/MultipartUpload/UploadId.php b/vendor/aws/Aws/Glacier/Model/MultipartUpload/UploadId.php new file mode 100644 index 0000000..2b5a150 --- /dev/null +++ b/vendor/aws/Aws/Glacier/Model/MultipartUpload/UploadId.php @@ -0,0 +1,35 @@ + '-', + 'uploadId' => false, + 'vaultName' => false + ); +} diff --git a/vendor/aws/Aws/Glacier/Model/MultipartUpload/UploadPart.php b/vendor/aws/Aws/Glacier/Model/MultipartUpload/UploadPart.php new file mode 100644 index 0000000..ef79aac --- /dev/null +++ b/vendor/aws/Aws/Glacier/Model/MultipartUpload/UploadPart.php @@ -0,0 +1,110 @@ + '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}/*"; + } +} diff --git a/vendor/aws/Aws/Glacier/Model/MultipartUpload/UploadPartContext.php b/vendor/aws/Aws/Glacier/Model/MultipartUpload/UploadPartContext.php new file mode 100644 index 0000000..47076b9 --- /dev/null +++ b/vendor/aws/Aws/Glacier/Model/MultipartUpload/UploadPartContext.php @@ -0,0 +1,138 @@ +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 $this + * @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; + } +} diff --git a/vendor/aws/Aws/Glacier/Model/MultipartUpload/UploadPartGenerator.php b/vendor/aws/Aws/Glacier/Model/MultipartUpload/UploadPartGenerator.php new file mode 100644 index 0000000..49bfeda --- /dev/null +++ b/vendor/aws/Aws/Glacier/Model/MultipartUpload/UploadPartGenerator.php @@ -0,0 +1,279 @@ + 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(); + } +} diff --git a/vendor/aws/Aws/Glacier/Resources/glacier-2012-06-01.php b/vendor/aws/Aws/Glacier/Resources/glacier-2012-06-01.php new file mode 100644 index 0000000..c185380 --- /dev/null +++ b/vendor/aws/Aws/Glacier/Resources/glacier-2012-06-01.php @@ -0,0 +1,1588 @@ + '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', + ), + ), + ), + 'GetDataRetrievalPolicy' => array( + 'httpMethod' => 'GET', + 'uri' => '/{accountId}/policies/data-retrieval', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'GetDataRetrievalPolicyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'accountId' => 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', + ), + ), + ), + '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 retrieval job would exceed the current data policy\'s retrieval rate limit. For more information about data retrieval policies,', + 'class' => 'PolicyEnforcedException', + ), + 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', + ), + ), + ), + 'SetDataRetrievalPolicy' => array( + 'httpMethod' => 'PUT', + 'uri' => '/{accountId}/policies/data-retrieval', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'accountId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'Policy' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Rules' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'DataRetrievalRule', + 'type' => 'object', + 'properties' => array( + 'Strategy' => array( + 'type' => 'string', + ), + 'BytesPerHour' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + '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', + ), + ), + ), + 'GetDataRetrievalPolicyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Policy' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Rules' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'DataRetrievalRule', + 'type' => 'object', + 'properties' => array( + 'Strategy' => array( + 'type' => 'string', + ), + 'BytesPerHour' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + ), + 'iterators' => array( + 'ListJobs' => array( + 'input_token' => 'marker', + 'output_token' => 'Marker', + 'limit_key' => 'limit', + 'result_key' => 'JobList', + ), + 'ListMultipartUploads' => array( + 'input_token' => 'marker', + 'output_token' => 'Marker', + 'limit_key' => 'limit', + 'result_key' => 'UploadsList', + ), + 'ListParts' => array( + 'input_token' => 'marker', + 'output_token' => 'Marker', + 'limit_key' => 'limit', + 'result_key' => 'Parts', + ), + 'ListVaults' => array( + 'input_token' => 'marker', + 'output_token' => 'Marker', + 'limit_key' => 'limit', + 'result_key' => 'VaultList', + ), + ), + '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', + ), + ), +); diff --git a/vendor/aws/Aws/Iam/Enum/AssignmentStatusType.php b/vendor/aws/Aws/Iam/Enum/AssignmentStatusType.php new file mode 100644 index 0000000..c9d1c6a --- /dev/null +++ b/vendor/aws/Aws/Iam/Enum/AssignmentStatusType.php @@ -0,0 +1,29 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/iam-%s.php' + )) + ->build(); + } +} diff --git a/vendor/aws/Aws/Iam/Resources/iam-2010-05-08.php b/vendor/aws/Aws/Iam/Resources/iam-2010-05-08.php new file mode 100644 index 0000000..72309c4 --- /dev/null +++ b/vendor/aws/Aws/Iam/Resources/iam-2010-05-08.php @@ -0,0 +1,7301 @@ + '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( + 'AddClientIDToOpenIDConnectProvider' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'AddClientIDToOpenIDConnectProvider', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'OpenIDConnectProviderArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 20, + 'maxLength' => 2048, + ), + 'ClientID' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 255, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because an invalid or out-of-range value was supplied for an input parameter.', + 'class' => 'InvalidInputException', + ), + 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 processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + 'AttachGroupPolicy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'AttachGroupPolicy', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'GroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'PolicyArn' => 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( + '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 an invalid or out-of-range value was supplied for an input parameter.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + 'AttachRolePolicy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'AttachRolePolicy', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'RoleName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'PolicyArn' => 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( + '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 an invalid or out-of-range value was supplied for an input parameter.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + 'AttachUserPolicy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'AttachUserPolicy', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'UserName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'PolicyArn' => 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( + '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 an invalid or out-of-range value was supplied for an input parameter.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + 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 processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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, + ), + 'PasswordResetRequired' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + 'CreateOpenIDConnectProvider' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'CreateOpenIDConnectProviderResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateOpenIDConnectProvider', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'Url' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'ClientIDList' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'ClientIDList.member', + 'items' => array( + 'name' => 'clientIDType', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + ), + 'ThumbprintList' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'ThumbprintList.member', + 'items' => array( + 'name' => 'thumbprintType', + 'type' => 'string', + 'minLength' => 40, + 'maxLength' => 40, + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because an invalid or out-of-range value was supplied for an input parameter.', + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + 'CreatePolicy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'CreatePolicyResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreatePolicy', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'PolicyName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'Path' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'PolicyDocument' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 131072, + ), + 'Description' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'maxLength' => 1000, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because an invalid or out-of-range value was supplied for an input parameter.', + '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', + ), + 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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + 'CreatePolicyVersion' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'CreatePolicyVersionResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreatePolicyVersion', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'PolicyArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 20, + 'maxLength' => 2048, + ), + 'PolicyDocument' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 131072, + ), + 'SetAsDefault' => 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 an invalid or out-of-range value was supplied for an input parameter.', + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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( + 'reason' => 'The request was rejected because an invalid or out-of-range value was supplied for an input parameter.', + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + 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 processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + 'DeleteOpenIDConnectProvider' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteOpenIDConnectProvider', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'OpenIDConnectProviderArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 20, + 'maxLength' => 2048, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because an invalid or out-of-range value was supplied for an input parameter.', + 'class' => 'InvalidInputException', + ), + 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 processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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' => '2010-05-08', + ), + 'PolicyArn' => 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( + '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 an invalid or out-of-range value was supplied for an input parameter.', + 'class' => 'InvalidInputException', + ), + 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 processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + 'DeletePolicyVersion' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeletePolicyVersion', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'PolicyArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 20, + 'maxLength' => 2048, + ), + 'VersionId' => 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', + ), + array( + 'reason' => 'The request was rejected because an invalid or out-of-range value was supplied for an input parameter.', + 'class' => 'InvalidInputException', + ), + 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 processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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( + 'reason' => 'The request was rejected because an invalid or out-of-range value was supplied for an input parameter.', + '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', + ), + 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 processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + 'DetachGroupPolicy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DetachGroupPolicy', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'GroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'PolicyArn' => 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( + '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 an invalid or out-of-range value was supplied for an input parameter.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + 'DetachRolePolicy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DetachRolePolicy', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'RoleName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'PolicyArn' => 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( + '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 an invalid or out-of-range value was supplied for an input parameter.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + 'DetachUserPolicy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DetachUserPolicy', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'UserName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'PolicyArn' => 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( + '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 an invalid or out-of-range value was supplied for an input parameter.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + 'GenerateCredentialReport' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'GenerateCredentialReportResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'GenerateCredentialReport', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + ), + '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 processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + 'GetAccountAuthorizationDetails' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'GetAccountAuthorizationDetailsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'GetAccountAuthorizationDetails', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'Filter' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Filter.member', + 'items' => array( + 'name' => 'EntityType', + 'type' => 'string', + ), + ), + 'MaxItems' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + 'minimum' => 1, + 'maximum' => 1000, + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 320, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + 'GetCredentialReport' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'GetCredentialReportResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'GetCredentialReport', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because the credential report does not exist. To generate a credential report, use GenerateCredentialReport.', + 'class' => 'CredentialReportNotPresentException', + ), + array( + 'reason' => 'The request was rejected because the most recent credential report has expired. To generate a new credential report, use GenerateCredentialReport. For more information about credential report expiration, see Getting Credential Reports in the Using IAM guide.', + 'class' => 'CredentialReportExpiredException', + ), + array( + 'reason' => 'The request was rejected because the credential report is still being generated.', + 'class' => 'CredentialReportNotReadyException', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + 'GetOpenIDConnectProvider' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'GetOpenIDConnectProviderResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'GetOpenIDConnectProvider', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'OpenIDConnectProviderArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 20, + 'maxLength' => 2048, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because an invalid or out-of-range value was supplied for an input parameter.', + 'class' => 'InvalidInputException', + ), + 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 processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + 'GetPolicy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'GetPolicyResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'GetPolicy', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'PolicyArn' => 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( + 'reason' => 'The request was rejected because an invalid or out-of-range value was supplied for an input parameter.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + 'GetPolicyVersion' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'GetPolicyVersionResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'GetPolicyVersion', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'PolicyArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 20, + 'maxLength' => 2048, + ), + 'VersionId' => 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 an invalid or out-of-range value was supplied for an input parameter.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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( + 'reason' => 'The request was rejected because an invalid or out-of-range value was supplied for an input parameter.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + 'ListAttachedGroupPolicies' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListAttachedGroupPoliciesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListAttachedGroupPolicies', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'GroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'PathPrefix' => 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, + ), + ), + '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 an invalid or out-of-range value was supplied for an input parameter.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + 'ListAttachedRolePolicies' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListAttachedRolePoliciesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListAttachedRolePolicies', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'RoleName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'PathPrefix' => 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, + ), + ), + '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 an invalid or out-of-range value was supplied for an input parameter.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + 'ListAttachedUserPolicies' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListAttachedUserPoliciesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListAttachedUserPolicies', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'UserName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'PathPrefix' => 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, + ), + ), + '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 an invalid or out-of-range value was supplied for an input parameter.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + 'ListEntitiesForPolicy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListEntitiesForPolicyResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListEntitiesForPolicy', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'PolicyArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 20, + 'maxLength' => 2048, + ), + 'EntityFilter' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + '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, + ), + ), + '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 an invalid or out-of-range value was supplied for an input parameter.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + 'ListOpenIDConnectProviders' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListOpenIDConnectProvidersResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListOpenIDConnectProviders', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + 'ListPolicies' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListPoliciesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListPolicies', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'Scope' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'OnlyAttached' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'PathPrefix' => 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, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + 'ListPolicyVersions' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListPolicyVersionsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListPolicyVersions', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'PolicyArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 20, + 'maxLength' => 2048, + ), + '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', + ), + array( + 'reason' => 'The request was rejected because an invalid or out-of-range value was supplied for an input parameter.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + 'RemoveClientIDFromOpenIDConnectProvider' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'RemoveClientIDFromOpenIDConnectProvider', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'OpenIDConnectProviderArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 20, + 'maxLength' => 2048, + ), + 'ClientID' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 255, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because an invalid or out-of-range value was supplied for an input parameter.', + 'class' => 'InvalidInputException', + ), + 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 processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + 'SetDefaultPolicyVersion' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'SetDefaultPolicyVersion', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'PolicyArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 20, + 'maxLength' => 2048, + ), + 'VersionId' => 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 an invalid or out-of-range value was supplied for an input parameter.', + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + 'MaxPasswordAge' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + 'minimum' => 1, + 'maximum' => 1095, + ), + 'PasswordReusePrevention' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + 'minimum' => 1, + 'maximum' => 24, + ), + 'HardExpiry' => 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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'PasswordResetRequired' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + 'UpdateOpenIDConnectProviderThumbprint' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'UpdateOpenIDConnectProviderThumbprint', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'OpenIDConnectProviderArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 20, + 'maxLength' => 2048, + ), + 'ThumbprintList' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'ThumbprintList.member', + 'items' => array( + 'name' => 'thumbprintType', + 'type' => 'string', + 'minLength' => 40, + 'maxLength' => 40, + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because an invalid or out-of-range value was supplied for an input parameter.', + 'class' => 'InvalidInputException', + ), + 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 processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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( + 'reason' => 'The request was rejected because an invalid or out-of-range value was supplied for an input parameter.', + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The request processing has failed because of an unknown error, exception or failure.', + 'class' => 'ServiceFailureException', + ), + ), + ), + ), + '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', + ), + 'PasswordResetRequired' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + 'CreateOpenIDConnectProviderResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'OpenIDConnectProviderArn' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'CreatePolicyResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Policy' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'PolicyName' => array( + 'type' => 'string', + ), + 'PolicyId' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'Path' => array( + 'type' => 'string', + ), + 'DefaultVersionId' => array( + 'type' => 'string', + ), + 'AttachmentCount' => array( + 'type' => 'numeric', + ), + 'IsAttachable' => array( + 'type' => 'boolean', + ), + 'Description' => array( + 'type' => 'string', + ), + 'CreateDate' => array( + 'type' => 'string', + ), + 'UpdateDate' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'CreatePolicyVersionResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'PolicyVersion' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Document' => array( + 'type' => 'string', + ), + 'VersionId' => array( + 'type' => 'string', + ), + 'IsDefaultVersion' => array( + 'type' => 'boolean', + ), + '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', + ), + 'PasswordLastUsed' => 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', + ), + 'PasswordLastUsed' => array( + 'type' => 'string', + ), + ), + ), + 'EnableDate' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'GenerateCredentialReportResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'State' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'Description' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'GetAccountAuthorizationDetailsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'UserDetailList' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'UserDetail', + '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', + ), + 'UserPolicyList' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'PolicyDetail', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'PolicyName' => array( + 'type' => 'string', + ), + 'PolicyDocument' => array( + 'type' => 'string', + ), + ), + ), + ), + 'GroupList' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'groupNameType', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + 'AttachedManagedPolicies' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AttachedPolicy', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'PolicyName' => array( + 'type' => 'string', + ), + 'PolicyArn' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'GroupDetailList' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'GroupDetail', + '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', + ), + 'GroupPolicyList' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'PolicyDetail', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'PolicyName' => array( + 'type' => 'string', + ), + 'PolicyDocument' => array( + 'type' => 'string', + ), + ), + ), + ), + 'AttachedManagedPolicies' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AttachedPolicy', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'PolicyName' => array( + 'type' => 'string', + ), + 'PolicyArn' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'RoleDetailList' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'RoleDetail', + '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', + ), + 'InstanceProfileList' => array( + 'type' => 'array', + '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', + ), + ), + ), + ), + ), + ), + ), + 'RolePolicyList' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'PolicyDetail', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'PolicyName' => array( + 'type' => 'string', + ), + 'PolicyDocument' => array( + 'type' => 'string', + ), + ), + ), + ), + 'AttachedManagedPolicies' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AttachedPolicy', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'PolicyName' => array( + 'type' => 'string', + ), + 'PolicyArn' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'Policies' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'ManagedPolicyDetail', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'PolicyName' => array( + 'type' => 'string', + ), + 'PolicyId' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'Path' => array( + 'type' => 'string', + ), + 'DefaultVersionId' => array( + 'type' => 'string', + ), + 'AttachmentCount' => array( + 'type' => 'numeric', + ), + 'IsAttachable' => array( + 'type' => 'boolean', + ), + 'Description' => array( + 'type' => 'string', + ), + 'CreateDate' => array( + 'type' => 'string', + ), + 'UpdateDate' => array( + 'type' => 'string', + ), + 'PolicyVersionList' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'PolicyVersion', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Document' => array( + 'type' => 'string', + ), + 'VersionId' => array( + 'type' => 'string', + ), + 'IsDefaultVersion' => array( + 'type' => 'boolean', + ), + 'CreateDate' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'IsTruncated' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + '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', + ), + 'PasswordReusePrevention' => array( + 'type' => 'numeric', + ), + 'HardExpiry' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + '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', + 'AccountAccessKeysPresent', + 'AccountSigningCertificatesPresent', + 'AttachedPoliciesPerGroupQuota', + 'AttachedPoliciesPerRoleQuota', + 'AttachedPoliciesPerUserQuota', + 'Policies', + 'PoliciesQuota', + 'PolicySizeQuota', + 'PolicyVersionsInUse', + 'PolicyVersionsInUseQuota', + 'VersionsPerPolicyQuota', + ), + ), + '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, + ), + ), + ), + 'GetCredentialReportResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Content' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'ReportFormat' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'GeneratedTime' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + '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', + ), + 'PasswordLastUsed' => 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', + ), + 'PasswordResetRequired' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + 'GetOpenIDConnectProviderResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Url' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'ClientIDList' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'clientIDType', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + 'ThumbprintList' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'thumbprintType', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + 'CreateDate' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'GetPolicyResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Policy' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'PolicyName' => array( + 'type' => 'string', + ), + 'PolicyId' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'Path' => array( + 'type' => 'string', + ), + 'DefaultVersionId' => array( + 'type' => 'string', + ), + 'AttachmentCount' => array( + 'type' => 'numeric', + ), + 'IsAttachable' => array( + 'type' => 'boolean', + ), + 'Description' => array( + 'type' => 'string', + ), + 'CreateDate' => array( + 'type' => 'string', + ), + 'UpdateDate' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'GetPolicyVersionResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'PolicyVersion' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Document' => array( + 'type' => 'string', + ), + 'VersionId' => array( + 'type' => 'string', + ), + 'IsDefaultVersion' => array( + 'type' => 'boolean', + ), + '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', + ), + 'Expiration' => 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', + ), + 'PasswordLastUsed' => 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', + ), + ), + ), + 'ListAttachedGroupPoliciesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'AttachedPolicies' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'AttachedPolicy', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'PolicyName' => array( + 'type' => 'string', + ), + 'PolicyArn' => array( + 'type' => 'string', + ), + ), + ), + ), + 'IsTruncated' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'ListAttachedRolePoliciesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'AttachedPolicies' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'AttachedPolicy', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'PolicyName' => array( + 'type' => 'string', + ), + 'PolicyArn' => array( + 'type' => 'string', + ), + ), + ), + ), + 'IsTruncated' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'ListAttachedUserPoliciesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'AttachedPolicies' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'AttachedPolicy', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'PolicyName' => array( + 'type' => 'string', + ), + 'PolicyArn' => array( + 'type' => 'string', + ), + ), + ), + ), + 'IsTruncated' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'ListEntitiesForPolicyResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'PolicyGroups' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'PolicyGroup', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'GroupName' => array( + 'type' => 'string', + ), + ), + ), + ), + 'PolicyUsers' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'PolicyUser', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'UserName' => array( + 'type' => 'string', + ), + ), + ), + ), + 'PolicyRoles' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'PolicyRole', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'RoleName' => array( + 'type' => 'string', + ), + ), + ), + ), + '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', + ), + ), + ), + 'ListOpenIDConnectProvidersResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'OpenIDConnectProviderList' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'OpenIDConnectProviderListEntry', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Arn' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'ListPoliciesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Policies' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'Policy', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'PolicyName' => array( + 'type' => 'string', + ), + 'PolicyId' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'Path' => array( + 'type' => 'string', + ), + 'DefaultVersionId' => array( + 'type' => 'string', + ), + 'AttachmentCount' => array( + 'type' => 'numeric', + ), + 'IsAttachable' => array( + 'type' => 'boolean', + ), + 'Description' => array( + 'type' => 'string', + ), + 'CreateDate' => array( + 'type' => 'string', + ), + 'UpdateDate' => array( + 'type' => 'string', + ), + ), + ), + ), + 'IsTruncated' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'ListPolicyVersionsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Versions' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'PolicyVersion', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Document' => array( + 'type' => 'string', + ), + 'VersionId' => array( + 'type' => 'string', + ), + 'IsDefaultVersion' => array( + 'type' => 'boolean', + ), + 'CreateDate' => 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', + ), + 'Expiration' => 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', + ), + 'PasswordLastUsed' => 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', + ), + 'PasswordLastUsed' => 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', + ), + 'Expiration' => 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( + 'GetAccountAuthorizationDetails' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'more_results' => 'IsTruncated', + 'limit_key' => 'MaxItems', + 'result_key' => 'UserDetailList || GroupDetailList || RoleDetailList', + ), + 'GetGroup' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'more_results' => 'IsTruncated', + 'limit_key' => 'MaxItems', + 'result_key' => 'Users', + ), + 'ListAccessKeys' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'more_results' => 'IsTruncated', + 'limit_key' => 'MaxItems', + 'result_key' => 'AccessKeyMetadata', + ), + 'ListAccountAliases' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'more_results' => 'IsTruncated', + 'limit_key' => 'MaxItems', + 'result_key' => 'AccountAliases', + ), + 'ListGroupPolicies' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'more_results' => 'IsTruncated', + 'limit_key' => 'MaxItems', + 'result_key' => 'PolicyNames', + ), + 'ListGroups' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'more_results' => 'IsTruncated', + 'limit_key' => 'MaxItems', + 'result_key' => 'Groups', + ), + 'ListGroupsForUser' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'more_results' => 'IsTruncated', + 'limit_key' => 'MaxItems', + 'result_key' => 'Groups', + ), + 'ListInstanceProfiles' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'more_results' => 'IsTruncated', + 'limit_key' => 'MaxItems', + 'result_key' => 'InstanceProfiles', + ), + 'ListInstanceProfilesForRole' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'more_results' => 'IsTruncated', + 'limit_key' => 'MaxItems', + 'result_key' => 'InstanceProfiles', + ), + 'ListMFADevices' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'more_results' => 'IsTruncated', + 'limit_key' => 'MaxItems', + 'result_key' => 'MFADevices', + ), + 'ListRolePolicies' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'more_results' => 'IsTruncated', + 'limit_key' => 'MaxItems', + 'result_key' => 'PolicyNames', + ), + 'ListRoles' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'more_results' => 'IsTruncated', + 'limit_key' => 'MaxItems', + 'result_key' => 'Roles', + ), + 'ListSAMLProviders' => array( + 'result_key' => 'SAMLProviderList', + ), + 'ListServerCertificates' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'more_results' => 'IsTruncated', + 'limit_key' => 'MaxItems', + 'result_key' => 'ServerCertificateMetadataList', + ), + 'ListSigningCertificates' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'more_results' => 'IsTruncated', + 'limit_key' => 'MaxItems', + 'result_key' => 'Certificates', + ), + 'ListUserPolicies' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'more_results' => 'IsTruncated', + 'limit_key' => 'MaxItems', + 'result_key' => 'PolicyNames', + ), + 'ListUsers' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'more_results' => 'IsTruncated', + 'limit_key' => 'MaxItems', + 'result_key' => 'Users', + ), + 'ListVirtualMFADevices' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'more_results' => 'IsTruncated', + 'limit_key' => 'MaxItems', + 'result_key' => 'VirtualMFADevices', + ), + ), +); diff --git a/vendor/aws/Aws/ImportExport/Enum/JobType.php b/vendor/aws/Aws/ImportExport/Enum/JobType.php new file mode 100644 index 0000000..9ae85ae --- /dev/null +++ b/vendor/aws/Aws/ImportExport/Enum/JobType.php @@ -0,0 +1,28 @@ +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; + } +} diff --git a/vendor/aws/Aws/ImportExport/JobManifestListener.php b/vendor/aws/Aws/ImportExport/JobManifestListener.php new file mode 100644 index 0000000..d6afc41 --- /dev/null +++ b/vendor/aws/Aws/ImportExport/JobManifestListener.php @@ -0,0 +1,51 @@ + 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)); + } + } + } +} diff --git a/vendor/aws/Aws/ImportExport/Resources/importexport-2010-06-01.php b/vendor/aws/Aws/ImportExport/Resources/importexport-2010-06-01.php new file mode 100644 index 0000000..4e822d2 --- /dev/null +++ b/vendor/aws/Aws/ImportExport/Resources/importexport-2010-06-01.php @@ -0,0 +1,774 @@ + '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', + ), + 'APIVersion' => array( + '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', + ), + array( + 'reason' => 'The client tool version is invalid.', + 'class' => 'InvalidVersionException', + ), + ), + ), + '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', + ), + 'APIVersion' => array( + 'type' => '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' => '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', + ), + array( + 'reason' => 'Each account can create only a certain number of jobs per day. If you need to create more than this, please contact awsimportexport@amazon.com to explain your particular use case.', + 'class' => 'CreateJobQuotaExceededException', + ), + array( + 'reason' => 'The JOBID was missing, not found, or not associated with the AWS account.', + 'class' => 'InvalidJobIdException', + ), + array( + 'reason' => 'The client tool version is invalid.', + 'class' => 'InvalidVersionException', + ), + ), + ), + 'GetShippingLabel' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'GetShippingLabelOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'GetShippingLabel', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-06-01', + ), + 'jobIds' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'jobIds.member', + 'items' => array( + 'name' => 'GenericString', + 'type' => 'string', + ), + ), + 'name' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'company' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'phoneNumber' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'country' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'stateOrProvince' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'city' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'postalCode' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'street1' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'street2' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'street3' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'APIVersion' => array( + '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', + ), + array( + 'reason' => 'The address specified in the manifest is invalid.', + 'class' => 'InvalidAddressException', + ), + array( + 'reason' => 'The client tool version is invalid.', + 'class' => 'InvalidVersionException', + ), + array( + 'reason' => 'One or more parameters had an invalid value.', + 'class' => 'InvalidParameterException', + ), + ), + ), + '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', + ), + 'APIVersion' => array( + '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', + ), + array( + 'reason' => 'The client tool version is invalid.', + 'class' => 'InvalidVersionException', + ), + ), + ), + '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', + ), + 'APIVersion' => 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', + ), + array( + 'reason' => 'The client tool version is invalid.', + 'class' => 'InvalidVersionException', + ), + ), + ), + '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', + ), + 'APIVersion' => array( + 'type' => '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', + ), + array( + 'reason' => 'AWS Import/Export cannot update the job', + 'class' => 'UnableToUpdateJobIdException', + ), + array( + 'reason' => 'The client tool version is invalid.', + 'class' => 'InvalidVersionException', + ), + ), + ), + ), + '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', + ), + 'Signature' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'SignatureFileContents' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'WarningMessage' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'ArtifactList' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'Artifact', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Description' => array( + 'type' => 'string', + ), + 'URL' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'GetShippingLabelOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ShippingLabelURL' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'Warning' => 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', + ), + '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', + ), + 'ArtifactList' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'Artifact', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Description' => array( + 'type' => 'string', + ), + 'URL' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + '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', + ), + 'ArtifactList' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'Artifact', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Description' => array( + 'type' => 'string', + ), + 'URL' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'iterators' => array( + 'ListJobs' => array( + 'input_token' => 'Marker', + 'output_token' => 'Jobs/#/JobId', + 'more_results' => 'IsTruncated', + 'limit_key' => 'MaxJobs', + 'result_key' => 'Jobs', + ), + ), +); diff --git a/vendor/aws/Aws/Kinesis/Enum/ShardIteratorType.php b/vendor/aws/Aws/Kinesis/Enum/ShardIteratorType.php new file mode 100644 index 0000000..58af9f5 --- /dev/null +++ b/vendor/aws/Aws/Kinesis/Enum/ShardIteratorType.php @@ -0,0 +1,30 @@ +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); + } + } +} diff --git a/vendor/aws/Aws/Kinesis/Resources/kinesis-2013-12-02.php b/vendor/aws/Aws/Kinesis/Resources/kinesis-2013-12-02.php new file mode 100644 index 0000000..a1e70c1 --- /dev/null +++ b/vendor/aws/Aws/Kinesis/Resources/kinesis-2013-12-02.php @@ -0,0 +1,1015 @@ + '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', + ), + 'us-west-2' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'kinesis.us-west-2.amazonaws.com', + ), + 'eu-west-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'kinesis.eu-west-1.amazonaws.com', + ), + 'ap-northeast-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'kinesis.ap-northeast-1.amazonaws.com', + ), + 'ap-southeast-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'kinesis.ap-southeast-1.amazonaws.com', + ), + 'ap-southeast-2' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'kinesis.ap-southeast-2.amazonaws.com', + ), + ), + 'operations' => array( + 'AddTagsToStream' => 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.AddTagsToStream', + ), + 'StreamName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'Tags' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'string', + 'maxLength' => 256, + 'data' => array( + 'shape_name' => 'TagKey', + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The requested resource could not be found. It might not be specified correctly, or it might not be in the ACTIVE state.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'The resource is not available for this operation. For example, you attempted to split a shard but the stream is not in the ACTIVE state.', + 'class' => 'ResourceInUseException', + ), + array( + 'reason' => 'A specified parameter exceeds its restrictions, is not supported, or can\'t be used. For more information, see the returned message.', + 'class' => 'InvalidArgumentException', + ), + array( + 'reason' => 'The requested resource exceeds the maximum number allowed, or the number of concurrent stream requests exceeds the maximum number allowed (5).', + 'class' => 'LimitExceededException', + ), + ), + ), + '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( + 'reason' => 'The resource is not available for this operation. For example, you attempted to split a shard but the stream is not in the ACTIVE state.', + 'class' => 'ResourceInUseException', + ), + array( + 'reason' => 'The requested resource exceeds the maximum number allowed, or the number of concurrent stream requests exceeds the maximum number allowed (5).', + 'class' => 'LimitExceededException', + ), + array( + 'reason' => 'A specified parameter exceeds its restrictions, is not supported, or can\'t be used. For more information, see the returned message.', + '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( + 'reason' => 'The requested resource could not be found. It might not be specified correctly, or it might not be in the ACTIVE state.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'The requested resource exceeds the maximum number allowed, or the number of concurrent stream requests exceeds the maximum number allowed (5).', + '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( + 'reason' => 'The requested resource could not be found. It might not be specified correctly, or it might not be in the ACTIVE state.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'The requested resource exceeds the maximum number allowed, or the number of concurrent stream requests exceeds the maximum number allowed (5).', + '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( + 'reason' => 'The requested resource could not be found. It might not be specified correctly, or it might not be in the ACTIVE state.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'A specified parameter exceeds its restrictions, is not supported, or can\'t be used. For more information, see the returned message.', + 'class' => 'InvalidArgumentException', + ), + array( + 'reason' => 'The request rate is too high, or the requested data is too large for the available throughput. Reduce the frequency or size of your requests. For more information, see Error Retries and Exponential Backoff in AWS in the AWS General Reference.', + 'class' => 'ProvisionedThroughputExceededException', + ), + array( + 'reason' => 'The provided iterator exceeds the maximum age allowed.', + '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( + 'reason' => 'The requested resource could not be found. It might not be specified correctly, or it might not be in the ACTIVE state.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'A specified parameter exceeds its restrictions, is not supported, or can\'t be used. For more information, see the returned message.', + 'class' => 'InvalidArgumentException', + ), + array( + 'reason' => 'The request rate is too high, or the requested data is too large for the available throughput. Reduce the frequency or size of your requests. For more information, see Error Retries and Exponential Backoff in AWS in the AWS General Reference.', + '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( + 'reason' => 'The requested resource exceeds the maximum number allowed, or the number of concurrent stream requests exceeds the maximum number allowed (5).', + 'class' => 'LimitExceededException', + ), + ), + ), + 'ListTagsForStream' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListTagsForStreamOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + '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.ListTagsForStream', + ), + 'StreamName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'ExclusiveStartTagKey' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'Limit' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 10, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The requested resource could not be found. It might not be specified correctly, or it might not be in the ACTIVE state.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'A specified parameter exceeds its restrictions, is not supported, or can\'t be used. For more information, see the returned message.', + 'class' => 'InvalidArgumentException', + ), + array( + 'reason' => 'The requested resource exceeds the maximum number allowed, or the number of concurrent stream requests exceeds the maximum number allowed (5).', + '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( + 'reason' => 'The requested resource could not be found. It might not be specified correctly, or it might not be in the ACTIVE state.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'The resource is not available for this operation. For example, you attempted to split a shard but the stream is not in the ACTIVE state.', + 'class' => 'ResourceInUseException', + ), + array( + 'reason' => 'A specified parameter exceeds its restrictions, is not supported, or can\'t be used. For more information, see the returned message.', + 'class' => 'InvalidArgumentException', + ), + array( + 'reason' => 'The requested resource exceeds the maximum number allowed, or the number of concurrent stream requests exceeds the maximum number allowed (5).', + '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( + 'reason' => 'The requested resource could not be found. It might not be specified correctly, or it might not be in the ACTIVE state.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'A specified parameter exceeds its restrictions, is not supported, or can\'t be used. For more information, see the returned message.', + 'class' => 'InvalidArgumentException', + ), + array( + 'reason' => 'The request rate is too high, or the requested data is too large for the available throughput. Reduce the frequency or size of your requests. For more information, see Error Retries and Exponential Backoff in AWS in the AWS General Reference.', + 'class' => 'ProvisionedThroughputExceededException', + ), + ), + ), + 'PutRecords' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'PutRecordsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + '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.PutRecords', + ), + 'Records' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'minItems' => 1, + 'maxItems' => 500, + 'items' => array( + 'name' => 'PutRecordsRequestEntry', + 'type' => 'object', + 'properties' => array( + 'Data' => array( + 'required' => true, + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + 'ExplicitHashKey' => array( + 'type' => 'string', + ), + 'PartitionKey' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + ), + ), + ), + 'StreamName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The requested resource could not be found. It might not be specified correctly, or it might not be in the ACTIVE state.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'A specified parameter exceeds its restrictions, is not supported, or can\'t be used. For more information, see the returned message.', + 'class' => 'InvalidArgumentException', + ), + array( + 'reason' => 'The request rate is too high, or the requested data is too large for the available throughput. Reduce the frequency or size of your requests. For more information, see Error Retries and Exponential Backoff in AWS in the AWS General Reference.', + 'class' => 'ProvisionedThroughputExceededException', + ), + ), + ), + 'RemoveTagsFromStream' => 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.RemoveTagsFromStream', + ), + 'StreamName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'TagKeys' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'minItems' => 1, + 'maxItems' => 10, + 'items' => array( + 'name' => 'TagKey', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The requested resource could not be found. It might not be specified correctly, or it might not be in the ACTIVE state.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'The resource is not available for this operation. For example, you attempted to split a shard but the stream is not in the ACTIVE state.', + 'class' => 'ResourceInUseException', + ), + array( + 'reason' => 'A specified parameter exceeds its restrictions, is not supported, or can\'t be used. For more information, see the returned message.', + 'class' => 'InvalidArgumentException', + ), + array( + 'reason' => 'The requested resource exceeds the maximum number allowed, or the number of concurrent stream requests exceeds the maximum number allowed (5).', + 'class' => 'LimitExceededException', + ), + ), + ), + '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( + 'reason' => 'The requested resource could not be found. It might not be specified correctly, or it might not be in the ACTIVE state.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'The resource is not available for this operation. For example, you attempted to split a shard but the stream is not in the ACTIVE state.', + 'class' => 'ResourceInUseException', + ), + array( + 'reason' => 'A specified parameter exceeds its restrictions, is not supported, or can\'t be used. For more information, see the returned message.', + 'class' => 'InvalidArgumentException', + ), + array( + 'reason' => 'The requested resource exceeds the maximum number allowed, or the number of concurrent stream requests exceeds the maximum number allowed (5).', + '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', + ), + ), + ), + 'ListTagsForStreamOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Tags' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + ), + ), + ), + 'HasMoreTags' => 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', + ), + ), + ), + 'PutRecordsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'FailedRecordCount' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'Records' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'PutRecordsResultEntry', + 'type' => 'object', + 'properties' => array( + 'SequenceNumber' => array( + 'type' => 'string', + ), + 'ShardId' => array( + 'type' => 'string', + ), + 'ErrorCode' => array( + 'type' => 'string', + ), + 'ErrorMessage' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'iterators' => array( + 'DescribeStream' => array( + 'input_token' => 'ExclusiveStartShardId', + 'limit_key' => 'Limit', + 'more_results' => 'StreamDescription/HasMoreShards', + 'output_token' => 'StreamDescription/Shards/#/ShardId', + 'result_key' => 'StreamDescription/Shards', + ), + 'ListStreams' => array( + 'input_token' => 'ExclusiveStartStreamName', + 'limit_key' => 'Limit', + 'more_results' => 'HasMoreStreams', + 'output_token' => 'StreamNames/#', + 'result_key' => 'StreamNames', + ), + ), +); diff --git a/vendor/aws/Aws/Kms/Exception/KmsException.php b/vendor/aws/Aws/Kms/Exception/KmsException.php new file mode 100644 index 0000000..4de7bd1 --- /dev/null +++ b/vendor/aws/Aws/Kms/Exception/KmsException.php @@ -0,0 +1,10 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/kms-%s.php' + )) + ->setExceptionParser(new JsonQueryExceptionParser) + ->build(); + } +} diff --git a/vendor/aws/Aws/Kms/Resources/kms-2014-11-01.php b/vendor/aws/Aws/Kms/Resources/kms-2014-11-01.php new file mode 100644 index 0000000..967c2c9 --- /dev/null +++ b/vendor/aws/Aws/Kms/Resources/kms-2014-11-01.php @@ -0,0 +1,1951 @@ + '2014-11-01', + 'endpointPrefix' => 'kms', + 'serviceFullName' => 'AWS Key Management Service', + 'serviceAbbreviation' => 'KMS', + 'serviceType' => 'json', + 'jsonVersion' => '1.1', + 'targetPrefix' => 'TrentService.', + 'signatureVersion' => 'v4', + 'namespace' => 'Kms', + 'operations' => array( + 'CreateAlias' => 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' => 'TrentService.CreateAlias', + ), + 'AliasName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'TargetKeyId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The system timed out while trying to fulfill the request.', + 'class' => 'DependencyTimeoutException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', + 'class' => 'AlreadyExistsException', + ), + array( + 'reason' => 'The request was rejected because the specified entity or resource could not be found.', + 'class' => 'NotFoundException', + ), + array( + 'reason' => 'The request was rejected because the specified alias name is not valid.', + 'class' => 'InvalidAliasNameException', + ), + array( + 'reason' => 'The request was rejected because an internal exception occurred. This error can be retried.', + 'class' => 'KMSInternalException', + ), + array( + 'reason' => 'The request was rejected because a quota was exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'CreateGrant' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'CreateGrantResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'TrentService.CreateGrant', + ), + 'KeyId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'GranteePrincipal' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'RetiringPrincipal' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'Operations' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'GrantOperation', + 'type' => 'string', + ), + ), + 'Constraints' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'EncryptionContextSubset' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'string', + 'data' => array( + 'shape_name' => 'EncryptionContextKey', + ), + ), + ), + 'EncryptionContextEquals' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'string', + 'data' => array( + 'shape_name' => 'EncryptionContextKey', + ), + ), + ), + ), + ), + 'GrantTokens' => array( + 'type' => 'array', + 'location' => 'json', + 'maxItems' => 10, + 'items' => array( + 'name' => 'GrantTokenType', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 8192, + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because the specified entity or resource could not be found.', + 'class' => 'NotFoundException', + ), + array( + 'reason' => 'A request was rejected because the specified key was marked as disabled.', + 'class' => 'DisabledException', + ), + array( + 'reason' => 'The system timed out while trying to fulfill the request.', + 'class' => 'DependencyTimeoutException', + ), + array( + 'reason' => 'The request was rejected because a specified ARN was not valid.', + 'class' => 'InvalidArnException', + ), + array( + 'reason' => 'The request was rejected because an internal exception occurred. This error can be retried.', + 'class' => 'KMSInternalException', + ), + array( + 'reason' => 'A grant token provided as part of the request is invalid.', + 'class' => 'InvalidGrantTokenException', + ), + array( + 'reason' => 'The request was rejected because a quota was exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'CreateKey' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'CreateKeyResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'TrentService.CreateKey', + ), + 'Policy' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 131072, + ), + 'Description' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 8192, + ), + 'KeyUsage' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because the specified policy is not syntactically or semantically correct.', + 'class' => 'MalformedPolicyDocumentException', + ), + array( + 'reason' => 'The system timed out while trying to fulfill the request.', + 'class' => 'DependencyTimeoutException', + ), + array( + 'reason' => 'The request was rejected because a specified ARN was not valid.', + 'class' => 'InvalidArnException', + ), + array( + 'reason' => 'The request was rejected because a specified parameter is not supported.', + 'class' => 'UnsupportedOperationException', + ), + array( + 'reason' => 'The request was rejected because an internal exception occurred. This error can be retried.', + 'class' => 'KMSInternalException', + ), + array( + 'reason' => 'The request was rejected because a quota was exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'Decrypt' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DecryptResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'TrentService.Decrypt', + ), + 'CiphertextBlob' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'filters' => array( + 'base64_encode', + ), + ), + 'EncryptionContext' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'string', + 'data' => array( + 'shape_name' => 'EncryptionContextKey', + ), + ), + ), + 'GrantTokens' => array( + 'type' => 'array', + 'location' => 'json', + 'maxItems' => 10, + 'items' => array( + 'name' => 'GrantTokenType', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 8192, + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because the specified entity or resource could not be found.', + 'class' => 'NotFoundException', + ), + array( + 'reason' => 'A request was rejected because the specified key was marked as disabled.', + 'class' => 'DisabledException', + ), + array( + 'reason' => 'The request was rejected because the specified ciphertext has been corrupted or is otherwise invalid.', + 'class' => 'InvalidCiphertextException', + ), + array( + 'reason' => 'The request was rejected because the key was disabled, not found, or otherwise not available.', + 'class' => 'KeyUnavailableException', + ), + array( + 'reason' => 'The system timed out while trying to fulfill the request.', + 'class' => 'DependencyTimeoutException', + ), + array( + 'reason' => 'A grant token provided as part of the request is invalid.', + 'class' => 'InvalidGrantTokenException', + ), + array( + 'reason' => 'The request was rejected because an internal exception occurred. This error can be retried.', + 'class' => 'KMSInternalException', + ), + ), + ), + 'DeleteAlias' => 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' => 'TrentService.DeleteAlias', + ), + 'AliasName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The system timed out while trying to fulfill the request.', + 'class' => 'DependencyTimeoutException', + ), + array( + 'reason' => 'The request was rejected because the specified entity or resource could not be found.', + 'class' => 'NotFoundException', + ), + array( + 'reason' => 'The request was rejected because an internal exception occurred. This error can be retried.', + 'class' => 'KMSInternalException', + ), + ), + ), + 'DescribeKey' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeKeyResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'TrentService.DescribeKey', + ), + 'KeyId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because the specified entity or resource could not be found.', + 'class' => 'NotFoundException', + ), + array( + 'reason' => 'The request was rejected because a specified ARN was not valid.', + 'class' => 'InvalidArnException', + ), + array( + 'reason' => 'The system timed out while trying to fulfill the request.', + 'class' => 'DependencyTimeoutException', + ), + array( + 'reason' => 'The request was rejected because an internal exception occurred. This error can be retried.', + 'class' => 'KMSInternalException', + ), + ), + ), + 'DisableKey' => 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' => 'TrentService.DisableKey', + ), + 'KeyId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because the specified entity or resource could not be found.', + 'class' => 'NotFoundException', + ), + array( + 'reason' => 'The request was rejected because a specified ARN was not valid.', + 'class' => 'InvalidArnException', + ), + array( + 'reason' => 'The system timed out while trying to fulfill the request.', + 'class' => 'DependencyTimeoutException', + ), + array( + 'reason' => 'The request was rejected because an internal exception occurred. This error can be retried.', + 'class' => 'KMSInternalException', + ), + ), + ), + 'DisableKeyRotation' => 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' => 'TrentService.DisableKeyRotation', + ), + 'KeyId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because the specified entity or resource could not be found.', + 'class' => 'NotFoundException', + ), + array( + 'reason' => 'The request was rejected because a specified ARN was not valid.', + 'class' => 'InvalidArnException', + ), + array( + 'reason' => 'The system timed out while trying to fulfill the request.', + 'class' => 'DependencyTimeoutException', + ), + array( + 'reason' => 'The request was rejected because an internal exception occurred. This error can be retried.', + 'class' => 'KMSInternalException', + ), + ), + ), + 'EnableKey' => 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' => 'TrentService.EnableKey', + ), + 'KeyId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because the specified entity or resource could not be found.', + 'class' => 'NotFoundException', + ), + array( + 'reason' => 'The request was rejected because a specified ARN was not valid.', + 'class' => 'InvalidArnException', + ), + array( + 'reason' => 'The system timed out while trying to fulfill the request.', + 'class' => 'DependencyTimeoutException', + ), + array( + 'reason' => 'The request was rejected because an internal exception occurred. This error can be retried.', + 'class' => 'KMSInternalException', + ), + array( + 'reason' => 'The request was rejected because a quota was exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'EnableKeyRotation' => 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' => 'TrentService.EnableKeyRotation', + ), + 'KeyId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because the specified entity or resource could not be found.', + 'class' => 'NotFoundException', + ), + array( + 'reason' => 'The request was rejected because a specified ARN was not valid.', + 'class' => 'InvalidArnException', + ), + array( + 'reason' => 'The system timed out while trying to fulfill the request.', + 'class' => 'DependencyTimeoutException', + ), + array( + 'reason' => 'The request was rejected because an internal exception occurred. This error can be retried.', + 'class' => 'KMSInternalException', + ), + ), + ), + 'Encrypt' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'EncryptResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'TrentService.Encrypt', + ), + 'KeyId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'Plaintext' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'filters' => array( + 'base64_encode', + ), + ), + 'EncryptionContext' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'string', + 'data' => array( + 'shape_name' => 'EncryptionContextKey', + ), + ), + ), + 'GrantTokens' => array( + 'type' => 'array', + 'location' => 'json', + 'maxItems' => 10, + 'items' => array( + 'name' => 'GrantTokenType', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 8192, + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because the specified entity or resource could not be found.', + 'class' => 'NotFoundException', + ), + array( + 'reason' => 'A request was rejected because the specified key was marked as disabled.', + 'class' => 'DisabledException', + ), + array( + 'reason' => 'The request was rejected because the key was disabled, not found, or otherwise not available.', + 'class' => 'KeyUnavailableException', + ), + array( + 'reason' => 'The system timed out while trying to fulfill the request.', + 'class' => 'DependencyTimeoutException', + ), + array( + 'reason' => 'The request was rejected because the specified KeySpec parameter is not valid. The currently supported value is ENCRYPT/DECRYPT.', + 'class' => 'InvalidKeyUsageException', + ), + array( + 'reason' => 'A grant token provided as part of the request is invalid.', + 'class' => 'InvalidGrantTokenException', + ), + array( + 'reason' => 'The request was rejected because an internal exception occurred. This error can be retried.', + 'class' => 'KMSInternalException', + ), + ), + ), + 'GenerateDataKey' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GenerateDataKeyResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'TrentService.GenerateDataKey', + ), + 'KeyId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'EncryptionContext' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'string', + 'data' => array( + 'shape_name' => 'EncryptionContextKey', + ), + ), + ), + 'NumberOfBytes' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 1024, + ), + 'KeySpec' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'GrantTokens' => array( + 'type' => 'array', + 'location' => 'json', + 'maxItems' => 10, + 'items' => array( + 'name' => 'GrantTokenType', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 8192, + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because the specified entity or resource could not be found.', + 'class' => 'NotFoundException', + ), + array( + 'reason' => 'A request was rejected because the specified key was marked as disabled.', + 'class' => 'DisabledException', + ), + array( + 'reason' => 'The request was rejected because the key was disabled, not found, or otherwise not available.', + 'class' => 'KeyUnavailableException', + ), + array( + 'reason' => 'The system timed out while trying to fulfill the request.', + 'class' => 'DependencyTimeoutException', + ), + array( + 'reason' => 'The request was rejected because the specified KeySpec parameter is not valid. The currently supported value is ENCRYPT/DECRYPT.', + 'class' => 'InvalidKeyUsageException', + ), + array( + 'reason' => 'A grant token provided as part of the request is invalid.', + 'class' => 'InvalidGrantTokenException', + ), + array( + 'reason' => 'The request was rejected because an internal exception occurred. This error can be retried.', + 'class' => 'KMSInternalException', + ), + ), + ), + 'GenerateDataKeyWithoutPlaintext' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GenerateDataKeyWithoutPlaintextResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'TrentService.GenerateDataKeyWithoutPlaintext', + ), + 'KeyId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'EncryptionContext' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'string', + 'data' => array( + 'shape_name' => 'EncryptionContextKey', + ), + ), + ), + 'KeySpec' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'NumberOfBytes' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 1024, + ), + 'GrantTokens' => array( + 'type' => 'array', + 'location' => 'json', + 'maxItems' => 10, + 'items' => array( + 'name' => 'GrantTokenType', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 8192, + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because the specified entity or resource could not be found.', + 'class' => 'NotFoundException', + ), + array( + 'reason' => 'A request was rejected because the specified key was marked as disabled.', + 'class' => 'DisabledException', + ), + array( + 'reason' => 'The request was rejected because the key was disabled, not found, or otherwise not available.', + 'class' => 'KeyUnavailableException', + ), + array( + 'reason' => 'The system timed out while trying to fulfill the request.', + 'class' => 'DependencyTimeoutException', + ), + array( + 'reason' => 'The request was rejected because the specified KeySpec parameter is not valid. The currently supported value is ENCRYPT/DECRYPT.', + 'class' => 'InvalidKeyUsageException', + ), + array( + 'reason' => 'A grant token provided as part of the request is invalid.', + 'class' => 'InvalidGrantTokenException', + ), + array( + 'reason' => 'The request was rejected because an internal exception occurred. This error can be retried.', + 'class' => 'KMSInternalException', + ), + ), + ), + 'GenerateRandom' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GenerateRandomResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'TrentService.GenerateRandom', + ), + 'NumberOfBytes' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 1024, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The system timed out while trying to fulfill the request.', + 'class' => 'DependencyTimeoutException', + ), + array( + 'reason' => 'The request was rejected because an internal exception occurred. This error can be retried.', + 'class' => 'KMSInternalException', + ), + ), + ), + 'GetKeyPolicy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GetKeyPolicyResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'TrentService.GetKeyPolicy', + ), + 'KeyId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'PolicyName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because the specified entity or resource could not be found.', + 'class' => 'NotFoundException', + ), + array( + 'reason' => 'The request was rejected because a specified ARN was not valid.', + 'class' => 'InvalidArnException', + ), + array( + 'reason' => 'The system timed out while trying to fulfill the request.', + 'class' => 'DependencyTimeoutException', + ), + array( + 'reason' => 'The request was rejected because an internal exception occurred. This error can be retried.', + 'class' => 'KMSInternalException', + ), + ), + ), + 'GetKeyRotationStatus' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GetKeyRotationStatusResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'TrentService.GetKeyRotationStatus', + ), + 'KeyId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because the specified entity or resource could not be found.', + 'class' => 'NotFoundException', + ), + array( + 'reason' => 'The request was rejected because a specified ARN was not valid.', + 'class' => 'InvalidArnException', + ), + array( + 'reason' => 'The system timed out while trying to fulfill the request.', + 'class' => 'DependencyTimeoutException', + ), + array( + 'reason' => 'The request was rejected because an internal exception occurred. This error can be retried.', + 'class' => 'KMSInternalException', + ), + ), + ), + 'ListAliases' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListAliasesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'TrentService.ListAliases', + ), + 'Limit' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 1000, + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 320, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The system timed out while trying to fulfill the request.', + 'class' => 'DependencyTimeoutException', + ), + array( + 'reason' => 'The request was rejected because an internal exception occurred. This error can be retried.', + 'class' => 'KMSInternalException', + ), + ), + ), + 'ListGrants' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListGrantsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'TrentService.ListGrants', + ), + 'KeyId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'Limit' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 1000, + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 320, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The system timed out while trying to fulfill the request.', + 'class' => 'DependencyTimeoutException', + ), + array( + 'reason' => 'The request was rejected because the marker that specifies where pagination should next begin is not valid.', + 'class' => 'InvalidMarkerException', + ), + array( + 'reason' => 'The request was rejected because an internal exception occurred. This error can be retried.', + 'class' => 'KMSInternalException', + ), + ), + ), + 'ListKeyPolicies' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListKeyPoliciesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'TrentService.ListKeyPolicies', + ), + 'KeyId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'Limit' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 1000, + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 320, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because the specified entity or resource could not be found.', + 'class' => 'NotFoundException', + ), + array( + 'reason' => 'The request was rejected because a specified ARN was not valid.', + 'class' => 'InvalidArnException', + ), + array( + 'reason' => 'The system timed out while trying to fulfill the request.', + 'class' => 'DependencyTimeoutException', + ), + array( + 'reason' => 'The request was rejected because an internal exception occurred. This error can be retried.', + 'class' => 'KMSInternalException', + ), + ), + ), + 'ListKeys' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListKeysResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'TrentService.ListKeys', + ), + 'Limit' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 1000, + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 320, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The system timed out while trying to fulfill the request.', + 'class' => 'DependencyTimeoutException', + ), + array( + 'reason' => 'The request was rejected because an internal exception occurred. This error can be retried.', + 'class' => 'KMSInternalException', + ), + ), + ), + 'PutKeyPolicy' => 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' => 'TrentService.PutKeyPolicy', + ), + 'KeyId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'PolicyName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'Policy' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 131072, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because the specified entity or resource could not be found.', + 'class' => 'NotFoundException', + ), + array( + 'reason' => 'The request was rejected because a specified ARN was not valid.', + 'class' => 'InvalidArnException', + ), + array( + 'reason' => 'The request was rejected because the specified policy is not syntactically or semantically correct.', + 'class' => 'MalformedPolicyDocumentException', + ), + array( + 'reason' => 'The system timed out while trying to fulfill the request.', + 'class' => 'DependencyTimeoutException', + ), + array( + 'reason' => 'The request was rejected because a specified ARN was not valid.', + 'class' => 'InvalidArnException', + ), + array( + 'reason' => 'The request was rejected because a specified parameter is not supported.', + 'class' => 'UnsupportedOperationException', + ), + array( + 'reason' => 'The request was rejected because an internal exception occurred. This error can be retried.', + 'class' => 'KMSInternalException', + ), + array( + 'reason' => 'The request was rejected because a quota was exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'ReEncrypt' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ReEncryptResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'TrentService.ReEncrypt', + ), + 'CiphertextBlob' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'filters' => array( + 'base64_encode', + ), + ), + 'SourceEncryptionContext' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'string', + 'data' => array( + 'shape_name' => 'EncryptionContextKey', + ), + ), + ), + 'DestinationKeyId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'DestinationEncryptionContext' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'string', + 'data' => array( + 'shape_name' => 'EncryptionContextKey', + ), + ), + ), + 'GrantTokens' => array( + 'type' => 'array', + 'location' => 'json', + 'maxItems' => 10, + 'items' => array( + 'name' => 'GrantTokenType', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 8192, + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because the specified entity or resource could not be found.', + 'class' => 'NotFoundException', + ), + array( + 'reason' => 'A request was rejected because the specified key was marked as disabled.', + 'class' => 'DisabledException', + ), + array( + 'reason' => 'The request was rejected because the specified ciphertext has been corrupted or is otherwise invalid.', + 'class' => 'InvalidCiphertextException', + ), + array( + 'reason' => 'The request was rejected because the key was disabled, not found, or otherwise not available.', + 'class' => 'KeyUnavailableException', + ), + array( + 'reason' => 'The system timed out while trying to fulfill the request.', + 'class' => 'DependencyTimeoutException', + ), + array( + 'reason' => 'The request was rejected because the specified KeySpec parameter is not valid. The currently supported value is ENCRYPT/DECRYPT.', + 'class' => 'InvalidKeyUsageException', + ), + array( + 'reason' => 'A grant token provided as part of the request is invalid.', + 'class' => 'InvalidGrantTokenException', + ), + array( + 'reason' => 'The request was rejected because an internal exception occurred. This error can be retried.', + 'class' => 'KMSInternalException', + ), + ), + ), + 'RetireGrant' => 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' => 'TrentService.RetireGrant', + ), + 'GrantToken' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 8192, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'A grant token provided as part of the request is invalid.', + 'class' => 'InvalidGrantTokenException', + ), + array( + 'reason' => 'The system timed out while trying to fulfill the request.', + 'class' => 'DependencyTimeoutException', + ), + array( + 'reason' => 'The request was rejected because an internal exception occurred. This error can be retried.', + 'class' => 'KMSInternalException', + ), + ), + ), + 'RevokeGrant' => 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' => 'TrentService.RevokeGrant', + ), + 'KeyId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'GrantId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because the specified entity or resource could not be found.', + 'class' => 'NotFoundException', + ), + array( + 'reason' => 'The system timed out while trying to fulfill the request.', + 'class' => 'DependencyTimeoutException', + ), + array( + 'reason' => 'The request was rejected because an internal exception occurred. This error can be retried.', + 'class' => 'KMSInternalException', + ), + ), + ), + 'UpdateKeyDescription' => 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' => 'TrentService.UpdateKeyDescription', + ), + 'KeyId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'Description' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 8192, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because the specified entity or resource could not be found.', + 'class' => 'NotFoundException', + ), + array( + 'reason' => 'The request was rejected because a specified ARN was not valid.', + 'class' => 'InvalidArnException', + ), + array( + 'reason' => 'The system timed out while trying to fulfill the request.', + 'class' => 'DependencyTimeoutException', + ), + array( + 'reason' => 'The request was rejected because an internal exception occurred. This error can be retried.', + 'class' => 'KMSInternalException', + ), + ), + ), + ), + 'models' => array( + 'EmptyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + ), + 'CreateGrantResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'GrantToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'GrantId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'CreateKeyResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'KeyMetadata' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'AWSAccountId' => array( + 'type' => 'string', + ), + 'KeyId' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'CreationDate' => array( + 'type' => 'string', + ), + 'Enabled' => array( + 'type' => 'boolean', + ), + 'Description' => array( + 'type' => 'string', + ), + 'KeyUsage' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'DecryptResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'KeyId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Plaintext' => array( + 'type' => 'string', + 'location' => 'json', + 'filters' => array( + 'base64_decode', + ), + ), + ), + ), + 'DescribeKeyResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'KeyMetadata' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'AWSAccountId' => array( + 'type' => 'string', + ), + 'KeyId' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'CreationDate' => array( + 'type' => 'string', + ), + 'Enabled' => array( + 'type' => 'boolean', + ), + 'Description' => array( + 'type' => 'string', + ), + 'KeyUsage' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'EncryptResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'CiphertextBlob' => array( + 'type' => 'string', + 'location' => 'json', + 'filters' => array( + 'base64_decode', + ), + ), + 'KeyId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'GenerateDataKeyResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'CiphertextBlob' => array( + 'type' => 'string', + 'location' => 'json', + 'filters' => array( + 'base64_decode', + ), + ), + 'Plaintext' => array( + 'type' => 'string', + 'location' => 'json', + 'filters' => array( + 'base64_decode', + ), + ), + 'KeyId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'GenerateDataKeyWithoutPlaintextResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'CiphertextBlob' => array( + 'type' => 'string', + 'location' => 'json', + 'filters' => array( + 'base64_decode', + ), + ), + 'KeyId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'GenerateRandomResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Plaintext' => array( + 'type' => 'string', + 'location' => 'json', + 'filters' => array( + 'base64_decode', + ), + ), + ), + ), + 'GetKeyPolicyResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Policy' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'GetKeyRotationStatusResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'KeyRotationEnabled' => array( + 'type' => 'boolean', + 'location' => 'json', + ), + ), + ), + 'ListAliasesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Aliases' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'AliasListEntry', + 'type' => 'object', + 'properties' => array( + 'AliasName' => array( + 'type' => 'string', + ), + 'AliasArn' => array( + 'type' => 'string', + ), + 'TargetKeyId' => array( + 'type' => 'string', + ), + ), + ), + ), + 'NextMarker' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Truncated' => array( + 'type' => 'boolean', + 'location' => 'json', + ), + ), + ), + 'ListGrantsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Grants' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'GrantListEntry', + 'type' => 'object', + 'properties' => array( + 'GrantId' => array( + 'type' => 'string', + ), + 'GranteePrincipal' => array( + 'type' => 'string', + ), + 'RetiringPrincipal' => array( + 'type' => 'string', + ), + 'IssuingAccount' => array( + 'type' => 'string', + ), + 'Operations' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'GrantOperation', + 'type' => 'string', + ), + ), + 'Constraints' => array( + 'type' => 'object', + 'properties' => array( + 'EncryptionContextSubset' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'string', + ), + ), + 'EncryptionContextEquals' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'NextMarker' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Truncated' => array( + 'type' => 'boolean', + 'location' => 'json', + ), + ), + ), + 'ListKeyPoliciesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'PolicyNames' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'PolicyNameType', + 'type' => 'string', + ), + ), + 'NextMarker' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Truncated' => array( + 'type' => 'boolean', + 'location' => 'json', + ), + ), + ), + 'ListKeysResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Keys' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'KeyListEntry', + 'type' => 'object', + 'properties' => array( + 'KeyId' => array( + 'type' => 'string', + ), + 'KeyArn' => array( + 'type' => 'string', + ), + ), + ), + ), + 'NextMarker' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Truncated' => array( + 'type' => 'boolean', + 'location' => 'json', + ), + ), + ), + 'ReEncryptResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'CiphertextBlob' => array( + 'type' => 'string', + 'location' => 'json', + 'filters' => array( + 'base64_decode', + ), + ), + 'SourceKeyId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'KeyId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + ), +); diff --git a/vendor/aws/Aws/Lambda/Exception/LambdaException.php b/vendor/aws/Aws/Lambda/Exception/LambdaException.php new file mode 100644 index 0000000..29a2f84 --- /dev/null +++ b/vendor/aws/Aws/Lambda/Exception/LambdaException.php @@ -0,0 +1,10 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/lambda-%s.php' + )) + ->setExceptionParser(new JsonRestExceptionParser()) + ->build(); + } +} diff --git a/vendor/aws/Aws/Lambda/Resources/lambda-2014-11-11.php b/vendor/aws/Aws/Lambda/Resources/lambda-2014-11-11.php new file mode 100644 index 0000000..84513e0 --- /dev/null +++ b/vendor/aws/Aws/Lambda/Resources/lambda-2014-11-11.php @@ -0,0 +1,742 @@ + '2014-11-11', + 'endpointPrefix' => 'lambda', + 'serviceFullName' => 'AWS Lambda', + 'serviceType' => 'rest-json', + 'signatureVersion' => 'v4', + 'namespace' => 'Lambda', + 'operations' => array( + 'AddEventSource' => array( + 'httpMethod' => 'POST', + 'uri' => '/2014-11-13/event-source-mappings/', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'EventSourceConfiguration', + 'responseType' => 'model', + 'parameters' => array( + 'EventSource' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'FunctionName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'Role' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'BatchSize' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'Parameters' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'string', + 'data' => array( + 'shape_name' => 'String', + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The AWS Lambda service encountered an internal error.', + 'class' => 'ServiceException', + ), + array( + 'reason' => 'One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS Lambda to assume in the UploadFunction or the UpdateFunctionConfiguration API, that AWS Lambda is unable to assume you will get this exception.', + 'class' => 'InvalidParameterValueException', + ), + ), + ), + 'DeleteFunction' => array( + 'httpMethod' => 'DELETE', + 'uri' => '/2014-11-13/functions/{FunctionName}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'FunctionName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 64, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The AWS Lambda service encountered an internal error.', + 'class' => 'ServiceException', + ), + array( + 'reason' => 'The function or the event source specified in the request does not exist.', + 'class' => 'ResourceNotFoundException', + ), + ), + ), + 'GetEventSource' => array( + 'httpMethod' => 'GET', + 'uri' => '/2014-11-13/event-source-mappings/{UUID}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'EventSourceConfiguration', + 'responseType' => 'model', + 'parameters' => array( + 'UUID' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The AWS Lambda service encountered an internal error.', + 'class' => 'ServiceException', + ), + array( + 'reason' => 'The function or the event source specified in the request does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS Lambda to assume in the UploadFunction or the UpdateFunctionConfiguration API, that AWS Lambda is unable to assume you will get this exception.', + 'class' => 'InvalidParameterValueException', + ), + ), + ), + 'GetFunction' => array( + 'httpMethod' => 'GET', + 'uri' => '/2014-11-13/functions/{FunctionName}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'GetFunctionResponse', + 'responseType' => 'model', + 'parameters' => array( + 'FunctionName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 64, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The AWS Lambda service encountered an internal error.', + 'class' => 'ServiceException', + ), + array( + 'reason' => 'The function or the event source specified in the request does not exist.', + 'class' => 'ResourceNotFoundException', + ), + ), + ), + 'GetFunctionConfiguration' => array( + 'httpMethod' => 'GET', + 'uri' => '/2014-11-13/functions/{FunctionName}/configuration', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'FunctionConfiguration', + 'responseType' => 'model', + 'parameters' => array( + 'FunctionName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 64, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The AWS Lambda service encountered an internal error.', + 'class' => 'ServiceException', + ), + array( + 'reason' => 'The function or the event source specified in the request does not exist.', + 'class' => 'ResourceNotFoundException', + ), + ), + ), + 'InvokeAsync' => array( + 'httpMethod' => 'POST', + 'uri' => '/2014-11-13/functions/{FunctionName}/invoke-async/', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'InvokeAsyncResponse', + 'responseType' => 'model', + 'parameters' => array( + 'FunctionName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'InvokeArgs' => array( + 'required' => true, + 'type' => array( + 'string', + 'object', + ), + 'location' => 'body', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The AWS Lambda service encountered an internal error.', + 'class' => 'ServiceException', + ), + array( + 'reason' => 'The function or the event source specified in the request does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'The request body could not be parsed as JSON.', + 'class' => 'InvalidRequestContentException', + ), + ), + ), + 'ListEventSources' => array( + 'httpMethod' => 'GET', + 'uri' => '/2014-11-13/event-source-mappings/', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'ListEventSourcesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'EventSourceArn' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'EventSource', + ), + 'FunctionName' => array( + 'type' => 'string', + 'location' => 'query', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'query', + ), + 'MaxItems' => array( + 'type' => 'numeric', + 'location' => 'query', + 'minimum' => 1, + 'maximum' => 10000, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The AWS Lambda service encountered an internal error.', + 'class' => 'ServiceException', + ), + array( + 'reason' => 'The function or the event source specified in the request does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS Lambda to assume in the UploadFunction or the UpdateFunctionConfiguration API, that AWS Lambda is unable to assume you will get this exception.', + 'class' => 'InvalidParameterValueException', + ), + ), + ), + 'ListFunctions' => array( + 'httpMethod' => 'GET', + 'uri' => '/2014-11-13/functions/', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'ListFunctionsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Marker' => array( + 'type' => 'string', + 'location' => 'query', + ), + 'MaxItems' => array( + 'type' => 'numeric', + 'location' => 'query', + 'minimum' => 1, + 'maximum' => 10000, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The AWS Lambda service encountered an internal error.', + 'class' => 'ServiceException', + ), + ), + ), + 'RemoveEventSource' => array( + 'httpMethod' => 'DELETE', + 'uri' => '/2014-11-13/event-source-mappings/{UUID}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'UUID' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The AWS Lambda service encountered an internal error.', + 'class' => 'ServiceException', + ), + array( + 'reason' => 'The function or the event source specified in the request does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS Lambda to assume in the UploadFunction or the UpdateFunctionConfiguration API, that AWS Lambda is unable to assume you will get this exception.', + 'class' => 'InvalidParameterValueException', + ), + ), + ), + 'UpdateFunctionConfiguration' => array( + 'httpMethod' => 'PUT', + 'uri' => '/2014-11-13/functions/{FunctionName}/configuration', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'FunctionConfiguration', + 'responseType' => 'model', + 'parameters' => array( + 'FunctionName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'Role' => array( + 'type' => 'string', + 'location' => 'query', + ), + 'Handler' => array( + 'type' => 'string', + 'location' => 'query', + ), + 'Description' => array( + 'type' => 'string', + 'location' => 'query', + 'maxLength' => 256, + ), + 'Timeout' => array( + 'type' => 'numeric', + 'location' => 'query', + 'minimum' => 1, + 'maximum' => 60, + ), + 'MemorySize' => array( + 'type' => 'numeric', + 'location' => 'query', + 'minimum' => 128, + 'maximum' => 1024, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The AWS Lambda service encountered an internal error.', + 'class' => 'ServiceException', + ), + array( + 'reason' => 'The function or the event source specified in the request does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS Lambda to assume in the UploadFunction or the UpdateFunctionConfiguration API, that AWS Lambda is unable to assume you will get this exception.', + 'class' => 'InvalidParameterValueException', + ), + ), + ), + 'UploadFunction' => array( + 'httpMethod' => 'PUT', + 'uri' => '/2014-11-13/functions/{FunctionName}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'FunctionConfiguration', + 'responseType' => 'model', + 'parameters' => array( + 'FunctionName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'FunctionZip' => array( + 'required' => true, + 'type' => array( + 'string', + 'object', + ), + 'location' => 'body', + ), + 'Runtime' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'query', + ), + 'Role' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'query', + ), + 'Handler' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'query', + ), + 'Mode' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'query', + ), + 'Description' => array( + 'type' => 'string', + 'location' => 'query', + 'maxLength' => 256, + ), + 'Timeout' => array( + 'type' => 'numeric', + 'location' => 'query', + 'minimum' => 1, + 'maximum' => 60, + ), + 'MemorySize' => array( + 'type' => 'numeric', + 'location' => 'query', + 'minimum' => 128, + 'maximum' => 1024, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The AWS Lambda service encountered an internal error.', + 'class' => 'ServiceException', + ), + array( + 'reason' => 'One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS Lambda to assume in the UploadFunction or the UpdateFunctionConfiguration API, that AWS Lambda is unable to assume you will get this exception.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'reason' => 'The function or the event source specified in the request does not exist.', + 'class' => 'ResourceNotFoundException', + ), + ), + ), + ), + 'models' => array( + 'EventSourceConfiguration' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'UUID' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'BatchSize' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'EventSource' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'FunctionName' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Parameters' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'string', + ), + ), + 'Role' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'LastModified' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'IsActive' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Status' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'EmptyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + ), + 'GetFunctionResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Configuration' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'FunctionName' => array( + 'type' => 'string', + ), + 'FunctionARN' => array( + 'type' => 'string', + ), + 'ConfigurationId' => array( + 'type' => 'string', + ), + 'Runtime' => array( + 'type' => 'string', + ), + 'Role' => array( + 'type' => 'string', + ), + 'Handler' => array( + 'type' => 'string', + ), + 'Mode' => array( + 'type' => 'string', + ), + 'CodeSize' => array( + 'type' => 'numeric', + ), + 'Description' => array( + 'type' => 'string', + ), + 'Timeout' => array( + 'type' => 'numeric', + ), + 'MemorySize' => array( + 'type' => 'numeric', + ), + 'LastModified' => array( + 'type' => 'string', + ), + ), + ), + 'Code' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'RepositoryType' => array( + 'type' => 'string', + ), + 'Location' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'FunctionConfiguration' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'FunctionName' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'FunctionARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'ConfigurationId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Runtime' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Role' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Handler' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Mode' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'CodeSize' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'Description' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Timeout' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'MemorySize' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'LastModified' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'InvokeAsyncResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Status' => array( + 'type' => 'numeric', + 'location' => 'statusCode', + ), + ), + ), + 'ListEventSourcesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'NextMarker' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'EventSources' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'EventSourceConfiguration', + 'type' => 'object', + 'properties' => array( + 'UUID' => array( + 'type' => 'string', + ), + 'BatchSize' => array( + 'type' => 'numeric', + ), + 'EventSource' => array( + 'type' => 'string', + ), + 'FunctionName' => array( + 'type' => 'string', + ), + 'Parameters' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'string', + ), + ), + 'Role' => array( + 'type' => 'string', + ), + 'LastModified' => array( + 'type' => 'string', + ), + 'IsActive' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'ListFunctionsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'NextMarker' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Functions' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'FunctionConfiguration', + 'type' => 'object', + 'properties' => array( + 'FunctionName' => array( + 'type' => 'string', + ), + 'FunctionARN' => array( + 'type' => 'string', + ), + 'ConfigurationId' => array( + 'type' => 'string', + ), + 'Runtime' => array( + 'type' => 'string', + ), + 'Role' => array( + 'type' => 'string', + ), + 'Handler' => array( + 'type' => 'string', + ), + 'Mode' => array( + 'type' => 'string', + ), + 'CodeSize' => array( + 'type' => 'numeric', + ), + 'Description' => array( + 'type' => 'string', + ), + 'Timeout' => array( + 'type' => 'numeric', + ), + 'MemorySize' => array( + 'type' => 'numeric', + ), + 'LastModified' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'iterators' => array( + 'ListEventSources' => array( + 'input_token' => 'Marker', + 'output_token' => 'NextMarker', + 'limit_key' => 'MaxItems', + 'result_key' => 'EventSources', + ), + 'ListFunctions' => array( + 'input_token' => 'Marker', + 'output_token' => 'NextMarker', + 'limit_key' => 'MaxItems', + 'result_key' => 'Functions', + ), + ), +); diff --git a/vendor/aws/Aws/Lambda/Resources/lambda-2015-03-31.php b/vendor/aws/Aws/Lambda/Resources/lambda-2015-03-31.php new file mode 100644 index 0000000..bb883a3 --- /dev/null +++ b/vendor/aws/Aws/Lambda/Resources/lambda-2015-03-31.php @@ -0,0 +1,1057 @@ + '2015-03-31', + 'endpointPrefix' => 'lambda', + 'serviceFullName' => 'AWS Lambda', + 'serviceType' => 'rest-json', + 'signatureVersion' => 'v4', + 'namespace' => 'Lambda', + 'operations' => array( + 'AddPermission' => array( + 'httpMethod' => 'POST', + 'uri' => '/2015-03-31/functions/{FunctionName}/versions/HEAD/policy', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'AddPermissionResponse', + 'responseType' => 'model', + 'parameters' => array( + 'FunctionName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 111, + ), + 'StatementId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 100, + ), + 'Action' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'Principal' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'SourceArn' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'SourceAccount' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The AWS Lambda service encountered an internal error.', + 'class' => 'ServiceException', + ), + array( + 'reason' => 'The resource (for example, a Lambda function or access policy statement) specified in the request does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'The resource already exists.', + 'class' => 'ResourceConflictException', + ), + array( + 'reason' => 'One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS Lambda is unable to assume you will get this exception.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'reason' => 'Lambda function access policy is limited to 20 KB.', + 'class' => 'PolicyLengthExceededException', + ), + array( + 'class' => 'TooManyRequestsException', + ), + ), + ), + 'CreateEventSourceMapping' => array( + 'httpMethod' => 'POST', + 'uri' => '/2015-03-31/event-source-mappings/', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'EventSourceMappingConfiguration', + 'responseType' => 'model', + 'parameters' => array( + 'EventSourceArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'FunctionName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 111, + ), + 'Enabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + 'BatchSize' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 10000, + ), + 'StartingPosition' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The AWS Lambda service encountered an internal error.', + 'class' => 'ServiceException', + ), + array( + 'reason' => 'One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS Lambda is unable to assume you will get this exception.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'reason' => 'The resource already exists.', + 'class' => 'ResourceConflictException', + ), + array( + 'class' => 'TooManyRequestsException', + ), + ), + ), + 'CreateFunction' => array( + 'httpMethod' => 'POST', + 'uri' => '/2015-03-31/functions', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'FunctionConfiguration', + 'responseType' => 'model', + 'parameters' => array( + 'FunctionName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 111, + ), + 'Runtime' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'Role' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'Handler' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 128, + ), + 'Description' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 256, + ), + 'Timeout' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 60, + ), + 'MemorySize' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 128, + 'maximum' => 1024, + ), + 'Code' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'ZipFile' => array( + 'type' => array( + 'string', + 'object', + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The AWS Lambda service encountered an internal error.', + 'class' => 'ServiceException', + ), + array( + 'reason' => 'One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS Lambda is unable to assume you will get this exception.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'reason' => 'The resource (for example, a Lambda function or access policy statement) specified in the request does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'The resource already exists.', + 'class' => 'ResourceConflictException', + ), + array( + 'class' => 'TooManyRequestsException', + ), + ), + ), + 'DeleteEventSourceMapping' => array( + 'httpMethod' => 'DELETE', + 'uri' => '/2015-03-31/event-source-mappings/{UUID}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'EventSourceMappingConfiguration', + 'responseType' => 'model', + 'parameters' => array( + 'UUID' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The AWS Lambda service encountered an internal error.', + 'class' => 'ServiceException', + ), + array( + 'reason' => 'The resource (for example, a Lambda function or access policy statement) specified in the request does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS Lambda is unable to assume you will get this exception.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'class' => 'TooManyRequestsException', + ), + ), + ), + 'DeleteFunction' => array( + 'httpMethod' => 'DELETE', + 'uri' => '/2015-03-31/functions/{FunctionName}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'FunctionName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 111, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The AWS Lambda service encountered an internal error.', + 'class' => 'ServiceException', + ), + array( + 'reason' => 'The resource (for example, a Lambda function or access policy statement) specified in the request does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'class' => 'TooManyRequestsException', + ), + ), + ), + 'GetEventSourceMapping' => array( + 'httpMethod' => 'GET', + 'uri' => '/2015-03-31/event-source-mappings/{UUID}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'EventSourceMappingConfiguration', + 'responseType' => 'model', + 'parameters' => array( + 'UUID' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The AWS Lambda service encountered an internal error.', + 'class' => 'ServiceException', + ), + array( + 'reason' => 'The resource (for example, a Lambda function or access policy statement) specified in the request does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS Lambda is unable to assume you will get this exception.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'class' => 'TooManyRequestsException', + ), + ), + ), + 'GetFunction' => array( + 'httpMethod' => 'GET', + 'uri' => '/2015-03-31/functions/{FunctionName}/versions/HEAD', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'GetFunctionResponse', + 'responseType' => 'model', + 'parameters' => array( + 'FunctionName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 111, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The AWS Lambda service encountered an internal error.', + 'class' => 'ServiceException', + ), + array( + 'reason' => 'The resource (for example, a Lambda function or access policy statement) specified in the request does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'class' => 'TooManyRequestsException', + ), + ), + ), + 'GetFunctionConfiguration' => array( + 'httpMethod' => 'GET', + 'uri' => '/2015-03-31/functions/{FunctionName}/versions/HEAD/configuration', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'FunctionConfiguration', + 'responseType' => 'model', + 'parameters' => array( + 'FunctionName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 111, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The AWS Lambda service encountered an internal error.', + 'class' => 'ServiceException', + ), + array( + 'reason' => 'The resource (for example, a Lambda function or access policy statement) specified in the request does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'class' => 'TooManyRequestsException', + ), + ), + ), + 'GetPolicy' => array( + 'httpMethod' => 'GET', + 'uri' => '/2015-03-31/functions/{FunctionName}/versions/HEAD/policy', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'GetPolicyResponse', + 'responseType' => 'model', + 'parameters' => array( + 'FunctionName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 111, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The AWS Lambda service encountered an internal error.', + 'class' => 'ServiceException', + ), + array( + 'reason' => 'The resource (for example, a Lambda function or access policy statement) specified in the request does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'class' => 'TooManyRequestsException', + ), + ), + ), + 'Invoke' => array( + 'httpMethod' => 'POST', + 'uri' => '/2015-03-31/functions/{FunctionName}/invocations', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'InvocationResponse', + 'responseType' => 'model', + 'parameters' => array( + 'FunctionName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 111, + ), + 'InvocationType' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'X-Amz-Invocation-Type', + ), + 'LogType' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'X-Amz-Log-Type', + ), + 'ClientContext' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'X-Amz-Client-Context', + ), + 'Payload' => array( + 'type' => array( + 'string', + 'object', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The AWS Lambda service encountered an internal error.', + 'class' => 'ServiceException', + ), + array( + 'reason' => 'The resource (for example, a Lambda function or access policy statement) specified in the request does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'The request body could not be parsed as JSON.', + 'class' => 'InvalidRequestContentException', + ), + array( + 'class' => 'RequestTooLargeException', + ), + array( + 'class' => 'UnsupportedMediaTypeException', + ), + array( + 'class' => 'TooManyRequestsException', + ), + ), + ), + 'InvokeAsync' => array( + 'httpMethod' => 'POST', + 'uri' => '/2014-11-13/functions/{FunctionName}/invoke-async/', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'InvokeAsyncResponse', + 'responseType' => 'model', + 'parameters' => array( + 'FunctionName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 111, + ), + 'InvokeArgs' => array( + 'required' => true, + 'type' => array( + 'string', + 'object', + ), + 'location' => 'body', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The AWS Lambda service encountered an internal error.', + 'class' => 'ServiceException', + ), + array( + 'reason' => 'The resource (for example, a Lambda function or access policy statement) specified in the request does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'The request body could not be parsed as JSON.', + 'class' => 'InvalidRequestContentException', + ), + ), + ), + 'ListEventSourceMappings' => array( + 'httpMethod' => 'GET', + 'uri' => '/2015-03-31/event-source-mappings/', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'ListEventSourceMappingsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'EventSourceArn' => array( + 'type' => 'string', + 'location' => 'query', + ), + 'FunctionName' => array( + 'type' => 'string', + 'location' => 'query', + 'minLength' => 1, + 'maxLength' => 111, + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'query', + ), + 'MaxItems' => array( + 'type' => 'numeric', + 'location' => 'query', + 'minimum' => 1, + 'maximum' => 10000, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The AWS Lambda service encountered an internal error.', + 'class' => 'ServiceException', + ), + array( + 'reason' => 'The resource (for example, a Lambda function or access policy statement) specified in the request does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS Lambda is unable to assume you will get this exception.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'class' => 'TooManyRequestsException', + ), + ), + ), + 'ListFunctions' => array( + 'httpMethod' => 'GET', + 'uri' => '/2015-03-31/functions/', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'ListFunctionsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Marker' => array( + 'type' => 'string', + 'location' => 'query', + ), + 'MaxItems' => array( + 'type' => 'numeric', + 'location' => 'query', + 'minimum' => 1, + 'maximum' => 10000, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The AWS Lambda service encountered an internal error.', + 'class' => 'ServiceException', + ), + array( + 'class' => 'TooManyRequestsException', + ), + ), + ), + 'RemovePermission' => array( + 'httpMethod' => 'DELETE', + 'uri' => '/2015-03-31/functions/{FunctionName}/versions/HEAD/policy/{StatementId}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'FunctionName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 111, + ), + 'StatementId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 100, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The AWS Lambda service encountered an internal error.', + 'class' => 'ServiceException', + ), + array( + 'reason' => 'The resource (for example, a Lambda function or access policy statement) specified in the request does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'class' => 'TooManyRequestsException', + ), + ), + ), + 'UpdateEventSourceMapping' => array( + 'httpMethod' => 'PUT', + 'uri' => '/2015-03-31/event-source-mappings/{UUID}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'EventSourceMappingConfiguration', + 'responseType' => 'model', + 'parameters' => array( + 'UUID' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'FunctionName' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 111, + ), + 'Enabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + 'BatchSize' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 10000, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The AWS Lambda service encountered an internal error.', + 'class' => 'ServiceException', + ), + array( + 'reason' => 'The resource (for example, a Lambda function or access policy statement) specified in the request does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS Lambda is unable to assume you will get this exception.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'class' => 'TooManyRequestsException', + ), + ), + ), + 'UpdateFunctionCode' => array( + 'httpMethod' => 'PUT', + 'uri' => '/2015-03-31/functions/{FunctionName}/versions/HEAD/code', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'FunctionConfiguration', + 'responseType' => 'model', + 'parameters' => array( + 'FunctionName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 111, + ), + 'ZipFile' => array( + 'required' => true, + 'type' => array( + 'string', + 'object', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The AWS Lambda service encountered an internal error.', + 'class' => 'ServiceException', + ), + array( + 'reason' => 'The resource (for example, a Lambda function or access policy statement) specified in the request does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS Lambda is unable to assume you will get this exception.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'class' => 'TooManyRequestsException', + ), + ), + ), + 'UpdateFunctionConfiguration' => array( + 'httpMethod' => 'PUT', + 'uri' => '/2015-03-31/functions/{FunctionName}/versions/HEAD/configuration', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'FunctionConfiguration', + 'responseType' => 'model', + 'parameters' => array( + 'FunctionName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'minLength' => 1, + 'maxLength' => 111, + ), + 'Role' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Handler' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 128, + ), + 'Description' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 256, + ), + 'Timeout' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 60, + ), + 'MemorySize' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 128, + 'maximum' => 1024, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The AWS Lambda service encountered an internal error.', + 'class' => 'ServiceException', + ), + array( + 'reason' => 'The resource (for example, a Lambda function or access policy statement) specified in the request does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'One of the parameters in the request is invalid. For example, if you provided an IAM role for AWS Lambda to assume in the CreateFunction or the UpdateFunctionConfiguration API, that AWS Lambda is unable to assume you will get this exception.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'class' => 'TooManyRequestsException', + ), + ), + ), + ), + 'models' => array( + 'AddPermissionResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Statement' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'EventSourceMappingConfiguration' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'UUID' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'BatchSize' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'EventSourceArn' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'FunctionArn' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'LastModified' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'LastProcessingResult' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'State' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'StateTransitionReason' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'FunctionConfiguration' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'FunctionName' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'FunctionArn' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Runtime' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Role' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Handler' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'CodeSize' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'Description' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Timeout' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'MemorySize' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'LastModified' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'EmptyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + ), + 'GetFunctionResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Configuration' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'FunctionName' => array( + 'type' => 'string', + ), + 'FunctionArn' => array( + 'type' => 'string', + ), + 'Runtime' => array( + 'type' => 'string', + ), + 'Role' => array( + 'type' => 'string', + ), + 'Handler' => array( + 'type' => 'string', + ), + 'CodeSize' => array( + 'type' => 'numeric', + ), + 'Description' => array( + 'type' => 'string', + ), + 'Timeout' => array( + 'type' => 'numeric', + ), + 'MemorySize' => array( + 'type' => 'numeric', + ), + 'LastModified' => array( + 'type' => 'string', + ), + ), + ), + 'Code' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'RepositoryType' => array( + 'type' => 'string', + ), + 'Location' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'GetPolicyResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Policy' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'InvocationResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'StatusCode' => array( + 'type' => 'numeric', + 'location' => 'statusCode', + ), + 'FunctionError' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'X-Amz-Function-Error', + ), + 'LogResult' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'X-Amz-Log-Result', + ), + 'Payload' => array( + 'type' => array( + 'string', + 'object', + ), + 'location' => 'json', + ), + ), + ), + 'InvokeAsyncResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Status' => array( + 'type' => 'numeric', + 'location' => 'statusCode', + ), + ), + ), + 'ListEventSourceMappingsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'NextMarker' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'EventSourceMappings' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'EventSourceMappingConfiguration', + 'type' => 'object', + 'properties' => array( + 'UUID' => array( + 'type' => 'string', + ), + 'BatchSize' => array( + 'type' => 'numeric', + ), + 'EventSourceArn' => array( + 'type' => 'string', + ), + 'FunctionArn' => array( + 'type' => 'string', + ), + 'LastModified' => array( + 'type' => 'string', + ), + 'LastProcessingResult' => array( + 'type' => 'string', + ), + 'State' => array( + 'type' => 'string', + ), + 'StateTransitionReason' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'ListFunctionsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'NextMarker' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Functions' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'FunctionConfiguration', + 'type' => 'object', + 'properties' => array( + 'FunctionName' => array( + 'type' => 'string', + ), + 'FunctionArn' => array( + 'type' => 'string', + ), + 'Runtime' => array( + 'type' => 'string', + ), + 'Role' => array( + 'type' => 'string', + ), + 'Handler' => array( + 'type' => 'string', + ), + 'CodeSize' => array( + 'type' => 'numeric', + ), + 'Description' => array( + 'type' => 'string', + ), + 'Timeout' => array( + 'type' => 'numeric', + ), + 'MemorySize' => array( + 'type' => 'numeric', + ), + 'LastModified' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'iterators' => array( + 'ListEventSourceMappings' => array( + 'input_token' => 'Marker', + 'output_token' => 'NextMarker', + 'limit_key' => 'MaxItems', + 'result_key' => 'EventSourceMappings', + ), + 'ListFunctions' => array( + 'input_token' => 'Marker', + 'output_token' => 'NextMarker', + 'limit_key' => 'MaxItems', + 'result_key' => 'Functions', + ), + ), +); diff --git a/vendor/aws/Aws/MachineLearning/Exception/MachineLearningException.php b/vendor/aws/Aws/MachineLearning/Exception/MachineLearningException.php new file mode 100644 index 0000000..edabbb1 --- /dev/null +++ b/vendor/aws/Aws/MachineLearning/Exception/MachineLearningException.php @@ -0,0 +1,10 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/machinelearning-%s.php', + )) + ->setExceptionParser(new JsonQueryExceptionParser()) + ->build(); + + $client->addSubscriber(new PredictEndpointListener()); + + return $client; + } +} diff --git a/vendor/aws/Aws/MachineLearning/PredictEndpointListener.php b/vendor/aws/Aws/MachineLearning/PredictEndpointListener.php new file mode 100644 index 0000000..ed0fe34 --- /dev/null +++ b/vendor/aws/Aws/MachineLearning/PredictEndpointListener.php @@ -0,0 +1,35 @@ + array('onCommandBeforeSend', -255)); + } + + /** + * Updates the request URL to use the Predict Endpoint + * + * @param Event $event Event emitted + */ + public function onCommandBeforeSend(Event $event) + { + /** @var $command AbstractCommand */ + $command = $event['command']; + if ($command->getName() === 'Predict') { + $request = $command->getRequest(); + $requestUrl = $request->getUrl(true); + $request->setUrl($requestUrl->combine($command->get('PredictEndpoint'))); + $request->getParams()->remove('PredictEndpoint'); + } + } +} diff --git a/vendor/aws/Aws/MachineLearning/Resources/machinelearning-2014-12-12.php b/vendor/aws/Aws/MachineLearning/Resources/machinelearning-2014-12-12.php new file mode 100644 index 0000000..b31d049 --- /dev/null +++ b/vendor/aws/Aws/MachineLearning/Resources/machinelearning-2014-12-12.php @@ -0,0 +1,2548 @@ + '2014-12-12', + 'endpointPrefix' => 'machinelearning', + 'serviceFullName' => 'Amazon Machine Learning', + 'serviceType' => 'json', + 'jsonVersion' => '1.1', + 'targetPrefix' => 'AmazonML_20141212.', + 'signatureVersion' => 'v4', + 'namespace' => 'MachineLearning', + 'operations' => array( + 'CreateBatchPrediction' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'CreateBatchPredictionOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonML_20141212.CreateBatchPrediction', + ), + 'BatchPredictionId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'BatchPredictionName' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'MLModelId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'BatchPredictionDataSourceId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'OutputUri' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 2048, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error on the client occurred. Typically, the cause is an invalid input value.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'An error on the server occurred when trying to process a request.', + 'class' => 'InternalServerException', + ), + array( + 'reason' => 'A second request to use or change an object was not allowed. This can result from retrying a request using a parameter that was not present in the original request.', + 'class' => 'IdempotentParameterMismatchException', + ), + ), + ), + 'CreateDataSourceFromRDS' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'CreateDataSourceFromRDSOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonML_20141212.CreateDataSourceFromRDS', + ), + 'DataSourceId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'DataSourceName' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'RDSData' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'DatabaseInformation' => array( + 'required' => true, + 'type' => 'object', + 'properties' => array( + 'InstanceIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 63, + ), + 'DatabaseName' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 64, + ), + ), + ), + 'SelectSqlQuery' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 16777216, + ), + 'DatabaseCredentials' => array( + 'required' => true, + 'type' => 'object', + 'properties' => array( + 'Username' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'Password' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 8, + 'maxLength' => 128, + ), + ), + ), + 'S3StagingLocation' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 2048, + ), + 'DataRearrangement' => array( + 'type' => 'string', + ), + 'DataSchema' => array( + 'type' => 'string', + 'maxLength' => 131071, + ), + 'DataSchemaUri' => array( + 'type' => 'string', + 'maxLength' => 2048, + ), + 'ResourceRole' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'ServiceRole' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'SubnetId' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'SecurityGroupIds' => array( + 'required' => true, + 'type' => 'array', + 'items' => array( + 'name' => 'EDPSecurityGroupId', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + ), + ), + ), + 'RoleARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 100, + ), + 'ComputeStatistics' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error on the client occurred. Typically, the cause is an invalid input value.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'An error on the server occurred when trying to process a request.', + 'class' => 'InternalServerException', + ), + array( + 'reason' => 'A second request to use or change an object was not allowed. This can result from retrying a request using a parameter that was not present in the original request.', + 'class' => 'IdempotentParameterMismatchException', + ), + ), + ), + 'CreateDataSourceFromRedshift' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'CreateDataSourceFromRedshiftOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonML_20141212.CreateDataSourceFromRedshift', + ), + 'DataSourceId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'DataSourceName' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'DataSpec' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'DatabaseInformation' => array( + 'required' => true, + 'type' => 'object', + 'properties' => array( + 'DatabaseName' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'ClusterIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 63, + ), + ), + ), + 'SelectSqlQuery' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 16777216, + ), + 'DatabaseCredentials' => array( + 'required' => true, + 'type' => 'object', + 'properties' => array( + 'Username' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'Password' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 8, + 'maxLength' => 64, + ), + ), + ), + 'S3StagingLocation' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 2048, + ), + 'DataRearrangement' => array( + 'type' => 'string', + ), + 'DataSchema' => array( + 'type' => 'string', + 'maxLength' => 131071, + ), + 'DataSchemaUri' => array( + 'type' => 'string', + 'maxLength' => 2048, + ), + ), + ), + 'RoleARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 100, + ), + 'ComputeStatistics' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error on the client occurred. Typically, the cause is an invalid input value.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'An error on the server occurred when trying to process a request.', + 'class' => 'InternalServerException', + ), + array( + 'reason' => 'A second request to use or change an object was not allowed. This can result from retrying a request using a parameter that was not present in the original request.', + 'class' => 'IdempotentParameterMismatchException', + ), + ), + ), + 'CreateDataSourceFromS3' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'CreateDataSourceFromS3Output', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonML_20141212.CreateDataSourceFromS3', + ), + 'DataSourceId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'DataSourceName' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'DataSpec' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'DataLocationS3' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 2048, + ), + 'DataRearrangement' => array( + 'type' => 'string', + ), + 'DataSchema' => array( + 'type' => 'string', + 'maxLength' => 131071, + ), + 'DataSchemaLocationS3' => array( + 'type' => 'string', + 'maxLength' => 2048, + ), + ), + ), + 'ComputeStatistics' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error on the client occurred. Typically, the cause is an invalid input value.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'An error on the server occurred when trying to process a request.', + 'class' => 'InternalServerException', + ), + array( + 'reason' => 'A second request to use or change an object was not allowed. This can result from retrying a request using a parameter that was not present in the original request.', + 'class' => 'IdempotentParameterMismatchException', + ), + ), + ), + 'CreateEvaluation' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'CreateEvaluationOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonML_20141212.CreateEvaluation', + ), + 'EvaluationId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'EvaluationName' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'MLModelId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'EvaluationDataSourceId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 64, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error on the client occurred. Typically, the cause is an invalid input value.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'An error on the server occurred when trying to process a request.', + 'class' => 'InternalServerException', + ), + array( + 'reason' => 'A second request to use or change an object was not allowed. This can result from retrying a request using a parameter that was not present in the original request.', + 'class' => 'IdempotentParameterMismatchException', + ), + ), + ), + 'CreateMLModel' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'CreateMLModelOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonML_20141212.CreateMLModel', + ), + 'MLModelId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'MLModelName' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'MLModelType' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'Parameters' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'string', + 'data' => array( + 'shape_name' => 'StringType', + ), + ), + ), + 'TrainingDataSourceId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'Recipe' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 131071, + ), + 'RecipeUri' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 2048, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error on the client occurred. Typically, the cause is an invalid input value.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'An error on the server occurred when trying to process a request.', + 'class' => 'InternalServerException', + ), + array( + 'reason' => 'A second request to use or change an object was not allowed. This can result from retrying a request using a parameter that was not present in the original request.', + 'class' => 'IdempotentParameterMismatchException', + ), + ), + ), + 'CreateRealtimeEndpoint' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'CreateRealtimeEndpointOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonML_20141212.CreateRealtimeEndpoint', + ), + 'MLModelId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 64, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error on the client occurred. Typically, the cause is an invalid input value.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'A specified resource cannot be located.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'An error on the server occurred when trying to process a request.', + 'class' => 'InternalServerException', + ), + ), + ), + 'DeleteBatchPrediction' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DeleteBatchPredictionOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonML_20141212.DeleteBatchPrediction', + ), + 'BatchPredictionId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 64, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error on the client occurred. Typically, the cause is an invalid input value.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'A specified resource cannot be located.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'An error on the server occurred when trying to process a request.', + 'class' => 'InternalServerException', + ), + ), + ), + 'DeleteDataSource' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DeleteDataSourceOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonML_20141212.DeleteDataSource', + ), + 'DataSourceId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 64, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error on the client occurred. Typically, the cause is an invalid input value.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'A specified resource cannot be located.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'An error on the server occurred when trying to process a request.', + 'class' => 'InternalServerException', + ), + ), + ), + 'DeleteEvaluation' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DeleteEvaluationOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonML_20141212.DeleteEvaluation', + ), + 'EvaluationId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 64, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error on the client occurred. Typically, the cause is an invalid input value.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'A specified resource cannot be located.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'An error on the server occurred when trying to process a request.', + 'class' => 'InternalServerException', + ), + ), + ), + 'DeleteMLModel' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DeleteMLModelOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonML_20141212.DeleteMLModel', + ), + 'MLModelId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 64, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error on the client occurred. Typically, the cause is an invalid input value.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'A specified resource cannot be located.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'An error on the server occurred when trying to process a request.', + 'class' => 'InternalServerException', + ), + ), + ), + 'DeleteRealtimeEndpoint' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DeleteRealtimeEndpointOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonML_20141212.DeleteRealtimeEndpoint', + ), + 'MLModelId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 64, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error on the client occurred. Typically, the cause is an invalid input value.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'A specified resource cannot be located.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'An error on the server occurred when trying to process a request.', + 'class' => 'InternalServerException', + ), + ), + ), + 'DescribeBatchPredictions' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeBatchPredictionsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonML_20141212.DescribeBatchPredictions', + ), + 'FilterVariable' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'EQ' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'GT' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'LT' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'GE' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'LE' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'NE' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'Prefix' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'SortOrder' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Limit' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 100, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error on the client occurred. Typically, the cause is an invalid input value.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'An error on the server occurred when trying to process a request.', + 'class' => 'InternalServerException', + ), + ), + ), + 'DescribeDataSources' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeDataSourcesOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonML_20141212.DescribeDataSources', + ), + 'FilterVariable' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'EQ' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'GT' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'LT' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'GE' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'LE' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'NE' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'Prefix' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'SortOrder' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Limit' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 100, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error on the client occurred. Typically, the cause is an invalid input value.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'An error on the server occurred when trying to process a request.', + 'class' => 'InternalServerException', + ), + ), + ), + 'DescribeEvaluations' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeEvaluationsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonML_20141212.DescribeEvaluations', + ), + 'FilterVariable' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'EQ' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'GT' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'LT' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'GE' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'LE' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'NE' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'Prefix' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'SortOrder' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Limit' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 100, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error on the client occurred. Typically, the cause is an invalid input value.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'An error on the server occurred when trying to process a request.', + 'class' => 'InternalServerException', + ), + ), + ), + 'DescribeMLModels' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeMLModelsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonML_20141212.DescribeMLModels', + ), + 'FilterVariable' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'EQ' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'GT' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'LT' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'GE' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'LE' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'NE' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'Prefix' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'SortOrder' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Limit' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 100, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error on the client occurred. Typically, the cause is an invalid input value.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'An error on the server occurred when trying to process a request.', + 'class' => 'InternalServerException', + ), + ), + ), + 'GetBatchPrediction' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GetBatchPredictionOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonML_20141212.GetBatchPrediction', + ), + 'BatchPredictionId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 64, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error on the client occurred. Typically, the cause is an invalid input value.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'A specified resource cannot be located.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'An error on the server occurred when trying to process a request.', + 'class' => 'InternalServerException', + ), + ), + ), + 'GetDataSource' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GetDataSourceOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonML_20141212.GetDataSource', + ), + 'DataSourceId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'Verbose' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error on the client occurred. Typically, the cause is an invalid input value.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'A specified resource cannot be located.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'An error on the server occurred when trying to process a request.', + 'class' => 'InternalServerException', + ), + ), + ), + 'GetEvaluation' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GetEvaluationOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonML_20141212.GetEvaluation', + ), + 'EvaluationId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 64, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error on the client occurred. Typically, the cause is an invalid input value.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'A specified resource cannot be located.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'An error on the server occurred when trying to process a request.', + 'class' => 'InternalServerException', + ), + ), + ), + 'GetMLModel' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GetMLModelOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonML_20141212.GetMLModel', + ), + 'MLModelId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'Verbose' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error on the client occurred. Typically, the cause is an invalid input value.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'A specified resource cannot be located.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'An error on the server occurred when trying to process a request.', + 'class' => 'InternalServerException', + ), + ), + ), + 'Predict' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'PredictOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonML_20141212.Predict', + ), + 'MLModelId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'Record' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'string', + 'maxLength' => 1024, + 'data' => array( + 'shape_name' => 'VariableName', + ), + ), + ), + 'PredictEndpoint' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 2048, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error on the client occurred. Typically, the cause is an invalid input value.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'A specified resource cannot be located.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'The subscriber exceeded the maximum number of operations. This exception can occur when listing objects such as DataSource.', + 'class' => 'LimitExceededException', + ), + array( + 'reason' => 'An error on the server occurred when trying to process a request.', + 'class' => 'InternalServerException', + ), + array( + 'reason' => 'The exception is thrown when a predict request is made to an unmounted MLModel.', + 'class' => 'PredictorNotMountedException', + ), + ), + ), + 'UpdateBatchPrediction' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'UpdateBatchPredictionOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonML_20141212.UpdateBatchPrediction', + ), + 'BatchPredictionId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'BatchPredictionName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error on the client occurred. Typically, the cause is an invalid input value.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'A specified resource cannot be located.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'An error on the server occurred when trying to process a request.', + 'class' => 'InternalServerException', + ), + ), + ), + 'UpdateDataSource' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'UpdateDataSourceOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonML_20141212.UpdateDataSource', + ), + 'DataSourceId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'DataSourceName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error on the client occurred. Typically, the cause is an invalid input value.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'A specified resource cannot be located.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'An error on the server occurred when trying to process a request.', + 'class' => 'InternalServerException', + ), + ), + ), + 'UpdateEvaluation' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'UpdateEvaluationOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonML_20141212.UpdateEvaluation', + ), + 'EvaluationId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'EvaluationName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error on the client occurred. Typically, the cause is an invalid input value.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'A specified resource cannot be located.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'An error on the server occurred when trying to process a request.', + 'class' => 'InternalServerException', + ), + ), + ), + 'UpdateMLModel' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'UpdateMLModelOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonML_20141212.UpdateMLModel', + ), + 'MLModelId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'MLModelName' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'ScoreThreshold' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error on the client occurred. Typically, the cause is an invalid input value.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'A specified resource cannot be located.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'An error on the server occurred when trying to process a request.', + 'class' => 'InternalServerException', + ), + ), + ), + ), + 'models' => array( + 'CreateBatchPredictionOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'BatchPredictionId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'CreateDataSourceFromRDSOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'DataSourceId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'CreateDataSourceFromRedshiftOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'DataSourceId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'CreateDataSourceFromS3Output' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'DataSourceId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'CreateEvaluationOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'EvaluationId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'CreateMLModelOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'MLModelId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'CreateRealtimeEndpointOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'MLModelId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'RealtimeEndpointInfo' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'PeakRequestsPerSecond' => array( + 'type' => 'numeric', + ), + 'CreatedAt' => array( + 'type' => 'string', + ), + 'EndpointUrl' => array( + 'type' => 'string', + ), + 'EndpointStatus' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'DeleteBatchPredictionOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'BatchPredictionId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DeleteDataSourceOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'DataSourceId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DeleteEvaluationOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'EvaluationId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DeleteMLModelOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'MLModelId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DeleteRealtimeEndpointOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'MLModelId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'RealtimeEndpointInfo' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'PeakRequestsPerSecond' => array( + 'type' => 'numeric', + ), + 'CreatedAt' => array( + 'type' => 'string', + ), + 'EndpointUrl' => array( + 'type' => 'string', + ), + 'EndpointStatus' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'DescribeBatchPredictionsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Results' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'BatchPrediction', + 'type' => 'object', + 'properties' => array( + 'BatchPredictionId' => array( + 'type' => 'string', + ), + 'MLModelId' => array( + 'type' => 'string', + ), + 'BatchPredictionDataSourceId' => array( + 'type' => 'string', + ), + 'InputDataLocationS3' => array( + 'type' => 'string', + ), + 'CreatedByIamUser' => array( + 'type' => 'string', + ), + 'CreatedAt' => array( + 'type' => 'string', + ), + 'LastUpdatedAt' => array( + 'type' => 'string', + ), + 'Name' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'OutputUri' => array( + 'type' => 'string', + ), + 'Message' => array( + 'type' => 'string', + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DescribeDataSourcesOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Results' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'DataSource', + 'type' => 'object', + 'properties' => array( + 'DataSourceId' => array( + 'type' => 'string', + ), + 'DataLocationS3' => array( + 'type' => 'string', + ), + 'DataRearrangement' => array( + 'type' => 'string', + ), + 'CreatedByIamUser' => array( + 'type' => 'string', + ), + 'CreatedAt' => array( + 'type' => 'string', + ), + 'LastUpdatedAt' => array( + 'type' => 'string', + ), + 'DataSizeInBytes' => array( + 'type' => 'numeric', + ), + 'NumberOfFiles' => array( + 'type' => 'numeric', + ), + 'Name' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'Message' => array( + 'type' => 'string', + ), + 'RedshiftMetadata' => array( + 'type' => 'object', + 'properties' => array( + 'RedshiftDatabase' => array( + 'type' => 'object', + 'properties' => array( + 'DatabaseName' => array( + 'type' => 'string', + ), + 'ClusterIdentifier' => array( + 'type' => 'string', + ), + ), + ), + 'DatabaseUserName' => array( + 'type' => 'string', + ), + 'SelectSqlQuery' => array( + 'type' => 'string', + ), + ), + ), + 'RDSMetadata' => array( + 'type' => 'object', + 'properties' => array( + 'Database' => array( + 'type' => 'object', + 'properties' => array( + 'InstanceIdentifier' => array( + 'type' => 'string', + ), + 'DatabaseName' => array( + 'type' => 'string', + ), + ), + ), + 'DatabaseUserName' => array( + 'type' => 'string', + ), + 'SelectSqlQuery' => array( + 'type' => 'string', + ), + 'ResourceRole' => array( + 'type' => 'string', + ), + 'ServiceRole' => array( + 'type' => 'string', + ), + 'DataPipelineId' => array( + 'type' => 'string', + ), + ), + ), + 'RoleARN' => array( + 'type' => 'string', + ), + 'ComputeStatistics' => array( + 'type' => 'boolean', + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DescribeEvaluationsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Results' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Evaluation', + 'type' => 'object', + 'properties' => array( + 'EvaluationId' => array( + 'type' => 'string', + ), + 'MLModelId' => array( + 'type' => 'string', + ), + 'EvaluationDataSourceId' => array( + 'type' => 'string', + ), + 'InputDataLocationS3' => array( + 'type' => 'string', + ), + 'CreatedByIamUser' => array( + 'type' => 'string', + ), + 'CreatedAt' => array( + 'type' => 'string', + ), + 'LastUpdatedAt' => array( + 'type' => 'string', + ), + 'Name' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'PerformanceMetrics' => array( + 'type' => 'object', + 'properties' => array( + 'Properties' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Message' => array( + 'type' => 'string', + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DescribeMLModelsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Results' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'MLModel', + 'type' => 'object', + 'properties' => array( + 'MLModelId' => array( + 'type' => 'string', + ), + 'TrainingDataSourceId' => array( + 'type' => 'string', + ), + 'CreatedByIamUser' => array( + 'type' => 'string', + ), + 'CreatedAt' => array( + 'type' => 'string', + ), + 'LastUpdatedAt' => array( + 'type' => 'string', + ), + 'Name' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'SizeInBytes' => array( + 'type' => 'numeric', + ), + 'EndpointInfo' => array( + 'type' => 'object', + 'properties' => array( + 'PeakRequestsPerSecond' => array( + 'type' => 'numeric', + ), + 'CreatedAt' => array( + 'type' => 'string', + ), + 'EndpointUrl' => array( + 'type' => 'string', + ), + 'EndpointStatus' => array( + 'type' => 'string', + ), + ), + ), + 'TrainingParameters' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'string', + ), + ), + 'InputDataLocationS3' => array( + 'type' => 'string', + ), + 'Algorithm' => array( + 'type' => 'string', + ), + 'MLModelType' => array( + 'type' => 'string', + ), + 'ScoreThreshold' => array( + 'type' => 'numeric', + ), + 'ScoreThresholdLastUpdatedAt' => array( + 'type' => 'string', + ), + 'Message' => array( + 'type' => 'string', + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'GetBatchPredictionOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'BatchPredictionId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'MLModelId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'BatchPredictionDataSourceId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'InputDataLocationS3' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'CreatedByIamUser' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'CreatedAt' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'LastUpdatedAt' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Name' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Status' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'OutputUri' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'LogUri' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Message' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'GetDataSourceOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'DataSourceId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'DataLocationS3' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'DataRearrangement' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'CreatedByIamUser' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'CreatedAt' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'LastUpdatedAt' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'DataSizeInBytes' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'NumberOfFiles' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'Name' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Status' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'LogUri' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Message' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'RedshiftMetadata' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'RedshiftDatabase' => array( + 'type' => 'object', + 'properties' => array( + 'DatabaseName' => array( + 'type' => 'string', + ), + 'ClusterIdentifier' => array( + 'type' => 'string', + ), + ), + ), + 'DatabaseUserName' => array( + 'type' => 'string', + ), + 'SelectSqlQuery' => array( + 'type' => 'string', + ), + ), + ), + 'RDSMetadata' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Database' => array( + 'type' => 'object', + 'properties' => array( + 'InstanceIdentifier' => array( + 'type' => 'string', + ), + 'DatabaseName' => array( + 'type' => 'string', + ), + ), + ), + 'DatabaseUserName' => array( + 'type' => 'string', + ), + 'SelectSqlQuery' => array( + 'type' => 'string', + ), + 'ResourceRole' => array( + 'type' => 'string', + ), + 'ServiceRole' => array( + 'type' => 'string', + ), + 'DataPipelineId' => array( + 'type' => 'string', + ), + ), + ), + 'RoleARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'ComputeStatistics' => array( + 'type' => 'boolean', + 'location' => 'json', + ), + 'DataSourceSchema' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'GetEvaluationOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'EvaluationId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'MLModelId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'EvaluationDataSourceId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'InputDataLocationS3' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'CreatedByIamUser' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'CreatedAt' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'LastUpdatedAt' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Name' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Status' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'PerformanceMetrics' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Properties' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'string', + ), + ), + ), + ), + 'LogUri' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Message' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'GetMLModelOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'MLModelId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'TrainingDataSourceId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'CreatedByIamUser' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'CreatedAt' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'LastUpdatedAt' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Name' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Status' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'SizeInBytes' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'EndpointInfo' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'PeakRequestsPerSecond' => array( + 'type' => 'numeric', + ), + 'CreatedAt' => array( + 'type' => 'string', + ), + 'EndpointUrl' => array( + 'type' => 'string', + ), + 'EndpointStatus' => array( + 'type' => 'string', + ), + ), + ), + 'TrainingParameters' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'string', + ), + ), + 'InputDataLocationS3' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'MLModelType' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'ScoreThreshold' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'ScoreThresholdLastUpdatedAt' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'LogUri' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Message' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Recipe' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Schema' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'PredictOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Prediction' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'predictedLabel' => array( + 'type' => 'string', + ), + 'predictedValue' => array( + 'type' => 'numeric', + ), + 'predictedScores' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'numeric', + ), + ), + 'details' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'UpdateBatchPredictionOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'BatchPredictionId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'UpdateDataSourceOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'DataSourceId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'UpdateEvaluationOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'EvaluationId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'UpdateMLModelOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'MLModelId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + ), + 'iterators' => array( + 'DescribeBatchPredictions' => array( + 'limit_key' => 'Limit', + 'output_token' => 'NextToken', + 'input_token' => 'NextToken', + 'result_key' => 'Results', + ), + 'DescribeDataSources' => array( + 'limit_key' => 'Limit', + 'output_token' => 'NextToken', + 'input_token' => 'NextToken', + 'result_key' => 'Results', + ), + 'DescribeEvaluations' => array( + 'limit_key' => 'Limit', + 'output_token' => 'NextToken', + 'input_token' => 'NextToken', + 'result_key' => 'Results', + ), + 'DescribeMLModels' => array( + 'limit_key' => 'Limit', + 'output_token' => 'NextToken', + 'input_token' => 'NextToken', + 'result_key' => 'Results', + ), + ), +); diff --git a/vendor/aws/Aws/OpsWorks/Enum/AppType.php b/vendor/aws/Aws/OpsWorks/Enum/AppType.php new file mode 100644 index 0000000..baaea4d --- /dev/null +++ b/vendor/aws/Aws/OpsWorks/Enum/AppType.php @@ -0,0 +1,31 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/opsworks-%s.php' + )) + ->setExceptionParser(new JsonQueryExceptionParser()) + ->build(); + } +} diff --git a/vendor/aws/Aws/OpsWorks/Resources/opsworks-2013-02-18.php b/vendor/aws/Aws/OpsWorks/Resources/opsworks-2013-02-18.php new file mode 100644 index 0000000..a8ed96c --- /dev/null +++ b/vendor/aws/Aws/OpsWorks/Resources/opsworks-2013-02-18.php @@ -0,0 +1,5495 @@ + '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( + 'AssignInstance' => 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.AssignInstance', + ), + 'InstanceId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + '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', + ), + ), + ), + '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', + ), + ), + ), + 'ChefConfiguration' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'ManageBerkshelf' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'BerkshelfVersion' => array( + 'type' => 'string', + ), + ), + ), + 'UseCustomCookbooks' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + 'UseOpsworksSecurityGroups' => 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', + ), + 'DataSources' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'DataSource', + 'type' => 'object', + 'properties' => array( + 'Type' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'DatabaseName' => array( + 'type' => 'string', + ), + ), + ), + ), + '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', + ), + ), + ), + 'Environment' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'EnvironmentVariable', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'required' => true, + 'type' => 'string', + ), + 'Value' => array( + 'required' => true, + 'type' => 'string', + ), + 'Secure' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + ), + ), + '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', + ), + 'VirtualizationType' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'SubnetId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Architecture' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'RootDeviceType' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'BlockDeviceMappings' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'BlockDeviceMapping', + 'type' => 'object', + 'properties' => array( + 'DeviceName' => array( + 'type' => 'string', + ), + 'NoDevice' => array( + 'type' => 'string', + ), + 'VirtualName' => array( + 'type' => 'string', + ), + 'Ebs' => array( + 'type' => 'object', + 'properties' => array( + 'SnapshotId' => array( + 'type' => 'string', + ), + 'Iops' => array( + 'type' => 'numeric', + ), + 'VolumeSize' => array( + 'type' => 'numeric', + ), + 'VolumeType' => array( + 'type' => 'string', + ), + 'DeleteOnTermination' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + ), + ), + ), + 'InstallUpdatesOnBoot' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + 'EbsOptimized' => 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', + ), + 'VolumeType' => array( + 'type' => 'string', + ), + 'Iops' => array( + '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', + ), + 'UseEbsOptimizedInstances' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + 'LifecycleEventConfiguration' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Shutdown' => array( + 'type' => 'object', + 'properties' => array( + 'ExecutionTimeout' => array( + 'type' => 'numeric', + ), + 'DelayUntilElbConnectionsDrained' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + 'ChefConfiguration' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'ManageBerkshelf' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'BerkshelfVersion' => array( + 'type' => 'string', + ), + ), + ), + 'UseCustomCookbooks' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + 'UseOpsworksSecurityGroups' => 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', + ), + ), + ), + 'DeregisterInstance' => 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.DeregisterInstance', + ), + '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', + ), + ), + ), + 'DeregisterRdsDbInstance' => 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.DeregisterRdsDbInstance', + ), + 'RdsDbInstanceArn' => 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', + ), + 'StackId' => 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', + ), + ), + ), + 'DescribeRdsDbInstances' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeRdsDbInstancesResult', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + '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.DescribeRdsDbInstances', + ), + 'StackId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'RdsDbInstanceArns' => 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', + ), + ), + ), + 'DescribeStackProvisioningParameters' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeStackProvisioningParametersResult', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + '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.DescribeStackProvisioningParameters', + ), + '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', + ), + ), + ), + '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', + ), + ), + ), + 'RegisterInstance' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'RegisterInstanceResult', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + '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.RegisterInstance', + ), + 'StackId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'Hostname' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'PublicIp' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'PrivateIp' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'RsaPublicKey' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'RsaPublicKeyFingerprint' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'InstanceIdentity' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Document' => array( + 'type' => 'string', + ), + 'Signature' => array( + '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', + ), + ), + ), + 'RegisterRdsDbInstance' => 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.RegisterRdsDbInstance', + ), + 'StackId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'RdsDbInstanceArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'DbUser' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'DbPassword' => 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', + ), + ), + ), + 'UnassignInstance' => 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.UnassignInstance', + ), + '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', + ), + ), + ), + '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', + ), + 'DataSources' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'DataSource', + 'type' => 'object', + 'properties' => array( + 'Type' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'DatabaseName' => array( + 'type' => 'string', + ), + ), + ), + ), + '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', + ), + ), + ), + 'Environment' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'EnvironmentVariable', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'required' => true, + 'type' => 'string', + ), + 'Value' => array( + 'required' => true, + 'type' => 'string', + ), + 'Secure' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + ), + ), + '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', + ), + 'EbsOptimized' => 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', + ), + 'VolumeType' => array( + 'type' => 'string', + ), + 'Iops' => array( + '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', + ), + 'UseEbsOptimizedInstances' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + 'LifecycleEventConfiguration' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Shutdown' => array( + 'type' => 'object', + 'properties' => array( + 'ExecutionTimeout' => array( + 'type' => 'numeric', + ), + 'DelayUntilElbConnectionsDrained' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + 'UpdateRdsDbInstance' => 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.UpdateRdsDbInstance', + ), + 'RdsDbInstanceArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'DbUser' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'DbPassword' => 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', + ), + ), + ), + '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', + ), + ), + ), + 'ChefConfiguration' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'ManageBerkshelf' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'BerkshelfVersion' => 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', + ), + 'UseOpsworksSecurityGroups' => 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', + ), + ), + ), + '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', + ), + 'DataSources' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'DataSource', + 'type' => 'object', + 'properties' => array( + 'Type' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'DatabaseName' => 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', + ), + 'Environment' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'EnvironmentVariable', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + 'Secure' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + ), + ), + ), + ), + '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', + ), + 'VirtualizationType' => 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', + ), + 'BlockDeviceMappings' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BlockDeviceMapping', + 'type' => 'object', + 'properties' => array( + 'DeviceName' => array( + 'type' => 'string', + ), + 'NoDevice' => array( + 'type' => 'string', + ), + 'VirtualName' => array( + 'type' => 'string', + ), + 'Ebs' => array( + 'type' => 'object', + 'properties' => array( + 'SnapshotId' => array( + 'type' => 'string', + ), + 'Iops' => array( + 'type' => 'numeric', + ), + 'VolumeSize' => array( + 'type' => 'numeric', + ), + 'VolumeType' => array( + 'type' => 'string', + ), + 'DeleteOnTermination' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + ), + 'InstallUpdatesOnBoot' => array( + 'type' => 'boolean', + ), + 'EbsOptimized' => array( + 'type' => 'boolean', + ), + 'ReportedAgentVersion' => array( + 'type' => 'string', + ), + 'ReportedOs' => array( + 'type' => 'object', + 'properties' => array( + 'Family' => array( + 'type' => 'string', + ), + 'Name' => array( + 'type' => 'string', + ), + 'Version' => array( + 'type' => 'string', + ), + ), + ), + 'InfrastructureClass' => array( + 'type' => 'string', + ), + 'RegisteredBy' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + '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', + ), + 'VolumeType' => array( + 'type' => 'string', + ), + 'Iops' => 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', + ), + 'UseEbsOptimizedInstances' => array( + 'type' => 'boolean', + ), + 'LifecycleEventConfiguration' => array( + 'type' => 'object', + 'properties' => array( + 'Shutdown' => array( + 'type' => 'object', + 'properties' => array( + 'ExecutionTimeout' => array( + 'type' => 'numeric', + ), + 'DelayUntilElbConnectionsDrained' => 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', + ), + 'StackId' => array( + 'type' => 'string', + ), + 'VolumeType' => array( + 'type' => 'string', + ), + 'Iops' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + 'DescribeRdsDbInstancesResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RdsDbInstances' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'RdsDbInstance', + 'type' => 'object', + 'properties' => array( + 'RdsDbInstanceArn' => array( + 'type' => 'string', + ), + 'DbInstanceIdentifier' => array( + 'type' => 'string', + ), + 'DbUser' => array( + 'type' => 'string', + ), + 'DbPassword' => array( + 'type' => 'string', + ), + 'Region' => array( + 'type' => 'string', + ), + 'Address' => array( + 'type' => 'string', + ), + 'Engine' => array( + 'type' => 'string', + ), + 'StackId' => array( + 'type' => 'string', + ), + 'MissingOnRds' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + 'DescribeStackProvisioningParametersResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'AgentInstallerUrl' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Parameters' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => 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', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'LayersCount' => array( + 'type' => 'numeric', + ), + 'AppsCount' => array( + 'type' => 'numeric', + ), + 'InstancesCount' => array( + 'type' => 'object', + 'properties' => array( + 'Assigning' => array( + 'type' => 'numeric', + ), + 'Booting' => array( + 'type' => 'numeric', + ), + 'ConnectionLost' => array( + 'type' => 'numeric', + ), + 'Deregistering' => array( + 'type' => 'numeric', + ), + 'Online' => array( + 'type' => 'numeric', + ), + 'Pending' => array( + 'type' => 'numeric', + ), + 'Rebooting' => array( + 'type' => 'numeric', + ), + 'Registered' => array( + 'type' => 'numeric', + ), + 'Registering' => 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', + ), + 'Stopping' => array( + 'type' => 'numeric', + ), + 'Terminated' => array( + 'type' => 'numeric', + ), + 'Terminating' => array( + 'type' => 'numeric', + ), + 'Unassigning' => 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', + ), + 'Arn' => 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', + ), + ), + ), + 'ChefConfiguration' => array( + 'type' => 'object', + 'properties' => array( + 'ManageBerkshelf' => array( + 'type' => 'boolean', + ), + 'BerkshelfVersion' => array( + 'type' => 'string', + ), + ), + ), + 'UseCustomCookbooks' => array( + 'type' => 'boolean', + ), + 'UseOpsworksSecurityGroups' => 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', + ), + 'VolumeType' => array( + 'type' => 'string', + ), + 'Iops' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + 'RegisterInstanceResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'InstanceId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'RegisterVolumeResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'VolumeId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + ), + 'iterators' => 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', + ), + 'DescribePermissions' => array( + 'result_key' => 'Permissions', + ), + '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', + ), + ), +); diff --git a/vendor/aws/Aws/Rds/Enum/ApplyMethod.php b/vendor/aws/Aws/Rds/Enum/ApplyMethod.php new file mode 100644 index 0000000..fe5fc29 --- /dev/null +++ b/vendor/aws/Aws/Rds/Enum/ApplyMethod.php @@ -0,0 +1,28 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/rds-%s.php' + )) + ->build(); + } +} diff --git a/vendor/aws/Aws/Rds/Resources/rds-2013-09-09.php b/vendor/aws/Aws/Rds/Resources/rds-2013-09-09.php new file mode 100644 index 0000000..48bf8b1 --- /dev/null +++ b/vendor/aws/Aws/Rds/Resources/rds-2013-09-09.php @@ -0,0 +1,5676 @@ + '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( + 'DescribeDBEngineVersions' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'DBEngineVersions', + ), + 'DescribeDBInstances' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'DBInstances', + ), + 'DescribeDBLogFiles' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'DescribeDBLogFiles', + ), + 'DescribeDBParameterGroups' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'DBParameterGroups', + ), + 'DescribeDBParameters' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'Parameters', + ), + 'DescribeDBSecurityGroups' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'DBSecurityGroups', + ), + 'DescribeDBSnapshots' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'DBSnapshots', + ), + 'DescribeDBSubnetGroups' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'DBSubnetGroups', + ), + 'DescribeEngineDefaultParameters' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'Parameters', + ), + 'DescribeEventSubscriptions' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'EventSubscriptionsList', + ), + 'DescribeEvents' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'Events', + ), + 'DescribeOptionGroupOptions' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'OptionGroupOptions', + ), + 'DescribeOptionGroups' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'OptionGroupsList', + ), + 'DescribeOrderableDBInstanceOptions' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'OrderableDBInstanceOptions', + ), + 'DescribeReservedDBInstances' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'ReservedDBInstances', + ), + 'DescribeReservedDBInstancesOfferings' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'ReservedDBInstancesOfferings', + ), + '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', + ), + ), + ), +); diff --git a/vendor/aws/Aws/Rds/Resources/rds-2014-09-01.php b/vendor/aws/Aws/Rds/Resources/rds-2014-09-01.php new file mode 100644 index 0000000..bcaa2f4 --- /dev/null +++ b/vendor/aws/Aws/Rds/Resources/rds-2014-09-01.php @@ -0,0 +1,6155 @@ + '2014-09-01', + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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', + ), + ), + ), + 'CopyDBParameterGroup' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DBParameterGroupWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CopyDBParameterGroup', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-09-01', + ), + 'SourceDBParameterGroupIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TargetDBParameterGroupIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TargetDBParameterGroupDescription' => 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' => 'DBParameterGroupName does not refer to an existing DB parameter group.', + 'class' => 'DBParameterGroupNotFoundException', + ), + array( + 'reason' => 'A DB parameter group with the same name exists.', + 'class' => 'DBParameterGroupAlreadyExistsException', + ), + array( + 'reason' => 'Request would result in user exceeding the allowed number of DB parameter groups.', + 'class' => 'DBParameterGroupQuotaExceededException', + ), + ), + ), + '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' => '2014-09-01', + ), + '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', + ), + ), + ), + 'CopyOptionGroup' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'OptionGroupWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CopyOptionGroup', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-09-01', + ), + 'SourceOptionGroupIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TargetOptionGroupIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TargetOptionGroupDescription' => 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 specified option group could not be found.', + 'class' => 'OptionGroupNotFoundException', + ), + array( + 'reason' => 'The quota of 20 option groups was exceeded for this AWS account.', + 'class' => 'OptionGroupQuotaExceededException', + ), + ), + ), + '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' => '2014-09-01', + ), + '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', + ), + ), + ), + ), + 'StorageType' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TdeCredentialArn' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TdeCredentialPassword' => 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' => 'DBSubnetGroupName does not refer to an existing DB subnet group.', + 'class' => 'DBSubnetGroupNotFoundException', + ), + array( + 'reason' => 'Subnets in the DB subnet group should cover at least two Availability Zones unless there is only one Availability 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' => 'StorageType specified cannot be associated with the DB Instance.', + 'class' => 'StorageTypeNotSupportedException', + ), + array( + 'reason' => 'Specified CIDRIP or EC2 security group is not authorized for the specified DB security group. RDS may not also be authorized via IAM to perform necessary actions on your behalf.', + 'class' => 'AuthorizationNotFoundException', + ), + ), + ), + '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' => '2014-09-01', + ), + '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', + ), + 'StorageType' => 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 two Availability Zones unless there is only one Availability 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', + ), + array( + 'reason' => 'StorageType specified cannot be associated with the DB Instance.', + 'class' => 'StorageTypeNotSupportedException', + ), + ), + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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 two Availability Zones unless there is only one Availability 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' => '2014-09-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', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + 'Engine' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'EngineVersion' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'DBParameterGroupFamily' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Filters' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Filters.member', + 'items' => array( + 'name' => 'Filter', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.member', + 'items' => array( + 'name' => 'Value', + 'type' => 'string', + ), + ), + ), + ), + ), + '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' => '2014-09-01', + ), + '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( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.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' => '2014-09-01', + ), + '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', + ), + 'Filters' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Filters.member', + 'items' => array( + 'name' => 'Filter', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.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', + ), + ), + ), + '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' => '2014-09-01', + ), + '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( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.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' => '2014-09-01', + ), + 'DBParameterGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Source' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Filters' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Filters.member', + 'items' => array( + 'name' => 'Filter', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.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', + ), + ), + ), + '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' => '2014-09-01', + ), + '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( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.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' => '2014-09-01', + ), + '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( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.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' => '2014-09-01', + ), + '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( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.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' => '2014-09-01', + ), + 'DBParameterGroupFamily' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Filters' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Filters.member', + 'items' => array( + 'name' => 'Filter', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.member', + 'items' => array( + 'name' => 'Value', + 'type' => 'string', + ), + ), + ), + ), + ), + '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' => '2014-09-01', + ), + 'SourceType' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Filters' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Filters.member', + 'items' => array( + 'name' => 'Filter', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.member', + 'items' => array( + 'name' => 'Value', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + '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' => '2014-09-01', + ), + '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( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.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' => '2014-09-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', + ), + 'EventCategories' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'EventCategories.member', + 'items' => array( + 'name' => 'EventCategory', + 'type' => 'string', + ), + ), + 'Filters' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Filters.member', + 'items' => array( + 'name' => 'Filter', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.member', + 'items' => array( + 'name' => 'Value', + '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' => '2014-09-01', + ), + 'EngineName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MajorEngineVersion' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Filters' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Filters.member', + 'items' => array( + 'name' => 'Filter', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.member', + 'items' => array( + 'name' => 'Value', + 'type' => 'string', + ), + ), + ), + ), + ), + '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' => '2014-09-01', + ), + '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( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.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' => '2014-09-01', + ), + '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', + ), + 'Filters' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Filters.member', + 'items' => array( + 'name' => 'Filter', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.member', + 'items' => array( + 'name' => 'Value', + 'type' => 'string', + ), + ), + ), + ), + ), + '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' => '2014-09-01', + ), + '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( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.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' => '2014-09-01', + ), + '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( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.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' => '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + 'ResourceName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Filters' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Filters.member', + 'items' => array( + 'name' => 'Filter', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.member', + 'items' => array( + 'name' => 'Value', + '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', + ), + ), + ), + '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' => '2014-09-01', + ), + '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', + ), + 'StorageType' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TdeCredentialArn' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TdeCredentialPassword' => 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', + ), + array( + 'reason' => 'StorageType specified cannot be associated with the DB Instance.', + 'class' => 'StorageTypeNotSupportedException', + ), + array( + 'reason' => 'Specified CIDRIP or EC2 security group is not authorized for the specified DB security group. RDS may not also be authorized via IAM to perform necessary actions on your behalf.', + 'class' => 'AuthorizationNotFoundException', + ), + ), + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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 two Availability Zones unless there is only one Availability 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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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' => '2014-09-01', + ), + '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', + ), + ), + ), + ), + 'StorageType' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TdeCredentialArn' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TdeCredentialPassword' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + '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 two Availability Zones unless there is only one Availability 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', + ), + array( + 'reason' => 'StorageType specified cannot be associated with the DB Instance.', + 'class' => 'StorageTypeNotSupportedException', + ), + array( + 'reason' => 'Specified CIDRIP or EC2 security group is not authorized for the specified DB security group. RDS may not also be authorized via IAM to perform necessary actions on your behalf.', + 'class' => 'AuthorizationNotFoundException', + ), + ), + ), + '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' => '2014-09-01', + ), + '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', + ), + ), + ), + ), + 'StorageType' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TdeCredentialArn' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TdeCredentialPassword' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + '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 two Availability Zones unless there is only one Availability 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', + ), + array( + 'reason' => 'StorageType specified cannot be associated with the DB Instance.', + 'class' => 'StorageTypeNotSupportedException', + ), + array( + 'reason' => 'Specified CIDRIP or EC2 security group is not authorized for the specified DB security group. RDS may not also be authorized via IAM to perform necessary actions on your behalf.', + 'class' => 'AuthorizationNotFoundException', + ), + ), + ), + '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' => '2014-09-01', + ), + '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. RDS may not also be authorized via IAM to perform necessary actions on your behalf.', + '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', + ), + ), + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + ), + ), + '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', + ), + 'StorageType' => array( + 'type' => 'string', + ), + 'TdeCredentialArn' => 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', + ), + ), + ), + ), + ), + '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', + ), + ), + ), + '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', + ), + 'StorageType' => 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', + ), + ), + ), + ), + 'StorageType' => array( + 'type' => 'string', + ), + 'TdeCredentialArn' => 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', + ), + ), + ), + 'SubnetStatus' => 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', + ), + ), + ), + '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', + ), + 'StorageType' => 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', + ), + ), + ), + ), + 'StorageType' => array( + 'type' => 'string', + ), + 'TdeCredentialArn' => 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', + ), + 'StorageType' => array( + 'type' => 'string', + ), + 'TdeCredentialArn' => 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', + ), + ), + ), + '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', + ), + ), + ), + ), + 'MultiAZCapable' => array( + 'type' => 'boolean', + ), + 'ReadReplicaCapable' => array( + 'type' => 'boolean', + ), + 'Vpc' => array( + 'type' => 'boolean', + ), + 'StorageType' => array( + 'type' => 'string', + ), + 'SupportsIops' => 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( + 'DescribeDBEngineVersions' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'DBEngineVersions', + ), + 'DescribeDBInstances' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'DBInstances', + ), + 'DescribeDBLogFiles' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'DescribeDBLogFiles', + ), + 'DescribeDBParameterGroups' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'DBParameterGroups', + ), + 'DescribeDBParameters' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'Parameters', + ), + 'DescribeDBSecurityGroups' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'DBSecurityGroups', + ), + 'DescribeDBSnapshots' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'DBSnapshots', + ), + 'DescribeDBSubnetGroups' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'DBSubnetGroups', + ), + 'DescribeEngineDefaultParameters' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'Parameters', + ), + 'DescribeEventSubscriptions' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'EventSubscriptionsList', + ), + 'DescribeEvents' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'Events', + ), + 'DescribeOptionGroupOptions' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'OptionGroupOptions', + ), + 'DescribeOptionGroups' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'OptionGroupsList', + ), + 'DescribeOrderableDBInstanceOptions' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'OrderableDBInstanceOptions', + ), + 'DescribeReservedDBInstances' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'ReservedDBInstances', + ), + 'DescribeReservedDBInstancesOfferings' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'ReservedDBInstancesOfferings', + ), + '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', + ), + ), + ), +); diff --git a/vendor/aws/Aws/Rds/Resources/rds-2014-10-31.php b/vendor/aws/Aws/Rds/Resources/rds-2014-10-31.php new file mode 100644 index 0000000..de9bb44 --- /dev/null +++ b/vendor/aws/Aws/Rds/Resources/rds-2014-10-31.php @@ -0,0 +1,6479 @@ + '2014-10-31', + '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' => '2014-10-31', + ), + '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' => '2014-10-31', + ), + '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', + ), + ), + ), + 'ApplyPendingMaintenanceAction' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ResourcePendingMaintenanceActionsWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ApplyPendingMaintenanceAction', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-10-31', + ), + 'ResourceIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'ApplyAction' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'OptInType' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified resource ID was not found.', + 'class' => 'ResourceNotFoundException', + ), + ), + ), + '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' => '2014-10-31', + ), + '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', + ), + ), + ), + 'CopyDBParameterGroup' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DBParameterGroupWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CopyDBParameterGroup', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-10-31', + ), + 'SourceDBParameterGroupIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TargetDBParameterGroupIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TargetDBParameterGroupDescription' => 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' => 'DBParameterGroupName does not refer to an existing DB parameter group.', + 'class' => 'DBParameterGroupNotFoundException', + ), + array( + 'reason' => 'A DB parameter group with the same name exists.', + 'class' => 'DBParameterGroupAlreadyExistsException', + ), + array( + 'reason' => 'Request would result in user exceeding the allowed number of DB parameter groups.', + 'class' => 'DBParameterGroupQuotaExceededException', + ), + ), + ), + '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' => '2014-10-31', + ), + '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', + ), + ), + ), + 'CopyOptionGroup' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'OptionGroupWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CopyOptionGroup', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-10-31', + ), + 'SourceOptionGroupIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TargetOptionGroupIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TargetOptionGroupDescription' => 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 specified option group could not be found.', + 'class' => 'OptionGroupNotFoundException', + ), + array( + 'reason' => 'The quota of 20 option groups was exceeded for this AWS account.', + 'class' => 'OptionGroupQuotaExceededException', + ), + ), + ), + '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' => '2014-10-31', + ), + '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', + ), + ), + ), + ), + 'StorageType' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TdeCredentialArn' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TdeCredentialPassword' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'StorageEncrypted' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'KmsKeyId' => 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' => 'DBSubnetGroupName does not refer to an existing DB subnet group.', + 'class' => 'DBSubnetGroupNotFoundException', + ), + array( + 'reason' => 'Subnets in the DB subnet group should cover at least two Availability Zones unless there is only one Availability 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' => 'StorageType specified cannot be associated with the DB Instance.', + 'class' => 'StorageTypeNotSupportedException', + ), + array( + 'reason' => 'Specified CIDRIP or EC2 security group is not authorized for the specified DB security group. RDS may not also be authorized via IAM to perform necessary actions on your behalf.', + 'class' => 'AuthorizationNotFoundException', + ), + array( + 'reason' => 'Error accessing KMS key.', + 'class' => 'KMSKeyNotAccessibleException', + ), + ), + ), + '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' => '2014-10-31', + ), + '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', + ), + 'StorageType' => 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 two Availability Zones unless there is only one Availability 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', + ), + array( + 'reason' => 'StorageType specified cannot be associated with the DB Instance.', + 'class' => 'StorageTypeNotSupportedException', + ), + array( + 'reason' => 'Error accessing KMS key.', + 'class' => 'KMSKeyNotAccessibleException', + ), + ), + ), + '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' => '2014-10-31', + ), + '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' => '2014-10-31', + ), + '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' => '2014-10-31', + ), + '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' => '2014-10-31', + ), + '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 two Availability Zones unless there is only one Availability 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' => '2014-10-31', + ), + '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' => '2014-10-31', + ), + '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' => '2014-10-31', + ), + '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' => '2014-10-31', + ), + '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' => '2014-10-31', + ), + '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' => '2014-10-31', + ), + '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' => '2014-10-31', + ), + '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' => '2014-10-31', + ), + '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' => '2014-10-31', + ), + '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', + ), + ), + ), + 'DescribeAccountAttributes' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'AccountAttributesMessage', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeAccountAttributes', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-10-31', + ), + ), + ), + 'DescribeCertificates' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'CertificateMessage', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeCertificates', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-10-31', + ), + 'CertificateIdentifier' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Filters' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Filters.member', + 'items' => array( + 'name' => 'Filter', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.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' => 'CertificateIdentifier does not refer to an existing certificate.', + 'class' => 'CertificateNotFoundException', + ), + ), + ), + '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' => '2014-10-31', + ), + 'Engine' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'EngineVersion' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'DBParameterGroupFamily' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Filters' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Filters.member', + 'items' => array( + 'name' => 'Filter', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.member', + 'items' => array( + 'name' => 'Value', + 'type' => 'string', + ), + ), + ), + ), + ), + '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' => '2014-10-31', + ), + '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( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.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' => '2014-10-31', + ), + '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', + ), + 'Filters' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Filters.member', + 'items' => array( + 'name' => 'Filter', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.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', + ), + ), + ), + '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' => '2014-10-31', + ), + '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( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.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' => '2014-10-31', + ), + 'DBParameterGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Source' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Filters' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Filters.member', + 'items' => array( + 'name' => 'Filter', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.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', + ), + ), + ), + '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' => '2014-10-31', + ), + '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( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.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' => '2014-10-31', + ), + '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( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.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' => '2014-10-31', + ), + '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( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.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' => '2014-10-31', + ), + 'DBParameterGroupFamily' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Filters' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Filters.member', + 'items' => array( + 'name' => 'Filter', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.member', + 'items' => array( + 'name' => 'Value', + 'type' => 'string', + ), + ), + ), + ), + ), + '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' => '2014-10-31', + ), + 'SourceType' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Filters' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Filters.member', + 'items' => array( + 'name' => 'Filter', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.member', + 'items' => array( + 'name' => 'Value', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + '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' => '2014-10-31', + ), + '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( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.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' => '2014-10-31', + ), + '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', + ), + ), + 'Filters' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Filters.member', + 'items' => array( + 'name' => 'Filter', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.member', + 'items' => array( + 'name' => 'Value', + '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' => '2014-10-31', + ), + 'EngineName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MajorEngineVersion' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Filters' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Filters.member', + 'items' => array( + 'name' => 'Filter', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.member', + 'items' => array( + 'name' => 'Value', + 'type' => 'string', + ), + ), + ), + ), + ), + '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' => '2014-10-31', + ), + '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( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.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' => '2014-10-31', + ), + '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', + ), + 'Filters' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Filters.member', + 'items' => array( + 'name' => 'Filter', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.member', + 'items' => array( + 'name' => 'Value', + 'type' => 'string', + ), + ), + ), + ), + ), + 'MaxRecords' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + ), + 'DescribePendingMaintenanceActions' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'PendingMaintenanceActionsMessage', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribePendingMaintenanceActions', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-10-31', + ), + 'ResourceIdentifier' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Filters' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Filters.member', + 'items' => array( + 'name' => 'Filter', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.member', + 'items' => array( + 'name' => 'Value', + 'type' => 'string', + ), + ), + ), + ), + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MaxRecords' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified resource ID was not found.', + 'class' => 'ResourceNotFoundException', + ), + ), + ), + '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' => '2014-10-31', + ), + '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( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.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' => '2014-10-31', + ), + '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( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.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' => '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' => '2014-10-31', + ), + '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' => '2014-10-31', + ), + 'ResourceName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Filters' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Filters.member', + 'items' => array( + 'name' => 'Filter', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Values' => array( + 'required' => true, + 'type' => 'array', + 'sentAs' => 'Values.member', + 'items' => array( + 'name' => 'Value', + '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', + ), + ), + ), + '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' => '2014-10-31', + ), + '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', + ), + 'StorageType' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TdeCredentialArn' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TdeCredentialPassword' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'CACertificateIdentifier' => 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', + ), + array( + 'reason' => 'StorageType specified cannot be associated with the DB Instance.', + 'class' => 'StorageTypeNotSupportedException', + ), + array( + 'reason' => 'Specified CIDRIP or EC2 security group is not authorized for the specified DB security group. RDS may not also be authorized via IAM to perform necessary actions on your behalf.', + 'class' => 'AuthorizationNotFoundException', + ), + array( + 'reason' => 'CertificateIdentifier does not refer to an existing certificate.', + 'class' => 'CertificateNotFoundException', + ), + ), + ), + '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' => '2014-10-31', + ), + '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' => '2014-10-31', + ), + '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 two Availability Zones unless there is only one Availability 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' => '2014-10-31', + ), + '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' => '2014-10-31', + ), + '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' => '2014-10-31', + ), + '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' => '2014-10-31', + ), + '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' => '2014-10-31', + ), + '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' => '2014-10-31', + ), + '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' => '2014-10-31', + ), + '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' => '2014-10-31', + ), + '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' => '2014-10-31', + ), + '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', + ), + ), + ), + ), + 'StorageType' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TdeCredentialArn' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TdeCredentialPassword' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + '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 two Availability Zones unless there is only one Availability 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', + ), + array( + 'reason' => 'StorageType specified cannot be associated with the DB Instance.', + 'class' => 'StorageTypeNotSupportedException', + ), + array( + 'reason' => 'Specified CIDRIP or EC2 security group is not authorized for the specified DB security group. RDS may not also be authorized via IAM to perform necessary actions on your behalf.', + 'class' => 'AuthorizationNotFoundException', + ), + array( + 'reason' => 'Error accessing KMS key.', + 'class' => 'KMSKeyNotAccessibleException', + ), + ), + ), + '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' => '2014-10-31', + ), + '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', + ), + ), + ), + ), + 'StorageType' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TdeCredentialArn' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TdeCredentialPassword' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + '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 two Availability Zones unless there is only one Availability 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', + ), + array( + 'reason' => 'StorageType specified cannot be associated with the DB Instance.', + 'class' => 'StorageTypeNotSupportedException', + ), + array( + 'reason' => 'Specified CIDRIP or EC2 security group is not authorized for the specified DB security group. RDS may not also be authorized via IAM to perform necessary actions on your behalf.', + 'class' => 'AuthorizationNotFoundException', + ), + array( + 'reason' => 'Error accessing KMS key.', + 'class' => 'KMSKeyNotAccessibleException', + ), + ), + ), + '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' => '2014-10-31', + ), + '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. RDS may not also be authorized via IAM to perform necessary actions on your behalf.', + '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, + ), + 'ResourcePendingMaintenanceActionsWrapper' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ResourcePendingMaintenanceActions' => array( + 'type' => 'object', + 'location' => 'xml', + 'data' => array( + 'wrapper' => true, + ), + 'properties' => array( + 'ResourceIdentifier' => array( + 'type' => 'string', + ), + 'PendingMaintenanceActionDetails' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'PendingMaintenanceAction', + 'type' => 'object', + 'sentAs' => 'PendingMaintenanceAction', + 'properties' => array( + 'Action' => array( + 'type' => 'string', + ), + 'AutoAppliedAfterDate' => array( + 'type' => 'string', + ), + 'ForcedApplyDate' => array( + 'type' => 'string', + ), + 'OptInStatus' => array( + 'type' => 'string', + ), + 'CurrentApplyDate' => array( + 'type' => 'string', + ), + 'Description' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + ), + ), + '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', + ), + 'StorageType' => array( + 'type' => 'string', + ), + 'TdeCredentialArn' => array( + 'type' => 'string', + ), + 'Encrypted' => array( + 'type' => 'boolean', + ), + 'KmsKeyId' => 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', + ), + ), + ), + ), + ), + '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', + ), + ), + ), + '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', + ), + 'StorageType' => array( + 'type' => 'string', + ), + 'CACertificateIdentifier' => 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', + ), + ), + ), + ), + 'StorageType' => array( + 'type' => 'string', + ), + 'TdeCredentialArn' => array( + 'type' => 'string', + ), + 'StorageEncrypted' => array( + 'type' => 'boolean', + ), + 'KmsKeyId' => array( + 'type' => 'string', + ), + 'DbiResourceId' => array( + 'type' => 'string', + ), + 'CACertificateIdentifier' => 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', + ), + ), + ), + 'SubnetStatus' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'AccountAttributesMessage' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'AccountQuotas' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'AccountQuota', + 'type' => 'object', + 'sentAs' => 'AccountQuota', + 'properties' => array( + 'AccountQuotaName' => array( + 'type' => 'string', + ), + 'Used' => array( + 'type' => 'numeric', + ), + 'Max' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + 'CertificateMessage' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Certificates' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'Certificate', + 'type' => 'object', + 'sentAs' => 'Certificate', + 'properties' => array( + 'CertificateIdentifier' => array( + 'type' => 'string', + ), + 'CertificateType' => array( + 'type' => 'string', + ), + 'Thumbprint' => array( + 'type' => 'string', + ), + 'ValidFrom' => array( + 'type' => 'string', + ), + 'ValidTill' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + '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', + ), + ), + ), + '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', + ), + 'StorageType' => array( + 'type' => 'string', + ), + 'CACertificateIdentifier' => 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', + ), + ), + ), + ), + 'StorageType' => array( + 'type' => 'string', + ), + 'TdeCredentialArn' => array( + 'type' => 'string', + ), + 'StorageEncrypted' => array( + 'type' => 'boolean', + ), + 'KmsKeyId' => array( + 'type' => 'string', + ), + 'DbiResourceId' => array( + 'type' => 'string', + ), + 'CACertificateIdentifier' => 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', + ), + 'StorageType' => array( + 'type' => 'string', + ), + 'TdeCredentialArn' => array( + 'type' => 'string', + ), + 'Encrypted' => array( + 'type' => 'boolean', + ), + 'KmsKeyId' => 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', + ), + ), + ), + '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', + ), + ), + ), + ), + 'MultiAZCapable' => array( + 'type' => 'boolean', + ), + 'ReadReplicaCapable' => array( + 'type' => 'boolean', + ), + 'Vpc' => array( + 'type' => 'boolean', + ), + 'SupportsStorageEncryption' => array( + 'type' => 'boolean', + ), + 'StorageType' => array( + 'type' => 'string', + ), + 'SupportsIops' => array( + 'type' => 'boolean', + ), + ), + ), + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'PendingMaintenanceActionsMessage' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'PendingMaintenanceActions' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'ResourcePendingMaintenanceActions', + 'type' => 'object', + 'sentAs' => 'ResourcePendingMaintenanceActions', + 'properties' => array( + 'ResourceIdentifier' => array( + 'type' => 'string', + ), + 'PendingMaintenanceActionDetails' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'PendingMaintenanceAction', + 'type' => 'object', + 'sentAs' => 'PendingMaintenanceAction', + 'properties' => array( + 'Action' => array( + 'type' => 'string', + ), + 'AutoAppliedAfterDate' => array( + 'type' => 'string', + ), + 'ForcedApplyDate' => array( + 'type' => 'string', + ), + 'OptInStatus' => array( + 'type' => 'string', + ), + 'CurrentApplyDate' => array( + 'type' => 'string', + ), + 'Description' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + '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( + 'DescribeEngineDefaultParameters' => array( + 'output_token' => 'Marker', + 'result_key' => 'Parameters', + ), + ), + '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', + ), + ), + ), +); diff --git a/vendor/aws/Aws/Redshift/Enum/SourceType.php b/vendor/aws/Aws/Redshift/Enum/SourceType.php new file mode 100644 index 0000000..d6a8798 --- /dev/null +++ b/vendor/aws/Aws/Redshift/Enum/SourceType.php @@ -0,0 +1,30 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/redshift-%s.php' + )) + ->build(); + } +} diff --git a/vendor/aws/Aws/Redshift/Resources/redshift-2012-12-01.php b/vendor/aws/Aws/Redshift/Resources/redshift-2012-12-01.php new file mode 100644 index 0000000..5f2fdb0 --- /dev/null +++ b/vendor/aws/Aws/Redshift/Resources/redshift-2012-12-01.php @@ -0,0 +1,5593 @@ + '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.', + '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.', + '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', + ), + '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', + ), + ), + ), + ), + 'KmsKeyId' => 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 Cluster 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 Cluster 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', + ), + array( + 'reason' => 'The request exceeds the limit of 10 tags for the resource.', + 'class' => 'TagLimitExceededException', + ), + array( + 'reason' => 'The tag is invalid.', + 'class' => 'InvalidTagException', + ), + ), + ), + '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', + ), + '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 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 Cluster Management Guide.', + 'class' => 'ClusterParameterGroupQuotaExceededException', + ), + array( + 'reason' => 'A cluster parameter group with the same name already exists.', + 'class' => 'ClusterParameterGroupAlreadyExistsException', + ), + array( + 'reason' => 'The request exceeds the limit of 10 tags for the resource.', + 'class' => 'TagLimitExceededException', + ), + array( + 'reason' => 'The tag is invalid.', + 'class' => 'InvalidTagException', + ), + ), + ), + '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', + ), + '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 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 Cluster Management Guide.', + 'class' => 'ClusterSecurityGroupQuotaExceededException', + ), + array( + 'reason' => 'The request exceeds the limit of 10 tags for the resource.', + 'class' => 'TagLimitExceededException', + ), + array( + 'reason' => 'The tag is invalid.', + 'class' => 'InvalidTagException', + ), + ), + ), + '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', + ), + '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 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', + ), + array( + 'reason' => 'The request exceeds the limit of 10 tags for the resource.', + 'class' => 'TagLimitExceededException', + ), + array( + 'reason' => 'The tag is invalid.', + 'class' => 'InvalidTagException', + ), + ), + ), + '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', + ), + ), + '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 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 Cluster 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 Cluster 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', + ), + array( + 'reason' => 'The request exceeds the limit of 10 tags for the resource.', + 'class' => 'TagLimitExceededException', + ), + array( + 'reason' => 'The tag is invalid.', + 'class' => 'InvalidTagException', + ), + ), + ), + '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', + ), + '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 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 Cluster 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', + ), + array( + 'reason' => 'The request exceeds the limit of 10 tags for the resource.', + 'class' => 'TagLimitExceededException', + ), + array( + 'reason' => 'The tag is invalid.', + 'class' => 'InvalidTagException', + ), + ), + ), + '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', + ), + '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' => '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 Cluster Management Guide.', + 'class' => 'HsmClientCertificateQuotaExceededException', + ), + array( + 'reason' => 'The request exceeds the limit of 10 tags for the resource.', + 'class' => 'TagLimitExceededException', + ), + array( + 'reason' => 'The tag is invalid.', + 'class' => 'InvalidTagException', + ), + ), + ), + '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', + ), + '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' => '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 Cluster Management Guide.', + 'class' => 'HsmConfigurationQuotaExceededException', + ), + array( + 'reason' => 'The request exceeds the limit of 10 tags for the resource.', + 'class' => 'TagLimitExceededException', + ), + array( + 'reason' => 'The tag is invalid.', + 'class' => 'InvalidTagException', + ), + ), + ), + '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' => '2012-12-01', + ), + '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' => 'The request exceeds the limit of 10 tags for the resource.', + 'class' => 'TagLimitExceededException', + ), + array( + 'reason' => 'The resource could not be found.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'The tag is invalid.', + 'class' => 'InvalidTagException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The subscription request is invalid because it is a duplicate request. This subscription request is already in progress.', + 'class' => 'InvalidSubscriptionStateException', + ), + ), + ), + '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', + ), + ), + ), + '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' => '2012-12-01', + ), + 'ResourceName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TagKeys' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'TagKeys.member', + 'items' => array( + 'name' => 'TagKey', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The resource could not be found.', + 'class' => 'ResourceNotFoundException', + ), + ), + ), + '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', + ), + 'TagKeys' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'TagKeys.member', + 'items' => array( + 'name' => 'TagKey', + 'type' => 'string', + ), + ), + 'TagValues' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'TagValues.member', + 'items' => array( + 'name' => 'TagValue', + 'type' => 'string', + ), + ), + ), + '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', + ), + 'TagKeys' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'TagKeys.member', + 'items' => array( + 'name' => 'TagKey', + 'type' => 'string', + ), + ), + 'TagValues' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'TagValues.member', + 'items' => array( + 'name' => 'TagValue', + 'type' => 'string', + ), + ), + ), + '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', + ), + 'TagKeys' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'TagKeys.member', + 'items' => array( + 'name' => 'TagKey', + 'type' => 'string', + ), + ), + 'TagValues' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'TagValues.member', + 'items' => array( + 'name' => 'TagValue', + 'type' => 'string', + ), + ), + ), + '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', + ), + 'TagKeys' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'TagKeys.member', + 'items' => array( + 'name' => 'TagKey', + 'type' => 'string', + ), + ), + 'TagValues' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'TagValues.member', + 'items' => array( + 'name' => 'TagValue', + 'type' => 'string', + ), + ), + ), + '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', + ), + 'TagKeys' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'TagKeys.member', + 'items' => array( + 'name' => 'TagKey', + 'type' => 'string', + ), + ), + 'TagValues' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'TagValues.member', + 'items' => array( + 'name' => 'TagValue', + 'type' => 'string', + ), + ), + ), + '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', + ), + 'TagKeys' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'TagKeys.member', + 'items' => array( + 'name' => 'TagKey', + 'type' => 'string', + ), + ), + 'TagValues' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'TagValues.member', + 'items' => array( + 'name' => 'TagValue', + 'type' => 'string', + ), + ), + ), + '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', + ), + 'TagKeys' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'TagKeys.member', + 'items' => array( + 'name' => 'TagKey', + 'type' => 'string', + ), + ), + 'TagValues' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'TagValues.member', + 'items' => array( + 'name' => 'TagValue', + 'type' => 'string', + ), + ), + ), + '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', + ), + ), + ), + 'DescribeTags' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'TaggedResourceListMessage', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeTags', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ResourceName' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'ResourceType' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MaxRecords' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TagKeys' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'TagKeys.member', + 'items' => array( + 'name' => 'TagKey', + 'type' => 'string', + ), + ), + 'TagValues' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'TagValues.member', + 'items' => array( + 'name' => 'TagValue', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The resource could not be found.', + 'class' => 'ResourceNotFoundException', + ), + ), + ), + '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' => 'The specified cluster is not in the available state.', + 'class' => 'InvalidClusterStateException', + ), + 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', + ), + 'NewClusterIdentifier' => 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 Cluster 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' => 'A 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', + ), + array( + 'reason' => 'The account already has a cluster with the given identifier.', + 'class' => 'ClusterAlreadyExistsException', + ), + ), + ), + '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 Cluster 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', + ), + array( + 'reason' => 'The subscription request is invalid because it is a duplicate request. This subscription request is already in progress.', + 'class' => 'InvalidSubscriptionStateException', + ), + ), + ), + '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', + ), + array( + 'reason' => 'The specified cluster is not in the available state.', + 'class' => 'InvalidClusterStateException', + ), + ), + ), + '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 Cluster 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', + ), + 'ClusterParameterGroupName' => array( + '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', + ), + ), + 'PreferredMaintenanceWindow' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'AutomatedSnapshotRetentionPeriod' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'KmsKeyId' => 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 Cluster 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 Cluster 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', + ), + 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', + ), + ), + ), + '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', + ), + 'Tags' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'sentAs' => 'Tag', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => 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', + ), + 'Tags' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'sentAs' => 'Tag', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'Tags' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'sentAs' => 'Tag', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => 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', + ), + 'KmsKeyId' => array( + 'type' => 'string', + ), + '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', + ), + 'Tags' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'sentAs' => 'Tag', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => 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', + ), + 'ClusterIdentifier' => array( + 'type' => 'string', + ), + ), + ), + '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', + ), + ), + ), + 'ClusterRevisionNumber' => array( + 'type' => 'string', + ), + 'Tags' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'sentAs' => 'Tag', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + ), + ), + ), + 'KmsKeyId' => 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', + ), + 'Tags' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'sentAs' => 'Tag', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => 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', + ), + ), + ), + ), + 'Tags' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'sentAs' => 'Tag', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => 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', + ), + 'Tags' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'sentAs' => 'Tag', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + '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', + ), + 'Tags' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'sentAs' => 'Tag', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => 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', + ), + 'Tags' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'sentAs' => 'Tag', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => 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', + ), + 'Tags' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'sentAs' => 'Tag', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => 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', + ), + 'Tags' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'sentAs' => 'Tag', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => 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', + ), + 'Tags' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'sentAs' => 'Tag', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'Tags' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'sentAs' => 'Tag', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => 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', + ), + 'KmsKeyId' => array( + 'type' => 'string', + ), + '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', + ), + 'Tags' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'sentAs' => 'Tag', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => 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', + ), + ), + ), + ), + 'Tags' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'sentAs' => 'Tag', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => 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', + ), + 'ClusterIdentifier' => array( + 'type' => 'string', + ), + ), + ), + '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', + ), + ), + ), + 'ClusterRevisionNumber' => array( + 'type' => 'string', + ), + 'Tags' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'sentAs' => 'Tag', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + ), + ), + ), + 'KmsKeyId' => 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', + ), + 'Tags' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'sentAs' => 'Tag', + 'properties' => array( + 'Key' => 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', + ), + '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', + ), + 'Tags' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'sentAs' => 'Tag', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => 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', + ), + 'Tags' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'sentAs' => 'Tag', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => 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', + ), + ), + 'AvgResizeRateInMegaBytesPerSecond' => array( + 'type' => 'numeric', + 'location' => 'xml', + ), + 'TotalResizeDataInMegaBytes' => array( + 'type' => 'numeric', + 'location' => 'xml', + ), + 'ProgressInMegaBytes' => array( + 'type' => 'numeric', + 'location' => 'xml', + ), + 'ElapsedTimeInSeconds' => array( + 'type' => 'numeric', + 'location' => 'xml', + ), + 'EstimatedTimeToCompletionInSeconds' => array( + 'type' => 'numeric', + 'location' => 'xml', + ), + ), + ), + 'TaggedResourceListMessage' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'TaggedResources' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'TaggedResource', + 'type' => 'object', + 'sentAs' => 'TaggedResource', + 'properties' => array( + 'Tag' => array( + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + ), + ), + 'ResourceName' => array( + 'type' => 'string', + ), + 'ResourceType' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + '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( + 'DescribeClusterParameterGroups' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'ParameterGroups', + ), + 'DescribeClusterParameters' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'Parameters', + ), + 'DescribeClusterSecurityGroups' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'ClusterSecurityGroups', + ), + 'DescribeClusterSnapshots' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'Snapshots', + ), + 'DescribeClusterSubnetGroups' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'ClusterSubnetGroups', + ), + 'DescribeClusterVersions' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'ClusterVersions', + ), + 'DescribeClusters' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'Clusters', + ), + 'DescribeDefaultClusterParameters' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'Parameters', + ), + 'DescribeEventSubscriptions' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'EventSubscriptionsList', + ), + 'DescribeEvents' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'Events', + ), + 'DescribeHsmClientCertificates' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'HsmClientCertificates', + ), + 'DescribeHsmConfigurations' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'HsmConfigurations', + ), + 'DescribeOrderableClusterOptions' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'OrderableClusterOptions', + ), + 'DescribeReservedNodeOfferings' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'ReservedNodeOfferings', + ), + 'DescribeReservedNodes' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'ReservedNodes', + ), + 'DescribeTags' => array( + 'input_token' => 'Marker', + 'output_token' => 'Marker', + 'limit_key' => 'MaxRecords', + 'result_key' => 'TaggedResources', + ), + ), + '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', + ), + ), + ), +); diff --git a/vendor/aws/Aws/Route53/Enum/Action.php b/vendor/aws/Aws/Route53/Enum/Action.php new file mode 100644 index 0000000..42652e5 --- /dev/null +++ b/vendor/aws/Aws/Route53/Enum/Action.php @@ -0,0 +1,29 @@ + '2013-04-01', + '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( + 'AssociateVPCWithHostedZone' => array( + 'httpMethod' => 'POST', + 'uri' => '/2013-04-01/hostedzone/{HostedZoneId}/associatevpc', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'AssociateVPCWithHostedZoneResponse', + 'responseType' => 'model', + 'data' => array( + 'xmlRoot' => array( + 'name' => 'AssociateVPCWithHostedZoneRequest', + 'namespaces' => array( + 'https://route53.amazonaws.com/doc/2013-04-01/', + ), + ), + ), + 'parameters' => array( + 'HostedZoneId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'maxLength' => 32, + ), + 'VPC' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'VPCRegion' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'VPCId' => array( + 'type' => 'string', + 'maxLength' => 1024, + ), + ), + ), + 'Comment' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/xml', + ), + ), + 'errorResponses' => array( + array( + 'class' => 'NoSuchHostedZoneException', + ), + array( + 'reason' => 'The hosted zone you are trying to create for your VPC_ID does not belong to you. Route 53 returns this error when the VPC specified by VPCId does not belong to you.', + 'class' => 'InvalidVPCIdException', + ), + array( + 'reason' => 'Some value specified in the request is invalid or the XML document is malformed.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'The hosted zone you are trying to associate VPC with doesn\'t have any VPC association. Route 53 currently doesn\'t support associate a VPC with a public hosted zone.', + 'class' => 'PublicZoneVPCAssociationException', + ), + array( + 'class' => 'ConflictingDomainExistsException', + ), + ), + ), + 'ChangeResourceRecordSets' => array( + 'httpMethod' => 'POST', + 'uri' => '/2013-04-01/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/2013-04-01/', + ), + ), + ), + '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, + ), + 'GeoLocation' => array( + 'type' => 'object', + 'properties' => array( + 'ContinentCode' => array( + 'type' => 'string', + 'minLength' => 2, + 'maxLength' => 2, + ), + 'CountryCode' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 2, + ), + 'SubdivisionCode' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 3, + ), + ), + ), + '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', + ), + ), + ), + 'ChangeTagsForResource' => array( + 'httpMethod' => 'POST', + 'uri' => '/2013-04-01/tags/{ResourceType}/{ResourceId}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'ChangeTagsForResourceResponse', + 'responseType' => 'model', + 'data' => array( + 'xmlRoot' => array( + 'name' => 'ChangeTagsForResourceRequest', + 'namespaces' => array( + 'https://route53.amazonaws.com/doc/2013-04-01/', + ), + ), + ), + 'parameters' => array( + 'ResourceType' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'ResourceId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'maxLength' => 64, + ), + 'AddTags' => array( + 'type' => 'array', + 'location' => 'xml', + 'minItems' => 1, + 'maxItems' => 10, + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + 'maxLength' => 128, + ), + 'Value' => array( + 'type' => 'string', + 'maxLength' => 256, + ), + ), + ), + ), + 'RemoveTagKeys' => array( + 'type' => 'array', + 'location' => 'xml', + 'minItems' => 1, + 'maxItems' => 10, + 'items' => array( + 'name' => 'Key', + 'type' => 'string', + 'maxLength' => 128, + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Some value specified in the request is invalid or the XML document is malformed.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'The health check you are trying to get or delete does not exist.', + 'class' => 'NoSuchHealthCheckException', + ), + array( + 'class' => 'NoSuchHostedZoneException', + ), + array( + 'reason' => 'The request was rejected because Route 53 was still processing a prior request.', + 'class' => 'PriorRequestNotCompleteException', + ), + array( + 'class' => 'ThrottlingException', + ), + ), + ), + 'CreateHealthCheck' => array( + 'httpMethod' => 'POST', + 'uri' => '/2013-04-01/healthcheck', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'CreateHealthCheckResponse', + 'responseType' => 'model', + 'data' => array( + 'xmlRoot' => array( + 'name' => 'CreateHealthCheckRequest', + 'namespaces' => array( + 'https://route53.amazonaws.com/doc/2013-04-01/', + ), + ), + ), + '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( + '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, + ), + 'SearchString' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'RequestInterval' => array( + 'type' => 'numeric', + 'minimum' => 10, + 'maximum' => 30, + ), + 'FailureThreshold' => array( + 'type' => 'numeric', + 'minimum' => 1, + 'maximum' => 10, + ), + ), + ), + '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' => '/2013-04-01/hostedzone', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'CreateHostedZoneResponse', + 'responseType' => 'model', + 'data' => array( + 'xmlRoot' => array( + 'name' => 'CreateHostedZoneRequest', + 'namespaces' => array( + 'https://route53.amazonaws.com/doc/2013-04-01/', + ), + ), + ), + 'parameters' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'xml', + 'maxLength' => 1024, + ), + 'VPC' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'VPCRegion' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'VPCId' => array( + 'type' => 'string', + '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, + ), + 'PrivateZone' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + 'DelegationSetId' => array( + 'type' => 'string', + 'location' => 'xml', + 'maxLength' => 32, + ), + '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' => 'The hosted zone you are trying to create for your VPC_ID does not belong to you. Route 53 returns this error when the VPC specified by VPCId does not belong to you.', + 'class' => 'InvalidVPCIdException', + ), + 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', + ), + array( + 'class' => 'ConflictingDomainExistsException', + ), + array( + 'reason' => 'The specified delegation set does not exist.', + 'class' => 'NoSuchDelegationSetException', + ), + array( + 'reason' => 'The specified delegation set has not been marked as reusable.', + 'class' => 'DelegationSetNotReusableException', + ), + ), + ), + 'CreateReusableDelegationSet' => array( + 'httpMethod' => 'POST', + 'uri' => '/2013-04-01/delegationset', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'CreateReusableDelegationSetResponse', + 'responseType' => 'model', + 'data' => array( + 'xmlRoot' => array( + 'name' => 'CreateReusableDelegationSetRequest', + 'namespaces' => array( + 'https://route53.amazonaws.com/doc/2013-04-01/', + ), + ), + ), + 'parameters' => array( + 'CallerReference' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'xml', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'HostedZoneId' => array( + 'type' => 'string', + 'location' => 'xml', + 'maxLength' => 32, + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/xml', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'A delegation set with the same owner and caller reference combination has already been created.', + 'class' => 'DelegationSetAlreadyCreatedException', + ), + array( + 'reason' => 'The limits specified for a resource have been exceeded.', + 'class' => 'LimitsExceededException', + ), + array( + 'reason' => 'The specified HostedZone cannot be found.', + 'class' => 'HostedZoneNotFoundException', + ), + array( + 'reason' => 'At least one of the specified arguments is invalid.', + 'class' => 'InvalidArgumentException', + ), + 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', + ), + array( + 'reason' => 'The specified delegation set has already been marked as reusable.', + 'class' => 'DelegationSetAlreadyReusableException', + ), + ), + ), + 'DeleteHealthCheck' => array( + 'httpMethod' => 'DELETE', + 'uri' => '/2013-04-01/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' => '/2013-04-01/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', + ), + ), + ), + 'DeleteReusableDelegationSet' => array( + 'httpMethod' => 'DELETE', + 'uri' => '/2013-04-01/delegationset/{Id}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'DeleteReusableDelegationSetResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Id' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'maxLength' => 32, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified delegation set does not exist.', + 'class' => 'NoSuchDelegationSetException', + ), + array( + 'reason' => 'The specified delegation contains associated hosted zones which must be deleted before the reusable delegation set can be deleted.', + 'class' => 'DelegationSetInUseException', + ), + array( + 'reason' => 'The specified delegation set has not been marked as reusable.', + 'class' => 'DelegationSetNotReusableException', + ), + array( + 'reason' => 'Some value specified in the request is invalid or the XML document is malformed.', + 'class' => 'InvalidInputException', + ), + ), + ), + 'DisassociateVPCFromHostedZone' => array( + 'httpMethod' => 'POST', + 'uri' => '/2013-04-01/hostedzone/{HostedZoneId}/disassociatevpc', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'DisassociateVPCFromHostedZoneResponse', + 'responseType' => 'model', + 'data' => array( + 'xmlRoot' => array( + 'name' => 'DisassociateVPCFromHostedZoneRequest', + 'namespaces' => array( + 'https://route53.amazonaws.com/doc/2013-04-01/', + ), + ), + ), + 'parameters' => array( + 'HostedZoneId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'maxLength' => 32, + ), + 'VPC' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'VPCRegion' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'VPCId' => array( + 'type' => 'string', + 'maxLength' => 1024, + ), + ), + ), + 'Comment' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/xml', + ), + ), + 'errorResponses' => array( + array( + 'class' => 'NoSuchHostedZoneException', + ), + array( + 'reason' => 'The hosted zone you are trying to create for your VPC_ID does not belong to you. Route 53 returns this error when the VPC specified by VPCId does not belong to you.', + 'class' => 'InvalidVPCIdException', + ), + array( + 'reason' => 'The VPC you specified is not currently associated with the hosted zone.', + 'class' => 'VPCAssociationNotFoundException', + ), + array( + 'reason' => 'The VPC you are trying to disassociate from the hosted zone is the last the VPC that is associated with the hosted zone. Route 53 currently doesn\'t support disassociate the last VPC from the hosted zone.', + 'class' => 'LastVPCAssociationException', + ), + array( + 'reason' => 'Some value specified in the request is invalid or the XML document is malformed.', + 'class' => 'InvalidInputException', + ), + ), + ), + 'GetChange' => array( + 'httpMethod' => 'GET', + 'uri' => '/2013-04-01/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', + ), + ), + ), + 'GetCheckerIpRanges' => array( + 'httpMethod' => 'GET', + 'uri' => '/2013-04-01/checkeripranges', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'GetCheckerIpRangesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'command.expects' => array( + 'static' => true, + 'default' => 'application/xml', + ), + ), + ), + 'GetGeoLocation' => array( + 'httpMethod' => 'GET', + 'uri' => '/2013-04-01/geolocation', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'GetGeoLocationResponse', + 'responseType' => 'model', + 'parameters' => array( + 'ContinentCode' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'continentcode', + 'minLength' => 2, + 'maxLength' => 2, + ), + 'CountryCode' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'countrycode', + 'minLength' => 1, + 'maxLength' => 2, + ), + 'SubdivisionCode' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'subdivisioncode', + 'minLength' => 1, + 'maxLength' => 3, + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/xml', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The geo location you are trying to get does not exist.', + 'class' => 'NoSuchGeoLocationException', + ), + array( + 'reason' => 'Some value specified in the request is invalid or the XML document is malformed.', + 'class' => 'InvalidInputException', + ), + ), + ), + 'GetHealthCheck' => array( + 'httpMethod' => 'GET', + 'uri' => '/2013-04-01/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', + ), + array( + 'reason' => 'The resource you are trying to access is unsupported on this Route 53 endpoint. Please consider using a newer endpoint or a tool that does so.', + 'class' => 'IncompatibleVersionException', + ), + ), + ), + 'GetHealthCheckCount' => array( + 'httpMethod' => 'GET', + 'uri' => '/2013-04-01/healthcheckcount', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'GetHealthCheckCountResponse', + 'responseType' => 'model', + 'parameters' => array( + 'command.expects' => array( + 'static' => true, + 'default' => 'application/xml', + ), + ), + ), + 'GetHealthCheckLastFailureReason' => array( + 'httpMethod' => 'GET', + 'uri' => '/2013-04-01/healthcheck/{HealthCheckId}/lastfailurereason', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'GetHealthCheckLastFailureReasonResponse', + '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', + ), + ), + ), + 'GetHealthCheckStatus' => array( + 'httpMethod' => 'GET', + 'uri' => '/2013-04-01/healthcheck/{HealthCheckId}/status', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'GetHealthCheckStatusResponse', + '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', + ), + ), + ), + 'GetHostedZone' => array( + 'httpMethod' => 'GET', + 'uri' => '/2013-04-01/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', + ), + ), + ), + 'GetHostedZoneCount' => array( + 'httpMethod' => 'GET', + 'uri' => '/2013-04-01/hostedzonecount', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'GetHostedZoneCountResponse', + 'responseType' => 'model', + 'parameters' => array( + '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', + ), + ), + ), + 'GetReusableDelegationSet' => array( + 'httpMethod' => 'GET', + 'uri' => '/2013-04-01/delegationset/{Id}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'GetReusableDelegationSetResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Id' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'maxLength' => 32, + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/xml', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified delegation set does not exist.', + 'class' => 'NoSuchDelegationSetException', + ), + array( + 'reason' => 'The specified delegation set has not been marked as reusable.', + 'class' => 'DelegationSetNotReusableException', + ), + array( + 'reason' => 'Some value specified in the request is invalid or the XML document is malformed.', + 'class' => 'InvalidInputException', + ), + ), + ), + 'ListGeoLocations' => array( + 'httpMethod' => 'GET', + 'uri' => '/2013-04-01/geolocations', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'ListGeoLocationsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'StartContinentCode' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'startcontinentcode', + 'minLength' => 2, + 'maxLength' => 2, + ), + 'StartCountryCode' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'startcountrycode', + 'minLength' => 1, + 'maxLength' => 2, + ), + 'StartSubdivisionCode' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'startsubdivisioncode', + 'minLength' => 1, + 'maxLength' => 3, + ), + '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', + ), + ), + ), + 'ListHealthChecks' => array( + 'httpMethod' => 'GET', + 'uri' => '/2013-04-01/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', + ), + array( + 'reason' => 'The resource you are trying to access is unsupported on this Route 53 endpoint. Please consider using a newer endpoint or a tool that does so.', + 'class' => 'IncompatibleVersionException', + ), + ), + ), + 'ListHostedZones' => array( + 'httpMethod' => 'GET', + 'uri' => '/2013-04-01/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', + ), + 'DelegationSetId' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'delegationsetid', + 'maxLength' => 32, + ), + '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', + ), + array( + 'reason' => 'The specified delegation set does not exist.', + 'class' => 'NoSuchDelegationSetException', + ), + array( + 'reason' => 'The specified delegation set has not been marked as reusable.', + 'class' => 'DelegationSetNotReusableException', + ), + ), + ), + 'ListHostedZonesByName' => array( + 'httpMethod' => 'GET', + 'uri' => '/2013-04-01/hostedzonesbyname', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'ListHostedZonesByNameResponse', + 'responseType' => 'model', + 'parameters' => array( + 'DNSName' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'dnsname', + 'maxLength' => 1024, + ), + 'HostedZoneId' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'hostedzoneid', + 'maxLength' => 32, + ), + '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', + ), + array( + 'reason' => 'This error indicates that the specified domain name is not valid.', + 'class' => 'InvalidDomainNameException', + ), + ), + ), + 'ListResourceRecordSets' => array( + 'httpMethod' => 'GET', + 'uri' => '/2013-04-01/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', + ), + ), + ), + 'ListReusableDelegationSets' => array( + 'httpMethod' => 'GET', + 'uri' => '/2013-04-01/delegationset', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'ListReusableDelegationSetsResponse', + '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', + ), + ), + ), + 'ListTagsForResource' => array( + 'httpMethod' => 'GET', + 'uri' => '/2013-04-01/tags/{ResourceType}/{ResourceId}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'ListTagsForResourceResponse', + 'responseType' => 'model', + 'parameters' => array( + 'ResourceType' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'ResourceId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'maxLength' => 64, + ), + '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', + ), + array( + 'reason' => 'The health check you are trying to get or delete does not exist.', + 'class' => 'NoSuchHealthCheckException', + ), + array( + 'class' => 'NoSuchHostedZoneException', + ), + array( + 'reason' => 'The request was rejected because Route 53 was still processing a prior request.', + 'class' => 'PriorRequestNotCompleteException', + ), + array( + 'class' => 'ThrottlingException', + ), + ), + ), + 'ListTagsForResources' => array( + 'httpMethod' => 'POST', + 'uri' => '/2013-04-01/tags/{ResourceType}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'ListTagsForResourcesResponse', + 'responseType' => 'model', + 'data' => array( + 'xmlRoot' => array( + 'name' => 'ListTagsForResourcesRequest', + 'namespaces' => array( + 'https://route53.amazonaws.com/doc/2013-04-01/', + ), + ), + ), + 'parameters' => array( + 'ResourceType' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'ResourceIds' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'xml', + 'minItems' => 1, + 'maxItems' => 10, + 'items' => array( + 'name' => 'ResourceId', + 'type' => 'string', + 'maxLength' => 64, + ), + ), + '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', + ), + array( + 'reason' => 'The health check you are trying to get or delete does not exist.', + 'class' => 'NoSuchHealthCheckException', + ), + array( + 'class' => 'NoSuchHostedZoneException', + ), + array( + 'reason' => 'The request was rejected because Route 53 was still processing a prior request.', + 'class' => 'PriorRequestNotCompleteException', + ), + array( + 'class' => 'ThrottlingException', + ), + ), + ), + 'UpdateHealthCheck' => array( + 'httpMethod' => 'POST', + 'uri' => '/2013-04-01/healthcheck/{HealthCheckId}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'UpdateHealthCheckResponse', + 'responseType' => 'model', + 'data' => array( + 'xmlRoot' => array( + 'name' => 'UpdateHealthCheckRequest', + 'namespaces' => array( + 'https://route53.amazonaws.com/doc/2013-04-01/', + ), + ), + ), + 'parameters' => array( + 'HealthCheckId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'maxLength' => 64, + ), + 'HealthCheckVersion' => array( + 'type' => 'numeric', + 'location' => 'xml', + 'minimum' => 1, + ), + 'IPAddress' => array( + 'type' => 'string', + 'location' => 'xml', + 'maxLength' => 15, + ), + 'Port' => array( + 'type' => 'numeric', + 'location' => 'xml', + 'minimum' => 1, + 'maximum' => 65535, + ), + 'ResourcePath' => array( + 'type' => 'string', + 'location' => 'xml', + 'maxLength' => 255, + ), + 'FullyQualifiedDomainName' => array( + 'type' => 'string', + 'location' => 'xml', + 'maxLength' => 255, + ), + 'SearchString' => array( + 'type' => 'string', + 'location' => 'xml', + 'maxLength' => 255, + ), + 'FailureThreshold' => array( + 'type' => 'numeric', + 'location' => 'xml', + 'minimum' => 1, + 'maximum' => 10, + ), + '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', + ), + array( + 'class' => 'HealthCheckVersionMismatchException', + ), + ), + ), + 'UpdateHostedZoneComment' => array( + 'httpMethod' => 'POST', + 'uri' => '/2013-04-01/hostedzone/{Id}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'UpdateHostedZoneCommentResponse', + 'responseType' => 'model', + 'data' => array( + 'xmlRoot' => array( + 'name' => 'UpdateHostedZoneCommentRequest', + 'namespaces' => array( + 'https://route53.amazonaws.com/doc/2013-04-01/', + ), + ), + ), + 'parameters' => array( + 'Id' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'maxLength' => 32, + ), + 'Comment' => array( + 'type' => 'string', + 'location' => 'xml', + 'maxLength' => 256, + ), + '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( + 'AssociateVPCWithHostedZoneResponse' => 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', + ), + ), + ), + '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', + ), + ), + ), + 'ChangeTagsForResourceResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + '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', + ), + 'SearchString' => array( + 'type' => 'string', + ), + 'RequestInterval' => array( + 'type' => 'numeric', + ), + 'FailureThreshold' => array( + 'type' => 'numeric', + ), + ), + ), + 'HealthCheckVersion' => array( + 'type' => 'numeric', + ), + ), + ), + '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', + ), + 'PrivateZone' => array( + 'type' => 'boolean', + ), + ), + ), + '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( + 'Id' => array( + 'type' => 'string', + ), + 'CallerReference' => array( + 'type' => 'string', + ), + 'NameServers' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NameServer', + 'type' => 'string', + 'sentAs' => 'NameServer', + ), + ), + ), + ), + 'VPC' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'VPCRegion' => array( + 'type' => 'string', + ), + 'VPCId' => array( + 'type' => 'string', + ), + ), + ), + 'Location' => array( + 'type' => 'string', + 'location' => 'header', + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'CreateReusableDelegationSetResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'DelegationSet' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'CallerReference' => array( + 'type' => 'string', + ), + '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', + ), + ), + ), + 'DeleteReusableDelegationSetResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'DisassociateVPCFromHostedZoneResponse' => 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', + ), + ), + ), + 'GetCheckerIpRangesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'CheckerIpRanges' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'IPAddressCidr', + 'type' => 'string', + ), + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'GetGeoLocationResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'GeoLocationDetails' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'ContinentCode' => array( + 'type' => 'string', + ), + 'ContinentName' => array( + 'type' => 'string', + ), + 'CountryCode' => array( + 'type' => 'string', + ), + 'CountryName' => array( + 'type' => 'string', + ), + 'SubdivisionCode' => array( + 'type' => 'string', + ), + 'SubdivisionName' => 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', + ), + 'SearchString' => array( + 'type' => 'string', + ), + 'RequestInterval' => array( + 'type' => 'numeric', + ), + 'FailureThreshold' => array( + 'type' => 'numeric', + ), + ), + ), + 'HealthCheckVersion' => array( + 'type' => 'numeric', + ), + ), + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'GetHealthCheckCountResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'HealthCheckCount' => array( + 'type' => 'numeric', + 'location' => 'xml', + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'GetHealthCheckLastFailureReasonResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'HealthCheckObservations' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'HealthCheckObservation', + 'type' => 'object', + 'sentAs' => 'HealthCheckObservation', + 'properties' => array( + 'IPAddress' => array( + 'type' => 'string', + ), + 'StatusReport' => array( + 'type' => 'object', + 'properties' => array( + 'Status' => array( + 'type' => 'string', + ), + 'CheckedTime' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'GetHealthCheckStatusResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'HealthCheckObservations' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'HealthCheckObservation', + 'type' => 'object', + 'sentAs' => 'HealthCheckObservation', + 'properties' => array( + 'IPAddress' => array( + 'type' => 'string', + ), + 'StatusReport' => array( + 'type' => 'object', + 'properties' => array( + 'Status' => array( + 'type' => 'string', + ), + 'CheckedTime' => 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', + ), + 'PrivateZone' => array( + 'type' => 'boolean', + ), + ), + ), + 'ResourceRecordSetCount' => array( + 'type' => 'numeric', + ), + ), + ), + 'DelegationSet' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'CallerReference' => array( + 'type' => 'string', + ), + 'NameServers' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NameServer', + 'type' => 'string', + 'sentAs' => 'NameServer', + ), + ), + ), + ), + 'VPCs' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'VPC', + 'type' => 'object', + 'sentAs' => 'VPC', + 'properties' => array( + 'VPCRegion' => array( + 'type' => 'string', + ), + 'VPCId' => array( + 'type' => 'string', + ), + ), + ), + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'GetHostedZoneCountResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'HostedZoneCount' => array( + 'type' => 'numeric', + 'location' => 'xml', + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'GetReusableDelegationSetResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'DelegationSet' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'CallerReference' => array( + 'type' => 'string', + ), + 'NameServers' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NameServer', + 'type' => 'string', + 'sentAs' => 'NameServer', + ), + ), + ), + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'ListGeoLocationsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'GeoLocationDetailsList' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'GeoLocationDetails', + 'type' => 'object', + 'sentAs' => 'GeoLocationDetails', + 'properties' => array( + 'ContinentCode' => array( + 'type' => 'string', + ), + 'ContinentName' => array( + 'type' => 'string', + ), + 'CountryCode' => array( + 'type' => 'string', + ), + 'CountryName' => array( + 'type' => 'string', + ), + 'SubdivisionCode' => array( + 'type' => 'string', + ), + 'SubdivisionName' => array( + 'type' => 'string', + ), + ), + ), + ), + 'IsTruncated' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'NextContinentCode' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'NextCountryCode' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'NextSubdivisionCode' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'MaxItems' => array( + 'type' => 'string', + 'location' => 'xml', + ), + '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', + ), + 'SearchString' => array( + 'type' => 'string', + ), + 'RequestInterval' => array( + 'type' => 'numeric', + ), + 'FailureThreshold' => array( + 'type' => 'numeric', + ), + ), + ), + 'HealthCheckVersion' => 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', + ), + ), + ), + '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', + ), + 'PrivateZone' => array( + 'type' => 'boolean', + ), + ), + ), + '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', + ), + ), + ), + 'ListHostedZonesByNameResponse' => 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', + ), + 'PrivateZone' => array( + 'type' => 'boolean', + ), + ), + ), + 'ResourceRecordSetCount' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'DNSName' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'HostedZoneId' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'IsTruncated' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'NextDNSName' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'NextHostedZoneId' => 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', + ), + 'GeoLocation' => array( + 'type' => 'object', + 'properties' => array( + 'ContinentCode' => array( + 'type' => 'string', + ), + 'CountryCode' => array( + 'type' => 'string', + ), + 'SubdivisionCode' => 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', + ), + ), + ), + 'ListReusableDelegationSetsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'DelegationSets' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'DelegationSet', + 'type' => 'object', + 'sentAs' => 'DelegationSet', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'CallerReference' => array( + 'type' => 'string', + ), + 'NameServers' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NameServer', + 'type' => 'string', + 'sentAs' => 'NameServer', + ), + ), + ), + ), + ), + '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', + ), + ), + ), + 'ListTagsForResourceResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ResourceTagSet' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'ResourceType' => array( + 'type' => 'string', + ), + 'ResourceId' => array( + 'type' => 'string', + ), + 'Tags' => array( + 'type' => 'array', + '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', + ), + ), + ), + 'ListTagsForResourcesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ResourceTagSets' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'ResourceTagSet', + 'type' => 'object', + 'sentAs' => 'ResourceTagSet', + 'properties' => array( + 'ResourceType' => array( + 'type' => 'string', + ), + 'ResourceId' => array( + 'type' => 'string', + ), + 'Tags' => array( + 'type' => 'array', + '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', + ), + ), + ), + 'UpdateHealthCheckResponse' => 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', + ), + 'SearchString' => array( + 'type' => 'string', + ), + 'RequestInterval' => array( + 'type' => 'numeric', + ), + 'FailureThreshold' => array( + 'type' => 'numeric', + ), + ), + ), + 'HealthCheckVersion' => array( + 'type' => 'numeric', + ), + ), + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'UpdateHostedZoneCommentResponse' => 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', + ), + 'PrivateZone' => array( + 'type' => 'boolean', + ), + ), + ), + 'ResourceRecordSetCount' => array( + 'type' => 'numeric', + ), + ), + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + ), + 'iterators' => array( + 'ListHealthChecks' => array( + 'input_token' => 'Marker', + 'output_token' => 'NextMarker', + 'more_results' => 'IsTruncated', + 'limit_key' => 'MaxItems', + 'result_key' => 'HealthChecks', + ), + 'ListHostedZones' => array( + 'input_token' => 'Marker', + 'output_token' => 'NextMarker', + 'more_results' => 'IsTruncated', + 'limit_key' => 'MaxItems', + 'result_key' => 'HostedZones', + ), + 'ListResourceRecordSets' => array( + 'more_results' => 'IsTruncated', + 'limit_key' => 'MaxItems', + 'result_key' => 'ResourceRecordSets', + 'input_token' => array( + 'StartRecordName', + 'StartRecordType', + 'StartRecordIdentifier', + ), + 'output_token' => array( + 'NextRecordName', + 'NextRecordType', + 'NextRecordIdentifier', + ), + ), + ), +); diff --git a/vendor/aws/Aws/Route53/Route53Client.php b/vendor/aws/Aws/Route53/Route53Client.php new file mode 100644 index 0000000..43ebd31 --- /dev/null +++ b/vendor/aws/Aws/Route53/Route53Client.php @@ -0,0 +1,124 @@ +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/', '/delegationset/'), '', $id); + } +} diff --git a/vendor/aws/Aws/Route53Domains/Exception/Route53DomainsException.php b/vendor/aws/Aws/Route53Domains/Exception/Route53DomainsException.php new file mode 100644 index 0000000..2278eec --- /dev/null +++ b/vendor/aws/Aws/Route53Domains/Exception/Route53DomainsException.php @@ -0,0 +1,10 @@ + '2014-05-15', + 'endpointPrefix' => 'route53domains', + 'serviceFullName' => 'Amazon Route 53 Domains', + 'serviceType' => 'json', + 'jsonVersion' => '1.1', + 'targetPrefix' => 'Route53Domains_v20140515.', + 'signatureVersion' => 'v4', + 'namespace' => 'Route53Domains', + 'regions' => array( + 'us-east-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'route53domains.us-east-1.amazonaws.com', + ), + ), + 'operations' => array( + 'CheckDomainAvailability' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'CheckDomainAvailabilityResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'Route53Domains_v20140515.CheckDomainAvailability', + ), + 'DomainName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 255, + ), + 'IdnLangCode' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 3, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The requested item is not acceptable. For example, for an OperationId it may refer to the ID of an operation that is already completed. For a domain name, it may not be a valid domain name or belong to the requester account.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'Amazon Route 53 does not support this top-level domain.', + 'class' => 'UnsupportedTLDException', + ), + ), + ), + 'DeleteTagsForDomain' => 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' => 'Route53Domains_v20140515.DeleteTagsForDomain', + ), + 'DomainName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 255, + ), + 'TagsToDelete' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'TagKey', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The requested item is not acceptable. For example, for an OperationId it may refer to the ID of an operation that is already completed. For a domain name, it may not be a valid domain name or belong to the requester account.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'The number of operations or jobs running exceeded the allowed threshold for the account.', + 'class' => 'OperationLimitExceededException', + ), + ), + ), + 'DisableDomainAutoRenew' => 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' => 'Route53Domains_v20140515.DisableDomainAutoRenew', + ), + 'DomainName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 255, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The requested item is not acceptable. For example, for an OperationId it may refer to the ID of an operation that is already completed. For a domain name, it may not be a valid domain name or belong to the requester account.', + 'class' => 'InvalidInputException', + ), + ), + ), + 'DisableDomainTransferLock' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DisableDomainTransferLockResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'Route53Domains_v20140515.DisableDomainTransferLock', + ), + 'DomainName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 255, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The requested item is not acceptable. For example, for an OperationId it may refer to the ID of an operation that is already completed. For a domain name, it may not be a valid domain name or belong to the requester account.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'The request is already in progress for the domain.', + 'class' => 'DuplicateRequestException', + ), + array( + 'reason' => 'The top-level domain does not support this operation.', + 'class' => 'TLDRulesViolationException', + ), + array( + 'reason' => 'The number of operations or jobs running exceeded the allowed threshold for the account.', + 'class' => 'OperationLimitExceededException', + ), + ), + ), + 'EnableDomainAutoRenew' => 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' => 'Route53Domains_v20140515.EnableDomainAutoRenew', + ), + 'DomainName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 255, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The requested item is not acceptable. For example, for an OperationId it may refer to the ID of an operation that is already completed. For a domain name, it may not be a valid domain name or belong to the requester account.', + 'class' => 'InvalidInputException', + ), + ), + ), + 'EnableDomainTransferLock' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'EnableDomainTransferLockResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'Route53Domains_v20140515.EnableDomainTransferLock', + ), + 'DomainName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 255, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The requested item is not acceptable. For example, for an OperationId it may refer to the ID of an operation that is already completed. For a domain name, it may not be a valid domain name or belong to the requester account.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'The request is already in progress for the domain.', + 'class' => 'DuplicateRequestException', + ), + array( + 'reason' => 'The top-level domain does not support this operation.', + 'class' => 'TLDRulesViolationException', + ), + array( + 'reason' => 'The number of operations or jobs running exceeded the allowed threshold for the account.', + 'class' => 'OperationLimitExceededException', + ), + ), + ), + 'GetDomainDetail' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GetDomainDetailResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'Route53Domains_v20140515.GetDomainDetail', + ), + 'DomainName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 255, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The requested item is not acceptable. For example, for an OperationId it may refer to the ID of an operation that is already completed. For a domain name, it may not be a valid domain name or belong to the requester account.', + 'class' => 'InvalidInputException', + ), + ), + ), + 'GetOperationDetail' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GetOperationDetailResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'Route53Domains_v20140515.GetOperationDetail', + ), + 'OperationId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 255, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The requested item is not acceptable. For example, for an OperationId it may refer to the ID of an operation that is already completed. For a domain name, it may not be a valid domain name or belong to the requester account.', + 'class' => 'InvalidInputException', + ), + ), + ), + 'ListDomains' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListDomainsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'Route53Domains_v20140515.ListDomains', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 4096, + ), + 'MaxItems' => array( + 'type' => 'numeric', + 'location' => 'json', + 'maximum' => 100, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The requested item is not acceptable. For example, for an OperationId it may refer to the ID of an operation that is already completed. For a domain name, it may not be a valid domain name or belong to the requester account.', + 'class' => 'InvalidInputException', + ), + ), + ), + 'ListOperations' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListOperationsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'Route53Domains_v20140515.ListOperations', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 4096, + ), + 'MaxItems' => array( + 'type' => 'numeric', + 'location' => 'json', + 'maximum' => 100, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The requested item is not acceptable. For example, for an OperationId it may refer to the ID of an operation that is already completed. For a domain name, it may not be a valid domain name or belong to the requester account.', + 'class' => 'InvalidInputException', + ), + ), + ), + 'ListTagsForDomain' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListTagsForDomainResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'Route53Domains_v20140515.ListTagsForDomain', + ), + 'DomainName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 255, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The requested item is not acceptable. For example, for an OperationId it may refer to the ID of an operation that is already completed. For a domain name, it may not be a valid domain name or belong to the requester account.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'The number of operations or jobs running exceeded the allowed threshold for the account.', + 'class' => 'OperationLimitExceededException', + ), + ), + ), + 'RegisterDomain' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'RegisterDomainResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'Route53Domains_v20140515.RegisterDomain', + ), + 'DomainName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 255, + ), + 'IdnLangCode' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 3, + ), + 'DurationInYears' => array( + 'required' => true, + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 10, + ), + 'AutoRenew' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + 'AdminContact' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'FirstName' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'LastName' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'ContactType' => array( + 'type' => 'string', + ), + 'OrganizationName' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'AddressLine1' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'AddressLine2' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'City' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'State' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'CountryCode' => array( + 'type' => 'string', + ), + 'ZipCode' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'PhoneNumber' => array( + 'type' => 'string', + 'maxLength' => 30, + ), + 'Email' => array( + 'type' => 'string', + 'maxLength' => 254, + ), + 'Fax' => array( + 'type' => 'string', + 'maxLength' => 30, + ), + 'ExtraParams' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ExtraParam', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Value' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 2048, + ), + ), + ), + ), + ), + ), + 'RegistrantContact' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'FirstName' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'LastName' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'ContactType' => array( + 'type' => 'string', + ), + 'OrganizationName' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'AddressLine1' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'AddressLine2' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'City' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'State' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'CountryCode' => array( + 'type' => 'string', + ), + 'ZipCode' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'PhoneNumber' => array( + 'type' => 'string', + 'maxLength' => 30, + ), + 'Email' => array( + 'type' => 'string', + 'maxLength' => 254, + ), + 'Fax' => array( + 'type' => 'string', + 'maxLength' => 30, + ), + 'ExtraParams' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ExtraParam', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Value' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 2048, + ), + ), + ), + ), + ), + ), + 'TechContact' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'FirstName' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'LastName' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'ContactType' => array( + 'type' => 'string', + ), + 'OrganizationName' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'AddressLine1' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'AddressLine2' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'City' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'State' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'CountryCode' => array( + 'type' => 'string', + ), + 'ZipCode' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'PhoneNumber' => array( + 'type' => 'string', + 'maxLength' => 30, + ), + 'Email' => array( + 'type' => 'string', + 'maxLength' => 254, + ), + 'Fax' => array( + 'type' => 'string', + 'maxLength' => 30, + ), + 'ExtraParams' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ExtraParam', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Value' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 2048, + ), + ), + ), + ), + ), + ), + 'PrivacyProtectAdminContact' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + 'PrivacyProtectRegistrantContact' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + 'PrivacyProtectTechContact' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The requested item is not acceptable. For example, for an OperationId it may refer to the ID of an operation that is already completed. For a domain name, it may not be a valid domain name or belong to the requester account.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'Amazon Route 53 does not support this top-level domain.', + 'class' => 'UnsupportedTLDException', + ), + array( + 'reason' => 'The request is already in progress for the domain.', + 'class' => 'DuplicateRequestException', + ), + array( + 'reason' => 'The top-level domain does not support this operation.', + 'class' => 'TLDRulesViolationException', + ), + array( + 'reason' => 'The number of domains has exceeded the allowed threshold for the account.', + 'class' => 'DomainLimitExceededException', + ), + array( + 'reason' => 'The number of operations or jobs running exceeded the allowed threshold for the account.', + 'class' => 'OperationLimitExceededException', + ), + ), + ), + 'RetrieveDomainAuthCode' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'RetrieveDomainAuthCodeResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'Route53Domains_v20140515.RetrieveDomainAuthCode', + ), + 'DomainName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 255, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The requested item is not acceptable. For example, for an OperationId it may refer to the ID of an operation that is already completed. For a domain name, it may not be a valid domain name or belong to the requester account.', + 'class' => 'InvalidInputException', + ), + ), + ), + 'TransferDomain' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'TransferDomainResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'Route53Domains_v20140515.TransferDomain', + ), + 'DomainName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 255, + ), + 'IdnLangCode' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 3, + ), + 'DurationInYears' => array( + 'required' => true, + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 10, + ), + 'Nameservers' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Nameserver', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 255, + ), + 'GlueIps' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'GlueIp', + 'type' => 'string', + 'maxLength' => 45, + ), + ), + ), + ), + ), + 'AuthCode' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'AutoRenew' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + 'AdminContact' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'FirstName' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'LastName' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'ContactType' => array( + 'type' => 'string', + ), + 'OrganizationName' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'AddressLine1' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'AddressLine2' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'City' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'State' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'CountryCode' => array( + 'type' => 'string', + ), + 'ZipCode' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'PhoneNumber' => array( + 'type' => 'string', + 'maxLength' => 30, + ), + 'Email' => array( + 'type' => 'string', + 'maxLength' => 254, + ), + 'Fax' => array( + 'type' => 'string', + 'maxLength' => 30, + ), + 'ExtraParams' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ExtraParam', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Value' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 2048, + ), + ), + ), + ), + ), + ), + 'RegistrantContact' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'FirstName' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'LastName' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'ContactType' => array( + 'type' => 'string', + ), + 'OrganizationName' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'AddressLine1' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'AddressLine2' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'City' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'State' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'CountryCode' => array( + 'type' => 'string', + ), + 'ZipCode' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'PhoneNumber' => array( + 'type' => 'string', + 'maxLength' => 30, + ), + 'Email' => array( + 'type' => 'string', + 'maxLength' => 254, + ), + 'Fax' => array( + 'type' => 'string', + 'maxLength' => 30, + ), + 'ExtraParams' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ExtraParam', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Value' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 2048, + ), + ), + ), + ), + ), + ), + 'TechContact' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'FirstName' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'LastName' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'ContactType' => array( + 'type' => 'string', + ), + 'OrganizationName' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'AddressLine1' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'AddressLine2' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'City' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'State' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'CountryCode' => array( + 'type' => 'string', + ), + 'ZipCode' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'PhoneNumber' => array( + 'type' => 'string', + 'maxLength' => 30, + ), + 'Email' => array( + 'type' => 'string', + 'maxLength' => 254, + ), + 'Fax' => array( + 'type' => 'string', + 'maxLength' => 30, + ), + 'ExtraParams' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ExtraParam', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Value' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 2048, + ), + ), + ), + ), + ), + ), + 'PrivacyProtectAdminContact' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + 'PrivacyProtectRegistrantContact' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + 'PrivacyProtectTechContact' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The requested item is not acceptable. For example, for an OperationId it may refer to the ID of an operation that is already completed. For a domain name, it may not be a valid domain name or belong to the requester account.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'Amazon Route 53 does not support this top-level domain.', + 'class' => 'UnsupportedTLDException', + ), + array( + 'reason' => 'The request is already in progress for the domain.', + 'class' => 'DuplicateRequestException', + ), + array( + 'reason' => 'The top-level domain does not support this operation.', + 'class' => 'TLDRulesViolationException', + ), + array( + 'reason' => 'The number of domains has exceeded the allowed threshold for the account.', + 'class' => 'DomainLimitExceededException', + ), + array( + 'reason' => 'The number of operations or jobs running exceeded the allowed threshold for the account.', + 'class' => 'OperationLimitExceededException', + ), + ), + ), + 'UpdateDomainContact' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'UpdateDomainContactResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'Route53Domains_v20140515.UpdateDomainContact', + ), + 'DomainName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 255, + ), + 'AdminContact' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'FirstName' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'LastName' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'ContactType' => array( + 'type' => 'string', + ), + 'OrganizationName' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'AddressLine1' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'AddressLine2' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'City' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'State' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'CountryCode' => array( + 'type' => 'string', + ), + 'ZipCode' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'PhoneNumber' => array( + 'type' => 'string', + 'maxLength' => 30, + ), + 'Email' => array( + 'type' => 'string', + 'maxLength' => 254, + ), + 'Fax' => array( + 'type' => 'string', + 'maxLength' => 30, + ), + 'ExtraParams' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ExtraParam', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Value' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 2048, + ), + ), + ), + ), + ), + ), + 'RegistrantContact' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'FirstName' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'LastName' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'ContactType' => array( + 'type' => 'string', + ), + 'OrganizationName' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'AddressLine1' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'AddressLine2' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'City' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'State' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'CountryCode' => array( + 'type' => 'string', + ), + 'ZipCode' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'PhoneNumber' => array( + 'type' => 'string', + 'maxLength' => 30, + ), + 'Email' => array( + 'type' => 'string', + 'maxLength' => 254, + ), + 'Fax' => array( + 'type' => 'string', + 'maxLength' => 30, + ), + 'ExtraParams' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ExtraParam', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Value' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 2048, + ), + ), + ), + ), + ), + ), + 'TechContact' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'FirstName' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'LastName' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'ContactType' => array( + 'type' => 'string', + ), + 'OrganizationName' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'AddressLine1' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'AddressLine2' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'City' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'State' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'CountryCode' => array( + 'type' => 'string', + ), + 'ZipCode' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'PhoneNumber' => array( + 'type' => 'string', + 'maxLength' => 30, + ), + 'Email' => array( + 'type' => 'string', + 'maxLength' => 254, + ), + 'Fax' => array( + 'type' => 'string', + 'maxLength' => 30, + ), + 'ExtraParams' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ExtraParam', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Value' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 2048, + ), + ), + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The requested item is not acceptable. For example, for an OperationId it may refer to the ID of an operation that is already completed. For a domain name, it may not be a valid domain name or belong to the requester account.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'The request is already in progress for the domain.', + 'class' => 'DuplicateRequestException', + ), + array( + 'reason' => 'The top-level domain does not support this operation.', + 'class' => 'TLDRulesViolationException', + ), + array( + 'reason' => 'The number of operations or jobs running exceeded the allowed threshold for the account.', + 'class' => 'OperationLimitExceededException', + ), + ), + ), + 'UpdateDomainContactPrivacy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'UpdateDomainContactPrivacyResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'Route53Domains_v20140515.UpdateDomainContactPrivacy', + ), + 'DomainName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 255, + ), + 'AdminPrivacy' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + 'RegistrantPrivacy' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + 'TechPrivacy' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The requested item is not acceptable. For example, for an OperationId it may refer to the ID of an operation that is already completed. For a domain name, it may not be a valid domain name or belong to the requester account.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'The request is already in progress for the domain.', + 'class' => 'DuplicateRequestException', + ), + array( + 'reason' => 'The top-level domain does not support this operation.', + 'class' => 'TLDRulesViolationException', + ), + array( + 'reason' => 'The number of operations or jobs running exceeded the allowed threshold for the account.', + 'class' => 'OperationLimitExceededException', + ), + ), + ), + 'UpdateDomainNameservers' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'UpdateDomainNameserversResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'Route53Domains_v20140515.UpdateDomainNameservers', + ), + 'DomainName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 255, + ), + 'FIAuthKey' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Nameservers' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Nameserver', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 255, + ), + 'GlueIps' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'GlueIp', + 'type' => 'string', + 'maxLength' => 45, + ), + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The requested item is not acceptable. For example, for an OperationId it may refer to the ID of an operation that is already completed. For a domain name, it may not be a valid domain name or belong to the requester account.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'The request is already in progress for the domain.', + 'class' => 'DuplicateRequestException', + ), + array( + 'reason' => 'The top-level domain does not support this operation.', + 'class' => 'TLDRulesViolationException', + ), + array( + 'reason' => 'The number of operations or jobs running exceeded the allowed threshold for the account.', + 'class' => 'OperationLimitExceededException', + ), + ), + ), + 'UpdateTagsForDomain' => 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' => 'Route53Domains_v20140515.UpdateTagsForDomain', + ), + 'DomainName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 255, + ), + 'TagsToUpdate' => 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' => 'The requested item is not acceptable. For example, for an OperationId it may refer to the ID of an operation that is already completed. For a domain name, it may not be a valid domain name or belong to the requester account.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'The number of operations or jobs running exceeded the allowed threshold for the account.', + 'class' => 'OperationLimitExceededException', + ), + ), + ), + ), + 'models' => array( + 'CheckDomainAvailabilityResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Availability' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'EmptyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + ), + 'DisableDomainTransferLockResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'OperationId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'EnableDomainTransferLockResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'OperationId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'GetDomainDetailResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'DomainName' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Nameservers' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Nameserver', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + 'GlueIps' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'GlueIp', + 'type' => 'string', + ), + ), + ), + ), + ), + 'AutoRenew' => array( + 'type' => 'boolean', + 'location' => 'json', + ), + 'AdminContact' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'FirstName' => array( + 'type' => 'string', + ), + 'LastName' => array( + 'type' => 'string', + ), + 'ContactType' => array( + 'type' => 'string', + ), + 'OrganizationName' => array( + 'type' => 'string', + ), + 'AddressLine1' => array( + 'type' => 'string', + ), + 'AddressLine2' => array( + 'type' => 'string', + ), + 'City' => array( + 'type' => 'string', + ), + 'State' => array( + 'type' => 'string', + ), + 'CountryCode' => array( + 'type' => 'string', + ), + 'ZipCode' => array( + 'type' => 'string', + ), + 'PhoneNumber' => array( + 'type' => 'string', + ), + 'Email' => array( + 'type' => 'string', + ), + 'Fax' => array( + 'type' => 'string', + ), + 'ExtraParams' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ExtraParam', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'RegistrantContact' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'FirstName' => array( + 'type' => 'string', + ), + 'LastName' => array( + 'type' => 'string', + ), + 'ContactType' => array( + 'type' => 'string', + ), + 'OrganizationName' => array( + 'type' => 'string', + ), + 'AddressLine1' => array( + 'type' => 'string', + ), + 'AddressLine2' => array( + 'type' => 'string', + ), + 'City' => array( + 'type' => 'string', + ), + 'State' => array( + 'type' => 'string', + ), + 'CountryCode' => array( + 'type' => 'string', + ), + 'ZipCode' => array( + 'type' => 'string', + ), + 'PhoneNumber' => array( + 'type' => 'string', + ), + 'Email' => array( + 'type' => 'string', + ), + 'Fax' => array( + 'type' => 'string', + ), + 'ExtraParams' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ExtraParam', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'TechContact' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'FirstName' => array( + 'type' => 'string', + ), + 'LastName' => array( + 'type' => 'string', + ), + 'ContactType' => array( + 'type' => 'string', + ), + 'OrganizationName' => array( + 'type' => 'string', + ), + 'AddressLine1' => array( + 'type' => 'string', + ), + 'AddressLine2' => array( + 'type' => 'string', + ), + 'City' => array( + 'type' => 'string', + ), + 'State' => array( + 'type' => 'string', + ), + 'CountryCode' => array( + 'type' => 'string', + ), + 'ZipCode' => array( + 'type' => 'string', + ), + 'PhoneNumber' => array( + 'type' => 'string', + ), + 'Email' => array( + 'type' => 'string', + ), + 'Fax' => array( + 'type' => 'string', + ), + 'ExtraParams' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ExtraParam', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'AdminPrivacy' => array( + 'type' => 'boolean', + 'location' => 'json', + ), + 'RegistrantPrivacy' => array( + 'type' => 'boolean', + 'location' => 'json', + ), + 'TechPrivacy' => array( + 'type' => 'boolean', + 'location' => 'json', + ), + 'RegistrarName' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'WhoIsServer' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'RegistrarUrl' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'AbuseContactEmail' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'AbuseContactPhone' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'RegistryDomainId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'CreationDate' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'UpdatedDate' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'ExpirationDate' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Reseller' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'DnsSec' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'StatusList' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'DomainStatus', + 'type' => 'string', + ), + ), + ), + ), + 'GetOperationDetailResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'OperationId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Status' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Message' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'DomainName' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Type' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'SubmittedDate' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListDomainsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Domains' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'DomainSummary', + 'type' => 'object', + 'properties' => array( + 'DomainName' => array( + 'type' => 'string', + ), + 'AutoRenew' => array( + 'type' => 'boolean', + ), + 'TransferLock' => array( + 'type' => 'boolean', + ), + 'Expiry' => array( + 'type' => 'string', + ), + ), + ), + ), + 'NextPageMarker' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListOperationsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Operations' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'OperationSummary', + 'type' => 'object', + 'properties' => array( + 'OperationId' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'Type' => array( + 'type' => 'string', + ), + 'SubmittedDate' => array( + 'type' => 'string', + ), + ), + ), + ), + 'NextPageMarker' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListTagsForDomainResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'TagList' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'RegisterDomainResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'OperationId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'RetrieveDomainAuthCodeResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'AuthCode' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'TransferDomainResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'OperationId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'UpdateDomainContactResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'OperationId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'UpdateDomainContactPrivacyResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'OperationId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'UpdateDomainNameserversResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'OperationId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + ), + 'iterators' => array( + 'ListDomains' => array( + 'limit_key' => 'MaxItems', + 'input_token' => 'Marker', + 'output_token' => 'NextPageMarker', + 'result_key' => 'Domains', + ), + 'ListOperations' => array( + 'limit_key' => 'MaxItems', + 'input_token' => 'Marker', + 'output_token' => 'NextPageMarker', + 'result_key' => 'Operations', + ), + ), +); diff --git a/vendor/aws/Aws/Route53Domains/Route53DomainsClient.php b/vendor/aws/Aws/Route53Domains/Route53DomainsClient.php new file mode 100644 index 0000000..8a7d819 --- /dev/null +++ b/vendor/aws/Aws/Route53Domains/Route53DomainsClient.php @@ -0,0 +1,48 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/route53domains-%s.php' + )) + ->setExceptionParser(new JsonQueryExceptionParser) + ->build(); + } +} diff --git a/vendor/aws/Aws/S3/AcpListener.php b/vendor/aws/Aws/S3/AcpListener.php new file mode 100644 index 0000000..2d28407 --- /dev/null +++ b/vendor/aws/Aws/S3/AcpListener.php @@ -0,0 +1,75 @@ + 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'); + } + } +} diff --git a/vendor/aws/Aws/S3/BucketStyleListener.php b/vendor/aws/Aws/S3/BucketStyleListener.php new file mode 100644 index 0000000..5d7bbde --- /dev/null +++ b/vendor/aws/Aws/S3/BucketStyleListener.php @@ -0,0 +1,89 @@ + true); + + public static function getSubscribedEvents() + { + return array('command.after_prepare' => 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; + + // Skip operations that do not need the bucket moved to the host. + if (isset(self::$exclusions[$command->getName()])) { + return; + } + + 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)) : '/') + ); + } + } +} diff --git a/vendor/aws/Aws/S3/Command/S3Command.php b/vendor/aws/Aws/S3/Command/S3Command.php new file mode 100644 index 0000000..d0d3b24 --- /dev/null +++ b/vendor/aws/Aws/S3/Command/S3Command.php @@ -0,0 +1,65 @@ +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()); + } + } +} diff --git a/vendor/aws/Aws/S3/Enum/CannedAcl.php b/vendor/aws/Aws/S3/Enum/CannedAcl.php new file mode 100644 index 0000000..da47045 --- /dev/null +++ b/vendor/aws/Aws/S3/Enum/CannedAcl.php @@ -0,0 +1,32 @@ +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; + } +} diff --git a/vendor/aws/Aws/S3/Exception/EntityTooLargeException.php b/vendor/aws/Aws/S3/Exception/EntityTooLargeException.php new file mode 100644 index 0000000..66e6da9 --- /dev/null +++ b/vendor/aws/Aws/S3/Exception/EntityTooLargeException.php @@ -0,0 +1,22 @@ +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'; + } + } + } +} diff --git a/vendor/aws/Aws/S3/Exception/PermanentRedirectException.php b/vendor/aws/Aws/S3/Exception/PermanentRedirectException.php new file mode 100644 index 0000000..d2af820 --- /dev/null +++ b/vendor/aws/Aws/S3/Exception/PermanentRedirectException.php @@ -0,0 +1,22 @@ +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; + } +} diff --git a/vendor/aws/Aws/S3/Iterator/ListMultipartUploadsIterator.php b/vendor/aws/Aws/S3/Iterator/ListMultipartUploadsIterator.php new file mode 100644 index 0000000..592aa0a --- /dev/null +++ b/vendor/aws/Aws/S3/Iterator/ListMultipartUploadsIterator.php @@ -0,0 +1,46 @@ +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; + } +} diff --git a/vendor/aws/Aws/S3/Iterator/ListObjectVersionsIterator.php b/vendor/aws/Aws/S3/Iterator/ListObjectVersionsIterator.php new file mode 100644 index 0000000..991a77e --- /dev/null +++ b/vendor/aws/Aws/S3/Iterator/ListObjectVersionsIterator.php @@ -0,0 +1,48 @@ +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; + } +} diff --git a/vendor/aws/Aws/S3/Iterator/ListObjectsIterator.php b/vendor/aws/Aws/S3/Iterator/ListObjectsIterator.php new file mode 100644 index 0000000..852b2a9 --- /dev/null +++ b/vendor/aws/Aws/S3/Iterator/ListObjectsIterator.php @@ -0,0 +1,68 @@ +get('Contents') ?: array(); + $numObjects = count($objects); + $lastKey = $numObjects ? $objects[$numObjects - 1]['Key'] : false; + if ($lastKey && !$result->hasKey($this->get('output_token'))) { + $result->set($this->get('output_token'), $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; + } +} diff --git a/vendor/aws/Aws/S3/Iterator/OpendirIterator.php b/vendor/aws/Aws/S3/Iterator/OpendirIterator.php new file mode 100644 index 0000000..82c0153 --- /dev/null +++ b/vendor/aws/Aws/S3/Iterator/OpendirIterator.php @@ -0,0 +1,86 @@ +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; + } +} diff --git a/vendor/aws/Aws/S3/Model/Acp.php b/vendor/aws/Aws/S3/Model/Acp.php new file mode 100644 index 0000000..6c19f66 --- /dev/null +++ b/vendor/aws/Aws/S3/Model/Acp.php @@ -0,0 +1,243 @@ +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 Acp + */ + 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 $this + * + * @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 $this + * + * @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 $this + */ + 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 $this + */ + 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 + ); + } +} diff --git a/vendor/aws/Aws/S3/Model/AcpBuilder.php b/vendor/aws/Aws/S3/Model/AcpBuilder.php new file mode 100644 index 0000000..b6d1be7 --- /dev/null +++ b/vendor/aws/Aws/S3/Model/AcpBuilder.php @@ -0,0 +1,134 @@ +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 $this + */ + 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 $this + */ + 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 $this + */ + 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 $this + */ + 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); + } +} diff --git a/vendor/aws/Aws/S3/Model/ClearBucket.php b/vendor/aws/Aws/S3/Model/ClearBucket.php new file mode 100644 index 0000000..09982d8 --- /dev/null +++ b/vendor/aws/Aws/S3/Model/ClearBucket.php @@ -0,0 +1,189 @@ +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 $this + */ + 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 $this + */ + 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 $this + */ + 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; + } +} diff --git a/vendor/aws/Aws/S3/Model/DeleteObjectsBatch.php b/vendor/aws/Aws/S3/Model/DeleteObjectsBatch.php new file mode 100644 index 0000000..ab6425b --- /dev/null +++ b/vendor/aws/Aws/S3/Model/DeleteObjectsBatch.php @@ -0,0 +1,87 @@ + %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 static + */ + 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 static($batch); + } + + /** + * Add an object to be deleted + * + * @param string $key Key of the object + * @param string $versionId VersionID of the object + * + * @return $this + */ + 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 parent::add($item); + } +} diff --git a/vendor/aws/Aws/S3/Model/DeleteObjectsTransfer.php b/vendor/aws/Aws/S3/Model/DeleteObjectsTransfer.php new file mode 100644 index 0000000..5918ff1 --- /dev/null +++ b/vendor/aws/Aws/S3/Model/DeleteObjectsTransfer.php @@ -0,0 +1,133 @@ +client = $client; + $this->bucket = $bucket; + $this->mfa = $mfa; + } + + /** + * Set a new MFA token value + * + * @param string $token MFA token + * + * @return $this + */ + 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); + } + } +} diff --git a/vendor/aws/Aws/S3/Model/Grant.php b/vendor/aws/Aws/S3/Model/Grant.php new file mode 100644 index 0000000..2e35f05 --- /dev/null +++ b/vendor/aws/Aws/S3/Model/Grant.php @@ -0,0 +1,139 @@ + '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 $this + */ + 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 $this + * + * @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 + ); + } +} diff --git a/vendor/aws/Aws/S3/Model/Grantee.php b/vendor/aws/Aws/S3/Model/Grantee.php new file mode 100644 index 0000000..7634b84 --- /dev/null +++ b/vendor/aws/Aws/S3/Model/Grantee.php @@ -0,0 +1,245 @@ + '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 = static::$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; + } +} diff --git a/vendor/aws/Aws/S3/Model/MultipartUpload/AbstractTransfer.php b/vendor/aws/Aws/S3/Model/MultipartUpload/AbstractTransfer.php new file mode 100644 index 0000000..c48232d --- /dev/null +++ b/vendor/aws/Aws/S3/Model/MultipartUpload/AbstractTransfer.php @@ -0,0 +1,103 @@ +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; + } +} diff --git a/vendor/aws/Aws/S3/Model/MultipartUpload/ParallelTransfer.php b/vendor/aws/Aws/S3/Model/MultipartUpload/ParallelTransfer.php new file mode 100644 index 0000000..caa9e88 --- /dev/null +++ b/vendor/aws/Aws/S3/Model/MultipartUpload/ParallelTransfer.php @@ -0,0 +1,124 @@ +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; + } +} diff --git a/vendor/aws/Aws/S3/Model/MultipartUpload/SerialTransfer.php b/vendor/aws/Aws/S3/Model/MultipartUpload/SerialTransfer.php new file mode 100644 index 0000000..4a5953f --- /dev/null +++ b/vendor/aws/Aws/S3/Model/MultipartUpload/SerialTransfer.php @@ -0,0 +1,86 @@ +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); + } + } +} diff --git a/vendor/aws/Aws/S3/Model/MultipartUpload/TransferState.php b/vendor/aws/Aws/S3/Model/MultipartUpload/TransferState.php new file mode 100644 index 0000000..c63663f --- /dev/null +++ b/vendor/aws/Aws/S3/Model/MultipartUpload/TransferState.php @@ -0,0 +1,41 @@ +getIterator('ListParts', $uploadId->toParams()) as $part) { + $transferState->addPart(UploadPart::fromArray($part)); + } + + return $transferState; + } +} diff --git a/vendor/aws/Aws/S3/Model/MultipartUpload/UploadBuilder.php b/vendor/aws/Aws/S3/Model/MultipartUpload/UploadBuilder.php new file mode 100644 index 0000000..e30f23a --- /dev/null +++ b/vendor/aws/Aws/S3/Model/MultipartUpload/UploadBuilder.php @@ -0,0 +1,297 @@ +setOption('Bucket', $bucket); + } + + /** + * Set the key of the object + * + * @param string $key Key of the object to upload + * + * @return $this + */ + 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 $this + */ + 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 $this + */ + 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 $this + */ + 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 $this + */ + 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 $this + */ + 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 $this + */ + 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 $this + */ + 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 $this + */ + 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 $this + */ + 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 (!isset($this->commandOptions['ContentType'])) { + 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)); + } +} diff --git a/vendor/aws/Aws/S3/Model/MultipartUpload/UploadId.php b/vendor/aws/Aws/S3/Model/MultipartUpload/UploadId.php new file mode 100644 index 0000000..9d5f384 --- /dev/null +++ b/vendor/aws/Aws/S3/Model/MultipartUpload/UploadId.php @@ -0,0 +1,35 @@ + false, + 'Key' => false, + 'UploadId' => false + ); +} diff --git a/vendor/aws/Aws/S3/Model/MultipartUpload/UploadPart.php b/vendor/aws/Aws/S3/Model/MultipartUpload/UploadPart.php new file mode 100644 index 0000000..e0ded33 --- /dev/null +++ b/vendor/aws/Aws/S3/Model/MultipartUpload/UploadPart.php @@ -0,0 +1,74 @@ + '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; + } +} diff --git a/vendor/aws/Aws/S3/Model/PostObject.php b/vendor/aws/Aws/S3/Model/PostObject.php new file mode 100644 index 0000000..0aa2dbc --- /dev/null +++ b/vendor/aws/Aws/S3/Model/PostObject.php @@ -0,0 +1,275 @@ + 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 + * - policy_callback: A callback used to modify the policy before encoding and signing it. The + * method signature for the callback should accept an array of the policy data as + * the 1st argument, (optionally) the PostObject as the 2nd argument, and return + * the policy data with the desired modifications. + * - 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-meta-*: Any custom meta tag that should be set to the object + * - 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-server-side​-encryption​-customer-algorithm: The SSE-C algorithm + * - x-amz-server-side​-encryption​-customer-key: The SSE-C customer secret key + * - x-amz-server-side​-encryption​-customer-key-MD5: The MD5 hash of the SSE-C customer secret key + * + * 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']); + + // If a policy or policy callback were provided, extract those from the options + $rawJsonPolicy = $options['policy']; + $policyCallback = $options['policy_callback']; + unset($options['policy'], $options['policy_callback']); + + // 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()); + if ($url->getScheme() === 'https' && strpos($this->bucket, '.') !== false) { + // Use path-style URLs + $url->setPath($this->bucket); + } else { + // Use virtual-style URLs + $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 + ); + unset($options['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); + } + } + + // Handle the policy + $policy = is_callable($policyCallback) ? $policyCallback($policy, $this) : $policy; + $this->jsonPolicy = $rawJsonPolicy ?: json_encode($policy); + $this->applyPolicy(); + + 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; + } + + /** + * Handles the encoding, singing, and injecting of the policy + */ + protected function applyPolicy() + { + $jsonPolicy64 = base64_encode($this->jsonPolicy); + $this->formInputs['policy'] = $jsonPolicy64; + + $this->formInputs['signature'] = base64_encode(hash_hmac( + 'sha1', + $jsonPolicy64, + $this->client->getCredentials()->getSecretKey(), + true + )); + } +} diff --git a/vendor/aws/Aws/S3/Resources/s3-2006-03-01.php b/vendor/aws/Aws/S3/Resources/s3-2006-03-01.php new file mode 100644 index 0000000..5699058 --- /dev/null +++ b/vendor/aws/Aws/S3/Resources/s3-2006-03-01.php @@ -0,0 +1,5287 @@ + '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', + ), + 'eu-central-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 's3-eu-central-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', + ), + 'RequestPayer' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-payer', + ), + ), + '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( + 'name' => 'CompletedPart', + 'type' => 'object', + 'sentAs' => 'Part', + 'properties' => array( + 'ETag' => array( + 'type' => 'string', + ), + 'PartNumber' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'UploadId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'uploadId', + ), + 'RequestPayer' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-payer', + ), + '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', + 'data' => array( + 'xmlRoot' => array( + 'name' => 'CopyObjectRequest', + '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', + ), + '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' => 'string', + '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' => 'string', + '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', + ), + 'SSECustomerAlgorithm' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-algorithm', + ), + 'SSECustomerKey' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-key', + ), + 'SSECustomerKeyMD5' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-key-MD5', + ), + 'SSEKMSKeyId' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-aws-kms-key-id', + ), + 'CopySourceSSECustomerAlgorithm' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-copy-source-server-side-encryption-customer-algorithm', + ), + 'CopySourceSSECustomerKey' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-copy-source-server-side-encryption-customer-key', + ), + 'CopySourceSSECustomerKeyMD5' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-copy-source-server-side-encryption-customer-key-MD5', + ), + 'RequestPayer' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-payer', + ), + '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', + 'data' => array( + 'xmlRoot' => array( + 'name' => 'CreateMultipartUploadRequest', + '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', + ), + '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', + ), + 'SSECustomerAlgorithm' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-algorithm', + ), + 'SSECustomerKey' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-key', + ), + 'SSECustomerKeyMD5' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-key-MD5', + ), + 'SSEKMSKeyId' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-aws-kms-key-id', + ), + 'RequestPayer' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-payer', + ), + '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', + ), + ), + ), + 'DeleteBucketReplication' => array( + 'httpMethod' => 'DELETE', + 'uri' => '/{Bucket}?replication', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'DeleteBucketReplicationOutput', + 'responseType' => 'model', + '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', + ), + 'RequestPayer' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-payer', + ), + ), + ), + '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( + 'name' => 'ObjectIdentifier', + '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', + ), + 'RequestPayer' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-payer', + ), + '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' => 'NotificationConfigurationDeprecated', + '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', + ), + ), + ), + 'GetBucketNotificationConfiguration' => array( + 'httpMethod' => 'GET', + 'uri' => '/{Bucket}?notification', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'NotificationConfiguration', + 'responseType' => 'model', + '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', + ), + ), + ), + 'GetBucketReplication' => array( + 'httpMethod' => 'GET', + 'uri' => '/{Bucket}?replication', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'GetBucketReplicationOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/xml', + ), + ), + ), + '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', + ), + 'SSECustomerAlgorithm' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-algorithm', + ), + 'SSECustomerKey' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-key', + ), + 'SSECustomerKeyMD5' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-key-MD5', + ), + 'RequestPayer' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-payer', + ), + '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', + ), + 'RequestPayer' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-payer', + ), + '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', + ), + ), + 'RequestPayer' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-payer', + ), + ), + ), + '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', + ), + 'SSECustomerAlgorithm' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-algorithm', + ), + 'SSECustomerKey' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-key', + ), + 'SSECustomerKeyMD5' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-key-MD5', + ), + 'RequestPayer' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-payer', + ), + ), + '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', + ), + 'RequestPayer' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-payer', + ), + '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( + 'name' => 'CORSRule', + 'type' => 'object', + 'sentAs' => 'CORSRule', + 'properties' => array( + 'AllowedHeaders' => array( + 'type' => 'array', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'AllowedHeader', + 'type' => 'string', + 'sentAs' => 'AllowedHeader', + ), + ), + 'AllowedMethods' => array( + 'type' => 'array', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'AllowedMethod', + 'type' => 'string', + 'sentAs' => 'AllowedMethod', + ), + ), + 'AllowedOrigins' => array( + 'type' => 'array', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'AllowedOrigin', + 'type' => 'string', + 'sentAs' => 'AllowedOrigin', + ), + ), + 'ExposeHeaders' => array( + 'type' => 'array', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'ExposeHeader', + '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( + 'name' => 'Rule', + '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', + ), + ), + ), + 'NoncurrentVersionTransition' => array( + 'type' => 'object', + 'properties' => array( + 'NoncurrentDays' => array( + 'type' => 'numeric', + ), + 'StorageClass' => array( + 'type' => 'string', + ), + ), + ), + 'NoncurrentVersionExpiration' => array( + 'type' => 'object', + 'properties' => array( + 'NoncurrentDays' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + ), + ), + '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/', + ), + ), + 'xmlAllowEmpty' => true, + ), + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'TopicConfiguration' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Events' => array( + 'type' => 'array', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'Event', + 'type' => 'string', + ), + ), + 'Event' => array( + 'type' => 'string', + ), + 'Topic' => array( + 'type' => 'string', + ), + ), + ), + 'QueueConfiguration' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Event' => array( + 'type' => 'string', + ), + 'Events' => array( + 'type' => 'array', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'Event', + 'type' => 'string', + ), + ), + 'Queue' => array( + 'type' => 'string', + ), + ), + ), + 'CloudFunctionConfiguration' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Event' => array( + 'type' => 'string', + ), + 'Events' => array( + 'type' => 'array', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'Event', + 'type' => 'string', + ), + ), + 'CloudFunction' => array( + 'type' => 'string', + ), + 'InvocationRole' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'PutBucketNotificationConfiguration' => array( + 'httpMethod' => 'PUT', + 'uri' => '/{Bucket}?notification', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'PutBucketNotificationConfigurationOutput', + 'responseType' => 'model', + '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', + ), + 'TopicConfigurations' => array( + 'type' => 'array', + 'location' => 'xml', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'TopicConfiguration', + 'type' => 'object', + 'sentAs' => 'TopicConfiguration', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'TopicArn' => array( + 'required' => true, + 'type' => 'string', + 'sentAs' => 'Topic', + ), + 'Events' => array( + 'required' => true, + 'type' => 'array', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'Event', + 'type' => 'string', + 'sentAs' => 'Event', + ), + ), + ), + ), + ), + 'QueueConfigurations' => array( + 'type' => 'array', + 'location' => 'xml', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'QueueConfiguration', + 'type' => 'object', + 'sentAs' => 'QueueConfiguration', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'QueueArn' => array( + 'required' => true, + 'type' => 'string', + 'sentAs' => 'Queue', + ), + 'Events' => array( + 'required' => true, + 'type' => 'array', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'Event', + 'type' => 'string', + 'sentAs' => 'Event', + ), + ), + ), + ), + ), + 'LambdaFunctionConfigurations' => array( + 'type' => 'array', + 'location' => 'xml', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'LambdaFunctionConfiguration', + 'type' => 'object', + 'sentAs' => 'CloudFunctionConfiguration', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'LambdaFunctionArn' => array( + 'required' => true, + 'type' => 'string', + 'sentAs' => 'CloudFunction', + ), + 'Events' => array( + 'required' => true, + 'type' => 'array', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'Event', + 'type' => 'string', + 'sentAs' => 'Event', + ), + ), + ), + ), + ), + ), + ), + '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', + 'data' => array( + 'xmlRoot' => array( + 'name' => 'PutBucketPolicyRequest', + 'namespaces' => array( + 'http://s3.amazonaws.com/doc/2006-03-01/', + ), + ), + ), + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'Policy' => array( + 'required' => true, + 'type' => array( + 'string', + 'object', + ), + 'location' => 'body', + ), + ), + ), + 'PutBucketReplication' => array( + 'httpMethod' => 'PUT', + 'uri' => '/{Bucket}?replication', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'PutBucketReplicationOutput', + 'responseType' => 'model', + 'data' => array( + 'xmlRoot' => array( + 'name' => 'ReplicationConfiguration', + 'namespaces' => array( + 'http://s3.amazonaws.com/doc/2006-03-01/', + ), + ), + ), + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'Role' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'xml', + ), + 'Rules' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'xml', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'ReplicationRule', + 'type' => 'object', + 'sentAs' => 'Rule', + 'properties' => array( + 'ID' => array( + 'type' => 'string', + ), + 'Prefix' => array( + 'required' => true, + 'type' => 'string', + ), + 'Status' => array( + 'required' => true, + 'type' => 'string', + ), + 'Destination' => array( + 'required' => true, + 'type' => 'object', + 'properties' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + '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', + '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', + 'sentAs' => 'MfaDelete', + ), + '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', + 'data' => array( + 'xmlRoot' => array( + 'name' => 'PutObjectRequest', + 'namespaces' => array( + 'http://s3.amazonaws.com/doc/2006-03-01/', + ), + ), + ), + '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', + ), + 'SSECustomerAlgorithm' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-algorithm', + ), + 'SSECustomerKey' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-key', + ), + 'SSECustomerKeyMD5' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-key-MD5', + ), + 'SSEKMSKeyId' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-aws-kms-key-id', + ), + 'RequestPayer' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-payer', + ), + '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', + ), + ), + 'RequestPayer' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-payer', + ), + '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', + ), + ), + 'VersionId' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'versionId', + ), + 'Days' => array( + 'required' => true, + 'type' => 'numeric', + 'location' => 'xml', + ), + 'RequestPayer' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-payer', + ), + ), + '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', + 'data' => array( + 'xmlRoot' => array( + 'name' => 'UploadPartRequest', + 'namespaces' => array( + 'http://s3.amazonaws.com/doc/2006-03-01/', + ), + ), + ), + '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', + ), + 'SSECustomerAlgorithm' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-algorithm', + ), + 'SSECustomerKey' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-key', + ), + 'SSECustomerKeyMD5' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-key-MD5', + ), + 'RequestPayer' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-payer', + ), + ), + ), + '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', + 'data' => array( + 'xmlRoot' => array( + 'name' => 'UploadPartCopyRequest', + 'namespaces' => array( + 'http://s3.amazonaws.com/doc/2006-03-01/', + ), + ), + ), + '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' => 'string', + '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' => 'string', + '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', + ), + 'SSECustomerAlgorithm' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-algorithm', + ), + 'SSECustomerKey' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-key', + ), + 'SSECustomerKeyMD5' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-key-MD5', + ), + 'CopySourceSSECustomerAlgorithm' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-copy-source-server-side-encryption-customer-algorithm', + ), + 'CopySourceSSECustomerKey' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-copy-source-server-side-encryption-customer-key', + ), + 'CopySourceSSECustomerKeyMD5' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-copy-source-server-side-encryption-customer-key-MD5', + ), + 'RequestPayer' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-payer', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/xml', + ), + ), + ), + ), + 'models' => array( + 'AbortMultipartUploadOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestCharged' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-charged', + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'CompleteMultipartUploadOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Location' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'Bucket' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'Key' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'Expiration' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-expiration', + ), + 'ETag' => 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', + ), + 'SSEKMSKeyId' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-aws-kms-key-id', + ), + 'RequestCharged' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-charged', + ), + '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', + ), + 'Expiration' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-expiration', + ), + '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', + ), + 'SSECustomerAlgorithm' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-algorithm', + ), + 'SSECustomerKeyMD5' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-key-MD5', + ), + 'SSEKMSKeyId' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-aws-kms-key-id', + ), + 'RequestCharged' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-charged', + ), + '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', + ), + 'UploadId' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'ServerSideEncryption' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption', + ), + 'SSECustomerAlgorithm' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-algorithm', + ), + 'SSECustomerKeyMD5' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-key-MD5', + ), + 'SSEKMSKeyId' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-aws-kms-key-id', + ), + 'RequestCharged' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-charged', + ), + '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', + ), + ), + ), + 'DeleteBucketReplicationOutput' => 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', + ), + 'RequestCharged' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-charged', + ), + '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( + 'name' => 'DeletedObject', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'VersionId' => array( + 'type' => 'string', + ), + 'DeleteMarker' => array( + 'type' => 'boolean', + ), + 'DeleteMarkerVersionId' => array( + 'type' => 'string', + ), + ), + ), + ), + 'RequestCharged' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-charged', + ), + 'Errors' => array( + 'type' => 'array', + 'location' => 'xml', + 'sentAs' => 'Error', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'Error', + 'type' => 'object', + 'sentAs' => 'Error', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'VersionId' => array( + 'type' => 'string', + ), + 'Code' => array( + 'type' => 'string', + ), + 'Message' => array( + 'type' => 'string', + ), + ), + ), + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'GetBucketAclOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Owner' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'DisplayName' => array( + 'type' => 'string', + ), + 'ID' => array( + 'type' => 'string', + ), + ), + ), + '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', + ), + ), + ), + ), + '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( + 'name' => 'CORSRule', + 'type' => 'object', + 'sentAs' => 'CORSRule', + 'properties' => array( + 'AllowedHeaders' => array( + 'type' => 'array', + 'sentAs' => 'AllowedHeader', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'AllowedHeader', + 'type' => 'string', + 'sentAs' => 'AllowedHeader', + ), + ), + 'AllowedMethods' => array( + 'type' => 'array', + 'sentAs' => 'AllowedMethod', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'AllowedMethod', + 'type' => 'string', + 'sentAs' => 'AllowedMethod', + ), + ), + 'AllowedOrigins' => array( + 'type' => 'array', + 'sentAs' => 'AllowedOrigin', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'AllowedOrigin', + 'type' => 'string', + 'sentAs' => 'AllowedOrigin', + ), + ), + 'ExposeHeaders' => array( + 'type' => 'array', + 'sentAs' => 'ExposeHeader', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'ExposeHeader', + '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( + 'name' => 'Rule', + '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', + ), + ), + ), + 'NoncurrentVersionTransition' => array( + 'type' => 'object', + 'properties' => array( + 'NoncurrentDays' => array( + 'type' => 'numeric', + ), + 'StorageClass' => array( + 'type' => 'string', + ), + ), + ), + 'NoncurrentVersionExpiration' => array( + 'type' => 'object', + 'properties' => array( + 'NoncurrentDays' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + 'NotificationConfigurationDeprecated' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'TopicConfiguration' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Events' => array( + 'type' => 'array', + 'sentAs' => 'Event', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'Event', + 'type' => 'string', + 'sentAs' => 'Event', + ), + ), + 'Event' => array( + 'type' => 'string', + ), + 'Topic' => array( + 'type' => 'string', + ), + ), + ), + 'QueueConfiguration' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Event' => array( + 'type' => 'string', + ), + 'Events' => array( + 'type' => 'array', + 'sentAs' => 'Event', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'Event', + 'type' => 'string', + 'sentAs' => 'Event', + ), + ), + 'Queue' => array( + 'type' => 'string', + ), + ), + ), + 'CloudFunctionConfiguration' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Event' => array( + 'type' => 'string', + ), + 'Events' => array( + 'type' => 'array', + 'sentAs' => 'Event', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'Event', + 'type' => 'string', + 'sentAs' => 'Event', + ), + ), + 'CloudFunction' => array( + 'type' => 'string', + ), + 'InvocationRole' => array( + 'type' => 'string', + ), + ), + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'NotificationConfiguration' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'TopicConfigurations' => array( + 'type' => 'array', + 'location' => 'xml', + 'sentAs' => 'TopicConfiguration', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'TopicConfiguration', + 'type' => 'object', + 'sentAs' => 'TopicConfiguration', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'TopicArn' => array( + 'type' => 'string', + 'sentAs' => 'Topic', + ), + 'Events' => array( + 'type' => 'array', + 'sentAs' => 'Event', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'Event', + 'type' => 'string', + 'sentAs' => 'Event', + ), + ), + ), + ), + ), + 'QueueConfigurations' => array( + 'type' => 'array', + 'location' => 'xml', + 'sentAs' => 'QueueConfiguration', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'QueueConfiguration', + 'type' => 'object', + 'sentAs' => 'QueueConfiguration', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'QueueArn' => array( + 'type' => 'string', + 'sentAs' => 'Queue', + ), + 'Events' => array( + 'type' => 'array', + 'sentAs' => 'Event', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'Event', + 'type' => 'string', + 'sentAs' => 'Event', + ), + ), + ), + ), + ), + 'LambdaFunctionConfigurations' => array( + 'type' => 'array', + 'location' => 'xml', + 'sentAs' => 'CloudFunctionConfiguration', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'LambdaFunctionConfiguration', + 'type' => 'object', + 'sentAs' => 'CloudFunctionConfiguration', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'LambdaFunctionArn' => array( + 'type' => 'string', + 'sentAs' => 'CloudFunction', + ), + 'Events' => array( + 'type' => 'array', + 'sentAs' => 'Event', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'Event', + 'type' => 'string', + 'sentAs' => 'Event', + ), + ), + ), + ), + ), + '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', + ), + ), + ), + 'GetBucketReplicationOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Role' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'Rules' => array( + 'type' => 'array', + 'location' => 'xml', + 'sentAs' => 'Rule', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'ReplicationRule', + 'type' => 'object', + 'sentAs' => 'Rule', + 'properties' => array( + 'ID' => array( + 'type' => 'string', + ), + 'Prefix' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'Destination' => array( + 'type' => 'object', + 'properties' => array( + 'Bucket' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + '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( + 'Status' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'MFADelete' => array( + 'type' => 'string', + 'location' => 'xml', + 'sentAs' => 'MfaDelete', + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'GetBucketWebsiteOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RedirectAllRequestsTo' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'HostName' => array( + 'type' => 'string', + ), + 'Protocol' => array( + 'type' => 'string', + ), + ), + ), + 'IndexDocument' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Suffix' => array( + 'type' => 'string', + ), + ), + ), + 'ErrorDocument' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Key' => 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( + 'Body' => array( + 'type' => 'string', + 'instanceOf' => 'Guzzle\\Http\\EntityBody', + 'location' => 'body', + ), + 'DeleteMarker' => array( + 'type' => 'boolean', + 'location' => 'header', + 'sentAs' => 'x-amz-delete-marker', + ), + 'AcceptRanges' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'accept-ranges', + ), + 'Expiration' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-expiration', + ), + 'Restore' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-restore', + ), + 'LastModified' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'Last-Modified', + ), + 'ContentLength' => array( + 'type' => 'numeric', + 'location' => 'header', + 'sentAs' => 'Content-Length', + ), + 'ETag' => array( + 'type' => 'string', + 'location' => 'header', + ), + 'MissingMeta' => array( + 'type' => 'numeric', + 'location' => 'header', + 'sentAs' => 'x-amz-missing-meta', + ), + 'VersionId' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-version-id', + ), + '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' => 'string', + 'location' => 'header', + ), + 'WebsiteRedirectLocation' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-website-redirect-location', + ), + 'ServerSideEncryption' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption', + ), + 'Metadata' => array( + 'type' => 'object', + 'location' => 'header', + 'sentAs' => 'x-amz-meta-', + 'additionalProperties' => array( + 'type' => 'string', + ), + ), + 'SSECustomerAlgorithm' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-algorithm', + ), + 'SSECustomerKeyMD5' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-key-MD5', + ), + 'SSEKMSKeyId' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-aws-kms-key-id', + ), + 'RequestCharged' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-charged', + ), + 'ReplicationStatus' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-replication-status', + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'GetObjectAclOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Owner' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'DisplayName' => array( + 'type' => 'string', + ), + 'ID' => array( + 'type' => 'string', + ), + ), + ), + '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', + ), + ), + ), + ), + 'RequestCharged' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-charged', + ), + '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', + ), + 'RequestCharged' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-charged', + ), + '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( + 'DeleteMarker' => array( + 'type' => 'boolean', + 'location' => 'header', + 'sentAs' => 'x-amz-delete-marker', + ), + 'AcceptRanges' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'accept-ranges', + ), + 'Expiration' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-expiration', + ), + 'Restore' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-restore', + ), + 'LastModified' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'Last-Modified', + ), + 'ContentLength' => array( + 'type' => 'numeric', + 'location' => 'header', + 'sentAs' => 'Content-Length', + ), + 'ETag' => array( + 'type' => 'string', + 'location' => 'header', + ), + 'MissingMeta' => array( + 'type' => 'numeric', + 'location' => 'header', + 'sentAs' => 'x-amz-missing-meta', + ), + 'VersionId' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-version-id', + ), + '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' => 'string', + 'location' => 'header', + ), + 'WebsiteRedirectLocation' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-website-redirect-location', + ), + 'ServerSideEncryption' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption', + ), + 'Metadata' => array( + 'type' => 'object', + 'location' => 'header', + 'sentAs' => 'x-amz-meta-', + 'additionalProperties' => array( + 'type' => 'string', + ), + ), + 'SSECustomerAlgorithm' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-algorithm', + ), + 'SSECustomerKeyMD5' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-key-MD5', + ), + 'SSEKMSKeyId' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-aws-kms-key-id', + ), + 'RequestCharged' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-charged', + ), + 'ReplicationStatus' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-replication-status', + ), + '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( + 'Name' => array( + 'type' => 'string', + ), + 'CreationDate' => 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', + ), + 'KeyMarker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'UploadIdMarker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'NextKeyMarker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'Prefix' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'Delimiter' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'NextUploadIdMarker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'MaxUploads' => array( + 'type' => 'numeric', + 'location' => 'xml', + ), + 'IsTruncated' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'Uploads' => array( + 'type' => 'array', + 'location' => 'xml', + 'sentAs' => 'Upload', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'MultipartUpload', + 'type' => 'object', + 'sentAs' => 'Upload', + 'properties' => array( + 'UploadId' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'Initiated' => array( + 'type' => 'string', + ), + 'StorageClass' => array( + 'type' => 'string', + ), + 'Owner' => array( + 'type' => 'object', + 'properties' => array( + 'DisplayName' => array( + 'type' => 'string', + ), + 'ID' => array( + 'type' => 'string', + ), + ), + ), + 'Initiator' => array( + 'type' => 'object', + 'properties' => array( + 'ID' => array( + 'type' => 'string', + ), + 'DisplayName' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'CommonPrefixes' => array( + 'type' => 'array', + 'location' => 'xml', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'CommonPrefix', + 'type' => 'object', + 'properties' => array( + 'Prefix' => array( + 'type' => 'string', + ), + ), + ), + ), + 'EncodingType' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'ListObjectVersionsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'IsTruncated' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'KeyMarker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'VersionIdMarker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'NextKeyMarker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'NextVersionIdMarker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'Versions' => array( + 'type' => 'array', + 'location' => 'xml', + 'sentAs' => 'Version', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'ObjectVersion', + 'type' => 'object', + 'sentAs' => 'Version', + 'properties' => array( + 'ETag' => array( + 'type' => 'string', + ), + 'Size' => array( + 'type' => 'numeric', + ), + 'StorageClass' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'VersionId' => array( + 'type' => 'string', + ), + 'IsLatest' => array( + 'type' => 'boolean', + ), + 'LastModified' => array( + 'type' => 'string', + ), + 'Owner' => array( + 'type' => 'object', + 'properties' => array( + 'DisplayName' => array( + 'type' => 'string', + ), + 'ID' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'DeleteMarkers' => array( + 'type' => 'array', + 'location' => 'xml', + 'sentAs' => 'DeleteMarker', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'DeleteMarkerEntry', + 'type' => 'object', + 'sentAs' => 'DeleteMarker', + 'properties' => array( + 'Owner' => array( + 'type' => 'object', + 'properties' => array( + 'DisplayName' => array( + 'type' => 'string', + ), + 'ID' => array( + 'type' => 'string', + ), + ), + ), + 'Key' => array( + 'type' => 'string', + ), + 'VersionId' => array( + 'type' => 'string', + ), + 'IsLatest' => array( + 'type' => 'boolean', + ), + 'LastModified' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Name' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'Prefix' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'Delimiter' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'MaxKeys' => array( + 'type' => 'numeric', + 'location' => 'xml', + ), + 'CommonPrefixes' => array( + 'type' => 'array', + 'location' => 'xml', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'CommonPrefix', + 'type' => 'object', + 'properties' => array( + 'Prefix' => array( + 'type' => 'string', + ), + ), + ), + ), + 'EncodingType' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'ListObjectsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'IsTruncated' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'NextMarker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'Contents' => array( + 'type' => 'array', + 'location' => 'xml', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'Object', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'LastModified' => array( + 'type' => 'string', + ), + 'ETag' => array( + 'type' => 'string', + ), + 'Size' => array( + 'type' => 'numeric', + ), + 'StorageClass' => array( + 'type' => 'string', + ), + 'Owner' => array( + 'type' => 'object', + 'properties' => array( + 'DisplayName' => array( + 'type' => 'string', + ), + 'ID' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'Name' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'Prefix' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'Delimiter' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'MaxKeys' => array( + 'type' => 'numeric', + 'location' => 'xml', + ), + 'CommonPrefixes' => array( + 'type' => 'array', + 'location' => 'xml', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'CommonPrefix', + 'type' => 'object', + 'properties' => array( + 'Prefix' => array( + 'type' => 'string', + ), + ), + ), + ), + 'EncodingType' => 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', + ), + 'Key' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'UploadId' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'PartNumberMarker' => array( + 'type' => 'numeric', + 'location' => 'xml', + ), + 'NextPartNumberMarker' => array( + 'type' => 'numeric', + 'location' => 'xml', + ), + 'MaxParts' => array( + 'type' => 'numeric', + 'location' => 'xml', + ), + 'IsTruncated' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'Parts' => array( + 'type' => 'array', + 'location' => 'xml', + 'sentAs' => 'Part', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'Part', + 'type' => 'object', + 'sentAs' => 'Part', + 'properties' => array( + 'PartNumber' => array( + 'type' => 'numeric', + ), + 'LastModified' => array( + 'type' => 'string', + ), + 'ETag' => array( + 'type' => 'string', + ), + 'Size' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'Initiator' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'ID' => array( + 'type' => 'string', + ), + 'DisplayName' => array( + 'type' => 'string', + ), + ), + ), + 'Owner' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'DisplayName' => array( + 'type' => 'string', + ), + 'ID' => array( + 'type' => 'string', + ), + ), + ), + 'StorageClass' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'RequestCharged' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-charged', + ), + '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', + ), + ), + ), + 'PutBucketNotificationConfigurationOutput' => 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', + ), + ), + ), + 'PutBucketReplicationOutput' => 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( + 'Expiration' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-expiration', + ), + 'ETag' => array( + 'type' => 'string', + 'location' => 'header', + ), + 'ServerSideEncryption' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption', + ), + 'VersionId' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-version-id', + ), + 'SSECustomerAlgorithm' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-algorithm', + ), + 'SSECustomerKeyMD5' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-key-MD5', + ), + 'SSEKMSKeyId' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-aws-kms-key-id', + ), + 'RequestCharged' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-charged', + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + 'ObjectURL' => array( + ), + ), + ), + 'PutObjectAclOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestCharged' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-charged', + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'RestoreObjectOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestCharged' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-charged', + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'UploadPartOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ServerSideEncryption' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption', + ), + 'ETag' => array( + 'type' => 'string', + 'location' => 'header', + ), + 'SSECustomerAlgorithm' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-algorithm', + ), + 'SSECustomerKeyMD5' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-key-MD5', + ), + 'SSEKMSKeyId' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-aws-kms-key-id', + ), + 'RequestCharged' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-charged', + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'UploadPartCopyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'CopySourceVersionId' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-copy-source-version-id', + ), + 'ETag' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'LastModified' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'ServerSideEncryption' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption', + ), + 'SSECustomerAlgorithm' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-algorithm', + ), + 'SSECustomerKeyMD5' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-customer-key-MD5', + ), + 'SSEKMSKeyId' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption-aws-kms-key-id', + ), + 'RequestCharged' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-request-charged', + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + ), + 'iterators' => array( + 'ListBuckets' => array( + 'result_key' => 'Buckets', + ), + 'ListMultipartUploads' => array( + 'limit_key' => 'MaxUploads', + 'more_results' => 'IsTruncated', + 'output_token' => array( + 'NextKeyMarker', + 'NextUploadIdMarker', + ), + 'input_token' => array( + 'KeyMarker', + 'UploadIdMarker', + ), + 'result_key' => array( + 'Uploads', + 'CommonPrefixes', + ), + ), + 'ListObjectVersions' => array( + 'more_results' => 'IsTruncated', + 'limit_key' => 'MaxKeys', + 'output_token' => array( + 'NextKeyMarker', + 'NextVersionIdMarker', + ), + 'input_token' => array( + 'KeyMarker', + 'VersionIdMarker', + ), + 'result_key' => array( + 'Versions', + 'DeleteMarkers', + 'CommonPrefixes', + ), + ), + 'ListObjects' => array( + 'more_results' => 'IsTruncated', + 'limit_key' => 'MaxKeys', + 'output_token' => 'NextMarker', + 'input_token' => 'Marker', + 'result_key' => array( + 'Contents', + 'CommonPrefixes', + ), + ), + 'ListParts' => array( + 'more_results' => 'IsTruncated', + 'limit_key' => 'MaxParts', + 'output_token' => 'NextPartNumberMarker', + 'input_token' => 'PartNumberMarker', + 'result_key' => 'Parts', + ), + ), + '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', + ), + ), + ), +); diff --git a/vendor/aws/Aws/S3/ResumableDownload.php b/vendor/aws/Aws/S3/ResumableDownload.php new file mode 100644 index 0000000..386a077 --- /dev/null +++ b/vendor/aws/Aws/S3/ResumableDownload.php @@ -0,0 +1,176 @@ +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}." + ); + } + } + } +} diff --git a/vendor/aws/Aws/S3/S3Client.php b/vendor/aws/Aws/S3/S3Client.php new file mode 100644 index 0000000..3c2bcbb --- /dev/null +++ b/vendor/aws/Aws/S3/S3Client.php @@ -0,0 +1,685 @@ + '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', + ); + + 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 S3Client + * @link http://docs.aws.amazon.com/aws-sdk-php/v2/guide/configuration.html#client-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] = static::createBackoffPlugin($exceptionParser); + } + + $config[Options::SIGNATURE] = $signature = static::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'))); + + // Ensures that if a SSE-CPK key is provided, the key and md5 are formatted correctly + $client->addSubscriber(new SseCpkListener); + + // Add aliases for some S3 operations + $default = CompositeFactory::getDefaultChain($client); + $default->add( + new AliasFactory($client, static::$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 CurlBackoffStrategy(null, + new HttpBackoffStrategy(null, + new SocketTimeoutChecker( + new ExpiredCredentialsChecker($exceptionParser, + new ExponentialBackoffStrategy() + ) + ) + ) + ) + ) + ); + } + + /** + * Create an appropriate signature based on the configuration settings + * + * @param $config + * + * @return \Aws\Common\Signature\SignatureInterface + * @throws InvalidArgumentException + */ + private static function createSignature($config) + { + $currentValue = isset($config[Options::SIGNATURE]) ? $config[Options::SIGNATURE] : null; + + // Force v4 if no value is provided, a region is in the config, and + // the region starts with "cn-" or "eu-central-". + $requiresV4 = !$currentValue + && isset($config['region']) + && (strpos($config['region'], 'eu-central-') === 0 + || strpos($config['region'], 'cn-') === 0); + + // 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' || $requiresV4) { + // 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(); + } + + // 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; + } + + /** + * 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 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 $this + */ + 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(); + + if ($options['before_upload']) { + $transfer->getEventDispatcher()->addListener( + AbstractTransfer::BEFORE_PART_UPLOAD, + $options['before_upload'] + ); + } + + return $transfer->upload(); + } + + /** + * 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' => realpath($directory) ?: $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; + } +} diff --git a/vendor/aws/Aws/S3/S3Md5Listener.php b/vendor/aws/Aws/S3/S3Md5Listener.php new file mode 100644 index 0000000..7558c47 --- /dev/null +++ b/vendor/aws/Aws/S3/S3Md5Listener.php @@ -0,0 +1,73 @@ + 'onCommandAfterPrepare'); + } + + public function __construct(SignatureInterface $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(); + $body = $request->getBody(); + if ($body && $body->getSize() > 0) { + if (false !== ($md5 = $body->getContentMd5(true, true))) { + $request->setHeader('Content-MD5', $md5); + } + } + } +} diff --git a/vendor/aws/Aws/S3/S3Signature.php b/vendor/aws/Aws/S3/S3Signature.php new file mode 100644 index 0000000..ef9a86b --- /dev/null +++ b/vendor/aws/Aws/S3/S3Signature.php @@ -0,0 +1,266 @@ +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); + } + + $request->removeHeader('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 + )); + + // Move X-Amz-* headers to the query string + foreach ($request->getHeaders() as $name => $header) { + $name = strtolower($name); + if (strpos($name, 'x-amz-') === 0) { + $request->getQuery()->set($name, (string) $header); + $request->removeHeader($name); + } + } + + 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() as $name => $header) { + $name = strtolower($name); + if (strpos($name, 'x-amz-') === 0) { + $value = trim((string) $header); + if ($value || $value === '0') { + $headers[$name] = $name . ':' . $value; + } + } + } + + if (!$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 empty sub-resources + if ($value !== '' && + $value !== false && + $value !== null && + $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()), ' .'); + } +} diff --git a/vendor/aws/Aws/S3/S3SignatureInterface.php b/vendor/aws/Aws/S3/S3SignatureInterface.php new file mode 100644 index 0000000..0b7e940 --- /dev/null +++ b/vendor/aws/Aws/S3/S3SignatureInterface.php @@ -0,0 +1,24 @@ +hasHeader('x-amz-content-sha256')) { + $request->setHeader( + 'x-amz-content-sha256', + $this->getPayload($request) + ); + } + + parent::signRequest($request, $credentials); + } + + /** + * Override used to allow pre-signed URLs to be created for an + * in-determinate request payload. + */ + protected function getPresignedPayload(RequestInterface $request) + { + return 'UNSIGNED-PAYLOAD'; + } + + /** + * Amazon S3 does not double-encode the path component in the canonical req + */ + protected function createCanonicalizedPath(RequestInterface $request) + { + return '/' . ltrim($request->getPath(), '/'); + } +} diff --git a/vendor/aws/Aws/S3/SocketTimeoutChecker.php b/vendor/aws/Aws/S3/SocketTimeoutChecker.php new file mode 100644 index 0000000..ede2b96 --- /dev/null +++ b/vendor/aws/Aws/S3/SocketTimeoutChecker.php @@ -0,0 +1,71 @@ +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) + ) { + return true; + } + } +} diff --git a/vendor/aws/Aws/S3/SseCpkListener.php b/vendor/aws/Aws/S3/SseCpkListener.php new file mode 100644 index 0000000..c1a9260 --- /dev/null +++ b/vendor/aws/Aws/S3/SseCpkListener.php @@ -0,0 +1,68 @@ + 'onCommandBeforePrepare'); + } + + public function onCommandBeforePrepare(Event $event) + { + /** @var CommandInterface $command */ + $command = $event['command']; + + // Allows only HTTPS connections when using SSE-C + if ($command['SSECustomerKey'] || + $command['CopySourceSSECustomerKey'] + ) { + $this->validateScheme($command); + } + + // Prepare the normal SSE-CPK headers + if ($command['SSECustomerKey']) { + $this->prepareSseParams($command); + } + + // If it's a copy operation, prepare the SSE-CPK headers for the source. + if ($command['CopySourceSSECustomerKey']) { + $this->prepareSseParams($command, true); + } + } + + private function validateScheme(CommandInterface $command) + { + if ($command->getClient()->getConfig('scheme') !== 'https') { + throw new RuntimeException('You must configure your S3 client to ' + . 'use HTTPS in order to use the SSE-C features.'); + } + } + + private function prepareSseParams( + CommandInterface $command, + $isCopy = false + ) { + $prefix = $isCopy ? 'CopySource' : ''; + + // Base64 encode the provided key + $key = $command[$prefix . 'SSECustomerKey']; + $command[$prefix . 'SSECustomerKey'] = base64_encode($key); + + // Base64 the provided MD5 or, generate an MD5 if not provided + if ($md5 = $command[$prefix . 'SSECustomerKeyMD5']) { + $command[$prefix . 'SSECustomerKeyMD5'] = base64_encode($md5); + } else { + $command[$prefix . 'SSECustomerKeyMD5'] = base64_encode(md5($key, true)); + } + } +} diff --git a/vendor/aws/Aws/S3/StreamWrapper.php b/vendor/aws/Aws/S3/StreamWrapper.php new file mode 100644 index 0000000..13cfbe3 --- /dev/null +++ b/vendor/aws/Aws/S3/StreamWrapper.php @@ -0,0 +1,892 @@ +/" 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 + * - 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', get_called_class(), STREAM_IS_URL); + static::$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' && static::$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 { + static::$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); + static::$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(static::$nextStat[$path])) { + return static::$nextStat[$path]; + } + + $parts = $this->getParams($path); + + if (!$parts['Key']) { + // Stat "directories": buckets, or "s3://" + if (!$parts['Bucket'] || static::$client->doesBucketExist($parts['Bucket'])) { + return $this->formatUrlStat($path); + } else { + return $this->triggerError("File or directory not found: {$path}", $flags); + } + } + + try { + try { + $result = static::$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 = static::$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. + * + * @return bool + * @link http://www.php.net/manual/en/streamwrapper.mkdir.php + */ + public function mkdir($path, $mode, $options) + { + $params = $this->getParams($path); + if (!$params['Bucket']) { + return false; + } + + if (!isset($params['ACL'])) { + $params['ACL'] = $this->determineAcl($mode); + } + + return !isset($params['Key']) || $params['Key'] === '/' + ? $this->createBucket($path, $params) + : $this->createPseudoDirectory($path, $params); + } + + /** + * Remove a bucket from Amazon S3 + * + * @param string $path the directory path + * @param int $options A bitwise mask of values + * + * @return bool true if directory was successfully removed + * @link http://www.php.net/manual/en/streamwrapper.rmdir.php + */ + public function rmdir($path, $options) + { + $params = $this->getParams($path); + if (!$params['Bucket']) { + return $this->triggerError('You cannot delete s3://. Please specify a bucket.'); + } + + try { + + if (!$params['Key']) { + static::$client->deleteBucket(array('Bucket' => $params['Bucket'])); + $this->clearStatInfo($path); + return true; + } + + // Use a key that adds a trailing slash if needed. + $prefix = rtrim($params['Key'], '/') . '/'; + + $result = static::$client->listObjects(array( + 'Bucket' => $params['Bucket'], + 'Prefix' => $prefix, + 'MaxKeys' => 1 + )); + + // Check if the bucket contains keys other than the placeholder + if ($result['Contents']) { + foreach ($result['Contents'] as $key) { + if ($key['Key'] == $prefix) { + continue; + } + return $this->triggerError('Psuedo folder is not empty'); + } + return $this->unlink(rtrim($path, '/') . '/'); + } + + return $result['CommonPrefixes'] + ? $this->triggerError('Pseudo folder contains nested folders') + : true; + + } catch (\Exception $e) { + return $this->triggerError($e->getMessage()); + } + } + + /** + * Support for opendir(). + * + * The opendir() method of the Amazon S3 stream wrapper supports a stream + * context option of "listFilter". listFilter must be a callable that + * accepts an associative array of object data and returns true if the + * object should be yielded when iterating the keys in a bucket. + * + * @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'); + $filterFn = $this->getOption('listFilter'); + + 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; + } + + $objectIterator = static::$client->getIterator('ListObjects', $operationParams, array( + 'return_prefixes' => true, + 'sort_results' => true + )); + + // Filter our "/" keys added by the console as directories, and ensure + // that if a filter function is provided that it passes the filter. + $this->objectIterator = new FilterIterator( + $objectIterator, + function ($key) use ($filterFn) { + // Each yielded results can contain a "Key" or "Prefix" + return (!$filterFn || call_user_func($filterFn, $key)) && + (!isset($key['Key']) || substr($key['Key'], -1, 1) !== '/'); + } + ); + + $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() + { + // Skip empty result keys + if (!$this->objectIterator->valid()) { + return false; + } + + $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. + static::$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 + static::$client->copyObject($this->getOptions() + array( + 'Bucket' => $partsTo['Bucket'], + 'Key' => $partsTo['Key'], + 'CopySource' => '/' . $partsFrom['Bucket'] . '/' . rawurlencode($partsFrom['Key']), + 'MetadataDirective' => 'COPY' + )); + // Delete the original object + static::$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']); + + 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(static::$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 = static::$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) { + // This is triggered with things like file_exists() + + if ($flags & STREAM_URL_STAT_LINK) { + // This is triggered for things like is_link() + return $this->formatUrlStat(false); + } + return false; + } + + // This is triggered when doing things like lstat() or stat() + 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; + $type = gettype($result); + + // Determine what type of data is being cached + if ($type == 'NULL' || $type == 'string') { + // Directory with 0777 access - see "man 2 stat". + $stat['mode'] = $stat[2] = 0040777; + } elseif ($type == 'array' && 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; + } + + 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) + { + static::$nextStat = array(); + if ($path) { + clearstatcache(true, $path); + } + } + + /** + * Creates a bucket for the given parameters. + * + * @param string $path Stream wrapper path + * @param array $params A result of StreamWrapper::getParams() + * + * @return bool Returns true on success or false on failure + */ + private function createBucket($path, array $params) + { + if (static::$client->doesBucketExist($params['Bucket'])) { + return $this->triggerError("Directory already exists: {$path}"); + } + + try { + static::$client->createBucket($params); + $this->clearStatInfo($path); + return true; + } catch (\Exception $e) { + return $this->triggerError($e->getMessage()); + } + } + + /** + * Creates a pseudo-folder by creating an empty "/" suffixed key + * + * @param string $path Stream wrapper path + * @param array $params A result of StreamWrapper::getParams() + * + * @return bool + */ + private function createPseudoDirectory($path, array $params) + { + // Ensure the path ends in "/" and the body is empty. + $params['Key'] = rtrim($params['Key'], '/') . '/'; + $params['Body'] = ''; + + // Fail if this pseudo directory key already exists + if (static::$client->doesObjectExist($params['Bucket'], $params['Key'])) { + return $this->triggerError("Directory already exists: {$path}"); + } + + try { + static::$client->putObject($params); + $this->clearStatInfo($path); + return true; + } catch (\Exception $e) { + return $this->triggerError($e->getMessage()); + } + } + + /** + * Determine the most appropriate ACL based on a file mode. + * + * @param int $mode File mode + * + * @return string + */ + private function determineAcl($mode) + { + $mode = decoct($mode); + + if ($mode >= 700 && $mode <= 799) { + return 'public-read'; + } + + if ($mode >= 600 && $mode <= 699) { + return 'authenticated-read'; + } + + return 'private'; + } +} diff --git a/vendor/aws/Aws/S3/Sync/AbstractSync.php b/vendor/aws/Aws/S3/Sync/AbstractSync.php new file mode 100644 index 0000000..ac5bbbe --- /dev/null +++ b/vendor/aws/Aws/S3/Sync/AbstractSync.php @@ -0,0 +1,127 @@ +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); + } + } + } +} diff --git a/vendor/aws/Aws/S3/Sync/AbstractSyncBuilder.php b/vendor/aws/Aws/S3/Sync/AbstractSyncBuilder.php new file mode 100644 index 0000000..df69f4a --- /dev/null +++ b/vendor/aws/Aws/S3/Sync/AbstractSyncBuilder.php @@ -0,0 +1,435 @@ +bucket = $bucket; + + return $this; + } + + /** + * Set the Amazon S3 client object that will send requests + * + * @param S3Client $client Amazon S3 client + * + * @return $this + */ + 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 $this + */ + 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 $this + */ + 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 $this + */ + 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 $this + */ + 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 $this + */ + 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 $this + */ + 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 $this + */ + 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 $this + */ + 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 $this + */ + 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 $this + */ + 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 $this + */ + 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 AbstractSync + */ + 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' => '', + 'listFilter' => function ($obj) { + // Ensure that we do not try to download a glacier object. + return !isset($obj['StorageClass']) || + $obj['StorageClass'] != 'GLACIER'; + } + ) + ))); + + // Add the trailing slash for the OpendirIterator concatenation + if (!$this->keyPrefix) { + $dir .= '/'; + } + + return $this->filterIterator(new \NoRewindIterator(new OpendirIterator($dh, $dir))); + } +} diff --git a/vendor/aws/Aws/S3/Sync/ChangedFilesIterator.php b/vendor/aws/Aws/S3/Sync/ChangedFilesIterator.php new file mode 100644 index 0000000..dc3e07c --- /dev/null +++ b/vendor/aws/Aws/S3/Sync/ChangedFilesIterator.php @@ -0,0 +1,130 @@ +targetIterator = $targetIterator; + $this->sourceConverter = $sourceConverter; + $this->targetConverter = $targetConverter; + parent::__construct($sourceIterator); + } + + public function accept() + { + $current = $this->current(); + $key = $this->sourceConverter->convert($this->normalize($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) + { + $key = $this->cleanKey($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($this->normalize($value)); + $filename = $this->cleanKey($filename); + + if ($filename == $key) { + return $data; + } + + $this->cache[$filename] = $data; + $it->next(); + } + + return false; + } + + private function normalize($current) + { + $asString = (string) $current; + + return strpos($asString, 's3://') === 0 + ? $asString + : $current->getRealPath(); + } + + private function cleanKey($key) + { + return ltrim($key, '/'); + } +} diff --git a/vendor/aws/Aws/S3/Sync/DownloadSync.php b/vendor/aws/Aws/S3/Sync/DownloadSync.php new file mode 100644 index 0000000..560ccdf --- /dev/null +++ b/vendor/aws/Aws/S3/Sync/DownloadSync.php @@ -0,0 +1,95 @@ +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)); + } +} diff --git a/vendor/aws/Aws/S3/Sync/DownloadSyncBuilder.php b/vendor/aws/Aws/S3/Sync/DownloadSyncBuilder.php new file mode 100644 index 0000000..d9cd044 --- /dev/null +++ b/vendor/aws/Aws/S3/Sync/DownloadSyncBuilder.php @@ -0,0 +1,129 @@ +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"); + } + }); + } +} diff --git a/vendor/aws/Aws/S3/Sync/FilenameConverterInterface.php b/vendor/aws/Aws/S3/Sync/FilenameConverterInterface.php new file mode 100644 index 0000000..ded2cfb --- /dev/null +++ b/vendor/aws/Aws/S3/Sync/FilenameConverterInterface.php @@ -0,0 +1,32 @@ +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; + } +} diff --git a/vendor/aws/Aws/S3/Sync/UploadSync.php b/vendor/aws/Aws/S3/Sync/UploadSync.php new file mode 100644 index 0000000..31b81e6 --- /dev/null +++ b/vendor/aws/Aws/S3/Sync/UploadSync.php @@ -0,0 +1,86 @@ +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->getRealPath() ?: $file->getPathName(); + + if (!($resource = fopen($filename, 'r'))) { + // @codeCoverageIgnoreStart + throw new RuntimeException('Could not open ' . $file->getPathname() . ' 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 + )); + } +} diff --git a/vendor/aws/Aws/S3/Sync/UploadSyncBuilder.php b/vendor/aws/Aws/S3/Sync/UploadSyncBuilder.php new file mode 100644 index 0000000..2083059 --- /dev/null +++ b/vendor/aws/Aws/S3/Sync/UploadSyncBuilder.php @@ -0,0 +1,190 @@ +baseDir = realpath($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 $this + * @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 $this + */ + 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 $this + */ + 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 $this + */ + 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; + } + ); + }); + } +} diff --git a/vendor/aws/Aws/Ses/Enum/IdentityType.php b/vendor/aws/Aws/Ses/Enum/IdentityType.php new file mode 100644 index 0000000..30d3234 --- /dev/null +++ b/vendor/aws/Aws/Ses/Enum/IdentityType.php @@ -0,0 +1,28 @@ + '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', + ), + 'DeliveryTopic' => 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( + 'ListIdentities' => array( + 'input_token' => 'NextToken', + 'output_token' => '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, + ), + ), +); diff --git a/vendor/aws/Aws/Ses/SesClient.php b/vendor/aws/Aws/Ses/SesClient.php new file mode 100644 index 0000000..3dd9a79 --- /dev/null +++ b/vendor/aws/Aws/Ses/SesClient.php @@ -0,0 +1,77 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/ses-%s.php', + Options::SIGNATURE_SERVICE => 'ses', + )) + ->build(); + } +} diff --git a/vendor/aws/Aws/SimpleDb/Exception/AttributeDoesNotExistException.php b/vendor/aws/Aws/SimpleDb/Exception/AttributeDoesNotExistException.php new file mode 100644 index 0000000..f061ac0 --- /dev/null +++ b/vendor/aws/Aws/SimpleDb/Exception/AttributeDoesNotExistException.php @@ -0,0 +1,22 @@ + '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', + ), + ), + ), + ), + 'iterators' => array( + 'ListDomains' => array( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'limit_key' => 'MaxNumberOfDomains', + 'result_key' => 'DomainNames', + ), + 'Select' => array( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'result_key' => 'Items', + ), + ), +); diff --git a/vendor/aws/Aws/SimpleDb/SimpleDbClient.php b/vendor/aws/Aws/SimpleDb/SimpleDbClient.php new file mode 100644 index 0000000..e1701d5 --- /dev/null +++ b/vendor/aws/Aws/SimpleDb/SimpleDbClient.php @@ -0,0 +1,67 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/simpledb-%s.php' + )) + ->build(); + } +} diff --git a/vendor/aws/Aws/Sns/Exception/AuthorizationErrorException.php b/vendor/aws/Aws/Sns/Exception/AuthorizationErrorException.php new file mode 100644 index 0000000..fb44055 --- /dev/null +++ b/vendor/aws/Aws/Sns/Exception/AuthorizationErrorException.php @@ -0,0 +1,22 @@ + 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; + } +} diff --git a/vendor/aws/Aws/Sns/MessageValidator/MessageValidator.php b/vendor/aws/Aws/Sns/MessageValidator/MessageValidator.php new file mode 100644 index 0000000..113453e --- /dev/null +++ b/vendor/aws/Aws/Sns/MessageValidator/MessageValidator.php @@ -0,0 +1,114 @@ +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')); + $this->validateUrl($certUrl); + + // 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(); + } + } + + private function validateUrl(Url $url) + { + // The host must match the following pattern + $hostPattern = '/^sns\.[a-zA-Z0-9\-]{3,}\.amazonaws\.com(\.cn)?$/'; + + if ($url->getScheme() !== 'https' || + substr($url, -4) !== '.pem' || + !preg_match($hostPattern, $url->getHost()) + ) { + throw new CertificateFromUnrecognizedSourceException(); + } + } + + /** + * 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; + } + } +} diff --git a/vendor/aws/Aws/Sns/Resources/sns-2010-03-31.php b/vendor/aws/Aws/Sns/Resources/sns-2010-03-31.php new file mode 100644 index 0000000..d781bd4 --- /dev/null +++ b/vendor/aws/Aws/Sns/Resources/sns-2010-03-31.php @@ -0,0 +1,1740 @@ + '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', + ), + 'MessageAttributes' => array( + 'type' => 'object', + 'location' => 'aws.query', + 'sentAs' => 'MessageAttributes.entry', + 'data' => array( + 'keyName' => 'Name', + 'valueName' => 'Value', + ), + 'additionalProperties' => array( + 'type' => 'object', + 'data' => array( + 'shape_name' => 'String', + ), + 'properties' => array( + 'DataType' => array( + 'required' => true, + 'type' => 'string', + ), + 'StringValue' => array( + 'type' => 'string', + ), + 'BinaryValue' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterValueException', + ), + 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( + 'ListEndpointsByPlatformApplication' => array( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'result_key' => 'Endpoints', + ), + 'ListPlatformApplications' => array( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'result_key' => 'PlatformApplications', + ), + 'ListSubscriptions' => array( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'result_key' => 'Subscriptions', + ), + 'ListSubscriptionsByTopic' => array( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'result_key' => 'Subscriptions', + ), + 'ListTopics' => array( + 'input_token' => 'NextToken', + 'output_token' => 'NextToken', + 'result_key' => 'Topics/*/TopicArn', + ), + ), +); diff --git a/vendor/aws/Aws/Sns/SnsClient.php b/vendor/aws/Aws/Sns/SnsClient.php new file mode 100644 index 0000000..d21e6ef --- /dev/null +++ b/vendor/aws/Aws/Sns/SnsClient.php @@ -0,0 +1,85 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/sns-%s.php' + )) + ->build(); + } +} diff --git a/vendor/aws/Aws/Sqs/Enum/MessageAttribute.php b/vendor/aws/Aws/Sqs/Enum/MessageAttribute.php new file mode 100644 index 0000000..dbf0b16 --- /dev/null +++ b/vendor/aws/Aws/Sqs/Enum/MessageAttribute.php @@ -0,0 +1,31 @@ + 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)); + } + } + } + } +} diff --git a/vendor/aws/Aws/Sqs/QueueUrlListener.php b/vendor/aws/Aws/Sqs/QueueUrlListener.php new file mode 100644 index 0000000..0b1ceea --- /dev/null +++ b/vendor/aws/Aws/Sqs/QueueUrlListener.php @@ -0,0 +1,52 @@ + 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'); + } + } +} diff --git a/vendor/aws/Aws/Sqs/Resources/sqs-2012-11-05.php b/vendor/aws/Aws/Sqs/Resources/sqs-2012-11-05.php new file mode 100644 index 0000000..59b12eb --- /dev/null +++ b/vendor/aws/Aws/Sqs/Resources/sqs-2012-11-05.php @@ -0,0 +1,1370 @@ + '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', + ), + ), + ), + 'PurgeQueue' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'PurgeQueue', + ), + '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', + ), + array( + 'reason' => 'Indicates that the specified queue previously received a PurgeQueue request within the last 60 seconds, the time it can take to delete the messages in the queue.', + 'class' => 'PurgeQueueInProgressException', + ), + ), + ), + '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', + ), + ), + 'MessageAttributeNames' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'MessageAttributeName', + 'items' => array( + 'name' => 'MessageAttributeName', + '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', + ), + 'MessageAttributes' => array( + 'type' => 'object', + 'location' => 'aws.query', + 'sentAs' => 'MessageAttribute', + 'data' => array( + 'keyName' => 'Name', + 'valueName' => 'Value', + ), + 'additionalProperties' => array( + 'type' => 'object', + 'data' => array( + 'shape_name' => 'String', + ), + 'properties' => array( + 'StringValue' => array( + 'type' => 'string', + ), + 'BinaryValue' => array( + 'type' => 'string', + ), + 'StringListValues' => array( + 'type' => 'array', + 'sentAs' => 'StringListValue', + 'items' => array( + 'name' => 'StringListValue', + 'type' => 'string', + ), + ), + 'BinaryListValues' => array( + 'type' => 'array', + 'sentAs' => 'BinaryListValue', + 'items' => array( + 'name' => 'BinaryListValue', + 'type' => 'string', + ), + ), + 'DataType' => array( + 'required' => true, + 'type' => 'string', + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The message contains characters outside the allowed set.', + 'class' => 'InvalidMessageContentsException', + ), + array( + 'reason' => 'Error code 400. Unsupported operation.', + 'class' => 'UnsupportedOperationException', + ), + ), + ), + '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', + ), + 'MessageAttributes' => array( + 'type' => 'object', + 'sentAs' => 'MessageAttribute', + 'data' => array( + 'keyName' => 'Name', + 'valueName' => 'Value', + ), + 'additionalProperties' => array( + 'type' => 'object', + 'data' => array( + 'shape_name' => 'String', + ), + 'properties' => array( + 'StringValue' => array( + 'type' => 'string', + ), + 'BinaryValue' => array( + 'type' => 'string', + ), + 'StringListValues' => array( + 'type' => 'array', + 'sentAs' => 'StringListValue', + 'items' => array( + 'name' => 'StringListValue', + 'type' => 'string', + ), + ), + 'BinaryListValues' => array( + 'type' => 'array', + 'sentAs' => 'BinaryListValue', + 'items' => array( + 'name' => 'BinaryListValue', + 'type' => 'string', + ), + ), + 'DataType' => 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 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', + ), + array( + 'reason' => 'Error code 400. Unsupported operation.', + 'class' => 'UnsupportedOperationException', + ), + ), + ), + '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, + ), + 'MD5OfMessageAttributes' => array( + 'type' => 'string', + ), + 'MessageAttributes' => array( + 'type' => 'array', + 'sentAs' => 'MessageAttribute', + 'data' => array( + 'xmlFlattened' => true, + ), + 'filters' => array( + array( + 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', + 'args' => array( + '@value', + 'MessageAttribute', + 'Name', + 'Value', + ), + ), + ), + 'items' => array( + 'name' => 'MessageAttribute', + 'type' => 'object', + 'sentAs' => 'MessageAttribute', + 'additionalProperties' => true, + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'object', + 'properties' => array( + 'StringValue' => array( + 'type' => 'string', + ), + 'BinaryValue' => array( + 'type' => 'string', + ), + 'StringListValues' => array( + 'type' => 'array', + 'sentAs' => 'StringListValue', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'StringListValue', + 'type' => 'string', + 'sentAs' => 'StringListValue', + ), + ), + 'BinaryListValues' => array( + 'type' => 'array', + 'sentAs' => 'BinaryListValue', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'BinaryListValue', + 'type' => 'string', + 'sentAs' => 'BinaryListValue', + ), + ), + 'DataType' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'additionalProperties' => false, + ), + ), + ), + ), + ), + ), + 'SendMessageResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'MD5OfMessageBody' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'MD5OfMessageAttributes' => 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', + ), + 'MD5OfMessageAttributes' => 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( + 'ListQueues' => array( + 'result_key' => 'QueueUrls', + ), + ), +); diff --git a/vendor/aws/Aws/Sqs/SqsClient.php b/vendor/aws/Aws/Sqs/SqsClient.php new file mode 100644 index 0000000..11c999e --- /dev/null +++ b/vendor/aws/Aws/Sqs/SqsClient.php @@ -0,0 +1,96 @@ +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' => '', + '/' => ':', + '.' => ':', + )); + } +} diff --git a/vendor/aws/Aws/Ssm/Exception/SsmException.php b/vendor/aws/Aws/Ssm/Exception/SsmException.php new file mode 100644 index 0000000..5567161 --- /dev/null +++ b/vendor/aws/Aws/Ssm/Exception/SsmException.php @@ -0,0 +1,24 @@ + '2014-11-06', + 'endpointPrefix' => 'ssm', + 'serviceFullName' => 'Amazon Simple Systems Management Service', + 'serviceAbbreviation' => 'Amazon SSM', + 'serviceType' => 'json', + 'jsonVersion' => '1.1', + 'targetPrefix' => 'AmazonSSM.', + 'signatureVersion' => 'v4', + 'namespace' => 'Ssm', + 'operations' => array( + 'CreateAssociation' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'CreateAssociationResult', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonSSM.CreateAssociation', + ), + 'Name' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 3, + 'maxLength' => 64, + ), + 'InstanceId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 10, + 'maxLength' => 10, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified association already exists.', + 'class' => 'AssociationAlreadyExistsException', + ), + array( + 'reason' => 'You can have at most 2,000 active associations.', + 'class' => 'AssociationLimitExceededException', + ), + array( + 'reason' => 'An error occurred on the server side.', + 'class' => 'InternalServerErrorException', + ), + array( + 'reason' => 'The configuration document is not valid.', + 'class' => 'InvalidDocumentException', + ), + array( + 'reason' => 'You must specify the ID of a running instance.', + 'class' => 'InvalidInstanceIdException', + ), + ), + ), + 'CreateAssociationBatch' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'CreateAssociationBatchResult', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonSSM.CreateAssociationBatch', + ), + 'Entries' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'entries', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + 'minLength' => 3, + 'maxLength' => 64, + ), + 'InstanceId' => array( + 'type' => 'string', + 'minLength' => 10, + 'maxLength' => 10, + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error occurred on the server side.', + 'class' => 'InternalServerErrorException', + ), + array( + 'reason' => 'The configuration document is not valid.', + 'class' => 'InvalidDocumentException', + ), + array( + 'reason' => 'You must specify the ID of a running instance.', + 'class' => 'InvalidInstanceIdException', + ), + array( + 'reason' => 'You cannot specify an instance ID in more than one association.', + 'class' => 'DuplicateInstanceIdException', + ), + array( + 'reason' => 'You can have at most 2,000 active associations.', + 'class' => 'AssociationLimitExceededException', + ), + ), + ), + 'CreateDocument' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'CreateDocumentResult', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonSSM.CreateDocument', + ), + 'Content' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + ), + 'Name' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 3, + 'maxLength' => 64, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified configuration document already exists.', + 'class' => 'DocumentAlreadyExistsException', + ), + array( + 'reason' => 'The size limit of a configuration document is 64 KB.', + 'class' => 'MaxDocumentSizeExceededException', + ), + array( + 'reason' => 'An error occurred on the server side.', + 'class' => 'InternalServerErrorException', + ), + array( + 'reason' => 'The content for the configuration document is not valid.', + 'class' => 'InvalidDocumentContentException', + ), + array( + 'reason' => 'You can have at most 100 active configuration documents.', + 'class' => 'DocumentLimitExceededException', + ), + ), + ), + 'DeleteAssociation' => 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' => 'AmazonSSM.DeleteAssociation', + ), + 'Name' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 3, + 'maxLength' => 64, + ), + 'InstanceId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 10, + 'maxLength' => 10, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified association does not exist.', + 'class' => 'AssociationDoesNotExistException', + ), + array( + 'reason' => 'An error occurred on the server side.', + 'class' => 'InternalServerErrorException', + ), + array( + 'reason' => 'The configuration document is not valid.', + 'class' => 'InvalidDocumentException', + ), + array( + 'reason' => 'You must specify the ID of a running instance.', + 'class' => 'InvalidInstanceIdException', + ), + array( + 'reason' => 'There are concurrent updates for a resource that supports one update at a time.', + 'class' => 'TooManyUpdatesException', + ), + ), + ), + 'DeleteDocument' => 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' => 'AmazonSSM.DeleteDocument', + ), + 'Name' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 3, + 'maxLength' => 64, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error occurred on the server side.', + 'class' => 'InternalServerErrorException', + ), + array( + 'reason' => 'The configuration document is not valid.', + 'class' => 'InvalidDocumentException', + ), + array( + 'reason' => 'You must disassociate a configuration document from all instances before you can delete it.', + 'class' => 'AssociatedInstancesException', + ), + ), + ), + 'DescribeAssociation' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeAssociationResult', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonSSM.DescribeAssociation', + ), + 'Name' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 3, + 'maxLength' => 64, + ), + 'InstanceId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 10, + 'maxLength' => 10, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified association does not exist.', + 'class' => 'AssociationDoesNotExistException', + ), + array( + 'reason' => 'An error occurred on the server side.', + 'class' => 'InternalServerErrorException', + ), + array( + 'reason' => 'The configuration document is not valid.', + 'class' => 'InvalidDocumentException', + ), + array( + 'reason' => 'You must specify the ID of a running instance.', + 'class' => 'InvalidInstanceIdException', + ), + ), + ), + 'DescribeDocument' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeDocumentResult', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonSSM.DescribeDocument', + ), + 'Name' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 3, + 'maxLength' => 64, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error occurred on the server side.', + 'class' => 'InternalServerErrorException', + ), + array( + 'reason' => 'The configuration document is not valid.', + 'class' => 'InvalidDocumentException', + ), + ), + ), + 'GetDocument' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GetDocumentResult', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonSSM.GetDocument', + ), + 'Name' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 3, + 'maxLength' => 64, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error occurred on the server side.', + 'class' => 'InternalServerErrorException', + ), + array( + 'reason' => 'The configuration document is not valid.', + 'class' => 'InvalidDocumentException', + ), + ), + ), + 'ListAssociations' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListAssociationsResult', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonSSM.ListAssociations', + ), + 'AssociationFilterList' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'minItems' => 1, + 'items' => array( + 'name' => 'AssociationFilter', + 'type' => 'object', + 'properties' => array( + 'key' => array( + 'required' => true, + 'type' => 'string', + ), + 'value' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + ), + ), + ), + ), + 'MaxResults' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 25, + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error occurred on the server side.', + 'class' => 'InternalServerErrorException', + ), + array( + 'reason' => 'The specified token is not valid.', + 'class' => 'InvalidNextTokenException', + ), + ), + ), + 'ListDocuments' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListDocumentsResult', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonSSM.ListDocuments', + ), + 'DocumentFilterList' => array( + 'type' => 'array', + 'location' => 'json', + 'minItems' => 1, + 'items' => array( + 'name' => 'DocumentFilter', + 'type' => 'object', + 'properties' => array( + 'key' => array( + 'required' => true, + 'type' => 'string', + ), + 'value' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + ), + ), + ), + ), + 'MaxResults' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 25, + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error occurred on the server side.', + 'class' => 'InternalServerErrorException', + ), + array( + 'reason' => 'The specified token is not valid.', + 'class' => 'InvalidNextTokenException', + ), + ), + ), + 'UpdateAssociationStatus' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'UpdateAssociationStatusResult', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AmazonSSM.UpdateAssociationStatus', + ), + 'Name' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 3, + 'maxLength' => 64, + ), + 'InstanceId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 10, + 'maxLength' => 10, + ), + 'AssociationStatus' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Date' => array( + 'required' => true, + 'type' => array( + 'object', + 'string', + 'integer', + ), + 'format' => 'date-time', + ), + 'Name' => array( + 'required' => true, + 'type' => 'string', + ), + 'Message' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 1024, + ), + 'AdditionalInfo' => array( + 'type' => 'string', + 'maxLength' => 1024, + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error occurred on the server side.', + 'class' => 'InternalServerErrorException', + ), + array( + 'reason' => 'You must specify the ID of a running instance.', + 'class' => 'InvalidInstanceIdException', + ), + array( + 'reason' => 'The configuration document is not valid.', + 'class' => 'InvalidDocumentException', + ), + array( + 'reason' => 'The specified association does not exist.', + 'class' => 'AssociationDoesNotExistException', + ), + array( + 'reason' => 'The updated status is the same as the current status.', + 'class' => 'StatusUnchangedException', + ), + array( + 'reason' => 'There are concurrent updates for a resource that supports one update at a time.', + 'class' => 'TooManyUpdatesException', + ), + ), + ), + ), + 'models' => array( + 'CreateAssociationResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'AssociationDescription' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + 'InstanceId' => array( + 'type' => 'string', + ), + 'Date' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'object', + 'properties' => array( + 'Date' => array( + 'type' => 'string', + ), + 'Name' => array( + 'type' => 'string', + ), + 'Message' => array( + 'type' => 'string', + ), + 'AdditionalInfo' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'CreateAssociationBatchResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Successful' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'AssociationDescription', + 'type' => 'object', + 'sentAs' => 'AssociationDescription', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + 'InstanceId' => array( + 'type' => 'string', + ), + 'Date' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'object', + 'properties' => array( + 'Date' => array( + 'type' => 'string', + ), + 'Name' => array( + 'type' => 'string', + ), + 'Message' => array( + 'type' => 'string', + ), + 'AdditionalInfo' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'Failed' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'FailedCreateAssociationEntry', + 'type' => 'object', + 'sentAs' => 'FailedCreateAssociationEntry', + 'properties' => array( + 'Entry' => array( + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + 'InstanceId' => array( + 'type' => 'string', + ), + ), + ), + 'Message' => array( + 'type' => 'string', + ), + 'Fault' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'CreateDocumentResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'DocumentDescription' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Sha1' => array( + 'type' => 'string', + ), + 'Name' => array( + 'type' => 'string', + ), + 'CreatedDate' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'EmptyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + ), + 'DescribeAssociationResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'AssociationDescription' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + 'InstanceId' => array( + 'type' => 'string', + ), + 'Date' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'object', + 'properties' => array( + 'Date' => array( + 'type' => 'string', + ), + 'Name' => array( + 'type' => 'string', + ), + 'Message' => array( + 'type' => 'string', + ), + 'AdditionalInfo' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'DescribeDocumentResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Document' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Sha1' => array( + 'type' => 'string', + ), + 'Name' => array( + 'type' => 'string', + ), + 'CreatedDate' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'GetDocumentResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Name' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Content' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListAssociationsResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Associations' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Association', + 'type' => 'object', + 'sentAs' => 'Association', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + 'InstanceId' => array( + 'type' => 'string', + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListDocumentsResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'DocumentIdentifiers' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'DocumentIdentifier', + 'type' => 'object', + 'sentAs' => 'DocumentIdentifier', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'UpdateAssociationStatusResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'AssociationDescription' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + 'InstanceId' => array( + 'type' => 'string', + ), + 'Date' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'object', + 'properties' => array( + 'Date' => array( + 'type' => 'string', + ), + 'Name' => array( + 'type' => 'string', + ), + 'Message' => array( + 'type' => 'string', + ), + 'AdditionalInfo' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), +); diff --git a/vendor/aws/Aws/Ssm/SsmClient.php b/vendor/aws/Aws/Ssm/SsmClient.php new file mode 100644 index 0000000..7661810 --- /dev/null +++ b/vendor/aws/Aws/Ssm/SsmClient.php @@ -0,0 +1,69 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/ssm-%s.php' + )) + ->setExceptionParser(new JsonQueryExceptionParser()) + ->build(); + } +} diff --git a/vendor/aws/Aws/StorageGateway/Enum/BandwidthType.php b/vendor/aws/Aws/StorageGateway/Enum/BandwidthType.php new file mode 100644 index 0000000..485bfda --- /dev/null +++ b/vendor/aws/Aws/StorageGateway/Enum/BandwidthType.php @@ -0,0 +1,29 @@ + '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', + ), + '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', + ), + ), + ), + 'ResetCache' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ResetCacheOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + '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.ResetCache', + ), + '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', + ), + ), + ), + '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', + ), + ), + ), + 'UpdateVTLDeviceType' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'UpdateVTLDeviceTypeOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + '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.UpdateVTLDeviceType', + ), + 'VTLDeviceARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + 'DeviceType' => array( + 'required' => true, + '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', + ), + ), + ), + ), + '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', + ), + 'DiskStatus' => 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', + ), + ), + ), + ), + ), + ), + 'ResetCacheOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'GatewayARN' => 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', + ), + ), + ), + 'UpdateVTLDeviceTypeOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'VTLDeviceARN' => array( + 'type' => 'string', + ), + ), + ), + ), + 'iterators' => array( + 'DescribeCachediSCSIVolumes' => array( + 'result_key' => 'CachediSCSIVolumes', + ), + 'DescribeStorediSCSIVolumes' => array( + 'result_key' => 'StorediSCSIVolumes', + ), + 'DescribeTapeArchives' => array( + 'input_token' => 'Marker', + 'limit_key' => 'Limit', + 'output_token' => 'Marker', + 'result_key' => 'TapeArchives', + ), + 'DescribeTapeRecoveryPoints' => array( + 'input_token' => 'Marker', + 'limit_key' => 'Limit', + 'output_token' => 'Marker', + 'result_key' => 'TapeRecoveryPointInfos', + ), + 'DescribeTapes' => array( + 'input_token' => 'Marker', + 'limit_key' => 'Limit', + 'output_token' => 'Marker', + 'result_key' => 'Tapes', + ), + 'DescribeVTLDevices' => array( + 'input_token' => 'Marker', + 'limit_key' => 'Limit', + 'output_token' => 'Marker', + 'result_key' => 'VTLDevices', + ), + 'ListGateways' => array( + 'input_token' => 'Marker', + 'limit_key' => 'Limit', + 'output_token' => 'Marker', + 'result_key' => 'Gateways', + ), + 'ListLocalDisks' => array( + 'result_key' => 'Disks', + ), + 'ListVolumeRecoveryPoints' => array( + 'result_key' => 'VolumeRecoveryPointInfos', + ), + 'ListVolumes' => array( + 'input_token' => 'Marker', + 'limit_key' => 'Limit', + 'output_token' => 'Marker', + 'result_key' => 'VolumeInfos', + ), + ), +); diff --git a/vendor/aws/Aws/StorageGateway/StorageGatewayClient.php b/vendor/aws/Aws/StorageGateway/StorageGatewayClient.php new file mode 100644 index 0000000..01e7fd5 --- /dev/null +++ b/vendor/aws/Aws/StorageGateway/StorageGatewayClient.php @@ -0,0 +1,116 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/storagegateway-%s.php' + )) + ->setExceptionParser(new JsonQueryExceptionParser()) + ->build(); + } +} diff --git a/vendor/aws/Aws/Sts/Exception/ExpiredTokenException.php b/vendor/aws/Aws/Sts/Exception/ExpiredTokenException.php new file mode 100644 index 0000000..50a5d99 --- /dev/null +++ b/vendor/aws/Aws/Sts/Exception/ExpiredTokenException.php @@ -0,0 +1,22 @@ + '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, + ), + 'SerialNumber' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 9, + 'maxLength' => 256, + ), + 'TokenCode' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 6, + 'maxLength' => 6, + ), + ), + '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', + ), + 'Subject' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'SubjectType' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'Issuer' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'Audience' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'NameQualifier' => array( + 'type' => 'string', + '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', + ), + 'Provider' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'Audience' => array( + 'type' => 'string', + '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', + ), + ), + ), + ), + ), + ), +); diff --git a/vendor/aws/Aws/Sts/StsClient.php b/vendor/aws/Aws/Sts/StsClient.php new file mode 100644 index 0000000..c23b6d2 --- /dev/null +++ b/vendor/aws/Aws/Sts/StsClient.php @@ -0,0 +1,115 @@ +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' + || $command->getName() === 'AssumeRoleWithSAML' + ) { + /** @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') + ); + } +} diff --git a/vendor/aws/Aws/Support/Exception/CaseCreationLimitExceededException.php b/vendor/aws/Aws/Support/Exception/CaseCreationLimitExceededException.php new file mode 100644 index 0000000..9eaa3c6 --- /dev/null +++ b/vendor/aws/Aws/Support/Exception/CaseCreationLimitExceededException.php @@ -0,0 +1,22 @@ + '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( + 'AddAttachmentsToSet' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'AddAttachmentsToSetResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + '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.AddAttachmentsToSet', + ), + 'attachmentSetId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'attachments' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Attachment', + 'type' => 'object', + 'properties' => array( + 'fileName' => array( + 'type' => 'string', + ), + 'data' => array( + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An internal server error occurred.', + 'class' => 'InternalServerErrorException', + ), + array( + 'reason' => 'An attachment set with the specified ID could not be found.', + 'class' => 'AttachmentSetIdNotFoundException', + ), + array( + 'reason' => 'The expiration time of the attachment set has passed. The set expires 1 hour after it is created.', + 'class' => 'AttachmentSetExpiredException', + ), + array( + 'reason' => 'A limit for the size of an attachment set has been exceeded. The limits are 3 attachments and 5 MB per attachment.', + 'class' => 'AttachmentSetSizeLimitExceededException', + ), + array( + 'reason' => 'The limit for the number of attachment sets created in a short period of time has been exceeded.', + 'class' => 'AttachmentLimitExceededException', + ), + ), + ), + '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', + ), + ), + 'attachmentSetId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An internal server error occurred.', + 'class' => 'InternalServerErrorException', + ), + array( + 'reason' => 'The requested CaseId could not be located.', + 'class' => 'CaseIdNotFoundException', + ), + array( + 'reason' => 'An attachment set with the specified ID could not be found.', + 'class' => 'AttachmentSetIdNotFoundException', + ), + array( + 'reason' => 'The expiration time of the attachment set has passed. The set expires 1 hour after it is created.', + 'class' => 'AttachmentSetExpiredException', + ), + ), + ), + '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', + ), + 'attachmentSetId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An internal server error occurred.', + 'class' => 'InternalServerErrorException', + ), + array( + 'reason' => 'The case creation limit for the account has been exceeded.', + 'class' => 'CaseCreationLimitExceededException', + ), + array( + 'reason' => 'An attachment set with the specified ID could not be found.', + 'class' => 'AttachmentSetIdNotFoundException', + ), + array( + 'reason' => 'The expiration time of the attachment set has passed. The set expires 1 hour after it is created.', + 'class' => 'AttachmentSetExpiredException', + ), + ), + ), + 'DescribeAttachment' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeAttachmentResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + '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.DescribeAttachment', + ), + 'attachmentId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An internal server error occurred.', + 'class' => 'InternalServerErrorException', + ), + array( + 'reason' => 'The limit for the number of DescribeAttachment requests in a short period of time has been exceeded.', + 'class' => 'DescribeAttachmentLimitExceededException', + ), + array( + 'reason' => 'An attachment with the specified ID could not be found.', + 'class' => 'AttachmentIdNotFoundException', + ), + ), + ), + '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', + ), + 'includeCommunications' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An internal server error occurred.', + 'class' => 'InternalServerErrorException', + ), + array( + 'reason' => 'The requested CaseId 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' => 'An internal server error occurred.', + 'class' => 'InternalServerErrorException', + ), + array( + 'reason' => 'The requested CaseId 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' => 'An internal server error occurred.', + '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' => 'An internal server error occurred.', + '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' => 'An internal server error occurred.', + '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' => 'An internal server error occurred.', + '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' => 'An internal server error occurred.', + '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' => 'An internal server error occurred.', + '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' => 'An internal server error occurred.', + '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' => 'An internal server error occurred.', + 'class' => 'InternalServerErrorException', + ), + array( + 'reason' => 'The requested CaseId could not be located.', + 'class' => 'CaseIdNotFoundException', + ), + ), + ), + ), + 'models' => array( + 'AddAttachmentsToSetResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'attachmentSetId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'expiryTime' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + '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', + ), + ), + ), + 'DescribeAttachmentResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'attachment' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'fileName' => array( + 'type' => 'string', + ), + 'data' => array( + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + ), + ), + ), + ), + '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', + ), + 'attachmentSet' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AttachmentDetails', + 'type' => 'object', + 'properties' => array( + 'attachmentId' => array( + 'type' => 'string', + ), + 'fileName' => 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', + ), + 'attachmentSet' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AttachmentDetails', + 'type' => 'object', + 'properties' => array( + 'attachmentId' => array( + 'type' => 'string', + ), + 'fileName' => 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( + 'DescribeCases' => array( + 'input_token' => 'nextToken', + 'output_token' => 'nextToken', + 'limit_key' => 'maxResults', + 'result_key' => 'cases', + ), + 'DescribeCommunications' => array( + 'input_token' => 'nextToken', + 'output_token' => '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', + ), + ), +); diff --git a/vendor/aws/Aws/Support/SupportClient.php b/vendor/aws/Aws/Support/SupportClient.php new file mode 100644 index 0000000..18b4a0b --- /dev/null +++ b/vendor/aws/Aws/Support/SupportClient.php @@ -0,0 +1,78 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/support-%s.php' + )) + ->setExceptionParser(new JsonQueryExceptionParser()) + ->build(); + } +} diff --git a/vendor/aws/Aws/Swf/Enum/ActivityTaskTimeoutType.php b/vendor/aws/Aws/Swf/Enum/ActivityTaskTimeoutType.php new file mode 100644 index 0000000..c3a591f --- /dev/null +++ b/vendor/aws/Aws/Swf/Enum/ActivityTaskTimeoutType.php @@ -0,0 +1,30 @@ + '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', + ), + ), + ), + ), + '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', + ), + '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', + ), + ), + ), + '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', + ), + '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', + ), + '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, + ), + ), + ), + 'defaultTaskPriority' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 11, + ), + '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, + ), + ), + ), + 'defaultTaskPriority' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 11, + ), + 'defaultChildPolicy' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + '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', + ), + '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, + ), + ), + ), + 'taskPriority' => array( + 'type' => 'string', + 'maxLength' => 11, + ), + '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, + ), + ), + ), + 'taskPriority' => array( + 'type' => 'string', + 'maxLength' => 11, + ), + 'taskStartToCloseTimeout' => array( + 'type' => 'string', + 'maxLength' => 8, + ), + 'childPolicy' => array( + 'type' => 'string', + ), + '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, + ), + ), + ), + 'taskPriority' => array( + 'type' => 'string', + 'maxLength' => 11, + ), + 'taskStartToCloseTimeout' => array( + 'type' => 'string', + 'maxLength' => 8, + ), + 'childPolicy' => array( + 'type' => 'string', + ), + '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, + ), + ), + ), + 'taskPriority' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 11, + ), + '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', + ), + ), + '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', + ), + ), + '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', + ), + ), + ), + 'defaultTaskPriority' => 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', + ), + ), + ), + 'taskPriority' => 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', + ), + ), + ), + 'defaultTaskPriority' => 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', + ), + ), + 'taskPriority' => array( + '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', + ), + ), + ), + 'taskPriority' => 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', + ), + ), + ), + 'taskPriority' => 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', + ), + ), + ), + 'taskPriority' => 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', + ), + ), + ), + 'taskPriority' => 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', + ), + ), + 'taskPriority' => array( + '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', + ), + ), + ), + 'taskPriority' => 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', + ), + ), + ), + 'taskPriority' => 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', + ), + ), + ), + 'taskPriority' => 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', + ), + ), + ), + 'taskPriority' => 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( + 'GetWorkflowExecutionHistory' => array( + 'limit_key' => 'maximumPageSize', + 'input_token' => 'nextPageToken', + 'output_token' => 'nextPageToken', + 'result_key' => 'events', + ), + 'ListActivityTypes' => array( + 'limit_key' => 'maximumPageSize', + 'input_token' => 'nextPageToken', + 'output_token' => 'nextPageToken', + 'result_key' => 'typeInfos', + ), + 'ListClosedWorkflowExecutions' => array( + 'limit_key' => 'maximumPageSize', + 'input_token' => 'nextPageToken', + 'output_token' => 'nextPageToken', + 'result_key' => 'executionInfos', + ), + 'ListDomains' => array( + 'limit_key' => 'maximumPageSize', + 'input_token' => 'nextPageToken', + 'output_token' => 'nextPageToken', + 'result_key' => 'domainInfos', + ), + 'ListOpenWorkflowExecutions' => array( + 'limit_key' => 'maximumPageSize', + 'input_token' => 'nextPageToken', + 'output_token' => 'nextPageToken', + 'result_key' => 'executionInfos', + ), + 'ListWorkflowTypes' => array( + 'limit_key' => 'maximumPageSize', + 'input_token' => 'nextPageToken', + 'output_token' => 'nextPageToken', + 'result_key' => 'typeInfos', + ), + 'PollForDecisionTask' => array( + 'limit_key' => 'maximumPageSize', + 'input_token' => 'nextPageToken', + 'output_token' => 'nextPageToken', + 'result_key' => 'events', + ), + ), +); diff --git a/vendor/aws/Aws/Swf/SwfClient.php b/vendor/aws/Aws/Swf/SwfClient.php new file mode 100644 index 0000000..4233461 --- /dev/null +++ b/vendor/aws/Aws/Swf/SwfClient.php @@ -0,0 +1,95 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/swf-%s.php' + )) + ->setExceptionParser(new JsonQueryExceptionParser()) + ->build(); + } +} diff --git a/vendor/aws/Aws/WorkSpaces/Exception/WorkSpacesException.php b/vendor/aws/Aws/WorkSpaces/Exception/WorkSpacesException.php new file mode 100644 index 0000000..19e9a41 --- /dev/null +++ b/vendor/aws/Aws/WorkSpaces/Exception/WorkSpacesException.php @@ -0,0 +1,10 @@ + '2015-04-08', + 'endpointPrefix' => 'workspaces', + 'serviceFullName' => 'Amazon WorkSpaces', + 'serviceType' => 'json', + 'jsonVersion' => '1.1', + 'targetPrefix' => 'WorkspacesService.', + 'signatureVersion' => 'v4', + 'namespace' => 'WorkSpaces', + 'operations' => array( + 'CreateWorkspaces' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'CreateWorkspacesResult', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'WorkspacesService.CreateWorkspaces', + ), + 'Workspaces' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'minItems' => 1, + 'maxItems' => 25, + 'items' => array( + 'name' => 'WorkspaceRequest', + 'type' => 'object', + 'properties' => array( + 'DirectoryId' => array( + 'required' => true, + 'type' => 'string', + ), + 'UserName' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 63, + ), + 'BundleId' => array( + 'required' => true, + 'type' => 'string', + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Your resource limits have been exceeded.', + 'class' => 'ResourceLimitExceededException', + ), + ), + ), + 'DescribeWorkspaceBundles' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeWorkspaceBundlesResult', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'WorkspacesService.DescribeWorkspaceBundles', + ), + 'BundleIds' => array( + 'type' => 'array', + 'location' => 'json', + 'minItems' => 1, + 'maxItems' => 25, + 'items' => array( + 'name' => 'BundleId', + 'type' => 'string', + ), + ), + 'Owner' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 63, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'One or more parameter values are not valid.', + 'class' => 'InvalidParameterValuesException', + ), + ), + ), + 'DescribeWorkspaceDirectories' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeWorkspaceDirectoriesResult', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'WorkspacesService.DescribeWorkspaceDirectories', + ), + 'DirectoryIds' => array( + 'type' => 'array', + 'location' => 'json', + 'minItems' => 1, + 'maxItems' => 25, + 'items' => array( + 'name' => 'DirectoryId', + 'type' => 'string', + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 63, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'One or more parameter values are not valid.', + 'class' => 'InvalidParameterValuesException', + ), + ), + ), + 'DescribeWorkspaces' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeWorkspacesResult', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'WorkspacesService.DescribeWorkspaces', + ), + 'WorkspaceIds' => array( + 'type' => 'array', + 'location' => 'json', + 'minItems' => 1, + 'maxItems' => 25, + 'items' => array( + 'name' => 'WorkspaceId', + 'type' => 'string', + ), + ), + 'DirectoryId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'UserName' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 63, + ), + 'BundleId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Limit' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 25, + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 63, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'One or more parameter values are not valid.', + 'class' => 'InvalidParameterValuesException', + ), + array( + 'reason' => 'The specified resource is not available.', + 'class' => 'ResourceUnavailableException', + ), + ), + ), + 'RebootWorkspaces' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'RebootWorkspacesResult', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'WorkspacesService.RebootWorkspaces', + ), + 'RebootWorkspaceRequests' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'minItems' => 1, + 'maxItems' => 25, + 'items' => array( + 'name' => 'RebootRequest', + 'type' => 'object', + 'properties' => array( + 'WorkspaceId' => array( + 'required' => true, + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'RebuildWorkspaces' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'RebuildWorkspacesResult', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'WorkspacesService.RebuildWorkspaces', + ), + 'RebuildWorkspaceRequests' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'minItems' => 1, + 'maxItems' => 1, + 'items' => array( + 'name' => 'RebuildRequest', + 'type' => 'object', + 'properties' => array( + 'WorkspaceId' => array( + 'required' => true, + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'TerminateWorkspaces' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'TerminateWorkspacesResult', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'WorkspacesService.TerminateWorkspaces', + ), + 'TerminateWorkspaceRequests' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'minItems' => 1, + 'maxItems' => 25, + 'items' => array( + 'name' => 'TerminateRequest', + 'type' => 'object', + 'properties' => array( + 'WorkspaceId' => array( + 'required' => true, + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'models' => array( + 'CreateWorkspacesResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'FailedRequests' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'FailedCreateWorkspaceRequest', + 'type' => 'object', + 'properties' => array( + 'WorkspaceRequest' => array( + 'type' => 'object', + 'properties' => array( + 'DirectoryId' => array( + 'type' => 'string', + ), + 'UserName' => array( + 'type' => 'string', + ), + 'BundleId' => array( + 'type' => 'string', + ), + ), + ), + 'ErrorCode' => array( + 'type' => 'string', + ), + 'ErrorMessage' => array( + 'type' => 'string', + ), + ), + ), + ), + 'PendingRequests' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Workspace', + 'type' => 'object', + 'properties' => array( + 'WorkspaceId' => array( + 'type' => 'string', + ), + 'DirectoryId' => array( + 'type' => 'string', + ), + 'UserName' => array( + 'type' => 'string', + ), + 'IpAddress' => array( + 'type' => 'string', + ), + 'State' => array( + 'type' => 'string', + ), + 'BundleId' => array( + 'type' => 'string', + ), + 'SubnetId' => array( + 'type' => 'string', + ), + 'ErrorMessage' => array( + 'type' => 'string', + ), + 'ErrorCode' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'DescribeWorkspaceBundlesResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Bundles' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'WorkspaceBundle', + 'type' => 'object', + 'properties' => array( + 'BundleId' => array( + 'type' => 'string', + ), + 'Name' => array( + 'type' => 'string', + ), + 'Owner' => array( + 'type' => 'string', + ), + 'Description' => array( + 'type' => 'string', + ), + 'UserStorage' => array( + 'type' => 'object', + 'properties' => array( + 'Capacity' => array( + 'type' => 'string', + ), + ), + ), + 'ComputeType' => array( + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DescribeWorkspaceDirectoriesResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Directories' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'WorkspaceDirectory', + 'type' => 'object', + 'properties' => array( + 'DirectoryId' => array( + 'type' => 'string', + ), + 'Alias' => array( + 'type' => 'string', + ), + 'DirectoryName' => array( + 'type' => 'string', + ), + 'RegistrationCode' => array( + 'type' => 'string', + ), + 'SubnetIds' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'SubnetId', + 'type' => 'string', + ), + ), + 'DnsIpAddresses' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'IpAddress', + 'type' => 'string', + ), + ), + 'CustomerUserName' => array( + 'type' => 'string', + ), + 'IamRoleId' => array( + 'type' => 'string', + ), + 'DirectoryType' => array( + 'type' => 'string', + ), + 'WorkspaceSecurityGroupId' => array( + 'type' => 'string', + ), + 'State' => array( + 'type' => 'string', + ), + 'WorkspaceCreationProperties' => array( + 'type' => 'object', + 'properties' => array( + 'EnableWorkDocs' => array( + 'type' => 'boolean', + ), + 'EnableInternetAccess' => array( + 'type' => 'boolean', + ), + 'DefaultOu' => array( + 'type' => 'string', + ), + 'CustomSecurityGroupId' => array( + 'type' => 'string', + ), + 'UserEnabledAsLocalAdministrator' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DescribeWorkspacesResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Workspaces' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Workspace', + 'type' => 'object', + 'properties' => array( + 'WorkspaceId' => array( + 'type' => 'string', + ), + 'DirectoryId' => array( + 'type' => 'string', + ), + 'UserName' => array( + 'type' => 'string', + ), + 'IpAddress' => array( + 'type' => 'string', + ), + 'State' => array( + 'type' => 'string', + ), + 'BundleId' => array( + 'type' => 'string', + ), + 'SubnetId' => array( + 'type' => 'string', + ), + 'ErrorMessage' => array( + 'type' => 'string', + ), + 'ErrorCode' => array( + 'type' => 'string', + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'RebootWorkspacesResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'FailedRequests' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'FailedWorkspaceChangeRequest', + 'type' => 'object', + 'properties' => array( + 'WorkspaceId' => array( + 'type' => 'string', + ), + 'ErrorCode' => array( + 'type' => 'string', + ), + 'ErrorMessage' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'RebuildWorkspacesResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'FailedRequests' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'FailedWorkspaceChangeRequest', + 'type' => 'object', + 'properties' => array( + 'WorkspaceId' => array( + 'type' => 'string', + ), + 'ErrorCode' => array( + 'type' => 'string', + ), + 'ErrorMessage' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'TerminateWorkspacesResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'FailedRequests' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'FailedWorkspaceChangeRequest', + 'type' => 'object', + 'properties' => array( + 'WorkspaceId' => array( + 'type' => 'string', + ), + 'ErrorCode' => array( + 'type' => 'string', + ), + 'ErrorMessage' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), +); diff --git a/vendor/aws/Aws/WorkSpaces/WorkSpacesClient.php b/vendor/aws/Aws/WorkSpaces/WorkSpacesClient.php new file mode 100644 index 0000000..b14d3dd --- /dev/null +++ b/vendor/aws/Aws/WorkSpaces/WorkSpacesClient.php @@ -0,0 +1,51 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/workspaces-%s.php' + )) + ->setExceptionParser(new JsonQueryExceptionParser()) + ->build(); + } +} diff --git a/vendor/aws/CHANGELOG.md b/vendor/aws/CHANGELOG.md new file mode 100644 index 0000000..9f4643d --- /dev/null +++ b/vendor/aws/CHANGELOG.md @@ -0,0 +1,896 @@ +# CHANGELOG + +## 2.8.0 - 2015-04-09 + +See the [Upgrading Guide](https://github.com/aws/aws-sdk-php/blob/master/UPGRADING.md) +for details about any changes you may need to make to your code for this upgrade. + +* `Aws\MachineLearning` - Added support for the Amazon Machine Learning service. +* `Aws\WorkSpaces` - Added support for the Amazon WorkSpaces service. +* `Aws\Ecs` - Added support for the ECS service scheduler operations. +* `Aws\S3` - Added support for the `getBucketNotificationConfiguration` and + `putBucketNotificationConfiguration` operations to the `S3Client` to replace + the, now deprecated, `getBucketNotification` and `putBucketNotification` + operations. +* [BC] `Aws\Lambda` - Added support for the new AWS Lambda API, which has been + changed based on customer feedback during Lambda's preview period. +* `Aws\Common` - Deprecated "facades". They will not be present in Version 3 of + the SDK. +* `Aws\Common` - Added `getAwsErrorCode`, `getAwsErrorType` and `getAwsRequestId` + methods to the `ServiceResponseException` to be forward-compatible with + Version 3 of the SDK. + +## 2.7.27 - 2015-04-07 + +* `Aws\DataPipeline` - Added support for `DeactivatePipeline` +* `Aws\ElasticBeanstalk` - Added support for `AbortEnvironmentUpdate` + +## 2.7.26 - 2015-04-02 + +* `Aws\CodeDeploy` - Added support deployments to on-premises instances. +* `Aws\Rds` - Added support for the `DescribeCertificates` operation. +* `Aws\ElasticTranscoder` - Added support for protecting content with PlayReady + Digital Rights Management (DRM). + +## 2.7.25 - 2015-03-26 + +* `Aws\ElasticTranscoder` - Added support for job timing. +* `Aws\Iam` - Added `NamedPolicy` to `GetAccountAuthorizationDetails`. +* `Aws\OpsWorks` - Added `BlockDeviceMapping` support. + +## 2.7.24 - 2015-03-24 + +* `Aws\S3` - Added support for cross-region replication. +* `Aws\S3` - Added support for ["Requester Pays" buckets](http://docs.aws.amazon.com/AmazonS3/latest/dev/RequesterPaysBuckets.html). + +## 2.7.23 - 2015-03-19 + +* `Aws\ElasticTranscoder` - API update to support AppliedColorSpaceConversion. +* `Aws\CloudSearchDomain` - Adding 504 status code to retry list. + +## 2.7.22 - 2015-03-12 + +* `Aws\CloudFront` - Fixed #482, which affected pre-signing CloudFront URLs. +* `Aws\CloudTrail` - Added support for the `LookupEvents` operation. +* `Aws\CloudWatchLogs` - Added ordering parameters to the `DescribeLogStreams` +* `Aws\Ec2` - Added pagination parameters to the `DescribeSnapshots` operation. + operation. + +## 2.7.21 - 2015-03-04 + +* `Aws\CognitoSync` - Added support for Amazon Cognito Streams. + +## 2.7.20 - 2015-02-23 + +* `Aws\DataPipeline` - Added support for pipeline tagging via the `AddTags` and + `RemoveTags` operations. +* `Aws\Route53` - Added support for the `GetHostedZoneCount` and + `ListHostedZonesByName` operations. + +## 2.7.19 - 2015-02-20 + +* `Aws\CloudFront` - Added support for origin paths in web distributions. +* `Aws\Ecs` - Added support for specifying volumes and mount points. Also +* `Aws\ElasticTranscoder` - Added support for cross-regional resource warnings. +* `Aws\Route53Domains` - Add iterators for `ListDomains` and `ListOperations`. +* `Aws\Ssm` - Added support for the **Amazon Simple Systems Management Service + (SSM)**. +* `Aws\Sts` - Added support for regional endpoints. + switched the client to use a JSON protocol. +* Changed our CHANGELOG format. ;-) + +## 2.7.18 - 2015-02-12 + +* Added support for named and managed policies to the IAM client. +* Added support for tagging operations to the Route 53 Domains client. +* Added support for tagging operations to the ElastiCache client. +* Added support for the Scan API for secondary indexes to the DynamoDB client. +* Added forward compatibility for the `'credentials'`, `'endpoint'`, and + `'http'` configuration options. +* Made the `marshalValue()` and `unmarshalValue()` methods public in the + DynamoDB Marshaler. + +## 2.7.17 - 2015-01-27 + +* Added support for `getShippingLabel` to the AWS Import/Export client. +* Added support for online indexing to the DynamoDB client. +* Updated the AWS Lambda client. + +## 2.7.16 - 2015-01-20 + +* Added support for custom security groups to the Amazon EMR client. +* Added support for the latest APIs to the Amazon Cognito Identity client. +* Added support for ClassicLink to the Auto Scaling client. +* Added the ability to set a client's API version to "latest" for forwards + compatibility with v3. + +## 2.7.15 - 2015-01-15 + +* Added support for [HLS Content Protection](https://aws.amazon.com/releasenotes/3388917394239147) + to the Elastic Transcoder client. +* Updated client factory logic to add the `SignatureListener`, even when + `NullCredentials` have been specified. This way, you can update a client's + credentials later if you want to begin signing requests. + +## 2.7.14 - 2015-01-09 + +* Fixed a regression in the CloudSearch Domain client (#448). + +## 2.7.13 - 2015-01-08 + +* Added the Amazon EC2 Container Service client. +* Added the Amazon CloudHSM client. +* Added support for dynamic fields to the Amazon CloudSearch client. +* Added support for the ClassicLink feature to the Amazon EC2 client. +* Updated the Amazon RDS client to use the latest 2014-10-31 API. +* Updated S3 signature so retries use a new Date header on each attempt. + +## 2.7.12 - 2014-12-18 + +* Added support for task priorities to Amazon Simple Workflow Service. + +## 2.7.11 - 2014-12-17 + +* Updated Amazon EMR to the latest API version. +* Added support for for the new ResetCache API operation to AWS Storage Gateway. + +## 2.7.10 - 2014-12-12 + +* Added support for user data to Amazon Elastic Transcoder. +* Added support for data retrieval policies and audit logging to the Amazon + Glacier client. +* Corrected the AWS Security Token Service endpoint. + +## 2.7.9 - 2014-12-08 + +* The Amazon Simple Queue Service client adds support for the PurgeQueue + operation. +* You can now use AWS OpsWorks with existing EC2 instances and on-premises + servers. + +## 2.7.8 - 2014-12-04 + +* Added support for the `PutRecords` batch operation to `KinesisClient`. +* Added support for the `GetAccountAuthorizationDetails` operation to the + `IamClient`. +* Added support for the `UpdateHostedZoneComment` operation to `Route53Client`. +* Added iterators for `ListEventSources` and `ListFunctions` operations the + `LambdaClient`. + +## 2.7.7 - 2014-11-25 + +* Added a DynamoDB `Marshaler` class, that allows you to marshal JSON documents + or native PHP arrays to the format that DynamoDB requires. You can also + unmarshal item data from operation results back into JSON documents or native + PHP arrays. +* Added support for media file encryption to Amazon Elastic Transcoder. +* Removing a few superfluous `x-amz-server-side-encryption-aws-kms-key-id` from + the Amazon S3 model. +* Added support for using AWS Data Pipeline templates to create pipelines and + bind values to parameters in the pipeline. + +## 2.7.6 - 2014-11-20 + +* Added support for AWS KMS integration to the Amazon Redshift Client. +* Fixed cn-north-1 endpoint for AWS Identity and Access Management. +* Updated `S3Client::getBucketLocation` method to work cross-region regardless + of the region's signature requirements. +* Fixed an issue with the DynamoDbClient that allows it to work better with + with DynamoDB Local. + +## 2.7.5 - 2014-11-13 + +* Added support for AWS Lambda. +* Added support for event notifications to the Amazon S3 client. +* Fixed an issue with S3 pre-signed URLs when using Signature V4. + +## 2.7.4 - 2014-11-12 + +* Added support for the AWS Key Management Service (AWS KMS). +* Added support for AWS CodeDeploy. +* Added support for AWS Config. +* Added support for AWS KMS encryption to the Amazon S3 client. +* Added support for AWS KMS encryption to the Amazon EC2 client. +* Added support for Amazon CloudWatch Logs delivery to the AWS CloudTrail + client. +* Added the GetTemplateSummary operation to the AWS CloudFormation client. +* Fixed an issue with sending signature version 4 Amazon S3 requests that + contained a 0 length body. + +## 2.7.3 - 2014-11-06 + +* Added support for private DNS for Amazon Virtual Private Clouds, health check + failure reasons, and reusable delegation sets to the Amazon Route 53 client. +* Updated the CloudFront model. +* Added support for configuring push synchronization to the Cognito Sync client. +* Updated docblocks in a few S3 and Glacier classes to improve IDE experience. + +## 2.7.2 - 2014-10-23 + +* Updated AWS Identity and Access Management (IAM) to the latest version. +* Updated Amazon Cognito Identity client to the latest version. +* Added auto-renew support to the Amazon Route 53 Domains client. +* Updated Amazon EC2 to the latest version. + +## 2.7.1 - 2014-10-16 + +* Updated the Amazon RDS client to the 2014-09-01 API version. +* Added support for advanced Japanese language processing to the Amazon + CloudSearch client. + +## 2.7.0 - 2014-10-08 + +* Added document model support to the Amazon DynamoDB client, including support + for the new data types (`L`, `M`, `BOOL`, and `NULL`), nested attributes, and + expressions. +* Deprecated the `Aws\DynamoDb\Model\Attribute`, `Aws\DynamoDb\Model\Item`, + and `Aws\DynamoDb\Iterator\ItemIterator` classes, and the + `Aws\DynamoDb\DynamoDbClient::formatValue` and + `Aws\DynamoDb\DynamoDbClient::formatAttribute` methods, since they do not + support the new types in the DynamoDB document model. These deprecated classes + and methods still work reliably with `S`, `N`, `B`, `SS`, `NS`, and `BS` + attributes. +* Updated the Amazon DynamoDB client to permanently disable client-side + parameter validation. This needed to be done in order to support the new + document model features. +* Updated the Amazon EC2 client to sign requests with Signature V4. +* Fixed an issue in the S3 service description to make the `VersionId` + work in `S3Client::restoreObject`. + +## 2.6.16 - 2014-09-11 + +* Added support for tagging to the Amazon Kinesis client. +* Added support for setting environment variables to the AWS OpsWorks client. +* Fixed issue #334 to allow the `before_upload` callback to work in the + `S3Client::upload` method. +* Fixed an issue in the Signature V4 signer that was causing an issue with some + CloudSearch Domain operations. + +## 2.6.15 - 2014-08-14 + +* Added support for signing requests to the Amazon CloudSearch Domain client. +* Added support for creating anonymous clients. + +## 2.6.14 - 2014-08-11 + +* Added support for tagging to the Elastic Load Balancing client. + +## 2.6.13 - 2014-07-31 + +* Added support for configurable idle timeouts to the Elastic Load Balancing + client. +* Added support for Lifecycle Hooks, Detach Instances, and Standby to the + AutoScaling client. +* Added support for creating Amazon ElastiCache for Memcached clusters with + nodes in multiple availability zones. +* Added minor fixes to the Amazon EC2 model for ImportVolume, + DescribeNetworkInterfaceAttribute, and DeleteVpcPeeringConnection +* Added support for getGeoLocation and listGeoLocations to the + Amazon Route 53 client. +* Added support for Amazon Route 53 Domains. +* Fixed an issue with deleting nested folders in the Amazon S3 stream wrapper. +* Fixed an issue with the Amazon S3 sync abstraction to ensure that S3->S3 + communication works correctly. +* Added stricter validation to the Amazon SNS MessageValidator. + +## 2.6.12 - 2014-07-16 + +* Added support for adding attachments to support case communications to the + AWS Support API client. +* Added support for credential reports and password rotation features to the + AWS IAM client. +* Added the `ap-northeast-1`, `ap-southeast-1`, and `ap-southeast-2` regions to + the Amazon Kinesis client. +* Added a `listFilter` stream context option that can be used when using + `opendir()` and the Amazon S3 stream wrapper. This option is used to filter + out specific objects from the files yielded from the stream wrapper. +* Fixed #322 so that the download sync builder ignores objects that have a + `GLACIER` storage class. +* Fixed an issue with the S3 SSE-C logic so that HTTPS is only required when + the SSE-C parameters are provided. +* Updated the Travis configuration to include running HHVM tests. + +## 2.6.11 - 2014-07-09 + +* Added support for **Amazon Cognito Identity**. +* Added support for **Amazon Cognito Sync**. +* Added support for **Amazon CloudWatch Logs**. +* Added support for editing existing health checks and associating health checks + with tags to the Amazon Route 53 client. +* Added the ModifySubnetAttribute operation to the Amazon EC2 client. + +## 2.6.10 - 2014-07-02 + +* Added the `ap-northeast-1`, `ap-southeast-1`, and `sa-east-1` regions to the + Amazon CloudTrail client. +* Added the `eu-west-1` and `us-west-2` regions to the Amazon Kinesis client. +* Fixed an issue with the SignatureV4 implementation when used with Amazon S3. +* Fixed an issue with a test that was causing failures when run on EC2 instances + that have associated Instance Metadata credentials. + +## 2.6.9 - 2014-06-26 + +* Added support for the CloudSearchDomain client, which allows you to search and + upload documents to your CloudSearch domains. +* Added support for delivery notifications to the Amazon SES client. +* Updated the CloudFront client to support the 2014-05-31 API. +* Merged PR #316 as a better solution for issue #309. + +## 2.6.8 - 2014-06-20 + +* Added support for closed captions to the Elastic Transcoder client. +* Added support for IAM roles to the Elastic MapReduce client. +* Updated the S3 PostObject to ease customization. +* Fixed an issue in some EC2 waiters by merging PR #306. +* Fixed an issue with the DynamoDB `WriteRequestBatch` by merging PR #310. +* Fixed issue #309, where the `url_stat()` logic in the S3 Stream Wrapper was + affected by a change in PHP 5.5.13. + +## 2.6.7 - 2014-06-12 + +* Added support for Amazon S3 server-side encryption using customer-provided + encryption keys. +* Updated Amazon SNS to support message attributes. +* Updated the Amazon Redshift model to support new cluster parameters. +* Updated PHPUnit dev dependency to 4.* to work around a PHP serializing bug. + +## 2.6.6 - 2014-05-29 + +* Added support for the [Desired Partition Count scaling + option](http://aws.amazon.com/releasenotes/2440176739861815) to the + CloudSearch client. Hebrew is also now a supported language. +* Updated the STS service description to the latest version. +* [Docs] Updated some of the documentation about credential profiles. +* Fixed an issue with the regular expression in the `S3Client::isValidBucketName` + method. See #298. + +## 2.6.5 - 2014-05-22 + +* Added cross-region support for the Amazon EC2 CopySnapshot operation. +* Added AWS Relational Database (RDS) support to the AWS OpsWorks client. +* Added support for tagging environments to the AWS Elastic Beanstalk client. +* Refactored the signature version 4 implementation to be able to pre-sign + most operations. + +## 2.6.4 - 2014-05-20 + +* Added support for lifecycles on versioning enabled buckets to the Amazon S3 + client. +* Fixed an Amazon S3 sync issue which resulted in unnecessary transfers when no + `$keyPrefix` argument was utilized. +* Corrected the `CopySourceIfMatch` and `CopySourceIfNoneMatch` parameter for + Amazon S3 to not use a timestamp shape. +* Corrected the sending of Amazon S3 PutBucketVersioning requests that utilize + the `MFADelete` parameter. + +## 2.6.3 - 2014-05-14 + +* Added the ability to modify Amazon SNS topic settings to the UpdateStack + operation of the AWS CloudFormation client. +* Added support for the us-west-1, ap-southeast-2, and eu-west-1 regions to the + AWS CloudTrail client. +* Removed no longer utilized AWS CloudTrail shapes from the model. + +## 2.6.2 - 2014-05-06 + +* Added support for Amazon SQS message attributes. +* Fixed Amazon S3 multi-part uploads so that manually set ContentType values are not overwritten. +* No longer recalculating file sizes when an Amazon S3 socket timeout occurs because this was causing issues with + multi-part uploads and it is very unlikely ever the culprit of a socket timeout. +* Added better environment variable detection. + +## 2.6.1 - 2014-04-25 + +* Added support for the `~/.aws/credentials` INI file and credential profiles (via the `profile` option) as a safer + alternative to using explicit credentials with the `key` and `secret` options. +* Added support for query filters and improved conditional expressions to the Amazon DynamoDB client. +* Added support for the `ChefConfiguration` parameter to a few operations on the AWS OpsWorks Client. +* Added support for Redis cache cluster snapshots to the Amazon ElastiCache client. +* Added support for the `PlacementTenancy` parameter to the `CreateLaunchConfiguration` operation of the Auto Scaling + client. +* Added support for the new R3 instance types to the Amazon EC2 client. +* Added the `SpotInstanceRequestFulfilled` waiter to the Amazon EC2 client (see #241). +* Improved the S3 Stream Wrapper by adding support for deleting pseudo directories (#264), updating error handling + (#276), and fixing `is_link()` for non-existent keys (#268). +* Fixed #252 and updated the DynamoDB `WriteRequestBatch` abstraction to handle batches that were completely rejected + due to exceeding provisioned throughput. +* Updated the SDK to support Guzzle 3.9.x + +## 2.6.0 - 2014-03-25 + +* [BC] Updated the Amazon CloudSearch client to use the new 2013-01-01 API version (see [their release + notes](http://aws.amazon.com/releasenotes/6125075708216342)). This API version of CloudSearch is significantly + different than the previous one, and is not backwards compatible. See the + [Upgrading Guide](https://github.com/aws/aws-sdk-php/blob/master/UPGRADING.md) for more details. +* Added support for the VPC peering features to the Amazon EC2 client. +* Updated the Amazon EC2 client to use the new 2014-02-01 API version. +* Added support for [resize progress data and the Cluster Revision Number + parameter](http://aws.amazon.com/releasenotes/0485739709714318) to the Amazon Redshift client. +* Added the `ap-northeast-1`, `ap-southeast-2`, and `sa-east-1` regions to the Amazon CloudSearch client. + +## 2.5.4 - 2014-03-20 + +* Added support for [access logs](http://docs.aws.amazon.com/ElasticLoadBalancing/latest/DeveloperGuide/access-log-collection.html) + to the Elastic Load Balancing client. +* Updated the Elastic Load Balancing client to the latest API version. +* Added support for the `AWS_SECRET_ACCESS_KEY` environment variables. +* Updated the Amazon CloudFront client to use the 2014-01-31 API version. See [their release + notes](http://aws.amazon.com/releasenotes/1900016175520505). +* Updates the AWS OpsWorks client to the latest API version. +* Amazon S3 Stream Wrapper now works correctly with pseudo folder keys created by the AWS Management Console. +* Amazon S3 Stream Wrapper now implements `mkdir()` for nested folders similar to the AWS Management Console. +* Addressed an issue with Amazon S3 presigned-URLs where X-Amz-* headers were not being added to the query string. +* Addressed an issue with the Amazon S3 directory sync where paths that contained dot-segments were not properly. + resolved. Removing the dot segments consistently helps to ensure that files are uploaded to their intended. + destinations and that file key comparisons are accurately performed when determining which files to upload. + +## 2.5.3 - 2014-02-27 + +* Added support for HTTP and HTTPS string-match health checks and HTTPS health checks to the Amazon Route 53 client +* Added support for the UPSERT action for the Amazon Route 53 ChangeResourceRecordSets operation +* Added support for SerialNumber and TokenCode to the AssumeRole operation of the IAM Security Token Service (STS). +* Added support for RequestInterval and FailureThreshold to the Amazon Route53 client. +* Added support for smooth streaming to the Amazon CloudFront client. +* Added the us-west-2, eu-west-1, ap-southeast-2, and ap-northeast-1 regions to the AWS Data Pipeline client. +* Added iterators to the Amazon Kinesis client +* Updated iterator configurations for all services to match our new iterator config spec (care was taken to continue + supporting manually-specified configurations in the old format to prevent BC) +* Updated the Amazon EC2 model to include the latest updates and documentation. Removed deprecated license-related + operations (this is not considered a BC since we have confirmed that these operations are not used by customers) +* Updated the Amazon Route 53 client to use the 2013-04-01 API version +* Fixed several iterator configurations for various services to better support existing operations and parameters +* Fixed an issue with the Amazon S3 client where an exception was thrown when trying to add a default Content-MD5 + header to a request that uses a non-rewindable stream. +* Updated the Amazon S3 PostObject class to work with CNAME style buckets. + +## 2.5.2 - 2014-01-29 + +* Added support for dead letter queues to Amazon SQS +* Added support for the new M3 medium and large instance types to the Amazon EC2 client +* Added support for using the `eu-west-1` and `us-west-2` regions to the Amazon SES client +* Adding content-type guessing to the Amazon S3 stream wrapper (see #210) +* Added an event to the Amazon S3 multipart upload helpers to allow granular customization of multipart uploads during + a sync (see #209) +* Updated Signature V4 logic for Amazon S3 to throw an exception if you attempt to create a presigned URL that expires + later than a week (see #215) +* Fixed the `downloadBucket` and `uploadDirectory` methods to support relative paths and better support + Windows (see #207) +* Fixed issue #195 in the Amazon S3 multipart upload helpers to properly support additional parameters (see #211) +* [Docs] Expanded examples in the [API reference](http://docs.aws.amazon.com/aws-sdk-php/latest/index.html) by default + so they don't get overlooked +* [Docs] Moved the API reference links in the [service-specific user guide + pages](http://docs.aws.amazon.com/aws-sdk-php/guide/latest/index.html#service-specific-guides) to the bottom so + the page's content takes priority + +## 2.5.1 - 2014-01-09 + +* Added support for attaching existing Amazon EC2 instances to an Auto Scaling group to the Auto Scaling client +* Added support for creating launch configurations from existing Amazon EC2 instances to the Auto Scaling client +* Added support for describing Auto Scaling account limits to the Auto Scaling client +* Added better support for block device mappings to the Amazon AutoScaling client when creating launch configurations +* Added support for [ranged inventory retrieval](http://docs.aws.amazon.com/amazonglacier/latest/dev/api-initiate-job-post.html#api-initiate-job-post-vault-inventory-list-filtering) + to the Amazon Glacier client +* [Docs] Updated and added a lot of content in the [User Guide](http://docs.aws.amazon.com/aws-sdk-php/guide/latest/index.html) +* Fixed a bug where the `KinesisClient::getShardIterator()` method was not working properly +* Fixed an issue with Amazon SimpleDB where the 'Value' attribute was marked as required on DeleteAttribute and BatchDeleteAttributes +* Fixed an issue with the Amazon S3 stream wrapper where empty place holder keys were being marked as files instead of directories +* Added the ability to specify a custom signature implementation using a string identifier (e.g., 'v4', 'v2', etc) + +## 2.5.0 - 2013-12-20 + +* Added support for the new **China (Beijing) Region** to various services. This region is currently in limited preview. + Please see for more information +* Added support for different audio compression schemes to the Elastic Transcoder client (includes AAC-LC, HE-AAC, + and HE-AACv2) +* Added support for preset and pipeline pagination to the Elastic Transcoder client. You can now view more than the + first 50 presets and pipelines with their corresponding list operations +* Added support for [geo restriction](http://docs.aws.amazon.com/AmazonCloudFront/latest/DeveloperGuide/WorkingWithDownloadDistributions.html#georestrictions) + to the Amazon CloudFront client +* [SDK] Added Signature V4 support to the Amazon S3 and Amazon EC2 clients for the new China (Beijing) Region +* [BC] Updated the AWS CloudTrail client to use their latest API changes due to early user feedback. Some parameters in + the `CreateTrail`, `UpdateTrail`, and `GetTrailStatus` have been deprecated and will be completely unavailable as + early as February 15th, 2014. Please see [this announcement on the CloudTrail + forum](https://forums.aws.amazon.com/ann.jspa?annID=2286). We are calling this out as a breaking change now to + encourage you to update your code at this time. +* Updated the Amazon CloudFront client to use the 2013-11-11 API version +* [BC] Updated the Amazon EC2 client to use the latest API. This resulted in a small change to a parameter in the + `RequestSpotInstances` operation. See [this commit](https://github.com/aws/aws-sdk-php/commit/36ae0f68d2a6dcc3bc28222f60ecb318449c4092#diff-bad2f6eac12565bb684f2015364c22bd) + for the change +* [BC] Removed Signature V3 support (no longer needed) and refactored parts of the signature-related classes + +## 2.4.12 - 2013-12-12 + +* Added support for **Amazon Kinesis** +* Added the CloudTrail `LogRecordIterator`, `LogFileIterator`, and `LogFileReader` classes for reading log files + generated by the CloudTrail service +* Added support for resource-level permissions to the AWS OpsWorks client +* Added support for worker environment tiers to the AWS Elastic Beanstalk client +* Added support for the new I2 instance types to the Amazon EC2 client +* Added support for resource tagging to the Amazon Elastic MapReduce client +* Added support for specifying a key encoding type to the Amazon S3 client +* Added support for global secondary indexes to the Amazon DynamoDB client +* Updated the Amazon ElastiCache client to use Signature Version 4 +* Fixed an issue in the waiter factory that caused an error when getting the factory for service clients without any + existing waiters +* Fixed issue #187, where the DynamoDB Session Handler would fail to save the session if all the data is removed + +## 2.4.11 - 2013-11-26 + +* Added support for copying DB snapshots from one AWS region to another to the Amazon RDS client +* Added support for pagination of the `DescribeInstances` and `DescribeTags` operations to the Amazon EC2 client +* Added support for the new C3 instance types and the g2.2xlarge instance type to the Amazon EC2 client +* Added support for enabling *Single Root I/O Virtualization* (SR-IOV) support for the new C3 instance types to the + Amazon EC2 client +* Updated the Amazon EC2 client to use the 2013-10-15 API version +* Updated the Amazon RDS client to use the 2013-09-09 API version +* Updated the Amazon CloudWatch client to use Signature Version 4 + +## 2.4.10 - 2013-11-14 + +* Added support for **AWS CloudTrail** +* Added support for identity federation using SAML 2.0 to the AWS STS client +* Added support for configuring SAML-compliant identity providers to the AWS IAM client +* Added support for event notifications to the Amazon Redshift client +* Added support for HSM storage for encryption keys to the Amazon Redshift client +* Added support for encryption key rotation to the Amazon Redshift client +* Added support for database audit logging to the Amazon Redshift client + +## 2.4.9 - 2013-11-08 + +* Added support for [cross-zone load balancing](http://aws.amazon.com/about-aws/whats-new/2013/11/06/elastic-load-balancing-adds-cross-zone-load-balancing/) + to the Elastic Load Balancing client. +* Added support for a [new gateway configuration](http://aws.amazon.com/about-aws/whats-new/2013/11/05/aws-storage-gateway-announces-gateway-virtual-tape-library/), + Gateway-Virtual Tape Library, to the AWS Storage Gateway client. +* Added support for stack policies to the the AWS CloudFormation client. +* Fixed issue #176 where attempting to upload a direct to Amazon S3 using the `UploadBuilder` failed when using a custom + iterator that needs to be rewound. + +## 2.4.8 - 2013-10-31 + +* Updated the AWS Direct Connect client +* Updated the Amazon Elastic MapReduce client to add support for new EMR APIs, termination of specific cluster + instances, and unlimited EMR steps. + +## 2.4.7 - 2013-10-17 + +* Added support for audio transcoding features to the Amazon Elastic Transcoder client +* Added support for modifying Reserved Instances in a region to the Amazon EC2 client +* Added support for new resource management features to the AWS OpsWorks client +* Added support for additional HTTP methods to the Amazon CloudFront client +* Added support for custom error page configuration to the Amazon CloudFront client +* Added support for the public IP address association of instances in Auto Scaling group via the Auto Scaling client +* Added support for tags and filters to various operations in the Amazon RDS client +* Added the ability to easily specify event listeners on waiters +* Added support for using the `ap-southeast-2` region to the Amazon Glacier client +* Added support for using the `ap-southeast-1` and `ap-southeast-2` regions to the Amazon Redshift client +* Updated the Amazon EC2 client to use the 2013-09-11 API version +* Updated the Amazon CloudFront client to use the 2013-09-27 API version +* Updated the AWS OpsWorks client to use the 2013-07-15 API version +* Updated the Amazon CloudSearch client to use Signature Version 4 +* Fixed an issue with the Amazon S3 Client so that the top-level XML element of the `CompleteMultipartUpload` operation + is correctly sent as `CompleteMultipartUpload` +* Fixed an issue with the Amazon S3 Client so that you can now disable bucket logging using with the `PutBucketLogging` + operation +* Fixed an issue with the Amazon CloudFront so that query string parameters in pre-signed URLs are correctly URL-encoded +* Fixed an issue with the Signature Version 4 implementation where headers with multiple values were sometimes sorted + and signed incorrectly + +## 2.4.6 - 2013-09-12 + +* Added support for modifying EC2 Reserved Instances to the Amazon EC2 client +* Added support for VPC features to the AWS OpsWorks client +* Updated the DynamoDB Session Handler to implement the SessionHandlerInterface of PHP 5.4 when available +* Updated the SNS Message Validator to throw an exception, instead of an error, when the raw post data is invalid +* Fixed an issue in the S3 signature which ensures that parameters are sorted correctly for signing +* Fixed an issue in the S3 client where the Sydney region was not allowed as a `LocationConstraint` for the + `PutObject` operation + +## 2.4.5 - 2013-09-04 + +* Added support for replication groups to the Amazon ElastiCache client +* Added support for using the `us-gov-west-1` region to the AWS CloudFormation client + +## 2.4.4 - 2013-08-29 + +* Added support for assigning a public IP address to an instance at launch to the Amazon EC2 client +* Updated the Amazon EC2 client to use the 2013-07-15 API version +* Updated the Amazon SWF client to sign requests with Signature V4 +* Updated the Instance Metadata client to allow for higher and more customizable connection timeouts +* Fixed an issue with the SDK where XML map structures were not being serialized correctly in some cases +* Fixed issue #136 where a few of the new Amazon SNS mobile push operations were not working properly +* Fixed an issue where the AWS STS `AssumeRoleWithWebIdentity` operation was requiring credentials and a signature + unnecessarily +* Fixed and issue with the `S3Client::uploadDirectory` method so that true key prefixes can be used +* [Docs] Updated the API docs to include sample code for each operation that indicates the parameter structure +* [Docs] Updated the API docs to include more information in the descriptions of operations and parameters +* [Docs] Added a page about Iterators to the user guide + +## 2.4.3 - 2013-08-12 + +* Added support for mobile push notifications to the Amazon SNS client +* Added support for progress reporting on snapshot restore operations to the the Amazon Redshift client +* Updated the Amazon Elastic MapReduce client to use JSON serialization +* Updated the Amazon Elastic MapReduce client to sign requests with Signature V4 +* Updated the SDK to throw `Aws\Common\Exception\TransferException` exceptions when a network error occurs instead of a + `Guzzle\Http\Exception\CurlException`. The TransferException class, however, extends from + `Guzzle\Http\Exception\CurlException`. You can continue to catch the Guzzle `CurlException` or catch + `Aws\Common\Exception\AwsExceptionInterface` to catch any exception that can be thrown by an AWS client +* Fixed an issue with the Amazon S3 stream wrapper where trailing slashes were being added when listing directories + +## 2.4.2 - 2013-07-25 + +* Added support for cross-account snapshot access control to the Amazon Redshift client +* Added support for decoding authorization messages to the AWS STS client +* Added support for checking for required permissions via the `DryRun` parameter to the Amazon EC2 client +* Added support for custom Amazon Machine Images (AMIs) and Chef 11 to the AWS OpsWorks client +* Added an SDK compatibility test to allow users to quickly determine if their system meets the requirements of the SDK +* Updated the Amazon EC2 client to use the 2013-06-15 API version +* Fixed an unmarshalling error with the Amazon EC2 `CreateKeyPair` operation +* Fixed an unmarshalling error with the Amazon S3 `ListMultipartUploads` operation +* Fixed an issue with the Amazon S3 stream wrapper "x" fopen mode +* Fixed an issue with `Aws\S3\S3Client::downloadBucket` by removing leading slashes from the passed `$keyPrefix` argument + +## 2.4.1 - 2013-06-08 + +* Added support for setting watermarks and max framerates to the Amazon Elastic Transcoder client +* Added the `Aws\DynamoDb\Iterator\ItemIterator` class to make it easier to get items from the results of DynamoDB + operations in a simpler form +* Added support for the `cr1.8xlarge` EC2 instance type. Use `Aws\Ec2\Enum\InstanceType::CR1_8XLARGE` +* Added support for the suppression list SES mailbox simulator. Use `Aws\Ses\Enum\MailboxSimulator::SUPPRESSION_LIST` +* [SDK] Fixed an issue with data formats throughout the SDK due to a regression. Dates are now sent over the wire with + the correct format. This issue affected the Amazon EC2, Amazon ElastiCache, AWS Elastic Beanstalk, Amazon EMR, and + Amazon RDS clients +* Fixed an issue with the parameter serialization of the `ImportInstance` operation in the Amazon EC2 client +* Fixed an issue with the Amazon S3 client where the `RoutingRules.Redirect.HostName` parameter of the + `PutBucketWebsite` operation was erroneously marked as required +* Fixed an issue with the Amazon S3 client where the `DeleteObject` operation was missing parameters +* Fixed an issue with the Amazon S3 client where the `Status` parameter of the `PutBucketVersioning` operation did not + properly support the "Suspended" value +* Fixed an issue with the Amazon Glacier `UploadPartGenerator` class so that an exception is thrown if the provided body + to upload is less than 1 byte +* Added MD5 validation to Amazon SQS ReceiveMessage operations + +## 2.4.0 - 2013-06-18 + +* [BC] Updated the Amazon CloudFront client to use the new 2013-05-12 API version which includes changes in how you + configure distributions. If you are not ready to upgrade to the new API, you can configure the SDK to use the previous + version of the API by setting the `version` option to `2012-05-05` when you instantiate the client (See + [`UPGRADING.md`](https://github.com/aws/aws-sdk-php/blob/master/UPGRADING.md)) +* Added abstractions for uploading a local directory to an Amazon S3 bucket (`$s3->uploadDirectory()`) +* Added abstractions for downloading an Amazon S3 bucket to local directory (`$s3->downloadBucket()`) +* Added an easy to way to delete objects from an Amazon S3 bucket that match a regular expression or key prefix +* Added an easy to way to upload an object to Amazon S3 that automatically uses a multipart upload if the size of the + object exceeds a customizable threshold (`$s3->upload()`) +* [SDK] Added facade classes for simple, static access to clients (e.g., `S3::putObject([...])`) +* Added the `Aws\S3\S3Client::getObjectUrl` convenience method for getting the URL of an Amazon S3 object. This works + for both public and pre-signed URLs +* Added support for using the `ap-northeast-1` region to the Amazon Redshift client +* Added support for configuring custom SSL certificates to the Amazon CloudFront client via the `ViewerCertificate` + parameter +* Added support for read replica status to the Amazon RDS client +* Added "magic" access to iterators to make using iterators more convenient (e.g., `$s3->getListBucketsIterator()`) +* Added the `waitUntilDBInstanceAvailable` and `waitUntilDBInstanceDeleted` waiters to the Amazon RDS client +* Added the `createCredentials` method to the AWS STS client to make it easier to create a credentials object from the + results of an STS operation +* Updated the Amazon RDS client to use the 2013-05-15 API version +* Updated request retrying logic to automatically refresh expired credentials and retry with new ones +* Updated the Amazon CloudFront client to sign requests with Signature V4 +* Updated the Amazon SNS client to sign requests with Signature V4, which enables larger payloads +* Updated the S3 Stream Wrapper so that you can use stream resources in any S3 operation without having to manually + specify the `ContentLength` option +* Fixed issue #94 so that the `Aws\S3\BucketStyleListener` is invoked on `command.after_prepare` and presigned URLs + are generated correctly from S3 commands +* Fixed an issue so that creating presigned URLs using the Amazon S3 client now works with temporary credentials +* Fixed an issue so that the `CORSRules.AllowedHeaders` parameter is now available when configuring CORS for Amazon S3 +* Set the Guzzle dependency to ~3.7.0 + +## 2.3.4 - 2013-05-30 + +* Set the Guzzle dependency to ~3.6.0 + +## 2.3.3 - 2013-05-28 + +* Added support for web identity federation in the AWS Security Token Service (STS) API +* Fixed an issue with creating pre-signed Amazon CloudFront RTMP URLs +* Fixed issue #85 to correct the parameter serialization of NetworkInterfaces within the Amazon EC2 RequestSpotInstances + operation + +## 2.3.2 - 2013-05-15 + +* Added support for doing parallel scans to the Amazon DynamoDB client +* [OpsWorks] Added support for using Elastic Load Balancer to the AWS OpsWorks client +* Added support for using EBS-backed instances to the AWS OpsWorks client along with some other minor updates +* Added support for finer-grained error messages to the AWS Data Pipeline client and updated the service description +* Added the ability to set the `key_pair_id` and `private_key` options at the time of signing a CloudFront URL instead + of when instantiating the client +* Added a new [Zip Download](http://pear.amazonwebservices.com/get/aws.zip) for installing the SDK +* Fixed the API version for the AWS Support client to be `2013-04-15` +* Fixed issue #78 by implementing `Aws\S3\StreamWrapper::stream_cast()` for the S3 stream wrapper +* Fixed issue #79 by updating the S3 `ClearBucket` object to work with the `ListObjects` operation +* Fixed issue #80 where the `ETag` was incorrectly labeled as a header value instead of being in the XML body for + the S3 `CompleteMultipartUpload` operation response +* Fixed an issue where the `setCredentials()` method did not properly update the `SignatureListener` +* Updated the required version of Guzzle to `">=3.4.3,<4"` to support Guzzle 3.5 which provides the SDK with improved + memory management + +## 2.3.1 - 2013-04-30 + +* Added support for **AWS Support** +* Added support for using the `eu-west-1` region to the Amazon Redshift client +* Fixed an issue with the Amazon RDS client where the `DownloadDBLogFilePortion` operation was not being serialized + properly +* Fixed an issue with the Amazon S3 client where the `PutObjectCopy` alias was interfering with the `CopyObject` + operation +* Added the ability to manually set a Content-Length header when using the `PutObject` and `UploadPart` operations of + the Amazon S3 client +* Fixed an issue where the Amazon S3 class was not throwing an exception for a non-followable 301 redirect response +* Fixed an issue where `fflush()` was called during the shutdown process of the stream handler for read-only streams + +## 2.3.0 - 2013-04-18 + +* Added support for Local Secondary Indexes to the Amazon DynamoDB client +* [BC] Updated the Amazon DynamoDB client to use the new 2012-08-10 API version which includes changes in how you + specify keys. If you are not ready to upgrade to the new API, you can configure the SDK to use the previous version of + the API by setting the `version` option to `2011-12-05` when you instantiate the client (See + [`UPGRADING.md`](https://github.com/aws/aws-sdk-php/blob/master/UPGRADING.md)). +* Added an Amazon S3 stream wrapper that allows PHP native file functions to be used to interact with S3 buckets and + objects +* Added support for automatically retrying *throttled* requests with exponential backoff to all service clients +* Added a new config option (`version`) to client objects to specify the API version to use if multiple are supported +* Added a new config option (`gc_operation_delay`) to the DynamoDB Session Handler to specify a delay between requests + to the service during garbage collection in order to help regulate the consumption of throughput +* Added support for using the `us-west-2` region to the Amazon Redshift client +* [Docs] Added a way to use marked integration test code as example code in the user guide and API docs +* Updated the Amazon RDS client to sign requests with Signature V4 +* Updated the Amazon S3 client to automatically add the `Content-Type` to `PutObject` and other upload operations +* Fixed an issue where service clients with a global endpoint could have their region for signing set incorrectly if a + region other than `us-east-1` was specified. +* Fixed an issue where reused command objects appended duplicate content to the user agent string +* [SDK] Fixed an issue in a few operations (including `SQS::receiveMessage`) where the `curl.options` could not be + modified +* [Docs] Added key information to the DynamoDB service description to provide more accurate API docs for some operations +* [Docs] Added a page about Waiters to the user guide +* [Docs] Added a page about the DynamoDB Session Handler to the user guide +* [Docs] Added a page about response Models to the user guide +* Bumped the required version of Guzzle to ~3.4.1 + +## 2.2.1 - 2013-03-18 + +* Added support for viewing and downloading DB log files to the Amazon RDS client +* Added the ability to validate incoming Amazon SNS messages. See the `Aws\Sns\MessageValidator` namespace +* Added the ability to easily change the credentials that a client is configured to use via `$client->setCredentials()` +* Added the `client.region_changed` and `client.credentials_changed` events on the client that are triggered when the + `setRegion()` and `setCredentials()` methods are called, respectively +* Added support for using the `ap-southeast-2` region with the Amazon ElastiCache client +* Added support for using the `us-gov-west-1` region with the Amazon SWF client +* Updated the Amazon RDS client to use the 2013-02-12 API version +* Fixed an issue in the Amazon EC2 service description that was affecting the use of the new `ModifyVpcAttribute` and + `DescribeVpcAttribute` operations +* Added `ObjectURL` to the output of an Amazon S3 PutObject operation so that you can more easily retrieve the URL of an + object after uploading +* Added a `createPresignedUrl()` method to any command object created by the Amazon S3 client to more easily create + presigned URLs + +## 2.2.0 - 2013-03-11 + +* Added support for **Amazon Elastic MapReduce (Amazon EMR)** +* Added support for **AWS Direct Connect** +* Added support for **Amazon ElastiCache** +* Added support for **AWS Storage Gateway** +* Added support for **AWS Import/Export** +* Added support for **AWS CloudFormation** +* Added support for **Amazon CloudSearch** +* Added support for [provisioned IOPS](http://docs.aws.amazon.com/AmazonRDS/latest/UserGuide/Overview.ProvisionedIOPS.html) + to the the Amazon RDS client +* Added support for promoting [read replicas](http://docs.aws.amazon.com/AmazonRDS/latest/UserGuide/USER_ReadRepl.html) + to the Amazon RDS client +* Added support for [event notification subscriptions](http://docs.aws.amazon.com/AmazonRDS/latest/UserGuide/USER_Events.html) + to the Amazon RDS client +* Added support for enabling\disabling DNS Hostnames and DNS Resolution in Amazon VPC to the Amazon EC2 client +* Added support for enumerating account attributes to the Amazon EC2 client +* Added support for copying AMIs across regions to the Amazon EC2 client +* Added the ability to get a Waiter object from a client using the `getWaiter()` method +* [SDK] Added the ability to load credentials from environmental variables `AWS_ACCESS_KEY_ID` and `AWS_SECRET_KEY`. + This is compatible with AWS Elastic Beanstalk environment configurations +* Added support for using the us-west-1, us-west-2, eu-west-1, and ap-southeast-1 regions with Amazon CloudSearch +* Updated the Amazon RDS client to use the 2013-01-10 API version +* Updated the Amazon EC2 client to use the 2013-02-01 API version +* Added support for using SecurityToken with signature version 2 services +* Added the client User-Agent header to exception messages for easier debugging +* Added an easier way to disable operation parameter validation by setting `validation` to false when creating clients +* Added the ability to disable the exponential backoff plugin +* Added the ability to easily fetch the region name that a client is configured to use via `$client->getRegion()` +* Added end-user guides available at http://docs.aws.amazon.com/aws-sdk-php/guide/latest/ +* Fixed issue #48 where signing Amazon S3 requests with null or empty metadata resulted in a signature error +* Fixed issue #29 where Amazon S3 was intermittently closing a connection +* Updated the Amazon S3 client to parse the AcceptRanges header for HeadObject and GetObject output +* Updated the Amazon Glacier client to allow the `saveAs` parameter to be specified as an alias for `command.response_body` +* Various performance improvements throughout the SDK +* Removed endpoint providers and now placing service region information directly in service descriptions +* Removed client resolvers when creating clients in a client's factory method (this should not have any impact to end users) + +## 2.1.2 - 2013-02-18 + +* Added support for **AWS OpsWorks** + +## 2.1.1 - 2013-02-15 + +* Added support for **Amazon Redshift** +* Added support for **Amazon Simple Queue Service (Amazon SQS)** +* Added support for **Amazon Simple Notification Service (Amazon SNS)** +* Added support for **Amazon Simple Email Service (Amazon SES)** +* Added support for **Auto Scaling** +* Added support for **Amazon CloudWatch** +* Added support for **Amazon Simple Workflow Service (Amazon SWF)** +* Added support for **Amazon Relational Database Service (Amazon RDS)** +* Added support for health checks and failover in Amazon Route 53 +* Updated the Amazon Route 53 client to use the 2012-12-12 API version +* Updated `AbstractWaiter` to dispatch `waiter.before_attempt` and `waiter.before_wait` events +* Updated `CallableWaiter` to allow for an array of context data to be passed to the callable +* Fixed issue #29 so that the stat cache is cleared before performing multipart uploads +* Fixed issue #38 so that Amazon CloudFront URLs are signed properly +* Fixed an issue with Amazon S3 website redirects +* Fixed a URL encoding inconsistency with Amazon S3 and pre-signed URLs +* Fixed issue #42 to eliminate cURL error 65 for JSON services +* Set Guzzle dependency to [~3.2.0](https://github.com/guzzle/guzzle/blob/master/CHANGELOG.md#320-2013-02-14) +* Minimum version of PHP is now 5.3.3 + +## 2.1.0 - 2013-01-28 + +* Waiters now require an associative array as input for the underlying operation performed by a waiter. See + `UPGRADING.md` for details. +* Added support for **Amazon Elastic Compute Cloud (Amazon EC2)** +* Added support for **Amazon Elastic Transcoder** +* Added support for **Amazon SimpleDB** +* Added support for **Elastic Load Balancing** +* Added support for **AWS Elastic Beanstalk** +* Added support for **AWS Identity and Access Management (IAM)** +* Added support for Amazon S3 website redirection rules +* Added support for the `RetrieveByteRange` parameter of the `InitiateJob` operation in Amazon Glacier +* Added support for Signature Version 2 +* Clients now gain more information from service descriptions rather than client factory methods +* Service descriptions are now versioned for clients +* Fixed an issue where Amazon S3 did not use "restore" as a signable resource +* Fixed an issue with Amazon S3 where `x-amz-meta-*` headers were not properly added with the CopyObject operation +* Fixed an issue where the Amazon Glacier client was not using the correct User-Agent header +* Fixed issue #13 in which constants defined by referencing other constants caused errors with early versions of PHP 5.3 + +## 2.0.3 - 2012-12-20 + +* Added support for **AWS Data Pipeline** +* Added support for **Amazon Route 53** +* Fixed an issue with the Amazon S3 client where object keys with slashes were causing errors +* Added a `SaveAs` parameter to the Amazon S3 `GetObject` operation to allow saving the object directly to a file +* Refactored iterators to remove code duplication and ease creation of future iterators + +## 2.0.2 - 2012-12-10 + +* Fixed an issue with the Amazon S3 client where non-DNS compatible buckets that was previously causing a signature + mismatch error +* Fixed an issue with the service description for the Amazon S3 `UploadPart` operation so that it works correctly +* Fixed an issue with the Amazon S3 service description dealing with `response-*` query parameters of `GetObject` +* Fixed an issue with the Amazon S3 client where object keys prefixed by the bucket name were being treated incorrectly +* Fixed an issue with `Aws\S3\Model\MultipartUpload\ParallelTransfer` class +* Added support for the `AssumeRole` operation for AWS STS +* Added a the `UploadBodyListener` which allows upload operations in Amazon S3 and Amazon Glacier to accept file handles + in the `Body` parameter and file paths in the `SourceFile` parameter +* Added Content-Type guessing for uploads +* Added new region endpoints, including sa-east-1 and us-gov-west-1 for Amazon DynamoDB +* Added methods to `Aws\S3\Model\MultipartUpload\UploadBuilder` class to make setting ACL and Content-Type easier + +## 2.0.1 - 2012-11-13 + +* Fixed a signature issue encountered when a request to Amazon S3 is redirected +* Added support for archiving Amazon S3 objects to Amazon Glacier +* Added CRC32 validation of Amazon DynamoDB responses +* Added ConsistentRead support to the `BatchGetItem` operation of Amazon DynamoDB +* Added new region endpoints, including Sydney + +## 2.0.0 - 2012-11-02 + +* Initial release of the AWS SDK for PHP Version 2. See for more information. +* Added support for **Amazon Simple Storage Service (Amazon S3)** +* Added support for **Amazon DynamoDB** +* Added support for **Amazon Glacier** +* Added support for **Amazon CloudFront** +* Added support for **AWS Security Token Service (AWS STS)** diff --git a/vendor/aws/Doctrine/Common/Cache/ApcCache.php b/vendor/aws/Doctrine/Common/Cache/ApcCache.php new file mode 100644 index 0000000..abd5e71 --- /dev/null +++ b/vendor/aws/Doctrine/Common/Cache/ApcCache.php @@ -0,0 +1,106 @@ +. + */ + +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 doFetchMultiple(array $keys) + { + return apc_fetch($keys); + } + + /** + * {@inheritdoc} + */ + protected function doGetStats() + { + $info = apc_cache_info('', true); + $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'], + ); + } +} diff --git a/vendor/aws/Doctrine/Common/Cache/ArrayCache.php b/vendor/aws/Doctrine/Common/Cache/ArrayCache.php new file mode 100644 index 0000000..31a0729 --- /dev/null +++ b/vendor/aws/Doctrine/Common/Cache/ArrayCache.php @@ -0,0 +1,94 @@ +. + */ + +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 $this->doContains($id) ? $this->data[$id] : false; + } + + /** + * {@inheritdoc} + */ + protected function doContains($id) + { + // isset() is required for performance optimizations, to avoid unnecessary function calls to array_key_exists. + return isset($this->data[$id]) || array_key_exists($id, $this->data); + } + + /** + * {@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; + } +} diff --git a/vendor/aws/Doctrine/Common/Cache/Cache.php b/vendor/aws/Doctrine/Common/Cache/Cache.php new file mode 100644 index 0000000..205a123 --- /dev/null +++ b/vendor/aws/Doctrine/Common/Cache/Cache.php @@ -0,0 +1,112 @@ +. + */ + +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 + * @author Kévin Dunglas + */ +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. + */ + public 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. + */ + public 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. + */ + public 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. + */ + public 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. + */ + public function getStats(); +} diff --git a/vendor/aws/Doctrine/Common/Cache/CacheProvider.php b/vendor/aws/Doctrine/Common/Cache/CacheProvider.php new file mode 100644 index 0000000..d7e9443 --- /dev/null +++ b/vendor/aws/Doctrine/Common/Cache/CacheProvider.php @@ -0,0 +1,277 @@ +. + */ + +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, FlushableCache, ClearableCache, MultiGetCache +{ + const DOCTRINE_NAMESPACE_CACHEKEY = 'DoctrineNamespaceCacheKey[%s]'; + + /** + * The namespace to prefix all cache ids with. + * + * @var string + */ + private $namespace = ''; + + /** + * The namespace version. + * + * @var integer|null + */ + 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 fetchMultiple(array $keys) + { + // note: the array_combine() is in place to keep an association between our $keys and the $namespacedKeys + $namespacedKeys = array_combine($keys, array_map(array($this, 'getNamespacedId'), $keys)); + $items = $this->doFetchMultiple($namespacedKeys); + $foundItems = array(); + + // no internal array function supports this sort of mapping: needs to be iterative + // this filters and combines keys in one pass + foreach ($namespacedKeys as $requestedKey => $namespacedKey) { + if (isset($items[$namespacedKey])) { + $foundItems[$requestedKey] = $items[$namespacedKey]; + } + } + + return $foundItems; + } + + /** + * {@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(); + } + + /** + * {@inheritDoc} + */ + public function flushAll() + { + return $this->doFlush(); + } + + /** + * {@inheritDoc} + */ + 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 integer + */ + 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; + } + + /** + * Default implementation of doFetchMultiple. Each driver that supports multi-get should owerwrite it. + * + * @param array $keys Array of keys to retrieve from cache + * @return array Array of values retrieved for the given keys. + */ + protected function doFetchMultiple(array $keys) + { + $returnValues = array(); + + foreach ($keys as $index => $key) { + if (false !== ($item = $this->doFetch($key))) { + $returnValues[$key] = $item; + } + } + + return $returnValues; + } + + /** + * Fetches an entry from the cache. + * + * @param string $id The id of the cache entry to fetch. + * + * @return string|boolean 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(); +} diff --git a/vendor/aws/Doctrine/Common/Cache/ChainCache.php b/vendor/aws/Doctrine/Common/Cache/ChainCache.php new file mode 100644 index 0000000..3b18c7b --- /dev/null +++ b/vendor/aws/Doctrine/Common/Cache/ChainCache.php @@ -0,0 +1,147 @@ +. + */ + +namespace Doctrine\Common\Cache; + +/** + * Cache provider that allows to easily chain multiple cache providers + * + * @author Michaël Gallego + */ +class ChainCache extends CacheProvider +{ + /** + * @var CacheProvider[] + */ + private $cacheProviders = array(); + + /** + * Constructor + * + * @param CacheProvider[] $cacheProviders + */ + public function __construct($cacheProviders = array()) + { + $this->cacheProviders = $cacheProviders; + } + + /** + * {@inheritDoc} + */ + public function setNamespace($namespace) + { + parent::setNamespace($namespace); + + foreach ($this->cacheProviders as $cacheProvider) { + $cacheProvider->setNamespace($namespace); + } + } + + /** + * {@inheritDoc} + */ + protected function doFetch($id) + { + foreach ($this->cacheProviders as $key => $cacheProvider) { + if ($cacheProvider->doContains($id)) { + $value = $cacheProvider->doFetch($id); + + // We populate all the previous cache layers (that are assumed to be faster) + for ($subKey = $key - 1 ; $subKey >= 0 ; $subKey--) { + $this->cacheProviders[$subKey]->doSave($id, $value); + } + + return $value; + } + } + + return false; + } + + /** + * {@inheritDoc} + */ + protected function doContains($id) + { + foreach ($this->cacheProviders as $cacheProvider) { + if ($cacheProvider->doContains($id)) { + return true; + } + } + + return false; + } + + /** + * {@inheritDoc} + */ + protected function doSave($id, $data, $lifeTime = 0) + { + $stored = true; + + foreach ($this->cacheProviders as $cacheProvider) { + $stored = $cacheProvider->doSave($id, $data, $lifeTime) && $stored; + } + + return $stored; + } + + /** + * {@inheritDoc} + */ + protected function doDelete($id) + { + $deleted = false; + + foreach ($this->cacheProviders as $cacheProvider) { + $deleted = $deleted || $cacheProvider->doDelete($id); + } + + return $deleted; + } + + /** + * {@inheritDoc} + */ + protected function doFlush() + { + $flushed = true; + + foreach ($this->cacheProviders as $cacheProvider) { + $flushed = $cacheProvider->doFlush() && $flushed; + } + + return $flushed; + } + + /** + * {@inheritDoc} + */ + protected function doGetStats() + { + // We return all the stats from all adapters + $stats = array(); + + foreach ($this->cacheProviders as $cacheProvider) { + $stats[] = $cacheProvider->doGetStats(); + } + + return $stats; + } +} diff --git a/vendor/aws/Doctrine/Common/Cache/ClearableCache.php b/vendor/aws/Doctrine/Common/Cache/ClearableCache.php new file mode 100644 index 0000000..f8b0161 --- /dev/null +++ b/vendor/aws/Doctrine/Common/Cache/ClearableCache.php @@ -0,0 +1,37 @@ +. + */ + +namespace Doctrine\Common\Cache; + +/** + * Interface for cache that can be flushed. + * + * @link www.doctrine-project.org + * @since 1.4 + * @author Adirelle + */ +interface ClearableCache +{ + /** + * Deletes all cache entries. + * + * @return boolean TRUE if the cache entries were successfully deleted, FALSE otherwise. + */ + public function deleteAll(); +} diff --git a/vendor/aws/Doctrine/Common/Cache/CouchbaseCache.php b/vendor/aws/Doctrine/Common/Cache/CouchbaseCache.php new file mode 100644 index 0000000..c21691d --- /dev/null +++ b/vendor/aws/Doctrine/Common/Cache/CouchbaseCache.php @@ -0,0 +1,121 @@ +. + */ + +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'], + ); + } +} diff --git a/vendor/aws/Doctrine/Common/Cache/FileCache.php b/vendor/aws/Doctrine/Common/Cache/FileCache.php new file mode 100644 index 0000000..243c28c --- /dev/null +++ b/vendor/aws/Doctrine/Common/Cache/FileCache.php @@ -0,0 +1,223 @@ +. + */ + +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 + */ + private $extension; + + /** + * @var string[] regular expressions for replacing disallowed characters in file name + */ + private $disallowedCharacterPatterns = array( + '/\-/', // replaced to disambiguate original `-` and `-` derived from replacements + '/[^a-zA-Z0-9\-_\[\]]/' // also excludes non-ascii chars (not supported, depending on FS) + ); + + /** + * @var string[] replacements for disallowed file characters + */ + private $replacementCharacters = array('__', '-'); + + /** + * Constructor. + * + * @param string $directory The cache directory. + * @param string $extension The cache file extension. + * + * @throws \InvalidArgumentException + */ + public function __construct($directory, $extension = '') + { + 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 = (string) $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) + { + return $this->directory + . DIRECTORY_SEPARATOR + . implode(str_split(hash('sha256', $id), 2), DIRECTORY_SEPARATOR) + . DIRECTORY_SEPARATOR + . preg_replace($this->disallowedCharacterPatterns, $this->replacementCharacters, $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 $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, + ); + } + + /** + * Create path if needed. + * + * @param string $path + * @return bool TRUE on success or if path already exists, FALSE if path cannot be created. + */ + private function createPathIfNeeded($path) + { + if ( ! is_dir($path)) { + if (false === @mkdir($path, 0777, true) && !is_dir($path)) { + return false; + } + } + + return true; + } + + /** + * Writes a string content to file in an atomic way. + * + * @param string $filename Path to the file where to write the data. + * @param string $content The content to write + * + * @return bool TRUE on success, FALSE if path cannot be created, if path is not writable or an any other error. + */ + protected function writeFile($filename, $content) + { + $filepath = pathinfo($filename, PATHINFO_DIRNAME); + + if ( ! $this->createPathIfNeeded($filepath)) { + return false; + } + + if ( ! is_writable($filepath)) { + return false; + } + + $tmpFile = tempnam($filepath, 'swap'); + + if (file_put_contents($tmpFile, $content) !== false) { + if (@rename($tmpFile, $filename)) { + @chmod($filename, 0666 & ~umask()); + + return true; + } + + @unlink($tmpFile); + } + + return false; + } + + /** + * @return \Iterator + */ + private function getIterator() + { + return new \RegexIterator( + new \RecursiveIteratorIterator(new \RecursiveDirectoryIterator($this->directory)), + '/^.+' . preg_quote($this->extension, '/') . '$/i' + ); + } +} diff --git a/vendor/aws/Doctrine/Common/Cache/FilesystemCache.php b/vendor/aws/Doctrine/Common/Cache/FilesystemCache.php new file mode 100644 index 0000000..6b44aa0 --- /dev/null +++ b/vendor/aws/Doctrine/Common/Cache/FilesystemCache.php @@ -0,0 +1,111 @@ +. + */ + +namespace Doctrine\Common\Cache; + +/** + * Filesystem cache driver. + * + * @since 2.3 + * @author Fabio B. Silva + */ +class FilesystemCache extends FileCache +{ + const EXTENSION = '.doctrinecache.data'; + + /** + * {@inheritdoc} + */ + public function __construct($directory, $extension = self::EXTENSION) + { + parent::__construct($directory, $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); + + return $this->writeFile($filename, $lifeTime . PHP_EOL . $data); + } +} diff --git a/vendor/aws/Doctrine/Common/Cache/FlushableCache.php b/vendor/aws/Doctrine/Common/Cache/FlushableCache.php new file mode 100644 index 0000000..817cee7 --- /dev/null +++ b/vendor/aws/Doctrine/Common/Cache/FlushableCache.php @@ -0,0 +1,37 @@ +. + */ + +namespace Doctrine\Common\Cache; + +/** + * Interface for cache that can be flushed. + * + * @link www.doctrine-project.org + * @since 1.4 + * @author Adirelle + */ +interface FlushableCache +{ + /** + * Flushes all cache entries. + * + * @return boolean TRUE if the cache entries were successfully flushed, FALSE otherwise. + */ + public function flushAll(); +} diff --git a/vendor/aws/Doctrine/Common/Cache/MemcacheCache.php b/vendor/aws/Doctrine/Common/Cache/MemcacheCache.php new file mode 100644 index 0000000..f839a65 --- /dev/null +++ b/vendor/aws/Doctrine/Common/Cache/MemcacheCache.php @@ -0,0 +1,121 @@ +. + */ + +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'], + ); + } +} diff --git a/vendor/aws/Doctrine/Common/Cache/MemcachedCache.php b/vendor/aws/Doctrine/Common/Cache/MemcachedCache.php new file mode 100644 index 0000000..040c26c --- /dev/null +++ b/vendor/aws/Doctrine/Common/Cache/MemcachedCache.php @@ -0,0 +1,132 @@ +. + */ + +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 doFetchMultiple(array $keys) + { + return $this->memcached->getMulti($keys); + } + + /** + * {@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'], + ); + } +} diff --git a/vendor/aws/Doctrine/Common/Cache/MongoDBCache.php b/vendor/aws/Doctrine/Common/Cache/MongoDBCache.php new file mode 100644 index 0000000..0c7ac0a --- /dev/null +++ b/vendor/aws/Doctrine/Common/Cache/MongoDBCache.php @@ -0,0 +1,191 @@ +. + */ + +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(); + } +} diff --git a/vendor/aws/Doctrine/Common/Cache/MultiGetCache.php b/vendor/aws/Doctrine/Common/Cache/MultiGetCache.php new file mode 100644 index 0000000..df7146d --- /dev/null +++ b/vendor/aws/Doctrine/Common/Cache/MultiGetCache.php @@ -0,0 +1,39 @@ +. + */ + +namespace Doctrine\Common\Cache; + +/** + * Interface for cache drivers that allows to get many items at once. + * + * @link www.doctrine-project.org + * @since 1.4 + * @author Asmir Mustafic + */ +interface MultiGetCache +{ + /** + * Returns an associative array of values for keys is found in cache. + * + * @param string[] $keys Array of keys to retrieve from cache + * @return mixed[] Array of retrieved values, indexed by the specified keys. + * Values that couldn't be retrieved are not contained in this array. + */ + function fetchMultiple(array $keys); +} diff --git a/vendor/aws/Doctrine/Common/Cache/PhpFileCache.php b/vendor/aws/Doctrine/Common/Cache/PhpFileCache.php new file mode 100644 index 0000000..bbe766c --- /dev/null +++ b/vendor/aws/Doctrine/Common/Cache/PhpFileCache.php @@ -0,0 +1,109 @@ +. + */ + +namespace Doctrine\Common\Cache; + +/** + * Php file cache driver. + * + * @since 2.3 + * @author Fabio B. Silva + */ +class PhpFileCache extends FileCache +{ + const EXTENSION = '.doctrinecache.php'; + + /** + * {@inheritdoc} + */ + public function __construct($directory, $extension = self::EXTENSION) + { + parent::__construct($directory, $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; + } + + if ( ! is_readable($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); + + $value = array( + 'lifetime' => $lifeTime, + 'data' => $data + ); + + $value = var_export($value, true); + $code = sprintf('writeFile($filename, $code); + } +} diff --git a/vendor/aws/Doctrine/Common/Cache/PredisCache.php b/vendor/aws/Doctrine/Common/Cache/PredisCache.php new file mode 100644 index 0000000..f2401e6 --- /dev/null +++ b/vendor/aws/Doctrine/Common/Cache/PredisCache.php @@ -0,0 +1,97 @@ + + */ +class PredisCache extends CacheProvider +{ + /** + * @var Client + */ + private $client; + + /** + * @param Client $client + * + * @return void + */ + public function __construct(Client $client) + { + $this->client = $client; + } + + /** + * {@inheritdoc} + */ + protected function doFetch($id) + { + $result = $this->client->get($id); + if (null === $result) { + return false; + } + + return $result; + } + + /** + * {@inheritdoc} + */ + protected function doContains($id) + { + return $this->client->exists($id); + } + + /** + * {@inheritdoc} + */ + protected function doSave($id, $data, $lifeTime = 0) + { + if ($lifeTime > 0) { + $response = $this->client->setex($id, $lifeTime, $data); + } else { + $response = $this->client->set($id, $data); + } + + return $response === true || $response == 'OK'; + } + + /** + * {@inheritdoc} + */ + protected function doDelete($id) + { + return $this->client->del($id) > 0; + } + + /** + * {@inheritdoc} + */ + protected function doFlush() + { + $response = $this->client->flushdb(); + + return $response === true || $response == 'OK'; + } + + /** + * {@inheritdoc} + */ + protected function doGetStats() + { + $info = $this->client->info(); + + return array( + Cache::STATS_HITS => false, + Cache::STATS_MISSES => false, + Cache::STATS_UPTIME => $info['Server']['uptime_in_seconds'], + Cache::STATS_MEMORY_USAGE => $info['Memory']['used_memory'], + Cache::STATS_MEMORY_AVAILABLE => false + ); + } +} diff --git a/vendor/aws/Doctrine/Common/Cache/RedisCache.php b/vendor/aws/Doctrine/Common/Cache/RedisCache.php new file mode 100644 index 0000000..1643732 --- /dev/null +++ b/vendor/aws/Doctrine/Common/Cache/RedisCache.php @@ -0,0 +1,134 @@ +. + */ + +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() + { + if (defined('HHVM_VERSION')) { + return Redis::SERIALIZER_PHP; + } + return defined('Redis::SERIALIZER_IGBINARY') ? Redis::SERIALIZER_IGBINARY : Redis::SERIALIZER_PHP; + } +} diff --git a/vendor/aws/Doctrine/Common/Cache/RiakCache.php b/vendor/aws/Doctrine/Common/Cache/RiakCache.php new file mode 100644 index 0000000..8bb6b4b --- /dev/null +++ b/vendor/aws/Doctrine/Common/Cache/RiakCache.php @@ -0,0 +1,250 @@ +. + */ + +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; + } +} diff --git a/vendor/aws/Doctrine/Common/Cache/SQLite3Cache.php b/vendor/aws/Doctrine/Common/Cache/SQLite3Cache.php new file mode 100644 index 0000000..b7bdb53 --- /dev/null +++ b/vendor/aws/Doctrine/Common/Cache/SQLite3Cache.php @@ -0,0 +1,219 @@ +. + */ + +namespace Doctrine\Common\Cache; + +use SQLite3; +use SQLite3Result; + +/** + * SQLite3 cache provider. + * + * @since 1.4 + * @author Jake Bell + */ +class SQLite3Cache extends CacheProvider +{ + /** + * The ID field will store the cache key. + */ + const ID_FIELD = 'k'; + + /** + * The data field will store the serialized PHP value. + */ + const DATA_FIELD = 'd'; + + /** + * The expiration field will store a date value indicating when the + * cache entry should expire. + */ + const EXPIRATION_FIELD = 'e'; + + /** + * @var SQLite3 + */ + private $sqlite; + + /** + * @var string + */ + private $table; + + /** + * Constructor. + * + * Calling the constructor will ensure that the database file and table + * exist and will create both if they don't. + * + * @param SQLite3 $sqlite + * @param string $table + */ + public function __construct(SQLite3 $sqlite, $table) + { + $this->sqlite = $sqlite; + $this->table = (string) $table; + + list($id, $data, $exp) = $this->getFields(); + + return $this->sqlite->exec(sprintf( + 'CREATE TABLE IF NOT EXISTS %s(%s TEXT PRIMARY KEY NOT NULL, %s BLOB, %s INTEGER)', + $table, + $id, + $data, + $exp + )); + } + + /** + * {@inheritdoc} + */ + protected function doFetch($id) + { + if ($item = $this->findById($id)) { + return unserialize($item[self::DATA_FIELD]); + } + + return false; + } + + /** + * {@inheritdoc} + */ + protected function doContains($id) + { + return (boolean) $this->findById($id, false); + } + + /** + * {@inheritdoc} + */ + protected function doSave($id, $data, $lifeTime = 0) + { + $statement = $this->sqlite->prepare(sprintf( + 'INSERT OR REPLACE INTO %s (%s) VALUES (:id, :data, :expire)', + $this->table, + implode(',', $this->getFields()) + )); + + $statement->bindValue(':id', $id); + $statement->bindValue(':data', serialize($data)); + $statement->bindValue(':expire', $lifeTime > 0 ? time() + $lifeTime : null); + + return $statement->execute() instanceof SQLite3Result; + } + + /** + * {@inheritdoc} + */ + protected function doDelete($id) + { + list($idField) = $this->getFields(); + + $statement = $this->sqlite->prepare(sprintf( + 'DELETE FROM %s WHERE %s = :id', + $this->table, + $idField + )); + + $statement->bindValue(':id', $id); + + return $statement->execute() instanceof SQLite3Result; + } + + /** + * {@inheritdoc} + */ + protected function doFlush() + { + return $this->sqlite->exec(sprintf('DELETE FROM %s', $this->table)); + } + + /** + * {@inheritdoc} + */ + protected function doGetStats() + { + // no-op. + } + + /** + * Find a single row by ID. + * + * @param mixed $id + * @param boolean $includeData + * + * @return array|null + */ + private function findById($id, $includeData = true) + { + list($idField) = $fields = $this->getFields(); + + if (!$includeData) { + $key = array_search(static::DATA_FIELD, $fields); + unset($fields[$key]); + } + + $statement = $this->sqlite->prepare(sprintf( + 'SELECT %s FROM %s WHERE %s = :id LIMIT 1', + implode(',', $fields), + $this->table, + $idField + )); + + $statement->bindValue(':id', $id, SQLITE3_TEXT); + + $item = $statement->execute()->fetchArray(); + + if ($item === false) { + return null; + } + + if ($this->isExpired($item)) { + $this->doDelete($id); + + return null; + } + + return $item; + } + + /** + * Gets an array of the fields in our table. + * + * @return array + */ + private function getFields() + { + return array(static::ID_FIELD, static::DATA_FIELD, static::EXPIRATION_FIELD); + } + + /** + * Check if the item is expired. + * + * @param array $item + * @return boolean + */ + private function isExpired(array $item) + { + return isset($item[static::EXPIRATION_FIELD]) && + $item[self::EXPIRATION_FIELD] !== null && + $item[self::EXPIRATION_FIELD] < time(); + } +} diff --git a/vendor/aws/Doctrine/Common/Cache/Version.php b/vendor/aws/Doctrine/Common/Cache/Version.php new file mode 100644 index 0000000..d742fa0 --- /dev/null +++ b/vendor/aws/Doctrine/Common/Cache/Version.php @@ -0,0 +1,25 @@ +. + */ + +namespace Doctrine\Common\Cache; + +class Version +{ + const VERSION = '1.4.0-DEV'; +} diff --git a/vendor/aws/Doctrine/Common/Cache/WinCacheCache.php b/vendor/aws/Doctrine/Common/Cache/WinCacheCache.php new file mode 100644 index 0000000..ae32772 --- /dev/null +++ b/vendor/aws/Doctrine/Common/Cache/WinCacheCache.php @@ -0,0 +1,91 @@ +. + */ + +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'], + ); + } +} diff --git a/vendor/aws/Doctrine/Common/Cache/XcacheCache.php b/vendor/aws/Doctrine/Common/Cache/XcacheCache.php new file mode 100644 index 0000000..a2c4ca5 --- /dev/null +++ b/vendor/aws/Doctrine/Common/Cache/XcacheCache.php @@ -0,0 +1,112 @@ +. + */ + +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); + + 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'], + ); + } +} diff --git a/vendor/aws/Doctrine/Common/Cache/ZendDataCache.php b/vendor/aws/Doctrine/Common/Cache/ZendDataCache.php new file mode 100644 index 0000000..6e35ac8 --- /dev/null +++ b/vendor/aws/Doctrine/Common/Cache/ZendDataCache.php @@ -0,0 +1,83 @@ +. + */ + +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; + } +} diff --git a/vendor/aws/Guzzle/Batch/AbstractBatchDecorator.php b/vendor/aws/Guzzle/Batch/AbstractBatchDecorator.php new file mode 100644 index 0000000..0625d71 --- /dev/null +++ b/vendor/aws/Guzzle/Batch/AbstractBatchDecorator.php @@ -0,0 +1,66 @@ +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; + } +} diff --git a/vendor/aws/Guzzle/Batch/Batch.php b/vendor/aws/Guzzle/Batch/Batch.php new file mode 100644 index 0000000..4d41c54 --- /dev/null +++ b/vendor/aws/Guzzle/Batch/Batch.php @@ -0,0 +1,92 @@ +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; + } + } + } +} diff --git a/vendor/aws/Guzzle/Batch/BatchBuilder.php b/vendor/aws/Guzzle/Batch/BatchBuilder.php new file mode 100644 index 0000000..ea99b4d --- /dev/null +++ b/vendor/aws/Guzzle/Batch/BatchBuilder.php @@ -0,0 +1,199 @@ + '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; + } +} diff --git a/vendor/aws/Guzzle/Batch/BatchClosureDivisor.php b/vendor/aws/Guzzle/Batch/BatchClosureDivisor.php new file mode 100644 index 0000000..e0a2d95 --- /dev/null +++ b/vendor/aws/Guzzle/Batch/BatchClosureDivisor.php @@ -0,0 +1,39 @@ +callable = $callable; + $this->context = $context; + } + + public function createBatches(\SplQueue $queue) + { + return call_user_func($this->callable, $queue, $this->context); + } +} diff --git a/vendor/aws/Guzzle/Batch/BatchClosureTransfer.php b/vendor/aws/Guzzle/Batch/BatchClosureTransfer.php new file mode 100644 index 0000000..9cbf1ab --- /dev/null +++ b/vendor/aws/Guzzle/Batch/BatchClosureTransfer.php @@ -0,0 +1,40 @@ +callable = $callable; + $this->context = $context; + } + + public function transfer(array $batch) + { + return empty($batch) ? null : call_user_func($this->callable, $batch, $this->context); + } +} diff --git a/vendor/aws/Guzzle/Batch/BatchCommandTransfer.php b/vendor/aws/Guzzle/Batch/BatchCommandTransfer.php new file mode 100644 index 0000000..d55ac7d --- /dev/null +++ b/vendor/aws/Guzzle/Batch/BatchCommandTransfer.php @@ -0,0 +1,75 @@ +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); + } +} diff --git a/vendor/aws/Guzzle/Batch/BatchDivisorInterface.php b/vendor/aws/Guzzle/Batch/BatchDivisorInterface.php new file mode 100644 index 0000000..0214f05 --- /dev/null +++ b/vendor/aws/Guzzle/Batch/BatchDivisorInterface.php @@ -0,0 +1,18 @@ +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); + } + } +} diff --git a/vendor/aws/Guzzle/Batch/BatchSizeDivisor.php b/vendor/aws/Guzzle/Batch/BatchSizeDivisor.php new file mode 100644 index 0000000..67f90a5 --- /dev/null +++ b/vendor/aws/Guzzle/Batch/BatchSizeDivisor.php @@ -0,0 +1,47 @@ +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); + } +} diff --git a/vendor/aws/Guzzle/Batch/BatchTransferInterface.php b/vendor/aws/Guzzle/Batch/BatchTransferInterface.php new file mode 100644 index 0000000..2e0b60d --- /dev/null +++ b/vendor/aws/Guzzle/Batch/BatchTransferInterface.php @@ -0,0 +1,16 @@ +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; + } +} diff --git a/vendor/aws/Guzzle/Batch/ExceptionBufferingBatch.php b/vendor/aws/Guzzle/Batch/ExceptionBufferingBatch.php new file mode 100644 index 0000000..d7a8928 --- /dev/null +++ b/vendor/aws/Guzzle/Batch/ExceptionBufferingBatch.php @@ -0,0 +1,50 @@ +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(); + } +} diff --git a/vendor/aws/Guzzle/Batch/FlushingBatch.php b/vendor/aws/Guzzle/Batch/FlushingBatch.php new file mode 100644 index 0000000..367b684 --- /dev/null +++ b/vendor/aws/Guzzle/Batch/FlushingBatch.php @@ -0,0 +1,60 @@ +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; + } +} diff --git a/vendor/aws/Guzzle/Batch/HistoryBatch.php b/vendor/aws/Guzzle/Batch/HistoryBatch.php new file mode 100644 index 0000000..e345fdc --- /dev/null +++ b/vendor/aws/Guzzle/Batch/HistoryBatch.php @@ -0,0 +1,39 @@ +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(); + } +} diff --git a/vendor/aws/Guzzle/Batch/NotifyingBatch.php b/vendor/aws/Guzzle/Batch/NotifyingBatch.php new file mode 100644 index 0000000..96d04da --- /dev/null +++ b/vendor/aws/Guzzle/Batch/NotifyingBatch.php @@ -0,0 +1,38 @@ +callable = $callable; + parent::__construct($decoratedBatch); + } + + public function flush() + { + $items = $this->decoratedBatch->flush(); + call_user_func($this->callable, $items); + + return $items; + } +} diff --git a/vendor/aws/Guzzle/Cache/AbstractCacheAdapter.php b/vendor/aws/Guzzle/Cache/AbstractCacheAdapter.php new file mode 100644 index 0000000..a5c5271 --- /dev/null +++ b/vendor/aws/Guzzle/Cache/AbstractCacheAdapter.php @@ -0,0 +1,21 @@ +cache; + } +} diff --git a/vendor/aws/Guzzle/Cache/CacheAdapterFactory.php b/vendor/aws/Guzzle/Cache/CacheAdapterFactory.php new file mode 100644 index 0000000..94e6234 --- /dev/null +++ b/vendor/aws/Guzzle/Cache/CacheAdapterFactory.php @@ -0,0 +1,117 @@ +newInstanceArgs($args); + } + } catch (\Exception $e) { + throw new RuntimeException($e->getMessage(), $e->getCode(), $e); + } + } +} diff --git a/vendor/aws/Guzzle/Cache/CacheAdapterInterface.php b/vendor/aws/Guzzle/Cache/CacheAdapterInterface.php new file mode 100644 index 0000000..970c9e2 --- /dev/null +++ b/vendor/aws/Guzzle/Cache/CacheAdapterInterface.php @@ -0,0 +1,55 @@ +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); + } +} diff --git a/vendor/aws/Guzzle/Cache/DoctrineCacheAdapter.php b/vendor/aws/Guzzle/Cache/DoctrineCacheAdapter.php new file mode 100644 index 0000000..e1aaf9f --- /dev/null +++ b/vendor/aws/Guzzle/Cache/DoctrineCacheAdapter.php @@ -0,0 +1,41 @@ +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 !== false ? $lifeTime : 0); + } +} diff --git a/vendor/aws/Guzzle/Cache/NullCacheAdapter.php b/vendor/aws/Guzzle/Cache/NullCacheAdapter.php new file mode 100644 index 0000000..68bd4af --- /dev/null +++ b/vendor/aws/Guzzle/Cache/NullCacheAdapter.php @@ -0,0 +1,31 @@ +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); + } +} diff --git a/vendor/aws/Guzzle/Cache/Zf2CacheAdapter.php b/vendor/aws/Guzzle/Cache/Zf2CacheAdapter.php new file mode 100644 index 0000000..1fc18a5 --- /dev/null +++ b/vendor/aws/Guzzle/Cache/Zf2CacheAdapter.php @@ -0,0 +1,41 @@ +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); + } +} diff --git a/vendor/aws/Guzzle/Common/AbstractHasDispatcher.php b/vendor/aws/Guzzle/Common/AbstractHasDispatcher.php new file mode 100644 index 0000000..d1e842b --- /dev/null +++ b/vendor/aws/Guzzle/Common/AbstractHasDispatcher.php @@ -0,0 +1,49 @@ +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; + } +} diff --git a/vendor/aws/Guzzle/Common/Collection.php b/vendor/aws/Guzzle/Common/Collection.php new file mode 100644 index 0000000..5cb1535 --- /dev/null +++ b/vendor/aws/Guzzle/Common/Collection.php @@ -0,0 +1,403 @@ +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); + } +} diff --git a/vendor/aws/Guzzle/Common/Event.php b/vendor/aws/Guzzle/Common/Event.php new file mode 100644 index 0000000..fad76a9 --- /dev/null +++ b/vendor/aws/Guzzle/Common/Event.php @@ -0,0 +1,52 @@ +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; + } +} diff --git a/vendor/aws/Guzzle/Common/Exception/BadMethodCallException.php b/vendor/aws/Guzzle/Common/Exception/BadMethodCallException.php new file mode 100644 index 0000000..08d1c72 --- /dev/null +++ b/vendor/aws/Guzzle/Common/Exception/BadMethodCallException.php @@ -0,0 +1,5 @@ +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); + } +} diff --git a/vendor/aws/Guzzle/Common/Exception/GuzzleException.php b/vendor/aws/Guzzle/Common/Exception/GuzzleException.php new file mode 100644 index 0000000..458e6f2 --- /dev/null +++ b/vendor/aws/Guzzle/Common/Exception/GuzzleException.php @@ -0,0 +1,8 @@ +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; + } +} diff --git a/vendor/aws/Guzzle/Http/CachingEntityBody.php b/vendor/aws/Guzzle/Http/CachingEntityBody.php new file mode 100644 index 0000000..c65c136 --- /dev/null +++ b/vendor/aws/Guzzle/Http/CachingEntityBody.php @@ -0,0 +1,229 @@ +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; + } +} diff --git a/vendor/aws/Guzzle/Http/Client.php b/vendor/aws/Guzzle/Http/Client.php new file mode 100644 index 0000000..3d7298d --- /dev/null +++ b/vendor/aws/Guzzle/Http/Client.php @@ -0,0 +1,524 @@ +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 (strpos($uri, '://')) { + // 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( + self::MAX_HANDLES, + $this->getConfig('select_timeout') ?: self::DEFAULT_SELECT_TIMEOUT + ); + } + + 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; + } + + /** + * 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() + { + $authority = $this->config[self::SSL_CERT_AUTHORITY]; + + if ($authority === 'system') { + return; + } + + if ($authority === null) { + $authority = true; + } + + if ($authority === true && substr(__FILE__, 0, 7) == 'phar://') { + $authority = self::extractPharCacert(__DIR__ . '/Resources/cacert.pem'); + } + + $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; + } + + /** + * @deprecated + */ + public function preparePharCacert($md5Check = true) + { + return sys_get_temp_dir() . '/guzzle-cacert.pem'; + } + + /** + * Copies the phar cacert from a phar into the temp directory. + * + * @param string $pharCacertPath Path to the phar cacert. For example: + * 'phar://aws.phar/Guzzle/Http/Resources/cacert.pem' + * + * @return string Returns the path to the extracted cacert file. + * @throws \RuntimeException Throws if the phar cacert cannot be found or + * the file cannot be copied to the temp dir. + */ + public static function extractPharCacert($pharCacertPath) + { + // Copy the cacert.pem file from the phar if it is not in the temp + // folder. + $certFile = sys_get_temp_dir() . '/guzzle-cacert.pem'; + + if (!file_exists($pharCacertPath)) { + throw new \RuntimeException("Could not find $pharCacertPath"); + } + + if (!file_exists($certFile) || + filesize($certFile) != filesize($pharCacertPath) + ) { + if (!copy($pharCacertPath, $certFile)) { + throw new \RuntimeException( + "Could not copy {$pharCacertPath} to {$certFile}: " + . var_export(error_get_last(), true) + ); + } + } + + return $certFile; + } +} diff --git a/vendor/aws/Guzzle/Http/ClientInterface.php b/vendor/aws/Guzzle/Http/ClientInterface.php new file mode 100644 index 0000000..10e4de2 --- /dev/null +++ b/vendor/aws/Guzzle/Http/ClientInterface.php @@ -0,0 +1,223 @@ +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 (null !== $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; + } +} diff --git a/vendor/aws/Guzzle/Http/Curl/CurlMulti.php b/vendor/aws/Guzzle/Http/Curl/CurlMulti.php new file mode 100644 index 0000000..9e4e637 --- /dev/null +++ b/vendor/aws/Guzzle/Http/Curl/CurlMulti.php @@ -0,0 +1,423 @@ + 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!') + ); + + /** @var float */ + protected $selectTimeout; + + public function __construct($selectTimeout = 1.0) + { + $this->selectTimeout = $selectTimeout; + $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) { + $this->addHandle($request); + } 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); + } + } + + private function addHandle(RequestInterface $request) + { + $handle = $this->createCurlHandle($request)->getHandle(); + $this->checkCurlResult( + curl_multi_add_handle($this->multiHandle, $handle) + ); + } + + /** + * 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 = $this->selectTimeout; + } 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) { + if ($this->validateResponseWasSet($request)) { + $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); + } + } + return; + } + + // 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 + ); + } + } + + /** + * @link https://github.com/guzzle/guzzle/issues/710 + */ + private function validateResponseWasSet(RequestInterface $request) + { + if ($request->getResponse()) { + return true; + } + + $body = $request instanceof EntityEnclosingRequestInterface + ? $request->getBody() + : null; + + if (!$body) { + $rex = new RequestException( + 'No response was received for a request with no body. This' + . ' could mean that you are saturating your network.' + ); + $rex->setRequest($request); + $this->removeErroredRequest($request, $rex); + } elseif (!$body->isSeekable() || !$body->seek(0)) { + // Nothing we can do with this. Sorry! + $rex = new RequestException( + 'The connection was unexpectedly closed. The request would' + . ' have been retried, but attempting to rewind the' + . ' request body failed.' + ); + $rex->setRequest($request); + $this->removeErroredRequest($request, $rex); + } else { + $this->remove($request); + // Add the request back to the batch to retry automatically. + $this->requests[] = $request; + $this->addHandle($request); + } + + return false; + } +} diff --git a/vendor/aws/Guzzle/Http/Curl/CurlMultiInterface.php b/vendor/aws/Guzzle/Http/Curl/CurlMultiInterface.php new file mode 100644 index 0000000..0ead757 --- /dev/null +++ b/vendor/aws/Guzzle/Http/Curl/CurlMultiInterface.php @@ -0,0 +1,58 @@ +maxHandles = $maxHandles; + $this->selectTimeout = $selectTimeout; + // 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($this->selectTimeout); + $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); + } + } +} diff --git a/vendor/aws/Guzzle/Http/Curl/CurlVersion.php b/vendor/aws/Guzzle/Http/Curl/CurlVersion.php new file mode 100644 index 0000000..c3f99dd --- /dev/null +++ b/vendor/aws/Guzzle/Http/Curl/CurlVersion.php @@ -0,0 +1,66 @@ +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; + } +} diff --git a/vendor/aws/Guzzle/Http/Curl/RequestMediator.php b/vendor/aws/Guzzle/Http/Curl/RequestMediator.php new file mode 100644 index 0000000..5d1a0cd --- /dev/null +++ b/vendor/aws/Guzzle/Http/Curl/RequestMediator.php @@ -0,0 +1,147 @@ +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; + } +} diff --git a/vendor/aws/Guzzle/Http/EntityBody.php b/vendor/aws/Guzzle/Http/EntityBody.php new file mode 100644 index 0000000..b60d170 --- /dev/null +++ b/vendor/aws/Guzzle/Http/EntityBody.php @@ -0,0 +1,201 @@ +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; + } +} diff --git a/vendor/aws/Guzzle/Http/EntityBodyInterface.php b/vendor/aws/Guzzle/Http/EntityBodyInterface.php new file mode 100644 index 0000000..e640f57 --- /dev/null +++ b/vendor/aws/Guzzle/Http/EntityBodyInterface.php @@ -0,0 +1,73 @@ +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; + } +} diff --git a/vendor/aws/Guzzle/Http/Exception/ClientErrorResponseException.php b/vendor/aws/Guzzle/Http/Exception/ClientErrorResponseException.php new file mode 100644 index 0000000..04d7ddc --- /dev/null +++ b/vendor/aws/Guzzle/Http/Exception/ClientErrorResponseException.php @@ -0,0 +1,8 @@ +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; + } +} diff --git a/vendor/aws/Guzzle/Http/Exception/HttpException.php b/vendor/aws/Guzzle/Http/Exception/HttpException.php new file mode 100644 index 0000000..ee87295 --- /dev/null +++ b/vendor/aws/Guzzle/Http/Exception/HttpException.php @@ -0,0 +1,10 @@ +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); + } +} diff --git a/vendor/aws/Guzzle/Http/Exception/RequestException.php b/vendor/aws/Guzzle/Http/Exception/RequestException.php new file mode 100644 index 0000000..274df2c --- /dev/null +++ b/vendor/aws/Guzzle/Http/Exception/RequestException.php @@ -0,0 +1,39 @@ +request = $request; + + return $this; + } + + /** + * Get the request that caused the exception + * + * @return RequestInterface + */ + public function getRequest() + { + return $this->request; + } +} diff --git a/vendor/aws/Guzzle/Http/Exception/ServerErrorResponseException.php b/vendor/aws/Guzzle/Http/Exception/ServerErrorResponseException.php new file mode 100644 index 0000000..f0f7cfe --- /dev/null +++ b/vendor/aws/Guzzle/Http/Exception/ServerErrorResponseException.php @@ -0,0 +1,8 @@ +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']; + } +} diff --git a/vendor/aws/Guzzle/Http/Message/AbstractMessage.php b/vendor/aws/Guzzle/Http/Message/AbstractMessage.php new file mode 100644 index 0000000..0d066ff --- /dev/null +++ b/vendor/aws/Guzzle/Http/Message/AbstractMessage.php @@ -0,0 +1,220 @@ +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; + } +} diff --git a/vendor/aws/Guzzle/Http/Message/EntityEnclosingRequest.php b/vendor/aws/Guzzle/Http/Message/EntityEnclosingRequest.php new file mode 100644 index 0000000..212850a --- /dev/null +++ b/vendor/aws/Guzzle/Http/Message/EntityEnclosingRequest.php @@ -0,0 +1,247 @@ +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'); + } + } + } +} diff --git a/vendor/aws/Guzzle/Http/Message/EntityEnclosingRequestInterface.php b/vendor/aws/Guzzle/Http/Message/EntityEnclosingRequestInterface.php new file mode 100644 index 0000000..49ad459 --- /dev/null +++ b/vendor/aws/Guzzle/Http/Message/EntityEnclosingRequestInterface.php @@ -0,0 +1,137 @@ + 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); +} diff --git a/vendor/aws/Guzzle/Http/Message/Header.php b/vendor/aws/Guzzle/Http/Message/Header.php new file mode 100644 index 0000000..50597b2 --- /dev/null +++ b/vendor/aws/Guzzle/Http/Message/Header.php @@ -0,0 +1,182 @@ +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); + } +} diff --git a/vendor/aws/Guzzle/Http/Message/Header/CacheControl.php b/vendor/aws/Guzzle/Http/Message/Header/CacheControl.php new file mode 100644 index 0000000..77789e5 --- /dev/null +++ b/vendor/aws/Guzzle/Http/Message/Header/CacheControl.php @@ -0,0 +1,121 @@ +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}"; + } + } +} diff --git a/vendor/aws/Guzzle/Http/Message/Header/HeaderCollection.php b/vendor/aws/Guzzle/Http/Message/Header/HeaderCollection.php new file mode 100644 index 0000000..8c7f6ae --- /dev/null +++ b/vendor/aws/Guzzle/Http/Message/Header/HeaderCollection.php @@ -0,0 +1,108 @@ +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; + } +} diff --git a/vendor/aws/Guzzle/Http/Message/Header/HeaderFactory.php b/vendor/aws/Guzzle/Http/Message/Header/HeaderFactory.php new file mode 100644 index 0000000..0273be5 --- /dev/null +++ b/vendor/aws/Guzzle/Http/Message/Header/HeaderFactory.php @@ -0,0 +1,26 @@ + '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); + } +} diff --git a/vendor/aws/Guzzle/Http/Message/Header/HeaderFactoryInterface.php b/vendor/aws/Guzzle/Http/Message/Header/HeaderFactoryInterface.php new file mode 100644 index 0000000..9457cf6 --- /dev/null +++ b/vendor/aws/Guzzle/Http/Message/Header/HeaderFactoryInterface.php @@ -0,0 +1,19 @@ +", "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; + } +} diff --git a/vendor/aws/Guzzle/Http/Message/MessageInterface.php b/vendor/aws/Guzzle/Http/Message/MessageInterface.php new file mode 100644 index 0000000..62bcd43 --- /dev/null +++ b/vendor/aws/Guzzle/Http/Message/MessageInterface.php @@ -0,0 +1,102 @@ +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'; + } +} diff --git a/vendor/aws/Guzzle/Http/Message/PostFileInterface.php b/vendor/aws/Guzzle/Http/Message/PostFileInterface.php new file mode 100644 index 0000000..7f0779d --- /dev/null +++ b/vendor/aws/Guzzle/Http/Message/PostFileInterface.php @@ -0,0 +1,83 @@ +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 ($port && (($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; + } +} diff --git a/vendor/aws/Guzzle/Http/Message/RequestFactory.php b/vendor/aws/Guzzle/Http/Message/RequestFactory.php new file mode 100644 index 0000000..ba00a76 --- /dev/null +++ b/vendor/aws/Guzzle/Http/Message/RequestFactory.php @@ -0,0 +1,359 @@ +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') { + // 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); + } + } +} diff --git a/vendor/aws/Guzzle/Http/Message/RequestFactoryInterface.php b/vendor/aws/Guzzle/Http/Message/RequestFactoryInterface.php new file mode 100644 index 0000000..6088f10 --- /dev/null +++ b/vendor/aws/Guzzle/Http/Message/RequestFactoryInterface.php @@ -0,0 +1,105 @@ + '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; + } +} diff --git a/vendor/aws/Guzzle/Http/Mimetypes.php b/vendor/aws/Guzzle/Http/Mimetypes.php new file mode 100644 index 0000000..d71586a --- /dev/null +++ b/vendor/aws/Guzzle/Http/Mimetypes.php @@ -0,0 +1,962 @@ + '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)); + } +} diff --git a/vendor/aws/Guzzle/Http/QueryAggregator/CommaAggregator.php b/vendor/aws/Guzzle/Http/QueryAggregator/CommaAggregator.php new file mode 100644 index 0000000..4b4e49d --- /dev/null +++ b/vendor/aws/Guzzle/Http/QueryAggregator/CommaAggregator.php @@ -0,0 +1,20 @@ +isUrlEncoding()) { + return array($query->encodeValue($key) => implode(',', array_map(array($query, 'encodeValue'), $value))); + } else { + return array($key => implode(',', $value)); + } + } +} diff --git a/vendor/aws/Guzzle/Http/QueryAggregator/DuplicateAggregator.php b/vendor/aws/Guzzle/Http/QueryAggregator/DuplicateAggregator.php new file mode 100644 index 0000000..1bf1730 --- /dev/null +++ b/vendor/aws/Guzzle/Http/QueryAggregator/DuplicateAggregator.php @@ -0,0 +1,22 @@ +isUrlEncoding()) { + return array($query->encodeValue($key) => array_map(array($query, 'encodeValue'), $value)); + } else { + return array($key => $value); + } + } +} diff --git a/vendor/aws/Guzzle/Http/QueryAggregator/PhpAggregator.php b/vendor/aws/Guzzle/Http/QueryAggregator/PhpAggregator.php new file mode 100644 index 0000000..133ea2b --- /dev/null +++ b/vendor/aws/Guzzle/Http/QueryAggregator/PhpAggregator.php @@ -0,0 +1,27 @@ + $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; + } +} diff --git a/vendor/aws/Guzzle/Http/QueryAggregator/QueryAggregatorInterface.php b/vendor/aws/Guzzle/Http/QueryAggregator/QueryAggregatorInterface.php new file mode 100644 index 0000000..72bee62 --- /dev/null +++ b/vendor/aws/Guzzle/Http/QueryAggregator/QueryAggregatorInterface.php @@ -0,0 +1,22 @@ +add($key, $value); + $foundDuplicates = true; + } elseif ($paramIsPhpStyleArray) { + $q[$key] = array($value); + } else { + $q[$key] = $value; + } + } else { + // Uses false by default to represent keys with no trailing "=" sign. + $q->add($key, false); + } + } + + // 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 + * @throws RuntimeException + */ + public function __toString() + { + if (!$this->data) { + return ''; + } + + $queryList = array(); + foreach ($this->prepareData($this->data) as $name => $value) { + $queryList[] = $this->convertKvp($name, $value); + } + + return implode($this->fieldSeparator, $queryList); + } + + /** + * 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 ($value === false || $value === null) { + // False and null will not include the "=". Use an empty string to include the "=". + $temp[$this->encodeValue($key)] = $value; + } elseif (is_array($value)) { + $temp = array_merge($temp, $this->aggregator->aggregate($key, $value, $this)); + } else { + $temp[$this->encodeValue($key)] = $this->encodeValue($value); + } + } + + return $temp; + } + + /** + * Converts a key value pair that can contain strings, nulls, false, or arrays + * into a single string. + * + * @param string $name Name of the field + * @param mixed $value Value of the field + * @return string + */ + private function convertKvp($name, $value) + { + if ($value === self::BLANK || $value === null || $value === false) { + return $name; + } elseif (!is_array($value)) { + return $name . $this->valueSeparator . $value; + } + + $result = ''; + foreach ($value as $v) { + $result .= $this->convertKvp($name, $v) . $this->fieldSeparator; + } + + return rtrim($result, $this->fieldSeparator); + } +} diff --git a/vendor/aws/Guzzle/Http/ReadLimitEntityBody.php b/vendor/aws/Guzzle/Http/ReadLimitEntityBody.php new file mode 100644 index 0000000..ef28273 --- /dev/null +++ b/vendor/aws/Guzzle/Http/ReadLimitEntityBody.php @@ -0,0 +1,122 @@ +setLimit($limit)->setOffset($offset); + } + + /** + * Returns only a subset of the decorated entity body when cast as a string + * {@inheritdoc} + */ + public function __toString() + { + if (!$this->body->isReadable() || + (!$this->body->isSeekable() && $this->body->isConsumed()) + ) { + return ''; + } + + $originalPos = $this->body->ftell(); + $this->body->seek($this->offset); + $data = ''; + while (!$this->feof()) { + $data .= $this->read(1048576); + } + $this->body->seek($originalPos); + + return (string) $data ?: ''; + } + + public function isConsumed() + { + return $this->body->isConsumed() || + ($this->body->ftell() >= $this->offset + $this->limit); + } + + /** + * 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; + } + } +} diff --git a/vendor/aws/Guzzle/Http/RedirectPlugin.php b/vendor/aws/Guzzle/Http/RedirectPlugin.php new file mode 100644 index 0000000..1a824b8 --- /dev/null +++ b/vendor/aws/Guzzle/Http/RedirectPlugin.php @@ -0,0 +1,250 @@ + 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); + } + ); + } +} diff --git a/vendor/aws/Guzzle/Http/Resources/cacert.pem b/vendor/aws/Guzzle/Http/Resources/cacert.pem new file mode 100644 index 0000000..18ce703 --- /dev/null +++ b/vendor/aws/Guzzle/Http/Resources/cacert.pem @@ -0,0 +1,3870 @@ +## +## Bundle of CA Root Certificates +## +## Certificate data from Mozilla downloaded on: Wed Aug 13 21:49:32 2014 +## +## 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://hg.mozilla.org/releases/mozilla-release/raw-file/default/security/nss/lib/ckfw/builtins/certdata.txt +## +## 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. +## +## Conversion done with mk-ca-bundle.pl verison 1.22. +## SHA1: bf2c15b3019e696660321d2227d942936dc50aa7 +## + + +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----- + +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----- +MIIEKjCCAxKgAwIBAgIEOGPe+DANBgkqhkiG9w0BAQUFADCBtDEUMBIGA1UEChMLRW50cnVzdC5u +ZXQxQDA+BgNVBAsUN3d3dy5lbnRydXN0Lm5ldC9DUFNfMjA0OCBpbmNvcnAuIGJ5IHJlZi4gKGxp +bWl0cyBsaWFiLikxJTAjBgNVBAsTHChjKSAxOTk5IEVudHJ1c3QubmV0IExpbWl0ZWQxMzAxBgNV +BAMTKkVudHJ1c3QubmV0IENlcnRpZmljYXRpb24gQXV0aG9yaXR5ICgyMDQ4KTAeFw05OTEyMjQx +NzUwNTFaFw0yOTA3MjQxNDE1MTJaMIG0MRQwEgYDVQQKEwtFbnRydXN0Lm5ldDFAMD4GA1UECxQ3 +d3d3LmVudHJ1c3QubmV0L0NQU18yMDQ4IGluY29ycC4gYnkgcmVmLiAobGltaXRzIGxpYWIuKTEl +MCMGA1UECxMcKGMpIDE5OTkgRW50cnVzdC5uZXQgTGltaXRlZDEzMDEGA1UEAxMqRW50cnVzdC5u +ZXQgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkgKDIwNDgpMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8A +MIIBCgKCAQEArU1LqRKGsuqjIAcVFmQqK0vRvwtKTY7tgHalZ7d4QMBzQshowNtTK91euHaYNZOL +Gp18EzoOH1u3Hs/lJBQesYGpjX24zGtLA/ECDNyrpUAkAH90lKGdCCmziAv1h3edVc3kw37XamSr +hRSGlVuXMlBvPci6Zgzj/L24ScF2iUkZ/cCovYmjZy/Gn7xxGWC4LeksyZB2ZnuU4q941mVTXTzW +nLLPKQP5L6RQstRIzgUyVYr9smRMDuSYB3Xbf9+5CFVghTAp+XtIpGmG4zU/HoZdenoVve8AjhUi +VBcAkCaTvA5JaJG/+EfTnZVCwQ5N328mz8MYIWJmQ3DW1cAH4QIDAQABo0IwQDAOBgNVHQ8BAf8E +BAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUVeSB0RGAvtiJuQijMfmhJAkWuXAwDQYJ +KoZIhvcNAQEFBQADggEBADubj1abMOdTmXx6eadNl9cZlZD7Bh/KM3xGY4+WZiT6QBshJ8rmcnPy +T/4xmf3IDExoU8aAghOY+rat2l098c5u9hURlIIM7j+VrxGrD9cv3h8Dj1csHsm7mhpElesYT6Yf +zX1XEC+bBAlahLVu2B064dae0Wx5XnkcFMXj0EyTO2U87d89vqbllRrDtRnDvV5bu/8j72gZyxKT +J1wDLW8w0B62GqzeWvfRqqgnpv55gcR5mTNXuhKwqeBCbJPKVt7+bYQLCIt+jerXmCHG8+c8eS9e +nNFMFY3h7CI3zJpDC5fcgJCNs2ebb0gIFVbPv/ErfF6adulZkMV8gzURZVE= +-----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----- + +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----- +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 +-----END CERTIFICATE----- + +QuoVadis Root CA 3 +================== +-----BEGIN CERTIFICATE----- +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 +-----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----- + +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----- +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 +-----END CERTIFICATE----- + +SwissSign Silver CA - G2 +======================== +-----BEGIN CERTIFICATE----- +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 +-----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----- +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 +-----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----- +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 +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----- +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 +-----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----- + +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----- +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 +-----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----- +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 +-----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----- + +TURKTRUST Certificate Services Provider Root 2007 +================================================= +-----BEGIN CERTIFICATE----- +MIIEPTCCAyWgAwIBAgIBATANBgkqhkiG9w0BAQUFADCBvzE/MD0GA1UEAww2VMOcUktUUlVTVCBF +bGVrdHJvbmlrIFNlcnRpZmlrYSBIaXptZXQgU2HEn2xhecSxY8Sxc8SxMQswCQYDVQQGEwJUUjEP +MA0GA1UEBwwGQW5rYXJhMV4wXAYDVQQKDFVUw5xSS1RSVVNUIEJpbGdpIMSwbGV0acWfaW0gdmUg +QmlsacWfaW0gR8O8dmVubGnEn2kgSGl6bWV0bGVyaSBBLsWeLiAoYykgQXJhbMSxayAyMDA3MB4X +DTA3MTIyNTE4MzcxOVoXDTE3MTIyMjE4MzcxOVowgb8xPzA9BgNVBAMMNlTDnFJLVFJVU1QgRWxl +a3Ryb25payBTZXJ0aWZpa2EgSGl6bWV0IFNhxJ9sYXnEsWPEsXPEsTELMAkGA1UEBhMCVFIxDzAN +BgNVBAcMBkFua2FyYTFeMFwGA1UECgxVVMOcUktUUlVTVCBCaWxnaSDEsGxldGnFn2ltIHZlIEJp +bGnFn2ltIEfDvHZlbmxpxJ9pIEhpem1ldGxlcmkgQS7Fni4gKGMpIEFyYWzEsWsgMjAwNzCCASIw +DQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAKu3PgqMyKVYFeaK7yc9SrToJdPNM8Ig3BnuiD9N +YvDdE3ePYakqtdTyuTFYKTsvP2qcb3N2Je40IIDu6rfwxArNK4aUyeNgsURSsloptJGXg9i3phQv +KUmi8wUG+7RP2qFsmmaf8EMJyupyj+sA1zU511YXRxcw9L6/P8JorzZAwan0qafoEGsIiveGHtya +KhUG9qPw9ODHFNRRf8+0222vR5YXm3dx2KdxnSQM9pQ/hTEST7ruToK4uT6PIzdezKKqdfcYbwnT +rqdUKDT74eA7YH2gvnmJhsifLfkKS8RQouf9eRbHegsYz85M733WB2+Y8a+xwXrXgTW4qhe04MsC +AwEAAaNCMEAwHQYDVR0OBBYEFCnFkKslrxHkYb+j/4hhkeYO/pyBMA4GA1UdDwEB/wQEAwIBBjAP +BgNVHRMBAf8EBTADAQH/MA0GCSqGSIb3DQEBBQUAA4IBAQAQDdr4Ouwo0RSVgrESLFF6QSU2TJ/s +Px+EnWVUXKgWAkD6bho3hO9ynYYKVZ1WKKxmLNA6VpM0ByWtCLCPyA8JWcqdmBzlVPi5RX9ql2+I +aE1KBiY3iAIOtsbWcpnOa3faYjGkVh+uX4132l32iPwa2Z61gfAyuOOI0JzzaqC5mxRZNTZPz/OO +Xl0XrRWV2N2y1RVuAE6zS89mlOTgzbUF2mNXi+WzqtvALhyQRNsaXRik7r4EW5nVcV9VZWRi1aKb +BFmGyGJ353yCRWo9F7/snXUMrqNvWtMvmDb08PUZqxFdyKbjKlhqQgnDvZImZjINXQhVdP+MmNAK +poRq0Tl9 +-----END CERTIFICATE----- + +D-TRUST Root Class 3 CA 2 2009 +============================== +-----BEGIN CERTIFICATE----- +MIIEMzCCAxugAwIBAgIDCYPzMA0GCSqGSIb3DQEBCwUAME0xCzAJBgNVBAYTAkRFMRUwEwYDVQQK +DAxELVRydXN0IEdtYkgxJzAlBgNVBAMMHkQtVFJVU1QgUm9vdCBDbGFzcyAzIENBIDIgMjAwOTAe +Fw0wOTExMDUwODM1NThaFw0yOTExMDUwODM1NThaME0xCzAJBgNVBAYTAkRFMRUwEwYDVQQKDAxE +LVRydXN0IEdtYkgxJzAlBgNVBAMMHkQtVFJVU1QgUm9vdCBDbGFzcyAzIENBIDIgMjAwOTCCASIw +DQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBANOySs96R+91myP6Oi/WUEWJNTrGa9v+2wBoqOAD +ER03UAifTUpolDWzU9GUY6cgVq/eUXjsKj3zSEhQPgrfRlWLJ23DEE0NkVJD2IfgXU42tSHKXzlA +BF9bfsyjxiupQB7ZNoTWSPOSHjRGICTBpFGOShrvUD9pXRl/RcPHAY9RySPocq60vFYJfxLLHLGv +KZAKyVXMD9O0Gu1HNVpK7ZxzBCHQqr0ME7UAyiZsxGsMlFqVlNpQmvH/pStmMaTJOKDfHR+4CS7z +p+hnUquVH+BGPtikw8paxTGA6Eian5Rp/hnd2HN8gcqW3o7tszIFZYQ05ub9VxC1X3a/L7AQDcUC +AwEAAaOCARowggEWMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFP3aFMSfMN4hvR5COfyrYyNJ +4PGEMA4GA1UdDwEB/wQEAwIBBjCB0wYDVR0fBIHLMIHIMIGAoH6gfIZ6bGRhcDovL2RpcmVjdG9y +eS5kLXRydXN0Lm5ldC9DTj1ELVRSVVNUJTIwUm9vdCUyMENsYXNzJTIwMyUyMENBJTIwMiUyMDIw +MDksTz1ELVRydXN0JTIwR21iSCxDPURFP2NlcnRpZmljYXRlcmV2b2NhdGlvbmxpc3QwQ6BBoD+G +PWh0dHA6Ly93d3cuZC10cnVzdC5uZXQvY3JsL2QtdHJ1c3Rfcm9vdF9jbGFzc18zX2NhXzJfMjAw +OS5jcmwwDQYJKoZIhvcNAQELBQADggEBAH+X2zDI36ScfSF6gHDOFBJpiBSVYEQBrLLpME+bUMJm +2H6NMLVwMeniacfzcNsgFYbQDfC+rAF1hM5+n02/t2A7nPPKHeJeaNijnZflQGDSNiH+0LS4F9p0 +o3/U37CYAqxva2ssJSRyoWXuJVrl5jLn8t+rSfrzkGkj2wTZ51xY/GXUl77M/C4KzCUqNQT4YJEV +dT1B/yMfGchs64JTBKbkTCJNjYy6zltz7GRUUG3RnFX7acM2w4y8PIWmawomDeCTmGCufsYkl4ph +X5GOZpIJhzbNi5stPvZR1FDUWSi9g/LMKHtThm3YJohw1+qRzT65ysCQblrGXnRl11z+o+I= +-----END CERTIFICATE----- + +D-TRUST Root Class 3 CA 2 EV 2009 +================================= +-----BEGIN CERTIFICATE----- +MIIEQzCCAyugAwIBAgIDCYP0MA0GCSqGSIb3DQEBCwUAMFAxCzAJBgNVBAYTAkRFMRUwEwYDVQQK +DAxELVRydXN0IEdtYkgxKjAoBgNVBAMMIUQtVFJVU1QgUm9vdCBDbGFzcyAzIENBIDIgRVYgMjAw +OTAeFw0wOTExMDUwODUwNDZaFw0yOTExMDUwODUwNDZaMFAxCzAJBgNVBAYTAkRFMRUwEwYDVQQK +DAxELVRydXN0IEdtYkgxKjAoBgNVBAMMIUQtVFJVU1QgUm9vdCBDbGFzcyAzIENBIDIgRVYgMjAw +OTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAJnxhDRwui+3MKCOvXwEz75ivJn9gpfS +egpnljgJ9hBOlSJzmY3aFS3nBfwZcyK3jpgAvDw9rKFs+9Z5JUut8Mxk2og+KbgPCdM03TP1YtHh +zRnp7hhPTFiu4h7WDFsVWtg6uMQYZB7jM7K1iXdODL/ZlGsTl28So/6ZqQTMFexgaDbtCHu39b+T +7WYxg4zGcTSHThfqr4uRjRxWQa4iN1438h3Z0S0NL2lRp75mpoo6Kr3HGrHhFPC+Oh25z1uxav60 +sUYgovseO3Dvk5h9jHOW8sXvhXCtKSb8HgQ+HKDYD8tSg2J87otTlZCpV6LqYQXY+U3EJ/pure35 +11H3a6UCAwEAAaOCASQwggEgMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFNOUikxiEyoZLsyv +cop9NteaHNxnMA4GA1UdDwEB/wQEAwIBBjCB3QYDVR0fBIHVMIHSMIGHoIGEoIGBhn9sZGFwOi8v +ZGlyZWN0b3J5LmQtdHJ1c3QubmV0L0NOPUQtVFJVU1QlMjBSb290JTIwQ2xhc3MlMjAzJTIwQ0El +MjAyJTIwRVYlMjAyMDA5LE89RC1UcnVzdCUyMEdtYkgsQz1ERT9jZXJ0aWZpY2F0ZXJldm9jYXRp +b25saXN0MEagRKBChkBodHRwOi8vd3d3LmQtdHJ1c3QubmV0L2NybC9kLXRydXN0X3Jvb3RfY2xh +c3NfM19jYV8yX2V2XzIwMDkuY3JsMA0GCSqGSIb3DQEBCwUAA4IBAQA07XtaPKSUiO8aEXUHL7P+ +PPoeUSbrh/Yp3uDx1MYkCenBz1UbtDDZzhr+BlGmFaQt77JLvyAoJUnRpjZ3NOhk31KxEcdzes05 +nsKtjHEh8lprr988TlWvsoRlFIm5d8sqMb7Po23Pb0iUMkZv53GMoKaEGTcH8gNFCSuGdXzfX2lX +ANtu2KZyIktQ1HWYVt+3GP9DQ1CuekR78HlR10M9p9OB0/DJT7naxpeG0ILD5EJt/rDiZE4OJudA +NCa1CInXCGNjOCd1HjPqbqjdn5lPdE2BiYBL3ZqXKVwvvoFBuYz/6n1gBp7N1z3TLqMVvKjmJuVv +w9y4AyHqnxbxLFS1 +-----END CERTIFICATE----- + +PSCProcert +========== +-----BEGIN CERTIFICATE----- +MIIJhjCCB26gAwIBAgIBCzANBgkqhkiG9w0BAQsFADCCAR4xPjA8BgNVBAMTNUF1dG9yaWRhZCBk +ZSBDZXJ0aWZpY2FjaW9uIFJhaXogZGVsIEVzdGFkbyBWZW5lem9sYW5vMQswCQYDVQQGEwJWRTEQ +MA4GA1UEBxMHQ2FyYWNhczEZMBcGA1UECBMQRGlzdHJpdG8gQ2FwaXRhbDE2MDQGA1UEChMtU2lz +dGVtYSBOYWNpb25hbCBkZSBDZXJ0aWZpY2FjaW9uIEVsZWN0cm9uaWNhMUMwQQYDVQQLEzpTdXBl +cmludGVuZGVuY2lhIGRlIFNlcnZpY2lvcyBkZSBDZXJ0aWZpY2FjaW9uIEVsZWN0cm9uaWNhMSUw +IwYJKoZIhvcNAQkBFhZhY3JhaXpAc3VzY2VydGUuZ29iLnZlMB4XDTEwMTIyODE2NTEwMFoXDTIw +MTIyNTIzNTk1OVowgdExJjAkBgkqhkiG9w0BCQEWF2NvbnRhY3RvQHByb2NlcnQubmV0LnZlMQ8w +DQYDVQQHEwZDaGFjYW8xEDAOBgNVBAgTB01pcmFuZGExKjAoBgNVBAsTIVByb3ZlZWRvciBkZSBD +ZXJ0aWZpY2Fkb3MgUFJPQ0VSVDE2MDQGA1UEChMtU2lzdGVtYSBOYWNpb25hbCBkZSBDZXJ0aWZp +Y2FjaW9uIEVsZWN0cm9uaWNhMQswCQYDVQQGEwJWRTETMBEGA1UEAxMKUFNDUHJvY2VydDCCAiIw +DQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBANW39KOUM6FGqVVhSQ2oh3NekS1wwQYalNo97BVC +wfWMrmoX8Yqt/ICV6oNEolt6Vc5Pp6XVurgfoCfAUFM+jbnADrgV3NZs+J74BCXfgI8Qhd19L3uA +3VcAZCP4bsm+lU/hdezgfl6VzbHvvnpC2Mks0+saGiKLt38GieU89RLAu9MLmV+QfI4tL3czkkoh +RqipCKzx9hEC2ZUWno0vluYC3XXCFCpa1sl9JcLB/KpnheLsvtF8PPqv1W7/U0HU9TI4seJfxPmO +EO8GqQKJ/+MMbpfg353bIdD0PghpbNjU5Db4g7ayNo+c7zo3Fn2/omnXO1ty0K+qP1xmk6wKImG2 +0qCZyFSTXai20b1dCl53lKItwIKOvMoDKjSuc/HUtQy9vmebVOvh+qBa7Dh+PsHMosdEMXXqP+UH +0quhJZb25uSgXTcYOWEAM11G1ADEtMo88aKjPvM6/2kwLkDd9p+cJsmWN63nOaK/6mnbVSKVUyqU +td+tFjiBdWbjxywbk5yqjKPK2Ww8F22c3HxT4CAnQzb5EuE8XL1mv6JpIzi4mWCZDlZTOpx+FIyw +Bm/xhnaQr/2v/pDGj59/i5IjnOcVdo/Vi5QTcmn7K2FjiO/mpF7moxdqWEfLcU8UC17IAggmosvp +r2uKGcfLFFb14dq12fy/czja+eevbqQ34gcnAgMBAAGjggMXMIIDEzASBgNVHRMBAf8ECDAGAQH/ +AgEBMDcGA1UdEgQwMC6CD3N1c2NlcnRlLmdvYi52ZaAbBgVghl4CAqASDBBSSUYtRy0yMDAwNDAz +Ni0wMB0GA1UdDgQWBBRBDxk4qpl/Qguk1yeYVKIXTC1RVDCCAVAGA1UdIwSCAUcwggFDgBStuyId +xuDSAaj9dlBSk+2YwU2u06GCASakggEiMIIBHjE+MDwGA1UEAxM1QXV0b3JpZGFkIGRlIENlcnRp +ZmljYWNpb24gUmFpeiBkZWwgRXN0YWRvIFZlbmV6b2xhbm8xCzAJBgNVBAYTAlZFMRAwDgYDVQQH +EwdDYXJhY2FzMRkwFwYDVQQIExBEaXN0cml0byBDYXBpdGFsMTYwNAYDVQQKEy1TaXN0ZW1hIE5h +Y2lvbmFsIGRlIENlcnRpZmljYWNpb24gRWxlY3Ryb25pY2ExQzBBBgNVBAsTOlN1cGVyaW50ZW5k +ZW5jaWEgZGUgU2VydmljaW9zIGRlIENlcnRpZmljYWNpb24gRWxlY3Ryb25pY2ExJTAjBgkqhkiG +9w0BCQEWFmFjcmFpekBzdXNjZXJ0ZS5nb2IudmWCAQowDgYDVR0PAQH/BAQDAgEGME0GA1UdEQRG +MESCDnByb2NlcnQubmV0LnZloBUGBWCGXgIBoAwMClBTQy0wMDAwMDKgGwYFYIZeAgKgEgwQUklG +LUotMzE2MzUzNzMtNzB2BgNVHR8EbzBtMEagRKBChkBodHRwOi8vd3d3LnN1c2NlcnRlLmdvYi52 +ZS9sY3IvQ0VSVElGSUNBRE8tUkFJWi1TSEEzODRDUkxERVIuY3JsMCOgIaAfhh1sZGFwOi8vYWNy +YWl6LnN1c2NlcnRlLmdvYi52ZTA3BggrBgEFBQcBAQQrMCkwJwYIKwYBBQUHMAGGG2h0dHA6Ly9v +Y3NwLnN1c2NlcnRlLmdvYi52ZTBBBgNVHSAEOjA4MDYGBmCGXgMBAjAsMCoGCCsGAQUFBwIBFh5o +dHRwOi8vd3d3LnN1c2NlcnRlLmdvYi52ZS9kcGMwDQYJKoZIhvcNAQELBQADggIBACtZ6yKZu4Sq +T96QxtGGcSOeSwORR3C7wJJg7ODU523G0+1ng3dS1fLld6c2suNUvtm7CpsR72H0xpkzmfWvADmN +g7+mvTV+LFwxNG9s2/NkAZiqlCxB3RWGymspThbASfzXg0gTB1GEMVKIu4YXx2sviiCtxQuPcD4q +uxtxj7mkoP3YldmvWb8lK5jpY5MvYB7Eqvh39YtsL+1+LrVPQA3uvFd359m21D+VJzog1eWuq2w1 +n8GhHVnchIHuTQfiSLaeS5UtQbHh6N5+LwUeaO6/u5BlOsju6rEYNxxik6SgMexxbJHmpHmJWhSn +FFAFTKQAVzAswbVhltw+HoSvOULP5dAssSS830DD7X9jSr3hTxJkhpXzsOfIt+FTvZLm8wyWuevo +5pLtp4EJFAv8lXrPj9Y0TzYS3F7RNHXGRoAvlQSMx4bEqCaJqD8Zm4G7UaRKhqsLEQ+xrmNTbSjq +3TNWOByyrYDT13K9mmyZY+gAu0F2BbdbmRiKw7gSXFbPVgx96OLP7bx0R/vu0xdOIk9W/1DzLuY5 +poLWccret9W6aAjtmcz9opLLabid+Qqkpj5PkygqYWwHJgD/ll9ohri4zspV4KuxPX+Y1zMOWj3Y +eMLEYC/HYvBhkdI4sPaeVdtAgAUSM84dkpvRabP/v/GSCmE1P93+hvS84Bpxs2Km +-----END CERTIFICATE----- + +China Internet Network Information Center EV Certificates Root +============================================================== +-----BEGIN CERTIFICATE----- +MIID9zCCAt+gAwIBAgIESJ8AATANBgkqhkiG9w0BAQUFADCBijELMAkGA1UEBhMCQ04xMjAwBgNV +BAoMKUNoaW5hIEludGVybmV0IE5ldHdvcmsgSW5mb3JtYXRpb24gQ2VudGVyMUcwRQYDVQQDDD5D +aGluYSBJbnRlcm5ldCBOZXR3b3JrIEluZm9ybWF0aW9uIENlbnRlciBFViBDZXJ0aWZpY2F0ZXMg +Um9vdDAeFw0xMDA4MzEwNzExMjVaFw0zMDA4MzEwNzExMjVaMIGKMQswCQYDVQQGEwJDTjEyMDAG +A1UECgwpQ2hpbmEgSW50ZXJuZXQgTmV0d29yayBJbmZvcm1hdGlvbiBDZW50ZXIxRzBFBgNVBAMM +PkNoaW5hIEludGVybmV0IE5ldHdvcmsgSW5mb3JtYXRpb24gQ2VudGVyIEVWIENlcnRpZmljYXRl +cyBSb290MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAm35z7r07eKpkQ0H1UN+U8i6y +jUqORlTSIRLIOTJCBumD1Z9S7eVnAztUwYyZmczpwA//DdmEEbK40ctb3B75aDFk4Zv6dOtouSCV +98YPjUesWgbdYavi7NifFy2cyjw1l1VxzUOFsUcW9SxTgHbP0wBkvUCZ3czY28Sf1hNfQYOL+Q2H +klY0bBoQCxfVWhyXWIQ8hBouXJE0bhlffxdpxWXvayHG1VA6v2G5BY3vbzQ6sm8UY78WO5upKv23 +KzhmBsUs4qpnHkWnjQRmQvaPK++IIGmPMowUc9orhpFjIpryp9vOiYurXccUwVswah+xt54ugQEC +7c+WXmPbqOY4twIDAQABo2MwYTAfBgNVHSMEGDAWgBR8cks5x8DbYqVPm6oYNJKiyoOCWTAPBgNV +HRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUfHJLOcfA22KlT5uqGDSSosqD +glkwDQYJKoZIhvcNAQEFBQADggEBACrDx0M3j92tpLIM7twUbY8opJhJywyA6vPtI2Z1fcXTIWd5 +0XPFtQO3WKwMVC/GVhMPMdoG52U7HW8228gd+f2ABsqjPWYWqJ1MFn3AlUa1UeTiH9fqBk1jjZaM +7+czV0I664zBechNdn3e9rG3geCg+aF4RhcaVpjwTj2rHO3sOdwHSPdj/gauwqRcalsyiMXHM4Ws +ZkJHwlgkmeHlPuV1LI5D1l08eB6olYIpUNHRFrrvwb562bTYzB5MRuF3sTGrvSrIzo9uoV1/A3U0 +5K2JRVRevq4opbs/eHnrc7MKDf2+yfdWrPa37S+bISnHOLaVxATywy39FCqQmbkHzJ8= +-----END CERTIFICATE----- + +Swisscom Root CA 2 +================== +-----BEGIN CERTIFICATE----- +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 +5OfNeOI5wSsSnqaeG8XmDtkx2Q== +-----END CERTIFICATE----- + +Swisscom Root EV CA 2 +===================== +-----BEGIN CERTIFICATE----- +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 +l8PVP3wbI+2ksx0WckNLIOFZfsLorSa/ovc= +-----END CERTIFICATE----- + +CA Disig Root R1 +================ +-----BEGIN CERTIFICATE----- +MIIFaTCCA1GgAwIBAgIJAMMDmu5QkG4oMA0GCSqGSIb3DQEBBQUAMFIxCzAJBgNVBAYTAlNLMRMw +EQYDVQQHEwpCcmF0aXNsYXZhMRMwEQYDVQQKEwpEaXNpZyBhLnMuMRkwFwYDVQQDExBDQSBEaXNp +ZyBSb290IFIxMB4XDTEyMDcxOTA5MDY1NloXDTQyMDcxOTA5MDY1NlowUjELMAkGA1UEBhMCU0sx +EzARBgNVBAcTCkJyYXRpc2xhdmExEzARBgNVBAoTCkRpc2lnIGEucy4xGTAXBgNVBAMTEENBIERp +c2lnIFJvb3QgUjEwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCqw3j33Jijp1pedxiy +3QRkD2P9m5YJgNXoqqXinCaUOuiZc4yd39ffg/N4T0Dhf9Kn0uXKE5Pn7cZ3Xza1lK/oOI7bm+V8 +u8yN63Vz4STN5qctGS7Y1oprFOsIYgrY3LMATcMjfF9DCCMyEtztDK3AfQ+lekLZWnDZv6fXARz2 +m6uOt0qGeKAeVjGu74IKgEH3G8muqzIm1Cxr7X1r5OJeIgpFy4QxTaz+29FHuvlglzmxZcfe+5nk +CiKxLU3lSCZpq+Kq8/v8kiky6bM+TR8noc2OuRf7JT7JbvN32g0S9l3HuzYQ1VTW8+DiR0jm3hTa +YVKvJrT1cU/J19IG32PK/yHoWQbgCNWEFVP3Q+V8xaCJmGtzxmjOZd69fwX3se72V6FglcXM6pM6 +vpmumwKjrckWtc7dXpl4fho5frLABaTAgqWjR56M6ly2vGfb5ipN0gTco65F97yLnByn1tUD3AjL +LhbKXEAz6GfDLuemROoRRRw1ZS0eRWEkG4IupZ0zXWX4Qfkuy5Q/H6MMMSRE7cderVC6xkGbrPAX +ZcD4XW9boAo0PO7X6oifmPmvTiT6l7Jkdtqr9O3jw2Dv1fkCyC2fg69naQanMVXVz0tv/wQFx1is +XxYb5dKj6zHbHzMVTdDypVP1y+E9Tmgt2BLdqvLmTZtJ5cUoobqwWsagtQIDAQABo0IwQDAPBgNV +HRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUiQq0OJMa5qvum5EY+fU8PjXQ +04IwDQYJKoZIhvcNAQEFBQADggIBADKL9p1Kyb4U5YysOMo6CdQbzoaz3evUuii+Eq5FLAR0rBNR +xVgYZk2C2tXck8An4b58n1KeElb21Zyp9HWc+jcSjxyT7Ff+Bw+r1RL3D65hXlaASfX8MPWbTx9B +LxyE04nH4toCdu0Jz2zBuByDHBb6lM19oMgY0sidbvW9adRtPTXoHqJPYNcHKfyyo6SdbhWSVhlM +CrDpfNIZTUJG7L399ldb3Zh+pE3McgODWF3vkzpBemOqfDqo9ayk0d2iLbYq/J8BjuIQscTK5Gfb +VSUZP/3oNn6z4eGBrxEWi1CXYBmCAMBrTXO40RMHPuq2MU/wQppt4hF05ZSsjYSVPCGvxdpHyN85 +YmLLW1AL14FABZyb7bq2ix4Eb5YgOe2kfSnbSM6C3NQCjR0EMVrHS/BsYVLXtFHCgWzN4funodKS +ds+xDzdYpPJScWc/DIh4gInByLUfkmO+p3qKViwaqKactV2zY9ATIKHrkWzQjX2v3wvkF7mGnjix +lAxYjOBVqjtjbZqJYLhkKpLGN/R+Q0O3c+gB53+XD9fyexn9GtePyfqFa3qdnom2piiZk4hA9z7N +UaPK6u95RyG1/jLix8NRb76AdPCkwzryT+lf3xkK8jsTQ6wxpLPn6/wY1gGp8yqPNg7rtLG8t0zJ +a7+h89n07eLw4+1knj0vllJPgFOL +-----END CERTIFICATE----- + +CA Disig Root R2 +================ +-----BEGIN CERTIFICATE----- +MIIFaTCCA1GgAwIBAgIJAJK4iNuwisFjMA0GCSqGSIb3DQEBCwUAMFIxCzAJBgNVBAYTAlNLMRMw +EQYDVQQHEwpCcmF0aXNsYXZhMRMwEQYDVQQKEwpEaXNpZyBhLnMuMRkwFwYDVQQDExBDQSBEaXNp +ZyBSb290IFIyMB4XDTEyMDcxOTA5MTUzMFoXDTQyMDcxOTA5MTUzMFowUjELMAkGA1UEBhMCU0sx +EzARBgNVBAcTCkJyYXRpc2xhdmExEzARBgNVBAoTCkRpc2lnIGEucy4xGTAXBgNVBAMTEENBIERp +c2lnIFJvb3QgUjIwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCio8QACdaFXS1tFPbC +w3OeNcJxVX6B+6tGUODBfEl45qt5WDza/3wcn9iXAng+a0EE6UG9vgMsRfYvZNSrXaNHPWSb6Wia +xswbP7q+sos0Ai6YVRn8jG+qX9pMzk0DIaPY0jSTVpbLTAwAFjxfGs3Ix2ymrdMxp7zo5eFm1tL7 +A7RBZckQrg4FY8aAamkw/dLukO8NJ9+flXP04SXabBbeQTg06ov80egEFGEtQX6sx3dOy1FU+16S +GBsEWmjGycT6txOgmLcRK7fWV8x8nhfRyyX+hk4kLlYMeE2eARKmK6cBZW58Yh2EhN/qwGu1pSqV +g8NTEQxzHQuyRpDRQjrOQG6Vrf/GlK1ul4SOfW+eioANSW1z4nuSHsPzwfPrLgVv2RvPN3YEyLRa +5Beny912H9AZdugsBbPWnDTYltxhh5EF5EQIM8HauQhl1K6yNg3ruji6DOWbnuuNZt2Zz9aJQfYE +koopKW1rOhzndX0CcQ7zwOe9yxndnWCywmZgtrEE7snmhrmaZkCo5xHtgUUDi/ZnWejBBhG93c+A +Ak9lQHhcR1DIm+YfgXvkRKhbhZri3lrVx/k6RGZL5DJUfORsnLMOPReisjQS1n6yqEm70XooQL6i +Fh/f5DcfEXP7kAplQ6INfPgGAVUzfbANuPT1rqVCV3w2EYx7XsQDnYx5nQIDAQABo0IwQDAPBgNV +HRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUtZn4r7CU9eMg1gqtzk5WpC5u +Qu0wDQYJKoZIhvcNAQELBQADggIBACYGXnDnZTPIgm7ZnBc6G3pmsgH2eDtpXi/q/075KMOYKmFM +tCQSin1tERT3nLXK5ryeJ45MGcipvXrA1zYObYVybqjGom32+nNjf7xueQgcnYqfGopTpti72TVV +sRHFqQOzVju5hJMiXn7B9hJSi+osZ7z+Nkz1uM/Rs0mSO9MpDpkblvdhuDvEK7Z4bLQjb/D907Je +dR+Zlais9trhxTF7+9FGs9K8Z7RiVLoJ92Owk6Ka+elSLotgEqv89WBW7xBci8QaQtyDW2QOy7W8 +1k/BfDxujRNt+3vrMNDcTa/F1balTFtxyegxvug4BkihGuLq0t4SOVga/4AOgnXmt8kHbA7v/zjx +mHHEt38OFdAlab0inSvtBfZGR6ztwPDUO+Ls7pZbkBNOHlY667DvlruWIxG68kOGdGSVyCh13x01 +utI3gzhTODY7z2zp+WsO0PsE6E9312UBeIYMej4hYvF/Y3EMyZ9E26gnonW+boE+18DrG5gPcFw0 +sorMwIUY6256s/daoQe/qUKS82Ail+QUoQebTnbAjn39pCXHR+3/H3OszMOl6W8KjptlwlCFtaOg +UxLMVYdh84GuEEZhvUQhuMI9dM9+JDX6HAcOmz0iyu8xL4ysEr3vQCj8KWefshNPZiTEUxnpHikV +7+ZtsH8tZ/3zbBt1RqPlShfppNcL +-----END CERTIFICATE----- + +ACCVRAIZ1 +========= +-----BEGIN CERTIFICATE----- +MIIH0zCCBbugAwIBAgIIXsO3pkN/pOAwDQYJKoZIhvcNAQEFBQAwQjESMBAGA1UEAwwJQUNDVlJB +SVoxMRAwDgYDVQQLDAdQS0lBQ0NWMQ0wCwYDVQQKDARBQ0NWMQswCQYDVQQGEwJFUzAeFw0xMTA1 +MDUwOTM3MzdaFw0zMDEyMzEwOTM3MzdaMEIxEjAQBgNVBAMMCUFDQ1ZSQUlaMTEQMA4GA1UECwwH +UEtJQUNDVjENMAsGA1UECgwEQUNDVjELMAkGA1UEBhMCRVMwggIiMA0GCSqGSIb3DQEBAQUAA4IC +DwAwggIKAoICAQCbqau/YUqXry+XZpp0X9DZlv3P4uRm7x8fRzPCRKPfmt4ftVTdFXxpNRFvu8gM +jmoYHtiP2Ra8EEg2XPBjs5BaXCQ316PWywlxufEBcoSwfdtNgM3802/J+Nq2DoLSRYWoG2ioPej0 +RGy9ocLLA76MPhMAhN9KSMDjIgro6TenGEyxCQ0jVn8ETdkXhBilyNpAlHPrzg5XPAOBOp0KoVdD +aaxXbXmQeOW1tDvYvEyNKKGno6e6Ak4l0Squ7a4DIrhrIA8wKFSVf+DuzgpmndFALW4ir50awQUZ +0m/A8p/4e7MCQvtQqR0tkw8jq8bBD5L/0KIV9VMJcRz/RROE5iZe+OCIHAr8Fraocwa48GOEAqDG +WuzndN9wrqODJerWx5eHk6fGioozl2A3ED6XPm4pFdahD9GILBKfb6qkxkLrQaLjlUPTAYVtjrs7 +8yM2x/474KElB0iryYl0/wiPgL/AlmXz7uxLaL2diMMxs0Dx6M/2OLuc5NF/1OVYm3z61PMOm3WR +5LpSLhl+0fXNWhn8ugb2+1KoS5kE3fj5tItQo05iifCHJPqDQsGH+tUtKSpacXpkatcnYGMN285J +9Y0fkIkyF/hzQ7jSWpOGYdbhdQrqeWZ2iE9x6wQl1gpaepPluUsXQA+xtrn13k/c4LOsOxFwYIRK +Q26ZIMApcQrAZQIDAQABo4ICyzCCAscwfQYIKwYBBQUHAQEEcTBvMEwGCCsGAQUFBzAChkBodHRw +Oi8vd3d3LmFjY3YuZXMvZmlsZWFkbWluL0FyY2hpdm9zL2NlcnRpZmljYWRvcy9yYWl6YWNjdjEu +Y3J0MB8GCCsGAQUFBzABhhNodHRwOi8vb2NzcC5hY2N2LmVzMB0GA1UdDgQWBBTSh7Tj3zcnk1X2 +VuqB5TbMjB4/vTAPBgNVHRMBAf8EBTADAQH/MB8GA1UdIwQYMBaAFNKHtOPfNyeTVfZW6oHlNsyM +Hj+9MIIBcwYDVR0gBIIBajCCAWYwggFiBgRVHSAAMIIBWDCCASIGCCsGAQUFBwICMIIBFB6CARAA +QQB1AHQAbwByAGkAZABhAGQAIABkAGUAIABDAGUAcgB0AGkAZgBpAGMAYQBjAGkA8wBuACAAUgBh +AO0AegAgAGQAZQAgAGwAYQAgAEEAQwBDAFYAIAAoAEEAZwBlAG4AYwBpAGEAIABkAGUAIABUAGUA +YwBuAG8AbABvAGcA7QBhACAAeQAgAEMAZQByAHQAaQBmAGkAYwBhAGMAaQDzAG4AIABFAGwAZQBj +AHQAcgDzAG4AaQBjAGEALAAgAEMASQBGACAAUQA0ADYAMAAxADEANQA2AEUAKQAuACAAQwBQAFMA +IABlAG4AIABoAHQAdABwADoALwAvAHcAdwB3AC4AYQBjAGMAdgAuAGUAczAwBggrBgEFBQcCARYk +aHR0cDovL3d3dy5hY2N2LmVzL2xlZ2lzbGFjaW9uX2MuaHRtMFUGA1UdHwROMEwwSqBIoEaGRGh0 +dHA6Ly93d3cuYWNjdi5lcy9maWxlYWRtaW4vQXJjaGl2b3MvY2VydGlmaWNhZG9zL3JhaXphY2N2 +MV9kZXIuY3JsMA4GA1UdDwEB/wQEAwIBBjAXBgNVHREEEDAOgQxhY2N2QGFjY3YuZXMwDQYJKoZI +hvcNAQEFBQADggIBAJcxAp/n/UNnSEQU5CmH7UwoZtCPNdpNYbdKl02125DgBS4OxnnQ8pdpD70E +R9m+27Up2pvZrqmZ1dM8MJP1jaGo/AaNRPTKFpV8M9xii6g3+CfYCS0b78gUJyCpZET/LtZ1qmxN +YEAZSUNUY9rizLpm5U9EelvZaoErQNV/+QEnWCzI7UiRfD+mAM/EKXMRNt6GGT6d7hmKG9Ww7Y49 +nCrADdg9ZuM8Db3VlFzi4qc1GwQA9j9ajepDvV+JHanBsMyZ4k0ACtrJJ1vnE5Bc5PUzolVt3OAJ +TS+xJlsndQAJxGJ3KQhfnlmstn6tn1QwIgPBHnFk/vk4CpYY3QIUrCPLBhwepH2NDd4nQeit2hW3 +sCPdK6jT2iWH7ehVRE2I9DZ+hJp4rPcOVkkO1jMl1oRQQmwgEh0q1b688nCBpHBgvgW1m54ERL5h +I6zppSSMEYCUWqKiuUnSwdzRp+0xESyeGabu4VXhwOrPDYTkF7eifKXeVSUG7szAh1xA2syVP1Xg +Nce4hL60Xc16gwFy7ofmXx2utYXGJt/mwZrpHgJHnyqobalbz+xFd3+YJ5oyXSrjhO7FmGYvliAd +3djDJ9ew+f7Zfc3Qn48LFFhRny+Lwzgt3uiP1o2HpPVWQxaZLPSkVrQ0uGE3ycJYgBugl6H8WY3p +EfbRD0tVNEYqi4Y7 +-----END CERTIFICATE----- + +TWCA Global Root CA +=================== +-----BEGIN CERTIFICATE----- +MIIFQTCCAymgAwIBAgICDL4wDQYJKoZIhvcNAQELBQAwUTELMAkGA1UEBhMCVFcxEjAQBgNVBAoT +CVRBSVdBTi1DQTEQMA4GA1UECxMHUm9vdCBDQTEcMBoGA1UEAxMTVFdDQSBHbG9iYWwgUm9vdCBD +QTAeFw0xMjA2MjcwNjI4MzNaFw0zMDEyMzExNTU5NTlaMFExCzAJBgNVBAYTAlRXMRIwEAYDVQQK +EwlUQUlXQU4tQ0ExEDAOBgNVBAsTB1Jvb3QgQ0ExHDAaBgNVBAMTE1RXQ0EgR2xvYmFsIFJvb3Qg +Q0EwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQCwBdvI64zEbooh745NnHEKH1Jw7W2C +nJfF10xORUnLQEK1EjRsGcJ0pDFfhQKX7EMzClPSnIyOt7h52yvVavKOZsTuKwEHktSz0ALfUPZV +r2YOy+BHYC8rMjk1Ujoog/h7FsYYuGLWRyWRzvAZEk2tY/XTP3VfKfChMBwqoJimFb3u/Rk28OKR +Q4/6ytYQJ0lM793B8YVwm8rqqFpD/G2Gb3PpN0Wp8DbHzIh1HrtsBv+baz4X7GGqcXzGHaL3SekV +tTzWoWH1EfcFbx39Eb7QMAfCKbAJTibc46KokWofwpFFiFzlmLhxpRUZyXx1EcxwdE8tmx2RRP1W +KKD+u4ZqyPpcC1jcxkt2yKsi2XMPpfRaAok/T54igu6idFMqPVMnaR1sjjIsZAAmY2E2TqNGtz99 +sy2sbZCilaLOz9qC5wc0GZbpuCGqKX6mOL6OKUohZnkfs8O1CWfe1tQHRvMq2uYiN2DLgbYPoA/p +yJV/v1WRBXrPPRXAb94JlAGD1zQbzECl8LibZ9WYkTunhHiVJqRaCPgrdLQABDzfuBSO6N+pjWxn +kjMdwLfS7JLIvgm/LCkFbwJrnu+8vyq8W8BQj0FwcYeyTbcEqYSjMq+u7msXi7Kx/mzhkIyIqJdI +zshNy/MGz19qCkKxHh53L46g5pIOBvwFItIm4TFRfTLcDwIDAQABoyMwITAOBgNVHQ8BAf8EBAMC +AQYwDwYDVR0TAQH/BAUwAwEB/zANBgkqhkiG9w0BAQsFAAOCAgEAXzSBdu+WHdXltdkCY4QWwa6g +cFGn90xHNcgL1yg9iXHZqjNB6hQbbCEAwGxCGX6faVsgQt+i0trEfJdLjbDorMjupWkEmQqSpqsn +LhpNgb+E1HAerUf+/UqdM+DyucRFCCEK2mlpc3INvjT+lIutwx4116KD7+U4x6WFH6vPNOw/KP4M +8VeGTslV9xzU2KV9Bnpv1d8Q34FOIWWxtuEXeZVFBs5fzNxGiWNoRI2T9GRwoD2dKAXDOXC4Ynsg +/eTb6QihuJ49CcdP+yz4k3ZB3lLg4VfSnQO8d57+nile98FRYB/e2guyLXW3Q0iT5/Z5xoRdgFlg +lPx4mI88k1HtQJAH32RjJMtOcQWh15QaiDLxInQirqWm2BJpTGCjAu4r7NRjkgtevi92a6O2JryP +A9gK8kxkRr05YuWW6zRjESjMlfGt7+/cgFhI6Uu46mWs6fyAtbXIRfmswZ/ZuepiiI7E8UuDEq3m +i4TWnsLrgxifarsbJGAzcMzs9zLzXNl5fe+epP7JI8Mk7hWSsT2RTyaGvWZzJBPqpK5jwa19hAM8 +EHiGG3njxPPyBJUgriOCxLM6AGK/5jYk4Ve6xx6QddVfP5VhK8E7zeWzaGHQRiapIVJpLesux+t3 +zqY6tQMzT3bR51xUAV3LePTJDL/PEo4XLSNolOer/qmyKwbQBM0= +-----END CERTIFICATE----- + +TeliaSonera Root CA v1 +====================== +-----BEGIN CERTIFICATE----- +MIIFODCCAyCgAwIBAgIRAJW+FqD3LkbxezmCcvqLzZYwDQYJKoZIhvcNAQEFBQAwNzEUMBIGA1UE +CgwLVGVsaWFTb25lcmExHzAdBgNVBAMMFlRlbGlhU29uZXJhIFJvb3QgQ0EgdjEwHhcNMDcxMDE4 +MTIwMDUwWhcNMzIxMDE4MTIwMDUwWjA3MRQwEgYDVQQKDAtUZWxpYVNvbmVyYTEfMB0GA1UEAwwW +VGVsaWFTb25lcmEgUm9vdCBDQSB2MTCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAMK+ +6yfwIaPzaSZVfp3FVRaRXP3vIb9TgHot0pGMYzHw7CTww6XScnwQbfQ3t+XmfHnqjLWCi65ItqwA +3GV17CpNX8GH9SBlK4GoRz6JI5UwFpB/6FcHSOcZrr9FZ7E3GwYq/t75rH2D+1665I+XZ75Ljo1k +B1c4VWk0Nj0TSO9P4tNmHqTPGrdeNjPUtAa9GAH9d4RQAEX1jF3oI7x+/jXh7VB7qTCNGdMJjmhn +Xb88lxhTuylixcpecsHHltTbLaC0H2kD7OriUPEMPPCs81Mt8Bz17Ww5OXOAFshSsCPN4D7c3TxH +oLs1iuKYaIu+5b9y7tL6pe0S7fyYGKkmdtwoSxAgHNN/Fnct7W+A90m7UwW7XWjH1Mh1Fj+JWov3 +F0fUTPHSiXk+TT2YqGHeOh7S+F4D4MHJHIzTjU3TlTazN19jY5szFPAtJmtTfImMMsJu7D0hADnJ +oWjiUIMusDor8zagrC/kb2HCUQk5PotTubtn2txTuXZZNp1D5SDgPTJghSJRt8czu90VL6R4pgd7 +gUY2BIbdeTXHlSw7sKMXNeVzH7RcWe/a6hBle3rQf5+ztCo3O3CLm1u5K7fsslESl1MpWtTwEhDc +TwK7EpIvYtQ/aUN8Ddb8WHUBiJ1YFkveupD/RwGJBmr2X7KQarMCpgKIv7NHfirZ1fpoeDVNAgMB +AAGjPzA9MA8GA1UdEwEB/wQFMAMBAf8wCwYDVR0PBAQDAgEGMB0GA1UdDgQWBBTwj1k4ALP1j5qW +DNXr+nuqF+gTEjANBgkqhkiG9w0BAQUFAAOCAgEAvuRcYk4k9AwI//DTDGjkk0kiP0Qnb7tt3oNm +zqjMDfz1mgbldxSR651Be5kqhOX//CHBXfDkH1e3damhXwIm/9fH907eT/j3HEbAek9ALCI18Bmx +0GtnLLCo4MBANzX2hFxc469CeP6nyQ1Q6g2EdvZR74NTxnr/DlZJLo961gzmJ1TjTQpgcmLNkQfW +pb/ImWvtxBnmq0wROMVvMeJuScg/doAmAyYp4Db29iBT4xdwNBedY2gea+zDTYa4EzAvXUYNR0PV +G6pZDrlcjQZIrXSHX8f8MVRBE+LHIQ6e4B4N4cB7Q4WQxYpYxmUKeFfyxiMPAdkgS94P+5KFdSpc +c41teyWRyu5FrgZLAMzTsVlQ2jqIOylDRl6XK1TOU2+NSueW+r9xDkKLfP0ooNBIytrEgUy7onOT +JsjrDNYmiLbAJM+7vVvrdX3pCI6GMyx5dwlppYn8s3CQh3aP0yK7Qs69cwsgJirQmz1wHiRszYd2 +qReWt88NkvuOGKmYSdGe/mBEciG5Ge3C9THxOUiIkCR1VBatzvT4aRRkOfujuLpwQMcnHL/EVlP6 +Y2XQ8xwOFvVrhlhNGNTkDY6lnVuR3HYkUD/GKvvZt5y11ubQ2egZixVxSK236thZiNSQvxaz2ems +WWFUyBy6ysHK4bkgTI86k4mloMy/0/Z1pHWWbVY= +-----END CERTIFICATE----- + +E-Tugra Certification Authority +=============================== +-----BEGIN CERTIFICATE----- +MIIGSzCCBDOgAwIBAgIIamg+nFGby1MwDQYJKoZIhvcNAQELBQAwgbIxCzAJBgNVBAYTAlRSMQ8w +DQYDVQQHDAZBbmthcmExQDA+BgNVBAoMN0UtVHXEn3JhIEVCRyBCaWxpxZ9pbSBUZWtub2xvamls +ZXJpIHZlIEhpem1ldGxlcmkgQS7Fni4xJjAkBgNVBAsMHUUtVHVncmEgU2VydGlmaWthc3lvbiBN +ZXJrZXppMSgwJgYDVQQDDB9FLVR1Z3JhIENlcnRpZmljYXRpb24gQXV0aG9yaXR5MB4XDTEzMDMw +NTEyMDk0OFoXDTIzMDMwMzEyMDk0OFowgbIxCzAJBgNVBAYTAlRSMQ8wDQYDVQQHDAZBbmthcmEx +QDA+BgNVBAoMN0UtVHXEn3JhIEVCRyBCaWxpxZ9pbSBUZWtub2xvamlsZXJpIHZlIEhpem1ldGxl +cmkgQS7Fni4xJjAkBgNVBAsMHUUtVHVncmEgU2VydGlmaWthc3lvbiBNZXJrZXppMSgwJgYDVQQD +DB9FLVR1Z3JhIENlcnRpZmljYXRpb24gQXV0aG9yaXR5MIICIjANBgkqhkiG9w0BAQEFAAOCAg8A +MIICCgKCAgEA4vU/kwVRHoViVF56C/UYB4Oufq9899SKa6VjQzm5S/fDxmSJPZQuVIBSOTkHS0vd +hQd2h8y/L5VMzH2nPbxHD5hw+IyFHnSOkm0bQNGZDbt1bsipa5rAhDGvykPL6ys06I+XawGb1Q5K +CKpbknSFQ9OArqGIW66z6l7LFpp3RMih9lRozt6Plyu6W0ACDGQXwLWTzeHxE2bODHnv0ZEoq1+g +ElIwcxmOj+GMB6LDu0rw6h8VqO4lzKRG+Bsi77MOQ7osJLjFLFzUHPhdZL3Dk14opz8n8Y4e0ypQ +BaNV2cvnOVPAmJ6MVGKLJrD3fY185MaeZkJVgkfnsliNZvcHfC425lAcP9tDJMW/hkd5s3kc91r0 +E+xs+D/iWR+V7kI+ua2oMoVJl0b+SzGPWsutdEcf6ZG33ygEIqDUD13ieU/qbIWGvaimzuT6w+Gz +rt48Ue7LE3wBf4QOXVGUnhMMti6lTPk5cDZvlsouDERVxcr6XQKj39ZkjFqzAQqptQpHF//vkUAq +jqFGOjGY5RH8zLtJVor8udBhmm9lbObDyz51Sf6Pp+KJxWfXnUYTTjF2OySznhFlhqt/7x3U+Lzn +rFpct1pHXFXOVbQicVtbC/DP3KBhZOqp12gKY6fgDT+gr9Oq0n7vUaDmUStVkhUXU8u3Zg5mTPj5 +dUyQ5xJwx0UCAwEAAaNjMGEwHQYDVR0OBBYEFC7j27JJ0JxUeVz6Jyr+zE7S6E5UMA8GA1UdEwEB +/wQFMAMBAf8wHwYDVR0jBBgwFoAULuPbsknQnFR5XPonKv7MTtLoTlQwDgYDVR0PAQH/BAQDAgEG +MA0GCSqGSIb3DQEBCwUAA4ICAQAFNzr0TbdF4kV1JI+2d1LoHNgQk2Xz8lkGpD4eKexd0dCrfOAK +kEh47U6YA5n+KGCRHTAduGN8qOY1tfrTYXbm1gdLymmasoR6d5NFFxWfJNCYExL/u6Au/U5Mh/jO +XKqYGwXgAEZKgoClM4so3O0409/lPun++1ndYYRP0lSWE2ETPo+Aab6TR7U1Q9Jauz1c77NCR807 +VRMGsAnb/WP2OogKmW9+4c4bU2pEZiNRCHu8W1Ki/QY3OEBhj0qWuJA3+GbHeJAAFS6LrVE1Uweo +a2iu+U48BybNCAVwzDk/dr2l02cmAYamU9JgO3xDf1WKvJUawSg5TB9D0pH0clmKuVb8P7Sd2nCc +dlqMQ1DujjByTd//SffGqWfZbawCEeI6FiWnWAjLb1NBnEg4R2gz0dfHj9R0IdTDBZB6/86WiLEV +KV0jq9BgoRJP3vQXzTLlyb/IQ639Lo7xr+L0mPoSHyDYwKcMhcWQ9DstliaxLL5Mq+ux0orJ23gT +Dx4JnW2PAJ8C2sH6H3p6CcRK5ogql5+Ji/03X186zjhZhkuvcQu02PJwT58yE+Owp1fl2tpDy4Q0 +8ijE6m30Ku/Ba3ba+367hTzSU8JNvnHhRdH9I2cNE3X7z2VnIp2usAnRCf8dNL/+I5c30jn6PQ0G +C7TbO6Orb1wdtn7os4I07QZcJA== +-----END CERTIFICATE----- + +T-TeleSec GlobalRoot Class 2 +============================ +-----BEGIN CERTIFICATE----- +MIIDwzCCAqugAwIBAgIBATANBgkqhkiG9w0BAQsFADCBgjELMAkGA1UEBhMCREUxKzApBgNVBAoM +IlQtU3lzdGVtcyBFbnRlcnByaXNlIFNlcnZpY2VzIEdtYkgxHzAdBgNVBAsMFlQtU3lzdGVtcyBU +cnVzdCBDZW50ZXIxJTAjBgNVBAMMHFQtVGVsZVNlYyBHbG9iYWxSb290IENsYXNzIDIwHhcNMDgx +MDAxMTA0MDE0WhcNMzMxMDAxMjM1OTU5WjCBgjELMAkGA1UEBhMCREUxKzApBgNVBAoMIlQtU3lz +dGVtcyBFbnRlcnByaXNlIFNlcnZpY2VzIEdtYkgxHzAdBgNVBAsMFlQtU3lzdGVtcyBUcnVzdCBD +ZW50ZXIxJTAjBgNVBAMMHFQtVGVsZVNlYyBHbG9iYWxSb290IENsYXNzIDIwggEiMA0GCSqGSIb3 +DQEBAQUAA4IBDwAwggEKAoIBAQCqX9obX+hzkeXaXPSi5kfl82hVYAUdAqSzm1nzHoqvNK38DcLZ +SBnuaY/JIPwhqgcZ7bBcrGXHX+0CfHt8LRvWurmAwhiCFoT6ZrAIxlQjgeTNuUk/9k9uN0goOA/F +vudocP05l03Sx5iRUKrERLMjfTlH6VJi1hKTXrcxlkIF+3anHqP1wvzpesVsqXFP6st4vGCvx970 +2cu+fjOlbpSD8DT6IavqjnKgP6TeMFvvhk1qlVtDRKgQFRzlAVfFmPHmBiiRqiDFt1MmUUOyCxGV +WOHAD3bZwI18gfNycJ5v/hqO2V81xrJvNHy+SE/iWjnX2J14np+GPgNeGYtEotXHAgMBAAGjQjBA +MA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBS/WSA2AHmgoCJrjNXy +YdK4LMuCSjANBgkqhkiG9w0BAQsFAAOCAQEAMQOiYQsfdOhyNsZt+U2e+iKo4YFWz827n+qrkRk4 +r6p8FU3ztqONpfSO9kSpp+ghla0+AGIWiPACuvxhI+YzmzB6azZie60EI4RYZeLbK4rnJVM3YlNf +vNoBYimipidx5joifsFvHZVwIEoHNN/q/xWA5brXethbdXwFeilHfkCoMRN3zUA7tFFHei4R40cR +3p1m0IvVVGb6g1XqfMIpiRvpb7PO4gWEyS8+eIVibslfwXhjdFjASBgMmTnrpMwatXlajRWc2BQN +9noHV8cigwUtPJslJj0Ys6lDfMjIq2SPDqO/nBudMNva0Bkuqjzx+zOAduTNrRlPBSeOE6Fuwg== +-----END CERTIFICATE----- + +Atos TrustedRoot 2011 +===================== +-----BEGIN CERTIFICATE----- +MIIDdzCCAl+gAwIBAgIIXDPLYixfszIwDQYJKoZIhvcNAQELBQAwPDEeMBwGA1UEAwwVQXRvcyBU +cnVzdGVkUm9vdCAyMDExMQ0wCwYDVQQKDARBdG9zMQswCQYDVQQGEwJERTAeFw0xMTA3MDcxNDU4 +MzBaFw0zMDEyMzEyMzU5NTlaMDwxHjAcBgNVBAMMFUF0b3MgVHJ1c3RlZFJvb3QgMjAxMTENMAsG +A1UECgwEQXRvczELMAkGA1UEBhMCREUwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCV +hTuXbyo7LjvPpvMpNb7PGKw+qtn4TaA+Gke5vJrf8v7MPkfoepbCJI419KkM/IL9bcFyYie96mvr +54rMVD6QUM+A1JX76LWC1BTFtqlVJVfbsVD2sGBkWXppzwO3bw2+yj5vdHLqqjAqc2K+SZFhyBH+ +DgMq92og3AIVDV4VavzjgsG1xZ1kCWyjWZgHJ8cblithdHFsQ/H3NYkQ4J7sVaE3IqKHBAUsR320 +HLliKWYoyrfhk/WklAOZuXCFteZI6o1Q/NnezG8HDt0Lcp2AMBYHlT8oDv3FdU9T1nSatCQujgKR +z3bFmx5VdJx4IbHwLfELn8LVlhgf8FQieowHAgMBAAGjfTB7MB0GA1UdDgQWBBSnpQaxLKYJYO7R +l+lwrrw7GWzbITAPBgNVHRMBAf8EBTADAQH/MB8GA1UdIwQYMBaAFKelBrEspglg7tGX6XCuvDsZ +bNshMBgGA1UdIAQRMA8wDQYLKwYBBAGwLQMEAQEwDgYDVR0PAQH/BAQDAgGGMA0GCSqGSIb3DQEB +CwUAA4IBAQAmdzTblEiGKkGdLD4GkGDEjKwLVLgfuXvTBznk+j57sj1O7Z8jvZfza1zv7v1Apt+h +k6EKhqzvINB5Ab149xnYJDE0BAGmuhWawyfc2E8PzBhj/5kPDpFrdRbhIfzYJsdHt6bPWHJxfrrh +TZVHO8mvbaG0weyJ9rQPOLXiZNwlz6bb65pcmaHFCN795trV1lpFDMS3wrUU77QR/w4VtfX128a9 +61qn8FYiqTxlVMYVqL2Gns2Dlmh6cYGJ4Qvh6hEbaAjMaZ7snkGeRDImeuKHCnE96+RapNLbxc3G +3mB/ufNPRJLvKrcYPqcZ2Qt9sTdBQrC6YB3y/gkRsPCHe6ed +-----END CERTIFICATE----- + diff --git a/vendor/aws/Guzzle/Http/StaticClient.php b/vendor/aws/Guzzle/Http/StaticClient.php new file mode 100644 index 0000000..dbd4c18 --- /dev/null +++ b/vendor/aws/Guzzle/Http/StaticClient.php @@ -0,0 +1,157 @@ +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); + } +} diff --git a/vendor/aws/Guzzle/Http/Url.php b/vendor/aws/Guzzle/Http/Url.php new file mode 100644 index 0000000..6a4e772 --- /dev/null +++ b/vendor/aws/Guzzle/Http/Url.php @@ -0,0 +1,554 @@ + 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) + { + if ($this->scheme == 'http' && $this->port == 80) { + $this->port = null; + } elseif ($this->scheme == 'https' && $this->port == 443) { + $this->port = null; + } + + $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 != '/' && is_string($relativePath) && strlen($relativePath) > 0) { + // Add a leading slash if needed + if ($relativePath[0] != '/') { + $relativePath = '/' . $relativePath; + } + $this->setPath(str_replace('//', '/', $this->path . $relativePath)); + } + + return $this; + } + + /** + * 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; + } +} diff --git a/vendor/aws/Guzzle/Inflection/Inflector.php b/vendor/aws/Guzzle/Inflection/Inflector.php new file mode 100644 index 0000000..c699773 --- /dev/null +++ b/vendor/aws/Guzzle/Inflection/Inflector.php @@ -0,0 +1,38 @@ + 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); + } + } +} diff --git a/vendor/aws/Guzzle/Inflection/PreComputedInflector.php b/vendor/aws/Guzzle/Inflection/PreComputedInflector.php new file mode 100644 index 0000000..db37e4f --- /dev/null +++ b/vendor/aws/Guzzle/Inflection/PreComputedInflector.php @@ -0,0 +1,59 @@ + 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); + } +} diff --git a/vendor/aws/Guzzle/Iterator/AppendIterator.php b/vendor/aws/Guzzle/Iterator/AppendIterator.php new file mode 100644 index 0000000..1b6bd7e --- /dev/null +++ b/vendor/aws/Guzzle/Iterator/AppendIterator.php @@ -0,0 +1,19 @@ +getArrayIterator()->append($iterator); + } +} diff --git a/vendor/aws/Guzzle/Iterator/ChunkedIterator.php b/vendor/aws/Guzzle/Iterator/ChunkedIterator.php new file mode 100644 index 0000000..d76cdd4 --- /dev/null +++ b/vendor/aws/Guzzle/Iterator/ChunkedIterator.php @@ -0,0 +1,56 @@ +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; + } +} diff --git a/vendor/aws/Guzzle/Iterator/FilterIterator.php b/vendor/aws/Guzzle/Iterator/FilterIterator.php new file mode 100644 index 0000000..b103367 --- /dev/null +++ b/vendor/aws/Guzzle/Iterator/FilterIterator.php @@ -0,0 +1,36 @@ +callback = $callback; + } + + public function accept() + { + return call_user_func($this->callback, $this->current()); + } +} diff --git a/vendor/aws/Guzzle/Iterator/MapIterator.php b/vendor/aws/Guzzle/Iterator/MapIterator.php new file mode 100644 index 0000000..7e586bd --- /dev/null +++ b/vendor/aws/Guzzle/Iterator/MapIterator.php @@ -0,0 +1,34 @@ +callback = $callback; + } + + public function current() + { + return call_user_func($this->callback, parent::current()); + } +} diff --git a/vendor/aws/Guzzle/Iterator/MethodProxyIterator.php b/vendor/aws/Guzzle/Iterator/MethodProxyIterator.php new file mode 100644 index 0000000..de4ab03 --- /dev/null +++ b/vendor/aws/Guzzle/Iterator/MethodProxyIterator.php @@ -0,0 +1,27 @@ +getInnerIterator(); + while ($i instanceof \OuterIterator) { + $i = $i->getInnerIterator(); + } + + return call_user_func_array(array($i, $name), $args); + } +} diff --git a/vendor/aws/Guzzle/Log/AbstractLogAdapter.php b/vendor/aws/Guzzle/Log/AbstractLogAdapter.php new file mode 100644 index 0000000..7f6271b --- /dev/null +++ b/vendor/aws/Guzzle/Log/AbstractLogAdapter.php @@ -0,0 +1,16 @@ +log; + } +} diff --git a/vendor/aws/Guzzle/Log/ArrayLogAdapter.php b/vendor/aws/Guzzle/Log/ArrayLogAdapter.php new file mode 100644 index 0000000..a70fc8d --- /dev/null +++ b/vendor/aws/Guzzle/Log/ArrayLogAdapter.php @@ -0,0 +1,34 @@ +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(); + } +} diff --git a/vendor/aws/Guzzle/Log/ClosureLogAdapter.php b/vendor/aws/Guzzle/Log/ClosureLogAdapter.php new file mode 100644 index 0000000..d4bb73f --- /dev/null +++ b/vendor/aws/Guzzle/Log/ClosureLogAdapter.php @@ -0,0 +1,23 @@ +log = $logObject; + } + + public function log($message, $priority = LOG_INFO, $extras = array()) + { + call_user_func($this->log, $message, $priority, $extras); + } +} diff --git a/vendor/aws/Guzzle/Log/LogAdapterInterface.php b/vendor/aws/Guzzle/Log/LogAdapterInterface.php new file mode 100644 index 0000000..d7ac4ea --- /dev/null +++ b/vendor/aws/Guzzle/Log/LogAdapterInterface.php @@ -0,0 +1,18 @@ +>>>>>>>\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 + ); + } +} diff --git a/vendor/aws/Guzzle/Log/MonologLogAdapter.php b/vendor/aws/Guzzle/Log/MonologLogAdapter.php new file mode 100644 index 0000000..6afe7b6 --- /dev/null +++ b/vendor/aws/Guzzle/Log/MonologLogAdapter.php @@ -0,0 +1,34 @@ + 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, $extras); + } +} diff --git a/vendor/aws/Guzzle/Log/PsrLogAdapter.php b/vendor/aws/Guzzle/Log/PsrLogAdapter.php new file mode 100644 index 0000000..38a2b60 --- /dev/null +++ b/vendor/aws/Guzzle/Log/PsrLogAdapter.php @@ -0,0 +1,36 @@ + 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); + } +} diff --git a/vendor/aws/Guzzle/Log/Zf1LogAdapter.php b/vendor/aws/Guzzle/Log/Zf1LogAdapter.php new file mode 100644 index 0000000..0ea8e3b --- /dev/null +++ b/vendor/aws/Guzzle/Log/Zf1LogAdapter.php @@ -0,0 +1,24 @@ +log = $logObject; + Version::warn(__CLASS__ . ' is deprecated'); + } + + public function log($message, $priority = LOG_INFO, $extras = array()) + { + $this->log->log($message, $priority, $extras); + } +} diff --git a/vendor/aws/Guzzle/Log/Zf2LogAdapter.php b/vendor/aws/Guzzle/Log/Zf2LogAdapter.php new file mode 100644 index 0000000..863f6a1 --- /dev/null +++ b/vendor/aws/Guzzle/Log/Zf2LogAdapter.php @@ -0,0 +1,21 @@ +log = $logObject; + } + + public function log($message, $priority = LOG_INFO, $extras = array()) + { + $this->log->log($priority, $message, $extras); + } +} diff --git a/vendor/aws/Guzzle/Parser/Cookie/CookieParser.php b/vendor/aws/Guzzle/Parser/Cookie/CookieParser.php new file mode 100644 index 0000000..4349eeb --- /dev/null +++ b/vendor/aws/Guzzle/Parser/Cookie/CookieParser.php @@ -0,0 +1,131 @@ + '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' => null, + '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']; + } + + // Check path attribute according RFC6265 http://tools.ietf.org/search/rfc6265#section-5.2.4 + // "If the attribute-value is empty or if the first character of the + // attribute-value is not %x2F ("/"): + // Let cookie-path be the default-path. + // Otherwise: + // Let cookie-path be the attribute-value." + if (!$data['path'] || substr($data['path'], 0, 1) !== '/') { + $data['path'] = $this->getDefaultPath($path); + } + + return $data; + } + + /** + * Get default cookie path according to RFC 6265 + * http://tools.ietf.org/search/rfc6265#section-5.1.4 Paths and Path-Match + * + * @param string $path Request uri-path + * + * @return string + */ + protected function getDefaultPath($path) { + // "The user agent MUST use an algorithm equivalent to the following algorithm + // to compute the default-path of a cookie:" + + // "2. If the uri-path is empty or if the first character of the uri-path is not + // a %x2F ("/") character, output %x2F ("/") and skip the remaining steps. + if (empty($path) || substr($path, 0, 1) !== '/') { + return '/'; + } + + // "3. If the uri-path contains no more than one %x2F ("/") character, output + // %x2F ("/") and skip the remaining step." + if ($path === "/") { + return $path; + } + + $rightSlashPos = strrpos($path, '/'); + if ($rightSlashPos === 0) { + return "/"; + } + + // "4. Output the characters of the uri-path from the first character up to, + // but not including, the right-most %x2F ("/")." + return substr($path, 0, $rightSlashPos); + + } +} diff --git a/vendor/aws/Guzzle/Parser/Cookie/CookieParserInterface.php b/vendor/aws/Guzzle/Parser/Cookie/CookieParserInterface.php new file mode 100644 index 0000000..d21ffe2 --- /dev/null +++ b/vendor/aws/Guzzle/Parser/Cookie/CookieParserInterface.php @@ -0,0 +1,33 @@ + $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; + } +} diff --git a/vendor/aws/Guzzle/Parser/Message/MessageParser.php b/vendor/aws/Guzzle/Parser/Message/MessageParser.php new file mode 100644 index 0000000..efc1aa3 --- /dev/null +++ b/vendor/aws/Guzzle/Parser/Message/MessageParser.php @@ -0,0 +1,110 @@ +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(isset($parts['start_line'][1]) ? $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 + ); + } +} diff --git a/vendor/aws/Guzzle/Parser/Message/MessageParserInterface.php b/vendor/aws/Guzzle/Parser/Message/MessageParserInterface.php new file mode 100644 index 0000000..cc44808 --- /dev/null +++ b/vendor/aws/Guzzle/Parser/Message/MessageParserInterface.php @@ -0,0 +1,27 @@ + $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 + ); + } +} diff --git a/vendor/aws/Guzzle/Parser/ParserRegistry.php b/vendor/aws/Guzzle/Parser/ParserRegistry.php new file mode 100644 index 0000000..f838683 --- /dev/null +++ b/vendor/aws/Guzzle/Parser/ParserRegistry.php @@ -0,0 +1,75 @@ + '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; + } +} diff --git a/vendor/aws/Guzzle/Parser/UriTemplate/PeclUriTemplate.php b/vendor/aws/Guzzle/Parser/UriTemplate/PeclUriTemplate.php new file mode 100644 index 0000000..b0764e8 --- /dev/null +++ b/vendor/aws/Guzzle/Parser/UriTemplate/PeclUriTemplate.php @@ -0,0 +1,26 @@ + 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); + } +} diff --git a/vendor/aws/Guzzle/Parser/UriTemplate/UriTemplateInterface.php b/vendor/aws/Guzzle/Parser/UriTemplate/UriTemplateInterface.php new file mode 100644 index 0000000..c81d515 --- /dev/null +++ b/vendor/aws/Guzzle/Parser/UriTemplate/UriTemplateInterface.php @@ -0,0 +1,21 @@ +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; + } +} diff --git a/vendor/aws/Guzzle/Parser/Url/UrlParserInterface.php b/vendor/aws/Guzzle/Parser/Url/UrlParserInterface.php new file mode 100644 index 0000000..89ac4b3 --- /dev/null +++ b/vendor/aws/Guzzle/Parser/Url/UrlParserInterface.php @@ -0,0 +1,19 @@ + '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'); + } +} diff --git a/vendor/aws/Guzzle/Plugin/Backoff/AbstractBackoffStrategy.php b/vendor/aws/Guzzle/Plugin/Backoff/AbstractBackoffStrategy.php new file mode 100644 index 0000000..0a85983 --- /dev/null +++ b/vendor/aws/Guzzle/Plugin/Backoff/AbstractBackoffStrategy.php @@ -0,0 +1,91 @@ +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 + ); +} diff --git a/vendor/aws/Guzzle/Plugin/Backoff/AbstractErrorCodeBackoffStrategy.php b/vendor/aws/Guzzle/Plugin/Backoff/AbstractErrorCodeBackoffStrategy.php new file mode 100644 index 0000000..6ebee6c --- /dev/null +++ b/vendor/aws/Guzzle/Plugin/Backoff/AbstractErrorCodeBackoffStrategy.php @@ -0,0 +1,40 @@ +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; + } +} diff --git a/vendor/aws/Guzzle/Plugin/Backoff/BackoffLogger.php b/vendor/aws/Guzzle/Plugin/Backoff/BackoffLogger.php new file mode 100644 index 0000000..ec54c28 --- /dev/null +++ b/vendor/aws/Guzzle/Plugin/Backoff/BackoffLogger.php @@ -0,0 +1,76 @@ +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'] + ) + )); + } +} diff --git a/vendor/aws/Guzzle/Plugin/Backoff/BackoffPlugin.php b/vendor/aws/Guzzle/Plugin/Backoff/BackoffPlugin.php new file mode 100644 index 0000000..99ace05 --- /dev/null +++ b/vendor/aws/Guzzle/Plugin/Backoff/BackoffPlugin.php @@ -0,0 +1,126 @@ +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); + } + } +} diff --git a/vendor/aws/Guzzle/Plugin/Backoff/BackoffStrategyInterface.php b/vendor/aws/Guzzle/Plugin/Backoff/BackoffStrategyInterface.php new file mode 100644 index 0000000..4e590db --- /dev/null +++ b/vendor/aws/Guzzle/Plugin/Backoff/BackoffStrategyInterface.php @@ -0,0 +1,30 @@ +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); + } +} diff --git a/vendor/aws/Guzzle/Plugin/Backoff/ConstantBackoffStrategy.php b/vendor/aws/Guzzle/Plugin/Backoff/ConstantBackoffStrategy.php new file mode 100644 index 0000000..061d2a4 --- /dev/null +++ b/vendor/aws/Guzzle/Plugin/Backoff/ConstantBackoffStrategy.php @@ -0,0 +1,34 @@ +delay = $delay; + } + + public function makesDecision() + { + return false; + } + + protected function getDelay($retries, RequestInterface $request, Response $response = null, HttpException $e = null) + { + return $this->delay; + } +} diff --git a/vendor/aws/Guzzle/Plugin/Backoff/CurlBackoffStrategy.php b/vendor/aws/Guzzle/Plugin/Backoff/CurlBackoffStrategy.php new file mode 100644 index 0000000..a584ed4 --- /dev/null +++ b/vendor/aws/Guzzle/Plugin/Backoff/CurlBackoffStrategy.php @@ -0,0 +1,28 @@ +errorCodes[$e->getErrorNo()]) ? true : null; + } + } +} diff --git a/vendor/aws/Guzzle/Plugin/Backoff/ExponentialBackoffStrategy.php b/vendor/aws/Guzzle/Plugin/Backoff/ExponentialBackoffStrategy.php new file mode 100644 index 0000000..fb2912d --- /dev/null +++ b/vendor/aws/Guzzle/Plugin/Backoff/ExponentialBackoffStrategy.php @@ -0,0 +1,25 @@ +isSuccessful()) { + return false; + } else { + return isset($this->errorCodes[$response->getStatusCode()]) ? true : null; + } + } + } +} diff --git a/vendor/aws/Guzzle/Plugin/Backoff/LinearBackoffStrategy.php b/vendor/aws/Guzzle/Plugin/Backoff/LinearBackoffStrategy.php new file mode 100644 index 0000000..b35e8a4 --- /dev/null +++ b/vendor/aws/Guzzle/Plugin/Backoff/LinearBackoffStrategy.php @@ -0,0 +1,36 @@ +step = $step; + } + + public function makesDecision() + { + return false; + } + + protected function getDelay($retries, RequestInterface $request, Response $response = null, HttpException $e = null) + { + return $retries * $this->step; + } +} diff --git a/vendor/aws/Guzzle/Plugin/Backoff/ReasonPhraseBackoffStrategy.php b/vendor/aws/Guzzle/Plugin/Backoff/ReasonPhraseBackoffStrategy.php new file mode 100644 index 0000000..4fd73fe --- /dev/null +++ b/vendor/aws/Guzzle/Plugin/Backoff/ReasonPhraseBackoffStrategy.php @@ -0,0 +1,25 @@ +errorCodes[$response->getReasonPhrase()]) ? true : null; + } + } +} diff --git a/vendor/aws/Guzzle/Plugin/Backoff/TruncatedBackoffStrategy.php b/vendor/aws/Guzzle/Plugin/Backoff/TruncatedBackoffStrategy.php new file mode 100644 index 0000000..3608f35 --- /dev/null +++ b/vendor/aws/Guzzle/Plugin/Backoff/TruncatedBackoffStrategy.php @@ -0,0 +1,36 @@ +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; + } +} diff --git a/vendor/aws/Guzzle/Plugin/Cache/CacheKeyProviderInterface.php b/vendor/aws/Guzzle/Plugin/Cache/CacheKeyProviderInterface.php new file mode 100644 index 0000000..7790f88 --- /dev/null +++ b/vendor/aws/Guzzle/Plugin/Cache/CacheKeyProviderInterface.php @@ -0,0 +1,11 @@ + 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)); + } + } + } +} diff --git a/vendor/aws/Guzzle/Plugin/Cache/CacheStorageInterface.php b/vendor/aws/Guzzle/Plugin/Cache/CacheStorageInterface.php new file mode 100644 index 0000000..f3d9154 --- /dev/null +++ b/vendor/aws/Guzzle/Plugin/Cache/CacheStorageInterface.php @@ -0,0 +1,43 @@ +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); + } +} diff --git a/vendor/aws/Guzzle/Plugin/Cache/CanCacheStrategyInterface.php b/vendor/aws/Guzzle/Plugin/Cache/CanCacheStrategyInterface.php new file mode 100644 index 0000000..6e01a8e --- /dev/null +++ b/vendor/aws/Guzzle/Plugin/Cache/CanCacheStrategyInterface.php @@ -0,0 +1,30 @@ +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; + } +} diff --git a/vendor/aws/Guzzle/Plugin/Cache/DefaultCacheStorage.php b/vendor/aws/Guzzle/Plugin/Cache/DefaultCacheStorage.php new file mode 100644 index 0000000..26d7a8b --- /dev/null +++ b/vendor/aws/Guzzle/Plugin/Cache/DefaultCacheStorage.php @@ -0,0 +1,266 @@ +cache = CacheAdapterFactory::fromCache($cache); + $this->defaultTtl = $defaultTtl; + $this->keyPrefix = $keyPrefix; + } + + public function cache(RequestInterface $request, Response $response) + { + $currentTime = time(); + + $overrideTtl = $request->getParams()->get('cache.override_ttl'); + if ($overrideTtl) { + $ttl = $overrideTtl; + } else { + $maxAge = $response->getMaxAge(); + if ($maxAge !== null) { + $ttl = $maxAge; + } else { + $ttl = $this->defaultTtl; + } + } + + if ($cacheControl = $response->getHeader('Cache-Control')) { + $stale = $cacheControl->getDirective('stale-if-error'); + if ($stale === true) { + $ttl += $ttl; + } else if (is_numeric($stale)) { + $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; + } +} diff --git a/vendor/aws/Guzzle/Plugin/Cache/DefaultCanCacheStrategy.php b/vendor/aws/Guzzle/Plugin/Cache/DefaultCanCacheStrategy.php new file mode 100644 index 0000000..3ca1fbf --- /dev/null +++ b/vendor/aws/Guzzle/Plugin/Cache/DefaultCanCacheStrategy.php @@ -0,0 +1,32 @@ +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(); + } +} diff --git a/vendor/aws/Guzzle/Plugin/Cache/DefaultRevalidation.php b/vendor/aws/Guzzle/Plugin/Cache/DefaultRevalidation.php new file mode 100644 index 0000000..af33234 --- /dev/null +++ b/vendor/aws/Guzzle/Plugin/Cache/DefaultRevalidation.php @@ -0,0 +1,174 @@ +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'); + + if ($response->getLastModified()) { + $revalidate->setHeader('If-Modified-Since', $response->getLastModified()); + } + + 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; + } +} diff --git a/vendor/aws/Guzzle/Plugin/Cache/DenyRevalidation.php b/vendor/aws/Guzzle/Plugin/Cache/DenyRevalidation.php new file mode 100644 index 0000000..88b86f3 --- /dev/null +++ b/vendor/aws/Guzzle/Plugin/Cache/DenyRevalidation.php @@ -0,0 +1,19 @@ + '', + '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) + { + // RFC6265 http://tools.ietf.org/search/rfc6265#section-5.1.4 + // A request-path path-matches a given cookie-path if at least one of + // the following conditions holds: + + // o The cookie-path and the request-path are identical. + if ($path == $this->getPath()) { + return true; + } + + $pos = stripos($path, $this->getPath()); + if ($pos === 0) { + // o The cookie-path is a prefix of the request-path, and the last + // character of the cookie-path is %x2F ("/"). + if (substr($this->getPath(), -1, 1) === "/") { + return true; + } + + // o The cookie-path is a prefix of the request-path, and the first + // character of the request-path that is not included in the cookie- + // path is a %x2F ("/") character. + if (substr($path, strlen($this->getPath()), 1) === "/") { + return true; + } + } + + return false; + } + + /** + * 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; + } +} diff --git a/vendor/aws/Guzzle/Plugin/Cookie/CookieJar/ArrayCookieJar.php b/vendor/aws/Guzzle/Plugin/Cookie/CookieJar/ArrayCookieJar.php new file mode 100644 index 0000000..6b67503 --- /dev/null +++ b/vendor/aws/Guzzle/Plugin/Cookie/CookieJar/ArrayCookieJar.php @@ -0,0 +1,237 @@ +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 { + $this->removeCookieIfEmpty($cookie); + 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; + } + + /** + * If a cookie already exists and the server asks to set it again with a null value, the + * cookie must be deleted. + * + * @param \Guzzle\Plugin\Cookie\Cookie $cookie + */ + private function removeCookieIfEmpty(Cookie $cookie) + { + $cookieValue = $cookie->getValue(); + if ($cookieValue === null || $cookieValue === '') { + $this->remove($cookie->getDomain(), $cookie->getPath(), $cookie->getName()); + } + } +} diff --git a/vendor/aws/Guzzle/Plugin/Cookie/CookieJar/CookieJarInterface.php b/vendor/aws/Guzzle/Plugin/Cookie/CookieJar/CookieJarInterface.php new file mode 100644 index 0000000..7faa7d2 --- /dev/null +++ b/vendor/aws/Guzzle/Plugin/Cookie/CookieJar/CookieJarInterface.php @@ -0,0 +1,85 @@ +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(); + } +} diff --git a/vendor/aws/Guzzle/Plugin/Cookie/CookiePlugin.php b/vendor/aws/Guzzle/Plugin/Cookie/CookiePlugin.php new file mode 100644 index 0000000..df3210e --- /dev/null +++ b/vendor/aws/Guzzle/Plugin/Cookie/CookiePlugin.php @@ -0,0 +1,70 @@ +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']); + } +} diff --git a/vendor/aws/Guzzle/Plugin/Cookie/Exception/InvalidCookieException.php b/vendor/aws/Guzzle/Plugin/Cookie/Exception/InvalidCookieException.php new file mode 100644 index 0000000..b1fa6fd --- /dev/null +++ b/vendor/aws/Guzzle/Plugin/Cookie/Exception/InvalidCookieException.php @@ -0,0 +1,7 @@ +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); + } +} diff --git a/vendor/aws/Guzzle/Plugin/ErrorResponse/ErrorResponseExceptionInterface.php b/vendor/aws/Guzzle/Plugin/ErrorResponse/ErrorResponseExceptionInterface.php new file mode 100644 index 0000000..5dce8bd --- /dev/null +++ b/vendor/aws/Guzzle/Plugin/ErrorResponse/ErrorResponseExceptionInterface.php @@ -0,0 +1,22 @@ + 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 (!(in_array($errorClassInterface, class_implements($className)))) { + throw new ErrorResponseException("{$className} must implement {$errorClassInterface}"); + } + throw $className::fromCommand($command, $response); + } + }; + } +} diff --git a/vendor/aws/Guzzle/Plugin/ErrorResponse/Exception/ErrorResponseException.php b/vendor/aws/Guzzle/Plugin/ErrorResponse/Exception/ErrorResponseException.php new file mode 100644 index 0000000..1d89e40 --- /dev/null +++ b/vendor/aws/Guzzle/Plugin/ErrorResponse/Exception/ErrorResponseException.php @@ -0,0 +1,7 @@ + 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']); + } +} diff --git a/vendor/aws/Guzzle/Plugin/Log/LogPlugin.php b/vendor/aws/Guzzle/Plugin/Log/LogPlugin.php new file mode 100644 index 0000000..cabdea8 --- /dev/null +++ b/vendor/aws/Guzzle/Plugin/Log/LogPlugin.php @@ -0,0 +1,161 @@ +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 + )); + } +} diff --git a/vendor/aws/Guzzle/Plugin/Md5/CommandContentMd5Plugin.php b/vendor/aws/Guzzle/Plugin/Md5/CommandContentMd5Plugin.php new file mode 100644 index 0000000..8512424 --- /dev/null +++ b/vendor/aws/Guzzle/Plugin/Md5/CommandContentMd5Plugin.php @@ -0,0 +1,57 @@ +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)); + } + } +} diff --git a/vendor/aws/Guzzle/Plugin/Md5/Md5ValidatorPlugin.php b/vendor/aws/Guzzle/Plugin/Md5/Md5ValidatorPlugin.php new file mode 100644 index 0000000..5d7a378 --- /dev/null +++ b/vendor/aws/Guzzle/Plugin/Md5/Md5ValidatorPlugin.php @@ -0,0 +1,88 @@ +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})." + ); + } + } +} diff --git a/vendor/aws/Guzzle/Plugin/Mock/MockPlugin.php b/vendor/aws/Guzzle/Plugin/Mock/MockPlugin.php new file mode 100644 index 0000000..2440578 --- /dev/null +++ b/vendor/aws/Guzzle/Plugin/Mock/MockPlugin.php @@ -0,0 +1,245 @@ +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 + * @throws \OutOfBoundsException When queue is empty + */ + public function onRequestBeforeSend(Event $event) + { + if (!$this->queue) { + throw new \OutOfBoundsException('Mock queue is empty'); + } + + $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); + } +} diff --git a/vendor/aws/Guzzle/Plugin/Oauth/OauthPlugin.php b/vendor/aws/Guzzle/Plugin/Oauth/OauthPlugin.php new file mode 100644 index 0000000..95e0c3e --- /dev/null +++ b/vendor/aws/Guzzle/Plugin/Oauth/OauthPlugin.php @@ -0,0 +1,306 @@ +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 = clone $request->getQuery(); + $parameterString->replace($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(); + uksort($params, 'strcmp'); + + 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; + } +} diff --git a/vendor/aws/Guzzle/Service/AbstractConfigLoader.php b/vendor/aws/Guzzle/Service/AbstractConfigLoader.php new file mode 100644 index 0000000..cd06f57 --- /dev/null +++ b/vendor/aws/Guzzle/Service/AbstractConfigLoader.php @@ -0,0 +1,177 @@ + '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); + } +} diff --git a/vendor/aws/Guzzle/Service/Builder/ServiceBuilder.php b/vendor/aws/Guzzle/Service/Builder/ServiceBuilder.php new file mode 100644 index 0000000..38150db --- /dev/null +++ b/vendor/aws/Guzzle/Service/Builder/ServiceBuilder.php @@ -0,0 +1,189 @@ +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); + } +} diff --git a/vendor/aws/Guzzle/Service/Builder/ServiceBuilderInterface.php b/vendor/aws/Guzzle/Service/Builder/ServiceBuilderInterface.php new file mode 100644 index 0000000..4fc310a --- /dev/null +++ b/vendor/aws/Guzzle/Service/Builder/ServiceBuilderInterface.php @@ -0,0 +1,40 @@ + &$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; + } +} diff --git a/vendor/aws/Guzzle/Service/CachingConfigLoader.php b/vendor/aws/Guzzle/Service/CachingConfigLoader.php new file mode 100644 index 0000000..26f8360 --- /dev/null +++ b/vendor/aws/Guzzle/Service/CachingConfigLoader.php @@ -0,0 +1,46 @@ +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; + } +} diff --git a/vendor/aws/Guzzle/Service/Client.php b/vendor/aws/Guzzle/Service/Client.php new file mode 100644 index 0000000..3e5f8e5 --- /dev/null +++ b/vendor/aws/Guzzle/Service/Client.php @@ -0,0 +1,297 @@ +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 ($this->getCommandFactory() && $this->getCommandFactory() instanceof CompositeFactory) { + $this->commandFactory->add(new Command\Factory\ServiceDescriptionFactory($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'); + } +} diff --git a/vendor/aws/Guzzle/Service/ClientInterface.php b/vendor/aws/Guzzle/Service/ClientInterface.php new file mode 100644 index 0000000..814154f --- /dev/null +++ b/vendor/aws/Guzzle/Service/ClientInterface.php @@ -0,0 +1,68 @@ +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(); + } +} diff --git a/vendor/aws/Guzzle/Service/Command/ClosureCommand.php b/vendor/aws/Guzzle/Service/Command/ClosureCommand.php new file mode 100644 index 0000000..cb6ac40 --- /dev/null +++ b/vendor/aws/Guzzle/Service/Command/ClosureCommand.php @@ -0,0 +1,41 @@ +request = $closure($this, $this->operation); + + if (!$this->request || !$this->request instanceof RequestInterface) { + throw new UnexpectedValueException('Closure command did not return a RequestInterface object'); + } + } +} diff --git a/vendor/aws/Guzzle/Service/Command/CommandInterface.php b/vendor/aws/Guzzle/Service/Command/CommandInterface.php new file mode 100644 index 0000000..fbb61d2 --- /dev/null +++ b/vendor/aws/Guzzle/Service/Command/CommandInterface.php @@ -0,0 +1,128 @@ +stopPropagation(); + } + + /** + * Get the created object + * + * @return mixed + */ + public function getResult() + { + return $this['result']; + } +} diff --git a/vendor/aws/Guzzle/Service/Command/DefaultRequestSerializer.php b/vendor/aws/Guzzle/Service/Command/DefaultRequestSerializer.php new file mode 100644 index 0000000..2dc4acd --- /dev/null +++ b/vendor/aws/Guzzle/Service/Command/DefaultRequestSerializer.php @@ -0,0 +1,169 @@ +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); + } +} diff --git a/vendor/aws/Guzzle/Service/Command/DefaultResponseParser.php b/vendor/aws/Guzzle/Service/Command/DefaultResponseParser.php new file mode 100644 index 0000000..4fe3803 --- /dev/null +++ b/vendor/aws/Guzzle/Service/Command/DefaultResponseParser.php @@ -0,0 +1,55 @@ +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; + } +} diff --git a/vendor/aws/Guzzle/Service/Command/Factory/AliasFactory.php b/vendor/aws/Guzzle/Service/Command/Factory/AliasFactory.php new file mode 100644 index 0000000..1c5ce07 --- /dev/null +++ b/vendor/aws/Guzzle/Service/Command/Factory/AliasFactory.php @@ -0,0 +1,39 @@ +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; + } + } + } +} diff --git a/vendor/aws/Guzzle/Service/Command/Factory/CompositeFactory.php b/vendor/aws/Guzzle/Service/Command/Factory/CompositeFactory.php new file mode 100644 index 0000000..8c46983 --- /dev/null +++ b/vendor/aws/Guzzle/Service/Command/Factory/CompositeFactory.php @@ -0,0 +1,154 @@ +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); + } +} diff --git a/vendor/aws/Guzzle/Service/Command/Factory/ConcreteClassFactory.php b/vendor/aws/Guzzle/Service/Command/Factory/ConcreteClassFactory.php new file mode 100644 index 0000000..0e93dea --- /dev/null +++ b/vendor/aws/Guzzle/Service/Command/Factory/ConcreteClassFactory.php @@ -0,0 +1,47 @@ +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); + } + } +} diff --git a/vendor/aws/Guzzle/Service/Command/Factory/FactoryInterface.php b/vendor/aws/Guzzle/Service/Command/Factory/FactoryInterface.php new file mode 100644 index 0000000..35c299d --- /dev/null +++ b/vendor/aws/Guzzle/Service/Command/Factory/FactoryInterface.php @@ -0,0 +1,21 @@ +map = $map; + } + + public function factory($name, array $args = array()) + { + if (isset($this->map[$name])) { + $class = $this->map[$name]; + + return new $class($args); + } + } +} diff --git a/vendor/aws/Guzzle/Service/Command/Factory/ServiceDescriptionFactory.php b/vendor/aws/Guzzle/Service/Command/Factory/ServiceDescriptionFactory.php new file mode 100644 index 0000000..b943a5b --- /dev/null +++ b/vendor/aws/Guzzle/Service/Command/Factory/ServiceDescriptionFactory.php @@ -0,0 +1,71 @@ +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); + } + } +} diff --git a/vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/AbstractRequestVisitor.php b/vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/AbstractRequestVisitor.php new file mode 100644 index 0000000..adcfca1 --- /dev/null +++ b/vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/AbstractRequestVisitor.php @@ -0,0 +1,69 @@ +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); + } +} diff --git a/vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/BodyVisitor.php b/vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/BodyVisitor.php new file mode 100644 index 0000000..168d780 --- /dev/null +++ b/vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/BodyVisitor.php @@ -0,0 +1,58 @@ +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'); + } + } + } + } +} diff --git a/vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/HeaderVisitor.php b/vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/HeaderVisitor.php new file mode 100644 index 0000000..2a53754 --- /dev/null +++ b/vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/HeaderVisitor.php @@ -0,0 +1,44 @@ +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); + } + } +} diff --git a/vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/JsonVisitor.php b/vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/JsonVisitor.php new file mode 100644 index 0000000..757e1c5 --- /dev/null +++ b/vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/JsonVisitor.php @@ -0,0 +1,63 @@ +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]); + } + } +} diff --git a/vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/PostFieldVisitor.php b/vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/PostFieldVisitor.php new file mode 100644 index 0000000..975850b --- /dev/null +++ b/vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/PostFieldVisitor.php @@ -0,0 +1,18 @@ +setPostField($param->getWireName(), $this->prepareValue($value, $param)); + } +} diff --git a/vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/PostFileVisitor.php b/vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/PostFileVisitor.php new file mode 100644 index 0000000..0853ebe --- /dev/null +++ b/vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/PostFileVisitor.php @@ -0,0 +1,24 @@ +filter($value); + if ($value instanceof PostFileInterface) { + $request->addPostFile($value); + } else { + $request->addPostFile($param->getWireName(), $value); + } + } +} diff --git a/vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/QueryVisitor.php b/vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/QueryVisitor.php new file mode 100644 index 0000000..315877a --- /dev/null +++ b/vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/QueryVisitor.php @@ -0,0 +1,18 @@ +getQuery()->set($param->getWireName(), $this->prepareValue($value, $param)); + } +} diff --git a/vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/RequestVisitorInterface.php b/vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/RequestVisitorInterface.php new file mode 100644 index 0000000..14e0b2d --- /dev/null +++ b/vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/RequestVisitorInterface.php @@ -0,0 +1,31 @@ +setResponseBody($value); + } +} diff --git a/vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/XmlVisitor.php b/vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/XmlVisitor.php new file mode 100644 index 0000000..5b71487 --- /dev/null +++ b/vendor/aws/Guzzle/Service/Command/LocationVisitor/Request/XmlVisitor.php @@ -0,0 +1,252 @@ +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']); + } + } +} diff --git a/vendor/aws/Guzzle/Service/Command/LocationVisitor/Response/AbstractResponseVisitor.php b/vendor/aws/Guzzle/Service/Command/LocationVisitor/Response/AbstractResponseVisitor.php new file mode 100644 index 0000000..d87eeb9 --- /dev/null +++ b/vendor/aws/Guzzle/Service/Command/LocationVisitor/Response/AbstractResponseVisitor.php @@ -0,0 +1,26 @@ +getName()] = $param->filter($response->getBody()); + } +} diff --git a/vendor/aws/Guzzle/Service/Command/LocationVisitor/Response/HeaderVisitor.php b/vendor/aws/Guzzle/Service/Command/LocationVisitor/Response/HeaderVisitor.php new file mode 100644 index 0000000..0f8737c --- /dev/null +++ b/vendor/aws/Guzzle/Service/Command/LocationVisitor/Response/HeaderVisitor.php @@ -0,0 +1,50 @@ +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; + } + } + } + } +} diff --git a/vendor/aws/Guzzle/Service/Command/LocationVisitor/Response/JsonVisitor.php b/vendor/aws/Guzzle/Service/Command/LocationVisitor/Response/JsonVisitor.php new file mode 100644 index 0000000..a609ebd --- /dev/null +++ b/vendor/aws/Guzzle/Service/Command/LocationVisitor/Response/JsonVisitor.php @@ -0,0 +1,93 @@ +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); + } +} diff --git a/vendor/aws/Guzzle/Service/Command/LocationVisitor/Response/ReasonPhraseVisitor.php b/vendor/aws/Guzzle/Service/Command/LocationVisitor/Response/ReasonPhraseVisitor.php new file mode 100644 index 0000000..1b10ebc --- /dev/null +++ b/vendor/aws/Guzzle/Service/Command/LocationVisitor/Response/ReasonPhraseVisitor.php @@ -0,0 +1,23 @@ +getName()] = $response->getReasonPhrase(); + } +} diff --git a/vendor/aws/Guzzle/Service/Command/LocationVisitor/Response/ResponseVisitorInterface.php b/vendor/aws/Guzzle/Service/Command/LocationVisitor/Response/ResponseVisitorInterface.php new file mode 100644 index 0000000..033f40c --- /dev/null +++ b/vendor/aws/Guzzle/Service/Command/LocationVisitor/Response/ResponseVisitorInterface.php @@ -0,0 +1,46 @@ +getName()] = $response->getStatusCode(); + } +} diff --git a/vendor/aws/Guzzle/Service/Command/LocationVisitor/Response/XmlVisitor.php b/vendor/aws/Guzzle/Service/Command/LocationVisitor/Response/XmlVisitor.php new file mode 100644 index 0000000..bb7124b --- /dev/null +++ b/vendor/aws/Guzzle/Service/Command/LocationVisitor/Response/XmlVisitor.php @@ -0,0 +1,151 @@ +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); + } elseif ($type == 'string' && gettype($value) == 'array') { + $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']); + } + } + } +} diff --git a/vendor/aws/Guzzle/Service/Command/LocationVisitor/VisitorFlyweight.php b/vendor/aws/Guzzle/Service/Command/LocationVisitor/VisitorFlyweight.php new file mode 100644 index 0000000..74cb628 --- /dev/null +++ b/vendor/aws/Guzzle/Service/Command/LocationVisitor/VisitorFlyweight.php @@ -0,0 +1,138 @@ + '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]; + } +} diff --git a/vendor/aws/Guzzle/Service/Command/OperationCommand.php b/vendor/aws/Guzzle/Service/Command/OperationCommand.php new file mode 100644 index 0000000..0748b5a --- /dev/null +++ b/vendor/aws/Guzzle/Service/Command/OperationCommand.php @@ -0,0 +1,89 @@ +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); + } +} diff --git a/vendor/aws/Guzzle/Service/Command/OperationResponseParser.php b/vendor/aws/Guzzle/Service/Command/OperationResponseParser.php new file mode 100644 index 0000000..ca00bc0 --- /dev/null +++ b/vendor/aws/Guzzle/Service/Command/OperationResponseParser.php @@ -0,0 +1,195 @@ +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); + } + } + } +} diff --git a/vendor/aws/Guzzle/Service/Command/RequestSerializerInterface.php b/vendor/aws/Guzzle/Service/Command/RequestSerializerInterface.php new file mode 100644 index 0000000..60b9334 --- /dev/null +++ b/vendor/aws/Guzzle/Service/Command/RequestSerializerInterface.php @@ -0,0 +1,21 @@ + 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), 'reason' (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; + } + } +} diff --git a/vendor/aws/Guzzle/Service/Description/OperationInterface.php b/vendor/aws/Guzzle/Service/Description/OperationInterface.php new file mode 100644 index 0000000..4de41bd --- /dev/null +++ b/vendor/aws/Guzzle/Service/Description/OperationInterface.php @@ -0,0 +1,159 @@ +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; + } +} diff --git a/vendor/aws/Guzzle/Service/Description/SchemaFormatter.php b/vendor/aws/Guzzle/Service/Description/SchemaFormatter.php new file mode 100644 index 0000000..7f47fc9 --- /dev/null +++ b/vendor/aws/Guzzle/Service/Description/SchemaFormatter.php @@ -0,0 +1,156 @@ +setTimezone(self::getUtcTimeZone())->format($format); + } + + throw new InvalidArgumentException('Date/Time values must be either a string, integer, or DateTime object'); + } +} diff --git a/vendor/aws/Guzzle/Service/Description/SchemaValidator.php b/vendor/aws/Guzzle/Service/Description/SchemaValidator.php new file mode 100644 index 0000000..b045422 --- /dev/null +++ b/vendor/aws/Guzzle/Service/Description/SchemaValidator.php @@ -0,0 +1,291 @@ +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 + foreach ($diff as $prop) { + $this->errors[] = sprintf('%s[%s] is not an allowed property', $path, $prop); + } + } + } + } + + // 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; + } +} diff --git a/vendor/aws/Guzzle/Service/Description/ServiceDescription.php b/vendor/aws/Guzzle/Service/Description/ServiceDescription.php new file mode 100644 index 0000000..286e65e --- /dev/null +++ b/vendor/aws/Guzzle/Service/Description/ServiceDescription.php @@ -0,0 +1,271 @@ +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]; + } + } +} diff --git a/vendor/aws/Guzzle/Service/Description/ServiceDescriptionInterface.php b/vendor/aws/Guzzle/Service/Description/ServiceDescriptionInterface.php new file mode 100644 index 0000000..5983e58 --- /dev/null +++ b/vendor/aws/Guzzle/Service/Description/ServiceDescriptionInterface.php @@ -0,0 +1,106 @@ + $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; + } +} diff --git a/vendor/aws/Guzzle/Service/Description/ValidatorInterface.php b/vendor/aws/Guzzle/Service/Description/ValidatorInterface.php new file mode 100644 index 0000000..94ca77d --- /dev/null +++ b/vendor/aws/Guzzle/Service/Description/ValidatorInterface.php @@ -0,0 +1,28 @@ +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()); + } +} diff --git a/vendor/aws/Guzzle/Service/Exception/DescriptionBuilderException.php b/vendor/aws/Guzzle/Service/Exception/DescriptionBuilderException.php new file mode 100644 index 0000000..1407e56 --- /dev/null +++ b/vendor/aws/Guzzle/Service/Exception/DescriptionBuilderException.php @@ -0,0 +1,7 @@ +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; + } +} diff --git a/vendor/aws/Guzzle/Service/Exception/ResponseClassException.php b/vendor/aws/Guzzle/Service/Exception/ResponseClassException.php new file mode 100644 index 0000000..d59ff21 --- /dev/null +++ b/vendor/aws/Guzzle/Service/Exception/ResponseClassException.php @@ -0,0 +1,9 @@ +errors = $errors; + } + + /** + * Get any validation errors + * + * @return array + */ + public function getErrors() + { + return $this->errors; + } +} diff --git a/vendor/aws/Guzzle/Service/Resource/AbstractResourceIteratorFactory.php b/vendor/aws/Guzzle/Service/Resource/AbstractResourceIteratorFactory.php new file mode 100644 index 0000000..21140e7 --- /dev/null +++ b/vendor/aws/Guzzle/Service/Resource/AbstractResourceIteratorFactory.php @@ -0,0 +1,37 @@ +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); +} diff --git a/vendor/aws/Guzzle/Service/Resource/CompositeResourceIteratorFactory.php b/vendor/aws/Guzzle/Service/Resource/CompositeResourceIteratorFactory.php new file mode 100644 index 0000000..2efc133 --- /dev/null +++ b/vendor/aws/Guzzle/Service/Resource/CompositeResourceIteratorFactory.php @@ -0,0 +1,67 @@ +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; + } +} diff --git a/vendor/aws/Guzzle/Service/Resource/MapResourceIteratorFactory.php b/vendor/aws/Guzzle/Service/Resource/MapResourceIteratorFactory.php new file mode 100644 index 0000000..c71ca9d --- /dev/null +++ b/vendor/aws/Guzzle/Service/Resource/MapResourceIteratorFactory.php @@ -0,0 +1,34 @@ +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; + } +} diff --git a/vendor/aws/Guzzle/Service/Resource/Model.php b/vendor/aws/Guzzle/Service/Resource/Model.php new file mode 100644 index 0000000..2322434 --- /dev/null +++ b/vendor/aws/Guzzle/Service/Resource/Model.php @@ -0,0 +1,64 @@ +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"; + } +} diff --git a/vendor/aws/Guzzle/Service/Resource/ResourceIterator.php b/vendor/aws/Guzzle/Service/Resource/ResourceIterator.php new file mode 100644 index 0000000..e141524 --- /dev/null +++ b/vendor/aws/Guzzle/Service/Resource/ResourceIterator.php @@ -0,0 +1,254 @@ +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(); +} diff --git a/vendor/aws/Guzzle/Service/Resource/ResourceIteratorApplyBatched.php b/vendor/aws/Guzzle/Service/Resource/ResourceIteratorApplyBatched.php new file mode 100644 index 0000000..6aa3615 --- /dev/null +++ b/vendor/aws/Guzzle/Service/Resource/ResourceIteratorApplyBatched.php @@ -0,0 +1,111 @@ +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; + } +} diff --git a/vendor/aws/Guzzle/Service/Resource/ResourceIteratorClassFactory.php b/vendor/aws/Guzzle/Service/Resource/ResourceIteratorClassFactory.php new file mode 100644 index 0000000..2fd9980 --- /dev/null +++ b/vendor/aws/Guzzle/Service/Resource/ResourceIteratorClassFactory.php @@ -0,0 +1,60 @@ + 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; + } +} diff --git a/vendor/aws/Guzzle/Service/Resource/ResourceIteratorFactoryInterface.php b/vendor/aws/Guzzle/Service/Resource/ResourceIteratorFactoryInterface.php new file mode 100644 index 0000000..8b4e8db --- /dev/null +++ b/vendor/aws/Guzzle/Service/Resource/ResourceIteratorFactoryInterface.php @@ -0,0 +1,30 @@ +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) + { + $errors = null; + set_error_handler(function ($_, $msg, $file, $line) use (&$errors) { + $errors[] = array( + 'message' => $msg, + 'file' => $file, + 'line' => $line + ); + return true; + }); + $resource = call_user_func($callback); + restore_error_handler(); + + if (!$resource) { + $message = 'Error creating resource. '; + foreach ($errors as $err) { + foreach ($err as $key => $value) { + $message .= "[$key] $value" . PHP_EOL; + } + } + throw new RuntimeException(trim($message)); + } + + return $resource; + } +} diff --git a/vendor/aws/Guzzle/Stream/Stream.php b/vendor/aws/Guzzle/Stream/Stream.php new file mode 100644 index 0000000..12bed26 --- /dev/null +++ b/vendor/aws/Guzzle/Stream/Stream.php @@ -0,0 +1,289 @@ + 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 (!$stream->feof()) { + hash_update($ctx, $stream->read(8192)); + } + + $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']]); + } +} diff --git a/vendor/aws/Guzzle/Stream/StreamInterface.php b/vendor/aws/Guzzle/Stream/StreamInterface.php new file mode 100644 index 0000000..6d7dc37 --- /dev/null +++ b/vendor/aws/Guzzle/Stream/StreamInterface.php @@ -0,0 +1,218 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Monolog; + +use Psr\Log\LoggerInterface; +use Psr\Log\LogLevel; + +/** + * Monolog error handler + * + * A facility to enable logging of runtime errors, exceptions and fatal errors. + * + * Quick setup: ErrorHandler::register($logger); + * + * @author Jordi Boggiano + */ +class ErrorHandler +{ + private $logger; + + private $previousExceptionHandler; + private $uncaughtExceptionLevel; + + private $previousErrorHandler; + private $errorLevelMap; + + private $fatalLevel; + private $reservedMemory; + private static $fatalErrors = array(E_ERROR, E_PARSE, E_CORE_ERROR, E_COMPILE_ERROR, E_USER_ERROR); + + public function __construct(LoggerInterface $logger) + { + $this->logger = $logger; + } + + /** + * Registers a new ErrorHandler for a given Logger + * + * By default it will handle errors, exceptions and fatal errors + * + * @param LoggerInterface $logger + * @param array|false $errorLevelMap an array of E_* constant to LogLevel::* constant mapping, or false to disable error handling + * @param int|false $exceptionLevel a LogLevel::* constant, or false to disable exception handling + * @param int|false $fatalLevel a LogLevel::* constant, or false to disable fatal error handling + * @return ErrorHandler + */ + public static function register(LoggerInterface $logger, $errorLevelMap = array(), $exceptionLevel = null, $fatalLevel = null) + { + $handler = new static($logger); + if ($errorLevelMap !== false) { + $handler->registerErrorHandler($errorLevelMap); + } + if ($exceptionLevel !== false) { + $handler->registerExceptionHandler($exceptionLevel); + } + if ($fatalLevel !== false) { + $handler->registerFatalHandler($fatalLevel); + } + + return $handler; + } + + public function registerExceptionHandler($level = null, $callPrevious = true) + { + $prev = set_exception_handler(array($this, 'handleException')); + $this->uncaughtExceptionLevel = $level; + if ($callPrevious && $prev) { + $this->previousExceptionHandler = $prev; + } + } + + public function registerErrorHandler(array $levelMap = array(), $callPrevious = true, $errorTypes = -1) + { + $prev = set_error_handler(array($this, 'handleError'), $errorTypes); + $this->errorLevelMap = array_replace($this->defaultErrorLevelMap(), $levelMap); + if ($callPrevious) { + $this->previousErrorHandler = $prev ?: true; + } + } + + public function registerFatalHandler($level = null, $reservedMemorySize = 20) + { + register_shutdown_function(array($this, 'handleFatalError')); + + $this->reservedMemory = str_repeat(' ', 1024 * $reservedMemorySize); + $this->fatalLevel = $level; + } + + protected function defaultErrorLevelMap() + { + return array( + E_ERROR => LogLevel::CRITICAL, + E_WARNING => LogLevel::WARNING, + E_PARSE => LogLevel::ALERT, + E_NOTICE => LogLevel::NOTICE, + E_CORE_ERROR => LogLevel::CRITICAL, + E_CORE_WARNING => LogLevel::WARNING, + E_COMPILE_ERROR => LogLevel::ALERT, + E_COMPILE_WARNING => LogLevel::WARNING, + E_USER_ERROR => LogLevel::ERROR, + E_USER_WARNING => LogLevel::WARNING, + E_USER_NOTICE => LogLevel::NOTICE, + E_STRICT => LogLevel::NOTICE, + E_RECOVERABLE_ERROR => LogLevel::ERROR, + E_DEPRECATED => LogLevel::NOTICE, + E_USER_DEPRECATED => LogLevel::NOTICE, + ); + } + + /** + * @private + */ + public function handleException(\Exception $e) + { + $this->logger->log( + $this->uncaughtExceptionLevel === null ? LogLevel::ERROR : $this->uncaughtExceptionLevel, + sprintf('Uncaught Exception %s: "%s" at %s line %s', get_class($e), $e->getMessage(), $e->getFile(), $e->getLine()), + array('exception' => $e) + ); + + if ($this->previousExceptionHandler) { + call_user_func($this->previousExceptionHandler, $e); + } + } + + /** + * @private + */ + public function handleError($code, $message, $file = '', $line = 0, $context = array()) + { + if (!(error_reporting() & $code)) { + return; + } + + $level = isset($this->errorLevelMap[$code]) ? $this->errorLevelMap[$code] : LogLevel::CRITICAL; + $this->logger->log($level, self::codeToString($code).': '.$message, array('code' => $code, 'message' => $message, 'file' => $file, 'line' => $line)); + + if ($this->previousErrorHandler === true) { + return false; + } elseif ($this->previousErrorHandler) { + return call_user_func($this->previousErrorHandler, $code, $message, $file, $line, $context); + } + } + + /** + * @private + */ + public function handleFatalError() + { + $this->reservedMemory = null; + + $lastError = error_get_last(); + if ($lastError && in_array($lastError['type'], self::$fatalErrors)) { + $this->logger->log( + $this->fatalLevel === null ? LogLevel::ALERT : $this->fatalLevel, + 'Fatal Error ('.self::codeToString($lastError['type']).'): '.$lastError['message'], + array('code' => $lastError['type'], 'message' => $lastError['message'], 'file' => $lastError['file'], 'line' => $lastError['line']) + ); + } + } + + private static function codeToString($code) + { + switch ($code) { + case E_ERROR: + return 'E_ERROR'; + case E_WARNING: + return 'E_WARNING'; + case E_PARSE: + return 'E_PARSE'; + case E_NOTICE: + return 'E_NOTICE'; + case E_CORE_ERROR: + return 'E_CORE_ERROR'; + case E_CORE_WARNING: + return 'E_CORE_WARNING'; + case E_COMPILE_ERROR: + return 'E_COMPILE_ERROR'; + case E_COMPILE_WARNING: + return 'E_COMPILE_WARNING'; + case E_USER_ERROR: + return 'E_USER_ERROR'; + case E_USER_WARNING: + return 'E_USER_WARNING'; + case E_USER_NOTICE: + return 'E_USER_NOTICE'; + case E_STRICT: + return 'E_STRICT'; + case E_RECOVERABLE_ERROR: + return 'E_RECOVERABLE_ERROR'; + case E_DEPRECATED: + return 'E_DEPRECATED'; + case E_USER_DEPRECATED: + return 'E_USER_DEPRECATED'; + } + + return 'Unknown PHP error'; + } +} diff --git a/vendor/aws/Monolog/Formatter/ChromePHPFormatter.php b/vendor/aws/Monolog/Formatter/ChromePHPFormatter.php new file mode 100644 index 0000000..56d3e27 --- /dev/null +++ b/vendor/aws/Monolog/Formatter/ChromePHPFormatter.php @@ -0,0 +1,79 @@ + + * + * 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; + } +} diff --git a/vendor/aws/Monolog/Formatter/ElasticaFormatter.php b/vendor/aws/Monolog/Formatter/ElasticaFormatter.php new file mode 100644 index 0000000..b0b0cf0 --- /dev/null +++ b/vendor/aws/Monolog/Formatter/ElasticaFormatter.php @@ -0,0 +1,87 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Monolog\Formatter; + +use Elastica\Document; + +/** + * Format a log message into an Elastica Document + * + * @author Jelle Vink + */ +class ElasticaFormatter extends NormalizerFormatter +{ + /** + * @var string Elastic search index name + */ + protected $index; + + /** + * @var string Elastic search document type + */ + protected $type; + + /** + * @param string $index Elastic Search index name + * @param string $type Elastic Search document type + */ + public function __construct($index, $type) + { + parent::__construct(\DateTime::ISO8601); + $this->index = $index; + $this->type = $type; + } + + /** + * {@inheritdoc} + */ + public function format(array $record) + { + $record = parent::format($record); + + return $this->getDocument($record); + } + + /** + * Getter index + * @return string + */ + public function getIndex() + { + return $this->index; + } + + /** + * Getter type + * @return string + */ + public function getType() + { + return $this->type; + } + + /** + * Convert a log message into an Elastica Document + * + * @param array $record Log message + * @return Document + */ + protected function getDocument($record) + { + $document = new Document(); + $document->setData($record); + $document->setType($this->type); + $document->setIndex($this->index); + + return $document; + } +} diff --git a/vendor/aws/Monolog/Formatter/FlowdockFormatter.php b/vendor/aws/Monolog/Formatter/FlowdockFormatter.php new file mode 100644 index 0000000..af63d01 --- /dev/null +++ b/vendor/aws/Monolog/Formatter/FlowdockFormatter.php @@ -0,0 +1,104 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Monolog\Formatter; + +/** + * formats the record to be used in the FlowdockHandler + * + * @author Dominik Liebler + */ +class FlowdockFormatter implements FormatterInterface +{ + /** + * @var string + */ + private $source; + + /** + * @var string + */ + private $sourceEmail; + + /** + * @param string $source + * @param string $sourceEmail + */ + public function __construct($source, $sourceEmail) + { + $this->source = $source; + $this->sourceEmail = $sourceEmail; + } + + /** + * {@inheritdoc} + */ + public function format(array $record) + { + $tags = array( + '#logs', + '#' . strtolower($record['level_name']), + '#' . $record['channel'], + ); + + foreach ($record['extra'] as $value) { + $tags[] = '#' . $value; + } + + $subject = sprintf( + 'in %s: %s - %s', + $this->source, + $record['level_name'], + $this->getShortMessage($record['message']) + ); + + $record['flowdock'] = array( + 'source' => $this->source, + 'from_address' => $this->sourceEmail, + 'subject' => $subject, + 'content' => $record['message'], + 'tags' => $tags, + 'project' => $this->source, + ); + + return $record; + } + + /** + * {@inheritdoc} + */ + public function formatBatch(array $records) + { + $formatted = array(); + + foreach ($records as $record) { + $formatted[] = $this->format($record); + } + + return $formatted; + } + + /** + * @param string $message + * + * @return string + */ + public function getShortMessage($message) + { + $maxLength = 45; + + if (strlen($message) > $maxLength) { + $message = substr($message, 0, $maxLength - 4) . ' ...'; + } + + return $message; + } +} diff --git a/vendor/aws/Monolog/Formatter/FormatterInterface.php b/vendor/aws/Monolog/Formatter/FormatterInterface.php new file mode 100644 index 0000000..b5de751 --- /dev/null +++ b/vendor/aws/Monolog/Formatter/FormatterInterface.php @@ -0,0 +1,36 @@ + + * + * 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); +} diff --git a/vendor/aws/Monolog/Formatter/GelfMessageFormatter.php b/vendor/aws/Monolog/Formatter/GelfMessageFormatter.php new file mode 100644 index 0000000..1e43175 --- /dev/null +++ b/vendor/aws/Monolog/Formatter/GelfMessageFormatter.php @@ -0,0 +1,111 @@ + + * + * 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); + + if (!isset($record['datetime'], $record['message'], $record['level'])) { + throw new \InvalidArgumentException('The record should at least contain datetime, message and level keys, '.var_export($record, true).' given'); + } + + $message = new Message(); + $message + ->setTimestamp($record['datetime']) + ->setShortMessage((string) $record['message']) + ->setHost($this->systemName) + ->setLevel($this->logLevels[$record['level']]); + + if (isset($record['channel'])) { + $message->setFacility($record['channel']); + } + if (isset($record['extra']['line'])) { + $message->setLine($record['extra']['line']); + unset($record['extra']['line']); + } + if (isset($record['extra']['file'])) { + $message->setFile($record['extra']['file']); + 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)); + } + + if (null === $message->getFile() && isset($record['context']['exception']['file'])) { + if (preg_match("/^(.+):([0-9]+)$/", $record['context']['exception']['file'], $matches)) { + $message->setFile($matches[1]); + $message->setLine($matches[2]); + } + } + + return $message; + } +} diff --git a/vendor/aws/Monolog/Formatter/HtmlFormatter.php b/vendor/aws/Monolog/Formatter/HtmlFormatter.php new file mode 100644 index 0000000..255d288 --- /dev/null +++ b/vendor/aws/Monolog/Formatter/HtmlFormatter.php @@ -0,0 +1,140 @@ + + * + * 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 incoming records into an HTML table + * + * This is especially useful for html email logging + * + * @author Tiago Brito + */ +class HtmlFormatter extends NormalizerFormatter +{ + /** + * Translates Monolog log levels to html color priorities. + */ + private $logLevels = array( + Logger::DEBUG => '#cccccc', + Logger::INFO => '#468847', + Logger::NOTICE => '#3a87ad', + Logger::WARNING => '#c09853', + Logger::ERROR => '#f0ad4e', + Logger::CRITICAL => '#FF7708', + Logger::ALERT => '#C12A19', + Logger::EMERGENCY => '#000000', + ); + + /** + * @param string $dateFormat The format of the timestamp: one supported by DateTime::format + */ + public function __construct($dateFormat = null) + { + parent::__construct($dateFormat); + } + + /** + * Creates an HTML table row + * + * @param string $th Row header content + * @param string $td Row standard cell content + * @param bool $escapeTd false if td content must not be html escaped + * @return string + */ + private function addRow($th, $td = ' ', $escapeTd = true) + { + $th = htmlspecialchars($th, ENT_NOQUOTES, 'UTF-8'); + if ($escapeTd) { + $td = '
'.htmlspecialchars($td, ENT_NOQUOTES, 'UTF-8').'
'; + } + + return "\n$th:\n".$td."\n"; + } + + /** + * Create a HTML h1 tag + * + * @param string $title Text to be in the h1 + * @param integer $level Error level + * @return string + */ + private function addTitle($title, $level) + { + $title = htmlspecialchars($title, ENT_NOQUOTES, 'UTF-8'); + + return '

'.$title.'

'; + } + /** + * Formats a log record. + * + * @param array $record A record to format + * @return mixed The formatted record + */ + public function format(array $record) + { + $output = $this->addTitle($record['level_name'], $record['level']); + $output .= ''; + + $output .= $this->addRow('Message', (string) $record['message']); + $output .= $this->addRow('Time', $record['datetime']->format($this->dateFormat)); + $output .= $this->addRow('Channel', $record['channel']); + if ($record['context']) { + $embeddedTable = '
'; + foreach ($record['context'] as $key => $value) { + $embeddedTable .= $this->addRow($key, $this->convertToString($value)); + } + $embeddedTable .= '
'; + $output .= $this->addRow('Context', $embeddedTable, false); + } + if ($record['extra']) { + $embeddedTable = ''; + foreach ($record['extra'] as $key => $value) { + $embeddedTable .= $this->addRow($key, $this->convertToString($value)); + } + $embeddedTable .= '
'; + $output .= $this->addRow('Extra', $embeddedTable, false); + } + + return $output.''; + } + + /** + * 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) + { + $message = ''; + foreach ($records as $record) { + $message .= $this->format($record); + } + + return $message; + } + + 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 json_encode($data, JSON_PRETTY_PRINT | JSON_UNESCAPED_SLASHES | JSON_UNESCAPED_UNICODE); + } + + return str_replace('\\/', '/', json_encode($data)); + } +} diff --git a/vendor/aws/Monolog/Formatter/JsonFormatter.php b/vendor/aws/Monolog/Formatter/JsonFormatter.php new file mode 100644 index 0000000..e5a1d2c --- /dev/null +++ b/vendor/aws/Monolog/Formatter/JsonFormatter.php @@ -0,0 +1,116 @@ + + * + * 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 +{ + const BATCH_MODE_JSON = 1; + const BATCH_MODE_NEWLINES = 2; + + protected $batchMode; + protected $appendNewline; + + /** + * @param int $batchMode + */ + public function __construct($batchMode = self::BATCH_MODE_JSON, $appendNewline = true) + { + $this->batchMode = $batchMode; + $this->appendNewline = $appendNewline; + } + + /** + * The batch mode option configures the formatting style for + * multiple records. By default, multiple records will be + * formatted as a JSON-encoded array. However, for + * compatibility with some API endpoints, alternative styles + * are available. + * + * @return int + */ + public function getBatchMode() + { + return $this->batchMode; + } + + /** + * True if newlines are appended to every formatted record + * + * @return bool + */ + public function isAppendingNewlines() + { + return $this->appendNewline; + } + + /** + * {@inheritdoc} + */ + public function format(array $record) + { + return json_encode($record) . ($this->appendNewline ? "\n" : ''); + } + + /** + * {@inheritdoc} + */ + public function formatBatch(array $records) + { + switch ($this->batchMode) { + case static::BATCH_MODE_NEWLINES: + return $this->formatBatchNewlines($records); + + case static::BATCH_MODE_JSON: + default: + return $this->formatBatchJson($records); + } + } + + /** + * Return a JSON-encoded array of records. + * + * @param array $records + * @return string + */ + protected function formatBatchJson(array $records) + { + return json_encode($records); + } + + /** + * Use new lines to separate records instead of a + * JSON-encoded array. + * + * @param array $records + * @return string + */ + protected function formatBatchNewlines(array $records) + { + $instance = $this; + + $oldNewline = $this->appendNewline; + $this->appendNewline = false; + array_walk($records, function (&$value, $key) use ($instance) { + $value = $instance->format($value); + }); + $this->appendNewline = $oldNewline; + + return implode("\n", $records); + } +} diff --git a/vendor/aws/Monolog/Formatter/LineFormatter.php b/vendor/aws/Monolog/Formatter/LineFormatter.php new file mode 100644 index 0000000..6983d1a --- /dev/null +++ b/vendor/aws/Monolog/Formatter/LineFormatter.php @@ -0,0 +1,159 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Monolog\Formatter; + +use Exception; + +/** + * 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; + protected $allowInlineLineBreaks; + protected $ignoreEmptyContextAndExtra; + protected $includeStacktraces; + + /** + * @param string $format The format of the message + * @param string $dateFormat The format of the timestamp: one supported by DateTime::format + * @param bool $allowInlineLineBreaks Whether to allow inline line breaks in log entries + * @param bool $ignoreEmptyContextAndExtra + */ + public function __construct($format = null, $dateFormat = null, $allowInlineLineBreaks = false, $ignoreEmptyContextAndExtra = false) + { + $this->format = $format ?: static::SIMPLE_FORMAT; + $this->allowInlineLineBreaks = $allowInlineLineBreaks; + $this->ignoreEmptyContextAndExtra = $ignoreEmptyContextAndExtra; + parent::__construct($dateFormat); + } + + public function includeStacktraces($include = true) + { + $this->includeStacktraces = $include; + if ($this->includeStacktraces) { + $this->allowInlineLineBreaks = true; + } + } + + public function allowInlineLineBreaks($allow = true) + { + $this->allowInlineLineBreaks = $allow; + } + + public function ignoreEmptyContextAndExtra($ignore = true) + { + $this->ignoreEmptyContextAndExtra = $ignore; + } + + /** + * {@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->stringify($val), $output); + unset($vars['extra'][$var]); + } + } + + if ($this->ignoreEmptyContextAndExtra) { + if (empty($vars['context'])) { + unset($vars['context']); + $output = str_replace('%context%', '', $output); + } + + if (empty($vars['extra'])) { + unset($vars['extra']); + $output = str_replace('%extra%', '', $output); + } + } + + foreach ($vars as $var => $val) { + if (false !== strpos($output, '%'.$var.'%')) { + $output = str_replace('%'.$var.'%', $this->stringify($val), $output); + } + } + + return $output; + } + + public function formatBatch(array $records) + { + $message = ''; + foreach ($records as $record) { + $message .= $this->format($record); + } + + return $message; + } + + public function stringify($value) + { + return $this->replaceNewlines($this->convertToString($value)); + } + + protected function normalizeException(Exception $e) + { + $previousText = ''; + if ($previous = $e->getPrevious()) { + do { + $previousText .= ', '.get_class($previous).'(code: '.$previous->getCode().'): '.$previous->getMessage().' at '.$previous->getFile().':'.$previous->getLine(); + } while ($previous = $previous->getPrevious()); + } + + $str = '[object] ('.get_class($e).'(code: '.$e->getCode().'): '.$e->getMessage().' at '.$e->getFile().':'.$e->getLine().$previousText.')'; + if ($this->includeStacktraces) { + $str .= "\n[stacktrace]\n".$e->getTraceAsString(); + } + + return $str; + } + + protected function convertToString($data) + { + if (null === $data || is_bool($data)) { + return var_export($data, true); + } + + if (is_scalar($data)) { + return (string) $data; + } + + if (version_compare(PHP_VERSION, '5.4.0', '>=')) { + return $this->toJson($data, true); + } + + return str_replace('\\/', '/', @json_encode($data)); + } + + protected function replaceNewlines($str) + { + if ($this->allowInlineLineBreaks) { + return $str; + } + + return strtr($str, array("\r\n" => ' ', "\r" => ' ', "\n" => ' ')); + } +} diff --git a/vendor/aws/Monolog/Formatter/LogglyFormatter.php b/vendor/aws/Monolog/Formatter/LogglyFormatter.php new file mode 100644 index 0000000..f02bceb --- /dev/null +++ b/vendor/aws/Monolog/Formatter/LogglyFormatter.php @@ -0,0 +1,47 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Monolog\Formatter; + +/** + * Encodes message information into JSON in a format compatible with Loggly. + * + * @author Adam Pancutt + */ +class LogglyFormatter extends JsonFormatter +{ + /** + * Overrides the default batch mode to new lines for compatibility with the + * Loggly bulk API. + * + * @param integer $batchMode + */ + public function __construct($batchMode = self::BATCH_MODE_NEWLINES, $appendNewline = false) + { + parent::__construct($batchMode, $appendNewline); + } + + /** + * Appends the 'timestamp' parameter for indexing by Loggly. + * + * @see https://www.loggly.com/docs/automated-parsing/#json + * @see \Monolog\Formatter\JsonFormatter::format() + */ + public function format(array $record) + { + if (isset($record["datetime"]) && ($record["datetime"] instanceof \DateTime)) { + $record["timestamp"] = $record["datetime"]->format("Y-m-d\TH:i:s.uO"); + // TODO 2.0 unset the 'datetime' parameter, retained for BC + } + + return parent::format($record); + } +} diff --git a/vendor/aws/Monolog/Formatter/LogstashFormatter.php b/vendor/aws/Monolog/Formatter/LogstashFormatter.php new file mode 100644 index 0000000..7a7b3b3 --- /dev/null +++ b/vendor/aws/Monolog/Formatter/LogstashFormatter.php @@ -0,0 +1,165 @@ + + * + * 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 +{ + const V0 = 0; + const V1 = 1; + + /** + * @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; + + /** + * @var integer logstash format version to use + */ + protected $version; + + /** + * @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_', $version = self::V0) + { + // logstash requires a ISO 8601 format date with optional millisecond precision. + parent::__construct('Y-m-d\TH:i:s.uP'); + + $this->systemName = $systemName ?: gethostname(); + $this->applicationName = $applicationName; + $this->extraPrefix = $extraPrefix; + $this->contextPrefix = $contextPrefix; + $this->version = $version; + } + + /** + * {@inheritdoc} + */ + public function format(array $record) + { + $record = parent::format($record); + + if ($this->version === self::V1) { + $message = $this->formatV1($record); + } else { + $message = $this->formatV0($record); + } + + return $this->toJson($message) . "\n"; + } + + protected function formatV0(array $record) + { + if (empty($record['datetime'])) { + $record['datetime'] = gmdate('c'); + } + $message = array( + '@timestamp' => $record['datetime'], + '@source' => $this->systemName, + '@fields' => array() + ); + if (isset($record['message'])) { + $message['@message'] = $record['message']; + } + if (isset($record['channel'])) { + $message['@tags'] = array($record['channel']); + $message['@fields']['channel'] = $record['channel']; + } + if (isset($record['level'])) { + $message['@fields']['level'] = $record['level']; + } + if ($this->applicationName) { + $message['@type'] = $this->applicationName; + } + if (isset($record['extra']['server'])) { + $message['@source_host'] = $record['extra']['server']; + } + if (isset($record['extra']['url'])) { + $message['@source_path'] = $record['extra']['url']; + } + if (!empty($record['extra'])) { + foreach ($record['extra'] as $key => $val) { + $message['@fields'][$this->extraPrefix . $key] = $val; + } + } + if (!empty($record['context'])) { + foreach ($record['context'] as $key => $val) { + $message['@fields'][$this->contextPrefix . $key] = $val; + } + } + + return $message; + } + + protected function formatV1(array $record) + { + if (empty($record['datetime'])) { + $record['datetime'] = gmdate('c'); + } + $message = array( + '@timestamp' => $record['datetime'], + '@version' => 1, + 'host' => $this->systemName, + ); + if (isset($record['message'])) { + $message['message'] = $record['message']; + } + if (isset($record['channel'])) { + $message['type'] = $record['channel']; + $message['channel'] = $record['channel']; + } + if (isset($record['level_name'])) { + $message['level'] = $record['level_name']; + } + if ($this->applicationName) { + $message['type'] = $this->applicationName; + } + if (!empty($record['extra'])) { + foreach ($record['extra'] as $key => $val) { + $message[$this->extraPrefix . $key] = $val; + } + } + if (!empty($record['context'])) { + foreach ($record['context'] as $key => $val) { + $message[$this->contextPrefix . $key] = $val; + } + } + + return $message; + } +} diff --git a/vendor/aws/Monolog/Formatter/MongoDBFormatter.php b/vendor/aws/Monolog/Formatter/MongoDBFormatter.php new file mode 100644 index 0000000..eb067bb --- /dev/null +++ b/vendor/aws/Monolog/Formatter/MongoDBFormatter.php @@ -0,0 +1,105 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Monolog\Formatter; + +/** + * Formats a record for use with the MongoDBHandler. + * + * @author Florian Plattner + */ +class MongoDBFormatter implements FormatterInterface +{ + private $exceptionTraceAsString; + private $maxNestingLevel; + + /** + * @param int $maxNestingLevel 0 means infinite nesting, the $record itself is level 1, $record['context'] is 2 + * @param bool $exceptionTraceAsString set to false to log exception traces as a sub documents instead of strings + */ + public function __construct($maxNestingLevel = 3, $exceptionTraceAsString = true) + { + $this->maxNestingLevel = max($maxNestingLevel, 0); + $this->exceptionTraceAsString = (bool) $exceptionTraceAsString; + } + + /** + * {@inheritDoc} + */ + public function format(array $record) + { + return $this->formatArray($record); + } + + /** + * {@inheritDoc} + */ + public function formatBatch(array $records) + { + foreach ($records as $key => $record) { + $records[$key] = $this->format($record); + } + + return $records; + } + + protected function formatArray(array $record, $nestingLevel = 0) + { + if ($this->maxNestingLevel == 0 || $nestingLevel <= $this->maxNestingLevel) { + foreach ($record as $name => $value) { + if ($value instanceof \DateTime) { + $record[$name] = $this->formatDate($value, $nestingLevel + 1); + } elseif ($value instanceof \Exception) { + $record[$name] = $this->formatException($value, $nestingLevel + 1); + } elseif (is_array($value)) { + $record[$name] = $this->formatArray($value, $nestingLevel + 1); + } elseif (is_object($value)) { + $record[$name] = $this->formatObject($value, $nestingLevel + 1); + } + } + } else { + $record = '[...]'; + } + + return $record; + } + + protected function formatObject($value, $nestingLevel) + { + $objectVars = get_object_vars($value); + $objectVars['class'] = get_class($value); + + return $this->formatArray($objectVars, $nestingLevel); + } + + protected function formatException(\Exception $exception, $nestingLevel) + { + $formattedException = array( + 'class' => get_class($exception), + 'message' => $exception->getMessage(), + 'code' => $exception->getCode(), + 'file' => $exception->getFile() . ':' . $exception->getLine(), + ); + + if ($this->exceptionTraceAsString === true) { + $formattedException['trace'] = $exception->getTraceAsString(); + } else { + $formattedException['trace'] = $exception->getTrace(); + } + + return $this->formatArray($formattedException, $nestingLevel); + } + + protected function formatDate(\DateTime $value, $nestingLevel) + { + return new \MongoDate($value->getTimestamp()); + } +} diff --git a/vendor/aws/Monolog/Formatter/NormalizerFormatter.php b/vendor/aws/Monolog/Formatter/NormalizerFormatter.php new file mode 100644 index 0000000..654e790 --- /dev/null +++ b/vendor/aws/Monolog/Formatter/NormalizerFormatter.php @@ -0,0 +1,150 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Monolog\Formatter; + +use Exception; + +/** + * 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; + if (!function_exists('json_encode')) { + throw new \RuntimeException('PHP\'s json extension is required to use Monolog\'s NormalizerFormatter'); + } + } + + /** + * {@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)) { + if (is_float($data)) { + if (is_infinite($data)) { + return ($data > 0 ? '' : '-') . 'INF'; + } + if (is_nan($data)) { + return 'NaN'; + } + } + + return $data; + } + + if (is_array($data) || $data instanceof \Traversable) { + $normalized = array(); + + $count = 1; + foreach ($data as $key => $value) { + if ($count++ >= 1000) { + $normalized['...'] = 'Over 1000 items, aborting normalization'; + break; + } + $normalized[$key] = $this->normalize($value); + } + + return $normalized; + } + + if ($data instanceof \DateTime) { + return $data->format($this->dateFormat); + } + + if (is_object($data)) { + if ($data instanceof Exception) { + return $this->normalizeException($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 normalizeException(Exception $e) + { + $data = array( + 'class' => get_class($e), + 'message' => $e->getMessage(), + 'code' => $e->getCode(), + 'file' => $e->getFile().':'.$e->getLine(), + ); + + $trace = $e->getTrace(); + foreach ($trace as $frame) { + if (isset($frame['file'])) { + $data['trace'][] = $frame['file'].':'.$frame['line']; + } else { + // We should again normalize the frames, because it might contain invalid items + $data['trace'][] = $this->toJson($this->normalize($frame), true); + } + } + + if ($previous = $e->getPrevious()) { + $data['previous'] = $this->normalizeException($previous); + } + + return $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); + } +} diff --git a/vendor/aws/Monolog/Formatter/ScalarFormatter.php b/vendor/aws/Monolog/Formatter/ScalarFormatter.php new file mode 100644 index 0000000..5d345d5 --- /dev/null +++ b/vendor/aws/Monolog/Formatter/ScalarFormatter.php @@ -0,0 +1,48 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Monolog\Formatter; + +/** + * Formats data into an associative array of scalar values. + * Objects and arrays will be JSON encoded. + * + * @author Andrew Lawson + */ +class ScalarFormatter extends NormalizerFormatter +{ + /** + * {@inheritdoc} + */ + public function format(array $record) + { + foreach ($record as $key => $value) { + $record[$key] = $this->normalizeValue($value); + } + + return $record; + } + + /** + * @param mixed $value + * @return mixed + */ + protected function normalizeValue($value) + { + $normalized = $this->normalize($value); + + if (is_array($normalized) || is_object($normalized)) { + return $this->toJson($normalized, true); + } + + return $normalized; + } +} diff --git a/vendor/aws/Monolog/Formatter/WildfireFormatter.php b/vendor/aws/Monolog/Formatter/WildfireFormatter.php new file mode 100644 index 0000000..654710a --- /dev/null +++ b/vendor/aws/Monolog/Formatter/WildfireFormatter.php @@ -0,0 +1,113 @@ + + * + * 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 +{ + const TABLE = 'table'; + + /** + * 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); + } + + if (isset($record['context'][self::TABLE])) { + $type = 'TABLE'; + $label = $record['channel'] .': '. $record['message']; + $message = $record['context'][self::TABLE]; + } else { + $type = $this->logLevels[$record['level']]; + $label = $record['channel']; + } + + // Create JSON object describing the appearance of the message in the console + $json = $this->toJson(array( + array( + 'Type' => $type, + 'File' => $file, + 'Line' => $line, + 'Label' => $label, + ), + $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); + } +} diff --git a/vendor/aws/Monolog/Handler/AbstractHandler.php b/vendor/aws/Monolog/Handler/AbstractHandler.php new file mode 100644 index 0000000..69ede49 --- /dev/null +++ b/vendor/aws/Monolog/Handler/AbstractHandler.php @@ -0,0 +1,184 @@ + + * + * 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 = true; + + /** + * @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->setLevel($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); + + return $this; + } + + /** + * {@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; + + return $this; + } + + /** + * {@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 + * @return self + */ + public function setLevel($level) + { + $this->level = Logger::toMonologLevel($level); + + return $this; + } + + /** + * 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 this handler allows bubbling. + * false means that bubbling is not permitted. + * @return self + */ + public function setBubble($bubble) + { + $this->bubble = $bubble; + + return $this; + } + + /** + * Gets the bubbling behavior. + * + * @return Boolean true means that this handler allows bubbling. + * false means that bubbling is not permitted. + */ + 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(); + } +} diff --git a/vendor/aws/Monolog/Handler/AbstractProcessingHandler.php b/vendor/aws/Monolog/Handler/AbstractProcessingHandler.php new file mode 100644 index 0000000..6f18f72 --- /dev/null +++ b/vendor/aws/Monolog/Handler/AbstractProcessingHandler.php @@ -0,0 +1,66 @@ + + * + * 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 (!$this->isHandling($record)) { + 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; + } +} diff --git a/vendor/aws/Monolog/Handler/AbstractSyslogHandler.php b/vendor/aws/Monolog/Handler/AbstractSyslogHandler.php new file mode 100644 index 0000000..3eb83bd --- /dev/null +++ b/vendor/aws/Monolog/Handler/AbstractSyslogHandler.php @@ -0,0 +1,92 @@ + + * + * 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; + +/** + * Common syslog functionality + */ +abstract class AbstractSyslogHandler extends AbstractProcessingHandler +{ + protected $facility; + + /** + * Translates Monolog log levels to syslog log priorities. + */ + protected $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. + */ + protected $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 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 + */ + public function __construct($facility = LOG_USER, $level = Logger::DEBUG, $bubble = true) + { + 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'); + } + + $this->facility = $facility; + } + + /** + * {@inheritdoc} + */ + protected function getDefaultFormatter() + { + return new LineFormatter('%channel%.%level_name%: %message% %context% %extra%'); + } +} diff --git a/vendor/aws/Monolog/Handler/AmqpHandler.php b/vendor/aws/Monolog/Handler/AmqpHandler.php new file mode 100644 index 0000000..a28ba02 --- /dev/null +++ b/vendor/aws/Monolog/Handler/AmqpHandler.php @@ -0,0 +1,98 @@ + + * + * 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; +use PhpAmqpLib\Message\AMQPMessage; +use PhpAmqpLib\Channel\AMQPChannel; +use AMQPExchange; + +class AmqpHandler extends AbstractProcessingHandler +{ + /** + * @var AMQPExchange|AMQPChannel $exchange + */ + protected $exchange; + + /** + * @var string + */ + protected $exchangeName; + + /** + * @param AMQPExchange|AMQPChannel $exchange AMQPExchange (php AMQP ext) or PHP AMQP lib channel, 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($exchange, $exchangeName = 'log', $level = Logger::DEBUG, $bubble = true) + { + if ($exchange instanceof AMQPExchange) { + $exchange->setName($exchangeName); + } elseif ($exchange instanceof AMQPChannel) { + $this->exchangeName = $exchangeName; + } else { + throw new \InvalidArgumentException('PhpAmqpLib\Channel\AMQPChannel or AMQPExchange instance required'); + } + $this->exchange = $exchange; + + parent::__construct($level, $bubble); + } + + /** + * {@inheritDoc} + */ + protected function write(array $record) + { + $data = $record["formatted"]; + + $routingKey = sprintf( + '%s.%s', + // TODO 2.0 remove substr call + substr($record['level_name'], 0, 4), + $record['channel'] + ); + + if ($this->exchange instanceof AMQPExchange) { + $this->exchange->publish( + $data, + strtolower($routingKey), + 0, + array( + 'delivery_mode' => 2, + 'Content-type' => 'application/json' + ) + ); + } else { + $this->exchange->basic_publish( + new AMQPMessage( + (string) $data, + array( + 'delivery_mode' => 2, + 'content_type' => 'application/json' + ) + ), + $this->exchangeName, + strtolower($routingKey) + ); + } + } + + /** + * {@inheritDoc} + */ + protected function getDefaultFormatter() + { + return new JsonFormatter(JsonFormatter::BATCH_MODE_JSON, false); + } +} diff --git a/vendor/aws/Monolog/Handler/BrowserConsoleHandler.php b/vendor/aws/Monolog/Handler/BrowserConsoleHandler.php new file mode 100644 index 0000000..bee6903 --- /dev/null +++ b/vendor/aws/Monolog/Handler/BrowserConsoleHandler.php @@ -0,0 +1,184 @@ + + * + * 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; + +/** + * Handler sending logs to browser's javascript console with no browser extension required + * + * @author Olivier Poitrey + */ +class BrowserConsoleHandler extends AbstractProcessingHandler +{ + protected static $initialized = false; + protected static $records = array(); + + /** + * {@inheritDoc} + * + * Formatted output may contain some formatting markers to be transferred to `console.log` using the %c format. + * + * Example of formatted string: + * + * You can do [[blue text]]{color: blue} or [[green background]]{background-color: green; color: white} + * + */ + protected function getDefaultFormatter() + { + return new LineFormatter('[[%channel%]]{macro: autolabel} [[%level_name%]]{font-weight: bold} %message%'); + } + + /** + * {@inheritDoc} + */ + protected function write(array $record) + { + // Accumulate records + self::$records[] = $record; + + // Register shutdown handler if not already done + if (PHP_SAPI !== 'cli' && !self::$initialized) { + self::$initialized = true; + register_shutdown_function(array('Monolog\Handler\BrowserConsoleHandler', 'send')); + } + } + + /** + * Convert records to javascript console commands and send it to the browser. + * This method is automatically called on PHP shutdown if output is HTML. + */ + public static function send() + { + // Check content type + foreach (headers_list() as $header) { + if (stripos($header, 'content-type:') === 0) { + if (stripos($header, 'text/html') === false) { + // This handler only works with HTML outputs + return; + } + break; + } + } + + if (count(self::$records)) { + echo ''; + self::reset(); + } + } + + /** + * Forget all logged records + */ + public static function reset() + { + self::$records = array(); + } + + private static function generateScript() + { + $script = array(); + foreach (self::$records as $record) { + $context = self::dump('Context', $record['context']); + $extra = self::dump('Extra', $record['extra']); + + if (empty($context) && empty($extra)) { + $script[] = self::call_array('log', self::handleStyles($record['formatted'])); + } else { + $script = array_merge($script, + array(self::call_array('groupCollapsed', self::handleStyles($record['formatted']))), + $context, + $extra, + array(self::call('groupEnd')) + ); + } + } + + return "(function (c) {if (c && c.groupCollapsed) {\n" . implode("\n", $script) . "\n}})(console);"; + } + + private static function handleStyles($formatted) + { + $args = array(self::quote('font-weight: normal')); + $format = '%c' . $formatted; + preg_match_all('/\[\[(.*?)\]\]\{([^}]*)\}/s', $format, $matches, PREG_OFFSET_CAPTURE | PREG_SET_ORDER); + + foreach (array_reverse($matches) as $match) { + $args[] = self::quote(self::handleCustomStyles($match[2][0], $match[1][0])); + $args[] = '"font-weight: normal"'; + + $pos = $match[0][1]; + $format = substr($format, 0, $pos) . '%c' . $match[1][0] . '%c' . substr($format, $pos + strlen($match[0][0])); + } + + array_unshift($args, self::quote($format)); + + return $args; + } + + private static function handleCustomStyles($style, $string) + { + static $colors = array('blue', 'green', 'red', 'magenta', 'orange', 'black', 'grey'); + static $labels = array(); + + return preg_replace_callback('/macro\s*:(.*?)(?:;|$)/', function ($m) use ($string, &$colors, &$labels) { + if (trim($m[1]) === 'autolabel') { + // Format the string as a label with consistent auto assigned background color + if (!isset($labels[$string])) { + $labels[$string] = $colors[count($labels) % count($colors)]; + } + $color = $labels[$string]; + + return "background-color: $color; color: white; border-radius: 3px; padding: 0 2px 0 2px"; + } + + return $m[1]; + }, $style); + } + + private static function dump($title, array $dict) + { + $script = array(); + $dict = array_filter($dict); + if (empty($dict)) { + return $script; + } + $script[] = self::call('log', self::quote('%c%s'), self::quote('font-weight: bold'), self::quote($title)); + foreach ($dict as $key => $value) { + $value = json_encode($value); + if (empty($value)) { + $value = self::quote(''); + } + $script[] = self::call('log', self::quote('%s: %o'), self::quote($key), $value); + } + + return $script; + } + + private static function quote($arg) + { + return '"' . addcslashes($arg, "\"\n") . '"'; + } + + private static function call() + { + $args = func_get_args(); + $method = array_shift($args); + + return self::call_array($method, $args); + } + + private static function call_array($method, array $args) + { + return 'c.' . $method . '(' . implode(', ', $args) . ');'; + } +} diff --git a/vendor/aws/Monolog/Handler/BufferHandler.php b/vendor/aws/Monolog/Handler/BufferHandler.php new file mode 100644 index 0000000..6d8136f --- /dev/null +++ b/vendor/aws/Monolog/Handler/BufferHandler.php @@ -0,0 +1,117 @@ + + * + * 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(); + protected $initialized = false; + + /** + * @param HandlerInterface $handler Handler. + * @param integer $bufferLimit 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, $bufferLimit = 0, $level = Logger::DEBUG, $bubble = true, $flushOnOverflow = false) + { + parent::__construct($level, $bubble); + $this->handler = $handler; + $this->bufferLimit = (int) $bufferLimit; + $this->flushOnOverflow = $flushOnOverflow; + } + + /** + * {@inheritdoc} + */ + public function handle(array $record) + { + if ($record['level'] < $this->level) { + return false; + } + + if (!$this->initialized) { + // __destructor() doesn't get called on Fatal errors + register_shutdown_function(array($this, 'close')); + $this->initialized = true; + } + + 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->clear(); + } + + public function __destruct() + { + // suppress the parent behavior since we already have register_shutdown_function() + // to call close(), and the reference contained there will prevent this from being + // GC'd until the end of the request + } + + /** + * {@inheritdoc} + */ + public function close() + { + $this->flush(); + } + + /** + * Clears the buffer without flushing any messages down to the wrapped handler. + */ + public function clear() + { + $this->bufferSize = 0; + $this->buffer = array(); + } +} diff --git a/vendor/aws/Monolog/Handler/ChromePHPHandler.php b/vendor/aws/Monolog/Handler/ChromePHPHandler.php new file mode 100644 index 0000000..bc65934 --- /dev/null +++ b/vendor/aws/Monolog/Handler/ChromePHPHandler.php @@ -0,0 +1,204 @@ + + * + * 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; +use Monolog\Logger; + +/** + * Handler sending logs to the ChromePHP extension (http://www.chromephp.com/) + * + * @author Christophe Coevoet + */ +class ChromePHPHandler extends AbstractProcessingHandler +{ + /** + * Version of the extension + */ + const VERSION = '4.0'; + + /** + * Header name + */ + const HEADER_NAME = 'X-ChromeLogger-Data'; + + protected static $initialized = false; + + /** + * Tracks whether we sent too much data + * + * Chrome limits the headers to 256KB, so when we sent 240KB we stop sending + * + * @var Boolean + */ + protected static $overflowed = false; + + protected static $json = array( + 'version' => self::VERSION, + 'columns' => array('label', 'log', 'backtrace', 'type'), + 'rows' => array(), + ); + + protected static $sendHeaders = true; + + /** + * @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) + { + parent::__construct($level, $bubble); + if (!function_exists('json_encode')) { + throw new \RuntimeException('PHP\'s json extension is required to use Monolog\'s ChromePHPHandler'); + } + } + + /** + * {@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::$overflowed || !self::$sendHeaders) { + return; + } + + if (!self::$initialized) { + self::$initialized = true; + + self::$sendHeaders = $this->headersAccepted(); + if (!self::$sendHeaders) { + return; + } + + self::$json['request_uri'] = isset($_SERVER['REQUEST_URI']) ? $_SERVER['REQUEST_URI'] : ''; + } + + $json = @json_encode(self::$json); + $data = base64_encode(utf8_encode($json)); + if (strlen($data) > 240*1024) { + self::$overflowed = true; + + $record = array( + 'message' => 'Incomplete logs, chrome header size limit reached', + 'context' => array(), + 'level' => Logger::WARNING, + 'level_name' => Logger::getLevelName(Logger::WARNING), + 'channel' => 'monolog', + 'datetime' => new \DateTime(), + 'extra' => array(), + ); + self::$json['rows'][count(self::$json['rows']) - 1] = $this->getFormatter()->format($record); + $json = @json_encode(self::$json); + $data = base64_encode(utf8_encode($json)); + } + + if (trim($data) !== '') { + $this->sendHeader(self::HEADER_NAME, $data); + } + } + + /** + * 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() + { + if (empty($_SERVER['HTTP_USER_AGENT'])) { + return false; + } + + return 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; + } +} diff --git a/vendor/aws/Monolog/Handler/CouchDBHandler.php b/vendor/aws/Monolog/Handler/CouchDBHandler.php new file mode 100644 index 0000000..b3687c3 --- /dev/null +++ b/vendor/aws/Monolog/Handler/CouchDBHandler.php @@ -0,0 +1,72 @@ + + * + * 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(JsonFormatter::BATCH_MODE_JSON, false); + } +} diff --git a/vendor/aws/Monolog/Handler/CubeHandler.php b/vendor/aws/Monolog/Handler/CubeHandler.php new file mode 100644 index 0000000..d968720 --- /dev/null +++ b/vendor/aws/Monolog/Handler/CubeHandler.php @@ -0,0 +1,145 @@ + + * + * 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 MissingExtensionException('The sockets extension is required 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.uO')); + 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); + } +} diff --git a/vendor/aws/Monolog/Handler/DoctrineCouchDBHandler.php b/vendor/aws/Monolog/Handler/DoctrineCouchDBHandler.php new file mode 100644 index 0000000..b91ffec --- /dev/null +++ b/vendor/aws/Monolog/Handler/DoctrineCouchDBHandler.php @@ -0,0 +1,45 @@ + + * + * 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; + } +} diff --git a/vendor/aws/Monolog/Handler/DynamoDbHandler.php b/vendor/aws/Monolog/Handler/DynamoDbHandler.php new file mode 100644 index 0000000..e7f843c --- /dev/null +++ b/vendor/aws/Monolog/Handler/DynamoDbHandler.php @@ -0,0 +1,89 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Monolog\Handler; + +use Aws\Common\Aws; +use Aws\DynamoDb\DynamoDbClient; +use Monolog\Formatter\ScalarFormatter; +use Monolog\Logger; + +/** + * Amazon DynamoDB handler (http://aws.amazon.com/dynamodb/) + * + * @link https://github.com/aws/aws-sdk-php/ + * @author Andrew Lawson + */ +class DynamoDbHandler extends AbstractProcessingHandler +{ + const DATE_FORMAT = 'Y-m-d\TH:i:s.uO'; + + /** + * @var DynamoDbClient + */ + protected $client; + + /** + * @var string + */ + protected $table; + + /** + * @param DynamoDbClient $client + * @param string $table + * @param integer $level + * @param boolean $bubble + */ + public function __construct(DynamoDbClient $client, $table, $level = Logger::DEBUG, $bubble = true) + { + if (!defined('Aws\Common\Aws::VERSION') || version_compare('3.0', Aws::VERSION, '<=')) { + throw new \RuntimeException('The DynamoDbHandler is only known to work with the AWS SDK 2.x releases'); + } + + $this->client = $client; + $this->table = $table; + + parent::__construct($level, $bubble); + } + + /** + * {@inheritdoc} + */ + protected function write(array $record) + { + $filtered = $this->filterEmptyFields($record['formatted']); + $formatted = $this->client->formatAttributes($filtered); + + $this->client->putItem(array( + 'TableName' => $this->table, + 'Item' => $formatted + )); + } + + /** + * @param array $record + * @return array + */ + protected function filterEmptyFields(array $record) + { + return array_filter($record, function ($value) { + return !empty($value) || false === $value || 0 === $value; + }); + } + + /** + * {@inheritdoc} + */ + protected function getDefaultFormatter() + { + return new ScalarFormatter(self::DATE_FORMAT); + } +} diff --git a/vendor/aws/Monolog/Handler/ElasticSearchHandler.php b/vendor/aws/Monolog/Handler/ElasticSearchHandler.php new file mode 100644 index 0000000..96e5d57 --- /dev/null +++ b/vendor/aws/Monolog/Handler/ElasticSearchHandler.php @@ -0,0 +1,128 @@ + + * + * 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; +use Monolog\Formatter\ElasticaFormatter; +use Monolog\Logger; +use Elastica\Client; +use Elastica\Exception\ExceptionInterface; + +/** + * Elastic Search handler + * + * Usage example: + * + * $client = new \Elastica\Client(); + * $options = array( + * 'index' => 'elastic_index_name', + * 'type' => 'elastic_doc_type', + * ); + * $handler = new ElasticSearchHandler($client, $options); + * $log = new Logger('application'); + * $log->pushHandler($handler); + * + * @author Jelle Vink + */ +class ElasticSearchHandler extends AbstractProcessingHandler +{ + /** + * @var Client + */ + protected $client; + + /** + * @var array Handler config options + */ + protected $options = array(); + + /** + * @param Client $client Elastica Client object + * @param array $options Handler configuration + * @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(Client $client, array $options = array(), $level = Logger::DEBUG, $bubble = true) + { + parent::__construct($level, $bubble); + $this->client = $client; + $this->options = array_merge( + array( + 'index' => 'monolog', // Elastic index name + 'type' => 'record', // Elastic document type + 'ignore_error' => false, // Suppress Elastica exceptions + ), + $options + ); + } + + /** + * {@inheritDoc} + */ + protected function write(array $record) + { + $this->bulkSend(array($record['formatted'])); + } + + /** + * {@inheritdoc} + */ + public function setFormatter(FormatterInterface $formatter) + { + if ($formatter instanceof ElasticaFormatter) { + return parent::setFormatter($formatter); + } + throw new \InvalidArgumentException('ElasticSearchHandler is only compatible with ElasticaFormatter'); + } + + /** + * Getter options + * @return array + */ + public function getOptions() + { + return $this->options; + } + + /** + * {@inheritDoc} + */ + protected function getDefaultFormatter() + { + return new ElasticaFormatter($this->options['index'], $this->options['type']); + } + + /** + * {@inheritdoc} + */ + public function handleBatch(array $records) + { + $documents = $this->getFormatter()->formatBatch($records); + $this->bulkSend($documents); + } + + /** + * Use Elasticsearch bulk API to send list of documents + * @param array $documents + * @throws \RuntimeException + */ + protected function bulkSend(array $documents) + { + try { + $this->client->addDocuments($documents); + } catch (ExceptionInterface $e) { + if (!$this->options['ignore_error']) { + throw new \RuntimeException("Error sending messages to Elasticsearch", 0, $e); + } + } + } +} diff --git a/vendor/aws/Monolog/Handler/ErrorLogHandler.php b/vendor/aws/Monolog/Handler/ErrorLogHandler.php new file mode 100644 index 0000000..d1e1ee6 --- /dev/null +++ b/vendor/aws/Monolog/Handler/ErrorLogHandler.php @@ -0,0 +1,82 @@ + + * + * 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; + +/** + * Stores to PHP error_log() handler. + * + * @author Elan Ruusamäe + */ +class ErrorLogHandler extends AbstractProcessingHandler +{ + const OPERATING_SYSTEM = 0; + const SAPI = 4; + + protected $messageType; + protected $expandNewlines; + + /** + * @param integer $messageType Says where the error should go. + * @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 $expandNewlines If set to true, newlines in the message will be expanded to be take multiple log entries + */ + public function __construct($messageType = self::OPERATING_SYSTEM, $level = Logger::DEBUG, $bubble = true, $expandNewlines = false) + { + parent::__construct($level, $bubble); + + if (false === in_array($messageType, self::getAvailableTypes())) { + $message = sprintf('The given message type "%s" is not supported', print_r($messageType, true)); + throw new \InvalidArgumentException($message); + } + + $this->messageType = $messageType; + $this->expandNewlines = $expandNewlines; + } + + /** + * @return array With all available types + */ + public static function getAvailableTypes() + { + return array( + self::OPERATING_SYSTEM, + self::SAPI, + ); + } + + /** + * {@inheritDoc} + */ + protected function getDefaultFormatter() + { + return new LineFormatter('[%datetime%] %channel%.%level_name%: %message% %context% %extra%'); + } + + /** + * {@inheritdoc} + */ + protected function write(array $record) + { + if ($this->expandNewlines) { + $lines = preg_split('{[\r\n]+}', (string) $record['formatted']); + foreach ($lines as $line) { + error_log($line, $this->messageType); + } + } else { + error_log((string) $record['formatted'], $this->messageType); + } + } +} diff --git a/vendor/aws/Monolog/Handler/ExceptionTestHandler.php b/vendor/aws/Monolog/Handler/ExceptionTestHandler.php new file mode 100644 index 0000000..f16db60 --- /dev/null +++ b/vendor/aws/Monolog/Handler/ExceptionTestHandler.php @@ -0,0 +1,34 @@ + + * + * 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. It + * throws an exception from handle and handleBatch to test the + * WhatFailureGroupHandler Class. + * + * @author Craig D'Amelio + */ +class ExceptionTestHandler extends TestHandler +{ + /** + * {@inheritdoc} + */ + public function handle(array $record) { + $return = parent::handle($record); + throw new \Exception("ExceptionTestHandler::handle"); + } +} diff --git a/vendor/aws/Monolog/Handler/FilterHandler.php b/vendor/aws/Monolog/Handler/FilterHandler.php new file mode 100644 index 0000000..dad8227 --- /dev/null +++ b/vendor/aws/Monolog/Handler/FilterHandler.php @@ -0,0 +1,140 @@ + + * + * 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; + +/** + * Simple handler wrapper that filters records based on a list of levels + * + * It can be configured with an exact list of levels to allow, or a min/max level. + * + * @author Hennadiy Verkh + * @author Jordi Boggiano + */ +class FilterHandler extends AbstractHandler +{ + /** + * Handler or factory callable($record, $this) + * + * @var callable|\Monolog\Handler\HandlerInterface + */ + protected $handler; + + /** + * Minimum level for logs that are passes to handler + * + * @var int[] + */ + protected $acceptedLevels; + + /** + * Whether the messages that are handled can bubble up the stack or not + * + * @var Boolean + */ + protected $bubble; + + /** + * @param callable|HandlerInterface $handler Handler or factory callable($record, $this). + * @param int|array $minLevelOrList A list of levels to accept or a minimum level if maxLevel is provided + * @param int $maxLevel Maximum level to accept, only used if $minLevelOrList is not an array + * @param Boolean $bubble Whether the messages that are handled can bubble up the stack or not + */ + public function __construct($handler, $minLevelOrList = Logger::DEBUG, $maxLevel = Logger::EMERGENCY, $bubble = true) + { + $this->handler = $handler; + $this->bubble = $bubble; + $this->setAcceptedLevels($minLevelOrList, $maxLevel); + + if (!$this->handler instanceof HandlerInterface && !is_callable($this->handler)) { + throw new \RuntimeException("The given handler (".json_encode($this->handler).") is not a callable nor a Monolog\Handler\HandlerInterface object"); + } + } + + /** + * @return array + */ + public function getAcceptedLevels() + { + return array_flip($this->acceptedLevels); + } + + /** + * @param int|array $minLevelOrList A list of levels to accept or a minimum level if maxLevel is provided + * @param int $maxLevel Maximum level to accept, only used if $minLevelOrList is not an array + */ + public function setAcceptedLevels($minLevelOrList = Logger::DEBUG, $maxLevel = Logger::EMERGENCY) + { + if (is_array($minLevelOrList)) { + $acceptedLevels = array_map('Monolog\Logger::toMonologLevel', $minLevelOrList); + } else { + $minLevelOrList = Logger::toMonologLevel($minLevelOrList); + $maxLevel = Logger::toMonologLevel($maxLevel); + $acceptedLevels = array_values(array_filter(Logger::getLevels(), function ($level) use ($minLevelOrList, $maxLevel) { + return $level >= $minLevelOrList && $level <= $maxLevel; + })); + } + $this->acceptedLevels = array_flip($acceptedLevels); + } + + /** + * {@inheritdoc} + */ + public function isHandling(array $record) + { + return isset($this->acceptedLevels[$record['level']]); + } + + /** + * {@inheritdoc} + */ + public function handle(array $record) + { + if (!$this->isHandling($record)) { + return false; + } + + // The same logic as in FingersCrossedHandler + if (!$this->handler instanceof HandlerInterface) { + $this->handler = call_user_func($this->handler, $record, $this); + if (!$this->handler instanceof HandlerInterface) { + throw new \RuntimeException("The factory callable should return a HandlerInterface"); + } + } + + if ($this->processors) { + foreach ($this->processors as $processor) { + $record = call_user_func($processor, $record); + } + } + + $this->handler->handle($record); + + return false === $this->bubble; + } + + /** + * {@inheritdoc} + */ + public function handleBatch(array $records) + { + $filtered = array(); + foreach ($records as $record) { + if ($this->isHandling($record)) { + $filtered[] = $record; + } + } + + $this->handler->handleBatch($filtered); + } +} diff --git a/vendor/aws/Monolog/Handler/FingersCrossed/ActivationStrategyInterface.php b/vendor/aws/Monolog/Handler/FingersCrossed/ActivationStrategyInterface.php new file mode 100644 index 0000000..c3e42ef --- /dev/null +++ b/vendor/aws/Monolog/Handler/FingersCrossed/ActivationStrategyInterface.php @@ -0,0 +1,28 @@ + + * + * 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); +} diff --git a/vendor/aws/Monolog/Handler/FingersCrossed/ChannelLevelActivationStrategy.php b/vendor/aws/Monolog/Handler/FingersCrossed/ChannelLevelActivationStrategy.php new file mode 100644 index 0000000..e3b403f --- /dev/null +++ b/vendor/aws/Monolog/Handler/FingersCrossed/ChannelLevelActivationStrategy.php @@ -0,0 +1,59 @@ + +* +* For the full copyright and license information, please view the LICENSE +* file that was distributed with this source code. +*/ + +namespace Monolog\Handler\FingersCrossed; + +use Monolog\Logger; + +/** + * Channel and Error level based monolog activation strategy. Allows to trigger activation + * based on level per channel. e.g. trigger activation on level 'ERROR' by default, except + * for records of the 'sql' channel; those should trigger activation on level 'WARN'. + * + * Example: + * + * + * $activationStrategy = new ChannelLevelActivationStrategy( + * Logger::CRITICAL, + * array( + * 'request' => Logger::ALERT, + * 'sensitive' => Logger::ERROR, + * ) + * ); + * $handler = new FingersCrossedHandler(new StreamHandler('php://stderr'), $activationStrategy); + * + * + * @author Mike Meessen + */ +class ChannelLevelActivationStrategy implements ActivationStrategyInterface +{ + private $defaultActionLevel; + private $channelToActionLevel; + + /** + * @param int $defaultActionLevel The default action level to be used if the record's category doesn't match any + * @param array $channelToActionLevel An array that maps channel names to action levels. + */ + public function __construct($defaultActionLevel, $channelToActionLevel = array()) + { + $this->defaultActionLevel = Logger::toMonologLevel($defaultActionLevel); + $this->channelToActionLevel = array_map('Monolog\Logger::toMonologLevel', $channelToActionLevel); + } + + public function isHandlerActivated(array $record) + { + if (isset($this->channelToActionLevel[$record['channel']])) { + return $record['level'] >= $this->channelToActionLevel[$record['channel']]; + } + + return $record['level'] >= $this->defaultActionLevel; + } +} diff --git a/vendor/aws/Monolog/Handler/FingersCrossed/ErrorLevelActivationStrategy.php b/vendor/aws/Monolog/Handler/FingersCrossed/ErrorLevelActivationStrategy.php new file mode 100644 index 0000000..6e63085 --- /dev/null +++ b/vendor/aws/Monolog/Handler/FingersCrossed/ErrorLevelActivationStrategy.php @@ -0,0 +1,34 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Monolog\Handler\FingersCrossed; + +use Monolog\Logger; + +/** + * Error level based activation strategy. + * + * @author Johannes M. Schmitt + */ +class ErrorLevelActivationStrategy implements ActivationStrategyInterface +{ + private $actionLevel; + + public function __construct($actionLevel) + { + $this->actionLevel = Logger::toMonologLevel($actionLevel); + } + + public function isHandlerActivated(array $record) + { + return $record['level'] >= $this->actionLevel; + } +} diff --git a/vendor/aws/Monolog/Handler/FingersCrossedHandler.php b/vendor/aws/Monolog/Handler/FingersCrossedHandler.php new file mode 100644 index 0000000..a81c9e6 --- /dev/null +++ b/vendor/aws/Monolog/Handler/FingersCrossedHandler.php @@ -0,0 +1,150 @@ + + * + * 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. + * + * You can find the various activation strategies in the + * Monolog\Handler\FingersCrossed\ namespace. + * + * @author Jordi Boggiano + */ +class FingersCrossedHandler extends AbstractHandler +{ + protected $handler; + protected $activationStrategy; + protected $buffering = true; + protected $bufferSize; + protected $buffer = array(); + protected $stopBuffering; + protected $passthruLevel; + + /** + * @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) + * @param int $passthruLevel Minimum level to always flush to handler on close, even if strategy not triggered + */ + public function __construct($handler, $activationStrategy = null, $bufferSize = 0, $bubble = true, $stopBuffering = true, $passthruLevel = null) + { + if (null === $activationStrategy) { + $activationStrategy = new ErrorLevelActivationStrategy(Logger::WARNING); + } + + // convert simple int activationStrategy to an object + if (!$activationStrategy instanceof ActivationStrategyInterface) { + $activationStrategy = new ErrorLevelActivationStrategy($activationStrategy); + } + + $this->handler = $handler; + $this->activationStrategy = $activationStrategy; + $this->bufferSize = $bufferSize; + $this->bubble = $bubble; + $this->stopBuffering = $stopBuffering; + $this->passthruLevel = $passthruLevel; + + if (!$this->handler instanceof HandlerInterface && !is_callable($this->handler)) { + throw new \RuntimeException("The given handler (".json_encode($this->handler).") is not a callable nor a Monolog\Handler\HandlerInterface object"); + } + } + + /** + * {@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) { + $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; + } + + /** + * {@inheritdoc} + */ + public function close() + { + if (null !== $this->passthruLevel) { + $level = $this->passthruLevel; + $this->buffer = array_filter($this->buffer, function ($record) use ($level) { + return $record['level'] >= $level; + }); + if (count($this->buffer) > 0) { + $this->handler->handleBatch($this->buffer); + $this->buffer = array(); + } + } + } + + /** + * Resets the state of the handler. Stops forwarding records to the wrapped handler. + */ + public function reset() + { + $this->buffering = true; + } + + /** + * Clears the buffer without flushing any messages down to the wrapped handler. + * + * It also resets the handler to its initial buffering state. + */ + public function clear() + { + $this->buffer = array(); + $this->reset(); + } +} diff --git a/vendor/aws/Monolog/Handler/FirePHPHandler.php b/vendor/aws/Monolog/Handler/FirePHPHandler.php new file mode 100644 index 0000000..fee4795 --- /dev/null +++ b/vendor/aws/Monolog/Handler/FirePHPHandler.php @@ -0,0 +1,195 @@ + + * + * 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) + { + if (!self::$sendHeaders) { + return; + } + + // WildFire-specific headers must be sent prior to any messages + if (!self::$initialized) { + self::$initialized = true; + + self::$sendHeaders = $this->headersAccepted(); + if (!self::$sendHeaders) { + return; + } + + foreach ($this->getInitHeaders() as $header => $content) { + $this->sendHeader($header, $content); + } + } + + $header = $this->createRecordHeader($record); + if (trim(current($header)) !== '') { + $this->sendHeader(key($header), current($header)); + } + } + + /** + * Verifies if the headers are accepted by the current user agent + * + * @return Boolean + */ + protected function headersAccepted() + { + if (!empty($_SERVER['HTTP_USER_AGENT']) && preg_match('{\bFirePHP/\d+\.\d+\b}', $_SERVER['HTTP_USER_AGENT'])) { + return true; + } + + return 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; + } +} diff --git a/vendor/aws/Monolog/Handler/FleepHookHandler.php b/vendor/aws/Monolog/Handler/FleepHookHandler.php new file mode 100644 index 0000000..388692c --- /dev/null +++ b/vendor/aws/Monolog/Handler/FleepHookHandler.php @@ -0,0 +1,126 @@ + + * + * 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; + +/** + * Sends logs to Fleep.io using Webhook integrations + * + * You'll need a Fleep.io account to use this handler. + * + * @see https://fleep.io/integrations/webhooks/ Fleep Webhooks Documentation + * @author Ando Roots + */ +class FleepHookHandler extends SocketHandler +{ + const FLEEP_HOST = 'fleep.io'; + + const FLEEP_HOOK_URI = '/hook/'; + + /** + * @var string Webhook token (specifies the conversation where logs are sent) + */ + protected $token; + + /** + * Construct a new Fleep.io Handler. + * + * For instructions on how to create a new web hook in your conversations + * see https://fleep.io/integrations/webhooks/ + * + * @param string $token Webhook token + * @param bool|int $level The minimum logging level at which this handler will be triggered + * @param bool $bubble Whether the messages that are handled can bubble up the stack or not + * @throws MissingExtensionException + */ + public function __construct($token, $level = Logger::DEBUG, $bubble = true) + { + if (!extension_loaded('openssl')) { + throw new MissingExtensionException('The OpenSSL PHP extension is required to use the FleepHookHandler'); + } + + $this->token = $token; + + $connectionString = 'ssl://' . self::FLEEP_HOST . ':443'; + parent::__construct($connectionString, $level, $bubble); + } + + /** + * Returns the default formatter to use with this handler + * + * Overloaded to remove empty context and extra arrays from the end of the log message. + * + * @return LineFormatter + */ + protected function getDefaultFormatter() + { + return new LineFormatter(null, null, true, true); + } + + /** + * Handles a log record + * + * @param array $record + */ + public function write(array $record) + { + parent::write($record); + $this->closeSocket(); + } + + /** + * {@inheritdoc} + * + * @param array $record + * @return string + */ + protected function generateDataStream($record) + { + $content = $this->buildContent($record); + + return $this->buildHeader($content) . $content; + } + + /** + * Builds the header of the API Call + * + * @param string $content + * @return string + */ + private function buildHeader($content) + { + $header = "POST " . self::FLEEP_HOOK_URI . $this->token . " HTTP/1.1\r\n"; + $header .= "Host: " . self::FLEEP_HOST . "\r\n"; + $header .= "Content-Type: application/x-www-form-urlencoded\r\n"; + $header .= "Content-Length: " . strlen($content) . "\r\n"; + $header .= "\r\n"; + + return $header; + } + + /** + * Builds the body of API call + * + * @param array $record + * @return string + */ + private function buildContent($record) + { + $dataArray = array( + 'message' => $record['formatted'] + ); + + return http_build_query($dataArray); + } +} diff --git a/vendor/aws/Monolog/Handler/FlowdockHandler.php b/vendor/aws/Monolog/Handler/FlowdockHandler.php new file mode 100644 index 0000000..6eaaa9d --- /dev/null +++ b/vendor/aws/Monolog/Handler/FlowdockHandler.php @@ -0,0 +1,103 @@ + + * + * 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 Flowdock push API + * + * This must be configured with a FlowdockFormatter instance via setFormatter() + * + * Notes: + * API token - Flowdock API token + * + * @author Dominik Liebler + * @see https://www.flowdock.com/api/push + */ +class FlowdockHandler extends SocketHandler +{ + /** + * @var string + */ + protected $apiToken; + + /** + * @param string $apiToken + * @param bool|int $level The minimum logging level at which this handler will be triggered + * @param bool $bubble Whether the messages that are handled can bubble up the stack or not + * + * @throws MissingExtensionException if OpenSSL is missing + */ + public function __construct($apiToken, $level = Logger::DEBUG, $bubble = true) + { + if (!extension_loaded('openssl')) { + throw new MissingExtensionException('The OpenSSL PHP extension is required to use the FlowdockHandler'); + } + + parent::__construct('ssl://api.flowdock.com:443', $level, $bubble); + $this->apiToken = $apiToken; + } + + /** + * {@inheritdoc} + * + * @param array $record + */ + protected function write(array $record) + { + parent::write($record); + + $this->closeSocket(); + } + + /** + * {@inheritdoc} + * + * @param array $record + * @return string + */ + protected function generateDataStream($record) + { + $content = $this->buildContent($record); + + return $this->buildHeader($content) . $content; + } + + /** + * Builds the body of API call + * + * @param array $record + * @return string + */ + private function buildContent($record) + { + return json_encode($record['formatted']['flowdock']); + } + + /** + * Builds the header of the API Call + * + * @param string $content + * @return string + */ + private function buildHeader($content) + { + $header = "POST /v1/messages/team_inbox/" . $this->apiToken . " HTTP/1.1\r\n"; + $header .= "Host: api.flowdock.com\r\n"; + $header .= "Content-Type: application/json\r\n"; + $header .= "Content-Length: " . strlen($content) . "\r\n"; + $header .= "\r\n"; + + return $header; + } +} diff --git a/vendor/aws/Monolog/Handler/GelfHandler.php b/vendor/aws/Monolog/Handler/GelfHandler.php new file mode 100644 index 0000000..790f636 --- /dev/null +++ b/vendor/aws/Monolog/Handler/GelfHandler.php @@ -0,0 +1,72 @@ + + * + * 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 Gelf\PublisherInterface; +use InvalidArgumentException; +use Monolog\Logger; +use Monolog\Formatter\GelfMessageFormatter; + +/** + * Handler to send messages to a Graylog2 (http://www.graylog2.org) server + * + * @author Matt Lehner + * @author Benjamin Zikarsky + */ +class GelfHandler extends AbstractProcessingHandler +{ + /** + * @var Publisher the publisher object that sends the message to the server + */ + protected $publisher; + + /** + * @param PublisherInterface|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($publisher, $level = Logger::DEBUG, $bubble = true) + { + parent::__construct($level, $bubble); + + if (!$publisher instanceof IMessagePublisher && !$publisher instanceof PublisherInterface) { + throw new InvalidArgumentException("Invalid publisher, expected a Gelf\IMessagePublisher or Gelf\PublisherInterface instance"); + } + + $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(); + } +} diff --git a/vendor/aws/Monolog/Handler/GroupHandler.php b/vendor/aws/Monolog/Handler/GroupHandler.php new file mode 100644 index 0000000..99384d3 --- /dev/null +++ b/vendor/aws/Monolog/Handler/GroupHandler.php @@ -0,0 +1,80 @@ + + * + * 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); + } + } +} diff --git a/vendor/aws/Monolog/Handler/HandlerInterface.php b/vendor/aws/Monolog/Handler/HandlerInterface.php new file mode 100644 index 0000000..d920c4b --- /dev/null +++ b/vendor/aws/Monolog/Handler/HandlerInterface.php @@ -0,0 +1,90 @@ + + * + * 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 Partial log record containing only a level key + * + * @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 + * @return self + */ + 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 + * @return self + */ + public function setFormatter(FormatterInterface $formatter); + + /** + * Gets the formatter. + * + * @return FormatterInterface + */ + public function getFormatter(); +} diff --git a/vendor/aws/Monolog/Handler/HipChatHandler.php b/vendor/aws/Monolog/Handler/HipChatHandler.php new file mode 100644 index 0000000..185e86e --- /dev/null +++ b/vendor/aws/Monolog/Handler/HipChatHandler.php @@ -0,0 +1,306 @@ + + * + * 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 hipchat api to a hipchat room + * + * Notes: + * API token - HipChat API token + * Room - HipChat Room Id or name, where messages are sent + * Name - Name used to send the message (from) + * notify - Should the message trigger a notification in the clients + * + * @author Rafael Dohms + * @see https://www.hipchat.com/docs/api + */ +class HipChatHandler extends SocketHandler +{ + /** + * The maximum allowed length for the name used in the "from" field. + */ + const MAXIMUM_NAME_LENGTH = 15; + + /** + * The maximum allowed length for the message. + */ + const MAXIMUM_MESSAGE_LENGTH = 9500; + + /** + * @var string + */ + private $token; + + /** + * @var string + */ + private $room; + + /** + * @var string + */ + private $name; + + /** + * @var bool + */ + private $notify; + + /** + * @var string + */ + private $format; + + /** + * @var string + */ + private $host; + + /** + * @param string $token HipChat API Token + * @param string $room The room that should be alerted of the message (Id or Name) + * @param string $name Name used in the "from" field + * @param bool $notify Trigger a notification in clients or not + * @param int $level The minimum logging level at which this handler will be triggered + * @param bool $bubble Whether the messages that are handled can bubble up the stack or not + * @param bool $useSSL Whether to connect via SSL. + * @param string $format The format of the messages (default to text, can be set to html if you have html in the messages) + * @param string $host The HipChat server hostname. + */ + public function __construct($token, $room, $name = 'Monolog', $notify = false, $level = Logger::CRITICAL, $bubble = true, $useSSL = true, $format = 'text', $host = 'api.hipchat.com') + { + if (!$this->validateStringLength($name, static::MAXIMUM_NAME_LENGTH)) { + throw new \InvalidArgumentException('The supplied name is too long. HipChat\'s v1 API supports names up to 15 UTF-8 characters.'); + } + + $connectionString = $useSSL ? 'ssl://'.$host.':443' : $host.':80'; + parent::__construct($connectionString, $level, $bubble); + + $this->token = $token; + $this->name = $name; + $this->notify = $notify; + $this->room = $room; + $this->format = $format; + $this->host = $host; + } + + /** + * {@inheritdoc} + * + * @param array $record + * @return string + */ + protected function generateDataStream($record) + { + $content = $this->buildContent($record); + + return $this->buildHeader($content) . $content; + } + + /** + * Builds the body of API call + * + * @param array $record + * @return string + */ + private function buildContent($record) + { + $dataArray = array( + 'from' => $this->name, + 'room_id' => $this->room, + 'notify' => $this->notify, + 'message' => $record['formatted'], + 'message_format' => $this->format, + 'color' => $this->getAlertColor($record['level']), + ); + + return http_build_query($dataArray); + } + + /** + * Builds the header of the API Call + * + * @param string $content + * @return string + */ + private function buildHeader($content) + { + $header = "POST /v1/rooms/message?format=json&auth_token=".$this->token." HTTP/1.1\r\n"; + $header .= "Host: {$this->host}\r\n"; + $header .= "Content-Type: application/x-www-form-urlencoded\r\n"; + $header .= "Content-Length: " . strlen($content) . "\r\n"; + $header .= "\r\n"; + + return $header; + } + + /** + * Assigns a color to each level of log records. + * + * @param integer $level + * @return string + */ + protected function getAlertColor($level) + { + switch (true) { + case $level >= Logger::ERROR: + return 'red'; + case $level >= Logger::WARNING: + return 'yellow'; + case $level >= Logger::INFO: + return 'green'; + case $level == Logger::DEBUG: + return 'gray'; + default: + return 'yellow'; + } + } + + /** + * {@inheritdoc} + * + * @param array $record + */ + protected function write(array $record) + { + parent::write($record); + $this->closeSocket(); + } + + /** + * {@inheritdoc} + */ + public function handleBatch(array $records) + { + if (count($records) == 0) { + return true; + } + + $batchRecords = $this->combineRecords($records); + + $handled = false; + foreach ($batchRecords as $batchRecord) { + if ($this->isHandling($batchRecord)) { + $this->write($batchRecord); + $handled = true; + } + } + + if (!$handled) { + return false; + } + + return false === $this->bubble; + } + + /** + * Combines multiple records into one. Error level of the combined record + * will be the highest level from the given records. Datetime will be taken + * from the first record. + * + * @param $records + * @return array + */ + private function combineRecords($records) + { + $batchRecord = null; + $batchRecords = array(); + $messages = array(); + $formattedMessages = array(); + $level = 0; + $levelName = null; + $datetime = null; + + foreach ($records as $record) { + $record = $this->processRecord($record); + + if ($record['level'] > $level) { + $level = $record['level']; + $levelName = $record['level_name']; + } + + if (null === $datetime) { + $datetime = $record['datetime']; + } + + $messages[] = $record['message']; + $messageStr = implode(PHP_EOL, $messages); + $formattedMessages[] = $this->getFormatter()->format($record); + $formattedMessageStr = implode('', $formattedMessages); + + $batchRecord = array( + 'message' => $messageStr, + 'formatted' => $formattedMessageStr, + 'context' => array(), + 'extra' => array(), + ); + + if (!$this->validateStringLength($batchRecord['formatted'], static::MAXIMUM_MESSAGE_LENGTH)) { + // Pop the last message and implode the remaining messages + $lastMessage = array_pop($messages); + $lastFormattedMessage = array_pop($formattedMessages); + $batchRecord['message'] = implode(PHP_EOL, $messages); + $batchRecord['formatted'] = implode('', $formattedMessages); + + $batchRecords[] = $batchRecord; + $messages = array($lastMessage); + $formattedMessages = array($lastFormattedMessage); + + $batchRecord = null; + } + } + + if (null !== $batchRecord) { + $batchRecords[] = $batchRecord; + } + + // Set the max level and datetime for all records + foreach ($batchRecords as &$batchRecord) { + $batchRecord = array_merge( + $batchRecord, + array( + 'level' => $level, + 'level_name' => $levelName, + 'datetime' => $datetime + ) + ); + } + + return $batchRecords; + } + + /** + * Validates the length of a string. + * + * If the `mb_strlen()` function is available, it will use that, as HipChat + * allows UTF-8 characters. Otherwise, it will fall back to `strlen()`. + * + * Note that this might cause false failures in the specific case of using + * a valid name with less than 16 characters, but 16 or more bytes, on a + * system where `mb_strlen()` is unavailable. + * + * @param string $str + * @param int $length + * + * @return bool + */ + private function validateStringLength($str, $length) + { + if (function_exists('mb_strlen')) { + return (mb_strlen($str) <= $length); + } + + return (strlen($str) <= $length); + } +} diff --git a/vendor/aws/Monolog/Handler/LogEntriesHandler.php b/vendor/aws/Monolog/Handler/LogEntriesHandler.php new file mode 100644 index 0000000..bd56230 --- /dev/null +++ b/vendor/aws/Monolog/Handler/LogEntriesHandler.php @@ -0,0 +1,55 @@ + + * + * 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; + +/** + * @author Robert Kaufmann III + */ +class LogEntriesHandler extends SocketHandler +{ + /** + * @var string + */ + protected $logToken; + + /** + * @param string $token Log token supplied by LogEntries + * @param boolean $useSSL Whether or not SSL encryption should be used. + * @param int $level The minimum logging level to trigger this handler + * @param boolean $bubble Whether or not messages that are handled should bubble up the stack. + * + * @throws MissingExtensionException If SSL encryption is set to true and OpenSSL is missing + */ + public function __construct($token, $useSSL = true, $level = Logger::DEBUG, $bubble = true) + { + if ($useSSL && !extension_loaded('openssl')) { + throw new MissingExtensionException('The OpenSSL PHP plugin is required to use SSL encrypted connection for LogEntriesHandler'); + } + + $endpoint = $useSSL ? 'ssl://data.logentries.com:443' : 'data.logentries.com:80'; + parent::__construct($endpoint, $level, $bubble); + $this->logToken = $token; + } + + /** + * {@inheritdoc} + * + * @param array $record + * @return string + */ + protected function generateDataStream($record) + { + return $this->logToken . ' ' . $record['formatted']; + } +} diff --git a/vendor/aws/Monolog/Handler/LogglyHandler.php b/vendor/aws/Monolog/Handler/LogglyHandler.php new file mode 100644 index 0000000..efd94d3 --- /dev/null +++ b/vendor/aws/Monolog/Handler/LogglyHandler.php @@ -0,0 +1,98 @@ + + * + * 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\LogglyFormatter; + +/** + * Sends errors to Loggly. + * + * @author Przemek Sobstel + * @author Adam Pancutt + */ +class LogglyHandler extends AbstractProcessingHandler +{ + const HOST = 'logs-01.loggly.com'; + const ENDPOINT_SINGLE = 'inputs'; + const ENDPOINT_BATCH = 'bulk'; + + protected $token; + + protected $tag; + + public function __construct($token, $level = Logger::DEBUG, $bubble = true) + { + if (!extension_loaded('curl')) { + throw new \LogicException('The curl extension is needed to use the LogglyHandler'); + } + + $this->token = $token; + + parent::__construct($level, $bubble); + } + + public function setTag($tag) + { + $this->tag = $tag; + } + + public function addTag($tag) + { + $this->tag = (strlen($this->tag) > 0) ? $this->tag .','. $tag : $tag; + } + + protected function write(array $record) + { + $this->send($record["formatted"], self::ENDPOINT_SINGLE); + } + + public function handleBatch(array $records) + { + $level = $this->level; + + $records = array_filter($records, function ($record) use ($level) { + return ($record['level'] >= $level); + }); + + if ($records) { + $this->send($this->getFormatter()->formatBatch($records), self::ENDPOINT_BATCH); + } + } + + protected function send($data, $endpoint) + { + $url = sprintf("https://%s/%s/%s/", self::HOST, $endpoint, $this->token); + + $headers = array('Content-Type: application/json'); + + if ($this->tag) { + $headers[] = "X-LOGGLY-TAG: {$this->tag}"; + } + + $ch = curl_init(); + + curl_setopt($ch, CURLOPT_URL, $url); + curl_setopt($ch, CURLOPT_POST, true); + curl_setopt($ch, CURLOPT_POSTFIELDS, $data); + curl_setopt($ch, CURLOPT_HTTPHEADER, $headers); + curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); + + curl_exec($ch); + curl_close($ch); + } + + protected function getDefaultFormatter() + { + return new LogglyFormatter(); + } +} diff --git a/vendor/aws/Monolog/Handler/MailHandler.php b/vendor/aws/Monolog/Handler/MailHandler.php new file mode 100644 index 0000000..50ed638 --- /dev/null +++ b/vendor/aws/Monolog/Handler/MailHandler.php @@ -0,0 +1,55 @@ + + * + * 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 formatted email body to be sent + * @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)); + } +} diff --git a/vendor/aws/Monolog/Handler/MandrillHandler.php b/vendor/aws/Monolog/Handler/MandrillHandler.php new file mode 100644 index 0000000..60a2901 --- /dev/null +++ b/vendor/aws/Monolog/Handler/MandrillHandler.php @@ -0,0 +1,69 @@ + + * + * 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; + +/** + * MandrillHandler uses cURL to send the emails to the Mandrill API + * + * @author Adam Nicholson + */ +class MandrillHandler extends MailHandler +{ + protected $client; + protected $message; + + /** + * @param string $apiKey A valid Mandrill API key + * @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($apiKey, $message, $level = Logger::ERROR, $bubble = true) + { + parent::__construct($level, $bubble); + + 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; + $this->apiKey = $apiKey; + } + + /** + * {@inheritdoc} + */ + protected function send($content, array $records) + { + $message = clone $this->message; + $message->setBody($content); + $message->setDate(time()); + + $ch = curl_init(); + + curl_setopt($ch, CURLOPT_URL, 'https://mandrillapp.com/api/1.0/messages/send-raw.json'); + curl_setopt($ch, CURLOPT_POST, 1); + curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); + curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query(array( + 'key' => $this->apiKey, + 'raw_message' => (string) $message, + 'async' => false, + ))); + + curl_exec($ch); + curl_close($ch); + } +} diff --git a/vendor/aws/Monolog/Handler/MissingExtensionException.php b/vendor/aws/Monolog/Handler/MissingExtensionException.php new file mode 100644 index 0000000..4724a7e --- /dev/null +++ b/vendor/aws/Monolog/Handler/MissingExtensionException.php @@ -0,0 +1,21 @@ + + * + * 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 +{ +} diff --git a/vendor/aws/Monolog/Handler/MongoDBHandler.php b/vendor/aws/Monolog/Handler/MongoDBHandler.php new file mode 100644 index 0000000..6c431f2 --- /dev/null +++ b/vendor/aws/Monolog/Handler/MongoDBHandler.php @@ -0,0 +1,55 @@ + + * + * 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 +{ + protected $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(); + } +} diff --git a/vendor/aws/Monolog/Handler/NativeMailerHandler.php b/vendor/aws/Monolog/Handler/NativeMailerHandler.php new file mode 100644 index 0000000..5118a0e --- /dev/null +++ b/vendor/aws/Monolog/Handler/NativeMailerHandler.php @@ -0,0 +1,176 @@ + + * + * 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 + * @author Mark Garrett + */ +class NativeMailerHandler extends MailHandler +{ + /** + * The email addresses to which the message will be sent + * @var array + */ + protected $to; + + /** + * The subject of the email + * @var string + */ + protected $subject; + + /** + * Optional headers for the message + * @var array + */ + protected $headers = array(); + + /** + * Optional parameters for the message + * @var array + */ + protected $parameters = array(); + + /** + * The wordwrap length for the message + * @var integer + */ + protected $maxColumnWidth; + + /** + * The Content-type for the message + * @var string + */ + protected $contentType = 'text/plain'; + + /** + * The encoding for the message + * @var string + */ + protected $encoding = '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 + * @param int $maxColumnWidth The maximum column width that the message lines will have + */ + public function __construct($to, $subject, $from, $level = Logger::ERROR, $bubble = true, $maxColumnWidth = 70) + { + parent::__construct($level, $bubble); + $this->to = is_array($to) ? $to : array($to); + $this->subject = $subject; + $this->addHeader(sprintf('From: %s', $from)); + $this->maxColumnWidth = $maxColumnWidth; + } + + /** + * Add headers to the message + * + * @param string|array $headers Custom added headers + * @return self + */ + 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; + } + + return $this; + } + + /** + * Add parameters to the message + * + * @param string|array $parameters Custom added parameters + * @return self + */ + public function addParameter($parameters) + { + $this->parameters = array_merge($this->parameters, (array) $parameters); + + return $this; + } + + /** + * {@inheritdoc} + */ + protected function send($content, array $records) + { + $content = wordwrap($content, $this->maxColumnWidth); + $headers = ltrim(implode("\r\n", $this->headers) . "\r\n", "\r\n"); + $headers .= 'Content-type: ' . $this->getContentType() . '; charset=' . $this->getEncoding() . "\r\n"; + if ($this->getContentType() == 'text/html' && false === strpos($headers, 'MIME-Version:')) { + $headers .= 'MIME-Version: 1.0' . "\r\n"; + } + foreach ($this->to as $to) { + mail($to, $this->subject, $content, $headers, implode(' ', $this->parameters)); + } + } + + /** + * @return string $contentType + */ + public function getContentType() + { + return $this->contentType; + } + + /** + * @return string $encoding + */ + public function getEncoding() + { + return $this->encoding; + } + + /** + * @param string $contentType The content type of the email - Defaults to text/plain. Use text/html for HTML + * messages. + * @return self + */ + public function setContentType($contentType) + { + if (strpos($contentType, "\n") !== false || strpos($contentType, "\r") !== false) { + throw new \InvalidArgumentException('The content type can not contain newline characters to prevent email header injection'); + } + + $this->contentType = $contentType; + + return $this; + } + + /** + * @param string $encoding + * @return self + */ + public function setEncoding($encoding) + { + if (strpos($encoding, "\n") !== false || strpos($encoding, "\r") !== false) { + throw new \InvalidArgumentException('The encoding can not contain newline characters to prevent email header injection'); + } + + $this->encoding = $encoding; + + return $this; + } +} diff --git a/vendor/aws/Monolog/Handler/NewRelicHandler.php b/vendor/aws/Monolog/Handler/NewRelicHandler.php new file mode 100644 index 0000000..0c26794 --- /dev/null +++ b/vendor/aws/Monolog/Handler/NewRelicHandler.php @@ -0,0 +1,176 @@ + + * + * 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; + +/** + * Class to record a log on a NewRelic application. + * Enabling New Relic High Security mode may prevent capture of useful information. + * + * @see https://docs.newrelic.com/docs/agents/php-agent + * @see https://docs.newrelic.com/docs/accounts-partnerships/accounts/security/high-security + */ +class NewRelicHandler extends AbstractProcessingHandler +{ + /** + * Name of the New Relic application that will receive logs from this handler. + * + * @var string + */ + protected $appName; + + /** + * Name of the current transaction + * + * @var string + */ + protected $transactionName; + + /** + * Some context and extra data is passed into the handler as arrays of values. Do we send them as is + * (useful if we are using the API), or explode them for display on the NewRelic RPM website? + * + * @var boolean + */ + protected $explodeArrays; + + /** + * {@inheritDoc} + * + * @param string $appName + * @param boolean $explodeArrays + * @param string $transactionName + */ + public function __construct( + $level = Logger::ERROR, + $bubble = true, + $appName = null, + $explodeArrays = false, + $transactionName = null + ) { + parent::__construct($level, $bubble); + + $this->appName = $appName; + $this->explodeArrays = $explodeArrays; + $this->transactionName = $transactionName; + } + + /** + * {@inheritDoc} + */ + protected function write(array $record) + { + if (!$this->isNewRelicEnabled()) { + throw new MissingExtensionException('The newrelic PHP extension is required to use the NewRelicHandler'); + } + + if ($appName = $this->getAppName($record['context'])) { + $this->setNewRelicAppName($appName); + } + + if ($transactionName = $this->getTransactionName($record['context'])) { + $this->setNewRelicTransactionName($transactionName); + unset($record['context']['transaction_name']); + } + + if (isset($record['context']['exception']) && $record['context']['exception'] instanceof \Exception) { + newrelic_notice_error($record['message'], $record['context']['exception']); + unset($record['context']['exception']); + } else { + newrelic_notice_error($record['message']); + } + + foreach ($record['context'] as $key => $parameter) { + if (is_array($parameter) && $this->explodeArrays) { + foreach ($parameter as $paramKey => $paramValue) { + newrelic_add_custom_parameter('context_' . $key . '_' . $paramKey, $paramValue); + } + } else { + newrelic_add_custom_parameter('context_' . $key, $parameter); + } + } + + foreach ($record['extra'] as $key => $parameter) { + if (is_array($parameter) && $this->explodeArrays) { + foreach ($parameter as $paramKey => $paramValue) { + newrelic_add_custom_parameter('extra_' . $key . '_' . $paramKey, $paramValue); + } + } else { + newrelic_add_custom_parameter('extra_' . $key, $parameter); + } + } + } + + /** + * Checks whether the NewRelic extension is enabled in the system. + * + * @return bool + */ + protected function isNewRelicEnabled() + { + return extension_loaded('newrelic'); + } + + /** + * Returns the appname where this log should be sent. Each log can override the default appname, set in this + * handler's constructor, by providing the appname in it's context. + * + * @param array $context + * @return null|string + */ + protected function getAppName(array $context) + { + if (isset($context['appname'])) { + return $context['appname']; + } + + return $this->appName; + } + + /** + * Returns the name of the current transaction. Each log can override the default transaction name, set in this + * handler's constructor, by providing the transaction_name in it's context + * + * @param array $context + * + * @return null|string + */ + protected function getTransactionName(array $context) + { + if (isset($context['transaction_name'])) { + return $context['transaction_name']; + } + + return $this->transactionName; + } + + /** + * Sets the NewRelic application that should receive this log. + * + * @param string $appName + */ + protected function setNewRelicAppName($appName) + { + newrelic_set_appname($appName); + } + + /** + * Overwrites the name of the current transaction + * + * @param $transactionName + */ + protected function setNewRelicTransactionName($transactionName) + { + newrelic_name_transaction($transactionName); + } +} diff --git a/vendor/aws/Monolog/Handler/NullHandler.php b/vendor/aws/Monolog/Handler/NullHandler.php new file mode 100644 index 0000000..3754e45 --- /dev/null +++ b/vendor/aws/Monolog/Handler/NullHandler.php @@ -0,0 +1,45 @@ + + * + * 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; + } +} diff --git a/vendor/aws/Monolog/Handler/PsrHandler.php b/vendor/aws/Monolog/Handler/PsrHandler.php new file mode 100644 index 0000000..1ae8584 --- /dev/null +++ b/vendor/aws/Monolog/Handler/PsrHandler.php @@ -0,0 +1,56 @@ + + * + * 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 Psr\Log\LoggerInterface; + +/** + * Proxies log messages to an existing PSR-3 compliant logger. + * + * @author Michael Moussa + */ +class PsrHandler extends AbstractHandler +{ + /** + * PSR-3 compliant logger + * + * @var LoggerInterface + */ + protected $logger; + + /** + * @param LoggerInterface $logger The underlying PSR-3 compliant logger to which messages will be proxied + * @param int $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(LoggerInterface $logger, $level = Logger::DEBUG, $bubble = true) + { + parent::__construct($level, $bubble); + + $this->logger = $logger; + } + + /** + * {@inheritDoc} + */ + public function handle(array $record) + { + if (!$this->isHandling($record)) { + return false; + } + + $this->logger->log(strtolower($record['level_name']), $record['message'], $record['context']); + + return false === $this->bubble; + } +} diff --git a/vendor/aws/Monolog/Handler/PushoverHandler.php b/vendor/aws/Monolog/Handler/PushoverHandler.php new file mode 100644 index 0000000..cd2fcfa --- /dev/null +++ b/vendor/aws/Monolog/Handler/PushoverHandler.php @@ -0,0 +1,172 @@ + + * + * 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 $users; + private $title; + private $user; + private $retry; + private $expire; + + private $highPriorityLevel; + private $emergencyLevel; + + /** + * All parameters that can be sent to Pushover + * @see https://pushover.net/api + * @var array + */ + private $parameterNames = array( + 'token' => true, + 'user' => true, + 'message' => true, + 'device' => true, + 'title' => true, + 'url' => true, + 'url_title' => true, + 'priority' => true, + 'timestamp' => true, + 'sound' => true, + 'retry' => true, + 'expire' => true, + 'callback' => true, + ); + + /** + * Sounds the api supports by default + * @see https://pushover.net/api#sounds + * @var array + */ + private $sounds = array( + 'pushover', 'bike', 'bugle', 'cashregister', 'classical', 'cosmic', 'falling', 'gamelan', 'incoming', + 'intermission', 'magic', 'mechanical', 'pianobar', 'siren', 'spacealarm', 'tugboat', 'alien', 'climb', + 'persistent', 'echo', 'updown', 'none', + ); + + /** + * @param string $token Pushover api token + * @param string|array $users Pushover user id or array of ids the message will be sent to + * @param string $title Title sent to the 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. + * @param integer $highPriorityLevel The minimum logging level at which this handler will start + * sending "high priority" requests to the Pushover API + * @param integer $emergencyLevel The minimum logging level at which this handler will start + * sending "emergency" requests to the Pushover API + * @param integer $retry The retry parameter specifies how often (in seconds) the Pushover servers will send the same notification to the user. + * @param integer $expire The expire parameter specifies how many seconds your notification will continue to be retried for (every retry seconds). + */ + public function __construct($token, $users, $title = null, $level = Logger::CRITICAL, $bubble = true, $useSSL = true, $highPriorityLevel = Logger::CRITICAL, $emergencyLevel = Logger::EMERGENCY, $retry = 30, $expire = 25200) + { + $connectionString = $useSSL ? 'ssl://api.pushover.net:443' : 'api.pushover.net:80'; + parent::__construct($connectionString, $level, $bubble); + + $this->token = $token; + $this->users = (array) $users; + $this->title = $title ?: gethostname(); + $this->highPriorityLevel = Logger::toMonologLevel($highPriorityLevel); + $this->emergencyLevel = Logger::toMonologLevel($emergencyLevel); + $this->retry = $retry; + $this->expire = $expire; + } + + 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 + ); + + if (isset($record['level']) && $record['level'] >= $this->emergencyLevel) { + $dataArray['priority'] = 2; + $dataArray['retry'] = $this->retry; + $dataArray['expire'] = $this->expire; + } elseif (isset($record['level']) && $record['level'] >= $this->highPriorityLevel) { + $dataArray['priority'] = 1; + } + + // First determine the available parameters + $context = array_intersect_key($record['context'], $this->parameterNames); + $extra = array_intersect_key($record['extra'], $this->parameterNames); + + // Least important info should be merged with subsequent info + $dataArray = array_merge($extra, $context, $dataArray); + + // Only pass sounds that are supported by the API + if (isset($dataArray['sound']) && !in_array($dataArray['sound'], $this->sounds)) { + unset($dataArray['sound']); + } + + 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; + } + + protected function write(array $record) + { + foreach ($this->users as $user) { + $this->user = $user; + + parent::write($record); + $this->closeSocket(); + } + + $this->user = null; + } + + public function setHighPriorityLevel($value) + { + $this->highPriorityLevel = $value; + } + + public function setEmergencyLevel($value) + { + $this->emergencyLevel = $value; + } +} diff --git a/vendor/aws/Monolog/Handler/RavenHandler.php b/vendor/aws/Monolog/Handler/RavenHandler.php new file mode 100644 index 0000000..69da8ca --- /dev/null +++ b/vendor/aws/Monolog/Handler/RavenHandler.php @@ -0,0 +1,187 @@ + + * + * 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\Formatter\FormatterInterface; +use Monolog\Logger; +use Raven_Client; + +/** + * Handler to send messages to a Sentry (https://github.com/getsentry/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; + + /** + * @var LineFormatter The formatter to use for the logs generated via handleBatch() + */ + protected $batchFormatter; + + /** + * @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} + */ + public function handleBatch(array $records) + { + $level = $this->level; + + // filter records based on their level + $records = array_filter($records, function ($record) use ($level) { + return $record['level'] >= $level; + }); + + if (!$records) { + return; + } + + // the record with the highest severity is the "main" one + $record = array_reduce($records, function ($highest, $record) { + if ($record['level'] >= $highest['level']) { + return $record; + } + + return $highest; + }); + + // the other ones are added as a context item + $logs = array(); + foreach ($records as $r) { + $logs[] = $this->processRecord($r); + } + + if ($logs) { + $record['context']['logs'] = (string) $this->getBatchFormatter()->formatBatch($logs); + } + + $this->handle($record); + } + + /** + * Sets the formatter for the logs generated by handleBatch(). + * + * @param FormatterInterface $formatter + */ + public function setBatchFormatter(FormatterInterface $formatter) + { + $this->batchFormatter = $formatter; + } + + /** + * Gets the formatter for the logs generated by handleBatch(). + * + * @return FormatterInterface + */ + public function getBatchFormatter() + { + if (!$this->batchFormatter) { + $this->batchFormatter = $this->getDefaultBatchFormatter(); + } + + return $this->batchFormatter; + } + + /** + * {@inheritdoc} + */ + protected function write(array $record) + { + // ensures user context is empty + $this->ravenClient->user_context(null); + $options = array(); + $options['level'] = $this->logLevels[$record['level']]; + $options['tags'] = array(); + if (!empty($record['extra']['tags'])) { + $options['tags'] = array_merge($options['tags'], $record['extra']['tags']); + unset($record['extra']['tags']); + } + if (!empty($record['context']['tags'])) { + $options['tags'] = array_merge($options['tags'], $record['context']['tags']); + unset($record['context']['tags']); + } + if (!empty($record['context']['logger'])) { + $options['logger'] = $record['context']['logger']; + unset($record['context']['logger']); + } else { + $options['logger'] = $record['channel']; + } + if (!empty($record['context'])) { + $options['extra']['context'] = $record['context']; + if (!empty($record['context']['user'])) { + $this->ravenClient->user_context($record['context']['user']); + unset($options['extra']['context']['user']); + } + } + if (!empty($record['extra'])) { + $options['extra']['extra'] = $record['extra']; + } + + if (isset($record['context']['exception']) && $record['context']['exception'] instanceof \Exception) { + $options['extra']['message'] = $record['formatted']; + $this->ravenClient->captureException($record['context']['exception'], $options); + + return; + } + + $this->ravenClient->captureMessage($record['formatted'], array(), $options); + } + + /** + * {@inheritDoc} + */ + protected function getDefaultFormatter() + { + return new LineFormatter('[%channel%] %message%'); + } + + /** + * Gets the default formatter for the logs generated by handleBatch(). + * + * @return FormatterInterface + */ + protected function getDefaultBatchFormatter() + { + return new LineFormatter(); + } +} diff --git a/vendor/aws/Monolog/Handler/RedisHandler.php b/vendor/aws/Monolog/Handler/RedisHandler.php new file mode 100644 index 0000000..3fc7f34 --- /dev/null +++ b/vendor/aws/Monolog/Handler/RedisHandler.php @@ -0,0 +1,58 @@ + + * + * 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(); + } +} diff --git a/vendor/aws/Monolog/Handler/RollbarHandler.php b/vendor/aws/Monolog/Handler/RollbarHandler.php new file mode 100644 index 0000000..81abf08 --- /dev/null +++ b/vendor/aws/Monolog/Handler/RollbarHandler.php @@ -0,0 +1,73 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Monolog\Handler; + +use RollbarNotifier; +use Exception; +use Monolog\Logger; + +/** + * Sends errors to Rollbar + * + * @author Paul Statezny + */ +class RollbarHandler extends AbstractProcessingHandler +{ + /** + * Rollbar notifier + * + * @var RollbarNotifier + */ + protected $rollbarNotifier; + + /** + * @param RollbarNotifier $rollbarNotifier RollbarNotifier object constructed with valid token + * @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(RollbarNotifier $rollbarNotifier, $level = Logger::ERROR, $bubble = true) + { + $this->rollbarNotifier = $rollbarNotifier; + + parent::__construct($level, $bubble); + } + + /** + * {@inheritdoc} + */ + protected function write(array $record) + { + if (isset($record['context']['exception']) && $record['context']['exception'] instanceof Exception) { + $this->rollbarNotifier->report_exception($record['context']['exception']); + } else { + $extraData = array( + 'level' => $record['level'], + 'channel' => $record['channel'], + 'datetime' => $record['datetime']->format('U'), + ); + + $this->rollbarNotifier->report_message( + $record['message'], + $record['level_name'], + array_merge($record['context'], $record['extra'], $extraData) + ); + } + } + + /** + * {@inheritdoc} + */ + public function close() + { + $this->rollbarNotifier->flush(); + } +} diff --git a/vendor/aws/Monolog/Handler/RotatingFileHandler.php b/vendor/aws/Monolog/Handler/RotatingFileHandler.php new file mode 100644 index 0000000..4168c32 --- /dev/null +++ b/vendor/aws/Monolog/Handler/RotatingFileHandler.php @@ -0,0 +1,153 @@ + + * + * 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; + protected $filenameFormat; + protected $dateFormat; + + /** + * @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 + * @param int|null $filePermission Optional file permissions (default (0644) are only for owner read/write) + * @param Boolean $useLocking Try to lock log file before doing any writes + */ + public function __construct($filename, $maxFiles = 0, $level = Logger::DEBUG, $bubble = true, $filePermission = null, $useLocking = false) + { + $this->filename = $filename; + $this->maxFiles = (int) $maxFiles; + $this->nextRotation = new \DateTime('tomorrow'); + $this->filenameFormat = '{filename}-{date}'; + $this->dateFormat = 'Y-m-d'; + + parent::__construct($this->getTimedFilename(), $level, $bubble, $filePermission, $useLocking); + } + + /** + * {@inheritdoc} + */ + public function close() + { + parent::close(); + + if (true === $this->mustRotate) { + $this->rotate(); + } + } + + public function setFilenameFormat($filenameFormat, $dateFormat) + { + $this->filenameFormat = $filenameFormat; + $this->dateFormat = $dateFormat; + $this->url = $this->getTimedFilename(); + $this->close(); + } + + /** + * {@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; + } + + $logFiles = glob($this->getGlobPattern()); + if ($this->maxFiles >= count($logFiles)) { + // no files to remove + return; + } + + // Sorting the files by name to remove the older ones + usort($logFiles, function ($a, $b) { + return strcmp($b, $a); + }); + + foreach (array_slice($logFiles, $this->maxFiles) as $file) { + if (is_writable($file)) { + unlink($file); + } + } + } + + protected function getTimedFilename() + { + $fileInfo = pathinfo($this->filename); + $timedFilename = str_replace( + array('{filename}', '{date}'), + array($fileInfo['filename'], date($this->dateFormat)), + $fileInfo['dirname'] . '/' . $this->filenameFormat + ); + + if (!empty($fileInfo['extension'])) { + $timedFilename .= '.'.$fileInfo['extension']; + } + + return $timedFilename; + } + + protected function getGlobPattern() + { + $fileInfo = pathinfo($this->filename); + $glob = str_replace( + array('{filename}', '{date}'), + array($fileInfo['filename'], '*'), + $fileInfo['dirname'] . '/' . $this->filenameFormat + ); + if (!empty($fileInfo['extension'])) { + $glob .= '.'.$fileInfo['extension']; + } + + return $glob; + } +} diff --git a/vendor/aws/Monolog/Handler/SamplingHandler.php b/vendor/aws/Monolog/Handler/SamplingHandler.php new file mode 100644 index 0000000..9509ae3 --- /dev/null +++ b/vendor/aws/Monolog/Handler/SamplingHandler.php @@ -0,0 +1,82 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Monolog\Handler; + +/** + * Sampling handler + * + * A sampled event stream can be useful for logging high frequency events in + * a production environment where you only need an idea of what is happening + * and are not concerned with capturing every occurrence. Since the decision to + * handle or not handle a particular event is determined randomly, the + * resulting sampled log is not guaranteed to contain 1/N of the events that + * occurred in the application, but based on the Law of large numbers, it will + * tend to be close to this ratio with a large number of attempts. + * + * @author Bryan Davis + * @author Kunal Mehta + */ +class SamplingHandler extends AbstractHandler +{ + /** + * @var callable|HandlerInterface $handler + */ + protected $handler; + + /** + * @var int $factor + */ + protected $factor; + + /** + * @param callable|HandlerInterface $handler Handler or factory callable($record, $fingersCrossedHandler). + * @param int $factor Sample factor + */ + public function __construct($handler, $factor) + { + parent::__construct(); + $this->handler = $handler; + $this->factor = $factor; + + if (!$this->handler instanceof HandlerInterface && !is_callable($this->handler)) { + throw new \RuntimeException("The given handler (".json_encode($this->handler).") is not a callable nor a Monolog\Handler\HandlerInterface object"); + } + } + + public function isHandling(array $record) + { + return $this->handler->isHandling($record); + } + + public function handle(array $record) + { + if ($this->isHandling($record) && mt_rand(1, $this->factor) === 1) { + // The same logic as in FingersCrossedHandler + if (!$this->handler instanceof HandlerInterface) { + $this->handler = call_user_func($this->handler, $record, $this); + if (!$this->handler instanceof HandlerInterface) { + throw new \RuntimeException("The factory callable should return a HandlerInterface"); + } + } + + if ($this->processors) { + foreach ($this->processors as $processor) { + $record = call_user_func($processor, $record); + } + } + + $this->handler->handle($record); + } + + return false === $this->bubble; + } +} diff --git a/vendor/aws/Monolog/Handler/SlackHandler.php b/vendor/aws/Monolog/Handler/SlackHandler.php new file mode 100644 index 0000000..7328dee --- /dev/null +++ b/vendor/aws/Monolog/Handler/SlackHandler.php @@ -0,0 +1,280 @@ + + * + * 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; + +/** + * Sends notifications through Slack API + * + * @author Greg Kedzierski + * @see https://api.slack.com/ + */ +class SlackHandler extends SocketHandler +{ + /** + * Slack API token + * @var string + */ + private $token; + + /** + * Slack channel (encoded ID or name) + * @var string + */ + private $channel; + + /** + * Name of a bot + * @var string + */ + private $username; + + /** + * Emoji icon name + * @var string + */ + private $iconEmoji; + + /** + * Whether the message should be added to Slack as attachment (plain text otherwise) + * @var bool + */ + private $useAttachment; + + /** + * Whether the the context/extra messages added to Slack as attachments are in a short style + * @var bool + */ + private $useShortAttachment; + + /** + * Whether the attachment should include context and extra data + * @var bool + */ + private $includeContextAndExtra; + + /** + * @var LineFormatter + */ + private $lineFormatter; + + /** + * @param string $token Slack API token + * @param string $channel Slack channel (encoded ID or name) + * @param string $username Name of a bot + * @param bool $useAttachment Whether the message should be added to Slack as attachment (plain text otherwise) + * @param string|null $iconEmoji The emoji name to use (or null) + * @param int $level The minimum logging level at which this handler will be triggered + * @param bool $bubble Whether the messages that are handled can bubble up the stack or not + * @param bool $useShortAttachment Whether the the context/extra messages added to Slack as attachments are in a short style + * @param bool $includeContextAndExtra Whether the attachment should include context and extra data + */ + public function __construct($token, $channel, $username = 'Monolog', $useAttachment = true, $iconEmoji = null, $level = Logger::CRITICAL, $bubble = true, $useShortAttachment = false, $includeContextAndExtra = false) + { + if (!extension_loaded('openssl')) { + throw new MissingExtensionException('The OpenSSL PHP extension is required to use the SlackHandler'); + } + + parent::__construct('ssl://slack.com:443', $level, $bubble); + + $this->token = $token; + $this->channel = $channel; + $this->username = $username; + $this->iconEmoji = trim($iconEmoji, ':'); + $this->useAttachment = $useAttachment; + $this->useShortAttachment = $useShortAttachment; + $this->includeContextAndExtra = $includeContextAndExtra; + if ($this->includeContextAndExtra) { + $this->lineFormatter = new LineFormatter; + } + } + + /** + * {@inheritdoc} + * + * @param array $record + * @return string + */ + protected function generateDataStream($record) + { + $content = $this->buildContent($record); + + return $this->buildHeader($content) . $content; + } + + /** + * Builds the body of API call + * + * @param array $record + * @return string + */ + private function buildContent($record) + { + $dataArray = array( + 'token' => $this->token, + 'channel' => $this->channel, + 'username' => $this->username, + 'text' => '', + 'attachments' => array() + ); + + if ($this->useAttachment) { + $attachment = array( + 'fallback' => $record['message'], + 'color' => $this->getAttachmentColor($record['level']) + ); + + if ($this->useShortAttachment) { + $attachment['fields'] = array( + array( + 'title' => $record['level_name'], + 'value' => $record['message'], + 'short' => false + ) + ); + } else { + $attachment['fields'] = array( + array( + 'title' => 'Message', + 'value' => $record['message'], + 'short' => false + ), + array( + 'title' => 'Level', + 'value' => $record['level_name'], + 'short' => true + ) + ); + } + + if ($this->includeContextAndExtra) { + if (!empty($record['extra'])) { + if ($this->useShortAttachment) { + $attachment['fields'][] = array( + 'title' => "Extra", + 'value' => $this->stringify($record['extra']), + 'short' => $this->useShortAttachment + ); + } else { + // Add all extra fields as individual fields in attachment + foreach ($record['extra'] as $var => $val) { + $attachment['fields'][] = array( + 'title' => $var, + 'value' => $val, + 'short' => $this->useShortAttachment + ); + } + } + } + + if (!empty($record['context'])) { + if ($this->useShortAttachment) { + $attachment['fields'][] = array( + 'title' => "Context", + 'value' => $this->stringify($record['context']), + 'short' => $this->useShortAttachment + ); + } else { + // Add all context fields as individual fields in attachment + foreach ($record['context'] as $var => $val) { + $attachment['fields'][] = array( + 'title' => $var, + 'value' => $val, + 'short' => $this->useShortAttachment + ); + } + } + } + } + + $dataArray['attachments'] = json_encode(array($attachment)); + } else { + $dataArray['text'] = $record['message']; + } + + if ($this->iconEmoji) { + $dataArray['icon_emoji'] = ":{$this->iconEmoji}:"; + } + + return http_build_query($dataArray); + } + + /** + * Builds the header of the API Call + * + * @param string $content + * @return string + */ + private function buildHeader($content) + { + $header = "POST /api/chat.postMessage HTTP/1.1\r\n"; + $header .= "Host: slack.com\r\n"; + $header .= "Content-Type: application/x-www-form-urlencoded\r\n"; + $header .= "Content-Length: " . strlen($content) . "\r\n"; + $header .= "\r\n"; + + return $header; + } + + /** + * {@inheritdoc} + * + * @param array $record + */ + protected function write(array $record) + { + parent::write($record); + $this->closeSocket(); + } + + /** + * Returned a Slack message attachment color associated with + * provided level. + * + * @param int $level + * @return string + */ + protected function getAttachmentColor($level) + { + switch (true) { + case $level >= Logger::ERROR: + return 'danger'; + case $level >= Logger::WARNING: + return 'warning'; + case $level >= Logger::INFO: + return 'good'; + default: + return '#e3e4e6'; + } + } + + /** + * Stringifies an array of key/value pairs to be used in attachment fields + * + * @param array $fields + * @access protected + * @return string + */ + protected function stringify($fields) + { + $string = ''; + foreach ($fields as $var => $val) { + $string .= $var.': '.$this->lineFormatter->stringify($val)." | "; + } + + $string = rtrim($string, " |"); + + return $string; + } +} diff --git a/vendor/aws/Monolog/Handler/SocketHandler.php b/vendor/aws/Monolog/Handler/SocketHandler.php new file mode 100644 index 0000000..ee486f6 --- /dev/null +++ b/vendor/aws/Monolog/Handler/SocketHandler.php @@ -0,0 +1,284 @@ + + * + * 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 + */ + protected 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)"); + } + } +} diff --git a/vendor/aws/Monolog/Handler/StreamHandler.php b/vendor/aws/Monolog/Handler/StreamHandler.php new file mode 100644 index 0000000..7965db7 --- /dev/null +++ b/vendor/aws/Monolog/Handler/StreamHandler.php @@ -0,0 +1,104 @@ + + * + * 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; + private $errorMessage; + protected $filePermission; + protected $useLocking; + + /** + * @param resource|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 + * @param int|null $filePermission Optional file permissions (default (0644) are only for owner read/write) + * @param Boolean $useLocking Try to lock log file before doing any writes + * + * @throws \InvalidArgumentException If stream is not a resource or string + */ + public function __construct($stream, $level = Logger::DEBUG, $bubble = true, $filePermission = null, $useLocking = false) + { + parent::__construct($level, $bubble); + if (is_resource($stream)) { + $this->stream = $stream; + } elseif (is_string($stream)) { + $this->url = $stream; + } else { + throw new \InvalidArgumentException('A stream must either be a resource or a string.'); + } + + $this->filePermission = $filePermission; + $this->useLocking = $useLocking; + } + + /** + * {@inheritdoc} + */ + public function close() + { + if (is_resource($this->stream)) { + fclose($this->stream); + } + $this->stream = null; + } + + /** + * {@inheritdoc} + */ + protected function write(array $record) + { + if (!is_resource($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().'); + } + $this->errorMessage = null; + set_error_handler(array($this, 'customErrorHandler')); + $this->stream = fopen($this->url, 'a'); + if ($this->filePermission !== null) { + @chmod($this->url, $this->filePermission); + } + restore_error_handler(); + if (!is_resource($this->stream)) { + $this->stream = null; + throw new \UnexpectedValueException(sprintf('The stream or file "%s" could not be opened: '.$this->errorMessage, $this->url)); + } + } + + if ($this->useLocking) { + // ignoring errors here, there's not much we can do about them + flock($this->stream, LOCK_EX); + } + + fwrite($this->stream, (string) $record['formatted']); + + if ($this->useLocking) { + flock($this->stream, LOCK_UN); + } + } + + private function customErrorHandler($code, $msg) + { + $this->errorMessage = preg_replace('{^fopen\(.*?\): }', '', $msg); + } +} diff --git a/vendor/aws/Monolog/Handler/SwiftMailerHandler.php b/vendor/aws/Monolog/Handler/SwiftMailerHandler.php new file mode 100644 index 0000000..003a1a2 --- /dev/null +++ b/vendor/aws/Monolog/Handler/SwiftMailerHandler.php @@ -0,0 +1,87 @@ + + * + * 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; + private $messageTemplate; + + /** + * @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; + $this->messageTemplate = $message; + } + + /** + * {@inheritdoc} + */ + protected function send($content, array $records) + { + $this->mailer->send($this->buildMessage($content, $records)); + } + + /** + * Creates instance of Swift_Message to be sent + * + * @param string $content formatted email body to be sent + * @param array $records Log records that formed the content + * @return \Swift_Message + */ + protected function buildMessage($content, array $records) + { + $message = null; + if ($this->messageTemplate instanceof \Swift_Message) { + $message = clone $this->messageTemplate; + } else if (is_callable($this->messageTemplate)) { + $message = call_user_func($this->messageTemplate, $content, $records); + } + + if (!$message instanceof \Swift_Message) { + throw new \InvalidArgumentException('Could not resolve message as instance of Swift_Message or a callable returning it'); + } + + $message->setBody($content); + $message->setDate(time()); + + return $message; + } + + /** + * BC getter, to be removed in 2.0 + */ + public function __get($name) + { + if ($name === 'message') { + trigger_error('SwiftMailerHandler->message is deprecated, use ->buildMessage() instead to retrieve the message', E_USER_DEPRECATED); + + return $this->buildMessage(null, array()); + } + + throw new \InvalidArgumentException('Invalid property '.$name); + } +} diff --git a/vendor/aws/Monolog/Handler/SyslogHandler.php b/vendor/aws/Monolog/Handler/SyslogHandler.php new file mode 100644 index 0000000..47c73e1 --- /dev/null +++ b/vendor/aws/Monolog/Handler/SyslogHandler.php @@ -0,0 +1,67 @@ + + * + * 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 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 AbstractSyslogHandler +{ + protected $ident; + protected $logopts; + + /** + * @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($facility, $level, $bubble); + + $this->ident = $ident; + $this->logopts = $logopts; + } + + /** + * {@inheritdoc} + */ + public function close() + { + closelog(); + } + + /** + * {@inheritdoc} + */ + protected function write(array $record) + { + if (!openlog($this->ident, $this->logopts, $this->facility)) { + throw new \LogicException('Can\'t open syslog for ident "'.$this->ident.'" and facility "'.$this->facility.'"'); + } + syslog($this->logLevels[$record['level']], (string) $record['formatted']); + } +} diff --git a/vendor/aws/Monolog/Handler/SyslogUdp/UdpSocket.php b/vendor/aws/Monolog/Handler/SyslogUdp/UdpSocket.php new file mode 100644 index 0000000..dcf3f1f --- /dev/null +++ b/vendor/aws/Monolog/Handler/SyslogUdp/UdpSocket.php @@ -0,0 +1,46 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Monolog\Handler\SyslogUdp; + +class UdpSocket +{ + const DATAGRAM_MAX_LENGTH = 65023; + + public function __construct($ip, $port = 514) + { + $this->ip = $ip; + $this->port = $port; + $this->socket = socket_create(AF_INET, SOCK_DGRAM, SOL_UDP); + } + + public function write($line, $header = "") + { + $this->send($this->assembleMessage($line, $header)); + } + + public function close() + { + socket_close($this->socket); + } + + protected function send($chunk) + { + socket_sendto($this->socket, $chunk, strlen($chunk), $flags = 0, $this->ip, $this->port); + } + + protected function assembleMessage($line, $header) + { + $chunkSize = self::DATAGRAM_MAX_LENGTH - strlen($header); + + return $header . substr($line, 0, $chunkSize); + } +} diff --git a/vendor/aws/Monolog/Handler/SyslogUdpHandler.php b/vendor/aws/Monolog/Handler/SyslogUdpHandler.php new file mode 100644 index 0000000..aa047c0 --- /dev/null +++ b/vendor/aws/Monolog/Handler/SyslogUdpHandler.php @@ -0,0 +1,80 @@ + + * + * 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\Handler\SyslogUdp\UdpSocket; + +/** + * A Handler for logging to a remote syslogd server. + * + * @author Jesper Skovgaard Nielsen + */ +class SyslogUdpHandler extends AbstractSyslogHandler +{ + /** + * @param string $host + * @param int $port + * @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 + */ + public function __construct($host, $port = 514, $facility = LOG_USER, $level = Logger::DEBUG, $bubble = true) + { + parent::__construct($facility, $level, $bubble); + + $this->socket = new UdpSocket($host, $port ?: 514); + } + + protected function write(array $record) + { + $lines = $this->splitMessageIntoLines($record['formatted']); + + $header = $this->makeCommonSyslogHeader($this->logLevels[$record['level']]); + + foreach ($lines as $line) { + $this->socket->write($line, $header); + } + } + + public function close() + { + $this->socket->close(); + } + + private function splitMessageIntoLines($message) + { + if (is_array($message)) { + $message = implode("\n", $message); + } + + return preg_split('/$\R?^/m', $message); + } + + /** + * Make common syslog header (see rfc5424) + */ + protected function makeCommonSyslogHeader($severity) + { + $priority = $severity + $this->facility; + + return "<$priority>1 "; + } + + /** + * Inject your own socket, mainly used for testing + */ + public function setSocket($socket) + { + $this->socket = $socket; + } +} diff --git a/vendor/aws/Monolog/Handler/TestHandler.php b/vendor/aws/Monolog/Handler/TestHandler.php new file mode 100644 index 0000000..085d9e1 --- /dev/null +++ b/vendor/aws/Monolog/Handler/TestHandler.php @@ -0,0 +1,140 @@ + + * + * 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; + } +} diff --git a/vendor/aws/Monolog/Handler/WhatFailureGroupHandler.php b/vendor/aws/Monolog/Handler/WhatFailureGroupHandler.php new file mode 100644 index 0000000..05a8817 --- /dev/null +++ b/vendor/aws/Monolog/Handler/WhatFailureGroupHandler.php @@ -0,0 +1,57 @@ + + * + * 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 suppressing failures of each handler + * and continuing through to give every handler a chance to succeed. + * + * @author Craig D'Amelio + */ +class WhatFailureGroupHandler extends GroupHandler +{ + /** + * {@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) { + try { + $handler->handle($record); + } catch (\Exception $e) { + // What failure? + } + } + + return false === $this->bubble; + } + + /** + * {@inheritdoc} + */ + public function handleBatch(array $records) + { + foreach ($this->handlers as $handler) { + try { + $handler->handleBatch($records); + } catch (\Exception $e) { + // What failure? + } + } + } +} diff --git a/vendor/aws/Monolog/Handler/ZendMonitorHandler.php b/vendor/aws/Monolog/Handler/ZendMonitorHandler.php new file mode 100644 index 0000000..f22cf21 --- /dev/null +++ b/vendor/aws/Monolog/Handler/ZendMonitorHandler.php @@ -0,0 +1,95 @@ + + * + * 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; + } +} diff --git a/vendor/aws/Monolog/Logger.php b/vendor/aws/Monolog/Logger.php new file mode 100644 index 0000000..4a38de7 --- /dev/null +++ b/vendor/aws/Monolog/Logger.php @@ -0,0 +1,615 @@ + + * + * 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; + + /** + * Monolog API version + * + * This is only bumped when API breaks are done and should + * follow the major version of the library + * + * @var int + */ + const API = 1; + + /** + * Logging levels from syslog protocol defined in RFC 5424 + * + * @var array $levels Logging levels + */ + 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; + + /** + * @var string + */ + protected $name; + + /** + * The handler stack + * + * @var 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 callable[] + */ + protected $processors; + + /** + * @param string $name The logging channel + * @param HandlerInterface[] $handlers Optional stack of handlers, the first one in the array is called first, etc. + * @param callable[] $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); + } + + /** + * @return HandlerInterface[] + */ + public function getHandlers() + { + return $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); + } + + /** + * @return callable[] + */ + public function getProcessors() + { + return $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)); + } + + $levelName = static::getLevelName($level); + + // check if any handler will handle this message so we can return early and save cycles + $handlerKey = null; + foreach ($this->handlers as $key => $handler) { + if ($handler->isHandling(array('level' => $level))) { + $handlerKey = $key; + break; + } + } + + if (null === $handlerKey) { + return false; + } + + if (!static::$timezone) { + static::$timezone = new \DateTimeZone(date_default_timezone_get() ?: 'UTC'); + } + + $record = array( + 'message' => (string) $message, + 'context' => $context, + 'level' => $level, + 'level_name' => $levelName, + 'channel' => $this->name, + 'datetime' => \DateTime::createFromFormat('U.u', sprintf('%.6F', microtime(true)), static::$timezone)->setTimezone(static::$timezone), + 'extra' => array(), + ); + + 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 all supported logging levels. + * + * @return array Assoc array with human-readable level names => level codes. + */ + public static function getLevels() + { + return array_flip(static::$levels); + } + + /** + * 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]; + } + + /** + * Converts PSR-3 levels to Monolog ones if necessary + * + * @param string|int Level number (monolog) or name (PSR-3) + * @return int + */ + public static function toMonologLevel($level) + { + if (is_string($level) && defined(__CLASS__.'::'.strtoupper($level))) { + return constant(__CLASS__.'::'.strtoupper($level)); + } + + return $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 $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 NOTICE 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); + } +} diff --git a/vendor/aws/Monolog/Processor/GitProcessor.php b/vendor/aws/Monolog/Processor/GitProcessor.php new file mode 100644 index 0000000..1899400 --- /dev/null +++ b/vendor/aws/Monolog/Processor/GitProcessor.php @@ -0,0 +1,64 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Monolog\Processor; + +use Monolog\Logger; + +/** + * Injects Git branch and Git commit SHA in all records + * + * @author Nick Otter + * @author Jordi Boggiano + */ +class GitProcessor +{ + private $level; + private static $cache; + + public function __construct($level = Logger::DEBUG) + { + $this->level = Logger::toMonologLevel($level); + } + + /** + * @param array $record + * @return array + */ + public function __invoke(array $record) + { + // return if the level is not high enough + if ($record['level'] < $this->level) { + return $record; + } + + $record['extra']['git'] = self::getGitInfo(); + + return $record; + } + + private static function getGitInfo() + { + if (self::$cache) { + return self::$cache; + } + + $branches = `git branch -v --no-abbrev`; + if (preg_match('{^\* (.+?)\s+([a-f0-9]{40})(?:\s|$)}m', $branches, $matches)) { + return self::$cache = array( + 'branch' => $matches[1], + 'commit' => $matches[2], + ); + } + + return self::$cache = array(); + } +} diff --git a/vendor/aws/Monolog/Processor/IntrospectionProcessor.php b/vendor/aws/Monolog/Processor/IntrospectionProcessor.php new file mode 100644 index 0000000..294a295 --- /dev/null +++ b/vendor/aws/Monolog/Processor/IntrospectionProcessor.php @@ -0,0 +1,82 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Monolog\Processor; + +use Monolog\Logger; + +/** + * 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 +{ + private $level; + + private $skipClassesPartials; + + public function __construct($level = Logger::DEBUG, array $skipClassesPartials = array('Monolog\\')) + { + $this->level = Logger::toMonologLevel($level); + $this->skipClassesPartials = $skipClassesPartials; + } + + /** + * @param array $record + * @return array + */ + public function __invoke(array $record) + { + // return if the level is not high enough + if ($record['level'] < $this->level) { + return $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'])) { + foreach ($this->skipClassesPartials as $part) { + if (strpos($trace[$i]['class'], $part) !== false) { + $i++; + continue 2; + } + } + break; + } + + // 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; + } +} diff --git a/vendor/aws/Monolog/Processor/MemoryPeakUsageProcessor.php b/vendor/aws/Monolog/Processor/MemoryPeakUsageProcessor.php new file mode 100644 index 0000000..552fd70 --- /dev/null +++ b/vendor/aws/Monolog/Processor/MemoryPeakUsageProcessor.php @@ -0,0 +1,40 @@ + + * + * 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 = $this->formatBytes($bytes); + + $record['extra'] = array_merge( + $record['extra'], + array( + 'memory_peak_usage' => $formatted, + ) + ); + + return $record; + } +} diff --git a/vendor/aws/Monolog/Processor/MemoryProcessor.php b/vendor/aws/Monolog/Processor/MemoryProcessor.php new file mode 100644 index 0000000..0820def --- /dev/null +++ b/vendor/aws/Monolog/Processor/MemoryProcessor.php @@ -0,0 +1,63 @@ + + * + * 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 +{ + /** + * @var boolean If true, get the real size of memory allocated from system. Else, only the memory used by emalloc() is reported. + */ + protected $realUsage; + + /** + * @var boolean If true, then format memory size to human readable string (MB, KB, B depending on size) + */ + protected $useFormatting; + + /** + * @param boolean $realUsage Set this to true to get the real size of memory allocated from system. + * @param boolean $useFormatting If true, then format memory size to human readable string (MB, KB, B depending on size) + */ + public function __construct($realUsage = true, $useFormatting = true) + { + $this->realUsage = (boolean) $realUsage; + $this->useFormatting = (boolean) $useFormatting; + } + + /** + * Formats bytes into a human readable string if $this->useFormatting is true, otherwise return $bytes as is + * + * @param int $bytes + * @return string|int Formatted string if $this->useFormatting is true, otherwise return $bytes as is + */ + protected function formatBytes($bytes) + { + $bytes = (int) $bytes; + + if (!$this->useFormatting) { + return $bytes; + } + + if ($bytes > 1024*1024) { + return round($bytes/1024/1024, 2).' MB'; + } elseif ($bytes > 1024) { + return round($bytes/1024, 2).' KB'; + } + + return $bytes . ' B'; + } +} diff --git a/vendor/aws/Monolog/Processor/MemoryUsageProcessor.php b/vendor/aws/Monolog/Processor/MemoryUsageProcessor.php new file mode 100644 index 0000000..0c4dd9a --- /dev/null +++ b/vendor/aws/Monolog/Processor/MemoryUsageProcessor.php @@ -0,0 +1,40 @@ + + * + * 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 = $this->formatBytes($bytes); + + $record['extra'] = array_merge( + $record['extra'], + array( + 'memory_usage' => $formatted, + ) + ); + + return $record; + } +} diff --git a/vendor/aws/Monolog/Processor/ProcessIdProcessor.php b/vendor/aws/Monolog/Processor/ProcessIdProcessor.php new file mode 100644 index 0000000..9d3f559 --- /dev/null +++ b/vendor/aws/Monolog/Processor/ProcessIdProcessor.php @@ -0,0 +1,31 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Monolog\Processor; + +/** + * Adds value of getmypid into records + * + * @author Andreas Hörnicke + */ +class ProcessIdProcessor +{ + /** + * @param array $record + * @return array + */ + public function __invoke(array $record) + { + $record['extra']['process_id'] = getmypid(); + + return $record; + } +} diff --git a/vendor/aws/Monolog/Processor/PsrLogMessageProcessor.php b/vendor/aws/Monolog/Processor/PsrLogMessageProcessor.php new file mode 100644 index 0000000..c2686ce --- /dev/null +++ b/vendor/aws/Monolog/Processor/PsrLogMessageProcessor.php @@ -0,0 +1,48 @@ + + * + * 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) { + if (is_null($val) || is_scalar($val) || (is_object($val) && method_exists($val, "__toString"))) { + $replacements['{'.$key.'}'] = $val; + } elseif (is_object($val)) { + $replacements['{'.$key.'}'] = '[object '.get_class($val).']'; + } else { + $replacements['{'.$key.'}'] = '['.gettype($val).']'; + } + } + + $record['message'] = strtr($record['message'], $replacements); + + return $record; + } +} diff --git a/vendor/aws/Monolog/Processor/TagProcessor.php b/vendor/aws/Monolog/Processor/TagProcessor.php new file mode 100644 index 0000000..2784cef --- /dev/null +++ b/vendor/aws/Monolog/Processor/TagProcessor.php @@ -0,0 +1,34 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Monolog\Processor; + +/** + * Adds a tags array into record + * + * @author Martijn Riemers + */ +class TagProcessor +{ + private $tags; + + public function __construct(array $tags = array()) + { + $this->tags = $tags; + } + + public function __invoke(array $record) + { + $record['extra']['tags'] = $this->tags; + + return $record; + } +} diff --git a/vendor/aws/Monolog/Processor/UidProcessor.php b/vendor/aws/Monolog/Processor/UidProcessor.php new file mode 100644 index 0000000..80270d0 --- /dev/null +++ b/vendor/aws/Monolog/Processor/UidProcessor.php @@ -0,0 +1,38 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Monolog\Processor; + +/** + * Adds a unique identifier into records + * + * @author Simon Mönch + */ +class UidProcessor +{ + private $uid; + + public function __construct($length = 7) + { + if (!is_int($length) || $length > 32 || $length < 1) { + throw new \InvalidArgumentException('The uid length must be an integer between 1 and 32'); + } + + $this->uid = substr(hash('md5', uniqid('', true)), 0, $length); + } + + public function __invoke(array $record) + { + $record['extra']['uid'] = $this->uid; + + return $record; + } +} diff --git a/vendor/aws/Monolog/Processor/WebProcessor.php b/vendor/aws/Monolog/Processor/WebProcessor.php new file mode 100644 index 0000000..21f22a6 --- /dev/null +++ b/vendor/aws/Monolog/Processor/WebProcessor.php @@ -0,0 +1,105 @@ + + * + * 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 +{ + /** + * @var array|\ArrayAccess + */ + protected $serverData; + + /** + * @var array + */ + protected $extraFields = array( + 'url' => 'REQUEST_URI', + 'ip' => 'REMOTE_ADDR', + 'http_method' => 'REQUEST_METHOD', + 'server' => 'SERVER_NAME', + 'referrer' => 'HTTP_REFERER', + ); + + /** + * @param array|\ArrayAccess $serverData Array or object w/ ArrayAccess that provides access to the $_SERVER data + * @param array|null $extraFields Extra field names to be added (all available by default) + */ + public function __construct($serverData = null, array $extraFields = 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.'); + } + + if (null !== $extraFields) { + foreach (array_keys($this->extraFields) as $fieldName) { + if (!in_array($fieldName, $extraFields)) { + unset($this->extraFields[$fieldName]); + } + } + } + } + + /** + * @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'] = $this->appendExtraFields($record['extra']); + + return $record; + } + + /** + * @param string $extraName + * @param string $serverName + * @return $this + */ + public function addExtraField($extraName, $serverName) + { + $this->extraFields[$extraName] = $serverName; + + return $this; + } + + /** + * @param array $extra + * @return array + */ + private function appendExtraFields(array $extra) + { + foreach ($this->extraFields as $extraName => $serverName) { + $extra[$extraName] = isset($this->serverData[$serverName]) ? $this->serverData[$serverName] : null; + } + + if (isset($this->serverData['UNIQUE_ID'])) { + $extra['unique_id'] = $this->serverData['UNIQUE_ID']; + } + + return $extra; + } +} diff --git a/vendor/aws/Monolog/Registry.php b/vendor/aws/Monolog/Registry.php new file mode 100644 index 0000000..923b774 --- /dev/null +++ b/vendor/aws/Monolog/Registry.php @@ -0,0 +1,134 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Monolog; + +use InvalidArgumentException; + +/** + * Monolog log registry + * + * Allows to get `Logger` instances in the global scope + * via static method calls on this class. + * + * + * $application = new Monolog\Logger('application'); + * $api = new Monolog\Logger('api'); + * + * Monolog\Registry::addLogger($application); + * Monolog\Registry::addLogger($api); + * + * function testLogger() + * { + * Monolog\Registry::api()->addError('Sent to $api Logger instance'); + * Monolog\Registry::application()->addError('Sent to $application Logger instance'); + * } + * + * + * @author Tomas Tatarko + */ +class Registry +{ + /** + * List of all loggers in the registry (ba named indexes) + * + * @var Logger[] + */ + private static $loggers = array(); + + /** + * Adds new logging channel to the registry + * + * @param Logger $logger Instance of the logging channel + * @param string|null $name Name of the logging channel ($logger->getName() by default) + * @param boolean $overwrite Overwrite instance in the registry if the given name already exists? + * @throws \InvalidArgumentException If $overwrite set to false and named Logger instance already exists + */ + public static function addLogger(Logger $logger, $name = null, $overwrite = false) + { + $name = $name ?: $logger->getName(); + + if (isset(self::$loggers[$name]) && !$overwrite) { + throw new InvalidArgumentException('Logger with the given name already exists'); + } + + self::$loggers[$name] = $logger; + } + + /** + * Checks if such logging channel exists by name or instance + * + * @param string|Logger $logger Name or logger instance + */ + public static function hasLogger($logger) + { + if ($logger instanceof Logger) { + $index = array_search($logger, self::$loggers, true); + + return false !== $index; + } else { + return isset(self::$loggers[$logger]); + } + } + + /** + * Removes instance from registry by name or instance + * + * @param string|Logger $logger Name or logger instance + */ + public static function removeLogger($logger) + { + if ($logger instanceof Logger) { + if (false !== ($idx = array_search($logger, self::$loggers, true))) { + unset(self::$loggers[$idx]); + } + } else { + unset(self::$loggers[$logger]); + } + } + + /** + * Clears the registry + */ + public static function clear() + { + self::$loggers = array(); + } + + /** + * Gets Logger instance from the registry + * + * @param string $name Name of the requested Logger instance + * @return Logger Requested instance of Logger + * @throws \InvalidArgumentException If named Logger instance is not in the registry + */ + public static function getInstance($name) + { + if (!isset(self::$loggers[$name])) { + throw new InvalidArgumentException(sprintf('Requested "%s" logger instance is not in the registry', $name)); + } + + return self::$loggers[$name]; + } + + /** + * Gets Logger instance from the registry via static method call + * + * @param string $name Name of the requested Logger instance + * @param array $arguments Arguments passed to static method call + * @return Logger Requested instance of Logger + * @throws \InvalidArgumentException If named Logger instance is not in the registry + */ + public static function __callStatic($name, $arguments) + { + return self::getInstance($name); + } +} diff --git a/vendor/aws/NOTICE.md b/vendor/aws/NOTICE.md new file mode 100644 index 0000000..8485853 --- /dev/null +++ b/vendor/aws/NOTICE.md @@ -0,0 +1,112 @@ +# 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. diff --git a/vendor/aws/Psr/Log/AbstractLogger.php b/vendor/aws/Psr/Log/AbstractLogger.php new file mode 100644 index 0000000..00f9034 --- /dev/null +++ b/vendor/aws/Psr/Log/AbstractLogger.php @@ -0,0 +1,120 @@ +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); + } +} diff --git a/vendor/aws/Psr/Log/InvalidArgumentException.php b/vendor/aws/Psr/Log/InvalidArgumentException.php new file mode 100644 index 0000000..67f852d --- /dev/null +++ b/vendor/aws/Psr/Log/InvalidArgumentException.php @@ -0,0 +1,7 @@ +logger = $logger; + } +} diff --git a/vendor/aws/Psr/Log/LoggerInterface.php b/vendor/aws/Psr/Log/LoggerInterface.php new file mode 100644 index 0000000..476bb96 --- /dev/null +++ b/vendor/aws/Psr/Log/LoggerInterface.php @@ -0,0 +1,114 @@ +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()); +} diff --git a/vendor/aws/Psr/Log/NullLogger.php b/vendor/aws/Psr/Log/NullLogger.php new file mode 100644 index 0000000..553a3c5 --- /dev/null +++ b/vendor/aws/Psr/Log/NullLogger.php @@ -0,0 +1,27 @@ +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 + } +} diff --git a/vendor/aws/Psr/Log/Test/LoggerInterfaceTest.php b/vendor/aws/Psr/Log/Test/LoggerInterfaceTest.php new file mode 100644 index 0000000..a932815 --- /dev/null +++ b/vendor/aws/Psr/Log/Test/LoggerInterfaceTest.php @@ -0,0 +1,116 @@ + " + * + * 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 +{ +} \ No newline at end of file diff --git a/vendor/aws/README.md b/vendor/aws/README.md new file mode 100644 index 0000000..fa9539f --- /dev/null +++ b/vendor/aws/README.md @@ -0,0 +1,185 @@ +# AWS SDK for PHP + +[![@awsforphp on Twitter](http://img.shields.io/badge/twitter-%40awsforphp-blue.svg?style=flat)](https://twitter.com/awsforphp) +[![Total Downloads](https://img.shields.io/packagist/dt/aws/aws-sdk-php.svg?style=flat)](https://packagist.org/packages/aws/aws-sdk-php) +[![Build Status](https://img.shields.io/travis/aws/aws-sdk-php.svg?style=flat)](https://travis-ci.org/aws/aws-sdk-php) +[![Apache 2 License](https://img.shields.io/packagist/l/aws/aws-sdk-php.svg?style=flat)](http://aws.amazon.com/apache-2-0/) +[![Code Climate](https://codeclimate.com/github/aws/aws-sdk-php/badges/gpa.svg)](https://codeclimate.com/github/aws/aws-sdk-php) +[![Gitter](https://badges.gitter.im/Join Chat.svg)](https://gitter.im/aws/aws-sdk-php?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge) + +The **AWS SDK for PHP** enables PHP developers to use [Amazon Web Services][aws] +in their PHP code, and build robust applications and software using services +like Amazon S3, Amazon DynamoDB, Amazon Glacier, etc. You can get started in +minutes by [installing the SDK through Composer][docs-installation] or by +downloading a single zip or phar file from our [latest release][latest-release]. + +## Resources + +* [User Guide][docs-guide] – For in-depth getting started and usage information +* [API Docs][docs-api] – For operations, parameters, responses, and examples +* [Blog][sdk-blog] – Tips & tricks, articles, and announcements +* [Sample Project][sdk-sample] - A quick, sample project to help get you started +* [Forum][sdk-forum] – Ask questions, get help, and give feedback +* [Issues][sdk-issues] – Report issues and submit pull requests + (see [Apache 2.0 License][sdk-license]) +* [@awsforphp][sdk-twitter] – Follow us on Twitter +* [Building Apps with Version 3 of the AWS SDK for PHP](http://youtu.be/STrtR89f5Pc) video from AWS + re:Invent 2014 + +## Features + +* Provides easy-to-use HTTP clients for all supported AWS + [services][docs-services], [regions][docs-rande], and authentication + protocols. +* Is built for PHP 5.3.3+ and is compliant with [PSR-0], [PSR-1], and [PSR-2]. +* Is easy to install through [Composer][install-packagist], or by downloading + the phar or zip file of our [latest release][latest-release]. +* Is built on [Guzzle v3][guzzle], and utilizes many of its features, including + persistent connections, parallel requests, events and plugins + (via [Symfony2 EventDispatcher][symfony2-events]), service descriptions, + [over-the-wire logging][docs-wire-logging], caching, flexible batching, and + request retrying with truncated exponential backoff. +* Provides convenience features including easy response pagination via + [Iterators][docs-iterators], resource [Waiters][docs-waiters], and simple + [modelled responses][docs-models]. +* Allows you to [sync local directories to Amazon S3 buckets][docs-s3-sync]. +* Provides a [multipart uploader tool][docs-s3-multipart] for Amazon S3 and + Amazon Glacier that can be paused and resumed. +* Provides an [Amazon S3 Stream Wrapper][docs-streamwrapper], so that you can + use PHP's native file handling functions to interact with your S3 buckets and + objects like a local filesystem. +* Provides the [Amazon DynamoDB Session Handler][docs-ddbsh] for easily scaling + sessions on a fast, NoSQL database. +* Automatically uses [IAM Instance Profile Credentials][aws-iam-credentials] on + configured Amazon EC2 instances. + +## Getting Started + +1. **Sign up for AWS** – Before you begin, you need to + [sign up for an AWS account][docs-signup] and retrieve your AWS credentials. +1. **Minimum requirements** – To run the SDK, your system will need to meet the + [minimum requirements][docs-requirements], including having **PHP 5.3.3+** + compiled with the cURL extension and cURL 7.16.2+ compiled with OpenSSL and + zlib. +1. **Install the SDK** – Using [Composer] is the recommended way to install the + AWS SDK for PHP. The SDK is available via [Packagist] under the + [`aws/aws-sdk-php`][install-packagist] package. Please see the + [Installation section of the User Guide][docs-installation] for more + detailed information about installing the SDK through Composer and other + means. +1. **Using the SDK** – The best way to become familiar with how to use the SDK + is to read the [User Guide][docs-guide]. The + [Getting Started Guide][docs-quickstart] will help you become familiar with + the basic concepts, and there are also specific guides for each of the + [supported services][docs-services]. + +## Quick Example + +### Upload a File to Amazon S3 + +```php +putObject(array( + 'Bucket' => 'my-bucket', + 'Key' => 'my-object', + 'Body' => fopen('/path/to/file', 'r'), + 'ACL' => 'public-read', + )); +} catch (S3Exception $e) { + echo "There was an error uploading the file.\n"; +} +``` + +You can also use the even easier `upload()` method, which will automatically do +either single or multipart uploads, as needed. + +```php +try { + $resource = fopen('/path/to/file', 'r'); + $s3->upload('my-bucket', 'my-object', $resource, 'public-read'); +} catch (S3Exception $e) { + echo "There was an error uploading the file.\n"; +} +``` + +### More Examples + +* [Get an object from Amazon S3 and save it to a file][example-s3-getobject] +* [Upload a large file to Amazon S3 in parts][example-s3-multipart] +* [Put an item in your Amazon DynamoDB table][example-dynamodb-putitem] +* [Send a message to your Amazon SQS queue][example-sqs-sendmessage] +* Please browse the [User Guide][docs-guide] and [API docs][docs-api] or check + out our [AWS SDK Development Blog][sdk-blog] for even more examples and + tutorials. + +### Related Projects + +* [AWS Service Provider for Laravel][mod-laravel] +* [AWS SDK ZF2 Module][mod-zf2] +* [AWS Service Provider for Silex][mod-silex] +* [Guzzle v3][guzzle-docs] – PHP HTTP client and framework +* Other [AWS SDKs & Tools][aws-tools] (e.g., js, cli, ruby, python, java, etc.) + +[sdk-website]: http://aws.amazon.com/sdkforphp +[sdk-forum]: https://forums.aws.amazon.com/forum.jspa?forumID=80 +[sdk-issues]: https://github.com/aws/aws-sdk-php/issues +[sdk-license]: http://aws.amazon.com/apache2.0/ +[sdk-blog]: http://blogs.aws.amazon.com/php +[sdk-twitter]: https://twitter.com/awsforphp +[sdk-sample]: http://aws.amazon.com/developers/getting-started/php + +[install-packagist]: https://packagist.org/packages/aws/aws-sdk-php +[latest-release]: https://github.com/aws/aws-sdk-php/releases/latest + +[docs-api]: http://docs.aws.amazon.com/aws-sdk-php/v2/api/index.html +[docs-guide]: http://docs.aws.amazon.com/aws-sdk-php/v2/guide/index.html +[docs-contribution]: https://github.com/aws/aws-sdk-php/blob/master/CONTRIBUTING.md +[docs-performance]: http://docs.aws.amazon.com/aws-sdk-php/v2/guide/performance.html +[docs-migration]: http://docs.aws.amazon.com/aws-sdk-php/v2/guide/migration-guide.html +[docs-signup]: http://docs.aws.amazon.com/aws-sdk-php/v2/guide/awssignup.html +[docs-requirements]: http://docs.aws.amazon.com/aws-sdk-php/v2/guide/requirements.html +[docs-installation]: http://docs.aws.amazon.com/aws-sdk-php/v2/guide/installation.html +[docs-quickstart]: http://docs.aws.amazon.com/aws-sdk-php/v2/guide/quick-start.html +[docs-iterators]: http://docs.aws.amazon.com/aws-sdk-php/v2/guide/quick-start.html#iterators +[docs-waiters]: http://docs.aws.amazon.com/aws-sdk-php/v2/guide/feature-waiters.html +[docs-models]: http://docs.aws.amazon.com/aws-sdk-php/v2/guide/feature-models.html +[docs-exceptions]: http://docs.aws.amazon.com/aws-sdk-php/v2/guide/quick-start.html#error-handling +[docs-wire-logging]: http://docs.aws.amazon.com/aws-sdk-php/v2/guide/faq.html#how-can-i-see-what-data-is-sent-over-the-wire +[docs-services]: http://docs.aws.amazon.com/aws-sdk-php/v2/guide/index.html#supported-services +[docs-ddbsh]: http://docs.aws.amazon.com/aws-sdk-php/v2/guide/feature-dynamodb-session-handler.html +[docs-rande]: http://docs.aws.amazon.com/general/latest/gr/rande.html +[docs-streamwrapper]: http://docs.aws.amazon.com/aws-sdk-php/v2/guide/service-s3.html#amazon-s3-stream-wrapper +[docs-s3-sync]: http://blogs.aws.amazon.com/php/post/Tx2W9JAA7RXVOXA/Syncing-Data-with-Amazon-S3 +[docs-s3-multipart]: http://docs.aws.amazon.com/aws-sdk-php/v2/guide/service-s3.html#uploading-large-files-using-multipart-uploads + +[aws]: http://aws.amazon.com +[aws-iam-credentials]: http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/UsingIAM.html#UsingIAMrolesWithAmazonEC2Instances +[aws-tools]: http://aws.amazon.com/tools +[guzzle]: https://github.com/guzzle/guzzle3 +[guzzle-docs]: https://guzzle3.readthedocs.org +[composer]: http://getcomposer.org +[packagist]: http://packagist.org +[psr-0]: https://github.com/php-fig/fig-standards/blob/master/accepted/PSR-0.md +[psr-1]: https://github.com/php-fig/fig-standards/blob/master/accepted/PSR-1-basic-coding-standard.md +[psr-2]: https://github.com/php-fig/fig-standards/blob/master/accepted/PSR-2-coding-style-guide.md +[symfony2-events]: http://symfony.com/doc/2.3/components/event_dispatcher/introduction.html + +[example-sqs-sendmessage]: http://docs.aws.amazon.com/aws-sdk-php/v2/guide/service-sqs.html#sending-messages +[example-s3-getobject]: http://docs.aws.amazon.com/aws-sdk-php/v2/guide/service-s3.html#saving-objects-to-a-file +[example-s3-multipart]: http://docs.aws.amazon.com/aws-sdk-php/v2/guide/service-s3.html#uploading-large-files-using-multipart-uploads +[example-dynamodb-putitem]: http://docs.aws.amazon.com/aws-sdk-php/v2/guide/service-dynamodb.html#adding-items + +[mod-laravel]: https://github.com/aws/aws-sdk-php-laravel +[mod-zf2]: https://github.com/aws/aws-sdk-php-zf2 +[mod-silex]: https://github.com/aws/aws-sdk-php-silex diff --git a/vendor/aws/Symfony/Component/EventDispatcher/ContainerAwareEventDispatcher.php b/vendor/aws/Symfony/Component/EventDispatcher/ContainerAwareEventDispatcher.php new file mode 100644 index 0000000..af0b6ce --- /dev/null +++ b/vendor/aws/Symfony/Component/EventDispatcher/ContainerAwareEventDispatcher.php @@ -0,0 +1,202 @@ + + * + * 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 int $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->listenerIds[$eventName])) { + foreach ($this->listenerIds[$eventName] as $i => $args) { + list($serviceId, $method, $priority) = $args; + $key = $serviceId.'.'.$method; + if (isset($this->listeners[$eventName][$key]) && $listener === array($this->listeners[$eventName][$key], $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 (bool) count($this->listenerIds) || (bool) 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; + } + } + } +} diff --git a/vendor/aws/Symfony/Component/EventDispatcher/Debug/TraceableEventDispatcher.php b/vendor/aws/Symfony/Component/EventDispatcher/Debug/TraceableEventDispatcher.php new file mode 100644 index 0000000..2119b81 --- /dev/null +++ b/vendor/aws/Symfony/Component/EventDispatcher/Debug/TraceableEventDispatcher.php @@ -0,0 +1,320 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Symfony\Component\EventDispatcher\Debug; + +use Symfony\Component\EventDispatcher\EventDispatcherInterface; +use Symfony\Component\EventDispatcher\EventSubscriberInterface; +use Symfony\Component\EventDispatcher\Event; +use Symfony\Component\Stopwatch\Stopwatch; +use Psr\Log\LoggerInterface; + +/** + * Collects some data about event listeners. + * + * This event dispatcher delegates the dispatching to another one. + * + * @author Fabien Potencier + */ +class TraceableEventDispatcher implements TraceableEventDispatcherInterface +{ + protected $logger; + protected $stopwatch; + + private $called; + private $dispatcher; + + /** + * Constructor. + * + * @param EventDispatcherInterface $dispatcher An EventDispatcherInterface instance + * @param Stopwatch $stopwatch A Stopwatch instance + * @param LoggerInterface $logger A LoggerInterface instance + */ + public function __construct(EventDispatcherInterface $dispatcher, Stopwatch $stopwatch, LoggerInterface $logger = null) + { + $this->dispatcher = $dispatcher; + $this->stopwatch = $stopwatch; + $this->logger = $logger; + $this->called = array(); + } + + /** + * {@inheritdoc} + */ + public function addListener($eventName, $listener, $priority = 0) + { + $this->dispatcher->addListener($eventName, $listener, $priority); + } + + /** + * {@inheritdoc} + */ + public function addSubscriber(EventSubscriberInterface $subscriber) + { + $this->dispatcher->addSubscriber($subscriber); + } + + /** + * {@inheritdoc} + */ + public function removeListener($eventName, $listener) + { + return $this->dispatcher->removeListener($eventName, $listener); + } + + /** + * {@inheritdoc} + */ + public function removeSubscriber(EventSubscriberInterface $subscriber) + { + return $this->dispatcher->removeSubscriber($subscriber); + } + + /** + * {@inheritdoc} + */ + public function getListeners($eventName = null) + { + return $this->dispatcher->getListeners($eventName); + } + + /** + * {@inheritdoc} + */ + public function hasListeners($eventName = null) + { + return $this->dispatcher->hasListeners($eventName); + } + + /** + * {@inheritdoc} + */ + public function dispatch($eventName, Event $event = null) + { + if (null === $event) { + $event = new Event(); + } + + $this->preProcess($eventName); + $this->preDispatch($eventName, $event); + + $e = $this->stopwatch->start($eventName, 'section'); + + $this->dispatcher->dispatch($eventName, $event); + + if ($e->isStarted()) { + $e->stop(); + } + + $this->postDispatch($eventName, $event); + $this->postProcess($eventName); + + return $event; + } + + /** + * {@inheritdoc} + */ + public function getCalledListeners() + { + $called = array(); + foreach ($this->called as $eventName => $listeners) { + foreach ($listeners as $listener) { + $info = $this->getListenerInfo($listener->getWrappedListener(), $eventName); + $called[$eventName.'.'.$info['pretty']] = $info; + } + } + + return $called; + } + + /** + * {@inheritdoc} + */ + public function getNotCalledListeners() + { + try { + $allListeners = $this->getListeners(); + } catch (\Exception $e) { + if (null !== $this->logger) { + $this->logger->info(sprintf('An exception was thrown while getting the uncalled listeners (%s)', $e->getMessage()), array('exception' => $e)); + } + + // unable to retrieve the uncalled listeners + return array(); + } + + $notCalled = array(); + foreach ($allListeners as $eventName => $listeners) { + foreach ($listeners as $listener) { + $called = false; + if (isset($this->called[$eventName])) { + foreach ($this->called[$eventName] as $l) { + if ($l->getWrappedListener() === $listener) { + $called = true; + + break; + } + } + } + + if (!$called) { + $info = $this->getListenerInfo($listener, $eventName); + $notCalled[$eventName.'.'.$info['pretty']] = $info; + } + } + } + + return $notCalled; + } + + /** + * Proxies all method calls to the original event dispatcher. + * + * @param string $method The method name + * @param array $arguments The method arguments + * + * @return mixed + */ + public function __call($method, $arguments) + { + return call_user_func_array(array($this->dispatcher, $method), $arguments); + } + + /** + * Called before dispatching the event. + * + * @param string $eventName The event name + * @param Event $event The event + */ + protected function preDispatch($eventName, Event $event) + { + } + + /** + * Called after dispatching the event. + * + * @param string $eventName The event name + * @param Event $event The event + */ + protected function postDispatch($eventName, Event $event) + { + } + + private function preProcess($eventName) + { + foreach ($this->dispatcher->getListeners($eventName) as $listener) { + $this->dispatcher->removeListener($eventName, $listener); + $info = $this->getListenerInfo($listener, $eventName); + $name = isset($info['class']) ? $info['class'] : $info['type']; + $this->dispatcher->addListener($eventName, new WrappedListener($listener, $name, $this->stopwatch, $this)); + } + } + + private function postProcess($eventName) + { + $skipped = false; + foreach ($this->dispatcher->getListeners($eventName) as $listener) { + if (!$listener instanceof WrappedListener) { // #12845: a new listener was added during dispatch. + continue; + } + // Unwrap listener + $this->dispatcher->removeListener($eventName, $listener); + $this->dispatcher->addListener($eventName, $listener->getWrappedListener()); + + $info = $this->getListenerInfo($listener->getWrappedListener(), $eventName); + if ($listener->wasCalled()) { + if (null !== $this->logger) { + $this->logger->debug(sprintf('Notified event "%s" to listener "%s".', $eventName, $info['pretty'])); + } + + if (!isset($this->called[$eventName])) { + $this->called[$eventName] = new \SplObjectStorage(); + } + + $this->called[$eventName]->attach($listener); + } + + if (null !== $this->logger && $skipped) { + $this->logger->debug(sprintf('Listener "%s" was not called for event "%s".', $info['pretty'], $eventName)); + } + + if ($listener->stoppedPropagation()) { + if (null !== $this->logger) { + $this->logger->debug(sprintf('Listener "%s" stopped propagation of the event "%s".', $info['pretty'], $eventName)); + } + + $skipped = true; + } + } + } + + /** + * Returns information about the listener + * + * @param object $listener The listener + * @param string $eventName The event name + * + * @return array Information about the listener + */ + private function getListenerInfo($listener, $eventName) + { + $info = array( + 'event' => $eventName, + ); + if ($listener instanceof \Closure) { + $info += array( + 'type' => 'Closure', + 'pretty' => 'closure', + ); + } elseif (is_string($listener)) { + try { + $r = new \ReflectionFunction($listener); + $file = $r->getFileName(); + $line = $r->getStartLine(); + } catch (\ReflectionException $e) { + $file = null; + $line = null; + } + $info += array( + 'type' => 'Function', + 'function' => $listener, + 'file' => $file, + 'line' => $line, + 'pretty' => $listener, + ); + } elseif (is_array($listener) || (is_object($listener) && is_callable($listener))) { + if (!is_array($listener)) { + $listener = array($listener, '__invoke'); + } + $class = is_object($listener[0]) ? get_class($listener[0]) : $listener[0]; + try { + $r = new \ReflectionMethod($class, $listener[1]); + $file = $r->getFileName(); + $line = $r->getStartLine(); + } catch (\ReflectionException $e) { + $file = null; + $line = null; + } + $info += array( + 'type' => 'Method', + 'class' => $class, + 'method' => $listener[1], + 'file' => $file, + 'line' => $line, + 'pretty' => $class.'::'.$listener[1], + ); + } + + return $info; + } +} diff --git a/vendor/aws/Symfony/Component/EventDispatcher/Debug/TraceableEventDispatcherInterface.php b/vendor/aws/Symfony/Component/EventDispatcher/Debug/TraceableEventDispatcherInterface.php new file mode 100644 index 0000000..5483e81 --- /dev/null +++ b/vendor/aws/Symfony/Component/EventDispatcher/Debug/TraceableEventDispatcherInterface.php @@ -0,0 +1,34 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Symfony\Component\EventDispatcher\Debug; + +use Symfony\Component\EventDispatcher\EventDispatcherInterface; + +/** + * @author Fabien Potencier + */ +interface TraceableEventDispatcherInterface extends EventDispatcherInterface +{ + /** + * 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(); +} diff --git a/vendor/aws/Symfony/Component/EventDispatcher/Debug/WrappedListener.php b/vendor/aws/Symfony/Component/EventDispatcher/Debug/WrappedListener.php new file mode 100644 index 0000000..e16627d --- /dev/null +++ b/vendor/aws/Symfony/Component/EventDispatcher/Debug/WrappedListener.php @@ -0,0 +1,71 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Symfony\Component\EventDispatcher\Debug; + +use Symfony\Component\Stopwatch\Stopwatch; +use Symfony\Component\EventDispatcher\Event; +use Symfony\Component\EventDispatcher\EventDispatcherInterface; + +/** + * @author Fabien Potencier + */ +class WrappedListener +{ + private $listener; + private $name; + private $called; + private $stoppedPropagation; + private $stopwatch; + private $dispatcher; + + public function __construct($listener, $name, Stopwatch $stopwatch, EventDispatcherInterface $dispatcher = null) + { + $this->listener = $listener; + $this->name = $name; + $this->stopwatch = $stopwatch; + $this->dispatcher = $dispatcher; + $this->called = false; + $this->stoppedPropagation = false; + } + + public function getWrappedListener() + { + return $this->listener; + } + + public function wasCalled() + { + return $this->called; + } + + public function stoppedPropagation() + { + return $this->stoppedPropagation; + } + + public function __invoke(Event $event, $eventName, EventDispatcherInterface $dispatcher) + { + $this->called = true; + + $e = $this->stopwatch->start($this->name, 'event_listener'); + + call_user_func($this->listener, $event, $eventName, $this->dispatcher ?: $dispatcher); + + if ($e->isStarted()) { + $e->stop(); + } + + if ($event->isPropagationStopped()) { + $this->stoppedPropagation = true; + } + } +} diff --git a/vendor/aws/Symfony/Component/EventDispatcher/DependencyInjection/RegisterListenersPass.php b/vendor/aws/Symfony/Component/EventDispatcher/DependencyInjection/RegisterListenersPass.php new file mode 100644 index 0000000..7e74a37 --- /dev/null +++ b/vendor/aws/Symfony/Component/EventDispatcher/DependencyInjection/RegisterListenersPass.php @@ -0,0 +1,110 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Symfony\Component\EventDispatcher\DependencyInjection; + +use Symfony\Component\DependencyInjection\ContainerBuilder; +use Symfony\Component\DependencyInjection\Compiler\CompilerPassInterface; + +/** + * Compiler pass to register tagged services for an event dispatcher. + */ +class RegisterListenersPass implements CompilerPassInterface +{ + /** + * @var string + */ + protected $dispatcherService; + + /** + * @var string + */ + protected $listenerTag; + + /** + * @var string + */ + protected $subscriberTag; + + /** + * Constructor. + * + * @param string $dispatcherService Service name of the event dispatcher in processed container + * @param string $listenerTag Tag name used for listener + * @param string $subscriberTag Tag name used for subscribers + */ + public function __construct($dispatcherService = 'event_dispatcher', $listenerTag = 'kernel.event_listener', $subscriberTag = 'kernel.event_subscriber') + { + $this->dispatcherService = $dispatcherService; + $this->listenerTag = $listenerTag; + $this->subscriberTag = $subscriberTag; + } + + public function process(ContainerBuilder $container) + { + if (!$container->hasDefinition($this->dispatcherService) && !$container->hasAlias($this->dispatcherService)) { + return; + } + + $definition = $container->findDefinition($this->dispatcherService); + + foreach ($container->findTaggedServiceIds($this->listenerTag) as $id => $events) { + $def = $container->getDefinition($id); + if (!$def->isPublic()) { + throw new \InvalidArgumentException(sprintf('The service "%s" must be public as event listeners are lazy-loaded.', $id)); + } + + if ($def->isAbstract()) { + throw new \InvalidArgumentException(sprintf('The service "%s" must not be abstract as event listeners are lazy-loaded.', $id)); + } + + foreach ($events as $event) { + $priority = isset($event['priority']) ? $event['priority'] : 0; + + if (!isset($event['event'])) { + throw new \InvalidArgumentException(sprintf('Service "%s" must define the "event" attribute on "%s" tags.', $id, $this->listenerTag)); + } + + if (!isset($event['method'])) { + $event['method'] = 'on'.preg_replace_callback(array( + '/(?<=\b)[a-z]/i', + '/[^a-z0-9]/i', + ), function ($matches) { return strtoupper($matches[0]); }, $event['event']); + $event['method'] = preg_replace('/[^a-z0-9]/i', '', $event['method']); + } + + $definition->addMethodCall('addListenerService', array($event['event'], array($id, $event['method']), $priority)); + } + } + + foreach ($container->findTaggedServiceIds($this->subscriberTag) as $id => $attributes) { + $def = $container->getDefinition($id); + if (!$def->isPublic()) { + throw new \InvalidArgumentException(sprintf('The service "%s" must be public as event subscribers are lazy-loaded.', $id)); + } + + if ($def->isAbstract()) { + throw new \InvalidArgumentException(sprintf('The service "%s" must not be abstract as event subscribers are lazy-loaded.', $id)); + } + + // We must assume that the class value has been correctly filled, even if the service is created by a factory + $class = $container->getParameterBag()->resolveValue($def->getClass()); + + $refClass = new \ReflectionClass($class); + $interface = 'Symfony\Component\EventDispatcher\EventSubscriberInterface'; + if (!$refClass->implementsInterface($interface)) { + throw new \InvalidArgumentException(sprintf('Service "%s" must implement interface "%s".', $id, $interface)); + } + + $definition->addMethodCall('addSubscriberService', array($id, $class)); + } + } +} diff --git a/vendor/aws/Symfony/Component/EventDispatcher/Event.php b/vendor/aws/Symfony/Component/EventDispatcher/Event.php new file mode 100644 index 0000000..dc39b05 --- /dev/null +++ b/vendor/aws/Symfony/Component/EventDispatcher/Event.php @@ -0,0 +1,130 @@ + + * + * 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 bool 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 bool 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; + } +} diff --git a/vendor/aws/Symfony/Component/EventDispatcher/EventDispatcher.php b/vendor/aws/Symfony/Component/EventDispatcher/EventDispatcher.php new file mode 100644 index 0000000..3b032fb --- /dev/null +++ b/vendor/aws/Symfony/Component/EventDispatcher/EventDispatcher.php @@ -0,0 +1,185 @@ + + * + * 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 array_filter($this->sorted); + } + + /** + * @see EventDispatcherInterface::hasListeners() + */ + public function hasListeners($eventName = null) + { + return (bool) 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]); + } + } +} diff --git a/vendor/aws/Symfony/Component/EventDispatcher/EventDispatcherInterface.php b/vendor/aws/Symfony/Component/EventDispatcher/EventDispatcherInterface.php new file mode 100644 index 0000000..efb7c5b --- /dev/null +++ b/vendor/aws/Symfony/Component/EventDispatcher/EventDispatcherInterface.php @@ -0,0 +1,96 @@ + + * + * 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 int $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 $eventName The event 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 bool true if the specified event has any listeners, false otherwise + */ + public function hasListeners($eventName = null); +} diff --git a/vendor/aws/Symfony/Component/EventDispatcher/EventSubscriberInterface.php b/vendor/aws/Symfony/Component/EventDispatcher/EventSubscriberInterface.php new file mode 100644 index 0000000..ff7e305 --- /dev/null +++ b/vendor/aws/Symfony/Component/EventDispatcher/EventSubscriberInterface.php @@ -0,0 +1,50 @@ + + * + * 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(); +} diff --git a/vendor/aws/Symfony/Component/EventDispatcher/GenericEvent.php b/vendor/aws/Symfony/Component/EventDispatcher/GenericEvent.php new file mode 100644 index 0000000..a8955ca --- /dev/null +++ b/vendor/aws/Symfony/Component/EventDispatcher/GenericEvent.php @@ -0,0 +1,186 @@ + + * + * 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 bool + */ + 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 bool + */ + 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); + } +} diff --git a/vendor/aws/Symfony/Component/EventDispatcher/ImmutableEventDispatcher.php b/vendor/aws/Symfony/Component/EventDispatcher/ImmutableEventDispatcher.php new file mode 100644 index 0000000..7ef9ece --- /dev/null +++ b/vendor/aws/Symfony/Component/EventDispatcher/ImmutableEventDispatcher.php @@ -0,0 +1,93 @@ + + * + * 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); + } +} diff --git a/vendor/aws/Symfony/Component/EventDispatcher/LICENSE b/vendor/aws/Symfony/Component/EventDispatcher/LICENSE new file mode 100644 index 0000000..43028bc --- /dev/null +++ b/vendor/aws/Symfony/Component/EventDispatcher/LICENSE @@ -0,0 +1,19 @@ +Copyright (c) 2004-2015 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. diff --git a/vendor/aws/Symfony/Component/EventDispatcher/Tests/AbstractEventDispatcherTest.php b/vendor/aws/Symfony/Component/EventDispatcher/Tests/AbstractEventDispatcherTest.php new file mode 100644 index 0000000..b9e4194 --- /dev/null +++ b/vendor/aws/Symfony/Component/EventDispatcher/Tests/AbstractEventDispatcherTest.php @@ -0,0 +1,369 @@ + + * + * 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\EventSubscriberInterface; + +abstract class AbstractEventDispatcherTest 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 = $this->createEventDispatcher(); + $this->listener = new TestEventListener(); + } + + protected function tearDown() + { + $this->dispatcher = null; + $this->listener = null; + } + + abstract protected function createEventDispatcher(); + + 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() + { + $dispatcher = null; + $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 = $this->createEventDispatcher(); + $dispatcher->addListener('bug.62976', new CallableClass()); + $dispatcher->removeListener('bug.62976', function () {}); + $this->assertTrue($dispatcher->hasListeners('bug.62976')); + } + + public function testHasListenersWhenAddedCallbackListenerIsRemoved() + { + $listener = function () {}; + $this->dispatcher->addListener('foo', $listener); + $this->dispatcher->removeListener('foo', $listener); + $this->assertFalse($this->dispatcher->hasListeners()); + } + + public function testGetListenersWhenAddedCallbackListenerIsRemoved() + { + $listener = function () {}; + $this->dispatcher->addListener('foo', $listener); + $this->dispatcher->removeListener('foo', $listener); + $this->assertSame(array(), $this->dispatcher->getListeners()); + } + + public function testHasListenersWithoutEventsReturnsFalseAfterHasListenersWithEventHasBeenCalled() + { + $this->assertFalse($this->dispatcher->hasListeners('foo')); + $this->assertFalse($this->dispatcher->hasListeners()); + } +} + +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), + )); + } +} diff --git a/vendor/aws/Symfony/Component/EventDispatcher/Tests/ContainerAwareEventDispatcherTest.php b/vendor/aws/Symfony/Component/EventDispatcher/Tests/ContainerAwareEventDispatcherTest.php new file mode 100644 index 0000000..6f2fbcb --- /dev/null +++ b/vendor/aws/Symfony/Component/EventDispatcher/Tests/ContainerAwareEventDispatcherTest.php @@ -0,0 +1,249 @@ + + * + * 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 AbstractEventDispatcherTest +{ + protected function createEventDispatcher() + { + $container = new Container(); + + return new ContainerAwareEventDispatcher($container); + } + + 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() + { + $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() + { + $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() + { + $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' => array('onEvent'), + ); + } + + public function onEvent(Event $e) + { + } +} diff --git a/vendor/aws/Symfony/Component/EventDispatcher/Tests/Debug/TraceableEventDispatcherTest.php b/vendor/aws/Symfony/Component/EventDispatcher/Tests/Debug/TraceableEventDispatcherTest.php new file mode 100644 index 0000000..68b9523 --- /dev/null +++ b/vendor/aws/Symfony/Component/EventDispatcher/Tests/Debug/TraceableEventDispatcherTest.php @@ -0,0 +1,185 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Symfony\Component\EventDispatcher\Tests\Debug; + +use Symfony\Component\EventDispatcher\Debug\TraceableEventDispatcher; +use Symfony\Component\EventDispatcher\EventSubscriberInterface; +use Symfony\Component\EventDispatcher\EventDispatcher; +use Symfony\Component\EventDispatcher\Event; +use Symfony\Component\Stopwatch\Stopwatch; + +class TraceableEventDispatcherTest extends \PHPUnit_Framework_TestCase +{ + public function testAddRemoveListener() + { + $dispatcher = new EventDispatcher(); + $tdispatcher = new TraceableEventDispatcher($dispatcher, new Stopwatch()); + + $tdispatcher->addListener('foo', $listener = function () {; }); + $listeners = $dispatcher->getListeners('foo'); + $this->assertCount(1, $listeners); + $this->assertSame($listener, $listeners[0]); + + $tdispatcher->removeListener('foo', $listener); + $this->assertCount(0, $dispatcher->getListeners('foo')); + } + + public function testGetListeners() + { + $dispatcher = new EventDispatcher(); + $tdispatcher = new TraceableEventDispatcher($dispatcher, new Stopwatch()); + + $tdispatcher->addListener('foo', $listener = function () {; }); + $this->assertSame($dispatcher->getListeners('foo'), $tdispatcher->getListeners('foo')); + } + + public function testHasListeners() + { + $dispatcher = new EventDispatcher(); + $tdispatcher = new TraceableEventDispatcher($dispatcher, new Stopwatch()); + + $this->assertFalse($dispatcher->hasListeners('foo')); + $this->assertFalse($tdispatcher->hasListeners('foo')); + + $tdispatcher->addListener('foo', $listener = function () {; }); + $this->assertTrue($dispatcher->hasListeners('foo')); + $this->assertTrue($tdispatcher->hasListeners('foo')); + } + + public function testAddRemoveSubscriber() + { + $dispatcher = new EventDispatcher(); + $tdispatcher = new TraceableEventDispatcher($dispatcher, new Stopwatch()); + + $subscriber = new EventSubscriber(); + + $tdispatcher->addSubscriber($subscriber); + $listeners = $dispatcher->getListeners('foo'); + $this->assertCount(1, $listeners); + $this->assertSame(array($subscriber, 'call'), $listeners[0]); + + $tdispatcher->removeSubscriber($subscriber); + $this->assertCount(0, $dispatcher->getListeners('foo')); + } + + public function testGetCalledListeners() + { + $dispatcher = new EventDispatcher(); + $tdispatcher = new TraceableEventDispatcher($dispatcher, new Stopwatch()); + $tdispatcher->addListener('foo', $listener = function () {; }); + + $this->assertEquals(array(), $tdispatcher->getCalledListeners()); + $this->assertEquals(array('foo.closure' => array('event' => 'foo', 'type' => 'Closure', 'pretty' => 'closure')), $tdispatcher->getNotCalledListeners()); + + $tdispatcher->dispatch('foo'); + + $this->assertEquals(array('foo.closure' => array('event' => 'foo', 'type' => 'Closure', 'pretty' => 'closure')), $tdispatcher->getCalledListeners()); + $this->assertEquals(array(), $tdispatcher->getNotCalledListeners()); + } + + public function testGetCalledListenersNested() + { + $tdispatcher = null; + $dispatcher = new TraceableEventDispatcher(new EventDispatcher(), new Stopwatch()); + $dispatcher->addListener('foo', function (Event $event, $eventName, $dispatcher) use (&$tdispatcher) { + $tdispatcher = $dispatcher; + $dispatcher->dispatch('bar'); + }); + $dispatcher->addListener('bar', function (Event $event) {}); + $dispatcher->dispatch('foo'); + $this->assertSame($dispatcher, $tdispatcher); + $this->assertCount(2, $dispatcher->getCalledListeners()); + } + + public function testLogger() + { + $logger = $this->getMock('Psr\Log\LoggerInterface'); + + $dispatcher = new EventDispatcher(); + $tdispatcher = new TraceableEventDispatcher($dispatcher, new Stopwatch(), $logger); + $tdispatcher->addListener('foo', $listener1 = function () {; }); + $tdispatcher->addListener('foo', $listener2 = function () {; }); + + $logger->expects($this->at(0))->method('debug')->with("Notified event \"foo\" to listener \"closure\"."); + $logger->expects($this->at(1))->method('debug')->with("Notified event \"foo\" to listener \"closure\"."); + + $tdispatcher->dispatch('foo'); + } + + public function testLoggerWithStoppedEvent() + { + $logger = $this->getMock('Psr\Log\LoggerInterface'); + + $dispatcher = new EventDispatcher(); + $tdispatcher = new TraceableEventDispatcher($dispatcher, new Stopwatch(), $logger); + $tdispatcher->addListener('foo', $listener1 = function (Event $event) { $event->stopPropagation(); }); + $tdispatcher->addListener('foo', $listener2 = function () {; }); + + $logger->expects($this->at(0))->method('debug')->with("Notified event \"foo\" to listener \"closure\"."); + $logger->expects($this->at(1))->method('debug')->with("Listener \"closure\" stopped propagation of the event \"foo\"."); + $logger->expects($this->at(2))->method('debug')->with("Listener \"closure\" was not called for event \"foo\"."); + + $tdispatcher->dispatch('foo'); + } + + public function testDispatchCallListeners() + { + $called = array(); + + $dispatcher = new EventDispatcher(); + $tdispatcher = new TraceableEventDispatcher($dispatcher, new Stopwatch()); + $tdispatcher->addListener('foo', $listener1 = function () use (&$called) { $called[] = 'foo1'; }); + $tdispatcher->addListener('foo', $listener2 = function () use (&$called) { $called[] = 'foo2'; }); + + $tdispatcher->dispatch('foo'); + + $this->assertEquals(array('foo1', 'foo2'), $called); + } + + public function testDispatchNested() + { + $dispatcher = new TraceableEventDispatcher(new EventDispatcher(), new Stopwatch()); + $loop = 1; + $dispatcher->addListener('foo', $listener1 = function () use ($dispatcher, &$loop) { + ++$loop; + if (2 == $loop) { + $dispatcher->dispatch('foo'); + } + }); + + $dispatcher->dispatch('foo'); + } + + public function testDispatchReusedEventNested() + { + $nestedCall = false; + $dispatcher = new TraceableEventDispatcher(new EventDispatcher(), new Stopwatch()); + $dispatcher->addListener('foo', function (Event $e) use ($dispatcher) { + $dispatcher->dispatch('bar', $e); + }); + $dispatcher->addListener('bar', function (Event $e) use (&$nestedCall) { + $nestedCall = true; + }); + + $this->assertFalse($nestedCall); + $dispatcher->dispatch('foo'); + $this->assertTrue($nestedCall); + } +} + +class EventSubscriber implements EventSubscriberInterface +{ + public static function getSubscribedEvents() + { + return array('foo' => 'call'); + } +} diff --git a/vendor/aws/Symfony/Component/EventDispatcher/Tests/DependencyInjection/RegisterListenersPassTest.php b/vendor/aws/Symfony/Component/EventDispatcher/Tests/DependencyInjection/RegisterListenersPassTest.php new file mode 100644 index 0000000..0fdd637 --- /dev/null +++ b/vendor/aws/Symfony/Component/EventDispatcher/Tests/DependencyInjection/RegisterListenersPassTest.php @@ -0,0 +1,200 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Symfony\Component\EventDispatcher\Tests\DependencyInjection; + +use Symfony\Component\DependencyInjection\ContainerBuilder; +use Symfony\Component\EventDispatcher\DependencyInjection\RegisterListenersPass; + +class RegisterListenersPassTest extends \PHPUnit_Framework_TestCase +{ + /** + * Tests that event subscribers not implementing EventSubscriberInterface + * trigger an exception. + * + * @expectedException \InvalidArgumentException + */ + public function testEventSubscriberWithoutInterface() + { + // one service, not implementing any interface + $services = array( + 'my_event_subscriber' => array(0 => array()), + ); + + $definition = $this->getMock('Symfony\Component\DependencyInjection\Definition'); + $definition->expects($this->atLeastOnce()) + ->method('isPublic') + ->will($this->returnValue(true)); + $definition->expects($this->atLeastOnce()) + ->method('getClass') + ->will($this->returnValue('stdClass')); + + $builder = $this->getMock( + 'Symfony\Component\DependencyInjection\ContainerBuilder', + array('hasDefinition', 'findTaggedServiceIds', 'getDefinition') + ); + $builder->expects($this->any()) + ->method('hasDefinition') + ->will($this->returnValue(true)); + + // We don't test kernel.event_listener here + $builder->expects($this->atLeastOnce()) + ->method('findTaggedServiceIds') + ->will($this->onConsecutiveCalls(array(), $services)); + + $builder->expects($this->atLeastOnce()) + ->method('getDefinition') + ->will($this->returnValue($definition)); + + $registerListenersPass = new RegisterListenersPass(); + $registerListenersPass->process($builder); + } + + public function testValidEventSubscriber() + { + $services = array( + 'my_event_subscriber' => array(0 => array()), + ); + + $definition = $this->getMock('Symfony\Component\DependencyInjection\Definition'); + $definition->expects($this->atLeastOnce()) + ->method('isPublic') + ->will($this->returnValue(true)); + $definition->expects($this->atLeastOnce()) + ->method('getClass') + ->will($this->returnValue('Symfony\Component\EventDispatcher\Tests\DependencyInjection\SubscriberService')); + + $builder = $this->getMock( + 'Symfony\Component\DependencyInjection\ContainerBuilder', + array('hasDefinition', 'findTaggedServiceIds', 'getDefinition', 'findDefinition') + ); + $builder->expects($this->any()) + ->method('hasDefinition') + ->will($this->returnValue(true)); + + // We don't test kernel.event_listener here + $builder->expects($this->atLeastOnce()) + ->method('findTaggedServiceIds') + ->will($this->onConsecutiveCalls(array(), $services)); + + $builder->expects($this->atLeastOnce()) + ->method('getDefinition') + ->will($this->returnValue($definition)); + + $builder->expects($this->atLeastOnce()) + ->method('findDefinition') + ->will($this->returnValue($definition)); + + $registerListenersPass = new RegisterListenersPass(); + $registerListenersPass->process($builder); + } + + /** + * @expectedException \InvalidArgumentException + * @expectedExceptionMessage The service "foo" must be public as event listeners are lazy-loaded. + */ + public function testPrivateEventListener() + { + $container = new ContainerBuilder(); + $container->register('foo', 'stdClass')->setPublic(false)->addTag('kernel.event_listener', array()); + $container->register('event_dispatcher', 'stdClass'); + + $registerListenersPass = new RegisterListenersPass(); + $registerListenersPass->process($container); + } + + /** + * @expectedException \InvalidArgumentException + * @expectedExceptionMessage The service "foo" must be public as event subscribers are lazy-loaded. + */ + public function testPrivateEventSubscriber() + { + $container = new ContainerBuilder(); + $container->register('foo', 'stdClass')->setPublic(false)->addTag('kernel.event_subscriber', array()); + $container->register('event_dispatcher', 'stdClass'); + + $registerListenersPass = new RegisterListenersPass(); + $registerListenersPass->process($container); + } + + /** + * @expectedException \InvalidArgumentException + * @expectedExceptionMessage The service "foo" must not be abstract as event listeners are lazy-loaded. + */ + public function testAbstractEventListener() + { + $container = new ContainerBuilder(); + $container->register('foo', 'stdClass')->setAbstract(true)->addTag('kernel.event_listener', array()); + $container->register('event_dispatcher', 'stdClass'); + + $registerListenersPass = new RegisterListenersPass(); + $registerListenersPass->process($container); + } + + /** + * @expectedException \InvalidArgumentException + * @expectedExceptionMessage The service "foo" must not be abstract as event subscribers are lazy-loaded. + */ + public function testAbstractEventSubscriber() + { + $container = new ContainerBuilder(); + $container->register('foo', 'stdClass')->setAbstract(true)->addTag('kernel.event_subscriber', array()); + $container->register('event_dispatcher', 'stdClass'); + + $registerListenersPass = new RegisterListenersPass(); + $registerListenersPass->process($container); + } + + public function testEventSubscriberResolvableClassName() + { + $container = new ContainerBuilder(); + + $container->setParameter('subscriber.class', 'Symfony\Component\EventDispatcher\Tests\DependencyInjection\SubscriberService'); + $container->register('foo', '%subscriber.class%')->addTag('kernel.event_subscriber', array()); + $container->register('event_dispatcher', 'stdClass'); + + $registerListenersPass = new RegisterListenersPass(); + $registerListenersPass->process($container); + + $definition = $container->getDefinition('event_dispatcher'); + $expected_calls = array( + array( + 'addSubscriberService', + array( + 'foo', + 'Symfony\Component\EventDispatcher\Tests\DependencyInjection\SubscriberService', + ), + ), + ); + $this->assertSame($expected_calls, $definition->getMethodCalls()); + } + + /** + * @expectedException \InvalidArgumentException + * @expectedExceptionMessage You have requested a non-existent parameter "subscriber.class" + */ + public function testEventSubscriberUnresolvableClassName() + { + $container = new ContainerBuilder(); + $container->register('foo', '%subscriber.class%')->addTag('kernel.event_subscriber', array()); + $container->register('event_dispatcher', 'stdClass'); + + $registerListenersPass = new RegisterListenersPass(); + $registerListenersPass->process($container); + } +} + +class SubscriberService implements \Symfony\Component\EventDispatcher\EventSubscriberInterface +{ + public static function getSubscribedEvents() + { + } +} diff --git a/vendor/aws/Symfony/Component/EventDispatcher/Tests/EventDispatcherTest.php b/vendor/aws/Symfony/Component/EventDispatcher/Tests/EventDispatcherTest.php new file mode 100644 index 0000000..5faa5c8 --- /dev/null +++ b/vendor/aws/Symfony/Component/EventDispatcher/Tests/EventDispatcherTest.php @@ -0,0 +1,22 @@ + + * + * 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\EventDispatcher; + +class EventDispatcherTest extends AbstractEventDispatcherTest +{ + protected function createEventDispatcher() + { + return new EventDispatcher(); + } +} diff --git a/vendor/aws/Symfony/Component/EventDispatcher/Tests/EventTest.php b/vendor/aws/Symfony/Component/EventDispatcher/Tests/EventTest.php new file mode 100644 index 0000000..4bd2697 --- /dev/null +++ b/vendor/aws/Symfony/Component/EventDispatcher/Tests/EventTest.php @@ -0,0 +1,100 @@ + + * + * 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()); + } + + /** + * @group legacy + */ + public function testLegacySetDispatcher() + { + $this->iniSet('error_reporting', -1 & ~E_USER_DEPRECATED); + $this->event->setDispatcher($this->dispatcher); + $this->assertSame($this->dispatcher, $this->event->getDispatcher()); + } + + /** + * @group legacy + */ + public function testLegacyGetDispatcher() + { + $this->iniSet('error_reporting', -1 & ~E_USER_DEPRECATED); + $this->assertNull($this->event->getDispatcher()); + } + + /** + * @group legacy + */ + public function testLegacyGetName() + { + $this->iniSet('error_reporting', -1 & ~E_USER_DEPRECATED); + $this->assertNull($this->event->getName()); + } + + /** + * @group legacy + */ + public function testLegacySetName() + { + $this->iniSet('error_reporting', -1 & ~E_USER_DEPRECATED); + $this->event->setName('foo'); + $this->assertEquals('foo', $this->event->getName()); + } +} diff --git a/vendor/aws/Symfony/Component/EventDispatcher/Tests/GenericEventTest.php b/vendor/aws/Symfony/Component/EventDispatcher/Tests/GenericEventTest.php new file mode 100644 index 0000000..aebd82d --- /dev/null +++ b/vendor/aws/Symfony/Component/EventDispatcher/Tests/GenericEventTest.php @@ -0,0 +1,139 @@ + + * + * 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')); + } + + /** + * 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); + } +} diff --git a/vendor/aws/Symfony/Component/EventDispatcher/Tests/ImmutableEventDispatcherTest.php b/vendor/aws/Symfony/Component/EventDispatcher/Tests/ImmutableEventDispatcherTest.php new file mode 100644 index 0000000..80a7e43 --- /dev/null +++ b/vendor/aws/Symfony/Component/EventDispatcher/Tests/ImmutableEventDispatcherTest.php @@ -0,0 +1,105 @@ + + * + * 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; + +/** + * @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); + } +} diff --git a/vendor/aws/aws-autoloader.php b/vendor/aws/aws-autoloader.php new file mode 100644 index 0000000..d6ad1b0 --- /dev/null +++ b/vendor/aws/aws-autoloader.php @@ -0,0 +1,1344 @@ + __DIR__ . '/Aws/AutoScaling/AutoScalingClient.php', + 'Aws\AutoScaling\Enum\LifecycleState' => __DIR__ . '/Aws/AutoScaling/Enum/LifecycleState.php', + 'Aws\AutoScaling\Enum\ScalingActivityStatusCode' => __DIR__ . '/Aws/AutoScaling/Enum/ScalingActivityStatusCode.php', + 'Aws\AutoScaling\Exception\AlreadyExistsException' => __DIR__ . '/Aws/AutoScaling/Exception/AlreadyExistsException.php', + 'Aws\AutoScaling\Exception\AutoScalingException' => __DIR__ . '/Aws/AutoScaling/Exception/AutoScalingException.php', + 'Aws\AutoScaling\Exception\InvalidNextTokenException' => __DIR__ . '/Aws/AutoScaling/Exception/InvalidNextTokenException.php', + 'Aws\AutoScaling\Exception\LimitExceededException' => __DIR__ . '/Aws/AutoScaling/Exception/LimitExceededException.php', + 'Aws\AutoScaling\Exception\ResourceInUseException' => __DIR__ . '/Aws/AutoScaling/Exception/ResourceInUseException.php', + 'Aws\AutoScaling\Exception\ScalingActivityInProgressException' => __DIR__ . '/Aws/AutoScaling/Exception/ScalingActivityInProgressException.php', + 'Aws\AutoScaling\Resources\autoscaling-2011-01-01' => __DIR__ . '/Aws/AutoScaling/Resources/autoscaling-2011-01-01.php', + 'Aws\CloudFormation\CloudFormationClient' => __DIR__ . '/Aws/CloudFormation/CloudFormationClient.php', + 'Aws\CloudFormation\Enum\Capability' => __DIR__ . '/Aws/CloudFormation/Enum/Capability.php', + 'Aws\CloudFormation\Enum\OnFailure' => __DIR__ . '/Aws/CloudFormation/Enum/OnFailure.php', + 'Aws\CloudFormation\Enum\ResourceStatus' => __DIR__ . '/Aws/CloudFormation/Enum/ResourceStatus.php', + 'Aws\CloudFormation\Enum\StackStatus' => __DIR__ . '/Aws/CloudFormation/Enum/StackStatus.php', + 'Aws\CloudFormation\Exception\AlreadyExistsException' => __DIR__ . '/Aws/CloudFormation/Exception/AlreadyExistsException.php', + 'Aws\CloudFormation\Exception\CloudFormationException' => __DIR__ . '/Aws/CloudFormation/Exception/CloudFormationException.php', + 'Aws\CloudFormation\Exception\InsufficientCapabilitiesException' => __DIR__ . '/Aws/CloudFormation/Exception/InsufficientCapabilitiesException.php', + 'Aws\CloudFormation\Exception\LimitExceededException' => __DIR__ . '/Aws/CloudFormation/Exception/LimitExceededException.php', + 'Aws\CloudFormation\Resources\cloudformation-2010-05-15' => __DIR__ . '/Aws/CloudFormation/Resources/cloudformation-2010-05-15.php', + 'Aws\CloudFront\CloudFrontClient' => __DIR__ . '/Aws/CloudFront/CloudFrontClient.php', + 'Aws\CloudFront\CloudFrontSignature' => __DIR__ . '/Aws/CloudFront/CloudFrontSignature.php', + 'Aws\CloudFront\Enum\GeoRestrictionType' => __DIR__ . '/Aws/CloudFront/Enum/GeoRestrictionType.php', + 'Aws\CloudFront\Enum\ItemSelection' => __DIR__ . '/Aws/CloudFront/Enum/ItemSelection.php', + 'Aws\CloudFront\Enum\Method' => __DIR__ . '/Aws/CloudFront/Enum/Method.php', + 'Aws\CloudFront\Enum\OriginProtocolPolicy' => __DIR__ . '/Aws/CloudFront/Enum/OriginProtocolPolicy.php', + 'Aws\CloudFront\Enum\PriceClass' => __DIR__ . '/Aws/CloudFront/Enum/PriceClass.php', + 'Aws\CloudFront\Enum\SSLSupportMethod' => __DIR__ . '/Aws/CloudFront/Enum/SSLSupportMethod.php', + 'Aws\CloudFront\Enum\ViewerProtocolPolicy' => __DIR__ . '/Aws/CloudFront/Enum/ViewerProtocolPolicy.php', + 'Aws\CloudFront\Exception\AccessDeniedException' => __DIR__ . '/Aws/CloudFront/Exception/AccessDeniedException.php', + 'Aws\CloudFront\Exception\BatchTooLargeException' => __DIR__ . '/Aws/CloudFront/Exception/BatchTooLargeException.php', + 'Aws\CloudFront\Exception\CloudFrontException' => __DIR__ . '/Aws/CloudFront/Exception/CloudFrontException.php', + 'Aws\CloudFront\Exception\CloudFrontOriginAccessIdentityAlreadyExistsException' => __DIR__ . '/Aws/CloudFront/Exception/CloudFrontOriginAccessIdentityAlreadyExistsException.php', + 'Aws\CloudFront\Exception\CloudFrontOriginAccessIdentityInUseException' => __DIR__ . '/Aws/CloudFront/Exception/CloudFrontOriginAccessIdentityInUseException.php', + 'Aws\CloudFront\Exception\CNAMEAlreadyExistsException' => __DIR__ . '/Aws/CloudFront/Exception/CNAMEAlreadyExistsException.php', + 'Aws\CloudFront\Exception\DistributionAlreadyExistsException' => __DIR__ . '/Aws/CloudFront/Exception/DistributionAlreadyExistsException.php', + 'Aws\CloudFront\Exception\DistributionNotDisabledException' => __DIR__ . '/Aws/CloudFront/Exception/DistributionNotDisabledException.php', + 'Aws\CloudFront\Exception\Exception' => __DIR__ . '/Aws/CloudFront/Exception/Exception.php', + 'Aws\CloudFront\Exception\IllegalUpdateException' => __DIR__ . '/Aws/CloudFront/Exception/IllegalUpdateException.php', + 'Aws\CloudFront\Exception\InconsistentQuantitiesException' => __DIR__ . '/Aws/CloudFront/Exception/InconsistentQuantitiesException.php', + 'Aws\CloudFront\Exception\InvalidArgumentException' => __DIR__ . '/Aws/CloudFront/Exception/InvalidArgumentException.php', + 'Aws\CloudFront\Exception\InvalidDefaultRootObjectException' => __DIR__ . '/Aws/CloudFront/Exception/InvalidDefaultRootObjectException.php', + 'Aws\CloudFront\Exception\InvalidErrorCodeException' => __DIR__ . '/Aws/CloudFront/Exception/InvalidErrorCodeException.php', + 'Aws\CloudFront\Exception\InvalidForwardCookiesException' => __DIR__ . '/Aws/CloudFront/Exception/InvalidForwardCookiesException.php', + 'Aws\CloudFront\Exception\InvalidGeoRestrictionParameterException' => __DIR__ . '/Aws/CloudFront/Exception/InvalidGeoRestrictionParameterException.php', + 'Aws\CloudFront\Exception\InvalidIfMatchVersionException' => __DIR__ . '/Aws/CloudFront/Exception/InvalidIfMatchVersionException.php', + 'Aws\CloudFront\Exception\InvalidLocationCodeException' => __DIR__ . '/Aws/CloudFront/Exception/InvalidLocationCodeException.php', + 'Aws\CloudFront\Exception\InvalidOriginAccessIdentityException' => __DIR__ . '/Aws/CloudFront/Exception/InvalidOriginAccessIdentityException.php', + 'Aws\CloudFront\Exception\InvalidOriginException' => __DIR__ . '/Aws/CloudFront/Exception/InvalidOriginException.php', + 'Aws\CloudFront\Exception\InvalidRelativePathException' => __DIR__ . '/Aws/CloudFront/Exception/InvalidRelativePathException.php', + 'Aws\CloudFront\Exception\InvalidRequiredProtocolException' => __DIR__ . '/Aws/CloudFront/Exception/InvalidRequiredProtocolException.php', + 'Aws\CloudFront\Exception\InvalidResponseCodeException' => __DIR__ . '/Aws/CloudFront/Exception/InvalidResponseCodeException.php', + 'Aws\CloudFront\Exception\InvalidViewerCertificateException' => __DIR__ . '/Aws/CloudFront/Exception/InvalidViewerCertificateException.php', + 'Aws\CloudFront\Exception\MissingBodyException' => __DIR__ . '/Aws/CloudFront/Exception/MissingBodyException.php', + 'Aws\CloudFront\Exception\NoSuchCloudFrontOriginAccessIdentityException' => __DIR__ . '/Aws/CloudFront/Exception/NoSuchCloudFrontOriginAccessIdentityException.php', + 'Aws\CloudFront\Exception\NoSuchDistributionException' => __DIR__ . '/Aws/CloudFront/Exception/NoSuchDistributionException.php', + 'Aws\CloudFront\Exception\NoSuchInvalidationException' => __DIR__ . '/Aws/CloudFront/Exception/NoSuchInvalidationException.php', + 'Aws\CloudFront\Exception\NoSuchOriginException' => __DIR__ . '/Aws/CloudFront/Exception/NoSuchOriginException.php', + 'Aws\CloudFront\Exception\NoSuchStreamingDistributionException' => __DIR__ . '/Aws/CloudFront/Exception/NoSuchStreamingDistributionException.php', + 'Aws\CloudFront\Exception\PreconditionFailedException' => __DIR__ . '/Aws/CloudFront/Exception/PreconditionFailedException.php', + 'Aws\CloudFront\Exception\StreamingDistributionAlreadyExistsException' => __DIR__ . '/Aws/CloudFront/Exception/StreamingDistributionAlreadyExistsException.php', + 'Aws\CloudFront\Exception\StreamingDistributionNotDisabledException' => __DIR__ . '/Aws/CloudFront/Exception/StreamingDistributionNotDisabledException.php', + 'Aws\CloudFront\Exception\TooManyCacheBehaviorsException' => __DIR__ . '/Aws/CloudFront/Exception/TooManyCacheBehaviorsException.php', + 'Aws\CloudFront\Exception\TooManyCertificatesException' => __DIR__ . '/Aws/CloudFront/Exception/TooManyCertificatesException.php', + 'Aws\CloudFront\Exception\TooManyCloudFrontOriginAccessIdentitiesException' => __DIR__ . '/Aws/CloudFront/Exception/TooManyCloudFrontOriginAccessIdentitiesException.php', + 'Aws\CloudFront\Exception\TooManyCookieNamesInWhiteListException' => __DIR__ . '/Aws/CloudFront/Exception/TooManyCookieNamesInWhiteListException.php', + 'Aws\CloudFront\Exception\TooManyDistributionCNAMEsException' => __DIR__ . '/Aws/CloudFront/Exception/TooManyDistributionCNAMEsException.php', + 'Aws\CloudFront\Exception\TooManyDistributionsException' => __DIR__ . '/Aws/CloudFront/Exception/TooManyDistributionsException.php', + 'Aws\CloudFront\Exception\TooManyInvalidationsInProgressException' => __DIR__ . '/Aws/CloudFront/Exception/TooManyInvalidationsInProgressException.php', + 'Aws\CloudFront\Exception\TooManyOriginsException' => __DIR__ . '/Aws/CloudFront/Exception/TooManyOriginsException.php', + 'Aws\CloudFront\Exception\TooManyStreamingDistributionCNAMEsException' => __DIR__ . '/Aws/CloudFront/Exception/TooManyStreamingDistributionCNAMEsException.php', + 'Aws\CloudFront\Exception\TooManyStreamingDistributionsException' => __DIR__ . '/Aws/CloudFront/Exception/TooManyStreamingDistributionsException.php', + 'Aws\CloudFront\Exception\TooManyTrustedSignersException' => __DIR__ . '/Aws/CloudFront/Exception/TooManyTrustedSignersException.php', + 'Aws\CloudFront\Exception\TrustedSignerDoesNotExistException' => __DIR__ . '/Aws/CloudFront/Exception/TrustedSignerDoesNotExistException.php', + 'Aws\CloudFront\Resources\cloudfront-2012-05-05' => __DIR__ . '/Aws/CloudFront/Resources/cloudfront-2012-05-05.php', + 'Aws\CloudFront\Resources\cloudfront-2014-11-06' => __DIR__ . '/Aws/CloudFront/Resources/cloudfront-2014-11-06.php', + 'Aws\CloudHsm\CloudHsmClient' => __DIR__ . '/Aws/CloudHsm/CloudHsmClient.php', + 'Aws\CloudHsm\Exception\CloudHsmException' => __DIR__ . '/Aws/CloudHsm/Exception/CloudHsmException.php', + 'Aws\CloudHsm\Resources\cloudhsm-2014-05-30' => __DIR__ . '/Aws/CloudHsm/Resources/cloudhsm-2014-05-30.php', + 'Aws\CloudSearch\CloudSearchClient' => __DIR__ . '/Aws/CloudSearch/CloudSearchClient.php', + 'Aws\CloudSearch\Enum\IndexFieldType' => __DIR__ . '/Aws/CloudSearch/Enum/IndexFieldType.php', + 'Aws\CloudSearch\Enum\OptionState' => __DIR__ . '/Aws/CloudSearch/Enum/OptionState.php', + 'Aws\CloudSearch\Enum\SearchInstanceType' => __DIR__ . '/Aws/CloudSearch/Enum/SearchInstanceType.php', + 'Aws\CloudSearch\Enum\SourceDataFunction' => __DIR__ . '/Aws/CloudSearch/Enum/SourceDataFunction.php', + 'Aws\CloudSearch\Exception\BaseException' => __DIR__ . '/Aws/CloudSearch/Exception/BaseException.php', + 'Aws\CloudSearch\Exception\CloudSearchException' => __DIR__ . '/Aws/CloudSearch/Exception/CloudSearchException.php', + 'Aws\CloudSearch\Exception\InternalException' => __DIR__ . '/Aws/CloudSearch/Exception/InternalException.php', + 'Aws\CloudSearch\Exception\InvalidTypeException' => __DIR__ . '/Aws/CloudSearch/Exception/InvalidTypeException.php', + 'Aws\CloudSearch\Exception\LimitExceededException' => __DIR__ . '/Aws/CloudSearch/Exception/LimitExceededException.php', + 'Aws\CloudSearch\Exception\ResourceNotFoundException' => __DIR__ . '/Aws/CloudSearch/Exception/ResourceNotFoundException.php', + 'Aws\CloudSearch\Resources\cloudsearch-2011-02-01' => __DIR__ . '/Aws/CloudSearch/Resources/cloudsearch-2011-02-01.php', + 'Aws\CloudSearch\Resources\cloudsearch-2013-01-01' => __DIR__ . '/Aws/CloudSearch/Resources/cloudsearch-2013-01-01.php', + 'Aws\CloudSearchDomain\CloudSearchDomainClient' => __DIR__ . '/Aws/CloudSearchDomain/CloudSearchDomainClient.php', + 'Aws\CloudSearchDomain\CloudSearchDomainClientBuilder' => __DIR__ . '/Aws/CloudSearchDomain/CloudSearchDomainClientBuilder.php', + 'Aws\CloudSearchDomain\Exception\CloudSearchDomainException' => __DIR__ . '/Aws/CloudSearchDomain/Exception/CloudSearchDomainException.php', + 'Aws\CloudSearchDomain\Resources\cloudsearchdomain-2013-01-01' => __DIR__ . '/Aws/CloudSearchDomain/Resources/cloudsearchdomain-2013-01-01.php', + 'Aws\CloudTrail\CloudTrailClient' => __DIR__ . '/Aws/CloudTrail/CloudTrailClient.php', + 'Aws\CloudTrail\Exception\CloudTrailException' => __DIR__ . '/Aws/CloudTrail/Exception/CloudTrailException.php', + 'Aws\CloudTrail\Exception\InsufficientS3BucketPolicyException' => __DIR__ . '/Aws/CloudTrail/Exception/InsufficientS3BucketPolicyException.php', + 'Aws\CloudTrail\Exception\InsufficientSnsTopicPolicyException' => __DIR__ . '/Aws/CloudTrail/Exception/InsufficientSnsTopicPolicyException.php', + 'Aws\CloudTrail\Exception\InternalErrorException' => __DIR__ . '/Aws/CloudTrail/Exception/InternalErrorException.php', + 'Aws\CloudTrail\Exception\InvalidS3BucketNameException' => __DIR__ . '/Aws/CloudTrail/Exception/InvalidS3BucketNameException.php', + 'Aws\CloudTrail\Exception\InvalidS3PrefixException' => __DIR__ . '/Aws/CloudTrail/Exception/InvalidS3PrefixException.php', + 'Aws\CloudTrail\Exception\InvalidSnsTopicNameException' => __DIR__ . '/Aws/CloudTrail/Exception/InvalidSnsTopicNameException.php', + 'Aws\CloudTrail\Exception\InvalidTrailNameException' => __DIR__ . '/Aws/CloudTrail/Exception/InvalidTrailNameException.php', + 'Aws\CloudTrail\Exception\MaximumNumberOfTrailsExceededException' => __DIR__ . '/Aws/CloudTrail/Exception/MaximumNumberOfTrailsExceededException.php', + 'Aws\CloudTrail\Exception\S3BucketDoesNotExistException' => __DIR__ . '/Aws/CloudTrail/Exception/S3BucketDoesNotExistException.php', + 'Aws\CloudTrail\Exception\TrailAlreadyExistsException' => __DIR__ . '/Aws/CloudTrail/Exception/TrailAlreadyExistsException.php', + 'Aws\CloudTrail\Exception\TrailNotFoundException' => __DIR__ . '/Aws/CloudTrail/Exception/TrailNotFoundException.php', + 'Aws\CloudTrail\Exception\TrailNotProvidedException' => __DIR__ . '/Aws/CloudTrail/Exception/TrailNotProvidedException.php', + 'Aws\CloudTrail\LogFileIterator' => __DIR__ . '/Aws/CloudTrail/LogFileIterator.php', + 'Aws\CloudTrail\LogFileReader' => __DIR__ . '/Aws/CloudTrail/LogFileReader.php', + 'Aws\CloudTrail\LogRecordIterator' => __DIR__ . '/Aws/CloudTrail/LogRecordIterator.php', + 'Aws\CloudTrail\Resources\cloudtrail-2013-11-01' => __DIR__ . '/Aws/CloudTrail/Resources/cloudtrail-2013-11-01.php', + 'Aws\CloudWatch\CloudWatchClient' => __DIR__ . '/Aws/CloudWatch/CloudWatchClient.php', + 'Aws\CloudWatch\Enum\ComparisonOperator' => __DIR__ . '/Aws/CloudWatch/Enum/ComparisonOperator.php', + 'Aws\CloudWatch\Enum\HistoryItemType' => __DIR__ . '/Aws/CloudWatch/Enum/HistoryItemType.php', + 'Aws\CloudWatch\Enum\StateValue' => __DIR__ . '/Aws/CloudWatch/Enum/StateValue.php', + 'Aws\CloudWatch\Enum\Statistic' => __DIR__ . '/Aws/CloudWatch/Enum/Statistic.php', + 'Aws\CloudWatch\Enum\Unit' => __DIR__ . '/Aws/CloudWatch/Enum/Unit.php', + 'Aws\CloudWatch\Exception\CloudWatchException' => __DIR__ . '/Aws/CloudWatch/Exception/CloudWatchException.php', + 'Aws\CloudWatch\Exception\InternalServiceException' => __DIR__ . '/Aws/CloudWatch/Exception/InternalServiceException.php', + 'Aws\CloudWatch\Exception\InvalidFormatException' => __DIR__ . '/Aws/CloudWatch/Exception/InvalidFormatException.php', + 'Aws\CloudWatch\Exception\InvalidNextTokenException' => __DIR__ . '/Aws/CloudWatch/Exception/InvalidNextTokenException.php', + 'Aws\CloudWatch\Exception\InvalidParameterCombinationException' => __DIR__ . '/Aws/CloudWatch/Exception/InvalidParameterCombinationException.php', + 'Aws\CloudWatch\Exception\InvalidParameterValueException' => __DIR__ . '/Aws/CloudWatch/Exception/InvalidParameterValueException.php', + 'Aws\CloudWatch\Exception\LimitExceededException' => __DIR__ . '/Aws/CloudWatch/Exception/LimitExceededException.php', + 'Aws\CloudWatch\Exception\MissingRequiredParameterException' => __DIR__ . '/Aws/CloudWatch/Exception/MissingRequiredParameterException.php', + 'Aws\CloudWatch\Exception\ResourceNotFoundException' => __DIR__ . '/Aws/CloudWatch/Exception/ResourceNotFoundException.php', + 'Aws\CloudWatch\Resources\cloudwatch-2010-08-01' => __DIR__ . '/Aws/CloudWatch/Resources/cloudwatch-2010-08-01.php', + 'Aws\CloudWatchLogs\CloudWatchLogsClient' => __DIR__ . '/Aws/CloudWatchLogs/CloudWatchLogsClient.php', + 'Aws\CloudWatchLogs\Exception\CloudWatchLogsException' => __DIR__ . '/Aws/CloudWatchLogs/Exception/CloudWatchLogsException.php', + 'Aws\CloudWatchLogs\Resources\cloudwatchlogs-2014-03-28' => __DIR__ . '/Aws/CloudWatchLogs/Resources/cloudwatchlogs-2014-03-28.php', + 'Aws\CodeDeploy\CodeDeployClient' => __DIR__ . '/Aws/CodeDeploy/CodeDeployClient.php', + 'Aws\CodeDeploy\Exception\CodeDeployException' => __DIR__ . '/Aws/CodeDeploy/Exception/CodeDeployException.php', + 'Aws\CodeDeploy\Resources\codedeploy-2014-10-06' => __DIR__ . '/Aws/CodeDeploy/Resources/codedeploy-2014-10-06.php', + 'Aws\CognitoIdentity\CognitoIdentityClient' => __DIR__ . '/Aws/CognitoIdentity/CognitoIdentityClient.php', + 'Aws\CognitoIdentity\Exception\CognitoIdentityException' => __DIR__ . '/Aws/CognitoIdentity/Exception/CognitoIdentityException.php', + 'Aws\CognitoIdentity\Resources\cognitoidentity-2014-06-30' => __DIR__ . '/Aws/CognitoIdentity/Resources/cognitoidentity-2014-06-30.php', + 'Aws\CognitoSync\CognitoSyncClient' => __DIR__ . '/Aws/CognitoSync/CognitoSyncClient.php', + 'Aws\CognitoSync\Exception\CognitoSyncException' => __DIR__ . '/Aws/CognitoSync/Exception/CognitoSyncException.php', + 'Aws\CognitoSync\Resources\cognitosync-2014-06-30' => __DIR__ . '/Aws/CognitoSync/Resources/cognitosync-2014-06-30.php', + 'Aws\Common\Aws' => __DIR__ . '/Aws/Common/Aws.php', + 'Aws\Common\Client\AbstractClient' => __DIR__ . '/Aws/Common/Client/AbstractClient.php', + 'Aws\Common\Client\AwsClientInterface' => __DIR__ . '/Aws/Common/Client/AwsClientInterface.php', + 'Aws\Common\Client\ClientBuilder' => __DIR__ . '/Aws/Common/Client/ClientBuilder.php', + 'Aws\Common\Client\DefaultClient' => __DIR__ . '/Aws/Common/Client/DefaultClient.php', + 'Aws\Common\Client\ExpiredCredentialsChecker' => __DIR__ . '/Aws/Common/Client/ExpiredCredentialsChecker.php', + 'Aws\Common\Client\ThrottlingErrorChecker' => __DIR__ . '/Aws/Common/Client/ThrottlingErrorChecker.php', + 'Aws\Common\Client\UploadBodyListener' => __DIR__ . '/Aws/Common/Client/UploadBodyListener.php', + 'Aws\Common\Client\UserAgentListener' => __DIR__ . '/Aws/Common/Client/UserAgentListener.php', + 'Aws\Common\Command\AwsQueryVisitor' => __DIR__ . '/Aws/Common/Command/AwsQueryVisitor.php', + 'Aws\Common\Command\JsonCommand' => __DIR__ . '/Aws/Common/Command/JsonCommand.php', + 'Aws\Common\Command\QueryCommand' => __DIR__ . '/Aws/Common/Command/QueryCommand.php', + 'Aws\Common\Command\XmlResponseLocationVisitor' => __DIR__ . '/Aws/Common/Command/XmlResponseLocationVisitor.php', + 'Aws\Common\Credentials\AbstractCredentialsDecorator' => __DIR__ . '/Aws/Common/Credentials/AbstractCredentialsDecorator.php', + 'Aws\Common\Credentials\AbstractRefreshableCredentials' => __DIR__ . '/Aws/Common/Credentials/AbstractRefreshableCredentials.php', + 'Aws\Common\Credentials\CacheableCredentials' => __DIR__ . '/Aws/Common/Credentials/CacheableCredentials.php', + 'Aws\Common\Credentials\Credentials' => __DIR__ . '/Aws/Common/Credentials/Credentials.php', + 'Aws\Common\Credentials\CredentialsInterface' => __DIR__ . '/Aws/Common/Credentials/CredentialsInterface.php', + 'Aws\Common\Credentials\NullCredentials' => __DIR__ . '/Aws/Common/Credentials/NullCredentials.php', + 'Aws\Common\Credentials\RefreshableInstanceProfileCredentials' => __DIR__ . '/Aws/Common/Credentials/RefreshableInstanceProfileCredentials.php', + 'Aws\Common\Enum\ClientOptions' => __DIR__ . '/Aws/Common/Enum/ClientOptions.php', + 'Aws\Common\Enum\DateFormat' => __DIR__ . '/Aws/Common/Enum/DateFormat.php', + 'Aws\Common\Enum\Region' => __DIR__ . '/Aws/Common/Enum/Region.php', + 'Aws\Common\Enum\Size' => __DIR__ . '/Aws/Common/Enum/Size.php', + 'Aws\Common\Enum\Time' => __DIR__ . '/Aws/Common/Enum/Time.php', + 'Aws\Common\Enum\UaString' => __DIR__ . '/Aws/Common/Enum/UaString.php', + 'Aws\Common\Enum' => __DIR__ . '/Aws/Common/Enum.php', + 'Aws\Common\Exception\AwsExceptionInterface' => __DIR__ . '/Aws/Common/Exception/AwsExceptionInterface.php', + 'Aws\Common\Exception\BadMethodCallException' => __DIR__ . '/Aws/Common/Exception/BadMethodCallException.php', + 'Aws\Common\Exception\DomainException' => __DIR__ . '/Aws/Common/Exception/DomainException.php', + 'Aws\Common\Exception\ExceptionFactoryInterface' => __DIR__ . '/Aws/Common/Exception/ExceptionFactoryInterface.php', + 'Aws\Common\Exception\ExceptionListener' => __DIR__ . '/Aws/Common/Exception/ExceptionListener.php', + 'Aws\Common\Exception\InstanceProfileCredentialsException' => __DIR__ . '/Aws/Common/Exception/InstanceProfileCredentialsException.php', + 'Aws\Common\Exception\InvalidArgumentException' => __DIR__ . '/Aws/Common/Exception/InvalidArgumentException.php', + 'Aws\Common\Exception\LogicException' => __DIR__ . '/Aws/Common/Exception/LogicException.php', + 'Aws\Common\Exception\MultipartUploadException' => __DIR__ . '/Aws/Common/Exception/MultipartUploadException.php', + 'Aws\Common\Exception\NamespaceExceptionFactory' => __DIR__ . '/Aws/Common/Exception/NamespaceExceptionFactory.php', + 'Aws\Common\Exception\OutOfBoundsException' => __DIR__ . '/Aws/Common/Exception/OutOfBoundsException.php', + 'Aws\Common\Exception\OverflowException' => __DIR__ . '/Aws/Common/Exception/OverflowException.php', + 'Aws\Common\Exception\Parser\AbstractJsonExceptionParser' => __DIR__ . '/Aws/Common/Exception/Parser/AbstractJsonExceptionParser.php', + 'Aws\Common\Exception\Parser\DefaultXmlExceptionParser' => __DIR__ . '/Aws/Common/Exception/Parser/DefaultXmlExceptionParser.php', + 'Aws\Common\Exception\Parser\ExceptionParserInterface' => __DIR__ . '/Aws/Common/Exception/Parser/ExceptionParserInterface.php', + 'Aws\Common\Exception\Parser\JsonQueryExceptionParser' => __DIR__ . '/Aws/Common/Exception/Parser/JsonQueryExceptionParser.php', + 'Aws\Common\Exception\Parser\JsonRestExceptionParser' => __DIR__ . '/Aws/Common/Exception/Parser/JsonRestExceptionParser.php', + 'Aws\Common\Exception\RequiredExtensionNotLoadedException' => __DIR__ . '/Aws/Common/Exception/RequiredExtensionNotLoadedException.php', + 'Aws\Common\Exception\RuntimeException' => __DIR__ . '/Aws/Common/Exception/RuntimeException.php', + 'Aws\Common\Exception\ServiceResponseException' => __DIR__ . '/Aws/Common/Exception/ServiceResponseException.php', + 'Aws\Common\Exception\TransferException' => __DIR__ . '/Aws/Common/Exception/TransferException.php', + 'Aws\Common\Exception\UnexpectedValueException' => __DIR__ . '/Aws/Common/Exception/UnexpectedValueException.php', + 'Aws\Common\Facade\facade-classes' => __DIR__ . '/Aws/Common/Facade/facade-classes.php', + 'Aws\Common\Facade\Facade' => __DIR__ . '/Aws/Common/Facade/Facade.php', + 'Aws\Common\Facade\FacadeInterface' => __DIR__ . '/Aws/Common/Facade/FacadeInterface.php', + 'Aws\Common\Hash\ChunkHash' => __DIR__ . '/Aws/Common/Hash/ChunkHash.php', + 'Aws\Common\Hash\ChunkHashInterface' => __DIR__ . '/Aws/Common/Hash/ChunkHashInterface.php', + 'Aws\Common\Hash\HashUtils' => __DIR__ . '/Aws/Common/Hash/HashUtils.php', + 'Aws\Common\Hash\TreeHash' => __DIR__ . '/Aws/Common/Hash/TreeHash.php', + 'Aws\Common\HostNameUtils' => __DIR__ . '/Aws/Common/HostNameUtils.php', + 'Aws\Common\InstanceMetadata\InstanceMetadataClient' => __DIR__ . '/Aws/Common/InstanceMetadata/InstanceMetadataClient.php', + 'Aws\Common\InstanceMetadata\Waiter\ServiceAvailable' => __DIR__ . '/Aws/Common/InstanceMetadata/Waiter/ServiceAvailable.php', + 'Aws\Common\Iterator\AwsResourceIterator' => __DIR__ . '/Aws/Common/Iterator/AwsResourceIterator.php', + 'Aws\Common\Iterator\AwsResourceIteratorFactory' => __DIR__ . '/Aws/Common/Iterator/AwsResourceIteratorFactory.php', + 'Aws\Common\Model\MultipartUpload\AbstractTransfer' => __DIR__ . '/Aws/Common/Model/MultipartUpload/AbstractTransfer.php', + 'Aws\Common\Model\MultipartUpload\AbstractTransferState' => __DIR__ . '/Aws/Common/Model/MultipartUpload/AbstractTransferState.php', + 'Aws\Common\Model\MultipartUpload\AbstractUploadBuilder' => __DIR__ . '/Aws/Common/Model/MultipartUpload/AbstractUploadBuilder.php', + 'Aws\Common\Model\MultipartUpload\AbstractUploadId' => __DIR__ . '/Aws/Common/Model/MultipartUpload/AbstractUploadId.php', + 'Aws\Common\Model\MultipartUpload\AbstractUploadPart' => __DIR__ . '/Aws/Common/Model/MultipartUpload/AbstractUploadPart.php', + 'Aws\Common\Model\MultipartUpload\TransferInterface' => __DIR__ . '/Aws/Common/Model/MultipartUpload/TransferInterface.php', + 'Aws\Common\Model\MultipartUpload\TransferStateInterface' => __DIR__ . '/Aws/Common/Model/MultipartUpload/TransferStateInterface.php', + 'Aws\Common\Model\MultipartUpload\UploadIdInterface' => __DIR__ . '/Aws/Common/Model/MultipartUpload/UploadIdInterface.php', + 'Aws\Common\Model\MultipartUpload\UploadPartInterface' => __DIR__ . '/Aws/Common/Model/MultipartUpload/UploadPartInterface.php', + 'Aws\Common\Resources\aws-config' => __DIR__ . '/Aws/Common/Resources/aws-config.php', + 'Aws\Common\Resources\public-endpoints' => __DIR__ . '/Aws/Common/Resources/public-endpoints.php', + 'Aws\Common\Resources\sdk1-config' => __DIR__ . '/Aws/Common/Resources/sdk1-config.php', + 'Aws\Common\RulesEndpointProvider' => __DIR__ . '/Aws/Common/RulesEndpointProvider.php', + 'Aws\Common\Signature\AbstractSignature' => __DIR__ . '/Aws/Common/Signature/AbstractSignature.php', + 'Aws\Common\Signature\EndpointSignatureInterface' => __DIR__ . '/Aws/Common/Signature/EndpointSignatureInterface.php', + 'Aws\Common\Signature\SignatureInterface' => __DIR__ . '/Aws/Common/Signature/SignatureInterface.php', + 'Aws\Common\Signature\SignatureListener' => __DIR__ . '/Aws/Common/Signature/SignatureListener.php', + 'Aws\Common\Signature\SignatureV2' => __DIR__ . '/Aws/Common/Signature/SignatureV2.php', + 'Aws\Common\Signature\SignatureV3Https' => __DIR__ . '/Aws/Common/Signature/SignatureV3Https.php', + 'Aws\Common\Signature\SignatureV4' => __DIR__ . '/Aws/Common/Signature/SignatureV4.php', + 'Aws\Common\Waiter\AbstractResourceWaiter' => __DIR__ . '/Aws/Common/Waiter/AbstractResourceWaiter.php', + 'Aws\Common\Waiter\AbstractWaiter' => __DIR__ . '/Aws/Common/Waiter/AbstractWaiter.php', + 'Aws\Common\Waiter\CallableWaiter' => __DIR__ . '/Aws/Common/Waiter/CallableWaiter.php', + 'Aws\Common\Waiter\CompositeWaiterFactory' => __DIR__ . '/Aws/Common/Waiter/CompositeWaiterFactory.php', + 'Aws\Common\Waiter\ConfigResourceWaiter' => __DIR__ . '/Aws/Common/Waiter/ConfigResourceWaiter.php', + 'Aws\Common\Waiter\ResourceWaiterInterface' => __DIR__ . '/Aws/Common/Waiter/ResourceWaiterInterface.php', + 'Aws\Common\Waiter\WaiterClassFactory' => __DIR__ . '/Aws/Common/Waiter/WaiterClassFactory.php', + 'Aws\Common\Waiter\WaiterConfig' => __DIR__ . '/Aws/Common/Waiter/WaiterConfig.php', + 'Aws\Common\Waiter\WaiterConfigFactory' => __DIR__ . '/Aws/Common/Waiter/WaiterConfigFactory.php', + 'Aws\Common\Waiter\WaiterFactoryInterface' => __DIR__ . '/Aws/Common/Waiter/WaiterFactoryInterface.php', + 'Aws\Common\Waiter\WaiterInterface' => __DIR__ . '/Aws/Common/Waiter/WaiterInterface.php', + 'Aws\ConfigService\ConfigServiceClient' => __DIR__ . '/Aws/ConfigService/ConfigServiceClient.php', + 'Aws\ConfigService\Exception\ConfigServiceException' => __DIR__ . '/Aws/ConfigService/Exception/ConfigServiceException.php', + 'Aws\ConfigService\Resources\configservice-2014-11-12' => __DIR__ . '/Aws/ConfigService/Resources/configservice-2014-11-12.php', + 'Aws\DataPipeline\DataPipelineClient' => __DIR__ . '/Aws/DataPipeline/DataPipelineClient.php', + 'Aws\DataPipeline\Enum\WorkStatus' => __DIR__ . '/Aws/DataPipeline/Enum/WorkStatus.php', + 'Aws\DataPipeline\Exception\DataPipelineException' => __DIR__ . '/Aws/DataPipeline/Exception/DataPipelineException.php', + 'Aws\DataPipeline\Exception\InternalServiceErrorException' => __DIR__ . '/Aws/DataPipeline/Exception/InternalServiceErrorException.php', + 'Aws\DataPipeline\Exception\InvalidRequestException' => __DIR__ . '/Aws/DataPipeline/Exception/InvalidRequestException.php', + 'Aws\DataPipeline\Exception\PipelineDeletedException' => __DIR__ . '/Aws/DataPipeline/Exception/PipelineDeletedException.php', + 'Aws\DataPipeline\Exception\PipelineNotFoundException' => __DIR__ . '/Aws/DataPipeline/Exception/PipelineNotFoundException.php', + 'Aws\DataPipeline\Exception\TaskNotFoundException' => __DIR__ . '/Aws/DataPipeline/Exception/TaskNotFoundException.php', + 'Aws\DataPipeline\Resources\datapipeline-2012-10-29' => __DIR__ . '/Aws/DataPipeline/Resources/datapipeline-2012-10-29.php', + 'Aws\DirectConnect\DirectConnectClient' => __DIR__ . '/Aws/DirectConnect/DirectConnectClient.php', + 'Aws\DirectConnect\Enum\ConnectionState' => __DIR__ . '/Aws/DirectConnect/Enum/ConnectionState.php', + 'Aws\DirectConnect\Enum\InterconnectState' => __DIR__ . '/Aws/DirectConnect/Enum/InterconnectState.php', + 'Aws\DirectConnect\Enum\StepState' => __DIR__ . '/Aws/DirectConnect/Enum/StepState.php', + 'Aws\DirectConnect\Enum\VirtualInterfaceState' => __DIR__ . '/Aws/DirectConnect/Enum/VirtualInterfaceState.php', + 'Aws\DirectConnect\Exception\DirectConnectClientException' => __DIR__ . '/Aws/DirectConnect/Exception/DirectConnectClientException.php', + 'Aws\DirectConnect\Exception\DirectConnectException' => __DIR__ . '/Aws/DirectConnect/Exception/DirectConnectException.php', + 'Aws\DirectConnect\Exception\DirectConnectServerException' => __DIR__ . '/Aws/DirectConnect/Exception/DirectConnectServerException.php', + 'Aws\DirectConnect\Resources\directconnect-2012-10-25' => __DIR__ . '/Aws/DirectConnect/Resources/directconnect-2012-10-25.php', + 'Aws\DynamoDb\Crc32ErrorChecker' => __DIR__ . '/Aws/DynamoDb/Crc32ErrorChecker.php', + 'Aws\DynamoDb\DynamoDbClient' => __DIR__ . '/Aws/DynamoDb/DynamoDbClient.php', + 'Aws\DynamoDb\DynamoDbCommand' => __DIR__ . '/Aws/DynamoDb/DynamoDbCommand.php', + 'Aws\DynamoDb\Enum\AttributeAction' => __DIR__ . '/Aws/DynamoDb/Enum/AttributeAction.php', + 'Aws\DynamoDb\Enum\AttributeType' => __DIR__ . '/Aws/DynamoDb/Enum/AttributeType.php', + 'Aws\DynamoDb\Enum\ComparisonOperator' => __DIR__ . '/Aws/DynamoDb/Enum/ComparisonOperator.php', + 'Aws\DynamoDb\Enum\IndexStatus' => __DIR__ . '/Aws/DynamoDb/Enum/IndexStatus.php', + 'Aws\DynamoDb\Enum\KeyType' => __DIR__ . '/Aws/DynamoDb/Enum/KeyType.php', + 'Aws\DynamoDb\Enum\ProjectionType' => __DIR__ . '/Aws/DynamoDb/Enum/ProjectionType.php', + 'Aws\DynamoDb\Enum\ReturnConsumedCapacity' => __DIR__ . '/Aws/DynamoDb/Enum/ReturnConsumedCapacity.php', + 'Aws\DynamoDb\Enum\ReturnItemCollectionMetrics' => __DIR__ . '/Aws/DynamoDb/Enum/ReturnItemCollectionMetrics.php', + 'Aws\DynamoDb\Enum\ReturnValue' => __DIR__ . '/Aws/DynamoDb/Enum/ReturnValue.php', + 'Aws\DynamoDb\Enum\ScalarAttributeType' => __DIR__ . '/Aws/DynamoDb/Enum/ScalarAttributeType.php', + 'Aws\DynamoDb\Enum\Select' => __DIR__ . '/Aws/DynamoDb/Enum/Select.php', + 'Aws\DynamoDb\Enum\TableStatus' => __DIR__ . '/Aws/DynamoDb/Enum/TableStatus.php', + 'Aws\DynamoDb\Enum\Type' => __DIR__ . '/Aws/DynamoDb/Enum/Type.php', + 'Aws\DynamoDb\Exception\AccessDeniedException' => __DIR__ . '/Aws/DynamoDb/Exception/AccessDeniedException.php', + 'Aws\DynamoDb\Exception\ConditionalCheckFailedException' => __DIR__ . '/Aws/DynamoDb/Exception/ConditionalCheckFailedException.php', + 'Aws\DynamoDb\Exception\DynamoDbException' => __DIR__ . '/Aws/DynamoDb/Exception/DynamoDbException.php', + 'Aws\DynamoDb\Exception\IncompleteSignatureException' => __DIR__ . '/Aws/DynamoDb/Exception/IncompleteSignatureException.php', + 'Aws\DynamoDb\Exception\InternalFailureException' => __DIR__ . '/Aws/DynamoDb/Exception/InternalFailureException.php', + 'Aws\DynamoDb\Exception\InternalServerErrorException' => __DIR__ . '/Aws/DynamoDb/Exception/InternalServerErrorException.php', + 'Aws\DynamoDb\Exception\ItemCollectionSizeLimitExceededException' => __DIR__ . '/Aws/DynamoDb/Exception/ItemCollectionSizeLimitExceededException.php', + 'Aws\DynamoDb\Exception\LimitExceededException' => __DIR__ . '/Aws/DynamoDb/Exception/LimitExceededException.php', + 'Aws\DynamoDb\Exception\MissingAuthenticationTokenException' => __DIR__ . '/Aws/DynamoDb/Exception/MissingAuthenticationTokenException.php', + 'Aws\DynamoDb\Exception\ProvisionedThroughputExceededException' => __DIR__ . '/Aws/DynamoDb/Exception/ProvisionedThroughputExceededException.php', + 'Aws\DynamoDb\Exception\ResourceInUseException' => __DIR__ . '/Aws/DynamoDb/Exception/ResourceInUseException.php', + 'Aws\DynamoDb\Exception\ResourceNotFoundException' => __DIR__ . '/Aws/DynamoDb/Exception/ResourceNotFoundException.php', + 'Aws\DynamoDb\Exception\ServiceUnavailableException' => __DIR__ . '/Aws/DynamoDb/Exception/ServiceUnavailableException.php', + 'Aws\DynamoDb\Exception\ThrottlingException' => __DIR__ . '/Aws/DynamoDb/Exception/ThrottlingException.php', + 'Aws\DynamoDb\Exception\UnprocessedWriteRequestsException' => __DIR__ . '/Aws/DynamoDb/Exception/UnprocessedWriteRequestsException.php', + 'Aws\DynamoDb\Exception\UnrecognizedClientException' => __DIR__ . '/Aws/DynamoDb/Exception/UnrecognizedClientException.php', + 'Aws\DynamoDb\Exception\ValidationException' => __DIR__ . '/Aws/DynamoDb/Exception/ValidationException.php', + 'Aws\DynamoDb\Iterator\ItemIterator' => __DIR__ . '/Aws/DynamoDb/Iterator/ItemIterator.php', + 'Aws\DynamoDb\Iterator\ScanIterator' => __DIR__ . '/Aws/DynamoDb/Iterator/ScanIterator.php', + 'Aws\DynamoDb\Marshaler' => __DIR__ . '/Aws/DynamoDb/Marshaler.php', + 'Aws\DynamoDb\Model\Attribute' => __DIR__ . '/Aws/DynamoDb/Model/Attribute.php', + 'Aws\DynamoDb\Model\BatchRequest\AbstractWriteRequest' => __DIR__ . '/Aws/DynamoDb/Model/BatchRequest/AbstractWriteRequest.php', + 'Aws\DynamoDb\Model\BatchRequest\DeleteRequest' => __DIR__ . '/Aws/DynamoDb/Model/BatchRequest/DeleteRequest.php', + 'Aws\DynamoDb\Model\BatchRequest\PutRequest' => __DIR__ . '/Aws/DynamoDb/Model/BatchRequest/PutRequest.php', + 'Aws\DynamoDb\Model\BatchRequest\UnprocessedRequest' => __DIR__ . '/Aws/DynamoDb/Model/BatchRequest/UnprocessedRequest.php', + 'Aws\DynamoDb\Model\BatchRequest\WriteRequestBatch' => __DIR__ . '/Aws/DynamoDb/Model/BatchRequest/WriteRequestBatch.php', + 'Aws\DynamoDb\Model\BatchRequest\WriteRequestBatchTransfer' => __DIR__ . '/Aws/DynamoDb/Model/BatchRequest/WriteRequestBatchTransfer.php', + 'Aws\DynamoDb\Model\BatchRequest\WriteRequestInterface' => __DIR__ . '/Aws/DynamoDb/Model/BatchRequest/WriteRequestInterface.php', + 'Aws\DynamoDb\Model\Item' => __DIR__ . '/Aws/DynamoDb/Model/Item.php', + 'Aws\DynamoDb\Resources\dynamodb-2011-12-05' => __DIR__ . '/Aws/DynamoDb/Resources/dynamodb-2011-12-05.php', + 'Aws\DynamoDb\Resources\dynamodb-2012-08-10' => __DIR__ . '/Aws/DynamoDb/Resources/dynamodb-2012-08-10.php', + 'Aws\DynamoDb\Session\LockingStrategy\AbstractLockingStrategy' => __DIR__ . '/Aws/DynamoDb/Session/LockingStrategy/AbstractLockingStrategy.php', + 'Aws\DynamoDb\Session\LockingStrategy\LockingStrategyFactory' => __DIR__ . '/Aws/DynamoDb/Session/LockingStrategy/LockingStrategyFactory.php', + 'Aws\DynamoDb\Session\LockingStrategy\LockingStrategyFactoryInterface' => __DIR__ . '/Aws/DynamoDb/Session/LockingStrategy/LockingStrategyFactoryInterface.php', + 'Aws\DynamoDb\Session\LockingStrategy\LockingStrategyInterface' => __DIR__ . '/Aws/DynamoDb/Session/LockingStrategy/LockingStrategyInterface.php', + 'Aws\DynamoDb\Session\LockingStrategy\NullLockingStrategy' => __DIR__ . '/Aws/DynamoDb/Session/LockingStrategy/NullLockingStrategy.php', + 'Aws\DynamoDb\Session\LockingStrategy\PessimisticLockingStrategy' => __DIR__ . '/Aws/DynamoDb/Session/LockingStrategy/PessimisticLockingStrategy.php', + 'Aws\DynamoDb\Session\SessionHandler' => __DIR__ . '/Aws/DynamoDb/Session/SessionHandler.php', + 'Aws\DynamoDb\Session\SessionHandlerConfig' => __DIR__ . '/Aws/DynamoDb/Session/SessionHandlerConfig.php', + 'Aws\DynamoDb\Session\SessionHandlerInterface' => __DIR__ . '/Aws/DynamoDb/Session/SessionHandlerInterface.php', + 'Aws\Ec2\CopySnapshotListener' => __DIR__ . '/Aws/Ec2/CopySnapshotListener.php', + 'Aws\Ec2\Ec2Client' => __DIR__ . '/Aws/Ec2/Ec2Client.php', + 'Aws\Ec2\Enum\ContainerFormat' => __DIR__ . '/Aws/Ec2/Enum/ContainerFormat.php', + 'Aws\Ec2\Enum\DiskImageFormat' => __DIR__ . '/Aws/Ec2/Enum/DiskImageFormat.php', + 'Aws\Ec2\Enum\DomainType' => __DIR__ . '/Aws/Ec2/Enum/DomainType.php', + 'Aws\Ec2\Enum\ExportEnvironment' => __DIR__ . '/Aws/Ec2/Enum/ExportEnvironment.php', + 'Aws\Ec2\Enum\HypervisorType' => __DIR__ . '/Aws/Ec2/Enum/HypervisorType.php', + 'Aws\Ec2\Enum\ImageState' => __DIR__ . '/Aws/Ec2/Enum/ImageState.php', + 'Aws\Ec2\Enum\InstanceAttributeName' => __DIR__ . '/Aws/Ec2/Enum/InstanceAttributeName.php', + 'Aws\Ec2\Enum\InstanceStateName' => __DIR__ . '/Aws/Ec2/Enum/InstanceStateName.php', + 'Aws\Ec2\Enum\InstanceType' => __DIR__ . '/Aws/Ec2/Enum/InstanceType.php', + 'Aws\Ec2\Enum\PlacementGroupState' => __DIR__ . '/Aws/Ec2/Enum/PlacementGroupState.php', + 'Aws\Ec2\Enum\PlacementStrategy' => __DIR__ . '/Aws/Ec2/Enum/PlacementStrategy.php', + 'Aws\Ec2\Enum\ResourceType' => __DIR__ . '/Aws/Ec2/Enum/ResourceType.php', + 'Aws\Ec2\Enum\RouteOrigin' => __DIR__ . '/Aws/Ec2/Enum/RouteOrigin.php', + 'Aws\Ec2\Enum\RuleAction' => __DIR__ . '/Aws/Ec2/Enum/RuleAction.php', + 'Aws\Ec2\Enum\SnapshotAttributeName' => __DIR__ . '/Aws/Ec2/Enum/SnapshotAttributeName.php', + 'Aws\Ec2\Enum\SnapshotState' => __DIR__ . '/Aws/Ec2/Enum/SnapshotState.php', + 'Aws\Ec2\Enum\SpotInstanceType' => __DIR__ . '/Aws/Ec2/Enum/SpotInstanceType.php', + 'Aws\Ec2\Enum\VirtualizationType' => __DIR__ . '/Aws/Ec2/Enum/VirtualizationType.php', + 'Aws\Ec2\Enum\VolumeAttachmentState' => __DIR__ . '/Aws/Ec2/Enum/VolumeAttachmentState.php', + 'Aws\Ec2\Enum\VolumeAttributeName' => __DIR__ . '/Aws/Ec2/Enum/VolumeAttributeName.php', + 'Aws\Ec2\Enum\VolumeState' => __DIR__ . '/Aws/Ec2/Enum/VolumeState.php', + 'Aws\Ec2\Enum\VolumeType' => __DIR__ . '/Aws/Ec2/Enum/VolumeType.php', + 'Aws\Ec2\Enum\VpcAttributeName' => __DIR__ . '/Aws/Ec2/Enum/VpcAttributeName.php', + 'Aws\Ec2\Exception\Ec2Exception' => __DIR__ . '/Aws/Ec2/Exception/Ec2Exception.php', + 'Aws\Ec2\Iterator\DescribeInstancesIterator' => __DIR__ . '/Aws/Ec2/Iterator/DescribeInstancesIterator.php', + 'Aws\Ec2\Resources\ec2-2014-10-01' => __DIR__ . '/Aws/Ec2/Resources/ec2-2014-10-01.php', + 'Aws\Ecs\EcsClient' => __DIR__ . '/Aws/Ecs/EcsClient.php', + 'Aws\Ecs\Exception\EcsException' => __DIR__ . '/Aws/Ecs/Exception/EcsException.php', + 'Aws\Ecs\Resources\ecs-2014-11-13' => __DIR__ . '/Aws/Ecs/Resources/ecs-2014-11-13.php', + 'Aws\ElastiCache\ElastiCacheClient' => __DIR__ . '/Aws/ElastiCache/ElastiCacheClient.php', + 'Aws\ElastiCache\Enum\SourceType' => __DIR__ . '/Aws/ElastiCache/Enum/SourceType.php', + 'Aws\ElastiCache\Exception\AuthorizationAlreadyExistsException' => __DIR__ . '/Aws/ElastiCache/Exception/AuthorizationAlreadyExistsException.php', + 'Aws\ElastiCache\Exception\AuthorizationNotFoundException' => __DIR__ . '/Aws/ElastiCache/Exception/AuthorizationNotFoundException.php', + 'Aws\ElastiCache\Exception\CacheClusterAlreadyExistsException' => __DIR__ . '/Aws/ElastiCache/Exception/CacheClusterAlreadyExistsException.php', + 'Aws\ElastiCache\Exception\CacheClusterNotFoundException' => __DIR__ . '/Aws/ElastiCache/Exception/CacheClusterNotFoundException.php', + 'Aws\ElastiCache\Exception\CacheParameterGroupAlreadyExistsException' => __DIR__ . '/Aws/ElastiCache/Exception/CacheParameterGroupAlreadyExistsException.php', + 'Aws\ElastiCache\Exception\CacheParameterGroupNotFoundException' => __DIR__ . '/Aws/ElastiCache/Exception/CacheParameterGroupNotFoundException.php', + 'Aws\ElastiCache\Exception\CacheParameterGroupQuotaExceededException' => __DIR__ . '/Aws/ElastiCache/Exception/CacheParameterGroupQuotaExceededException.php', + 'Aws\ElastiCache\Exception\CacheSecurityGroupAlreadyExistsException' => __DIR__ . '/Aws/ElastiCache/Exception/CacheSecurityGroupAlreadyExistsException.php', + 'Aws\ElastiCache\Exception\CacheSecurityGroupNotFoundException' => __DIR__ . '/Aws/ElastiCache/Exception/CacheSecurityGroupNotFoundException.php', + 'Aws\ElastiCache\Exception\CacheSecurityGroupQuotaExceededException' => __DIR__ . '/Aws/ElastiCache/Exception/CacheSecurityGroupQuotaExceededException.php', + 'Aws\ElastiCache\Exception\CacheSubnetGroupAlreadyExistsException' => __DIR__ . '/Aws/ElastiCache/Exception/CacheSubnetGroupAlreadyExistsException.php', + 'Aws\ElastiCache\Exception\CacheSubnetGroupInUseException' => __DIR__ . '/Aws/ElastiCache/Exception/CacheSubnetGroupInUseException.php', + 'Aws\ElastiCache\Exception\CacheSubnetGroupNotFoundException' => __DIR__ . '/Aws/ElastiCache/Exception/CacheSubnetGroupNotFoundException.php', + 'Aws\ElastiCache\Exception\CacheSubnetGroupQuotaExceededException' => __DIR__ . '/Aws/ElastiCache/Exception/CacheSubnetGroupQuotaExceededException.php', + 'Aws\ElastiCache\Exception\CacheSubnetQuotaExceededException' => __DIR__ . '/Aws/ElastiCache/Exception/CacheSubnetQuotaExceededException.php', + 'Aws\ElastiCache\Exception\ClusterQuotaForCustomerExceededException' => __DIR__ . '/Aws/ElastiCache/Exception/ClusterQuotaForCustomerExceededException.php', + 'Aws\ElastiCache\Exception\ElastiCacheException' => __DIR__ . '/Aws/ElastiCache/Exception/ElastiCacheException.php', + 'Aws\ElastiCache\Exception\InsufficientCacheClusterCapacityException' => __DIR__ . '/Aws/ElastiCache/Exception/InsufficientCacheClusterCapacityException.php', + 'Aws\ElastiCache\Exception\InvalidCacheClusterStateException' => __DIR__ . '/Aws/ElastiCache/Exception/InvalidCacheClusterStateException.php', + 'Aws\ElastiCache\Exception\InvalidCacheParameterGroupStateException' => __DIR__ . '/Aws/ElastiCache/Exception/InvalidCacheParameterGroupStateException.php', + 'Aws\ElastiCache\Exception\InvalidCacheSecurityGroupStateException' => __DIR__ . '/Aws/ElastiCache/Exception/InvalidCacheSecurityGroupStateException.php', + 'Aws\ElastiCache\Exception\InvalidParameterCombinationException' => __DIR__ . '/Aws/ElastiCache/Exception/InvalidParameterCombinationException.php', + 'Aws\ElastiCache\Exception\InvalidParameterValueException' => __DIR__ . '/Aws/ElastiCache/Exception/InvalidParameterValueException.php', + 'Aws\ElastiCache\Exception\InvalidReplicationGroupStateException' => __DIR__ . '/Aws/ElastiCache/Exception/InvalidReplicationGroupStateException.php', + 'Aws\ElastiCache\Exception\InvalidSubnetException' => __DIR__ . '/Aws/ElastiCache/Exception/InvalidSubnetException.php', + 'Aws\ElastiCache\Exception\InvalidVPCNetworkStateException' => __DIR__ . '/Aws/ElastiCache/Exception/InvalidVPCNetworkStateException.php', + 'Aws\ElastiCache\Exception\NodeQuotaForClusterExceededException' => __DIR__ . '/Aws/ElastiCache/Exception/NodeQuotaForClusterExceededException.php', + 'Aws\ElastiCache\Exception\NodeQuotaForCustomerExceededException' => __DIR__ . '/Aws/ElastiCache/Exception/NodeQuotaForCustomerExceededException.php', + 'Aws\ElastiCache\Exception\ReplicationGroupAlreadyExistsException' => __DIR__ . '/Aws/ElastiCache/Exception/ReplicationGroupAlreadyExistsException.php', + 'Aws\ElastiCache\Exception\ReplicationGroupNotFoundException' => __DIR__ . '/Aws/ElastiCache/Exception/ReplicationGroupNotFoundException.php', + 'Aws\ElastiCache\Exception\ReservedCacheNodeAlreadyExistsException' => __DIR__ . '/Aws/ElastiCache/Exception/ReservedCacheNodeAlreadyExistsException.php', + 'Aws\ElastiCache\Exception\ReservedCacheNodeNotFoundException' => __DIR__ . '/Aws/ElastiCache/Exception/ReservedCacheNodeNotFoundException.php', + 'Aws\ElastiCache\Exception\ReservedCacheNodeQuotaExceededException' => __DIR__ . '/Aws/ElastiCache/Exception/ReservedCacheNodeQuotaExceededException.php', + 'Aws\ElastiCache\Exception\ReservedCacheNodesOfferingNotFoundException' => __DIR__ . '/Aws/ElastiCache/Exception/ReservedCacheNodesOfferingNotFoundException.php', + 'Aws\ElastiCache\Exception\SubnetInUseException' => __DIR__ . '/Aws/ElastiCache/Exception/SubnetInUseException.php', + 'Aws\ElastiCache\Resources\elasticache-2015-02-02' => __DIR__ . '/Aws/ElastiCache/Resources/elasticache-2015-02-02.php', + 'Aws\ElasticBeanstalk\ElasticBeanstalkClient' => __DIR__ . '/Aws/ElasticBeanstalk/ElasticBeanstalkClient.php', + 'Aws\ElasticBeanstalk\Enum\ConfigurationDeploymentStatus' => __DIR__ . '/Aws/ElasticBeanstalk/Enum/ConfigurationDeploymentStatus.php', + 'Aws\ElasticBeanstalk\Enum\ConfigurationOptionValueType' => __DIR__ . '/Aws/ElasticBeanstalk/Enum/ConfigurationOptionValueType.php', + 'Aws\ElasticBeanstalk\Enum\EnvironmentHealth' => __DIR__ . '/Aws/ElasticBeanstalk/Enum/EnvironmentHealth.php', + 'Aws\ElasticBeanstalk\Enum\EnvironmentInfoType' => __DIR__ . '/Aws/ElasticBeanstalk/Enum/EnvironmentInfoType.php', + 'Aws\ElasticBeanstalk\Enum\EnvironmentStatus' => __DIR__ . '/Aws/ElasticBeanstalk/Enum/EnvironmentStatus.php', + 'Aws\ElasticBeanstalk\Enum\EventSeverity' => __DIR__ . '/Aws/ElasticBeanstalk/Enum/EventSeverity.php', + 'Aws\ElasticBeanstalk\Enum\ValidationSeverity' => __DIR__ . '/Aws/ElasticBeanstalk/Enum/ValidationSeverity.php', + 'Aws\ElasticBeanstalk\Exception\ElasticBeanstalkException' => __DIR__ . '/Aws/ElasticBeanstalk/Exception/ElasticBeanstalkException.php', + 'Aws\ElasticBeanstalk\Exception\InsufficientPrivilegesException' => __DIR__ . '/Aws/ElasticBeanstalk/Exception/InsufficientPrivilegesException.php', + 'Aws\ElasticBeanstalk\Exception\OperationInProgressException' => __DIR__ . '/Aws/ElasticBeanstalk/Exception/OperationInProgressException.php', + 'Aws\ElasticBeanstalk\Exception\S3LocationNotInServiceRegionException' => __DIR__ . '/Aws/ElasticBeanstalk/Exception/S3LocationNotInServiceRegionException.php', + 'Aws\ElasticBeanstalk\Exception\S3SubscriptionRequiredException' => __DIR__ . '/Aws/ElasticBeanstalk/Exception/S3SubscriptionRequiredException.php', + 'Aws\ElasticBeanstalk\Exception\SourceBundleDeletionException' => __DIR__ . '/Aws/ElasticBeanstalk/Exception/SourceBundleDeletionException.php', + 'Aws\ElasticBeanstalk\Exception\TooManyApplicationsException' => __DIR__ . '/Aws/ElasticBeanstalk/Exception/TooManyApplicationsException.php', + 'Aws\ElasticBeanstalk\Exception\TooManyApplicationVersionsException' => __DIR__ . '/Aws/ElasticBeanstalk/Exception/TooManyApplicationVersionsException.php', + 'Aws\ElasticBeanstalk\Exception\TooManyBucketsException' => __DIR__ . '/Aws/ElasticBeanstalk/Exception/TooManyBucketsException.php', + 'Aws\ElasticBeanstalk\Exception\TooManyConfigurationTemplatesException' => __DIR__ . '/Aws/ElasticBeanstalk/Exception/TooManyConfigurationTemplatesException.php', + 'Aws\ElasticBeanstalk\Exception\TooManyEnvironmentsException' => __DIR__ . '/Aws/ElasticBeanstalk/Exception/TooManyEnvironmentsException.php', + 'Aws\ElasticBeanstalk\Resources\elasticbeanstalk-2010-12-01' => __DIR__ . '/Aws/ElasticBeanstalk/Resources/elasticbeanstalk-2010-12-01.php', + 'Aws\ElasticLoadBalancing\ElasticLoadBalancingClient' => __DIR__ . '/Aws/ElasticLoadBalancing/ElasticLoadBalancingClient.php', + 'Aws\ElasticLoadBalancing\Exception\AccessPointNotFoundException' => __DIR__ . '/Aws/ElasticLoadBalancing/Exception/AccessPointNotFoundException.php', + 'Aws\ElasticLoadBalancing\Exception\CertificateNotFoundException' => __DIR__ . '/Aws/ElasticLoadBalancing/Exception/CertificateNotFoundException.php', + 'Aws\ElasticLoadBalancing\Exception\DuplicateAccessPointNameException' => __DIR__ . '/Aws/ElasticLoadBalancing/Exception/DuplicateAccessPointNameException.php', + 'Aws\ElasticLoadBalancing\Exception\DuplicateListenerException' => __DIR__ . '/Aws/ElasticLoadBalancing/Exception/DuplicateListenerException.php', + 'Aws\ElasticLoadBalancing\Exception\DuplicatePolicyNameException' => __DIR__ . '/Aws/ElasticLoadBalancing/Exception/DuplicatePolicyNameException.php', + 'Aws\ElasticLoadBalancing\Exception\ElasticLoadBalancingException' => __DIR__ . '/Aws/ElasticLoadBalancing/Exception/ElasticLoadBalancingException.php', + 'Aws\ElasticLoadBalancing\Exception\InvalidConfigurationRequestException' => __DIR__ . '/Aws/ElasticLoadBalancing/Exception/InvalidConfigurationRequestException.php', + 'Aws\ElasticLoadBalancing\Exception\InvalidEndPointException' => __DIR__ . '/Aws/ElasticLoadBalancing/Exception/InvalidEndPointException.php', + 'Aws\ElasticLoadBalancing\Exception\InvalidSchemeException' => __DIR__ . '/Aws/ElasticLoadBalancing/Exception/InvalidSchemeException.php', + 'Aws\ElasticLoadBalancing\Exception\InvalidSecurityGroupException' => __DIR__ . '/Aws/ElasticLoadBalancing/Exception/InvalidSecurityGroupException.php', + 'Aws\ElasticLoadBalancing\Exception\InvalidSubnetException' => __DIR__ . '/Aws/ElasticLoadBalancing/Exception/InvalidSubnetException.php', + 'Aws\ElasticLoadBalancing\Exception\ListenerNotFoundException' => __DIR__ . '/Aws/ElasticLoadBalancing/Exception/ListenerNotFoundException.php', + 'Aws\ElasticLoadBalancing\Exception\LoadBalancerAttributeNotFoundException' => __DIR__ . '/Aws/ElasticLoadBalancing/Exception/LoadBalancerAttributeNotFoundException.php', + 'Aws\ElasticLoadBalancing\Exception\PolicyNotFoundException' => __DIR__ . '/Aws/ElasticLoadBalancing/Exception/PolicyNotFoundException.php', + 'Aws\ElasticLoadBalancing\Exception\PolicyTypeNotFoundException' => __DIR__ . '/Aws/ElasticLoadBalancing/Exception/PolicyTypeNotFoundException.php', + 'Aws\ElasticLoadBalancing\Exception\SubnetNotFoundException' => __DIR__ . '/Aws/ElasticLoadBalancing/Exception/SubnetNotFoundException.php', + 'Aws\ElasticLoadBalancing\Exception\TooManyAccessPointsException' => __DIR__ . '/Aws/ElasticLoadBalancing/Exception/TooManyAccessPointsException.php', + 'Aws\ElasticLoadBalancing\Exception\TooManyPoliciesException' => __DIR__ . '/Aws/ElasticLoadBalancing/Exception/TooManyPoliciesException.php', + 'Aws\ElasticLoadBalancing\Resources\elasticloadbalancing-2012-06-01' => __DIR__ . '/Aws/ElasticLoadBalancing/Resources/elasticloadbalancing-2012-06-01.php', + 'Aws\ElasticTranscoder\ElasticTranscoderClient' => __DIR__ . '/Aws/ElasticTranscoder/ElasticTranscoderClient.php', + 'Aws\ElasticTranscoder\Exception\AccessDeniedException' => __DIR__ . '/Aws/ElasticTranscoder/Exception/AccessDeniedException.php', + 'Aws\ElasticTranscoder\Exception\ElasticTranscoderException' => __DIR__ . '/Aws/ElasticTranscoder/Exception/ElasticTranscoderException.php', + 'Aws\ElasticTranscoder\Exception\IncompatibleVersionException' => __DIR__ . '/Aws/ElasticTranscoder/Exception/IncompatibleVersionException.php', + 'Aws\ElasticTranscoder\Exception\InternalServiceException' => __DIR__ . '/Aws/ElasticTranscoder/Exception/InternalServiceException.php', + 'Aws\ElasticTranscoder\Exception\LimitExceededException' => __DIR__ . '/Aws/ElasticTranscoder/Exception/LimitExceededException.php', + 'Aws\ElasticTranscoder\Exception\ResourceInUseException' => __DIR__ . '/Aws/ElasticTranscoder/Exception/ResourceInUseException.php', + 'Aws\ElasticTranscoder\Exception\ResourceNotFoundException' => __DIR__ . '/Aws/ElasticTranscoder/Exception/ResourceNotFoundException.php', + 'Aws\ElasticTranscoder\Exception\ValidationException' => __DIR__ . '/Aws/ElasticTranscoder/Exception/ValidationException.php', + 'Aws\ElasticTranscoder\Resources\elastictranscoder-2012-09-25' => __DIR__ . '/Aws/ElasticTranscoder/Resources/elastictranscoder-2012-09-25.php', + 'Aws\Emr\EmrClient' => __DIR__ . '/Aws/Emr/EmrClient.php', + 'Aws\Emr\Enum\ActionOnFailure' => __DIR__ . '/Aws/Emr/Enum/ActionOnFailure.php', + 'Aws\Emr\Enum\ClusterState' => __DIR__ . '/Aws/Emr/Enum/ClusterState.php', + 'Aws\Emr\Enum\ClusterStateChangeReasonCode' => __DIR__ . '/Aws/Emr/Enum/ClusterStateChangeReasonCode.php', + 'Aws\Emr\Enum\InstanceGroupState' => __DIR__ . '/Aws/Emr/Enum/InstanceGroupState.php', + 'Aws\Emr\Enum\InstanceGroupStateChangeReasonCode' => __DIR__ . '/Aws/Emr/Enum/InstanceGroupStateChangeReasonCode.php', + 'Aws\Emr\Enum\InstanceGroupType' => __DIR__ . '/Aws/Emr/Enum/InstanceGroupType.php', + 'Aws\Emr\Enum\InstanceRoleType' => __DIR__ . '/Aws/Emr/Enum/InstanceRoleType.php', + 'Aws\Emr\Enum\InstanceState' => __DIR__ . '/Aws/Emr/Enum/InstanceState.php', + 'Aws\Emr\Enum\InstanceStateChangeReasonCode' => __DIR__ . '/Aws/Emr/Enum/InstanceStateChangeReasonCode.php', + 'Aws\Emr\Enum\JobFlowExecutionState' => __DIR__ . '/Aws/Emr/Enum/JobFlowExecutionState.php', + 'Aws\Emr\Enum\MarketType' => __DIR__ . '/Aws/Emr/Enum/MarketType.php', + 'Aws\Emr\Enum\StepExecutionState' => __DIR__ . '/Aws/Emr/Enum/StepExecutionState.php', + 'Aws\Emr\Enum\StepState' => __DIR__ . '/Aws/Emr/Enum/StepState.php', + 'Aws\Emr\Enum\StepStateChangeReasonCode' => __DIR__ . '/Aws/Emr/Enum/StepStateChangeReasonCode.php', + 'Aws\Emr\Exception\EmrException' => __DIR__ . '/Aws/Emr/Exception/EmrException.php', + 'Aws\Emr\Exception\InternalServerErrorException' => __DIR__ . '/Aws/Emr/Exception/InternalServerErrorException.php', + 'Aws\Emr\Exception\InternalServerException' => __DIR__ . '/Aws/Emr/Exception/InternalServerException.php', + 'Aws\Emr\Exception\InvalidRequestException' => __DIR__ . '/Aws/Emr/Exception/InvalidRequestException.php', + 'Aws\Emr\Resources\emr-2009-03-31' => __DIR__ . '/Aws/Emr/Resources/emr-2009-03-31.php', + 'Aws\Glacier\Enum\Action' => __DIR__ . '/Aws/Glacier/Enum/Action.php', + 'Aws\Glacier\Enum\ActionCode' => __DIR__ . '/Aws/Glacier/Enum/ActionCode.php', + 'Aws\Glacier\Enum\StatusCode' => __DIR__ . '/Aws/Glacier/Enum/StatusCode.php', + 'Aws\Glacier\Exception\GlacierException' => __DIR__ . '/Aws/Glacier/Exception/GlacierException.php', + 'Aws\Glacier\Exception\InvalidParameterValueException' => __DIR__ . '/Aws/Glacier/Exception/InvalidParameterValueException.php', + 'Aws\Glacier\Exception\LimitExceededException' => __DIR__ . '/Aws/Glacier/Exception/LimitExceededException.php', + 'Aws\Glacier\Exception\MissingParameterValueException' => __DIR__ . '/Aws/Glacier/Exception/MissingParameterValueException.php', + 'Aws\Glacier\Exception\RequestTimeoutException' => __DIR__ . '/Aws/Glacier/Exception/RequestTimeoutException.php', + 'Aws\Glacier\Exception\ResourceNotFoundException' => __DIR__ . '/Aws/Glacier/Exception/ResourceNotFoundException.php', + 'Aws\Glacier\Exception\ServiceUnavailableException' => __DIR__ . '/Aws/Glacier/Exception/ServiceUnavailableException.php', + 'Aws\Glacier\GlacierClient' => __DIR__ . '/Aws/Glacier/GlacierClient.php', + 'Aws\Glacier\GlacierUploadListener' => __DIR__ . '/Aws/Glacier/GlacierUploadListener.php', + 'Aws\Glacier\Model\MultipartUpload\AbstractTransfer' => __DIR__ . '/Aws/Glacier/Model/MultipartUpload/AbstractTransfer.php', + 'Aws\Glacier\Model\MultipartUpload\ParallelTransfer' => __DIR__ . '/Aws/Glacier/Model/MultipartUpload/ParallelTransfer.php', + 'Aws\Glacier\Model\MultipartUpload\SerialTransfer' => __DIR__ . '/Aws/Glacier/Model/MultipartUpload/SerialTransfer.php', + 'Aws\Glacier\Model\MultipartUpload\TransferState' => __DIR__ . '/Aws/Glacier/Model/MultipartUpload/TransferState.php', + 'Aws\Glacier\Model\MultipartUpload\UploadBuilder' => __DIR__ . '/Aws/Glacier/Model/MultipartUpload/UploadBuilder.php', + 'Aws\Glacier\Model\MultipartUpload\UploadId' => __DIR__ . '/Aws/Glacier/Model/MultipartUpload/UploadId.php', + 'Aws\Glacier\Model\MultipartUpload\UploadPart' => __DIR__ . '/Aws/Glacier/Model/MultipartUpload/UploadPart.php', + 'Aws\Glacier\Model\MultipartUpload\UploadPartContext' => __DIR__ . '/Aws/Glacier/Model/MultipartUpload/UploadPartContext.php', + 'Aws\Glacier\Model\MultipartUpload\UploadPartGenerator' => __DIR__ . '/Aws/Glacier/Model/MultipartUpload/UploadPartGenerator.php', + 'Aws\Glacier\Resources\glacier-2012-06-01' => __DIR__ . '/Aws/Glacier/Resources/glacier-2012-06-01.php', + 'Aws\Iam\Enum\AssignmentStatusType' => __DIR__ . '/Aws/Iam/Enum/AssignmentStatusType.php', + 'Aws\Iam\Enum\StatusType' => __DIR__ . '/Aws/Iam/Enum/StatusType.php', + 'Aws\Iam\Exception\DeleteConflictException' => __DIR__ . '/Aws/Iam/Exception/DeleteConflictException.php', + 'Aws\Iam\Exception\DuplicateCertificateException' => __DIR__ . '/Aws/Iam/Exception/DuplicateCertificateException.php', + 'Aws\Iam\Exception\EntityAlreadyExistsException' => __DIR__ . '/Aws/Iam/Exception/EntityAlreadyExistsException.php', + 'Aws\Iam\Exception\EntityTemporarilyUnmodifiableException' => __DIR__ . '/Aws/Iam/Exception/EntityTemporarilyUnmodifiableException.php', + 'Aws\Iam\Exception\IamException' => __DIR__ . '/Aws/Iam/Exception/IamException.php', + 'Aws\Iam\Exception\InvalidAuthenticationCodeException' => __DIR__ . '/Aws/Iam/Exception/InvalidAuthenticationCodeException.php', + 'Aws\Iam\Exception\InvalidCertificateException' => __DIR__ . '/Aws/Iam/Exception/InvalidCertificateException.php', + 'Aws\Iam\Exception\InvalidInputException' => __DIR__ . '/Aws/Iam/Exception/InvalidInputException.php', + 'Aws\Iam\Exception\InvalidUserTypeException' => __DIR__ . '/Aws/Iam/Exception/InvalidUserTypeException.php', + 'Aws\Iam\Exception\KeyPairMismatchException' => __DIR__ . '/Aws/Iam/Exception/KeyPairMismatchException.php', + 'Aws\Iam\Exception\LimitExceededException' => __DIR__ . '/Aws/Iam/Exception/LimitExceededException.php', + 'Aws\Iam\Exception\MalformedCertificateException' => __DIR__ . '/Aws/Iam/Exception/MalformedCertificateException.php', + 'Aws\Iam\Exception\MalformedPolicyDocumentException' => __DIR__ . '/Aws/Iam/Exception/MalformedPolicyDocumentException.php', + 'Aws\Iam\Exception\NoSuchEntityException' => __DIR__ . '/Aws/Iam/Exception/NoSuchEntityException.php', + 'Aws\Iam\Exception\PasswordPolicyViolationException' => __DIR__ . '/Aws/Iam/Exception/PasswordPolicyViolationException.php', + 'Aws\Iam\IamClient' => __DIR__ . '/Aws/Iam/IamClient.php', + 'Aws\Iam\Resources\iam-2010-05-08' => __DIR__ . '/Aws/Iam/Resources/iam-2010-05-08.php', + 'Aws\ImportExport\Enum\JobType' => __DIR__ . '/Aws/ImportExport/Enum/JobType.php', + 'Aws\ImportExport\Exception\BucketPermissionException' => __DIR__ . '/Aws/ImportExport/Exception/BucketPermissionException.php', + 'Aws\ImportExport\Exception\CanceledJobIdException' => __DIR__ . '/Aws/ImportExport/Exception/CanceledJobIdException.php', + 'Aws\ImportExport\Exception\ExpiredJobIdException' => __DIR__ . '/Aws/ImportExport/Exception/ExpiredJobIdException.php', + 'Aws\ImportExport\Exception\ImportExportException' => __DIR__ . '/Aws/ImportExport/Exception/ImportExportException.php', + 'Aws\ImportExport\Exception\InvalidAccessKeyIdException' => __DIR__ . '/Aws/ImportExport/Exception/InvalidAccessKeyIdException.php', + 'Aws\ImportExport\Exception\InvalidAddressException' => __DIR__ . '/Aws/ImportExport/Exception/InvalidAddressException.php', + 'Aws\ImportExport\Exception\InvalidCustomsException' => __DIR__ . '/Aws/ImportExport/Exception/InvalidCustomsException.php', + 'Aws\ImportExport\Exception\InvalidFileSystemException' => __DIR__ . '/Aws/ImportExport/Exception/InvalidFileSystemException.php', + 'Aws\ImportExport\Exception\InvalidJobIdException' => __DIR__ . '/Aws/ImportExport/Exception/InvalidJobIdException.php', + 'Aws\ImportExport\Exception\InvalidManifestFieldException' => __DIR__ . '/Aws/ImportExport/Exception/InvalidManifestFieldException.php', + 'Aws\ImportExport\Exception\InvalidParameterException' => __DIR__ . '/Aws/ImportExport/Exception/InvalidParameterException.php', + 'Aws\ImportExport\Exception\MalformedManifestException' => __DIR__ . '/Aws/ImportExport/Exception/MalformedManifestException.php', + 'Aws\ImportExport\Exception\MissingCustomsException' => __DIR__ . '/Aws/ImportExport/Exception/MissingCustomsException.php', + 'Aws\ImportExport\Exception\MissingManifestFieldException' => __DIR__ . '/Aws/ImportExport/Exception/MissingManifestFieldException.php', + 'Aws\ImportExport\Exception\MissingParameterException' => __DIR__ . '/Aws/ImportExport/Exception/MissingParameterException.php', + 'Aws\ImportExport\Exception\MultipleRegionsException' => __DIR__ . '/Aws/ImportExport/Exception/MultipleRegionsException.php', + 'Aws\ImportExport\Exception\NoSuchBucketException' => __DIR__ . '/Aws/ImportExport/Exception/NoSuchBucketException.php', + 'Aws\ImportExport\Exception\UnableToCancelJobIdException' => __DIR__ . '/Aws/ImportExport/Exception/UnableToCancelJobIdException.php', + 'Aws\ImportExport\ImportExportClient' => __DIR__ . '/Aws/ImportExport/ImportExportClient.php', + 'Aws\ImportExport\JobManifestListener' => __DIR__ . '/Aws/ImportExport/JobManifestListener.php', + 'Aws\ImportExport\Resources\importexport-2010-06-01' => __DIR__ . '/Aws/ImportExport/Resources/importexport-2010-06-01.php', + 'Aws\Kinesis\Enum\ShardIteratorType' => __DIR__ . '/Aws/Kinesis/Enum/ShardIteratorType.php', + 'Aws\Kinesis\Enum\StreamStatus' => __DIR__ . '/Aws/Kinesis/Enum/StreamStatus.php', + 'Aws\Kinesis\Exception\ExpiredIteratorException' => __DIR__ . '/Aws/Kinesis/Exception/ExpiredIteratorException.php', + 'Aws\Kinesis\Exception\InvalidArgumentException' => __DIR__ . '/Aws/Kinesis/Exception/InvalidArgumentException.php', + 'Aws\Kinesis\Exception\KinesisException' => __DIR__ . '/Aws/Kinesis/Exception/KinesisException.php', + 'Aws\Kinesis\Exception\LimitExceededException' => __DIR__ . '/Aws/Kinesis/Exception/LimitExceededException.php', + 'Aws\Kinesis\Exception\ProvisionedThroughputExceededException' => __DIR__ . '/Aws/Kinesis/Exception/ProvisionedThroughputExceededException.php', + 'Aws\Kinesis\Exception\ResourceInUseException' => __DIR__ . '/Aws/Kinesis/Exception/ResourceInUseException.php', + 'Aws\Kinesis\Exception\ResourceNotFoundException' => __DIR__ . '/Aws/Kinesis/Exception/ResourceNotFoundException.php', + 'Aws\Kinesis\KinesisClient' => __DIR__ . '/Aws/Kinesis/KinesisClient.php', + 'Aws\Kinesis\Resources\kinesis-2013-12-02' => __DIR__ . '/Aws/Kinesis/Resources/kinesis-2013-12-02.php', + 'Aws\Kms\Exception\KmsException' => __DIR__ . '/Aws/Kms/Exception/KmsException.php', + 'Aws\Kms\KmsClient' => __DIR__ . '/Aws/Kms/KmsClient.php', + 'Aws\Kms\Resources\kms-2014-11-01' => __DIR__ . '/Aws/Kms/Resources/kms-2014-11-01.php', + 'Aws\Lambda\Exception\LambdaException' => __DIR__ . '/Aws/Lambda/Exception/LambdaException.php', + 'Aws\Lambda\LambdaClient' => __DIR__ . '/Aws/Lambda/LambdaClient.php', + 'Aws\Lambda\Resources\lambda-2014-11-11' => __DIR__ . '/Aws/Lambda/Resources/lambda-2014-11-11.php', + 'Aws\Lambda\Resources\lambda-2015-03-31' => __DIR__ . '/Aws/Lambda/Resources/lambda-2015-03-31.php', + 'Aws\MachineLearning\Exception\MachineLearningException' => __DIR__ . '/Aws/MachineLearning/Exception/MachineLearningException.php', + 'Aws\MachineLearning\MachineLearningClient' => __DIR__ . '/Aws/MachineLearning/MachineLearningClient.php', + 'Aws\MachineLearning\PredictEndpointListener' => __DIR__ . '/Aws/MachineLearning/PredictEndpointListener.php', + 'Aws\MachineLearning\Resources\machinelearning-2014-12-12' => __DIR__ . '/Aws/MachineLearning/Resources/machinelearning-2014-12-12.php', + 'Aws\OpsWorks\Enum\AppType' => __DIR__ . '/Aws/OpsWorks/Enum/AppType.php', + 'Aws\OpsWorks\Enum\Architecture' => __DIR__ . '/Aws/OpsWorks/Enum/Architecture.php', + 'Aws\OpsWorks\Enum\AutoScalingType' => __DIR__ . '/Aws/OpsWorks/Enum/AutoScalingType.php', + 'Aws\OpsWorks\Enum\DeploymentCommandName' => __DIR__ . '/Aws/OpsWorks/Enum/DeploymentCommandName.php', + 'Aws\OpsWorks\Enum\LayerType' => __DIR__ . '/Aws/OpsWorks/Enum/LayerType.php', + 'Aws\OpsWorks\Enum\PermissionLevel' => __DIR__ . '/Aws/OpsWorks/Enum/PermissionLevel.php', + 'Aws\OpsWorks\Enum\RootDeviceType' => __DIR__ . '/Aws/OpsWorks/Enum/RootDeviceType.php', + 'Aws\OpsWorks\Enum\SourceType' => __DIR__ . '/Aws/OpsWorks/Enum/SourceType.php', + 'Aws\OpsWorks\Exception\OpsWorksException' => __DIR__ . '/Aws/OpsWorks/Exception/OpsWorksException.php', + 'Aws\OpsWorks\Exception\ResourceNotFoundException' => __DIR__ . '/Aws/OpsWorks/Exception/ResourceNotFoundException.php', + 'Aws\OpsWorks\Exception\ValidationException' => __DIR__ . '/Aws/OpsWorks/Exception/ValidationException.php', + 'Aws\OpsWorks\OpsWorksClient' => __DIR__ . '/Aws/OpsWorks/OpsWorksClient.php', + 'Aws\OpsWorks\Resources\opsworks-2013-02-18' => __DIR__ . '/Aws/OpsWorks/Resources/opsworks-2013-02-18.php', + 'Aws\Rds\Enum\ApplyMethod' => __DIR__ . '/Aws/Rds/Enum/ApplyMethod.php', + 'Aws\Rds\Enum\SourceType' => __DIR__ . '/Aws/Rds/Enum/SourceType.php', + 'Aws\Rds\Exception\AuthorizationAlreadyExistsException' => __DIR__ . '/Aws/Rds/Exception/AuthorizationAlreadyExistsException.php', + 'Aws\Rds\Exception\AuthorizationNotFoundException' => __DIR__ . '/Aws/Rds/Exception/AuthorizationNotFoundException.php', + 'Aws\Rds\Exception\AuthorizationQuotaExceededException' => __DIR__ . '/Aws/Rds/Exception/AuthorizationQuotaExceededException.php', + 'Aws\Rds\Exception\DBInstanceAlreadyExistsException' => __DIR__ . '/Aws/Rds/Exception/DBInstanceAlreadyExistsException.php', + 'Aws\Rds\Exception\DBInstanceNotFoundException' => __DIR__ . '/Aws/Rds/Exception/DBInstanceNotFoundException.php', + 'Aws\Rds\Exception\DBParameterGroupAlreadyExistsException' => __DIR__ . '/Aws/Rds/Exception/DBParameterGroupAlreadyExistsException.php', + 'Aws\Rds\Exception\DBParameterGroupNotFoundException' => __DIR__ . '/Aws/Rds/Exception/DBParameterGroupNotFoundException.php', + 'Aws\Rds\Exception\DBParameterGroupQuotaExceededException' => __DIR__ . '/Aws/Rds/Exception/DBParameterGroupQuotaExceededException.php', + 'Aws\Rds\Exception\DBSecurityGroupAlreadyExistsException' => __DIR__ . '/Aws/Rds/Exception/DBSecurityGroupAlreadyExistsException.php', + 'Aws\Rds\Exception\DBSecurityGroupNotFoundException' => __DIR__ . '/Aws/Rds/Exception/DBSecurityGroupNotFoundException.php', + 'Aws\Rds\Exception\DBSecurityGroupNotSupportedException' => __DIR__ . '/Aws/Rds/Exception/DBSecurityGroupNotSupportedException.php', + 'Aws\Rds\Exception\DBSecurityGroupQuotaExceededException' => __DIR__ . '/Aws/Rds/Exception/DBSecurityGroupQuotaExceededException.php', + 'Aws\Rds\Exception\DBSnapshotAlreadyExistsException' => __DIR__ . '/Aws/Rds/Exception/DBSnapshotAlreadyExistsException.php', + 'Aws\Rds\Exception\DBSnapshotNotFoundException' => __DIR__ . '/Aws/Rds/Exception/DBSnapshotNotFoundException.php', + 'Aws\Rds\Exception\DBSubnetGroupAlreadyExistsException' => __DIR__ . '/Aws/Rds/Exception/DBSubnetGroupAlreadyExistsException.php', + 'Aws\Rds\Exception\DBSubnetGroupDoesNotCoverEnoughAZsException' => __DIR__ . '/Aws/Rds/Exception/DBSubnetGroupDoesNotCoverEnoughAZsException.php', + 'Aws\Rds\Exception\DBSubnetGroupNotAllowedException' => __DIR__ . '/Aws/Rds/Exception/DBSubnetGroupNotAllowedException.php', + 'Aws\Rds\Exception\DBSubnetGroupNotFoundException' => __DIR__ . '/Aws/Rds/Exception/DBSubnetGroupNotFoundException.php', + 'Aws\Rds\Exception\DBSubnetGroupQuotaExceededException' => __DIR__ . '/Aws/Rds/Exception/DBSubnetGroupQuotaExceededException.php', + 'Aws\Rds\Exception\DBSubnetQuotaExceededException' => __DIR__ . '/Aws/Rds/Exception/DBSubnetQuotaExceededException.php', + 'Aws\Rds\Exception\DBUpgradeDependencyFailureException' => __DIR__ . '/Aws/Rds/Exception/DBUpgradeDependencyFailureException.php', + 'Aws\Rds\Exception\EventSubscriptionQuotaExceededException' => __DIR__ . '/Aws/Rds/Exception/EventSubscriptionQuotaExceededException.php', + 'Aws\Rds\Exception\InstanceQuotaExceededException' => __DIR__ . '/Aws/Rds/Exception/InstanceQuotaExceededException.php', + 'Aws\Rds\Exception\InsufficientDBInstanceCapacityException' => __DIR__ . '/Aws/Rds/Exception/InsufficientDBInstanceCapacityException.php', + 'Aws\Rds\Exception\InvalidDBInstanceStateException' => __DIR__ . '/Aws/Rds/Exception/InvalidDBInstanceStateException.php', + 'Aws\Rds\Exception\InvalidDBParameterGroupStateException' => __DIR__ . '/Aws/Rds/Exception/InvalidDBParameterGroupStateException.php', + 'Aws\Rds\Exception\InvalidDBSecurityGroupStateException' => __DIR__ . '/Aws/Rds/Exception/InvalidDBSecurityGroupStateException.php', + 'Aws\Rds\Exception\InvalidDBSnapshotStateException' => __DIR__ . '/Aws/Rds/Exception/InvalidDBSnapshotStateException.php', + 'Aws\Rds\Exception\InvalidDBSubnetGroupException' => __DIR__ . '/Aws/Rds/Exception/InvalidDBSubnetGroupException.php', + 'Aws\Rds\Exception\InvalidDBSubnetGroupStateException' => __DIR__ . '/Aws/Rds/Exception/InvalidDBSubnetGroupStateException.php', + 'Aws\Rds\Exception\InvalidDBSubnetStateException' => __DIR__ . '/Aws/Rds/Exception/InvalidDBSubnetStateException.php', + 'Aws\Rds\Exception\InvalidEventSubscriptionStateException' => __DIR__ . '/Aws/Rds/Exception/InvalidEventSubscriptionStateException.php', + 'Aws\Rds\Exception\InvalidOptionGroupStateException' => __DIR__ . '/Aws/Rds/Exception/InvalidOptionGroupStateException.php', + 'Aws\Rds\Exception\InvalidRestoreException' => __DIR__ . '/Aws/Rds/Exception/InvalidRestoreException.php', + 'Aws\Rds\Exception\InvalidSubnetException' => __DIR__ . '/Aws/Rds/Exception/InvalidSubnetException.php', + 'Aws\Rds\Exception\InvalidVPCNetworkStateException' => __DIR__ . '/Aws/Rds/Exception/InvalidVPCNetworkStateException.php', + 'Aws\Rds\Exception\OptionGroupAlreadyExistsException' => __DIR__ . '/Aws/Rds/Exception/OptionGroupAlreadyExistsException.php', + 'Aws\Rds\Exception\OptionGroupNotFoundException' => __DIR__ . '/Aws/Rds/Exception/OptionGroupNotFoundException.php', + 'Aws\Rds\Exception\OptionGroupQuotaExceededException' => __DIR__ . '/Aws/Rds/Exception/OptionGroupQuotaExceededException.php', + 'Aws\Rds\Exception\PointInTimeRestoreNotEnabledException' => __DIR__ . '/Aws/Rds/Exception/PointInTimeRestoreNotEnabledException.php', + 'Aws\Rds\Exception\ProvisionedIopsNotAvailableInAZException' => __DIR__ . '/Aws/Rds/Exception/ProvisionedIopsNotAvailableInAZException.php', + 'Aws\Rds\Exception\RdsException' => __DIR__ . '/Aws/Rds/Exception/RdsException.php', + 'Aws\Rds\Exception\ReservedDBInstanceAlreadyExistsException' => __DIR__ . '/Aws/Rds/Exception/ReservedDBInstanceAlreadyExistsException.php', + 'Aws\Rds\Exception\ReservedDBInstanceNotFoundException' => __DIR__ . '/Aws/Rds/Exception/ReservedDBInstanceNotFoundException.php', + 'Aws\Rds\Exception\ReservedDBInstanceQuotaExceededException' => __DIR__ . '/Aws/Rds/Exception/ReservedDBInstanceQuotaExceededException.php', + 'Aws\Rds\Exception\ReservedDBInstancesOfferingNotFoundException' => __DIR__ . '/Aws/Rds/Exception/ReservedDBInstancesOfferingNotFoundException.php', + 'Aws\Rds\Exception\SnapshotQuotaExceededException' => __DIR__ . '/Aws/Rds/Exception/SnapshotQuotaExceededException.php', + 'Aws\Rds\Exception\SNSInvalidTopicException' => __DIR__ . '/Aws/Rds/Exception/SNSInvalidTopicException.php', + 'Aws\Rds\Exception\SNSNoAuthorizationException' => __DIR__ . '/Aws/Rds/Exception/SNSNoAuthorizationException.php', + 'Aws\Rds\Exception\SNSTopicArnNotFoundException' => __DIR__ . '/Aws/Rds/Exception/SNSTopicArnNotFoundException.php', + 'Aws\Rds\Exception\SourceNotFoundException' => __DIR__ . '/Aws/Rds/Exception/SourceNotFoundException.php', + 'Aws\Rds\Exception\StorageQuotaExceededException' => __DIR__ . '/Aws/Rds/Exception/StorageQuotaExceededException.php', + 'Aws\Rds\Exception\SubnetAlreadyInUseException' => __DIR__ . '/Aws/Rds/Exception/SubnetAlreadyInUseException.php', + 'Aws\Rds\Exception\SubscriptionAlreadyExistException' => __DIR__ . '/Aws/Rds/Exception/SubscriptionAlreadyExistException.php', + 'Aws\Rds\Exception\SubscriptionCategoryNotFoundException' => __DIR__ . '/Aws/Rds/Exception/SubscriptionCategoryNotFoundException.php', + 'Aws\Rds\Exception\SubscriptionNotFoundException' => __DIR__ . '/Aws/Rds/Exception/SubscriptionNotFoundException.php', + 'Aws\Rds\RdsClient' => __DIR__ . '/Aws/Rds/RdsClient.php', + 'Aws\Rds\Resources\rds-2014-10-31' => __DIR__ . '/Aws/Rds/Resources/rds-2014-10-31.php', + 'Aws\Redshift\Enum\SourceType' => __DIR__ . '/Aws/Redshift/Enum/SourceType.php', + 'Aws\Redshift\Exception\AccessToSnapshotDeniedException' => __DIR__ . '/Aws/Redshift/Exception/AccessToSnapshotDeniedException.php', + 'Aws\Redshift\Exception\AuthorizationAlreadyExistsException' => __DIR__ . '/Aws/Redshift/Exception/AuthorizationAlreadyExistsException.php', + 'Aws\Redshift\Exception\AuthorizationNotFoundException' => __DIR__ . '/Aws/Redshift/Exception/AuthorizationNotFoundException.php', + 'Aws\Redshift\Exception\AuthorizationQuotaExceededException' => __DIR__ . '/Aws/Redshift/Exception/AuthorizationQuotaExceededException.php', + 'Aws\Redshift\Exception\BucketNotFoundException' => __DIR__ . '/Aws/Redshift/Exception/BucketNotFoundException.php', + 'Aws\Redshift\Exception\ClusterAlreadyExistsException' => __DIR__ . '/Aws/Redshift/Exception/ClusterAlreadyExistsException.php', + 'Aws\Redshift\Exception\ClusterNotFoundException' => __DIR__ . '/Aws/Redshift/Exception/ClusterNotFoundException.php', + 'Aws\Redshift\Exception\ClusterParameterGroupAlreadyExistsException' => __DIR__ . '/Aws/Redshift/Exception/ClusterParameterGroupAlreadyExistsException.php', + 'Aws\Redshift\Exception\ClusterParameterGroupNotFoundException' => __DIR__ . '/Aws/Redshift/Exception/ClusterParameterGroupNotFoundException.php', + 'Aws\Redshift\Exception\ClusterParameterGroupQuotaExceededException' => __DIR__ . '/Aws/Redshift/Exception/ClusterParameterGroupQuotaExceededException.php', + 'Aws\Redshift\Exception\ClusterQuotaExceededException' => __DIR__ . '/Aws/Redshift/Exception/ClusterQuotaExceededException.php', + 'Aws\Redshift\Exception\ClusterSecurityGroupAlreadyExistsException' => __DIR__ . '/Aws/Redshift/Exception/ClusterSecurityGroupAlreadyExistsException.php', + 'Aws\Redshift\Exception\ClusterSecurityGroupNotFoundException' => __DIR__ . '/Aws/Redshift/Exception/ClusterSecurityGroupNotFoundException.php', + 'Aws\Redshift\Exception\ClusterSecurityGroupQuotaExceededException' => __DIR__ . '/Aws/Redshift/Exception/ClusterSecurityGroupQuotaExceededException.php', + 'Aws\Redshift\Exception\ClusterSnapshotAlreadyExistsException' => __DIR__ . '/Aws/Redshift/Exception/ClusterSnapshotAlreadyExistsException.php', + 'Aws\Redshift\Exception\ClusterSnapshotNotFoundException' => __DIR__ . '/Aws/Redshift/Exception/ClusterSnapshotNotFoundException.php', + 'Aws\Redshift\Exception\ClusterSnapshotQuotaExceededException' => __DIR__ . '/Aws/Redshift/Exception/ClusterSnapshotQuotaExceededException.php', + 'Aws\Redshift\Exception\ClusterSubnetGroupAlreadyExistsException' => __DIR__ . '/Aws/Redshift/Exception/ClusterSubnetGroupAlreadyExistsException.php', + 'Aws\Redshift\Exception\ClusterSubnetGroupNotFoundException' => __DIR__ . '/Aws/Redshift/Exception/ClusterSubnetGroupNotFoundException.php', + 'Aws\Redshift\Exception\ClusterSubnetGroupQuotaExceededException' => __DIR__ . '/Aws/Redshift/Exception/ClusterSubnetGroupQuotaExceededException.php', + 'Aws\Redshift\Exception\ClusterSubnetQuotaExceededException' => __DIR__ . '/Aws/Redshift/Exception/ClusterSubnetQuotaExceededException.php', + 'Aws\Redshift\Exception\CopyToRegionDisabledException' => __DIR__ . '/Aws/Redshift/Exception/CopyToRegionDisabledException.php', + 'Aws\Redshift\Exception\EventSubscriptionQuotaExceededException' => __DIR__ . '/Aws/Redshift/Exception/EventSubscriptionQuotaExceededException.php', + 'Aws\Redshift\Exception\HsmClientCertificateAlreadyExistsException' => __DIR__ . '/Aws/Redshift/Exception/HsmClientCertificateAlreadyExistsException.php', + 'Aws\Redshift\Exception\HsmClientCertificateNotFoundException' => __DIR__ . '/Aws/Redshift/Exception/HsmClientCertificateNotFoundException.php', + 'Aws\Redshift\Exception\HsmClientCertificateQuotaExceededException' => __DIR__ . '/Aws/Redshift/Exception/HsmClientCertificateQuotaExceededException.php', + 'Aws\Redshift\Exception\HsmConfigurationAlreadyExistsException' => __DIR__ . '/Aws/Redshift/Exception/HsmConfigurationAlreadyExistsException.php', + 'Aws\Redshift\Exception\HsmConfigurationNotFoundException' => __DIR__ . '/Aws/Redshift/Exception/HsmConfigurationNotFoundException.php', + 'Aws\Redshift\Exception\HsmConfigurationQuotaExceededException' => __DIR__ . '/Aws/Redshift/Exception/HsmConfigurationQuotaExceededException.php', + 'Aws\Redshift\Exception\IncompatibleOrderableOptionsException' => __DIR__ . '/Aws/Redshift/Exception/IncompatibleOrderableOptionsException.php', + 'Aws\Redshift\Exception\InsufficientClusterCapacityException' => __DIR__ . '/Aws/Redshift/Exception/InsufficientClusterCapacityException.php', + 'Aws\Redshift\Exception\InsufficientS3BucketPolicyFaultException' => __DIR__ . '/Aws/Redshift/Exception/InsufficientS3BucketPolicyFaultException.php', + 'Aws\Redshift\Exception\InvalidClusterParameterGroupStateException' => __DIR__ . '/Aws/Redshift/Exception/InvalidClusterParameterGroupStateException.php', + 'Aws\Redshift\Exception\InvalidClusterSecurityGroupStateException' => __DIR__ . '/Aws/Redshift/Exception/InvalidClusterSecurityGroupStateException.php', + 'Aws\Redshift\Exception\InvalidClusterSnapshotStateException' => __DIR__ . '/Aws/Redshift/Exception/InvalidClusterSnapshotStateException.php', + 'Aws\Redshift\Exception\InvalidClusterStateException' => __DIR__ . '/Aws/Redshift/Exception/InvalidClusterStateException.php', + 'Aws\Redshift\Exception\InvalidClusterSubnetGroupStateException' => __DIR__ . '/Aws/Redshift/Exception/InvalidClusterSubnetGroupStateException.php', + 'Aws\Redshift\Exception\InvalidClusterSubnetStateException' => __DIR__ . '/Aws/Redshift/Exception/InvalidClusterSubnetStateException.php', + 'Aws\Redshift\Exception\InvalidElasticIpException' => __DIR__ . '/Aws/Redshift/Exception/InvalidElasticIpException.php', + 'Aws\Redshift\Exception\InvalidHsmClientCertificateStateException' => __DIR__ . '/Aws/Redshift/Exception/InvalidHsmClientCertificateStateException.php', + 'Aws\Redshift\Exception\InvalidHsmConfigurationStateException' => __DIR__ . '/Aws/Redshift/Exception/InvalidHsmConfigurationStateException.php', + 'Aws\Redshift\Exception\InvalidRestoreException' => __DIR__ . '/Aws/Redshift/Exception/InvalidRestoreException.php', + 'Aws\Redshift\Exception\InvalidS3BucketNameFaultException' => __DIR__ . '/Aws/Redshift/Exception/InvalidS3BucketNameFaultException.php', + 'Aws\Redshift\Exception\InvalidS3KeyPrefixFaultException' => __DIR__ . '/Aws/Redshift/Exception/InvalidS3KeyPrefixFaultException.php', + 'Aws\Redshift\Exception\InvalidSubnetException' => __DIR__ . '/Aws/Redshift/Exception/InvalidSubnetException.php', + 'Aws\Redshift\Exception\InvalidVPCNetworkStateException' => __DIR__ . '/Aws/Redshift/Exception/InvalidVPCNetworkStateException.php', + 'Aws\Redshift\Exception\NumberOfNodesPerClusterLimitExceededException' => __DIR__ . '/Aws/Redshift/Exception/NumberOfNodesPerClusterLimitExceededException.php', + 'Aws\Redshift\Exception\NumberOfNodesQuotaExceededException' => __DIR__ . '/Aws/Redshift/Exception/NumberOfNodesQuotaExceededException.php', + 'Aws\Redshift\Exception\RedshiftException' => __DIR__ . '/Aws/Redshift/Exception/RedshiftException.php', + 'Aws\Redshift\Exception\ReservedNodeAlreadyExistsException' => __DIR__ . '/Aws/Redshift/Exception/ReservedNodeAlreadyExistsException.php', + 'Aws\Redshift\Exception\ReservedNodeNotFoundException' => __DIR__ . '/Aws/Redshift/Exception/ReservedNodeNotFoundException.php', + 'Aws\Redshift\Exception\ReservedNodeOfferingNotFoundException' => __DIR__ . '/Aws/Redshift/Exception/ReservedNodeOfferingNotFoundException.php', + 'Aws\Redshift\Exception\ReservedNodeQuotaExceededException' => __DIR__ . '/Aws/Redshift/Exception/ReservedNodeQuotaExceededException.php', + 'Aws\Redshift\Exception\ResizeNotFoundException' => __DIR__ . '/Aws/Redshift/Exception/ResizeNotFoundException.php', + 'Aws\Redshift\Exception\SnapshotCopyAlreadyDisabledException' => __DIR__ . '/Aws/Redshift/Exception/SnapshotCopyAlreadyDisabledException.php', + 'Aws\Redshift\Exception\SnapshotCopyAlreadyEnabledException' => __DIR__ . '/Aws/Redshift/Exception/SnapshotCopyAlreadyEnabledException.php', + 'Aws\Redshift\Exception\SnapshotCopyDisabledException' => __DIR__ . '/Aws/Redshift/Exception/SnapshotCopyDisabledException.php', + 'Aws\Redshift\Exception\SNSInvalidTopicException' => __DIR__ . '/Aws/Redshift/Exception/SNSInvalidTopicException.php', + 'Aws\Redshift\Exception\SNSNoAuthorizationException' => __DIR__ . '/Aws/Redshift/Exception/SNSNoAuthorizationException.php', + 'Aws\Redshift\Exception\SNSTopicArnNotFoundException' => __DIR__ . '/Aws/Redshift/Exception/SNSTopicArnNotFoundException.php', + 'Aws\Redshift\Exception\SourceNotFoundException' => __DIR__ . '/Aws/Redshift/Exception/SourceNotFoundException.php', + 'Aws\Redshift\Exception\SubnetAlreadyInUseException' => __DIR__ . '/Aws/Redshift/Exception/SubnetAlreadyInUseException.php', + 'Aws\Redshift\Exception\SubscriptionAlreadyExistException' => __DIR__ . '/Aws/Redshift/Exception/SubscriptionAlreadyExistException.php', + 'Aws\Redshift\Exception\SubscriptionCategoryNotFoundException' => __DIR__ . '/Aws/Redshift/Exception/SubscriptionCategoryNotFoundException.php', + 'Aws\Redshift\Exception\SubscriptionEventIdNotFoundException' => __DIR__ . '/Aws/Redshift/Exception/SubscriptionEventIdNotFoundException.php', + 'Aws\Redshift\Exception\SubscriptionNotFoundException' => __DIR__ . '/Aws/Redshift/Exception/SubscriptionNotFoundException.php', + 'Aws\Redshift\Exception\SubscriptionSeverityNotFoundException' => __DIR__ . '/Aws/Redshift/Exception/SubscriptionSeverityNotFoundException.php', + 'Aws\Redshift\Exception\UnauthorizedOperationException' => __DIR__ . '/Aws/Redshift/Exception/UnauthorizedOperationException.php', + 'Aws\Redshift\Exception\UnknownSnapshotCopyRegionException' => __DIR__ . '/Aws/Redshift/Exception/UnknownSnapshotCopyRegionException.php', + 'Aws\Redshift\Exception\UnsupportedOptionException' => __DIR__ . '/Aws/Redshift/Exception/UnsupportedOptionException.php', + 'Aws\Redshift\RedshiftClient' => __DIR__ . '/Aws/Redshift/RedshiftClient.php', + 'Aws\Redshift\Resources\redshift-2012-12-01' => __DIR__ . '/Aws/Redshift/Resources/redshift-2012-12-01.php', + 'Aws\Route53\Enum\Action' => __DIR__ . '/Aws/Route53/Enum/Action.php', + 'Aws\Route53\Enum\HealthCheckType' => __DIR__ . '/Aws/Route53/Enum/HealthCheckType.php', + 'Aws\Route53\Enum\RecordType' => __DIR__ . '/Aws/Route53/Enum/RecordType.php', + 'Aws\Route53\Enum\ResourceRecordSetFailover' => __DIR__ . '/Aws/Route53/Enum/ResourceRecordSetFailover.php', + 'Aws\Route53\Enum\Status' => __DIR__ . '/Aws/Route53/Enum/Status.php', + 'Aws\Route53\Exception\DelegationSetNotAvailableException' => __DIR__ . '/Aws/Route53/Exception/DelegationSetNotAvailableException.php', + 'Aws\Route53\Exception\HealthCheckAlreadyExistsException' => __DIR__ . '/Aws/Route53/Exception/HealthCheckAlreadyExistsException.php', + 'Aws\Route53\Exception\HealthCheckInUseException' => __DIR__ . '/Aws/Route53/Exception/HealthCheckInUseException.php', + 'Aws\Route53\Exception\HostedZoneAlreadyExistsException' => __DIR__ . '/Aws/Route53/Exception/HostedZoneAlreadyExistsException.php', + 'Aws\Route53\Exception\HostedZoneNotEmptyException' => __DIR__ . '/Aws/Route53/Exception/HostedZoneNotEmptyException.php', + 'Aws\Route53\Exception\IncompatibleVersionException' => __DIR__ . '/Aws/Route53/Exception/IncompatibleVersionException.php', + 'Aws\Route53\Exception\InvalidChangeBatchException' => __DIR__ . '/Aws/Route53/Exception/InvalidChangeBatchException.php', + 'Aws\Route53\Exception\InvalidDomainNameException' => __DIR__ . '/Aws/Route53/Exception/InvalidDomainNameException.php', + 'Aws\Route53\Exception\InvalidInputException' => __DIR__ . '/Aws/Route53/Exception/InvalidInputException.php', + 'Aws\Route53\Exception\NoSuchChangeException' => __DIR__ . '/Aws/Route53/Exception/NoSuchChangeException.php', + 'Aws\Route53\Exception\NoSuchHealthCheckException' => __DIR__ . '/Aws/Route53/Exception/NoSuchHealthCheckException.php', + 'Aws\Route53\Exception\NoSuchHostedZoneException' => __DIR__ . '/Aws/Route53/Exception/NoSuchHostedZoneException.php', + 'Aws\Route53\Exception\PriorRequestNotCompleteException' => __DIR__ . '/Aws/Route53/Exception/PriorRequestNotCompleteException.php', + 'Aws\Route53\Exception\Route53Exception' => __DIR__ . '/Aws/Route53/Exception/Route53Exception.php', + 'Aws\Route53\Exception\TooManyHealthChecksException' => __DIR__ . '/Aws/Route53/Exception/TooManyHealthChecksException.php', + 'Aws\Route53\Exception\TooManyHostedZonesException' => __DIR__ . '/Aws/Route53/Exception/TooManyHostedZonesException.php', + 'Aws\Route53\Resources\route53-2013-04-01' => __DIR__ . '/Aws/Route53/Resources/route53-2013-04-01.php', + 'Aws\Route53\Route53Client' => __DIR__ . '/Aws/Route53/Route53Client.php', + 'Aws\Route53Domains\Exception\Route53DomainsException' => __DIR__ . '/Aws/Route53Domains/Exception/Route53DomainsException.php', + 'Aws\Route53Domains\Resources\route53domains-2014-05-15' => __DIR__ . '/Aws/Route53Domains/Resources/route53domains-2014-05-15.php', + 'Aws\Route53Domains\Route53DomainsClient' => __DIR__ . '/Aws/Route53Domains/Route53DomainsClient.php', + 'Aws\S3\AcpListener' => __DIR__ . '/Aws/S3/AcpListener.php', + 'Aws\S3\BucketStyleListener' => __DIR__ . '/Aws/S3/BucketStyleListener.php', + 'Aws\S3\Command\S3Command' => __DIR__ . '/Aws/S3/Command/S3Command.php', + 'Aws\S3\Enum\CannedAcl' => __DIR__ . '/Aws/S3/Enum/CannedAcl.php', + 'Aws\S3\Enum\EncodingType' => __DIR__ . '/Aws/S3/Enum/EncodingType.php', + 'Aws\S3\Enum\Event' => __DIR__ . '/Aws/S3/Enum/Event.php', + 'Aws\S3\Enum\GranteeType' => __DIR__ . '/Aws/S3/Enum/GranteeType.php', + 'Aws\S3\Enum\Group' => __DIR__ . '/Aws/S3/Enum/Group.php', + 'Aws\S3\Enum\MetadataDirective' => __DIR__ . '/Aws/S3/Enum/MetadataDirective.php', + 'Aws\S3\Enum\MFADelete' => __DIR__ . '/Aws/S3/Enum/MFADelete.php', + 'Aws\S3\Enum\Payer' => __DIR__ . '/Aws/S3/Enum/Payer.php', + 'Aws\S3\Enum\Permission' => __DIR__ . '/Aws/S3/Enum/Permission.php', + 'Aws\S3\Enum\Protocol' => __DIR__ . '/Aws/S3/Enum/Protocol.php', + 'Aws\S3\Enum\ServerSideEncryption' => __DIR__ . '/Aws/S3/Enum/ServerSideEncryption.php', + 'Aws\S3\Enum\Status' => __DIR__ . '/Aws/S3/Enum/Status.php', + 'Aws\S3\Enum\Storage' => __DIR__ . '/Aws/S3/Enum/Storage.php', + 'Aws\S3\Enum\StorageClass' => __DIR__ . '/Aws/S3/Enum/StorageClass.php', + 'Aws\S3\Exception\AccessDeniedException' => __DIR__ . '/Aws/S3/Exception/AccessDeniedException.php', + 'Aws\S3\Exception\AccountProblemException' => __DIR__ . '/Aws/S3/Exception/AccountProblemException.php', + 'Aws\S3\Exception\AmbiguousGrantByEmailAddressException' => __DIR__ . '/Aws/S3/Exception/AmbiguousGrantByEmailAddressException.php', + 'Aws\S3\Exception\BadDigestException' => __DIR__ . '/Aws/S3/Exception/BadDigestException.php', + 'Aws\S3\Exception\BucketAlreadyExistsException' => __DIR__ . '/Aws/S3/Exception/BucketAlreadyExistsException.php', + 'Aws\S3\Exception\BucketAlreadyOwnedByYouException' => __DIR__ . '/Aws/S3/Exception/BucketAlreadyOwnedByYouException.php', + 'Aws\S3\Exception\BucketNotEmptyException' => __DIR__ . '/Aws/S3/Exception/BucketNotEmptyException.php', + 'Aws\S3\Exception\CredentialsNotSupportedException' => __DIR__ . '/Aws/S3/Exception/CredentialsNotSupportedException.php', + 'Aws\S3\Exception\CrossLocationLoggingProhibitedException' => __DIR__ . '/Aws/S3/Exception/CrossLocationLoggingProhibitedException.php', + 'Aws\S3\Exception\DeleteMultipleObjectsException' => __DIR__ . '/Aws/S3/Exception/DeleteMultipleObjectsException.php', + 'Aws\S3\Exception\EntityTooLargeException' => __DIR__ . '/Aws/S3/Exception/EntityTooLargeException.php', + 'Aws\S3\Exception\EntityTooSmallException' => __DIR__ . '/Aws/S3/Exception/EntityTooSmallException.php', + 'Aws\S3\Exception\ExpiredTokenException' => __DIR__ . '/Aws/S3/Exception/ExpiredTokenException.php', + 'Aws\S3\Exception\IllegalVersioningConfigurationException' => __DIR__ . '/Aws/S3/Exception/IllegalVersioningConfigurationException.php', + 'Aws\S3\Exception\IncompleteBodyException' => __DIR__ . '/Aws/S3/Exception/IncompleteBodyException.php', + 'Aws\S3\Exception\IncorrectNumberOfFilesInPostRequestException' => __DIR__ . '/Aws/S3/Exception/IncorrectNumberOfFilesInPostRequestException.php', + 'Aws\S3\Exception\InlineDataTooLargeException' => __DIR__ . '/Aws/S3/Exception/InlineDataTooLargeException.php', + 'Aws\S3\Exception\InternalErrorException' => __DIR__ . '/Aws/S3/Exception/InternalErrorException.php', + 'Aws\S3\Exception\InvalidAccessKeyIdException' => __DIR__ . '/Aws/S3/Exception/InvalidAccessKeyIdException.php', + 'Aws\S3\Exception\InvalidAddressingHeaderException' => __DIR__ . '/Aws/S3/Exception/InvalidAddressingHeaderException.php', + 'Aws\S3\Exception\InvalidArgumentException' => __DIR__ . '/Aws/S3/Exception/InvalidArgumentException.php', + 'Aws\S3\Exception\InvalidBucketNameException' => __DIR__ . '/Aws/S3/Exception/InvalidBucketNameException.php', + 'Aws\S3\Exception\InvalidBucketStateException' => __DIR__ . '/Aws/S3/Exception/InvalidBucketStateException.php', + 'Aws\S3\Exception\InvalidDigestException' => __DIR__ . '/Aws/S3/Exception/InvalidDigestException.php', + 'Aws\S3\Exception\InvalidLocationConstraintException' => __DIR__ . '/Aws/S3/Exception/InvalidLocationConstraintException.php', + 'Aws\S3\Exception\InvalidPartException' => __DIR__ . '/Aws/S3/Exception/InvalidPartException.php', + 'Aws\S3\Exception\InvalidPartOrderException' => __DIR__ . '/Aws/S3/Exception/InvalidPartOrderException.php', + 'Aws\S3\Exception\InvalidPayerException' => __DIR__ . '/Aws/S3/Exception/InvalidPayerException.php', + 'Aws\S3\Exception\InvalidPolicyDocumentException' => __DIR__ . '/Aws/S3/Exception/InvalidPolicyDocumentException.php', + 'Aws\S3\Exception\InvalidRangeException' => __DIR__ . '/Aws/S3/Exception/InvalidRangeException.php', + 'Aws\S3\Exception\InvalidRequestException' => __DIR__ . '/Aws/S3/Exception/InvalidRequestException.php', + 'Aws\S3\Exception\InvalidSecurityException' => __DIR__ . '/Aws/S3/Exception/InvalidSecurityException.php', + 'Aws\S3\Exception\InvalidSOAPRequestException' => __DIR__ . '/Aws/S3/Exception/InvalidSOAPRequestException.php', + 'Aws\S3\Exception\InvalidStorageClassException' => __DIR__ . '/Aws/S3/Exception/InvalidStorageClassException.php', + 'Aws\S3\Exception\InvalidTagErrorException' => __DIR__ . '/Aws/S3/Exception/InvalidTagErrorException.php', + 'Aws\S3\Exception\InvalidTargetBucketForLoggingException' => __DIR__ . '/Aws/S3/Exception/InvalidTargetBucketForLoggingException.php', + 'Aws\S3\Exception\InvalidTokenException' => __DIR__ . '/Aws/S3/Exception/InvalidTokenException.php', + 'Aws\S3\Exception\InvalidURIException' => __DIR__ . '/Aws/S3/Exception/InvalidURIException.php', + 'Aws\S3\Exception\KeyTooLongException' => __DIR__ . '/Aws/S3/Exception/KeyTooLongException.php', + 'Aws\S3\Exception\MalformedACLErrorException' => __DIR__ . '/Aws/S3/Exception/MalformedACLErrorException.php', + 'Aws\S3\Exception\MalformedPOSTRequestException' => __DIR__ . '/Aws/S3/Exception/MalformedPOSTRequestException.php', + 'Aws\S3\Exception\MalformedXMLException' => __DIR__ . '/Aws/S3/Exception/MalformedXMLException.php', + 'Aws\S3\Exception\MaxMessageLengthExceededException' => __DIR__ . '/Aws/S3/Exception/MaxMessageLengthExceededException.php', + 'Aws\S3\Exception\MaxPostPreDataLengthExceededErrorException' => __DIR__ . '/Aws/S3/Exception/MaxPostPreDataLengthExceededErrorException.php', + 'Aws\S3\Exception\MetadataTooLargeException' => __DIR__ . '/Aws/S3/Exception/MetadataTooLargeException.php', + 'Aws\S3\Exception\MethodNotAllowedException' => __DIR__ . '/Aws/S3/Exception/MethodNotAllowedException.php', + 'Aws\S3\Exception\MissingAttachmentException' => __DIR__ . '/Aws/S3/Exception/MissingAttachmentException.php', + 'Aws\S3\Exception\MissingContentLengthException' => __DIR__ . '/Aws/S3/Exception/MissingContentLengthException.php', + 'Aws\S3\Exception\MissingRequestBodyErrorException' => __DIR__ . '/Aws/S3/Exception/MissingRequestBodyErrorException.php', + 'Aws\S3\Exception\MissingSecurityElementException' => __DIR__ . '/Aws/S3/Exception/MissingSecurityElementException.php', + 'Aws\S3\Exception\MissingSecurityHeaderException' => __DIR__ . '/Aws/S3/Exception/MissingSecurityHeaderException.php', + 'Aws\S3\Exception\NoLoggingStatusForKeyException' => __DIR__ . '/Aws/S3/Exception/NoLoggingStatusForKeyException.php', + 'Aws\S3\Exception\NoSuchBucketException' => __DIR__ . '/Aws/S3/Exception/NoSuchBucketException.php', + 'Aws\S3\Exception\NoSuchBucketPolicyException' => __DIR__ . '/Aws/S3/Exception/NoSuchBucketPolicyException.php', + 'Aws\S3\Exception\NoSuchCORSConfigurationException' => __DIR__ . '/Aws/S3/Exception/NoSuchCORSConfigurationException.php', + 'Aws\S3\Exception\NoSuchKeyException' => __DIR__ . '/Aws/S3/Exception/NoSuchKeyException.php', + 'Aws\S3\Exception\NoSuchLifecycleConfigurationException' => __DIR__ . '/Aws/S3/Exception/NoSuchLifecycleConfigurationException.php', + 'Aws\S3\Exception\NoSuchTagSetErrorException' => __DIR__ . '/Aws/S3/Exception/NoSuchTagSetErrorException.php', + 'Aws\S3\Exception\NoSuchUploadException' => __DIR__ . '/Aws/S3/Exception/NoSuchUploadException.php', + 'Aws\S3\Exception\NoSuchVersionException' => __DIR__ . '/Aws/S3/Exception/NoSuchVersionException.php', + 'Aws\S3\Exception\NoSuchWebsiteConfigurationException' => __DIR__ . '/Aws/S3/Exception/NoSuchWebsiteConfigurationException.php', + 'Aws\S3\Exception\NotImplementedException' => __DIR__ . '/Aws/S3/Exception/NotImplementedException.php', + 'Aws\S3\Exception\NotSignedUpException' => __DIR__ . '/Aws/S3/Exception/NotSignedUpException.php', + 'Aws\S3\Exception\NotSuchBucketPolicyException' => __DIR__ . '/Aws/S3/Exception/NotSuchBucketPolicyException.php', + 'Aws\S3\Exception\ObjectAlreadyInActiveTierErrorException' => __DIR__ . '/Aws/S3/Exception/ObjectAlreadyInActiveTierErrorException.php', + 'Aws\S3\Exception\ObjectNotInActiveTierErrorException' => __DIR__ . '/Aws/S3/Exception/ObjectNotInActiveTierErrorException.php', + 'Aws\S3\Exception\OperationAbortedException' => __DIR__ . '/Aws/S3/Exception/OperationAbortedException.php', + 'Aws\S3\Exception\Parser\S3ExceptionParser' => __DIR__ . '/Aws/S3/Exception/Parser/S3ExceptionParser.php', + 'Aws\S3\Exception\PermanentRedirectException' => __DIR__ . '/Aws/S3/Exception/PermanentRedirectException.php', + 'Aws\S3\Exception\PreconditionFailedException' => __DIR__ . '/Aws/S3/Exception/PreconditionFailedException.php', + 'Aws\S3\Exception\RedirectException' => __DIR__ . '/Aws/S3/Exception/RedirectException.php', + 'Aws\S3\Exception\RequestIsNotMultiPartContentException' => __DIR__ . '/Aws/S3/Exception/RequestIsNotMultiPartContentException.php', + 'Aws\S3\Exception\RequestTimeoutException' => __DIR__ . '/Aws/S3/Exception/RequestTimeoutException.php', + 'Aws\S3\Exception\RequestTimeTooSkewedException' => __DIR__ . '/Aws/S3/Exception/RequestTimeTooSkewedException.php', + 'Aws\S3\Exception\RequestTorrentOfBucketErrorException' => __DIR__ . '/Aws/S3/Exception/RequestTorrentOfBucketErrorException.php', + 'Aws\S3\Exception\S3Exception' => __DIR__ . '/Aws/S3/Exception/S3Exception.php', + 'Aws\S3\Exception\ServiceUnavailableException' => __DIR__ . '/Aws/S3/Exception/ServiceUnavailableException.php', + 'Aws\S3\Exception\SignatureDoesNotMatchException' => __DIR__ . '/Aws/S3/Exception/SignatureDoesNotMatchException.php', + 'Aws\S3\Exception\SlowDownException' => __DIR__ . '/Aws/S3/Exception/SlowDownException.php', + 'Aws\S3\Exception\TemporaryRedirectException' => __DIR__ . '/Aws/S3/Exception/TemporaryRedirectException.php', + 'Aws\S3\Exception\TokenRefreshRequiredException' => __DIR__ . '/Aws/S3/Exception/TokenRefreshRequiredException.php', + 'Aws\S3\Exception\TooManyBucketsException' => __DIR__ . '/Aws/S3/Exception/TooManyBucketsException.php', + 'Aws\S3\Exception\UnexpectedContentException' => __DIR__ . '/Aws/S3/Exception/UnexpectedContentException.php', + 'Aws\S3\Exception\UnresolvableGrantByEmailAddressException' => __DIR__ . '/Aws/S3/Exception/UnresolvableGrantByEmailAddressException.php', + 'Aws\S3\Exception\UserKeyMustBeSpecifiedException' => __DIR__ . '/Aws/S3/Exception/UserKeyMustBeSpecifiedException.php', + 'Aws\S3\Iterator\ListBucketsIterator' => __DIR__ . '/Aws/S3/Iterator/ListBucketsIterator.php', + 'Aws\S3\Iterator\ListMultipartUploadsIterator' => __DIR__ . '/Aws/S3/Iterator/ListMultipartUploadsIterator.php', + 'Aws\S3\Iterator\ListObjectsIterator' => __DIR__ . '/Aws/S3/Iterator/ListObjectsIterator.php', + 'Aws\S3\Iterator\ListObjectVersionsIterator' => __DIR__ . '/Aws/S3/Iterator/ListObjectVersionsIterator.php', + 'Aws\S3\Iterator\OpendirIterator' => __DIR__ . '/Aws/S3/Iterator/OpendirIterator.php', + 'Aws\S3\Model\Acp' => __DIR__ . '/Aws/S3/Model/Acp.php', + 'Aws\S3\Model\AcpBuilder' => __DIR__ . '/Aws/S3/Model/AcpBuilder.php', + 'Aws\S3\Model\ClearBucket' => __DIR__ . '/Aws/S3/Model/ClearBucket.php', + 'Aws\S3\Model\DeleteObjectsBatch' => __DIR__ . '/Aws/S3/Model/DeleteObjectsBatch.php', + 'Aws\S3\Model\DeleteObjectsTransfer' => __DIR__ . '/Aws/S3/Model/DeleteObjectsTransfer.php', + 'Aws\S3\Model\Grant' => __DIR__ . '/Aws/S3/Model/Grant.php', + 'Aws\S3\Model\Grantee' => __DIR__ . '/Aws/S3/Model/Grantee.php', + 'Aws\S3\Model\MultipartUpload\AbstractTransfer' => __DIR__ . '/Aws/S3/Model/MultipartUpload/AbstractTransfer.php', + 'Aws\S3\Model\MultipartUpload\ParallelTransfer' => __DIR__ . '/Aws/S3/Model/MultipartUpload/ParallelTransfer.php', + 'Aws\S3\Model\MultipartUpload\SerialTransfer' => __DIR__ . '/Aws/S3/Model/MultipartUpload/SerialTransfer.php', + 'Aws\S3\Model\MultipartUpload\TransferState' => __DIR__ . '/Aws/S3/Model/MultipartUpload/TransferState.php', + 'Aws\S3\Model\MultipartUpload\UploadBuilder' => __DIR__ . '/Aws/S3/Model/MultipartUpload/UploadBuilder.php', + 'Aws\S3\Model\MultipartUpload\UploadId' => __DIR__ . '/Aws/S3/Model/MultipartUpload/UploadId.php', + 'Aws\S3\Model\MultipartUpload\UploadPart' => __DIR__ . '/Aws/S3/Model/MultipartUpload/UploadPart.php', + 'Aws\S3\Model\PostObject' => __DIR__ . '/Aws/S3/Model/PostObject.php', + 'Aws\S3\Resources\s3-2006-03-01' => __DIR__ . '/Aws/S3/Resources/s3-2006-03-01.php', + 'Aws\S3\ResumableDownload' => __DIR__ . '/Aws/S3/ResumableDownload.php', + 'Aws\S3\S3Client' => __DIR__ . '/Aws/S3/S3Client.php', + 'Aws\S3\S3Md5Listener' => __DIR__ . '/Aws/S3/S3Md5Listener.php', + 'Aws\S3\S3Signature' => __DIR__ . '/Aws/S3/S3Signature.php', + 'Aws\S3\S3SignatureInterface' => __DIR__ . '/Aws/S3/S3SignatureInterface.php', + 'Aws\S3\S3SignatureV4' => __DIR__ . '/Aws/S3/S3SignatureV4.php', + 'Aws\S3\SocketTimeoutChecker' => __DIR__ . '/Aws/S3/SocketTimeoutChecker.php', + 'Aws\S3\SseCpkListener' => __DIR__ . '/Aws/S3/SseCpkListener.php', + 'Aws\S3\StreamWrapper' => __DIR__ . '/Aws/S3/StreamWrapper.php', + 'Aws\S3\Sync\AbstractSync' => __DIR__ . '/Aws/S3/Sync/AbstractSync.php', + 'Aws\S3\Sync\AbstractSyncBuilder' => __DIR__ . '/Aws/S3/Sync/AbstractSyncBuilder.php', + 'Aws\S3\Sync\ChangedFilesIterator' => __DIR__ . '/Aws/S3/Sync/ChangedFilesIterator.php', + 'Aws\S3\Sync\DownloadSync' => __DIR__ . '/Aws/S3/Sync/DownloadSync.php', + 'Aws\S3\Sync\DownloadSyncBuilder' => __DIR__ . '/Aws/S3/Sync/DownloadSyncBuilder.php', + 'Aws\S3\Sync\FilenameConverterInterface' => __DIR__ . '/Aws/S3/Sync/FilenameConverterInterface.php', + 'Aws\S3\Sync\KeyConverter' => __DIR__ . '/Aws/S3/Sync/KeyConverter.php', + 'Aws\S3\Sync\UploadSync' => __DIR__ . '/Aws/S3/Sync/UploadSync.php', + 'Aws\S3\Sync\UploadSyncBuilder' => __DIR__ . '/Aws/S3/Sync/UploadSyncBuilder.php', + 'Aws\Ses\Enum\IdentityType' => __DIR__ . '/Aws/Ses/Enum/IdentityType.php', + 'Aws\Ses\Enum\MailboxSimulator' => __DIR__ . '/Aws/Ses/Enum/MailboxSimulator.php', + 'Aws\Ses\Enum\NotificationType' => __DIR__ . '/Aws/Ses/Enum/NotificationType.php', + 'Aws\Ses\Enum\VerificationStatus' => __DIR__ . '/Aws/Ses/Enum/VerificationStatus.php', + 'Aws\Ses\Exception\MessageRejectedException' => __DIR__ . '/Aws/Ses/Exception/MessageRejectedException.php', + 'Aws\Ses\Exception\SesException' => __DIR__ . '/Aws/Ses/Exception/SesException.php', + 'Aws\Ses\Resources\ses-2010-12-01' => __DIR__ . '/Aws/Ses/Resources/ses-2010-12-01.php', + 'Aws\Ses\SesClient' => __DIR__ . '/Aws/Ses/SesClient.php', + 'Aws\SimpleDb\Exception\AttributeDoesNotExistException' => __DIR__ . '/Aws/SimpleDb/Exception/AttributeDoesNotExistException.php', + 'Aws\SimpleDb\Exception\DuplicateItemNameException' => __DIR__ . '/Aws/SimpleDb/Exception/DuplicateItemNameException.php', + 'Aws\SimpleDb\Exception\InvalidNextTokenException' => __DIR__ . '/Aws/SimpleDb/Exception/InvalidNextTokenException.php', + 'Aws\SimpleDb\Exception\InvalidNumberPredicatesException' => __DIR__ . '/Aws/SimpleDb/Exception/InvalidNumberPredicatesException.php', + 'Aws\SimpleDb\Exception\InvalidNumberValueTestsException' => __DIR__ . '/Aws/SimpleDb/Exception/InvalidNumberValueTestsException.php', + 'Aws\SimpleDb\Exception\InvalidParameterValueException' => __DIR__ . '/Aws/SimpleDb/Exception/InvalidParameterValueException.php', + 'Aws\SimpleDb\Exception\InvalidQueryExpressionException' => __DIR__ . '/Aws/SimpleDb/Exception/InvalidQueryExpressionException.php', + 'Aws\SimpleDb\Exception\MissingParameterException' => __DIR__ . '/Aws/SimpleDb/Exception/MissingParameterException.php', + 'Aws\SimpleDb\Exception\NoSuchDomainException' => __DIR__ . '/Aws/SimpleDb/Exception/NoSuchDomainException.php', + 'Aws\SimpleDb\Exception\NumberDomainAttributesExceededException' => __DIR__ . '/Aws/SimpleDb/Exception/NumberDomainAttributesExceededException.php', + 'Aws\SimpleDb\Exception\NumberDomainBytesExceededException' => __DIR__ . '/Aws/SimpleDb/Exception/NumberDomainBytesExceededException.php', + 'Aws\SimpleDb\Exception\NumberDomainsExceededException' => __DIR__ . '/Aws/SimpleDb/Exception/NumberDomainsExceededException.php', + 'Aws\SimpleDb\Exception\NumberItemAttributesExceededException' => __DIR__ . '/Aws/SimpleDb/Exception/NumberItemAttributesExceededException.php', + 'Aws\SimpleDb\Exception\NumberSubmittedAttributesExceededException' => __DIR__ . '/Aws/SimpleDb/Exception/NumberSubmittedAttributesExceededException.php', + 'Aws\SimpleDb\Exception\NumberSubmittedItemsExceededException' => __DIR__ . '/Aws/SimpleDb/Exception/NumberSubmittedItemsExceededException.php', + 'Aws\SimpleDb\Exception\RequestTimeoutException' => __DIR__ . '/Aws/SimpleDb/Exception/RequestTimeoutException.php', + 'Aws\SimpleDb\Exception\SimpleDbException' => __DIR__ . '/Aws/SimpleDb/Exception/SimpleDbException.php', + 'Aws\SimpleDb\Exception\TooManyRequestedAttributesException' => __DIR__ . '/Aws/SimpleDb/Exception/TooManyRequestedAttributesException.php', + 'Aws\SimpleDb\Resources\simpledb-2009-04-15' => __DIR__ . '/Aws/SimpleDb/Resources/simpledb-2009-04-15.php', + 'Aws\SimpleDb\SimpleDbClient' => __DIR__ . '/Aws/SimpleDb/SimpleDbClient.php', + 'Aws\Sns\Exception\AuthorizationErrorException' => __DIR__ . '/Aws/Sns/Exception/AuthorizationErrorException.php', + 'Aws\Sns\Exception\EndpointDisabledException' => __DIR__ . '/Aws/Sns/Exception/EndpointDisabledException.php', + 'Aws\Sns\Exception\InternalErrorException' => __DIR__ . '/Aws/Sns/Exception/InternalErrorException.php', + 'Aws\Sns\Exception\InvalidParameterException' => __DIR__ . '/Aws/Sns/Exception/InvalidParameterException.php', + 'Aws\Sns\Exception\NotFoundException' => __DIR__ . '/Aws/Sns/Exception/NotFoundException.php', + 'Aws\Sns\Exception\PlatformApplicationDisabledException' => __DIR__ . '/Aws/Sns/Exception/PlatformApplicationDisabledException.php', + 'Aws\Sns\Exception\SnsException' => __DIR__ . '/Aws/Sns/Exception/SnsException.php', + 'Aws\Sns\Exception\SubscriptionLimitExceededException' => __DIR__ . '/Aws/Sns/Exception/SubscriptionLimitExceededException.php', + 'Aws\Sns\Exception\TopicLimitExceededException' => __DIR__ . '/Aws/Sns/Exception/TopicLimitExceededException.php', + 'Aws\Sns\MessageValidator\Exception\CannotGetPublicKeyFromCertificateException' => __DIR__ . '/Aws/Sns/MessageValidator/Exception/CannotGetPublicKeyFromCertificateException.php', + 'Aws\Sns\MessageValidator\Exception\CertificateFromUnrecognizedSourceException' => __DIR__ . '/Aws/Sns/MessageValidator/Exception/CertificateFromUnrecognizedSourceException.php', + 'Aws\Sns\MessageValidator\Exception\InvalidMessageSignatureException' => __DIR__ . '/Aws/Sns/MessageValidator/Exception/InvalidMessageSignatureException.php', + 'Aws\Sns\MessageValidator\Exception\SnsMessageValidatorException' => __DIR__ . '/Aws/Sns/MessageValidator/Exception/SnsMessageValidatorException.php', + 'Aws\Sns\MessageValidator\Message' => __DIR__ . '/Aws/Sns/MessageValidator/Message.php', + 'Aws\Sns\MessageValidator\MessageValidator' => __DIR__ . '/Aws/Sns/MessageValidator/MessageValidator.php', + 'Aws\Sns\Resources\sns-2010-03-31' => __DIR__ . '/Aws/Sns/Resources/sns-2010-03-31.php', + 'Aws\Sns\SnsClient' => __DIR__ . '/Aws/Sns/SnsClient.php', + 'Aws\Sqs\Enum\MessageAttribute' => __DIR__ . '/Aws/Sqs/Enum/MessageAttribute.php', + 'Aws\Sqs\Enum\QueueAttribute' => __DIR__ . '/Aws/Sqs/Enum/QueueAttribute.php', + 'Aws\Sqs\Exception\SqsException' => __DIR__ . '/Aws/Sqs/Exception/SqsException.php', + 'Aws\Sqs\Md5ValidatorListener' => __DIR__ . '/Aws/Sqs/Md5ValidatorListener.php', + 'Aws\Sqs\QueueUrlListener' => __DIR__ . '/Aws/Sqs/QueueUrlListener.php', + 'Aws\Sqs\Resources\sqs-2012-11-05' => __DIR__ . '/Aws/Sqs/Resources/sqs-2012-11-05.php', + 'Aws\Sqs\SqsClient' => __DIR__ . '/Aws/Sqs/SqsClient.php', + 'Aws\Ssm\Exception\SsmException' => __DIR__ . '/Aws/Ssm/Exception/SsmException.php', + 'Aws\Ssm\Resources\ssm-2014-11-06' => __DIR__ . '/Aws/Ssm/Resources/ssm-2014-11-06.php', + 'Aws\Ssm\SsmClient' => __DIR__ . '/Aws/Ssm/SsmClient.php', + 'Aws\StorageGateway\Enum\BandwidthType' => __DIR__ . '/Aws/StorageGateway/Enum/BandwidthType.php', + 'Aws\StorageGateway\Enum\DiskAllocationType' => __DIR__ . '/Aws/StorageGateway/Enum/DiskAllocationType.php', + 'Aws\StorageGateway\Enum\ErrorCode' => __DIR__ . '/Aws/StorageGateway/Enum/ErrorCode.php', + 'Aws\StorageGateway\Enum\GatewayState' => __DIR__ . '/Aws/StorageGateway/Enum/GatewayState.php', + 'Aws\StorageGateway\Enum\GatewayTimezone' => __DIR__ . '/Aws/StorageGateway/Enum/GatewayTimezone.php', + 'Aws\StorageGateway\Enum\GatewayType' => __DIR__ . '/Aws/StorageGateway/Enum/GatewayType.php', + 'Aws\StorageGateway\Enum\VolumeStatus' => __DIR__ . '/Aws/StorageGateway/Enum/VolumeStatus.php', + 'Aws\StorageGateway\Enum\VolumeType' => __DIR__ . '/Aws/StorageGateway/Enum/VolumeType.php', + 'Aws\StorageGateway\Exception\InternalServerErrorException' => __DIR__ . '/Aws/StorageGateway/Exception/InternalServerErrorException.php', + 'Aws\StorageGateway\Exception\InvalidGatewayRequestException' => __DIR__ . '/Aws/StorageGateway/Exception/InvalidGatewayRequestException.php', + 'Aws\StorageGateway\Exception\StorageGatewayException' => __DIR__ . '/Aws/StorageGateway/Exception/StorageGatewayException.php', + 'Aws\StorageGateway\Resources\storagegateway-2013-06-30' => __DIR__ . '/Aws/StorageGateway/Resources/storagegateway-2013-06-30.php', + 'Aws\StorageGateway\StorageGatewayClient' => __DIR__ . '/Aws/StorageGateway/StorageGatewayClient.php', + 'Aws\Sts\Exception\ExpiredTokenException' => __DIR__ . '/Aws/Sts/Exception/ExpiredTokenException.php', + 'Aws\Sts\Exception\IDPCommunicationErrorException' => __DIR__ . '/Aws/Sts/Exception/IDPCommunicationErrorException.php', + 'Aws\Sts\Exception\IDPRejectedClaimException' => __DIR__ . '/Aws/Sts/Exception/IDPRejectedClaimException.php', + 'Aws\Sts\Exception\IncompleteSignatureException' => __DIR__ . '/Aws/Sts/Exception/IncompleteSignatureException.php', + 'Aws\Sts\Exception\InternalFailureException' => __DIR__ . '/Aws/Sts/Exception/InternalFailureException.php', + 'Aws\Sts\Exception\InvalidActionException' => __DIR__ . '/Aws/Sts/Exception/InvalidActionException.php', + 'Aws\Sts\Exception\InvalidAuthorizationMessageException' => __DIR__ . '/Aws/Sts/Exception/InvalidAuthorizationMessageException.php', + 'Aws\Sts\Exception\InvalidClientTokenIdException' => __DIR__ . '/Aws/Sts/Exception/InvalidClientTokenIdException.php', + 'Aws\Sts\Exception\InvalidIdentityTokenException' => __DIR__ . '/Aws/Sts/Exception/InvalidIdentityTokenException.php', + 'Aws\Sts\Exception\InvalidParameterCombinationException' => __DIR__ . '/Aws/Sts/Exception/InvalidParameterCombinationException.php', + 'Aws\Sts\Exception\InvalidParameterValueException' => __DIR__ . '/Aws/Sts/Exception/InvalidParameterValueException.php', + 'Aws\Sts\Exception\InvalidQueryParameterException' => __DIR__ . '/Aws/Sts/Exception/InvalidQueryParameterException.php', + 'Aws\Sts\Exception\MalformedPolicyDocumentException' => __DIR__ . '/Aws/Sts/Exception/MalformedPolicyDocumentException.php', + 'Aws\Sts\Exception\MalformedQueryStringException' => __DIR__ . '/Aws/Sts/Exception/MalformedQueryStringException.php', + 'Aws\Sts\Exception\MissingActionException' => __DIR__ . '/Aws/Sts/Exception/MissingActionException.php', + 'Aws\Sts\Exception\MissingAuthenticationTokenException' => __DIR__ . '/Aws/Sts/Exception/MissingAuthenticationTokenException.php', + 'Aws\Sts\Exception\MissingParameterException' => __DIR__ . '/Aws/Sts/Exception/MissingParameterException.php', + 'Aws\Sts\Exception\OptInRequiredException' => __DIR__ . '/Aws/Sts/Exception/OptInRequiredException.php', + 'Aws\Sts\Exception\PackedPolicyTooLargeException' => __DIR__ . '/Aws/Sts/Exception/PackedPolicyTooLargeException.php', + 'Aws\Sts\Exception\RequestExpiredException' => __DIR__ . '/Aws/Sts/Exception/RequestExpiredException.php', + 'Aws\Sts\Exception\ServiceUnavailableException' => __DIR__ . '/Aws/Sts/Exception/ServiceUnavailableException.php', + 'Aws\Sts\Exception\StsException' => __DIR__ . '/Aws/Sts/Exception/StsException.php', + 'Aws\Sts\Exception\ThrottlingException' => __DIR__ . '/Aws/Sts/Exception/ThrottlingException.php', + 'Aws\Sts\Resources\sts-2011-06-15' => __DIR__ . '/Aws/Sts/Resources/sts-2011-06-15.php', + 'Aws\Sts\StsClient' => __DIR__ . '/Aws/Sts/StsClient.php', + 'Aws\Support\Exception\CaseCreationLimitExceededException' => __DIR__ . '/Aws/Support/Exception/CaseCreationLimitExceededException.php', + 'Aws\Support\Exception\CaseIdNotFoundException' => __DIR__ . '/Aws/Support/Exception/CaseIdNotFoundException.php', + 'Aws\Support\Exception\InternalServerErrorException' => __DIR__ . '/Aws/Support/Exception/InternalServerErrorException.php', + 'Aws\Support\Exception\SupportException' => __DIR__ . '/Aws/Support/Exception/SupportException.php', + 'Aws\Support\Resources\support-2013-04-15' => __DIR__ . '/Aws/Support/Resources/support-2013-04-15.php', + 'Aws\Support\SupportClient' => __DIR__ . '/Aws/Support/SupportClient.php', + 'Aws\Swf\Enum\ActivityTaskTimeoutType' => __DIR__ . '/Aws/Swf/Enum/ActivityTaskTimeoutType.php', + 'Aws\Swf\Enum\ChildPolicy' => __DIR__ . '/Aws/Swf/Enum/ChildPolicy.php', + 'Aws\Swf\Enum\CloseStatus' => __DIR__ . '/Aws/Swf/Enum/CloseStatus.php', + 'Aws\Swf\Enum\DecisionTaskTimeoutType' => __DIR__ . '/Aws/Swf/Enum/DecisionTaskTimeoutType.php', + 'Aws\Swf\Enum\DecisionType' => __DIR__ . '/Aws/Swf/Enum/DecisionType.php', + 'Aws\Swf\Enum\EventType' => __DIR__ . '/Aws/Swf/Enum/EventType.php', + 'Aws\Swf\Enum\ExecutionStatus' => __DIR__ . '/Aws/Swf/Enum/ExecutionStatus.php', + 'Aws\Swf\Enum\RegistrationStatus' => __DIR__ . '/Aws/Swf/Enum/RegistrationStatus.php', + 'Aws\Swf\Enum\WorkflowExecutionTimeoutType' => __DIR__ . '/Aws/Swf/Enum/WorkflowExecutionTimeoutType.php', + 'Aws\Swf\Exception\DefaultUndefinedException' => __DIR__ . '/Aws/Swf/Exception/DefaultUndefinedException.php', + 'Aws\Swf\Exception\DomainAlreadyExistsException' => __DIR__ . '/Aws/Swf/Exception/DomainAlreadyExistsException.php', + 'Aws\Swf\Exception\DomainDeprecatedException' => __DIR__ . '/Aws/Swf/Exception/DomainDeprecatedException.php', + 'Aws\Swf\Exception\LimitExceededException' => __DIR__ . '/Aws/Swf/Exception/LimitExceededException.php', + 'Aws\Swf\Exception\OperationNotPermittedException' => __DIR__ . '/Aws/Swf/Exception/OperationNotPermittedException.php', + 'Aws\Swf\Exception\SwfException' => __DIR__ . '/Aws/Swf/Exception/SwfException.php', + 'Aws\Swf\Exception\TypeAlreadyExistsException' => __DIR__ . '/Aws/Swf/Exception/TypeAlreadyExistsException.php', + 'Aws\Swf\Exception\TypeDeprecatedException' => __DIR__ . '/Aws/Swf/Exception/TypeDeprecatedException.php', + 'Aws\Swf\Exception\UnknownResourceException' => __DIR__ . '/Aws/Swf/Exception/UnknownResourceException.php', + 'Aws\Swf\Exception\WorkflowExecutionAlreadyStartedException' => __DIR__ . '/Aws/Swf/Exception/WorkflowExecutionAlreadyStartedException.php', + 'Aws\Swf\Resources\swf-2012-01-25' => __DIR__ . '/Aws/Swf/Resources/swf-2012-01-25.php', + 'Aws\Swf\SwfClient' => __DIR__ . '/Aws/Swf/SwfClient.php', + 'Aws\WorkSpaces\Exception\WorkSpacesException' => __DIR__ . '/Aws/WorkSpaces/Exception/WorkSpacesException.php', + 'Aws\WorkSpaces\Resources\workspaces-2015-04-08' => __DIR__ . '/Aws/WorkSpaces/Resources/workspaces-2015-04-08.php', + 'Aws\WorkSpaces\WorkSpacesClient' => __DIR__ . '/Aws/WorkSpaces/WorkSpacesClient.php', + 'Doctrine\Common\Cache\ApcCache' => __DIR__ . '/Doctrine/Common/Cache/ApcCache.php', + 'Doctrine\Common\Cache\ArrayCache' => __DIR__ . '/Doctrine/Common/Cache/ArrayCache.php', + 'Doctrine\Common\Cache\Cache' => __DIR__ . '/Doctrine/Common/Cache/Cache.php', + 'Doctrine\Common\Cache\CacheProvider' => __DIR__ . '/Doctrine/Common/Cache/CacheProvider.php', + 'Doctrine\Common\Cache\ChainCache' => __DIR__ . '/Doctrine/Common/Cache/ChainCache.php', + 'Doctrine\Common\Cache\ClearableCache' => __DIR__ . '/Doctrine/Common/Cache/ClearableCache.php', + 'Doctrine\Common\Cache\CouchbaseCache' => __DIR__ . '/Doctrine/Common/Cache/CouchbaseCache.php', + 'Doctrine\Common\Cache\FileCache' => __DIR__ . '/Doctrine/Common/Cache/FileCache.php', + 'Doctrine\Common\Cache\FilesystemCache' => __DIR__ . '/Doctrine/Common/Cache/FilesystemCache.php', + 'Doctrine\Common\Cache\FlushableCache' => __DIR__ . '/Doctrine/Common/Cache/FlushableCache.php', + 'Doctrine\Common\Cache\MemcacheCache' => __DIR__ . '/Doctrine/Common/Cache/MemcacheCache.php', + 'Doctrine\Common\Cache\MemcachedCache' => __DIR__ . '/Doctrine/Common/Cache/MemcachedCache.php', + 'Doctrine\Common\Cache\MongoDBCache' => __DIR__ . '/Doctrine/Common/Cache/MongoDBCache.php', + 'Doctrine\Common\Cache\MultiGetCache' => __DIR__ . '/Doctrine/Common/Cache/MultiGetCache.php', + 'Doctrine\Common\Cache\PhpFileCache' => __DIR__ . '/Doctrine/Common/Cache/PhpFileCache.php', + 'Doctrine\Common\Cache\PredisCache' => __DIR__ . '/Doctrine/Common/Cache/PredisCache.php', + 'Doctrine\Common\Cache\RedisCache' => __DIR__ . '/Doctrine/Common/Cache/RedisCache.php', + 'Doctrine\Common\Cache\RiakCache' => __DIR__ . '/Doctrine/Common/Cache/RiakCache.php', + 'Doctrine\Common\Cache\SQLite3Cache' => __DIR__ . '/Doctrine/Common/Cache/SQLite3Cache.php', + 'Doctrine\Common\Cache\Version' => __DIR__ . '/Doctrine/Common/Cache/Version.php', + 'Doctrine\Common\Cache\WinCacheCache' => __DIR__ . '/Doctrine/Common/Cache/WinCacheCache.php', + 'Doctrine\Common\Cache\XcacheCache' => __DIR__ . '/Doctrine/Common/Cache/XcacheCache.php', + 'Doctrine\Common\Cache\ZendDataCache' => __DIR__ . '/Doctrine/Common/Cache/ZendDataCache.php', + 'Guzzle\Batch\AbstractBatchDecorator' => __DIR__ . '/Guzzle/Batch/AbstractBatchDecorator.php', + 'Guzzle\Batch\Batch' => __DIR__ . '/Guzzle/Batch/Batch.php', + 'Guzzle\Batch\BatchBuilder' => __DIR__ . '/Guzzle/Batch/BatchBuilder.php', + 'Guzzle\Batch\BatchClosureDivisor' => __DIR__ . '/Guzzle/Batch/BatchClosureDivisor.php', + 'Guzzle\Batch\BatchClosureTransfer' => __DIR__ . '/Guzzle/Batch/BatchClosureTransfer.php', + 'Guzzle\Batch\BatchCommandTransfer' => __DIR__ . '/Guzzle/Batch/BatchCommandTransfer.php', + 'Guzzle\Batch\BatchDivisorInterface' => __DIR__ . '/Guzzle/Batch/BatchDivisorInterface.php', + 'Guzzle\Batch\BatchInterface' => __DIR__ . '/Guzzle/Batch/BatchInterface.php', + 'Guzzle\Batch\BatchRequestTransfer' => __DIR__ . '/Guzzle/Batch/BatchRequestTransfer.php', + 'Guzzle\Batch\BatchSizeDivisor' => __DIR__ . '/Guzzle/Batch/BatchSizeDivisor.php', + 'Guzzle\Batch\BatchTransferInterface' => __DIR__ . '/Guzzle/Batch/BatchTransferInterface.php', + 'Guzzle\Batch\Exception\BatchTransferException' => __DIR__ . '/Guzzle/Batch/Exception/BatchTransferException.php', + 'Guzzle\Batch\ExceptionBufferingBatch' => __DIR__ . '/Guzzle/Batch/ExceptionBufferingBatch.php', + 'Guzzle\Batch\FlushingBatch' => __DIR__ . '/Guzzle/Batch/FlushingBatch.php', + 'Guzzle\Batch\HistoryBatch' => __DIR__ . '/Guzzle/Batch/HistoryBatch.php', + 'Guzzle\Batch\NotifyingBatch' => __DIR__ . '/Guzzle/Batch/NotifyingBatch.php', + 'Guzzle\Cache\AbstractCacheAdapter' => __DIR__ . '/Guzzle/Cache/AbstractCacheAdapter.php', + 'Guzzle\Cache\CacheAdapterFactory' => __DIR__ . '/Guzzle/Cache/CacheAdapterFactory.php', + 'Guzzle\Cache\CacheAdapterInterface' => __DIR__ . '/Guzzle/Cache/CacheAdapterInterface.php', + 'Guzzle\Cache\ClosureCacheAdapter' => __DIR__ . '/Guzzle/Cache/ClosureCacheAdapter.php', + 'Guzzle\Cache\DoctrineCacheAdapter' => __DIR__ . '/Guzzle/Cache/DoctrineCacheAdapter.php', + 'Guzzle\Cache\NullCacheAdapter' => __DIR__ . '/Guzzle/Cache/NullCacheAdapter.php', + 'Guzzle\Cache\Zf1CacheAdapter' => __DIR__ . '/Guzzle/Cache/Zf1CacheAdapter.php', + 'Guzzle\Cache\Zf2CacheAdapter' => __DIR__ . '/Guzzle/Cache/Zf2CacheAdapter.php', + 'Guzzle\Common\AbstractHasDispatcher' => __DIR__ . '/Guzzle/Common/AbstractHasDispatcher.php', + 'Guzzle\Common\Collection' => __DIR__ . '/Guzzle/Common/Collection.php', + 'Guzzle\Common\Event' => __DIR__ . '/Guzzle/Common/Event.php', + 'Guzzle\Common\Exception\BadMethodCallException' => __DIR__ . '/Guzzle/Common/Exception/BadMethodCallException.php', + 'Guzzle\Common\Exception\ExceptionCollection' => __DIR__ . '/Guzzle/Common/Exception/ExceptionCollection.php', + 'Guzzle\Common\Exception\GuzzleException' => __DIR__ . '/Guzzle/Common/Exception/GuzzleException.php', + 'Guzzle\Common\Exception\InvalidArgumentException' => __DIR__ . '/Guzzle/Common/Exception/InvalidArgumentException.php', + 'Guzzle\Common\Exception\RuntimeException' => __DIR__ . '/Guzzle/Common/Exception/RuntimeException.php', + 'Guzzle\Common\Exception\UnexpectedValueException' => __DIR__ . '/Guzzle/Common/Exception/UnexpectedValueException.php', + 'Guzzle\Common\FromConfigInterface' => __DIR__ . '/Guzzle/Common/FromConfigInterface.php', + 'Guzzle\Common\HasDispatcherInterface' => __DIR__ . '/Guzzle/Common/HasDispatcherInterface.php', + 'Guzzle\Common\ToArrayInterface' => __DIR__ . '/Guzzle/Common/ToArrayInterface.php', + 'Guzzle\Common\Version' => __DIR__ . '/Guzzle/Common/Version.php', + 'Guzzle\Http\AbstractEntityBodyDecorator' => __DIR__ . '/Guzzle/Http/AbstractEntityBodyDecorator.php', + 'Guzzle\Http\CachingEntityBody' => __DIR__ . '/Guzzle/Http/CachingEntityBody.php', + 'Guzzle\Http\Client' => __DIR__ . '/Guzzle/Http/Client.php', + 'Guzzle\Http\ClientInterface' => __DIR__ . '/Guzzle/Http/ClientInterface.php', + 'Guzzle\Http\Curl\CurlHandle' => __DIR__ . '/Guzzle/Http/Curl/CurlHandle.php', + 'Guzzle\Http\Curl\CurlMulti' => __DIR__ . '/Guzzle/Http/Curl/CurlMulti.php', + 'Guzzle\Http\Curl\CurlMultiInterface' => __DIR__ . '/Guzzle/Http/Curl/CurlMultiInterface.php', + 'Guzzle\Http\Curl\CurlMultiProxy' => __DIR__ . '/Guzzle/Http/Curl/CurlMultiProxy.php', + 'Guzzle\Http\Curl\CurlVersion' => __DIR__ . '/Guzzle/Http/Curl/CurlVersion.php', + 'Guzzle\Http\Curl\RequestMediator' => __DIR__ . '/Guzzle/Http/Curl/RequestMediator.php', + 'Guzzle\Http\EntityBody' => __DIR__ . '/Guzzle/Http/EntityBody.php', + 'Guzzle\Http\EntityBodyInterface' => __DIR__ . '/Guzzle/Http/EntityBodyInterface.php', + 'Guzzle\Http\Exception\BadResponseException' => __DIR__ . '/Guzzle/Http/Exception/BadResponseException.php', + 'Guzzle\Http\Exception\ClientErrorResponseException' => __DIR__ . '/Guzzle/Http/Exception/ClientErrorResponseException.php', + 'Guzzle\Http\Exception\CouldNotRewindStreamException' => __DIR__ . '/Guzzle/Http/Exception/CouldNotRewindStreamException.php', + 'Guzzle\Http\Exception\CurlException' => __DIR__ . '/Guzzle/Http/Exception/CurlException.php', + 'Guzzle\Http\Exception\HttpException' => __DIR__ . '/Guzzle/Http/Exception/HttpException.php', + 'Guzzle\Http\Exception\MultiTransferException' => __DIR__ . '/Guzzle/Http/Exception/MultiTransferException.php', + 'Guzzle\Http\Exception\RequestException' => __DIR__ . '/Guzzle/Http/Exception/RequestException.php', + 'Guzzle\Http\Exception\ServerErrorResponseException' => __DIR__ . '/Guzzle/Http/Exception/ServerErrorResponseException.php', + 'Guzzle\Http\Exception\TooManyRedirectsException' => __DIR__ . '/Guzzle/Http/Exception/TooManyRedirectsException.php', + 'Guzzle\Http\IoEmittingEntityBody' => __DIR__ . '/Guzzle/Http/IoEmittingEntityBody.php', + 'Guzzle\Http\Message\AbstractMessage' => __DIR__ . '/Guzzle/Http/Message/AbstractMessage.php', + 'Guzzle\Http\Message\EntityEnclosingRequest' => __DIR__ . '/Guzzle/Http/Message/EntityEnclosingRequest.php', + 'Guzzle\Http\Message\EntityEnclosingRequestInterface' => __DIR__ . '/Guzzle/Http/Message/EntityEnclosingRequestInterface.php', + 'Guzzle\Http\Message\Header\CacheControl' => __DIR__ . '/Guzzle/Http/Message/Header/CacheControl.php', + 'Guzzle\Http\Message\Header\HeaderCollection' => __DIR__ . '/Guzzle/Http/Message/Header/HeaderCollection.php', + 'Guzzle\Http\Message\Header\HeaderFactory' => __DIR__ . '/Guzzle/Http/Message/Header/HeaderFactory.php', + 'Guzzle\Http\Message\Header\HeaderFactoryInterface' => __DIR__ . '/Guzzle/Http/Message/Header/HeaderFactoryInterface.php', + 'Guzzle\Http\Message\Header\HeaderInterface' => __DIR__ . '/Guzzle/Http/Message/Header/HeaderInterface.php', + 'Guzzle\Http\Message\Header\Link' => __DIR__ . '/Guzzle/Http/Message/Header/Link.php', + 'Guzzle\Http\Message\Header' => __DIR__ . '/Guzzle/Http/Message/Header.php', + 'Guzzle\Http\Message\MessageInterface' => __DIR__ . '/Guzzle/Http/Message/MessageInterface.php', + 'Guzzle\Http\Message\PostFile' => __DIR__ . '/Guzzle/Http/Message/PostFile.php', + 'Guzzle\Http\Message\PostFileInterface' => __DIR__ . '/Guzzle/Http/Message/PostFileInterface.php', + 'Guzzle\Http\Message\Request' => __DIR__ . '/Guzzle/Http/Message/Request.php', + 'Guzzle\Http\Message\RequestFactory' => __DIR__ . '/Guzzle/Http/Message/RequestFactory.php', + 'Guzzle\Http\Message\RequestFactoryInterface' => __DIR__ . '/Guzzle/Http/Message/RequestFactoryInterface.php', + 'Guzzle\Http\Message\RequestInterface' => __DIR__ . '/Guzzle/Http/Message/RequestInterface.php', + 'Guzzle\Http\Message\Response' => __DIR__ . '/Guzzle/Http/Message/Response.php', + 'Guzzle\Http\Mimetypes' => __DIR__ . '/Guzzle/Http/Mimetypes.php', + 'Guzzle\Http\QueryAggregator\CommaAggregator' => __DIR__ . '/Guzzle/Http/QueryAggregator/CommaAggregator.php', + 'Guzzle\Http\QueryAggregator\DuplicateAggregator' => __DIR__ . '/Guzzle/Http/QueryAggregator/DuplicateAggregator.php', + 'Guzzle\Http\QueryAggregator\PhpAggregator' => __DIR__ . '/Guzzle/Http/QueryAggregator/PhpAggregator.php', + 'Guzzle\Http\QueryAggregator\QueryAggregatorInterface' => __DIR__ . '/Guzzle/Http/QueryAggregator/QueryAggregatorInterface.php', + 'Guzzle\Http\QueryString' => __DIR__ . '/Guzzle/Http/QueryString.php', + 'Guzzle\Http\ReadLimitEntityBody' => __DIR__ . '/Guzzle/Http/ReadLimitEntityBody.php', + 'Guzzle\Http\RedirectPlugin' => __DIR__ . '/Guzzle/Http/RedirectPlugin.php', + 'Guzzle\Http\StaticClient' => __DIR__ . '/Guzzle/Http/StaticClient.php', + 'Guzzle\Http\Url' => __DIR__ . '/Guzzle/Http/Url.php', + 'Guzzle\Inflection\Inflector' => __DIR__ . '/Guzzle/Inflection/Inflector.php', + 'Guzzle\Inflection\InflectorInterface' => __DIR__ . '/Guzzle/Inflection/InflectorInterface.php', + 'Guzzle\Inflection\MemoizingInflector' => __DIR__ . '/Guzzle/Inflection/MemoizingInflector.php', + 'Guzzle\Inflection\PreComputedInflector' => __DIR__ . '/Guzzle/Inflection/PreComputedInflector.php', + 'Guzzle\Iterator\AppendIterator' => __DIR__ . '/Guzzle/Iterator/AppendIterator.php', + 'Guzzle\Iterator\ChunkedIterator' => __DIR__ . '/Guzzle/Iterator/ChunkedIterator.php', + 'Guzzle\Iterator\FilterIterator' => __DIR__ . '/Guzzle/Iterator/FilterIterator.php', + 'Guzzle\Iterator\MapIterator' => __DIR__ . '/Guzzle/Iterator/MapIterator.php', + 'Guzzle\Iterator\MethodProxyIterator' => __DIR__ . '/Guzzle/Iterator/MethodProxyIterator.php', + 'Guzzle\Log\AbstractLogAdapter' => __DIR__ . '/Guzzle/Log/AbstractLogAdapter.php', + 'Guzzle\Log\ArrayLogAdapter' => __DIR__ . '/Guzzle/Log/ArrayLogAdapter.php', + 'Guzzle\Log\ClosureLogAdapter' => __DIR__ . '/Guzzle/Log/ClosureLogAdapter.php', + 'Guzzle\Log\LogAdapterInterface' => __DIR__ . '/Guzzle/Log/LogAdapterInterface.php', + 'Guzzle\Log\MessageFormatter' => __DIR__ . '/Guzzle/Log/MessageFormatter.php', + 'Guzzle\Log\MonologLogAdapter' => __DIR__ . '/Guzzle/Log/MonologLogAdapter.php', + 'Guzzle\Log\PsrLogAdapter' => __DIR__ . '/Guzzle/Log/PsrLogAdapter.php', + 'Guzzle\Log\Zf1LogAdapter' => __DIR__ . '/Guzzle/Log/Zf1LogAdapter.php', + 'Guzzle\Log\Zf2LogAdapter' => __DIR__ . '/Guzzle/Log/Zf2LogAdapter.php', + 'Guzzle\Parser\Cookie\CookieParser' => __DIR__ . '/Guzzle/Parser/Cookie/CookieParser.php', + 'Guzzle\Parser\Cookie\CookieParserInterface' => __DIR__ . '/Guzzle/Parser/Cookie/CookieParserInterface.php', + 'Guzzle\Parser\Message\AbstractMessageParser' => __DIR__ . '/Guzzle/Parser/Message/AbstractMessageParser.php', + 'Guzzle\Parser\Message\MessageParser' => __DIR__ . '/Guzzle/Parser/Message/MessageParser.php', + 'Guzzle\Parser\Message\MessageParserInterface' => __DIR__ . '/Guzzle/Parser/Message/MessageParserInterface.php', + 'Guzzle\Parser\Message\PeclHttpMessageParser' => __DIR__ . '/Guzzle/Parser/Message/PeclHttpMessageParser.php', + 'Guzzle\Parser\ParserRegistry' => __DIR__ . '/Guzzle/Parser/ParserRegistry.php', + 'Guzzle\Parser\UriTemplate\PeclUriTemplate' => __DIR__ . '/Guzzle/Parser/UriTemplate/PeclUriTemplate.php', + 'Guzzle\Parser\UriTemplate\UriTemplate' => __DIR__ . '/Guzzle/Parser/UriTemplate/UriTemplate.php', + 'Guzzle\Parser\UriTemplate\UriTemplateInterface' => __DIR__ . '/Guzzle/Parser/UriTemplate/UriTemplateInterface.php', + 'Guzzle\Parser\Url\UrlParser' => __DIR__ . '/Guzzle/Parser/Url/UrlParser.php', + 'Guzzle\Parser\Url\UrlParserInterface' => __DIR__ . '/Guzzle/Parser/Url/UrlParserInterface.php', + 'Guzzle\Plugin\Async\AsyncPlugin' => __DIR__ . '/Guzzle/Plugin/Async/AsyncPlugin.php', + 'Guzzle\Plugin\Backoff\AbstractBackoffStrategy' => __DIR__ . '/Guzzle/Plugin/Backoff/AbstractBackoffStrategy.php', + 'Guzzle\Plugin\Backoff\AbstractErrorCodeBackoffStrategy' => __DIR__ . '/Guzzle/Plugin/Backoff/AbstractErrorCodeBackoffStrategy.php', + 'Guzzle\Plugin\Backoff\BackoffLogger' => __DIR__ . '/Guzzle/Plugin/Backoff/BackoffLogger.php', + 'Guzzle\Plugin\Backoff\BackoffPlugin' => __DIR__ . '/Guzzle/Plugin/Backoff/BackoffPlugin.php', + 'Guzzle\Plugin\Backoff\BackoffStrategyInterface' => __DIR__ . '/Guzzle/Plugin/Backoff/BackoffStrategyInterface.php', + 'Guzzle\Plugin\Backoff\CallbackBackoffStrategy' => __DIR__ . '/Guzzle/Plugin/Backoff/CallbackBackoffStrategy.php', + 'Guzzle\Plugin\Backoff\ConstantBackoffStrategy' => __DIR__ . '/Guzzle/Plugin/Backoff/ConstantBackoffStrategy.php', + 'Guzzle\Plugin\Backoff\CurlBackoffStrategy' => __DIR__ . '/Guzzle/Plugin/Backoff/CurlBackoffStrategy.php', + 'Guzzle\Plugin\Backoff\ExponentialBackoffStrategy' => __DIR__ . '/Guzzle/Plugin/Backoff/ExponentialBackoffStrategy.php', + 'Guzzle\Plugin\Backoff\HttpBackoffStrategy' => __DIR__ . '/Guzzle/Plugin/Backoff/HttpBackoffStrategy.php', + 'Guzzle\Plugin\Backoff\LinearBackoffStrategy' => __DIR__ . '/Guzzle/Plugin/Backoff/LinearBackoffStrategy.php', + 'Guzzle\Plugin\Backoff\ReasonPhraseBackoffStrategy' => __DIR__ . '/Guzzle/Plugin/Backoff/ReasonPhraseBackoffStrategy.php', + 'Guzzle\Plugin\Backoff\TruncatedBackoffStrategy' => __DIR__ . '/Guzzle/Plugin/Backoff/TruncatedBackoffStrategy.php', + 'Guzzle\Plugin\Cache\CacheKeyProviderInterface' => __DIR__ . '/Guzzle/Plugin/Cache/CacheKeyProviderInterface.php', + 'Guzzle\Plugin\Cache\CachePlugin' => __DIR__ . '/Guzzle/Plugin/Cache/CachePlugin.php', + 'Guzzle\Plugin\Cache\CacheStorageInterface' => __DIR__ . '/Guzzle/Plugin/Cache/CacheStorageInterface.php', + 'Guzzle\Plugin\Cache\CallbackCanCacheStrategy' => __DIR__ . '/Guzzle/Plugin/Cache/CallbackCanCacheStrategy.php', + 'Guzzle\Plugin\Cache\CanCacheStrategyInterface' => __DIR__ . '/Guzzle/Plugin/Cache/CanCacheStrategyInterface.php', + 'Guzzle\Plugin\Cache\DefaultCacheKeyProvider' => __DIR__ . '/Guzzle/Plugin/Cache/DefaultCacheKeyProvider.php', + 'Guzzle\Plugin\Cache\DefaultCacheStorage' => __DIR__ . '/Guzzle/Plugin/Cache/DefaultCacheStorage.php', + 'Guzzle\Plugin\Cache\DefaultCanCacheStrategy' => __DIR__ . '/Guzzle/Plugin/Cache/DefaultCanCacheStrategy.php', + 'Guzzle\Plugin\Cache\DefaultRevalidation' => __DIR__ . '/Guzzle/Plugin/Cache/DefaultRevalidation.php', + 'Guzzle\Plugin\Cache\DenyRevalidation' => __DIR__ . '/Guzzle/Plugin/Cache/DenyRevalidation.php', + 'Guzzle\Plugin\Cache\RevalidationInterface' => __DIR__ . '/Guzzle/Plugin/Cache/RevalidationInterface.php', + 'Guzzle\Plugin\Cache\SkipRevalidation' => __DIR__ . '/Guzzle/Plugin/Cache/SkipRevalidation.php', + 'Guzzle\Plugin\Cookie\Cookie' => __DIR__ . '/Guzzle/Plugin/Cookie/Cookie.php', + 'Guzzle\Plugin\Cookie\CookieJar\ArrayCookieJar' => __DIR__ . '/Guzzle/Plugin/Cookie/CookieJar/ArrayCookieJar.php', + 'Guzzle\Plugin\Cookie\CookieJar\CookieJarInterface' => __DIR__ . '/Guzzle/Plugin/Cookie/CookieJar/CookieJarInterface.php', + 'Guzzle\Plugin\Cookie\CookieJar\FileCookieJar' => __DIR__ . '/Guzzle/Plugin/Cookie/CookieJar/FileCookieJar.php', + 'Guzzle\Plugin\Cookie\CookiePlugin' => __DIR__ . '/Guzzle/Plugin/Cookie/CookiePlugin.php', + 'Guzzle\Plugin\Cookie\Exception\InvalidCookieException' => __DIR__ . '/Guzzle/Plugin/Cookie/Exception/InvalidCookieException.php', + 'Guzzle\Plugin\CurlAuth\CurlAuthPlugin' => __DIR__ . '/Guzzle/Plugin/CurlAuth/CurlAuthPlugin.php', + 'Guzzle\Plugin\ErrorResponse\ErrorResponseExceptionInterface' => __DIR__ . '/Guzzle/Plugin/ErrorResponse/ErrorResponseExceptionInterface.php', + 'Guzzle\Plugin\ErrorResponse\ErrorResponsePlugin' => __DIR__ . '/Guzzle/Plugin/ErrorResponse/ErrorResponsePlugin.php', + 'Guzzle\Plugin\ErrorResponse\Exception\ErrorResponseException' => __DIR__ . '/Guzzle/Plugin/ErrorResponse/Exception/ErrorResponseException.php', + 'Guzzle\Plugin\History\HistoryPlugin' => __DIR__ . '/Guzzle/Plugin/History/HistoryPlugin.php', + 'Guzzle\Plugin\Log\LogPlugin' => __DIR__ . '/Guzzle/Plugin/Log/LogPlugin.php', + 'Guzzle\Plugin\Md5\CommandContentMd5Plugin' => __DIR__ . '/Guzzle/Plugin/Md5/CommandContentMd5Plugin.php', + 'Guzzle\Plugin\Md5\Md5ValidatorPlugin' => __DIR__ . '/Guzzle/Plugin/Md5/Md5ValidatorPlugin.php', + 'Guzzle\Plugin\Mock\MockPlugin' => __DIR__ . '/Guzzle/Plugin/Mock/MockPlugin.php', + 'Guzzle\Plugin\Oauth\OauthPlugin' => __DIR__ . '/Guzzle/Plugin/Oauth/OauthPlugin.php', + 'Guzzle\Service\AbstractConfigLoader' => __DIR__ . '/Guzzle/Service/AbstractConfigLoader.php', + 'Guzzle\Service\Builder\ServiceBuilder' => __DIR__ . '/Guzzle/Service/Builder/ServiceBuilder.php', + 'Guzzle\Service\Builder\ServiceBuilderInterface' => __DIR__ . '/Guzzle/Service/Builder/ServiceBuilderInterface.php', + 'Guzzle\Service\Builder\ServiceBuilderLoader' => __DIR__ . '/Guzzle/Service/Builder/ServiceBuilderLoader.php', + 'Guzzle\Service\CachingConfigLoader' => __DIR__ . '/Guzzle/Service/CachingConfigLoader.php', + 'Guzzle\Service\Client' => __DIR__ . '/Guzzle/Service/Client.php', + 'Guzzle\Service\ClientInterface' => __DIR__ . '/Guzzle/Service/ClientInterface.php', + 'Guzzle\Service\Command\AbstractCommand' => __DIR__ . '/Guzzle/Service/Command/AbstractCommand.php', + 'Guzzle\Service\Command\ClosureCommand' => __DIR__ . '/Guzzle/Service/Command/ClosureCommand.php', + 'Guzzle\Service\Command\CommandInterface' => __DIR__ . '/Guzzle/Service/Command/CommandInterface.php', + 'Guzzle\Service\Command\CreateResponseClassEvent' => __DIR__ . '/Guzzle/Service/Command/CreateResponseClassEvent.php', + 'Guzzle\Service\Command\DefaultRequestSerializer' => __DIR__ . '/Guzzle/Service/Command/DefaultRequestSerializer.php', + 'Guzzle\Service\Command\DefaultResponseParser' => __DIR__ . '/Guzzle/Service/Command/DefaultResponseParser.php', + 'Guzzle\Service\Command\Factory\AliasFactory' => __DIR__ . '/Guzzle/Service/Command/Factory/AliasFactory.php', + 'Guzzle\Service\Command\Factory\CompositeFactory' => __DIR__ . '/Guzzle/Service/Command/Factory/CompositeFactory.php', + 'Guzzle\Service\Command\Factory\ConcreteClassFactory' => __DIR__ . '/Guzzle/Service/Command/Factory/ConcreteClassFactory.php', + 'Guzzle\Service\Command\Factory\FactoryInterface' => __DIR__ . '/Guzzle/Service/Command/Factory/FactoryInterface.php', + 'Guzzle\Service\Command\Factory\MapFactory' => __DIR__ . '/Guzzle/Service/Command/Factory/MapFactory.php', + 'Guzzle\Service\Command\Factory\ServiceDescriptionFactory' => __DIR__ . '/Guzzle/Service/Command/Factory/ServiceDescriptionFactory.php', + 'Guzzle\Service\Command\LocationVisitor\Request\AbstractRequestVisitor' => __DIR__ . '/Guzzle/Service/Command/LocationVisitor/Request/AbstractRequestVisitor.php', + 'Guzzle\Service\Command\LocationVisitor\Request\BodyVisitor' => __DIR__ . '/Guzzle/Service/Command/LocationVisitor/Request/BodyVisitor.php', + 'Guzzle\Service\Command\LocationVisitor\Request\HeaderVisitor' => __DIR__ . '/Guzzle/Service/Command/LocationVisitor/Request/HeaderVisitor.php', + 'Guzzle\Service\Command\LocationVisitor\Request\JsonVisitor' => __DIR__ . '/Guzzle/Service/Command/LocationVisitor/Request/JsonVisitor.php', + 'Guzzle\Service\Command\LocationVisitor\Request\PostFieldVisitor' => __DIR__ . '/Guzzle/Service/Command/LocationVisitor/Request/PostFieldVisitor.php', + 'Guzzle\Service\Command\LocationVisitor\Request\PostFileVisitor' => __DIR__ . '/Guzzle/Service/Command/LocationVisitor/Request/PostFileVisitor.php', + 'Guzzle\Service\Command\LocationVisitor\Request\QueryVisitor' => __DIR__ . '/Guzzle/Service/Command/LocationVisitor/Request/QueryVisitor.php', + 'Guzzle\Service\Command\LocationVisitor\Request\RequestVisitorInterface' => __DIR__ . '/Guzzle/Service/Command/LocationVisitor/Request/RequestVisitorInterface.php', + 'Guzzle\Service\Command\LocationVisitor\Request\ResponseBodyVisitor' => __DIR__ . '/Guzzle/Service/Command/LocationVisitor/Request/ResponseBodyVisitor.php', + 'Guzzle\Service\Command\LocationVisitor\Request\XmlVisitor' => __DIR__ . '/Guzzle/Service/Command/LocationVisitor/Request/XmlVisitor.php', + 'Guzzle\Service\Command\LocationVisitor\Response\AbstractResponseVisitor' => __DIR__ . '/Guzzle/Service/Command/LocationVisitor/Response/AbstractResponseVisitor.php', + 'Guzzle\Service\Command\LocationVisitor\Response\BodyVisitor' => __DIR__ . '/Guzzle/Service/Command/LocationVisitor/Response/BodyVisitor.php', + 'Guzzle\Service\Command\LocationVisitor\Response\HeaderVisitor' => __DIR__ . '/Guzzle/Service/Command/LocationVisitor/Response/HeaderVisitor.php', + 'Guzzle\Service\Command\LocationVisitor\Response\JsonVisitor' => __DIR__ . '/Guzzle/Service/Command/LocationVisitor/Response/JsonVisitor.php', + 'Guzzle\Service\Command\LocationVisitor\Response\ReasonPhraseVisitor' => __DIR__ . '/Guzzle/Service/Command/LocationVisitor/Response/ReasonPhraseVisitor.php', + 'Guzzle\Service\Command\LocationVisitor\Response\ResponseVisitorInterface' => __DIR__ . '/Guzzle/Service/Command/LocationVisitor/Response/ResponseVisitorInterface.php', + 'Guzzle\Service\Command\LocationVisitor\Response\StatusCodeVisitor' => __DIR__ . '/Guzzle/Service/Command/LocationVisitor/Response/StatusCodeVisitor.php', + 'Guzzle\Service\Command\LocationVisitor\Response\XmlVisitor' => __DIR__ . '/Guzzle/Service/Command/LocationVisitor/Response/XmlVisitor.php', + 'Guzzle\Service\Command\LocationVisitor\VisitorFlyweight' => __DIR__ . '/Guzzle/Service/Command/LocationVisitor/VisitorFlyweight.php', + 'Guzzle\Service\Command\OperationCommand' => __DIR__ . '/Guzzle/Service/Command/OperationCommand.php', + 'Guzzle\Service\Command\OperationResponseParser' => __DIR__ . '/Guzzle/Service/Command/OperationResponseParser.php', + 'Guzzle\Service\Command\RequestSerializerInterface' => __DIR__ . '/Guzzle/Service/Command/RequestSerializerInterface.php', + 'Guzzle\Service\Command\ResponseClassInterface' => __DIR__ . '/Guzzle/Service/Command/ResponseClassInterface.php', + 'Guzzle\Service\Command\ResponseParserInterface' => __DIR__ . '/Guzzle/Service/Command/ResponseParserInterface.php', + 'Guzzle\Service\ConfigLoaderInterface' => __DIR__ . '/Guzzle/Service/ConfigLoaderInterface.php', + 'Guzzle\Service\Description\Operation' => __DIR__ . '/Guzzle/Service/Description/Operation.php', + 'Guzzle\Service\Description\OperationInterface' => __DIR__ . '/Guzzle/Service/Description/OperationInterface.php', + 'Guzzle\Service\Description\Parameter' => __DIR__ . '/Guzzle/Service/Description/Parameter.php', + 'Guzzle\Service\Description\SchemaFormatter' => __DIR__ . '/Guzzle/Service/Description/SchemaFormatter.php', + 'Guzzle\Service\Description\SchemaValidator' => __DIR__ . '/Guzzle/Service/Description/SchemaValidator.php', + 'Guzzle\Service\Description\ServiceDescription' => __DIR__ . '/Guzzle/Service/Description/ServiceDescription.php', + 'Guzzle\Service\Description\ServiceDescriptionInterface' => __DIR__ . '/Guzzle/Service/Description/ServiceDescriptionInterface.php', + 'Guzzle\Service\Description\ServiceDescriptionLoader' => __DIR__ . '/Guzzle/Service/Description/ServiceDescriptionLoader.php', + 'Guzzle\Service\Description\ValidatorInterface' => __DIR__ . '/Guzzle/Service/Description/ValidatorInterface.php', + 'Guzzle\Service\Exception\CommandException' => __DIR__ . '/Guzzle/Service/Exception/CommandException.php', + 'Guzzle\Service\Exception\CommandTransferException' => __DIR__ . '/Guzzle/Service/Exception/CommandTransferException.php', + 'Guzzle\Service\Exception\DescriptionBuilderException' => __DIR__ . '/Guzzle/Service/Exception/DescriptionBuilderException.php', + 'Guzzle\Service\Exception\InconsistentClientTransferException' => __DIR__ . '/Guzzle/Service/Exception/InconsistentClientTransferException.php', + 'Guzzle\Service\Exception\ResponseClassException' => __DIR__ . '/Guzzle/Service/Exception/ResponseClassException.php', + 'Guzzle\Service\Exception\ServiceBuilderException' => __DIR__ . '/Guzzle/Service/Exception/ServiceBuilderException.php', + 'Guzzle\Service\Exception\ServiceNotFoundException' => __DIR__ . '/Guzzle/Service/Exception/ServiceNotFoundException.php', + 'Guzzle\Service\Exception\ValidationException' => __DIR__ . '/Guzzle/Service/Exception/ValidationException.php', + 'Guzzle\Service\Resource\AbstractResourceIteratorFactory' => __DIR__ . '/Guzzle/Service/Resource/AbstractResourceIteratorFactory.php', + 'Guzzle\Service\Resource\CompositeResourceIteratorFactory' => __DIR__ . '/Guzzle/Service/Resource/CompositeResourceIteratorFactory.php', + 'Guzzle\Service\Resource\MapResourceIteratorFactory' => __DIR__ . '/Guzzle/Service/Resource/MapResourceIteratorFactory.php', + 'Guzzle\Service\Resource\Model' => __DIR__ . '/Guzzle/Service/Resource/Model.php', + 'Guzzle\Service\Resource\ResourceIterator' => __DIR__ . '/Guzzle/Service/Resource/ResourceIterator.php', + 'Guzzle\Service\Resource\ResourceIteratorApplyBatched' => __DIR__ . '/Guzzle/Service/Resource/ResourceIteratorApplyBatched.php', + 'Guzzle\Service\Resource\ResourceIteratorClassFactory' => __DIR__ . '/Guzzle/Service/Resource/ResourceIteratorClassFactory.php', + 'Guzzle\Service\Resource\ResourceIteratorFactoryInterface' => __DIR__ . '/Guzzle/Service/Resource/ResourceIteratorFactoryInterface.php', + 'Guzzle\Service\Resource\ResourceIteratorInterface' => __DIR__ . '/Guzzle/Service/Resource/ResourceIteratorInterface.php', + 'Guzzle\Stream\PhpStreamRequestFactory' => __DIR__ . '/Guzzle/Stream/PhpStreamRequestFactory.php', + 'Guzzle\Stream\Stream' => __DIR__ . '/Guzzle/Stream/Stream.php', + 'Guzzle\Stream\StreamInterface' => __DIR__ . '/Guzzle/Stream/StreamInterface.php', + 'Guzzle\Stream\StreamRequestFactoryInterface' => __DIR__ . '/Guzzle/Stream/StreamRequestFactoryInterface.php', + 'Monolog\ErrorHandler' => __DIR__ . '/Monolog/ErrorHandler.php', + 'Monolog\Formatter\ChromePHPFormatter' => __DIR__ . '/Monolog/Formatter/ChromePHPFormatter.php', + 'Monolog\Formatter\ElasticaFormatter' => __DIR__ . '/Monolog/Formatter/ElasticaFormatter.php', + 'Monolog\Formatter\FlowdockFormatter' => __DIR__ . '/Monolog/Formatter/FlowdockFormatter.php', + 'Monolog\Formatter\FormatterInterface' => __DIR__ . '/Monolog/Formatter/FormatterInterface.php', + 'Monolog\Formatter\GelfMessageFormatter' => __DIR__ . '/Monolog/Formatter/GelfMessageFormatter.php', + 'Monolog\Formatter\HtmlFormatter' => __DIR__ . '/Monolog/Formatter/HtmlFormatter.php', + 'Monolog\Formatter\JsonFormatter' => __DIR__ . '/Monolog/Formatter/JsonFormatter.php', + 'Monolog\Formatter\LineFormatter' => __DIR__ . '/Monolog/Formatter/LineFormatter.php', + 'Monolog\Formatter\LogglyFormatter' => __DIR__ . '/Monolog/Formatter/LogglyFormatter.php', + 'Monolog\Formatter\LogstashFormatter' => __DIR__ . '/Monolog/Formatter/LogstashFormatter.php', + 'Monolog\Formatter\MongoDBFormatter' => __DIR__ . '/Monolog/Formatter/MongoDBFormatter.php', + 'Monolog\Formatter\NormalizerFormatter' => __DIR__ . '/Monolog/Formatter/NormalizerFormatter.php', + 'Monolog\Formatter\ScalarFormatter' => __DIR__ . '/Monolog/Formatter/ScalarFormatter.php', + 'Monolog\Formatter\WildfireFormatter' => __DIR__ . '/Monolog/Formatter/WildfireFormatter.php', + 'Monolog\Handler\AbstractHandler' => __DIR__ . '/Monolog/Handler/AbstractHandler.php', + 'Monolog\Handler\AbstractProcessingHandler' => __DIR__ . '/Monolog/Handler/AbstractProcessingHandler.php', + 'Monolog\Handler\AbstractSyslogHandler' => __DIR__ . '/Monolog/Handler/AbstractSyslogHandler.php', + 'Monolog\Handler\AmqpHandler' => __DIR__ . '/Monolog/Handler/AmqpHandler.php', + 'Monolog\Handler\BrowserConsoleHandler' => __DIR__ . '/Monolog/Handler/BrowserConsoleHandler.php', + 'Monolog\Handler\BufferHandler' => __DIR__ . '/Monolog/Handler/BufferHandler.php', + 'Monolog\Handler\ChromePHPHandler' => __DIR__ . '/Monolog/Handler/ChromePHPHandler.php', + 'Monolog\Handler\CouchDBHandler' => __DIR__ . '/Monolog/Handler/CouchDBHandler.php', + 'Monolog\Handler\CubeHandler' => __DIR__ . '/Monolog/Handler/CubeHandler.php', + 'Monolog\Handler\DoctrineCouchDBHandler' => __DIR__ . '/Monolog/Handler/DoctrineCouchDBHandler.php', + 'Monolog\Handler\DynamoDbHandler' => __DIR__ . '/Monolog/Handler/DynamoDbHandler.php', + 'Monolog\Handler\ElasticSearchHandler' => __DIR__ . '/Monolog/Handler/ElasticSearchHandler.php', + 'Monolog\Handler\ErrorLogHandler' => __DIR__ . '/Monolog/Handler/ErrorLogHandler.php', + 'Monolog\Handler\FilterHandler' => __DIR__ . '/Monolog/Handler/FilterHandler.php', + 'Monolog\Handler\FingersCrossed\ActivationStrategyInterface' => __DIR__ . '/Monolog/Handler/FingersCrossed/ActivationStrategyInterface.php', + 'Monolog\Handler\FingersCrossed\ChannelLevelActivationStrategy' => __DIR__ . '/Monolog/Handler/FingersCrossed/ChannelLevelActivationStrategy.php', + 'Monolog\Handler\FingersCrossed\ErrorLevelActivationStrategy' => __DIR__ . '/Monolog/Handler/FingersCrossed/ErrorLevelActivationStrategy.php', + 'Monolog\Handler\FingersCrossedHandler' => __DIR__ . '/Monolog/Handler/FingersCrossedHandler.php', + 'Monolog\Handler\FirePHPHandler' => __DIR__ . '/Monolog/Handler/FirePHPHandler.php', + 'Monolog\Handler\FleepHookHandler' => __DIR__ . '/Monolog/Handler/FleepHookHandler.php', + 'Monolog\Handler\FlowdockHandler' => __DIR__ . '/Monolog/Handler/FlowdockHandler.php', + 'Monolog\Handler\GelfHandler' => __DIR__ . '/Monolog/Handler/GelfHandler.php', + 'Monolog\Handler\GroupHandler' => __DIR__ . '/Monolog/Handler/GroupHandler.php', + 'Monolog\Handler\HandlerInterface' => __DIR__ . '/Monolog/Handler/HandlerInterface.php', + 'Monolog\Handler\HipChatHandler' => __DIR__ . '/Monolog/Handler/HipChatHandler.php', + 'Monolog\Handler\LogEntriesHandler' => __DIR__ . '/Monolog/Handler/LogEntriesHandler.php', + 'Monolog\Handler\LogglyHandler' => __DIR__ . '/Monolog/Handler/LogglyHandler.php', + 'Monolog\Handler\MailHandler' => __DIR__ . '/Monolog/Handler/MailHandler.php', + 'Monolog\Handler\MandrillHandler' => __DIR__ . '/Monolog/Handler/MandrillHandler.php', + 'Monolog\Handler\MissingExtensionException' => __DIR__ . '/Monolog/Handler/MissingExtensionException.php', + 'Monolog\Handler\MongoDBHandler' => __DIR__ . '/Monolog/Handler/MongoDBHandler.php', + 'Monolog\Handler\NativeMailerHandler' => __DIR__ . '/Monolog/Handler/NativeMailerHandler.php', + 'Monolog\Handler\NewRelicHandler' => __DIR__ . '/Monolog/Handler/NewRelicHandler.php', + 'Monolog\Handler\NullHandler' => __DIR__ . '/Monolog/Handler/NullHandler.php', + 'Monolog\Handler\PsrHandler' => __DIR__ . '/Monolog/Handler/PsrHandler.php', + 'Monolog\Handler\PushoverHandler' => __DIR__ . '/Monolog/Handler/PushoverHandler.php', + 'Monolog\Handler\RavenHandler' => __DIR__ . '/Monolog/Handler/RavenHandler.php', + 'Monolog\Handler\RedisHandler' => __DIR__ . '/Monolog/Handler/RedisHandler.php', + 'Monolog\Handler\RollbarHandler' => __DIR__ . '/Monolog/Handler/RollbarHandler.php', + 'Monolog\Handler\RotatingFileHandler' => __DIR__ . '/Monolog/Handler/RotatingFileHandler.php', + 'Monolog\Handler\SamplingHandler' => __DIR__ . '/Monolog/Handler/SamplingHandler.php', + 'Monolog\Handler\SlackHandler' => __DIR__ . '/Monolog/Handler/SlackHandler.php', + 'Monolog\Handler\SocketHandler' => __DIR__ . '/Monolog/Handler/SocketHandler.php', + 'Monolog\Handler\StreamHandler' => __DIR__ . '/Monolog/Handler/StreamHandler.php', + 'Monolog\Handler\SwiftMailerHandler' => __DIR__ . '/Monolog/Handler/SwiftMailerHandler.php', + 'Monolog\Handler\SyslogHandler' => __DIR__ . '/Monolog/Handler/SyslogHandler.php', + 'Monolog\Handler\SyslogUdp\UdpSocket' => __DIR__ . '/Monolog/Handler/SyslogUdp/UdpSocket.php', + 'Monolog\Handler\SyslogUdpHandler' => __DIR__ . '/Monolog/Handler/SyslogUdpHandler.php', + 'Monolog\Handler\TestHandler' => __DIR__ . '/Monolog/Handler/TestHandler.php', + 'Monolog\Handler\WhatFailureGroupHandler' => __DIR__ . '/Monolog/Handler/WhatFailureGroupHandler.php', + 'Monolog\Handler\ZendMonitorHandler' => __DIR__ . '/Monolog/Handler/ZendMonitorHandler.php', + 'Monolog\Logger' => __DIR__ . '/Monolog/Logger.php', + 'Monolog\Processor\GitProcessor' => __DIR__ . '/Monolog/Processor/GitProcessor.php', + 'Monolog\Processor\IntrospectionProcessor' => __DIR__ . '/Monolog/Processor/IntrospectionProcessor.php', + 'Monolog\Processor\MemoryPeakUsageProcessor' => __DIR__ . '/Monolog/Processor/MemoryPeakUsageProcessor.php', + 'Monolog\Processor\MemoryProcessor' => __DIR__ . '/Monolog/Processor/MemoryProcessor.php', + 'Monolog\Processor\MemoryUsageProcessor' => __DIR__ . '/Monolog/Processor/MemoryUsageProcessor.php', + 'Monolog\Processor\ProcessIdProcessor' => __DIR__ . '/Monolog/Processor/ProcessIdProcessor.php', + 'Monolog\Processor\PsrLogMessageProcessor' => __DIR__ . '/Monolog/Processor/PsrLogMessageProcessor.php', + 'Monolog\Processor\TagProcessor' => __DIR__ . '/Monolog/Processor/TagProcessor.php', + 'Monolog\Processor\UidProcessor' => __DIR__ . '/Monolog/Processor/UidProcessor.php', + 'Monolog\Processor\WebProcessor' => __DIR__ . '/Monolog/Processor/WebProcessor.php', + 'Monolog\Registry' => __DIR__ . '/Monolog/Registry.php', + 'Psr\Log\AbstractLogger' => __DIR__ . '/Psr/Log/AbstractLogger.php', + 'Psr\Log\InvalidArgumentException' => __DIR__ . '/Psr/Log/InvalidArgumentException.php', + 'Psr\Log\LoggerAwareInterface' => __DIR__ . '/Psr/Log/LoggerAwareInterface.php', + 'Psr\Log\LoggerAwareTrait' => __DIR__ . '/Psr/Log/LoggerAwareTrait.php', + 'Psr\Log\LoggerInterface' => __DIR__ . '/Psr/Log/LoggerInterface.php', + 'Psr\Log\LoggerTrait' => __DIR__ . '/Psr/Log/LoggerTrait.php', + 'Psr\Log\LogLevel' => __DIR__ . '/Psr/Log/LogLevel.php', + 'Psr\Log\NullLogger' => __DIR__ . '/Psr/Log/NullLogger.php', + 'Psr\Log\Test\LoggerInterfaceTest' => __DIR__ . '/Psr/Log/Test/LoggerInterfaceTest.php', + 'Symfony\Component\EventDispatcher\ContainerAwareEventDispatcher' => __DIR__ . '/Symfony/Component/EventDispatcher/ContainerAwareEventDispatcher.php', + 'Symfony\Component\EventDispatcher\Debug\TraceableEventDispatcher' => __DIR__ . '/Symfony/Component/EventDispatcher/Debug/TraceableEventDispatcher.php', + 'Symfony\Component\EventDispatcher\Debug\TraceableEventDispatcherInterface' => __DIR__ . '/Symfony/Component/EventDispatcher/Debug/TraceableEventDispatcherInterface.php', + 'Symfony\Component\EventDispatcher\Debug\WrappedListener' => __DIR__ . '/Symfony/Component/EventDispatcher/Debug/WrappedListener.php', + 'Symfony\Component\EventDispatcher\DependencyInjection\RegisterListenersPass' => __DIR__ . '/Symfony/Component/EventDispatcher/DependencyInjection/RegisterListenersPass.php', + 'Symfony\Component\EventDispatcher\Event' => __DIR__ . '/Symfony/Component/EventDispatcher/Event.php', + 'Symfony\Component\EventDispatcher\EventDispatcher' => __DIR__ . '/Symfony/Component/EventDispatcher/EventDispatcher.php', + 'Symfony\Component\EventDispatcher\EventDispatcherInterface' => __DIR__ . '/Symfony/Component/EventDispatcher/EventDispatcherInterface.php', + 'Symfony\Component\EventDispatcher\EventSubscriberInterface' => __DIR__ . '/Symfony/Component/EventDispatcher/EventSubscriberInterface.php', + 'Symfony\Component\EventDispatcher\GenericEvent' => __DIR__ . '/Symfony/Component/EventDispatcher/GenericEvent.php', + 'Symfony\Component\EventDispatcher\ImmutableEventDispatcher' => __DIR__ . '/Symfony/Component/EventDispatcher/ImmutableEventDispatcher.php', + 'Symfony\Component\EventDispatcher\Tests\AbstractEventDispatcherTest' => __DIR__ . '/Symfony/Component/EventDispatcher/Tests/AbstractEventDispatcherTest.php', + 'Symfony\Component\EventDispatcher\Tests\ContainerAwareEventDispatcherTest' => __DIR__ . '/Symfony/Component/EventDispatcher/Tests/ContainerAwareEventDispatcherTest.php', + 'Symfony\Component\EventDispatcher\Tests\Debug\TraceableEventDispatcherTest' => __DIR__ . '/Symfony/Component/EventDispatcher/Tests/Debug/TraceableEventDispatcherTest.php', + 'Symfony\Component\EventDispatcher\Tests\DependencyInjection\RegisterListenersPassTest' => __DIR__ . '/Symfony/Component/EventDispatcher/Tests/DependencyInjection/RegisterListenersPassTest.php', + 'Symfony\Component\EventDispatcher\Tests\EventDispatcherTest' => __DIR__ . '/Symfony/Component/EventDispatcher/Tests/EventDispatcherTest.php', + 'Symfony\Component\EventDispatcher\Tests\EventTest' => __DIR__ . '/Symfony/Component/EventDispatcher/Tests/EventTest.php', + 'Symfony\Component\EventDispatcher\Tests\GenericEventTest' => __DIR__ . '/Symfony/Component/EventDispatcher/Tests/GenericEventTest.php', + 'Symfony\Component\EventDispatcher\Tests\ImmutableEventDispatcherTest' => __DIR__ . '/Symfony/Component/EventDispatcher/Tests/ImmutableEventDispatcherTest.php', +); + +spl_autoload_register(function ($class) use ($mapping) { + if (isset($mapping[$class])) { + require $mapping[$class]; + } +}, true); +