diff --git a/api/download.php b/api/download.php new file mode 100644 index 0000000..49e11bd --- /dev/null +++ b/api/download.php @@ -0,0 +1,13 @@ +download($_POST['id']); +echo($downloadLink); +if (!$downloadLink) { + header("Location: /login"); + die("You need to log in to download this file."); +} + +header("Location: $downloadLink"); +die("$downloadLink"); +print_r($_POST); diff --git a/composer.json b/composer.json new file mode 100644 index 0000000..ccb6160 --- /dev/null +++ b/composer.json @@ -0,0 +1,5 @@ +{ + "require": { + "aws/aws-sdk-php": "2.*" + } +} diff --git a/composer.lock b/composer.lock new file mode 100644 index 0000000..ddbb5bc --- /dev/null +++ b/composer.lock @@ -0,0 +1,245 @@ +{ + "_readme": [ + "This file locks the dependencies of your project to a known state", + "Read more about it at http://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file", + "This file is @generated automatically" + ], + "hash": "b30634f092e6a4a463fbfac3e52b53d1", + "packages": [ + { + "name": "aws/aws-sdk-php", + "version": "2.6.6", + "source": { + "type": "git", + "url": "https://github.com/aws/aws-sdk-php.git", + "reference": "37d5572e2408c5ea7104c361b64a187b1a0a53bd" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/aws/aws-sdk-php/zipball/37d5572e2408c5ea7104c361b64a187b1a0a53bd", + "reference": "37d5572e2408c5ea7104c361b64a187b1a0a53bd", + "shasum": "" + }, + "require": { + "guzzle/guzzle": ">=3.7.0,<=3.9.9", + "php": ">=5.3.3" + }, + "require-dev": { + "doctrine/cache": "~1.0", + "ext-openssl": "*", + "monolog/monolog": "1.4.*", + "phpunit/phpunit": "3.7.*", + "symfony/class-loader": "2.*", + "symfony/yaml": "2.*" + }, + "suggest": { + "doctrine/cache": "Adds support for caching of credentials and responses", + "ext-apc": "Allows service description opcode caching, request and response caching, and credentials caching", + "ext-openssl": "Allows working with CloudFront private distributions and verifying received SNS messages", + "monolog/monolog": "Adds support for logging HTTP requests and responses", + "symfony/yaml": "Eases the ability to write manifests for creating jobs in AWS Import/Export" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "2.6.x-dev" + } + }, + "autoload": { + "psr-0": { + "Aws": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "Apache-2.0" + ], + "authors": [ + { + "name": "Amazon Web Services", + "homepage": "http://aws.amazon.com" + } + ], + "description": "AWS SDK for PHP - Use Amazon Web Services in your PHP project", + "homepage": "http://aws.amazon.com/sdkforphp", + "keywords": [ + "amazon", + "aws", + "cloud", + "dynamodb", + "ec2", + "glacier", + "s3", + "sdk" + ], + "time": "2014-05-29 18:57:57" + }, + { + "name": "guzzle/guzzle", + "version": "v3.9.1", + "source": { + "type": "git", + "url": "https://github.com/guzzle/guzzle3.git", + "reference": "92d9934f2fca1da15178c91239576ae26e505e60" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/guzzle/guzzle3/zipball/92d9934f2fca1da15178c91239576ae26e505e60", + "reference": "92d9934f2fca1da15178c91239576ae26e505e60", + "shasum": "" + }, + "require": { + "ext-curl": "*", + "php": ">=5.3.3", + "symfony/event-dispatcher": "~2.1" + }, + "replace": { + "guzzle/batch": "self.version", + "guzzle/cache": "self.version", + "guzzle/common": "self.version", + "guzzle/http": "self.version", + "guzzle/inflection": "self.version", + "guzzle/iterator": "self.version", + "guzzle/log": "self.version", + "guzzle/parser": "self.version", + "guzzle/plugin": "self.version", + "guzzle/plugin-async": "self.version", + "guzzle/plugin-backoff": "self.version", + "guzzle/plugin-cache": "self.version", + "guzzle/plugin-cookie": "self.version", + "guzzle/plugin-curlauth": "self.version", + "guzzle/plugin-error-response": "self.version", + "guzzle/plugin-history": "self.version", + "guzzle/plugin-log": "self.version", + "guzzle/plugin-md5": "self.version", + "guzzle/plugin-mock": "self.version", + "guzzle/plugin-oauth": "self.version", + "guzzle/service": "self.version", + "guzzle/stream": "self.version" + }, + "require-dev": { + "doctrine/cache": "~1.3", + "monolog/monolog": "~1.0", + "phpunit/phpunit": "3.7.*", + "psr/log": "~1.0", + "symfony/class-loader": "~2.1", + "zendframework/zend-cache": "2.*,<2.3", + "zendframework/zend-log": "2.*,<2.3" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "3.8-dev" + } + }, + "autoload": { + "psr-0": { + "Guzzle": "src/", + "Guzzle\\Tests": "tests/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Michael Dowling", + "email": "mtdowling@gmail.com", + "homepage": "https://github.com/mtdowling" + }, + { + "name": "Guzzle Community", + "homepage": "https://github.com/guzzle/guzzle/contributors" + } + ], + "description": "Guzzle is a PHP HTTP client library and framework for building RESTful web service clients", + "homepage": "http://guzzlephp.org/", + "keywords": [ + "client", + "curl", + "framework", + "http", + "http client", + "rest", + "web service" + ], + "time": "2014-05-07 17:04:22" + }, + { + "name": "symfony/event-dispatcher", + "version": "v2.5.0", + "target-dir": "Symfony/Component/EventDispatcher", + "source": { + "type": "git", + "url": "https://github.com/symfony/EventDispatcher.git", + "reference": "cb62ec8dd05893fc8e4f0e6e21e326e1fc731fe8" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/EventDispatcher/zipball/cb62ec8dd05893fc8e4f0e6e21e326e1fc731fe8", + "reference": "cb62ec8dd05893fc8e4f0e6e21e326e1fc731fe8", + "shasum": "" + }, + "require": { + "php": ">=5.3.3" + }, + "require-dev": { + "psr/log": "~1.0", + "symfony/config": "~2.0", + "symfony/dependency-injection": "~2.0", + "symfony/stopwatch": "~2.2" + }, + "suggest": { + "symfony/dependency-injection": "", + "symfony/http-kernel": "" + }, + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "2.5-dev" + } + }, + "autoload": { + "psr-0": { + "Symfony\\Component\\EventDispatcher\\": "" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com", + "homepage": "http://fabien.potencier.org", + "role": "Lead Developer" + }, + { + "name": "Symfony Community", + "homepage": "http://symfony.com/contributors" + } + ], + "description": "Symfony EventDispatcher Component", + "homepage": "http://symfony.com", + "time": "2014-04-29 10:13:57" + } + ], + "packages-dev": [ + + ], + "aliases": [ + + ], + "minimum-stability": "stable", + "stability-flags": [ + + ], + "platform": [ + + ], + "platform-dev": [ + + ] +} diff --git a/composer.phar b/composer.phar new file mode 100755 index 0000000..dc8035d Binary files /dev/null and b/composer.phar differ diff --git a/functions.php b/functions.php index 55a421c..1b37c41 100755 --- a/functions.php +++ b/functions.php @@ -1,7 +1,14 @@ L2}M9*8%7]B6F"); @@ -52,14 +59,20 @@ function share($title, $description, $file) { } function vote($isUpvote = 0) { - + return true; } function download($item) { - + $mysqli = mysqli_connect(DB_HOSTNAME, DB_USERNAME, DB_PASSWORD, DB_NAME) or die("Error " . mysqli_error($link)); + $item_safe = mysqli_real_escape_string($mysqli,$item); + $query = "SELECT `hash`,`extension` FROM `submissions` WHERE `id` = '$item_safe'"; + $result = mysqli_query($mysqli, $query); + $row = mysqli_fetch_assoc($result); + $s3 = S3Client::factory(); + return $s3->getObjectUrl("TheHWHack", $row['hash'].".".$row['extension'], '5 minutes') . PHP_EOL . PHP_EOL; } - - // Returns an array of information pertaining to a homework assignment + + // Returns an array of information pertaining to a homework assignment function homework($id) { $mysqli = mysqli_connect(DB_HOSTNAME, DB_USERNAME, DB_PASSWORD, DB_NAME) or die("Error " . mysqli_error($link)); $id_safe = mysqli_real_escape_string($mysqli,$id); @@ -88,8 +101,9 @@ function getProfileID() { $sid = mysqli_real_escape_string($mysqli,$_COOKIE['sid']); $query = "SELECT `id` FROM `sessions` WHERE `sid` = '$sid'"; $result = mysqli_query($mysqli, $query); - $row = mysqli_fetch_array($result); - return $row[0]["sid"]; + if (!$result) return false; + $row = mysqli_fetch_assoc($result); + return $row['id']; } function availableCreditsCount() { diff --git a/hw/hw.php b/hw/hw.php index afed12e..7ec48c0 100644 --- a/hw/hw.php +++ b/hw/hw.php @@ -1,4 +1,4 @@ -
-
+
diff --git a/includes/header.php b/includes/header.php index 15c5120..c7e9887 100755 --- a/includes/header.php +++ b/includes/header.php @@ -1,7 +1,7 @@ +if(isset($searchPage) && $searchPage = true) { ?>
diff --git a/vendor/autoload.php b/vendor/autoload.php new file mode 100644 index 0000000..4b5f544 --- /dev/null +++ b/vendor/autoload.php @@ -0,0 +1,7 @@ +> ~/.phpenv/versions/$(phpenv version-name)/etc/php.ini; fi;' + - cp test_services.json.dist test_services.json + - composer self-update + - composer install --no-interaction --prefer-source --dev + +script: vendor/bin/phpunit + +matrix: + allow_failures: + - php: 5.6 + fast_finish: true diff --git a/vendor/aws/aws-sdk-php/CHANGELOG.md b/vendor/aws/aws-sdk-php/CHANGELOG.md new file mode 100644 index 0000000..2463ea2 --- /dev/null +++ b/vendor/aws/aws-sdk-php/CHANGELOG.md @@ -0,0 +1,602 @@ +CHANGELOG +========= + +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/aws-sdk-php/CONTRIBUTING.md b/vendor/aws/aws-sdk-php/CONTRIBUTING.md new file mode 100644 index 0000000..a2d1fab --- /dev/null +++ b/vendor/aws/aws-sdk-php/CONTRIBUTING.md @@ -0,0 +1,80 @@ +# Contributing to the AWS SDK for PHP + +We work hard to provide a high-quality and useful SDK, and we greatly value feedback and contributions from our +community. Whether it's a new feature, correction, or additional documentation, we welcome your pull requests. +Please submit any [issues][] or [pull requests][pull-requests] through GitHub. + +## What you should keep in mind + +1. The SDK is released under the [Apache license][license]. Any code you submit will be released under that license. For + substantial contributions, we may ask you to sign a [Contributor License Agreement (CLA)][cla]. +2. We follow the [PSR-0][], [PSR-1][], and [PSR-2][] recommendations from the [PHP Framework Interop Group][php-fig]. + Please submit code that follows these standards. The [PHP CS Fixer][cs-fixer] tool can be helpful for formatting your + code. +3. We maintain a high percentage of code coverage in our unit tests. If you make changes to the code, please add, + update, and/or remove unit (and integration) tests as appropriate. +4. We may choose not to accept pull requests that change service descriptions (e.g., files like + `src/Aws/OpsWorks/Resources/opsworks-2013-02-18.php`). We generate these files based on our internal knowledge of + the AWS services. If there is something incorrect with or missing from a service description, it may be more + appropriate to [submit an issue][issues]. We *will*, however, consider pull requests affecting service descriptions, + if the changes are related to **Iterator** or **Waiter** configurations (e.g. [PR #84][pr-84]). +5. If your code does not conform to the PSR standards or does not include adequate tests, we may ask you to update your + pull requests before we accept them. We also reserve the right to deny any pull requests that do not align with our + standards or goals. +6. If you would like to implement support for a significant feature that is not yet available in the SDK, please talk to + us beforehand to avoid any duplication of effort. + +## What we are looking for + +We are open to anything that improves the SDK and doesn't unnecessarily cause backwards-incompatible changes. If you are +unsure if your idea is something we would be open to, please ask us (open a ticket, send us an email, post on the +forums, etc.) Specifically, here are a few things that we would appreciate help on: + +1. **Waiters** – Waiter configurations are located in the service descriptions. You can also create concrete waiters + within the `Aws\*\Waiter` namespace of a service if the logic of the waiter absolutely cannot be defined using waiter + configuration. There are many waiters that we currently provide, but many that we do not. Please let us know if you + have any questions about creating waiter configurations. +2. **Docs** – Our [User Guide][user-guide] is an ongoing project, and we would greatly appreciate contributions. The + docs are written as a [Sphinx][] website using [reStructuredText][] (very similar to Markdown). The User Guide is + located in the `docs` directory of this repository. Please see the [User Guide README][docs-readme] for more + information about how to build the User Guide. +3. **Tests** – We maintain high code coverage, but if there are any tests you feel are missing, please add them. +4. **Convenience features** – Are there any features you feel would add value to the SDK (e.g., batching for SES, SNS + message verification, S3 stream wrapper, etc.)? Contributions in this area would be greatly appreciated. +5. **Third-party modules** – We have modules published for [Silex](mod-silex), [Laravel 4](mod-laravel), and [Zend + Framework 2][mod-zf2]. Please let us know if you are interested in creating integrations with other frameworks. We + would be happy to help. +6. If you have some other ideas, please let us know! + +## Running the unit tests + +The AWS SDK for PHP is unit tested using PHPUnit. You can run the unit tests of the SDK after copying +phpunit.xml.dist to phpunit.xml: + + cp phpunit.xml.dist phpunit.xml + +Next, you need to install the dependencies of the SDK using Composer: + + composer.phar install + +Now you're ready to run the unit tests using PHPUnit: + + vendor/bin/phpunit + +[issues]: https://github.com/aws/aws-sdk-php/issues +[pull-requests]: https://github.com/aws/aws-sdk-php/pulls +[license]: http://aws.amazon.com/apache2.0/ +[cla]: http://en.wikipedia.org/wiki/Contributor_License_Agreement +[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 +[php-fig]: http://php-fig.org +[cs-fixer]: http://cs.sensiolabs.org/ +[user-guide]: http://docs.aws.amazon.com/aws-sdk-php/guide/latest/index.html +[sphinx]: http://sphinx-doc.org/ +[restructuredtext]: http://sphinx-doc.org/rest.html +[docs-readme]: https://github.com/aws/aws-sdk-php/blob/master/docs/README.md +[mod-silex]: https://github.com/aws/aws-sdk-php-silex +[mod-laravel]: https://github.com/aws/aws-sdk-php-laravel +[mod-zf2]: https://github.com/aws/aws-sdk-php-zf2 +[pr-84]: https://github.com/aws/aws-sdk-php/pull/84 diff --git a/vendor/aws/aws-sdk-php/LICENSE.md b/vendor/aws/aws-sdk-php/LICENSE.md new file mode 100644 index 0000000..8d53e9f --- /dev/null +++ b/vendor/aws/aws-sdk-php/LICENSE.md @@ -0,0 +1,141 @@ +# Apache License +Version 2.0, January 2004 + +TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + +## 1. Definitions. + +"License" shall mean the terms and conditions for use, reproduction, and distribution as defined by Sections 1 +through 9 of this document. + +"Licensor" shall mean the copyright owner or entity authorized by the copyright owner that is granting the +License. + +"Legal Entity" shall mean the union of the acting entity and all other entities that control, are controlled +by, or are under common control with that entity. For the purposes of this definition, "control" means +(i) the power, direct or indirect, to cause the direction or management of such entity, whether by contract +or otherwise, or (ii) ownership of fifty percent (50%) or more of the outstanding shares, or (iii) beneficial +ownership of such entity. + +"You" (or "Your") shall mean an individual or Legal Entity exercising permissions granted by this License. + +"Source" form shall mean the preferred form for making modifications, including but not limited to software +source code, documentation source, and configuration files. + +"Object" form shall mean any form resulting from mechanical transformation or translation of a Source form, +including but not limited to compiled object code, generated documentation, and conversions to other media +types. + +"Work" shall mean the work of authorship, whether in Source or Object form, made available under the License, +as indicated by a copyright notice that is included in or attached to the work (an example is provided in the +Appendix below). + +"Derivative Works" shall mean any work, whether in Source or Object form, that is based on (or derived from) +the Work and for which the editorial revisions, annotations, elaborations, or other modifications represent, +as a whole, an original work of authorship. For the purposes of this License, Derivative Works shall not +include works that remain separable from, or merely link (or bind by name) to the interfaces of, the Work +and Derivative Works thereof. + +"Contribution" shall mean any work of authorship, including the original version of the Work and any +modifications or additions to that Work or Derivative Works thereof, that is intentionally submitted to +Licensor for inclusion in the Work by the copyright owner or by an individual or Legal Entity authorized to +submit on behalf of the copyright owner. For the purposes of this definition, "submitted" means any form of +electronic, verbal, or written communication sent to the Licensor or its representatives, including but not +limited to communication on electronic mailing lists, source code control systems, and issue tracking systems +that are managed by, or on behalf of, the Licensor for the purpose of discussing and improving the Work, but +excluding communication that is conspicuously marked or otherwise designated in writing by the copyright +owner as "Not a Contribution." + +"Contributor" shall mean Licensor and any individual or Legal Entity on behalf of whom a Contribution has been +received by Licensor and subsequently incorporated within the Work. + +## 2. Grant of Copyright License. + +Subject to the terms and conditions of this License, each Contributor hereby grants to You a perpetual, +worldwide, non-exclusive, no-charge, royalty-free, irrevocable copyright license to reproduce, prepare +Derivative Works of, publicly display, publicly perform, sublicense, and distribute the Work and such +Derivative Works in Source or Object form. + +## 3. Grant of Patent License. + +Subject to the terms and conditions of this License, each Contributor hereby grants to You a perpetual, +worldwide, non-exclusive, no-charge, royalty-free, irrevocable (except as stated in this section) patent +license to make, have made, use, offer to sell, sell, import, and otherwise transfer the Work, where such +license applies only to those patent claims licensable by such Contributor that are necessarily infringed by +their Contribution(s) alone or by combination of their Contribution(s) with the Work to which such +Contribution(s) was submitted. If You institute patent litigation against any entity (including a cross-claim +or counterclaim in a lawsuit) alleging that the Work or a Contribution incorporated within the Work +constitutes direct or contributory patent infringement, then any patent licenses granted to You under this +License for that Work shall terminate as of the date such litigation is filed. + +## 4. Redistribution. + +You may reproduce and distribute copies of the Work or Derivative Works thereof in any medium, with or without +modifications, and in Source or Object form, provided that You meet the following conditions: + + 1. You must give any other recipients of the Work or Derivative Works a copy of this License; and + + 2. You must cause any modified files to carry prominent notices stating that You changed the files; and + + 3. You must retain, in the Source form of any Derivative Works that You distribute, all copyright, patent, + trademark, and attribution notices from the Source form of the Work, excluding those notices that do + not pertain to any part of the Derivative Works; and + + 4. If the Work includes a "NOTICE" text file as part of its distribution, then any Derivative Works that + You distribute must include a readable copy of the attribution notices contained within such NOTICE + file, excluding those notices that do not pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed as part of the Derivative Works; within + the Source form or documentation, if provided along with the Derivative Works; or, within a display + generated by the Derivative Works, if and wherever such third-party notices normally appear. The + contents of the NOTICE file are for informational purposes only and do not modify the License. You may + add Your own attribution notices within Derivative Works that You distribute, alongside or as an + addendum to the NOTICE text from the Work, provided that such additional attribution notices cannot be + construed as modifying the License. + +You may add Your own copyright statement to Your modifications and may provide additional or different license +terms and conditions for use, reproduction, or distribution of Your modifications, or for any such Derivative +Works as a whole, provided Your use, reproduction, and distribution of the Work otherwise complies with the +conditions stated in this License. + +## 5. Submission of Contributions. + +Unless You explicitly state otherwise, any Contribution intentionally submitted for inclusion in the Work by +You to the Licensor shall be under the terms and conditions of this License, without any additional terms or +conditions. Notwithstanding the above, nothing herein shall supersede or modify the terms of any separate +license agreement you may have executed with Licensor regarding such Contributions. + +## 6. Trademarks. + +This License does not grant permission to use the trade names, trademarks, service marks, or product names of +the Licensor, except as required for reasonable and customary use in describing the origin of the Work and +reproducing the content of the NOTICE file. + +## 7. Disclaimer of Warranty. + +Unless required by applicable law or agreed to in writing, Licensor provides the Work (and each Contributor +provides its Contributions) on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express +or implied, including, without limitation, any warranties or conditions of TITLE, NON-INFRINGEMENT, +MERCHANTABILITY, or FITNESS FOR A PARTICULAR PURPOSE. You are solely responsible for determining the +appropriateness of using or redistributing the Work and assume any risks associated with Your exercise of +permissions under this License. + +## 8. Limitation of Liability. + +In no event and under no legal theory, whether in tort (including negligence), contract, or otherwise, unless +required by applicable law (such as deliberate and grossly negligent acts) or agreed to in writing, shall any +Contributor be liable to You for damages, including any direct, indirect, special, incidental, or consequential +damages of any character arising as a result of this License or out of the use or inability to use the Work +(including but not limited to damages for loss of goodwill, work stoppage, computer failure or malfunction, or +any and all other commercial damages or losses), even if such Contributor has been advised of the possibility +of such damages. + +## 9. Accepting Warranty or Additional Liability. + +While redistributing the Work or Derivative Works thereof, You may choose to offer, and charge a fee for, +acceptance of support, warranty, indemnity, or other liability obligations and/or rights consistent with this +License. However, in accepting such obligations, You may act only on Your own behalf and on Your sole +responsibility, not on behalf of any other Contributor, and only if You agree to indemnify, defend, and hold +each Contributor harmless for any liability incurred by, or claims asserted against, such Contributor by reason +of your accepting any such warranty or additional liability. + +END OF TERMS AND CONDITIONS diff --git a/vendor/aws/aws-sdk-php/NOTICE.md b/vendor/aws/aws-sdk-php/NOTICE.md new file mode 100644 index 0000000..8485853 --- /dev/null +++ b/vendor/aws/aws-sdk-php/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/aws-sdk-php/README.md b/vendor/aws/aws-sdk-php/README.md new file mode 100644 index 0000000..abadfd3 --- /dev/null +++ b/vendor/aws/aws-sdk-php/README.md @@ -0,0 +1,171 @@ +# AWS SDK for PHP + +[![Latest Stable Version](https://poser.pugx.org/aws/aws-sdk-php/version.png)](https://packagist.org/packages/aws/aws-sdk-php) +[![Total Downloads](https://poser.pugx.org/aws/aws-sdk-php/d/total.png)](https://packagist.org/packages/aws/aws-sdk-php) +[![Build Status](https://travis-ci.org/aws/aws-sdk-php.png)](https://travis-ci.org/aws/aws-sdk-php) +[![Code Coverage](https://scrutinizer-ci.com/g/aws/aws-sdk-php/badges/coverage.png?s=a5e380fe64b957af62cc52a999e77c0641c6bc91)](https://scrutinizer-ci.com/g/aws/aws-sdk-php/) + +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][install-zip] or +[phar][install-phar] file. + +## 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 + +**NEW:** Watch our video — **[Mastering the AWS SDK for PHP](http://youtu.be/_zaW2VZB1ok)** from AWS re:Invent 2013! + +## 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], [PEAR][install-pear], or single download ([zip][install-zip] + or [phar][install-phar]). +* 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 (e.g., [Phar][install-phar], [Zip][install-zip], [PEAR][install-pear]). +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 +get('s3'); + +// Upload a publicly accessible file. +// The file size, file type, and MD5 hash are automatically calculated by the SDK +try { + $s3->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 { + $s3->upload('my-bucket', 'my-object', fopen('/path/to/file', 'r'), '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. + +### 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 +[install-phar]: http://pear.amazonwebservices.com/get/aws.phar +[install-zip]: http://pear.amazonwebservices.com/get/aws.zip +[install-pear]: http://pear.amazonwebservices.com + +[docs-api]: http://docs.aws.amazon.com/aws-sdk-php/latest/index.html +[docs-guide]: http://docs.aws.amazon.com/aws-sdk-php/guide/latest/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/guide/latest/performance.html +[docs-migration]: http://docs.aws.amazon.com/aws-sdk-php/guide/latest/migration-guide.html +[docs-signup]: http://docs.aws.amazon.com/aws-sdk-php/guide/latest/awssignup.html +[docs-requirements]: http://docs.aws.amazon.com/aws-sdk-php/guide/latest/requirements.html +[docs-installation]: http://docs.aws.amazon.com/aws-sdk-php/guide/latest/installation.html +[docs-quickstart]: http://docs.aws.amazon.com/aws-sdk-php/guide/latest/quick-start.html +[docs-iterators]: http://docs.aws.amazon.com/aws-sdk-php/guide/latest/quick-start.html#iterators +[docs-waiters]: http://docs.aws.amazon.com/aws-sdk-php/guide/latest/feature-waiters.html +[docs-models]: http://docs.aws.amazon.com/aws-sdk-php/guide/latest/feature-models.html +[docs-exceptions]: http://docs.aws.amazon.com/aws-sdk-php/guide/latest/quick-start.html#error-handling +[docs-wire-logging]: http://docs.aws.amazon.com/aws-sdk-php/guide/latest/faq.html#how-can-i-see-what-data-is-sent-over-the-wire +[docs-services]: http://docs.aws.amazon.com/aws-sdk-php/guide/latest/index.html#supported-services +[docs-ddbsh]: http://docs.aws.amazon.com/aws-sdk-php/guide/latest/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/guide/latest/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/guide/latest/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/guide/latest/service-sqs.html#sending-messages +[example-s3-getobject]: http://docs.aws.amazon.com/aws-sdk-php/guide/latest/service-s3.html#saving-objects-to-a-file +[example-s3-multipart]: http://docs.aws.amazon.com/aws-sdk-php/guide/latest/service-s3.html#uploading-large-files-using-multipart-uploads +[example-dynamodb-putitem]: http://docs.aws.amazon.com/aws-sdk-php/guide/latest/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/aws-sdk-php/UPGRADING.md b/vendor/aws/aws-sdk-php/UPGRADING.md new file mode 100644 index 0000000..0984c41 --- /dev/null +++ b/vendor/aws/aws-sdk-php/UPGRADING.md @@ -0,0 +1,263 @@ +Upgrading Guide +=============== + +Upgrade from 2.5 to 2.6 +----------------------- + +**IMPORTANT:** Version 2.6 *is* backwards compatible with version 2.5, *unless* you are using the Amazon CloudSearch +client. If you are using CloudSearch, please read the next section carefully. + +### Amazon CloudSearch + +Version 2.6 of the AWS SDK for PHP has been updated to use the 2013-01-01 API version of Amazon CloudSearch by default. + +The 2013-01-01 API marks a significant upgrade of Amazon CloudSearch, but includes numerous breaking changes to the API. +CloudSearch now supports 33 languages, highlighting, autocomplete suggestions, geospatial search, AWS IAM integration to +control access to domain configuration actions, and user configurable scaling and availability options. These new +features are reflected in the changes to the method and parameters of the CloudSearch client. + +For details about the new API and how to update your usage of CloudSearch, please consult the [Configuration API +Reference for Amazon CloudSearch](http://docs.aws.amazon.com/cloudsearch/latest/developerguide/configuration-api.html) +and the guide for [Migrating to the Amazon CloudSearch 2013-01-01 API](http://docs.aws.amazon.com/cloudsearch/latest/developerguide/migrating.html). + +If you would like to continue using the older 2011-02-01 API, you can configure this when you instantiate the +`CloudSearchClient`: + +```php +use Aws\CloudSearch\CloudSearchClient; + +$client = CloudSearchClient::factory(array( + 'key' => '', + 'secret' => '', + 'region' => '', + 'version' => '2011-02-01', +)); +``` + +Upgrade from 2.4 to 2.5 +----------------------- + +### Amazon EC2 + +A small, backwards-incompatible change has been made to the Amazon EC2 API. The `LaunchConfiguration.MonitoringEnabled` +parameter of the `RequestSpotInstances` operation has been change to `LaunchConfiguration.Monitoring.Enabled` See [this +commit](https://github.com/aws/aws-sdk-php/commit/36ae0f68d2a6dcc3bc28222f60ecb318449c4092#diff-bad2f6eac12565bb684f2015364c22bd) +for the exact change. You are only affected by this change if you are using this specific parameter. To fix your code to +work with the updated parameter, you will need to change the structure of your request slightly. + +```php +// The OLD way +$result = $ec2->requestSpotInstances(array( + // ... + 'LaunchSpecification' => array( + // ... + 'MonitoringEnabled' => true, + // ... + ), + // ... +)); + +// The NEW way +$result = $ec2->requestSpotInstances(array( + // ... + 'LaunchSpecification' => array( + // ... + 'Monitoring' => array( + 'Enabled' => true, + ), + // ... + ), + // ... +)); +``` + +### AWS CloudTrail + +AWS CloudTrail has made changes to their API. If you are not using the CloudTrail service, then you will not be +affected by this change. + +Here is an excerpt (with minor modifications) directly from the [CloudTrail team's +announcement](https://forums.aws.amazon.com/ann.jspa?annID=2286) regarding this change: + +> [...] We have made some minor improvements/fixes to the service API, based on early feedback. The impact of these +> changes to you depends on how you are currently interacting with the CloudTrail service. [...] If you have code that +> calls the APIs below, you will need to make minor changes. +> +> There are two changes: +> +> 1) `CreateTrail` / `UpdateTrail`: These APIs originally took a single parameter, a `Trail` object. [...] We have +> changed this so that you can now simply pass individual parameters directly to these APIs. The same applies to the +> responses of these APIs, namely the APIs return individual fields directly [...] +> 2) `GetTrailStatus`: The actual values of the fields returned and their data types were not all as intended. As such, +> we are deprecating a set of fields, and adding a new set of replacement fields. The following fields are now +> deprecated, and should no longer be used: +> +> * `LatestDeliveryAttemptTime` (String): Time CloudTrail most recently attempted to deliver a file to S3 configured +> bucket. +> * `LatestNotificationAttemptTime` (String): As above, but for publishing a notification to configured SNS topic. +> * `LatestDeliveryAttemptSucceeded` (String): This one had a mismatch between implementation and documentation. As +> documented: whether or not the latest file delivery was successful. As implemented: Time of most recent successful +> file delivery. +> * `LatestNotificationAttemptSucceeded` (String): As above, but for SNS notifications. +> * `TimeLoggingStarted` (String): Time `StartLogging` was most recently called. [...] +> * `TimeLoggingStarted` (String): Time `StopLogging` was most recently called. +> +> The following fields are new, and replace the fields above: +> +> * `LatestDeliveryTime` (Date): Date/Time that CloudTrail most recently delivered a log file. +> * `LatestNotificationTime` (Date): As above, for SNS notifications. +> * `StartLoggingTime` (Date): Same as `TimeLoggingStarted`, but with more consistent naming, and correct data type. +> * `StopLoggingTime` (Date): Same as `TimeLoggingStopped`, but with more consistent naming, and correct data type. +> +> Note that `LatestDeliveryAttemptSucceeded` and `LatestNotificationAttemptSucceeded` have no direct replacement. To +> query whether everything is configured correctly for log file delivery, it is sufficient to query LatestDeliveryError, +> and if non-empty that means that there is a configuration problem preventing CloudTrail from being able to deliver +> logs successfully. Basically either the bucket doesn’t exist, or CloudTrail doesn’t have sufficient permissions to +> write to the configured path in the bucket. Likewise for `LatestNotificationAttemptSucceeded`. +> +> The deprecated fields will be removed in the future, no earlier than February 15. Both set of fields will coexist on +> the service during this period to give those who are using the deprecated fields time to switch over to the use the +> new fields. However new SDKs and CLIs will remove the deprecated fields sooner than that. Previous SDK and CLI +> versions will continue to work until the deprecated fields are removed from the service. +> +> We apologize for any inconvenience, and appreciate your understanding as we make these adjustments to improve the +> long-term usability of the CloudTrail APIs. + +We are marking this as a breaking change now, preemptive of the February 15th cutoff, and we encourage everyone to +update their code now. The changes to how you use `createTrail()` and `updateTrail()` are easy changes: + +```php +// The OLD way +$cloudTrail->createTrail(array( + 'trail' => array( + 'Name' => 'TRAIL_NAME', + 'S3BucketName' => 'BUCKET_NAME', + ) +)); + +// The NEW way +$cloudTrail->createTrail(array( + 'Name' => 'TRAIL_NAME', + 'S3BucketName' => 'BUCKET_NAME', +)); +``` + +### China (Beijing) Region / Signatures + +This release adds support for the new China (Beijing) Region. This region requires that Signature V4 be used for both +Amazon S3 and Amazon EC2 requests. We've added support for Signature V4 in both of these services for clients +configured for this region. While doing this work, we did some refactoring to the signature classes and also removed +support for Signature V3, as it is no longer needed. Unless you are explicitly referencing Signature V3 or explicitly +interacting with signature objects, these changes should not affect you. + +Upgrade from 2.3 to 2.4 +----------------------- + +### Amazon CloudFront Client + +The new 2013-05-12 API version of Amazon CloudFront includes support for custom SSL certificates via the +`ViewerCertificate` parameter, but also introduces breaking changes to the API. Version 2.4 of the SDK now ships with +two versions of the Amazon CloudFront service description, one for the new 2013-05-12 API and one for the next most +recent 2012-05-05 API. The SDK defaults to using the newest API version, so CloudFront users may experience a breaking +change to their projects when upgrading. This can be easily circumvented by switching back to the 2012-05-05 API by +using the `version` option when instantiating the CloudFront client. + +### Guzzle 3.7 + +Version 2.4 of the AWS SDK for PHP requires at least version 3.7 of Guzzle. + +Upgrade from 2.2 to 2.3 +----------------------- + +### Amazon DynamoDB Client + +The newly released 2012-08-10 API version of the Amazon DynamoDB service includes the new Local Secondary Indexes +feature, but also introduces breaking changes to the API. The most notable change is in the way that you specify keys +when creating tables and retrieving items. Version 2.3 of the SDK now ships with 2 versions of the DynamoDB service +description, one for the new 2012-08-10 API and one for the next most recent 2011-12-05 API. The SDK defaults to using +the newest API version, so DynamoDB users may experience a breaking change to their projects when upgrading. This can be +easily fixed by switching back to the 2011-12-05 API by using the new `version` configuration setting when instantiating +the DynamoDB client. + +```php +use Aws\DynamoDb\DynamoDbClient; + +$client = DynamoDbClient::factory(array( + 'key' => '', + 'secret' => '', + 'region' => '', + 'version' => '2011-12-05' +)); +``` + +If you are using a config file with `Aws\Common\Aws`, then you can modify your file like the following. + +```json +{ + "includes": ["_aws"], + "services": { + "default_settings": { + "params": { + "key": "", + "secret": "", + "region": "" + } + }, + "dynamodb": { + "extends": "dynamodb", + "params": { + "version": "2011-12-05" + } + } + } +} +``` + +The [SDK user guide](http://docs.aws.amazon.com/aws-sdk-php/guide/latest/index.html) has a guide and examples for both +versions of the API. + +### Guzzle 3.4.1 + +Version 2.3 of the AWS SDK for PHP requires at least version 3.4.1 of Guzzle. + +Upgrade from 2.1 to 2.2 +----------------------- + +### Full Service Coverage + +The AWS SDK for PHP now supports the full set of AWS services. + +### Guzzle 3.3 + +Version 2.2 of the AWS SDK for PHP requires at least version 3.3 of Guzzle. + +Upgrade from 2.0 to 2.1 +----------------------- + +### General + +Service descriptions are now versioned under the Resources/ directory of each client. + +### Waiters + +Waiters now require an associative array as input for the underlying operation performed by a waiter. The configuration +system for waiters under 2.0.x utilized strings to determine the parameters used to create an operation. For example, +when waiting for an object to exist with Amazon S3, you would pass a string containing the bucket name concatenated +with the object name using a '/' separator (e.g. 'foo/baz'). In the 2.1 release, these parameters are now more +explicitly tied to the underlying operation utilized by a waiter. For example, to use the ObjectExists waiter of +Amazon S3 pass an associative array of `array('Bucket' => 'foo', 'Key' => 'baz')`. These options match the option names +and rules associated with the HeadObject operation performed by the waiter. The API documentation of each client +describes the waiters associated with the client and what underlying operation is responsible for waiting on the +resource. Waiter specific options like the maximum number of attempts (max_attempts) or interval to wait between +retries (interval) can be specified in this same configuration array by prefixing the keys with `waiter.`. + +Waiters can also be invoked using magic methods on the client. These magic methods are listed in each client's docblock +using `@method` tags. + +```php +$s3Client->waitUntilObjectExists(array( + 'Bucket' => 'foo', + 'Key' => 'bar', + 'waiter.max_attempts' => 3 +)); +``` diff --git a/vendor/aws/aws-sdk-php/build.xml b/vendor/aws/aws-sdk-php/build.xml new file mode 100644 index 0000000..f4c5cde --- /dev/null +++ b/vendor/aws/aws-sdk-php/build.xml @@ -0,0 +1,254 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + php -d mock=true `which phpunit` -c phpunit.functional.xml + + + + + + + + + You must copy phpunit.functional.dist to phpunit.functional.xml and modify the appropriate property settings + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/vendor/aws/aws-sdk-php/build/aws-autoloader.php b/vendor/aws/aws-sdk-php/build/aws-autoloader.php new file mode 100644 index 0000000..2b7d7ac --- /dev/null +++ b/vendor/aws/aws-sdk-php/build/aws-autoloader.php @@ -0,0 +1,35 @@ +registerNamespaces(array( + 'Aws' => AWS_FILE_PREFIX, + 'Guzzle' => AWS_FILE_PREFIX, + 'Symfony' => AWS_FILE_PREFIX, + 'Doctrine' => AWS_FILE_PREFIX, + 'Psr' => AWS_FILE_PREFIX, + 'Monolog' => AWS_FILE_PREFIX +)); + +$classLoader->register(); + +return $classLoader; diff --git a/vendor/aws/aws-sdk-php/build/phar-stub.php b/vendor/aws/aws-sdk-php/build/phar-stub.php new file mode 100644 index 0000000..5c36dcc --- /dev/null +++ b/vendor/aws/aws-sdk-php/build/phar-stub.php @@ -0,0 +1,36 @@ +isCli = php_sapi_name() == 'cli'; + $title = 'AWS SDK for PHP Compatibility Test'; + if ($this->isCli) { + $rep = str_repeat('=', strlen($title)); + $this->lines[] = "{$rep}\n{$title}\n{$rep}"; + } else { + $this->lines[] = sprintf( + '', + 'html {font-family:verdana;} .OK {color: #166116;}', + '.FAIL {margin-top: 1em; color: #A52C27;} .WARNING {margin-top: 1em; color:#6B036B;}' + ); + $this->lines[] = "

{$title}

"; + } + } + + public function endTest() + { + $text = implode("\n", $this->lines); + echo $this->isCli ? $text : "{$text}"; + } + + public function title($text) + { + $this->lines[] = $this->isCli + ? "\n" . $text . "\n" . str_repeat('-', strlen($text)) . "\n" + : "

{$text}

"; + } + + public function write($text) + { + $this->lines[] = $text; + } + + public function quote($text) + { + return !$this->isCli + ? "
{$text}
" + : implode("\n", array_map(function ($t) { return ' ' . $t; }, explode("\n", $text))); + } + + public function check($info, $func, $text, $required) + { + $level = $func() ? 'OK' : ($required ? 'FAIL' : 'WARNING'); + if ($this->isCli) { + $text = $level == 'OK' ? "- {$info}: [OK]" : "- {$info}: [{$level}]\n - {$text}"; + } else { + $text = $level == 'OK' + ? "{$info}
" + : "
{$info}: [{$level}]
{$text}
"; + } + $this->write($text); + } + + public function addRecommend($info, $func, $text) + { + $this->check($info, $func, $text, false); + } + + public function addRequire($info, $func, $text) + { + $this->check($info, $func, $text, true); + } + + public function iniCheck($info, $setting, $expected, $required = true, $help = null) + { + $current = ini_get($setting); + $cb = function () use ($current, $expected) { + return is_callable($expected) + ? call_user_func($expected, $current) + : $current == $expected; + }; + + $message = sprintf( + '%s in %s is currently set to %s but %s be set to %s.', + $setting, + php_ini_loaded_file(), + var_export($current, true), + $required ? 'must' : 'should', + var_export($expected, true) + ) . ' ' . $help; + + $this->check($info, $cb, trim($message), $required); + } + + public function extCheck($ext, $required = true, $help = '') + { + $info = sprintf('Checking if the %s extension is installed', $ext); + $cb = function () use ($ext) { return extension_loaded($ext); }; + $message = $help ?: sprintf('The %s extension %s be installed', $ext, $required ? 'must' : 'should'); + $this->check($info, $cb, $message, $required); + } +} + +$c = new CompatibilityTest(); +$c->title('System requirements'); +$c->addRequire( + 'Ensuring that the version of PHP is >= 5.3.3', + function () { return version_compare(phpversion(), '5.3.3', '>='); }, + 'You must update your version of PHP to 5.3.3 to run the AWS SDK for PHP' +); + +$c->iniCheck('Ensuring that detect_unicode is disabled', 'detect_unicode', false, true, 'Enabling detect_unicode may cause errors when using phar files. See https://bugs.php.net/bug.php?id=42396'); +$c->iniCheck('Ensuring that session.auto_start is disabled', 'session.auto_start', false); + +if (extension_loaded('suhosin')) { + $c->addRequire( + 'Ensuring that phar files can be run with the suhosin patch', + function () { + return false !== stripos(ini_get('suhosin.executor.include.whitelist'), 'phar'); + }, + sprintf('suhosin.executor.include.whitelist must be configured to include "phar" in %s so that the phar file works correctly', php_ini_loaded_file()) + ); +} + +foreach (array('pcre', 'spl', 'json', 'dom', 'simplexml', 'curl') as $ext) { + $c->extCheck($ext, true); +} + +if (function_exists('curl_version')) { + $c->addRequire('Ensuring that cURL can send https requests', function () { + $version = curl_version(); + return in_array('https', $version['protocols'], true); + }, 'cURL must be able to send https requests'); +} + +$c->addRequire('Ensuring that file_get_contents works', function () { + return function_exists('file_get_contents'); +}, 'file_get_contents has been disabled'); + +$c->title('System recommendations'); + +$c->addRecommend( + 'Checking if PHP version is >= 5.4.1', + function () { return version_compare(phpversion(), '5.4.1', '>='); }, + 'You are using an older version of PHP (' . phpversion() . '). Consider updating to PHP 5.4.1 or newer to improve the performance and stability of the SDK.' +); + +$c->addRecommend('Checking if you are running on a 64-bit platform', function () { + return PHP_INT_MAX === 9223372036854775807; +}, 'You are not running on a 64-bit installation of PHP. You may run into issues uploading or downloading files larger than 2GB.'); + +$c->iniCheck('Ensuring that zend.enable_gc is enabled', 'zend.enable_gc', true, false); + +$c->check('Ensuring that date.timezone is set', function () { + return (bool) ini_get('date.timezone'); +}, 'The date.timezone PHP ini setting has not been set in ' . php_ini_loaded_file(), false); + +if (extension_loaded('xdebug')) { + $c->addRecommend('Checking if Xdebug is installed', function () { return false; }, 'Xdebug is installed. Consider uninstalling Xdebug to make the SDK run much faster.'); + $c->iniCheck('Ensuring that Xdebug\'s infinite recursion detection does not erroneously cause a fatal error', 'xdebug.max_nesting_level', 0, false); +} + +$c->extCheck('openssl', false); +$c->extCheck('zlib', false); +$c->extCheck('uri_template', false, 'Installing the uri_template extension will make the SDK faster. Install using pecl install uri_template-alpha'); + +// Is an opcode cache installed or are they running >= PHP 5.5? +$c->addRecommend( + 'Checking if an opcode cache is installed', + function () { + return version_compare(phpversion(), '5.5.0', '>=') || extension_loaded('apc') || extension_loaded('xcache'); + }, + 'You are not utilizing an opcode cache. Consider upgrading to PHP >= 5.5 or install APC.' +); + +$c->title('PHP information'); +ob_start(); +phpinfo(INFO_GENERAL); +$info = ob_get_clean(); +$c->write($c->quote($info)); + +$c->endTest(); diff --git a/vendor/aws/aws-sdk-php/composer.json b/vendor/aws/aws-sdk-php/composer.json new file mode 100755 index 0000000..fd7cabd --- /dev/null +++ b/vendor/aws/aws-sdk-php/composer.json @@ -0,0 +1,47 @@ +{ + "name": "aws/aws-sdk-php", + "homepage": "http://aws.amazon.com/sdkforphp", + "description": "AWS SDK for PHP - Use Amazon Web Services in your PHP project", + "keywords": ["aws","amazon","sdk","s3","ec2","dynamodb","cloud","glacier"], + "type": "library", + "license": "Apache-2.0", + "authors": [ + { + "name": "Amazon Web Services", + "homepage": "http://aws.amazon.com" + } + ], + "support": { + "forum": "https://forums.aws.amazon.com/forum.jspa?forumID=80", + "issues": "https://github.com/aws/aws-sdk-php/issues" + }, + "require": { + "php": ">=5.3.3", + "guzzle/guzzle": ">=3.7.0,<=3.9.9" + }, + "suggest": { + "doctrine/cache": "Adds support for caching of credentials and responses", + "ext-apc": "Allows service description opcode caching, request and response caching, and credentials caching", + "ext-openssl": "Allows working with CloudFront private distributions and verifying received SNS messages", + "monolog/monolog": "Adds support for logging HTTP requests and responses", + "symfony/yaml": "Eases the ability to write manifests for creating jobs in AWS Import/Export" + }, + "require-dev": { + "doctrine/cache": "~1.0", + "ext-openssl": "*", + "monolog/monolog": "1.4.*", + "phpunit/phpunit": "3.7.*", + "symfony/class-loader": "2.*", + "symfony/yaml": "2.*" + }, + "autoload": { + "psr-0": { + "Aws": "src/" + } + }, + "extra": { + "branch-alias": { + "dev-master": "2.6.x-dev" + } + } +} diff --git a/vendor/aws/aws-sdk-php/docs/Makefile b/vendor/aws/aws-sdk-php/docs/Makefile new file mode 100644 index 0000000..3c2a1b0 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/Makefile @@ -0,0 +1,160 @@ +# Makefile for Sphinx documentation +# + +# You can set these variables from the command line. +SPHINXOPTS = +SPHINXBUILD = sphinx-build +PAPER = +BUILDDIR = _build +TRACKING = + +# Internal variables. +PAPEROPT_a4 = -D latex_paper_size=a4 +PAPEROPT_letter = -D latex_paper_size=letter +ALLSPHINXOPTS = -d $(BUILDDIR)/doctrees $(PAPEROPT_$(PAPER)) $(SPHINXOPTS) . +# the i18n builder cannot share the environment and doctrees with the others +I18NSPHINXOPTS = $(PAPEROPT_$(PAPER)) $(SPHINXOPTS) . + +.PHONY: help clean html dirhtml singlehtml pickle json htmlhelp qthelp devhelp epub latex latexpdf text man changes linkcheck doctest gettext + +help: + @echo "Please use \`make ' where is one of" + @echo " html to make standalone HTML files" + @echo " pdf to make PDF files" + @echo " dirhtml to make HTML files named index.html in directories" + @echo " singlehtml to make a single large HTML file" + @echo " pickle to make pickle files" + @echo " json to make JSON files" + @echo " htmlhelp to make HTML files and a HTML help project" + @echo " qthelp to make HTML files and a qthelp project" + @echo " devhelp to make HTML files and a Devhelp project" + @echo " epub to make an epub" + @echo " latex to make LaTeX files, you can set PAPER=a4 or PAPER=letter" + @echo " latexpdf to make LaTeX files and run them through pdflatex" + @echo " text to make text files" + @echo " man to make manual pages" + @echo " texinfo to make Texinfo files" + @echo " info to make Texinfo files and run them through makeinfo" + @echo " gettext to make PO message catalogs" + @echo " changes to make an overview of all changed/added/deprecated items" + @echo " linkcheck to check all external links for integrity" + @echo " doctest to run all doctests embedded in the documentation (if enabled)" + +clean: + -rm -rf $(BUILDDIR)/* + +html: + $(SPHINXBUILD) -b html $(ALLSPHINXOPTS) $(BUILDDIR)/html + @echo + @echo "Build finished. The HTML pages are in $(BUILDDIR)/html." + +pdf: + $(SPHINXBUILD) -b pdf $(ALLSPHINXOPTS) $(BUILDDIR)/pdf + @echo + @echo "Build finished. The PDF file is in $(BUILDDIR)/pdf." + +dirhtml: + $(SPHINXBUILD) -b dirhtml $(ALLSPHINXOPTS) $(BUILDDIR)/dirhtml + @echo + @echo "Build finished. The HTML pages are in $(BUILDDIR)/dirhtml." + +singlehtml: + $(SPHINXBUILD) -b singlehtml $(ALLSPHINXOPTS) $(BUILDDIR)/singlehtml + @echo + @echo "Build finished. The HTML page is in $(BUILDDIR)/singlehtml." + +pickle: + $(SPHINXBUILD) -b pickle $(ALLSPHINXOPTS) $(BUILDDIR)/pickle + @echo + @echo "Build finished; now you can process the pickle files." + +json: + $(SPHINXBUILD) -b json $(ALLSPHINXOPTS) $(BUILDDIR)/json + @echo + @echo "Build finished; now you can process the JSON files." + +htmlhelp: + $(SPHINXBUILD) -b htmlhelp $(ALLSPHINXOPTS) $(BUILDDIR)/htmlhelp + @echo + @echo "Build finished; now you can run HTML Help Workshop with the" \ + ".hhp project file in $(BUILDDIR)/htmlhelp." + +qthelp: + $(SPHINXBUILD) -b qthelp $(ALLSPHINXOPTS) $(BUILDDIR)/qthelp + @echo + @echo "Build finished; now you can run "qcollectiongenerator" with the" \ + ".qhcp project file in $(BUILDDIR)/qthelp, like this:" + @echo "# qcollectiongenerator $(BUILDDIR)/qthelp/AWSSDKforPHP.qhcp" + @echo "To view the help file:" + @echo "# assistant -collectionFile $(BUILDDIR)/qthelp/AWSSDKforPHP.qhc" + +devhelp: + $(SPHINXBUILD) -b devhelp $(ALLSPHINXOPTS) $(BUILDDIR)/devhelp + @echo + @echo "Build finished." + @echo "To view the help file:" + @echo "# mkdir -p $$HOME/.local/share/devhelp/AWSSDKforPHP" + @echo "# ln -s $(BUILDDIR)/devhelp $$HOME/.local/share/devhelp/AWSSDKforPHP" + @echo "# devhelp" + +epub: + $(SPHINXBUILD) -b epub $(ALLSPHINXOPTS) $(BUILDDIR)/epub + @echo + @echo "Build finished. The epub file is in $(BUILDDIR)/epub." + +latex: + $(SPHINXBUILD) -b latex $(ALLSPHINXOPTS) $(BUILDDIR)/latex + @echo + @echo "Build finished; the LaTeX files are in $(BUILDDIR)/latex." + @echo "Run \`make' in that directory to run these through (pdf)latex" \ + "(use \`make latexpdf' here to do that automatically)." + +latexpdf: + $(SPHINXBUILD) -b latex $(ALLSPHINXOPTS) $(BUILDDIR)/latex + @echo "Running LaTeX files through pdflatex..." + $(MAKE) -C $(BUILDDIR)/latex all-pdf + @echo "pdflatex finished; the PDF files are in $(BUILDDIR)/latex." + +text: + $(SPHINXBUILD) -b text $(ALLSPHINXOPTS) $(BUILDDIR)/text + @echo + @echo "Build finished. The text files are in $(BUILDDIR)/text." + +man: + $(SPHINXBUILD) -b man $(ALLSPHINXOPTS) $(BUILDDIR)/man + @echo + @echo "Build finished. The manual pages are in $(BUILDDIR)/man." + +texinfo: + $(SPHINXBUILD) -b texinfo $(ALLSPHINXOPTS) $(BUILDDIR)/texinfo + @echo + @echo "Build finished. The Texinfo files are in $(BUILDDIR)/texinfo." + @echo "Run \`make' in that directory to run these through makeinfo" \ + "(use \`make info' here to do that automatically)." + +info: + $(SPHINXBUILD) -b texinfo $(ALLSPHINXOPTS) $(BUILDDIR)/texinfo + @echo "Running Texinfo files through makeinfo..." + make -C $(BUILDDIR)/texinfo info + @echo "makeinfo finished; the Info files are in $(BUILDDIR)/texinfo." + +gettext: + $(SPHINXBUILD) -b gettext $(I18NSPHINXOPTS) $(BUILDDIR)/locale + @echo + @echo "Build finished. The message catalogs are in $(BUILDDIR)/locale." + +changes: + $(SPHINXBUILD) -b changes $(ALLSPHINXOPTS) $(BUILDDIR)/changes + @echo + @echo "The overview file is in $(BUILDDIR)/changes." + +linkcheck: + $(SPHINXBUILD) -b linkcheck $(ALLSPHINXOPTS) $(BUILDDIR)/linkcheck + @echo + @echo "Link check complete; look for any errors in the above output " \ + "or in $(BUILDDIR)/linkcheck/output.txt." + +doctest: + $(SPHINXBUILD) -b doctest $(ALLSPHINXOPTS) $(BUILDDIR)/doctest + @echo "Testing of doctests in the sources finished, look at the " \ + "results in $(BUILDDIR)/doctest/output.txt." diff --git a/vendor/aws/aws-sdk-php/docs/README.md b/vendor/aws/aws-sdk-php/docs/README.md new file mode 100644 index 0000000..04328ba --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/README.md @@ -0,0 +1,13 @@ +AWS SDK for PHP +=============== + +Documentation for the [AWS SDK for PHP](https://github.com/aws/aws-sdk-php). + +Building the documentation +-------------------------- + +The documentation is written in [reStructuredText](http://docutils.sourceforge.net/rst.html) and can be built using +[Sphinx](http://sphinx.pocoo.org/). + +1. pip install -r requirements.txt +2. Make the HTML documentation: ``make html`` diff --git a/vendor/aws/aws-sdk-php/docs/_ext/aws/__init__.py b/vendor/aws/aws-sdk-php/docs/_ext/aws/__init__.py new file mode 100644 index 0000000..aa0d934 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/_ext/aws/__init__.py @@ -0,0 +1,368 @@ +import os, re, subprocess, json, collections +from sphinx.addnodes import toctree +from docutils import io, nodes, statemachine, utils +from docutils.parsers.rst import Directive +from jinja2 import Environment, PackageLoader + +# Maintain a cache of previously loaded examples +example_cache = {} + +# Maintain a cache of previously loaded service descriptions +description_cache = {} + + +def setup(app): + """ + see: http://sphinx.pocoo.org/ext/appapi.html + this is the primary extension point for Sphinx + """ + from sphinx.application import Sphinx + if not isinstance(app, Sphinx): return + + app.add_role('regions', regions_role) + app.add_directive('service', ServiceIntro) + app.add_directive('apiref', ServiceApiRef) + app.add_directive('indexlinks', ServiceIndexLinks) + app.add_directive('example', ExampleDirective) + + +def regions_role(name, rawtext, text, lineno, inliner, options={}, content={}): + """Inserts a list of regions available to a service name + + Returns 2 part tuple containing list of nodes to insert into the + document and a list of system messages. Both are allowed to be + empty. + + :param name: The role name used in the document. + :param rawtext: The entire markup snippet, with role. + :param text: The text marked with the role. + :param lineno: The line number where rawtext appears in the input. + :param inliner: The inliner instance that called us. + :param options: Directive options for customization. + :param content: The directive content for customization. + """ + try: + service_name = str(text) + if not service_name: + raise ValueError + app = inliner.document.settings.env.app + node = make_regions_node(rawtext, app, str(service_name), options) + return [node], [] + except ValueError: + msg = inliner.reporter.error( + 'The service name "%s" is invalid; ' % text, line=lineno) + prb = inliner.problematic(rawtext, rawtext, msg) + return [prb], [msg] + + +def get_regions(service_name): + """Get the regions for a service by name + + Returns a list of regions + + :param service_name: Retrieve regions for this service by name + """ + return load_service_description(service_name)['regions'].keys() + + +def make_regions_node(rawtext, app, service_name, options): + """Create a list of regions for a service name + + :param rawtext: Text being replaced with the list node. + :param app: Sphinx application context + :param service_name: Service name + :param options: Options dictionary passed to role func. + """ + regions = get_regions(service_name) + return nodes.Text(", ".join(regions)) + + +class ServiceDescription(): + """ + Loads the service description for a given source file + """ + + def __init__(self, service): + self.service_name = service + self.description = self.load_description(self.determine_filename()) + + def determine_filename(self): + """Determines the filename to load for a service""" + # Determine the path to the aws-config + path = os.path.abspath("../src/Aws/Common/Resources/aws-config.php") + self.config = self.__load_php(path) + + # Iterate over the loaded dictionary and see if a matching service exists + for key in self.config["services"]: + alias = self.config["services"][key].get("alias", "") + if key == self.service_name or alias == self.service_name: + break + else: + raise ValueError("No service matches %s" % (self.service_name)) + + # Determine the name of the client class to load + class_path = self.config["services"][key]["class"].replace("\\", "/") + client_path = os.path.abspath("../src/" + class_path + ".php") + contents = open(client_path, 'r').read() + + # Determine the current version of the client (look at the LATEST_API_VERSION constant value) + version = re.search("LATEST_API_VERSION = '(.+)'", contents).groups(0)[0] + + # Determine the name of the service description used by the client + matches = re.search("__DIR__ \. '/Resources/(.+)\.php'", contents) + description = matches.groups(0)[0] % (version) + + # Strip the filename of the client and determine the description path + service_path = "/".join(client_path.split(os.sep)[0:-1]) + service_path += "/Resources/" + description + ".php" + + return service_path + + def load_description(self, path): + """Determines the filename to load for a service + + :param path: Path to a service description to load + """ + return self.__load_php(path) + + def __load_php(self, path): + """Load a PHP script that returns an array using JSON + + :param path: Path to the script to load + """ + path = os.path.abspath(path) + + # Make command to each environment Linux/Mac and Windows + if os.name == 'nt': + sh = 'php -r \"$c = include \'' + path + '\'; echo json_encode($c);\"' + else: + sh = 'php -r \'$c = include "' + path + '"; echo json_encode($c);\'' + + loaded = subprocess.check_output(sh, shell=True) + return json.loads(loaded) + + def __getitem__(self, i): + """Allows access to the service description items via the class""" + return self.description.get(i) + + +def load_service_description(name): + if name not in description_cache: + description_cache[name] = ServiceDescription(name) + return description_cache[name] + + +class ServiceDescriptionDirective(Directive): + """ + Base class for directives that use information from service descriptions + """ + + required_arguments = 1 + optional_arguments = 1 + final_argument_whitespace = True + + def run(self): + if len(self.arguments) == 2: + api_version = self.arguments[1].strip() + else: + api_version = "" + service_name = self.arguments[0].strip() + service_description = load_service_description(service_name) + + rawtext = self.generate_rst(service_description, api_version) + tab_width = 4 + include_lines = statemachine.string2lines( + rawtext, tab_width, convert_whitespace=1) + self.state_machine.insert_input( + include_lines, os.path.abspath(__file__)) + return [] + + def get_service_doc_url(self, namespace): + """Determine the documentation link for a service""" + namespace = namespace.lower() + if namespace == "sts": + return "http://aws.amazon.com/documentation/iam/" + else: + return "http://aws.amazon.com/documentation/" + namespace + + def get_api_ref_url(self, namespace): + """Determine the PHP API documentation link for a service""" + return "http://docs.aws.amazon.com/aws-sdk-php/latest/class-Aws." + namespace + "." + namespace + "Client.html" + + def get_locator_name(self, name): + """Determine the service locator name for an endpoint""" + return name + + +class ServiceIntro(ServiceDescriptionDirective): + """ + Creates a service introduction to inject into a document + """ + + def generate_rst(self, d, api_version): + rawtext = "" + scalar = {} + + # Grab all of the simple strings from the description + for key in d.description: + if isinstance(d[key], str) or isinstance(d[key], unicode): + scalar[key] = d[key] + # Add substitutions for top-level data in a service description + rawtext += ".. |%s| replace:: %s\n\n" % (key, scalar[key]) + + # Determine the doc URL + docs = self.get_service_doc_url(d["namespace"]) + + # Determine the "namespace" used for linking to API docs + if api_version: + apiVersionSuffix = "_" + api_version.replace("-", "_") + else: + apiVersionSuffix = "" + + env = Environment(loader=PackageLoader('aws', 'templates')) + template = env.get_template("client_intro") + rawtext += template.render( + scalar, + regions=get_regions(d["namespace"]), + doc_url=docs, + specifiedApiVersion=api_version, + apiVersionSuffix=apiVersionSuffix) + + return rawtext + + +class ServiceApiRef(ServiceDescriptionDirective): + """ + Inserts a formatted PHPUnit example into the source + """ + + def generate_rst(self, d, api_version): + rawtext = "" + scalar = {} + # Sort the operations by key + operations = collections.OrderedDict(sorted(d.description['operations'].items())) + + # Grab all of the simple strings from the description + for key in d.description: + if isinstance(d[key], str) or isinstance(d[key], unicode): + scalar[key] = d[key] + # Add substitutions for top-level data in a service description + rawtext += ".. |%s| replace:: %s\n\n" % (key, scalar[key]) + + # Add magic methods to each operation + for key in operations: + operations[key]['magicMethod'] = key[0].lower() + key[1:] + + # Set the ordered dict of operations on the description + d.description['operations'] = operations + + # Determine the "namespace" used for linking to API docs + if api_version: + apiVersionSuffix = "_" + api_version.replace("-", "_") + else: + apiVersionSuffix = "" + + env = Environment(loader=PackageLoader('aws', 'templates')) + template = env.get_template("api_reference") + rawtext += template.render( + scalar, + description=d.description, + regions=get_regions(d["namespace"]), + apiVersionSuffix=apiVersionSuffix) + + return rawtext + + +class ServiceIndexLinks(ServiceDescriptionDirective): + """ + Inserts a formatted PHPUnit example into the source + """ + + def generate_rst(self, service_description, api_version): + d = service_description.description + + service_name = d["serviceFullName"] + if "serviceAbbreviation" in d: + service_name = d["serviceAbbreviation"] + + rawtext = "* :doc:`Using the " + service_name + " PHP client `\n"; + rawtext += "* `PHP API reference <" + self.get_api_ref_url(d["namespace"]) + ">`_\n"; + #rawtext += "* `General service documentation for " + service_name + " <" + self.get_service_doc_url(d["namespace"]) + ">`_\n"; + + return rawtext + + +class ExampleDirective(Directive): + """ + Inserts a formatted PHPUnit example into the source + """ + + # Directive configuration + required_arguments = 2 + optional_arguments = 0 + final_argument_whitespace = True + + def run(self): + self.end_function = " }\n" + self.begin_tag = " // @begin\n" + self.end_tag = " // @end\n" + + example_file = self.arguments[0].strip() + example_name = self.arguments[1].strip() + + if not example_name: + raise ValueError("Must specify both an example file and example name") + + contents = self.load_example(example_file, example_name) + rawtext = self.generate_rst(contents) + tab_width = 4 + include_lines = statemachine.string2lines( + rawtext, tab_width, convert_whitespace=1) + self.state_machine.insert_input( + include_lines, os.path.abspath(__file__)) + return [] + + def load_example(self, example_file, example_name): + """Loads the contents of an example and strips out non-example parts""" + key = example_file + '.' + example_name + + # Check if this example is cached already + if key in example_cache: + return example_cache[key] + + # Not cached, so index the example file functions + path = os.path.abspath(__file__ + "/../../../../tests/Aws/Tests/" + example_file) + + f = open(path, 'r') + in_example = False + capturing = False + buffer = "" + + # Scan each line of the file and create example hashes + for line in f: + if in_example: + if line == self.end_function: + if in_example: + example_cache[in_example] = buffer + buffer = "" + in_example = False + elif line == self.begin_tag: + # Look for the opening // @begin tag to begin capturing + buffer = "" + capturing = True + elif line == self.end_tag: + # Look for the optional closing tag to stop capturing + capturing = False + elif capturing: + buffer += line + elif "public function test" in line: + # Grab the function name from the line and keep track of the + # name of the current example being captured + current_name = re.search('function (.+)\s*\(', line).group(1) + in_example = example_file + "." + current_name + f.close() + return example_cache[key] + + def generate_rst(self, contents): + rawtext = ".. code-block:: php\n\n" + contents + return rawtext diff --git a/vendor/aws/aws-sdk-php/docs/_ext/aws/templates/api_reference b/vendor/aws/aws-sdk-php/docs/_ext/aws/templates/api_reference new file mode 100644 index 0000000..069a61c --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/_ext/aws/templates/api_reference @@ -0,0 +1,28 @@ + +API Reference +------------- + +Please see the `{{ serviceFullName }} Client API reference `_ +for a details about all of the available methods, including descriptions of the inputs and outputs. + +{# Here we are creating a list-table. The contents of a list-table looks like: + * - Foo + - Bar + * - Baz + - Bam + + We must also ensure that the same number of columns are available for each table row. +#} + +.. list-table:: + :header-rows: 0 + :stub-columns: 0 + :class: two-column + + {% for key, op in description.operations.iteritems() %} + {% if loop.index is odd %}* {% else %} {% endif %}- `{{ key }} `_ + {%- if op.documentationUrl %} (`service docs <{{ op.documentationUrl}}>`_){%- endif %} + {%- if loop.last and loop.index is odd %} + - + {%- endif %} + {% endfor %} diff --git a/vendor/aws/aws-sdk-php/docs/_ext/aws/templates/client_intro b/vendor/aws/aws-sdk-php/docs/_ext/aws/templates/client_intro new file mode 100644 index 0000000..92c93a4 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/_ext/aws/templates/client_intro @@ -0,0 +1,72 @@ +==================================================================================== +{{serviceFullName}}{% if specifiedApiVersion %} ({{specifiedApiVersion}}){% endif %} +==================================================================================== + +This guide focuses on the AWS SDK for PHP client for `{{ serviceFullName }} <{{ doc_url }}>`_. This guide assumes that +you have already downloaded and installed the AWS SDK for PHP. See :doc:`installation` for more information on +getting started. + +{% if specifiedApiVersion %} +**Note:** This guide is for the **{{ specifiedApiVersion }}** API version of {{ serviceFullName }}. You may also be +interested in the :doc:`guide for the latest API version of {{ serviceFullName }} `. +{% endif %} + +Creating a client +----------------- + +First you need to create a client object using one of the following techniques. + +Factory method +~~~~~~~~~~~~~~ + +The easiest way to get up and running quickly is to use the ``Aws\{{namespace}}\{{namespace}}Client::factory()`` method +and provide your credential profile (via the ``profile`` option), which identifies the set of credentials you want to +use from your ``~/.aws/credentials`` file (see :ref:`credential_profiles`). + +{% if not globalEndpoint -%} +A ``region`` parameter is also required and must be set to one of the following values: ``{{ regions|join("``, ``") }}`` +{% endif %} + +.. code-block:: php + + use Aws\{{namespace}}\{{namespace}}Client; + + $client = {{namespace}}Client::factory(array( + 'profile' => ''{% if not globalEndpoint -%}, + 'region' => ''{% endif %}{% if specifiedApiVersion -%}, + 'version' => '{{specifiedApiVersion}}'{% endif %} + )); + +You can provide your credential profile like in the preceding example, specify your access keys directly (via ``key`` +and ``secret``), or you can choose to omit any credential information if you are using `AWS Identity and Access +Management (IAM) roles for EC2 instances `_ +or credentials sourced from the ``AWS_ACCESS_KEY_ID`` and ``AWS_SECRET_ACCESS_KEY`` environment variables. + +.. note:: + + The ``profile`` option and AWS credential file support is only available for version 2.6.1 of the SDK and higher. + We recommend that all users update their copies of the SDK to take advantage of this feature, which is a safer way + to specify credentials than explicitly providing ``key`` and ``secret``. + +Service builder +~~~~~~~~~~~~~~~ + +A more robust way to connect to {{ serviceFullName }} is through the service builder. This allows you to specify +credentials and other configuration settings in a configuration file. These settings can then be shared across all +clients so that you only have to specify your settings once. + +.. code-block:: php + + use Aws\Common\Aws; + + // Create a service builder using a configuration file + $aws = Aws::factory('/path/to/my_config.json'); + + // Get the client from the builder by namespace + {% if specifiedApiVersion -%} + $client = $aws->get('{{ namespace|lower() }}_{{ apiVersionSuffix|replace("_", "") }}'); + {% else -%} + $client = $aws->get('{{ namespace }}'); + {% endif %} + +.. _{{ namespace }}{{ apiVersionSuffix }}_operations: diff --git a/vendor/aws/aws-sdk-php/docs/_snippets/incomplete.txt b/vendor/aws/aws-sdk-php/docs/_snippets/incomplete.txt new file mode 100644 index 0000000..c655a2d --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/_snippets/incomplete.txt @@ -0,0 +1,10 @@ +------------------------------ + +.. admonition:: This guide is incomplete + + This guide is not quite finished. If you are looking for a good way to contribute to the SDK and to the rest of + the AWS PHP community, then helping to write documentation is a great place to start. Our guides are written + in `ReStructuredText `_ and generated using + `Sphinx `_. Feel free to add some content to our documentation and send a pull request + to https://github.com/aws/aws-sdk-php. You can view our documentation sources at + https://github.com/aws/aws-sdk-php/tree/master/docs. diff --git a/vendor/aws/aws-sdk-php/docs/_snippets/iterators-intro.txt b/vendor/aws/aws-sdk-php/docs/_snippets/iterators-intro.txt new file mode 100644 index 0000000..9f16e63 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/_snippets/iterators-intro.txt @@ -0,0 +1,21 @@ +Some AWS operations return truncated results that require subsequent requests in order to retrieve the entire result +set. The subsequent requests typically require pagination tokens or markers from the previous request in order to +retrieve the next set of results. Working with these tokens can be cumbersome, since you must manually keep track of +them, and the API for each service you are using may differ in the names and details of the tokens. + +The AWS SDK for PHP has a feature called **Iterators** that allow you to retrieve an *entire* result set without +manually handling pagination tokens or markers. The Iterators in the SDK implement PHP's ``Iterator`` interface, which +allows you to easily enumerate or iterate through resources from a result set with ``foreach``. + +Operations that start with ``List`` or ``Describe``, or any other operations that are designed to return multiple +records can be used with Iterators. To use an Iterator, you must call the ``getIterator()`` method of the client and +provide the operation name. The following is an example of creating an Amazon S3 ``ListObjects`` Iterator, to iterate +over objects in a bucket. + +.. code-block:: php + + $iterator = $client->getIterator('ListObjects', array('Bucket' => 'my-bucket')); + + foreach ($iterator as $object) { + echo $object['Key'] . "\n"; + } diff --git a/vendor/aws/aws-sdk-php/docs/_snippets/models-intro.txt b/vendor/aws/aws-sdk-php/docs/_snippets/models-intro.txt new file mode 100644 index 0000000..68db25b --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/_snippets/models-intro.txt @@ -0,0 +1,32 @@ +The result of a performing an operation is what we refer to as a **modeled response**. Instead of returning the raw XML +or JSON data, the SDK will coerce the data into an associative array and normalize some aspects of the data based on its +knowledge of the specific service and the underlying response structure. + +The actual value returned is a `Model `_ +(``Guzzle\Service\Resource\Model``) object. The Model class is a part of the SDK's underlying Guzzle library, but you do +not need to know anything about Guzzle to use your operation results. The Model object contains the data from the +response and can be used like an array (e.g., ``$result['Table']``). It also has convenience methods like ``get()``, +``getPath()``, and ``toArray()``. The contents of the modeled response depend on the operation that was executed and are +documented in the API docs for each operation (e.g., see the *Returns* section in the API docs for the `DynamoDB +DescribeTable operation `_). + +.. code-block:: php + + $result = $dynamoDbClient->describeTable(array( + 'TableName' => 'YourTableName', + )); + + // Get a specific value from the result + $table = $result['Table']; + if ($table && isset($table['TableStatus'])) { + echo $table['TableStatus']; + } + //> ACTIVE + + // Get nested values from the result easily + echo $result->getPath('Table/TableStatus'); + //> ACTIVE + + // Convert the Model to a plain array + var_export($result->toArray()); + //> array ( 'Table' => array ( 'AttributeDefinitions' => array ( ... ) ... ) ... ) diff --git a/vendor/aws/aws-sdk-php/docs/_snippets/performing-operations.txt b/vendor/aws/aws-sdk-php/docs/_snippets/performing-operations.txt new file mode 100644 index 0000000..dfbd064 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/_snippets/performing-operations.txt @@ -0,0 +1,14 @@ +You can perform a service **operation** by calling the method of the same name on the client object. For example, to +perform the `Amazon DynamoDB DescribeTable operation +`_, you must call the +``Aws\DynamoDb\DynamoDbClient::describeTable()`` method. Operation methods, like ``describeTable()``, all accept a +single argument that is an associative array of values representing the parameters to the operation. The structure of +this array is defined for each operation in the SDK's `API Documentation `_ +(e.g., see the `API docs for describeTable() +`_). + +.. code-block:: php + + $result = $dynamoDbClient->describeTable(array( + 'TableName' => 'YourTableName', + )); diff --git a/vendor/aws/aws-sdk-php/docs/_snippets/waiters-intro.txt b/vendor/aws/aws-sdk-php/docs/_snippets/waiters-intro.txt new file mode 100644 index 0000000..c0cbe35 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/_snippets/waiters-intro.txt @@ -0,0 +1,15 @@ +One of the higher-level abstractions provided by the SDK are **Waiters**. Waiters help make it easier to work with +*eventually consistent* systems by providing an easy way to wait until a resource enters into a particular state by +polling the resource. You can find a list of the waiters supported by a client by viewing the API Documentation of a +service client. Any method with a name starting with "``waitUntil``" will create and invoke a Waiter. + +In the following example, the Amazon S3 Client is used to create a bucket. Then the Waiter is used to wait until the +bucket exists. + +.. code-block:: php + + // Create a bucket + $s3Client->createBucket(array('Bucket' => 'my-bucket')); + + // Wait until the created bucket is available + $s3Client->waitUntil('BucketExists', array('Bucket' => 'my-bucket')); diff --git a/vendor/aws/aws-sdk-php/docs/_static/logo.png b/vendor/aws/aws-sdk-php/docs/_static/logo.png new file mode 100644 index 0000000..684f30f Binary files /dev/null and b/vendor/aws/aws-sdk-php/docs/_static/logo.png differ diff --git a/vendor/aws/aws-sdk-php/docs/_templates/feedback.html b/vendor/aws/aws-sdk-php/docs/_templates/feedback.html new file mode 100644 index 0000000..34bf965 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/_templates/feedback.html @@ -0,0 +1,16 @@ +
+

Feedback

+ +
+ +
+

Follow Us

+ + +
+ +
+ Recent Blog Posts +
diff --git a/vendor/aws/aws-sdk-php/docs/_templates/layout.html b/vendor/aws/aws-sdk-php/docs/_templates/layout.html new file mode 100644 index 0000000..e596618 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/_templates/layout.html @@ -0,0 +1,29 @@ +{%- extends "!layout.html" %} + +{%- block nav_links %} +
  • Docs
  • +
  • API Docs
  • +
  • Blog
  • +
  • Forum
  • +
  • Issues
  • +
  • Packagist
  • +
  • Homepage
  • +
  • PDF
  • +{%- endblock %} + +{% block ga %} +{% if theme_google_analytics_account %} + + + + + + +{% endif %} +{% endblock %} diff --git a/vendor/aws/aws-sdk-php/docs/_templates/sidebarlogo.html b/vendor/aws/aws-sdk-php/docs/_templates/sidebarlogo.html new file mode 100644 index 0000000..e3206e7 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/_templates/sidebarlogo.html @@ -0,0 +1,5 @@ + diff --git a/vendor/aws/aws-sdk-php/docs/awssignup.rst b/vendor/aws/aws-sdk-php/docs/awssignup.rst new file mode 100644 index 0000000..29d4423 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/awssignup.rst @@ -0,0 +1,62 @@ +================== +Signing Up for AWS +================== + +.. important:: This page is obsolete. Please see `About Access Keys `_. + +Creating an AWS account +----------------------- + +Before you begin, you need to create an account. When you sign up for AWS, AWS signs your account up for all services. +You are charged only for the services you use. + +To sign up for AWS +~~~~~~~~~~~~~~~~~~ + +#. Go to http://aws.amazon.com and click **Sign Up Now**. + +#. Follow the on-screen instructions. + +AWS sends you a confirmation email after the sign-up process is complete. At any time, you can view your current account +activity and manage your account at http://aws.amazon.com/account. From the **My Account** page, you can view current +charges and account activity and download usage reports. + +To view your AWS credentials +~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +#. Go to http://aws.amazon.com/. + +#. Click **My Account/Console**, and then click **Security Credentials**. + +#. Under **Your Account**, click **Security Credentials**. + +#. In the spaces provided, type your user name and password, and then click **Sign in using our secure server**. + +#. Under **Access Credentials**, on the **Access Keys** tab, your access key ID is displayed. To view your secret key, + under **Secret Access Key**, click **Show**. + +Your secret key must remain a secret that is known only by you and AWS. Keep it confidential in order to protect your +account. Store it securely in a safe place, and never email it. Do not share it outside your organization, even if an +inquiry appears to come from AWS or Amazon.com. No one who legitimately represents Amazon will ever ask you for your +secret key. + +Getting your AWS credentials +---------------------------- + +In order to use the AWS SDK for PHP, you need your AWS Access Key ID and Secret Access Key. + +To get your AWS Access Key ID and Secret Access Key + +- Go to http://aws.amazon.com/. +- Click **Account** and then click **Security Credentials**. The Security Credentials page displays (you might be + prompted to log in). +- Scroll down to Access Credentials and make sure the **Access Keys** tab is selected. The AWS Access Key ID appears in + the Access Key column. +- To view the Secret Access Key, click **Show**. + +.. note:: + + **Important: Your Secret Access Key is a secret**, which only you and AWS should know. It is important to keep it confidential + to protect your account. Store it securely in a safe place. Never include it in your requests to AWS, and never + e-mail it to anyone. Do not share it outside your organization, even if an inquiry appears to come from AWS or + Amazon.com. No one who legitimately represents Amazon will ever ask you for your Secret Access Key. diff --git a/vendor/aws/aws-sdk-php/docs/conf.py b/vendor/aws/aws-sdk-php/docs/conf.py new file mode 100644 index 0000000..73f5c66 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/conf.py @@ -0,0 +1,269 @@ +# -*- coding: utf-8 -*- +# +# AWS SDK for PHP documentation build configuration file, created by +# sphinx-quickstart on Mon Dec 10 19:00:11 2012. +# +# This file is execfile()d with the current directory set to its containing dir. +# +# Note that not all possible configuration values are present in this +# autogenerated file. +# +# All configuration values have a default; values that are commented out +# serve to show the default. + +import sys, os, subprocess + +# Don't require opening PHP tags in PHP examples +from sphinx.highlighting import lexers +from pygments.lexers.web import PhpLexer +lexers['php'] = PhpLexer(startinline=True, linenos=1) +lexers['php-annotations'] = PhpLexer(startinline=True, linenos=1) +primary_domain = 'php' + +# If extensions (or modules to document with autodoc) are in another directory, +# add these directories to sys.path here. If the directory is relative to the +# documentation root, use os.path.abspath to make it absolute, like shown here. +#sys.path.insert(0, os.path.abspath('.')) + +# -- General configuration ----------------------------------------------------- + +# If your documentation needs a minimal Sphinx version, state it here. +#needs_sphinx = '1.0' + +# Add our custom extensions +sys.path.append(os.path.abspath('_ext/')) + +# Add any Sphinx extension module names here, as strings. They can be extensions +# coming with Sphinx (named 'sphinx.ext.*') or your custom ones. +extensions = ['aws', 'rst2pdf.pdfbuilder'] + +# index, rst2pdf, title, author +pdf_documents = [('index', u'aws-sdk-php-guide', u'AWS SDK for PHP', u'Amazon Web Services')] + +# Add any paths that contain templates here, relative to this directory. +templates_path = ['_templates'] + +# The suffix of source filenames. +source_suffix = '.rst' + +# The encoding of source files. +#source_encoding = 'utf-8-sig' + +# The master toctree document. +master_doc = 'index' + +# General information about the project. +project = u'AWS SDK for PHP' +copyright = u'2013, Amazon Web Services' + +# The version info for the project you're documenting, acts as replacement for +# |version| and |release|, also used in various other places throughout the +# built documents. +# +# The short X.Y version. +version = subprocess.check_output('git describe --abbrev=0 --tags', shell=True).strip() +# The full version, including alpha/beta/rc tags. +release = version + +# The language for content autogenerated by Sphinx. Refer to documentation +# for a list of supported languages. +#language = None + +# There are two options for replacing |today|: either, you set today to some +# non-false value, then it is used: +#today = '' +# Else, today_fmt is used as the format for a strftime call. +#today_fmt = '%B %d, %Y' + +# List of patterns, relative to source directory, that match files and +# directories to ignore when looking for source files. +exclude_patterns = ['_build'] + +# The reST default role (used for this markup: `text`) to use for all documents. +#default_role = None + +# If true, '()' will be appended to :func: etc. cross-reference text. +#add_function_parentheses = True + +# If true, the current module name will be prepended to all description +# unit titles (such as .. function::). +#add_module_names = True + +# If true, sectionauthor and moduleauthor directives will be shown in the +# output. They are ignored by default. +#show_authors = False + +# A list of ignored prefixes for module index sorting. +#modindex_common_prefix = [] + +# -- Options for HTML output --------------------------------------------------- + +# The theme to use for HTML and HTML Help pages. See the documentation for +# a list of builtin themes. + +# Theme options are theme-specific and customize the look and feel of a theme +# further. For a list of options available for each theme, see the +# documentation. +#html_theme_options = {} + +# Add any paths that contain custom themes here, relative to this directory. +#html_theme_path = [] + +# The name for this set of Sphinx documents. If None, it defaults to +# " v documentation". +#html_title = None + +# A shorter title for the navigation bar. Default is the same as html_title. +#html_short_title = None + +# The name of an image file (relative to this directory) to place at the top +# of the sidebar. +#html_logo = None + +# The name of an image file (within the static path) to use as favicon of the +# docs. This file should be a Windows icon file (.ico) being 16x16 or 32x32 +# pixels large. +#html_favicon = None + +# Add any paths that contain custom static files (such as style sheets) here, +# relative to this directory. They are copied after the builtin static files, +# so a file named "default.css" will overwrite the builtin "default.css". +html_static_path = ['_static'] + +# If not '', a 'Last updated on:' timestamp is inserted at every page bottom, +# using the given strftime format. +#html_last_updated_fmt = '%b %d, %Y' + +# If true, SmartyPants will be used to convert quotes and dashes to +# typographically correct entities. +#html_use_smartypants = True + +# Custom sidebar templates, maps document names to template names. +html_sidebars = { + '**': ['sidebarlogo.html', 'localtoc.html', 'searchbox.html', 'feedback.html'] +} + +# Additional templates that should be rendered to pages, maps page names to +# template names. +#html_additional_pages = {} + +# If false, no module index is generated. +#html_domain_indices = True + +# If false, no index is generated. +#html_use_index = True + +# If true, the index is split into individual pages for each letter. +#html_split_index = False + +# If true, links to the reST sources are added to the pages. +html_show_sourcelink = False + +# If true, "Created using Sphinx" is shown in the HTML footer. Default is True. +#html_show_sphinx = True + +# If true, "(C) Copyright ..." is shown in the HTML footer. Default is True. +#html_show_copyright = True + +# If true, an OpenSearch description file will be output, and all pages will +# contain a tag referring to it. The value of this option must be the +# base URL from which the finished HTML is served. +#html_use_opensearch = '' + +# This is the file name suffix for HTML files (e.g. ".xhtml"). +#html_file_suffix = None + +# Output file base name for HTML help builder. +htmlhelp_basename = 'AWSSDKforPHPdoc' + + +# -- Options for LaTeX output -------------------------------------------------- + +latex_elements = { +# The paper size ('letterpaper' or 'a4paper'). +#'papersize': 'letterpaper', + +# The font size ('10pt', '11pt' or '12pt'). +#'pointsize': '10pt', + +# Additional stuff for the LaTeX preamble. +#'preamble': '', +} + +# Grouping the document tree into LaTeX files. List of tuples +# (source start file, target name, title, author, documentclass [howto/manual]). +latex_documents = [ + ('index', 'AWSSDKforPHP.tex', u'AWS SDK for PHP Documentation', + u'Amazon Web Services', 'manual'), +] + +# The name of an image file (relative to this directory) to place at the top of +# the title page. +#latex_logo = None + +# For "manual" documents, if this is true, then toplevel headings are parts, +# not chapters. +#latex_use_parts = False + +# If true, show page references after internal links. +#latex_show_pagerefs = False + +# If true, show URL addresses after external links. +#latex_show_urls = False + +# Documents to append as an appendix to all manuals. +#latex_appendices = [] + +# If false, no module index is generated. +#latex_domain_indices = True + + +# -- Options for manual page output -------------------------------------------- + +# One entry per manual page. List of tuples +# (source start file, name, description, authors, manual section). +man_pages = [ + ('index', 'awssdkforphp', u'AWS SDK for PHP Documentation', + [u'Amazon Web Services'], 1) +] + +# If true, show URL addresses after external links. +#man_show_urls = False + + +# -- Options for Texinfo output ------------------------------------------------ + +# Grouping the document tree into Texinfo files. List of tuples +# (source start file, target name, title, author, +# dir menu entry, description, category) +texinfo_documents = [ + ('index', 'AWSSDKforPHP', u'AWS SDK for PHP Documentation', + u'Amazon Web Services', 'AWSSDKforPHP', 'One line description of project.', + 'Miscellaneous'), +] + +# Documents to append as an appendix to all manuals. +#texinfo_appendices = [] + +# If false, no module index is generated. +#texinfo_domain_indices = True + +# How to display URL addresses: 'footnote', 'no', or 'inline'. +#texinfo_show_urls = 'footnote' + +# -- HTML theme settings ------------------------------------------------ +import guzzle_sphinx_theme +extensions.append("guzzle_sphinx_theme") +html_translator_class = 'guzzle_sphinx_theme.HTMLTranslator' +html_theme_path = guzzle_sphinx_theme.html_theme_path() +html_theme = 'guzzle_sphinx_theme' + +# Guzzle theme options (see theme.conf for more information) +html_theme_options = { + # hack to add tracking + "google_analytics_account": os.getenv('TRACKING', False), + "project_nav_name": "AWS SDK for PHP", + "github_user": "aws", + "github_repo": "aws-sdk-php", + "base_url": "http://docs.aws.amazon.com/aws-sdk-php/guide/latest/" +} diff --git a/vendor/aws/aws-sdk-php/docs/configuration.rst b/vendor/aws/aws-sdk-php/docs/configuration.rst new file mode 100644 index 0000000..822ae8e --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/configuration.rst @@ -0,0 +1,316 @@ +Configuring the SDK +=================== + +The AWS SDK for PHP can be configured in many ways to suit your needs. This guide highlights the use of configuration +files with the service builder as well as individual client configuration options. + +Configuration files +------------------- + +How configuration files work +~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +When passing an array of parameters to the first argument of ``Aws\Common\Aws::factory()``, the service builder loads +the default ``aws-config.php`` file and merges the array of shared parameters into the default configuration. + +Excerpt from ``src/Aws/Common/Resources/aws-config.php``: + +.. code-block:: php + + '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' + ), + // ... + ); + +The ``aws-config.php`` file provides default configuration settings for associating client classes with service names. +This file tells the ``Aws\Common\Aws`` service builder which class to instantiate when you reference a client by name. + +You can supply your credential profile (see :ref:`credential_profiles`) and other configuration settings to the service +builder so that each client is instantiated with those settings. To do this, pass an array of settings (including your +``profile``) into the first argument of ``Aws\Common\Aws::factory()``. + +.. code-block:: php + + 'my_profile', + 'region' => 'us-east-1', + )); + +Using a custom configuration file +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +You can use a custom configuration file that allows you to create custom named clients with pre-configured settings. + +Let's say you want to use the default ``aws-config.php`` settings, but you want to supply your keys using a +configuration file. Each service defined in the default configuration file extends from ``default_settings`` service. +You can create a custom configuration file that extends the default configuration file and add credentials to the +``default_settings`` service: + +.. code-block:: php + + array('_aws'), + 'services' => array( + 'default_settings' => array( + 'params' => array( + 'profile' => 'my_profile', // Looks up credentials in ~/.aws/credentials + 'region' => 'us-west-2' + ) + ) + ) + ); + +Make sure to include the ``'includes' => array('_aws'),`` line in your configuration file, because this extends the +default configuration that makes all of the service clients available to the service builder. If this is missing, then +you will get an exception when trying to retrieve a service client. + +You can use your custom configuration file with the ``Aws\Common\Aws`` class by passing the full path to the +configuration file in the first argument of the ``factory()`` method: + +.. code-block:: php + + array('_aws'), + 'services' => array( + 'foo.dynamodb' => array( + 'extends' => 'dynamodb', + 'params' => array( + 'profile' => 'my_profile', + 'region' => 'us-west-2' + ) + ), + 'bar.dynamodb' => array( + 'extends' => 'dynamodb', + 'params' => array( + 'profile' => 'my_other_profile', + 'region' => 'us-west-2' + ) + ) + ) + ); + +If you prefer JSON syntax, you can define your configuration in JSON format instead of PHP. + +.. code-block:: js + + { + "includes": ["_aws"], + "services": { + "default_settings": { + "params": { + "profile": "my_profile", + "region": "us-west-2" + } + } + } + } + +For more information about writing custom configuration files, please see `Using the Service Builder +`_ in the Guzzle documentation. + +Client configuration options +----------------------------- + +Basic client configuration options include your credentials ``profile`` (see :doc:`credentials`) and a ``region`` +(see :ref:`specify_region`). For typical use cases, you will not need to provide more than these 3 options. +The following represents all of the possible client configuration options for service clients in the SDK. + +========================= ============================================================================================== +Credentials Options +------------------------------------------------------------------------------------------------------------------------ +Options Description +========================= ============================================================================================== +``profile`` The AWS credential profile associated with the credentials you want to use. The profile is + used to look up your credentials in your credentials file (``~/.aws/credentials``). See + :ref:`credential_profiles` for more information. + +``key`` An AWS access key ID. Unless you are setting temporary credentials provided by AWS STS, it is + recommended that you avoid hard-coding credentials with this parameter. Please see + :doc:`credentials` for my information about credentials. + +``secret`` An AWS secret access key. Unless you are setting temporary credentials provided by AWS STS, it + is recommended that you avoid hard-coding credentials with this parameter. Please see + :doc:`credentials` for my information about credentials. + +``token`` An AWS security token to use with request authentication. These are typically provided by the + AWS STS service. Please note that not all services accept temporary credentials. + See http://docs.aws.amazon.com/STS/latest/UsingSTS/UsingTokens.html. + +``token.ttd`` The UNIX timestamp for when the provided credentials expire. + +``credentials`` A credentials object (``Aws\Common\Credentials\CredentialsInterface``) can be provided instead + explicit access keys and tokens. + +``credentials.cache.key`` Optional custom cache key to use with the credentials. + +``credentials.client`` Pass this option to specify a custom ``Guzzle\Http\ClientInterface`` to use if your + credentials require a HTTP request (e.g. ``RefreshableInstanceProfileCredentials``). +========================= ============================================================================================== + +========================= ============================================================================================== +Endpoint and Signature Options +------------------------------------------------------------------------------------------------------------------------ +Options Description +========================= ============================================================================================== +``region`` Region name (e.g., 'us-east-1', 'us-west-1', 'us-west-2', 'eu-west-1', etc.). + See :ref:`specify_region`. + +``scheme`` URI Scheme of the base URL (e.g.. 'https', 'http') used when base_url is not supplied. + +``base_url`` Allows you to specify a custom endpoint instead of have the SDK build one automatically from + the region and scheme. + +``signature`` Overrides the signature used by the client. Clients will always choose an appropriate default + signature. However, it can be useful to override this with a custom setting. This can be set + to "v4", "v3https", "v2" or an instance of ``Aws\Common\Signature\SignatureInterface``. + +``signature.service`` The signature service scope for Signature V4. See :ref:`custom_endpoint`. + +``signature.region`` The signature region scope for Signature V4. See :ref:`custom_endpoint`. +========================= ============================================================================================== + +================================== ===================================================================================== +Generic Client Options +------------------------------------------------------------------------------------------------------------------------ +Options Description +================================== ===================================================================================== +``ssl.certificate_authority`` Set to true to use the SDK bundled SSL certificate bundle (this is used by default), + ``'system'`` to use the bundle on your system, a string pointing to a file to use a + specific certificate file, a string pointing to a directory to use multiple + certificates, or false to disable SSL validation (not recommended). + + When using the ``aws.phar``, the bundled SSL certificate will be extracted to your + system's temp folder, and each time a client is created an MD5 check will be + performed to ensure the integrity of the certificate. + +``curl.options`` Associative array of cURL options to apply to every request created by the client. + If either the key or value of an entry in the array is a string, Guzzle will attempt + to find a matching defined cURL constant automatically (e.g. ``"CURLOPT_PROXY"`` will + be converted to the constant ``CURLOPT_PROXY``). + +``request.options`` Associative array of `Guzzle request options + `_ to + apply to every request created by the client. + +``command.params`` An associative array of default options to set on each command created by the client. + +``client.backoff.logger`` A ``Guzzle\Log\LogAdapterInterface`` object used to log backoff retries. Use + ``'debug'`` to emit PHP warnings when a retry is issued. + +``client.backoff.logger.template`` Optional template to use for exponential backoff log messages. See the + ``Guzzle\Plugin\Backoff\BackoffLogger`` class for formatting information. +================================== ===================================================================================== + +.. _specify_region: + +Specifying a region +~~~~~~~~~~~~~~~~~~~ + +Some clients require a ``region`` configuration setting. You can find out if the client you are using requires a region +and the regions available to a client by consulting the documentation for that particular client +(see :ref:`supported-services`). + +Here's an example of creating an Amazon DynamoDB client that uses the ``us-west-1`` region: + +.. code-block:: php + + require 'vendor/autoload.php'; + + use Aws\DynamoDb\DynamoDbClient; + + // Create a client that uses the us-west-1 region + $client = DynamoDbClient::factory(array( + 'key' => 'YOUR_AWS_ACCESS_KEY_ID', + 'secret' => 'YOUR_AWS_SECRET_ACCESS_KEY', + 'region' => 'us-west-1' + )); + +.. _custom_endpoint: + +Setting a custom endpoint +~~~~~~~~~~~~~~~~~~~~~~~~~ + +You can specify a completely customized endpoint for a client using the client's ``base_url`` option. If the client you +are using requires a region, then must still specify the name of the region using the ``region`` option. Setting a +custom endpoint can be useful if you're using a mock web server that emulates a web service, you're testing against a +private beta endpoint, or you are trying to a use a new region not yet supported by the SDK. + +Here's an example of creating an Amazon DynamoDB client that uses a completely customized endpoint: + +.. code-block:: php + + require 'vendor/autoload.php'; + + use Aws\DynamoDb\DynamoDbClient; + + // Create a client that that contacts a completely customized base URL + $client = DynamoDbClient::factory(array( + 'base_url' => 'http://my-custom-url', + 'region' => 'my-region-1', + 'key' => 'abc', + 'secret' => '123' + )); + +If your custom endpoint uses signature version 4 and must be signed with custom signature scoping values, then you can +specify the signature scoping values using ``signature.service`` (the scoped name of the service) and +``signature.region`` (the region that you are contacting). These values are typically not required. + +.. _using_proxy: + +Using a proxy +~~~~~~~~~~~~~ + +You can send requests with the AWS SDK for PHP through a proxy using the "request options" of a client. These +"request options" are applied to each HTTP request sent from the client. One of the option settings that can be +specified is the `proxy` option. + +Request options are passed to a client through the client's factory method: + +.. code-block:: php + + use Aws\S3\S3Client; + + $s3 = S3Client::factory(array( + 'request.options' => array( + 'proxy' => '127.0.0.1:123' + ) + )); + +The above example tells the client that all requests should be proxied through an HTTP proxy located at the +`127.0.0.1` IP address using port `123`. + +You can supply a username and password when specifying your proxy setting if needed, using the format of +``username:password@host:port``. diff --git a/vendor/aws/aws-sdk-php/docs/credentials.rst b/vendor/aws/aws-sdk-php/docs/credentials.rst new file mode 100644 index 0000000..24f1018 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/credentials.rst @@ -0,0 +1,453 @@ +Providing Credentials to the SDK +================================ + +Introduction +------------ + +In order to authenticate requests, AWS services require you to provide your `AWS access keys +`_, also known as your AWS **access key ID** and **secret access key**. +In the AWS SDK for PHP, these access keys are often referred to collectively as your **credentials**. This guide +demonstrates how to provide your credentials to the AWS SDK for SDK. + +There are many ways to provide credentials: + +#. :ref:`environment_credentials` +#. :ref:`instance_profile_credentials` +#. :ref:`credential_profiles` +#. :ref:`configuration_credentials` +#. :ref:`factory_credentials` +#. :ref:`set_credentials` +#. :ref:`temporary_credentials` + +Which technique should you choose? +---------------------------------- + +The technique that you use to provide credentials to the SDK for your application is entirely up to you. Please read +each section on this page to determine what is the best fit for you. What you choose will depend on many different +factors, including: + +* The environment you are operating in (e.g., development, testing, production) +* The host of your application (e.g., localhost, Amazon EC2, third-party server) +* How many sets of credentials you are using +* The type of project you are developing (e.g., application, CLI, library) +* How often you rotate your credentials +* If you rely on temporary or federated credentials +* Your deployment process +* Your application framework + +Regardless of the technique used, it is encouraged that you follow the `IAM Best Practices +`_ when managing your credentials, including the +recommendation to not use your AWS account's root credentials. Instead, create separate IAM users with their own access +keys for each project, and tailor the permissions of the users specific to those projects. + +*In general, it is recommended that you use IAM roles when running your application on Amazon EC2 and use credential +profiles or environment variables elsewhere.* + +.. _environment_credentials: + +Using credentials from environment variables +-------------------------------------------- + +If you do not provide credentials to a client object at the time of its instantiation (e.g., via the client's factory +method or via a service builder configuration), the SDK will attempt to find credentials in your environment when you +call your first operation. The SDK will use the ``$_SERVER`` superglobal and/or ``getenv()`` function to look for the +``AWS_ACCESS_KEY_ID`` and ``AWS_SECRET_ACCESS_KEY`` environment variables. These credentials are referred to as +**environment credentials**. + +.. _instance_profile_credentials: + +Using IAM roles for Amazon EC2 instances +---------------------------------------- + +*Using IAM roles is the preferred technique for providing credentials to applications running on Amazon EC2.* IAM roles +remove the need to worry about credential management from your application. They allow an instance to "assume" a role by +retrieving temporary credentials from the EC2 instance's metadata server. These temporary credentials, often referred to +as **instance profile credentials**, allow access to the actions and resources that the role's policy allows. + +When launching an EC2 instance, you can choose to associate it with an IAM role. Any application running on that EC2 +instance is then allowed to assume the associated role. Amazon EC2 handles all the legwork of securely authenticating +instances to the IAM service to assume the role and periodically refreshing the retrieved role credentials, keeping your +application secure with almost no work on your part. + +If you do not explicitly provide credentials to the client object and no environment variable credentials are available, +the SDK attempts to retrieve instance profile credentials from an Amazon EC2 instance metadata server. These credentials +are available only when running on Amazon EC2 instances that have been configured with an IAM role. + +.. note:: + + Instance profile credentials and other temporary credentials generated by the AWS Security Token Service (AWS STS) + are not supported by every service. Please check if the service you are using supports temporary credentials by + reading `AWS Services that Support AWS STS `_. + +For more information, see `IAM Roles for Amazon EC2 `_. + +.. _caching_credentials: + +Caching IAM role credentials +~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +While using IAM role credentials is the preferred method for providing credentials to an application running on an +Amazon EC2 instance, the roundtrip from the application to the instance metadata server on each request can introduce +latency. In these situations, you might find that utilizing a caching layer on top of your IAM role credentials can +eliminate the introduced latency. + +The easiest way to add a cache to your IAM role credentials is to specify a credentials cache using the +``credentials.cache`` option in a client's factory method or in a service builder configuration file. The +``credentials.cache`` configuration setting should be set to an object that implements Guzzle's +``Guzzle\Cache\CacheAdapterInterface`` (see `Guzzle cache adapters +`_). This interface provides an +abstraction layer over various cache backends, including Doctrine Cache, Zend Framework 2 cache, etc. + +.. code-block:: php + + $cacheAdapter + )); + +In the preceding example, the addition of ``credentials.cache`` causes credentials to be cached to the local filesystem +using `Doctrine's caching system `_. Every request that uses this cache adapter first +checks if the credentials are in the cache. If the credentials are found in the cache, the client then ensures that the +credentials are not expired. In the event that cached credentials become expired, the client automatically refreshes the +credentials on the next request and populates the cache with the updated credentials. + +A credentials cache can also be used in a service builder configuration: + +.. code-block:: php + + array('_aws'), + 'services' => array( + 'default_settings' => array( + 'params' => array( + 'credentials.cache' => $cacheAdapter + ) + ) + ) + ); + +If you were to use the above configuration file with a service builder, then all of the clients created through the +service builder would utilize a shared credentials cache object. + +.. _credential_profiles: + +Using the AWS credentials file and credential profiles +------------------------------------------------------ + +Starting with the AWS SDK for PHP version 2.6.2, you can use an AWS credentials file to specify your credentials. This +is a special, INI-formatted file stored under your HOME directory, and is a good way to manage credentials for your +development environment. The file should be placed at ``~/.aws/credentials``, where ``~`` represents your HOME +directory. + +Using an AWS credentials file offers a few benefits: + +1. Your projects' credentials are stored outside of your projects, so there is no chance of accidentally committing + them into version control. +2. You can define and name multiple sets of credentials in one place. +3. You can easily reuse the same credentials between projects. +4. Other AWS SDKs and tools support, or will soon support, this same credentials file. This allows you to reuse your + credentials with other tools. + +The format of the AWS credentials file should look something like the following: + +.. code-block:: ini + + [default] + aws_access_key_id = YOUR_AWS_ACCESS_KEY_ID + aws_secret_access_key = YOUR_AWS_SECRET_ACCESS_KEY + + [project1] + aws_access_key_id = ANOTHER_AWS_ACCESS_KEY_ID + aws_secret_access_key = ANOTHER_AWS_SECRET_ACCESS_KEY + +Each section (e.g., ``[default]``, ``[project1]``), represents a separate credential **profile**. Profiles can be +referenced from an SDK configuration file, or when you are instantiating a client, using the ``profile`` option: + +.. code-block:: php + + 'project1', + 'region' => 'us-west-2', + )); + +If no credentials or profiles were explicitly provided to the SDK and no credentials were defined in environment +variables, but a credentials file is defined, the SDK will use the "default" profile. You can change the default +profile by specifying an alternate profile name in the ``AWS_PROFILE`` environment variable. + +.. _hardcoded_credentials: + +Setting credentials explicitly in your code +------------------------------------------- + +The SDK allows you to explicitly set your credentials in your project in a few different ways. These techniques are +useful for rapid development, integrating with existing configurations systems (e.g., your PHP framework of choice), and +using :ref:`temporary credentials `. However, **be careful to not hard-code your credentials** +inside of your applications. Hard-coding your credentials can be dangerous, because it is easy to accidentally commit +your credentials into an SCM repository, potentially exposing your credentials to more people than intended. It can also +make it difficult to rotate credentials in the future. + +.. _configuration_credentials: + +Using a configuration file with the service builder +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +The SDK provides a service builder that can be used to share configuration values across multiple clients. The service +builder allows you to specify default configuration values (e.g., credentials and regions) that are used by every +client. The service builder is configured using either JSON configuration files or PHP scripts that return an array. + +The following is an example of a configuration script that returns an array of configuration data that can be used by +the service builder: + +.. code-block:: php + + array('_aws'), + 'services' => array( + // All AWS clients extend from 'default_settings'. Here we are + // overriding 'default_settings' with our default credentials and + // providing a default region setting. + 'default_settings' => array( + 'params' => array( + 'key' => 'YOUR_AWS_ACCESS_KEY_ID', + 'secret' => 'YOUR_AWS_SECRET_ACCESS_KEY', + 'region' => 'us-west-1' + ) + ) + ) + ); + +After creating and saving the configuration file, you need to instantiate a service builder. + +.. code-block:: php + + get('s3'); + +.. _factory_credentials: + +Passing credentials into a client factory method +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +A simple way to specify your credentials is by injecting them directly into the factory method when instantiating the +client object. + +.. code-block:: php + + 'YOUR_AWS_ACCESS_KEY_ID', + 'secret' => 'YOUR_AWS_SECRET_ACCESS_KEY', + )); + +In some cases, you may already have an instance of a ``Credentials`` object. You can use this instead of specifying your +access keys separately. + +.. code-block:: php + + $credentials + )); + +You may also want to read the section in the Getting Started Guide about +:ref:`using a client's factory method ` for more details. + +.. _set_credentials: + +Setting credentials after instantiation +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +At any time after instantiating the client, you can set the credentials the client should use with the +``setCredentials()`` method. + +.. code-block:: php + + setCredentials($credentials); + +This can be used to change the credentials, set temporary credentials, refresh expired credentials, etc. + +Using the ``setCredentials()`` method will also trigger a ``client.credentials_changed`` event, so you can program other +parts of your application to react to the change. To do this, you just need to add a listener to the client object. + +.. code-block:: php + + use Aws\S3\S3Client; + use Aws\Common\Credentials\Credentials + + // Create 2 sets of credentials + $credentials1 = new Credentials('ACCESS_KEY_1', 'SECRET_KEY_1'); + $credentials2 = new Credentials('ACCESS_KEY_2', 'SECRET_KEY_2'); + + // Instantiate the client with the first credential set + $s3Client = S3Client::factory(array('credentials' => $credentials1)); + + // Get the event dispatcher and register a listener for the credential change + $dispatcher = $s3Client->getEventDispatcher(); + $dispatcher->addListener('client.credentials_changed', function ($event) { + $formerAccessKey = $event['former_credentials']->getAccessKey(); + $currentAccessKey = $event['credentials']->getAccessKey(); + echo "Access key has changed from {$formerAccessKey} to {$currentAccessKey}.\n"; + }); + + // Change the credentials to the second set to trigger the event + $s3Client->setCredentials($credentials2); + //> Access key has changed from ACCESS_KEY_1 to ACCESS_KEY_2. + +.. _temporary_credentials: + +Using temporary credentials from AWS STS +---------------------------------------- + +`AWS Security Token Service `_ (AWS STS) enables you to +request limited-privilege, **temporary credentials** for AWS IAM users or for users that you authenticate via identity +federation. One common use case for using temporary credentials is to grant mobile or client-side applications access to +AWS resources by authenticating users through third-party identity providers (read more about `Web Identity Federation +`_). + +.. note:: + + Temporary credentials generated by AWS STS are not supported by every service. Please check if the service you are + using supports temporary credentials by reading `AWS Services that Support AWS STS + `_. + +Getting temporary credentials +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +AWS STS has several operations that return temporary credentials, but the ``GetSessionToken`` operation is the simplest +for demonstration purposes. Assuming you have an instance of ``Aws\Sts\StsClient`` stored in the ``$stsClient`` +variable, this is how you call it: + +.. code-block:: php + + $result = $stsClient->getSessionToken(); + +The result for ``GetSessionToken`` and the other AWS STS operations always contains a ``'Credentials'`` value. If you +print the result (e.g., ``print_r($result)``), it looks like the following: + +:: + + Array + ( + ... + [Credentials] => Array + ( + [SessionToken] => '' + [SecretAccessKey] => '' + [Expiration] => 2013-11-01T01:57:52Z + [AccessKeyId] => '' + ) + ... + ) + +Providing temporary credentials to the SDK +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +You can use temporary credentials with another AWS client by instantiating the client and passing in the values received +from AWS STS directly. + +.. code-block:: php + + use Aws\S3\S3Client; + + $result = $stsClient->getSessionToken(); + + $s3Client = S3Client::factory(array( + 'key' => $result['Credentials']['AccessKeyId'], + 'secret' => $result['Credentials']['SecretAccessKey'], + 'token' => $result['Credentials']['SessionToken'], + )); + +You can also construct a ``Credentials`` object and use that when instantiating the client. + +.. code-block:: php + + use Aws\Common\Credentials\Credentials; + use Aws\S3\S3Client; + + $result = $stsClient->getSessionToken(); + + $credentials = new Credentials( + $result['Credentials']['AccessKeyId'], + $result['Credentials']['SecretAccessKey'], + $result['Credentials']['SessionToken'] + ); + + $s3Client = S3Client::factory(array('credentials' => $credentials)); + +However, the *best* way to provide temporary credentials is to use the ``createCredentials()`` helper method included +with the ``StsClient``. This method extracts the data from an AWS STS result and creates the ``Credentials`` object for +you. + +.. code-block:: php + + $result = $stsClient->getSessionToken(); + $credentials = $stsClient->createCredentials($result); + + $s3Client = S3Client::factory(array('credentials' => $credentials)); + +You can also use the same technique when setting credentials on an existing client object. + +.. code-block:: php + + $credentials = $stsClient->createCredentials($stsClient->getSessionToken()); + $s3Client->setCredentials($credentials); + +For more information about why you might need to use temporary credentials in your application or project, see +`Scenarios for Granting Temporary Access `_ in the AWS +STS documentation. diff --git a/vendor/aws/aws-sdk-php/docs/faq.rst b/vendor/aws/aws-sdk-php/docs/faq.rst new file mode 100644 index 0000000..65566bc --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/faq.rst @@ -0,0 +1,220 @@ +================================ +Frequently Asked Questions (FAQ) +================================ + +What methods are available on a client? +--------------------------------------- + +The AWS SDK for PHP utilizes service descriptions and dynamic +`magic __call() methods `_ to execute API +operations. Every magic method supported by a client is documented in the docblock of a client class using ``@method`` +annotations. Several PHP IDEs, including `PHPStorm `_ and +`Zend Studio `_, are able to autocomplete based on ``@method`` annotations. +You can find a full list of methods available for a web service client in the +`API documentation `_ of the client or in the +`user guide `_ for that client. + +For example, the Amazon S3 client supports the following operations: :ref:`S3_operations` + +What do I do about a cURL SSL certificate error? +------------------------------------------------ + +This issue can occur when using an out of date CA bundle with cURL and SSL. You +can get around this issue by updating the CA bundle on your server or downloading +a more up to date CA bundle from the `cURL website directly `_. + +Simply download a more up to date CA bundle somewhere on your system and instruct the +SDK to use that CA bundle rather than the default. You can configure the SDK to +use a more up to date CA bundle by specifying the ``ssl.certificate_authority`` +in a client's factory method or the configuration settings used with +``Aws\Common\Aws``. + +.. code-block:: php + + $aws = Aws\Common\Aws::factory(array( + 'region' => 'us-west-2', + 'key' => '****', + 'secret' => '****', + 'ssl.certificate_authority' => '/path/to/updated/cacert.pem' + )); + +You can find out more about how cURL bundles the CA bundle here: http://curl.haxx.se/docs/caextract.html + +How do I disable SSL? +--------------------- + +.. warning:: + + Because SSL requires all data to be encrypted and requires more TCP packets to complete a connection handshake than + just TCP, disabling SSL may provide a small performance improvement. However, with SSL disabled, all data is sent + over the wire unencrypted. Before disabling SSL, you must carefully consider the security implications and the + potential for eavesdropping over the network. + +You can disable SSL by setting the ``scheme`` parameter in a client factory method to 'http'. + +.. code-block:: php + + $client = Aws\DynamoDb\DynamoDbClient::factory(array( + 'region' => 'us-west-2', + 'scheme' => 'http' + )); + +How can I make the SDK faster? +------------------------------ + +See :doc:`performance` for more information. + +Why can't I upload or download files greater than 2GB? +------------------------------------------------------ + +Because PHP's integer type is signed and many platforms use 32-bit integers, the +AWS SDK for PHP does not correctly handle files larger than 2GB on a 32-bit stack +(where "stack" includes CPU, OS, web server, and PHP binary). This is a +`well-known PHP issue `_. In the +case of Microsoft® Windows®, there are no official builds of PHP that support +64-bit integers. + +The recommended solution is to use a `64-bit Linux stack `_, +such as the 64-bit Amazon Linux AMI with the latest version of PHP installed. + +For more information, please see: `PHP filesize :Return values `_. + +How can I see what data is sent over the wire? +---------------------------------------------- + +You can attach a ``Guzzle\Plugin\Log\LogPlugin`` to any client to see all request and +response data sent over the wire. The LogPlugin works with any logger that implements +the ``Guzzle\Log\LogAdapterInterface`` interface (currently Monolog, ZF1, ZF2). + +If you just want to quickly see what data is being sent over the wire, you can +simply attach a debug log plugin to your client. + +.. code-block:: php + + use Guzzle\Plugin\Log\LogPlugin; + + // Create an Amazon S3 client + $s3Client = S3Client::factory(); + + // Add a debug log plugin + $s3Client->addSubscriber(LogPlugin::getDebugPlugin()); + +For more complex logging or logging to a file, you can build a LogPlugin manually. + +.. code-block:: php + + use Guzzle\Common\Log\MonologLogAdapter; + use Guzzle\Plugin\Log\LogPlugin; + use Monolog\Logger; + use Monolog\Handler\StreamHandler; + + // Create a log channel + $log = new Logger('aws'); + $log->pushHandler(new StreamHandler('/path/to/your.log', Logger::WARNING)); + + // Create a log adapter for Monolog + $logger = new MonologLogAdapter($log); + + // Create the LogPlugin + $logPlugin = new LogPlugin($logger); + + // Create an Amazon S3 client + $s3Client = S3Client::factory(); + + // Add the LogPlugin to the client + $s3Client->addSubscriber($logPlugin); + +You can find out more about the LogPlugin on the Guzzle website: http://guzzlephp.org/guide/plugins.html#log-plugin + +How can I set arbitrary headers on a request? +--------------------------------------------- + +You can add any arbitrary headers to a service operation by setting the ``command.headers`` value. The following example +shows how to add an ``X-Foo-Baz`` header to an Amazon S3 PutObject operation. + +.. code-block:: php + + $s3Client = S3Client::factory(); + $s3Client->putObject(array( + 'Key' => 'test', + 'Bucket' => 'mybucket', + 'command.headers' => array( + 'X-Foo-Baz' => 'Bar' + ) + )); + +Does the SDK follow semantic versioning? +---------------------------------------- + +Yes. The SDK follows a semantic versioning scheme similar to – but not the same as – `semver `_. +Instead of the **MAJOR.MINOR.PATCH** scheme specified by semver, the SDK actually follows a scheme that looks like +**PARADIGM.MAJOR.MINOR** where: + +1. The **PARADIGM** version number is incremented when **drastic, breaking changes** are made to the SDK, such that the + fundamental way of using the SDK is different. You are probably aware that version 1.x and version 2.x of the AWS SDK + for PHP are *very* different. +2. The **MAJOR** version number is incremented when **breaking changes** are made to the API. These are usually small + changes, and only occur when one of the services makes breaking changes changes to their API. Make sure to check the + `CHANGELOG `_ and + `UPGRADING `_ documents when these changes occur. +3. The **MINOR** version number is incremented when any **backwards-compatible** change is made, whether it's a new + feature or a bug fix. + +The best way to ensure that you are not affected by breaking changes is to set your dependency on the SDK in Composer to +stay within a particular **PARADIGM.MAJOR** version. This can be done using the wildcard syntax: + +.. code-block:: json + + { + "require": { + "aws/aws-sdk-php": "2.4.*" + } + } + +...Or by using the the tilde operator. The following statement is equivalent to `>=2.4.9,<2.5`: + +.. code-block:: json + + { + "require": { + "aws/aws-sdk-php": "~2.4.9" + } + } + +See the `Composer documentation `_ for more information +on configuring your dependencies. + +The SDK may at some point adopt the semver standard, but this will probably not happen until the next paradigm-type +change. + +Why am I seeing a "Cannot redeclare class" error? +------------------------------------------------- + +We have observed this error a few times when using the ``aws.phar`` from the CLI with APC enabled. This is due to some +kind of issue with phars and APC. Luckily there are a few ways to get around this. Please choose the one that makes the +most sense for your environment and application. + +1. **Disable APC for CLI** - Change the ``apc.enable_cli`` INI setting to ``Off``. +2. **Tell APC not to cache phars** - Change the ``apc.filters`` INI setting to include ``"^phar://"``. +3. **Don't use APC** - PHP 5.5, for example, comes with Zend OpCache built in. This problem has not been observed with + Zend OpCache. +4. **Don't use the phar** - You can install the SDK through Composer (recommended) or by using the zip file. + +What is an InstanceProfileCredentialsException? +----------------------------------------------- + +If you are seeing an ``Aws\Common\Exception\InstanceProfileCredentialsException`` while using the SDK, this means that +the SDK was not provided with any credentials. + +If you instantiate a client *without* credentials, on the first time that you perform a service operation, the SDK will +attempt to find credentials. It first checks in some specific environment variables, then it looks for instance profile +credentials, which are only available on configured Amazon EC2 instances. If absolutely no credentials are provided or +found, an ``Aws\Common\Exception\InstanceProfileCredentialsException`` is thrown. + +If you are seeing this error and you are intending to use instance profile credentials, then you need to make sure that +the Amazon EC2 instance that the SDK is running on is configured with an appropriate IAM role. + +If you are seeing this error and you are **not** intending to use instance profile credentials, then you need to make +sure that you are properly providing credentials to the SDK. + +For more information, see :doc:`credentials`. diff --git a/vendor/aws/aws-sdk-php/docs/feature-commands.rst b/vendor/aws/aws-sdk-php/docs/feature-commands.rst new file mode 100644 index 0000000..2c54449 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/feature-commands.rst @@ -0,0 +1,204 @@ +=============== +Command Objects +=============== + +Command objects are fundamental to how the SDK works. In normal usage of the SDK, you may never interact with command +objects. However, if you are :ref:`performing operations in parallel `, +:ref:`inspecting data from the request or response `, or writing custom plugins, you will need +to understand how they work. + +Typical SDK usage +----------------- + +.. include:: _snippets/performing-operations.txt + +A peek under the hood +--------------------- + +If you examine a client class, you will see that the methods corresponding to the operations do not actually exist. They +are implemented using the ``__call()`` magic method behavior. These pseudo-methods are actually shortcuts that +encapsulate the SDK's — and the underlying Guzzle library's — use of command objects. + +For example, you could perform the same ``DescribeTable`` operation from the preceding section using command objects: + +.. code-block:: php + + $command = $dynamoDbClient->getCommand('DescribeTable', array( + 'TableName' => 'YourTableName', + )); + $result = $command->getResult(); + +A **Command** is an object that represents the execution of a service operation. Command objects are an abstraction of +the process of formatting a request to a service, executing the request, receiving the response, and formatting the +results. Commands are created and executed by the client and contain references to **Request** and **Response** objects. +The **Result** object is a what we refer to as a :doc:`"modeled response" `. + +Using command objects +--------------------- + +Using the pseudo-methods for performing operations is shorter and preferred for typical use cases, but command objects +provide greater flexibility and access to additional data. + +Manipulating command objects before execution +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +When you create a command using a client's ``getCommand()`` method, it does not immediately execute. Because commands +are lazily executed, it is possible to pass the command object around and add or modify the parameters. The following +examples show how to work with command objects: + +.. code-block:: php + + // You can add parameters after instantiation + $command = $s3Client->getCommand('ListObjects'); + $command->set('MaxKeys', 50); + $command->set('Prefix', 'foo/baz/'); + $result = $command->getResult(); + + // You can also modify parameters + $command = $s3Client->getCommand('ListObjects', array( + 'MaxKeys' => 50, + 'Prefix' => 'foo/baz/', + )); + $command->set('MaxKeys', 100); + $result = $command->getResult(); + + // The set method is chainable + $result = $s3Client->getCommand('ListObjects') + ->set('MaxKeys', 50); + ->set('Prefix', 'foo/baz/'); + ->getResult(); + + // You can also use array access + $command = $s3Client->getCommand('ListObjects'); + $command['MaxKeys'] = 50; + $command['Prefix'] = 'foo/baz/'; + $result = $command->getResult(); + +Also, see the `API docs for commands +`_. + +.. _requests_and_responses: + +Request and response objects +~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +From the command object, you can access the request, response, and result objects. The availability of these objects +depend on the state of the command object. + +Managing command state +^^^^^^^^^^^^^^^^^^^^^^ + +Commands must be prepared before the request object is available, and commands must executed before the response and +result objects are available. + +.. code-block:: php + + // 1. Create + $command = $client->getCommand('OperationName'); + + // 2. Prepare + $command->prepare(); + $request = $command->getRequest(); + // Note: `prepare()` also returns the request object + + // 3. Execute + $command->execute(); + $response = $command->getResponse(); + $result = $command->getResult(); + // Note: `execute()` also returns the result object + +This is nice, because it gives you a chance to modify the request before it is actually sent. + +.. code-block:: php + + $command = $client->getCommand('OperationName'); + $request = $command->prepare(); + $request->addHeader('foo', 'bar'); + $result = $command->execute(); + +You don't have to manage each aspect of the state though, calling ``execute()`` will also prepare the command, and +calling ``getResult()`` will prepare and execute the command. + +Using requests and responses +^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +Request and response objects contain data about the actual requests and responses to the service. + +.. code-block:: php + + $command = $client->getCommand('OperationName'); + $command->execute(); + + // Get and use the request object + $request = $command->getRequest(); + $contentLength = $request->getHeader('Content-Length'); + $url = $request->getUrl(); + + // Get and use the response object + $response = $command->getResponse(); + $success = $response->isSuccessful(); + $status = $response->getStatusCode(); + +You can also take advantage of the ``__toString`` behavior of the request and response objects. If you print them +(e.g., ``echo $request;``), you can see the raw request and response data that was sent over the wire. + +To learn more, read the API docs for the `Request +`_ and `Response +`_ classes. + +.. _parallel_commands: + +Executing commands in parallel +------------------------------ + +The AWS SDK for PHP allows you to execute multiple operations in parallel when you use command objects. This can reduce +the total time (sometimes drastically) it takes to perform a set of operations, since you can do them at the same time +instead of one after another. The following shows an example of how you could upload two files to Amazon S3 at the same +time. + +.. code-block:: php + + $commands = array(); + $commands[] = $s3Client->getCommand('PutObject', array( + 'Bucket' => 'SOME_BUCKET', + 'Key' => 'photos/photo01.jpg', + 'Body' => fopen('/tmp/photo01.jpg', 'r'), + )); + $commands[] = $s3Client->getCommand('PutObject', array( + 'Bucket' => 'SOME_BUCKET', + 'Key' => 'photos/photo02.jpg', + 'Body' => fopen('/tmp/photo02.jpg', 'r'), + )); + + // Execute an array of command objects to do them in parallel + $s3Client->execute($commands); + + // Loop over the commands, which have now all been executed + foreach ($commands as $command) { + $result = $command->getResult(); + // Do something with result + } + +Error handling with parallel commands +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +When executing commands in parallel, error handling becomes a bit trickier. If an exception is thrown, then the SDK (via +Guzzle) will aggregate the exceptions together and throw a single ``Guzzle\Service\Exception\CommandTransferException`` +(`see the API docs +`_) once all +of the commands have completed execution. This exception class keeps track of which commands succeeded and which failed +and also allows you to fetch the original exceptions thrown for failed commands. + +.. code-block:: php + + use Guzzle\Service\Exception\CommandTransferException; + + try { + $succeeded = $client->execute($commands); + } catch (CommandTransferException $e) { + $succeeded = $e->getSuccessfulCommands(); + echo "Failed Commands:\n"; + foreach ($e->getFailedCommands() as $failedCommand) { + echo $e->getExceptionForFailedCommand($failedCommand)->getMessage() . "\n"; + } + } diff --git a/vendor/aws/aws-sdk-php/docs/feature-dynamodb-session-handler.rst b/vendor/aws/aws-sdk-php/docs/feature-dynamodb-session-handler.rst new file mode 100644 index 0000000..36da691 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/feature-dynamodb-session-handler.rst @@ -0,0 +1,292 @@ +======================== +DynamoDB Session Handler +======================== + +Introduction +------------ + +The **DynamoDB Session Handler** is a custom session handler for PHP that allows developers to use Amazon DynamoDB as a +session store. Using DynamoDB for session storage alleviates issues that occur with session handling in a distributed +web application by moving sessions off of the local file system and into a shared location. DynamoDB is fast, scalable, +easy to setup, and handles replication of your data automatically. + +The DynamoDB Session Handler uses the ``session_set_save_handler()`` function to hook DynamoDB operations into PHP's +`native session functions `_ to allow for a true drop in replacement. This +includes support for features like session locking and garbage collection which are a part of PHP's default session +handler. + +For more information on the Amazon DynamoDB service, please visit the `Amazon DynamoDB homepage +`_. + +Basic Usage +----------- + +1. Register the handler +~~~~~~~~~~~~~~~~~~~~~~~ + +The first step is to instantiate the Amazon DynamoDB client and register the session handler. + +.. code-block:: php + + require 'vendor/autoload.php'; + + use Aws\DynamoDb\DynamoDbClient; + + $dynamoDb = DynamoDbClient::factory(array( + 'key' => '', + 'secret' => '', + 'region' => '' + )); + + $sessionHandler = $dynamoDb->registerSessionHandler(array( + 'table_name' => 'sessions' + )); + +You can also instantiate the ``SessionHandler`` object directly using it's ``factory`` method. + +.. code-block:: php + + require 'vendor/autoload.php'; + + use Aws\DynamoDb\DynamoDbClient; + use Aws\DynamoDb\Session\SessionHandler; + + $dynamoDb = DynamoDbClient::factory(array( + 'key' => '', + 'secret' => '', + 'region' => '', + )); + + $sessionHandler = SessionHandler::factory(array( + 'dynamodb_client' => $dynamoDb, + 'table_name' => 'sessions', + )); + $sessionHandler->register(); + +2. Create a table for storing your sessions +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Before you can actually use the session handler, you need to create a table in which to store the sessions. This can be +done ahead of time through the `AWS Console for Amazon DynamoDB `_, or you +can use the session handler object (which you've already configured with the table name) by doing the following: + +.. code-block:: php + + $sessionHandler->createSessionsTable(5, 5); + +The two parameters for this function are used to specify the read and write provisioned throughput for the table, +respectively. + +.. note:: + + The ``createSessionsTable`` function uses the ``TableExists`` :doc:`waiter ` internally, so this + function call will block until the table exists and is ready to be used. + +3. Use PHP sessions like normal +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Once the session handler is registered and the table exists, you can write to and read from the session using the +``$_SESSION`` superglobal, just like you normally do with PHP's default session handler. The DynamoDB Session Handler +encapsulates and abstracts the interactions with Amazon DynamoDB and enables you to simply use PHP's native session +functions and interface. + +.. code-block:: php + + // Start the session + session_start(); + + // Alter the session data + $_SESSION['user.name'] = 'jeremy'; + $_SESSION['user.role'] = 'admin'; + + // Close the session (optional, but recommended) + session_write_close(); + +Configuration +------------- + +You may configure the behavior of the session handler using the following options. All options are optional, but you +should make sure to understand what the defaults are. + +============================ =========================================================================================== +``table_name`` The name of the DynamoDB table in which to store the sessions. This defaults to ``sessions``. +---------------------------- ------------------------------------------------------------------------------------------- +``hash_key`` The name of the hash key in the DynamoDB sessions table. This defaults to ``id``. +---------------------------- ------------------------------------------------------------------------------------------- +``session_lifetime`` The lifetime of an inactive session before it should be garbage collected. If it is not + provided, then the actual lifetime value that will be used is + ``ini_get('session.gc_maxlifetime')``. +---------------------------- ------------------------------------------------------------------------------------------- +``consistent_read`` Whether or not the session handler should use consistent reads for the ``GetItem`` + operation. This defaults to ``true``. +---------------------------- ------------------------------------------------------------------------------------------- +``locking_strategy`` The strategy used for doing session locking. By default the handler uses the + ``NullLockingStrategy``, which means that session locking is **not** enabled (see the + :ref:`ddbsh-session-locking` section for more information). Valid values for this option + include null, 'null', 'pessemistic', or an instance of ``NullLockingStrategy`` or + ``PessimisticLockingStrategy``. +---------------------------- ------------------------------------------------------------------------------------------- +``automatic_gc`` Whether or not to use PHP's session auto garbage collection. This defaults to the value of + ``(bool) ini_get('session.gc_probability')``, but the recommended value is ``false``. (see + the :ref:`ddbsh-garbage-collection` section for more information). +---------------------------- ------------------------------------------------------------------------------------------- +``gc_batch_size`` The batch size used for removing expired sessions during garbage collection. This defaults + to ``25``, which is the maximum size of a single ``BatchWriteItem`` operation. This value + should also take your provisioned throughput into account as well as the timing of your + garbage collection. +---------------------------- ------------------------------------------------------------------------------------------- +``gc_operation_delay`` The delay (in seconds) between service operations performed during garbage collection. This + defaults to ``0``. Increasing this value allows you to throttle your own requests in an + attempt to stay within your provisioned throughput capacity during garbage collection. +---------------------------- ------------------------------------------------------------------------------------------- +``max_lock_wait_time`` Maximum time (in seconds) that the session handler should wait to acquire a lock before + giving up. This defaults to ``10`` and is only used with the ``PessimisticLockingStrategy``. +---------------------------- ------------------------------------------------------------------------------------------- +``min_lock_retry_microtime`` Minimum time (in microseconds) that the session handler should wait between attempts + to acquire a lock. This defaults to ``10000`` and is only used with the + ``PessimisticLockingStrategy``. +---------------------------- ------------------------------------------------------------------------------------------- +``max_lock_retry_microtime`` Maximum time (in microseconds) that the session handler should wait between attempts + to acquire a lock. This defaults to ``50000`` and is only used with the + ``PessimisticLockingStrategy``. +---------------------------- ------------------------------------------------------------------------------------------- +``dynamodb_client`` The ``DynamoDbClient`` object that should be used for performing DynamoDB operations. If + you register the session handler from a client object using the ``registerSessionHandler()`` + method, this will default to the client you are registering it from. If using the + ``SessionHandler::factory()`` method, you are required to provide an instance of + ``DynamoDbClient``. +============================ =========================================================================================== + +To configure the Session Handler, you must specify the configuration options when you instantiate the handler. The +following code is an example with all of the configuration options specified. + +.. code-block:: php + + $sessionHandler = $dynamoDb->registerSessionHandler(array( + 'table_name' => 'sessions', + 'hash_key' => 'id', + 'session_lifetime' => 3600, + 'consistent_read' => true, + 'locking_strategy' => null, + 'automatic_gc' => 0, + 'gc_batch_size' => 50, + 'max_lock_wait_time' => 15, + 'min_lock_retry_microtime' => 5000, + 'max_lock_retry_microtime' => 50000, + )); + +Pricing +------- + +Aside from data storage and data transfer fees, the costs associated with using Amazon DynamoDB are calculated based on +the provisioned throughput capacity of your table (see the `Amazon DynamoDB pricing details +`_). Throughput is measured in units of Write Capacity and Read Capacity. The +Amazon DynamoDB homepage says: + + A unit of Write Capacity enables you to perform one write per second for items of up to 1KB in size. Similarly, a + unit of Read Capacity enables you to perform one strongly consistent read per second (or two eventually consistent + reads per second) of items of up to 1KB in size. Larger items will require more capacity. You can calculate the + number of units of read and write capacity you need by estimating the number of reads or writes you need to do per + second and multiplying by the size of your items (rounded up to the nearest KB). + +Ultimately, the throughput and the costs required for your sessions table is going to correlate with your expected +traffic and session size. The following table explains the amount of read and write operations that are performed on +your DynamoDB table for each of the session functions. + ++----------------------------------------+-----------------------------------------------------------------------------+ +| Read via ``session_start()`` | * 1 read operation (only 0.5 if ``consistent_read`` is ``false``). | +| (Using ``NullLockingStrategy``) | * (Conditional) 1 write operation to delete the session if it is expired. | ++----------------------------------------+-----------------------------------------------------------------------------+ +| Read via ``session_start()`` | * A minimum of 1 *write* operation. | +| (Using ``PessimisticLockingStrategy``) | * (Conditional) Additional write operations for each attempt at acquiring a | +| | lock on the session. Based on configured lock wait time and retry options.| +| | * (Conditional) 1 write operation to delete the session if it is expired. | ++----------------------------------------+-----------------------------------------------------------------------------+ +| Write via ``session_write_close()`` | * 1 write operation. | ++----------------------------------------+-----------------------------------------------------------------------------+ +| Delete via ``session_destroy()`` | * 1 write operation. | ++----------------------------------------+-----------------------------------------------------------------------------+ +| Garbage Collection | * 0.5 read operations **per KB of data in the table** to scan for expired | +| | sessions. | +| | * 1 write operation **per expired item** to delete it. | ++----------------------------------------+-----------------------------------------------------------------------------+ + +.. _ddbsh-session-locking: + +Session Locking +--------------- + +The DynamoDB Session Handler supports pessimistic session locking in order to mimic the behavior of PHP's default +session handler. By default the DynamoDB Session Handler has this feature *turned off* since it can become a performance +bottleneck and drive up costs, especially when an application accesses the session when using ajax requests or iframes. +You should carefully consider whether or not your application requires session locking or not before enabling it. + +By default the session handler uses the ``NullLockingStrategy`` which does not do any session locking. To enable session +locking, you should use the ``PessimisticLockingStrategy``, which can be specified when the session handler is created. + +.. code-block:: php + + $sessionHandler = $dynamoDb->registerSessionHandler(array( + 'table_name' => 'sessions', + 'locking_strategy' => 'pessimistic', + )); + +.. _ddbsh-garbage-collection: + +Garbage Collection +------------------ + +The DynamoDB Session Handler supports session garbage collection by using a series of ``Scan`` and ``BatchWriteItem`` +operations. Due to the nature of how the ``Scan`` operation works and in order to find all of the expired sessions and +delete them, the garbage collection process can require a lot of provisioned throughput. + +For this reason it is discouraged to rely on the PHP's normal session garbage collection triggers (i.e., the +``session.gc_probability`` and ``session.gc_divisor`` ini settings). A better practice is to set +``session.gc_probability`` to ``0`` and schedule the garbage collection to occur during an off-peak time where a +burst of consumed throughput will not disrupt the rest of the application. + +For example, you could have a nightly cron job trigger a script to run the garbage collection. This script might look +something like the following: + +.. code-block:: php + + require 'vendor/autoload.php'; + + use Aws\DynamoDb\DynamoDbClient; + use Aws\DynamoDb\Session\SessionHandler; + + $dynamoDb = DynamoDbClient::factory(array( + 'key' => '', + 'secret' => '', + 'region' => '', + )); + + $sessionHandler = SessionHandler::factory(array( + 'dynamodb_client' => $dynamoDb, + 'table_name' => 'sessions', + )); + + $sessionHandler->garbageCollect(); + +You can also use the ``gc_operation_delay`` configuration option on the session handler to introduce delays in between +the ``Scan`` and ``BatchWriteItem`` operations that are performed by the garbage collection process. This will increase +the amount of time it takes the garbage collection to complete, but it can help you spread out the requests made by the +session handler in order to help you stay close to or within your provisioned throughput capacity during garbage +collection. + +Best Practices +-------------- + +#. Create your sessions table in a region that is geographically closest to or in the same region as your application + servers. This will ensure the lowest latency between your application and DynamoDB database. +#. Choose the provisioned throughput capacity of your sessions table carefully, taking into account the expected traffic + to your application and the expected size of your sessions. +#. Monitor your consumed throughput through the AWS Management Console or with Amazon CloudWatch and adjust your + throughput settings as needed to meet the demands of your application. +#. Keep the size of your sessions small. Sessions that are less than 1KB will perform better and require less + provisioned throughput capacity. +#. Do not use session locking unless your application requires it. +#. Instead of using PHP's built-in session garbage collection triggers, schedule your garbage collection via a cron job, + or another scheduling mechanism, to run during off-peak hours. Use the ``gc_operation_delay`` option to add delays + in between the requests performed for the garbage collection process. + diff --git a/vendor/aws/aws-sdk-php/docs/feature-facades.rst b/vendor/aws/aws-sdk-php/docs/feature-facades.rst new file mode 100644 index 0000000..dcb0c5f --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/feature-facades.rst @@ -0,0 +1,170 @@ +===================== +Static Client Facades +===================== + +Introduction +------------ + +Version 2.4 of the AWS SDK for PHP adds the ability to enable and use static client "facades". These facades provide an +easy, static interface to service clients available in the service builder. For example, when working with a normal +client instance, you might have code that looks like the following: + +.. code-block:: php + + // Get the configured S3 client from the service builder + $s3 = $aws->get('s3'); + + // Execute the CreateBucket command using the S3 client + $s3->createBucket(array('Bucket' => 'your_new_bucket_name')); + +With client facades enabled, this can also be accomplished with the following code: + +.. code-block:: php + + // Execute the CreateBucket command using the S3 client + S3::createBucket(array('Bucket' => 'your_new_bucket_name')); + +Why Use Client Facades? +----------------------- + +The use of static client facades is completely optional. We have included this feature in the SDK in order to appeal to +PHP developers who prefer static notation or who are familiar with PHP frameworks like Code Ignitor, Laravel, or Kohana +where this style of method invocation is common. + +Though using static client facades has little real benefit over using client instances, it can make your code more +concise and prevent your from having to inject the service builder or client instance into the context of where you +need the client object. This can make your code easier to write and understand. Whether or not you should use the client +facades is purely a matter of preference. + +The way in which client facades work in the AWS SDK for PHP is similar to how `facades work in the Laravel 4 +Framework `_. Even though you are calling static classes, all of the method calls are +proxied to method calls on actual client instances — the ones stored in the service builder. This means that the usage +of the clients via the client facades can still be mocked in your unit tests, which removes one of the general +disadvantages to using static classes in object-oriented programming. For information about how to test code that uses +client facades, please see the **Testing Code that Uses Client Facades** +below. + +Enabling and Using Client Facades +--------------------------------- + +To enable static client facades to be used in your application, you must use the ``Aws\Common\Aws::enableFacades`` +method when you setup the service builder. + +.. code-block:: php + + // Include the Composer autoloader + require 'vendor/autoload.php'; + + // Instantiate the SDK service builder with my config and enable facades + $aws = Aws::factory('/path/to/my_config.php')->enableFacades(); + +This will setup the client facades and alias them into the global namespace. After that, you can use them anywhere to +have more simple and expressive code for interacting with AWS services. + +.. code-block:: php + + // List current buckets + echo "Current Buckets:\n"; + foreach (S3::getListBucketsIterator() as $bucket) { + echo "{$bucket['Name']}\n"; + } + + $args = array('Bucket' => 'your_new_bucket_name'); + $file = '/path/to/the/file/to/upload.jpg'; + + // Create a new bucket and wait until it is available for uploads + S3::createBucket($args) and S3::waitUntilBucketExists($args); + echo "\nCreated a new bucket: {$args['Bucket']}.\n"; + + // Upload a file to the new bucket + $result = S3::putObject($args + array( + 'Key' => basename($file), + 'Body' => fopen($file, 'r'), + )); + echo "\nCreated a new object: {$result['ObjectURL']}\n"; + +You can also mount the facades into a namespace other than the global namespace. For example, if you wanted to make the +client facades available in the "Services" namespace, then you could do the following: + +.. code-block:: php + + Aws::factory('/path/to/my_config.php')->enableFacades('Services'); + + $result = Services\DynamoDb::listTables(); + +The client facades that are available are determined by what is in your service builder configuration (see +:doc:`configuration`). If you are extending the SDK's default configuration file or not providing one at all, then all +of the clients should be accessible from the service builder instance and client facades (once enabled) by default. + +Based on the following excerpt from the default configuration file (located at +``src/Aws/Common/Resources/aws-config.php``): + +.. code-block:: php + + 's3' => array( + 'alias' => 'S3', + 'extends' => 'default_settings', + 'class' => 'Aws\S3\S3Client' + ), + +The ``'class'`` key indicates the client class that the static client facade will proxy to, and the ``'alias'`` key +indicates what the client facade will be named. Only entries in the service builder config that have both the +``'alias'`` and ``'class'`` keys specified will be mounted as static client facades. You can potentially update or add +to your service builder config to alter or create new or custom client facades. + +Testing Code that Uses Client Facades +------------------------------------- + +With the static client facades in the SDK, even though you are calling static classes, all of the method calls are +proxied to method calls on actual client instances — the ones stored in the service builder. This means that they can +be mocked during tests, which removes one of the general disadvantages to using static classes in object-oriented +programming. + +To mock a client facade for a test, you can explicitly set a mocked client object for the key in the service builder +that would normally contain the client referenced by the client facade. Here is a complete, but contrived, PHPUnit test +showing how this is done: + +.. code-block:: php + + serviceBuilder = Aws::factory(); + $this->serviceBuilder->enableFacades(); + } + + public function testCanDoSomethingWithYourAppsFileBrowserClass() + { + // Mock the ListBuckets method of S3 client + $mockS3Client = $this->getMockBuilder('Aws\S3\S3Client') + ->disableOriginalConstructor() + ->getMock(); + $mockS3Client->expects($this->any()) + ->method('listBuckets') + ->will($this->returnValue(new Model(array( + 'Buckets' => array( + array('Name' => 'foo'), + array('Name' => 'bar'), + array('Name' => 'baz') + ) + )))); + $this->serviceBuilder->set('s3', $mockS3Client); + + // Test the FileBrowser object that uses the S3 client facade internally + $fileBrowser = new FileBrowser(); + $partitions = $fileBrowser->getPartitions(); + $this->assertEquals(array('foo', 'bar', 'baz'), $partitions); + } + } + +Alternatively, if you are specifically only mocking responses from clients, you might consider using the `Guzzle Mock +Plugin `_. diff --git a/vendor/aws/aws-sdk-php/docs/feature-iterators.rst b/vendor/aws/aws-sdk-php/docs/feature-iterators.rst new file mode 100644 index 0000000..7c08304 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/feature-iterators.rst @@ -0,0 +1,93 @@ +========= +Iterators +========= + +Introduction +------------ + +.. include:: _snippets/iterators-intro.txt + +The ``getIterator()`` method also accepts a command object for the first argument. If you have a command object already +instantiated, you can create an iterator directly from the command object. + +.. code-block:: php + + $command = $client->getCommand('ListObjects', array('Bucket' => 'my-bucket')); + $iterator = $client->getIterator($command); + +Iterator Objects +---------------- + +The actual object returned by ``getIterator()`` is an instance of the ``Aws\Common\Iterator\AwsResourceIterator`` class +(see the `API docs `_ +for more information about its methods and properties). This class implements PHP's native ``Iterator`` interface, which +is why it works with ``foreach``, can be used with iterator functions like ``iterator_to_array``, and integrates well +with `SPL iterators `_ like ``LimitIterator``. + +Iterator objects only store one "page" of results at a time and only make as many requests as they need based on the +current iteration. The S3 ``ListObjects`` operation only returns up to 1000 objects at a time. If your bucket has ~10000 +objects, then the iterator would need to do 10 requests. However, it does not execute the subsequent requests until +needed. If you are iterating through the results, the first request would happen when you start iterating, and the +second request would not happen until you iterate to the 1001th object. This can help your application save memory by +only holding one page of results at a time. + +Basic Configuration +------------------- + +Iterators accept an extra set of parameters that are not passed into the commands. You can set a limit on the number of +results you want with the ``limit`` parameter, and you can control how many results you want to get back per request +using the ``page_size`` parameter. If no ``limit`` is specified, then all results are retrieved. If no ``page_size`` is +specified, then the Iterator will use the maximum page size allowed by the operation being executed. + +The following example will make 10 Amazon S3 ``ListObjects`` requests (assuming there are more than 1000 objects in the +specified bucket) that each return up to 100 objects. The ``foreach`` loop will yield up to 999 objects. + +.. code-block:: php + + $iterator = $client->getIterator('ListObjects', array( + 'Bucket' => 'my-bucket' + ), array( + 'limit' => 999, + 'page_size' => 100 + )); + + foreach ($iterator as $object) { + echo $object['Key'] . "\n"; + } + +There are some limitations to the ``limit`` and ``page_size`` parameters though. Not all operations support specifying +a page size or limit, so the Iterator will do its best with what you provide. For example, if an operation always +returns 1000 results, and you specify a limit of 100, the Iterator will only yield 100 results, even though the actual +request sent to the service yielded 1000. + +Iterator Events +--------------- + +Iterators emit 2 kinds of events: + +1. ``resource_iterator.before_send`` - Emitted right before a request is sent to retrieve results. +2. ``resource_iterator.after_send`` - Emitted right after a request is sent to retrieve results. + +Iterator objects extend the ``Guzzle\Common\AbstractHasDispatcher`` class which exposes the ``addSubscriber()`` method +and the ``getEventDispatcher()`` method. To attach listeners, you can use the following example which echoes a message +right before and after a request is executed by the iterator. + +.. code-block:: php + + $iterator = $client->getIterator('ListObjects', array( + 'Bucket' => 'my-bucket' + )); + + // Get the event dispatcher and register listeners for both events + $dispatcher = $iterator->getEventDispatcher(); + $dispatcher->addListener('resource_iterator.before_send', function ($event) { + echo "Getting more results…\n"; + }); + $dispatcher->addListener('resource_iterator.after_send', function ($event) use ($iterator) { + $requestCount = $iterator->getRequestCount(); + echo "Results received. {$requestCount} request(s) made so far.\n"; + }); + + foreach ($iterator as $object) { + echo $object['Key'] . "\n"; + } diff --git a/vendor/aws/aws-sdk-php/docs/feature-models.rst b/vendor/aws/aws-sdk-php/docs/feature-models.rst new file mode 100644 index 0000000..1d9614f --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/feature-models.rst @@ -0,0 +1,167 @@ +================= +Modeled Responses +================= + +Introduction +------------ + +.. include:: _snippets/models-intro.txt + +Working with Model objects +-------------------------- + +Model objects (and Command objects) inherit from the `Guzzle Collection class +`_ and implement PHP's native +``ArrayAccess``, ``IteratorAggregate``, and ``Countable`` interfaces. This means that they behave like arrays when you +are accessing keys and iterating over key-value pairs. You can also use the ``toArray()`` method of the Model object to +get the array form directly. + +However, model objects will not throw errors on undefined keys, so it's safe to use values directly without doing +``isset()`` checks. It the key doesn't exist, then the value will be returned as ``null``. + +.. code-block:: php + + // Use an instance of S3Client to get an object + $result = $s3Client->getObject(array( + 'Bucket' => 'my-bucket', + 'Key' => 'test.txt' + )); + + // Using a value that may not exist + if (!$result['ContentLength']) { + echo "Empty file."; + } + + $isDeleted = (bool) $result->get('DeleteMarker'); + +Of course, you can still use ``isset()`` checks if you want to, since ``Model`` does implement ``ArrayAccess``. The +model object (and underlying Collection object) also has convenience methods for finding and checking for keys and +values. + +.. code-block:: php + + // You can use isset() since the object implements ArrayAccess + if (!isset($result['ContentLength'])) { + echo "Empty file."; + } + + // There is also a method that does the same type of check + if (!$result->hasKey('ContentLength')) { + echo "Empty file."; + } + + // If needed, you can search for a key in a case-insensitive manner + echo $result->keySearch('body'); + //> Body + echo $result->keySearch('Body'); + //> Body + + // You can also list all of the keys in the result + var_export($result->getKeys()); + //> array ( 'Body', 'DeleteMarker', 'Expiration', 'ContentLength', ... ) + + // The getAll() method will return the result data as an array + // You can specify a set of keys to only get a subset of the data + var_export($result->getAll(array('Body', 'ContentLength'))); + //> array ( 'Body' => 'Hello!' , 'ContentLength' => 6 ) + +Getting nested values +~~~~~~~~~~~~~~~~~~~~~ + +The ``getPath()`` method of the model is useful for easily getting nested values from a response. The path is specified +as a series of keys separated by slashes. + +.. code-block:: php + + // Perform a RunInstances operation and traverse into the results to get the InstanceId + $result = $ec2Client->runInstances(array( + 'ImageId' => 'ami-548f13d', + 'MinCount' => 1, + 'MaxCount' => 1, + 'InstanceType' => 't1.micro', + )); + $instanceId = $result->getPath('Instances/0/InstanceId'); + +Wildcards are also supported so that you can get extract an array of data. The following example is a modification of +the preceding such that multiple InstanceIds can be retrieved. + +.. code-block:: php + + // Perform a RunInstances operation and get an array of the InstanceIds that were created + $result = $ec2Client->runInstances(array( + 'ImageId' => 'ami-548f13d', + 'MinCount' => 3, + 'MaxCount' => 5, + 'InstanceType' => 't1.micro', + )); + $instanceId = $result->getPath('Instances/*/InstanceId'); + +Using data in the model +----------------------- + +Response Models contain the parsed data from the response from a service operation, so the contents of the model will +be different depending on which operation you've performed. + +The SDK's API docs are the best resource for discovering what the model object will contain for a given operation. The +API docs contain a full specification of the data in the response model under the *Returns* section of the docs for an +operation (e.g., `S3 GetObject operation `_, +`EC2 RunInstances operation `_). + +From within your code you can convert the response model directly into an array using the ``toArray()`` method. If you +are doing some debugging in your code, you could use ``toArray()`` in conjunction with ``print_r()`` to print out a +simple representation of the response data. + +.. code-block:: php + + $result = $ec2Client->runInstances(array(/* ... */)); + print_r($result->toArray()); + +You can also examine the service description for a service, which is located in the ``Resources`` directory within a +given client's namespace directory. For example, here is a snippet from the SQS service description (located in +``src/Aws/Sqs/Resources/``) that shows the schema for the response of the ``SendMessage`` operation. + +.. code-block:: php + + // ... + 'SendMessageResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'MD5OfMessageBody' => array( + 'description' => 'An MD5 digest of the non-URL-encoded message body string. This can be used [...]', + 'type' => 'string', + 'location' => 'xml', + ), + 'MessageId' => array( + 'description' => 'The message ID of the message added to the queue.', + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + // ... + +Getting Response Headers +------------------------ + +The ``Response`` object is not directly accessible from the ``Model`` object. If you are interested in getting header +values, the status code, or other data from the response you will need to get the ``Response`` object from the +``Command`` object (see :doc:`feature-commands`). You may need to switch from using the shorthand command syntax to the +expanded syntax so that the command object can be accessed directly. + +.. code-block:: php + + // Getting the response Model with the shorthand syntax + $result = $s3Client->createBucket(array(/* ... */)); + + // Getting the response Model with the expanded syntax + $command = $s3Client->getCommand('CreateBucket', array(/* ... */)); + $result = $command->getResult(); + + // Getting the Response object from the Command + $response = $command->getResponse(); + $contentLength = $response->getHeader('Content-Length'); + $statusCode = $response->getStatusCode(); + +In some cases, particularly with REST-like services like Amazon S3 and Amazon Glacier, most of the important headers are +already included in the response model. diff --git a/vendor/aws/aws-sdk-php/docs/feature-s3-stream-wrapper.rst b/vendor/aws/aws-sdk-php/docs/feature-s3-stream-wrapper.rst new file mode 100644 index 0000000..baa9222 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/feature-s3-stream-wrapper.rst @@ -0,0 +1,279 @@ +======================== +Amazon S3 Stream Wrapper +======================== + +Introduction +------------ + +The Amazon S3 stream wrapper allows you to store and retrieve data from Amazon S3 using built-in PHP functions like +``file_get_contents``, ``fopen``, ``copy``, ``rename``, ``unlink``, ``mkdir``, ``rmdir``, etc. + +You need to register the Amazon S3 stream wrapper in order to use it: + +.. code-block:: php + + // Register the stream wrapper from an S3Client object + $client->registerStreamWrapper(); + +This allows you to access buckets and objects stored in Amazon S3 using the ``s3://`` protocol. The "s3" stream wrapper +accepts strings that contain a bucket name followed by a forward slash and an optional object key or prefix: +``s3://[/]``. + +Downloading data +---------------- + +You can grab the contents of an object using ``file_get_contents``. Be careful with this function though; it loads the +entire contents of the object into memory. + +.. code-block:: php + + // Download the body of the "key" object in the "bucket" bucket + $data = file_get_contents('s3://bucket/key'); + +Use ``fopen()`` when working with larger files or if you need to stream data from Amazon S3. + +.. code-block:: php + + // Open a stream in read-only mode + if ($stream = fopen('s3://bucket/key', 'r')) { + // While the stream is still open + while (!feof($stream)) { + // Read 1024 bytes from the stream + echo fread($stream, 1024); + } + // Be sure to close the stream resource when you're done with it + fclose($stream); + } + +Opening Seekable streams +~~~~~~~~~~~~~~~~~~~~~~~~ + +Streams opened in "r" mode only allow data to be read from the stream, and are not seekable by default. This is so that +data can be downloaded from Amazon S3 in a truly streaming manner where previously read bytes do not need to be +buffered into memory. If you need a stream to be seekable, you can pass ``seekable`` into the `stream context +options `_ of a function. + +.. code-block:: php + + $context = stream_context_create(array( + 's3' => array( + 'seekable' => true + ) + )); + + if ($stream = fopen('s3://bucket/key', 'r', false, $context)) { + // Read bytes from the stream + fread($stream, 1024); + // Seek back to the beginning of the stream + fseek($steam, 0); + // Read the same bytes that were previously read + fread($stream, 1024); + fclose($stream); + } + +Opening seekable streams allows you to seek only to bytes that were previously read. You cannot skip ahead to bytes +that have not yet been read from the remote server. In order to allow previously read data to recalled, data is +buffered in a PHP temp stream using Guzzle's +`CachingEntityBody `_ decorator. +When the amount of cached data exceed 2MB, the data in the temp stream will transfer from memory to disk. Keep this in +mind when downloading large files from Amazon S3 using the ``seekable`` stream context setting. + +Uploading data +-------------- + +Data can be uploaded to Amazon S3 using ``file_put_contents()``. + +.. code-block:: php + + file_put_contents('s3://bucket/key', 'Hello!'); + +You can upload larger files by streaming data using ``fopen()`` and a "w", "x", or "a" stream access mode. The Amazon +S3 stream wrapper does **not** support simultaneous read and write streams (e.g. "r+", "w+", etc). This is because the +HTTP protocol does not allow simultaneous reading and writing. + +.. code-block:: php + + $stream = fopen('s3://bucket/key', 'w'); + fwrite($stream, 'Hello!'); + fclose($stream); + +.. note:: + + Because Amazon S3 requires a Content-Length header to be specified before the payload of a request is sent, the + data to be uploaded in a PutObject operation is internally buffered using a PHP temp stream until the stream is + flushed or closed. + +fopen modes +----------- + +PHP's `fopen() `_ function requires that a ``$mode`` option is specified. +The mode option specifies whether or not data can be read or written to a stream and if the file must exist when +opening a stream. The Amazon S3 stream wrapper supports the following modes: + += ====================================================================================================================== +r A read only stream where the file must already exist. +w A write only stream. If the file already exists it will be overwritten. +a A write only stream. If the file already exists, it will be downloaded to a temporary stream and any writes to + the stream will be appended to any previously uploaded data. +x A write only stream. An error is raised if the file does not already exist. += ====================================================================================================================== + +Other object functions +---------------------- + +Stream wrappers allow many different built-in PHP functions to work with a custom system like Amazon S3. Here are some +of the functions that the Amazon S3 stream wrapper allows you to perform with objects stored in Amazon S3. + +=============== ======================================================================================================== +unlink() Delete an object from a bucket. + + .. code-block:: php + + // Delete an object from a bucket + unlink('s3://bucket/key'); + + You can pass in any options available to the ``DeleteObject`` operation to modify how the object is + deleted (e.g. specifying a specific object version). + + .. code-block:: php + + // Delete a specific version of an object from a bucket + unlink('s3://bucket/key', stream_context_create(array( + 's3' => array('VersionId' => '123') + )); + +filesize() Get the size of an object. + + .. code-block:: php + + // Get the Content-Length of an object + $size = filesize('s3://bucket/key', ); + +is_file() Checks if a URL is a file. + + .. code-block:: php + + if (is_file('s3://bucket/key')) { + echo 'It is a file!'; + } + +file_exists() Checks if an object exists. + + .. code-block:: php + + if (file_exists('s3://bucket/key')) { + echo 'It exists!'; + } + +filetype() Checks if a URL maps to a file or bucket (dir). +file() Load the contents of an object in an array of lines. You can pass in any options available to the + ``GetObject`` operation to modify how the file is downloaded. +filemtime() Get the last modified date of an object. +rename() Rename an object by copying the object then deleting the original. You can pass in options available to + the ``CopyObject`` and ``DeleteObject`` operations to the stream context parameters to modify how the + object is copied and deleted. +copy() Copy an object from one location to another. You can pass options available to the ``CopyObject`` + operation into the stream context options to modify how the object is copied. + + .. code-block:: php + + // Copy a file on Amazon S3 to another bucket + copy('s3://bucket/key', 's3://other_bucket/key'); + +=============== ======================================================================================================== + +Working with buckets +-------------------- + +You can modify and browse Amazon S3 buckets similar to how PHP allows the modification and traversal of directories on +your filesystem. + +Here's an example of creating a bucket: + +.. code-block:: php + + mkdir('s3://bucket'); + +You can pass in stream context options to the ``mkdir()`` method to modify how the bucket is created using the +parameters available to the +`CreateBucket `_ operation. + +.. code-block:: php + + // Create a bucket in the EU region + mkdir('s3://bucket', stream_context_create(array( + 's3' => array( + 'LocationConstraint' => 'eu-west-1' + ) + )); + +You can delete buckets using the ``rmdir()`` function. + +.. code-block:: php + + // Delete a bucket + rmdir('s3://bucket'); + +.. note:: + + A bucket can only be deleted if it is empty. + +Listing the contents of a bucket +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +The `opendir() `_, +`readdir() `_, +`rewinddir() `_, and +`closedir() `_ PHP functions can be used with the Amazon S3 stream +wrapper to traverse the contents of a bucket. You can pass in parameters available to the +`ListObjects `_ operation as +custom stream context options to the ``opendir()`` function to modify how objects are listed. + +.. code-block:: php + + $dir = "s3://bucket/"; + + if (is_dir($dir) && ($dh = opendir($dir))) { + while (($file = readdir($dh)) !== false) { + echo "filename: {$file} : filetype: " . filetype($dir . $file) . "\n"; + } + closedir($dh); + } + +You can recursively list each object and prefix in a bucket using PHP's +`RecursiveDirectoryIterator `_. + +.. code-block:: php + + $dir = 's3://bucket'; + $iterator = new RecursiveIteratorIterator(new RecursiveDirectoryIterator($dir)); + + foreach ($iterator as $file) { + echo $file->getType() . ': ' . $file . "\n"; + } + +Another easy way to list the contents of the bucket is using the +`Symfony2 Finder component `_. + +.. code-block:: php + + get('s3')->registerStreamWrapper(); + + $finder = new Finder(); + + // Get all files and folders (key prefixes) from "bucket" that are less than 100k + // and have been updated in the last year + $finder->in('s3://bucket') + ->size('< 100K') + ->date('since 1 year ago'); + + foreach ($finder as $file) { + echo $file->getType() . ": {$file}\n"; + } diff --git a/vendor/aws/aws-sdk-php/docs/feature-waiters.rst b/vendor/aws/aws-sdk-php/docs/feature-waiters.rst new file mode 100644 index 0000000..2526e4c --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/feature-waiters.rst @@ -0,0 +1,175 @@ +======= +Waiters +======= + +Introduction +------------ + +.. include:: _snippets/waiters-intro.txt + +If the Waiter has to poll the bucket too many times, it will throw an ``Aws\Common\Exception\RuntimeException`` +exception. + +Basic Configuration +------------------- + +You can tune the number of polling attempts issued by a Waiter or the number of seconds to delay between each poll by +passing optional values prefixed with "waiter.": + +.. code-block:: php + + $s3Client->waitUntilBucketExists(array( + 'Bucket' => 'my-bucket', + 'waiter.interval' => 10, + 'waiter.max_attempts' => 3 + )); + +Waiter Objects +-------------- + +To interact with the Waiter object directly, you must use the ``getWaiter()`` method. The following code is equivalent +to the example in the preceding section. + +.. code-block:: php + + $bucketExistsWaiter = $s3Client->getWaiter('BucketExists') + ->setConfig(array('Bucket' => 'my-bucket')) + ->setInterval(10) + ->setMaxAttempts(3); + $bucketExistsWaiter->wait(); + +Waiter Events +------------- + +One benefit of working directly with the Waiter object is that you can attach event listeners. Waiters emit up to two +events in each **wait cycle**. A wait cycle does the following: + +#. Dispatch the ``waiter.before_attempt`` event. +#. Attempt to resolve the wait condition by making a request to the service and checking the result. +#. If the wait condition is resolved, the wait cycle exits. If ``max_attempts`` is reached, an exception is thrown. +#. Dispatch the ``waiter.before_wait`` event. +#. Sleep ``interval`` amount of seconds. + +Waiter objects extend the ``Guzzle\Common\AbstractHasDispatcher`` class which exposes the ``addSubscriber()`` method and +``getEventDispatcher()`` method. To attach listeners, you can use the following example, which is a modified version of +the previous one. + +.. code-block:: php + + // Get and configure the Waiter object + $waiter = $s3Client->getWaiter('BucketExists') + ->setConfig(array('Bucket' => 'my-bucket')) + ->setInterval(10) + ->setMaxAttempts(3); + + // Get the event dispatcher and register listeners for both events emitted by the Waiter + $dispatcher = $waiter->getEventDispatcher(); + $dispatcher->addListener('waiter.before_attempt', function () { + echo "Checking if the wait condition has been met…\n"; + }); + $dispatcher->addListener('waiter.before_wait', function () use ($waiter) { + $interval = $waiter->getInterval(); + echo "Sleeping for {$interval} seconds…\n"; + }); + + $waiter->wait(); + +Custom Waiters +-------------- + +It is possible to implement custom Waiter objects if your use case requires application-specific Waiter logic or Waiters +that are not yet supported by the SDK. You can use the ``getWaiterFactory()`` and ``setWaiterFactory()`` methods on the +client to manipulate the Waiter factory used by the client such that your custom Waiter can be instantiated. By default +the service clients use a ``Aws\Common\Waiter\CompositeWaiterFactory`` which allows you to add additional factories if +needed. The following example shows how to implement a contrived custom Waiter class and then modify a client's Waiter +factory such that it can create instances of the custom Waiter. + +.. code-block:: php + + namespace MyApp\FakeWaiters + { + use Aws\Common\Waiter\AbstractResourceWaiter; + + class SleptThreeTimes extends AbstractResourceWaiter + { + public function doWait() + { + if ($this->attempts < 3) { + echo "Need to sleep…\n"; + return false; + } else { + echo "Now I've slept 3 times.\n"; + return true; + } + } + } + } + + namespace + { + use Aws\S3\S3Client; + use Aws\Common\Waiter\WaiterClassFactory; + + $s3Client = S3Client::factory(); + + $compositeFactory = $s3Client->getWaiterFactory(); + $compositeFactory->addFactory(new WaiterClassFactory('MyApp\FakeWaiters')); + + $waiter = $s3Client->waitUntilSleptThreeTimes(); + } + +The result of this code should look like the following:: + + Need to sleep… + Need to sleep… + Need to sleep… + Now I've slept 3 times. + +Waiter Definitions +------------------ + +The Waiters that are included in the SDK are defined in the service description for their client. They are defined +using a configuration DSL (domain-specific language) that describes the default wait intervals, wait conditions, and +how to check or poll the resource to resolve the condition. + +This data is automatically consumed and used by the ``Aws\Common\Waiter\WaiterConfigFactory`` class when a client is +instantiated so that the waiters defined in the service description are available to the client. + +The following is an excerpt of the Amazon Glacier service description that defines the Waiters provided by +``Aws\Glacier\GlacierClient``. + +.. code-block:: php + + return array( + // ... + + 'waiters' => array( + '__default__' => array( + 'interval' => 3, + 'max_attempts' => 15, + ), + '__VaultState' => array( + 'operation' => 'DescribeVault', + ), + 'VaultExists' => array( + 'extends' => '__VaultState', + 'success.type' => 'output', + 'description' => 'Wait until a vault can be accessed.', + 'ignore_errors' => array( + 'ResourceNotFoundException', + ), + ), + 'VaultNotExists' => array( + 'extends' => '__VaultState', + 'description' => 'Wait until a vault is deleted.', + 'success.type' => 'error', + 'success.value' => 'ResourceNotFoundException', + ), + ), + + // ... + ); + +In order for you to contribute Waiters to the SDK, you will need to implement them using the Waiters DSL. The DSL is not +documented yet, since it is currently subject to change, so if you are interested in helping to implement more Waiters, +please reach out to us via `GitHub `_. diff --git a/vendor/aws/aws-sdk-php/docs/index.rst b/vendor/aws/aws-sdk-php/docs/index.rst new file mode 100644 index 0000000..fa03a4c --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/index.rst @@ -0,0 +1,282 @@ +=============== +AWS SDK for PHP +=============== + +.. toctree:: + :hidden: + + awssignup + requirements + installation + quick-start + migration-guide + side-by-side + + credentials + configuration + feature-commands + feature-waiters + feature-iterators + feature-models + feature-facades + performance + faq + + service-autoscaling + service-cloudformation + service-cloudfront + service-cloudfront-20120505 + service-cloudsearch + service-cloudtrail + service-cloudwatch + service-datapipeline + service-directconnect + service-dynamodb + service-dynamodb-20111205 + service-ec2 + service-elasticache + service-elasticbeanstalk + service-elasticloadbalancing + service-elastictranscoder + service-emr + service-glacier + service-iam + service-importexport + service-kinesis + service-opsworks + service-rds + service-redshift + service-route53 + service-s3 + service-ses + service-simpledb + service-sns + service-sqs + service-storagegateway + service-sts + service-support + service-swf + feature-dynamodb-session-handler + feature-s3-stream-wrapper + +The **AWS SDK for PHP** enables PHP developers to use `Amazon Web Services `_ from 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 — by requiring the ``aws/aws-sdk-php`` package — +or by downloading the standalone `aws.zip `_ or +`aws.phar `_ files. + +Getting Started +--------------- + +* Before you use the SDK + + * `Sign up for AWS and get your AWS access keys `_ + * :doc:`Verify that your system meets the minimum requirements for the SDK ` + * :doc:`Install the AWS SDK for PHP ` + +* Using the SDK + + * :doc:`quick-start` – Everything you need to know to use the AWS SDK for PHP + * `Sample Project `_ + +* Migrating from Version 1 of the SDK? + + * :doc:`migration-guide` – Migrating from Version 1 of the SDK to Version 2 + * :doc:`side-by-side` – Using Version 1 and Version 2 of the SDK side-by-side in the same project + +In-Depth Guides +--------------- + +* :doc:`credentials` +* :doc:`configuration` +* SDK Features + + * :doc:`feature-iterators` + * :doc:`feature-waiters` + * :doc:`feature-commands` + * :ref:`Parallel Commands ` + * :doc:`feature-models` + +* :doc:`faq` +* :doc:`performance` +* `Contributing to the SDK `_ +* `Guzzle V3 Documentation `_ + +.. _supported-services: + +Service-Specific Guides +----------------------- + +* Amazon CloudFront + + .. indexlinks:: CloudFront + + * :doc:`Using the older 2012-05-05 API version ` + +* Amazon CloudSearch + + .. indexlinks:: CloudSearch + + * :doc:`Using the older 2011-02-01 API version ` + +* Amazon CloudWatch + + .. indexlinks:: CloudWatch + +* Amazon DynamoDB + + .. indexlinks:: DynamoDb + + * :doc:`Special Feature: DynamoDB Session Handler ` + * :doc:`Using the older 2011-12-05 API version ` + +* Amazon Elastic Compute Cloud (Amazon EC2) + + .. indexlinks:: Ec2 + +* Amazon Elastic MapReduce (Amazon EMR) + + .. indexlinks:: Emr + +* Amazon Elastic Transcoder + + .. indexlinks:: ElasticTranscoder + +* Amazon ElastiCache + + .. indexlinks:: ElastiCache + +* Amazon Glacier + + .. indexlinks:: Glacier + +* Amazon Kinesis + + .. indexlinks:: Kinesis + +* Amazon Redshift + + .. indexlinks:: Redshift + +* Amazon Relational Database Service (Amazon RDS) + + .. indexlinks:: Rds + +* Amazon Route 53 + + .. indexlinks:: Route53 + +* Amazon Simple Email Service (Amazon SES) + + .. indexlinks:: Ses + +* Amazon Simple Notification Service (Amazon SNS) + + .. indexlinks:: Sns + +* Amazon Simple Queue Service (Amazon SQS) + + .. indexlinks:: Sqs + +* Amazon Simple Storage Service (Amazon S3) + + .. indexlinks:: S3 + + * :doc:`Special Feature: Amazon S3 Stream Wrapper ` + +* Amazon Simple Workflow Service (Amazon SWF) + + .. indexlinks:: Swf + +* Amazon SimpleDB + + .. indexlinks:: SimpleDb + +* Auto Scaling + + .. indexlinks:: AutoScaling + +* AWS CloudFormation + + .. indexlinks:: CloudFormation + +* AWS CloudTrail + + .. indexlinks:: CloudTrail + +* AWS Data Pipeline + + .. indexlinks:: DataPipeline + +* AWS Direct Connect + + .. indexlinks:: DirectConnect + +* AWS Elastic Beanstalk + + .. indexlinks:: ElasticBeanstalk + +* AWS Identity and Access Management (AWS IAM) + + .. indexlinks:: Iam + +* AWS Import/Export + + .. indexlinks:: ImportExport + +* AWS OpsWorks + + .. indexlinks:: OpsWorks + +* AWS Security Token Service (AWS STS) + + .. indexlinks:: Sts + +* AWS Storage Gateway + + .. indexlinks:: StorageGateway + +* AWS Support + + .. indexlinks:: Support + +* Elastic Load Balancing + + .. indexlinks:: ElasticLoadBalancing + +Articles from the Blog +---------------------- + +* `Syncing Data with Amazon S3 `_ +* `Amazon S3 PHP Stream Wrapper `_ +* `Transferring Files To and From Amazon S3 `_ +* `Provision an Amazon EC2 Instance with PHP `_ +* `Uploading Archives to Amazon Glacier from PHP `_ +* `Using AWS CloudTrail in PHP - Part 1 `_ +* `Using AWS CloudTrail in PHP - Part 2 `_ +* `Providing credentials to the AWS SDK for PHP `_ +* `Using Credentials from AWS Security Token Service `_ +* `Iterating through Amazon DynamoDB Results `_ +* `Sending requests through a proxy `_ +* `Wire Logging in the AWS SDK for PHP `_ +* `Streaming Amazon S3 Objects From a Web Server `_ +* `Using New Regions and Endpoints `_ +* `Receiving Amazon SNS Messages in PHP `_ +* `Testing Webhooks Locally for Amazon SNS `_ + +Presentations +------------- + +Slides +~~~~~~ + +* `Mastering the AWS SDK for PHP `_ +* `Getting Good with the AWS SDK for PHP `_ +* `Using DynamoDB with the AWS SDK for PHP `_ +* `Controlling the AWS Cloud with PHP `_ + +Videos +~~~~~~ + +* `Mastering the AWS SDK for PHP `_ (AWS re:Invent 2013) +* `Using DynamoDB with the AWS SDK for PHP `_ (AWS re:Invent 2012) diff --git a/vendor/aws/aws-sdk-php/docs/installation.rst b/vendor/aws/aws-sdk-php/docs/installation.rst new file mode 100644 index 0000000..ee57300 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/installation.rst @@ -0,0 +1,150 @@ +============ +Installation +============ + +Installing via Composer +----------------------- + +Using `Composer `_ is the recommended way to install the AWS SDK for PHP. Composer is a +dependency management tool for PHP that allows you to declare the dependencies your project needs and installs them into +your project. In order to use the SDK with Composer, you must do the following: + +#. Add ``"aws/aws-sdk-php"`` as a dependency in your project's ``composer.json`` file. + + .. code-block:: js + + { + "require": { + "aws/aws-sdk-php": "2.*" + } + } + + Consider tightening your dependencies to a known version (e.g., ``2.5.*``). + +#. Download and install Composer. + + .. code-block:: sh + + curl -sS https://getcomposer.org/installer | php + +#. Install your dependencies. + + .. code-block:: sh + + php composer.phar install + +#. Require Composer's autoloader. + + Composer prepares an autoload file that's capable of autoloading all of the classes in any of the libraries that + it downloads. To use it, just add the following line to your code's bootstrap process. + + .. code-block:: php + + require '/path/to/sdk/vendor/autoload.php'; + +You can find out more on how to install Composer, configure autoloading, and other best-practices for defining +dependencies at `getcomposer.org `_. + +During your development, you can keep up with the latest changes on the master branch by setting the version +requirement for the SDK to ``dev-master``. + +.. code-block:: js + + { + "require": { + "aws/aws-sdk-php": "dev-master" + } + } + +If you are deploying your application to `AWS Elastic Beanstalk +`_, and you have a ``composer.json`` +file in the root of your package, then Elastic Beanstalk will automatically perform a Composer ``install`` when you +deploy your application. + +Installing via Phar +------------------- + +Each release of the AWS SDK for PHP ships with a pre-packaged `phar `_ (PHP +archive) file containing all of the classes and dependencies you need to run the SDK. Additionally, the phar file +automatically registers a class autoloader for the AWS SDK for PHP and all of its dependencies when included. Bundled +with the phar file are the following required and suggested libraries: + +- `Guzzle `_ for HTTP requests +- `Symfony2 EventDispatcher `_ for events +- `Monolog `_ and `Psr\\Log `_ for logging +- `Doctrine `_ for caching + +You can `download the packaged Phar `_ and simply include it in your +scripts to get started:: + + require '/path/to/aws.phar'; + +If you have `phing `_ installed, you can clone the SDK and build a phar file yourself using the +*"phar"* task. + +.. note:: + + If you are using PHP with the Suhosin patch (especially common on Ubuntu and Debian distributions), you may need + to enable the use of phars in the ``suhosin.ini``. Without this, including a phar file in your code will cause it to + silently fail. You should modify the ``suhosin.ini`` file by adding the line: + + ``suhosin.executor.include.whitelist = phar`` + +Installing via Zip +------------------ + +Each release of the AWS SDK for PHP (since 2.3.2) ships with a zip file containing all of the classes and dependencies +you need to run the SDK in a `PSR-0 `_ +compatible directory structure. Additionally, the zip file includes a class autoloader for the AWS SDK for PHP and the +following required and suggested libraries: + +- `Guzzle `_ for HTTP requests +- `Symfony2 EventDispatcher `_ for events +- `Monolog `_ and `Psr\\Log `_ for logging +- `Doctrine `_ for caching + +Using the zip file is great if you: + +1. Prefer not to or cannot use package managers like Composer and PEAR. +2. Cannot use phar files due to environment limitations. +3. Want to use only specific files from the SDK. + +To get started, you must `download the zip file `_, unzip it into your +project to a location of your choosing, and include the autoloader:: + + require '/path/to/aws-autoloader.php'; + +Alternatively, you can write your own autoloader or use an existing one from your project. + +If you have `phing `_ installed, you can clone the SDK and build a zip file yourself using the +*"zip"* task. + +Installing via PEAR +~~~~~~~~~~~~~~~~~~~ + +`PEAR `_ packages are easy to install, and are available in your PHP environment path so that they +are accessible to any PHP project. PEAR packages are not specific to your project, but rather to the machine they're +installed on. + +From the command-line, you can install the SDK with PEAR as follows (this might need to be run as ``sudo``): + +.. code-block:: sh + + pear config-set auto_discover 1 + pear channel-discover pear.amazonwebservices.com + pear install aws/sdk + +Alternatively, you can combine all three of the preceding statements into one by doing the following: + +.. code-block:: sh + + pear -D auto_discover=1 install pear.amazonwebservices.com/sdk + +Once the SDK has been installed via PEAR, you can include the ``aws.phar`` into your project with: + +.. code-block:: php + + require 'AWSSDKforPHP/aws.phar'; + +This assumes that the PEAR directory is in your PHP include path, which it probably is, if PEAR is working correctly. +If needed, you can determine your PEAR directory by running ``pear config-get php_dir``. diff --git a/vendor/aws/aws-sdk-php/docs/make.bat b/vendor/aws/aws-sdk-php/docs/make.bat new file mode 100644 index 0000000..a5573a7 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/make.bat @@ -0,0 +1,190 @@ +@ECHO OFF + +REM Command file for Sphinx documentation + +if "%SPHINXBUILD%" == "" ( + set SPHINXBUILD=sphinx-build +) +set BUILDDIR=_build +set ALLSPHINXOPTS=-d %BUILDDIR%/doctrees %SPHINXOPTS% . +set I18NSPHINXOPTS=%SPHINXOPTS% . +if NOT "%PAPER%" == "" ( + set ALLSPHINXOPTS=-D latex_paper_size=%PAPER% %ALLSPHINXOPTS% + set I18NSPHINXOPTS=-D latex_paper_size=%PAPER% %I18NSPHINXOPTS% +) + +if "%1" == "" goto help + +if "%1" == "help" ( + :help + echo.Please use `make ^` where ^ is one of + echo. html to make standalone HTML files + echo. dirhtml to make HTML files named index.html in directories + echo. singlehtml to make a single large HTML file + echo. pickle to make pickle files + echo. json to make JSON files + echo. htmlhelp to make HTML files and a HTML help project + echo. qthelp to make HTML files and a qthelp project + echo. devhelp to make HTML files and a Devhelp project + echo. epub to make an epub + echo. latex to make LaTeX files, you can set PAPER=a4 or PAPER=letter + echo. text to make text files + echo. man to make manual pages + echo. texinfo to make Texinfo files + echo. gettext to make PO message catalogs + echo. changes to make an overview over all changed/added/deprecated items + echo. linkcheck to check all external links for integrity + echo. doctest to run all doctests embedded in the documentation if enabled + goto end +) + +if "%1" == "clean" ( + for /d %%i in (%BUILDDIR%\*) do rmdir /q /s %%i + del /q /s %BUILDDIR%\* + goto end +) + +if "%1" == "html" ( + %SPHINXBUILD% -b html %ALLSPHINXOPTS% %BUILDDIR%/html + if errorlevel 1 exit /b 1 + echo. + echo.Build finished. The HTML pages are in %BUILDDIR%/html. + goto end +) + +if "%1" == "dirhtml" ( + %SPHINXBUILD% -b dirhtml %ALLSPHINXOPTS% %BUILDDIR%/dirhtml + if errorlevel 1 exit /b 1 + echo. + echo.Build finished. The HTML pages are in %BUILDDIR%/dirhtml. + goto end +) + +if "%1" == "singlehtml" ( + %SPHINXBUILD% -b singlehtml %ALLSPHINXOPTS% %BUILDDIR%/singlehtml + if errorlevel 1 exit /b 1 + echo. + echo.Build finished. The HTML pages are in %BUILDDIR%/singlehtml. + goto end +) + +if "%1" == "pickle" ( + %SPHINXBUILD% -b pickle %ALLSPHINXOPTS% %BUILDDIR%/pickle + if errorlevel 1 exit /b 1 + echo. + echo.Build finished; now you can process the pickle files. + goto end +) + +if "%1" == "json" ( + %SPHINXBUILD% -b json %ALLSPHINXOPTS% %BUILDDIR%/json + if errorlevel 1 exit /b 1 + echo. + echo.Build finished; now you can process the JSON files. + goto end +) + +if "%1" == "htmlhelp" ( + %SPHINXBUILD% -b htmlhelp %ALLSPHINXOPTS% %BUILDDIR%/htmlhelp + if errorlevel 1 exit /b 1 + echo. + echo.Build finished; now you can run HTML Help Workshop with the ^ +.hhp project file in %BUILDDIR%/htmlhelp. + goto end +) + +if "%1" == "qthelp" ( + %SPHINXBUILD% -b qthelp %ALLSPHINXOPTS% %BUILDDIR%/qthelp + if errorlevel 1 exit /b 1 + echo. + echo.Build finished; now you can run "qcollectiongenerator" with the ^ +.qhcp project file in %BUILDDIR%/qthelp, like this: + echo.^> qcollectiongenerator %BUILDDIR%\qthelp\AWSSDKforPHP.qhcp + echo.To view the help file: + echo.^> assistant -collectionFile %BUILDDIR%\qthelp\AWSSDKforPHP.ghc + goto end +) + +if "%1" == "devhelp" ( + %SPHINXBUILD% -b devhelp %ALLSPHINXOPTS% %BUILDDIR%/devhelp + if errorlevel 1 exit /b 1 + echo. + echo.Build finished. + goto end +) + +if "%1" == "epub" ( + %SPHINXBUILD% -b epub %ALLSPHINXOPTS% %BUILDDIR%/epub + if errorlevel 1 exit /b 1 + echo. + echo.Build finished. The epub file is in %BUILDDIR%/epub. + goto end +) + +if "%1" == "latex" ( + %SPHINXBUILD% -b latex %ALLSPHINXOPTS% %BUILDDIR%/latex + if errorlevel 1 exit /b 1 + echo. + echo.Build finished; the LaTeX files are in %BUILDDIR%/latex. + goto end +) + +if "%1" == "text" ( + %SPHINXBUILD% -b text %ALLSPHINXOPTS% %BUILDDIR%/text + if errorlevel 1 exit /b 1 + echo. + echo.Build finished. The text files are in %BUILDDIR%/text. + goto end +) + +if "%1" == "man" ( + %SPHINXBUILD% -b man %ALLSPHINXOPTS% %BUILDDIR%/man + if errorlevel 1 exit /b 1 + echo. + echo.Build finished. The manual pages are in %BUILDDIR%/man. + goto end +) + +if "%1" == "texinfo" ( + %SPHINXBUILD% -b texinfo %ALLSPHINXOPTS% %BUILDDIR%/texinfo + if errorlevel 1 exit /b 1 + echo. + echo.Build finished. The Texinfo files are in %BUILDDIR%/texinfo. + goto end +) + +if "%1" == "gettext" ( + %SPHINXBUILD% -b gettext %I18NSPHINXOPTS% %BUILDDIR%/locale + if errorlevel 1 exit /b 1 + echo. + echo.Build finished. The message catalogs are in %BUILDDIR%/locale. + goto end +) + +if "%1" == "changes" ( + %SPHINXBUILD% -b changes %ALLSPHINXOPTS% %BUILDDIR%/changes + if errorlevel 1 exit /b 1 + echo. + echo.The overview file is in %BUILDDIR%/changes. + goto end +) + +if "%1" == "linkcheck" ( + %SPHINXBUILD% -b linkcheck %ALLSPHINXOPTS% %BUILDDIR%/linkcheck + if errorlevel 1 exit /b 1 + echo. + echo.Link check complete; look for any errors in the above output ^ +or in %BUILDDIR%/linkcheck/output.txt. + goto end +) + +if "%1" == "doctest" ( + %SPHINXBUILD% -b doctest %ALLSPHINXOPTS% %BUILDDIR%/doctest + if errorlevel 1 exit /b 1 + echo. + echo.Testing of doctests in the sources finished, look at the ^ +results in %BUILDDIR%/doctest/output.txt. + goto end +) + +:end diff --git a/vendor/aws/aws-sdk-php/docs/migration-guide.rst b/vendor/aws/aws-sdk-php/docs/migration-guide.rst new file mode 100644 index 0000000..d20191f --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/migration-guide.rst @@ -0,0 +1,480 @@ +=============== +Migration Guide +=============== + +This guide shows how to migrate your code to use the new AWS SDK for PHP and how the new SDK differs from the +AWS SDK for PHP - Version 1. + +Introduction +------------ + +The PHP language and community have evolved significantly over the past few years. Since the inception of the AWS SDK +for PHP, PHP has gone through two major version changes (`versions 5.3 and 5.4 `_) and +many in the PHP community have unified behind the recommendations of the `PHP Framework Interop Group +`_. Consequently, we decided to make breaking changes to the SDK in order to align with the more +modern patterns used in the PHP community. + +For the new release, we rewrote the SDK from the ground up to address popular customer requests. The new SDK is built on +top of the `Guzzle HTTP client framework `_, which provides increased performance and enables +event-driven customization. We also introduced high-level abstractions to make programming common tasks easy. The SDK +is compatible with PHP 5.3.3 and newer, and follows the PSR-0 standard for namespaces and autoloading. + +Which Services are Supported? +----------------------------- + +The AWS SDK for PHP supports all of the AWS services supported by Version 1 of the SDK and more, including Amazon +Route 53, Amazon Glacier, and AWS Direct Connect. See the `AWS SDK for PHP website `_ +for the full list of services supported by the SDK. Be sure to watch or star our `AWS SDK for PHP GitHub repository +`_ to stay up-to-date with the latest changes. + +What's New? +----------- + +- `PHP 5.3 namespaces `_ +- Follows `PSR-0, PSR-1, and PSR-2 standards `_ +- Built on `Guzzle `_ and utilizes the Guzzle feature set +- Persistent connection management for both serial and parallel requests +- Event hooks (via `Symfony2 EventDispatcher + `_) for event-driven, custom behavior +- Request and response entity bodies are stored in ``php://temp`` streams to reduce memory usage +- Transient networking and cURL failures are automatically retried using truncated exponential backoff +- Plug-ins for over-the-wire logging and response caching +- "Waiter" objects that allow you to poll a resource until it is in a desired state +- Resource iterator objects for easily iterating over paginated responses +- Service-specific sets of exceptions +- Modeled responses with a simpler interface +- Grouped constants (Enums) for service parameter options +- Flexible request batching system +- Service builder/container that supports easy configuration and dependency injection +- Full unit test suite with extensive code coverage +- `Composer `_ support (including PSR-0 compliance) for installing and autoloading SDK + dependencies +- `Phing `_ ``build.xml`` for installing dev tools, driving testing, and producing ``.phar`` files +- Fast Amazon DynamoDB batch PutItem and DeleteItem system +- Multipart upload system for Amazon Simple Storage Service (Amazon S3) and Amazon Glacier that can be paused and + resumed +- Redesigned DynamoDB Session Handler with smarter writing and garbage collection +- Improved multi-region support + +What's Different? +----------------- + +Architecture +~~~~~~~~~~~~ + +The new SDK is built on top of `Guzzle `_ and inherits its features and +conventions. Every AWS service client extends the Guzzle client, defining operations through a service description +file. The SDK has a much more robust and flexible object-oriented architecture, including the use of design patterns, +event dispatching and dependency injection. As a result, many of the classes and methods from the previous SDK have +been changed. + +Project Dependencies +~~~~~~~~~~~~~~~~~~~~ + +Unlike the Version 1 of the SDK, the new SDK does not pre-package all of its dependencies +in the repository. Dependencies are best resolved and autoloaded via `Composer `_. However, +when installing the SDK via the downloadable phar, the dependencies are resolved for you. + +Namespaces +~~~~~~~~~~ + +The SDK's directory structure and namespaces are organized according to `PSR-0 standards +`_, making the SDK inherently modular. The +``Aws\Common`` namespace contains the core code of the SDK, and each service client is contained in its own separate +namespace (e.g., ``Aws\DynamoDb``). + +Coding Standards +~~~~~~~~~~~~~~~~ + +The SDK adopts the PSR standards produced by the PHP Framework Interop Group. An immediately +noticeable change is that all method names are now named using lower camel-case +(e.g., ``putObject`` instead of ``put_object``). + +Required Regions +~~~~~~~~~~~~~~~~ + +The `region `_ must be provided to instantiate a client +(except in the case where the service has a single endpoint like Amazon CloudFront). The AWS region you select may +affect both your performance and costs. + +Client Factories +~~~~~~~~~~~~~~~~ + +Factory methods instantiate service clients and do the work of setting up the signature, +exponential backoff settings, exception handler, and so forth. At a minimum you must provide your access key, secret +key, and region to the client factory, but there are many other settings you can use to customize the client +behavior. + +.. code-block:: php + + $dynamodb = Aws\DynamoDb\DynamoDbClient::factory(array( + 'key' => 'your-aws-access-key-id', + 'secret' => 'your-aws-secret-access-key', + 'region' => 'us-west-2', + )); + +Configuration +~~~~~~~~~~~~~ + +A global configuration file can be used to inject credentials into clients +automatically via the service builder. The service builder acts as a dependency injection container for the service +clients. (**Note:** The SDK does not automatically attempt to load the configuration file like in Version 1 of the +SDK.) + +.. code-block:: php + + $aws = Aws\Common\Aws::factory('/path/to/custom/config.php'); + $s3 = $aws->get('s3'); + +This technique is the preferred way for instantiating service clients. Your ``config.php`` might look similar to the +following: + +.. code-block:: php + + array('_aws'), + 'services' => array( + 'default_settings' => array( + 'params' => array( + 'key' => 'your-aws-access-key-id', + 'secret' => 'your-aws-secret-access-key', + 'region' => 'us-west-2' + ) + ) + ) + ); + +The line that says ``'includes' => array('_aws')`` includes the default configuration file packaged with the SDK. This +sets up all of the service clients for you so you can retrieve them by name with the ``get()`` method of the service +builder. + +Service Operations +~~~~~~~~~~~~~~~~~~ + +Executing operations in the new SDK is similar to how it was in the previous SDK, with two +main differences. First, operations follow the lower camel-case naming convention. Second, a single array parameter is +used to pass in all of the operation options. The following examples show the Amazon S3 ``PutObject`` operation +performed in each SDK: + +.. code-block:: php + + // Previous SDK - PutObject operation + $s3->create_object('bucket-name', 'object-key.txt', array( + 'body' => 'lorem ipsum' + )); + +.. code-block:: php + + // New SDK - PutObject operation + $result = $s3->putObject(array( + 'Bucket' => 'bucket-name', + 'Key' => 'object-key.txt', + 'Body' => 'lorem ipsum' + )); + +In the new SDK, the ``putObject()`` method doesn't actually exist as a method on the client. It is implemented using +the ``__call()`` magic method of the client and acts as a shortcut to instantiate a command, execute the command, +and retrieve the result. + +A ``Command`` object encapsulates the request and response of the call to AWS. From the ``Command`` object, you can +call the ``getResult()`` method (as in the preceding example) to retrieve the parsed result, or you can call the +``getResponse()`` method to retrieve data about the response (e.g., the status code or the raw response). + +The ``Command`` object can also be useful when you want to manipulate the command before execution or need to execute +several commands in parallel. The following is an example of the same ``PutObject`` operation using the command +syntax: + +.. code-block:: php + + $command = $s3->getCommand('PutObject', array( + 'Bucket' => 'bucket-name', + 'Key' => 'object-key.txt', + 'Body' => 'lorem ipsum' + )); + $result = $command->getResult(); + +Or you can use the chainable ``set()`` method on the ``Command`` object: + +.. code-block:: php + + $result = $s3->getCommand('PutObject') + ->set('Bucket', 'bucket-name') + ->set('Key', 'object-key.txt') + ->set('Body', 'lorem ipsum') + ->getResult(); + +Responses +~~~~~~~~~ + +The format of responses has changed. Responses are no longer instances of the ``CFResponse`` object. +The ``Command`` object (as seen in the preceding section) of the new SDK encapsulates the request and response, and is +the object from which to retrieve the results. + +.. code-block:: php + + // Previous SDK + // Execute the operation and get the CFResponse object + $response = $s3->list_tables(); + // Get the parsed response body as a SimpleXMLElement + $result = $response->body; + + // New SDK + // Executes the operation and gets the response in an array-like object + $result = $s3->listTables(); + +The new syntax is similar, but a few fundamental differences exist between responses in the previous SDK and this +version: + +The new SDK represents parsed responses (i.e., the results) as Guzzle ``Model`` objects instead of ``CFSimpleXML`` +objects as in the prior version. These Model objects are easy to work with since they act like arrays. They also +have helpful built-in features such as mapping and filtering. The content of the results will also look different +n this version of the SDK. The SDK marshals responses into the models and then transforms them into more convenient +structures based on the service description. The API documentation details the response of all operations. + +Exceptions +~~~~~~~~~~ + +The new SDK uses exceptions to communicate errors and bad responses. + +Instead of relying on the ``CFResponse::isOK()`` method of the previous SDK to determine if an operation is +successful, the new SDK throws exceptions when the operation is *not* successful. Therefore, you can assume success +if there was no exception thrown, but you will need to add ``try...catch`` logic to your application code in order to +handle potential errors. The following is an example of how to handle the response of an Amazon DynamoDB +``DescribeTable`` call in the new SDK: + +.. code-block:: php + + $tableName = 'my-table'; + try { + $result = $dynamoDb->describeTable(array('TableName' => $tableName)); + + printf('The provisioned throughput for table "%s" is %d RCUs and %d WCUs.', + $tableName, + $result->getPath('Table/ProvisionedThroughput/ReadCapacityUnits'), + $result->getPath('Table/ProvisionedThroughput/WriteCapacityUnits') + ); + } catch (Aws\DynamoDb\Exception\DynamoDbException $e) { + echo "Error describing table {$tableName}"; + } + +You can get the Guzzle response object back from the command. This is helpful if you need to retrieve the status +code, additional data from the headers, or the raw response body. + +.. code-block:: php + + $command = $dynamoDb->getCommand('DescribeTable', array('TableName' => $tableName)); + $statusCode = $command->getResponse()->getStatusCode(); + +You can also get the response object and status code from the exception if one is thrown. + +.. code-block:: php + + try { + $command = $dynamoDb->getCommand('DescribeTable', array( + 'TableName' => $tableName + )); + $statusCode = $command->getResponse()->getStatusCode(); + } catch (Aws\DynamoDb\Exception\DynamoDbException $e) { + $statusCode = $e->getResponse()->getStatusCode(); + } + +Iterators +~~~~~~~~~ + +The SDK provides iterator classes that make it easier to traverse results from list and describe type +operations. Instead of having to code solutions that perform multiple requests in a loop and keep track of tokens or +markers, the iterator classes do that for you. You can simply foreach over the iterator: + +.. code-block:: php + + $objects = $s3->getIterator('ListObjects', array( + 'Bucket' => 'my-bucket-name' + )); + + foreach ($objects as $object) { + echo $object['Key'] . PHP_EOL; + } + +Comparing Code Samples from Both SDKs +------------------------------------- + +Example 1 - Amazon S3 ListParts Operation +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +From Version 1 of the SDK +^^^^^^^^^^^^^^^^^^^^^^^^^ + +.. code-block:: php + + list_parts('my-bucket-name', 'my-object-key', 'my-upload-id', array( + 'max-parts' => 10 + )); + + if ($response->isOK()) + { + // Loop through and display the part numbers + foreach ($response->body->Part as $part) { + echo "{$part->PartNumber}\n"; + } + } + else + { + echo "Error during S3 ListParts operation.\n"; + } + +From Version 2 of the SDK +^^^^^^^^^^^^^^^^^^^^^^^^^ + +.. code-block:: php + + get('s3'); + + try { + $result = $s3->listParts(array( + 'Bucket' => 'my-bucket-name', + 'Key' => 'my-object-key', + 'UploadId' => 'my-upload-id', + 'MaxParts' => 10 + )); + + // Loop through and display the part numbers + foreach ($result['Part'] as $part) { + echo "{$part[PartNumber]}\n"; + } + } catch (S3Exception $e) { + echo "Error during S3 ListParts operation.\n"; + } + +Example 2 - Amazon DynamoDB Scan Operation +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +From Version 1 of the SDK +^^^^^^^^^^^^^^^^^^^^^^^^^ + +.. code-block:: php + + 'people', + 'AttributesToGet' => array('id', 'age', 'name'), + 'ScanFilter' => array( + 'age' => array( + 'ComparisonOperator' => + AmazonDynamoDB::CONDITION_GREATER_THAN_OR_EQUAL, + 'AttributeValueList' => array( + array(AmazonDynamoDB::TYPE_NUMBER => '16') + ) + ), + ) + ); + + // Add the exclusive start key parameter if needed + if ($start_key) + { + $params['ExclusiveStartKey'] = array( + 'HashKeyElement' => array( + AmazonDynamoDB::TYPE_STRING => $start_key + ) + ); + + $start_key = null; + } + + // Perform the Scan operation and get the response + $response = $dynamo_db->scan($params); + + // If the response succeeded, get the results + if ($response->isOK()) + { + foreach ($response->body->Items as $item) + { + $people[] = (string) $item->name->{AmazonDynamoDB::TYPE_STRING}; + } + + // Get the last evaluated key if it is provided + if ($response->body->LastEvaluatedKey) + { + $start_key = (string) $response->body + ->LastEvaluatedKey + ->HashKeyElement + ->{AmazonDynamoDB::TYPE_STRING}; + } + } + else + { + // Throw an exception if the response was not OK (200-level) + throw new DynamoDB_Exception('DynamoDB Scan operation failed.'); + } + } + while ($start_key); + + print_r($people); + +From Version 2 of the SDK +^^^^^^^^^^^^^^^^^^^^^^^^^ + +.. code-block:: php + + get('dynamodb'); + + // Create a ScanIterator and setup the parameters for the DynamoDB Scan operation + $scan = $dynamodb->getIterator('Scan', array( + 'TableName' => 'people', + 'AttributesToGet' => array('id', 'age', 'name'), + 'ScanFilter' => array( + 'age' => array( + 'ComparisonOperator' => ComparisonOperator::GE, + 'AttributeValueList' => array( + array(Type::NUMBER => '16') + ) + ), + ) + )); + + // Perform as many Scan operations as needed to acquire all the names of people + // that are 16 or older + $people = array(); + foreach ($scan as $item) { + $people[] = $item['name'][Type::STRING]; + } + + print_r($people); diff --git a/vendor/aws/aws-sdk-php/docs/performance.rst b/vendor/aws/aws-sdk-php/docs/performance.rst new file mode 100644 index 0000000..353678c --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/performance.rst @@ -0,0 +1,287 @@ +================= +Performance Guide +================= + +The AWS SDK for PHP is able to send HTTP requests to various web services with minimal overhead. This document serves +as a guide that will help you to achieve optimal performance with the SDK. + +.. contents:: + :depth: 1 + :local: + :class: inline-toc + +Upgrade PHP +----------- + +Using an up-to-date version of PHP will generally improve the performance of your PHP applications. Did you know that +PHP 5.4 is `20-40% faster `_ than PHP 5.3? +`Upgrading to PHP 5.4 `_ or greater will provide better performance and +lower memory usage. If you cannot upgrade from PHP 5.3 to PHP 5.4 or PHP 5.5, upgrading to PHP 5.3.18 or greater will +improve performance over older versions of PHP 5.3. + +You can install PHP 5.4 on an Amazon Linux AMI using the following command. + +.. code-block:: bash + + yum install php54 + +Use PHP 5.5 or an opcode cache like APC +--------------------------------------- + +To improve the overall performance of your PHP environment, it is highly recommended that you use an opcode cache +such as the OPCache built into PHP 5.5, APC, XCache, or WinCache. By default, PHP must load a file from disk, parse +the PHP code into opcodes, and finally execute the opcodes. Installing an opcode cache allows the parsed opcodes to +be cached in memory so that you do not need to parse the script on every web server request, and in ideal +circumstances, these opcodes can be served directly from memory. + +We have taken great care to ensure that the SDK will perform well in an environment that utilizes an opcode cache. + +.. note:: + + PHP 5.5 comes with an opcode cache that is installed and enabled by default: + http://php.net/manual/en/book.opcache.php + + If you are using PHP 5.5, then you may skip the remainder of this section. + +APC +~~~ + +If you are not able to run PHP 5.5, then we recommend using APC as an opcode cache. + +Installing on Amazon Linux +^^^^^^^^^^^^^^^^^^^^^^^^^^ + +When using Amazon Linux, you can install APC using one of the following commands depending on if you are using PHP 5.3 +or PHP 5.4. + +.. code-block:: bash + + # For PHP 5.4 + yum install php54-pecl-apc + + # For PHP 5.3 + yum install php-pecl-apc + +Modifying APC settings +^^^^^^^^^^^^^^^^^^^^^^ + +APC configuration settings can be set and configured in the ``apc.ini`` file of most systems. You can find more +information about configuring APC in the PHP.net `APC documentation `_. + +The APC configuration file is located at ``/etc/php.d/apc.ini`` on Amazon Linux. + +.. code-block:: bash + + # You can only modify the file as sudo + sudo vim /etc/php.d/apc.ini + +apc.shm_size=128M +^^^^^^^^^^^^^^^^^ + +It is recommended that you set the `apc.shm_size `_ +setting to be 128M or higher. You should investigate what the right value will be for your application. The ideal +value will depend on how many files your application includes, what other frameworks are used by your application, and +if you are caching data in the APC user cache. + +You can run the following command on Amazon Linux to set apc.shm_size to 128M:: + + sed -i "s/apc.shm_size=.*/apc.shm_size=128M/g" /etc/php.d/apc.ini + +apc.stat=0 +^^^^^^^^^^ + +The SDK adheres to PSR-0 and relies heavily on class autoloading. When ``apc.stat=1``, APC will perform a stat on +each cached entry to ensure that the file has not been updated since it was cache in APC. This incurs a system call for +every autoloaded class required by a PHP script (you can see this for yourself by running ``strace`` on your +application). + +You can tell APC to not stat each cached file by setting ``apc.stat=0`` in you apc.ini file. This change will generally +improve the overall performance of APC, but it will require you to explicitly clear the APC cache when a cached file +should be updated. This can be accomplished with Apache by issuing a hard or graceful restart. This restart step could +be added as part of the deployment process of your application. + +You can run the following command on Amazon Linux to set apc.stat to 0:: + + sed -i "s/apc.stat=1/apc.stat=0/g" /etc/php.d/apc.ini + +.. admonition:: From the `PHP documentation `_ + + This defaults to on, forcing APC to stat (check) the script on each request to determine if it has been modified. If + it has been modified it will recompile and cache the new version. If this setting is off, APC will not check, which + usually means that to force APC to recheck files, the web server will have to be restarted or the cache will have to + be manually cleared. Note that FastCGI web server configurations may not clear the cache on restart. On a production + server where the script files rarely change, a significant performance boost can be achieved by disabled stats. + + For included/required files this option applies as well, but note that for relative path includes (any path that + doesn't start with / on Unix) APC has to check in order to uniquely identify the file. If you use absolute path + includes APC can skip the stat and use that absolute path as the unique identifier for the file. + +Use Composer with a classmap autoloader +--------------------------------------- + +Using `Composer `_ is the recommended way to install the AWS SDK for PHP. Composer is a +dependency manager for PHP that can be used to pull in all of the dependencies of the SDK and generate an autoloader. + +Autoloaders are used to lazily load classes as they are required by a PHP script. Composer will generate an autoloader +that is able to autoload the PHP scripts of your application and all of the PHP scripts of the vendors required by your +application (i.e. the AWS SDK for PHP). When running in production, it is highly recommended that you use a classmap +autoloader to improve the autoloader's speed. You can generate a classmap autoloader by passing the ``-o`` or +``--optimize-autoloader`` option to Composer's `install command `_:: + + php composer.phar install --optimize-autoloader + +Please consult the :doc:`installation` guide for more information on how to install the SDK using Composer. + +Uninstall Xdebug +---------------- + +`Xdebug `_ is an amazing tool that can be used to identify performance bottlenecks. However, if +performance is critical to your application, do not install the Xdebug extension on your production environment. Simply +loading the extension will greatly slow down the SDK. + +When running on Amazon Linux, Xdebug can be removed with the following command: + +.. code-block:: bash + + # PHP 5.4 + yum remove php54-pecl-xdebug + + # PHP 5.3 + yum remove php-pecl-xdebug + +Install PECL uri_template +------------------------- + +The SDK utilizes URI templates to power each operation. In order to be compatible out of the box with the majority +of PHP environments, the default URI template expansion implementation is written in PHP. +`PECL URI_Template `_ is a URI template extension for PHP written in C. This C +implementation is about 3 times faster than the default PHP implementation for expanding URI templates. Your +application will automatically begin utilizing the PECL uri_template extension after it is installed. + +.. code-block:: bash + + pecl install uri_template-alpha + +Turn off parameter validation +----------------------------- + +The SDK utilizes service descriptions to tell the client how to serialize an HTTP request and parse an HTTP response +into a Model object. Along with serialization information, service descriptions are used to validate operation inputs +client-side before sending a request. Disabling parameter validation is a micro-optimization, but this setting can +typically be disabled in production by setting the ``validation`` option in a client factory method to ``false``. + +.. code-block:: php + + $client = Aws\DynamoDb\DynamoDbClient::factory(array( + 'region' => 'us-west-2', + 'validation' => false + )); + +Cache instance profile credentials +---------------------------------- + +When you do not provide credentials to the SDK and do not have credentials defined in your environment variables, the +SDK will attempt to utilize IAM instance profile credentials by contacting the Amazon EC2 instance metadata service +(IMDS). Contacting the IMDS requires an HTTP request to retrieve credentials from the IMDS. + +You can cache these instance profile credentials in memory until they expire and avoid the cost of sending an HTTP +request to the IMDS each time the SDK is utilized. Set the ``credentials.cache`` option to ``true`` to attempt to +utilize the `Doctrine Cache `_ PHP library to cache credentials with APC. + +.. code-block:: php + + $client = Aws\DynamoDb\DynamoDbClient::factory(array( + 'region' => 'us-west-2', + 'credentials.cache' => true + )); + +.. note:: + + You will need to install Doctrine Cache in order for the SDK to cache credentials when setting + ``credentials.cache`` to ``true``. You can add doctrine/cache to your composer.json dependencies by adding to your + project's ``required`` section:: + + { + "required": { + "aws/sdk": "2.*", + "doctrine/cache": "1.*" + } + } + +Check if you are being throttled +-------------------------------- + +You can check to see if you are being throttled by enabling the exponential backoff logger option. You can set the +``client.backoff.logger`` option to ``debug`` when in development, but we recommend that you provide a +``Guzzle\Log\LogAdapterInterface`` object when running in production. + +.. code-block:: php + + $client = Aws\DynamoDb\DynamoDbClient::factory(array( + 'region' => 'us-west-2', + 'client.backoff.logger' => 'debug' + )); + +When using Amazon DynamoDB, you can monitor your tables for throttling using +`Amazon CloudWatch `_. + +Preload frequently included files +--------------------------------- + +The AWS SDK for PHP adheres to PSR-0 and heavily utilizes class autoloading. Each class is in a separate file and +are included lazily as they are required. Enabling an opcode cache like APC, setting ``apc.stat=0``, and utilizing an +optimized Composer autoloader will help to mitigate the performance cost of autoloading the classes needed to utilize +the SDK. In situations like hosting a webpage where you are loading the same classes over and over, you can shave off a +bit more time by compiling all of the autoloaded classes into a single file thereby completely eliminating the cost of +autoloading. This technique can not only speed up the use of the SDK for specific use cases (e.g. using the +Amazon DynamoDB session handler), but can also speed up other aspects of your application. Even with ``apc.stat=0``, +preloading classes that you know will be used in your application will be slightly faster than relying on autoloading. + +You can easily generate a compiled autoloader file using the +`ClassPreloader `_ project. View the project's README for information on +creating a "preloader" for use with the AWS SDK for PHP. + +Profile your code to find performance bottlenecks +------------------------------------------------- + +You will need to profile your application to determine the bottlenecks. This can be done using +`Xdebug `_, `XHProf `_, +`strace `_, and various other tools. There are many resources available on the +internet to help you track down performance problems with your application. Here are a few that we have found useful: + +* http://talks.php.net/show/devconf/0 +* http://talks.php.net/show/perf_tunning/16 + +Comparing SDK1 and SDK2 +----------------------- + +Software performance is very subjective and depends heavily on factors outside of the control of the SDK. The +AWS SDK for PHP is tuned to cover the broadest set of performance sensitive applications using AWS. While there may +be a few isolated cases where V1 of the the SDK is as fast or faster than V2, that is not generally true and comes +with the loss of extensibility, maintainability, persistent HTTP connections, response parsing, PSR compliance, etc. + +Depending on your use case, you will find that a properly configured environment running the AWS SDK for PHP is +generally just as fast as SDK1 for sending a single request and more than 350% faster than SDK1 for sending many +requests. + +Comparing batch requests +~~~~~~~~~~~~~~~~~~~~~~~~ + +A common misconception when comparing the performance of SDK1 and SDK2 is that SDK1 is faster than SDK2 when sending +requests using the "batch()" API. + +SDK1 is generally *not* faster at sending requests in parallel than SDK2. There may be some cases where SDK1 will appear +to more quickly complete the process of sending multiple requests in parallel, but SDK1 does not retry throttled +requests when using the ``batch()`` API. In SDK2, throttled requests are automatically retried in parallel using +truncated exponential backoff. Automatically retrying failed requests will help to ensure that your application is +successfully completing the requests that you think it is. + +You can always disable retries if your use case does not benefit from retrying failed requests. To disable retries, +set 'client.backoff' to ``false`` when creating a client. + +.. code-block:: php + + $client = Aws\DynamoDb\DynamoDbClient::factory(array( + 'region' => 'us-west-2', + 'client.backoff' => false + )); diff --git a/vendor/aws/aws-sdk-php/docs/quick-start.rst b/vendor/aws/aws-sdk-php/docs/quick-start.rst new file mode 100644 index 0000000..2c84b93 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/quick-start.rst @@ -0,0 +1,197 @@ +===================== +Getting Started Guide +===================== + +This "Getting Started Guide" focuses on basic usage of the **AWS SDK for PHP**. After reading through this material, you +should be familiar with the SDK and be able to start using the SDK in your application. This guide assumes that you have +already :doc:`downloaded and installed the SDK ` and retrieved your `AWS access keys +`_. + +Including the SDK +----------------- + +No matter which technique you have used to to install the SDK, the SDK can be included into your project or script with +just a single include (or require) statement. Please refer to the following table for the PHP code that best fits your +installation technique. Please replace any instances of ``/path/to/`` with the actual path on your system. + +========================== ============================================================================================= +Installation Technique Include Statement +========================== ============================================================================================= +Using Composer ``require '/path/to/vendor/autoload.php';`` +-------------------------- --------------------------------------------------------------------------------------------- +Using the Phar ``require '/path/to/aws.phar';`` +-------------------------- --------------------------------------------------------------------------------------------- +Using the Zip ``require '/path/to/aws-autoloader.php';`` +-------------------------- --------------------------------------------------------------------------------------------- +Using PEAR ``require 'AWSSDKforPHP/aws.phar';`` +========================== ============================================================================================= + +For the remainder of this guide, we will show examples that use the Composer installation method. If you are using a +different installation method, then you can refer to this section and substitute in the proper code. + +Creating a client object +------------------------ + +To use the SDK, you first you need to instantiate a **client** object for the service you are using. We'll use the +Amazon Simple Storage Service (Amazon S3) client as an example. You can instantiate a client using two different +techniques. + +.. _client_factory_method: + +Factory method +~~~~~~~~~~~~~~ + +The easiest way to get up and running quickly is to use the web service client's ``factory()`` method and provide your +**credential profile** (via the ``profile`` option), which identifies the set of credentials you want to use from your +``~/.aws/credentials`` file (see :ref:`credential_profiles`). + +.. code-block:: php + + 'my_profile', + )); + +You can also choose to forgo specifying credentials if you are relying on **instance profile credentials**, provided via +`AWS Identity and Access Management (AWS IAM) roles for EC2 instances `_, +or **environment credentials** sourced from the ``AWS_ACCESS_KEY_ID`` and ``AWS_SECRET_ACCESS_KEY`` environment +variables. For more information about credentials, see :doc:`credentials`. + +.. note:: + + Instance profile credentials and other temporary credentials generated by the AWS Security Token Service (AWS STS) + are not supported by every service. Please check if the service you are using supports temporary credentials by + reading `AWS Services that Support AWS STS `_. + +Depending on the service, you may also need to provide a **region** value to the ``factory()`` method. The region value +is used by the SDK to determine the `regional endpoint `_ to +use to communicate with the service. Amazon S3 does not require you to provide a region, but other services like Amazon +Elastic Compute Cloud (Amazon EC2) do. You can specify a region and other configuration settings along with your +credentials in the array argument that you provide. + +.. code-block:: php + + $ec2Client = \Aws\Ec2\Ec2Client::factory(array( + 'profile' => 'my_profile', + 'region' => 'us-east-1', + )); + +To know if the service client you are using requires a region and to find out which regions are supported by the client, +please see the appropriate :ref:`service-specific guide `. + +Service builder +~~~~~~~~~~~~~~~ + +Another way to instantiate a service client is using the ``Aws\Common\Aws`` object (a.k.a the **service builder**). +The ``Aws`` object is essentially a `service locator `_, and +allows you to specify credentials and configuration settings such that they can be shared across all client instances. +Also, every time you fetch a client object from the ``Aws`` object, it will be exactly the same instance. + +.. code-block:: php + + use Aws\Common\Aws; + + // Create a service locator using a configuration file + $aws = Aws::factory(array( + 'profile' => 'my_profile', + 'region' => 'us-east-1', + )); + + // Get client instances from the service locator by name + $s3Client = $aws->get('s3'); + $ec2Client = $aws->get('ec2'); + + // The service locator always returns the same instance + $anotherS3Client = $aws->get('s3'); + assert('$s3Client === $anotherS3Client'); + +You can also declare your credentials and settings in a **configuration file**, and provide the path to that file (in +either php or json format) when you instantiate the ``Aws`` object. + +.. code-block:: php + + // Create a `Aws` object using a configuration file + $aws = Aws::factory('/path/to/config.php'); + + // Get the client from the service locator by namespace + $s3Client = $aws->get('s3'); + +A simple configuration file should look something like this: + +.. code-block:: php + + array('_aws'), + 'services' => array( + 'default_settings' => array( + 'params' => array( + 'key' => 'YOUR_AWS_ACCESS_KEY_ID', + 'secret' => 'YOUR_AWS_SECRET_ACCESS_KEY', + // OR: 'profile' => 'my_profile', + 'region' => 'us-west-2' + ) + ) + ) + ); + +For more information about configuration files, please see :doc:`configuration`. + +Performing service operations +----------------------------- + +.. include:: _snippets/performing-operations.txt + +To learn about performing operations in more detail, including using command objects, see :doc:`feature-commands`. + +Working with modeled responses +------------------------------ + +.. include:: _snippets/models-intro.txt + +To learn more about how to work with modeled responses, read the detailed guide to :doc:`feature-models`. + +Detecting and handling errors +----------------------------- + +When you preform an operation, and it succeeds, it will return a modeled response. If there was an error with the +request, then an exception is thrown. For this reason, you should use ``try``/``catch`` blocks around your operations if +you need to handle errors in your code. The SDK throws service-specific exceptions when a server-side error occurs. + +In the following example, the ``Aws\S3\S3Client`` is used. If there is an error, the exception thrown will be of the +type: ``Aws\S3\Exception\S3Exception``. + +.. code-block:: php + + try { + $s3Client->createBucket(array( + 'Bucket' => 'my-bucket' + )); + } catch (\Aws\S3\Exception\S3Exception $e) { + // The bucket couldn't be created + echo $e->getMessage(); + } + +Exceptions thrown by the SDK like this all extend the ``ServiceResponseException`` class (`see the API docs +`_), which has +some custom methods that might help you discover what went wrong. + +Waiters +------- + +.. include:: _snippets/waiters-intro.txt + +To learn more about how to use and configure waiters, please read the detailed guide to :doc:`feature-waiters`. + +Iterators +--------- + +.. include:: _snippets/iterators-intro.txt + +To learn more about how to use and configure iterators, please read the detailed guide to :doc:`feature-iterators`. diff --git a/vendor/aws/aws-sdk-php/docs/requirements.rst b/vendor/aws/aws-sdk-php/docs/requirements.rst new file mode 100644 index 0000000..d4258ae --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/requirements.rst @@ -0,0 +1,39 @@ +============ +Requirements +============ + +Aside from a baseline understanding of object-oriented programming in PHP (including PHP 5.3 namespaces), there are a +few minimum system requirements to start using the AWS SDK for PHP. The extensions listed are common and are +installed with PHP 5.3 by default in most environments. + +Minimum requirements +-------------------- + +* PHP 5.3.3+ compiled with the cURL extension +* A recent version of cURL 7.16.2+ compiled with OpenSSL and zlib + +.. note:: + + To work with Amazon CloudFront private distributions, you must have the OpenSSL PHP extension to sign private + CloudFront URLs. + +.. _optimal-settings: + +Optimal settings +---------------- + +Please consult the :doc:`performance` for a list of recommendations and optimal settings that can be made to +ensure that you are using the SDK as efficiently as possible. + +Compatibility test +------------------ + +Run the `compatibility-test.php` file in the SDK to quickly check if your system is capable of running the SDK. In +addition to meeting the minimum system requirements of the SDK, the compatibility test checks for optional settings and +makes recommendations that can help you to improve the performance of the SDK. The compatibility test can output text +for the command line or a web browser. When running in a browser, successful checks appear in green, warnings in +purple, and failures in red. When running from the CLI, the result of a check will appear on each line. + +When reporting an issue with the SDK, it is often helpful to share information about your system. Supplying the output +of the compatibility test in forum posts or GitHub issues can help to streamline the process of identifying the root +cause of an issue. diff --git a/vendor/aws/aws-sdk-php/docs/requirements.txt b/vendor/aws/aws-sdk-php/docs/requirements.txt new file mode 100644 index 0000000..bd758a7 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/requirements.txt @@ -0,0 +1,3 @@ +rst2pdf +Sphinx>=1.2b1 +guzzle_sphinx_theme>=0.3.0 diff --git a/vendor/aws/aws-sdk-php/docs/service-autoscaling.rst b/vendor/aws/aws-sdk-php/docs/service-autoscaling.rst new file mode 100644 index 0000000..ceed814 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-autoscaling.rst @@ -0,0 +1,5 @@ +.. service:: AutoScaling + +.. include:: _snippets/incomplete.txt + +.. apiref:: AutoScaling diff --git a/vendor/aws/aws-sdk-php/docs/service-cloudformation.rst b/vendor/aws/aws-sdk-php/docs/service-cloudformation.rst new file mode 100644 index 0000000..bc932f1 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-cloudformation.rst @@ -0,0 +1,5 @@ +.. service:: CloudFormation + +.. include:: _snippets/incomplete.txt + +.. apiref:: CloudFormation diff --git a/vendor/aws/aws-sdk-php/docs/service-cloudfront-20120505.rst b/vendor/aws/aws-sdk-php/docs/service-cloudfront-20120505.rst new file mode 100644 index 0000000..1feb701 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-cloudfront-20120505.rst @@ -0,0 +1,134 @@ +.. service:: CloudFront 2012-05-05 + +Signing CloudFront URLs for Private Distributions +------------------------------------------------- + +Signed URLs allow you to provide users access to your private content. A signed URL includes additional information +(e.g., expiration time) that gives you more control over access to your content. This additional information appears in +a policy statement, which is based on either a canned policy or a custom policy. For information about how to set up +private distributions and why you need to sign URLs, please read the `Serving Private Content through CloudFront section +`_ of the CloudFront Developer +Guide. + +.. note: + + You must have the OpenSSL extension installed in you PHP environment in order to sign CloudFront URLs. + +You can sign a URL using the CloudFront client in the SDK. First you must make sure to provide your CloudFront +Private Key and Key Pair ID to the CloudFront client. + +.. code-block:: php + + '/path/to/your/cloudfront-private-key.pem', + 'key_pair_id' => '', + )); + +You can alternatively specify the Private Key and Key Pair ID in your AWS config file and use the service builder to +instantiate the CloudFront client. The following is an example config file that specifies the CloudFront key information. + +.. code-block:: php + + array('_aws'), + 'services' => array( + 'default_settings' => array( + 'params' => array( + 'key' => '', + 'secret' => '', + 'region' => 'us-west-2' + ) + ), + 'cloudfront' => array( + 'extends' => 'cloudfront', + 'params' => array( + 'private_key' => '/path/to/your/cloudfront-private-key.pem', + 'key_pair_id' => '' + ) + ) + ) + ); + +You can sign a CloudFront URL for a video resource using either a canned or custom policy. + +.. code-block:: php + + // Setup parameter values for the resource + $streamHostUrl = 'rtmp://example-distribution.cloudfront.net'; + $resourceKey = 'videos/example.mp4'; + $expires = time() + 300; + + // Create a signed URL for the resource using the canned policy + $signedUrlCannedPolicy = $cloudFront->getSignedUrl(array( + 'url' => $streamHostUrl . '/' . $resourceKey, + 'expires' => $expires, + )); + +For versions of the SDK later than 2.3.1, instead of providing your private key information when you instantiate the +client, you can provide it at the time when you sign the URL. + +.. code-block:: php + + $signedUrlCannedPolicy = $cloudFront->getSignedUrl(array( + 'url' => $streamHostUrl . '/' . $resourceKey, + 'expires' => $expires, + 'private_key' => '/path/to/your/cloudfront-private-key.pem', + 'key_pair_id' => '' + )); + +To use a custom policy, provide the ``policy`` key instead of ``expires``. + +.. code-block:: php + + $customPolicy = <<getSignedUrl(array( + 'url' => $streamHostUrl . '/' . $resourceKey, + 'policy' => $customPolicy, + )); + +The form of the signed URL is actually different depending on if the URL you are signing is using the "http" or "rtmp" +scheme. In the case of "http", the full, absolute URL is returned. For "rtmp", only the relative URL is returned for +your convenience, because some players require the host and path to be provided as separate parameters. + +The following is an example of how you could use the signed URL to construct a web page displaying a video using +`JWPlayer `_. The same type of technique would apply to other players like +`FlowPlayer `_, but will require different client-side code. + +.. code-block:: html + + + + Amazon CloudFront Streaming Example + + + +
    The canned policy video will be here.
    + + + + +.. include:: _snippets/incomplete.txt + +.. apiref:: CloudFront 2012-05-05 diff --git a/vendor/aws/aws-sdk-php/docs/service-cloudfront.rst b/vendor/aws/aws-sdk-php/docs/service-cloudfront.rst new file mode 100644 index 0000000..4190b26 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-cloudfront.rst @@ -0,0 +1,134 @@ +.. service:: CloudFront + +Signing CloudFront URLs for Private Distributions +------------------------------------------------- + +Signed URLs allow you to provide users access to your private content. A signed URL includes additional information +(e.g., expiration time) that gives you more control over access to your content. This additional information appears in +a policy statement, which is based on either a canned policy or a custom policy. For information about how to set up +private distributions and why you need to sign URLs, please read the `Serving Private Content through CloudFront section +`_ of the CloudFront Developer +Guide. + +.. note: + + You must have the OpenSSL extension installed in you PHP environment in order to sign CloudFront URLs. + +You can sign a URL using the CloudFront client in the SDK. First you must make sure to provide your CloudFront +Private Key and Key Pair ID to the CloudFront client. + +.. code-block:: php + + '/path/to/your/cloudfront-private-key.pem', + 'key_pair_id' => '', + )); + +You can alternatively specify the Private Key and Key Pair ID in your AWS config file and use the service builder to +instantiate the CloudFront client. The following is an example config file that specifies the CloudFront key information. + +.. code-block:: php + + array('_aws'), + 'services' => array( + 'default_settings' => array( + 'params' => array( + 'key' => '', + 'secret' => '', + 'region' => 'us-west-2' + ) + ), + 'cloudfront' => array( + 'extends' => 'cloudfront', + 'params' => array( + 'private_key' => '/path/to/your/cloudfront-private-key.pem', + 'key_pair_id' => '' + ) + ) + ) + ); + +You can sign a CloudFront URL for a video resource using either a canned or custom policy. + +.. code-block:: php + + // Setup parameter values for the resource + $streamHostUrl = 'rtmp://example-distribution.cloudfront.net'; + $resourceKey = 'videos/example.mp4'; + $expires = time() + 300; + + // Create a signed URL for the resource using the canned policy + $signedUrlCannedPolicy = $cloudFront->getSignedUrl(array( + 'url' => $streamHostUrl . '/' . $resourceKey, + 'expires' => $expires, + )); + +For versions of the SDK later than 2.3.1, instead of providing your private key information when you instantiate the +client, you can provide it at the time when you sign the URL. + +.. code-block:: php + + $signedUrlCannedPolicy = $cloudFront->getSignedUrl(array( + 'url' => $streamHostUrl . '/' . $resourceKey, + 'expires' => $expires, + 'private_key' => '/path/to/your/cloudfront-private-key.pem', + 'key_pair_id' => '' + )); + +To use a custom policy, provide the ``policy`` key instead of ``expires``. + +.. code-block:: php + + $customPolicy = <<getSignedUrl(array( + 'url' => $streamHostUrl . '/' . $resourceKey, + 'policy' => $customPolicy, + )); + +The form of the signed URL is actually different depending on if the URL you are signing is using the "http" or "rtmp" +scheme. In the case of "http", the full, absolute URL is returned. For "rtmp", only the relative URL is returned for +your convenience, because some players require the host and path to be provided as separate parameters. + +The following is an example of how you could use the signed URL to construct a web page displaying a video using +`JWPlayer `_. The same type of technique would apply to other players like +`FlowPlayer `_, but will require different client-side code. + +.. code-block:: html + + + + Amazon CloudFront Streaming Example + + + +
    The canned policy video will be here.
    + + + + +.. include:: _snippets/incomplete.txt + +.. apiref:: CloudFront diff --git a/vendor/aws/aws-sdk-php/docs/service-cloudsearch-20110201.rst b/vendor/aws/aws-sdk-php/docs/service-cloudsearch-20110201.rst new file mode 100644 index 0000000..98cdd6b --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-cloudsearch-20110201.rst @@ -0,0 +1 @@ +.. service:: CloudSearch 2011-02-01 diff --git a/vendor/aws/aws-sdk-php/docs/service-cloudsearch.rst b/vendor/aws/aws-sdk-php/docs/service-cloudsearch.rst new file mode 100644 index 0000000..a7a3af2 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-cloudsearch.rst @@ -0,0 +1,5 @@ +.. service:: CloudSearch + +.. include:: _snippets/incomplete.txt + +.. apiref:: CloudSearch diff --git a/vendor/aws/aws-sdk-php/docs/service-cloudtrail.rst b/vendor/aws/aws-sdk-php/docs/service-cloudtrail.rst new file mode 100644 index 0000000..e8112c6 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-cloudtrail.rst @@ -0,0 +1,11 @@ +.. service:: CloudTrail + +Blog articles +------------- + +* `Using AWS CloudTrail in PHP - Part 1 `_ +* `Using AWS CloudTrail in PHP - Part 2 `_ + +.. include:: _snippets/incomplete.txt + +.. apiref:: CloudTrail diff --git a/vendor/aws/aws-sdk-php/docs/service-cloudwatch.rst b/vendor/aws/aws-sdk-php/docs/service-cloudwatch.rst new file mode 100644 index 0000000..fca0b50 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-cloudwatch.rst @@ -0,0 +1,5 @@ +.. service:: CloudWatch + +.. include:: _snippets/incomplete.txt + +.. apiref:: CloudWatch diff --git a/vendor/aws/aws-sdk-php/docs/service-datapipeline.rst b/vendor/aws/aws-sdk-php/docs/service-datapipeline.rst new file mode 100644 index 0000000..8006580 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-datapipeline.rst @@ -0,0 +1,5 @@ +.. service:: DataPipeline + +.. include:: _snippets/incomplete.txt + +.. apiref:: DataPipeline diff --git a/vendor/aws/aws-sdk-php/docs/service-directconnect.rst b/vendor/aws/aws-sdk-php/docs/service-directconnect.rst new file mode 100644 index 0000000..cfe646a --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-directconnect.rst @@ -0,0 +1,5 @@ +.. service:: DirectConnect + +.. include:: _snippets/incomplete.txt + +.. apiref:: DirectConnect diff --git a/vendor/aws/aws-sdk-php/docs/service-dynamodb-20111205.rst b/vendor/aws/aws-sdk-php/docs/service-dynamodb-20111205.rst new file mode 100644 index 0000000..ba5f9cd --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-dynamodb-20111205.rst @@ -0,0 +1,162 @@ +.. service:: DynamoDb 2011-12-05 + +Creating tables +--------------- + +You must first create a table that can be used to store items. Even though Amazon DynamoDB tables do not use a fixed +schema, you do need to create a schema for the table's keys. This is explained in greater detail in Amazon DynamoDB's +`Data Model documentation `_. You +will also need to specify the amount of `provisioned throughput +`_ that should +be made available to the table. + +.. example:: DynamoDb/Integration/DynamoDb_20111205_Test.php testCreateTable + +The table will now have a status of ``CREATING`` while the table is being provisioned. You can use a waiter to poll the +table until it becomes ``ACTIVE``. + +.. example:: DynamoDb/Integration/DynamoDb_20111205_Test.php testWaitUntilTableExists + +A full list of the parameters available to the ``createTable()`` operation can be found in the +`API documentation `_. + +Updating a table +---------------- + +You can also update the table after it's been created using the `updateTable() `_ method. This allows you to do things +like increase or decrease your provisioned throughput capacity. + +.. example:: DynamoDb/Integration/DynamoDb_20111205_Test.php testUpdateTable + +Describing a table +------------------ + +Now that the table is created, you can use the +`describeTable() `_ +method to get information about the table. + +.. example:: DynamoDb/Integration/DynamoDb_20111205_Test.php testDescribeTable + +The return value of the ``describeTable()`` method is a ``Guzzle\Service\Resource\Model`` object that can be used like +an array. For example, you could retrieve the number of items in a table or the amount of provisioned read throughput. + +Listing tables +-------------- + +You can retrieve a list of all of the tables associated with a specific endpoint using the +`listTables() `_ +method. Each Amazon DynamoDB endpoint is entirely independent. For example, if you have two tables called "MyTable," one +in US-EAST-1 and one in US-WEST-2, they are completely independent and do not share any data. The ListTables operation +returns all of the table names associated with the account making the request, for the endpoint that receives the +request. + +.. example:: DynamoDb/Integration/DynamoDb_20111205_Test.php testListTables + +Iterating over all tables +~~~~~~~~~~~~~~~~~~~~~~~~~ + +The result of a ``listTables()`` operation might be truncated. Because of this, it is usually better to use an iterator +to retrieve a complete list of all of the tables owned by your account in a specific region. The iterator will +automatically handle sending any necessary subsequent requests. + +.. example:: DynamoDb/Integration/DynamoDb_20111205_Test.php testListTablesWithIterator + +.. tip:: + + You can convert an iterator to an array using the ``toArray()`` method of the iterator. + +Adding items +------------ + +You can add an item to our *errors* table using the +`putItem() `_ +method of the client. + +.. example:: DynamoDb/Integration/DynamoDb_20111205_Test.php testAddItem + +As you can see, the ``formatAttributes()`` method of the client can be used to more easily format the attributes of the +item. Alternatively, you can provide the item attributes without using the helper method: + +.. example:: DynamoDb/Integration/DynamoDb_20111205_Test.php testAddItemWithoutHelperMethod + +Retrieving items +---------------- + +You can check if the item was added correctly using the +`getItem() `_ +method of the client. Because Amazon DynamoDB works under an 'eventual consistency' model, we need to specify that we +are performing a `consistent read +`_ operation. + +.. example:: DynamoDb/Integration/DynamoDb_20111205_Test.php testGetItem + +You can also retrieve items in batches of up to 100 using the `BatchGetItem() +`_ method. + +.. example:: DynamoDb/Integration/DynamoDb_20111205_Test.php testBatchGetItem + +Query and scan +-------------- + +Once data is in an Amazon DynamoDB table, you have two APIs for searching the data: +`Query and Scan `_. + +Query +~~~~~ + +A query operation searches only primary key attribute values and supports a subset of comparison operators on key +attribute values to refine the search process. A query returns all of the item data for the matching primary keys +(all of each item's attributes) up to 1MB of data per query operation. + +Let's say we want a list of all "1201" errors that occurred in the last 15 minutes. We could issue a single query +that will search by the primary key of the table and retrieve up to 1MB of the items. However, a better approach is to +use the query iterator to retrieve the entire list of all items matching the query. + +.. example:: DynamoDb/Integration/DynamoDb_20111205_Test.php testQuery + +Scan +~~~~ + +A scan operation scans the entire table. You can specify filters to apply to the results to refine the values +returned to you, after the complete scan. Amazon DynamoDB puts a 1MB limit on the scan (the limit applies before +the results are filtered). + +A scan can be useful for more complex searches. For example, we can retrieve all of the errors in the last 15 +minutes that contain the word "overflow": + +.. example:: DynamoDb/Integration/DynamoDb_20111205_Test.php testScan + +Deleting a table +---------------- + +.. warning:: + + Deleting a table will also permanently delete all of its contents. + +Now that you've taken a quick tour of the PHP client for Amazon DynamoDB, you will want to clean up by deleting the +resources you created. + +.. example:: DynamoDb/Integration/DynamoDb_20111205_Test.php testDeleteTable + +Using the WriteRequestBatch +--------------------------- + +You can use the ``WriteRequestBatch`` if you need to write or delete many items as quickly as possible. The +WriteRequestBatch provides a high level of performance because it converts what would normally be a separate HTTP +request for each operation into HTTP requests containing up to 25 comparable requests per transaction. + +If you have a large array of items you wish to add to your table, you could iterate over the them, add each item to the +batch object. After all the items are added call ``flush()``. The batch object will automatically flush the batch and +write items to Amazon DynamoDB after hitting a customizable threshold. A final call to the batch object's ``flush()`` +method is necessary to transfer any remaining items in the queue. + +.. example:: DynamoDb/Integration/WriteRequestBatch_20111205_Test.php testWriteRequestBatchForPuts + +You can also use the ``WriteRequestBatch`` object to delete items in batches. + +.. example:: DynamoDb/Integration/WriteRequestBatch_20111205_Test.php testWriteRequestBatchForDeletes + +The ``WriteRequestBatch``, ``PutRequest``, and ``DeleteRequest`` classes are all a part of the +``Aws\DynamoDb\Model\BatchRequest`` namespace. + +.. apiref:: DynamoDb 2011-12-05 diff --git a/vendor/aws/aws-sdk-php/docs/service-dynamodb.rst b/vendor/aws/aws-sdk-php/docs/service-dynamodb.rst new file mode 100644 index 0000000..0820fb2 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-dynamodb.rst @@ -0,0 +1,215 @@ +.. service:: DynamoDb + +Creating tables +--------------- + +You must first create a table that can be used to store items. Even though Amazon DynamoDB tables do not use a fixed +schema, you do need to create a schema for the table's keys. This is explained in greater detail in Amazon DynamoDB's +`Data Model documentation `_. You +will also need to specify the amount of `provisioned throughput +`_ that should +be made available to the table. + +.. example:: DynamoDb/Integration/DynamoDb_20120810_Test.php testCreateTable + +The table will now have a status of ``CREATING`` while the table is being provisioned. You can use a waiter to poll the +table until it becomes ``ACTIVE``. + +.. example:: DynamoDb/Integration/DynamoDb_20120810_Test.php testWaitUntilTableExists + +A full list of the parameters available to the ``createTable()`` operation can be found in the `API documentation +`_. For more +information about using Local Secondary Indexes, please see the :ref:`dynamodb-lsi` section of this guide. + +Updating a table +---------------- + +You can also update the table after it's been created using the `updateTable() `_ method. This allows you to do things +like increase or decrease your provisioned throughput capacity. + +.. example:: DynamoDb/Integration/DynamoDb_20120810_Test.php testUpdateTable + +Describing a table +------------------ + +Now that the table is created, you can use the +`describeTable() `_ +method to get information about the table. + +.. example:: DynamoDb/Integration/DynamoDb_20120810_Test.php testDescribeTable + +The return value of the ``describeTable()`` method is a ``Guzzle\Service\Resource\Model`` object that can be used like +an array. For example, you could retrieve the number of items in a table or the amount of provisioned read throughput. + +Listing tables +-------------- + +You can retrieve a list of all of the tables associated with a specific endpoint using the +`listTables() `_ +method. Each Amazon DynamoDB endpoint is entirely independent. For example, if you have two tables called "MyTable," one +in US-EAST-1 and one in US-WEST-2, they are completely independent and do not share any data. The ListTables operation +returns all of the table names associated with the account making the request, for the endpoint that receives the +request. + +.. example:: DynamoDb/Integration/DynamoDb_20120810_Test.php testListTables + +Iterating over all tables +~~~~~~~~~~~~~~~~~~~~~~~~~ + +The result of a ``listTables()`` operation might be truncated. Because of this, it is usually better to use an iterator +to retrieve a complete list of all of the tables owned by your account in a specific region. The iterator will +automatically handle sending any necessary subsequent requests. + +.. example:: DynamoDb/Integration/DynamoDb_20120810_Test.php testListTablesWithIterator + +.. tip:: + + You can convert an iterator to an array using the ``toArray()`` method of the iterator. + +Adding items +------------ + +You can add an item to our *errors* table using the +`putItem() `_ +method of the client. + +.. example:: DynamoDb/Integration/DynamoDb_20120810_Test.php testAddItem + +As you can see, the ``formatAttributes()`` method of the client can be used to more easily format the attributes of the +item. Alternatively, you can provide the item attributes without using the helper method: + +.. example:: DynamoDb/Integration/DynamoDb_20120810_Test.php testAddItemWithoutHelperMethod + +You can also add items in batches of up to 25 items using the `BatchWriteItem() +`_ +method. Please see the example as shown in the :ref:`dynamodb-lsi` section of this guide. + +There is also a higher-level abstraction in the SDK over the ``BatchWriteItem`` operation called the +``WriteRequestBatch`` that handles queuing of write requests and retrying of unprocessed items. Please see the +:ref:`dynamodb-wrb` section of this guide for more information. + +Retrieving items +---------------- + +You can check if the item was added correctly using the +`getItem() `_ +method of the client. Because Amazon DynamoDB works under an 'eventual consistency' model, we need to specify that we +are performing a `consistent read +`_ operation. + +.. example:: DynamoDb/Integration/DynamoDb_20120810_Test.php testGetItem + +You can also retrieve items in batches of up to 100 using the `BatchGetItem() +`_ method. + +.. example:: DynamoDb/Integration/DynamoDb_20120810_Test.php testBatchGetItem + +Query and scan +-------------- + +Once data is in an Amazon DynamoDB table, you have two APIs for searching the data: +`Query and Scan `_. + +Query +~~~~~ + +A query operation searches only primary key attribute values and supports a subset of comparison operators on key +attribute values to refine the search process. A query returns all of the item data for the matching primary keys +(all of each item's attributes) up to 1MB of data per query operation. + +Let's say we want a list of all "1201" errors that occurred in the last 15 minutes. We could issue a single query +that will search by the primary key of the table and retrieve up to 1MB of the items. However, a better approach is to +use the query iterator to retrieve the entire list of all items matching the query. + +.. example:: DynamoDb/Integration/DynamoDb_20120810_Test.php testQuery + +Scan +~~~~ + +A scan operation scans the entire table. You can specify filters to apply to the results to refine the values +returned to you, after the complete scan. Amazon DynamoDB puts a 1MB limit on the scan (the limit applies before +the results are filtered). + +A scan can be useful for more complex searches. For example, we can retrieve all of the errors in the last 15 +minutes that contain the word "overflow": + +.. example:: DynamoDb/Integration/DynamoDb_20120810_Test.php testScan + +Deleting items +-------------- + +To delete an item you must use the `DeleteItem() +`_ method. +The following example scans through a table and deletes every item one by one. + +.. example:: DynamoDb/Integration/DynamoDb_20120810_Test.php testDeleteItem + +You can also delete items in batches of up to 25 items using the `BatchWriteItem() +`_ method. + +Deleting a table +---------------- + +.. warning:: + + Deleting a table will also permanently delete all of its contents. + +Now that you've taken a quick tour of the PHP client for Amazon DynamoDB, you will want to clean up by deleting the +resources you created. + +.. example:: DynamoDb/Integration/DynamoDb_20120810_Test.php testDeleteTable + +.. _dynamodb-lsi: + +Local secondary indexes +----------------------- + +Local secondary indexes (LSI) pair your table's leading hash key with an alternate range key, in order to enable +specific queries to run more quickly than they would using a standard composite primary key. The following code samples +will show how to create an *Orders* table with a hash key of *CustomerId* and a range key of *OrderId*, but also include +a local secondary index on the *OrderDate* attribute so that searching the table based by *OrderDate* can be done with a +``Query`` operation instead of a ``Scan`` operation. + +First you must create the table with the local secondary index. Note that the attributes referenced in the key schema +for the table *and* the index must all be declared in the ``AttributeDefinitions`` parameter. When you create a local +secondary index, you can specify which attributes get "projected" into the index using the ``Projection`` parameter. + +.. example:: DynamoDb/Integration/DynamoDb_20120810_Test.php testCreateTableWithLocalSecondaryIndexes + +Next you must add some items to the table that you will be querying. There's nothing in the ``BatchWriteItem`` operation +that is specific to the LSI features, but since there is not an example of this operation elsewhere in the guide, this +seems like a good place to show how to use this operation. + +.. example:: DynamoDb/Integration/DynamoDb_20120810_Test.php testBatchWriteItem + +When you query the table with an LSI, you must specify the name of the index using the ``IndexName`` parameter. The +attributes that are returned will depend on the value of the ``Select`` parameter and on what the table is projecting +to the index. In this case ``'Select' => 'COUNT'`` has been specified, so only the count of the items will be returned. + +.. example:: DynamoDb/Integration/DynamoDb_20120810_Test.php testQueryWithLocalSecondaryIndexes + +.. _dynamodb-wrb: + +Using the WriteRequestBatch +--------------------------- + +You can use the ``WriteRequestBatch`` if you need to write or delete many items as quickly as possible. The +WriteRequestBatch provides a high level of performance because it converts what would normally be a separate HTTP +request for each operation into HTTP requests containing up to 25 comparable requests per transaction. + +If you have a large array of items you wish to add to your table, you could iterate over the them, add each item to the +batch object. After all the items are added call ``flush()``. The batch object will automatically flush the batch and +write items to Amazon DynamoDB after hitting a customizable threshold. A final call to the batch object's ``flush()`` +method is necessary to transfer any remaining items in the queue. + +.. example:: DynamoDb/Integration/WriteRequestBatch_20120810_Test.php testWriteRequestBatchForPuts + +You can also use the ``WriteRequestBatch`` object to delete items in batches. + +.. example:: DynamoDb/Integration/WriteRequestBatch_20120810_Test.php testWriteRequestBatchForDeletes + +The ``WriteRequestBatch``, ``PutRequest``, and ``DeleteRequest`` classes are all a part of the +``Aws\DynamoDb\Model\BatchRequest`` namespace. + +.. apiref:: DynamoDb + diff --git a/vendor/aws/aws-sdk-php/docs/service-ec2.rst b/vendor/aws/aws-sdk-php/docs/service-ec2.rst new file mode 100644 index 0000000..7807fbc --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-ec2.rst @@ -0,0 +1,5 @@ +.. service:: Ec2 + +.. include:: _snippets/incomplete.txt + +.. apiref:: Ec2 diff --git a/vendor/aws/aws-sdk-php/docs/service-elasticache.rst b/vendor/aws/aws-sdk-php/docs/service-elasticache.rst new file mode 100644 index 0000000..3b273ef --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-elasticache.rst @@ -0,0 +1,5 @@ +.. service:: ElastiCache + +.. include:: _snippets/incomplete.txt + +.. apiref:: ElastiCache diff --git a/vendor/aws/aws-sdk-php/docs/service-elasticbeanstalk.rst b/vendor/aws/aws-sdk-php/docs/service-elasticbeanstalk.rst new file mode 100644 index 0000000..f05463d --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-elasticbeanstalk.rst @@ -0,0 +1,5 @@ +.. service:: ElasticBeanstalk + +.. include:: _snippets/incomplete.txt + +.. apiref:: ElasticBeanstalk diff --git a/vendor/aws/aws-sdk-php/docs/service-elasticloadbalancing.rst b/vendor/aws/aws-sdk-php/docs/service-elasticloadbalancing.rst new file mode 100644 index 0000000..01348d5 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-elasticloadbalancing.rst @@ -0,0 +1,5 @@ +.. service:: ElasticLoadBalancing + +.. include:: _snippets/incomplete.txt + +.. apiref:: ElasticLoadBalancing diff --git a/vendor/aws/aws-sdk-php/docs/service-elastictranscoder.rst b/vendor/aws/aws-sdk-php/docs/service-elastictranscoder.rst new file mode 100644 index 0000000..e74d682 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-elastictranscoder.rst @@ -0,0 +1,5 @@ +.. service:: ElasticTranscoder + +.. include:: _snippets/incomplete.txt + +.. apiref:: ElasticTranscoder diff --git a/vendor/aws/aws-sdk-php/docs/service-emr.rst b/vendor/aws/aws-sdk-php/docs/service-emr.rst new file mode 100644 index 0000000..70e74b1 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-emr.rst @@ -0,0 +1,5 @@ +.. service:: Emr + +.. include:: _snippets/incomplete.txt + +.. apiref:: Emr diff --git a/vendor/aws/aws-sdk-php/docs/service-glacier.rst b/vendor/aws/aws-sdk-php/docs/service-glacier.rst new file mode 100644 index 0000000..7d407fc --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-glacier.rst @@ -0,0 +1,5 @@ +.. service:: Glacier + +.. include:: _snippets/incomplete.txt + +.. apiref:: Glacier diff --git a/vendor/aws/aws-sdk-php/docs/service-iam.rst b/vendor/aws/aws-sdk-php/docs/service-iam.rst new file mode 100644 index 0000000..82619bb --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-iam.rst @@ -0,0 +1,5 @@ +.. service:: Iam + +.. include:: _snippets/incomplete.txt + +.. apiref:: Iam diff --git a/vendor/aws/aws-sdk-php/docs/service-importexport.rst b/vendor/aws/aws-sdk-php/docs/service-importexport.rst new file mode 100644 index 0000000..6cf780e --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-importexport.rst @@ -0,0 +1,5 @@ +.. service:: ImportExport + +.. include:: _snippets/incomplete.txt + +.. apiref:: ImportExport diff --git a/vendor/aws/aws-sdk-php/docs/service-kinesis.rst b/vendor/aws/aws-sdk-php/docs/service-kinesis.rst new file mode 100644 index 0000000..1fcd3c7 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-kinesis.rst @@ -0,0 +1,15 @@ +.. service:: Kinesis + +To learn about the Amazon Kinesis API, see the `Amazon Kinesis Developer Guide `_. + +Creating a stream +----------------- + +The main resource in Amazon Kinesis is the stream. To create a stream you need to decide on a stream name and shard +count. + +.. example:: Kinesis/Integration/Kinesis_20131104_Test.php testCreateStream + +.. include:: _snippets/incomplete.txt + +.. apiref:: Kinesis diff --git a/vendor/aws/aws-sdk-php/docs/service-opsworks.rst b/vendor/aws/aws-sdk-php/docs/service-opsworks.rst new file mode 100644 index 0000000..5eefaa4 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-opsworks.rst @@ -0,0 +1,5 @@ +.. service:: OpsWorks + +.. include:: _snippets/incomplete.txt + +.. apiref:: OpsWorks diff --git a/vendor/aws/aws-sdk-php/docs/service-rds.rst b/vendor/aws/aws-sdk-php/docs/service-rds.rst new file mode 100644 index 0000000..c9541ab --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-rds.rst @@ -0,0 +1,5 @@ +.. service:: Rds + +.. include:: _snippets/incomplete.txt + +.. apiref:: Rds diff --git a/vendor/aws/aws-sdk-php/docs/service-redshift.rst b/vendor/aws/aws-sdk-php/docs/service-redshift.rst new file mode 100644 index 0000000..dd959a1 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-redshift.rst @@ -0,0 +1,78 @@ +.. service:: Redshift + +Creating a cluster +------------------ + +The primary resource in Amazon Redshift is the cluster. To create a cluster you will use the ``CreateCluster`` +operation. There are several parameters you can send when creating a cluster, so please refer to the API docs to +determine which parameters to use. The following is basic example. + +.. code-block:: php + + $client->createCluster(array( + 'ClusterIdentifier' => 'your-unique-cluster-id', + 'ClusterType' => 'multi-node', + 'MasterUsername' => 'yourusername', + 'MasterUserPassword' => 'Y0urP@$$w0rd', + 'NodeType' => 'dw.hs1.xlarge', + 'NumberOfNodes' => 2, + )); + +After the ``CreateCluster`` operation is complete, the record for your cluster will exist, but it will still take some +time before the cluster is actually available for use. You can describe your cluster to check it's status. + +.. code-block:: php + + $result = $client->describeClusters(array( + 'ClusterIdentifier' => 'your-unique-cluster-id', + )); + $clusters = $result->get('Clusters'); + $status = $clusters['ClusterStatus']; + +If you would like your code to wait until the cluster is available, you can use the the ``ClusterAvailable`` waiter. + +.. code-block:: php + + $client->waitUntilClusterAvailable(array( + 'ClusterIdentifier' => 'your-unique-cluster-id', + )); + +.. warning:: It can take over 20 minutes for a cluster to become available. + +Creating snapshots +------------------ + +You can also take snapshots of your cluster with the ``CreateClusterSnapshot`` operation. Snapshots can take a little +time before they become available as well, so there is a corresponding ``SnapshotAvailable`` waiter. + +.. code-block:: php + + $client->createClusterSnapshot(array( + 'ClusterIdentifier' => 'your-unique-cluster-id', + 'SnapshotIdentifier' => 'your-unique-snapshot-id', + )); + $client->waitUntilSnapshotAvailable(array( + 'SnapshotIdentifier' => 'your-unique-snapshot-id', + )); + +Events +------ + +Amazon Redshift records events that take place with your clusters and account. These events are available for up to 14 +days and can be retrieved via the ``DescribeEvents`` operation. Only 100 events can be returned at a time, so using the +SDK's iterators feature allows you to easily fetch and iterate over all the events in your query without having to +manually send repeated requests. The ``StartTime`` and ``EndTime`` parameters can take any PHP date string or DateTime +object. + +.. code-block:: php + + $events = $client->getIterator('DescribeEvents', array( + 'StartTime' => strtotime('-3 days'), + 'EndTime' => strtotime('now'), + )); + + foreach ($events as $event) { + echo "{$event['Date']}: {$event['Message']}\n"; + } + +.. apiref:: Redshift diff --git a/vendor/aws/aws-sdk-php/docs/service-route53.rst b/vendor/aws/aws-sdk-php/docs/service-route53.rst new file mode 100644 index 0000000..b6d8a5c --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-route53.rst @@ -0,0 +1,5 @@ +.. service:: Route53 + +.. include:: _snippets/incomplete.txt + +.. apiref:: Route53 diff --git a/vendor/aws/aws-sdk-php/docs/service-s3.rst b/vendor/aws/aws-sdk-php/docs/service-s3.rst new file mode 100644 index 0000000..cbcb6e4 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-s3.rst @@ -0,0 +1,451 @@ +.. service:: S3 + +Creating a bucket +----------------- + +Now that we've created a client object, let's create a bucket. This bucket will be used throughout the remainder of this +guide. + +.. example:: S3/Integration/S3_20060301_Test.php testBucketAlreadyExists + +If you run the above code example unaltered, you'll probably trigger the following exception:: + + PHP Fatal error: Uncaught Aws\S3\Exception\BucketAlreadyExistsException: AWS Error + Code: BucketAlreadyExists, Status Code: 409, AWS Request ID: D94E6394791E98A4, + AWS Error Type: client, AWS Error Message: 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. + +This is because bucket names in Amazon S3 reside in a global namespace. You'll need to change the actual name of the +bucket used in the examples of this tutorial in order for them to work correctly. + +Creating a bucket in another region +----------------------------------- + +The above example creates a bucket in the standard US-EAST-1 region. You can change the bucket location by passing a +``LocationConstraint`` value. + +.. example:: S3/Integration/S3_20060301_Test.php testCreateBucketInRegion + +You'll notice in the above example that we are using the ``Aws\Common\Enum\Region`` object to provide the ``US_WEST_2`` +constant. The SDK provides various Enum classes under the ``Aws\Common\Enum`` namespace that can be useful for +remembering available values and ensuring you do not enter a typo. + +.. note:: + + Using the enum classes is not required. You could just pass 'us-west-2' in the ``LocationConstraint`` key. + +Waiting until the bucket exists +------------------------------- + +Now that we've created a bucket, let's force our application to wait until the bucket exists. This can be done easily +using a *waiter*. The following snippet of code will poll the bucket until it exists or the maximum number of +polling attempts are completed. + +.. example:: S3/Integration/S3_20060301_Test.php testWaitUntilBucketExists + +Uploading objects +----------------- + +Now that you've created a bucket, let's put some data in it. The following example creates an object in your bucket +called data.txt that contains 'Hello!'. + +.. example:: S3/Integration/S3_20060301_Test.php testPutObject + +The AWS SDK for PHP will attempt to automatically determine the most appropriate Content-Type header used to store the +object. If you are using a less common file extension and your Content-Type header is not added automatically, you can +add a Content-Type header by passing a ``ContentType`` option to the operation. + +Uploading a file +~~~~~~~~~~~~~~~~ + +The above example uploaded text data to your object. You can alternatively upload the contents of a file by passing +the ``SourceFile`` option. Let's also put some metadata on the object. + +.. example:: S3/Integration/S3_20060301_Test.php testPutObjectFromFile + +Uploading from a stream +~~~~~~~~~~~~~~~~~~~~~~~ + +Alternatively, you can pass a resource returned from an ``fopen`` call to the ``Body`` parameter. + +.. example:: S3/Integration/S3_20060301_Test.php testPutObjectFromStream + +Because the AWS SDK for PHP is built around Guzzle, you can also pass an EntityBody object. + +.. example:: S3/Integration/S3_20060301_Test.php testPutObjectFromEntityBody + +Listing your buckets +-------------------- + +You can list all of the buckets owned by your account using the ``listBuckets`` method. + +.. example:: S3/Integration/S3_20060301_Test.php testListBuckets + +All service operation calls using the AWS SDK for PHP return a ``Guzzle\Service\Resource\Model`` object. This object +contains all of the data returned from the service in a normalized array like object. The object also contains a +``get()`` method used to retrieve values from the model by name, and a ``getPath()`` method that can be used to +retrieve nested values. + +.. example:: S3/Integration/S3_20060301_Test.php testListBucketsWithGetPath + +Listing objects in your buckets +------------------------------- + +Listing objects is a lot easier in the new SDK thanks to *iterators*. You can list all of the objects in a bucket using +the ``ListObjectsIterator``. + +.. example:: S3/Integration/S3_20060301_Test.php testListObjectsWithIterator + +Iterators will handle sending any required subsequent requests when a response is truncated. The ListObjects iterator +works with other parameters too. + +.. code-block:: php + + $iterator = $client->getIterator('ListObjects', array( + 'Bucket' => $bucket, + 'Prefix' => 'foo' + )); + + foreach ($iterator as $object) { + echo $object['Key'] . "\n"; + } + +You can convert any iterator to an array using the ``toArray()`` method of the iterator. + +.. note:: + + Converting an iterator to an array will load the entire contents of the iterator into memory. + +Downloading objects +------------------- + +You can use the ``GetObject`` operation to download an object. + +.. example:: S3/Integration/S3_20060301_Test.php testGetObject + +The contents of the object are stored in the ``Body`` parameter of the model object. Other parameters are stored in +model including ``ContentType``, ``ContentLength``, ``VersionId``, ``ETag``, etc... + +The ``Body`` parameter stores a reference to a ``Guzzle\Http\EntityBody`` object. The SDK will store the data in a +temporary PHP stream by default. This will work for most use-cases and will automatically protect your application from +attempting to download extremely large files into memory. + +The EntityBody object has other nice features that allow you to read data using streams. + +.. example:: S3/Integration/S3_20060301_Test.php testGetObjectUsingEntityBody + +Saving objects to a file +~~~~~~~~~~~~~~~~~~~~~~~~ + +You can save the contents of an object to a file by setting the SaveAs parameter. + +.. example:: S3/Integration/S3_20060301_Test.php testGetObjectWithSaveAs + +Uploading large files using multipart uploads +--------------------------------------------- + +Amazon S3 allows you to uploads large files in pieces. The AWS SDK for PHP provides an abstraction layer that makes it +easier to upload large files using multipart upload. + +.. code-block:: php + + use Aws\Common\Enum\Size; + use Aws\Common\Exception\MultipartUploadException; + use Aws\S3\Model\MultipartUpload\UploadBuilder; + + $uploader = UploadBuilder::newInstance() + ->setClient($client) + ->setSource('/path/to/large/file.mov') + ->setBucket('mybucket') + ->setKey('my-object-key') + ->setOption('Metadata', array('Foo' => 'Bar')) + ->setOption('CacheControl', 'max-age=3600') + ->build(); + + // Perform the upload. Abort the upload if something goes wrong + try { + $uploader->upload(); + echo "Upload complete.\n"; + } catch (MultipartUploadException $e) { + $uploader->abort(); + echo "Upload failed.\n"; + } + +You can attempt to upload parts in parallel by specifying the concurrency option on the UploadBuilder object. The +following example will create a transfer object that will attempt to upload three parts in parallel until the entire +object has been uploaded. + +.. code-block:: php + + $uploader = UploadBuilder::newInstance() + ->setClient($client) + ->setSource('/path/to/large/file.mov') + ->setBucket('mybucket') + ->setKey('my-object-key') + ->setConcurrency(3) + ->build(); + +You can use the ``Aws\S3\S3Client::upload()`` method if you just want to upload files and not worry if they are too +large to send in a single PutObject operation or require a multipart upload. + +.. code-block:: php + + $client->upload('bucket', 'key', 'object body', 'public-read'); + +Setting ACLs and Access Control Policies +---------------------------------------- + +You can specify a canned ACL on an object when uploading: + +.. code-block:: php + + $client->putObject(array( + 'Bucket' => 'mybucket', + 'Key' => 'data.txt', + 'SourceFile' => '/path/to/data.txt', + 'ACL' => 'public-read' + )); + +You can use the ``Aws\S3\Enum\CannedAcl`` object to provide canned ACL constants: + +.. code-block:: php + + use Aws\S3\Enum\CannedAcl; + + $client->putObject(array( + 'Bucket' => 'mybucket', + 'Key' => 'data.txt', + 'SourceFile' => '/path/to/data.txt', + 'ACL' => CannedAcl::PUBLIC_READ + )); + +You can specify more complex ACLs using the ``ACP`` parameter when sending PutObject, CopyObject, CreateBucket, +CreateMultipartUpload, PutBucketAcl, PutObjectAcl, and other operations that accept a canned ACL. Using the ``ACP`` +parameter allows you specify more granular access control policies using a ``Aws\S3\Model\Acp`` object. The easiest +way to create an Acp object is through the ``Aws\S3\Model\AcpBuilder``. + +.. code-block:: php + + use Aws\S3\Enum\Permission; + use Aws\S3\Enum\Group; + use Aws\S3\Model\AcpBuilder; + + $acp = AcpBuilder::newInstance() + ->setOwner($myOwnerId) + ->addGrantForEmail(Permission::READ, 'test@example.com') + ->addGrantForUser(Permission::FULL_CONTROL, 'user-id') + ->addGrantForGroup(Permission::READ, Group::AUTHENTICATED_USERS) + ->build(); + + $client->putObject(array( + 'Bucket' => 'mybucket', + 'Key' => 'data.txt', + 'SourceFile' => '/path/to/data.txt', + 'ACP' => $acp + )); + +Creating a pre-signed URL +------------------------- + +You can authenticate certain types of requests by passing the required information as query-string parameters instead +of using the Authorization HTTP header. This is useful for enabling direct third-party browser access to your private +Amazon S3 data, without proxying the request. The idea is to construct a "pre-signed" request and encode it as a URL +that an end-user's browser can retrieve. Additionally, you can limit a pre-signed request by specifying an expiration +time. + +The most common scenario is creating a pre-signed URL to GET an object. The easiest way to do this is to use the +``getObjectUrl`` method of the Amazon S3 client. This same method can also be used to get an unsigned URL of a public +S3 object. + +.. example:: S3/Integration/S3_20060301_Test.php testGetObjectUrl + +You can also create pre-signed URLs for any Amazon S3 operation using the ``getCommand`` method for creating a Guzzle +command object and then calling the ``createPresignedUrl()`` method on the command. + +.. example:: S3/Integration/S3_20060301_Test.php testCreatePresignedUrlFromCommand + +If you need more flexibility in creating your pre-signed URL, then you can create a pre-signed URL for a completely +custom ``Guzzle\Http\Message\RequestInterface`` object. You can use the ``get()``, ``post()``, ``head()``, ``put()``, +and ``delete()`` methods of a client object to easily create a Guzzle request object. + +.. example:: S3/Integration/S3_20060301_Test.php testCreatePresignedUrl + +Amazon S3 stream wrapper +------------------------ + +The Amazon S3 stream wrapper allows you to store and retrieve data from Amazon S3 using built-in PHP functions like +``file_get_contents``, ``fopen``, ``copy``, ``rename``, ``unlink``, ``mkdir``, ``rmdir``, etc. + +See :doc:`feature-s3-stream-wrapper`. + +Syncing data with Amazon S3 +--------------------------- + +Uploading a directory to a bucket +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Uploading a local directory to an Amazon S3 bucket is rather simple: + +.. code-block:: php + + $client->uploadDirectory('/local/directory', 'my-bucket'); + +The ``uploadDirectory()`` method of a client will compare the contents of the local directory to the contents in the +Amazon S3 bucket and only transfer files that have changed. While iterating over the keys in the bucket and comparing +against the names of local files using a customizable filename to key converter, the changed files are added to an in +memory queue and uploaded concurrently. When the size of a file exceeds a customizable ``multipart_upload_size`` +parameter, the uploader will automatically upload the file using a multipart upload. + +Customizing the upload sync +^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +The method signature of the `uploadDirectory()` method allows for the following arguments: + +.. code-block:: php + + public function uploadDirectory($directory, $bucket, $keyPrefix = null, array $options = array()) + +By specifying ``$keyPrefix``, you can cause the uploaded objects to be placed under a virtual folder in the Amazon S3 +bucket. For example, if the ``$bucket`` name is ``my-bucket`` and the ``$keyPrefix`` is 'testing/', then your files +will be uploaded to ``my-bucket`` under the ``testing/`` virtual folder: +``https://my-bucket.s3.amazonaws.com/testing/filename.txt`` + +The ``uploadDirectory()`` method also accepts an optional associative array of ``$options`` that can be used to further +control the transfer. + +=========== ============================================================================================================ +params Array of parameters to use with each ``PutObject`` or ``CreateMultipartUpload`` operation performed during + the transfer. For example, you can specify an ``ACL`` key to change the ACL of each uploaded object. + See `PutObject `_ + for a list of available options. +base_dir Base directory to remove from each object key. By default, the ``$directory`` passed into the + ``uploadDirectory()`` method will be removed 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 5) +debug Set to true to enable debug mode to print information about each upload. Setting this value to an ``fopen`` + resource will write the debug output to a stream rather than to ``STDOUT``. +=========== ============================================================================================================ + +In the following example, a local directory is uploaded with each object stored in the bucket using a ``public-read`` +ACL, 20 requests are sent in parallel, and debug information is printed to standard output as each request is +transferred. + +.. code-block:: php + + $dir = '/local/directory'; + $bucket = 'my-bucket'; + $keyPrefix = ''; + + $client->uploadDirectory($dir, $bucket, $keyPrefix, array( + 'params' => array('ACL' => 'public-read'), + 'concurrency' => 20, + 'debug' => true + )); + +More control with the UploadSyncBuilder +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +The ``uploadDirectory()`` method is an abstraction layer over the much more powerful ``Aws\S3\Sync\UploadSyncBuilder``. +You can use an ``UploadSyncBuilder`` object directly if you need more control over the transfer. Using an +``UploadSyncBuilder`` allows for the following advanced features: + +* Can upload only files that match a glob expression +* Can upload only files that match a regular expression +* Can specify a custom ``\Iterator`` object to use to yield files to an ``UploadSync`` object. This can be used, for + example, to filter out which files are transferred even further using something like the + `Symfony 2 Finder component `_. +* Can specify the ``Aws\S3\Sync\FilenameConverterInterface`` objects used to convert Amazon S3 object names to local + filenames and vice versa. This can be useful if you require files to be renamed in a specific way. + +.. code-block:: php + + use Aws\S3\Sync\UploadSyncBuilder; + + UploadSyncBuilder::getInstance() + ->setClient($client) + ->setBucket('my-bucket') + ->setAcl('public-read') + ->uploadFromGlob('/path/to/file/*.php') + ->build() + ->transfer(); + +Downloading a bucket to a directory +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +You can download the objects stored in an Amazon S3 bucket using features similar to the ``uploadDirectory()`` method +and the ``UploadSyncBuilder``. You can download the entire contents of a bucket using the +``Aws\S3\S3Client::downloadBucket()`` method. + +The following example will download all of the objects from ``my-bucket`` and store them in ``/local/directory``. +Object keys that are under virtual subfolders are converted into a nested directory structure when downloading the +objects. Any directories missing on the local filesystem will be created automatically. + +.. code-block:: php + + $client->downloadBucket('/local/directory', 'my-bucket'); + +Customizing the download sync +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +The method signature of the ``downloadBucket()`` method allows for the following arguments: + +.. code-block:: php + + public function downloadBucket($directory, $bucket, $keyPrefix = null, array $options = array()) + +By specifying ``$keyPrefix``, you can limit the downloaded objects to only keys that begin with the specified +``$keyPrefix``. This, for example, can be useful for downloading objects under a specific virtual directory. + +The ``downloadBucket()`` method also accepts an optional associative array of ``$options`` that can be used to further +control the transfer. + +=============== ============================================================================================================ +params Array of parameters to use with each ``GetObject`` operation performed during the transfer. See + `GetObject `_ + for a list of available options. +base_dir Base directory to remove from each object key when downloading. By default, the entire object key is + used to determine the path to the file on 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 to enable debug mode to print information about each download. Setting this value to an + ``fopen`` resource will write the debug output to a stream rather than to ``STDOUT``. +allow_resumable Set to true to allow previously interrupted downloads to be resumed using a Range GET +=============== ============================================================================================================ + +More control with the DownloadSyncBuilder +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +The ``downloadBucket()`` method is an abstraction layer over the much more powerful +``Aws\S3\Sync\DownloadSyncBuilder``. You can use a ``DownloadSyncBuilder`` object directly if you need more control +over the transfer. Using the ``DownloadSyncBuilder`` allows for the following advanced features: + +* Can download only files that match a regular expression +* Just like the ``UploadSyncBuilder``, you can specify a custom ``\Iterator`` object to use to yield files to a + ``DownloadSync`` object. +* Can specify the ``Aws\S3\Sync\FilenameConverterInterface`` objects used to convert Amazon S3 object names to local + filenames and vice versa. + +.. code-block:: php + + use Aws\S3\Sync\DownloadSyncBuilder; + + DownloadSyncBuilder::getInstance() + ->setClient($client) + ->setDirectory('/path/to/directory') + ->setBucket('my-bucket') + ->setKeyPrefix('/under-prefix') + ->allowResumableDownloads() + ->build() + ->transfer(); + +Cleaning up +----------- + +Now that we've taken a tour of how you can use the Amazon S3 client, let's clean up any resources we may have created. + +.. example:: S3/Integration/S3_20060301_Test.php testCleanUpBucket + +.. apiref:: S3 + diff --git a/vendor/aws/aws-sdk-php/docs/service-ses.rst b/vendor/aws/aws-sdk-php/docs/service-ses.rst new file mode 100644 index 0000000..f38b85e --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-ses.rst @@ -0,0 +1,5 @@ +.. service:: Ses + +.. include:: _snippets/incomplete.txt + +.. apiref:: Ses diff --git a/vendor/aws/aws-sdk-php/docs/service-simpledb.rst b/vendor/aws/aws-sdk-php/docs/service-simpledb.rst new file mode 100644 index 0000000..5e4dab4 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-simpledb.rst @@ -0,0 +1,165 @@ +.. service:: SimpleDb + +Creating domains +---------------- + +The first step in storing data within Amazon SimpleDB is to +`create one or more domains `_. + +Domains are similar to database tables, except that you cannot perform functions across multiple domains, such as +querying multiple domains or using foreign keys. As a consequence, you should plan an Amazon SimpleDB data +architecture that will meet the needs of your project. + +Let's use the CreateDomain operation of the |serviceFullName| client to create a domain. + +.. code-block:: php + + $client->createDomain(array('DomainName' => 'mydomain')); + +List all domains +---------------- + +Now that the domain is created, we can list the domains in our account to verify that it exists. This is done using the +ListDomains operation and the ListDomains iterator. + +.. code-block:: php + + $domains = $client->getIterator('ListDomains')->toArray(); + var_export($domains); + // Lists an array of domain names, including "mydomain" + +Retrieving a domain +------------------- + +You can get more information about a domain using the DomainMetadata operation. This operation returns information about +a domain, including when the domain was created, the number of items and attributes, and the size of attribute names +and values. + +.. code-block:: php + + $result = $client->domainMetadata(array('DomainName' => 'mydomain')); + echo $result['ItemCount'] . "\n"; + echo $result['ItemNamesSizeBytes'] . "\n"; + echo $result['AttributeNameCount'] . "\n"; + echo $result['AttributeNamesSizeBytes'] . "\n"; + echo $result['AttributeValueCount'] . "\n"; + echo $result['AttributeValuesSizeBytes'] . "\n"; + echo $result['Timestamp'] . "\n"; + +Adding items +------------ + +After creating a domain, you are ready to start putting data into it. Domains consist of items, which are described by +attribute name-value pairs. Items are added to a domain using the PutAttributes operation. + +.. code-block:: php + + $client->putAttributes(array( + 'DomainName' => 'mydomain', + 'ItemName' => 'test', + 'Attributes' => array( + array('Name' => 'a', 'Value' => 1, 'Replace' => true), + array('Name' => 'b', 'Value' => 2), + ) + )); + +.. note:: + + When you put attributes, notice that the Replace parameter is optional, and set to false by default. If you do not + explicitly set Replace to true, a new attribute name-value pair is created each time; even if the Name value + already exists in your Amazon SimpleDB domain. + +Retrieving items +---------------- + +GetAttributes +~~~~~~~~~~~~~ + +We can check to see if the item was added correctly by retrieving the specific item by name using the GetAttribute +operation. + +.. code-block:: php + + $result = $client->getAttributes(array( + 'DomainName' => 'mydomain', + 'ItemName' => 'test', + 'Attributes' => array( + 'a', 'b' + ), + 'ConsistentRead' => true + )); + +Notice that we set the `ConsistentRead` option to `true`. Amazon SimpleDB keeps multiple copies of each domain. A +successful write (using PutAttributes, BatchPutAttributes, DeleteAttributes, BatchDeleteAttributes, CreateDomain, or +DeleteDomain) guarantees that all copies of the domain will durably persist. Amazon SimpleDB supports two read +consistency options: eventually consistent read and consistent read. A consistent read (using Select or GetAttributes +with ConsistentRead=true) returns a result that reflects all writes that received a successful response prior to the +read. + +You can find out more about consistency and |serviceFullName| in the service's +`developer guide on consistency `_. + +Select +~~~~~~ + +You can retrieve attributes for items by name, but |serviceFullName| also supports the Select operation. The Select +operation returns a set of Attributes for ItemNames that match the select expression. Select is similar to the standard +SQL SELECT statement. + +Let's write a select query that will return all items withe the `a` attribute set to `1`. + +.. code-block:: php + + $result = $client->select(array( + 'SelectExpression' => "select * from mydomain where a = '1'" + )); + foreach ($result['Items'] as $item) { + echo $item['Name'] . "\n"; + var_export($item['Attributes']); + } + +Because some responses will be truncated and require subsequent requests, it is recommended to always use the +Select iterator to easily retrieve an entire result set. + +.. code-block:: php + + $iterator = $client->getIterator('Select', array( + 'SelectExpression' => "select * from mydomain where a = '1'" + )); + foreach ($iterator as $item) { + echo $item['Name'] . "\n"; + var_export($item['Attributes']); + } + +You can find much more information about the Select operation in the service's +`developer guide on select `_. + +Deleting items +-------------- + +You can delete specific attributes of an item or an entire item using the DeleteAttributes operation. If all attributes +of an item are deleted, the item is deleted. + +Let's go ahead and delete the item we created in `mydomain`. + +.. code-block:: php + + $client->deleteAttributes(array( + 'DomainName' => 'mydomain', + 'ItemName' => 'test' + )); + +Because we did not specify an `Attributes` parameter, the entire item is deleted. + +Deleting domains +---------------- + +Now that we've explored some of the features of |serviceFullName|, we should delete our testing data. The +DeleteDomain operation deletes a domain. Any items (and their attributes) in the domain are deleted as well. The +DeleteDomain operation might take 10 or more seconds to complete. + +.. code-block:: php + + $client->deleteDomain(array('DomainName' => 'mydomain')); + +.. apiref:: SimpleDb diff --git a/vendor/aws/aws-sdk-php/docs/service-sns.rst b/vendor/aws/aws-sdk-php/docs/service-sns.rst new file mode 100644 index 0000000..097fe03 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-sns.rst @@ -0,0 +1,5 @@ +.. service:: Sns + +.. include:: _snippets/incomplete.txt + +.. apiref:: Sns diff --git a/vendor/aws/aws-sdk-php/docs/service-sqs.rst b/vendor/aws/aws-sdk-php/docs/service-sqs.rst new file mode 100644 index 0000000..d77dc21 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-sqs.rst @@ -0,0 +1,103 @@ +.. service:: Sqs + +Creating a queue +---------------- + +Now, let's create a queue. You can create a standard queue by just providing a name. Make sure to get the queue's URL +from the result, since the queue URL is the unique identifier used to specify the queue in order to send and receive +messages. + +.. code-block:: php + + $result = $client->createQueue(array('QueueName' => 'my-queue')); + $queueUrl = $result->get('QueueUrl'); + +You can also set attributes on your queue when you create it. + +.. code-block:: php + + use Aws\Common\Enum\Size; + use Aws\Sqs\Enum\QueueAttribute; + + $result = $client->createQueue(array( + 'QueueName' => 'my-queue', + 'Attributes' => array( + QueueAttribute::DELAY_SECONDS => 5, + QueueAttribute::MAXIMUM_MESSAGE_SIZE => 4 * Size::KB, + ), + )); + $queueUrl = $result->get('QueueUrl'); + +Or you can also set queue attributes later. + +.. code-block:: php + + use Aws\Common\Enum\Time; + use Aws\Sqs\Enum\QueueAttribute; + + $result = $client->setQueueAttributes(array( + 'QueueUrl' => $queueUrl, + 'Attributes' => array( + QueueAttribute::VISIBILITY_TIMEOUT => 2 * Time::MINUTES, + ), + )); + +Sending messages +---------------- + +Sending a message to a queue is straight forward with the ``SendMessage`` command. + +.. code-block:: php + + $client->sendMessage(array( + 'QueueUrl' => $queueUrl, + 'MessageBody' => 'An awesome message!', + )); + +You can overwrite the queue's default delay for a message when you send it. + +.. code-block:: php + + $client->sendMessage(array( + 'QueueUrl' => $queueUrl, + 'MessageBody' => 'An awesome message!', + 'DelaySeconds' => 30, + )); + +Receiving messages +------------------ + +Receiving messages is done with the ``ReceiveMessage`` command. + +.. code-block:: php + + $result = $client->receiveMessage(array( + 'QueueUrl' => $queueUrl, + )); + + foreach ($result->getPath('Messages/*/Body') as $messageBody) { + // Do something with the message + echo $messageBody; + } + +By default, only one message will be returned. If you want to get more messages, make sure to use the +``MaxNumberOfMessages`` parameter and specify a number of messages (1 to 10). Remember that you are not guaranteed to +receive that many messages, but you can receive up to that amount depending on how many are actually in the queue at +the time of your request. + +SQS also supports `"long polling" +`_, meaning that you +can instruct SQS to hold the connection open with the SDK for up to 20 seconds in order to wait for a message to arrive +in the queue. To configure this behavior, you must use the ``WaitTimeSeconds`` parameter. + +.. code-block:: php + + $result = $client->receiveMessage(array( + 'QueueUrl' => $queueUrl, + 'WaitTimeSeconds' => 10, + )); + +.. note:: You can also configure long-polling at the queue level by setting the ``ReceiveMessageWaitTimeSeconds`` queue + attribute. + +.. apiref:: Sqs diff --git a/vendor/aws/aws-sdk-php/docs/service-storagegateway.rst b/vendor/aws/aws-sdk-php/docs/service-storagegateway.rst new file mode 100644 index 0000000..45fa360 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-storagegateway.rst @@ -0,0 +1,5 @@ +.. service:: StorageGateway + +.. include:: _snippets/incomplete.txt + +.. apiref:: StorageGateway diff --git a/vendor/aws/aws-sdk-php/docs/service-sts.rst b/vendor/aws/aws-sdk-php/docs/service-sts.rst new file mode 100644 index 0000000..ef66635 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-sts.rst @@ -0,0 +1,92 @@ +.. service:: Sts + +.. note:: + + For information about why you might need to use temporary credentials in your application or project, see + `Scenarios for Granting Temporary Access `_ in the + AWS STS documentation. + +Getting Temporary Credentials +----------------------------- + +AWS STS has five operations that return temporary credentials: ``AssumeRole``, ``AssumeRoleWithWebIdentity``, +``AssumeRoleWithSAML``, ``GetFederationToken``, and ``GetSessionToken``. Using the ``GetSessionToken`` operation is +trivial, so let's use that one as an example. + +.. code-block:: php + + $result = $client->getSessionToken(); + +The result for ``GetSessionToken`` and the other AWS STS operations always contains a ``'Credentials'`` value. If you +print the result (e.g., ``print_r($result)``), it looks like the following: + +.. code-block:: php + + Array + ( + ... + [Credentials] => Array + ( + [SessionToken] => '' + [SecretAccessKey] => '' + [Expiration] => 2013-11-01T01:57:52Z + [AccessKeyId] => '' + ) + ... + ) + +Using Temporary Credentials +--------------------------- + +You can use temporary credentials with another AWS client by instantiating the client and passing in the values received +from AWS STS directly. + +.. code-block:: php + + use Aws\S3\S3Client; + + $result = $client->getSessionToken(); + + $s3 = S3Client::factory(array( + 'key' => $result['Credentials']['AccessKeyId'], + 'secret' => $result['Credentials']['SecretAccessKey'], + 'token' => $result['Credentials']['SessionToken'], + )); + +You can also construct a ``Credentials`` object and use that when instantiating the client. + +.. code-block:: php + + use Aws\Common\Credentials\Credentials; + use Aws\S3\S3Client; + + $result = $client->getSessionToken(); + + $credentials = new Credentials( + $result['Credentials']['AccessKeyId'], + $result['Credentials']['SecretAccessKey'], + $result['Credentials']['SessionToken'] + ); + + $s3 = S3Client::factory(array('credentials' => $credentials)); + +However, the *best* way to provide temporary credentials is to use the ``createCredentials()`` helper method included +with ``StsClient``. This method extracts the data from an AWS STS result and creates the ``Credentials`` object for you. + +.. code-block:: php + + $result = $sts->getSessionToken(); + $credentials = $sts->createCredentials($result); + + $s3 = S3Client::factory(array('credentials' => $credentials)); + +You can also use the same technique when setting credentials on an existing client object. + +.. code-block:: php + + $credentials = $sts->createCredentials($sts->getSessionToken()); + $s3->setCredentials($credentials); + +.. include:: _snippets/incomplete.txt + +.. apiref:: Sts diff --git a/vendor/aws/aws-sdk-php/docs/service-support.rst b/vendor/aws/aws-sdk-php/docs/service-support.rst new file mode 100644 index 0000000..217073a --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-support.rst @@ -0,0 +1,5 @@ +.. service:: Support + +.. include:: _snippets/incomplete.txt + +.. apiref:: Support diff --git a/vendor/aws/aws-sdk-php/docs/service-swf.rst b/vendor/aws/aws-sdk-php/docs/service-swf.rst new file mode 100644 index 0000000..9c60ee9 --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/service-swf.rst @@ -0,0 +1,5 @@ +.. service:: Swf + +.. include:: _snippets/incomplete.txt + +.. apiref:: Swf diff --git a/vendor/aws/aws-sdk-php/docs/side-by-side.rst b/vendor/aws/aws-sdk-php/docs/side-by-side.rst new file mode 100644 index 0000000..ced75ac --- /dev/null +++ b/vendor/aws/aws-sdk-php/docs/side-by-side.rst @@ -0,0 +1,277 @@ +================== +Side-by-side Guide +================== + +This guide helps you install, configure, and run Version 1 and Version 2 of the AWS SDK for PHP side-by-side within the +same application or project. Please see the :doc:`migration-guide` for more information on migrating code from the +original AWS SDK for PHP to Version 2. + +Since Version 2 of the AWS SDK for PHP now supports all of the AWS services supported by Version 1 (and more), it is +recommended that you should begin migrating your code to use Version 2 of the SDK. Using both SDKs side-by-side may be +helpful if your use case requires you to migrate only sections of your code at a time. + +Installing and Including the SDKs +--------------------------------- + +To install and include the SDKs in your project, you must first choose whether or not to use Composer. + +Using Composer +~~~~~~~~~~~~~~ + +Using `Composer `_ is the recommended way to install both versions of the AWS SDK for PHP. +Composer is a dependency management tool for PHP that allows you to declare the dependencies your project requres and +installs them into your project. In order to simultaneously use both versions of the SDK in the same project through +Composer, you must do the following: + +#. Add both of the SDKs as dependencies in your project's ``composer.json`` file. + + .. code-block:: js + + { + "require": { + "aws/aws-sdk-php": "*", + "amazonwebservices/aws-sdk-for-php": "*" + } + } + + **Note:** Consider tightening your dependencies to a known version when deploying mission critical applications + (e.g., ``2.0.*``). + +#. Download and install Composer. + + .. code-block:: sh + + curl -s "http://getcomposer.org/installer" | php + +#. Install your dependencies. + + .. code-block:: sh + + php composer.phar install + +#. Require Composer's autoloader. + + Composer also prepares an autoload file that's capable of autoloading all of the classes in any of the libraries that + it downloads. To use it, just add the following line to your code's bootstrap process. + + .. code-block:: php + + require '/path/to/sdk/vendor/autoload.php'; + +You can find out more on how to install Composer, configure autoloading, and other best-practices for defining +dependencies at `getcomposer.org `_. + +Without Composer +~~~~~~~~~~~~~~~~ + +Without Composer, you must manage your own project dependencies. + +#. Download both of the SDKs (via PEAR, GitHub, or the AWS website) into a location accessible by your project. Make + certain to use the pre-packaged ``aws.phar`` file, which includes all of the dependencies for the AWS SDK for PHP. + +#. In your code's bootstrap process, you need to explicitly require the bootstrap file from Version 1 of the SDK and the + ``aws.phar`` file containing Version 2 of the SDK: + + .. code-block:: php + + // Include each of the SDK's bootstrap files to setup autoloading + require '/path/to/sdk.class.php'; // Load the Version 1 bootstrap file + require '/path/to/aws.phar'; // Load the Version 2 pre-packaged phar file + +Configuring and Instantiating the SDKs +-------------------------------------- + +How you configure and instantiate the SDKs is determined by whether or not you are using the service builder +(``Aws\Common\Aws`` class). + +Instantiating Clients via the Service Builder +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +The service builder (``Aws\Common\Aws class``) in the AWS SDK for PHP enables configuring all service clients with the +same credentials. It also accepts additional settings for some or all of the clients. The service builder functionality +is inherited from the `Guzzle `_ project. + +You can pass the service builder a configuration file containing your credentials and other settings. It will then +inject these into all of the service clients your code instantiates. For more information about the configuration file, +please read the :doc:`configuration` section of the guide. When using both SDKs side-by-side, your configuration file +must include the following line: + +.. code-block:: php + + 'includes' => array('_sdk1'), + +This will automatically set up the service clients from Version 1 of the SDK making them accessible through the service +builder by keys such as ``v1.s3`` and ``v1.cloudformation``. Here is an example configuration file that includes +referencing the Version 1 of the SDK: + +.. code-block:: php + + array('_sdk1'), + 'services' => array( + 'default_settings' => array( + 'params' => array( + 'key' => 'your-aws-access-key-id', + 'secret' => 'your-aws-secret-access-key', + 'region' => 'us-west-2' + ) + ) + ) + ); + +Your code must instantiate the service builder through its factory method by passing in the path of the configuration +file. Your code then retrieves instances of the specific service clients from the returned builder object. + +.. code-block:: php + + use Aws\Common\Aws; + + // Instantiate the service builder + $aws = Aws::factory('/path/to/your/config.php'); + + // Instantiate S3 clients via the service builder + $s3v1 = $aws->get('v1.s3'); // All Version 1 clients are prefixed with "v1." + $s3v2 = $aws->get('s3'); + +Instantiating Clients via Client Factories +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Your code can instantiate service clients using their respective ``factory()`` methods by passing in an array of +configuration data, including your credentials. The ``factory()`` will work for clients in either versions of the SDK. + +.. code-block:: php + + use Aws\S3\S3Client; + + // Create an array of configuration options + $config = array( + 'key' => 'your-aws-access-key-id', + 'secret' => 'your-aws-secret-access-key', + ); + + // Instantiate Amazon S3 clients from both SDKs via their factory methods + $s3v1 = AmazonS3::factory($config); + $s3v2 = S3Client::factory($config); + +Optionally, you could alias the classes to make it clearer which version of the SDK they are from. + +.. code-block:: php + + use AmazonS3 as S3ClientV1; + use Aws\S3\S3Client as S3ClientV2; + + $config = array( + 'key' => 'your-aws-access-key-id', + 'secret' => 'your-aws-secret-access-key', + ); + + $s3v1 = S3ClientV1::factory($config); + $s3v2 = S3ClientV2::factory($config); + +Complete Examples +----------------- + +The following two examples fully demonstrate including, configuring, instantiating, and using both SDKs side-by-side. +These examples adopt the recommended practices of using Composer and the service builder. + +Example 1 - Dual Amazon S3 Clients +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +This example demonstrates using an Amazon S3 client from the AWS SDK for PHP working side-by-side with an Amazon S3 +client from the first PHP SDK. + +.. code-block:: php + + get('v1.s3'); + $s3v2 = $aws->get('s3'); + + echo "ListBuckets with SDK Version 1:\n"; + echo "-------------------------------\n"; + $response = $s3v1->listBuckets(); + if ($response->isOK()) { + foreach ($response->body->Buckets->Bucket as $bucket) { + echo "- {$bucket->Name}\n"; + } + } else { + echo "Request failed.\n"; + } + echo "\n"; + + echo "ListBuckets with SDK Version 2:\n"; + echo "-------------------------------\n"; + try { + $result = $s3v2->listBuckets(); + foreach ($result['Buckets'] as $bucket) { + echo "- {$bucket['Name']}\n"; + } + } catch (Aws\S3\Exception\S3Exception $e) { + echo "Request failed.\n"; + } + echo "\n"; + +Example 2 - Amazon DynamoDB and Amazon SNS Clients +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +This example shows how the AWS SDK for PHP DynamoDB client works together with the SNS client from the original SDK. +For this example, an ice cream parlor publishes a daily message (via SNS) containing its "flavors of the day" to +subscribers. First, it retrieves the flavors of the day from its DynamoDB database using the AWS SDK for PHP DynamoDB +client. It then uses the SNS client from the first SDK to publish a message to its SNS topic. + +.. code-block:: php + + get('dynamodb'); + $sns = $aws->get('v1.sns'); + $sns->set_region(AmazonSNS::REGION_US_W2); + + // Get today's flavors from DynamoDB using Version 2 of the SDK + $date = new DateTime(); + $flavors = $ddb->getItem(array( + 'TableName' => 'flavors-of-the-day', + 'Key' => array( + 'HashKeyElement' => array('N' => $date->format('n')), + 'RangeKeyElement' => array('N' => $date->format('j')) + ) + ))->getResult()->getPath('Item/flavors/SS'); + + // Generate the message + $today = $date->format('l, F jS'); + $message = "It's {$today}, and here are our flavors of the day:\n"; + foreach ($flavors as $flavor) { + $message .= "- {$flavor}\n"; + } + $message .= "\nCome visit Mr. Foo\'s Ice Cream Parlor on 5th and Pine!\n"; + echo "{$message}\n"; + + // Send today's flavors to subscribers using Version 1 of the SDK + $response = $sns->publish('flavors-of-the-day-sns-topic', $message, array( + 'Subject' => 'Flavors of the Day - Mr. Foo\'s Ice Cream Parlor' + )); + if ($response->isOK()) { + echo "Sent the flavors of the day to your subscribers.\n"; + } else { + echo "There was an error sending the flavors of the day to your subscribers.\n"; + } + +Final Notes +----------- + +Remember that **instantiating clients from the original SDK using the service builder from AWS SDK for PHP does not +change how those clients work**. For example, notice the differences in response handling between SDK versions. For a +full list of differences between the versions, please see the :doc:`migration-guide`. + +For more information about using the original version of the SDK, please see the `Version 1 API Documentation +`_ and the `Version 1 SDK README +`_. diff --git a/vendor/aws/aws-sdk-php/phpunit.functional.xml.dist b/vendor/aws/aws-sdk-php/phpunit.functional.xml.dist new file mode 100644 index 0000000..aa951be --- /dev/null +++ b/vendor/aws/aws-sdk-php/phpunit.functional.xml.dist @@ -0,0 +1,44 @@ + + + + + + + + + + + + + + + + + + + + ./tests/Aws/Tests + + + + + + + integration + performance + + + + diff --git a/vendor/aws/aws-sdk-php/phpunit.xml.dist b/vendor/aws/aws-sdk-php/phpunit.xml.dist new file mode 100644 index 0000000..9c940ae --- /dev/null +++ b/vendor/aws/aws-sdk-php/phpunit.xml.dist @@ -0,0 +1,80 @@ + + + + + + tests/Aws/Tests + + + + + + + integration + performance + + + + + + + + + + ./src/Aws + + ./src/Aws + ./src/Aws/**/Enum + ./src/Aws/**/Resources + ./src/Aws/Common/Exception/DomainException.php + ./src/Aws/Common/Exception/InvalidArgumentException.php + ./src/Aws/Common/Exception/LogicException.php + ./src/Aws/Common/Exception/OverflowException.php + ./src/Aws/Common/Exception/OutOfBoundsException.php + ./src/Aws/Common/Exception/RuntimeException.php + ./src/Aws/Common/Exception/UnexpectedValueException.php + ./src/Aws/AutoScaling/Exception + ./src/Aws/CloudFormation/Exception + ./src/Aws/CloudFront/Exception + ./src/Aws/CloudSearch/Exception + ./src/Aws/CloudTrail/Exception + ./src/Aws/CloudWatch/Exception + ./src/Aws/DataPipeline/Exception + ./src/Aws/DirectConnect/Exception + ./src/Aws/DynamoDb/Exception + ./src/Aws/Ec2/Exception + ./src/Aws/ElastiCache/Exception + ./src/Aws/ElasticBeanstalk/Exception + ./src/Aws/ElasticLoadBalancing/Exception + ./src/Aws/ElasticTranscoder/Exception + ./src/Aws/Emr/Exception + ./src/Aws/Glacier/Exception + ./src/Aws/Iam/Exception + ./src/Aws/ImportExport/Exception + ./src/Aws/Kinesis/Exception + ./src/Aws/OpsWorks/Exception + ./src/Aws/Rds/Exception + ./src/Aws/Redshift/Exception + ./src/Aws/Route53/Exception + ./src/Aws/S3/Exception + ./src/Aws/Ses/Exception + ./src/Aws/SimpleDb/Exception + ./src/Aws/Sns/Exception + ./src/Aws/Sqs/Exception + ./src/Aws/StorageGateway/Exception + ./src/Aws/Sts/Exception + ./src/Aws/Support/Exception + ./src/Aws/Swf/Exception + + + + + diff --git a/vendor/aws/aws-sdk-php/src/Aws/AutoScaling/AutoScalingClient.php b/vendor/aws/aws-sdk-php/src/Aws/AutoScaling/AutoScalingClient.php new file mode 100644 index 0000000..e387976 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/AutoScaling/AutoScalingClient.php @@ -0,0 +1,99 @@ +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-sdk-php/src/Aws/AutoScaling/Enum/LifecycleState.php b/vendor/aws/aws-sdk-php/src/Aws/AutoScaling/Enum/LifecycleState.php new file mode 100644 index 0000000..439a02f --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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, + ), + ), + ), + 'CreateAutoScalingGroup' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateAutoScalingGroup', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'AutoScalingGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'LaunchConfigurationName' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + 'InstanceId' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 16, + ), + 'MinSize' => array( + 'required' => true, + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'MaxSize' => array( + 'required' => true, + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'DesiredCapacity' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'DefaultCooldown' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'AvailabilityZones' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'AvailabilityZones.member', + 'minItems' => 1, + 'items' => array( + 'name' => 'XmlStringMaxLen255', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + ), + 'LoadBalancerNames' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'LoadBalancerNames.member', + 'items' => array( + 'name' => 'XmlStringMaxLen255', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + ), + 'HealthCheckType' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 32, + ), + 'HealthCheckGracePeriod' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'PlacementGroup' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'VPCZoneIdentifier' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'TerminationPolicies' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'TerminationPolicies.member', + 'items' => array( + 'name' => 'XmlStringMaxLen1600', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 1600, + ), + ), + 'Tags' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Tags.member', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'properties' => array( + 'ResourceId' => array( + 'type' => 'string', + ), + 'ResourceType' => array( + 'type' => 'string', + ), + 'Key' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'Value' => array( + 'type' => 'string', + 'maxLength' => 256, + ), + 'PropagateAtLaunch' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The named Auto Scaling group or launch configuration already exists.', + 'class' => 'AlreadyExistsException', + ), + array( + 'reason' => 'The quota for capacity groups or launch configurations for this customer has already been reached.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'CreateLaunchConfiguration' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateLaunchConfiguration', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'LaunchConfigurationName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'ImageId' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'KeyName' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'SecurityGroups' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'SecurityGroups.member', + 'items' => array( + 'name' => 'XmlString', + 'type' => 'string', + ), + ), + 'UserData' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'maxLength' => 21847, + ), + 'InstanceId' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 16, + ), + 'InstanceType' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'KernelId' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'RamdiskId' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'BlockDeviceMappings' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'BlockDeviceMappings.member', + 'items' => array( + 'name' => 'BlockDeviceMapping', + 'type' => 'object', + 'properties' => array( + 'VirtualName' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'DeviceName' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'Ebs' => array( + 'type' => 'object', + 'properties' => array( + 'SnapshotId' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'VolumeSize' => array( + 'type' => 'numeric', + 'minimum' => 1, + 'maximum' => 1024, + ), + 'VolumeType' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'DeleteOnTermination' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'Iops' => array( + 'type' => 'numeric', + 'minimum' => 100, + 'maximum' => 4000, + ), + ), + ), + 'NoDevice' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + ), + 'InstanceMonitoring' => array( + 'type' => 'object', + 'location' => 'aws.query', + 'properties' => array( + 'Enabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + 'SpotPrice' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'IamInstanceProfile' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + 'EbsOptimized' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'AssociatePublicIpAddress' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'PlacementTenancy' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 64, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The named Auto Scaling group or launch configuration already exists.', + 'class' => 'AlreadyExistsException', + ), + array( + 'reason' => 'The quota for capacity groups or launch configurations for this customer has already been reached.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'CreateOrUpdateTags' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateOrUpdateTags', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'Tags' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Tags.member', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'properties' => array( + 'ResourceId' => array( + 'type' => 'string', + ), + 'ResourceType' => array( + 'type' => 'string', + ), + 'Key' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'Value' => array( + 'type' => 'string', + 'maxLength' => 256, + ), + 'PropagateAtLaunch' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The quota for capacity groups or launch configurations for this customer has already been reached.', + 'class' => 'LimitExceededException', + ), + array( + 'reason' => 'The named Auto Scaling group or launch configuration already exists.', + 'class' => 'AlreadyExistsException', + ), + ), + ), + 'DeleteAutoScalingGroup' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteAutoScalingGroup', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'AutoScalingGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + 'ForceDelete' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'You cannot delete an Auto Scaling group while there are scaling activities in progress for that group.', + 'class' => 'ScalingActivityInProgressException', + ), + array( + 'reason' => 'This is returned when you cannot delete a launch configuration or Auto Scaling group because it is being used.', + 'class' => 'ResourceInUseException', + ), + ), + ), + 'DeleteLaunchConfiguration' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteLaunchConfiguration', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'LaunchConfigurationName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'This is returned when you cannot delete a launch configuration or Auto Scaling group because it is being used.', + 'class' => 'ResourceInUseException', + ), + ), + ), + 'DeleteNotificationConfiguration' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteNotificationConfiguration', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'AutoScalingGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + 'TopicARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + ), + ), + 'DeletePolicy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeletePolicy', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'AutoScalingGroupName' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + 'PolicyName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + ), + ), + 'DeleteScheduledAction' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteScheduledAction', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'AutoScalingGroupName' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + 'ScheduledActionName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + ), + ), + 'DeleteTags' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteTags', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'Tags' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Tags.member', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'properties' => array( + 'ResourceId' => array( + 'type' => 'string', + ), + 'ResourceType' => array( + 'type' => 'string', + ), + 'Key' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'Value' => array( + 'type' => 'string', + 'maxLength' => 256, + ), + 'PropagateAtLaunch' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + ), + ), + ), + 'DescribeAccountLimits' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DescribeAccountLimitsAnswer', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeAccountLimits', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + ), + ), + 'DescribeAdjustmentTypes' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DescribeAdjustmentTypesAnswer', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeAdjustmentTypes', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + ), + ), + 'DescribeAutoScalingGroups' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'AutoScalingGroupsType', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeAutoScalingGroups', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'AutoScalingGroupNames' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'AutoScalingGroupNames.member', + 'items' => array( + 'name' => 'ResourceName', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 1600, + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MaxRecords' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The NextToken value is invalid.', + 'class' => 'InvalidNextTokenException', + ), + ), + ), + 'DescribeAutoScalingInstances' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'AutoScalingInstancesType', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeAutoScalingInstances', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'InstanceIds' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'InstanceIds.member', + 'items' => array( + 'name' => 'XmlStringMaxLen16', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 16, + ), + ), + 'MaxRecords' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The NextToken value is invalid.', + 'class' => 'InvalidNextTokenException', + ), + ), + ), + 'DescribeAutoScalingNotificationTypes' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DescribeAutoScalingNotificationTypesAnswer', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeAutoScalingNotificationTypes', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + ), + ), + 'DescribeLaunchConfigurations' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'LaunchConfigurationsType', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeLaunchConfigurations', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'LaunchConfigurationNames' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'LaunchConfigurationNames.member', + 'items' => array( + 'name' => 'ResourceName', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 1600, + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MaxRecords' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The NextToken value is invalid.', + 'class' => 'InvalidNextTokenException', + ), + ), + ), + 'DescribeMetricCollectionTypes' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DescribeMetricCollectionTypesAnswer', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeMetricCollectionTypes', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + ), + ), + 'DescribeNotificationConfigurations' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DescribeNotificationConfigurationsAnswer', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeNotificationConfigurations', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'AutoScalingGroupNames' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'AutoScalingGroupNames.member', + 'items' => array( + 'name' => 'ResourceName', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 1600, + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MaxRecords' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The NextToken value is invalid.', + 'class' => 'InvalidNextTokenException', + ), + ), + ), + 'DescribePolicies' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'PoliciesType', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribePolicies', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'AutoScalingGroupName' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + 'PolicyNames' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'PolicyNames.member', + 'items' => array( + 'name' => 'ResourceName', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 1600, + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MaxRecords' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The NextToken value is invalid.', + 'class' => 'InvalidNextTokenException', + ), + ), + ), + 'DescribeScalingActivities' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ActivitiesType', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeScalingActivities', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'ActivityIds' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'ActivityIds.member', + 'items' => array( + 'name' => 'XmlString', + 'type' => 'string', + ), + ), + 'AutoScalingGroupName' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + 'MaxRecords' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The NextToken value is invalid.', + 'class' => 'InvalidNextTokenException', + ), + ), + ), + 'DescribeScalingProcessTypes' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ProcessesType', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeScalingProcessTypes', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + ), + ), + 'DescribeScheduledActions' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ScheduledActionsType', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeScheduledActions', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'AutoScalingGroupName' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + 'ScheduledActionNames' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'ScheduledActionNames.member', + 'items' => array( + 'name' => 'ResourceName', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 1600, + ), + ), + 'StartTime' => array( + 'type' => array( + 'object', + 'string', + 'integer', + ), + 'format' => 'date-time', + 'location' => 'aws.query', + ), + 'EndTime' => array( + 'type' => array( + 'object', + 'string', + 'integer', + ), + 'format' => 'date-time', + 'location' => 'aws.query', + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MaxRecords' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The NextToken value is invalid.', + 'class' => 'InvalidNextTokenException', + ), + ), + ), + 'DescribeTags' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'TagsType', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeTags', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'Filters' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Filters.member', + 'items' => array( + 'name' => 'Filter', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + 'Values' => array( + 'type' => 'array', + 'sentAs' => 'Values.member', + 'items' => array( + 'name' => 'XmlString', + 'type' => 'string', + ), + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MaxRecords' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The NextToken value is invalid.', + 'class' => 'InvalidNextTokenException', + ), + ), + ), + 'DescribeTerminationPolicyTypes' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DescribeTerminationPolicyTypesAnswer', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeTerminationPolicyTypes', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + ), + ), + 'DisableMetricsCollection' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DisableMetricsCollection', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'AutoScalingGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + 'Metrics' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Metrics.member', + 'items' => array( + 'name' => 'XmlStringMaxLen255', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + ), + ), + ), + 'EnableMetricsCollection' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'EnableMetricsCollection', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'AutoScalingGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + 'Metrics' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Metrics.member', + 'items' => array( + 'name' => 'XmlStringMaxLen255', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + ), + 'Granularity' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 255, + ), + ), + ), + 'ExecutePolicy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ExecutePolicy', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'AutoScalingGroupName' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + 'PolicyName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + 'HonorCooldown' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'You cannot delete an Auto Scaling group while there are scaling activities in progress for that group.', + 'class' => 'ScalingActivityInProgressException', + ), + ), + ), + 'PutNotificationConfiguration' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'PutNotificationConfiguration', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'AutoScalingGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + 'TopicARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + 'NotificationTypes' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'NotificationTypes.member', + 'items' => array( + 'name' => 'XmlStringMaxLen255', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The quota for capacity groups or launch configurations for this customer has already been reached.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'PutScalingPolicy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'PolicyARNType', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'PutScalingPolicy', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'AutoScalingGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + 'PolicyName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'ScalingAdjustment' => array( + 'required' => true, + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'AdjustmentType' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'Cooldown' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'MinAdjustmentStep' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The quota for capacity groups or launch configurations for this customer has already been reached.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'PutScheduledUpdateGroupAction' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'PutScheduledUpdateGroupAction', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'AutoScalingGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + 'ScheduledActionName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'Time' => array( + 'type' => array( + 'object', + 'string', + 'integer', + ), + 'format' => 'date-time', + 'location' => 'aws.query', + ), + 'StartTime' => array( + 'type' => array( + 'object', + 'string', + 'integer', + ), + 'format' => 'date-time', + 'location' => 'aws.query', + ), + 'EndTime' => array( + 'type' => array( + 'object', + 'string', + 'integer', + ), + 'format' => 'date-time', + 'location' => 'aws.query', + ), + 'Recurrence' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'MinSize' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'MaxSize' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'DesiredCapacity' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The named Auto Scaling group or launch configuration already exists.', + 'class' => 'AlreadyExistsException', + ), + array( + 'reason' => 'The quota for capacity groups or launch configurations for this customer has already been reached.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'ResumeProcesses' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ResumeProcesses', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'AutoScalingGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + 'ScalingProcesses' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'ScalingProcesses.member', + 'items' => array( + 'name' => 'XmlStringMaxLen255', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + ), + ), + ), + 'SetDesiredCapacity' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'SetDesiredCapacity', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'AutoScalingGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + 'DesiredCapacity' => array( + 'required' => true, + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'HonorCooldown' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'You cannot delete an Auto Scaling group while there are scaling activities in progress for that group.', + 'class' => 'ScalingActivityInProgressException', + ), + ), + ), + 'SetInstanceHealth' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'SetInstanceHealth', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'InstanceId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 16, + ), + 'HealthStatus' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 32, + ), + 'ShouldRespectGracePeriod' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + ), + ), + 'SuspendProcesses' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'SuspendProcesses', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'AutoScalingGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + 'ScalingProcesses' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'ScalingProcesses.member', + 'items' => array( + 'name' => 'XmlStringMaxLen255', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + ), + ), + ), + 'TerminateInstanceInAutoScalingGroup' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ActivityType', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'TerminateInstanceInAutoScalingGroup', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'InstanceId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 16, + ), + 'ShouldDecrementDesiredCapacity' => array( + 'required' => true, + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'You cannot delete an Auto Scaling group while there are scaling activities in progress for that group.', + 'class' => 'ScalingActivityInProgressException', + ), + ), + ), + 'UpdateAutoScalingGroup' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'UpdateAutoScalingGroup', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2011-01-01', + ), + 'AutoScalingGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + 'LaunchConfigurationName' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1600, + ), + 'MinSize' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'MaxSize' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'DesiredCapacity' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'DefaultCooldown' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'AvailabilityZones' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'AvailabilityZones.member', + 'minItems' => 1, + 'items' => array( + 'name' => 'XmlStringMaxLen255', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + ), + 'HealthCheckType' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 32, + ), + 'HealthCheckGracePeriod' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'PlacementGroup' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'VPCZoneIdentifier' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'TerminationPolicies' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'TerminationPolicies.member', + 'items' => array( + 'name' => 'XmlStringMaxLen1600', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 1600, + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'You cannot delete an Auto Scaling group while there are scaling activities in progress for that group.', + 'class' => 'ScalingActivityInProgressException', + ), + ), + ), + ), + 'models' => array( + 'EmptyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + ), + 'DescribeAccountLimitsAnswer' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'MaxNumberOfAutoScalingGroups' => array( + 'type' => 'numeric', + 'location' => 'xml', + ), + 'MaxNumberOfLaunchConfigurations' => array( + 'type' => 'numeric', + 'location' => 'xml', + ), + ), + ), + 'DescribeAdjustmentTypesAnswer' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'AdjustmentTypes' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'AdjustmentType', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'AdjustmentType' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'AutoScalingGroupsType' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'AutoScalingGroups' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'AutoScalingGroup', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'AutoScalingGroupName' => array( + 'type' => 'string', + ), + 'AutoScalingGroupARN' => array( + 'type' => 'string', + ), + 'LaunchConfigurationName' => array( + 'type' => 'string', + ), + 'MinSize' => array( + 'type' => 'numeric', + ), + 'MaxSize' => array( + 'type' => 'numeric', + ), + 'DesiredCapacity' => array( + 'type' => 'numeric', + ), + 'DefaultCooldown' => array( + 'type' => 'numeric', + ), + 'AvailabilityZones' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'XmlStringMaxLen255', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + 'LoadBalancerNames' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'XmlStringMaxLen255', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + 'HealthCheckType' => array( + 'type' => 'string', + ), + 'HealthCheckGracePeriod' => array( + 'type' => 'numeric', + ), + 'Instances' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Instance', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'InstanceId' => array( + 'type' => 'string', + ), + 'AvailabilityZone' => array( + 'type' => 'string', + ), + 'LifecycleState' => array( + 'type' => 'string', + ), + 'HealthStatus' => array( + 'type' => 'string', + ), + 'LaunchConfigurationName' => array( + 'type' => 'string', + ), + ), + ), + ), + 'CreatedTime' => array( + 'type' => 'string', + ), + 'SuspendedProcesses' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'SuspendedProcess', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'ProcessName' => array( + 'type' => 'string', + ), + 'SuspensionReason' => array( + 'type' => 'string', + ), + ), + ), + ), + 'PlacementGroup' => array( + 'type' => 'string', + ), + 'VPCZoneIdentifier' => array( + 'type' => 'string', + ), + 'EnabledMetrics' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'EnabledMetric', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Metric' => array( + 'type' => 'string', + ), + 'Granularity' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Status' => array( + 'type' => 'string', + ), + 'Tags' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'TagDescription', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'ResourceId' => array( + 'type' => 'string', + ), + 'ResourceType' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + 'PropagateAtLaunch' => array( + 'type' => 'boolean', + ), + ), + ), + ), + 'TerminationPolicies' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'XmlStringMaxLen1600', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'AutoScalingInstancesType' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'AutoScalingInstances' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'AutoScalingInstanceDetails', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'InstanceId' => array( + 'type' => 'string', + ), + 'AutoScalingGroupName' => array( + 'type' => 'string', + ), + 'AvailabilityZone' => array( + 'type' => 'string', + ), + 'LifecycleState' => array( + 'type' => 'string', + ), + 'HealthStatus' => array( + 'type' => 'string', + ), + 'LaunchConfigurationName' => array( + 'type' => 'string', + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'DescribeAutoScalingNotificationTypesAnswer' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'AutoScalingNotificationTypes' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'XmlStringMaxLen255', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + ), + ), + 'LaunchConfigurationsType' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'LaunchConfigurations' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'LaunchConfiguration', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'LaunchConfigurationName' => array( + 'type' => 'string', + ), + 'LaunchConfigurationARN' => array( + 'type' => 'string', + ), + 'ImageId' => array( + 'type' => 'string', + ), + 'KeyName' => array( + 'type' => 'string', + ), + 'SecurityGroups' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'XmlString', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + 'UserData' => array( + 'type' => 'string', + ), + 'InstanceType' => array( + 'type' => 'string', + ), + 'KernelId' => array( + 'type' => 'string', + ), + 'RamdiskId' => array( + 'type' => 'string', + ), + 'BlockDeviceMappings' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BlockDeviceMapping', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'VirtualName' => array( + 'type' => 'string', + ), + 'DeviceName' => array( + 'type' => 'string', + ), + 'Ebs' => array( + 'type' => 'object', + 'properties' => array( + 'SnapshotId' => array( + 'type' => 'string', + ), + 'VolumeSize' => array( + 'type' => 'numeric', + ), + 'VolumeType' => array( + 'type' => 'string', + ), + 'DeleteOnTermination' => array( + 'type' => 'boolean', + ), + 'Iops' => array( + 'type' => 'numeric', + ), + ), + ), + 'NoDevice' => array( + 'type' => 'boolean', + ), + ), + ), + ), + 'InstanceMonitoring' => array( + 'type' => 'object', + 'properties' => array( + 'Enabled' => array( + 'type' => 'boolean', + ), + ), + ), + 'SpotPrice' => array( + 'type' => 'string', + ), + 'IamInstanceProfile' => array( + 'type' => 'string', + ), + 'CreatedTime' => array( + 'type' => 'string', + ), + 'EbsOptimized' => array( + 'type' => 'boolean', + ), + 'AssociatePublicIpAddress' => array( + 'type' => 'boolean', + ), + 'PlacementTenancy' => array( + 'type' => 'string', + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'DescribeMetricCollectionTypesAnswer' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Metrics' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'MetricCollectionType', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Metric' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Granularities' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'MetricGranularityType', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Granularity' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'DescribeNotificationConfigurationsAnswer' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'NotificationConfigurations' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'NotificationConfiguration', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'AutoScalingGroupName' => array( + 'type' => 'string', + ), + 'TopicARN' => array( + 'type' => 'string', + ), + 'NotificationType' => array( + 'type' => 'string', + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'PoliciesType' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ScalingPolicies' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'ScalingPolicy', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'AutoScalingGroupName' => array( + 'type' => 'string', + ), + 'PolicyName' => array( + 'type' => 'string', + ), + 'ScalingAdjustment' => array( + 'type' => 'numeric', + ), + 'AdjustmentType' => array( + 'type' => 'string', + ), + 'Cooldown' => array( + 'type' => 'numeric', + ), + 'PolicyARN' => array( + 'type' => 'string', + ), + 'Alarms' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Alarm', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'AlarmName' => array( + 'type' => 'string', + ), + 'AlarmARN' => array( + 'type' => 'string', + ), + ), + ), + ), + 'MinAdjustmentStep' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'ActivitiesType' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Activities' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'Activity', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'ActivityId' => array( + 'type' => 'string', + ), + 'AutoScalingGroupName' => array( + 'type' => 'string', + ), + 'Description' => array( + 'type' => 'string', + ), + 'Cause' => array( + 'type' => 'string', + ), + 'StartTime' => array( + 'type' => 'string', + ), + 'EndTime' => array( + 'type' => 'string', + ), + 'StatusCode' => array( + 'type' => 'string', + ), + 'StatusMessage' => array( + 'type' => 'string', + ), + 'Progress' => array( + 'type' => 'numeric', + ), + 'Details' => array( + 'type' => 'string', + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'ProcessesType' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Processes' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'ProcessType', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'ProcessName' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'ScheduledActionsType' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ScheduledUpdateGroupActions' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'ScheduledUpdateGroupAction', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'AutoScalingGroupName' => array( + 'type' => 'string', + ), + 'ScheduledActionName' => array( + 'type' => 'string', + ), + 'ScheduledActionARN' => array( + 'type' => 'string', + ), + 'Time' => array( + 'type' => 'string', + ), + 'StartTime' => array( + 'type' => 'string', + ), + 'EndTime' => array( + 'type' => 'string', + ), + 'Recurrence' => array( + 'type' => 'string', + ), + 'MinSize' => array( + 'type' => 'numeric', + ), + 'MaxSize' => array( + 'type' => 'numeric', + ), + 'DesiredCapacity' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'TagsType' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Tags' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'TagDescription', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'ResourceId' => array( + 'type' => 'string', + ), + 'ResourceType' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + 'PropagateAtLaunch' => array( + 'type' => 'boolean', + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'DescribeTerminationPolicyTypesAnswer' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'TerminationPolicyTypes' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'XmlStringMaxLen1600', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + ), + ), + 'PolicyARNType' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'PolicyARN' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'ActivityType' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Activity' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'ActivityId' => array( + 'type' => 'string', + ), + 'AutoScalingGroupName' => array( + 'type' => 'string', + ), + 'Description' => array( + 'type' => 'string', + ), + 'Cause' => array( + 'type' => 'string', + ), + 'StartTime' => array( + 'type' => 'string', + ), + 'EndTime' => array( + 'type' => 'string', + ), + 'StatusCode' => array( + 'type' => 'string', + ), + 'StatusMessage' => array( + 'type' => 'string', + ), + 'Progress' => array( + 'type' => 'numeric', + ), + 'Details' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'iterators' => array( + '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-sdk-php/src/Aws/CloudFormation/CloudFormationClient.php b/vendor/aws/aws-sdk-php/src/Aws/CloudFormation/CloudFormationClient.php new file mode 100644 index 0000000..899f99e --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/CloudFormation/CloudFormationClient.php @@ -0,0 +1,75 @@ +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-sdk-php/src/Aws/CloudFormation/Enum/Capability.php b/vendor/aws/aws-sdk-php/src/Aws/CloudFormation/Enum/Capability.php new file mode 100644 index 0000000..a89a4d8 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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', + ), + ), + ), + 'ListStackResources' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListStackResourcesOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListStackResources', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-15', + ), + 'StackName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1024, + ), + ), + ), + 'ListStacks' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListStacksOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListStacks', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-15', + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1024, + ), + 'StackStatusFilter' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'StackStatusFilter.member', + 'items' => array( + 'name' => 'StackStatus', + 'type' => 'string', + ), + ), + ), + ), + 'SetStackPolicy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'SetStackPolicy', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-15', + ), + 'StackName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'StackPolicyBody' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 16384, + ), + 'StackPolicyURL' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1350, + ), + ), + ), + 'UpdateStack' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'UpdateStackOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'UpdateStack', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-15', + ), + 'StackName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TemplateBody' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + ), + 'TemplateURL' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 1024, + ), + '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', + ), + ), + ), + '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-sdk-php/src/Aws/CloudFront/CloudFrontClient.php b/vendor/aws/aws-sdk-php/src/Aws/CloudFront/CloudFrontClient.php new file mode 100644 index 0000000..50fbbd0 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/CloudFront/CloudFrontClient.php @@ -0,0 +1,229 @@ +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'], '/') + . (isset($parts['query']) ? "?{$parts['query']}" : ''); + } else { + throw new InvalidArgumentException("Invalid URI scheme: {$scheme}. Must be one of http or rtmp."); + } + + return sprintf( + '{"Statement":[{"Resource":"%s","Condition":{"DateLessThan":{"AWS:EpochTime":%d}}}]}', + $resource, + $expires + ); + } +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/CloudFront/CloudFrontSignature.php b/vendor/aws/aws-sdk-php/src/Aws/CloudFront/CloudFrontSignature.php new file mode 100644 index 0000000..dcc6482 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/CloudFront/Enum/GeoRestrictionType.php b/vendor/aws/aws-sdk-php/src/Aws/CloudFront/Enum/GeoRestrictionType.php new file mode 100644 index 0000000..a9c3361 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/CloudFront/Resources/cloudfront-2014-01-31.php b/vendor/aws/aws-sdk-php/src/Aws/CloudFront/Resources/cloudfront-2014-01-31.php new file mode 100644 index 0000000..319ae30 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/CloudFront/Resources/cloudfront-2014-01-31.php @@ -0,0 +1,5246 @@ + '2014-01-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-01-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-01-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-01-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-01-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', + ), + ), + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + ), + ), + '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( + '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-01-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-01-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-01-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-01-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-01-31/origin-access-identity/cloudfront/{Id}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'DeleteCloudFrontOriginAccessIdentity2014_01_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-01-31/distribution/{Id}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'DeleteDistribution2014_01_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-01-31/streaming-distribution/{Id}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'DeleteStreamingDistribution2014_01_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-01-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-01-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-01-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-01-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-01-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-01-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-01-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-01-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-01-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-01-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-01-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-01-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-01-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-01-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-01-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', + ), + ), + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + ), + ), + '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( + '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-01-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-01-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', + ), + ), + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + ), + ), + '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_01_31Output' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'DeleteDistribution2014_01_31Output' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'DeleteStreamingDistribution2014_01_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', + ), + ), + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + ), + ), + '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-sdk-php/src/Aws/CloudSearch/CloudSearchClient.php b/vendor/aws/aws-sdk-php/src/Aws/CloudSearch/CloudSearchClient.php new file mode 100644 index 0000000..2c6129e --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/CloudSearch/CloudSearchClient.php @@ -0,0 +1,84 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/cloudsearch-%s.php' + )) + ->build(); + } +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/CloudSearch/Enum/IndexFieldType.php b/vendor/aws/aws-sdk-php/src/Aws/CloudSearch/Enum/IndexFieldType.php new file mode 100644 index 0000000..048b6e1 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/CloudSearch/Resources/cloudsearch-2013-01-01.php b/vendor/aws/aws-sdk-php/src/Aws/CloudSearch/Resources/cloudsearch-2013-01-01.php new file mode 100644 index 0000000..c58b935 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/CloudSearch/Resources/cloudsearch-2013-01-01.php @@ -0,0 +1,3452 @@ + '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', + ), + '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' => 'FieldName', + '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' => 'FieldName', + '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' => 'FieldName', + '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' => 'FieldName', + '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', + ), + ), + ), + ), + ), + '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', + ), + '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', + ), + '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', + ), + ), + ), + ), + ), + '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', + ), + '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', + ), + ), + ), + ), + ), + ), + '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-sdk-php/src/Aws/CloudTrail/CloudTrailClient.php b/vendor/aws/aws-sdk-php/src/Aws/CloudTrail/CloudTrailClient.php new file mode 100644 index 0000000..918a190 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/CloudTrail/CloudTrailClient.php @@ -0,0 +1,64 @@ +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-sdk-php/src/Aws/CloudTrail/Exception/CloudTrailException.php b/vendor/aws/aws-sdk-php/src/Aws/CloudTrail/Exception/CloudTrailException.php new file mode 100644 index 0000000..e197599 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/CloudTrail/LogFileReader.php b/vendor/aws/aws-sdk-php/src/Aws/CloudTrail/LogFileReader.php new file mode 100644 index 0000000..de5173f --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/CloudTrail/LogRecordIterator.php b/vendor/aws/aws-sdk-php/src/Aws/CloudTrail/LogRecordIterator.php new file mode 100644 index 0000000..d66cf59 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/CloudTrail/Resources/cloudtrail-2013-11-01.php b/vendor/aws/aws-sdk-php/src/Aws/CloudTrail/Resources/cloudtrail-2013-11-01.php new file mode 100644 index 0000000..b67102b --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/CloudTrail/Resources/cloudtrail-2013-11-01.php @@ -0,0 +1,530 @@ + '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-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', + ), + ), + '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', + ), + ), + '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', + ), + ), + ), + 'DeleteTrail' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'com.amazonaws.cloudtrail.v20131101.CloudTrail_20131101.DeleteTrail', + ), + 'Name' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'This exception is thrown when the trail with the given name is not found.', + 'class' => 'TrailNotFoundException', + ), + array( + 'reason' => 'This exception is thrown when the provided trail name is not valid.', + 'class' => 'InvalidTrailNameException', + ), + ), + ), + 'DescribeTrails' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeTrailsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'com.amazonaws.cloudtrail.v20131101.CloudTrail_20131101.DescribeTrails', + ), + 'trailNameList' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + ), + ), + 'GetTrailStatus' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GetTrailStatusResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'com.amazonaws.cloudtrail.v20131101.CloudTrail_20131101.GetTrailStatus', + ), + 'Name' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'This exception is thrown when the trail with the given name is not found.', + 'class' => 'TrailNotFoundException', + ), + array( + 'reason' => 'This exception is thrown when the provided trail name is not valid.', + 'class' => 'InvalidTrailNameException', + ), + ), + ), + 'StartLogging' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'com.amazonaws.cloudtrail.v20131101.CloudTrail_20131101.StartLogging', + ), + 'Name' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'This exception is thrown when the trail with the given name is not found.', + 'class' => 'TrailNotFoundException', + ), + array( + 'reason' => 'This exception is thrown when the provided trail name is not valid.', + 'class' => 'InvalidTrailNameException', + ), + ), + ), + 'StopLogging' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'com.amazonaws.cloudtrail.v20131101.CloudTrail_20131101.StopLogging', + ), + 'Name' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'This exception is thrown when the trail with the given name is not found.', + 'class' => 'TrailNotFoundException', + ), + array( + 'reason' => 'This exception is thrown when the provided trail name is not valid.', + 'class' => 'InvalidTrailNameException', + ), + ), + ), + 'UpdateTrail' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'UpdateTrailResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'com.amazonaws.cloudtrail.v20131101.CloudTrail_20131101.UpdateTrail', + ), + 'Name' => array( + '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', + ), + ), + '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', + ), + ), + ), + ), + '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', + ), + ), + ), + 'EmptyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + ), + 'DescribeTrailsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'trailList' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Trail', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + 'S3BucketName' => array( + 'type' => 'string', + ), + 'S3KeyPrefix' => array( + 'type' => 'string', + ), + 'SnsTopicName' => array( + 'type' => 'string', + ), + 'IncludeGlobalServiceEvents' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + ), + 'GetTrailStatusResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'IsLogging' => array( + 'type' => 'boolean', + 'location' => 'json', + ), + 'LatestDeliveryError' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'LatestNotificationError' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'LatestDeliveryTime' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'LatestNotificationTime' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'StartLoggingTime' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'StopLoggingTime' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + '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', + ), + ), + ), + ), + 'iterators' => array( + 'DescribeTrails' => array( + 'result_key' => 'trailList', + ), + ), +); diff --git a/vendor/aws/aws-sdk-php/src/Aws/CloudWatch/CloudWatchClient.php b/vendor/aws/aws-sdk-php/src/Aws/CloudWatch/CloudWatchClient.php new file mode 100644 index 0000000..9e19e8b --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/CloudWatch/Enum/ComparisonOperator.php b/vendor/aws/aws-sdk-php/src/Aws/CloudWatch/Enum/ComparisonOperator.php new file mode 100644 index 0000000..61dc947 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Aws.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Aws.php new file mode 100644 index 0000000..11a0df4 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/Common/Aws.php @@ -0,0 +1,105 @@ +addAlias('_aws', self::getDefaultServiceDefinition()) + ->addAlias('_sdk1', __DIR__ . '/Resources/sdk1-config.php'); + + return $loader->load($config, $globalParameters); + } + + /** + * Get the full path to the default service builder definition file + * + * @return string + */ + public static function getDefaultServiceDefinition() + { + return __DIR__ . '/Resources/aws-config.php'; + } + + /** + * Returns the configuration for the service builder + * + * @return array + */ + public function getConfig() + { + return $this->builderConfig; + } + + /** + * Enables the facades for the clients defined in the service builder + * + * @param string|null $namespace The namespace that the facades should be mounted to. Defaults to global namespace + * + * @return Aws + */ + public function enableFacades($namespace = null) + { + Facade::mountFacades($this, $namespace); + + return $this; + } +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/Common/Client/AbstractClient.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Client/AbstractClient.php new file mode 100644 index 0000000..8f41703 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/Common/Client/AbstractClient.php @@ -0,0 +1,294 @@ +get(Options::BASE_URL), $config); + $this->credentials = $credentials; + $this->signature = $signature; + + // Make sure the user agent is prefixed by the SDK version + $this->setUserAgent('aws-sdk-php2/' . Aws::VERSION, true); + + // Add the event listener so that requests are signed before they are sent + $dispatcher = $this->getEventDispatcher(); + $dispatcher->addSubscriber(new SignatureListener($credentials, $signature)); + + if ($backoff = $config->get(Options::BACKOFF)) { + $dispatcher->addSubscriber($backoff, -255); + } + } + + public function __call($method, $args) + { + if (substr($method, 0, 3) === 'get' && substr($method, -8) === 'Iterator') { + // Allow magic method calls for iterators (e.g. $client->getIterator($params)) + $commandOptions = isset($args[0]) ? $args[0] : null; + $iteratorOptions = isset($args[1]) ? $args[1] : array(); + return $this->getIterator(substr($method, 3, -8), $commandOptions, $iteratorOptions); + } elseif (substr($method, 0, 9) == 'waitUntil') { + // Allow magic method calls for waiters (e.g. $client->waitUntil($params)) + return $this->waitUntil(substr($method, 9), isset($args[0]) ? $args[0]: array()); + } else { + return parent::__call(ucfirst($method), $args); + } + } + + /** + * Get an endpoint for a specific region from a service description + * + * @param ServiceDescriptionInterface $description Service description + * @param string $region Region of the endpoint + * @param string $scheme URL scheme + * + * @return string + * @throws InvalidArgumentException + */ + public static function getEndpoint(ServiceDescriptionInterface $description, $region, $scheme) + { + $service = $description->getData('serviceFullName'); + // Lookup the region in the service description + if (!($regions = $description->getData('regions'))) { + throw new InvalidArgumentException("No regions found in the {$service} description"); + } + // Ensure that the region exists for the service + if (!isset($regions[$region])) { + throw new InvalidArgumentException("{$region} is not a valid region for {$service}"); + } + // Ensure that the scheme is valid + if ($regions[$region][$scheme] == false) { + throw new InvalidArgumentException("{$scheme} is not a valid URI scheme for {$service} in {$region}"); + } + + return $scheme . '://' . $regions[$region]['hostname']; + } + + /** + * {@inheritdoc} + */ + public function getCredentials() + { + return $this->credentials; + } + + /** + * {@inheritdoc} + */ + public function setCredentials(CredentialsInterface $credentials) + { + $formerCredentials = $this->credentials; + $this->credentials = $credentials; + + // Dispatch an event that the credentials have been changed + $this->dispatch('client.credentials_changed', array( + 'credentials' => $credentials, + 'former_credentials' => $formerCredentials, + )); + + return $this; + } + + /** + * {@inheritdoc} + */ + public function getSignature() + { + return $this->signature; + } + + /** + * {@inheritdoc} + */ + public function getRegions() + { + return $this->serviceDescription->getData('regions'); + } + + /** + * {@inheritdoc} + */ + public function getRegion() + { + return $this->getConfig(Options::REGION); + } + + /** + * {@inheritdoc} + */ + public function setRegion($region) + { + $config = $this->getConfig(); + $formerRegion = $config->get(Options::REGION); + $global = $this->serviceDescription->getData('globalEndpoint'); + + // Only change the region if the service does not have a global endpoint + if (!$global || $this->serviceDescription->getData('namespace') === 'S3') { + $baseUrl = self::getEndpoint($this->serviceDescription, $region, $config->get(Options::SCHEME)); + $this->setBaseUrl($baseUrl); + $config->set(Options::BASE_URL, $baseUrl)->set(Options::REGION, $region); + + // Update the signature if necessary + $signature = $this->getSignature(); + if ($signature instanceof EndpointSignatureInterface) { + /** @var $signature EndpointSignatureInterface */ + $signature->setRegionName($region); + } + + // Dispatch an event that the region has been changed + $this->dispatch('client.region_changed', array( + 'region' => $region, + 'former_region' => $formerRegion, + )); + } + + return $this; + } + + /** + * {@inheritdoc} + */ + public function waitUntil($waiter, array $input = array()) + { + $this->getWaiter($waiter, $input)->wait(); + + return $this; + } + + /** + * {@inheritdoc} + */ + public function getWaiter($waiter, array $input = array()) + { + return $this->getWaiterFactory()->build($waiter) + ->setClient($this) + ->setConfig($input); + } + + /** + * {@inheritdoc} + */ + public function setWaiterFactory(WaiterFactoryInterface $waiterFactory) + { + $this->waiterFactory = $waiterFactory; + + return $this; + } + + /** + * {@inheritdoc} + */ + public function getWaiterFactory() + { + if (!$this->waiterFactory) { + $clientClass = get_class($this); + // Use a composite factory that checks for classes first, then config waiters + $this->waiterFactory = new CompositeWaiterFactory(array( + new WaiterClassFactory(substr($clientClass, 0, strrpos($clientClass, '\\')) . '\\Waiter') + )); + if ($this->getDescription()) { + $waiterConfig = $this->getDescription()->getData('waiters') ?: array(); + $this->waiterFactory->addFactory(new WaiterConfigFactory($waiterConfig)); + } + } + + return $this->waiterFactory; + } + + /** + * {@inheritdoc} + */ + public function getApiVersion() + { + return $this->serviceDescription->getApiVersion(); + } + + /** + * {@inheritdoc} + * @throws \Aws\Common\Exception\TransferException + */ + public function send($requests) + { + try { + return parent::send($requests); + } catch (CurlException $e) { + $wrapped = new TransferException($e->getMessage(), null, $e); + $wrapped->setCurlHandle($e->getCurlHandle()) + ->setCurlInfo($e->getCurlInfo()) + ->setError($e->getError(), $e->getErrorNo()) + ->setRequest($e->getRequest()); + throw $wrapped; + } + } +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/Common/Client/AwsClientInterface.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Client/AwsClientInterface.php new file mode 100644 index 0000000..4c0579f --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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(); + + /** + * Factory method for creating the client builder + * + * @param string $namespace The namespace of the client + * + * @return ClientBuilder + */ + public static function factory($namespace = null) + { + return new static($namespace); + } + + /** + * Constructs a client builder + * + * @param string $namespace The namespace of the client + */ + public function __construct($namespace = null) + { + $this->clientNamespace = $namespace; + } + + /** + * Sets the config options + * + * @param array|Collection $config The config options + * + * @return ClientBuilder + */ + public function setConfig($config) + { + $this->config = $this->processArray($config); + + return $this; + } + + /** + * Sets the config options' defaults + * + * @param array|Collection $defaults The default values + * + * @return ClientBuilder + */ + public function setConfigDefaults($defaults) + { + $this->configDefaults = $this->processArray($defaults); + + return $this; + } + + /** + * Sets the required config options + * + * @param array|Collection $required The required config options + * + * @return ClientBuilder + */ + public function setConfigRequirements($required) + { + $this->configRequirements = $this->processArray($required); + + return $this; + } + + /** + * Sets the exception parser. If one is not provided the builder will use + * the default XML exception parser. + * + * @param ExceptionParserInterface $parser The exception parser + * + * @return ClientBuilder + */ + public function setExceptionParser(ExceptionParserInterface $parser) + { + $this->exceptionParser = $parser; + + return $this; + } + + /** + * Set the configuration for the client's iterators + * + * @param array $config Configuration data for client's iterators + * + * @return ClientBuilder + */ + public function setIteratorsConfig(array $config) + { + $this->iteratorsConfig = $config; + + return $this; + } + + /** + * Performs the building logic using all of the parameters that have been + * set and falling back to default values. Returns an instantiate service + * client with credentials prepared and plugins attached. + * + * @return AwsClientInterface + * @throws InvalidArgumentException + */ + public function build() + { + // Resolve configuration + $config = Collection::fromConfig( + $this->config, + array_merge(self::$commonConfigDefaults, $this->configDefaults), + (self::$commonConfigRequirements + $this->configRequirements) + ); + + // Resolve endpoint and signature from the config and service description + $description = $this->updateConfigFromDescription($config); + $signature = $this->getSignature($description, $config); + + // Resolve credentials + if (!$credentials = $config->get('credentials')) { + $credentials = Credentials::factory($config); + } + + // Resolve exception parser + if (!$this->exceptionParser) { + $this->exceptionParser = new DefaultXmlExceptionParser(); + } + + // Resolve backoff strategy + $backoff = $config->get(Options::BACKOFF); + if ($backoff === null) { + $backoff = new BackoffPlugin( + // Retry failed requests up to 3 times if it is determined that the request can be retried + new TruncatedBackoffStrategy(3, + // Retry failed requests with 400-level responses due to throttling + new ThrottlingErrorChecker($this->exceptionParser, + // Retry failed requests with 500-level responses + new HttpBackoffStrategy(array(500, 503, 509), + // Retry failed requests due to transient network or cURL problems + new CurlBackoffStrategy(null, + // Retry requests that failed due to expired credentials + new ExpiredCredentialsChecker($this->exceptionParser, + new ExponentialBackoffStrategy() + ) + ) + ) + ) + ) + ); + $config->set(Options::BACKOFF, $backoff); + } + + if ($backoff) { + $this->addBackoffLogger($backoff, $config); + } + + // Determine service and class name + $clientClass = 'Aws\Common\Client\DefaultClient'; + if ($this->clientNamespace) { + $serviceName = substr($this->clientNamespace, strrpos($this->clientNamespace, '\\') + 1); + $clientClass = $this->clientNamespace . '\\' . $serviceName . 'Client'; + } + + /** @var $client AwsClientInterface */ + $client = new $clientClass($credentials, $signature, $config); + $client->setDescription($description); + + // Add exception marshaling so that more descriptive exception are thrown + if ($this->clientNamespace) { + $exceptionFactory = new NamespaceExceptionFactory( + $this->exceptionParser, + "{$this->clientNamespace}\\Exception", + "{$this->clientNamespace}\\Exception\\{$serviceName}Exception" + ); + $client->addSubscriber(new ExceptionListener($exceptionFactory)); + } + + // Add the UserAgentPlugin to append to the User-Agent header of requests + $client->addSubscriber(new UserAgentListener()); + + // Filters used for the cache plugin + $client->getConfig()->set( + 'params.cache.key_filter', + 'header=date,x-amz-date,x-amz-security-token,x-amzn-authorization' + ); + + // Set the iterator resource factory based on the provided iterators config + $client->setResourceIteratorFactory(new AwsResourceIteratorFactory( + $this->iteratorsConfig, + new ResourceIteratorClassFactory($this->clientNamespace . '\\Iterator') + )); + + // Disable parameter validation if needed + if ($config->get(Options::VALIDATION) === false) { + $params = $config->get('command.params') ?: array(); + $params['command.disable_validation'] = true; + $config->set('command.params', $params); + } + + return $client; + } + + /** + * Add backoff logging to the backoff plugin if needed + * + * @param BackoffPlugin $plugin Backoff plugin + * @param Collection $config Configuration settings + * + * @throws InvalidArgumentException + */ + protected function addBackoffLogger(BackoffPlugin $plugin, Collection $config) + { + // The log option can be set to `debug` or an instance of a LogAdapterInterface + if ($logger = $config->get(Options::BACKOFF_LOGGER)) { + $format = $config->get(Options::BACKOFF_LOGGER_TEMPLATE); + if ($logger === 'debug') { + $logger = new ClosureLogAdapter(function ($message) { + trigger_error($message . "\n"); + }); + } elseif (!($logger instanceof LogAdapterInterface)) { + throw new InvalidArgumentException( + Options::BACKOFF_LOGGER . ' must be set to `debug` or an instance of ' + . 'Guzzle\\Common\\Log\\LogAdapterInterface' + ); + } + // Create the plugin responsible for logging exponential backoff retries + $logPlugin = new BackoffLogger($logger); + // You can specify a custom format or use the default + if ($format) { + $logPlugin->setTemplate($format); + } + $plugin->addSubscriber($logPlugin); + } + } + + /** + * Ensures that an array (e.g. for config data) is actually in array form + * + * @param array|Collection $array The array data + * + * @return array + * @throws InvalidArgumentException if the arg is not an array or Collection + */ + protected function processArray($array) + { + if ($array instanceof Collection) { + $array = $array->getAll(); + } + + if (!is_array($array)) { + throw new InvalidArgumentException('The config must be provided as an array or Collection.'); + } + + return $array; + } + + /** + * Update a configuration object from a service description + * + * @param Collection $config Config to update + * + * @return ServiceDescription + * @throws InvalidArgumentException + */ + protected function updateConfigFromDescription(Collection $config) + { + $description = $config->get(Options::SERVICE_DESCRIPTION); + if (!($description instanceof ServiceDescription)) { + // Inject the version into the sprintf template if it is a string + if (is_string($description)) { + $description = sprintf($description, $config->get(Options::VERSION)); + } + $description = ServiceDescription::factory($description); + $config->set(Options::SERVICE_DESCRIPTION, $description); + } + + if (!$config->get(Options::SERVICE)) { + $config->set(Options::SERVICE, $description->getData('endpointPrefix')); + } + + if ($iterators = $description->getData('iterators')) { + $this->setIteratorsConfig($iterators); + } + + // Ensure that the service description has regions + if (!$description->getData('regions')) { + throw new InvalidArgumentException( + 'No regions found in the ' . $description->getData('serviceFullName'). ' description' + ); + } + + // Make sure a valid region is set + $region = $config->get(Options::REGION); + $global = $description->getData('globalEndpoint'); + if (!$global && !$region) { + throw new InvalidArgumentException( + 'A region is required when using ' . $description->getData('serviceFullName') + . '. Set "region" to one of: ' . implode(', ', array_keys($description->getData('regions'))) + ); + } elseif ($global && (!$region || $description->getData('namespace') !== 'S3')) { + $region = Region::US_EAST_1; + $config->set(Options::REGION, $region); + } + + if (!$config->get(Options::BASE_URL)) { + // Set the base URL using the scheme and hostname of the service's region + $config->set(Options::BASE_URL, AbstractClient::getEndpoint( + $description, + $region, + $config->get(Options::SCHEME) + )); + } + + return $description; + } + + /** + * Return an appropriate signature object for a a client based on the + * "signature" configuration setting, or the default signature specified in + * a service description. The signature can be set to a valid signature + * version identifier string or an instance of Aws\Common\Signature\SignatureInterface. + * + * @param ServiceDescription $description Description that holds a signature option + * @param Collection $config Configuration options + * + * @return SignatureInterface + * @throws InvalidArgumentException + */ + protected function getSignature(ServiceDescription $description, Collection $config) + { + // If a custom signature has not been provided, then use the default + // signature setting specified in the service description. + $signature = $config->get(Options::SIGNATURE) ?: $description->getData('signatureVersion'); + + if (is_string($signature)) { + if ($signature == 'v4') { + $signature = new SignatureV4(); + } elseif ($signature == 'v2') { + $signature = new SignatureV2(); + } elseif ($signature == 'v3https') { + $signature = new SignatureV3Https(); + } else { + throw new InvalidArgumentException("Invalid signature type: {$signature}"); + } + } elseif (!($signature instanceof SignatureInterface)) { + throw new InvalidArgumentException('The provided signature is not ' + . 'a signature version string or an instance of ' + . 'Aws\\Common\\Signature\\SignatureInterface'); + } + + // Allow a custom service name or region value to be provided + if ($signature instanceof EndpointSignatureInterface) { + + // Determine the service name to use when signing + $signature->setServiceName($config->get(Options::SIGNATURE_SERVICE) + ?: $description->getData('signingName') + ?: $description->getData('endpointPrefix')); + + // Determine the region to use when signing requests + $signature->setRegionName($config->get(Options::SIGNATURE_REGION) ?: $config->get(Options::REGION)); + } + + return $signature; + } +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/Common/Client/DefaultClient.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Client/DefaultClient.php new file mode 100644 index 0000000..1dc276d --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/Common/Client/DefaultClient.php @@ -0,0 +1,67 @@ +setConfig($config) + ->setConfigDefaults(array(Options::SCHEME => 'https')) + ->build(); + } +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/Common/Client/ExpiredCredentialsChecker.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Client/ExpiredCredentialsChecker.php new file mode 100644 index 0000000..d20f7f8 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Client/ThrottlingErrorChecker.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Client/ThrottlingErrorChecker.php new file mode 100644 index 0000000..a35cbcb --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Client/UploadBodyListener.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Client/UploadBodyListener.php new file mode 100644 index 0000000..a99d2fa --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Client/UserAgentListener.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Client/UserAgentListener.php new file mode 100644 index 0000000..cc7e312 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Command/AwsQueryVisitor.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Command/AwsQueryVisitor.php new file mode 100644 index 0000000..dceaafa --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Command/JsonCommand.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Command/JsonCommand.php new file mode 100644 index 0000000..15ad593 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Command/QueryCommand.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Command/QueryCommand.php new file mode 100644 index 0000000..63eb8e8 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Command/XmlResponseLocationVisitor.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Command/XmlResponseLocationVisitor.php new file mode 100644 index 0000000..ad229fd --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Credentials/AbstractCredentialsDecorator.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Credentials/AbstractCredentialsDecorator.php new file mode 100644 index 0000000..b3a1df9 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Credentials/AbstractRefreshableCredentials.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Credentials/AbstractRefreshableCredentials.php new file mode 100644 index 0000000..235bf9d --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Credentials/CacheableCredentials.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Credentials/CacheableCredentials.php new file mode 100644 index 0000000..fbebf78 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Credentials/Credentials.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Credentials/Credentials.php new file mode 100644 index 0000000..73b8ffa --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Credentials/CredentialsInterface.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Credentials/CredentialsInterface.php new file mode 100644 index 0000000..dd43037 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Enum.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Enum.php new file mode 100644 index 0000000..7f4d356 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/Common/Enum.php @@ -0,0 +1,55 @@ +getConstants(); + } + + return self::$cache[$class]; + } +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/Common/Enum/ClientOptions.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Enum/ClientOptions.php new file mode 100644 index 0000000..4027cae --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/Common/Enum/ClientOptions.php @@ -0,0 +1,151 @@ +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-sdk-php/src/Aws/Common/Exception/InstanceProfileCredentialsException.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Exception/InstanceProfileCredentialsException.php new file mode 100644 index 0000000..fb1dcf1 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Exception/InvalidArgumentException.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Exception/InvalidArgumentException.php new file mode 100644 index 0000000..4360a00 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Exception/NamespaceExceptionFactory.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Exception/NamespaceExceptionFactory.php new file mode 100644 index 0000000..6489069 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Exception/OutOfBoundsException.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Exception/OutOfBoundsException.php new file mode 100644 index 0000000..6738c0c --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Exception/Parser/DefaultXmlExceptionParser.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Exception/Parser/DefaultXmlExceptionParser.php new file mode 100644 index 0000000..a9fda69 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Exception/Parser/ExceptionParserInterface.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Exception/Parser/ExceptionParserInterface.php new file mode 100644 index 0000000..1b25d96 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Exception/RequiredExtensionNotLoadedException.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Exception/RequiredExtensionNotLoadedException.php new file mode 100644 index 0000000..c4a072c --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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; + } +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/Common/Exception/TransferException.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Exception/TransferException.php new file mode 100644 index 0000000..47aa80d --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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)) { + // @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-sdk-php/src/Aws/Common/Facade/FacadeInterface.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Facade/FacadeInterface.php new file mode 100644 index 0000000..b1325bb --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/Common/Facade/FacadeInterface.php @@ -0,0 +1,32 @@ +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-sdk-php/src/Aws/Common/Hash/ChunkHashInterface.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Hash/ChunkHashInterface.php new file mode 100644 index 0000000..5fcf9a5 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/HostNameUtils.php b/vendor/aws/aws-sdk-php/src/Aws/Common/HostNameUtils.php new file mode 100644 index 0000000..4b791aa --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/InstanceMetadata/InstanceMetadataClient.php b/vendor/aws/aws-sdk-php/src/Aws/Common/InstanceMetadata/InstanceMetadataClient.php new file mode 100644 index 0000000..229be15 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/InstanceMetadata/Waiter/ServiceAvailable.php b/vendor/aws/aws-sdk-php/src/Aws/Common/InstanceMetadata/Waiter/ServiceAvailable.php new file mode 100644 index 0000000..ac305c3 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Iterator/AwsResourceIterator.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Iterator/AwsResourceIterator.php new file mode 100644 index 0000000..cdd8119 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Iterator/AwsResourceIteratorFactory.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Iterator/AwsResourceIteratorFactory.php new file mode 100644 index 0000000..ce668a2 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Model/MultipartUpload/AbstractTransfer.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Model/MultipartUpload/AbstractTransfer.php new file mode 100644 index 0000000..751b558 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Model/MultipartUpload/AbstractTransferState.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Model/MultipartUpload/AbstractTransferState.php new file mode 100644 index 0000000..06d6c84 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Model/MultipartUpload/AbstractUploadBuilder.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Model/MultipartUpload/AbstractUploadBuilder.php new file mode 100644 index 0000000..a1ad678 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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 self + */ + public function resumeFrom($state) + { + $this->state = $state; + + return $this; + } + + /** + * Set the data source of the transfer + * + * @param resource|string|EntityBody $source Source of the transfer. Pass a string to transfer from a file on disk. + * You can also stream from a resource returned from fopen or a Guzzle + * {@see EntityBody} object. + * + * @return self + * @throws InvalidArgumentException when the source cannot be found or opened + */ + public function setSource($source) + { + // Use the contents of a file as the data source + if (is_string($source)) { + if (!file_exists($source)) { + throw new InvalidArgumentException("File does not exist: {$source}"); + } + // Clear the cache so that we send accurate file sizes + clearstatcache(true, $source); + $source = fopen($source, 'r'); + } + + $this->source = EntityBody::factory($source); + + if ($this->source->isSeekable() && $this->source->getSize() == 0) { + throw new InvalidArgumentException('Empty body provided to upload builder'); + } + + return $this; + } + + /** + * Specify the headers to set on the upload + * + * @param array $headers Headers to add to the uploaded object + * + * @return self + */ + public function setHeaders(array $headers) + { + $this->headers = $headers; + + return $this; + } + + /** + * Build the appropriate uploader based on the builder options + * + * @return TransferInterface + */ + abstract public function build(); + + /** + * Initiate the multipart upload + * + * @return TransferStateInterface + */ + abstract protected function initiateMultipartUpload(); +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/Common/Model/MultipartUpload/AbstractUploadId.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Model/MultipartUpload/AbstractUploadId.php new file mode 100644 index 0000000..da79521 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Model/MultipartUpload/AbstractUploadPart.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Model/MultipartUpload/AbstractUploadPart.php new file mode 100644 index 0000000..1cf4c6d --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Model/MultipartUpload/TransferInterface.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Model/MultipartUpload/TransferInterface.php new file mode 100644 index 0000000..1fc1ae9 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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' + ) + ), + + 'cloudsearch' => array( + 'alias' => 'CloudSearch', + 'extends' => 'default_settings', + 'class' => 'Aws\CloudSearch\CloudSearchClient' + ), + + 'cloudsearch_20110201' => array( + 'extends' => 'cloudsearch', + 'params' => array( + 'version' => '2011-02-01' + ) + ), + + 'cloudtrail' => array( + 'alias' => 'CloudTrail', + 'extends' => 'default_settings', + 'class' => 'Aws\CloudTrail\CloudTrailClient' + ), + + 'cloudwatch' => array( + 'alias' => 'CloudWatch', + 'extends' => 'default_settings', + 'class' => 'Aws\CloudWatch\CloudWatchClient' + ), + + 'datapipeline' => array( + 'alias' => 'DataPipeline', + 'extends' => 'default_settings', + 'class' => 'Aws\DataPipeline\DataPipelineClient' + ), + + 'directconnect' => array( + 'alias' => 'DirectConnect', + 'extends' => 'default_settings', + 'class' => 'Aws\DirectConnect\DirectConnectClient' + ), + + 'dynamodb' => array( + 'alias' => 'DynamoDb', + 'extends' => 'default_settings', + 'class' => 'Aws\DynamoDb\DynamoDbClient' + ), + + 'dynamodb_20111205' => array( + 'extends' => 'dynamodb', + 'params' => array( + 'version' => '2011-12-05' + ) + ), + + 'ec2' => array( + 'alias' => 'Ec2', + 'extends' => 'default_settings', + 'class' => 'Aws\Ec2\Ec2Client' + ), + + 'elasticache' => array( + 'alias' => 'ElastiCache', + 'extends' => 'default_settings', + 'class' => 'Aws\ElastiCache\ElastiCacheClient' + ), + + 'elasticbeanstalk' => array( + 'alias' => 'ElasticBeanstalk', + 'extends' => 'default_settings', + 'class' => 'Aws\ElasticBeanstalk\ElasticBeanstalkClient' + ), + + 'elasticloadbalancing' => array( + 'alias' => 'ElasticLoadBalancing', + 'extends' => 'default_settings', + 'class' => 'Aws\ElasticLoadBalancing\ElasticLoadBalancingClient' + ), + + 'elastictranscoder' => array( + 'alias' => 'ElasticTranscoder', + 'extends' => 'default_settings', + 'class' => 'Aws\ElasticTranscoder\ElasticTranscoderClient' + ), + + 'emr' => array( + 'alias' => 'Emr', + 'extends' => 'default_settings', + 'class' => 'Aws\Emr\EmrClient' + ), + + 'glacier' => array( + 'alias' => 'Glacier', + 'extends' => 'default_settings', + 'class' => 'Aws\Glacier\GlacierClient' + ), + + 'kinesis' => array( + 'alias' => 'Kinesis', + 'extends' => 'default_settings', + 'class' => 'Aws\Kinesis\KinesisClient' + ), + + 'iam' => array( + 'alias' => 'Iam', + 'extends' => 'default_settings', + 'class' => 'Aws\Iam\IamClient' + ), + + 'importexport' => array( + 'alias' => 'ImportExport', + 'extends' => 'default_settings', + 'class' => 'Aws\ImportExport\ImportExportClient' + ), + + 'opsworks' => array( + 'alias' => 'OpsWorks', + 'extends' => 'default_settings', + 'class' => 'Aws\OpsWorks\OpsWorksClient' + ), + + 'rds' => array( + 'alias' => 'Rds', + 'extends' => 'default_settings', + 'class' => 'Aws\Rds\RdsClient' + ), + + 'redshift' => array( + 'alias' => 'Redshift', + 'extends' => 'default_settings', + 'class' => 'Aws\Redshift\RedshiftClient' + ), + + 'route53' => array( + 'alias' => 'Route53', + 'extends' => 'default_settings', + 'class' => 'Aws\Route53\Route53Client' + ), + + 's3' => array( + 'alias' => 'S3', + 'extends' => 'default_settings', + 'class' => 'Aws\S3\S3Client' + ), + + 'sdb' => array( + 'alias' => 'SimpleDb', + 'extends' => 'default_settings', + 'class' => 'Aws\SimpleDb\SimpleDbClient' + ), + + 'ses' => array( + 'alias' => 'Ses', + 'extends' => 'default_settings', + 'class' => 'Aws\Ses\SesClient' + ), + + 'sns' => array( + 'alias' => 'Sns', + 'extends' => 'default_settings', + 'class' => 'Aws\Sns\SnsClient' + ), + + 'sqs' => array( + 'alias' => 'Sqs', + 'extends' => 'default_settings', + 'class' => 'Aws\Sqs\SqsClient' + ), + + 'storagegateway' => array( + 'alias' => 'StorageGateway', + 'extends' => 'default_settings', + 'class' => 'Aws\StorageGateway\StorageGatewayClient' + ), + + 'sts' => array( + 'alias' => 'Sts', + 'extends' => 'default_settings', + 'class' => 'Aws\Sts\StsClient' + ), + + 'support' => array( + 'alias' => 'Support', + 'extends' => 'default_settings', + 'class' => 'Aws\Support\SupportClient' + ), + + 'swf' => array( + 'alias' => 'Swf', + 'extends' => 'default_settings', + 'class' => 'Aws\Swf\SwfClient' + ), + ) +); diff --git a/vendor/aws/aws-sdk-php/src/Aws/Common/Resources/sdk1-config.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Resources/sdk1-config.php new file mode 100644 index 0000000..a5121ab --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Signature/AbstractSignature.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Signature/AbstractSignature.php new file mode 100644 index 0000000..f6875f4 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/Common/Signature/AbstractSignature.php @@ -0,0 +1,41 @@ +credentials = $credentials; + $this->signature = $signature; + } + + /** + * {@inheritdoc} + */ + public static function getSubscribedEvents() + { + return array( + 'request.before_send' => array('onRequestBeforeSend', -255), + 'client.credentials_changed' => array('onCredentialsChanged') + ); + } + + /** + * Updates the listener with new credentials if the client is updated + * + * @param Event $event Event emitted + */ + public function onCredentialsChanged(Event $event) + { + $this->credentials = $event['credentials']; + } + + /** + * Signs requests before they are sent + * + * @param Event $event Event emitted + */ + public function onRequestBeforeSend(Event $event) + { + $this->signature->signRequest($event['request'], $this->credentials); + } +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/Common/Signature/SignatureV2.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Signature/SignatureV2.php new file mode 100644 index 0000000..c900287 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Signature/SignatureV3Https.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Signature/SignatureV3Https.php new file mode 100644 index 0000000..be0514e --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Signature/SignatureV4.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Signature/SignatureV4.php new file mode 100644 index 0000000..2ecf591 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/Common/Signature/SignatureV4.php @@ -0,0 +1,463 @@ +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) { + return hash( + 'sha256', + $request->getMethod() == 'POST' && count($request->getPostFields()) + ? (string) $request->getPostFields() + : (string) $request->getBody() + ); + } + + 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); + } + + 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) + { + // Normalize the path as required by SigV4 and ensure it's absolute + $canon = $request->getMethod() . "\n" + . '/' . ltrim($request->getPath(), '/') . "\n" + . $this->getCanonicalizedQueryString($request) . "\n"; + + // Create the canonical headers + $headers = array(); + foreach ($request->getHeaders()->getAll() as $key => $values) { + $key = strtolower($key); + if ($key != 'user-agent') { + $headers[$key] = array(); + foreach ($values as $value) { + $headers[$key][] = preg_replace('/\s+/', ' ', trim($value)); + } + // Sort the value if there is more than one + if (count($values) > 1) { + sort($headers[$key]); + } + } + } + + // The headers must be sorted + ksort($headers); + + // Continue to build the canonical request by adding headers + foreach ($headers as $key => $values) { + // Combine multi-value headers into a comma separated list + $canon .= $key . ':' . implode(',', $values) . "\n"; + } + + // Create the signed headers + $signedHeaders = implode(';', array_keys($headers)); + $canon .= "\n{$signedHeaders}\n{$payload}"; + + return array( + 'canonical_request' => $canon, + 'signed_headers' => $signedHeaders + ); + } + + /** + * Get 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) { + $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-sdk-php/src/Aws/Common/Waiter/AbstractResourceWaiter.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Waiter/AbstractResourceWaiter.php new file mode 100644 index 0000000..5334848 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Waiter/AbstractWaiter.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Waiter/AbstractWaiter.php new file mode 100644 index 0000000..09dbea1 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Waiter/CallableWaiter.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Waiter/CallableWaiter.php new file mode 100644 index 0000000..a205e06 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Waiter/CompositeWaiterFactory.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Waiter/CompositeWaiterFactory.php new file mode 100644 index 0000000..5278e49 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Waiter/ConfigResourceWaiter.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Waiter/ConfigResourceWaiter.php new file mode 100644 index 0000000..8ef0577 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Waiter/ResourceWaiterInterface.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Waiter/ResourceWaiterInterface.php new file mode 100644 index 0000000..07cf41d --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Waiter/WaiterConfig.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Waiter/WaiterConfig.php new file mode 100644 index 0000000..7c10f5a --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Waiter/WaiterConfigFactory.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Waiter/WaiterConfigFactory.php new file mode 100644 index 0000000..cb92149 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Common/Waiter/WaiterFactoryInterface.php b/vendor/aws/aws-sdk-php/src/Aws/Common/Waiter/WaiterFactoryInterface.php new file mode 100644 index 0000000..b9bf0f4 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/Common/Waiter/WaiterFactoryInterface.php @@ -0,0 +1,41 @@ +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-sdk-php/src/Aws/DataPipeline/Enum/WorkStatus.php b/vendor/aws/aws-sdk-php/src/Aws/DataPipeline/Enum/WorkStatus.php new file mode 100644 index 0000000..70231f5 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', + 'class' => 'PipelineNotFoundException', + ), + array( + 'reason' => 'The specified pipeline has been deleted.', + 'class' => 'PipelineDeletedException', + ), + array( + 'reason' => 'An internal service error occurred.', + 'class' => 'InternalServiceErrorException', + ), + array( + 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'CreatePipeline' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'CreatePipelineOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'DataPipeline.CreatePipeline', + ), + 'name' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 1024, + ), + 'uniqueId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 1024, + ), + 'description' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An internal service error occurred.', + 'class' => 'InternalServiceErrorException', + ), + array( + 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'DeletePipeline' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'DataPipeline.DeletePipeline', + ), + 'pipelineId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 1024, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', + 'class' => 'PipelineNotFoundException', + ), + array( + 'reason' => 'An internal service error occurred.', + 'class' => 'InternalServiceErrorException', + ), + array( + 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'DescribeObjects' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeObjectsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'DataPipeline.DescribeObjects', + ), + 'pipelineId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 1024, + ), + 'objectIds' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'id', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 1024, + ), + ), + 'evaluateExpressions' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + 'marker' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An internal service error occurred.', + 'class' => 'InternalServiceErrorException', + ), + array( + 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', + 'class' => 'InvalidRequestException', + ), + array( + 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', + 'class' => 'PipelineNotFoundException', + ), + array( + 'reason' => 'The specified pipeline has been deleted.', + 'class' => 'PipelineDeletedException', + ), + ), + ), + 'DescribePipelines' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribePipelinesOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'DataPipeline.DescribePipelines', + ), + 'pipelineIds' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'id', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 1024, + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', + 'class' => 'PipelineNotFoundException', + ), + array( + 'reason' => 'The specified pipeline has been deleted.', + 'class' => 'PipelineDeletedException', + ), + array( + 'reason' => 'An internal service error occurred.', + 'class' => 'InternalServiceErrorException', + ), + array( + 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'EvaluateExpression' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'EvaluateExpressionOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'DataPipeline.EvaluateExpression', + ), + 'pipelineId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 1024, + ), + 'objectId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 1024, + ), + 'expression' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 20971520, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An internal service error occurred.', + 'class' => 'InternalServiceErrorException', + ), + array( + 'reason' => 'The specified task was not found.', + 'class' => 'TaskNotFoundException', + ), + array( + 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', + 'class' => 'InvalidRequestException', + ), + array( + 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', + 'class' => 'PipelineNotFoundException', + ), + array( + 'reason' => 'The specified pipeline has been deleted.', + 'class' => 'PipelineDeletedException', + ), + ), + ), + 'GetPipelineDefinition' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GetPipelineDefinitionOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'DataPipeline.GetPipelineDefinition', + ), + 'pipelineId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 1024, + ), + 'version' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An internal service error occurred.', + 'class' => 'InternalServiceErrorException', + ), + array( + 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', + 'class' => 'InvalidRequestException', + ), + array( + 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', + 'class' => 'PipelineNotFoundException', + ), + array( + 'reason' => 'The specified pipeline has been deleted.', + 'class' => 'PipelineDeletedException', + ), + ), + ), + 'ListPipelines' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListPipelinesOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'DataPipeline.ListPipelines', + ), + 'marker' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An internal service error occurred.', + 'class' => 'InternalServiceErrorException', + ), + array( + 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'PollForTask' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'PollForTaskOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'DataPipeline.PollForTask', + ), + 'workerGroup' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'hostname' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 1024, + ), + 'instanceIdentity' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'document' => array( + 'type' => 'string', + 'maxLength' => 1024, + ), + 'signature' => array( + 'type' => 'string', + 'maxLength' => 1024, + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An internal service error occurred.', + 'class' => 'InternalServiceErrorException', + ), + array( + 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', + 'class' => 'InvalidRequestException', + ), + array( + 'reason' => 'The specified task was not found.', + 'class' => 'TaskNotFoundException', + ), + ), + ), + 'PutPipelineDefinition' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'PutPipelineDefinitionOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'DataPipeline.PutPipelineDefinition', + ), + 'pipelineId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 1024, + ), + 'pipelineObjects' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'PipelineObject', + 'type' => 'object', + 'properties' => array( + 'id' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 1024, + ), + 'name' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 1024, + ), + 'fields' => array( + 'required' => true, + 'type' => 'array', + 'items' => array( + 'name' => 'Field', + 'type' => 'object', + 'properties' => array( + 'key' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'stringValue' => array( + 'type' => 'string', + 'maxLength' => 10240, + ), + 'refValue' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + ), + ), + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An internal service error occurred.', + 'class' => 'InternalServiceErrorException', + ), + array( + 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', + 'class' => 'InvalidRequestException', + ), + array( + 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', + 'class' => 'PipelineNotFoundException', + ), + array( + 'reason' => 'The specified pipeline has been deleted.', + 'class' => 'PipelineDeletedException', + ), + ), + ), + 'QueryObjects' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'QueryObjectsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'DataPipeline.QueryObjects', + ), + 'pipelineId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 1024, + ), + 'query' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'selectors' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Selector', + 'type' => 'object', + 'properties' => array( + 'fieldName' => array( + 'type' => 'string', + 'maxLength' => 1024, + ), + 'operator' => array( + 'type' => 'object', + 'properties' => array( + '' => array( + ), + ), + ), + ), + ), + ), + ), + ), + 'sphere' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'marker' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'limit' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', + 'class' => 'PipelineNotFoundException', + ), + array( + 'reason' => 'The specified pipeline has been deleted.', + 'class' => 'PipelineDeletedException', + ), + array( + 'reason' => 'An internal service error occurred.', + 'class' => 'InternalServiceErrorException', + ), + array( + 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'ReportTaskProgress' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ReportTaskProgressOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'DataPipeline.ReportTaskProgress', + ), + 'taskId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 2048, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An internal service error occurred.', + 'class' => 'InternalServiceErrorException', + ), + array( + 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', + 'class' => 'InvalidRequestException', + ), + array( + 'reason' => 'The specified task was not found.', + 'class' => 'TaskNotFoundException', + ), + array( + 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', + 'class' => 'PipelineNotFoundException', + ), + array( + 'reason' => 'The specified pipeline has been deleted.', + 'class' => 'PipelineDeletedException', + ), + ), + ), + 'ReportTaskRunnerHeartbeat' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ReportTaskRunnerHeartbeatOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'DataPipeline.ReportTaskRunnerHeartbeat', + ), + 'taskrunnerId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 1024, + ), + 'workerGroup' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'hostname' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 1024, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An internal service error occurred.', + 'class' => 'InternalServiceErrorException', + ), + array( + 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'SetStatus' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'DataPipeline.SetStatus', + ), + 'pipelineId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 1024, + ), + 'objectIds' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'id', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 1024, + ), + ), + 'status' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', + 'class' => 'PipelineNotFoundException', + ), + array( + 'reason' => 'The specified pipeline has been deleted.', + 'class' => 'PipelineDeletedException', + ), + array( + 'reason' => 'An internal service error occurred.', + 'class' => 'InternalServiceErrorException', + ), + array( + 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'SetTaskStatus' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'DataPipeline.SetTaskStatus', + ), + 'taskId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 2048, + ), + 'taskStatus' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'errorId' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'errorMessage' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'errorStackTrace' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An internal service error occurred.', + 'class' => 'InternalServiceErrorException', + ), + array( + 'reason' => 'The specified task was not found.', + 'class' => 'TaskNotFoundException', + ), + array( + 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', + 'class' => 'InvalidRequestException', + ), + array( + 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', + 'class' => 'PipelineNotFoundException', + ), + array( + 'reason' => 'The specified pipeline has been deleted.', + 'class' => 'PipelineDeletedException', + ), + ), + ), + 'ValidatePipelineDefinition' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ValidatePipelineDefinitionOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'DataPipeline.ValidatePipelineDefinition', + ), + 'pipelineId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 1024, + ), + 'pipelineObjects' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'PipelineObject', + 'type' => 'object', + 'properties' => array( + 'id' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 1024, + ), + 'name' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 1024, + ), + 'fields' => array( + 'required' => true, + 'type' => 'array', + 'items' => array( + 'name' => 'Field', + 'type' => 'object', + 'properties' => array( + 'key' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'stringValue' => array( + 'type' => 'string', + 'maxLength' => 10240, + ), + 'refValue' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + ), + ), + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An internal service error occurred.', + 'class' => 'InternalServiceErrorException', + ), + array( + 'reason' => 'The request was not valid. Verify that your request was properly formatted, that the signature was generated with the correct credentials, and that you haven\'t exceeded any of the service limits for your account.', + 'class' => 'InvalidRequestException', + ), + array( + 'reason' => 'The specified pipeline was not found. Verify that you used the correct user and account identifiers.', + 'class' => 'PipelineNotFoundException', + ), + array( + 'reason' => 'The specified pipeline has been deleted.', + 'class' => 'PipelineDeletedException', + ), + ), + ), + ), + 'models' => array( + 'EmptyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + ), + 'CreatePipelineOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'pipelineId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DescribeObjectsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'pipelineObjects' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'PipelineObject', + 'type' => 'object', + 'properties' => array( + 'id' => array( + 'type' => 'string', + ), + 'name' => array( + 'type' => 'string', + ), + 'fields' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Field', + 'type' => 'object', + 'properties' => array( + 'key' => array( + 'type' => 'string', + ), + 'stringValue' => array( + 'type' => 'string', + ), + 'refValue' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'marker' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'hasMoreResults' => array( + 'type' => 'boolean', + 'location' => 'json', + ), + ), + ), + 'DescribePipelinesOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'pipelineDescriptionList' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'PipelineDescription', + 'type' => 'object', + 'properties' => array( + 'pipelineId' => array( + 'type' => 'string', + ), + 'name' => array( + 'type' => 'string', + ), + 'fields' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Field', + 'type' => 'object', + 'properties' => array( + 'key' => array( + 'type' => 'string', + ), + 'stringValue' => array( + 'type' => 'string', + ), + 'refValue' => array( + 'type' => 'string', + ), + ), + ), + ), + 'description' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'EvaluateExpressionOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'evaluatedExpression' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'GetPipelineDefinitionOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'pipelineObjects' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'PipelineObject', + 'type' => 'object', + 'properties' => array( + 'id' => array( + 'type' => 'string', + ), + 'name' => array( + 'type' => 'string', + ), + 'fields' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Field', + 'type' => 'object', + 'properties' => array( + 'key' => array( + 'type' => 'string', + ), + 'stringValue' => array( + 'type' => 'string', + ), + 'refValue' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'ListPipelinesOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'pipelineIdList' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'PipelineIdName', + 'type' => 'object', + 'properties' => array( + 'id' => array( + 'type' => 'string', + ), + 'name' => array( + 'type' => 'string', + ), + ), + ), + ), + 'marker' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'hasMoreResults' => array( + 'type' => 'boolean', + 'location' => 'json', + ), + ), + ), + 'PollForTaskOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'taskObject' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'taskId' => array( + 'type' => 'string', + ), + 'pipelineId' => array( + 'type' => 'string', + ), + 'attemptId' => array( + 'type' => 'string', + ), + 'objects' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'id' => array( + 'type' => 'string', + ), + 'name' => array( + 'type' => 'string', + ), + 'fields' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Field', + 'type' => 'object', + 'properties' => array( + 'key' => array( + 'type' => 'string', + ), + 'stringValue' => array( + 'type' => 'string', + ), + 'refValue' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'PutPipelineDefinitionOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'validationErrors' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'ValidationError', + 'type' => 'object', + 'properties' => array( + 'id' => array( + 'type' => 'string', + ), + 'errors' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'validationMessage', + 'type' => 'string', + ), + ), + ), + ), + ), + 'validationWarnings' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'ValidationWarning', + 'type' => 'object', + 'properties' => array( + 'id' => array( + 'type' => 'string', + ), + 'warnings' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'validationMessage', + 'type' => 'string', + ), + ), + ), + ), + ), + 'errored' => array( + 'type' => 'boolean', + 'location' => 'json', + ), + ), + ), + 'QueryObjectsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ids' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'id', + 'type' => 'string', + ), + ), + 'marker' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'hasMoreResults' => array( + 'type' => 'boolean', + 'location' => 'json', + ), + ), + ), + 'ReportTaskProgressOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'canceled' => array( + 'type' => 'boolean', + 'location' => 'json', + ), + ), + ), + 'ReportTaskRunnerHeartbeatOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'terminate' => array( + 'type' => 'boolean', + 'location' => 'json', + ), + ), + ), + 'ValidatePipelineDefinitionOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'validationErrors' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'ValidationError', + 'type' => 'object', + 'properties' => array( + 'id' => array( + 'type' => 'string', + ), + 'errors' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'validationMessage', + 'type' => 'string', + ), + ), + ), + ), + ), + 'validationWarnings' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'ValidationWarning', + 'type' => 'object', + 'properties' => array( + 'id' => array( + 'type' => 'string', + ), + 'warnings' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'validationMessage', + 'type' => 'string', + ), + ), + ), + ), + ), + 'errored' => array( + 'type' => 'boolean', + 'location' => 'json', + ), + ), + ), + ), + '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-sdk-php/src/Aws/DirectConnect/DirectConnectClient.php b/vendor/aws/aws-sdk-php/src/Aws/DirectConnect/DirectConnectClient.php new file mode 100644 index 0000000..8252112 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/DirectConnect/Enum/ConnectionState.php b/vendor/aws/aws-sdk-php/src/Aws/DirectConnect/Enum/ConnectionState.php new file mode 100644 index 0000000..fdd48a4 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/DynamoDb/Crc32ErrorChecker.php b/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/Crc32ErrorChecker.php new file mode 100644 index 0000000..914eda2 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/DynamoDb/DynamoDbClient.php b/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/DynamoDbClient.php new file mode 100644 index 0000000..1daa21f --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/DynamoDbClient.php @@ -0,0 +1,192 @@ +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. + */ + public function formatValue($value, $format = Attribute::FORMAT_PUT) + { + return Attribute::factory($value)->getFormatted($format); + } + + /** + * Formats an array of values as DynamoDB attributes. + * + * @param array $values The values to format for DynamoDB. + * @param string $format The type of format (e.g. put, update). + * + * @return array The formatted values. + */ + public function formatAttributes(array $values, $format = Attribute::FORMAT_PUT) + { + $formatted = array(); + + foreach ($values as $key => $value) { + $formatted[$key] = $this->formatValue($value, $format); + } + + return $formatted; + } + + /** + * Calculate the amount of time needed for an exponential backoff to wait + * before retrying a request + * + * @param int $retries Number of retries + * + * @return float Returns the amount of time to wait in seconds + */ + public static function calculateRetryDelay($retries) + { + return $retries == 0 ? 0 : (50 * (int) pow(2, $retries - 1)) / 1000; + } + + /** + * Convenience method for instantiating and registering the DynamoDB + * Session handler with this DynamoDB client object. + * + * @param array $config Array of options for the session handler factory + * + * @return SessionHandler + */ + public function registerSessionHandler(array $config = array()) + { + $config = array_replace(array('dynamodb_client' => $this), $config); + + $handler = SessionHandler::factory($config); + $handler->register(); + + return $handler; + } +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/Enum/AttributeAction.php b/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/Enum/AttributeAction.php new file mode 100644 index 0000000..a0f1d2f --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/DynamoDb/Exception/UnrecognizedClientException.php b/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/Exception/UnrecognizedClientException.php new file mode 100644 index 0000000..04d9d93 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/DynamoDb/Iterator/ScanIterator.php b/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/Iterator/ScanIterator.php new file mode 100644 index 0000000..e227ad9 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/DynamoDb/Model/Attribute.php b/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/Model/Attribute.php new file mode 100644 index 0000000..9b5d2ed --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/Model/Attribute.php @@ -0,0 +1,245 @@ + 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-sdk-php/src/Aws/DynamoDb/Model/BatchRequest/AbstractWriteRequest.php b/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/Model/BatchRequest/AbstractWriteRequest.php new file mode 100644 index 0000000..3589816 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/Model/BatchRequest/AbstractWriteRequest.php @@ -0,0 +1,36 @@ +tableName; + } +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/Model/BatchRequest/DeleteRequest.php b/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/Model/BatchRequest/DeleteRequest.php new file mode 100644 index 0000000..f01cedc --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/DynamoDb/Model/BatchRequest/PutRequest.php b/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/Model/BatchRequest/PutRequest.php new file mode 100644 index 0000000..eec3d1c --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/Model/BatchRequest/PutRequest.php @@ -0,0 +1,98 @@ +getName() !== 'PutItem') { + throw new InvalidArgumentException(); + } + + // Get relevant data for a PutRequest + $table = $command->get('TableName'); + $item = $command->get('Item'); + + // Create an Item object from the 'item' command data + if (!($item instanceof Item)) { + $item = new Item($item, $table); + } + + // Return an instantiated PutRequest object + return new PutRequest($item, $table); + } + + /** + * Constructs a new put request + * + * @param Item $item The item to put into DynamoDB + * @param string $tableName The name of the table which has the item + * + * @throw InvalidArgumentException if the table name is not provided + */ + public function __construct(Item $item, $tableName = null) + { + $this->item = $item; + $this->tableName = $tableName ?: $item->getTableName(); + + if (!$this->tableName) { + throw new InvalidArgumentException('A table name is required to create a PutRequest.'); + } + } + + /** + * The parameter form of the request + * + * @return array + */ + public function toArray() + { + return array('PutRequest' => array('Item' => $this->item->toArray())); + } + + /** + * Get the item + * + * @return Item + */ + public function getItem() + { + return $this->item; + } +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/Model/BatchRequest/UnprocessedRequest.php b/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/Model/BatchRequest/UnprocessedRequest.php new file mode 100644 index 0000000..4519630 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/DynamoDb/Model/BatchRequest/WriteRequestBatch.php b/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/Model/BatchRequest/WriteRequestBatch.php new file mode 100644 index 0000000..b44e7e6 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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 are are trying to add to the batch queue is invalid.'); + } + + return $this->decoratedBatch->add($item); + } + + /** + * {@inheritdoc} + */ + public function flush() + { + // Flush the queue + $items = array(); + while (!$this->decoratedBatch->isEmpty()) { + try { + $items = array_merge($items, $this->decoratedBatch->flush()); + } catch (BatchTransferException $e) { + $unprocessed = $e->getPrevious(); + if ($unprocessed instanceof UnprocessedWriteRequestsException) { + // Handles the UnprocessedItemsException that may occur for + // throttled items the batch. These are re-queued here + foreach ($unprocessed as $unprocessedItem) { + $this->add($unprocessedItem); + } + } else { + // Re-throw the exception if not handled + throw $e; + } + } + } + + return $items; + } +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/Model/BatchRequest/WriteRequestBatchTransfer.php b/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/Model/BatchRequest/WriteRequestBatchTransfer.php new file mode 100755 index 0000000..168925d --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/Model/BatchRequest/WriteRequestBatchTransfer.php @@ -0,0 +1,250 @@ +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); + } + } + + // 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-sdk-php/src/Aws/DynamoDb/Model/BatchRequest/WriteRequestInterface.php b/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/Model/BatchRequest/WriteRequestInterface.php new file mode 100644 index 0000000..70503e2 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/DynamoDb/Resources/dynamodb-2011-12-05.php b/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/Resources/dynamodb-2011-12-05.php new file mode 100644 index 0000000..1c1d216 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/DynamoDb/Resources/dynamodb-2012-08-10.php b/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/Resources/dynamodb-2012-08-10.php new file mode 100644 index 0000000..3fcf6cf --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/Resources/dynamodb-2012-08-10.php @@ -0,0 +1,4220 @@ + '2012-08-10', + 'endpointPrefix' => 'dynamodb', + 'serviceFullName' => 'Amazon DynamoDB', + 'serviceAbbreviation' => 'DynamoDB', + 'serviceType' => 'json', + 'jsonVersion' => '1.0', + 'targetPrefix' => 'DynamoDB_20120810.', + 'signatureVersion' => 'v4', + 'namespace' => 'DynamoDb', + 'regions' => array( + 'us-east-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'dynamodb.us-east-1.amazonaws.com', + ), + 'us-west-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'dynamodb.us-west-1.amazonaws.com', + ), + 'us-west-2' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'dynamodb.us-west-2.amazonaws.com', + ), + 'eu-west-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'dynamodb.eu-west-1.amazonaws.com', + ), + 'ap-northeast-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'dynamodb.ap-northeast-1.amazonaws.com', + ), + 'ap-southeast-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'dynamodb.ap-southeast-1.amazonaws.com', + ), + 'ap-southeast-2' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'dynamodb.ap-southeast-2.amazonaws.com', + ), + 'sa-east-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'dynamodb.sa-east-1.amazonaws.com', + ), + 'cn-north-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'dynamodb.cn-north-1.amazonaws.com.cn', + ), + 'us-gov-west-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'dynamodb.us-gov-west-1.amazonaws.com', + ), + ), + 'operations' => array( + 'BatchGetItem' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'BatchGetItemOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.0', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'DynamoDB_20120810.BatchGetItem', + ), + 'RequestItems' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'object', + 'data' => array( + 'shape_name' => 'TableName', + 'key_pattern' => '/[a-zA-Z0-9_.-]+/', + ), + 'properties' => array( + 'Keys' => array( + 'required' => true, + 'type' => 'array', + 'minItems' => 1, + 'maxItems' => 100, + 'items' => array( + 'name' => 'Key', + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'object', + 'data' => array( + 'shape_name' => 'AttributeName', + ), + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + ), + ), + ), + ), + ), + 'AttributesToGet' => array( + 'type' => 'array', + 'minItems' => 1, + 'items' => array( + 'name' => 'AttributeName', + 'type' => 'string', + 'maxLength' => 65535, + ), + ), + 'ConsistentRead' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + ), + 'ReturnConsumedCapacity' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request rate is too high, or the request is too large, for the available throughput to accommodate. The AWS SDKs automatically retry requests that receive this exception; therefore, your request will eventually succeed, unless the request is too large or your retry queue is too large to finish. Reduce the frequency of requests by using the strategies listed in Error Retries and Exponential Backoff in the Amazon DynamoDB Developer Guide.', + 'class' => 'ProvisionedThroughputExceededException', + ), + array( + 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'An error occurred on the server side.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'BatchWriteItem' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'BatchWriteItemOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.0', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'DynamoDB_20120810.BatchWriteItem', + ), + 'RequestItems' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'array', + 'minItems' => 1, + 'maxItems' => 25, + 'data' => array( + 'shape_name' => 'TableName', + 'key_pattern' => '/[a-zA-Z0-9_.-]+/', + ), + 'items' => array( + 'name' => 'WriteRequest', + 'type' => 'object', + 'properties' => array( + 'PutRequest' => array( + 'type' => 'object', + 'properties' => array( + 'Item' => array( + 'required' => true, + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'object', + 'data' => array( + 'shape_name' => 'AttributeName', + ), + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + ), + ), + ), + ), + ), + ), + 'DeleteRequest' => array( + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'required' => true, + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'object', + 'data' => array( + 'shape_name' => 'AttributeName', + ), + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + ), + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'ReturnConsumedCapacity' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'ReturnItemCollectionMetrics' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request rate is too high, or the request is too large, for the available throughput to accommodate. The AWS SDKs automatically retry requests that receive this exception; therefore, your request will eventually succeed, unless the request is too large or your retry queue is too large to finish. Reduce the frequency of requests by using the strategies listed in Error Retries and Exponential Backoff in the Amazon DynamoDB Developer Guide.', + 'class' => 'ProvisionedThroughputExceededException', + ), + array( + 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'An item collection is too large. This exception is only returned for tables that have one or more local secondary indexes.', + 'class' => 'ItemCollectionSizeLimitExceededException', + ), + array( + 'reason' => 'An error occurred on the server side.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'CreateTable' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'CreateTableOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.0', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'DynamoDB_20120810.CreateTable', + ), + 'AttributeDefinitions' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'AttributeDefinition', + 'type' => 'object', + 'properties' => array( + 'AttributeName' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'AttributeType' => array( + 'required' => true, + 'type' => 'string', + ), + ), + ), + ), + 'TableName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 3, + 'maxLength' => 255, + ), + 'KeySchema' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'minItems' => 1, + 'maxItems' => 2, + 'items' => array( + 'name' => 'KeySchemaElement', + 'type' => 'object', + 'properties' => array( + 'AttributeName' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'KeyType' => array( + 'required' => true, + 'type' => 'string', + ), + ), + ), + ), + 'LocalSecondaryIndexes' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'LocalSecondaryIndex', + 'type' => 'object', + 'properties' => array( + 'IndexName' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 3, + 'maxLength' => 255, + ), + 'KeySchema' => array( + 'required' => true, + 'type' => 'array', + 'minItems' => 1, + 'maxItems' => 2, + 'items' => array( + 'name' => 'KeySchemaElement', + 'type' => 'object', + 'properties' => array( + 'AttributeName' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'KeyType' => array( + 'required' => true, + 'type' => 'string', + ), + ), + ), + ), + 'Projection' => array( + 'required' => true, + 'type' => 'object', + 'properties' => array( + 'ProjectionType' => array( + 'type' => 'string', + ), + 'NonKeyAttributes' => array( + 'type' => 'array', + 'minItems' => 1, + 'maxItems' => 20, + 'items' => array( + 'name' => 'NonKeyAttributeName', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + ), + ), + ), + ), + ), + ), + 'GlobalSecondaryIndexes' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'GlobalSecondaryIndex', + 'type' => 'object', + 'properties' => array( + 'IndexName' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 3, + 'maxLength' => 255, + ), + 'KeySchema' => array( + 'required' => true, + 'type' => 'array', + 'minItems' => 1, + 'maxItems' => 2, + 'items' => array( + 'name' => 'KeySchemaElement', + 'type' => 'object', + 'properties' => array( + 'AttributeName' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'KeyType' => array( + 'required' => true, + 'type' => 'string', + ), + ), + ), + ), + 'Projection' => array( + 'required' => true, + 'type' => 'object', + 'properties' => array( + 'ProjectionType' => array( + 'type' => 'string', + ), + 'NonKeyAttributes' => array( + 'type' => 'array', + 'minItems' => 1, + 'maxItems' => 20, + 'items' => array( + 'name' => 'NonKeyAttributeName', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + ), + ), + ), + 'ProvisionedThroughput' => array( + 'required' => true, + 'type' => 'object', + 'properties' => array( + 'ReadCapacityUnits' => array( + 'required' => true, + 'type' => 'numeric', + 'minimum' => 1, + ), + 'WriteCapacityUnits' => array( + 'required' => true, + 'type' => 'numeric', + 'minimum' => 1, + ), + ), + ), + ), + ), + ), + 'ProvisionedThroughput' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'ReadCapacityUnits' => array( + 'required' => true, + 'type' => 'numeric', + 'minimum' => 1, + ), + 'WriteCapacityUnits' => array( + 'required' => true, + 'type' => 'numeric', + 'minimum' => 1, + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The operation conflicts with the resource\'s availability. For example, you attempted to recreate an existing table, or tried to delete a table currently in the CREATING state.', + 'class' => 'ResourceInUseException', + ), + array( + 'reason' => 'The number of concurrent table requests (cumulative number of tables in the CREATING, DELETING or UPDATING state) exceeds the maximum allowed of 10. Also, for tables with secondary indexes, only one of those tables can be in the CREATING state at any point in time. Do not attempt to create more than one such table simultaneously. The total limit of tables in the ACTIVE state is 250.', + 'class' => 'LimitExceededException', + ), + array( + 'reason' => 'An error occurred on the server side.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'DeleteItem' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DeleteItemOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.0', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'DynamoDB_20120810.DeleteItem', + ), + 'TableName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 3, + 'maxLength' => 255, + ), + 'Key' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'object', + 'data' => array( + 'shape_name' => 'AttributeName', + ), + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + ), + ), + ), + ), + 'Expected' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'object', + 'data' => array( + 'shape_name' => 'AttributeName', + ), + 'properties' => array( + 'Value' => array( + 'type' => 'object', + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + ), + ), + ), + 'Exists' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'ComparisonOperator' => array( + 'type' => 'string', + ), + 'AttributeValueList' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AttributeValue', + 'type' => 'object', + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'ConditionalOperator' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'ReturnValues' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'ReturnConsumedCapacity' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'ReturnItemCollectionMetrics' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'A condition specified in the operation could not be evaluated.', + 'class' => 'ConditionalCheckFailedException', + ), + array( + 'reason' => 'The request rate is too high, or the request is too large, for the available throughput to accommodate. The AWS SDKs automatically retry requests that receive this exception; therefore, your request will eventually succeed, unless the request is too large or your retry queue is too large to finish. Reduce the frequency of requests by using the strategies listed in Error Retries and Exponential Backoff in the Amazon DynamoDB Developer Guide.', + 'class' => 'ProvisionedThroughputExceededException', + ), + array( + 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'An item collection is too large. This exception is only returned for tables that have one or more local secondary indexes.', + 'class' => 'ItemCollectionSizeLimitExceededException', + ), + array( + 'reason' => 'An error occurred on the server side.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'DeleteTable' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DeleteTableOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.0', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'DynamoDB_20120810.DeleteTable', + ), + 'TableName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 3, + 'maxLength' => 255, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The operation conflicts with the resource\'s availability. For example, you attempted to recreate an existing table, or tried to delete a table currently in the CREATING state.', + 'class' => 'ResourceInUseException', + ), + array( + 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'The number of concurrent table requests (cumulative number of tables in the CREATING, DELETING or UPDATING state) exceeds the maximum allowed of 10. Also, for tables with secondary indexes, only one of those tables can be in the CREATING state at any point in time. Do not attempt to create more than one such table simultaneously. The total limit of tables in the ACTIVE state is 250.', + 'class' => 'LimitExceededException', + ), + array( + 'reason' => 'An error occurred on the server side.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'DescribeTable' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeTableOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.0', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'DynamoDB_20120810.DescribeTable', + ), + 'TableName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 3, + 'maxLength' => 255, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'An error occurred on the server side.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'GetItem' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GetItemOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.0', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'DynamoDB_20120810.GetItem', + ), + 'TableName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 3, + 'maxLength' => 255, + ), + 'Key' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'object', + 'data' => array( + 'shape_name' => 'AttributeName', + ), + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + ), + ), + ), + ), + 'AttributesToGet' => array( + 'type' => 'array', + 'location' => 'json', + 'minItems' => 1, + 'items' => array( + 'name' => 'AttributeName', + 'type' => 'string', + 'maxLength' => 65535, + ), + ), + 'ConsistentRead' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + 'ReturnConsumedCapacity' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request rate is too high, or the request is too large, for the available throughput to accommodate. The AWS SDKs automatically retry requests that receive this exception; therefore, your request will eventually succeed, unless the request is too large or your retry queue is too large to finish. Reduce the frequency of requests by using the strategies listed in Error Retries and Exponential Backoff in the Amazon DynamoDB Developer Guide.', + 'class' => 'ProvisionedThroughputExceededException', + ), + array( + 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'An error occurred on the server side.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'ListTables' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListTablesOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.0', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'DynamoDB_20120810.ListTables', + ), + 'ExclusiveStartTableName' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 3, + 'maxLength' => 255, + ), + 'Limit' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 100, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An error occurred on the server side.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'PutItem' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'PutItemOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.0', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'DynamoDB_20120810.PutItem', + ), + 'TableName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 3, + 'maxLength' => 255, + ), + 'Item' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'object', + 'data' => array( + 'shape_name' => 'AttributeName', + ), + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + ), + ), + ), + ), + 'Expected' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'object', + 'data' => array( + 'shape_name' => 'AttributeName', + ), + 'properties' => array( + 'Value' => array( + 'type' => 'object', + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + ), + ), + ), + 'Exists' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'ComparisonOperator' => array( + 'type' => 'string', + ), + 'AttributeValueList' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AttributeValue', + 'type' => 'object', + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'ReturnValues' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'ReturnConsumedCapacity' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'ReturnItemCollectionMetrics' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'ConditionalOperator' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'A condition specified in the operation could not be evaluated.', + 'class' => 'ConditionalCheckFailedException', + ), + array( + 'reason' => 'The request rate is too high, or the request is too large, for the available throughput to accommodate. The AWS SDKs automatically retry requests that receive this exception; therefore, your request will eventually succeed, unless the request is too large or your retry queue is too large to finish. Reduce the frequency of requests by using the strategies listed in Error Retries and Exponential Backoff in the Amazon DynamoDB Developer Guide.', + 'class' => 'ProvisionedThroughputExceededException', + ), + array( + 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'An item collection is too large. This exception is only returned for tables that have one or more local secondary indexes.', + 'class' => 'ItemCollectionSizeLimitExceededException', + ), + array( + 'reason' => 'An error occurred on the server side.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'Query' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'QueryOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.0', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'DynamoDB_20120810.Query', + ), + 'TableName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 3, + 'maxLength' => 255, + ), + 'IndexName' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 3, + 'maxLength' => 255, + ), + 'Select' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'AttributesToGet' => array( + 'type' => 'array', + 'location' => 'json', + 'minItems' => 1, + 'items' => array( + 'name' => 'AttributeName', + 'type' => 'string', + 'maxLength' => 65535, + ), + ), + 'Limit' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + ), + 'ConsistentRead' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + 'KeyConditions' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'object', + 'data' => array( + 'shape_name' => 'AttributeName', + ), + 'properties' => array( + 'AttributeValueList' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AttributeValue', + 'type' => 'object', + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + ), + ), + ), + ), + 'ComparisonOperator' => array( + 'required' => true, + 'type' => 'string', + ), + ), + ), + ), + 'QueryFilter' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'object', + 'data' => array( + 'shape_name' => 'AttributeName', + ), + 'properties' => array( + 'AttributeValueList' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AttributeValue', + 'type' => 'object', + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + ), + ), + ), + ), + 'ComparisonOperator' => array( + 'required' => true, + 'type' => 'string', + ), + ), + ), + ), + 'ConditionalOperator' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'ScanIndexForward' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + 'ExclusiveStartKey' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'object', + 'data' => array( + 'shape_name' => 'AttributeName', + ), + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + ), + ), + ), + ), + 'ReturnConsumedCapacity' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request rate is too high, or the request is too large, for the available throughput to accommodate. The AWS SDKs automatically retry requests that receive this exception; therefore, your request will eventually succeed, unless the request is too large or your retry queue is too large to finish. Reduce the frequency of requests by using the strategies listed in Error Retries and Exponential Backoff in the Amazon DynamoDB Developer Guide.', + 'class' => 'ProvisionedThroughputExceededException', + ), + array( + 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'An error occurred on the server side.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'Scan' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ScanOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.0', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'DynamoDB_20120810.Scan', + ), + 'TableName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 3, + 'maxLength' => 255, + ), + 'AttributesToGet' => array( + 'type' => 'array', + 'location' => 'json', + 'minItems' => 1, + 'items' => array( + 'name' => 'AttributeName', + 'type' => 'string', + 'maxLength' => 65535, + ), + ), + 'Limit' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + ), + 'Select' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'ScanFilter' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'object', + 'data' => array( + 'shape_name' => 'AttributeName', + ), + 'properties' => array( + 'AttributeValueList' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AttributeValue', + 'type' => 'object', + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + ), + ), + ), + ), + 'ComparisonOperator' => array( + 'required' => true, + 'type' => 'string', + ), + ), + ), + ), + 'ConditionalOperator' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'ExclusiveStartKey' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'object', + 'data' => array( + 'shape_name' => 'AttributeName', + ), + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + ), + ), + ), + ), + 'ReturnConsumedCapacity' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'TotalSegments' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 1000000, + ), + 'Segment' => array( + 'type' => 'numeric', + 'location' => 'json', + 'maximum' => 999999, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request rate is too high, or the request is too large, for the available throughput to accommodate. The AWS SDKs automatically retry requests that receive this exception; therefore, your request will eventually succeed, unless the request is too large or your retry queue is too large to finish. Reduce the frequency of requests by using the strategies listed in Error Retries and Exponential Backoff in the Amazon DynamoDB Developer Guide.', + 'class' => 'ProvisionedThroughputExceededException', + ), + array( + 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'An error occurred on the server side.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'UpdateItem' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'UpdateItemOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.0', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'DynamoDB_20120810.UpdateItem', + ), + 'TableName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 3, + 'maxLength' => 255, + ), + 'Key' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'object', + 'data' => array( + 'shape_name' => 'AttributeName', + ), + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + ), + ), + ), + ), + 'AttributeUpdates' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'object', + 'data' => array( + 'shape_name' => 'AttributeName', + ), + 'properties' => array( + 'Value' => array( + 'type' => 'object', + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + ), + ), + ), + 'Action' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Expected' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'object', + 'data' => array( + 'shape_name' => 'AttributeName', + ), + 'properties' => array( + 'Value' => array( + 'type' => 'object', + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + ), + ), + ), + 'Exists' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'ComparisonOperator' => array( + 'type' => 'string', + ), + 'AttributeValueList' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AttributeValue', + 'type' => 'object', + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_encode', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'ConditionalOperator' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'ReturnValues' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'ReturnConsumedCapacity' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'ReturnItemCollectionMetrics' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'A condition specified in the operation could not be evaluated.', + 'class' => 'ConditionalCheckFailedException', + ), + array( + 'reason' => 'The request rate is too high, or the request is too large, for the available throughput to accommodate. The AWS SDKs automatically retry requests that receive this exception; therefore, your request will eventually succeed, unless the request is too large or your retry queue is too large to finish. Reduce the frequency of requests by using the strategies listed in Error Retries and Exponential Backoff in the Amazon DynamoDB Developer Guide.', + 'class' => 'ProvisionedThroughputExceededException', + ), + array( + 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'An item collection is too large. This exception is only returned for tables that have one or more local secondary indexes.', + 'class' => 'ItemCollectionSizeLimitExceededException', + ), + array( + 'reason' => 'An error occurred on the server side.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'UpdateTable' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'UpdateTableOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.0', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'DynamoDB_20120810.UpdateTable', + ), + 'TableName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 3, + 'maxLength' => 255, + ), + 'ProvisionedThroughput' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'ReadCapacityUnits' => array( + 'required' => true, + 'type' => 'numeric', + 'minimum' => 1, + ), + 'WriteCapacityUnits' => array( + 'required' => true, + 'type' => 'numeric', + 'minimum' => 1, + ), + ), + ), + 'GlobalSecondaryIndexUpdates' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'GlobalSecondaryIndexUpdate', + 'type' => 'object', + 'properties' => array( + 'Update' => array( + 'type' => 'object', + 'properties' => array( + 'IndexName' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 3, + 'maxLength' => 255, + ), + 'ProvisionedThroughput' => array( + 'required' => true, + 'type' => 'object', + 'properties' => array( + 'ReadCapacityUnits' => array( + 'required' => true, + 'type' => 'numeric', + 'minimum' => 1, + ), + 'WriteCapacityUnits' => array( + 'required' => true, + 'type' => 'numeric', + 'minimum' => 1, + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The operation conflicts with the resource\'s availability. For example, you attempted to recreate an existing table, or tried to delete a table currently in the CREATING state.', + 'class' => 'ResourceInUseException', + ), + array( + 'reason' => 'The operation tried to access a nonexistent table or index. The resource may not be specified correctly, or its status may not be ACTIVE.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'The number of concurrent table requests (cumulative number of tables in the CREATING, DELETING or UPDATING state) exceeds the maximum allowed of 10. Also, for tables with secondary indexes, only one of those tables can be in the CREATING state at any point in time. Do not attempt to create more than one such table simultaneously. The total limit of tables in the ACTIVE state is 250.', + 'class' => 'LimitExceededException', + ), + array( + 'reason' => 'An error occurred on the server side.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + ), + 'models' => array( + 'BatchGetItemOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Responses' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AttributeMap', + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + ), + ), + ), + ), + ), + ), + 'UnprocessedKeys' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'Keys' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Key', + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + ), + ), + ), + ), + ), + 'AttributesToGet' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AttributeName', + 'type' => 'string', + ), + ), + 'ConsistentRead' => array( + 'type' => 'boolean', + ), + ), + ), + ), + 'ConsumedCapacity' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'ConsumedCapacity', + 'type' => 'object', + 'properties' => array( + 'TableName' => array( + 'type' => 'string', + ), + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + 'Table' => array( + 'type' => 'object', + 'properties' => array( + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + 'LocalSecondaryIndexes' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'GlobalSecondaryIndexes' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'BatchWriteItemOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'UnprocessedItems' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'WriteRequest', + 'type' => 'object', + 'properties' => array( + 'PutRequest' => array( + 'type' => 'object', + 'properties' => array( + 'Item' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + ), + ), + ), + ), + ), + ), + 'DeleteRequest' => array( + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + ), + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'ItemCollectionMetrics' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ItemCollectionMetrics', + 'type' => 'object', + 'properties' => array( + 'ItemCollectionKey' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + ), + ), + ), + ), + 'SizeEstimateRangeGB' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ItemCollectionSizeEstimateBound', + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + 'ConsumedCapacity' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'ConsumedCapacity', + 'type' => 'object', + 'properties' => array( + 'TableName' => array( + 'type' => 'string', + ), + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + 'Table' => array( + 'type' => 'object', + 'properties' => array( + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + 'LocalSecondaryIndexes' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'GlobalSecondaryIndexes' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'CreateTableOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'TableDescription' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'AttributeDefinitions' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AttributeDefinition', + 'type' => 'object', + 'properties' => array( + 'AttributeName' => array( + 'type' => 'string', + ), + 'AttributeType' => array( + 'type' => 'string', + ), + ), + ), + ), + 'TableName' => array( + 'type' => 'string', + ), + 'KeySchema' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'KeySchemaElement', + 'type' => 'object', + 'properties' => array( + 'AttributeName' => array( + 'type' => 'string', + ), + 'KeyType' => array( + 'type' => 'string', + ), + ), + ), + ), + 'TableStatus' => array( + 'type' => 'string', + ), + 'CreationDateTime' => array( + 'type' => 'string', + ), + 'ProvisionedThroughput' => array( + 'type' => 'object', + 'properties' => array( + 'LastIncreaseDateTime' => array( + 'type' => 'string', + ), + 'LastDecreaseDateTime' => array( + 'type' => 'string', + ), + 'NumberOfDecreasesToday' => array( + 'type' => 'numeric', + ), + 'ReadCapacityUnits' => array( + 'type' => 'numeric', + ), + 'WriteCapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + 'TableSizeBytes' => array( + 'type' => 'numeric', + ), + 'ItemCount' => array( + 'type' => 'numeric', + ), + 'LocalSecondaryIndexes' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'LocalSecondaryIndexDescription', + 'type' => 'object', + 'properties' => array( + 'IndexName' => array( + 'type' => 'string', + ), + 'KeySchema' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'KeySchemaElement', + 'type' => 'object', + 'properties' => array( + 'AttributeName' => array( + 'type' => 'string', + ), + 'KeyType' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Projection' => array( + 'type' => 'object', + 'properties' => array( + 'ProjectionType' => array( + 'type' => 'string', + ), + 'NonKeyAttributes' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NonKeyAttributeName', + 'type' => 'string', + ), + ), + ), + ), + 'IndexSizeBytes' => array( + 'type' => 'numeric', + ), + 'ItemCount' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'GlobalSecondaryIndexes' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'GlobalSecondaryIndexDescription', + 'type' => 'object', + 'properties' => array( + 'IndexName' => array( + 'type' => 'string', + ), + 'KeySchema' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'KeySchemaElement', + 'type' => 'object', + 'properties' => array( + 'AttributeName' => array( + 'type' => 'string', + ), + 'KeyType' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Projection' => array( + 'type' => 'object', + 'properties' => array( + 'ProjectionType' => array( + 'type' => 'string', + ), + 'NonKeyAttributes' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NonKeyAttributeName', + 'type' => 'string', + ), + ), + ), + ), + 'IndexStatus' => array( + 'type' => 'string', + ), + 'ProvisionedThroughput' => array( + 'type' => 'object', + 'properties' => array( + 'LastIncreaseDateTime' => array( + 'type' => 'string', + ), + 'LastDecreaseDateTime' => array( + 'type' => 'string', + ), + 'NumberOfDecreasesToday' => array( + 'type' => 'numeric', + ), + 'ReadCapacityUnits' => array( + 'type' => 'numeric', + ), + 'WriteCapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + 'IndexSizeBytes' => array( + 'type' => 'numeric', + ), + 'ItemCount' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + ), + ), + 'DeleteItemOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Attributes' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + ), + ), + ), + ), + 'ConsumedCapacity' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'TableName' => array( + 'type' => 'string', + ), + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + 'Table' => array( + 'type' => 'object', + 'properties' => array( + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + 'LocalSecondaryIndexes' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'GlobalSecondaryIndexes' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + 'ItemCollectionMetrics' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'ItemCollectionKey' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + ), + ), + ), + ), + 'SizeEstimateRangeGB' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ItemCollectionSizeEstimateBound', + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + 'DeleteTableOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'TableDescription' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'AttributeDefinitions' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AttributeDefinition', + 'type' => 'object', + 'properties' => array( + 'AttributeName' => array( + 'type' => 'string', + ), + 'AttributeType' => array( + 'type' => 'string', + ), + ), + ), + ), + 'TableName' => array( + 'type' => 'string', + ), + 'KeySchema' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'KeySchemaElement', + 'type' => 'object', + 'properties' => array( + 'AttributeName' => array( + 'type' => 'string', + ), + 'KeyType' => array( + 'type' => 'string', + ), + ), + ), + ), + 'TableStatus' => array( + 'type' => 'string', + ), + 'CreationDateTime' => array( + 'type' => 'string', + ), + 'ProvisionedThroughput' => array( + 'type' => 'object', + 'properties' => array( + 'LastIncreaseDateTime' => array( + 'type' => 'string', + ), + 'LastDecreaseDateTime' => array( + 'type' => 'string', + ), + 'NumberOfDecreasesToday' => array( + 'type' => 'numeric', + ), + 'ReadCapacityUnits' => array( + 'type' => 'numeric', + ), + 'WriteCapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + 'TableSizeBytes' => array( + 'type' => 'numeric', + ), + 'ItemCount' => array( + 'type' => 'numeric', + ), + 'LocalSecondaryIndexes' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'LocalSecondaryIndexDescription', + 'type' => 'object', + 'properties' => array( + 'IndexName' => array( + 'type' => 'string', + ), + 'KeySchema' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'KeySchemaElement', + 'type' => 'object', + 'properties' => array( + 'AttributeName' => array( + 'type' => 'string', + ), + 'KeyType' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Projection' => array( + 'type' => 'object', + 'properties' => array( + 'ProjectionType' => array( + 'type' => 'string', + ), + 'NonKeyAttributes' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NonKeyAttributeName', + 'type' => 'string', + ), + ), + ), + ), + 'IndexSizeBytes' => array( + 'type' => 'numeric', + ), + 'ItemCount' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'GlobalSecondaryIndexes' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'GlobalSecondaryIndexDescription', + 'type' => 'object', + 'properties' => array( + 'IndexName' => array( + 'type' => 'string', + ), + 'KeySchema' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'KeySchemaElement', + 'type' => 'object', + 'properties' => array( + 'AttributeName' => array( + 'type' => 'string', + ), + 'KeyType' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Projection' => array( + 'type' => 'object', + 'properties' => array( + 'ProjectionType' => array( + 'type' => 'string', + ), + 'NonKeyAttributes' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NonKeyAttributeName', + 'type' => 'string', + ), + ), + ), + ), + 'IndexStatus' => array( + 'type' => 'string', + ), + 'ProvisionedThroughput' => array( + 'type' => 'object', + 'properties' => array( + 'LastIncreaseDateTime' => array( + 'type' => 'string', + ), + 'LastDecreaseDateTime' => array( + 'type' => 'string', + ), + 'NumberOfDecreasesToday' => array( + 'type' => 'numeric', + ), + 'ReadCapacityUnits' => array( + 'type' => 'numeric', + ), + 'WriteCapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + 'IndexSizeBytes' => array( + 'type' => 'numeric', + ), + 'ItemCount' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + ), + ), + 'DescribeTableOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Table' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'AttributeDefinitions' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AttributeDefinition', + 'type' => 'object', + 'properties' => array( + 'AttributeName' => array( + 'type' => 'string', + ), + 'AttributeType' => array( + 'type' => 'string', + ), + ), + ), + ), + 'TableName' => array( + 'type' => 'string', + ), + 'KeySchema' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'KeySchemaElement', + 'type' => 'object', + 'properties' => array( + 'AttributeName' => array( + 'type' => 'string', + ), + 'KeyType' => array( + 'type' => 'string', + ), + ), + ), + ), + 'TableStatus' => array( + 'type' => 'string', + ), + 'CreationDateTime' => array( + 'type' => 'string', + ), + 'ProvisionedThroughput' => array( + 'type' => 'object', + 'properties' => array( + 'LastIncreaseDateTime' => array( + 'type' => 'string', + ), + 'LastDecreaseDateTime' => array( + 'type' => 'string', + ), + 'NumberOfDecreasesToday' => array( + 'type' => 'numeric', + ), + 'ReadCapacityUnits' => array( + 'type' => 'numeric', + ), + 'WriteCapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + 'TableSizeBytes' => array( + 'type' => 'numeric', + ), + 'ItemCount' => array( + 'type' => 'numeric', + ), + 'LocalSecondaryIndexes' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'LocalSecondaryIndexDescription', + 'type' => 'object', + 'properties' => array( + 'IndexName' => array( + 'type' => 'string', + ), + 'KeySchema' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'KeySchemaElement', + 'type' => 'object', + 'properties' => array( + 'AttributeName' => array( + 'type' => 'string', + ), + 'KeyType' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Projection' => array( + 'type' => 'object', + 'properties' => array( + 'ProjectionType' => array( + 'type' => 'string', + ), + 'NonKeyAttributes' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NonKeyAttributeName', + 'type' => 'string', + ), + ), + ), + ), + 'IndexSizeBytes' => array( + 'type' => 'numeric', + ), + 'ItemCount' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'GlobalSecondaryIndexes' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'GlobalSecondaryIndexDescription', + 'type' => 'object', + 'properties' => array( + 'IndexName' => array( + 'type' => 'string', + ), + 'KeySchema' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'KeySchemaElement', + 'type' => 'object', + 'properties' => array( + 'AttributeName' => array( + 'type' => 'string', + ), + 'KeyType' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Projection' => array( + 'type' => 'object', + 'properties' => array( + 'ProjectionType' => array( + 'type' => 'string', + ), + 'NonKeyAttributes' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NonKeyAttributeName', + 'type' => 'string', + ), + ), + ), + ), + 'IndexStatus' => array( + 'type' => 'string', + ), + 'ProvisionedThroughput' => array( + 'type' => 'object', + 'properties' => array( + 'LastIncreaseDateTime' => array( + 'type' => 'string', + ), + 'LastDecreaseDateTime' => array( + 'type' => 'string', + ), + 'NumberOfDecreasesToday' => array( + 'type' => 'numeric', + ), + 'ReadCapacityUnits' => array( + 'type' => 'numeric', + ), + 'WriteCapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + 'IndexSizeBytes' => array( + 'type' => 'numeric', + ), + 'ItemCount' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + ), + ), + 'GetItemOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Item' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + ), + ), + ), + ), + 'ConsumedCapacity' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'TableName' => array( + 'type' => 'string', + ), + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + 'Table' => array( + 'type' => 'object', + 'properties' => array( + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + 'LocalSecondaryIndexes' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'GlobalSecondaryIndexes' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + ), + ), + 'ListTablesOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'TableNames' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'TableName', + 'type' => 'string', + ), + ), + 'LastEvaluatedTableName' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'PutItemOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Attributes' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + ), + ), + ), + ), + 'ConsumedCapacity' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'TableName' => array( + 'type' => 'string', + ), + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + 'Table' => array( + 'type' => 'object', + 'properties' => array( + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + 'LocalSecondaryIndexes' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'GlobalSecondaryIndexes' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + 'ItemCollectionMetrics' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'ItemCollectionKey' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + ), + ), + ), + ), + 'SizeEstimateRangeGB' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ItemCollectionSizeEstimateBound', + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + 'QueryOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Items' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'AttributeMap', + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + ), + ), + ), + ), + ), + 'Count' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'ScannedCount' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'LastEvaluatedKey' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + ), + ), + ), + ), + 'ConsumedCapacity' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'TableName' => array( + 'type' => 'string', + ), + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + 'Table' => array( + 'type' => 'object', + 'properties' => array( + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + 'LocalSecondaryIndexes' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'GlobalSecondaryIndexes' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + ), + ), + 'ScanOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Items' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'AttributeMap', + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + ), + ), + ), + ), + ), + 'Count' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'ScannedCount' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'LastEvaluatedKey' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + ), + ), + ), + ), + 'ConsumedCapacity' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'TableName' => array( + 'type' => 'string', + ), + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + 'Table' => array( + 'type' => 'object', + 'properties' => array( + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + 'LocalSecondaryIndexes' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'GlobalSecondaryIndexes' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + ), + ), + 'UpdateItemOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Attributes' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + ), + ), + ), + ), + 'ConsumedCapacity' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'TableName' => array( + 'type' => 'string', + ), + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + 'Table' => array( + 'type' => 'object', + 'properties' => array( + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + 'LocalSecondaryIndexes' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'GlobalSecondaryIndexes' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'CapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + 'ItemCollectionMetrics' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'ItemCollectionKey' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'S' => array( + 'type' => 'string', + ), + 'N' => array( + 'type' => 'string', + ), + 'B' => array( + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + 'SS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StringAttributeValue', + 'type' => 'string', + ), + ), + 'NS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NumberAttributeValue', + 'type' => 'string', + ), + ), + 'BS' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BinaryAttributeValue', + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + ), + ), + ), + ), + 'SizeEstimateRangeGB' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ItemCollectionSizeEstimateBound', + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + 'UpdateTableOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'TableDescription' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'AttributeDefinitions' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AttributeDefinition', + 'type' => 'object', + 'properties' => array( + 'AttributeName' => array( + 'type' => 'string', + ), + 'AttributeType' => array( + 'type' => 'string', + ), + ), + ), + ), + 'TableName' => array( + 'type' => 'string', + ), + 'KeySchema' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'KeySchemaElement', + 'type' => 'object', + 'properties' => array( + 'AttributeName' => array( + 'type' => 'string', + ), + 'KeyType' => array( + 'type' => 'string', + ), + ), + ), + ), + 'TableStatus' => array( + 'type' => 'string', + ), + 'CreationDateTime' => array( + 'type' => 'string', + ), + 'ProvisionedThroughput' => array( + 'type' => 'object', + 'properties' => array( + 'LastIncreaseDateTime' => array( + 'type' => 'string', + ), + 'LastDecreaseDateTime' => array( + 'type' => 'string', + ), + 'NumberOfDecreasesToday' => array( + 'type' => 'numeric', + ), + 'ReadCapacityUnits' => array( + 'type' => 'numeric', + ), + 'WriteCapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + 'TableSizeBytes' => array( + 'type' => 'numeric', + ), + 'ItemCount' => array( + 'type' => 'numeric', + ), + 'LocalSecondaryIndexes' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'LocalSecondaryIndexDescription', + 'type' => 'object', + 'properties' => array( + 'IndexName' => array( + 'type' => 'string', + ), + 'KeySchema' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'KeySchemaElement', + 'type' => 'object', + 'properties' => array( + 'AttributeName' => array( + 'type' => 'string', + ), + 'KeyType' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Projection' => array( + 'type' => 'object', + 'properties' => array( + 'ProjectionType' => array( + 'type' => 'string', + ), + 'NonKeyAttributes' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NonKeyAttributeName', + 'type' => 'string', + ), + ), + ), + ), + 'IndexSizeBytes' => array( + 'type' => 'numeric', + ), + 'ItemCount' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'GlobalSecondaryIndexes' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'GlobalSecondaryIndexDescription', + 'type' => 'object', + 'properties' => array( + 'IndexName' => array( + 'type' => 'string', + ), + 'KeySchema' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'KeySchemaElement', + 'type' => 'object', + 'properties' => array( + 'AttributeName' => array( + 'type' => 'string', + ), + 'KeyType' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Projection' => array( + 'type' => 'object', + 'properties' => array( + 'ProjectionType' => array( + 'type' => 'string', + ), + 'NonKeyAttributes' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NonKeyAttributeName', + 'type' => 'string', + ), + ), + ), + ), + 'IndexStatus' => array( + 'type' => 'string', + ), + 'ProvisionedThroughput' => array( + 'type' => 'object', + 'properties' => array( + 'LastIncreaseDateTime' => array( + 'type' => 'string', + ), + 'LastDecreaseDateTime' => array( + 'type' => 'string', + ), + 'NumberOfDecreasesToday' => array( + 'type' => 'numeric', + ), + 'ReadCapacityUnits' => array( + 'type' => 'numeric', + ), + 'WriteCapacityUnits' => array( + 'type' => 'numeric', + ), + ), + ), + 'IndexSizeBytes' => array( + 'type' => 'numeric', + ), + 'ItemCount' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + ), + ), + ), + '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-sdk-php/src/Aws/DynamoDb/Session/LockingStrategy/AbstractLockingStrategy.php b/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/Session/LockingStrategy/AbstractLockingStrategy.php new file mode 100644 index 0000000..7db4ade --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/DynamoDb/Session/LockingStrategy/LockingStrategyFactory.php b/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/Session/LockingStrategy/LockingStrategyFactory.php new file mode 100644 index 0000000..5d0093b --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/DynamoDb/Session/LockingStrategy/LockingStrategyFactoryInterface.php b/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/Session/LockingStrategy/LockingStrategyFactoryInterface.php new file mode 100644 index 0000000..0834ee3 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/DynamoDb/Session/LockingStrategy/PessimisticLockingStrategy.php b/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/Session/LockingStrategy/PessimisticLockingStrategy.php new file mode 100644 index 0000000..e7c3895 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/DynamoDb/Session/SessionHandler.php b/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/Session/SessionHandler.php new file mode 100644 index 0000000..da0cc8e --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/DynamoDb/Session/SessionHandlerConfig.php b/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/Session/SessionHandlerConfig.php new file mode 100644 index 0000000..e27288f --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/DynamoDb/Session/SessionHandlerInterface.php b/vendor/aws/aws-sdk-php/src/Aws/DynamoDb/Session/SessionHandlerInterface.php new file mode 100644 index 0000000..7710fd0 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Ec2/CopySnapshotListener.php b/vendor/aws/aws-sdk-php/src/Aws/Ec2/CopySnapshotListener.php new file mode 100644 index 0000000..440904a --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Ec2/Ec2Client.php b/vendor/aws/aws-sdk-php/src/Aws/Ec2/Ec2Client.php new file mode 100644 index 0000000..6f310c8 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/Ec2/Ec2Client.php @@ -0,0 +1,268 @@ +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-sdk-php/src/Aws/Ec2/Enum/ContainerFormat.php b/vendor/aws/aws-sdk-php/src/Aws/Ec2/Enum/ContainerFormat.php new file mode 100644 index 0000000..422be1f --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Ec2/Resources/ec2-2014-05-01.php b/vendor/aws/aws-sdk-php/src/Aws/Ec2/Resources/ec2-2014-05-01.php new file mode 100644 index 0000000..f3d69cb --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/Ec2/Resources/ec2-2014-05-01.php @@ -0,0 +1,15795 @@ + '2014-05-01', + 'endpointPrefix' => 'ec2', + 'serviceFullName' => 'Amazon Elastic Compute Cloud', + 'serviceAbbreviation' => 'Amazon EC2', + 'serviceType' => 'query', + 'signatureVersion' => 'v2', + 'namespace' => 'Ec2', + 'regions' => array( + 'us-east-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'ec2.us-east-1.amazonaws.com', + ), + 'us-west-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'ec2.us-west-1.amazonaws.com', + ), + 'us-west-2' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'ec2.us-west-2.amazonaws.com', + ), + 'eu-west-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'ec2.eu-west-1.amazonaws.com', + ), + 'ap-northeast-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'ec2.ap-northeast-1.amazonaws.com', + ), + 'ap-southeast-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'ec2.ap-southeast-1.amazonaws.com', + ), + 'ap-southeast-2' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'ec2.ap-southeast-2.amazonaws.com', + ), + 'sa-east-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'ec2.sa-east-1.amazonaws.com', + ), + 'cn-north-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'ec2.cn-north-1.amazonaws.com.cn', + ), + 'us-gov-west-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'ec2.us-gov-west-1.amazonaws.com', + ), + ), + 'operations' => array( + '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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'VpcPeeringConnectionId' => array( + '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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'NetworkInterfaceId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Description' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SourceDestCheck' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Groups' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'sentAs' => 'GroupSet', + ), + 'Attachment' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + ), + 'DescribeNetworkInterfaces' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DescribeNetworkInterfacesResult', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeNetworkInterfaces', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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', + ), + ), + ), + ), + ), + ), + ), + '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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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', + ), + ), + '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-05-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-05-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'AvailabilityZone' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Image' => array( + 'type' => 'object', + 'location' => 'aws.query', + 'properties' => array( + 'Format' => array( + 'required' => true, + 'type' => 'string', + ), + 'Bytes' => array( + 'required' => true, + 'type' => 'numeric', + ), + 'ImportManifestUrl' => array( + 'required' => true, + 'type' => 'string', + ), + ), + ), + 'Description' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Volume' => array( + 'type' => 'object', + 'location' => 'aws.query', + 'properties' => array( + 'Size' => array( + 'required' => true, + 'type' => 'numeric', + ), + ), + ), + ), + ), + 'ModifyImageAttribute' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ModifyImageAttribute', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-05-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-05-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-05-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-05-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-05-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', + ), + ), + ), + ), + ), + ), + ), + ), + '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-05-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'VolumeId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'AutoEnableIO' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + ), + ), + 'ModifyVpcAttribute' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ModifyVpcAttribute', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-05-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-05-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-05-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-05-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-05-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'ImageLocation' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Name' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Description' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Architecture' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'KernelId' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'RamdiskId' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'RootDeviceName' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'BlockDeviceMappings' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'BlockDeviceMapping', + 'items' => array( + 'name' => 'BlockDeviceMapping', + 'type' => 'object', + 'properties' => array( + 'VirtualName' => array( + 'type' => 'string', + ), + 'DeviceName' => array( + 'type' => 'string', + ), + 'Ebs' => array( + 'type' => 'object', + 'properties' => array( + 'SnapshotId' => array( + 'type' => 'string', + ), + 'VolumeSize' => array( + 'type' => 'numeric', + ), + 'DeleteOnTermination' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'VolumeType' => array( + 'type' => 'string', + ), + 'Iops' => array( + 'type' => 'numeric', + ), + '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-05-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'VpcPeeringConnectionId' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + ), + 'ReleaseAddress' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ReleaseAddress', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-05-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-05-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-05-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-05-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-05-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-05-01', + ), + 'DryRun' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'Instances' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'InstanceId', + 'items' => array( + 'name' => 'InstanceId', + 'type' => 'string', + ), + ), + 'Status' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'StartTime' => array( + 'type' => array( + 'object', + 'string', + 'integer', + ), + 'format' => 'date-time', + 'location' => 'aws.query', + ), + 'EndTime' => array( + 'type' => array( + 'object', + 'string', + 'integer', + ), + 'format' => 'date-time', + 'location' => 'aws.query', + ), + 'ReasonCodes' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'ReasonCode', + 'items' => array( + 'name' => 'ReasonCode', + 'type' => 'string', + ), + ), + 'Description' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + ), + 'RequestSpotInstances' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'RequestSpotInstancesResult', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'RequestSpotInstances', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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-05-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', + ), + ), + ), + ), + ), + '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', + ), + 'DescribeVpcPeeringConnections' => array( + 'result_key' => 'VpcPeeringConnections', + ), + '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', + ), + '__SpotInstanceRequestState' => array( + 'operation' => 'DescribeSpotInstanceRequests', + 'acceptor.path' => 'SpotInstanceRequests/*/Status/Code', + ), + 'SpotInstanceRequestFulfilled' => array( + 'extends' => '__SpotInstanceRequestState', + 'success.value' => 'fulfilled', + 'failure.value' => array( + 'schedule-expired', + 'canceled-before-fulfillment', + 'bad-parameters', + 'system-error', + ) + ), + '__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-sdk-php/src/Aws/ElastiCache/ElastiCacheClient.php b/vendor/aws/aws-sdk-php/src/Aws/ElastiCache/ElastiCacheClient.php new file mode 100644 index 0000000..18cb92e --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/ElastiCache/ElastiCacheClient.php @@ -0,0 +1,101 @@ +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-sdk-php/src/Aws/ElastiCache/Enum/SourceType.php b/vendor/aws/aws-sdk-php/src/Aws/ElastiCache/Enum/SourceType.php new file mode 100644 index 0000000..f5c841b --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/ElastiCache/Enum/SourceType.php @@ -0,0 +1,30 @@ + '2014-03-24', + '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-03-24', + ), + '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-03-24', + ), + '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-03-24', + ), + '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', + ), + 'PreferredAvailabilityZone' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'PreferredMaintenanceWindow' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Port' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'NotificationTopicArn' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'AutoMinorVersionUpgrade' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + '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-03-24', + ), + '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-03-24', + ), + '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-03-24', + ), + '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-03-24', + ), + '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-03-24', + ), + '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-03-24', + ), + '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-03-24', + ), + '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-03-24', + ), + '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-03-24', + ), + '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-03-24', + ), + '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-03-24', + ), + '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-03-24', + ), + '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-03-24', + ), + '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-03-24', + ), + '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-03-24', + ), + '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-03-24', + ), + '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-03-24', + ), + '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-03-24', + ), + '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-03-24', + ), + '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-03-24', + ), + '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-03-24', + ), + '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-03-24', + ), + '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-03-24', + ), + '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-03-24', + ), + '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', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The requested cache cluster is not in the available state.', + 'class' => 'InvalidCacheClusterStateException', + ), + array( + 'reason' => 'The current state of the cache security group does not allow deletion.', + 'class' => 'InvalidCacheSecurityGroupStateException', + ), + array( + 'reason' => 'The requested cache cluster ID does not refer to an existing cache cluster.', + 'class' => 'CacheClusterNotFoundException', + ), + array( + 'reason' => 'The request cannot be processed because it would exceed the allowed number of cache nodes in a single cache cluster.', + 'class' => 'NodeQuotaForClusterExceededException', + ), + array( + 'reason' => 'The request cannot be processed because it would exceed the allowed number of cache nodes per customer.', + 'class' => 'NodeQuotaForCustomerExceededException', + ), + array( + 'reason' => 'The requested cache security group name does not refer to an existing cache security group.', + 'class' => 'CacheSecurityGroupNotFoundException', + ), + array( + 'reason' => 'The requested cache parameter group name does not refer to an existing cache parameter group.', + 'class' => 'CacheParameterGroupNotFoundException', + ), + array( + 'reason' => 'The VPC network is in an invalid state.', + 'class' => 'InvalidVPCNetworkStateException', + ), + array( + 'reason' => 'The value for a parameter is invalid.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'reason' => 'Two or more incompatible parameters were specified.', + 'class' => 'InvalidParameterCombinationException', + ), + ), + ), + 'ModifyCacheParameterGroup' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'CacheParameterGroupNameMessage', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ModifyCacheParameterGroup', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2014-03-24', + ), + '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-03-24', + ), + '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-03-24', + ), + '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-03-24', + ), + '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-03-24', + ), + '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-03-24', + ), + '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-03-24', + ), + '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', + ), + ), + ), + ), + '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', + ), + ), + ), + ), + '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-sdk-php/src/Aws/ElasticBeanstalk/ElasticBeanstalkClient.php b/vendor/aws/aws-sdk-php/src/Aws/ElasticBeanstalk/ElasticBeanstalkClient.php new file mode 100644 index 0000000..a618f32 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/ElasticBeanstalk/ElasticBeanstalkClient.php @@ -0,0 +1,92 @@ +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-sdk-php/src/Aws/ElasticBeanstalk/Enum/ConfigurationDeploymentStatus.php b/vendor/aws/aws-sdk-php/src/Aws/ElasticBeanstalk/Enum/ConfigurationDeploymentStatus.php new file mode 100644 index 0000000..5d67ed1 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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( + '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, + ), + 'OptionSettings' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'OptionSettings.member', + 'items' => array( + 'name' => 'ConfigurationOptionSetting', + 'type' => 'object', + 'properties' => array( + 'Namespace' => array( + 'type' => 'string', + ), + 'OptionName' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + ), + ), + ), + 'OptionsToRemove' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'OptionsToRemove.member', + 'items' => array( + 'name' => 'OptionSpecification', + 'type' => 'object', + 'properties' => array( + 'Namespace' => array( + 'type' => 'string', + ), + 'OptionName' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Unable to perform the specified operation because the user does not have enough privileges for one of more downstream aws services', + 'class' => 'InsufficientPrivilegesException', + ), + ), + ), + 'ValidateConfigurationSettings' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ConfigurationSettingsValidationMessages', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ValidateConfigurationSettings', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-12-01', + ), + 'ApplicationName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 100, + ), + 'TemplateName' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 100, + ), + 'EnvironmentName' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 4, + 'maxLength' => 23, + ), + 'OptionSettings' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'OptionSettings.member', + 'items' => array( + 'name' => 'ConfigurationOptionSetting', + 'type' => 'object', + 'properties' => array( + 'Namespace' => array( + 'type' => 'string', + ), + 'OptionName' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Unable to perform the specified operation because the user does not have enough privileges for one of more downstream aws services', + 'class' => 'InsufficientPrivilegesException', + ), + ), + ), + ), + 'models' => array( + 'CheckDNSAvailabilityResultMessage' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Available' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'FullyQualifiedCNAME' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'ApplicationDescriptionMessage' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Application' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'ApplicationName' => array( + 'type' => 'string', + ), + 'Description' => array( + 'type' => 'string', + ), + 'DateCreated' => array( + 'type' => 'string', + ), + 'DateUpdated' => array( + 'type' => 'string', + ), + 'Versions' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'VersionLabel', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + 'ConfigurationTemplates' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ConfigurationTemplateName', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + ), + ), + ), + ), + 'ApplicationVersionDescriptionMessage' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ApplicationVersion' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'ApplicationName' => array( + 'type' => 'string', + ), + 'Description' => array( + 'type' => 'string', + ), + 'VersionLabel' => array( + 'type' => 'string', + ), + 'SourceBundle' => array( + 'type' => 'object', + 'properties' => array( + 'S3Bucket' => array( + 'type' => 'string', + ), + 'S3Key' => array( + 'type' => 'string', + ), + ), + ), + 'DateCreated' => array( + 'type' => 'string', + ), + 'DateUpdated' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'ConfigurationSettingsDescription' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'SolutionStackName' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'ApplicationName' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'TemplateName' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'Description' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'EnvironmentName' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'DeploymentStatus' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'DateCreated' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'DateUpdated' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'OptionSettings' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'ConfigurationOptionSetting', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Namespace' => array( + 'type' => 'string', + ), + 'OptionName' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'EnvironmentDescription' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'EnvironmentName' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'EnvironmentId' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'ApplicationName' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'VersionLabel' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'SolutionStackName' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'TemplateName' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'Description' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'EndpointURL' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'CNAME' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'DateCreated' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'DateUpdated' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'Status' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'Health' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'Resources' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'LoadBalancer' => array( + 'type' => 'object', + 'properties' => array( + 'LoadBalancerName' => array( + 'type' => 'string', + ), + 'Domain' => array( + 'type' => 'string', + ), + 'Listeners' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Listener', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Protocol' => array( + 'type' => 'string', + ), + 'Port' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + ), + ), + 'Tier' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + 'Type' => array( + 'type' => 'string', + ), + 'Version' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'CreateStorageLocationResultMessage' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'S3Bucket' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'EmptyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + ), + 'ApplicationVersionDescriptionsMessage' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ApplicationVersions' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'ApplicationVersionDescription', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'ApplicationName' => array( + 'type' => 'string', + ), + 'Description' => array( + 'type' => 'string', + ), + 'VersionLabel' => array( + 'type' => 'string', + ), + 'SourceBundle' => array( + 'type' => 'object', + 'properties' => array( + 'S3Bucket' => array( + 'type' => 'string', + ), + 'S3Key' => array( + 'type' => 'string', + ), + ), + ), + 'DateCreated' => array( + 'type' => 'string', + ), + 'DateUpdated' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'ApplicationDescriptionsMessage' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Applications' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'ApplicationDescription', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'ApplicationName' => array( + 'type' => 'string', + ), + 'Description' => array( + 'type' => 'string', + ), + 'DateCreated' => array( + 'type' => 'string', + ), + 'DateUpdated' => array( + 'type' => 'string', + ), + 'Versions' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'VersionLabel', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + 'ConfigurationTemplates' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ConfigurationTemplateName', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + ), + ), + ), + ), + ), + 'ConfigurationOptionsDescription' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'SolutionStackName' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'Options' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'ConfigurationOptionDescription', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Namespace' => array( + 'type' => 'string', + ), + 'Name' => array( + 'type' => 'string', + ), + 'DefaultValue' => array( + 'type' => 'string', + ), + 'ChangeSeverity' => array( + 'type' => 'string', + ), + 'UserDefined' => array( + 'type' => 'boolean', + ), + 'ValueType' => array( + 'type' => 'string', + ), + 'ValueOptions' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ConfigurationOptionPossibleValue', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + 'MinValue' => array( + 'type' => 'numeric', + ), + 'MaxValue' => array( + 'type' => 'numeric', + ), + 'MaxLength' => array( + 'type' => 'numeric', + ), + 'Regex' => array( + 'type' => 'object', + 'properties' => array( + 'Pattern' => array( + 'type' => 'string', + ), + 'Label' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'ConfigurationSettingsDescriptions' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ConfigurationSettings' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'ConfigurationSettingsDescription', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'SolutionStackName' => array( + 'type' => 'string', + ), + 'ApplicationName' => array( + 'type' => 'string', + ), + 'TemplateName' => array( + 'type' => 'string', + ), + 'Description' => array( + 'type' => 'string', + ), + 'EnvironmentName' => array( + 'type' => 'string', + ), + 'DeploymentStatus' => array( + 'type' => 'string', + ), + 'DateCreated' => array( + 'type' => 'string', + ), + 'DateUpdated' => array( + 'type' => 'string', + ), + 'OptionSettings' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ConfigurationOptionSetting', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Namespace' => array( + 'type' => 'string', + ), + 'OptionName' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'EnvironmentResourceDescriptionsMessage' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'EnvironmentResources' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'EnvironmentName' => array( + 'type' => 'string', + ), + 'AutoScalingGroups' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AutoScalingGroup', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Instances' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Instance', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + ), + ), + ), + 'LaunchConfigurations' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'LaunchConfiguration', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + ), + ), + ), + 'LoadBalancers' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'LoadBalancer', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Triggers' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Trigger', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Queues' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Queue', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + 'URL' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'EnvironmentDescriptionsMessage' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Environments' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'EnvironmentDescription', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'EnvironmentName' => array( + 'type' => 'string', + ), + 'EnvironmentId' => array( + 'type' => 'string', + ), + 'ApplicationName' => array( + 'type' => 'string', + ), + 'VersionLabel' => array( + 'type' => 'string', + ), + 'SolutionStackName' => array( + 'type' => 'string', + ), + 'TemplateName' => array( + 'type' => 'string', + ), + 'Description' => array( + 'type' => 'string', + ), + 'EndpointURL' => array( + 'type' => 'string', + ), + 'CNAME' => array( + 'type' => 'string', + ), + 'DateCreated' => array( + 'type' => 'string', + ), + 'DateUpdated' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'Health' => array( + 'type' => 'string', + ), + 'Resources' => array( + 'type' => 'object', + 'properties' => array( + 'LoadBalancer' => array( + 'type' => 'object', + 'properties' => array( + 'LoadBalancerName' => array( + 'type' => 'string', + ), + 'Domain' => array( + 'type' => 'string', + ), + 'Listeners' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Listener', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Protocol' => array( + 'type' => 'string', + ), + 'Port' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + ), + ), + 'Tier' => array( + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + 'Type' => array( + 'type' => 'string', + ), + 'Version' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'EventDescriptionsMessage' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Events' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'EventDescription', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'EventDate' => array( + 'type' => 'string', + ), + 'Message' => array( + 'type' => 'string', + ), + 'ApplicationName' => array( + 'type' => 'string', + ), + 'VersionLabel' => array( + 'type' => 'string', + ), + 'TemplateName' => array( + 'type' => 'string', + ), + 'EnvironmentName' => array( + 'type' => 'string', + ), + 'RequestId' => array( + 'type' => 'string', + ), + 'Severity' => array( + 'type' => 'string', + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'ListAvailableSolutionStacksResultMessage' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'SolutionStacks' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'SolutionStackName', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + 'SolutionStackDetails' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'SolutionStackDescription', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'SolutionStackName' => array( + 'type' => 'string', + ), + 'PermittedFileTypes' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'FileTypeExtension', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + ), + ), + ), + ), + ), + 'RetrieveEnvironmentInfoResultMessage' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'EnvironmentInfo' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'EnvironmentInfoDescription', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'InfoType' => array( + 'type' => 'string', + ), + 'Ec2InstanceId' => array( + 'type' => 'string', + ), + 'SampleTimestamp' => array( + 'type' => 'string', + ), + 'Message' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'ConfigurationSettingsValidationMessages' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Messages' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'ValidationMessage', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Message' => array( + 'type' => 'string', + ), + 'Severity' => array( + 'type' => 'string', + ), + 'Namespace' => array( + 'type' => 'string', + ), + 'OptionName' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'iterators' => array( + '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-sdk-php/src/Aws/ElasticLoadBalancing/ElasticLoadBalancingClient.php b/vendor/aws/aws-sdk-php/src/Aws/ElasticLoadBalancing/ElasticLoadBalancingClient.php new file mode 100644 index 0000000..47753fd --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/ElasticLoadBalancing/ElasticLoadBalancingClient.php @@ -0,0 +1,84 @@ +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-sdk-php/src/Aws/ElasticLoadBalancing/Exception/AccessPointNotFoundException.php b/vendor/aws/aws-sdk-php/src/Aws/ElasticLoadBalancing/Exception/AccessPointNotFoundException.php new file mode 100644 index 0000000..8c94d39 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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( + 'ApplySecurityGroupsToLoadBalancer' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ApplySecurityGroupsToLoadBalancerOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ApplySecurityGroupsToLoadBalancer', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-06-01', + ), + 'LoadBalancerName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SecurityGroups' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'SecurityGroups.member', + 'items' => array( + 'name' => 'SecurityGroupId', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified load balancer could not be found.', + 'class' => 'AccessPointNotFoundException', + ), + array( + 'reason' => 'Requested configuration change is invalid.', + 'class' => 'InvalidConfigurationRequestException', + ), + array( + 'reason' => 'One or more specified security groups do not exist.', + 'class' => 'InvalidSecurityGroupException', + ), + ), + ), + 'AttachLoadBalancerToSubnets' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'AttachLoadBalancerToSubnetsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'AttachLoadBalancerToSubnets', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-06-01', + ), + 'LoadBalancerName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Subnets' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Subnets.member', + 'items' => array( + 'name' => 'SubnetId', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified load balancer could not be found.', + 'class' => 'AccessPointNotFoundException', + ), + array( + 'reason' => 'Requested configuration change is invalid.', + 'class' => 'InvalidConfigurationRequestException', + ), + array( + 'reason' => 'One or more subnets were not found.', + 'class' => 'SubnetNotFoundException', + ), + array( + 'reason' => 'The VPC has no Internet gateway.', + 'class' => 'InvalidSubnetException', + ), + ), + ), + 'ConfigureHealthCheck' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ConfigureHealthCheckOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ConfigureHealthCheck', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-06-01', + ), + 'LoadBalancerName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'HealthCheck' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'aws.query', + 'properties' => array( + 'Target' => array( + 'required' => true, + 'type' => 'string', + ), + 'Interval' => array( + 'required' => true, + 'type' => 'numeric', + 'minimum' => 1, + 'maximum' => 300, + ), + 'Timeout' => array( + 'required' => true, + 'type' => 'numeric', + 'minimum' => 1, + 'maximum' => 300, + ), + 'UnhealthyThreshold' => array( + 'required' => true, + 'type' => 'numeric', + 'minimum' => 2, + 'maximum' => 10, + ), + 'HealthyThreshold' => array( + 'required' => true, + 'type' => 'numeric', + 'minimum' => 2, + 'maximum' => 10, + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified load balancer could not be found.', + 'class' => 'AccessPointNotFoundException', + ), + ), + ), + 'CreateAppCookieStickinessPolicy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateAppCookieStickinessPolicy', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-06-01', + ), + 'LoadBalancerName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'PolicyName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'CookieName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified load balancer could not be found.', + 'class' => 'AccessPointNotFoundException', + ), + array( + 'reason' => 'Policy with the same name exists for this load balancer. Please choose another name.', + 'class' => 'DuplicatePolicyNameException', + ), + array( + 'reason' => 'Quota for number of policies for this load balancer has already been reached.', + 'class' => 'TooManyPoliciesException', + ), + array( + 'reason' => 'Requested configuration change is invalid.', + 'class' => 'InvalidConfigurationRequestException', + ), + ), + ), + 'CreateLBCookieStickinessPolicy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateLBCookieStickinessPolicy', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-06-01', + ), + 'LoadBalancerName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'PolicyName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'CookieExpirationPeriod' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified load balancer could not be found.', + 'class' => 'AccessPointNotFoundException', + ), + array( + 'reason' => 'Policy with the same name exists for this load balancer. Please choose another name.', + 'class' => 'DuplicatePolicyNameException', + ), + array( + 'reason' => 'Quota for number of policies for this load balancer has already been reached.', + 'class' => 'TooManyPoliciesException', + ), + array( + 'reason' => 'Requested configuration change is invalid.', + 'class' => 'InvalidConfigurationRequestException', + ), + ), + ), + 'CreateLoadBalancer' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'CreateAccessPointOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateLoadBalancer', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-06-01', + ), + 'LoadBalancerName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Listeners' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Listeners.member', + 'items' => array( + 'name' => 'Listener', + 'type' => 'object', + 'properties' => array( + 'Protocol' => array( + 'required' => true, + 'type' => 'string', + ), + 'LoadBalancerPort' => array( + 'required' => true, + 'type' => 'numeric', + ), + 'InstanceProtocol' => array( + 'type' => 'string', + ), + 'InstancePort' => array( + 'required' => true, + 'type' => 'numeric', + 'minimum' => 1, + 'maximum' => 65535, + ), + 'SSLCertificateId' => array( + 'type' => 'string', + ), + ), + ), + ), + 'AvailabilityZones' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'AvailabilityZones.member', + 'items' => array( + 'name' => 'AvailabilityZone', + 'type' => 'string', + ), + ), + 'Subnets' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Subnets.member', + 'items' => array( + 'name' => 'SubnetId', + 'type' => 'string', + ), + ), + 'SecurityGroups' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'SecurityGroups.member', + 'items' => array( + 'name' => 'SecurityGroupId', + 'type' => 'string', + ), + ), + 'Scheme' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Load balancer name already exists for this account. Please choose another name.', + 'class' => 'DuplicateAccessPointNameException', + ), + array( + 'reason' => 'The quota for the number of load balancers has already been reached.', + 'class' => 'TooManyAccessPointsException', + ), + array( + 'reason' => 'The specified SSL ID does not refer to a valid SSL certificate in the AWS Identity and Access Management Service.', + 'class' => 'CertificateNotFoundException', + ), + array( + 'reason' => 'Requested configuration change is invalid.', + 'class' => 'InvalidConfigurationRequestException', + ), + array( + 'reason' => 'One or more subnets were not found.', + 'class' => 'SubnetNotFoundException', + ), + array( + 'reason' => 'The VPC has no Internet gateway.', + 'class' => 'InvalidSubnetException', + ), + array( + 'reason' => 'One or more specified security groups do not exist.', + 'class' => 'InvalidSecurityGroupException', + ), + array( + 'reason' => 'Invalid value for scheme. Scheme can only be specified for load balancers in VPC.', + 'class' => 'InvalidSchemeException', + ), + ), + ), + 'CreateLoadBalancerListeners' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateLoadBalancerListeners', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-06-01', + ), + 'LoadBalancerName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Listeners' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Listeners.member', + 'items' => array( + 'name' => 'Listener', + 'type' => 'object', + 'properties' => array( + 'Protocol' => array( + 'required' => true, + 'type' => 'string', + ), + 'LoadBalancerPort' => array( + 'required' => true, + 'type' => 'numeric', + ), + 'InstanceProtocol' => array( + 'type' => 'string', + ), + 'InstancePort' => array( + 'required' => true, + 'type' => 'numeric', + 'minimum' => 1, + 'maximum' => 65535, + ), + 'SSLCertificateId' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified load balancer could not be found.', + 'class' => 'AccessPointNotFoundException', + ), + array( + 'reason' => 'A Listener already exists for the given LoadBalancerName and LoadBalancerPort, but with a different InstancePort, Protocol, or SSLCertificateId.', + 'class' => 'DuplicateListenerException', + ), + array( + 'reason' => 'The specified SSL ID does not refer to a valid SSL certificate in the AWS Identity and Access Management Service.', + 'class' => 'CertificateNotFoundException', + ), + array( + 'reason' => 'Requested configuration change is invalid.', + 'class' => 'InvalidConfigurationRequestException', + ), + ), + ), + 'CreateLoadBalancerPolicy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateLoadBalancerPolicy', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-06-01', + ), + 'LoadBalancerName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'PolicyName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'PolicyTypeName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'PolicyAttributes' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'PolicyAttributes.member', + 'items' => array( + 'name' => 'PolicyAttribute', + 'type' => 'object', + 'properties' => array( + 'AttributeName' => array( + 'type' => 'string', + ), + 'AttributeValue' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified load balancer could not be found.', + 'class' => 'AccessPointNotFoundException', + ), + array( + 'reason' => 'One or more of the specified policy types do not exist.', + 'class' => 'PolicyTypeNotFoundException', + ), + array( + 'reason' => 'Policy with the same name exists for this load balancer. Please choose another name.', + 'class' => 'DuplicatePolicyNameException', + ), + array( + 'reason' => 'Quota for number of policies for this load balancer has already been reached.', + 'class' => 'TooManyPoliciesException', + ), + array( + 'reason' => 'Requested configuration change is invalid.', + 'class' => 'InvalidConfigurationRequestException', + ), + ), + ), + 'DeleteLoadBalancer' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteLoadBalancer', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-06-01', + ), + 'LoadBalancerName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + ), + 'DeleteLoadBalancerListeners' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteLoadBalancerListeners', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-06-01', + ), + 'LoadBalancerName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'LoadBalancerPorts' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'LoadBalancerPorts.member', + 'items' => array( + 'name' => 'AccessPointPort', + 'type' => 'numeric', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified load balancer could not be found.', + 'class' => 'AccessPointNotFoundException', + ), + ), + ), + 'DeleteLoadBalancerPolicy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteLoadBalancerPolicy', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-06-01', + ), + 'LoadBalancerName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'PolicyName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified load balancer could not be found.', + 'class' => 'AccessPointNotFoundException', + ), + array( + 'reason' => 'Requested configuration change is invalid.', + 'class' => 'InvalidConfigurationRequestException', + ), + ), + ), + 'DeregisterInstancesFromLoadBalancer' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DeregisterEndPointsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeregisterInstancesFromLoadBalancer', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-06-01', + ), + 'LoadBalancerName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Instances' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Instances.member', + 'items' => array( + 'name' => 'Instance', + 'type' => 'object', + 'properties' => array( + 'InstanceId' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified load balancer could not be found.', + 'class' => 'AccessPointNotFoundException', + ), + array( + 'reason' => 'The specified EndPoint is not valid.', + 'class' => 'InvalidEndPointException', + ), + ), + ), + 'DescribeInstanceHealth' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DescribeEndPointStateOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeInstanceHealth', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-06-01', + ), + 'LoadBalancerName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Instances' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Instances.member', + 'items' => array( + 'name' => 'Instance', + 'type' => 'object', + 'properties' => array( + 'InstanceId' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified load balancer could not be found.', + 'class' => 'AccessPointNotFoundException', + ), + array( + 'reason' => 'The specified EndPoint is not valid.', + 'class' => 'InvalidEndPointException', + ), + ), + ), + 'DescribeLoadBalancerAttributes' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DescribeLoadBalancerAttributesOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeLoadBalancerAttributes', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-06-01', + ), + 'LoadBalancerName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified load balancer could not be found.', + 'class' => 'AccessPointNotFoundException', + ), + array( + 'reason' => 'The specified load balancer attribute could not be found.', + 'class' => 'LoadBalancerAttributeNotFoundException', + ), + ), + ), + 'DescribeLoadBalancerPolicies' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DescribeLoadBalancerPoliciesOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeLoadBalancerPolicies', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-06-01', + ), + 'LoadBalancerName' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'PolicyNames' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'PolicyNames.member', + 'items' => array( + 'name' => 'PolicyName', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified load balancer could not be found.', + 'class' => 'AccessPointNotFoundException', + ), + array( + 'reason' => 'One or more specified policies were not found.', + 'class' => 'PolicyNotFoundException', + ), + ), + ), + 'DescribeLoadBalancerPolicyTypes' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DescribeLoadBalancerPolicyTypesOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeLoadBalancerPolicyTypes', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-06-01', + ), + 'PolicyTypeNames' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'PolicyTypeNames.member', + 'items' => array( + 'name' => 'PolicyTypeName', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'One or more of the specified policy types do not exist.', + 'class' => 'PolicyTypeNotFoundException', + ), + ), + ), + 'DescribeLoadBalancers' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DescribeAccessPointsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeLoadBalancers', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-06-01', + ), + 'LoadBalancerNames' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'LoadBalancerNames.member', + 'items' => array( + 'name' => 'AccessPointName', + 'type' => 'string', + ), + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified load balancer could not be found.', + 'class' => 'AccessPointNotFoundException', + ), + ), + ), + 'DetachLoadBalancerFromSubnets' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DetachLoadBalancerFromSubnetsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DetachLoadBalancerFromSubnets', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-06-01', + ), + 'LoadBalancerName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Subnets' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Subnets.member', + 'items' => array( + 'name' => 'SubnetId', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified load balancer could not be found.', + 'class' => 'AccessPointNotFoundException', + ), + array( + 'reason' => 'Requested configuration change is invalid.', + 'class' => 'InvalidConfigurationRequestException', + ), + ), + ), + 'DisableAvailabilityZonesForLoadBalancer' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'RemoveAvailabilityZonesOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DisableAvailabilityZonesForLoadBalancer', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-06-01', + ), + 'LoadBalancerName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'AvailabilityZones' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'AvailabilityZones.member', + 'items' => array( + 'name' => 'AvailabilityZone', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified load balancer could not be found.', + 'class' => 'AccessPointNotFoundException', + ), + array( + 'reason' => 'Requested configuration change is invalid.', + 'class' => 'InvalidConfigurationRequestException', + ), + ), + ), + 'EnableAvailabilityZonesForLoadBalancer' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'AddAvailabilityZonesOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'EnableAvailabilityZonesForLoadBalancer', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-06-01', + ), + 'LoadBalancerName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'AvailabilityZones' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'AvailabilityZones.member', + 'items' => array( + 'name' => 'AvailabilityZone', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified load balancer could not be found.', + 'class' => 'AccessPointNotFoundException', + ), + ), + ), + 'ModifyLoadBalancerAttributes' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => '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', + ), + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified load balancer could not be found.', + 'class' => 'AccessPointNotFoundException', + ), + array( + 'reason' => 'The specified load balancer attribute could not be found.', + 'class' => 'LoadBalancerAttributeNotFoundException', + ), + array( + 'reason' => 'Requested configuration change is invalid.', + 'class' => 'InvalidConfigurationRequestException', + ), + ), + ), + 'RegisterInstancesWithLoadBalancer' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'RegisterEndPointsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'RegisterInstancesWithLoadBalancer', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-06-01', + ), + 'LoadBalancerName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Instances' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Instances.member', + 'items' => array( + 'name' => 'Instance', + 'type' => 'object', + 'properties' => array( + 'InstanceId' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified load balancer could not be found.', + 'class' => 'AccessPointNotFoundException', + ), + array( + 'reason' => 'The specified EndPoint is not valid.', + 'class' => 'InvalidEndPointException', + ), + ), + ), + 'SetLoadBalancerListenerSSLCertificate' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'SetLoadBalancerListenerSSLCertificate', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-06-01', + ), + 'LoadBalancerName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'LoadBalancerPort' => array( + 'required' => true, + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'SSLCertificateId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified SSL ID does not refer to a valid SSL certificate in the AWS Identity and Access Management Service.', + 'class' => 'CertificateNotFoundException', + ), + array( + 'reason' => 'The specified load balancer could not be found.', + 'class' => 'AccessPointNotFoundException', + ), + array( + 'reason' => 'Load balancer does not have a listener configured at the given port.', + 'class' => 'ListenerNotFoundException', + ), + array( + 'reason' => 'Requested configuration change is invalid.', + 'class' => 'InvalidConfigurationRequestException', + ), + ), + ), + 'SetLoadBalancerPoliciesForBackendServer' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'SetLoadBalancerPoliciesForBackendServer', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-06-01', + ), + 'LoadBalancerName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'InstancePort' => array( + 'required' => true, + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'PolicyNames' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'PolicyNames.member', + 'items' => array( + 'name' => 'PolicyName', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified load balancer could not be found.', + 'class' => 'AccessPointNotFoundException', + ), + array( + 'reason' => 'One or more specified policies were not found.', + 'class' => 'PolicyNotFoundException', + ), + array( + 'reason' => 'Requested configuration change is invalid.', + 'class' => 'InvalidConfigurationRequestException', + ), + ), + ), + 'SetLoadBalancerPoliciesOfListener' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'SetLoadBalancerPoliciesOfListener', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-06-01', + ), + 'LoadBalancerName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'LoadBalancerPort' => array( + 'required' => true, + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'PolicyNames' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'PolicyNames.member', + 'items' => array( + 'name' => 'PolicyName', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified load balancer could not be found.', + 'class' => 'AccessPointNotFoundException', + ), + array( + 'reason' => 'One or more specified policies were not found.', + 'class' => 'PolicyNotFoundException', + ), + array( + 'reason' => 'Load balancer does not have a listener configured at the given port.', + 'class' => 'ListenerNotFoundException', + ), + array( + 'reason' => 'Requested configuration change is invalid.', + 'class' => 'InvalidConfigurationRequestException', + ), + ), + ), + ), + 'models' => array( + 'ApplySecurityGroupsToLoadBalancerOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'SecurityGroups' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'SecurityGroupId', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + ), + ), + 'AttachLoadBalancerToSubnetsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Subnets' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'SubnetId', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + ), + ), + 'ConfigureHealthCheckOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'HealthCheck' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Target' => array( + 'type' => 'string', + ), + 'Interval' => array( + 'type' => 'numeric', + ), + 'Timeout' => array( + 'type' => 'numeric', + ), + 'UnhealthyThreshold' => array( + 'type' => 'numeric', + ), + 'HealthyThreshold' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + 'EmptyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + ), + 'CreateAccessPointOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'DNSName' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'DeregisterEndPointsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Instances' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'Instance', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'InstanceId' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'DescribeEndPointStateOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'InstanceStates' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'InstanceState', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'InstanceId' => array( + 'type' => 'string', + ), + 'State' => array( + 'type' => 'string', + ), + 'ReasonCode' => array( + 'type' => 'string', + ), + 'Description' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'DescribeLoadBalancerAttributesOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'LoadBalancerAttributes' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'CrossZoneLoadBalancing' => array( + 'type' => 'object', + 'properties' => array( + 'Enabled' => array( + 'type' => 'boolean', + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + ), + 'DescribeLoadBalancerPoliciesOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'PolicyDescriptions' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'PolicyDescription', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'PolicyName' => array( + 'type' => 'string', + ), + 'PolicyTypeName' => array( + 'type' => 'string', + ), + 'PolicyAttributeDescriptions' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'PolicyAttributeDescription', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'AttributeName' => array( + 'type' => 'string', + ), + 'AttributeValue' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'DescribeLoadBalancerPolicyTypesOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'PolicyTypeDescriptions' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'PolicyTypeDescription', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'PolicyTypeName' => array( + 'type' => 'string', + ), + 'Description' => array( + 'type' => 'string', + ), + 'PolicyAttributeTypeDescriptions' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'PolicyAttributeTypeDescription', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'AttributeName' => array( + 'type' => 'string', + ), + 'AttributeType' => array( + 'type' => 'string', + ), + 'Description' => array( + 'type' => 'string', + ), + 'DefaultValue' => array( + 'type' => 'string', + ), + 'Cardinality' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'DescribeAccessPointsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'LoadBalancerDescriptions' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'LoadBalancerDescription', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'LoadBalancerName' => array( + 'type' => 'string', + ), + 'DNSName' => array( + 'type' => 'string', + ), + 'CanonicalHostedZoneName' => array( + 'type' => 'string', + ), + 'CanonicalHostedZoneNameID' => array( + 'type' => 'string', + ), + 'ListenerDescriptions' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ListenerDescription', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Listener' => array( + 'type' => 'object', + 'properties' => array( + 'Protocol' => array( + 'type' => 'string', + ), + 'LoadBalancerPort' => array( + 'type' => 'numeric', + ), + 'InstanceProtocol' => array( + 'type' => 'string', + ), + 'InstancePort' => array( + 'type' => 'numeric', + ), + 'SSLCertificateId' => array( + 'type' => 'string', + ), + ), + ), + 'PolicyNames' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'PolicyName', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + ), + ), + ), + 'Policies' => array( + 'type' => 'object', + 'properties' => array( + 'AppCookieStickinessPolicies' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AppCookieStickinessPolicy', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'PolicyName' => array( + 'type' => 'string', + ), + 'CookieName' => array( + 'type' => 'string', + ), + ), + ), + ), + 'LBCookieStickinessPolicies' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'LBCookieStickinessPolicy', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'PolicyName' => array( + 'type' => 'string', + ), + 'CookieExpirationPeriod' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'OtherPolicies' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'PolicyName', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + ), + ), + 'BackendServerDescriptions' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BackendServerDescription', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'InstancePort' => array( + 'type' => 'numeric', + ), + 'PolicyNames' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'PolicyName', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + ), + ), + ), + 'AvailabilityZones' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AvailabilityZone', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + 'Subnets' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'SubnetId', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + 'VPCId' => array( + 'type' => 'string', + ), + 'Instances' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Instance', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'InstanceId' => array( + 'type' => 'string', + ), + ), + ), + ), + 'HealthCheck' => array( + 'type' => 'object', + 'properties' => array( + 'Target' => array( + 'type' => 'string', + ), + 'Interval' => array( + 'type' => 'numeric', + ), + 'Timeout' => array( + 'type' => 'numeric', + ), + 'UnhealthyThreshold' => array( + 'type' => 'numeric', + ), + 'HealthyThreshold' => array( + 'type' => 'numeric', + ), + ), + ), + 'SourceSecurityGroup' => array( + 'type' => 'object', + 'properties' => array( + 'OwnerAlias' => array( + 'type' => 'string', + ), + 'GroupName' => array( + 'type' => 'string', + ), + ), + ), + 'SecurityGroups' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'SecurityGroupId', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + 'CreatedTime' => array( + 'type' => 'string', + ), + 'Scheme' => array( + 'type' => 'string', + ), + ), + ), + ), + 'NextMarker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'DetachLoadBalancerFromSubnetsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Subnets' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'SubnetId', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + ), + ), + 'RemoveAvailabilityZonesOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'AvailabilityZones' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'AvailabilityZone', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + ), + ), + 'AddAvailabilityZonesOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'AvailabilityZones' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'AvailabilityZone', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + ), + ), + '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', + ), + ), + ), + ), + ), + ), + ), + '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', + ), + ), +); diff --git a/vendor/aws/aws-sdk-php/src/Aws/ElasticTranscoder/ElasticTranscoderClient.php b/vendor/aws/aws-sdk-php/src/Aws/ElasticTranscoder/ElasticTranscoderClient.php new file mode 100644 index 0000000..027d9da --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/ElasticTranscoder/Exception/AccessDeniedException.php b/vendor/aws/aws-sdk-php/src/Aws/ElasticTranscoder/Exception/AccessDeniedException.php new file mode 100644 index 0000000..bdba28f --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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( + 'type' => 'string', + 'location' => 'json', + ), + 'Input' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'FrameRate' => array( + 'type' => 'string', + ), + 'Resolution' => array( + 'type' => 'string', + ), + 'AspectRatio' => array( + 'type' => 'string', + ), + 'Interlaced' => array( + 'type' => 'string', + ), + 'Container' => array( + 'type' => 'string', + ), + ), + ), + 'Output' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'ThumbnailPattern' => array( + 'type' => 'string', + ), + 'Rotate' => array( + 'type' => 'string', + ), + 'PresetId' => array( + 'type' => 'string', + ), + 'SegmentDuration' => array( + 'type' => 'string', + ), + 'Watermarks' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'JobWatermark', + 'type' => 'object', + 'properties' => array( + 'PresetWatermarkId' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 40, + ), + 'InputKey' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + ), + ), + ), + 'AlbumArt' => array( + 'type' => 'object', + 'properties' => array( + 'MergePolicy' => array( + 'type' => 'string', + ), + 'Artwork' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Artwork', + 'type' => 'object', + 'properties' => array( + 'InputKey' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'MaxWidth' => array( + 'type' => 'string', + ), + 'MaxHeight' => array( + 'type' => 'string', + ), + 'SizingPolicy' => array( + 'type' => 'string', + ), + 'PaddingPolicy' => array( + 'type' => 'string', + ), + 'AlbumArtFormat' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'Composition' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Clip', + 'type' => 'object', + 'properties' => array( + 'TimeSpan' => array( + 'type' => 'object', + 'properties' => array( + 'StartTime' => array( + 'type' => 'string', + ), + 'Duration' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'Outputs' => array( + 'type' => 'array', + 'location' => 'json', + 'maxItems' => 30, + 'items' => array( + 'name' => 'CreateJobOutput', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'ThumbnailPattern' => array( + 'type' => 'string', + ), + 'Rotate' => array( + 'type' => 'string', + ), + 'PresetId' => array( + 'type' => 'string', + ), + 'SegmentDuration' => array( + 'type' => 'string', + ), + 'Watermarks' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'JobWatermark', + 'type' => 'object', + 'properties' => array( + 'PresetWatermarkId' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 40, + ), + 'InputKey' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + ), + ), + ), + 'AlbumArt' => array( + 'type' => 'object', + 'properties' => array( + 'MergePolicy' => array( + 'type' => 'string', + ), + 'Artwork' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Artwork', + 'type' => 'object', + 'properties' => array( + 'InputKey' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'MaxWidth' => array( + 'type' => 'string', + ), + 'MaxHeight' => array( + 'type' => 'string', + ), + 'SizingPolicy' => array( + 'type' => 'string', + ), + 'PaddingPolicy' => array( + 'type' => 'string', + ), + 'AlbumArtFormat' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'Composition' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Clip', + 'type' => 'object', + 'properties' => array( + 'TimeSpan' => array( + 'type' => 'object', + 'properties' => array( + 'StartTime' => array( + 'type' => 'string', + ), + 'Duration' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'OutputKeyPrefix' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'Playlists' => array( + 'type' => 'array', + 'location' => 'json', + 'maxItems' => 30, + 'items' => array( + 'name' => 'CreateJobPlaylist', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'Format' => array( + 'type' => 'string', + ), + 'OutputKeys' => array( + 'type' => 'array', + 'maxItems' => 30, + 'items' => array( + 'name' => 'Key', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'One or more required parameter values were not provided in the request.', + 'class' => 'ValidationException', + ), + array( + 'class' => 'IncompatibleVersionException', + ), + array( + 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'General authentication failure. The request was not signed correctly.', + 'class' => 'AccessDeniedException', + ), + array( + 'reason' => 'Too many operations for a given AWS account. For example, the number of pipelines exceeds the maximum allowed.', + 'class' => 'LimitExceededException', + ), + array( + 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', + 'class' => 'InternalServiceException', + ), + ), + ), + 'CreatePipeline' => array( + 'httpMethod' => 'POST', + 'uri' => '/2012-09-25/pipelines', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'CreatePipelineResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Name' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 40, + ), + 'InputBucket' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'OutputBucket' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Role' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Notifications' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Progressing' => array( + 'type' => 'string', + ), + 'Completed' => array( + 'type' => 'string', + ), + 'Warning' => array( + 'type' => 'string', + ), + 'Error' => array( + 'type' => 'string', + ), + ), + ), + 'ContentConfig' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Bucket' => array( + 'type' => 'string', + ), + 'StorageClass' => array( + 'type' => 'string', + ), + 'Permissions' => array( + 'type' => 'array', + 'maxItems' => 30, + 'items' => array( + 'name' => 'Permission', + 'type' => 'object', + 'properties' => array( + 'GranteeType' => array( + 'type' => 'string', + ), + 'Grantee' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'Access' => array( + 'type' => 'array', + 'maxItems' => 30, + 'items' => array( + 'name' => 'AccessControl', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'ThumbnailConfig' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Bucket' => array( + 'type' => 'string', + ), + 'StorageClass' => array( + 'type' => 'string', + ), + 'Permissions' => array( + 'type' => 'array', + 'maxItems' => 30, + 'items' => array( + 'name' => 'Permission', + 'type' => 'object', + 'properties' => array( + 'GranteeType' => array( + 'type' => 'string', + ), + 'Grantee' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'Access' => array( + 'type' => 'array', + 'maxItems' => 30, + 'items' => array( + 'name' => 'AccessControl', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'One or more required parameter values were not provided in the request.', + 'class' => 'ValidationException', + ), + array( + 'class' => 'IncompatibleVersionException', + ), + array( + 'reason' => 'General authentication failure. The request was not signed correctly.', + 'class' => 'AccessDeniedException', + ), + array( + 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Too many operations for a given AWS account. For example, the number of pipelines exceeds the maximum allowed.', + 'class' => 'LimitExceededException', + ), + array( + 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', + 'class' => 'InternalServiceException', + ), + ), + ), + 'CreatePreset' => array( + 'httpMethod' => 'POST', + 'uri' => '/2012-09-25/presets', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'CreatePresetResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Name' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 40, + ), + 'Description' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 255, + ), + 'Container' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Video' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Codec' => array( + 'type' => 'string', + ), + 'CodecOptions' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + 'data' => array( + 'shape_name' => 'CodecOption', + ), + ), + ), + 'KeyframesMaxDist' => array( + 'type' => 'string', + ), + 'FixedGOP' => array( + 'type' => 'string', + ), + 'BitRate' => array( + 'type' => 'string', + ), + 'FrameRate' => array( + 'type' => 'string', + ), + 'MaxFrameRate' => array( + 'type' => 'string', + ), + 'Resolution' => array( + 'type' => 'string', + ), + 'AspectRatio' => array( + 'type' => 'string', + ), + 'MaxWidth' => array( + 'type' => 'string', + ), + 'MaxHeight' => array( + 'type' => 'string', + ), + 'DisplayAspectRatio' => array( + 'type' => 'string', + ), + 'SizingPolicy' => array( + 'type' => 'string', + ), + 'PaddingPolicy' => array( + 'type' => 'string', + ), + 'Watermarks' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'PresetWatermark', + 'type' => 'object', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 40, + ), + 'MaxWidth' => array( + 'type' => 'string', + ), + 'MaxHeight' => array( + 'type' => 'string', + ), + 'SizingPolicy' => array( + 'type' => 'string', + ), + 'HorizontalAlign' => array( + 'type' => 'string', + ), + 'HorizontalOffset' => array( + 'type' => 'string', + ), + 'VerticalAlign' => array( + 'type' => 'string', + ), + 'VerticalOffset' => array( + 'type' => 'string', + ), + 'Opacity' => array( + 'type' => 'string', + ), + 'Target' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'Audio' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Codec' => array( + 'type' => 'string', + ), + 'SampleRate' => array( + 'type' => 'string', + ), + 'BitRate' => array( + 'type' => 'string', + ), + 'Channels' => array( + 'type' => 'string', + ), + 'CodecOptions' => array( + 'type' => 'object', + 'properties' => array( + 'Profile' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'Thumbnails' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Format' => array( + 'type' => 'string', + ), + 'Interval' => array( + 'type' => 'string', + ), + 'Resolution' => array( + 'type' => 'string', + ), + 'AspectRatio' => array( + 'type' => 'string', + ), + 'MaxWidth' => array( + 'type' => 'string', + ), + 'MaxHeight' => array( + 'type' => 'string', + ), + 'SizingPolicy' => array( + 'type' => 'string', + ), + 'PaddingPolicy' => array( + 'type' => 'string', + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'One or more required parameter values were not provided in the request.', + 'class' => 'ValidationException', + ), + array( + 'class' => 'IncompatibleVersionException', + ), + array( + 'reason' => 'General authentication failure. The request was not signed correctly.', + 'class' => 'AccessDeniedException', + ), + array( + 'reason' => 'Too many operations for a given AWS account. For example, the number of pipelines exceeds the maximum allowed.', + 'class' => 'LimitExceededException', + ), + array( + 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', + 'class' => 'InternalServiceException', + ), + ), + ), + 'DeletePipeline' => array( + 'httpMethod' => 'DELETE', + 'uri' => '/2012-09-25/pipelines/{Id}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Id' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'One or more required parameter values were not provided in the request.', + 'class' => 'ValidationException', + ), + array( + 'class' => 'IncompatibleVersionException', + ), + array( + 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'The resource you are attempting to change is in use. For example, you are attempting to delete a pipeline that is currently in use.', + 'class' => 'ResourceInUseException', + ), + array( + 'reason' => 'General authentication failure. The request was not signed correctly.', + 'class' => 'AccessDeniedException', + ), + array( + 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', + 'class' => 'InternalServiceException', + ), + ), + ), + 'DeletePreset' => array( + 'httpMethod' => 'DELETE', + 'uri' => '/2012-09-25/presets/{Id}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Id' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'One or more required parameter values were not provided in the request.', + 'class' => 'ValidationException', + ), + array( + 'class' => 'IncompatibleVersionException', + ), + array( + 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'General authentication failure. The request was not signed correctly.', + 'class' => 'AccessDeniedException', + ), + array( + 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', + 'class' => 'InternalServiceException', + ), + ), + ), + 'ListJobsByPipeline' => array( + 'httpMethod' => 'GET', + 'uri' => '/2012-09-25/jobsByPipeline/{PipelineId}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'ListJobsByPipelineResponse', + 'responseType' => 'model', + 'parameters' => array( + 'PipelineId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'Ascending' => array( + 'type' => 'string', + 'location' => 'query', + ), + 'PageToken' => array( + 'type' => 'string', + 'location' => 'query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'One or more required parameter values were not provided in the request.', + 'class' => 'ValidationException', + ), + array( + 'class' => 'IncompatibleVersionException', + ), + array( + 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'General authentication failure. The request was not signed correctly.', + 'class' => 'AccessDeniedException', + ), + array( + 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', + 'class' => 'InternalServiceException', + ), + ), + ), + 'ListJobsByStatus' => array( + 'httpMethod' => 'GET', + 'uri' => '/2012-09-25/jobsByStatus/{Status}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'ListJobsByStatusResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Status' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'Ascending' => array( + 'type' => 'string', + 'location' => 'query', + ), + 'PageToken' => array( + 'type' => 'string', + 'location' => 'query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'One or more required parameter values were not provided in the request.', + 'class' => 'ValidationException', + ), + array( + 'class' => 'IncompatibleVersionException', + ), + array( + 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'General authentication failure. The request was not signed correctly.', + 'class' => 'AccessDeniedException', + ), + array( + 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', + 'class' => 'InternalServiceException', + ), + ), + ), + 'ListPipelines' => array( + 'httpMethod' => 'GET', + 'uri' => '/2012-09-25/pipelines', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'ListPipelinesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Ascending' => array( + 'type' => 'string', + 'location' => 'query', + ), + 'PageToken' => array( + 'type' => 'string', + 'location' => 'query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'One or more required parameter values were not provided in the request.', + 'class' => 'ValidationException', + ), + array( + 'class' => 'IncompatibleVersionException', + ), + array( + 'reason' => 'General authentication failure. The request was not signed correctly.', + 'class' => 'AccessDeniedException', + ), + array( + 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', + 'class' => 'InternalServiceException', + ), + ), + ), + 'ListPresets' => array( + 'httpMethod' => 'GET', + 'uri' => '/2012-09-25/presets', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'ListPresetsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Ascending' => array( + 'type' => 'string', + 'location' => 'query', + ), + 'PageToken' => array( + 'type' => 'string', + 'location' => 'query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'One or more required parameter values were not provided in the request.', + 'class' => 'ValidationException', + ), + array( + 'class' => 'IncompatibleVersionException', + ), + array( + 'reason' => 'General authentication failure. The request was not signed correctly.', + 'class' => 'AccessDeniedException', + ), + array( + 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', + 'class' => 'InternalServiceException', + ), + ), + ), + 'ReadJob' => array( + 'httpMethod' => 'GET', + 'uri' => '/2012-09-25/jobs/{Id}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'ReadJobResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Id' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'One or more required parameter values were not provided in the request.', + 'class' => 'ValidationException', + ), + array( + 'class' => 'IncompatibleVersionException', + ), + array( + 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'General authentication failure. The request was not signed correctly.', + 'class' => 'AccessDeniedException', + ), + array( + 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', + 'class' => 'InternalServiceException', + ), + ), + ), + 'ReadPipeline' => array( + 'httpMethod' => 'GET', + 'uri' => '/2012-09-25/pipelines/{Id}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'ReadPipelineResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Id' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'One or more required parameter values were not provided in the request.', + 'class' => 'ValidationException', + ), + array( + 'class' => 'IncompatibleVersionException', + ), + array( + 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'General authentication failure. The request was not signed correctly.', + 'class' => 'AccessDeniedException', + ), + array( + 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', + 'class' => 'InternalServiceException', + ), + ), + ), + 'ReadPreset' => array( + 'httpMethod' => 'GET', + 'uri' => '/2012-09-25/presets/{Id}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'ReadPresetResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Id' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'One or more required parameter values were not provided in the request.', + 'class' => 'ValidationException', + ), + array( + 'class' => 'IncompatibleVersionException', + ), + array( + 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'General authentication failure. The request was not signed correctly.', + 'class' => 'AccessDeniedException', + ), + array( + 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', + 'class' => 'InternalServiceException', + ), + ), + ), + 'TestRole' => array( + 'httpMethod' => 'POST', + 'uri' => '/2012-09-25/roleTests', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'TestRoleResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Role' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'InputBucket' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'OutputBucket' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Topics' => array( + 'type' => 'array', + 'location' => 'json', + 'maxItems' => 30, + 'items' => array( + 'name' => 'SnsTopic', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'One or more required parameter values were not provided in the request.', + 'class' => 'ValidationException', + ), + array( + 'class' => 'IncompatibleVersionException', + ), + array( + 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'General authentication failure. The request was not signed correctly.', + 'class' => 'AccessDeniedException', + ), + array( + 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', + 'class' => 'InternalServiceException', + ), + ), + ), + 'UpdatePipeline' => array( + 'httpMethod' => 'PUT', + 'uri' => '/2012-09-25/pipelines/{Id}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'UpdatePipelineResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Id' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'Name' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 40, + ), + 'InputBucket' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Role' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Notifications' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Progressing' => array( + 'type' => 'string', + ), + 'Completed' => array( + 'type' => 'string', + ), + 'Warning' => array( + 'type' => 'string', + ), + 'Error' => array( + 'type' => 'string', + ), + ), + ), + 'ContentConfig' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Bucket' => array( + 'type' => 'string', + ), + 'StorageClass' => array( + 'type' => 'string', + ), + 'Permissions' => array( + 'type' => 'array', + 'maxItems' => 30, + 'items' => array( + 'name' => 'Permission', + 'type' => 'object', + 'properties' => array( + 'GranteeType' => array( + 'type' => 'string', + ), + 'Grantee' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'Access' => array( + 'type' => 'array', + 'maxItems' => 30, + 'items' => array( + 'name' => 'AccessControl', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'ThumbnailConfig' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Bucket' => array( + 'type' => 'string', + ), + 'StorageClass' => array( + 'type' => 'string', + ), + 'Permissions' => array( + 'type' => 'array', + 'maxItems' => 30, + 'items' => array( + 'name' => 'Permission', + 'type' => 'object', + 'properties' => array( + 'GranteeType' => array( + 'type' => 'string', + ), + 'Grantee' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'Access' => array( + 'type' => 'array', + 'maxItems' => 30, + 'items' => array( + 'name' => 'AccessControl', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'One or more required parameter values were not provided in the request.', + 'class' => 'ValidationException', + ), + array( + 'class' => 'IncompatibleVersionException', + ), + array( + 'reason' => 'General authentication failure. The request was not signed correctly.', + 'class' => 'AccessDeniedException', + ), + array( + 'reason' => 'The resource you are attempting to change is in use. For example, you are attempting to delete a pipeline that is currently in use.', + 'class' => 'ResourceInUseException', + ), + array( + 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', + 'class' => 'InternalServiceException', + ), + ), + ), + 'UpdatePipelineNotifications' => array( + 'httpMethod' => 'POST', + 'uri' => '/2012-09-25/pipelines/{Id}/notifications', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'UpdatePipelineNotificationsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Id' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'Notifications' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Progressing' => array( + 'type' => 'string', + ), + 'Completed' => array( + 'type' => 'string', + ), + 'Warning' => array( + 'type' => 'string', + ), + 'Error' => array( + 'type' => 'string', + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'One or more required parameter values were not provided in the request.', + 'class' => 'ValidationException', + ), + array( + 'class' => 'IncompatibleVersionException', + ), + array( + 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'The resource you are attempting to change is in use. For example, you are attempting to delete a pipeline that is currently in use.', + 'class' => 'ResourceInUseException', + ), + array( + 'reason' => 'General authentication failure. The request was not signed correctly.', + 'class' => 'AccessDeniedException', + ), + array( + 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', + 'class' => 'InternalServiceException', + ), + ), + ), + 'UpdatePipelineStatus' => array( + 'httpMethod' => 'POST', + 'uri' => '/2012-09-25/pipelines/{Id}/status', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'UpdatePipelineStatusResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Id' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'Status' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'One or more required parameter values were not provided in the request.', + 'class' => 'ValidationException', + ), + array( + 'class' => 'IncompatibleVersionException', + ), + array( + 'reason' => 'The requested resource does not exist or is not available. For example, the pipeline to which you\'re trying to add a job doesn\'t exist or is still being created.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'The resource you are attempting to change is in use. For example, you are attempting to delete a pipeline that is currently in use.', + 'class' => 'ResourceInUseException', + ), + array( + 'reason' => 'General authentication failure. The request was not signed correctly.', + 'class' => 'AccessDeniedException', + ), + array( + 'reason' => 'Elastic Transcoder encountered an unexpected exception while trying to fulfill the request.', + 'class' => 'InternalServiceException', + ), + ), + ), + ), + 'models' => array( + 'EmptyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + ), + 'CreateJobResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Job' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'PipelineId' => array( + 'type' => 'string', + ), + 'Input' => array( + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'FrameRate' => array( + 'type' => 'string', + ), + 'Resolution' => array( + 'type' => 'string', + ), + 'AspectRatio' => array( + 'type' => 'string', + ), + 'Interlaced' => array( + 'type' => 'string', + ), + 'Container' => array( + 'type' => 'string', + ), + ), + ), + 'Output' => array( + 'type' => 'object', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'ThumbnailPattern' => array( + 'type' => 'string', + ), + 'Rotate' => array( + 'type' => 'string', + ), + 'PresetId' => array( + 'type' => 'string', + ), + 'SegmentDuration' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'StatusDetail' => array( + 'type' => 'string', + ), + 'Duration' => array( + 'type' => 'numeric', + ), + 'Width' => array( + 'type' => 'numeric', + ), + 'Height' => array( + 'type' => 'numeric', + ), + 'Watermarks' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'JobWatermark', + 'type' => 'object', + 'properties' => array( + 'PresetWatermarkId' => array( + 'type' => 'string', + ), + 'InputKey' => array( + 'type' => 'string', + ), + ), + ), + ), + 'AlbumArt' => array( + 'type' => 'object', + 'properties' => array( + 'MergePolicy' => array( + 'type' => 'string', + ), + 'Artwork' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Artwork', + 'type' => 'object', + 'properties' => array( + 'InputKey' => array( + 'type' => 'string', + ), + 'MaxWidth' => array( + 'type' => 'string', + ), + 'MaxHeight' => array( + 'type' => 'string', + ), + 'SizingPolicy' => array( + 'type' => 'string', + ), + 'PaddingPolicy' => array( + 'type' => 'string', + ), + 'AlbumArtFormat' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'Composition' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Clip', + 'type' => 'object', + 'properties' => array( + 'TimeSpan' => array( + 'type' => 'object', + 'properties' => array( + 'StartTime' => array( + 'type' => 'string', + ), + 'Duration' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'Outputs' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'JobOutput', + 'type' => 'object', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'ThumbnailPattern' => array( + 'type' => 'string', + ), + 'Rotate' => array( + 'type' => 'string', + ), + 'PresetId' => array( + 'type' => 'string', + ), + 'SegmentDuration' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'StatusDetail' => array( + 'type' => 'string', + ), + 'Duration' => array( + 'type' => 'numeric', + ), + 'Width' => array( + 'type' => 'numeric', + ), + 'Height' => array( + 'type' => 'numeric', + ), + 'Watermarks' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'JobWatermark', + 'type' => 'object', + 'properties' => array( + 'PresetWatermarkId' => array( + 'type' => 'string', + ), + 'InputKey' => array( + 'type' => 'string', + ), + ), + ), + ), + 'AlbumArt' => array( + 'type' => 'object', + 'properties' => array( + 'MergePolicy' => array( + 'type' => 'string', + ), + 'Artwork' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Artwork', + 'type' => 'object', + 'properties' => array( + 'InputKey' => array( + 'type' => 'string', + ), + 'MaxWidth' => array( + 'type' => 'string', + ), + 'MaxHeight' => array( + 'type' => 'string', + ), + 'SizingPolicy' => array( + 'type' => 'string', + ), + 'PaddingPolicy' => array( + 'type' => 'string', + ), + 'AlbumArtFormat' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'Composition' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Clip', + 'type' => 'object', + 'properties' => array( + 'TimeSpan' => array( + 'type' => 'object', + 'properties' => array( + 'StartTime' => array( + 'type' => 'string', + ), + 'Duration' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'OutputKeyPrefix' => array( + 'type' => 'string', + ), + 'Playlists' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Playlist', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + 'Format' => array( + 'type' => 'string', + ), + 'OutputKeys' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Key', + 'type' => 'string', + ), + ), + 'Status' => array( + 'type' => 'string', + ), + 'StatusDetail' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Status' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'CreatePipelineResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Pipeline' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'Name' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'InputBucket' => array( + 'type' => 'string', + ), + 'OutputBucket' => array( + 'type' => 'string', + ), + 'Role' => array( + 'type' => 'string', + ), + 'Notifications' => array( + 'type' => 'object', + 'properties' => array( + 'Progressing' => array( + 'type' => 'string', + ), + 'Completed' => array( + 'type' => 'string', + ), + 'Warning' => array( + 'type' => 'string', + ), + 'Error' => array( + 'type' => 'string', + ), + ), + ), + 'ContentConfig' => array( + 'type' => 'object', + 'properties' => array( + 'Bucket' => array( + 'type' => 'string', + ), + 'StorageClass' => array( + 'type' => 'string', + ), + 'Permissions' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Permission', + 'type' => 'object', + 'properties' => array( + 'GranteeType' => array( + 'type' => 'string', + ), + 'Grantee' => array( + 'type' => 'string', + ), + 'Access' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AccessControl', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'ThumbnailConfig' => array( + 'type' => 'object', + 'properties' => array( + 'Bucket' => array( + 'type' => 'string', + ), + 'StorageClass' => array( + 'type' => 'string', + ), + 'Permissions' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Permission', + 'type' => 'object', + 'properties' => array( + 'GranteeType' => array( + 'type' => 'string', + ), + 'Grantee' => array( + 'type' => 'string', + ), + 'Access' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AccessControl', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'CreatePresetResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Preset' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'Name' => array( + 'type' => 'string', + ), + 'Description' => array( + 'type' => 'string', + ), + 'Container' => array( + 'type' => 'string', + ), + 'Audio' => array( + 'type' => 'object', + 'properties' => array( + 'Codec' => array( + 'type' => 'string', + ), + 'SampleRate' => array( + 'type' => 'string', + ), + 'BitRate' => array( + 'type' => 'string', + ), + 'Channels' => array( + 'type' => 'string', + ), + 'CodecOptions' => array( + 'type' => 'object', + 'properties' => array( + 'Profile' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'Video' => array( + 'type' => 'object', + 'properties' => array( + 'Codec' => array( + 'type' => 'string', + ), + 'CodecOptions' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'string', + ), + ), + 'KeyframesMaxDist' => array( + 'type' => 'string', + ), + 'FixedGOP' => array( + 'type' => 'string', + ), + 'BitRate' => array( + 'type' => 'string', + ), + 'FrameRate' => array( + 'type' => 'string', + ), + 'MaxFrameRate' => array( + 'type' => 'string', + ), + 'Resolution' => array( + 'type' => 'string', + ), + 'AspectRatio' => array( + 'type' => 'string', + ), + 'MaxWidth' => array( + 'type' => 'string', + ), + 'MaxHeight' => array( + 'type' => 'string', + ), + 'DisplayAspectRatio' => array( + 'type' => 'string', + ), + 'SizingPolicy' => array( + 'type' => 'string', + ), + 'PaddingPolicy' => array( + 'type' => 'string', + ), + 'Watermarks' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'PresetWatermark', + 'type' => 'object', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'MaxWidth' => array( + 'type' => 'string', + ), + 'MaxHeight' => array( + 'type' => 'string', + ), + 'SizingPolicy' => array( + 'type' => 'string', + ), + 'HorizontalAlign' => array( + 'type' => 'string', + ), + 'HorizontalOffset' => array( + 'type' => 'string', + ), + 'VerticalAlign' => array( + 'type' => 'string', + ), + 'VerticalOffset' => array( + 'type' => 'string', + ), + 'Opacity' => array( + 'type' => 'string', + ), + 'Target' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'Thumbnails' => array( + 'type' => 'object', + 'properties' => array( + 'Format' => array( + 'type' => 'string', + ), + 'Interval' => array( + 'type' => 'string', + ), + 'Resolution' => array( + 'type' => 'string', + ), + 'AspectRatio' => array( + 'type' => 'string', + ), + 'MaxWidth' => array( + 'type' => 'string', + ), + 'MaxHeight' => array( + 'type' => 'string', + ), + 'SizingPolicy' => array( + 'type' => 'string', + ), + 'PaddingPolicy' => array( + 'type' => 'string', + ), + ), + ), + 'Type' => array( + 'type' => 'string', + ), + ), + ), + 'Warning' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListJobsByPipelineResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Jobs' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Job', + 'type' => 'object', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'PipelineId' => array( + 'type' => 'string', + ), + 'Input' => array( + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'FrameRate' => array( + 'type' => 'string', + ), + 'Resolution' => array( + 'type' => 'string', + ), + 'AspectRatio' => array( + 'type' => 'string', + ), + 'Interlaced' => array( + 'type' => 'string', + ), + 'Container' => array( + 'type' => 'string', + ), + ), + ), + 'Output' => array( + 'type' => 'object', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'ThumbnailPattern' => array( + 'type' => 'string', + ), + 'Rotate' => array( + 'type' => 'string', + ), + 'PresetId' => array( + 'type' => 'string', + ), + 'SegmentDuration' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'StatusDetail' => array( + 'type' => 'string', + ), + 'Duration' => array( + 'type' => 'numeric', + ), + 'Width' => array( + 'type' => 'numeric', + ), + 'Height' => array( + 'type' => 'numeric', + ), + 'Watermarks' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'JobWatermark', + 'type' => 'object', + 'properties' => array( + 'PresetWatermarkId' => array( + 'type' => 'string', + ), + 'InputKey' => array( + 'type' => 'string', + ), + ), + ), + ), + 'AlbumArt' => array( + 'type' => 'object', + 'properties' => array( + 'MergePolicy' => array( + 'type' => 'string', + ), + 'Artwork' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Artwork', + 'type' => 'object', + 'properties' => array( + 'InputKey' => array( + 'type' => 'string', + ), + 'MaxWidth' => array( + 'type' => 'string', + ), + 'MaxHeight' => array( + 'type' => 'string', + ), + 'SizingPolicy' => array( + 'type' => 'string', + ), + 'PaddingPolicy' => array( + 'type' => 'string', + ), + 'AlbumArtFormat' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'Composition' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Clip', + 'type' => 'object', + 'properties' => array( + 'TimeSpan' => array( + 'type' => 'object', + 'properties' => array( + 'StartTime' => array( + 'type' => 'string', + ), + 'Duration' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'Outputs' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'JobOutput', + 'type' => 'object', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'ThumbnailPattern' => array( + 'type' => 'string', + ), + 'Rotate' => array( + 'type' => 'string', + ), + 'PresetId' => array( + 'type' => 'string', + ), + 'SegmentDuration' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'StatusDetail' => array( + 'type' => 'string', + ), + 'Duration' => array( + 'type' => 'numeric', + ), + 'Width' => array( + 'type' => 'numeric', + ), + 'Height' => array( + 'type' => 'numeric', + ), + 'Watermarks' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'JobWatermark', + 'type' => 'object', + 'properties' => array( + 'PresetWatermarkId' => array( + 'type' => 'string', + ), + 'InputKey' => array( + 'type' => 'string', + ), + ), + ), + ), + 'AlbumArt' => array( + 'type' => 'object', + 'properties' => array( + 'MergePolicy' => array( + 'type' => 'string', + ), + 'Artwork' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Artwork', + 'type' => 'object', + 'properties' => array( + 'InputKey' => array( + 'type' => 'string', + ), + 'MaxWidth' => array( + 'type' => 'string', + ), + 'MaxHeight' => array( + 'type' => 'string', + ), + 'SizingPolicy' => array( + 'type' => 'string', + ), + 'PaddingPolicy' => array( + 'type' => 'string', + ), + 'AlbumArtFormat' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'Composition' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Clip', + 'type' => 'object', + 'properties' => array( + 'TimeSpan' => array( + 'type' => 'object', + 'properties' => array( + 'StartTime' => array( + 'type' => 'string', + ), + 'Duration' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'OutputKeyPrefix' => array( + 'type' => 'string', + ), + 'Playlists' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Playlist', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + 'Format' => array( + 'type' => 'string', + ), + 'OutputKeys' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Key', + 'type' => 'string', + ), + ), + 'Status' => array( + 'type' => 'string', + ), + 'StatusDetail' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Status' => array( + 'type' => 'string', + ), + ), + ), + ), + 'NextPageToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListJobsByStatusResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Jobs' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Job', + 'type' => 'object', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'PipelineId' => array( + 'type' => 'string', + ), + 'Input' => array( + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'FrameRate' => array( + 'type' => 'string', + ), + 'Resolution' => array( + 'type' => 'string', + ), + 'AspectRatio' => array( + 'type' => 'string', + ), + 'Interlaced' => array( + 'type' => 'string', + ), + 'Container' => array( + 'type' => 'string', + ), + ), + ), + 'Output' => array( + 'type' => 'object', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'ThumbnailPattern' => array( + 'type' => 'string', + ), + 'Rotate' => array( + 'type' => 'string', + ), + 'PresetId' => array( + 'type' => 'string', + ), + 'SegmentDuration' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'StatusDetail' => array( + 'type' => 'string', + ), + 'Duration' => array( + 'type' => 'numeric', + ), + 'Width' => array( + 'type' => 'numeric', + ), + 'Height' => array( + 'type' => 'numeric', + ), + 'Watermarks' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'JobWatermark', + 'type' => 'object', + 'properties' => array( + 'PresetWatermarkId' => array( + 'type' => 'string', + ), + 'InputKey' => array( + 'type' => 'string', + ), + ), + ), + ), + 'AlbumArt' => array( + 'type' => 'object', + 'properties' => array( + 'MergePolicy' => array( + 'type' => 'string', + ), + 'Artwork' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Artwork', + 'type' => 'object', + 'properties' => array( + 'InputKey' => array( + 'type' => 'string', + ), + 'MaxWidth' => array( + 'type' => 'string', + ), + 'MaxHeight' => array( + 'type' => 'string', + ), + 'SizingPolicy' => array( + 'type' => 'string', + ), + 'PaddingPolicy' => array( + 'type' => 'string', + ), + 'AlbumArtFormat' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'Composition' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Clip', + 'type' => 'object', + 'properties' => array( + 'TimeSpan' => array( + 'type' => 'object', + 'properties' => array( + 'StartTime' => array( + 'type' => 'string', + ), + 'Duration' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'Outputs' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'JobOutput', + 'type' => 'object', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'ThumbnailPattern' => array( + 'type' => 'string', + ), + 'Rotate' => array( + 'type' => 'string', + ), + 'PresetId' => array( + 'type' => 'string', + ), + 'SegmentDuration' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'StatusDetail' => array( + 'type' => 'string', + ), + 'Duration' => array( + 'type' => 'numeric', + ), + 'Width' => array( + 'type' => 'numeric', + ), + 'Height' => array( + 'type' => 'numeric', + ), + 'Watermarks' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'JobWatermark', + 'type' => 'object', + 'properties' => array( + 'PresetWatermarkId' => array( + 'type' => 'string', + ), + 'InputKey' => array( + 'type' => 'string', + ), + ), + ), + ), + 'AlbumArt' => array( + 'type' => 'object', + 'properties' => array( + 'MergePolicy' => array( + 'type' => 'string', + ), + 'Artwork' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Artwork', + 'type' => 'object', + 'properties' => array( + 'InputKey' => array( + 'type' => 'string', + ), + 'MaxWidth' => array( + 'type' => 'string', + ), + 'MaxHeight' => array( + 'type' => 'string', + ), + 'SizingPolicy' => array( + 'type' => 'string', + ), + 'PaddingPolicy' => array( + 'type' => 'string', + ), + 'AlbumArtFormat' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'Composition' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Clip', + 'type' => 'object', + 'properties' => array( + 'TimeSpan' => array( + 'type' => 'object', + 'properties' => array( + 'StartTime' => array( + 'type' => 'string', + ), + 'Duration' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'OutputKeyPrefix' => array( + 'type' => 'string', + ), + 'Playlists' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Playlist', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + 'Format' => array( + 'type' => 'string', + ), + 'OutputKeys' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Key', + 'type' => 'string', + ), + ), + 'Status' => array( + 'type' => 'string', + ), + 'StatusDetail' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Status' => array( + 'type' => 'string', + ), + ), + ), + ), + 'NextPageToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListPipelinesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Pipelines' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Pipeline', + 'type' => 'object', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'Name' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'InputBucket' => array( + 'type' => 'string', + ), + 'OutputBucket' => array( + 'type' => 'string', + ), + 'Role' => array( + 'type' => 'string', + ), + 'Notifications' => array( + 'type' => 'object', + 'properties' => array( + 'Progressing' => array( + 'type' => 'string', + ), + 'Completed' => array( + 'type' => 'string', + ), + 'Warning' => array( + 'type' => 'string', + ), + 'Error' => array( + 'type' => 'string', + ), + ), + ), + 'ContentConfig' => array( + 'type' => 'object', + 'properties' => array( + 'Bucket' => array( + 'type' => 'string', + ), + 'StorageClass' => array( + 'type' => 'string', + ), + 'Permissions' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Permission', + 'type' => 'object', + 'properties' => array( + 'GranteeType' => array( + 'type' => 'string', + ), + 'Grantee' => array( + 'type' => 'string', + ), + 'Access' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AccessControl', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'ThumbnailConfig' => array( + 'type' => 'object', + 'properties' => array( + 'Bucket' => array( + 'type' => 'string', + ), + 'StorageClass' => array( + 'type' => 'string', + ), + 'Permissions' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Permission', + 'type' => 'object', + 'properties' => array( + 'GranteeType' => array( + 'type' => 'string', + ), + 'Grantee' => array( + 'type' => 'string', + ), + 'Access' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AccessControl', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'NextPageToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListPresetsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Presets' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Preset', + 'type' => 'object', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'Name' => array( + 'type' => 'string', + ), + 'Description' => array( + 'type' => 'string', + ), + 'Container' => array( + 'type' => 'string', + ), + 'Audio' => array( + 'type' => 'object', + 'properties' => array( + 'Codec' => array( + 'type' => 'string', + ), + 'SampleRate' => array( + 'type' => 'string', + ), + 'BitRate' => array( + 'type' => 'string', + ), + 'Channels' => array( + 'type' => 'string', + ), + 'CodecOptions' => array( + 'type' => 'object', + 'properties' => array( + 'Profile' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'Video' => array( + 'type' => 'object', + 'properties' => array( + 'Codec' => array( + 'type' => 'string', + ), + 'CodecOptions' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'string', + ), + ), + 'KeyframesMaxDist' => array( + 'type' => 'string', + ), + 'FixedGOP' => array( + 'type' => 'string', + ), + 'BitRate' => array( + 'type' => 'string', + ), + 'FrameRate' => array( + 'type' => 'string', + ), + 'MaxFrameRate' => array( + 'type' => 'string', + ), + 'Resolution' => array( + 'type' => 'string', + ), + 'AspectRatio' => array( + 'type' => 'string', + ), + 'MaxWidth' => array( + 'type' => 'string', + ), + 'MaxHeight' => array( + 'type' => 'string', + ), + 'DisplayAspectRatio' => array( + 'type' => 'string', + ), + 'SizingPolicy' => array( + 'type' => 'string', + ), + 'PaddingPolicy' => array( + 'type' => 'string', + ), + 'Watermarks' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'PresetWatermark', + 'type' => 'object', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'MaxWidth' => array( + 'type' => 'string', + ), + 'MaxHeight' => array( + 'type' => 'string', + ), + 'SizingPolicy' => array( + 'type' => 'string', + ), + 'HorizontalAlign' => array( + 'type' => 'string', + ), + 'HorizontalOffset' => array( + 'type' => 'string', + ), + 'VerticalAlign' => array( + 'type' => 'string', + ), + 'VerticalOffset' => array( + 'type' => 'string', + ), + 'Opacity' => array( + 'type' => 'string', + ), + 'Target' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'Thumbnails' => array( + 'type' => 'object', + 'properties' => array( + 'Format' => array( + 'type' => 'string', + ), + 'Interval' => array( + 'type' => 'string', + ), + 'Resolution' => array( + 'type' => 'string', + ), + 'AspectRatio' => array( + 'type' => 'string', + ), + 'MaxWidth' => array( + 'type' => 'string', + ), + 'MaxHeight' => array( + 'type' => 'string', + ), + 'SizingPolicy' => array( + 'type' => 'string', + ), + 'PaddingPolicy' => array( + 'type' => 'string', + ), + ), + ), + 'Type' => array( + 'type' => 'string', + ), + ), + ), + ), + 'NextPageToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ReadJobResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Job' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'PipelineId' => array( + 'type' => 'string', + ), + 'Input' => array( + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'FrameRate' => array( + 'type' => 'string', + ), + 'Resolution' => array( + 'type' => 'string', + ), + 'AspectRatio' => array( + 'type' => 'string', + ), + 'Interlaced' => array( + 'type' => 'string', + ), + 'Container' => array( + 'type' => 'string', + ), + ), + ), + 'Output' => array( + 'type' => 'object', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'ThumbnailPattern' => array( + 'type' => 'string', + ), + 'Rotate' => array( + 'type' => 'string', + ), + 'PresetId' => array( + 'type' => 'string', + ), + 'SegmentDuration' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'StatusDetail' => array( + 'type' => 'string', + ), + 'Duration' => array( + 'type' => 'numeric', + ), + 'Width' => array( + 'type' => 'numeric', + ), + 'Height' => array( + 'type' => 'numeric', + ), + 'Watermarks' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'JobWatermark', + 'type' => 'object', + 'properties' => array( + 'PresetWatermarkId' => array( + 'type' => 'string', + ), + 'InputKey' => array( + 'type' => 'string', + ), + ), + ), + ), + 'AlbumArt' => array( + 'type' => 'object', + 'properties' => array( + 'MergePolicy' => array( + 'type' => 'string', + ), + 'Artwork' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Artwork', + 'type' => 'object', + 'properties' => array( + 'InputKey' => array( + 'type' => 'string', + ), + 'MaxWidth' => array( + 'type' => 'string', + ), + 'MaxHeight' => array( + 'type' => 'string', + ), + 'SizingPolicy' => array( + 'type' => 'string', + ), + 'PaddingPolicy' => array( + 'type' => 'string', + ), + 'AlbumArtFormat' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'Composition' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Clip', + 'type' => 'object', + 'properties' => array( + 'TimeSpan' => array( + 'type' => 'object', + 'properties' => array( + 'StartTime' => array( + 'type' => 'string', + ), + 'Duration' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'Outputs' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'JobOutput', + 'type' => 'object', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Key' => array( + 'type' => 'string', + ), + 'ThumbnailPattern' => array( + 'type' => 'string', + ), + 'Rotate' => array( + 'type' => 'string', + ), + 'PresetId' => array( + 'type' => 'string', + ), + 'SegmentDuration' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'StatusDetail' => array( + 'type' => 'string', + ), + 'Duration' => array( + 'type' => 'numeric', + ), + 'Width' => array( + 'type' => 'numeric', + ), + 'Height' => array( + 'type' => 'numeric', + ), + 'Watermarks' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'JobWatermark', + 'type' => 'object', + 'properties' => array( + 'PresetWatermarkId' => array( + 'type' => 'string', + ), + 'InputKey' => array( + 'type' => 'string', + ), + ), + ), + ), + 'AlbumArt' => array( + 'type' => 'object', + 'properties' => array( + 'MergePolicy' => array( + 'type' => 'string', + ), + 'Artwork' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Artwork', + 'type' => 'object', + 'properties' => array( + 'InputKey' => array( + 'type' => 'string', + ), + 'MaxWidth' => array( + 'type' => 'string', + ), + 'MaxHeight' => array( + 'type' => 'string', + ), + 'SizingPolicy' => array( + 'type' => 'string', + ), + 'PaddingPolicy' => array( + 'type' => 'string', + ), + 'AlbumArtFormat' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'Composition' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Clip', + 'type' => 'object', + 'properties' => array( + 'TimeSpan' => array( + 'type' => 'object', + 'properties' => array( + 'StartTime' => array( + 'type' => 'string', + ), + 'Duration' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'OutputKeyPrefix' => array( + 'type' => 'string', + ), + 'Playlists' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Playlist', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + 'Format' => array( + 'type' => 'string', + ), + 'OutputKeys' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Key', + 'type' => 'string', + ), + ), + 'Status' => array( + 'type' => 'string', + ), + 'StatusDetail' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Status' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'ReadPipelineResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Pipeline' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'Name' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'InputBucket' => array( + 'type' => 'string', + ), + 'OutputBucket' => array( + 'type' => 'string', + ), + 'Role' => array( + 'type' => 'string', + ), + 'Notifications' => array( + 'type' => 'object', + 'properties' => array( + 'Progressing' => array( + 'type' => 'string', + ), + 'Completed' => array( + 'type' => 'string', + ), + 'Warning' => array( + 'type' => 'string', + ), + 'Error' => array( + 'type' => 'string', + ), + ), + ), + 'ContentConfig' => array( + 'type' => 'object', + 'properties' => array( + 'Bucket' => array( + 'type' => 'string', + ), + 'StorageClass' => array( + 'type' => 'string', + ), + 'Permissions' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Permission', + 'type' => 'object', + 'properties' => array( + 'GranteeType' => array( + 'type' => 'string', + ), + 'Grantee' => array( + 'type' => 'string', + ), + 'Access' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AccessControl', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'ThumbnailConfig' => array( + 'type' => 'object', + 'properties' => array( + 'Bucket' => array( + 'type' => 'string', + ), + 'StorageClass' => array( + 'type' => 'string', + ), + 'Permissions' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Permission', + 'type' => 'object', + 'properties' => array( + 'GranteeType' => array( + 'type' => 'string', + ), + 'Grantee' => array( + 'type' => 'string', + ), + 'Access' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AccessControl', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'ReadPresetResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Preset' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'Name' => array( + 'type' => 'string', + ), + 'Description' => array( + 'type' => 'string', + ), + 'Container' => array( + 'type' => 'string', + ), + 'Audio' => array( + 'type' => 'object', + 'properties' => array( + 'Codec' => array( + 'type' => 'string', + ), + 'SampleRate' => array( + 'type' => 'string', + ), + 'BitRate' => array( + 'type' => 'string', + ), + 'Channels' => array( + 'type' => 'string', + ), + 'CodecOptions' => array( + 'type' => 'object', + 'properties' => array( + 'Profile' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'Video' => array( + 'type' => 'object', + 'properties' => array( + 'Codec' => array( + 'type' => 'string', + ), + 'CodecOptions' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'string', + ), + ), + 'KeyframesMaxDist' => array( + 'type' => 'string', + ), + 'FixedGOP' => array( + 'type' => 'string', + ), + 'BitRate' => array( + 'type' => 'string', + ), + 'FrameRate' => array( + 'type' => 'string', + ), + 'MaxFrameRate' => array( + 'type' => 'string', + ), + 'Resolution' => array( + 'type' => 'string', + ), + 'AspectRatio' => array( + 'type' => 'string', + ), + 'MaxWidth' => array( + 'type' => 'string', + ), + 'MaxHeight' => array( + 'type' => 'string', + ), + 'DisplayAspectRatio' => array( + 'type' => 'string', + ), + 'SizingPolicy' => array( + 'type' => 'string', + ), + 'PaddingPolicy' => array( + 'type' => 'string', + ), + 'Watermarks' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'PresetWatermark', + 'type' => 'object', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'MaxWidth' => array( + 'type' => 'string', + ), + 'MaxHeight' => array( + 'type' => 'string', + ), + 'SizingPolicy' => array( + 'type' => 'string', + ), + 'HorizontalAlign' => array( + 'type' => 'string', + ), + 'HorizontalOffset' => array( + 'type' => 'string', + ), + 'VerticalAlign' => array( + 'type' => 'string', + ), + 'VerticalOffset' => array( + 'type' => 'string', + ), + 'Opacity' => array( + 'type' => 'string', + ), + 'Target' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'Thumbnails' => array( + 'type' => 'object', + 'properties' => array( + 'Format' => array( + 'type' => 'string', + ), + 'Interval' => array( + 'type' => 'string', + ), + 'Resolution' => array( + 'type' => 'string', + ), + 'AspectRatio' => array( + 'type' => 'string', + ), + 'MaxWidth' => array( + 'type' => 'string', + ), + 'MaxHeight' => array( + 'type' => 'string', + ), + 'SizingPolicy' => array( + 'type' => 'string', + ), + 'PaddingPolicy' => array( + 'type' => 'string', + ), + ), + ), + 'Type' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'TestRoleResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Success' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Messages' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + ), + ), + 'UpdatePipelineResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Pipeline' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'Name' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'InputBucket' => array( + 'type' => 'string', + ), + 'OutputBucket' => array( + 'type' => 'string', + ), + 'Role' => array( + 'type' => 'string', + ), + 'Notifications' => array( + 'type' => 'object', + 'properties' => array( + 'Progressing' => array( + 'type' => 'string', + ), + 'Completed' => array( + 'type' => 'string', + ), + 'Warning' => array( + 'type' => 'string', + ), + 'Error' => array( + 'type' => 'string', + ), + ), + ), + 'ContentConfig' => array( + 'type' => 'object', + 'properties' => array( + 'Bucket' => array( + 'type' => 'string', + ), + 'StorageClass' => array( + 'type' => 'string', + ), + 'Permissions' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Permission', + 'type' => 'object', + 'properties' => array( + 'GranteeType' => array( + 'type' => 'string', + ), + 'Grantee' => array( + 'type' => 'string', + ), + 'Access' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AccessControl', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'ThumbnailConfig' => array( + 'type' => 'object', + 'properties' => array( + 'Bucket' => array( + 'type' => 'string', + ), + 'StorageClass' => array( + 'type' => 'string', + ), + 'Permissions' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Permission', + 'type' => 'object', + 'properties' => array( + 'GranteeType' => array( + 'type' => 'string', + ), + 'Grantee' => array( + 'type' => 'string', + ), + 'Access' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AccessControl', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'UpdatePipelineNotificationsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Pipeline' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'Name' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'InputBucket' => array( + 'type' => 'string', + ), + 'OutputBucket' => array( + 'type' => 'string', + ), + 'Role' => array( + 'type' => 'string', + ), + 'Notifications' => array( + 'type' => 'object', + 'properties' => array( + 'Progressing' => array( + 'type' => 'string', + ), + 'Completed' => array( + 'type' => 'string', + ), + 'Warning' => array( + 'type' => 'string', + ), + 'Error' => array( + 'type' => 'string', + ), + ), + ), + 'ContentConfig' => array( + 'type' => 'object', + 'properties' => array( + 'Bucket' => array( + 'type' => 'string', + ), + 'StorageClass' => array( + 'type' => 'string', + ), + 'Permissions' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Permission', + 'type' => 'object', + 'properties' => array( + 'GranteeType' => array( + 'type' => 'string', + ), + 'Grantee' => array( + 'type' => 'string', + ), + 'Access' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AccessControl', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'ThumbnailConfig' => array( + 'type' => 'object', + 'properties' => array( + 'Bucket' => array( + 'type' => 'string', + ), + 'StorageClass' => array( + 'type' => 'string', + ), + 'Permissions' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Permission', + 'type' => 'object', + 'properties' => array( + 'GranteeType' => array( + 'type' => 'string', + ), + 'Grantee' => array( + 'type' => 'string', + ), + 'Access' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AccessControl', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'UpdatePipelineStatusResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Pipeline' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'Name' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'InputBucket' => array( + 'type' => 'string', + ), + 'OutputBucket' => array( + 'type' => 'string', + ), + 'Role' => array( + 'type' => 'string', + ), + 'Notifications' => array( + 'type' => 'object', + 'properties' => array( + 'Progressing' => array( + 'type' => 'string', + ), + 'Completed' => array( + 'type' => 'string', + ), + 'Warning' => array( + 'type' => 'string', + ), + 'Error' => array( + 'type' => 'string', + ), + ), + ), + 'ContentConfig' => array( + 'type' => 'object', + 'properties' => array( + 'Bucket' => array( + 'type' => 'string', + ), + 'StorageClass' => array( + 'type' => 'string', + ), + 'Permissions' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Permission', + 'type' => 'object', + 'properties' => array( + 'GranteeType' => array( + 'type' => 'string', + ), + 'Grantee' => array( + 'type' => 'string', + ), + 'Access' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AccessControl', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'ThumbnailConfig' => array( + 'type' => 'object', + 'properties' => array( + 'Bucket' => array( + 'type' => 'string', + ), + 'StorageClass' => array( + 'type' => 'string', + ), + 'Permissions' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Permission', + 'type' => 'object', + 'properties' => array( + 'GranteeType' => array( + 'type' => 'string', + ), + 'Grantee' => array( + 'type' => 'string', + ), + 'Access' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AccessControl', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'iterators' => array( + '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-sdk-php/src/Aws/Emr/EmrClient.php b/vendor/aws/aws-sdk-php/src/Aws/Emr/EmrClient.php new file mode 100644 index 0000000..47e7e80 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Emr/Enum/ActionOnFailure.php b/vendor/aws/aws-sdk-php/src/Aws/Emr/Enum/ActionOnFailure.php new file mode 100644 index 0000000..f1f8ecf --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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( + 'type' => 'string', + 'location' => 'json', + ), + 'Tags' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'This exception occurs when there is an internal failure in the EMR service.', + 'class' => 'InternalServerException', + ), + array( + 'reason' => 'This exception occurs when there is something wrong with user input.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'DescribeCluster' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeClusterOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'ElasticMapReduce.DescribeCluster', + ), + 'ClusterId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'This exception occurs when there is an internal failure in the EMR service.', + 'class' => 'InternalServerException', + ), + array( + 'reason' => 'This exception occurs when there is something wrong with user input.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'DescribeJobFlows' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeJobFlowsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'ElasticMapReduce.DescribeJobFlows', + ), + 'CreatedAfter' => array( + 'type' => array( + 'object', + 'string', + 'integer', + ), + 'format' => 'timestamp', + 'location' => 'json', + ), + 'CreatedBefore' => array( + 'type' => array( + 'object', + 'string', + 'integer', + ), + 'format' => 'timestamp', + 'location' => 'json', + ), + 'JobFlowIds' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'XmlString', + 'type' => 'string', + 'maxLength' => 10280, + ), + ), + 'JobFlowStates' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'JobFlowExecutionState', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that an error occurred while processing the request and that the request was not completed.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'DescribeStep' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeStepOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'ElasticMapReduce.DescribeStep', + ), + 'ClusterId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'StepId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'This exception occurs when there is an internal failure in the EMR service.', + 'class' => 'InternalServerException', + ), + array( + 'reason' => 'This exception occurs when there is something wrong with user input.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'ListBootstrapActions' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListBootstrapActionsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'ElasticMapReduce.ListBootstrapActions', + ), + 'ClusterId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'This exception occurs when there is an internal failure in the EMR service.', + 'class' => 'InternalServerException', + ), + array( + 'reason' => 'This exception occurs when there is something wrong with user input.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'ListClusters' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListClustersOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'ElasticMapReduce.ListClusters', + ), + 'CreatedAfter' => array( + 'type' => array( + 'object', + 'string', + 'integer', + ), + 'format' => 'timestamp', + 'location' => 'json', + ), + 'CreatedBefore' => array( + 'type' => array( + 'object', + 'string', + 'integer', + ), + 'format' => 'timestamp', + 'location' => 'json', + ), + 'ClusterStates' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'ClusterState', + 'type' => 'string', + ), + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'This exception occurs when there is an internal failure in the EMR service.', + 'class' => 'InternalServerException', + ), + array( + 'reason' => 'This exception occurs when there is something wrong with user input.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'ListInstanceGroups' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListInstanceGroupsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'ElasticMapReduce.ListInstanceGroups', + ), + 'ClusterId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'This exception occurs when there is an internal failure in the EMR service.', + 'class' => 'InternalServerException', + ), + array( + 'reason' => 'This exception occurs when there is something wrong with user input.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'ListInstances' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListInstancesOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'ElasticMapReduce.ListInstances', + ), + 'ClusterId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'InstanceGroupId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'InstanceGroupTypes' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'InstanceGroupType', + 'type' => 'string', + ), + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'This exception occurs when there is an internal failure in the EMR service.', + 'class' => 'InternalServerException', + ), + array( + 'reason' => 'This exception occurs when there is something wrong with user input.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'ListSteps' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListStepsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'ElasticMapReduce.ListSteps', + ), + 'ClusterId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'StepStates' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'StepState', + 'type' => 'string', + ), + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'This exception occurs when there is an internal failure in the EMR service.', + 'class' => 'InternalServerException', + ), + array( + 'reason' => 'This exception occurs when there is something wrong with user input.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'ModifyInstanceGroups' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'ElasticMapReduce.ModifyInstanceGroups', + ), + 'InstanceGroups' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'InstanceGroupModifyConfig', + 'type' => 'object', + 'properties' => array( + 'InstanceGroupId' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 256, + ), + 'InstanceCount' => array( + 'type' => 'numeric', + ), + 'EC2InstanceIdsToTerminate' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'InstanceId', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that an error occurred while processing the request and that the request was not completed.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'RemoveTags' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'ElasticMapReduce.RemoveTags', + ), + 'ResourceId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'TagKeys' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'This exception occurs when there is an internal failure in the EMR service.', + 'class' => 'InternalServerException', + ), + array( + 'reason' => 'This exception occurs when there is something wrong with user input.', + 'class' => 'InvalidRequestException', + ), + ), + ), + 'RunJobFlow' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'RunJobFlowOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'ElasticMapReduce.RunJobFlow', + ), + 'Name' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 256, + ), + 'LogUri' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 10280, + ), + 'AdditionalInfo' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 10280, + ), + 'AmiVersion' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 256, + ), + 'Instances' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'MasterInstanceType' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'SlaveInstanceType' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'InstanceCount' => array( + 'type' => 'numeric', + ), + 'InstanceGroups' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'InstanceGroupConfig', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + 'maxLength' => 256, + ), + 'Market' => array( + 'type' => 'string', + ), + 'InstanceRole' => array( + 'required' => true, + 'type' => 'string', + ), + 'BidPrice' => array( + 'type' => 'string', + 'maxLength' => 256, + ), + 'InstanceType' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'InstanceCount' => array( + 'required' => true, + 'type' => 'numeric', + ), + ), + ), + ), + 'Ec2KeyName' => array( + 'type' => 'string', + 'maxLength' => 256, + ), + 'Placement' => array( + 'type' => 'object', + 'properties' => array( + 'AvailabilityZone' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 10280, + ), + ), + ), + 'KeepJobFlowAliveWhenNoSteps' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'TerminationProtected' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'HadoopVersion' => array( + 'type' => 'string', + 'maxLength' => 256, + ), + 'Ec2SubnetId' => array( + 'type' => 'string', + 'maxLength' => 256, + ), + ), + ), + 'Steps' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'StepConfig', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 256, + ), + 'ActionOnFailure' => array( + 'type' => 'string', + ), + 'HadoopJarStep' => array( + 'required' => true, + 'type' => 'object', + 'properties' => array( + 'Properties' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'KeyValue', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + 'maxLength' => 10280, + ), + 'Value' => array( + 'type' => 'string', + 'maxLength' => 10280, + ), + ), + ), + ), + 'Jar' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 10280, + ), + 'MainClass' => array( + 'type' => 'string', + 'maxLength' => 10280, + ), + 'Args' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'XmlString', + 'type' => 'string', + 'maxLength' => 10280, + ), + ), + ), + ), + ), + ), + ), + 'BootstrapActions' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'BootstrapActionConfig', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 256, + ), + 'ScriptBootstrapAction' => array( + 'required' => true, + 'type' => 'object', + 'properties' => array( + 'Path' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 10280, + ), + 'Args' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'XmlString', + 'type' => 'string', + 'maxLength' => 10280, + ), + ), + ), + ), + ), + ), + ), + 'SupportedProducts' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'XmlStringMaxLen256', + 'type' => 'string', + 'maxLength' => 256, + ), + ), + 'NewSupportedProducts' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'SupportedProductConfig', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + 'maxLength' => 256, + ), + 'Args' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'XmlString', + 'type' => 'string', + 'maxLength' => 10280, + ), + ), + ), + ), + ), + 'VisibleToAllUsers' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + 'JobFlowRole' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 10280, + ), + 'Tags' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that an error occurred while processing the request and that the request was not completed.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'SetTerminationProtection' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'ElasticMapReduce.SetTerminationProtection', + ), + 'JobFlowIds' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'XmlString', + 'type' => 'string', + 'maxLength' => 10280, + ), + ), + 'TerminationProtected' => array( + 'required' => true, + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that an error occurred while processing the request and that the request was not completed.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'SetVisibleToAllUsers' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'ElasticMapReduce.SetVisibleToAllUsers', + ), + 'JobFlowIds' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'XmlString', + 'type' => 'string', + 'maxLength' => 10280, + ), + ), + 'VisibleToAllUsers' => array( + 'required' => true, + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that an error occurred while processing the request and that the request was not completed.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'TerminateJobFlows' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'ElasticMapReduce.TerminateJobFlows', + ), + 'JobFlowIds' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'XmlString', + 'type' => 'string', + 'maxLength' => 10280, + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that an error occurred while processing the request and that the request was not completed.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + ), + 'models' => array( + 'AddInstanceGroupsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'JobFlowId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'InstanceGroupIds' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'XmlStringMaxLen256', + 'type' => 'string', + ), + ), + ), + ), + 'AddJobFlowStepsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'StepIds' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'XmlStringMaxLen256', + 'type' => 'string', + ), + ), + ), + ), + 'EmptyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + ), + 'DescribeClusterOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Cluster' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Name' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'object', + 'properties' => array( + 'State' => array( + 'type' => 'string', + ), + 'StateChangeReason' => array( + 'type' => 'object', + 'properties' => array( + 'Code' => array( + 'type' => 'string', + ), + 'Message' => array( + 'type' => 'string', + ), + ), + ), + 'Timeline' => array( + 'type' => 'object', + 'properties' => array( + 'CreationDateTime' => array( + 'type' => 'string', + ), + 'ReadyDateTime' => array( + 'type' => 'string', + ), + 'EndDateTime' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'Ec2InstanceAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'Ec2KeyName' => array( + 'type' => 'string', + ), + 'Ec2SubnetId' => array( + 'type' => 'string', + ), + 'Ec2AvailabilityZone' => array( + 'type' => 'string', + ), + 'IamInstanceProfile' => array( + 'type' => 'string', + ), + ), + ), + 'LogUri' => array( + 'type' => 'string', + ), + 'RequestedAmiVersion' => array( + 'type' => 'string', + ), + 'RunningAmiVersion' => array( + 'type' => 'string', + ), + 'AutoTerminate' => array( + 'type' => 'boolean', + ), + 'TerminationProtected' => array( + 'type' => 'boolean', + ), + 'VisibleToAllUsers' => array( + 'type' => 'boolean', + ), + 'Applications' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Application', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + 'Version' => array( + 'type' => 'string', + ), + 'Args' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + 'AdditionalInfo' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'Tags' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'DescribeJobFlowsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'JobFlows' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'JobFlowDetail', + 'type' => 'object', + 'properties' => array( + 'JobFlowId' => array( + 'type' => 'string', + ), + 'Name' => array( + 'type' => 'string', + ), + 'LogUri' => array( + 'type' => 'string', + ), + 'AmiVersion' => array( + 'type' => 'string', + ), + 'ExecutionStatusDetail' => array( + 'type' => 'object', + 'properties' => array( + 'State' => array( + 'type' => 'string', + ), + 'CreationDateTime' => array( + 'type' => 'string', + ), + 'StartDateTime' => array( + 'type' => 'string', + ), + 'ReadyDateTime' => array( + 'type' => 'string', + ), + 'EndDateTime' => array( + 'type' => 'string', + ), + 'LastStateChangeReason' => array( + 'type' => 'string', + ), + ), + ), + 'Instances' => array( + 'type' => 'object', + 'properties' => array( + 'MasterInstanceType' => array( + 'type' => 'string', + ), + 'MasterPublicDnsName' => array( + 'type' => 'string', + ), + 'MasterInstanceId' => array( + 'type' => 'string', + ), + 'SlaveInstanceType' => array( + 'type' => 'string', + ), + 'InstanceCount' => array( + 'type' => 'numeric', + ), + 'InstanceGroups' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'InstanceGroupDetail', + 'type' => 'object', + 'properties' => array( + 'InstanceGroupId' => array( + 'type' => 'string', + ), + 'Name' => array( + 'type' => 'string', + ), + 'Market' => array( + 'type' => 'string', + ), + 'InstanceRole' => array( + 'type' => 'string', + ), + 'BidPrice' => array( + 'type' => 'string', + ), + 'InstanceType' => array( + 'type' => 'string', + ), + 'InstanceRequestCount' => array( + 'type' => 'numeric', + ), + 'InstanceRunningCount' => array( + 'type' => 'numeric', + ), + 'State' => array( + 'type' => 'string', + ), + 'LastStateChangeReason' => array( + 'type' => 'string', + ), + 'CreationDateTime' => array( + 'type' => 'string', + ), + 'StartDateTime' => array( + 'type' => 'string', + ), + 'ReadyDateTime' => array( + 'type' => 'string', + ), + 'EndDateTime' => array( + 'type' => 'string', + ), + ), + ), + ), + 'NormalizedInstanceHours' => array( + 'type' => 'numeric', + ), + 'Ec2KeyName' => array( + 'type' => 'string', + ), + 'Ec2SubnetId' => array( + 'type' => 'string', + ), + 'Placement' => array( + 'type' => 'object', + 'properties' => array( + 'AvailabilityZone' => array( + 'type' => 'string', + ), + ), + ), + 'KeepJobFlowAliveWhenNoSteps' => array( + 'type' => 'boolean', + ), + 'TerminationProtected' => array( + 'type' => 'boolean', + ), + 'HadoopVersion' => array( + 'type' => 'string', + ), + ), + ), + 'Steps' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'StepDetail', + 'type' => 'object', + 'properties' => array( + 'StepConfig' => array( + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + 'ActionOnFailure' => array( + 'type' => 'string', + ), + 'HadoopJarStep' => array( + 'type' => 'object', + 'properties' => array( + 'Properties' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'KeyValue', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Jar' => array( + 'type' => 'string', + ), + 'MainClass' => array( + 'type' => 'string', + ), + 'Args' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'XmlString', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'ExecutionStatusDetail' => array( + 'type' => 'object', + 'properties' => array( + 'State' => array( + 'type' => 'string', + ), + 'CreationDateTime' => array( + 'type' => 'string', + ), + 'StartDateTime' => array( + 'type' => 'string', + ), + 'EndDateTime' => array( + 'type' => 'string', + ), + 'LastStateChangeReason' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'BootstrapActions' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'BootstrapActionDetail', + 'type' => 'object', + 'properties' => array( + 'BootstrapActionConfig' => array( + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + 'ScriptBootstrapAction' => array( + 'type' => 'object', + 'properties' => array( + 'Path' => array( + 'type' => 'string', + ), + 'Args' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'XmlString', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'SupportedProducts' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'XmlStringMaxLen256', + 'type' => 'string', + ), + ), + 'VisibleToAllUsers' => array( + 'type' => 'boolean', + ), + 'JobFlowRole' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'DescribeStepOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Step' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Name' => array( + 'type' => 'string', + ), + 'Config' => array( + 'type' => 'object', + 'properties' => array( + 'Jar' => array( + 'type' => 'string', + ), + 'Properties' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'string', + ), + ), + 'MainClass' => array( + 'type' => 'string', + ), + 'Args' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + ), + ), + 'ActionOnFailure' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'object', + 'properties' => array( + 'State' => array( + 'type' => 'string', + ), + 'StateChangeReason' => array( + 'type' => 'object', + 'properties' => array( + 'Code' => array( + 'type' => 'string', + ), + 'Message' => array( + 'type' => 'string', + ), + ), + ), + 'Timeline' => array( + 'type' => 'object', + 'properties' => array( + 'CreationDateTime' => array( + 'type' => 'string', + ), + 'StartDateTime' => array( + 'type' => 'string', + ), + 'EndDateTime' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'ListBootstrapActionsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'BootstrapActions' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Command', + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + 'ScriptPath' => array( + 'type' => 'string', + ), + 'Args' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + ), + ), + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListClustersOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Clusters' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'ClusterSummary', + 'type' => 'object', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Name' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'object', + 'properties' => array( + 'State' => array( + 'type' => 'string', + ), + 'StateChangeReason' => array( + 'type' => 'object', + 'properties' => array( + 'Code' => array( + 'type' => 'string', + ), + 'Message' => array( + 'type' => 'string', + ), + ), + ), + 'Timeline' => array( + 'type' => 'object', + 'properties' => array( + 'CreationDateTime' => array( + 'type' => 'string', + ), + 'ReadyDateTime' => array( + 'type' => 'string', + ), + 'EndDateTime' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListInstanceGroupsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'InstanceGroups' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'InstanceGroup', + 'type' => 'object', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Name' => array( + 'type' => 'string', + ), + 'Market' => array( + 'type' => 'string', + ), + 'InstanceGroupType' => array( + 'type' => 'string', + ), + 'BidPrice' => array( + 'type' => 'string', + ), + 'InstanceType' => array( + 'type' => 'string', + ), + 'RequestedInstanceCount' => array( + 'type' => 'numeric', + ), + 'RunningInstanceCount' => array( + 'type' => 'numeric', + ), + 'Status' => array( + 'type' => 'object', + 'properties' => array( + 'State' => array( + 'type' => 'string', + ), + 'StateChangeReason' => array( + 'type' => 'object', + 'properties' => array( + 'Code' => array( + 'type' => 'string', + ), + 'Message' => array( + 'type' => 'string', + ), + ), + ), + 'Timeline' => array( + 'type' => 'object', + 'properties' => array( + 'CreationDateTime' => array( + 'type' => 'string', + ), + 'ReadyDateTime' => array( + 'type' => 'string', + ), + 'EndDateTime' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListInstancesOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Instances' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Instance', + 'type' => 'object', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Ec2InstanceId' => array( + 'type' => 'string', + ), + 'PublicDnsName' => array( + 'type' => 'string', + ), + 'PublicIpAddress' => array( + 'type' => 'string', + ), + 'PrivateDnsName' => array( + 'type' => 'string', + ), + 'PrivateIpAddress' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'object', + 'properties' => array( + 'State' => array( + 'type' => 'string', + ), + 'StateChangeReason' => array( + 'type' => 'object', + 'properties' => array( + 'Code' => array( + 'type' => 'string', + ), + 'Message' => array( + 'type' => 'string', + ), + ), + ), + 'Timeline' => array( + 'type' => 'object', + 'properties' => array( + 'CreationDateTime' => array( + 'type' => 'string', + ), + 'ReadyDateTime' => array( + 'type' => 'string', + ), + 'EndDateTime' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListStepsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Steps' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'StepSummary', + 'type' => 'object', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Name' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'object', + 'properties' => array( + 'State' => array( + 'type' => 'string', + ), + 'StateChangeReason' => array( + 'type' => 'object', + 'properties' => array( + 'Code' => array( + 'type' => 'string', + ), + 'Message' => array( + 'type' => 'string', + ), + ), + ), + 'Timeline' => array( + 'type' => 'object', + 'properties' => array( + 'CreationDateTime' => array( + 'type' => 'string', + ), + 'StartDateTime' => array( + 'type' => 'string', + ), + 'EndDateTime' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'RunJobFlowOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'JobFlowId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + ), + 'iterators' => array( + '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-sdk-php/src/Aws/Glacier/Enum/Action.php b/vendor/aws/aws-sdk-php/src/Aws/Glacier/Enum/Action.php new file mode 100644 index 0000000..00ec7a8 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Glacier/GlacierUploadListener.php b/vendor/aws/aws-sdk-php/src/Aws/Glacier/GlacierUploadListener.php new file mode 100644 index 0000000..2e95cdd --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Glacier/Model/MultipartUpload/AbstractTransfer.php b/vendor/aws/aws-sdk-php/src/Aws/Glacier/Model/MultipartUpload/AbstractTransfer.php new file mode 100644 index 0000000..d7b1a74 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Glacier/Model/MultipartUpload/ParallelTransfer.php b/vendor/aws/aws-sdk-php/src/Aws/Glacier/Model/MultipartUpload/ParallelTransfer.php new file mode 100644 index 0000000..8f6c0e0 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Glacier/Model/MultipartUpload/SerialTransfer.php b/vendor/aws/aws-sdk-php/src/Aws/Glacier/Model/MultipartUpload/SerialTransfer.php new file mode 100644 index 0000000..f23dfb1 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Glacier/Model/MultipartUpload/TransferState.php b/vendor/aws/aws-sdk-php/src/Aws/Glacier/Model/MultipartUpload/TransferState.php new file mode 100644 index 0000000..a4abeb2 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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 self + */ + 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-sdk-php/src/Aws/Glacier/Model/MultipartUpload/UploadBuilder.php b/vendor/aws/aws-sdk-php/src/Aws/Glacier/Model/MultipartUpload/UploadBuilder.php new file mode 100644 index 0000000..df07baa --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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 self + */ + public function setVaultName($vaultName) + { + $this->vaultName = $vaultName; + + return $this; + } + + /** + * Set the upload part size + * + * @param int $partSize Upload part size + * + * @return self + */ + public function setPartSize($partSize) + { + $this->partSize = (int) $partSize; + + return $this; + } + + /** + * Set the archive description + * + * @param string $archiveDescription Archive description + * + * @return self + */ + public function setArchiveDescription($archiveDescription) + { + $this->archiveDescription = $archiveDescription; + + return $this; + } + + /** + * Set the concurrency level to use when uploading parts. This affects how many parts are uploaded in parallel. You + * must use a local file as your data source when using a concurrency greater than 1 + * + * @param int $concurrency Concurrency level + * + * @return self + */ + public function setConcurrency($concurrency) + { + $this->concurrency = $concurrency; + + return $this; + } + + /** + * Sets the Glacier upload helper object that pre-calculates hashes and sizes for all upload parts + * + * @param UploadPartGenerator $partGenerator Glacier upload helper object + * + * @return self + */ + public function setPartGenerator(UploadPartGenerator $partGenerator) + { + $this->partGenerator = $partGenerator; + + return $this; + } + + /** + * {@inheritdoc} + * @throws InvalidArgumentException when attempting to resume a transfer using a non-seekable stream + * @throws InvalidArgumentException when missing required properties (bucket, key, client, source) + */ + public function build() + { + // If a Glacier upload helper object was set, use the source and part size from it + if ($this->partGenerator) { + $this->partSize = $this->partGenerator->getPartSize(); + } + + if (!($this->state instanceof State) && !$this->vaultName || !$this->client || !$this->source) { + throw new InvalidArgumentException('You must specify a vault name, client, and source.'); + } + + if (!$this->source->isSeekable()) { + throw new InvalidArgumentException('You cannot upload from a non-seekable source.'); + } + + // If no state was set, then create one by initiating or loading a multipart upload + if (is_string($this->state)) { + if (!$this->partGenerator) { + throw new InvalidArgumentException('You must provide an UploadPartGenerator when resuming an upload.'); + } + /** @var $state \Aws\Glacier\Model\MultipartUpload\TransferState */ + $this->state = TransferState::fromUploadId($this->client, UploadId::fromParams(array( + 'accountId' => $this->accountId, + 'vaultName' => $this->vaultName, + 'uploadId' => $this->state + ))); + $this->state->setPartGenerator($this->partGenerator); + } elseif (!$this->state) { + $this->state = $this->initiateMultipartUpload(); + } + + $options = array( + 'concurrency' => $this->concurrency + ); + + return $this->concurrency > 1 + ? new ParallelTransfer($this->client, $this->state, $this->source, $options) + : new SerialTransfer($this->client, $this->state, $this->source, $options); + } + + /** + * {@inheritdoc} + */ + protected function initiateMultipartUpload() + { + $params = array( + 'accountId' => $this->accountId, + 'vaultName' => $this->vaultName + ); + + $partGenerator = $this->partGenerator ?: UploadPartGenerator::factory($this->source, $this->partSize); + + $command = $this->client->getCommand('InitiateMultipartUpload', array_replace($params, array( + 'command.headers' => $this->headers, + 'partSize' => $partGenerator->getPartSize(), + 'archiveDescription' => $this->archiveDescription, + Ua::OPTION => Ua::MULTIPART_UPLOAD + ))); + $params['uploadId'] = $command->getResult()->get('uploadId'); + + // Create a new state based on the initiated upload + $state = new TransferState(UploadId::fromParams($params)); + $state->setPartGenerator($partGenerator); + + return $state; + } +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/Glacier/Model/MultipartUpload/UploadId.php b/vendor/aws/aws-sdk-php/src/Aws/Glacier/Model/MultipartUpload/UploadId.php new file mode 100644 index 0000000..2b5a150 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/Glacier/Model/MultipartUpload/UploadId.php @@ -0,0 +1,35 @@ + '-', + 'uploadId' => false, + 'vaultName' => false + ); +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/Glacier/Model/MultipartUpload/UploadPart.php b/vendor/aws/aws-sdk-php/src/Aws/Glacier/Model/MultipartUpload/UploadPart.php new file mode 100644 index 0000000..ef79aac --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Glacier/Model/MultipartUpload/UploadPartContext.php b/vendor/aws/aws-sdk-php/src/Aws/Glacier/Model/MultipartUpload/UploadPartContext.php new file mode 100644 index 0000000..0706609 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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 self + * @throws LogicException when the context is already finalized + */ + public function addData($data) + { + $size = strlen($data); + + if ($this->size + $size > $this->maxSize) { + throw new LogicException('You cannot add data that will exceed the maximum size of this upload.'); + } + + try { + $this->treeHash->addData($data); + $this->chunkHash->addData($data); + $this->size += $size; + } catch (LogicException $e) { + throw new LogicException('You cannot add data to a finalized UploadPartContext.', 0, $e); + } + + return $this; + } + + /** + * Finalizes the context by calculating the final hashes and generates an upload part object + * + * @return UploadPart + */ + public function generatePart() + { + if (!$this->uploadPart) { + $this->uploadPart = UploadPart::fromArray(array( + 'partNumber' => (int) ($this->offset / $this->maxSize + 1), + 'checksum' => $this->treeHash->getHash(), + 'contentHash' => $this->chunkHash->getHash(), + 'size' => $this->size, + 'offset' => $this->offset + )); + } + + return $this->uploadPart; + } + + /** + * Checks if the size of the context is the same as the maximum size + * + * @return bool + */ + public function isFull() + { + return $this->size === $this->maxSize; + } + + /** + * Checks if the size of the context is 0 + * + * @return bool + */ + public function isEmpty() + { + return $this->size === 0; + } +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/Glacier/Model/MultipartUpload/UploadPartGenerator.php b/vendor/aws/aws-sdk-php/src/Aws/Glacier/Model/MultipartUpload/UploadPartGenerator.php new file mode 100644 index 0000000..49bfeda --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Glacier/Resources/glacier-2012-06-01.php b/vendor/aws/aws-sdk-php/src/Aws/Glacier/Resources/glacier-2012-06-01.php new file mode 100644 index 0000000..b82d6e3 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/Glacier/Resources/glacier-2012-06-01.php @@ -0,0 +1,1480 @@ + '2012-06-01', + 'endpointPrefix' => 'glacier', + 'serviceFullName' => 'Amazon Glacier', + 'serviceType' => 'rest-json', + 'signatureVersion' => 'v4', + 'namespace' => 'Glacier', + 'regions' => array( + 'us-east-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'glacier.us-east-1.amazonaws.com', + ), + 'us-west-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'glacier.us-west-1.amazonaws.com', + ), + 'us-west-2' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'glacier.us-west-2.amazonaws.com', + ), + 'eu-west-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'glacier.eu-west-1.amazonaws.com', + ), + 'ap-southeast-2' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'glacier.ap-southeast-2.amazonaws.com', + ), + 'ap-northeast-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'glacier.ap-northeast-1.amazonaws.com', + ), + 'cn-north-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'glacier.cn-north-1.amazonaws.com.cn', + ), + ), + 'operations' => array( + 'AbortMultipartUpload' => array( + 'httpMethod' => 'DELETE', + 'uri' => '/{accountId}/vaults/{vaultName}/multipart-uploads/{uploadId}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'accountId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'vaultName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'uploadId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'reason' => 'Returned if a required header or parameter is missing from the request.', + 'class' => 'MissingParameterValueException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + 'CompleteMultipartUpload' => array( + 'httpMethod' => 'POST', + 'uri' => '/{accountId}/vaults/{vaultName}/multipart-uploads/{uploadId}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'ArchiveCreationOutput', + 'responseType' => 'model', + 'parameters' => array( + 'accountId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'vaultName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'uploadId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'archiveSize' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-archive-size', + ), + 'checksum' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-sha256-tree-hash', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'reason' => 'Returned if a required header or parameter is missing from the request.', + 'class' => 'MissingParameterValueException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + 'CreateVault' => array( + 'httpMethod' => 'PUT', + 'uri' => '/{accountId}/vaults/{vaultName}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'CreateVaultOutput', + 'responseType' => 'model', + 'parameters' => array( + 'accountId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'vaultName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'reason' => 'Returned if a required header or parameter is missing from the request.', + 'class' => 'MissingParameterValueException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + array( + 'reason' => 'Returned if the request results in a vault or account limit being exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'DeleteArchive' => array( + 'httpMethod' => 'DELETE', + 'uri' => '/{accountId}/vaults/{vaultName}/archives/{archiveId}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'accountId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'vaultName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'archiveId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'reason' => 'Returned if a required header or parameter is missing from the request.', + 'class' => 'MissingParameterValueException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + 'DeleteVault' => array( + 'httpMethod' => 'DELETE', + 'uri' => '/{accountId}/vaults/{vaultName}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'accountId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'vaultName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'reason' => 'Returned if a required header or parameter is missing from the request.', + 'class' => 'MissingParameterValueException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + 'DeleteVaultNotifications' => array( + 'httpMethod' => 'DELETE', + 'uri' => '/{accountId}/vaults/{vaultName}/notification-configuration', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'accountId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'vaultName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'reason' => 'Returned if a required header or parameter is missing from the request.', + 'class' => 'MissingParameterValueException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + 'DescribeJob' => array( + 'httpMethod' => 'GET', + 'uri' => '/{accountId}/vaults/{vaultName}/jobs/{jobId}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'GlacierJobDescription', + 'responseType' => 'model', + 'parameters' => array( + 'accountId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'vaultName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'jobId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'reason' => 'Returned if a required header or parameter is missing from the request.', + 'class' => 'MissingParameterValueException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + 'DescribeVault' => array( + 'httpMethod' => 'GET', + 'uri' => '/{accountId}/vaults/{vaultName}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'DescribeVaultOutput', + 'responseType' => 'model', + 'parameters' => array( + 'accountId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'vaultName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'reason' => 'Returned if a required header or parameter is missing from the request.', + 'class' => 'MissingParameterValueException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + 'GetJobOutput' => array( + 'httpMethod' => 'GET', + 'uri' => '/{accountId}/vaults/{vaultName}/jobs/{jobId}/output', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'GetJobOutputOutput', + 'responseType' => 'model', + 'parameters' => array( + 'accountId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'vaultName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'jobId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'range' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'Range', + ), + 'saveAs' => array( + 'location' => 'response_body', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'reason' => 'Returned if a required header or parameter is missing from the request.', + 'class' => 'MissingParameterValueException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + 'GetVaultNotifications' => array( + 'httpMethod' => 'GET', + 'uri' => '/{accountId}/vaults/{vaultName}/notification-configuration', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'GetVaultNotificationsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'accountId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'vaultName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'reason' => 'Returned if a required header or parameter is missing from the request.', + 'class' => 'MissingParameterValueException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + 'InitiateJob' => array( + 'httpMethod' => 'POST', + 'uri' => '/{accountId}/vaults/{vaultName}/jobs', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'InitiateJobOutput', + 'responseType' => 'model', + 'parameters' => array( + 'accountId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'vaultName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'Format' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Type' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'ArchiveId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Description' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'SNSTopic' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'RetrievalByteRange' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'InventoryRetrievalParameters' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'StartDate' => array( + 'type' => 'string', + ), + 'EndDate' => array( + 'type' => 'string', + ), + 'Limit' => array( + 'type' => 'string', + ), + 'Marker' => array( + 'type' => 'string', + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'reason' => 'Returned if a required header or parameter is missing from the request.', + 'class' => 'MissingParameterValueException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + 'InitiateMultipartUpload' => array( + 'httpMethod' => 'POST', + 'uri' => '/{accountId}/vaults/{vaultName}/multipart-uploads', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'InitiateMultipartUploadOutput', + 'responseType' => 'model', + 'parameters' => array( + 'accountId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'vaultName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'archiveDescription' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-archive-description', + ), + 'partSize' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-part-size', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'reason' => 'Returned if a required header or parameter is missing from the request.', + 'class' => 'MissingParameterValueException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + 'ListJobs' => array( + 'httpMethod' => 'GET', + 'uri' => '/{accountId}/vaults/{vaultName}/jobs', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'ListJobsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'accountId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'vaultName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'limit' => array( + 'type' => 'string', + 'location' => 'query', + ), + 'marker' => array( + 'type' => 'string', + 'location' => 'query', + ), + 'statuscode' => array( + 'type' => 'string', + 'location' => 'query', + ), + 'completed' => array( + 'type' => 'string', + 'location' => 'query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'reason' => 'Returned if a required header or parameter is missing from the request.', + 'class' => 'MissingParameterValueException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + 'ListMultipartUploads' => array( + 'httpMethod' => 'GET', + 'uri' => '/{accountId}/vaults/{vaultName}/multipart-uploads', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'ListMultipartUploadsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'accountId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'vaultName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'limit' => array( + 'type' => 'string', + 'location' => 'query', + ), + 'marker' => array( + 'type' => 'string', + 'location' => 'query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'reason' => 'Returned if a required header or parameter is missing from the request.', + 'class' => 'MissingParameterValueException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + 'ListParts' => array( + 'httpMethod' => 'GET', + 'uri' => '/{accountId}/vaults/{vaultName}/multipart-uploads/{uploadId}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'ListPartsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'accountId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'vaultName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'uploadId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'marker' => array( + 'type' => 'string', + 'location' => 'query', + ), + 'limit' => array( + 'type' => 'string', + 'location' => 'query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'reason' => 'Returned if a required header or parameter is missing from the request.', + 'class' => 'MissingParameterValueException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + 'ListVaults' => array( + 'httpMethod' => 'GET', + 'uri' => '/{accountId}/vaults', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'ListVaultsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'accountId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'marker' => array( + 'type' => 'string', + 'location' => 'query', + ), + 'limit' => array( + 'type' => 'string', + 'location' => 'query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'reason' => 'Returned if a required header or parameter is missing from the request.', + 'class' => 'MissingParameterValueException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + 'SetVaultNotifications' => array( + 'httpMethod' => 'PUT', + 'uri' => '/{accountId}/vaults/{vaultName}/notification-configuration', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'accountId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'vaultName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'SNSTopic' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Events' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'string', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'reason' => 'Returned if a required header or parameter is missing from the request.', + 'class' => 'MissingParameterValueException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + 'UploadArchive' => array( + 'httpMethod' => 'POST', + 'uri' => '/{accountId}/vaults/{vaultName}/archives', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'ArchiveCreationOutput', + 'responseType' => 'model', + 'parameters' => array( + 'vaultName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'accountId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'archiveDescription' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-archive-description', + ), + 'checksum' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-sha256-tree-hash', + ), + 'body' => array( + 'type' => array( + 'string', + 'object', + ), + 'location' => 'body', + ), + 'ContentSHA256' => array( + 'default' => true, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'reason' => 'Returned if a required header or parameter is missing from the request.', + 'class' => 'MissingParameterValueException', + ), + array( + 'reason' => 'Returned if, when uploading an archive, Amazon Glacier times out while receiving the upload.', + 'class' => 'RequestTimeoutException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + 'UploadMultipartPart' => array( + 'httpMethod' => 'PUT', + 'uri' => '/{accountId}/vaults/{vaultName}/multipart-uploads/{uploadId}', + 'class' => 'Guzzle\\Service\\Command\\OperationCommand', + 'responseClass' => 'UploadMultipartPartOutput', + 'responseType' => 'model', + 'parameters' => array( + 'accountId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'vaultName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'uploadId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'checksum' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-sha256-tree-hash', + ), + 'range' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'Content-Range', + ), + 'body' => array( + 'type' => array( + 'string', + 'object', + ), + 'location' => 'body', + ), + 'ContentSHA256' => array( + 'default' => true, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if the specified resource, such as a vault, upload ID, or job ID, does not exist.', + 'class' => 'ResourceNotFoundException', + ), + array( + 'reason' => 'Returned if a parameter of the request is incorrectly specified.', + 'class' => 'InvalidParameterValueException', + ), + array( + 'reason' => 'Returned if a required header or parameter is missing from the request.', + 'class' => 'MissingParameterValueException', + ), + array( + 'reason' => 'Returned if, when uploading an archive, Amazon Glacier times out while receiving the upload.', + 'class' => 'RequestTimeoutException', + ), + array( + 'reason' => 'Returned if the service cannot complete the request.', + 'class' => 'ServiceUnavailableException', + ), + ), + ), + ), + 'models' => array( + 'EmptyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + ), + 'ArchiveCreationOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'location' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'Location', + ), + 'checksum' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-sha256-tree-hash', + ), + 'archiveId' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-archive-id', + ), + ), + ), + 'CreateVaultOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'location' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'Location', + ), + ), + ), + 'GlacierJobDescription' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'JobId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'JobDescription' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Action' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'ArchiveId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'VaultARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'CreationDate' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Completed' => array( + 'type' => 'boolean', + 'location' => 'json', + ), + 'StatusCode' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'StatusMessage' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'ArchiveSizeInBytes' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'InventorySizeInBytes' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'SNSTopic' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'CompletionDate' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'SHA256TreeHash' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'ArchiveSHA256TreeHash' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'RetrievalByteRange' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'InventoryRetrievalParameters' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Format' => array( + 'type' => 'string', + ), + 'StartDate' => array( + 'type' => 'string', + ), + 'EndDate' => array( + 'type' => 'string', + ), + 'Limit' => array( + 'type' => 'string', + ), + 'Marker' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'DescribeVaultOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'VaultARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'VaultName' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'CreationDate' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'LastInventoryDate' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'NumberOfArchives' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'SizeInBytes' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + ), + ), + 'GetJobOutputOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'body' => array( + 'type' => 'string', + 'instanceOf' => 'Guzzle\\Http\\EntityBody', + 'location' => 'body', + ), + 'checksum' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-sha256-tree-hash', + ), + 'status' => array( + 'type' => 'numeric', + 'location' => 'statusCode', + ), + 'contentRange' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'Content-Range', + ), + 'acceptRanges' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'Accept-Ranges', + ), + 'contentType' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'Content-Type', + ), + 'archiveDescription' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-archive-description', + ), + ), + ), + 'GetVaultNotificationsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'SNSTopic' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Events' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'string', + 'type' => 'string', + ), + ), + ), + ), + 'InitiateJobOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'location' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'Location', + ), + 'jobId' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-job-id', + ), + ), + ), + 'InitiateMultipartUploadOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'location' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'Location', + ), + 'uploadId' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-multipart-upload-id', + ), + ), + ), + 'ListJobsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'JobList' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'GlacierJobDescription', + 'type' => 'object', + 'properties' => array( + 'JobId' => array( + 'type' => 'string', + ), + 'JobDescription' => array( + 'type' => 'string', + ), + 'Action' => array( + 'type' => 'string', + ), + 'ArchiveId' => array( + 'type' => 'string', + ), + 'VaultARN' => array( + 'type' => 'string', + ), + 'CreationDate' => array( + 'type' => 'string', + ), + 'Completed' => array( + 'type' => 'boolean', + ), + 'StatusCode' => array( + 'type' => 'string', + ), + 'StatusMessage' => array( + 'type' => 'string', + ), + 'ArchiveSizeInBytes' => array( + 'type' => 'numeric', + ), + 'InventorySizeInBytes' => array( + 'type' => 'numeric', + ), + 'SNSTopic' => array( + 'type' => 'string', + ), + 'CompletionDate' => array( + 'type' => 'string', + ), + 'SHA256TreeHash' => array( + 'type' => 'string', + ), + 'ArchiveSHA256TreeHash' => array( + 'type' => 'string', + ), + 'RetrievalByteRange' => array( + 'type' => 'string', + ), + 'InventoryRetrievalParameters' => array( + 'type' => 'object', + 'properties' => array( + 'Format' => array( + 'type' => 'string', + ), + 'StartDate' => array( + 'type' => 'string', + ), + 'EndDate' => array( + 'type' => 'string', + ), + 'Limit' => array( + 'type' => 'string', + ), + 'Marker' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListMultipartUploadsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'UploadsList' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'UploadListElement', + 'type' => 'object', + 'properties' => array( + 'MultipartUploadId' => array( + 'type' => 'string', + ), + 'VaultARN' => array( + 'type' => 'string', + ), + 'ArchiveDescription' => array( + 'type' => 'string', + ), + 'PartSizeInBytes' => array( + 'type' => 'numeric', + ), + 'CreationDate' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListPartsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'MultipartUploadId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'VaultARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'ArchiveDescription' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'PartSizeInBytes' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'CreationDate' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Parts' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'PartListElement', + 'type' => 'object', + 'properties' => array( + 'RangeInBytes' => array( + 'type' => 'string', + ), + 'SHA256TreeHash' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListVaultsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'VaultList' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'DescribeVaultOutput', + 'type' => 'object', + 'properties' => array( + 'VaultARN' => array( + 'type' => 'string', + ), + 'VaultName' => array( + 'type' => 'string', + ), + 'CreationDate' => array( + 'type' => 'string', + ), + 'LastInventoryDate' => array( + 'type' => 'string', + ), + 'NumberOfArchives' => array( + 'type' => 'numeric', + ), + 'SizeInBytes' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'UploadMultipartPartOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'checksum' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-sha256-tree-hash', + ), + ), + ), + ), + '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-sdk-php/src/Aws/Iam/Enum/AssignmentStatusType.php b/vendor/aws/aws-sdk-php/src/Aws/Iam/Enum/AssignmentStatusType.php new file mode 100644 index 0000000..c9d1c6a --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Iam/Resources/iam-2010-05-08.php b/vendor/aws/aws-sdk-php/src/Aws/Iam/Resources/iam-2010-05-08.php new file mode 100644 index 0000000..c88d1b4 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/Iam/Resources/iam-2010-05-08.php @@ -0,0 +1,4677 @@ + '2010-05-08', + 'endpointPrefix' => 'iam', + 'serviceFullName' => 'AWS Identity and Access Management', + 'serviceAbbreviation' => 'IAM', + 'serviceType' => 'query', + 'globalEndpoint' => 'iam.amazonaws.com', + 'resultWrapped' => true, + 'signatureVersion' => 'v4', + 'namespace' => 'Iam', + 'regions' => array( + 'us-east-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'iam.amazonaws.com', + ), + 'us-west-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'iam.amazonaws.com', + ), + 'us-west-2' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'iam.amazonaws.com', + ), + 'eu-west-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'iam.amazonaws.com', + ), + 'ap-northeast-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'iam.amazonaws.com', + ), + 'ap-southeast-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'iam.amazonaws.com', + ), + 'ap-southeast-2' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'iam.amazonaws.com', + ), + 'sa-east-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'iam.amazonaws.com', + ), + 'cn-north-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'iam.cn-north-1.amazonaws.com.cn', + ), + 'us-gov-west-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'iam.us-gov.amazonaws.com', + ), + ), + 'operations' => array( + 'AddRoleToInstanceProfile' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'AddRoleToInstanceProfile', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'InstanceProfileName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'RoleName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 64, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', + 'class' => 'EntityAlreadyExistsException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'AddUserToGroup' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'AddUserToGroup', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'GroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'UserName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'ChangePassword' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ChangePassword', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'OldPassword' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'NewPassword' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'reason' => 'The request was rejected because the type of user for the transaction was incorrect.', + 'class' => 'InvalidUserTypeException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + array( + 'reason' => 'The request was rejected because it referenced an entity that is temporarily unmodifiable, such as a user name that was deleted and then recreated. The error indicates that the request is likely to succeed if you try again after waiting several minutes. The error message describes the entity.', + 'class' => 'EntityTemporarilyUnmodifiableException', + ), + ), + ), + 'CreateAccessKey' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'CreateAccessKeyResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateAccessKey', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'UserName' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'CreateAccountAlias' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateAccountAlias', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'AccountAlias' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 3, + 'maxLength' => 63, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', + 'class' => 'EntityAlreadyExistsException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'CreateGroup' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'CreateGroupResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateGroup', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'Path' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 512, + ), + 'GroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', + 'class' => 'EntityAlreadyExistsException', + ), + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + ), + ), + 'CreateInstanceProfile' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'CreateInstanceProfileResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateInstanceProfile', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'InstanceProfileName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'Path' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 512, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', + 'class' => 'EntityAlreadyExistsException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'CreateLoginProfile' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'CreateLoginProfileResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateLoginProfile', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'UserName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'Password' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', + 'class' => 'EntityAlreadyExistsException', + ), + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'reason' => 'The request was rejected because the provided password did not meet the requirements imposed by the account password policy.', + 'class' => 'PasswordPolicyViolationException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'CreateRole' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'CreateRoleResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateRole', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'Path' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 512, + ), + 'RoleName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'AssumeRolePolicyDocument' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 131072, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', + 'class' => 'EntityAlreadyExistsException', + ), + array( + 'reason' => 'The request was rejected because the policy document was malformed. The error message describes the specific error.', + 'class' => 'MalformedPolicyDocumentException', + ), + ), + ), + 'CreateSAMLProvider' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'CreateSAMLProviderResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateSAMLProvider', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'SAMLMetadataDocument' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1000, + 'maxLength' => 10000000, + ), + 'Name' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', + 'class' => 'EntityAlreadyExistsException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'CreateUser' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'CreateUserResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateUser', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'Path' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 512, + ), + 'UserName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 64, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', + 'class' => 'EntityAlreadyExistsException', + ), + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + ), + ), + 'CreateVirtualMFADevice' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'CreateVirtualMFADeviceResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateVirtualMFADevice', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'Path' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 512, + ), + 'VirtualMFADeviceName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', + 'class' => 'EntityAlreadyExistsException', + ), + ), + ), + 'DeactivateMFADevice' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeactivateMFADevice', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'UserName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'SerialNumber' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 9, + 'maxLength' => 256, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that is temporarily unmodifiable, such as a user name that was deleted and then recreated. The error indicates that the request is likely to succeed if you try again after waiting several minutes. The error message describes the entity.', + 'class' => 'EntityTemporarilyUnmodifiableException', + ), + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'DeleteAccessKey' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteAccessKey', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'UserName' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'AccessKeyId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 16, + 'maxLength' => 32, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'DeleteAccountAlias' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteAccountAlias', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'AccountAlias' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 3, + 'maxLength' => 63, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'DeleteAccountPasswordPolicy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteAccountPasswordPolicy', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + ), + ), + 'DeleteGroup' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteGroup', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'GroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'reason' => 'The request was rejected because it attempted to delete a resource that has attached subordinate entities. The error message describes these entities.', + 'class' => 'DeleteConflictException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'DeleteGroupPolicy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteGroupPolicy', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'GroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'PolicyName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'DeleteInstanceProfile' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteInstanceProfile', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'InstanceProfileName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'reason' => 'The request was rejected because it attempted to delete a resource that has attached subordinate entities. The error message describes these entities.', + 'class' => 'DeleteConflictException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'DeleteLoginProfile' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteLoginProfile', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'UserName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 64, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that is temporarily unmodifiable, such as a user name that was deleted and then recreated. The error indicates that the request is likely to succeed if you try again after waiting several minutes. The error message describes the entity.', + 'class' => 'EntityTemporarilyUnmodifiableException', + ), + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'DeleteRole' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteRole', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'RoleName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 64, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'reason' => 'The request was rejected because it attempted to delete a resource that has attached subordinate entities. The error message describes these entities.', + 'class' => 'DeleteConflictException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'DeleteRolePolicy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteRolePolicy', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'RoleName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'PolicyName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'DeleteSAMLProvider' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteSAMLProvider', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'SAMLProviderArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 20, + 'maxLength' => 2048, + ), + ), + 'errorResponses' => array( + array( + 'class' => 'InvalidInputException', + ), + ), + ), + 'DeleteServerCertificate' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteServerCertificate', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'ServerCertificateName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'reason' => 'The request was rejected because it attempted to delete a resource that has attached subordinate entities. The error message describes these entities.', + 'class' => 'DeleteConflictException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'DeleteSigningCertificate' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteSigningCertificate', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'UserName' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'CertificateId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 24, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'DeleteUser' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteUser', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'UserName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'reason' => 'The request was rejected because it attempted to delete a resource that has attached subordinate entities. The error message describes these entities.', + 'class' => 'DeleteConflictException', + ), + ), + ), + 'DeleteUserPolicy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteUserPolicy', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'UserName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'PolicyName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'DeleteVirtualMFADevice' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteVirtualMFADevice', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'SerialNumber' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 9, + 'maxLength' => 256, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'reason' => 'The request was rejected because it attempted to delete a resource that has attached subordinate entities. The error message describes these entities.', + 'class' => 'DeleteConflictException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'EnableMFADevice' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'EnableMFADevice', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'UserName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'SerialNumber' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 9, + 'maxLength' => 256, + ), + 'AuthenticationCode1' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 6, + 'maxLength' => 6, + ), + 'AuthenticationCode2' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 6, + 'maxLength' => 6, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', + 'class' => 'EntityAlreadyExistsException', + ), + array( + 'reason' => 'The request was rejected because it referenced an entity that is temporarily unmodifiable, such as a user name that was deleted and then recreated. The error indicates that the request is likely to succeed if you try again after waiting several minutes. The error message describes the entity.', + 'class' => 'EntityTemporarilyUnmodifiableException', + ), + array( + 'reason' => 'The request was rejected because the authentication code was not recognized. The error message describes the specific error.', + 'class' => 'InvalidAuthenticationCodeException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + ), + ), + 'GetAccountPasswordPolicy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'GetAccountPasswordPolicyResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'GetAccountPasswordPolicy', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + ), + ), + 'GetAccountSummary' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'GetAccountSummaryResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'GetAccountSummary', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + ), + ), + 'GetGroup' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'GetGroupResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'GetGroup', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'GroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 320, + ), + 'MaxItems' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + 'minimum' => 1, + 'maximum' => 1000, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + ), + ), + 'GetGroupPolicy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'GetGroupPolicyResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'GetGroupPolicy', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'GroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'PolicyName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + ), + ), + 'GetInstanceProfile' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'GetInstanceProfileResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'GetInstanceProfile', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'InstanceProfileName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + ), + ), + 'GetLoginProfile' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'GetLoginProfileResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'GetLoginProfile', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'UserName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 64, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + ), + ), + 'GetRole' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'GetRoleResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'GetRole', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'RoleName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 64, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + ), + ), + 'GetRolePolicy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'GetRolePolicyResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'GetRolePolicy', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'RoleName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'PolicyName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + ), + ), + 'GetSAMLProvider' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'GetSAMLProviderResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'GetSAMLProvider', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'SAMLProviderArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 20, + 'maxLength' => 2048, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'class' => 'InvalidInputException', + ), + ), + ), + 'GetServerCertificate' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'GetServerCertificateResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'GetServerCertificate', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'ServerCertificateName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + ), + ), + 'GetUser' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'GetUserResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'GetUser', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'UserName' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + ), + ), + 'GetUserPolicy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'GetUserPolicyResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'GetUserPolicy', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'UserName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'PolicyName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + ), + ), + 'ListAccessKeys' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListAccessKeysResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListAccessKeys', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'UserName' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 320, + ), + 'MaxItems' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + 'minimum' => 1, + 'maximum' => 1000, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + ), + ), + 'ListAccountAliases' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListAccountAliasesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListAccountAliases', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 320, + ), + 'MaxItems' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + 'minimum' => 1, + 'maximum' => 1000, + ), + ), + ), + 'ListGroupPolicies' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListGroupPoliciesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListGroupPolicies', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'GroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 320, + ), + 'MaxItems' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + 'minimum' => 1, + 'maximum' => 1000, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + ), + ), + 'ListGroups' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListGroupsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListGroups', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'PathPrefix' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 512, + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 320, + ), + 'MaxItems' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + 'minimum' => 1, + 'maximum' => 1000, + ), + ), + ), + 'ListGroupsForUser' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListGroupsForUserResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListGroupsForUser', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'UserName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 320, + ), + 'MaxItems' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + 'minimum' => 1, + 'maximum' => 1000, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + ), + ), + 'ListInstanceProfiles' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListInstanceProfilesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListInstanceProfiles', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'PathPrefix' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 512, + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 320, + ), + 'MaxItems' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + 'minimum' => 1, + 'maximum' => 1000, + ), + ), + ), + 'ListInstanceProfilesForRole' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListInstanceProfilesForRoleResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListInstanceProfilesForRole', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'RoleName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 320, + ), + 'MaxItems' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + 'minimum' => 1, + 'maximum' => 1000, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + ), + ), + 'ListMFADevices' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListMFADevicesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListMFADevices', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'UserName' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 320, + ), + 'MaxItems' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + 'minimum' => 1, + 'maximum' => 1000, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + ), + ), + 'ListRolePolicies' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListRolePoliciesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListRolePolicies', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'RoleName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 320, + ), + 'MaxItems' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + 'minimum' => 1, + 'maximum' => 1000, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + ), + ), + 'ListRoles' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListRolesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListRoles', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'PathPrefix' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 512, + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 320, + ), + 'MaxItems' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + 'minimum' => 1, + 'maximum' => 1000, + ), + ), + ), + 'ListSAMLProviders' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListSAMLProvidersResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListSAMLProviders', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + ), + ), + 'ListServerCertificates' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListServerCertificatesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListServerCertificates', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'PathPrefix' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 512, + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 320, + ), + 'MaxItems' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + 'minimum' => 1, + 'maximum' => 1000, + ), + ), + ), + 'ListSigningCertificates' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListSigningCertificatesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListSigningCertificates', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'UserName' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 320, + ), + 'MaxItems' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + 'minimum' => 1, + 'maximum' => 1000, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + ), + ), + 'ListUserPolicies' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListUserPoliciesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListUserPolicies', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'UserName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 320, + ), + 'MaxItems' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + 'minimum' => 1, + 'maximum' => 1000, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + ), + ), + 'ListUsers' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListUsersResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListUsers', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'PathPrefix' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 512, + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 320, + ), + 'MaxItems' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + 'minimum' => 1, + 'maximum' => 1000, + ), + ), + ), + 'ListVirtualMFADevices' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListVirtualMFADevicesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListVirtualMFADevices', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'AssignmentStatus' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 320, + ), + 'MaxItems' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + 'minimum' => 1, + 'maximum' => 1000, + ), + ), + ), + 'PutGroupPolicy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'PutGroupPolicy', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'GroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'PolicyName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'PolicyDocument' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 131072, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + array( + 'reason' => 'The request was rejected because the policy document was malformed. The error message describes the specific error.', + 'class' => 'MalformedPolicyDocumentException', + ), + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + ), + ), + 'PutRolePolicy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'PutRolePolicy', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'RoleName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'PolicyName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'PolicyDocument' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 131072, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + array( + 'reason' => 'The request was rejected because the policy document was malformed. The error message describes the specific error.', + 'class' => 'MalformedPolicyDocumentException', + ), + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + ), + ), + 'PutUserPolicy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'PutUserPolicy', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'UserName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'PolicyName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'PolicyDocument' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 131072, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + array( + 'reason' => 'The request was rejected because the policy document was malformed. The error message describes the specific error.', + 'class' => 'MalformedPolicyDocumentException', + ), + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + ), + ), + 'RemoveRoleFromInstanceProfile' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'RemoveRoleFromInstanceProfile', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'InstanceProfileName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'RoleName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 64, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'RemoveUserFromGroup' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'RemoveUserFromGroup', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'GroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'UserName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'ResyncMFADevice' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ResyncMFADevice', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'UserName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'SerialNumber' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 9, + 'maxLength' => 256, + ), + 'AuthenticationCode1' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 6, + 'maxLength' => 6, + ), + 'AuthenticationCode2' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 6, + 'maxLength' => 6, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because the authentication code was not recognized. The error message describes the specific error.', + 'class' => 'InvalidAuthenticationCodeException', + ), + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'UpdateAccessKey' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'UpdateAccessKey', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'UserName' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'AccessKeyId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 16, + 'maxLength' => 32, + ), + 'Status' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'UpdateAccountPasswordPolicy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'UpdateAccountPasswordPolicy', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'MinimumPasswordLength' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + 'minimum' => 6, + 'maximum' => 128, + ), + 'RequireSymbols' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'RequireNumbers' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'RequireUppercaseCharacters' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'RequireLowercaseCharacters' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'AllowUsersToChangePassword' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'reason' => 'The request was rejected because the policy document was malformed. The error message describes the specific error.', + 'class' => 'MalformedPolicyDocumentException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'UpdateAssumeRolePolicy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'UpdateAssumeRolePolicy', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'RoleName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'PolicyDocument' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 131072, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'reason' => 'The request was rejected because the policy document was malformed. The error message describes the specific error.', + 'class' => 'MalformedPolicyDocumentException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'UpdateGroup' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'UpdateGroup', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'GroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'NewPath' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 512, + ), + 'NewGroupName' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', + 'class' => 'EntityAlreadyExistsException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'UpdateLoginProfile' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'UpdateLoginProfile', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'UserName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'Password' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that is temporarily unmodifiable, such as a user name that was deleted and then recreated. The error indicates that the request is likely to succeed if you try again after waiting several minutes. The error message describes the entity.', + 'class' => 'EntityTemporarilyUnmodifiableException', + ), + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'reason' => 'The request was rejected because the provided password did not meet the requirements imposed by the account password policy.', + 'class' => 'PasswordPolicyViolationException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'UpdateSAMLProvider' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'UpdateSAMLProviderResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'UpdateSAMLProvider', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'SAMLMetadataDocument' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1000, + 'maxLength' => 10000000, + ), + 'SAMLProviderArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 20, + 'maxLength' => 2048, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'UpdateServerCertificate' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'UpdateServerCertificate', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'ServerCertificateName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'NewPath' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 512, + ), + 'NewServerCertificateName' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', + 'class' => 'EntityAlreadyExistsException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'UpdateSigningCertificate' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'UpdateSigningCertificate', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'UserName' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'CertificateId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 24, + 'maxLength' => 128, + ), + 'Status' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + ), + ), + 'UpdateUser' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'UpdateUser', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'UserName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'NewPath' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 512, + ), + 'NewUserName' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 64, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', + 'class' => 'EntityAlreadyExistsException', + ), + array( + 'reason' => 'The request was rejected because it referenced an entity that is temporarily unmodifiable, such as a user name that was deleted and then recreated. The error indicates that the request is likely to succeed if you try again after waiting several minutes. The error message describes the entity.', + 'class' => 'EntityTemporarilyUnmodifiableException', + ), + ), + ), + 'UploadServerCertificate' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'UploadServerCertificateResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'UploadServerCertificate', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'Path' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 512, + ), + 'ServerCertificateName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'CertificateBody' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 16384, + ), + 'PrivateKey' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 16384, + ), + 'CertificateChain' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 2097152, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', + 'class' => 'EntityAlreadyExistsException', + ), + array( + 'reason' => 'The request was rejected because the certificate was malformed or expired. The error message describes the specific error.', + 'class' => 'MalformedCertificateException', + ), + array( + 'reason' => 'The request was rejected because the public key certificate and the private key do not match.', + 'class' => 'KeyPairMismatchException', + ), + ), + ), + 'UploadSigningCertificate' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'UploadSigningCertificateResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'UploadSigningCertificate', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-05-08', + ), + 'UserName' => array( + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'CertificateBody' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + 'minLength' => 1, + 'maxLength' => 16384, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request was rejected because it attempted to create resources beyond the current AWS account limits. The error message describes the limit exceeded.', + 'class' => 'LimitExceededException', + ), + array( + 'reason' => 'The request was rejected because it attempted to create a resource that already exists.', + 'class' => 'EntityAlreadyExistsException', + ), + array( + 'reason' => 'The request was rejected because the certificate was malformed or expired. The error message describes the specific error.', + 'class' => 'MalformedCertificateException', + ), + array( + 'reason' => 'The request was rejected because the certificate is invalid.', + 'class' => 'InvalidCertificateException', + ), + array( + 'reason' => 'The request was rejected because the same certificate is associated to another user under the account.', + 'class' => 'DuplicateCertificateException', + ), + array( + 'reason' => 'The request was rejected because it referenced an entity that does not exist. The error message describes the entity.', + 'class' => 'NoSuchEntityException', + ), + ), + ), + ), + 'models' => array( + 'EmptyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + ), + 'CreateAccessKeyResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'AccessKey' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'UserName' => array( + 'type' => 'string', + ), + 'AccessKeyId' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'SecretAccessKey' => array( + 'type' => 'string', + ), + 'CreateDate' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'CreateGroupResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Group' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Path' => array( + 'type' => 'string', + ), + 'GroupName' => array( + 'type' => 'string', + ), + 'GroupId' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'CreateDate' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'CreateInstanceProfileResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'InstanceProfile' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Path' => array( + 'type' => 'string', + ), + 'InstanceProfileName' => array( + 'type' => 'string', + ), + 'InstanceProfileId' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'CreateDate' => array( + 'type' => 'string', + ), + 'Roles' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Role', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Path' => array( + 'type' => 'string', + ), + 'RoleName' => array( + 'type' => 'string', + ), + 'RoleId' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'CreateDate' => array( + 'type' => 'string', + ), + 'AssumeRolePolicyDocument' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'CreateLoginProfileResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'LoginProfile' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'UserName' => array( + 'type' => 'string', + ), + 'CreateDate' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'CreateRoleResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Role' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Path' => array( + 'type' => 'string', + ), + 'RoleName' => array( + 'type' => 'string', + ), + 'RoleId' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'CreateDate' => array( + 'type' => 'string', + ), + 'AssumeRolePolicyDocument' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'CreateSAMLProviderResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'SAMLProviderArn' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'CreateUserResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'User' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Path' => array( + 'type' => 'string', + ), + 'UserName' => array( + 'type' => 'string', + ), + 'UserId' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'CreateDate' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'CreateVirtualMFADeviceResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'VirtualMFADevice' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'SerialNumber' => array( + 'type' => 'string', + ), + 'Base32StringSeed' => array( + 'type' => 'string', + ), + 'QRCodePNG' => array( + 'type' => 'string', + ), + 'User' => array( + 'type' => 'object', + 'properties' => array( + 'Path' => array( + 'type' => 'string', + ), + 'UserName' => array( + 'type' => 'string', + ), + 'UserId' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'CreateDate' => array( + 'type' => 'string', + ), + ), + ), + 'EnableDate' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'GetAccountPasswordPolicyResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'PasswordPolicy' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'MinimumPasswordLength' => array( + 'type' => 'numeric', + ), + 'RequireSymbols' => array( + 'type' => 'boolean', + ), + 'RequireNumbers' => array( + 'type' => 'boolean', + ), + 'RequireUppercaseCharacters' => array( + 'type' => 'boolean', + ), + 'RequireLowercaseCharacters' => array( + 'type' => 'boolean', + ), + 'AllowUsersToChangePassword' => array( + 'type' => 'boolean', + ), + 'ExpirePasswords' => array( + 'type' => 'boolean', + ), + 'MaxPasswordAge' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + 'GetAccountSummaryResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'SummaryMap' => array( + 'type' => 'array', + 'location' => 'xml', + 'data' => array( + 'xmlMap' => array( + 'Users', + 'UsersQuota', + 'Groups', + 'GroupsQuota', + 'ServerCertificates', + 'ServerCertificatesQuota', + 'UserPolicySizeQuota', + 'GroupPolicySizeQuota', + 'GroupsPerUserQuota', + 'SigningCertificatesPerUserQuota', + 'AccessKeysPerUserQuota', + 'MFADevices', + 'MFADevicesInUse', + 'AccountMFAEnabled', + ), + ), + 'filters' => array( + array( + 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', + 'args' => array( + '@value', + 'entry', + 'key', + 'value', + ), + ), + ), + 'items' => array( + 'name' => 'entry', + 'type' => 'object', + 'sentAs' => 'entry', + 'additionalProperties' => true, + 'properties' => array( + 'key' => array( + 'type' => 'string', + ), + 'value' => array( + 'type' => 'numeric', + ), + ), + ), + 'additionalProperties' => false, + ), + ), + ), + 'GetGroupResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Group' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Path' => array( + 'type' => 'string', + ), + 'GroupName' => array( + 'type' => 'string', + ), + 'GroupId' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'CreateDate' => array( + 'type' => 'string', + ), + ), + ), + 'Users' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'User', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Path' => array( + 'type' => 'string', + ), + 'UserName' => array( + 'type' => 'string', + ), + 'UserId' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'CreateDate' => array( + 'type' => 'string', + ), + ), + ), + ), + 'IsTruncated' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'GetGroupPolicyResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'GroupName' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'PolicyName' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'PolicyDocument' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'GetInstanceProfileResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'InstanceProfile' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Path' => array( + 'type' => 'string', + ), + 'InstanceProfileName' => array( + 'type' => 'string', + ), + 'InstanceProfileId' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'CreateDate' => array( + 'type' => 'string', + ), + 'Roles' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Role', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Path' => array( + 'type' => 'string', + ), + 'RoleName' => array( + 'type' => 'string', + ), + 'RoleId' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'CreateDate' => array( + 'type' => 'string', + ), + 'AssumeRolePolicyDocument' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'GetLoginProfileResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'LoginProfile' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'UserName' => array( + 'type' => 'string', + ), + 'CreateDate' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'GetRoleResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Role' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Path' => array( + 'type' => 'string', + ), + 'RoleName' => array( + 'type' => 'string', + ), + 'RoleId' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'CreateDate' => array( + 'type' => 'string', + ), + 'AssumeRolePolicyDocument' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'GetRolePolicyResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RoleName' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'PolicyName' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'PolicyDocument' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'GetSAMLProviderResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'SAMLMetadataDocument' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'CreateDate' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'ValidUntil' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'GetServerCertificateResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ServerCertificate' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'ServerCertificateMetadata' => array( + 'type' => 'object', + 'properties' => array( + 'Path' => array( + 'type' => 'string', + ), + 'ServerCertificateName' => array( + 'type' => 'string', + ), + 'ServerCertificateId' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'UploadDate' => array( + 'type' => 'string', + ), + ), + ), + 'CertificateBody' => array( + 'type' => 'string', + ), + 'CertificateChain' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'GetUserResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'User' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Path' => array( + 'type' => 'string', + ), + 'UserName' => array( + 'type' => 'string', + ), + 'UserId' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'CreateDate' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'GetUserPolicyResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'UserName' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'PolicyName' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'PolicyDocument' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'ListAccessKeysResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'AccessKeyMetadata' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'AccessKeyMetadata', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'UserName' => array( + 'type' => 'string', + ), + 'AccessKeyId' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'CreateDate' => array( + 'type' => 'string', + ), + ), + ), + ), + 'IsTruncated' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'ListAccountAliasesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'AccountAliases' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'accountAliasType', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + 'IsTruncated' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'ListGroupPoliciesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'PolicyNames' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'policyNameType', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + 'IsTruncated' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'ListGroupsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Groups' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'Group', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Path' => array( + 'type' => 'string', + ), + 'GroupName' => array( + 'type' => 'string', + ), + 'GroupId' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'CreateDate' => array( + 'type' => 'string', + ), + ), + ), + ), + 'IsTruncated' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'ListGroupsForUserResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Groups' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'Group', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Path' => array( + 'type' => 'string', + ), + 'GroupName' => array( + 'type' => 'string', + ), + 'GroupId' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'CreateDate' => array( + 'type' => 'string', + ), + ), + ), + ), + 'IsTruncated' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'ListInstanceProfilesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'InstanceProfiles' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'InstanceProfile', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Path' => array( + 'type' => 'string', + ), + 'InstanceProfileName' => array( + 'type' => 'string', + ), + 'InstanceProfileId' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'CreateDate' => array( + 'type' => 'string', + ), + 'Roles' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Role', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Path' => array( + 'type' => 'string', + ), + 'RoleName' => array( + 'type' => 'string', + ), + 'RoleId' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'CreateDate' => array( + 'type' => 'string', + ), + 'AssumeRolePolicyDocument' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'IsTruncated' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'ListInstanceProfilesForRoleResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'InstanceProfiles' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'InstanceProfile', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Path' => array( + 'type' => 'string', + ), + 'InstanceProfileName' => array( + 'type' => 'string', + ), + 'InstanceProfileId' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'CreateDate' => array( + 'type' => 'string', + ), + 'Roles' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Role', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Path' => array( + 'type' => 'string', + ), + 'RoleName' => array( + 'type' => 'string', + ), + 'RoleId' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'CreateDate' => array( + 'type' => 'string', + ), + 'AssumeRolePolicyDocument' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'IsTruncated' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'ListMFADevicesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'MFADevices' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'MFADevice', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'UserName' => array( + 'type' => 'string', + ), + 'SerialNumber' => array( + 'type' => 'string', + ), + 'EnableDate' => array( + 'type' => 'string', + ), + ), + ), + ), + 'IsTruncated' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'ListRolePoliciesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'PolicyNames' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'policyNameType', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + 'IsTruncated' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'ListRolesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Roles' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'Role', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Path' => array( + 'type' => 'string', + ), + 'RoleName' => array( + 'type' => 'string', + ), + 'RoleId' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'CreateDate' => array( + 'type' => 'string', + ), + 'AssumeRolePolicyDocument' => array( + 'type' => 'string', + ), + ), + ), + ), + 'IsTruncated' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'ListSAMLProvidersResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'SAMLProviderList' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'SAMLProviderListEntry', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Arn' => array( + 'type' => 'string', + ), + 'ValidUntil' => array( + 'type' => 'string', + ), + 'CreateDate' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'ListServerCertificatesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ServerCertificateMetadataList' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'ServerCertificateMetadata', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Path' => array( + 'type' => 'string', + ), + 'ServerCertificateName' => array( + 'type' => 'string', + ), + 'ServerCertificateId' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'UploadDate' => array( + 'type' => 'string', + ), + ), + ), + ), + 'IsTruncated' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'ListSigningCertificatesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Certificates' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'SigningCertificate', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'UserName' => array( + 'type' => 'string', + ), + 'CertificateId' => array( + 'type' => 'string', + ), + 'CertificateBody' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'UploadDate' => array( + 'type' => 'string', + ), + ), + ), + ), + 'IsTruncated' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'ListUserPoliciesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'PolicyNames' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'policyNameType', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + 'IsTruncated' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'ListUsersResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Users' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'User', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'Path' => array( + 'type' => 'string', + ), + 'UserName' => array( + 'type' => 'string', + ), + 'UserId' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'CreateDate' => array( + 'type' => 'string', + ), + ), + ), + ), + 'IsTruncated' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'ListVirtualMFADevicesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'VirtualMFADevices' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'VirtualMFADevice', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'SerialNumber' => array( + 'type' => 'string', + ), + 'Base32StringSeed' => array( + 'type' => 'string', + ), + 'QRCodePNG' => array( + 'type' => 'string', + ), + 'User' => array( + 'type' => 'object', + 'properties' => array( + 'Path' => array( + 'type' => 'string', + ), + 'UserName' => array( + 'type' => 'string', + ), + 'UserId' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'CreateDate' => array( + 'type' => 'string', + ), + ), + ), + 'EnableDate' => array( + 'type' => 'string', + ), + ), + ), + ), + 'IsTruncated' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'UpdateSAMLProviderResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'SAMLProviderArn' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'UploadServerCertificateResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ServerCertificateMetadata' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Path' => array( + 'type' => 'string', + ), + 'ServerCertificateName' => array( + 'type' => 'string', + ), + 'ServerCertificateId' => array( + 'type' => 'string', + ), + 'Arn' => array( + 'type' => 'string', + ), + 'UploadDate' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'UploadSigningCertificateResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Certificate' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'UserName' => array( + 'type' => 'string', + ), + 'CertificateId' => array( + 'type' => 'string', + ), + 'CertificateBody' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'UploadDate' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'iterators' => array( + '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-sdk-php/src/Aws/ImportExport/Enum/JobType.php b/vendor/aws/aws-sdk-php/src/Aws/ImportExport/Enum/JobType.php new file mode 100644 index 0000000..9ae85ae --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/ImportExport/JobManifestListener.php b/vendor/aws/aws-sdk-php/src/Aws/ImportExport/JobManifestListener.php new file mode 100644 index 0000000..d6afc41 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/ImportExport/Resources/importexport-2010-06-01.php b/vendor/aws/aws-sdk-php/src/Aws/ImportExport/Resources/importexport-2010-06-01.php new file mode 100644 index 0000000..debd3fd --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/ImportExport/Resources/importexport-2010-06-01.php @@ -0,0 +1,566 @@ + '2010-06-01', + 'endpointPrefix' => 'importexport', + 'serviceFullName' => 'AWS Import/Export', + 'serviceType' => 'query', + 'globalEndpoint' => 'importexport.amazonaws.com', + 'resultWrapped' => true, + 'signatureVersion' => 'v2', + 'namespace' => 'ImportExport', + 'regions' => array( + 'us-east-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'importexport.amazonaws.com', + ), + 'us-west-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'importexport.amazonaws.com', + ), + 'us-west-2' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'importexport.amazonaws.com', + ), + 'eu-west-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'importexport.amazonaws.com', + ), + 'ap-northeast-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'importexport.amazonaws.com', + ), + 'ap-southeast-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'importexport.amazonaws.com', + ), + 'ap-southeast-2' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'importexport.amazonaws.com', + ), + 'sa-east-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'importexport.amazonaws.com', + ), + ), + 'operations' => array( + 'CancelJob' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'CancelJobOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CancelJob', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-06-01', + ), + 'JobId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The JOBID was missing, not found, or not associated with the AWS account.', + 'class' => 'InvalidJobIdException', + ), + array( + 'reason' => 'Indicates that the specified job has expired out of the system.', + 'class' => 'ExpiredJobIdException', + ), + array( + 'reason' => 'The specified job ID has been canceled and is no longer valid.', + 'class' => 'CanceledJobIdException', + ), + array( + 'reason' => 'AWS Import/Export cannot cancel the job', + 'class' => 'UnableToCancelJobIdException', + ), + array( + 'reason' => 'The AWS Access Key ID specified in the request did not match the manifest\'s accessKeyId value. The manifest and the request authentication must use the same AWS Access Key ID.', + 'class' => 'InvalidAccessKeyIdException', + ), + ), + ), + 'CreateJob' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'CreateJobOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateJob', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-06-01', + ), + 'JobType' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Manifest' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'ManifestAddendum' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'ValidateOnly' => array( + 'required' => true, + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'One or more required parameters was missing from the request.', + 'class' => 'MissingParameterException', + ), + array( + 'reason' => 'One or more parameters had an invalid value.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'One or more parameters had an invalid value.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'The AWS Access Key ID specified in the request did not match the manifest\'s accessKeyId value. The manifest and the request authentication must use the same AWS Access Key ID.', + 'class' => 'InvalidAccessKeyIdException', + ), + array( + 'reason' => 'The address specified in the manifest is invalid.', + 'class' => 'InvalidAddressException', + ), + array( + 'reason' => 'One or more manifest fields was invalid. Please correct and resubmit.', + 'class' => 'InvalidManifestFieldException', + ), + array( + 'reason' => 'One or more required fields were missing from the manifest file. Please correct and resubmit.', + 'class' => 'MissingManifestFieldException', + ), + array( + 'reason' => 'The specified bucket does not exist. Create the specified bucket or change the manifest\'s bucket, exportBucket, or logBucket field to a bucket that the account, as specified by the manifest\'s Access Key ID, has write permissions to.', + 'class' => 'NoSuchBucketException', + ), + array( + 'reason' => 'One or more required customs parameters was missing from the manifest.', + 'class' => 'MissingCustomsException', + ), + array( + 'reason' => 'One or more customs parameters was invalid. Please correct and resubmit.', + 'class' => 'InvalidCustomsException', + ), + array( + 'reason' => 'File system specified in export manifest is invalid.', + 'class' => 'InvalidFileSystemException', + ), + array( + 'reason' => 'Your manifest file contained buckets from multiple regions. A job is restricted to buckets from one region. Please correct and resubmit.', + 'class' => 'MultipleRegionsException', + ), + array( + 'reason' => 'The account specified does not have the appropriate bucket permissions.', + 'class' => 'BucketPermissionException', + ), + array( + 'reason' => 'Your manifest is not well-formed.', + 'class' => 'MalformedManifestException', + ), + ), + ), + 'GetStatus' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'GetStatusOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'GetStatus', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-06-01', + ), + 'JobId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The JOBID was missing, not found, or not associated with the AWS account.', + 'class' => 'InvalidJobIdException', + ), + array( + 'reason' => 'Indicates that the specified job has expired out of the system.', + 'class' => 'ExpiredJobIdException', + ), + array( + 'reason' => 'The specified job ID has been canceled and is no longer valid.', + 'class' => 'CanceledJobIdException', + ), + array( + 'reason' => 'The AWS Access Key ID specified in the request did not match the manifest\'s accessKeyId value. The manifest and the request authentication must use the same AWS Access Key ID.', + 'class' => 'InvalidAccessKeyIdException', + ), + ), + ), + 'ListJobs' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListJobsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListJobs', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-06-01', + ), + 'MaxJobs' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'One or more parameters had an invalid value.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'The AWS Access Key ID specified in the request did not match the manifest\'s accessKeyId value. The manifest and the request authentication must use the same AWS Access Key ID.', + 'class' => 'InvalidAccessKeyIdException', + ), + ), + ), + 'UpdateJob' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'UpdateJobOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'UpdateJob', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-06-01', + ), + 'JobId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Manifest' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'JobType' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'ValidateOnly' => array( + 'required' => true, + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'One or more required parameters was missing from the request.', + 'class' => 'MissingParameterException', + ), + array( + 'reason' => 'One or more parameters had an invalid value.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'The AWS Access Key ID specified in the request did not match the manifest\'s accessKeyId value. The manifest and the request authentication must use the same AWS Access Key ID.', + 'class' => 'InvalidAccessKeyIdException', + ), + array( + 'reason' => 'The address specified in the manifest is invalid.', + 'class' => 'InvalidAddressException', + ), + array( + 'reason' => 'One or more manifest fields was invalid. Please correct and resubmit.', + 'class' => 'InvalidManifestFieldException', + ), + array( + 'reason' => 'The JOBID was missing, not found, or not associated with the AWS account.', + 'class' => 'InvalidJobIdException', + ), + array( + 'reason' => 'One or more required fields were missing from the manifest file. Please correct and resubmit.', + 'class' => 'MissingManifestFieldException', + ), + array( + 'reason' => 'The specified bucket does not exist. Create the specified bucket or change the manifest\'s bucket, exportBucket, or logBucket field to a bucket that the account, as specified by the manifest\'s Access Key ID, has write permissions to.', + 'class' => 'NoSuchBucketException', + ), + array( + 'reason' => 'Indicates that the specified job has expired out of the system.', + 'class' => 'ExpiredJobIdException', + ), + array( + 'reason' => 'The specified job ID has been canceled and is no longer valid.', + 'class' => 'CanceledJobIdException', + ), + array( + 'reason' => 'One or more required customs parameters was missing from the manifest.', + 'class' => 'MissingCustomsException', + ), + array( + 'reason' => 'One or more customs parameters was invalid. Please correct and resubmit.', + 'class' => 'InvalidCustomsException', + ), + array( + 'reason' => 'File system specified in export manifest is invalid.', + 'class' => 'InvalidFileSystemException', + ), + array( + 'reason' => 'Your manifest file contained buckets from multiple regions. A job is restricted to buckets from one region. Please correct and resubmit.', + 'class' => 'MultipleRegionsException', + ), + array( + 'reason' => 'The account specified does not have the appropriate bucket permissions.', + 'class' => 'BucketPermissionException', + ), + array( + 'reason' => 'Your manifest is not well-formed.', + 'class' => 'MalformedManifestException', + ), + ), + ), + ), + 'models' => array( + 'CancelJobOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Success' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + ), + ), + 'CreateJobOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'JobId' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'JobType' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'AwsShippingAddress' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'Signature' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'SignatureFileContents' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'WarningMessage' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'GetStatusOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'JobId' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'JobType' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'AwsShippingAddress' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'LocationCode' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'LocationMessage' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'ProgressCode' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'ProgressMessage' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'Carrier' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'TrackingNumber' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'LogBucket' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'LogKey' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'ErrorCount' => array( + 'type' => 'numeric', + 'location' => 'xml', + ), + 'Signature' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'SignatureFileContents' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'CurrentManifest' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'CreationDate' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'ListJobsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Jobs' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'Job', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'JobId' => array( + 'type' => 'string', + ), + 'CreationDate' => array( + 'type' => 'string', + ), + 'IsCanceled' => array( + 'type' => 'boolean', + ), + 'JobType' => array( + 'type' => 'string', + ), + ), + ), + ), + 'IsTruncated' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + ), + ), + 'UpdateJobOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Success' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'WarningMessage' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + ), + 'iterators' => array( + 'ListJobs' => array( + 'input_token' => 'Marker', + 'output_token' => 'Jobs/#/JobId', + 'more_results' => 'IsTruncated', + 'limit_key' => 'MaxJobs', + 'result_key' => 'Jobs', + ), + ), +); diff --git a/vendor/aws/aws-sdk-php/src/Aws/Kinesis/Enum/ShardIteratorType.php b/vendor/aws/aws-sdk-php/src/Aws/Kinesis/Enum/ShardIteratorType.php new file mode 100644 index 0000000..58af9f5 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Kinesis/Resources/kinesis-2013-12-02.php b/vendor/aws/aws-sdk-php/src/Aws/Kinesis/Resources/kinesis-2013-12-02.php new file mode 100644 index 0000000..894665b --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/Kinesis/Resources/kinesis-2013-12-02.php @@ -0,0 +1,662 @@ + '2013-12-02', + 'endpointPrefix' => 'kinesis', + 'serviceFullName' => 'Amazon Kinesis', + 'serviceAbbreviation' => 'Kinesis', + 'serviceType' => 'json', + 'jsonVersion' => '1.1', + 'targetPrefix' => 'Kinesis_20131202.', + 'signatureVersion' => 'v4', + 'namespace' => 'Kinesis', + 'regions' => array( + 'us-east-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'kinesis.us-east-1.amazonaws.com', + ), + ), + 'operations' => array( + 'CreateStream' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'Kinesis_20131202.CreateStream', + ), + 'StreamName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'ShardCount' => array( + 'required' => true, + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + ), + ), + 'errorResponses' => array( + array( + 'class' => 'ResourceInUseException', + ), + array( + 'class' => 'LimitExceededException', + ), + array( + 'class' => 'InvalidArgumentException', + ), + ), + ), + 'DeleteStream' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'Kinesis_20131202.DeleteStream', + ), + 'StreamName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'class' => 'ResourceNotFoundException', + ), + array( + 'class' => 'LimitExceededException', + ), + ), + ), + 'DescribeStream' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeStreamOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'Kinesis_20131202.DescribeStream', + ), + 'StreamName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'Limit' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 10000, + ), + 'ExclusiveStartShardId' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'class' => 'ResourceNotFoundException', + ), + array( + 'class' => 'LimitExceededException', + ), + ), + ), + 'GetRecords' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GetRecordsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'Kinesis_20131202.GetRecords', + ), + 'ShardIterator' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 512, + ), + 'Limit' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 10000, + ), + ), + 'errorResponses' => array( + array( + 'class' => 'ResourceNotFoundException', + ), + array( + 'class' => 'InvalidArgumentException', + ), + array( + 'class' => 'ProvisionedThroughputExceededException', + ), + array( + 'class' => 'ExpiredIteratorException', + ), + ), + ), + 'GetShardIterator' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'GetShardIteratorOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'Kinesis_20131202.GetShardIterator', + ), + 'StreamName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'ShardId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'ShardIteratorType' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'StartingSequenceNumber' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'class' => 'ResourceNotFoundException', + ), + array( + 'class' => 'InvalidArgumentException', + ), + array( + 'class' => 'ProvisionedThroughputExceededException', + ), + ), + ), + 'ListStreams' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListStreamsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'Kinesis_20131202.ListStreams', + ), + 'Limit' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 10000, + ), + 'ExclusiveStartStreamName' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'class' => 'LimitExceededException', + ), + ), + ), + 'MergeShards' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'Kinesis_20131202.MergeShards', + ), + 'StreamName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'ShardToMerge' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'AdjacentShardToMerge' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 128, + ), + ), + 'errorResponses' => array( + array( + 'class' => 'ResourceNotFoundException', + ), + array( + 'class' => 'ResourceInUseException', + ), + array( + 'class' => 'InvalidArgumentException', + ), + array( + 'class' => 'LimitExceededException', + ), + ), + ), + 'PutRecord' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'PutRecordOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'Kinesis_20131202.PutRecord', + ), + 'StreamName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'Data' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'filters' => array( + 'base64_encode', + ), + ), + 'PartitionKey' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'ExplicitHashKey' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'SequenceNumberForOrdering' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'class' => 'ResourceNotFoundException', + ), + array( + 'class' => 'InvalidArgumentException', + ), + array( + 'class' => 'ProvisionedThroughputExceededException', + ), + ), + ), + 'SplitShard' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'Kinesis_20131202.SplitShard', + ), + 'StreamName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'ShardToSplit' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'NewStartingHashKey' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'class' => 'ResourceNotFoundException', + ), + array( + 'class' => 'ResourceInUseException', + ), + array( + 'class' => 'InvalidArgumentException', + ), + array( + 'class' => 'LimitExceededException', + ), + ), + ), + ), + 'models' => array( + 'EmptyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + ), + 'DescribeStreamOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'StreamDescription' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'StreamName' => array( + 'type' => 'string', + ), + 'StreamARN' => array( + 'type' => 'string', + ), + 'StreamStatus' => array( + 'type' => 'string', + ), + 'Shards' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Shard', + 'type' => 'object', + 'properties' => array( + 'ShardId' => array( + 'type' => 'string', + ), + 'ParentShardId' => array( + 'type' => 'string', + ), + 'AdjacentParentShardId' => array( + 'type' => 'string', + ), + 'HashKeyRange' => array( + 'type' => 'object', + 'properties' => array( + 'StartingHashKey' => array( + 'type' => 'string', + ), + 'EndingHashKey' => array( + 'type' => 'string', + ), + ), + ), + 'SequenceNumberRange' => array( + 'type' => 'object', + 'properties' => array( + 'StartingSequenceNumber' => array( + 'type' => 'string', + ), + 'EndingSequenceNumber' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'HasMoreShards' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + 'GetRecordsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Records' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Record', + 'type' => 'object', + 'properties' => array( + 'SequenceNumber' => array( + 'type' => 'string', + ), + 'Data' => array( + 'type' => 'string', + 'filters' => array( + 'base64_decode', + ), + ), + 'PartitionKey' => array( + 'type' => 'string', + ), + ), + ), + ), + 'NextShardIterator' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'GetShardIteratorOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ShardIterator' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListStreamsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'StreamNames' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'StreamName', + 'type' => 'string', + ), + ), + 'HasMoreStreams' => array( + 'type' => 'boolean', + 'location' => 'json', + ), + ), + ), + 'PutRecordOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ShardId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'SequenceNumber' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + ), + 'iterators' => array( + 'DescribeStream' => array( + 'input_token' => 'ExclusiveStartShardId', + 'limit_key' => 'Limit', + 'more_results' => 'StreamDescription/HasMoreShards', + 'output_token' => 'StreamDescription/Shards/#/ShardId', + 'result_key' => 'StreamDescription/Shards', + ), + 'GetRecords' => array( + 'input_token' => 'ShardIterator', + 'limit_key' => 'Limit', + 'output_token' => 'NextShardIterator', + 'result_key' => 'Records', + ), + 'ListStreams' => array( + 'input_token' => 'ExclusiveStartStreamName', + 'limit_key' => 'Limit', + 'more_results' => 'HasMoreStreams', + 'output_token' => 'StreamNames/#', + 'result_key' => 'StreamNames', + ), + ), +); diff --git a/vendor/aws/aws-sdk-php/src/Aws/OpsWorks/Enum/AppType.php b/vendor/aws/aws-sdk-php/src/Aws/OpsWorks/Enum/AppType.php new file mode 100644 index 0000000..baaea4d --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/OpsWorks/Resources/opsworks-2013-02-18.php b/vendor/aws/aws-sdk-php/src/Aws/OpsWorks/Resources/opsworks-2013-02-18.php new file mode 100644 index 0000000..fe181b2 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/OpsWorks/Resources/opsworks-2013-02-18.php @@ -0,0 +1,5000 @@ + '2013-02-18', + 'endpointPrefix' => 'opsworks', + 'serviceFullName' => 'AWS OpsWorks', + 'serviceType' => 'json', + 'jsonVersion' => '1.1', + 'targetPrefix' => 'OpsWorks_20130218.', + 'signatureVersion' => 'v4', + 'namespace' => 'OpsWorks', + 'regions' => array( + 'us-east-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'opsworks.us-east-1.amazonaws.com', + ), + ), + 'operations' => array( + 'AssignVolume' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'OpsWorks_20130218.AssignVolume', + ), + 'VolumeId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'InstanceId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that a request was invalid.', + 'class' => 'ValidationException', + ), + array( + 'reason' => 'Indicates that a resource was not found.', + 'class' => 'ResourceNotFoundException', + ), + ), + ), + 'AssociateElasticIp' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'OpsWorks_20130218.AssociateElasticIp', + ), + 'ElasticIp' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'InstanceId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that a request was invalid.', + 'class' => 'ValidationException', + ), + array( + 'reason' => 'Indicates that a resource was not found.', + 'class' => 'ResourceNotFoundException', + ), + ), + ), + 'AttachElasticLoadBalancer' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'OpsWorks_20130218.AttachElasticLoadBalancer', + ), + 'ElasticLoadBalancerName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'LayerId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that a request was invalid.', + 'class' => 'ValidationException', + ), + array( + 'reason' => 'Indicates that a resource was not found.', + 'class' => 'ResourceNotFoundException', + ), + ), + ), + 'CloneStack' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'CloneStackResult', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'OpsWorks_20130218.CloneStack', + ), + 'SourceStackId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'Name' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Region' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'VpcId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Attributes' => array( + 'type' => 'object', + 'location' => 'json', + 'additionalProperties' => array( + 'type' => 'string', + 'data' => array( + 'shape_name' => 'StackAttributesKeys', + ), + ), + ), + 'ServiceRoleArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'DefaultInstanceProfileArn' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'DefaultOs' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'HostnameTheme' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'DefaultAvailabilityZone' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'DefaultSubnetId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'CustomJson' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'ConfigurationManager' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + 'Version' => array( + 'type' => 'string', + ), + ), + ), + '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', + ), + ), + ), + ), + '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', + ), + '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', + ), + ), + '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', + ), + ), + ), + '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', + ), + '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', + ), + ), + ), + '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', + ), + ), + ), + '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', + ), + ), + ), + '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', + ), + ), + ), + ), + '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', + ), + ), + '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', + ), + ), + ), + ), + ), + ), + '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', + ), + 'InstallUpdatesOnBoot' => array( + 'type' => 'boolean', + ), + 'EbsOptimized' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + ), + 'DescribeLayersResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Layers' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Layer', + 'type' => 'object', + 'properties' => array( + 'StackId' => array( + 'type' => 'string', + ), + 'LayerId' => array( + 'type' => 'string', + ), + 'Type' => array( + 'type' => 'string', + ), + 'Name' => array( + 'type' => 'string', + ), + 'Shortname' => array( + 'type' => 'string', + ), + 'Attributes' => array( + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'string', + ), + ), + 'CustomInstanceProfileArn' => array( + 'type' => 'string', + ), + 'CustomSecurityGroupIds' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + 'DefaultSecurityGroupNames' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + 'Packages' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + 'VolumeConfigurations' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'VolumeConfiguration', + 'type' => 'object', + 'properties' => array( + 'MountPoint' => array( + 'type' => 'string', + ), + 'RaidLevel' => array( + 'type' => 'numeric', + ), + 'NumberOfDisks' => array( + 'type' => 'numeric', + ), + 'Size' => array( + 'type' => 'numeric', + ), + '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', + ), + ), + ), + ), + ), + ), + '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', + ), + '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', + ), + ), + ), + ), + ), + ), + '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( + 'Booting' => array( + 'type' => 'numeric', + ), + 'ConnectionLost' => array( + 'type' => 'numeric', + ), + 'Online' => array( + 'type' => 'numeric', + ), + 'Pending' => array( + 'type' => 'numeric', + ), + 'Rebooting' => array( + 'type' => 'numeric', + ), + 'Requested' => array( + 'type' => 'numeric', + ), + 'RunningSetup' => array( + 'type' => 'numeric', + ), + 'SetupFailed' => array( + 'type' => 'numeric', + ), + 'ShuttingDown' => array( + 'type' => 'numeric', + ), + 'StartFailed' => array( + 'type' => 'numeric', + ), + 'Stopped' => array( + 'type' => 'numeric', + ), + 'Stopping' => array( + 'type' => 'numeric', + ), + 'Terminated' => array( + 'type' => 'numeric', + ), + 'Terminating' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + ), + 'DescribeStacksResult' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Stacks' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Stack', + 'type' => 'object', + 'properties' => array( + 'StackId' => array( + 'type' => 'string', + ), + 'Name' => array( + 'type' => 'string', + ), + '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', + ), + ), + ), + '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-sdk-php/src/Aws/Rds/Enum/ApplyMethod.php b/vendor/aws/aws-sdk-php/src/Aws/Rds/Enum/ApplyMethod.php new file mode 100644 index 0000000..fe5fc29 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Rds/Resources/rds-2013-09-09.php b/vendor/aws/aws-sdk-php/src/Aws/Rds/Resources/rds-2013-09-09.php new file mode 100644 index 0000000..48bf8b1 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Redshift/Enum/SourceType.php b/vendor/aws/aws-sdk-php/src/Aws/Redshift/Enum/SourceType.php new file mode 100644 index 0000000..d6a8798 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Redshift/Resources/redshift-2012-12-01.php b/vendor/aws/aws-sdk-php/src/Aws/Redshift/Resources/redshift-2012-12-01.php new file mode 100644 index 0000000..c55051a --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/Redshift/Resources/redshift-2012-12-01.php @@ -0,0 +1,4668 @@ + '2012-12-01', + 'endpointPrefix' => 'redshift', + 'serviceFullName' => 'Amazon Redshift', + 'serviceType' => 'query', + 'resultWrapped' => true, + 'signatureVersion' => 'v4', + 'namespace' => 'Redshift', + 'regions' => array( + 'us-east-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'redshift.us-east-1.amazonaws.com', + ), + 'us-west-2' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'redshift.us-west-2.amazonaws.com', + ), + 'eu-west-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'redshift.eu-west-1.amazonaws.com', + ), + 'ap-southeast-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'redshift.ap-southeast-1.amazonaws.com', + ), + 'ap-southeast-2' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'redshift.ap-southeast-2.amazonaws.com', + ), + 'ap-northeast-1' => array( + 'http' => false, + 'https' => true, + 'hostname' => 'redshift.ap-northeast-1.amazonaws.com', + ), + ), + 'operations' => array( + 'AuthorizeClusterSecurityGroupIngress' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ClusterSecurityGroupWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'AuthorizeClusterSecurityGroupIngress', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ClusterSecurityGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'CIDRIP' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'EC2SecurityGroupName' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'EC2SecurityGroupOwnerId' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The cluster security group name does not refer to an existing cluster security group.', + 'class' => 'ClusterSecurityGroupNotFoundException', + ), + array( + 'reason' => 'The state of the cluster security group is not "available".', + 'class' => 'InvalidClusterSecurityGroupStateException', + ), + array( + 'reason' => 'The specified CIDR block or EC2 security group is already authorized for the specified cluster security group.', + 'class' => 'AuthorizationAlreadyExistsException', + ), + array( + 'reason' => 'The authorization quota for the cluster security group has been reached. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', + 'class' => 'AuthorizationQuotaExceededException', + ), + ), + ), + 'AuthorizeSnapshotAccess' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'SnapshotWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'AuthorizeSnapshotAccess', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'SnapshotIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SnapshotClusterIdentifier' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'AccountWithRestoreAccess' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The snapshot identifier does not refer to an existing cluster snapshot.', + 'class' => 'ClusterSnapshotNotFoundException', + ), + array( + 'reason' => 'The specified CIDR block or EC2 security group is already authorized for the specified cluster security group.', + 'class' => 'AuthorizationAlreadyExistsException', + ), + array( + 'reason' => 'The authorization quota for the cluster security group has been reached. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', + 'class' => 'AuthorizationQuotaExceededException', + ), + ), + ), + 'CopyClusterSnapshot' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'SnapshotWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CopyClusterSnapshot', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'SourceSnapshotIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SourceSnapshotClusterIdentifier' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TargetSnapshotIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The value specified as a snapshot identifier is already used by an existing snapshot.', + 'class' => 'ClusterSnapshotAlreadyExistsException', + ), + array( + 'reason' => 'The snapshot identifier does not refer to an existing cluster snapshot.', + 'class' => 'ClusterSnapshotNotFoundException', + ), + array( + 'reason' => 'The state of the cluster snapshot is not "available", or other accounts are authorized to access the snapshot.', + 'class' => 'InvalidClusterSnapshotStateException', + ), + array( + 'reason' => 'The request would result in the user exceeding the allowed number of cluster snapshots.', + 'class' => 'ClusterSnapshotQuotaExceededException', + ), + ), + ), + 'CreateCluster' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ClusterWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateCluster', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'DBName' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'ClusterIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'ClusterType' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'NodeType' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MasterUsername' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MasterUserPassword' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'ClusterSecurityGroups' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'ClusterSecurityGroups.member', + 'items' => array( + 'name' => 'ClusterSecurityGroupName', + 'type' => 'string', + ), + ), + 'VpcSecurityGroupIds' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'VpcSecurityGroupIds.member', + 'items' => array( + 'name' => 'VpcSecurityGroupId', + 'type' => 'string', + ), + ), + 'ClusterSubnetGroupName' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'AvailabilityZone' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'PreferredMaintenanceWindow' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'ClusterParameterGroupName' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'AutomatedSnapshotRetentionPeriod' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'Port' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'ClusterVersion' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'AllowVersionUpgrade' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'NumberOfNodes' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'PubliclyAccessible' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'Encrypted' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'HsmClientCertificateIdentifier' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'HsmConfigurationIdentifier' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'ElasticIp' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The account already has a cluster with the given identifier.', + 'class' => 'ClusterAlreadyExistsException', + ), + array( + 'reason' => 'The number of nodes specified exceeds the allotted capacity of the cluster.', + 'class' => 'InsufficientClusterCapacityException', + ), + array( + 'reason' => 'The parameter group name does not refer to an existing parameter group.', + 'class' => 'ClusterParameterGroupNotFoundException', + ), + array( + 'reason' => 'The cluster security group name does not refer to an existing cluster security group.', + 'class' => 'ClusterSecurityGroupNotFoundException', + ), + array( + 'reason' => 'The request would exceed the allowed number of cluster instances for this account. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', + 'class' => 'ClusterQuotaExceededException', + ), + array( + 'reason' => 'The operation would exceed the number of nodes allotted to the account. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', + 'class' => 'NumberOfNodesQuotaExceededException', + ), + array( + 'reason' => 'The operation would exceed the number of nodes allowed for a cluster.', + 'class' => 'NumberOfNodesPerClusterLimitExceededException', + ), + array( + 'reason' => 'The cluster subnet group name does not refer to an existing cluster subnet group.', + 'class' => 'ClusterSubnetGroupNotFoundException', + ), + array( + 'reason' => 'The cluster subnet group does not cover all Availability Zones.', + 'class' => 'InvalidVPCNetworkStateException', + ), + array( + 'reason' => 'The cluster subnet group cannot be deleted because it is in use.', + 'class' => 'InvalidClusterSubnetGroupStateException', + ), + array( + 'reason' => 'The requested subnet is not valid, or not all of the subnets are in the same VPC.', + 'class' => 'InvalidSubnetException', + ), + array( + 'reason' => 'Your account is not authorized to perform the requested operation.', + 'class' => 'UnauthorizedOperationException', + ), + array( + 'reason' => 'There is no Amazon Redshift HSM client certificate with the specified identifier.', + 'class' => 'HsmClientCertificateNotFoundException', + ), + array( + 'reason' => 'There is no Amazon Redshift HSM configuration with the specified identifier.', + 'class' => 'HsmConfigurationNotFoundException', + ), + array( + 'reason' => 'The Elastic IP (EIP) is invalid or cannot be found.', + 'class' => 'InvalidElasticIpException', + ), + ), + ), + 'CreateClusterParameterGroup' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ClusterParameterGroupWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateClusterParameterGroup', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ParameterGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'ParameterGroupFamily' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Description' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request would result in the user exceeding the allowed number of cluster parameter groups. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', + 'class' => 'ClusterParameterGroupQuotaExceededException', + ), + array( + 'reason' => 'A cluster parameter group with the same name already exists.', + 'class' => 'ClusterParameterGroupAlreadyExistsException', + ), + ), + ), + 'CreateClusterSecurityGroup' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ClusterSecurityGroupWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateClusterSecurityGroup', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ClusterSecurityGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Description' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'A cluster security group with the same name already exists.', + 'class' => 'ClusterSecurityGroupAlreadyExistsException', + ), + array( + 'reason' => 'The request would result in the user exceeding the allowed number of cluster security groups. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', + 'class' => 'ClusterSecurityGroupQuotaExceededException', + ), + ), + ), + 'CreateClusterSnapshot' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'SnapshotWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateClusterSnapshot', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'SnapshotIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'ClusterIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The value specified as a snapshot identifier is already used by an existing snapshot.', + 'class' => 'ClusterSnapshotAlreadyExistsException', + ), + array( + 'reason' => 'The specified cluster is not in the available state.', + 'class' => 'InvalidClusterStateException', + ), + array( + 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', + 'class' => 'ClusterNotFoundException', + ), + array( + 'reason' => 'The request would result in the user exceeding the allowed number of cluster snapshots.', + 'class' => 'ClusterSnapshotQuotaExceededException', + ), + ), + ), + 'CreateClusterSubnetGroup' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ClusterSubnetGroupWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateClusterSubnetGroup', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ClusterSubnetGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Description' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SubnetIds' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'SubnetIds.member', + 'items' => array( + 'name' => 'SubnetIdentifier', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'A ClusterSubnetGroupName is already used by an existing cluster subnet group.', + 'class' => 'ClusterSubnetGroupAlreadyExistsException', + ), + array( + 'reason' => 'The request would result in user exceeding the allowed number of cluster subnet groups. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', + 'class' => 'ClusterSubnetGroupQuotaExceededException', + ), + array( + 'reason' => 'The request would result in user exceeding the allowed number of subnets in a cluster subnet groups. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', + 'class' => 'ClusterSubnetQuotaExceededException', + ), + array( + 'reason' => 'The requested subnet is not valid, or not all of the subnets are in the same VPC.', + 'class' => 'InvalidSubnetException', + ), + array( + 'reason' => 'Your account is not authorized to perform the requested operation.', + 'class' => 'UnauthorizedOperationException', + ), + ), + ), + 'CreateEventSubscription' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EventSubscriptionWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateEventSubscription', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'SubscriptionName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SnsTopicArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SourceType' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SourceIds' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'SourceIds.member', + 'items' => array( + 'name' => 'SourceId', + 'type' => 'string', + ), + ), + 'EventCategories' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'EventCategories.member', + 'items' => array( + 'name' => 'EventCategory', + 'type' => 'string', + ), + ), + 'Severity' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Enabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The request would exceed the allowed number of event subscriptions for this account. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', + 'class' => 'EventSubscriptionQuotaExceededException', + ), + array( + 'reason' => 'There is already an existing event notification subscription with the specified name.', + 'class' => 'SubscriptionAlreadyExistException', + ), + array( + 'reason' => 'Amazon SNS has responded that there is a problem with the specified Amazon SNS topic.', + 'class' => 'SNSInvalidTopicException', + ), + array( + 'reason' => 'You do not have permission to publish to the specified Amazon SNS topic.', + 'class' => 'SNSNoAuthorizationException', + ), + array( + 'reason' => 'An Amazon SNS topic with the specified Amazon Resource Name (ARN) does not exist.', + 'class' => 'SNSTopicArnNotFoundException', + ), + array( + 'reason' => 'An Amazon Redshift event with the specified event ID does not exist.', + 'class' => 'SubscriptionEventIdNotFoundException', + ), + array( + 'reason' => 'The value specified for the event category was not one of the allowed values, or it specified a category that does not apply to the specified source type. The allowed values are Configuration, Management, Monitoring, and Security.', + 'class' => 'SubscriptionCategoryNotFoundException', + ), + array( + 'reason' => 'The value specified for the event severity was not one of the allowed values, or it specified a severity that does not apply to the specified source type. The allowed values are ERROR and INFO.', + 'class' => 'SubscriptionSeverityNotFoundException', + ), + array( + 'reason' => 'The specified Amazon Redshift event source could not be found.', + 'class' => 'SourceNotFoundException', + ), + ), + ), + 'CreateHsmClientCertificate' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'HsmClientCertificateWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateHsmClientCertificate', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'HsmClientCertificateIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'There is already an existing Amazon Redshift HSM client certificate with the specified identifier.', + 'class' => 'HsmClientCertificateAlreadyExistsException', + ), + array( + 'reason' => 'The quota for HSM client certificates has been reached. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', + 'class' => 'HsmClientCertificateQuotaExceededException', + ), + ), + ), + 'CreateHsmConfiguration' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'HsmConfigurationWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateHsmConfiguration', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'HsmConfigurationIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Description' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'HsmIpAddress' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'HsmPartitionName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'HsmPartitionPassword' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'HsmServerPublicCertificate' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'There is already an existing Amazon Redshift HSM configuration with the specified identifier.', + 'class' => 'HsmConfigurationAlreadyExistsException', + ), + array( + 'reason' => 'The quota for HSM configurations has been reached. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', + 'class' => 'HsmConfigurationQuotaExceededException', + ), + ), + ), + 'DeleteCluster' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ClusterWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteCluster', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ClusterIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SkipFinalClusterSnapshot' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'FinalClusterSnapshotIdentifier' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', + 'class' => 'ClusterNotFoundException', + ), + array( + 'reason' => 'The specified cluster is not in the available state.', + 'class' => 'InvalidClusterStateException', + ), + array( + 'reason' => 'The value specified as a snapshot identifier is already used by an existing snapshot.', + 'class' => 'ClusterSnapshotAlreadyExistsException', + ), + array( + 'reason' => 'The request would result in the user exceeding the allowed number of cluster snapshots.', + 'class' => 'ClusterSnapshotQuotaExceededException', + ), + ), + ), + 'DeleteClusterParameterGroup' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteClusterParameterGroup', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ParameterGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The cluster parameter group action can not be completed because another task is in progress that involves the parameter group. Wait a few moments and try the operation again.', + 'class' => 'InvalidClusterParameterGroupStateException', + ), + array( + 'reason' => 'The parameter group name does not refer to an existing parameter group.', + 'class' => 'ClusterParameterGroupNotFoundException', + ), + ), + ), + 'DeleteClusterSecurityGroup' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteClusterSecurityGroup', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ClusterSecurityGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The state of the cluster security group is not "available".', + 'class' => 'InvalidClusterSecurityGroupStateException', + ), + array( + 'reason' => 'The cluster security group name does not refer to an existing cluster security group.', + 'class' => 'ClusterSecurityGroupNotFoundException', + ), + ), + ), + 'DeleteClusterSnapshot' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'SnapshotWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteClusterSnapshot', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'SnapshotIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SnapshotClusterIdentifier' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The state of the cluster snapshot is not "available", or other accounts are authorized to access the snapshot.', + 'class' => 'InvalidClusterSnapshotStateException', + ), + array( + 'reason' => 'The snapshot identifier does not refer to an existing cluster snapshot.', + 'class' => 'ClusterSnapshotNotFoundException', + ), + ), + ), + 'DeleteClusterSubnetGroup' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteClusterSubnetGroup', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ClusterSubnetGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The cluster subnet group cannot be deleted because it is in use.', + 'class' => 'InvalidClusterSubnetGroupStateException', + ), + array( + 'reason' => 'The state of the subnet is invalid.', + 'class' => 'InvalidClusterSubnetStateException', + ), + array( + 'reason' => 'The cluster subnet group name does not refer to an existing cluster subnet group.', + 'class' => 'ClusterSubnetGroupNotFoundException', + ), + ), + ), + 'DeleteEventSubscription' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteEventSubscription', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'SubscriptionName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An Amazon Redshift event notification subscription with the specified name does not exist.', + 'class' => 'SubscriptionNotFoundException', + ), + ), + ), + 'DeleteHsmClientCertificate' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteHsmClientCertificate', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'HsmClientCertificateIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified HSM client certificate is not in the available state, or it is still in use by one or more Amazon Redshift clusters.', + 'class' => 'InvalidHsmClientCertificateStateException', + ), + array( + 'reason' => 'There is no Amazon Redshift HSM client certificate with the specified identifier.', + 'class' => 'HsmClientCertificateNotFoundException', + ), + ), + ), + 'DeleteHsmConfiguration' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteHsmConfiguration', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'HsmConfigurationIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified HSM configuration is not in the available state, or it is still in use by one or more Amazon Redshift clusters.', + 'class' => 'InvalidHsmConfigurationStateException', + ), + array( + 'reason' => 'There is no Amazon Redshift HSM configuration with the specified identifier.', + 'class' => 'HsmConfigurationNotFoundException', + ), + ), + ), + 'DescribeClusterParameterGroups' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ClusterParameterGroupsMessage', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeClusterParameterGroups', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ParameterGroupName' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MaxRecords' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The parameter group name does not refer to an existing parameter group.', + 'class' => 'ClusterParameterGroupNotFoundException', + ), + ), + ), + 'DescribeClusterParameters' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ClusterParameterGroupDetails', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeClusterParameters', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ParameterGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Source' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MaxRecords' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The parameter group name does not refer to an existing parameter group.', + 'class' => 'ClusterParameterGroupNotFoundException', + ), + ), + ), + 'DescribeClusterSecurityGroups' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ClusterSecurityGroupMessage', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeClusterSecurityGroups', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ClusterSecurityGroupName' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MaxRecords' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The cluster security group name does not refer to an existing cluster security group.', + 'class' => 'ClusterSecurityGroupNotFoundException', + ), + ), + ), + 'DescribeClusterSnapshots' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'SnapshotMessage', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeClusterSnapshots', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ClusterIdentifier' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SnapshotIdentifier' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SnapshotType' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'StartTime' => array( + 'type' => array( + 'object', + 'string', + 'integer', + ), + 'format' => 'date-time', + 'location' => 'aws.query', + ), + 'EndTime' => array( + 'type' => array( + 'object', + 'string', + 'integer', + ), + 'format' => 'date-time', + 'location' => 'aws.query', + ), + 'MaxRecords' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'OwnerAccount' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The snapshot identifier does not refer to an existing cluster snapshot.', + 'class' => 'ClusterSnapshotNotFoundException', + ), + ), + ), + 'DescribeClusterSubnetGroups' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ClusterSubnetGroupMessage', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeClusterSubnetGroups', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ClusterSubnetGroupName' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MaxRecords' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The cluster subnet group name does not refer to an existing cluster subnet group.', + 'class' => 'ClusterSubnetGroupNotFoundException', + ), + ), + ), + 'DescribeClusterVersions' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ClusterVersionsMessage', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeClusterVersions', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ClusterVersion' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'ClusterParameterGroupFamily' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MaxRecords' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + ), + 'DescribeClusters' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ClustersMessage', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeClusters', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ClusterIdentifier' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MaxRecords' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', + 'class' => 'ClusterNotFoundException', + ), + ), + ), + 'DescribeDefaultClusterParameters' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DefaultClusterParametersWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeDefaultClusterParameters', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ParameterGroupFamily' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MaxRecords' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + ), + 'DescribeEventCategories' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EventCategoriesMessage', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeEventCategories', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'SourceType' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + ), + 'DescribeEventSubscriptions' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EventSubscriptionsMessage', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeEventSubscriptions', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'SubscriptionName' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MaxRecords' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An Amazon Redshift event notification subscription with the specified name does not exist.', + 'class' => 'SubscriptionNotFoundException', + ), + ), + ), + 'DescribeEvents' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EventsMessage', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeEvents', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'SourceIdentifier' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SourceType' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'StartTime' => array( + 'type' => array( + 'object', + 'string', + 'integer', + ), + 'format' => 'date-time', + 'location' => 'aws.query', + ), + 'EndTime' => array( + 'type' => array( + 'object', + 'string', + 'integer', + ), + 'format' => 'date-time', + 'location' => 'aws.query', + ), + 'Duration' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'MaxRecords' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + ), + 'DescribeHsmClientCertificates' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'HsmClientCertificateMessage', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeHsmClientCertificates', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'HsmClientCertificateIdentifier' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MaxRecords' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'There is no Amazon Redshift HSM client certificate with the specified identifier.', + 'class' => 'HsmClientCertificateNotFoundException', + ), + ), + ), + 'DescribeHsmConfigurations' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'HsmConfigurationMessage', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeHsmConfigurations', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'HsmConfigurationIdentifier' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MaxRecords' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'There is no Amazon Redshift HSM configuration with the specified identifier.', + 'class' => 'HsmConfigurationNotFoundException', + ), + ), + ), + 'DescribeLoggingStatus' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'LoggingStatus', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeLoggingStatus', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ClusterIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', + 'class' => 'ClusterNotFoundException', + ), + ), + ), + 'DescribeOrderableClusterOptions' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'OrderableClusterOptionsMessage', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeOrderableClusterOptions', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ClusterVersion' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'NodeType' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MaxRecords' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + ), + 'DescribeReservedNodeOfferings' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ReservedNodeOfferingsMessage', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeReservedNodeOfferings', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ReservedNodeOfferingId' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MaxRecords' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Specified offering does not exist.', + 'class' => 'ReservedNodeOfferingNotFoundException', + ), + ), + ), + 'DescribeReservedNodes' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ReservedNodesMessage', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeReservedNodes', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ReservedNodeId' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MaxRecords' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified reserved compute node not found.', + 'class' => 'ReservedNodeNotFoundException', + ), + ), + ), + 'DescribeResize' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ResizeProgressMessage', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DescribeResize', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ClusterIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', + 'class' => 'ClusterNotFoundException', + ), + array( + 'reason' => 'A resize operation for the specified cluster is not found.', + 'class' => 'ResizeNotFoundException', + ), + ), + ), + 'DisableLogging' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'LoggingStatus', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DisableLogging', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ClusterIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', + 'class' => 'ClusterNotFoundException', + ), + ), + ), + 'DisableSnapshotCopy' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ClusterWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DisableSnapshotCopy', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ClusterIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', + 'class' => 'ClusterNotFoundException', + ), + array( + 'reason' => 'The cluster already has cross-region snapshot copy disabled.', + 'class' => 'SnapshotCopyAlreadyDisabledException', + ), + array( + 'reason' => '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', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified cluster is not in the available state.', + 'class' => 'InvalidClusterStateException', + ), + array( + 'reason' => 'The state of the cluster security group is not "available".', + 'class' => 'InvalidClusterSecurityGroupStateException', + ), + array( + 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', + 'class' => 'ClusterNotFoundException', + ), + array( + 'reason' => 'The operation would exceed the number of nodes allotted to the account. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', + 'class' => 'NumberOfNodesQuotaExceededException', + ), + array( + 'reason' => 'The cluster security group name does not refer to an existing cluster security group.', + 'class' => 'ClusterSecurityGroupNotFoundException', + ), + array( + 'reason' => 'The parameter group name does not refer to an existing parameter group.', + 'class' => 'ClusterParameterGroupNotFoundException', + ), + array( + 'reason' => 'The number of nodes specified exceeds the allotted capacity of the cluster.', + 'class' => 'InsufficientClusterCapacityException', + ), + array( + 'reason' => 'An request option was specified that is not supported.', + 'class' => 'UnsupportedOptionException', + ), + array( + 'reason' => 'Your account is not authorized to perform the requested operation.', + 'class' => 'UnauthorizedOperationException', + ), + array( + 'reason' => 'There is no Amazon Redshift HSM client certificate with the specified identifier.', + 'class' => 'HsmClientCertificateNotFoundException', + ), + array( + 'reason' => 'There is no Amazon Redshift HSM configuration with the specified identifier.', + 'class' => 'HsmConfigurationNotFoundException', + ), + ), + ), + 'ModifyClusterParameterGroup' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ClusterParameterGroupNameMessage', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ModifyClusterParameterGroup', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ParameterGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Parameters' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Parameters.member', + 'items' => array( + 'name' => 'Parameter', + 'type' => 'object', + 'properties' => array( + 'ParameterName' => array( + 'type' => 'string', + ), + 'ParameterValue' => array( + 'type' => 'string', + ), + 'Description' => array( + 'type' => 'string', + ), + 'Source' => array( + 'type' => 'string', + ), + 'DataType' => array( + 'type' => 'string', + ), + 'AllowedValues' => array( + 'type' => 'string', + ), + 'IsModifiable' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'MinimumEngineVersion' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The parameter group name does not refer to an existing parameter group.', + 'class' => 'ClusterParameterGroupNotFoundException', + ), + array( + 'reason' => 'The cluster parameter group action can not be completed because another task is in progress that involves the parameter group. Wait a few moments and try the operation again.', + 'class' => 'InvalidClusterParameterGroupStateException', + ), + ), + ), + 'ModifyClusterSubnetGroup' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ClusterSubnetGroupWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ModifyClusterSubnetGroup', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ClusterSubnetGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Description' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SubnetIds' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'SubnetIds.member', + 'items' => array( + 'name' => 'SubnetIdentifier', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The cluster subnet group name does not refer to an existing cluster subnet group.', + 'class' => 'ClusterSubnetGroupNotFoundException', + ), + array( + 'reason' => 'The request would result in user exceeding the allowed number of subnets in a cluster subnet groups. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', + 'class' => 'ClusterSubnetQuotaExceededException', + ), + array( + 'reason' => 'A specified subnet is already in use by another cluster.', + 'class' => 'SubnetAlreadyInUseException', + ), + array( + 'reason' => 'The requested subnet is not valid, or not all of the subnets are in the same VPC.', + 'class' => 'InvalidSubnetException', + ), + array( + 'reason' => 'Your account is not authorized to perform the requested operation.', + 'class' => 'UnauthorizedOperationException', + ), + ), + ), + 'ModifyEventSubscription' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EventSubscriptionWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ModifyEventSubscription', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'SubscriptionName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SnsTopicArn' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SourceType' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SourceIds' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'SourceIds.member', + 'items' => array( + 'name' => 'SourceId', + 'type' => 'string', + ), + ), + 'EventCategories' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'EventCategories.member', + 'items' => array( + 'name' => 'EventCategory', + 'type' => 'string', + ), + ), + 'Severity' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Enabled' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An Amazon Redshift event notification subscription with the specified name does not exist.', + 'class' => 'SubscriptionNotFoundException', + ), + array( + 'reason' => 'Amazon SNS has responded that there is a problem with the specified Amazon SNS topic.', + 'class' => 'SNSInvalidTopicException', + ), + array( + 'reason' => 'You do not have permission to publish to the specified Amazon SNS topic.', + 'class' => 'SNSNoAuthorizationException', + ), + array( + 'reason' => 'An Amazon SNS topic with the specified Amazon Resource Name (ARN) does not exist.', + 'class' => 'SNSTopicArnNotFoundException', + ), + array( + 'reason' => 'An Amazon Redshift event with the specified event ID does not exist.', + 'class' => 'SubscriptionEventIdNotFoundException', + ), + array( + 'reason' => 'The value specified for the event category was not one of the allowed values, or it specified a category that does not apply to the specified source type. The allowed values are Configuration, Management, Monitoring, and Security.', + 'class' => 'SubscriptionCategoryNotFoundException', + ), + array( + 'reason' => 'The value specified for the event severity was not one of the allowed values, or it specified a severity that does not apply to the specified source type. The allowed values are ERROR and INFO.', + 'class' => 'SubscriptionSeverityNotFoundException', + ), + array( + 'reason' => 'The specified Amazon Redshift event source could not be found.', + 'class' => 'SourceNotFoundException', + ), + ), + ), + 'ModifySnapshotCopyRetentionPeriod' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ClusterWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ModifySnapshotCopyRetentionPeriod', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ClusterIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'RetentionPeriod' => array( + 'required' => true, + 'type' => 'numeric', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', + 'class' => 'ClusterNotFoundException', + ), + array( + 'reason' => 'Cross-region snapshot copy was temporarily disabled. Try your request again.', + 'class' => 'SnapshotCopyDisabledException', + ), + array( + 'reason' => 'Your account is not authorized to perform the requested operation.', + 'class' => 'UnauthorizedOperationException', + ), + 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 Management Guide.', + 'class' => 'ReservedNodeQuotaExceededException', + ), + ), + ), + 'RebootCluster' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ClusterWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'RebootCluster', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ClusterIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified cluster is not in the available state.', + 'class' => 'InvalidClusterStateException', + ), + array( + 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', + 'class' => 'ClusterNotFoundException', + ), + ), + ), + 'ResetClusterParameterGroup' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ClusterParameterGroupNameMessage', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ResetClusterParameterGroup', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ParameterGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'ResetAllParameters' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'Parameters' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'Parameters.member', + 'items' => array( + 'name' => 'Parameter', + 'type' => 'object', + 'properties' => array( + 'ParameterName' => array( + 'type' => 'string', + ), + 'ParameterValue' => array( + 'type' => 'string', + ), + 'Description' => array( + 'type' => 'string', + ), + 'Source' => array( + 'type' => 'string', + ), + 'DataType' => array( + 'type' => 'string', + ), + 'AllowedValues' => array( + 'type' => 'string', + ), + 'IsModifiable' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + 'MinimumEngineVersion' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The cluster parameter group action can not be completed because another task is in progress that involves the parameter group. Wait a few moments and try the operation again.', + 'class' => 'InvalidClusterParameterGroupStateException', + ), + array( + 'reason' => 'The parameter group name does not refer to an existing parameter group.', + 'class' => 'ClusterParameterGroupNotFoundException', + ), + ), + ), + 'RestoreFromClusterSnapshot' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ClusterWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'RestoreFromClusterSnapshot', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ClusterIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SnapshotIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SnapshotClusterIdentifier' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Port' => array( + 'type' => 'numeric', + 'location' => 'aws.query', + ), + 'AvailabilityZone' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'AllowVersionUpgrade' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'ClusterSubnetGroupName' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'PubliclyAccessible' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'aws.query', + ), + 'OwnerAccount' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'HsmClientCertificateIdentifier' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'HsmConfigurationIdentifier' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'ElasticIp' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The owner of the specified snapshot has not authorized your account to access the snapshot.', + 'class' => 'AccessToSnapshotDeniedException', + ), + array( + 'reason' => 'The account already has a cluster with the given identifier.', + 'class' => 'ClusterAlreadyExistsException', + ), + array( + 'reason' => 'The snapshot identifier does not refer to an existing cluster snapshot.', + 'class' => 'ClusterSnapshotNotFoundException', + ), + array( + 'reason' => 'The request would exceed the allowed number of cluster instances for this account. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', + 'class' => 'ClusterQuotaExceededException', + ), + array( + 'reason' => 'The number of nodes specified exceeds the allotted capacity of the cluster.', + 'class' => 'InsufficientClusterCapacityException', + ), + array( + 'reason' => 'The state of the cluster snapshot is not "available", or other accounts are authorized to access the snapshot.', + 'class' => 'InvalidClusterSnapshotStateException', + ), + array( + 'reason' => 'The restore is invalid.', + 'class' => 'InvalidRestoreException', + ), + array( + 'reason' => 'The operation would exceed the number of nodes allotted to the account. For information about increasing your quota, go to Limits in Amazon Redshift in the Amazon Redshift Management Guide.', + 'class' => 'NumberOfNodesQuotaExceededException', + ), + array( + 'reason' => 'The operation would exceed the number of nodes allowed for a cluster.', + 'class' => 'NumberOfNodesPerClusterLimitExceededException', + ), + array( + 'reason' => 'The cluster subnet group does not cover all Availability Zones.', + 'class' => 'InvalidVPCNetworkStateException', + ), + array( + 'reason' => 'The cluster subnet group cannot be deleted because it is in use.', + 'class' => 'InvalidClusterSubnetGroupStateException', + ), + array( + 'reason' => 'The requested subnet is not valid, or not all of the subnets are in the same VPC.', + 'class' => 'InvalidSubnetException', + ), + array( + 'reason' => 'The cluster subnet group name does not refer to an existing cluster subnet group.', + 'class' => 'ClusterSubnetGroupNotFoundException', + ), + array( + 'reason' => 'Your account is not authorized to perform the requested operation.', + 'class' => 'UnauthorizedOperationException', + ), + array( + 'reason' => 'There is no Amazon Redshift HSM client certificate with the specified identifier.', + 'class' => 'HsmClientCertificateNotFoundException', + ), + array( + 'reason' => 'There is no Amazon Redshift HSM configuration with the specified identifier.', + 'class' => 'HsmConfigurationNotFoundException', + ), + array( + 'reason' => 'The Elastic IP (EIP) is invalid or cannot be found.', + 'class' => 'InvalidElasticIpException', + ), + ), + ), + 'RevokeClusterSecurityGroupIngress' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ClusterSecurityGroupWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'RevokeClusterSecurityGroupIngress', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ClusterSecurityGroupName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'CIDRIP' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'EC2SecurityGroupName' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'EC2SecurityGroupOwnerId' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The cluster security group name does not refer to an existing cluster security group.', + 'class' => 'ClusterSecurityGroupNotFoundException', + ), + array( + 'reason' => 'The specified CIDR IP range or EC2 security group is not authorized for the specified cluster security group.', + 'class' => 'AuthorizationNotFoundException', + ), + array( + 'reason' => 'The state of the cluster security group is not "available".', + 'class' => 'InvalidClusterSecurityGroupStateException', + ), + ), + ), + 'RevokeSnapshotAccess' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'SnapshotWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'RevokeSnapshotAccess', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'SnapshotIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'SnapshotClusterIdentifier' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'AccountWithRestoreAccess' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The owner of the specified snapshot has not authorized your account to access the snapshot.', + 'class' => 'AccessToSnapshotDeniedException', + ), + array( + 'reason' => 'The specified CIDR IP range or EC2 security group is not authorized for the specified cluster security group.', + 'class' => 'AuthorizationNotFoundException', + ), + array( + 'reason' => 'The snapshot identifier does not refer to an existing cluster snapshot.', + 'class' => 'ClusterSnapshotNotFoundException', + ), + ), + ), + 'RotateEncryptionKey' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ClusterWrapper', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'RotateEncryptionKey', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-12-01', + ), + 'ClusterIdentifier' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The ClusterIdentifier parameter does not refer to an existing cluster.', + 'class' => 'ClusterNotFoundException', + ), + array( + 'reason' => 'The specified cluster is not in the available state.', + 'class' => 'InvalidClusterStateException', + ), + ), + ), + ), + 'models' => array( + 'ClusterSecurityGroupWrapper' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ClusterSecurityGroup' => array( + 'type' => 'object', + 'location' => 'xml', + 'data' => array( + 'wrapper' => true, + ), + 'properties' => array( + 'ClusterSecurityGroupName' => array( + 'type' => 'string', + ), + 'Description' => array( + 'type' => 'string', + ), + 'EC2SecurityGroups' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'EC2SecurityGroup', + 'type' => 'object', + 'sentAs' => 'EC2SecurityGroup', + 'properties' => array( + 'Status' => array( + 'type' => 'string', + ), + 'EC2SecurityGroupName' => array( + 'type' => 'string', + ), + 'EC2SecurityGroupOwnerId' => array( + 'type' => 'string', + ), + ), + ), + ), + 'IPRanges' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'IPRange', + 'type' => 'object', + 'sentAs' => 'IPRange', + 'properties' => array( + 'Status' => array( + 'type' => 'string', + ), + 'CIDRIP' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'SnapshotWrapper' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Snapshot' => array( + 'type' => 'object', + 'location' => 'xml', + 'data' => array( + 'wrapper' => true, + ), + 'properties' => array( + 'SnapshotIdentifier' => array( + 'type' => 'string', + ), + 'ClusterIdentifier' => array( + 'type' => 'string', + ), + 'SnapshotCreateTime' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'Port' => array( + 'type' => 'numeric', + ), + 'AvailabilityZone' => array( + 'type' => 'string', + ), + 'ClusterCreateTime' => array( + 'type' => 'string', + ), + 'MasterUsername' => array( + 'type' => 'string', + ), + 'ClusterVersion' => array( + 'type' => 'string', + ), + 'SnapshotType' => array( + 'type' => 'string', + ), + 'NodeType' => array( + 'type' => 'string', + ), + 'NumberOfNodes' => array( + 'type' => 'numeric', + ), + 'DBName' => array( + 'type' => 'string', + ), + 'VpcId' => array( + 'type' => 'string', + ), + 'Encrypted' => array( + 'type' => 'boolean', + ), + 'EncryptedWithHSM' => array( + 'type' => 'boolean', + ), + 'AccountsWithRestoreAccess' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AccountWithRestoreAccess', + 'type' => 'object', + 'sentAs' => 'AccountWithRestoreAccess', + 'properties' => array( + 'AccountId' => array( + 'type' => 'string', + ), + ), + ), + ), + 'OwnerAccount' => array( + 'type' => 'string', + ), + 'TotalBackupSizeInMegaBytes' => array( + 'type' => 'numeric', + ), + 'ActualIncrementalBackupSizeInMegaBytes' => array( + 'type' => 'numeric', + ), + 'BackupProgressInMegaBytes' => array( + 'type' => 'numeric', + ), + 'CurrentBackupRateInMegaBytesPerSecond' => array( + 'type' => 'numeric', + ), + 'EstimatedSecondsToCompletion' => array( + 'type' => 'numeric', + ), + 'ElapsedTimeInSeconds' => array( + 'type' => 'numeric', + ), + 'SourceRegion' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'ClusterWrapper' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Cluster' => array( + 'type' => 'object', + 'location' => 'xml', + 'data' => array( + 'wrapper' => true, + ), + 'properties' => array( + 'ClusterIdentifier' => array( + 'type' => 'string', + ), + 'NodeType' => array( + 'type' => 'string', + ), + 'ClusterStatus' => array( + 'type' => 'string', + ), + 'ModifyStatus' => array( + 'type' => 'string', + ), + 'MasterUsername' => array( + 'type' => 'string', + ), + 'DBName' => array( + 'type' => 'string', + ), + 'Endpoint' => array( + 'type' => 'object', + 'properties' => array( + 'Address' => array( + 'type' => 'string', + ), + 'Port' => array( + 'type' => 'numeric', + ), + ), + ), + 'ClusterCreateTime' => array( + 'type' => 'string', + ), + 'AutomatedSnapshotRetentionPeriod' => array( + 'type' => 'numeric', + ), + 'ClusterSecurityGroups' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ClusterSecurityGroup', + 'type' => 'object', + 'sentAs' => 'ClusterSecurityGroup', + 'properties' => array( + 'ClusterSecurityGroupName' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + ), + ), + ), + 'VpcSecurityGroups' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'VpcSecurityGroup', + 'type' => 'object', + 'sentAs' => 'VpcSecurityGroup', + 'properties' => array( + 'VpcSecurityGroupId' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + ), + ), + ), + 'ClusterParameterGroups' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ClusterParameterGroup', + 'type' => 'object', + 'sentAs' => 'ClusterParameterGroup', + 'properties' => array( + 'ParameterGroupName' => array( + 'type' => 'string', + ), + 'ParameterApplyStatus' => array( + 'type' => 'string', + ), + ), + ), + ), + 'ClusterSubnetGroupName' => array( + 'type' => 'string', + ), + 'VpcId' => array( + 'type' => 'string', + ), + 'AvailabilityZone' => array( + 'type' => 'string', + ), + 'PreferredMaintenanceWindow' => array( + 'type' => 'string', + ), + 'PendingModifiedValues' => array( + 'type' => 'object', + 'properties' => array( + 'MasterUserPassword' => array( + 'type' => 'string', + ), + 'NodeType' => array( + 'type' => 'string', + ), + 'NumberOfNodes' => array( + 'type' => 'numeric', + ), + 'ClusterType' => array( + 'type' => 'string', + ), + 'ClusterVersion' => array( + 'type' => 'string', + ), + 'AutomatedSnapshotRetentionPeriod' => array( + 'type' => 'numeric', + ), + ), + ), + 'ClusterVersion' => array( + 'type' => 'string', + ), + 'AllowVersionUpgrade' => array( + 'type' => 'boolean', + ), + 'NumberOfNodes' => array( + 'type' => 'numeric', + ), + 'PubliclyAccessible' => array( + 'type' => 'boolean', + ), + 'Encrypted' => array( + 'type' => 'boolean', + ), + 'RestoreStatus' => array( + 'type' => 'object', + 'properties' => array( + 'Status' => array( + 'type' => 'string', + ), + 'CurrentRestoreRateInMegaBytesPerSecond' => array( + 'type' => 'numeric', + ), + 'SnapshotSizeInMegaBytes' => array( + 'type' => 'numeric', + ), + 'ProgressInMegaBytes' => array( + 'type' => 'numeric', + ), + 'ElapsedTimeInSeconds' => array( + 'type' => 'numeric', + ), + 'EstimatedTimeToCompletionInSeconds' => array( + 'type' => 'numeric', + ), + ), + ), + 'HsmStatus' => array( + 'type' => 'object', + 'properties' => array( + 'HsmClientCertificateIdentifier' => array( + 'type' => 'string', + ), + 'HsmConfigurationIdentifier' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + ), + ), + 'ClusterSnapshotCopyStatus' => array( + 'type' => 'object', + 'properties' => array( + 'DestinationRegion' => array( + 'type' => 'string', + ), + 'RetentionPeriod' => array( + 'type' => 'numeric', + ), + ), + ), + 'ClusterPublicKey' => array( + 'type' => 'string', + ), + 'ClusterNodes' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ClusterNode', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'NodeRole' => array( + 'type' => 'string', + ), + 'PrivateIPAddress' => array( + 'type' => 'string', + ), + 'PublicIPAddress' => array( + 'type' => 'string', + ), + ), + ), + ), + 'ElasticIpStatus' => array( + 'type' => 'object', + 'properties' => array( + 'ElasticIp' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + ), + ), + 'ClusterRevisionNumber' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'ClusterParameterGroupWrapper' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ClusterParameterGroup' => array( + 'type' => 'object', + 'location' => 'xml', + 'data' => array( + 'wrapper' => true, + ), + 'properties' => array( + 'ParameterGroupName' => array( + 'type' => 'string', + ), + 'ParameterGroupFamily' => array( + 'type' => 'string', + ), + 'Description' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'ClusterSubnetGroupWrapper' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ClusterSubnetGroup' => array( + 'type' => 'object', + 'location' => 'xml', + 'data' => array( + 'wrapper' => true, + ), + 'properties' => array( + 'ClusterSubnetGroupName' => array( + 'type' => 'string', + ), + 'Description' => array( + 'type' => 'string', + ), + 'VpcId' => array( + 'type' => 'string', + ), + 'SubnetGroupStatus' => array( + 'type' => 'string', + ), + 'Subnets' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Subnet', + 'type' => 'object', + 'sentAs' => 'Subnet', + 'properties' => array( + 'SubnetIdentifier' => array( + 'type' => 'string', + ), + 'SubnetAvailabilityZone' => array( + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + ), + ), + 'SubnetStatus' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'EventSubscriptionWrapper' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'EventSubscription' => array( + 'type' => 'object', + 'location' => 'xml', + 'data' => array( + 'wrapper' => true, + ), + 'properties' => array( + 'CustomerAwsId' => array( + 'type' => 'string', + ), + 'CustSubscriptionId' => array( + 'type' => 'string', + ), + 'SnsTopicArn' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'SubscriptionCreationTime' => array( + 'type' => 'string', + ), + 'SourceType' => array( + 'type' => 'string', + ), + 'SourceIdsList' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'SourceId', + 'type' => 'string', + 'sentAs' => 'SourceId', + ), + ), + 'EventCategoriesList' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'EventCategory', + 'type' => 'string', + 'sentAs' => 'EventCategory', + ), + ), + 'Severity' => array( + 'type' => 'string', + ), + 'Enabled' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + 'HsmClientCertificateWrapper' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'HsmClientCertificate' => array( + 'type' => 'object', + 'location' => 'xml', + 'data' => array( + 'wrapper' => true, + ), + 'properties' => array( + 'HsmClientCertificateIdentifier' => array( + 'type' => 'string', + ), + 'HsmClientCertificatePublicKey' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'HsmConfigurationWrapper' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'HsmConfiguration' => array( + 'type' => 'object', + 'location' => 'xml', + 'data' => array( + 'wrapper' => true, + ), + 'properties' => array( + 'HsmConfigurationIdentifier' => array( + 'type' => 'string', + ), + 'Description' => array( + 'type' => 'string', + ), + 'HsmIpAddress' => array( + 'type' => 'string', + ), + 'HsmPartitionName' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'EmptyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + ), + 'ClusterParameterGroupsMessage' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'ParameterGroups' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'ClusterParameterGroup', + 'type' => 'object', + 'sentAs' => 'ClusterParameterGroup', + 'properties' => array( + 'ParameterGroupName' => array( + 'type' => 'string', + ), + 'ParameterGroupFamily' => array( + 'type' => 'string', + ), + 'Description' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'ClusterParameterGroupDetails' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Parameters' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'Parameter', + 'type' => 'object', + 'sentAs' => 'Parameter', + 'properties' => array( + 'ParameterName' => array( + 'type' => 'string', + ), + 'ParameterValue' => array( + 'type' => 'string', + ), + 'Description' => array( + 'type' => 'string', + ), + 'Source' => array( + 'type' => 'string', + ), + 'DataType' => array( + 'type' => 'string', + ), + 'AllowedValues' => array( + 'type' => 'string', + ), + 'IsModifiable' => array( + 'type' => 'boolean', + ), + 'MinimumEngineVersion' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'ClusterSecurityGroupMessage' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'ClusterSecurityGroups' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'ClusterSecurityGroup', + 'type' => 'object', + 'sentAs' => 'ClusterSecurityGroup', + 'properties' => array( + 'ClusterSecurityGroupName' => array( + 'type' => 'string', + ), + 'Description' => array( + 'type' => 'string', + ), + 'EC2SecurityGroups' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'EC2SecurityGroup', + 'type' => 'object', + 'sentAs' => 'EC2SecurityGroup', + 'properties' => array( + 'Status' => array( + 'type' => 'string', + ), + 'EC2SecurityGroupName' => array( + 'type' => 'string', + ), + 'EC2SecurityGroupOwnerId' => array( + 'type' => 'string', + ), + ), + ), + ), + 'IPRanges' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'IPRange', + 'type' => 'object', + 'sentAs' => 'IPRange', + 'properties' => array( + 'Status' => array( + 'type' => 'string', + ), + 'CIDRIP' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'SnapshotMessage' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'Snapshots' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'Snapshot', + 'type' => 'object', + 'sentAs' => 'Snapshot', + 'properties' => array( + 'SnapshotIdentifier' => array( + 'type' => 'string', + ), + 'ClusterIdentifier' => array( + 'type' => 'string', + ), + 'SnapshotCreateTime' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'Port' => array( + 'type' => 'numeric', + ), + 'AvailabilityZone' => array( + 'type' => 'string', + ), + 'ClusterCreateTime' => array( + 'type' => 'string', + ), + 'MasterUsername' => array( + 'type' => 'string', + ), + 'ClusterVersion' => array( + 'type' => 'string', + ), + 'SnapshotType' => array( + 'type' => 'string', + ), + 'NodeType' => array( + 'type' => 'string', + ), + 'NumberOfNodes' => array( + 'type' => 'numeric', + ), + 'DBName' => array( + 'type' => 'string', + ), + 'VpcId' => array( + 'type' => 'string', + ), + 'Encrypted' => array( + 'type' => 'boolean', + ), + 'EncryptedWithHSM' => array( + 'type' => 'boolean', + ), + 'AccountsWithRestoreAccess' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AccountWithRestoreAccess', + 'type' => 'object', + 'sentAs' => 'AccountWithRestoreAccess', + 'properties' => array( + 'AccountId' => array( + 'type' => 'string', + ), + ), + ), + ), + 'OwnerAccount' => array( + 'type' => 'string', + ), + 'TotalBackupSizeInMegaBytes' => array( + 'type' => 'numeric', + ), + 'ActualIncrementalBackupSizeInMegaBytes' => array( + 'type' => 'numeric', + ), + 'BackupProgressInMegaBytes' => array( + 'type' => 'numeric', + ), + 'CurrentBackupRateInMegaBytesPerSecond' => array( + 'type' => 'numeric', + ), + 'EstimatedSecondsToCompletion' => array( + 'type' => 'numeric', + ), + 'ElapsedTimeInSeconds' => array( + 'type' => 'numeric', + ), + 'SourceRegion' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'ClusterSubnetGroupMessage' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'ClusterSubnetGroups' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'ClusterSubnetGroup', + 'type' => 'object', + 'sentAs' => 'ClusterSubnetGroup', + 'properties' => array( + 'ClusterSubnetGroupName' => array( + 'type' => 'string', + ), + 'Description' => array( + 'type' => 'string', + ), + 'VpcId' => array( + 'type' => 'string', + ), + 'SubnetGroupStatus' => array( + 'type' => 'string', + ), + 'Subnets' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Subnet', + 'type' => 'object', + 'sentAs' => 'Subnet', + 'properties' => array( + 'SubnetIdentifier' => array( + 'type' => 'string', + ), + 'SubnetAvailabilityZone' => array( + 'type' => 'object', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + ), + ), + 'SubnetStatus' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'ClusterVersionsMessage' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'ClusterVersions' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'ClusterVersion', + 'type' => 'object', + 'sentAs' => 'ClusterVersion', + 'properties' => array( + 'ClusterVersion' => array( + 'type' => 'string', + ), + 'ClusterParameterGroupFamily' => array( + 'type' => 'string', + ), + 'Description' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'ClustersMessage' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'Clusters' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'Cluster', + 'type' => 'object', + 'sentAs' => 'Cluster', + 'properties' => array( + 'ClusterIdentifier' => array( + 'type' => 'string', + ), + 'NodeType' => array( + 'type' => 'string', + ), + 'ClusterStatus' => array( + 'type' => 'string', + ), + 'ModifyStatus' => array( + 'type' => 'string', + ), + 'MasterUsername' => array( + 'type' => 'string', + ), + 'DBName' => array( + 'type' => 'string', + ), + 'Endpoint' => array( + 'type' => 'object', + 'properties' => array( + 'Address' => array( + 'type' => 'string', + ), + 'Port' => array( + 'type' => 'numeric', + ), + ), + ), + 'ClusterCreateTime' => array( + 'type' => 'string', + ), + 'AutomatedSnapshotRetentionPeriod' => array( + 'type' => 'numeric', + ), + 'ClusterSecurityGroups' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ClusterSecurityGroup', + 'type' => 'object', + 'sentAs' => 'ClusterSecurityGroup', + 'properties' => array( + 'ClusterSecurityGroupName' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + ), + ), + ), + 'VpcSecurityGroups' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'VpcSecurityGroup', + 'type' => 'object', + 'sentAs' => 'VpcSecurityGroup', + 'properties' => array( + 'VpcSecurityGroupId' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + ), + ), + ), + 'ClusterParameterGroups' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ClusterParameterGroup', + 'type' => 'object', + 'sentAs' => 'ClusterParameterGroup', + 'properties' => array( + 'ParameterGroupName' => array( + 'type' => 'string', + ), + 'ParameterApplyStatus' => array( + 'type' => 'string', + ), + ), + ), + ), + 'ClusterSubnetGroupName' => array( + 'type' => 'string', + ), + 'VpcId' => array( + 'type' => 'string', + ), + 'AvailabilityZone' => array( + 'type' => 'string', + ), + 'PreferredMaintenanceWindow' => array( + 'type' => 'string', + ), + 'PendingModifiedValues' => array( + 'type' => 'object', + 'properties' => array( + 'MasterUserPassword' => array( + 'type' => 'string', + ), + 'NodeType' => array( + 'type' => 'string', + ), + 'NumberOfNodes' => array( + 'type' => 'numeric', + ), + 'ClusterType' => array( + 'type' => 'string', + ), + 'ClusterVersion' => array( + 'type' => 'string', + ), + 'AutomatedSnapshotRetentionPeriod' => array( + 'type' => 'numeric', + ), + ), + ), + 'ClusterVersion' => array( + 'type' => 'string', + ), + 'AllowVersionUpgrade' => array( + 'type' => 'boolean', + ), + 'NumberOfNodes' => array( + 'type' => 'numeric', + ), + 'PubliclyAccessible' => array( + 'type' => 'boolean', + ), + 'Encrypted' => array( + 'type' => 'boolean', + ), + 'RestoreStatus' => array( + 'type' => 'object', + 'properties' => array( + 'Status' => array( + 'type' => 'string', + ), + 'CurrentRestoreRateInMegaBytesPerSecond' => array( + 'type' => 'numeric', + ), + 'SnapshotSizeInMegaBytes' => array( + 'type' => 'numeric', + ), + 'ProgressInMegaBytes' => array( + 'type' => 'numeric', + ), + 'ElapsedTimeInSeconds' => array( + 'type' => 'numeric', + ), + 'EstimatedTimeToCompletionInSeconds' => array( + 'type' => 'numeric', + ), + ), + ), + 'HsmStatus' => array( + 'type' => 'object', + 'properties' => array( + 'HsmClientCertificateIdentifier' => array( + 'type' => 'string', + ), + 'HsmConfigurationIdentifier' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + ), + ), + 'ClusterSnapshotCopyStatus' => array( + 'type' => 'object', + 'properties' => array( + 'DestinationRegion' => array( + 'type' => 'string', + ), + 'RetentionPeriod' => array( + 'type' => 'numeric', + ), + ), + ), + 'ClusterPublicKey' => array( + 'type' => 'string', + ), + 'ClusterNodes' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ClusterNode', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'NodeRole' => array( + 'type' => 'string', + ), + 'PrivateIPAddress' => array( + 'type' => 'string', + ), + 'PublicIPAddress' => array( + 'type' => 'string', + ), + ), + ), + ), + 'ElasticIpStatus' => array( + 'type' => 'object', + 'properties' => array( + 'ElasticIp' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + ), + ), + 'ClusterRevisionNumber' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'DefaultClusterParametersWrapper' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'DefaultClusterParameters' => array( + 'type' => 'object', + 'location' => 'xml', + 'data' => array( + 'wrapper' => true, + ), + 'properties' => array( + 'ParameterGroupFamily' => array( + 'type' => 'string', + ), + 'Marker' => array( + 'type' => 'string', + ), + 'Parameters' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Parameter', + 'type' => 'object', + 'sentAs' => 'Parameter', + 'properties' => array( + 'ParameterName' => array( + 'type' => 'string', + ), + 'ParameterValue' => array( + 'type' => 'string', + ), + 'Description' => array( + 'type' => 'string', + ), + 'Source' => array( + 'type' => 'string', + ), + 'DataType' => array( + 'type' => 'string', + ), + 'AllowedValues' => array( + 'type' => 'string', + ), + 'IsModifiable' => array( + 'type' => 'boolean', + ), + 'MinimumEngineVersion' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + 'EventCategoriesMessage' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'EventCategoriesMapList' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'EventCategoriesMap', + 'type' => 'object', + 'sentAs' => 'EventCategoriesMap', + 'properties' => array( + 'SourceType' => array( + 'type' => 'string', + ), + 'Events' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'EventInfoMap', + 'type' => 'object', + 'sentAs' => 'EventInfoMap', + 'properties' => array( + 'EventId' => array( + 'type' => 'string', + ), + 'EventCategories' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'EventCategory', + 'type' => 'string', + 'sentAs' => 'EventCategory', + ), + ), + 'EventDescription' => array( + 'type' => 'string', + ), + 'Severity' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'EventSubscriptionsMessage' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'EventSubscriptionsList' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'EventSubscription', + 'type' => 'object', + 'sentAs' => 'EventSubscription', + 'properties' => array( + 'CustomerAwsId' => array( + 'type' => 'string', + ), + 'CustSubscriptionId' => array( + 'type' => 'string', + ), + 'SnsTopicArn' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'SubscriptionCreationTime' => array( + 'type' => 'string', + ), + 'SourceType' => array( + 'type' => 'string', + ), + 'SourceIdsList' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'SourceId', + 'type' => 'string', + 'sentAs' => 'SourceId', + ), + ), + 'EventCategoriesList' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'EventCategory', + 'type' => 'string', + 'sentAs' => 'EventCategory', + ), + ), + 'Severity' => array( + 'type' => 'string', + ), + 'Enabled' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + ), + 'EventsMessage' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'Events' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'Event', + 'type' => 'object', + 'sentAs' => 'Event', + 'properties' => array( + 'SourceIdentifier' => array( + 'type' => 'string', + ), + 'SourceType' => array( + 'type' => 'string', + ), + 'Message' => array( + 'type' => 'string', + ), + 'EventCategories' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'EventCategory', + 'type' => 'string', + 'sentAs' => 'EventCategory', + ), + ), + 'Severity' => array( + 'type' => 'string', + ), + 'Date' => array( + 'type' => 'string', + ), + 'EventId' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'HsmClientCertificateMessage' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'HsmClientCertificates' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'HsmClientCertificate', + 'type' => 'object', + 'sentAs' => 'HsmClientCertificate', + 'properties' => array( + 'HsmClientCertificateIdentifier' => array( + 'type' => 'string', + ), + 'HsmClientCertificatePublicKey' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'HsmConfigurationMessage' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'HsmConfigurations' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'HsmConfiguration', + 'type' => 'object', + 'sentAs' => 'HsmConfiguration', + 'properties' => array( + 'HsmConfigurationIdentifier' => array( + 'type' => 'string', + ), + 'Description' => array( + 'type' => 'string', + ), + 'HsmIpAddress' => array( + 'type' => 'string', + ), + 'HsmPartitionName' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'LoggingStatus' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'LoggingEnabled' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'BucketName' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'S3KeyPrefix' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'LastSuccessfulDeliveryTime' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'LastFailureTime' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'LastFailureMessage' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'OrderableClusterOptionsMessage' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'OrderableClusterOptions' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'OrderableClusterOption', + 'type' => 'object', + 'sentAs' => 'OrderableClusterOption', + 'properties' => array( + 'ClusterVersion' => array( + 'type' => 'string', + ), + 'ClusterType' => array( + 'type' => 'string', + ), + 'NodeType' => array( + 'type' => 'string', + ), + 'AvailabilityZones' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'AvailabilityZone', + 'type' => 'object', + 'sentAs' => 'AvailabilityZone', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'ReservedNodeOfferingsMessage' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'ReservedNodeOfferings' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'ReservedNodeOffering', + 'type' => 'object', + 'sentAs' => 'ReservedNodeOffering', + 'properties' => array( + 'ReservedNodeOfferingId' => array( + 'type' => 'string', + ), + 'NodeType' => array( + 'type' => 'string', + ), + 'Duration' => array( + 'type' => 'numeric', + ), + 'FixedPrice' => array( + 'type' => 'numeric', + ), + 'UsagePrice' => array( + 'type' => 'numeric', + ), + 'CurrencyCode' => array( + 'type' => 'string', + ), + 'OfferingType' => array( + 'type' => 'string', + ), + 'RecurringCharges' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'RecurringCharge', + 'type' => 'object', + 'sentAs' => 'RecurringCharge', + 'properties' => array( + 'RecurringChargeAmount' => array( + 'type' => 'numeric', + ), + 'RecurringChargeFrequency' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'ReservedNodesMessage' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'ReservedNodes' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'ReservedNode', + 'type' => 'object', + 'sentAs' => 'ReservedNode', + 'properties' => array( + 'ReservedNodeId' => array( + 'type' => 'string', + ), + 'ReservedNodeOfferingId' => array( + 'type' => 'string', + ), + 'NodeType' => array( + 'type' => 'string', + ), + 'StartTime' => array( + 'type' => 'string', + ), + 'Duration' => array( + 'type' => 'numeric', + ), + 'FixedPrice' => array( + 'type' => 'numeric', + ), + 'UsagePrice' => array( + 'type' => 'numeric', + ), + 'CurrencyCode' => array( + 'type' => 'string', + ), + 'NodeCount' => array( + 'type' => 'numeric', + ), + 'State' => array( + 'type' => 'string', + ), + 'OfferingType' => array( + 'type' => 'string', + ), + 'RecurringCharges' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'RecurringCharge', + 'type' => 'object', + 'sentAs' => 'RecurringCharge', + 'properties' => array( + 'RecurringChargeAmount' => array( + 'type' => 'numeric', + ), + 'RecurringChargeFrequency' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'ResizeProgressMessage' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'TargetNodeType' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'TargetNumberOfNodes' => array( + 'type' => 'numeric', + 'location' => 'xml', + ), + 'TargetClusterType' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'Status' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'ImportTablesCompleted' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + 'ImportTablesInProgress' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + 'ImportTablesNotStarted' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + 'sentAs' => 'member', + ), + ), + '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', + ), + ), + ), + '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', + ), + ), + '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-sdk-php/src/Aws/Route53/Enum/Action.php b/vendor/aws/aws-sdk-php/src/Aws/Route53/Enum/Action.php new file mode 100644 index 0000000..42652e5 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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( + '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, + ), + 'Failover' => array( + 'type' => 'string', + ), + 'TTL' => array( + 'type' => 'numeric', + 'maximum' => 2147483647, + ), + 'ResourceRecords' => array( + 'type' => 'array', + 'minItems' => 1, + 'items' => array( + 'name' => 'ResourceRecord', + 'type' => 'object', + 'properties' => array( + 'Value' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 4000, + ), + ), + ), + ), + 'AliasTarget' => array( + 'type' => 'object', + 'properties' => array( + 'HostedZoneId' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 32, + ), + 'DNSName' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 1024, + ), + 'EvaluateTargetHealth' => array( + 'required' => true, + 'type' => 'boolean', + 'format' => 'boolean-string', + ), + ), + ), + 'HealthCheckId' => array( + 'type' => 'string', + 'maxLength' => 64, + ), + ), + ), + ), + ), + ), + ), + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/xml', + ), + ), + 'errorResponses' => array( + array( + 'class' => 'NoSuchHostedZoneException', + ), + array( + 'reason' => 'The health check you are trying to get or delete does not exist.', + 'class' => 'NoSuchHealthCheckException', + ), + array( + 'reason' => 'This error contains a list of one or more error messages. Each error message indicates one error in the change batch. For more information, see Example InvalidChangeBatch Errors.', + 'class' => 'InvalidChangeBatchException', + ), + array( + 'reason' => 'Some value specified in the request is invalid or the XML document is malformed.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'The request was rejected because Route 53 was still processing a prior request.', + 'class' => 'PriorRequestNotCompleteException', + ), + ), + ), + 'CreateHealthCheck' => array( + 'httpMethod' => 'POST', + 'uri' => '/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( + 'required' => true, + 'type' => 'string', + 'maxLength' => 15, + ), + 'Port' => array( + 'type' => 'numeric', + 'minimum' => 1, + 'maximum' => 65535, + ), + 'Type' => array( + 'required' => true, + 'type' => 'string', + ), + 'ResourcePath' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + 'FullyQualifiedDomainName' => array( + 'type' => 'string', + 'maxLength' => 255, + ), + '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, + ), + 'CallerReference' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'xml', + 'minLength' => 1, + 'maxLength' => 128, + ), + 'HostedZoneConfig' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Comment' => array( + 'type' => 'string', + 'maxLength' => 256, + ), + ), + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/xml', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'This error indicates that the specified domain name is not valid.', + 'class' => 'InvalidDomainNameException', + ), + array( + 'reason' => 'The hosted zone you are trying to create already exists. Route 53 returns this error when a hosted zone has already been created with the specified CallerReference.', + 'class' => 'HostedZoneAlreadyExistsException', + ), + array( + 'reason' => 'This error indicates that you\'ve reached the maximum number of hosted zones that can be created for the current AWS account. You can request an increase to the limit on the Contact Us page.', + 'class' => 'TooManyHostedZonesException', + ), + array( + 'reason' => 'Some value specified in the request is invalid or the XML document is malformed.', + 'class' => 'InvalidInputException', + ), + array( + 'reason' => 'Route 53 allows some duplicate domain names, but there is a maximum number of duplicate names. This error indicates that you have reached that maximum. If you want to create another hosted zone with the same name and Route 53 generates this error, you can request an increase to the limit on the Contact Us page.', + 'class' => 'DelegationSetNotAvailableException', + ), + ), + ), + 'DeleteHealthCheck' => array( + 'httpMethod' => 'DELETE', + 'uri' => '/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', + ), + ), + ), + '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', + ), + ), + ), + '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', + ), + ), + ), + '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', + ), + ), + ), + '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', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/xml', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Some value specified in the request is invalid or the XML document is malformed.', + 'class' => 'InvalidInputException', + ), + ), + ), + 'ListResourceRecordSets' => array( + 'httpMethod' => 'GET', + 'uri' => '/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', + ), + ), + ), + ), + 'models' => array( + 'ChangeResourceRecordSetsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ChangeInfo' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'SubmittedAt' => array( + 'type' => 'string', + ), + 'Comment' => array( + 'type' => 'string', + ), + ), + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'CreateHealthCheckResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'HealthCheck' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'CallerReference' => array( + 'type' => 'string', + ), + 'HealthCheckConfig' => array( + 'type' => 'object', + 'properties' => array( + 'IPAddress' => array( + 'type' => 'string', + ), + 'Port' => array( + 'type' => 'numeric', + ), + 'Type' => array( + 'type' => 'string', + ), + 'ResourcePath' => array( + 'type' => 'string', + ), + 'FullyQualifiedDomainName' => array( + 'type' => 'string', + ), + 'SearchString' => array( + 'type' => 'string', + ), + 'RequestInterval' => array( + 'type' => 'numeric', + ), + 'FailureThreshold' => 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', + ), + ), + ), + 'ResourceRecordSetCount' => array( + 'type' => 'numeric', + ), + ), + ), + 'ChangeInfo' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'SubmittedAt' => array( + 'type' => 'string', + ), + 'Comment' => array( + 'type' => 'string', + ), + ), + ), + 'DelegationSet' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'NameServers' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NameServer', + 'type' => 'string', + 'sentAs' => 'NameServer', + ), + ), + ), + ), + 'Location' => array( + 'type' => 'string', + 'location' => 'header', + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'DeleteHealthCheckResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'DeleteHostedZoneResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ChangeInfo' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'SubmittedAt' => array( + 'type' => 'string', + ), + 'Comment' => array( + 'type' => 'string', + ), + ), + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'GetChangeResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ChangeInfo' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Status' => array( + 'type' => 'string', + ), + 'SubmittedAt' => array( + 'type' => 'string', + ), + 'Comment' => array( + 'type' => 'string', + ), + ), + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'GetHealthCheckResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'HealthCheck' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'CallerReference' => array( + 'type' => 'string', + ), + 'HealthCheckConfig' => array( + 'type' => 'object', + 'properties' => array( + 'IPAddress' => array( + 'type' => 'string', + ), + 'Port' => array( + 'type' => 'numeric', + ), + 'Type' => array( + 'type' => 'string', + ), + 'ResourcePath' => array( + 'type' => 'string', + ), + 'FullyQualifiedDomainName' => array( + 'type' => 'string', + ), + 'SearchString' => array( + 'type' => 'string', + ), + 'RequestInterval' => array( + 'type' => 'numeric', + ), + 'FailureThreshold' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'GetHostedZoneResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'HostedZone' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'Name' => array( + 'type' => 'string', + ), + 'CallerReference' => array( + 'type' => 'string', + ), + 'Config' => array( + 'type' => 'object', + 'properties' => array( + 'Comment' => array( + 'type' => 'string', + ), + ), + ), + 'ResourceRecordSetCount' => array( + 'type' => 'numeric', + ), + ), + ), + 'DelegationSet' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'NameServers' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'NameServer', + 'type' => 'string', + 'sentAs' => 'NameServer', + ), + ), + ), + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'ListHealthChecksResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'HealthChecks' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'HealthCheck', + 'type' => 'object', + 'sentAs' => 'HealthCheck', + 'properties' => array( + 'Id' => array( + 'type' => 'string', + ), + 'CallerReference' => array( + 'type' => 'string', + ), + 'HealthCheckConfig' => array( + 'type' => 'object', + 'properties' => array( + 'IPAddress' => array( + 'type' => 'string', + ), + 'Port' => array( + 'type' => 'numeric', + ), + 'Type' => array( + 'type' => 'string', + ), + 'ResourcePath' => array( + 'type' => 'string', + ), + 'FullyQualifiedDomainName' => array( + 'type' => 'string', + ), + 'SearchString' => array( + 'type' => 'string', + ), + 'RequestInterval' => array( + 'type' => 'numeric', + ), + 'FailureThreshold' => 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', + ), + ), + ), + 'ResourceRecordSetCount' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'IsTruncated' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'NextMarker' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'MaxItems' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'ListResourceRecordSetsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ResourceRecordSets' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'ResourceRecordSet', + 'type' => 'object', + 'sentAs' => 'ResourceRecordSet', + 'properties' => array( + 'Name' => array( + 'type' => 'string', + ), + 'Type' => array( + 'type' => 'string', + ), + 'SetIdentifier' => array( + 'type' => 'string', + ), + 'Weight' => array( + 'type' => 'numeric', + ), + 'Region' => array( + 'type' => 'string', + ), + 'Failover' => array( + 'type' => 'string', + ), + 'TTL' => array( + 'type' => 'numeric', + ), + 'ResourceRecords' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'ResourceRecord', + 'type' => 'object', + 'sentAs' => 'ResourceRecord', + 'properties' => array( + 'Value' => array( + 'type' => 'string', + ), + ), + ), + ), + 'AliasTarget' => array( + 'type' => 'object', + 'properties' => array( + 'HostedZoneId' => array( + 'type' => 'string', + ), + 'DNSName' => array( + 'type' => 'string', + ), + 'EvaluateTargetHealth' => array( + 'type' => 'boolean', + ), + ), + ), + 'HealthCheckId' => array( + 'type' => 'string', + ), + ), + ), + ), + 'IsTruncated' => array( + 'type' => 'boolean', + 'location' => 'xml', + ), + 'NextRecordName' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'NextRecordType' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'NextRecordIdentifier' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'MaxItems' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + ), + 'iterators' => array( + '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-sdk-php/src/Aws/Route53/Route53Client.php b/vendor/aws/aws-sdk-php/src/Aws/Route53/Route53Client.php new file mode 100644 index 0000000..911fa0b --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/Route53/Route53Client.php @@ -0,0 +1,105 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/route53-%s.php' + )) + ->build(); + } + + /** + * Retrieves the server time from Route53. Can be useful for detecting and/or preventing clock skew. + * + * @return \DateTime The server time from Route53 + * @link http://docs.aws.amazon.com/Route53/latest/DeveloperGuide/RESTAuthentication.html#FetchingDate + */ + public function getServerTime() + { + try { + $response = $this->get('https://route53.amazonaws.com/date')->send(); + } catch (ServiceResponseException $e) { + $response = $e->getResponse(); + } + + $serverTime = trim($response->getHeader('Date', true)); + $serverTime = \DateTime::createFromFormat(DateFormat::RFC1123, $serverTime); + + return $serverTime; + } + + /** + * Filter function used to remove ID prefixes. This is used automatically by the client so that Hosted Zone and + * Change Record IDs can be specified with or without the prefix. + * + * @param string $id The ID value to clean + * + * @return string + */ + public static function cleanId($id) + { + return str_replace(array('/hostedzone/', '/change/'), '', $id); + } +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/S3/AcpListener.php b/vendor/aws/aws-sdk-php/src/Aws/S3/AcpListener.php new file mode 100644 index 0000000..2d28407 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/S3/BucketStyleListener.php b/vendor/aws/aws-sdk-php/src/Aws/S3/BucketStyleListener.php new file mode 100644 index 0000000..6bb5bb4 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/S3/BucketStyleListener.php @@ -0,0 +1,85 @@ + array('onCommandAfterPrepare', -255)); + } + + /** + * Changes how buckets are referenced in the HTTP request + * + * @param Event $event Event emitted + */ + public function onCommandAfterPrepare(Event $event) + { + $command = $event['command']; + $bucket = $command['Bucket']; + $request = $command->getRequest(); + $pathStyle = false; + + if ($key = $command['Key']) { + // Modify the command Key to account for the {/Key*} explosion into an array + if (is_array($key)) { + $command['Key'] = $key = implode('/', $key); + } + } + + // Set the key and bucket on the request + $request->getParams()->set('bucket', $bucket)->set('key', $key); + + // Switch to virtual if PathStyle is disabled, or not a DNS compatible bucket name, or the scheme is + // http, or the scheme is https and there are no dots in the host header (avoids SSL issues) + if (!$command['PathStyle'] && $command->getClient()->isValidBucketName($bucket) + && !($command->getRequest()->getScheme() == 'https' && strpos($bucket, '.')) + ) { + // Switch to virtual hosted bucket + $request->setHost($bucket . '.' . $request->getHost()); + $request->setPath(preg_replace("#^/{$bucket}#", '', $request->getPath())); + } else { + $pathStyle = true; + } + + if (!$bucket) { + $request->getParams()->set('s3.resource', '/'); + } elseif ($pathStyle) { + // Path style does not need a trailing slash + $request->getParams()->set( + 's3.resource', + '/' . rawurlencode($bucket) . ($key ? ('/' . S3Client::encodeKey($key)) : '') + ); + } else { + // Bucket style needs a trailing slash + $request->getParams()->set( + 's3.resource', + '/' . rawurlencode($bucket) . ($key ? ('/' . S3Client::encodeKey($key)) : '/') + ); + } + } +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/S3/Command/S3Command.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Command/S3Command.php new file mode 100644 index 0000000..d0d3b24 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/S3/Enum/CannedAcl.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Enum/CannedAcl.php new file mode 100644 index 0000000..da47045 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/S3/Exception/EntityTooLargeException.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Exception/EntityTooLargeException.php new file mode 100644 index 0000000..66e6da9 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/S3/Exception/PermanentRedirectException.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Exception/PermanentRedirectException.php new file mode 100644 index 0000000..d2af820 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/S3/Iterator/ListMultipartUploadsIterator.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Iterator/ListMultipartUploadsIterator.php new file mode 100644 index 0000000..592aa0a --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/S3/Iterator/ListObjectVersionsIterator.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Iterator/ListObjectVersionsIterator.php new file mode 100644 index 0000000..991a77e --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/S3/Iterator/ListObjectsIterator.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Iterator/ListObjectsIterator.php new file mode 100644 index 0000000..852b2a9 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/S3/Iterator/OpendirIterator.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Iterator/OpendirIterator.php new file mode 100644 index 0000000..82c0153 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/S3/Model/Acp.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Model/Acp.php new file mode 100644 index 0000000..8325a2b --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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 self + */ + public static function fromArray(array $data) + { + $builder = new AcpBuilder(); + $builder->setOwner((string) $data['Owner']['ID'], $data['Owner']['DisplayName']); + + // Add each Grantee to the ACP + foreach ($data['Grants'] as $grant) { + $permission = $grant['Permission']; + + // Determine the type for response bodies that are missing the Type parameter + if (!isset($grant['Grantee']['Type'])) { + if (isset($grant['Grantee']['ID'])) { + $grant['Grantee']['Type'] = 'CanonicalUser'; + } elseif (isset($grant['Grantee']['URI'])) { + $grant['Grantee']['Type'] = 'Group'; + } else { + $grant['Grantee']['Type'] = 'AmazonCustomerByEmail'; + } + } + + switch ($grant['Grantee']['Type']) { + case 'Group': + $builder->addGrantForGroup($permission, $grant['Grantee']['URI']); + break; + case 'AmazonCustomerByEmail': + $builder->addGrantForEmail($permission, $grant['Grantee']['EmailAddress']); + break; + case 'CanonicalUser': + $builder->addGrantForUser( + $permission, + $grant['Grantee']['ID'], + $grant['Grantee']['DisplayName'] + ); + } + } + + return $builder->build(); + } + + /** + * Set the owner of the ACP policy + * + * @param Grantee $owner ACP policy owner + * + * @return self + * + * @throws InvalidArgumentException if the grantee does not have an ID set + */ + public function setOwner(Grantee $owner) + { + if (!$owner->isCanonicalUser()) { + throw new InvalidArgumentException('The owner must have an ID set.'); + } + + $this->owner = $owner; + + return $this; + } + + /** + * Get the owner of the ACP policy + * + * @return Grantee + */ + public function getOwner() + { + return $this->owner; + } + + /** + * Set the grants for the ACP + * + * @param array|\Traversable $grants List of grants for the ACP + * + * @return self + * + * @throws InvalidArgumentException + */ + public function setGrants($grants = array()) + { + $this->grants = new \SplObjectStorage(); + + if ($grants) { + if (is_array($grants) || $grants instanceof \Traversable) { + /** @var $grant Grant */ + foreach ($grants as $grant) { + $this->addGrant($grant); + } + } else { + throw new InvalidArgumentException('Grants must be passed in as an array or Traversable object.'); + } + } + + return $this; + } + + /** + * Get all of the grants + * + * @return \SplObjectStorage + */ + public function getGrants() + { + return $this->grants; + } + + /** + * Add a Grant + * + * @param Grant $grant Grant to add + * + * @return self + */ + public function addGrant(Grant $grant) + { + if (count($this->grants) < 100) { + $this->grants->attach($grant); + } else { + throw new OverflowException('An ACP may contain up to 100 grants.'); + } + + return $this; + } + + /** + * Get the total number of attributes + * + * @return int + */ + public function count() + { + return count($this->grants); + } + + /** + * Returns the grants for iteration + * + * @return \SplObjectStorage + */ + public function getIterator() + { + return $this->grants; + } + + /** + * Applies grant headers to a command's parameters + * + * @param AbstractCommand $command Command to be updated + * + * @return self + */ + public function updateCommand(AbstractCommand $command) + { + $parameters = array(); + foreach ($this->grants as $grant) { + /** @var $grant Grant */ + $parameters = array_merge_recursive($parameters, $grant->getParameterArray()); + } + + foreach ($parameters as $name => $values) { + $command->set($name, implode(', ', (array) $values)); + } + + return $this; + } + + /** + * {@inheritdoc} + */ + public function toArray() + { + $grants = array(); + foreach ($this->grants as $grant) { + $grants[] = $grant->toArray(); + } + + return array( + 'Owner' => array( + 'ID' => $this->owner->getId(), + 'DisplayName' => $this->owner->getDisplayName() + ), + 'Grants' => $grants + ); + } +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/S3/Model/AcpBuilder.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Model/AcpBuilder.php new file mode 100644 index 0000000..0e41c3c --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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 self + */ + public function addGrantForUser($permission, $id, $displayName = null) + { + $grantee = new Grantee($id, $displayName ?: $id, GranteeType::USER); + $this->addGrant($permission, $grantee); + + return $this; + } + + /** + * Create and store a Grant with a AmazonCustomerByEmail Grantee for the ACL + * + * @param string $permission Permission for the Grant + * @param string $email Grantee email address + * + * @return self + */ + public function addGrantForEmail($permission, $email) + { + $grantee = new Grantee($email, null, GranteeType::EMAIL); + $this->addGrant($permission, $grantee); + + return $this; + } + + /** + * Create and store a Grant with a Group Grantee for the ACL + * + * @param string $permission Permission for the Grant + * @param string $group Grantee group + * + * @return self + */ + public function addGrantForGroup($permission, $group) + { + $grantee = new Grantee($group, null, GranteeType::GROUP); + $this->addGrant($permission, $grantee); + + return $this; + } + + /** + * Create and store a Grant for the ACL + * + * @param string $permission Permission for the Grant + * @param Grantee $grantee The Grantee for the Grant + * + * @return self + */ + public function addGrant($permission, Grantee $grantee) + { + $this->grants[] = new Grant($grantee, $permission); + + return $this; + } + + /** + * Builds the ACP and returns it + * + * @return Acp + */ + public function build() + { + return new Acp($this->owner, $this->grants); + } +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/S3/Model/ClearBucket.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Model/ClearBucket.php new file mode 100644 index 0000000..77ce937 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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 self + */ + public function setBucket($bucket) + { + $this->bucket = $bucket; + + return $this; + } + + /** + * Get the iterator used to yield the keys to be deleted. A default iterator + * will be created and returned if no iterator has been explicitly set. + * + * @return \Iterator + */ + public function getIterator() + { + if (!$this->iterator) { + $this->iterator = $this->client->getIterator('ListObjectVersions', array( + 'Bucket' => $this->bucket + )); + } + + return $this->iterator; + } + + /** + * Sets a different iterator to use than the default iterator. This can be helpful when you wish to delete + * only specific keys from a bucket (e.g. keys that match a certain prefix or delimiter, or perhaps keys that + * pass through a filtered, decorated iterator). + * + * @param \Iterator $iterator Iterator used to yield the keys to be deleted + * + * @return self + */ + public function setIterator(\Iterator $iterator) + { + $this->iterator = $iterator; + + return $this; + } + + /** + * Set the MFA token to send with each request + * + * @param string $mfa MFA token to send with each request. The value is the concatenation of the authentication + * device's serial number, a space, and the value displayed on your authentication device. + * + * @return self + */ + public function setMfa($mfa) + { + $this->mfa = $mfa; + + return $this; + } + + /** + * Clear the bucket + * + * @return int Returns the number of deleted keys + * @throws ExceptionCollection + */ + public function clear() + { + $that = $this; + $batch = DeleteObjectsBatch::factory($this->client, $this->bucket, $this->mfa); + $batch = new NotifyingBatch($batch, function ($items) use ($that) { + $that->dispatch(ClearBucket::AFTER_DELETE, array('keys' => $items)); + }); + $batch = new FlushingBatch(new ExceptionBufferingBatch($batch), 1000); + + // Let any listeners know that the bucket is about to be cleared + $this->dispatch(self::BEFORE_CLEAR, array( + 'iterator' => $this->getIterator(), + 'batch' => $batch, + 'mfa' => $this->mfa + )); + + $deleted = 0; + foreach ($this->getIterator() as $object) { + if (isset($object['VersionId'])) { + $versionId = $object['VersionId'] == 'null' ? null : $object['VersionId']; + } else { + $versionId = null; + } + $batch->addKey($object['Key'], $versionId); + $deleted++; + } + $batch->flush(); + + // If any errors were encountered, then throw an ExceptionCollection + if (count($batch->getExceptions())) { + $e = new ExceptionCollection(); + foreach ($batch->getExceptions() as $exception) { + $e->add($exception->getPrevious()); + } + throw $e; + } + + // Let any listeners know that the bucket was cleared + $this->dispatch(self::AFTER_CLEAR, array('deleted' => $deleted)); + + return $deleted; + } +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/S3/Model/DeleteObjectsBatch.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Model/DeleteObjectsBatch.php new file mode 100644 index 0000000..17d8af3 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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 self + */ + public static function factory(AwsClientInterface $client, $bucket, $mfa = null) + { + $batch = BatchBuilder::factory() + ->createBatchesWith(new BatchSizeDivisor(1000)) + ->transferWith(new DeleteObjectsTransfer($client, $bucket, $mfa)) + ->build(); + + return new self($batch); + } + + /** + * Add an object to be deleted + * + * @param string $key Key of the object + * @param string $versionId VersionID of the object + * + * @return self + */ + public function addKey($key, $versionId = null) + { + return $this->add(array( + 'Key' => $key, + 'VersionId' => $versionId + )); + } + + /** + * {@inheritdoc} + */ + public function add($item) + { + if ($item instanceof AbstractCommand && $item->getName() == 'DeleteObject') { + $item = array( + 'Key' => $item['Key'], + 'VersionId' => $item['VersionId'] + ); + } + + if (!is_array($item) || (!isset($item['Key']))) { + throw new InvalidArgumentException('Item must be a DeleteObject command or array containing a Key and VersionId key.'); + } + + return $this->decoratedBatch->add($item); + } +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/S3/Model/DeleteObjectsTransfer.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Model/DeleteObjectsTransfer.php new file mode 100644 index 0000000..c3d3828 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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 self + */ + public function setMfa($token) + { + $this->mfa = $token; + + return $this; + } + + /** + * {@inheritdoc} + * @throws OverflowException if a batch has more than 1000 items + * @throws InvalidArgumentException when an invalid batch item is encountered + */ + public function transfer(array $batch) + { + if (empty($batch)) { + return; + } + + if (count($batch) > 1000) { + throw new OverflowException('Batches should be divided into chunks of no larger than 1000 keys'); + } + + $del = array(); + $command = $this->client->getCommand('DeleteObjects', array( + 'Bucket' => $this->bucket, + Ua::OPTION => Ua::BATCH + )); + + if ($this->mfa) { + $command->getRequestHeaders()->set('x-amz-mfa', $this->mfa); + } + + foreach ($batch as $object) { + // Ensure that the batch item is valid + if (!is_array($object) || !isset($object['Key'])) { + throw new InvalidArgumentException('Invalid batch item encountered: ' . var_export($batch, true)); + } + $del[] = array( + 'Key' => $object['Key'], + 'VersionId' => isset($object['VersionId']) ? $object['VersionId'] : null + ); + } + + $command['Objects'] = $del; + + $command->execute(); + $this->processResponse($command); + } + + /** + * Process the response of the DeleteMultipleObjects request + * + * @paramCommandInterface $command Command executed + */ + protected function processResponse(CommandInterface $command) + { + $result = $command->getResult(); + + // Ensure that the objects were deleted successfully + if (!empty($result['Errors'])) { + $errors = $result['Errors']; + throw new DeleteMultipleObjectsException($errors); + } + } +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/S3/Model/Grant.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Model/Grant.php new file mode 100644 index 0000000..afc2757 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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 self + */ + public function setGrantee(Grantee $grantee) + { + $this->grantee = $grantee; + + return $this; + } + + /** + * Get the grantee affected by the grant + * + * @return Grantee + */ + public function getGrantee() + { + return $this->grantee; + } + + /** + * Set the permission set by the grant + * + * @param string $permission Permission applied + * + * @return self + * + * @throws InvalidArgumentException + */ + public function setPermission($permission) + { + $valid = Permission::values(); + if (!in_array($permission, $valid)) { + throw new InvalidArgumentException('The permission must be one of ' + . 'the following: ' . implode(', ', $valid) . '.'); + } + + $this->permission = $permission; + + return $this; + } + + /** + * Get the permission set by the grant + * + * @return string + */ + public function getPermission() + { + return $this->permission; + } + + /** + * Returns an array of the operation parameter and value to set on the operation + * + * @return array + */ + public function getParameterArray() + { + return array( + self::$parameterMap[$this->permission] => $this->grantee->getHeaderValue() + ); + } + + /** + * {@inheritdoc} + */ + public function toArray() + { + return array( + 'Grantee' => $this->grantee->toArray(), + 'Permission' => $this->permission + ); + } +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/S3/Model/Grantee.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Model/Grantee.php new file mode 100644 index 0000000..f49c70f --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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 = self::$headerMap[$this->type]; + + return "{$key}=\"{$this->id}\""; + } + + /** + * {@inheritdoc} + */ + public function toArray() + { + $result = array( + 'Type' => $this->type + ); + + switch ($this->type) { + case GranteeType::USER: + $result['ID'] = $this->id; + $result['DisplayName'] = $this->displayName; + break; + case GranteeType::EMAIL: + $result['EmailAddress'] = $this->id; + break; + case GranteeType::GROUP: + $result['URI'] = $this->id; + } + + return $result; + } +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/S3/Model/MultipartUpload/AbstractTransfer.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Model/MultipartUpload/AbstractTransfer.php new file mode 100644 index 0000000..c48232d --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/S3/Model/MultipartUpload/ParallelTransfer.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Model/MultipartUpload/ParallelTransfer.php new file mode 100644 index 0000000..caa9e88 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/S3/Model/MultipartUpload/SerialTransfer.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Model/MultipartUpload/SerialTransfer.php new file mode 100644 index 0000000..4a5953f --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/S3/Model/MultipartUpload/TransferState.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Model/MultipartUpload/TransferState.php new file mode 100644 index 0000000..c63663f --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/S3/Model/MultipartUpload/UploadBuilder.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Model/MultipartUpload/UploadBuilder.php new file mode 100644 index 0000000..cae7658 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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 self + */ + public function setKey($key) + { + return $this->setOption('Key', $key); + } + + /** + * Set the minimum acceptable part size + * + * @param int $minSize Minimum acceptable part size in bytes + * + * @return self + */ + public function setMinPartSize($minSize) + { + $this->minPartSize = (int) max((int) $minSize, AbstractTransfer::MIN_PART_SIZE); + + return $this; + } + + /** + * Set the concurrency level to use when uploading parts. This affects how + * many parts are uploaded in parallel. You must use a local file as your + * data source when using a concurrency greater than 1 + * + * @param int $concurrency Concurrency level + * + * @return self + */ + public function setConcurrency($concurrency) + { + $this->concurrency = $concurrency; + + return $this; + } + + /** + * Explicitly set the MD5 hash of the entire body + * + * @param string $md5 MD5 hash of the entire body + * + * @return self + */ + public function setMd5($md5) + { + $this->md5 = $md5; + + return $this; + } + + /** + * Set to true to have the builder calculate the MD5 hash of the entire data + * source before initiating a multipart upload (this could be an expensive + * operation). This setting can ony be used with seekable data sources. + * + * @param bool $calculateMd5 Set to true to calculate the MD5 hash of the body + * + * @return self + */ + public function calculateMd5($calculateMd5) + { + $this->calculateEntireMd5 = (bool) $calculateMd5; + + return $this; + } + + /** + * Specify whether or not to calculate the MD5 hash of each uploaded part. + * This setting defaults to true. + * + * @param bool $usePartMd5 Set to true to calculate the MD5 has of each part + * + * @return self + */ + public function calculatePartMd5($usePartMd5) + { + $this->calculatePartMd5 = (bool) $usePartMd5; + + return $this; + } + + /** + * Set the ACP to use on the object + * + * @param Acp $acp ACP to set on the object + * + * @return self + */ + public function setAcp(Acp $acp) + { + return $this->setOption('ACP', $acp); + } + + /** + * Set an option to pass to the initial CreateMultipartUpload operation + * + * @param string $name Option name + * @param string $value Option value + * + * @return self + */ + public function setOption($name, $value) + { + $this->commandOptions[$name] = $value; + + return $this; + } + + /** + * Add an array of options to pass to the initial CreateMultipartUpload operation + * + * @param array $options Array of CreateMultipartUpload operation parameters + * + * @return self + */ + public function addOptions(array $options) + { + $this->commandOptions = array_replace($this->commandOptions, $options); + + return $this; + } + + /** + * Set an array of transfer options to apply to the upload transfer object + * + * @param array $options Transfer options + * + * @return self + */ + public function setTransferOptions(array $options) + { + $this->transferOptions = $options; + + return $this; + } + + /** + * {@inheritdoc} + * @throws InvalidArgumentException when attempting to resume a transfer using a non-seekable stream + * @throws InvalidArgumentException when missing required properties (bucket, key, client, source) + */ + public function build() + { + if ($this->state instanceof TransferState) { + $this->commandOptions = array_replace($this->commandOptions, $this->state->getUploadId()->toParams()); + } + + if (!isset($this->commandOptions['Bucket']) || !isset($this->commandOptions['Key']) + || !$this->client || !$this->source + ) { + throw new InvalidArgumentException('You must specify a Bucket, Key, client, and source.'); + } + + if ($this->state && !$this->source->isSeekable()) { + throw new InvalidArgumentException('You cannot resume a transfer using a non-seekable source.'); + } + + // If no state was set, then create one by initiating or loading a multipart upload + if (is_string($this->state)) { + $this->state = TransferState::fromUploadId($this->client, UploadId::fromParams(array( + 'Bucket' => $this->commandOptions['Bucket'], + 'Key' => $this->commandOptions['Key'], + 'UploadId' => $this->state + ))); + } elseif (!$this->state) { + $this->state = $this->initiateMultipartUpload(); + } + + $options = array_replace(array( + 'min_part_size' => $this->minPartSize, + 'part_md5' => (bool) $this->calculatePartMd5, + 'concurrency' => $this->concurrency + ), $this->transferOptions); + + return $this->concurrency > 1 + ? new ParallelTransfer($this->client, $this->state, $this->source, $options) + : new SerialTransfer($this->client, $this->state, $this->source, $options); + } + + /** + * {@inheritdoc} + */ + protected function initiateMultipartUpload() + { + // Determine Content-Type + if (!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-sdk-php/src/Aws/S3/Model/MultipartUpload/UploadId.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Model/MultipartUpload/UploadId.php new file mode 100644 index 0000000..9d5f384 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/S3/Model/MultipartUpload/UploadId.php @@ -0,0 +1,35 @@ + false, + 'Key' => false, + 'UploadId' => false + ); +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/S3/Model/MultipartUpload/UploadPart.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Model/MultipartUpload/UploadPart.php new file mode 100644 index 0000000..e0ded33 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/S3/Model/PostObject.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Model/PostObject.php new file mode 100644 index 0000000..f23f2bc --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/S3/Model/PostObject.php @@ -0,0 +1,259 @@ + tag attributes as an array + */ + protected $formAttributes; + + /** + * @var array The form's elements as an array + */ + protected $formInputs; + + /** + * @var string The raw json policy + */ + protected $jsonPolicy; + + /** + * Constructs the PostObject + * + * The options array accepts the following keys: + * + * - acl: The access control setting to apply to the uploaded file. Accepts any of the + * CannedAcl constants + * - Cache-Control: The Cache-Control HTTP header value to apply to the uploaded file + * - Content-Disposition: The Content-Disposition HTTP header value to apply to the uploaded file + * - Content-Encoding: The Content-Encoding HTTP header value to apply to the uploaded file + * - Content-Type: The Content-Type HTTP header value to apply to the uploaded file. The default + * value is `application/octet-stream` + * - Expires: The Expires HTTP header value to apply to the uploaded file + * - key: The location where the file should be uploaded to. The default value is + * `^${filename}` which will use the name of the uploaded file + * - policy: A raw policy in JSON format. By default, the PostObject creates one for you + * - success_action_redirect: The URI for Amazon S3 to redirect to upon successful upload + * - success_action_status: The status code for Amazon S3 to return upon successful upload + * - ttd: The expiration time for the generated upload form data + * - x-amz-server-side-encryption: The server-side encryption mechanism to use + * - x-amz-storage-class: The storage setting to apply to the object + * - x-amz-meta-*: Any custom meta tag that should be set to the object + * + * For the Cache-Control, Content-Disposition, Content-Encoding, + * Content-Type, Expires, and key options, to use a "starts-with" comparison + * instead of an equals comparison, prefix the value with a ^ (carat) + * character + * + * @param S3Client $client + * @param $bucket + * @param array $options + */ + public function __construct(S3Client $client, $bucket, array $options = array()) + { + $this->setClient($client); + $this->setBucket($bucket); + parent::__construct($options); + } + + /** + * Analyzes the provided data and turns it into useful data that can be + * consumed and used to build an upload form + * + * @return PostObject + */ + public function prepareData() + { + // Validate required options + $options = Collection::fromConfig($this->data, array( + 'ttd' => '+1 hour', + 'key' => '^${filename}', + )); + + // Format ttd option + $ttd = $options['ttd']; + $ttd = is_numeric($ttd) ? (int) $ttd : strtotime($ttd); + unset($options['ttd']); + + // Save policy if passed in + $rawPolicy = $options['policy']; + unset($options['policy']); + + // Setup policy document + $policy = array( + 'expiration' => gmdate(DateFormat::ISO8601_S3, $ttd), + 'conditions' => array(array('bucket' => $this->bucket)) + ); + + // Configure the endpoint/action + $url = Url::factory($this->client->getBaseUrl()); + 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 + ); + $options->remove('success_action_status'); + } + + // Add other options + foreach ($options as $key => $value) { + $value = (string) $value; + if ($value[0] === '^') { + $value = substr($value, 1); + $this->formInputs[$key] = $value; + $value = preg_replace('/\$\{(\w*)\}/', '', $value); + $policy['conditions'][] = array('starts-with', '$' . $key, $value); + } else { + $this->formInputs[$key] = $value; + $policy['conditions'][] = array($key => $value); + } + } + + // Add policy + $this->jsonPolicy = $rawPolicy ?: json_encode($policy); + $jsonPolicy64 = base64_encode($this->jsonPolicy); + $this->formInputs['policy'] = $jsonPolicy64; + + // Add signature + $this->formInputs['signature'] = base64_encode(hash_hmac( + 'sha1', + $jsonPolicy64, + $this->client->getCredentials()->getSecretKey(), + true + )); + + return $this; + } + + /** + * Sets the S3 client + * + * @param S3Client $client + * + * @return PostObject + */ + public function setClient(S3Client $client) + { + $this->client = $client; + + return $this; + } + + /** + * Gets the S3 client + * + * @return S3Client + */ + public function getClient() + { + return $this->client; + } + + /** + * Sets the bucket and makes sure it is a valid bucket name + * + * @param string $bucket + * + * @return PostObject + */ + public function setBucket($bucket) + { + $this->bucket = $bucket; + + return $this; + } + + /** + * Gets the bucket name + * + * @return string + */ + public function getBucket() + { + return $this->bucket; + } + + /** + * Gets the form attributes as an array + * + * @return array + */ + public function getFormAttributes() + { + return $this->formAttributes; + } + + /** + * Gets the form inputs as an array + * + * @return array + */ + public function getFormInputs() + { + return $this->formInputs; + } + + /** + * Gets the raw JSON policy + * + * @return string + */ + public function getJsonPolicy() + { + return $this->jsonPolicy; + } +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/S3/Resources/s3-2006-03-01.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Resources/s3-2006-03-01.php new file mode 100644 index 0000000..67dd76f --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/S3/Resources/s3-2006-03-01.php @@ -0,0 +1,4277 @@ + '2006-03-01', + 'endpointPrefix' => 's3', + 'serviceFullName' => 'Amazon Simple Storage Service', + 'serviceAbbreviation' => 'Amazon S3', + 'serviceType' => 'rest-xml', + 'timestampFormat' => 'rfc822', + 'globalEndpoint' => 's3.amazonaws.com', + 'signatureVersion' => 's3', + 'namespace' => 'S3', + 'regions' => array( + 'us-east-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 's3.amazonaws.com', + ), + 'us-west-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 's3-us-west-1.amazonaws.com', + ), + 'us-west-2' => array( + 'http' => true, + 'https' => true, + 'hostname' => 's3-us-west-2.amazonaws.com', + ), + 'eu-west-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 's3-eu-west-1.amazonaws.com', + ), + 'ap-northeast-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 's3-ap-northeast-1.amazonaws.com', + ), + 'ap-southeast-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 's3-ap-southeast-1.amazonaws.com', + ), + 'ap-southeast-2' => array( + 'http' => true, + 'https' => true, + 'hostname' => 's3-ap-southeast-2.amazonaws.com', + ), + 'sa-east-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 's3-sa-east-1.amazonaws.com', + ), + 'cn-north-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 's3.cn-north-1.amazonaws.com.cn', + ), + 'us-gov-west-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 's3-us-gov-west-1.amazonaws.com', + ), + ), + 'operations' => array( + 'AbortMultipartUpload' => array( + 'httpMethod' => 'DELETE', + 'uri' => '/{Bucket}{/Key*}', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'AbortMultipartUploadOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/mpUploadAbort.html', + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'Key' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'filters' => array( + 'Aws\\S3\\S3Client::explodeKey', + ), + ), + 'UploadId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'uploadId', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified multipart upload does not exist.', + 'class' => 'NoSuchUploadException', + ), + ), + ), + 'CompleteMultipartUpload' => array( + 'httpMethod' => 'POST', + 'uri' => '/{Bucket}{/Key*}', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'CompleteMultipartUploadOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/mpUploadComplete.html', + 'data' => array( + 'xmlRoot' => array( + 'name' => 'CompleteMultipartUpload', + 'namespaces' => array( + 'http://s3.amazonaws.com/doc/2006-03-01/', + ), + ), + ), + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'Key' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'filters' => array( + 'Aws\\S3\\S3Client::explodeKey', + ), + ), + 'Parts' => array( + 'type' => 'array', + 'location' => 'xml', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + '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', + ), + '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', + ), + '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', + ), + 'ACP' => array( + 'type' => 'object', + 'additionalProperties' => true, + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/xml', + ), + ), + ), + 'DeleteBucket' => array( + 'httpMethod' => 'DELETE', + 'uri' => '/{Bucket}', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'DeleteBucketOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketDELETE.html', + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + ), + ), + 'DeleteBucketCors' => array( + 'httpMethod' => 'DELETE', + 'uri' => '/{Bucket}?cors', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'DeleteBucketCorsOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketDELETEcors.html', + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + ), + ), + 'DeleteBucketLifecycle' => array( + 'httpMethod' => 'DELETE', + 'uri' => '/{Bucket}?lifecycle', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'DeleteBucketLifecycleOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketDELETElifecycle.html', + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + ), + ), + 'DeleteBucketPolicy' => array( + 'httpMethod' => 'DELETE', + 'uri' => '/{Bucket}?policy', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'DeleteBucketPolicyOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketDELETEpolicy.html', + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + ), + ), + 'DeleteBucketTagging' => array( + 'httpMethod' => 'DELETE', + 'uri' => '/{Bucket}?tagging', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'DeleteBucketTaggingOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketDELETEtagging.html', + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + ), + ), + 'DeleteBucketWebsite' => array( + 'httpMethod' => 'DELETE', + 'uri' => '/{Bucket}?website', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'DeleteBucketWebsiteOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketDELETEwebsite.html', + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + ), + ), + 'DeleteObject' => array( + 'httpMethod' => 'DELETE', + 'uri' => '/{Bucket}{/Key*}', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'DeleteObjectOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTObjectDELETE.html', + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'Key' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'filters' => array( + 'Aws\\S3\\S3Client::explodeKey', + ), + ), + 'MFA' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-mfa', + ), + 'VersionId' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'versionId', + ), + ), + ), + 'DeleteObjects' => array( + 'httpMethod' => 'POST', + 'uri' => '/{Bucket}?delete', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'DeleteObjectsOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/multiobjectdeleteapi.html', + 'data' => array( + 'xmlRoot' => array( + 'name' => 'Delete', + 'namespaces' => array( + 'http://s3.amazonaws.com/doc/2006-03-01/', + ), + ), + 'contentMd5' => true, + ), + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'Objects' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'xml', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + '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', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/xml', + ), + ), + ), + 'GetBucketAcl' => array( + 'httpMethod' => 'GET', + 'uri' => '/{Bucket}?acl', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'GetBucketAclOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETacl.html', + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/xml', + ), + ), + ), + 'GetBucketCors' => array( + 'httpMethod' => 'GET', + 'uri' => '/{Bucket}?cors', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'GetBucketCorsOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETcors.html', + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/xml', + ), + ), + ), + 'GetBucketLifecycle' => array( + 'httpMethod' => 'GET', + 'uri' => '/{Bucket}?lifecycle', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'GetBucketLifecycleOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETlifecycle.html', + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/xml', + ), + ), + ), + 'GetBucketLocation' => array( + 'httpMethod' => 'GET', + 'uri' => '/{Bucket}?location', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'GetBucketLocationOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETlocation.html', + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + ), + ), + 'GetBucketLogging' => array( + 'httpMethod' => 'GET', + 'uri' => '/{Bucket}?logging', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'GetBucketLoggingOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETlogging.html', + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/xml', + ), + ), + ), + 'GetBucketNotification' => array( + 'httpMethod' => 'GET', + 'uri' => '/{Bucket}?notification', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'GetBucketNotificationOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETnotification.html', + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/xml', + ), + ), + ), + 'GetBucketPolicy' => array( + 'httpMethod' => 'GET', + 'uri' => '/{Bucket}?policy', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'GetBucketPolicyOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETpolicy.html', + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + ), + ), + 'GetBucketRequestPayment' => array( + 'httpMethod' => 'GET', + 'uri' => '/{Bucket}?requestPayment', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'GetBucketRequestPaymentOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTrequestPaymentGET.html', + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/xml', + ), + ), + ), + 'GetBucketTagging' => array( + 'httpMethod' => 'GET', + 'uri' => '/{Bucket}?tagging', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'GetBucketTaggingOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETtagging.html', + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/xml', + ), + ), + ), + 'GetBucketVersioning' => array( + 'httpMethod' => 'GET', + 'uri' => '/{Bucket}?versioning', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'GetBucketVersioningOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETversioningStatus.html', + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/xml', + ), + ), + ), + 'GetBucketWebsite' => array( + 'httpMethod' => 'GET', + 'uri' => '/{Bucket}?website', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'GetBucketWebsiteOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETwebsite.html', + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/xml', + ), + ), + ), + 'GetObject' => array( + 'httpMethod' => 'GET', + 'uri' => '/{Bucket}{/Key*}', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'GetObjectOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTObjectGET.html', + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'IfMatch' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'If-Match', + ), + 'IfModifiedSince' => array( + 'type' => array( + 'object', + 'string', + 'integer', + ), + 'format' => 'date-time-http', + 'location' => 'header', + 'sentAs' => 'If-Modified-Since', + ), + 'IfNoneMatch' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'If-None-Match', + ), + 'IfUnmodifiedSince' => array( + 'type' => array( + 'object', + 'string', + 'integer', + ), + 'format' => 'date-time-http', + 'location' => 'header', + 'sentAs' => 'If-Unmodified-Since', + ), + 'Key' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'filters' => array( + 'Aws\\S3\\S3Client::explodeKey', + ), + ), + 'Range' => array( + 'type' => 'string', + 'location' => 'header', + ), + 'ResponseCacheControl' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'response-cache-control', + ), + 'ResponseContentDisposition' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'response-content-disposition', + ), + 'ResponseContentEncoding' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'response-content-encoding', + ), + 'ResponseContentLanguage' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'response-content-language', + ), + 'ResponseContentType' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'response-content-type', + ), + 'ResponseExpires' => array( + 'type' => array( + 'object', + 'string', + 'integer', + ), + 'format' => 'date-time-http', + 'location' => 'query', + 'sentAs' => 'response-expires', + ), + 'VersionId' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'versionId', + ), + 'SaveAs' => array( + 'location' => 'response_body', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified key does not exist.', + 'class' => 'NoSuchKeyException', + ), + ), + ), + 'GetObjectAcl' => array( + 'httpMethod' => 'GET', + 'uri' => '/{Bucket}{/Key*}?acl', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'GetObjectAclOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTObjectGETacl.html', + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'Key' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'filters' => array( + 'Aws\\S3\\S3Client::explodeKey', + ), + ), + 'VersionId' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'versionId', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/xml', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified key does not exist.', + 'class' => 'NoSuchKeyException', + ), + ), + ), + 'GetObjectTorrent' => array( + 'httpMethod' => 'GET', + 'uri' => '/{Bucket}{/Key*}?torrent', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'GetObjectTorrentOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTObjectGETtorrent.html', + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'Key' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'filters' => array( + 'Aws\\S3\\S3Client::explodeKey', + ), + ), + ), + ), + 'HeadBucket' => array( + 'httpMethod' => 'HEAD', + 'uri' => '/{Bucket}', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'HeadBucketOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketHEAD.html', + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified bucket does not exist.', + 'class' => 'NoSuchBucketException', + ), + ), + ), + 'HeadObject' => array( + 'httpMethod' => 'HEAD', + 'uri' => '/{Bucket}{/Key*}', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'HeadObjectOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTObjectHEAD.html', + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'IfMatch' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'If-Match', + ), + 'IfModifiedSince' => array( + 'type' => array( + 'object', + 'string', + 'integer', + ), + 'format' => 'date-time-http', + 'location' => 'header', + 'sentAs' => 'If-Modified-Since', + ), + 'IfNoneMatch' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'If-None-Match', + ), + 'IfUnmodifiedSince' => array( + 'type' => array( + 'object', + 'string', + 'integer', + ), + 'format' => 'date-time-http', + 'location' => 'header', + 'sentAs' => 'If-Unmodified-Since', + ), + 'Key' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'filters' => array( + 'Aws\\S3\\S3Client::explodeKey', + ), + ), + 'Range' => array( + 'type' => 'string', + 'location' => 'header', + ), + 'VersionId' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'versionId', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified key does not exist.', + 'class' => 'NoSuchKeyException', + ), + ), + ), + 'ListBuckets' => array( + 'httpMethod' => 'GET', + 'uri' => '/', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'ListBucketsOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTServiceGET.html', + 'parameters' => array( + 'command.expects' => array( + 'static' => true, + 'default' => 'application/xml', + ), + ), + ), + 'ListMultipartUploads' => array( + 'httpMethod' => 'GET', + 'uri' => '/{Bucket}?uploads', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'ListMultipartUploadsOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/mpUploadListMPUpload.html', + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'Delimiter' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'delimiter', + ), + 'EncodingType' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'encoding-type', + ), + 'KeyMarker' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'key-marker', + ), + 'MaxUploads' => array( + 'type' => 'numeric', + 'location' => 'query', + 'sentAs' => 'max-uploads', + ), + 'Prefix' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'prefix', + ), + 'UploadIdMarker' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'upload-id-marker', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/xml', + ), + ), + ), + 'ListObjectVersions' => array( + 'httpMethod' => 'GET', + 'uri' => '/{Bucket}?versions', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'ListObjectVersionsOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGETVersion.html', + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'Delimiter' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'delimiter', + ), + 'EncodingType' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'encoding-type', + ), + 'KeyMarker' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'key-marker', + ), + 'MaxKeys' => array( + 'type' => 'numeric', + 'location' => 'query', + 'sentAs' => 'max-keys', + ), + 'Prefix' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'prefix', + ), + 'VersionIdMarker' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'version-id-marker', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/xml', + ), + ), + ), + 'ListObjects' => array( + 'httpMethod' => 'GET', + 'uri' => '/{Bucket}', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'ListObjectsOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketGET.html', + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'Delimiter' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'delimiter', + ), + 'EncodingType' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'encoding-type', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'marker', + ), + 'MaxKeys' => array( + 'type' => 'numeric', + 'location' => 'query', + 'sentAs' => 'max-keys', + ), + 'Prefix' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'prefix', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/xml', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified bucket does not exist.', + 'class' => 'NoSuchBucketException', + ), + ), + ), + 'ListParts' => array( + 'httpMethod' => 'GET', + 'uri' => '/{Bucket}{/Key*}', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'ListPartsOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/mpUploadListParts.html', + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'Key' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'filters' => array( + 'Aws\\S3\\S3Client::explodeKey', + ), + ), + 'MaxParts' => array( + 'type' => 'numeric', + 'location' => 'query', + 'sentAs' => 'max-parts', + ), + 'PartNumberMarker' => array( + 'type' => 'numeric', + 'location' => 'query', + 'sentAs' => 'part-number-marker', + ), + 'UploadId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'uploadId', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/xml', + ), + ), + ), + 'PutBucketAcl' => array( + 'httpMethod' => 'PUT', + 'uri' => '/{Bucket}?acl', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'PutBucketAclOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketPUTacl.html', + 'data' => array( + 'xmlRoot' => array( + 'name' => 'AccessControlPolicy', + 'namespaces' => array( + 'http://s3.amazonaws.com/doc/2006-03-01/', + ), + ), + ), + 'parameters' => array( + 'ACL' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-acl', + ), + 'Grants' => array( + 'type' => 'array', + 'location' => 'xml', + 'sentAs' => 'AccessControlList', + 'items' => array( + 'name' => 'Grant', + 'type' => 'object', + 'properties' => array( + 'Grantee' => array( + 'type' => 'object', + 'properties' => array( + 'DisplayName' => array( + 'type' => 'string', + ), + 'EmailAddress' => array( + 'type' => 'string', + ), + 'ID' => array( + 'type' => 'string', + ), + 'Type' => array( + 'required' => true, + 'type' => 'string', + 'sentAs' => 'xsi:type', + 'data' => array( + 'xmlAttribute' => true, + 'xmlNamespace' => 'http://www.w3.org/2001/XMLSchema-instance', + ), + ), + 'URI' => array( + 'type' => 'string', + ), + ), + ), + 'Permission' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Owner' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'DisplayName' => array( + 'type' => 'string', + ), + 'ID' => array( + 'type' => 'string', + ), + ), + ), + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'GrantFullControl' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-grant-full-control', + ), + 'GrantRead' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-grant-read', + ), + 'GrantReadACP' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-grant-read-acp', + ), + 'GrantWrite' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-grant-write', + ), + 'GrantWriteACP' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-grant-write-acp', + ), + 'ACP' => array( + 'type' => 'object', + 'additionalProperties' => true, + ), + ), + ), + 'PutBucketCors' => array( + 'httpMethod' => 'PUT', + 'uri' => '/{Bucket}?cors', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'PutBucketCorsOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketPUTcors.html', + 'data' => array( + 'xmlRoot' => array( + 'name' => 'CORSConfiguration', + 'namespaces' => array( + 'http://s3.amazonaws.com/doc/2006-03-01/', + ), + ), + 'contentMd5' => true, + ), + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'CORSRules' => array( + 'type' => 'array', + 'location' => 'xml', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + '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/', + ), + ), + ), + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'TopicConfiguration' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Event' => array( + 'type' => 'string', + ), + 'Topic' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'PutBucketPolicy' => array( + 'httpMethod' => 'PUT', + 'uri' => '/{Bucket}?policy', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'PutBucketPolicyOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTBucketPUTpolicy.html', + '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', + ), + ), + ), + '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', + ), + 'ACP' => array( + 'type' => 'object', + 'additionalProperties' => true, + ), + ), + ), + 'PutObjectAcl' => array( + 'httpMethod' => 'PUT', + 'uri' => '/{Bucket}{/Key*}?acl', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'PutObjectAclOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTObjectPUTacl.html', + 'data' => array( + 'xmlRoot' => array( + 'name' => 'AccessControlPolicy', + 'namespaces' => array( + 'http://s3.amazonaws.com/doc/2006-03-01/', + ), + ), + ), + 'parameters' => array( + 'ACL' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-acl', + ), + 'Grants' => array( + 'type' => 'array', + 'location' => 'xml', + 'sentAs' => 'AccessControlList', + 'items' => array( + 'name' => 'Grant', + 'type' => 'object', + 'properties' => array( + 'Grantee' => array( + 'type' => 'object', + 'properties' => array( + 'DisplayName' => array( + 'type' => 'string', + ), + 'EmailAddress' => array( + 'type' => 'string', + ), + 'ID' => array( + 'type' => 'string', + ), + 'Type' => array( + 'required' => true, + 'type' => 'string', + 'sentAs' => 'xsi:type', + 'data' => array( + 'xmlAttribute' => true, + 'xmlNamespace' => 'http://www.w3.org/2001/XMLSchema-instance', + ), + ), + 'URI' => array( + 'type' => 'string', + ), + ), + ), + 'Permission' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Owner' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'DisplayName' => array( + 'type' => 'string', + ), + 'ID' => array( + 'type' => 'string', + ), + ), + ), + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'GrantFullControl' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-grant-full-control', + ), + 'GrantRead' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-grant-read', + ), + 'GrantReadACP' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-grant-read-acp', + ), + 'GrantWrite' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-grant-write', + ), + 'GrantWriteACP' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-grant-write-acp', + ), + 'Key' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'filters' => array( + 'Aws\\S3\\S3Client::explodeKey', + ), + ), + 'ACP' => array( + 'type' => 'object', + 'additionalProperties' => true, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The specified key does not exist.', + 'class' => 'NoSuchKeyException', + ), + ), + ), + 'RestoreObject' => array( + 'httpMethod' => 'POST', + 'uri' => '/{Bucket}{/Key*}?restore', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'RestoreObjectOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/RESTObjectRestore.html', + 'data' => array( + 'xmlRoot' => array( + 'name' => 'RestoreRequest', + 'namespaces' => array( + 'http://s3.amazonaws.com/doc/2006-03-01/', + ), + ), + ), + 'parameters' => array( + 'Bucket' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + ), + 'Key' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'uri', + 'filters' => array( + 'Aws\\S3\\S3Client::explodeKey', + ), + ), + 'VersionId' => array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'versionId', + ), + 'Days' => array( + 'required' => true, + 'type' => 'numeric', + 'location' => 'xml', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'This operation is not allowed against this storage tier', + 'class' => 'ObjectAlreadyInActiveTierErrorException', + ), + ), + ), + 'UploadPart' => array( + 'httpMethod' => 'PUT', + 'uri' => '/{Bucket}{/Key*}', + 'class' => 'Aws\\S3\\Command\\S3Command', + 'responseClass' => 'UploadPartOutput', + 'responseType' => 'model', + 'documentationUrl' => 'http://docs.aws.amazon.com/AmazonS3/latest/API/mpUploadUploadPart.html', + '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', + ), + ), + ), + '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', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/xml', + ), + ), + ), + ), + 'models' => array( + 'AbortMultipartUploadOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'CompleteMultipartUploadOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + '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', + ), + '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', + ), + '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', + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'DeleteBucketOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'DeleteBucketCorsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'DeleteBucketLifecycleOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'DeleteBucketPolicyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'DeleteBucketTaggingOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'DeleteBucketWebsiteOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'DeleteObjectOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'DeleteMarker' => array( + 'type' => 'boolean', + 'location' => 'header', + 'sentAs' => 'x-amz-delete-marker', + ), + 'VersionId' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-version-id', + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'DeleteObjectsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Deleted' => array( + 'type' => 'array', + 'location' => 'xml', + 'data' => array( + 'xmlFlattened' => true, + ), + 'items' => array( + 'name' => 'DeletedObject', + 'type' => 'object', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'VersionId' => array( + 'type' => 'string', + ), + 'DeleteMarker' => array( + 'type' => 'boolean', + ), + 'DeleteMarkerVersionId' => array( + 'type' => 'string', + ), + ), + ), + ), + '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', + ), + ), + ), + 'GetBucketNotificationOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'TopicConfiguration' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Event' => array( + 'type' => 'string', + ), + 'Topic' => array( + 'type' => 'string', + ), + ), + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'GetBucketPolicyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Policy' => array( + 'type' => 'string', + 'instanceOf' => 'Guzzle\\Http\\EntityBody', + 'location' => 'body', + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'GetBucketRequestPaymentOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Payer' => array( + 'type' => 'string', + 'location' => 'xml', + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'GetBucketTaggingOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'TagSet' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'Tag', + 'type' => 'object', + 'sentAs' => 'Tag', + 'properties' => array( + 'Key' => array( + 'type' => 'string', + ), + 'Value' => array( + 'type' => 'string', + ), + ), + ), + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'GetBucketVersioningOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + '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', + ), + ), + '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', + ), + ), + ), + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'GetObjectTorrentOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Body' => array( + 'type' => 'string', + 'instanceOf' => 'Guzzle\\Http\\EntityBody', + 'location' => 'body', + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'HeadBucketOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'HeadObjectOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + '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', + ), + ), + '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', + ), + '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', + ), + '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', + ), + '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', + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'PutBucketAclOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'PutBucketCorsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'PutBucketLifecycleOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'PutBucketLoggingOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'PutBucketNotificationOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'PutBucketPolicyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'PutBucketRequestPaymentOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'PutBucketTaggingOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'PutBucketVersioningOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'PutBucketWebsiteOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'PutObjectOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + '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', + ), + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + 'ObjectURL' => array( + ), + ), + ), + 'PutObjectAclOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'RestoreObjectOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'RequestId' => array( + 'location' => 'header', + 'sentAs' => 'x-amz-request-id', + ), + ), + ), + 'UploadPartOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ServerSideEncryption' => array( + 'type' => 'string', + 'location' => 'header', + 'sentAs' => 'x-amz-server-side-encryption', + ), + 'ETag' => array( + 'type' => 'string', + 'location' => 'header', + ), + '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', + ), + '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-sdk-php/src/Aws/S3/ResumableDownload.php b/vendor/aws/aws-sdk-php/src/Aws/S3/ResumableDownload.php new file mode 100644 index 0000000..386a077 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/S3/S3Client.php b/vendor/aws/aws-sdk-php/src/Aws/S3/S3Client.php new file mode 100644 index 0000000..8f65c40 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/S3/S3Client.php @@ -0,0 +1,673 @@ + '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 self + * @link http://docs.aws.amazon.com/aws-sdk-php/guide/latest/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] = self::createBackoffPlugin($exceptionParser); + } + + $config[Options::SIGNATURE] = $signature = self::createSignature($config); + + $client = ClientBuilder::factory(__NAMESPACE__) + ->setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/s3-%s.php' + )) + ->setExceptionParser($exceptionParser) + ->setIteratorsConfig(array( + 'more_key' => 'IsTruncated', + 'operations' => array( + 'ListBuckets', + 'ListMultipartUploads' => array( + 'limit_param' => 'MaxUploads', + 'token_param' => array('KeyMarker', 'UploadIdMarker'), + 'token_key' => array('NextKeyMarker', 'NextUploadIdMarker'), + ), + 'ListObjects' => array( + 'limit_param' => 'MaxKeys', + 'token_param' => 'Marker', + 'token_key' => 'NextMarker', + ), + 'ListObjectVersions' => array( + 'limit_param' => 'MaxKeys', + 'token_param' => array('KeyMarker', 'VersionIdMarker'), + 'token_key' => array('nextKeyMarker', 'nextVersionIdMarker'), + ), + 'ListParts' => array( + 'limit_param' => 'MaxParts', + 'result_key' => 'Parts', + 'token_param' => 'PartNumberMarker', + 'token_key' => 'NextPartNumberMarker', + ), + ) + )) + ->build(); + + // Use virtual hosted buckets when possible + $client->addSubscriber(new BucketStyleListener()); + // Ensure that ACP headers are applied when needed + $client->addSubscriber(new AcpListener()); + // Validate and add required Content-MD5 hashes (e.g. DeleteObjects) + $client->addSubscriber(new S3Md5Listener($signature)); + + // Allow for specifying bodies with file paths and file handles + $client->addSubscriber(new UploadBodyListener(array('PutObject', 'UploadPart'))); + + // Add aliases for some S3 operations + $default = CompositeFactory::getDefaultChain($client); + $default->add( + new AliasFactory($client, self::$commandAliases), + 'Guzzle\Service\Command\Factory\ServiceDescriptionFactory' + ); + $client->setCommandFactory($default); + + return $client; + } + + /** + * Create an Amazon S3 specific backoff plugin + * + * @param S3ExceptionParser $exceptionParser + * + * @return BackoffPlugin + */ + private static function createBackoffPlugin(S3ExceptionParser $exceptionParser) + { + return new BackoffPlugin( + new TruncatedBackoffStrategy(3, + new HttpBackoffStrategy(null, + new SocketTimeoutChecker( + new CurlBackoffStrategy(null, + new ExpiredCredentialsChecker($exceptionParser, + new ExponentialBackoffStrategy() + ) + ) + ) + ) + ) + ); + } + + /** + * Create an appropriate signature based on the configuration settings + * + * @param $config + * + * @return \Aws\Common\Signature\SignatureInterface + * @throws InvalidArgumentException + */ + private static function createSignature($config) + { + $currentValue = isset($config[Options::SIGNATURE]) ? $config[Options::SIGNATURE] : null; + + // Use the Amazon S3 signature V4 when the value is set to "v4" or when + // the value is not set and the region starts with "cn-". + if ($currentValue == 'v4' || + (!$currentValue && isset($config['region']) && substr($config['region'], 0, 3) == 'cn-') + ) { + // Force SignatureV4 for specific regions or if specified in the config + $currentValue = new S3SignatureV4('s3'); + } elseif (!$currentValue || $currentValue == 's3') { + // Use the Amazon S3 signature by default + $currentValue = new S3Signature(); + } + + // 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 self + */ + public function registerStreamWrapper() + { + StreamWrapper::register($this); + + return $this; + } + + /** + * Upload a file, stream, or string to a bucket. If the upload size exceeds the specified threshold, the upload + * will be performed using parallel multipart uploads. + * + * @param string $bucket Bucket to upload the object + * @param string $key Key of the object + * @param mixed $body Object data to upload. Can be a Guzzle\Http\EntityBodyInterface, stream resource, or + * string of data to upload. + * @param string $acl ACL to apply to the object + * @param array $options Custom options used when executing commands: + * - params: Custom parameters to use with the upload. The parameters must map to a PutObject + * or InitiateMultipartUpload operation parameters. + * - min_part_size: Minimum size to allow for each uploaded part when performing a multipart upload. + * - concurrency: Maximum number of concurrent multipart uploads. + * - before_upload: Callback to invoke before each multipart upload. The callback will receive a + * Guzzle\Common\Event object with context. + * + * @see Aws\S3\Model\MultipartUpload\UploadBuilder for more options and customization + * @return \Guzzle\Service\Resource\Model Returns the modeled result of the performed operation + */ + public function upload($bucket, $key, $body, $acl = 'private', array $options = array()) + { + $body = EntityBody::factory($body); + $options = Collection::fromConfig(array_change_key_case($options), array( + 'min_part_size' => AbstractMulti::MIN_PART_SIZE, + 'params' => array(), + 'concurrency' => $body->getWrapper() == 'plainfile' ? 3 : 1 + )); + + if ($body->getSize() < $options['min_part_size']) { + // Perform a simple PutObject operation + return $this->putObject(array( + 'Bucket' => $bucket, + 'Key' => $key, + 'Body' => $body, + 'ACL' => $acl + ) + $options['params']); + } + + // Perform a multipart upload if the file is large enough + $transfer = UploadBuilder::newInstance() + ->setBucket($bucket) + ->setKey($key) + ->setMinPartSize($options['min_part_size']) + ->setConcurrency($options['concurrency']) + ->setClient($this) + ->setSource($body) + ->setTransferOptions($options->toArray()) + ->addOptions($options['params']) + ->setOption('ACL', $acl) + ->build() + ->upload(); + + if ($options['before_upload']) { + $transfer->getEventDispatcher()->addListener( + AbstractTransfer::BEFORE_PART_UPLOAD, + $options['before_upload'] + ); + } + + return $transfer; + } + + /** + * Recursively uploads all files in a given directory to a given bucket. + * + * @param string $directory Full path to a directory to upload + * @param string $bucket Name of the bucket + * @param string $keyPrefix Virtual directory key prefix to add to each upload + * @param array $options Associative array of upload options + * - params: Array of parameters to use with each PutObject operation performed during the transfer + * - base_dir: Base directory to remove from each object key + * - force: Set to true to upload every file, even if the file is already in Amazon S3 and has not changed + * - concurrency: Maximum number of parallel uploads (defaults to 10) + * - debug: Set to true or an fopen resource to enable debug mode to print information about each upload + * - multipart_upload_size: When the size of a file exceeds this value, the file will be uploaded using a + * multipart upload. + * + * @see Aws\S3\S3Sync\S3Sync for more options and customization + */ + public function uploadDirectory($directory, $bucket, $keyPrefix = null, array $options = array()) + { + $options = Collection::fromConfig( + $options, + array( + 'base_dir' => 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-sdk-php/src/Aws/S3/S3Md5Listener.php b/vendor/aws/aws-sdk-php/src/Aws/S3/S3Md5Listener.php new file mode 100644 index 0000000..7558c47 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/S3/S3Signature.php b/vendor/aws/aws-sdk-php/src/Aws/S3/S3Signature.php new file mode 100644 index 0000000..4dcc2a8 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/S3/S3Signature.php @@ -0,0 +1,268 @@ +signableQueryString); + + // Add the security token header if one is being used by the credentials + if ($token = $credentials->getSecurityToken()) { + $request->setHeader('x-amz-security-token', $token); + } + + // Add a date header if one is not set + if (!$request->hasHeader('date') && !$request->hasHeader('x-amz-date')) { + $request->setHeader('Date', gmdate(\DateTime::RFC2822)); + } + + $stringToSign = $this->createCanonicalizedString($request); + $request->getParams()->set('aws.string_to_sign', $stringToSign); + + $request->setHeader( + 'Authorization', + 'AWS ' . $credentials->getAccessKeyId() . ':' . $this->signString($stringToSign, $credentials) + ); + } + + public function createPresignedUrl( + RequestInterface $request, + CredentialsInterface $credentials, + $expires + ) { + if ($expires instanceof \DateTime) { + $expires = $expires->getTimestamp(); + } elseif (!is_numeric($expires)) { + $expires = strtotime($expires); + } + + // Operate on a clone of the request, so the original is not altered + $request = clone $request; + + // URL encoding already occurs in the URI template expansion. Undo that and encode using the same encoding as + // GET object, PUT object, etc. + $path = S3Client::encodeKey(rawurldecode($request->getPath())); + $request->setPath($path); + + // Make sure to handle temporary credentials + if ($token = $credentials->getSecurityToken()) { + $request->setHeader('x-amz-security-token', $token); + $request->getQuery()->set('x-amz-security-token', $token); + } + + // Set query params required for pre-signed URLs + $request->getQuery() + ->set('AWSAccessKeyId', $credentials->getAccessKeyId()) + ->set('Expires', $expires) + ->set('Signature', $this->signString( + $this->createCanonicalizedString($request, $expires), + $credentials + )); + + // 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-sdk-php/src/Aws/S3/S3SignatureInterface.php b/vendor/aws/aws-sdk-php/src/Aws/S3/S3SignatureInterface.php new file mode 100644 index 0000000..0b7e940 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/S3/S3SignatureInterface.php @@ -0,0 +1,24 @@ +getBody() && + !$request->hasHeader('x-amz-content-sha256') + ) { + $request->setHeader( + 'X-Amz-Content-Sha256', + $this->getPresignedPayload($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) + { + $result = parent::getPresignedPayload($request); + + // If the body is empty, then sign with 'UNSIGNED-PAYLOAD' + if ($result === self::DEFAULT_PAYLOAD) { + $result = 'UNSIGNED-PAYLOAD'; + } + + return $result; + } +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/S3/SocketTimeoutChecker.php b/vendor/aws/aws-sdk-php/src/Aws/S3/SocketTimeoutChecker.php new file mode 100644 index 0000000..ede2b96 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/S3/StreamWrapper.php b/vendor/aws/aws-sdk-php/src/Aws/S3/StreamWrapper.php new file mode 100644 index 0000000..a533c65 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/S3/StreamWrapper.php @@ -0,0 +1,868 @@ +/" 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); + self::$client = $client; + } + + /** + * Close the stream + */ + public function stream_close() + { + $this->body = null; + } + + /** + * @param string $path + * @param string $mode + * @param int $options + * @param string $opened_path + * + * @return bool + */ + public function stream_open($path, $mode, $options, &$opened_path) + { + // We don't care about the binary flag + $this->mode = $mode = rtrim($mode, 'bt'); + $this->params = $params = $this->getParams($path); + $errors = array(); + + if (!$params['Key']) { + $errors[] = 'Cannot open a bucket. You must specify a path in the form of s3://bucket/key'; + } + + if (strpos($mode, '+')) { + $errors[] = 'The Amazon S3 stream wrapper does not allow simultaneous reading and writing.'; + } + + if (!in_array($mode, array('r', 'w', 'a', 'x'))) { + $errors[] = "Mode not supported: {$mode}. Use one 'r', 'w', 'a', or 'x'."; + } + + // When using mode "x" validate if the file exists before attempting to read + if ($mode == 'x' && self::$client->doesObjectExist($params['Bucket'], $params['Key'], $this->getOptions())) { + $errors[] = "{$path} already exists on Amazon S3"; + } + + if (!$errors) { + if ($mode == 'r') { + $this->openReadStream($params, $errors); + } elseif ($mode == 'a') { + $this->openAppendStream($params, $errors); + } else { + $this->openWriteStream($params, $errors); + } + } + + return $errors ? $this->triggerError($errors) : true; + } + + /** + * @return bool + */ + public function stream_eof() + { + return $this->body->feof(); + } + + /** + * @return bool + */ + public function stream_flush() + { + if ($this->mode == 'r') { + return false; + } + + $this->body->rewind(); + $params = $this->params; + $params['Body'] = $this->body; + + // Attempt to guess the ContentType of the upload based on the + // file extension of the key + if (!isset($params['ContentType']) && + ($type = Mimetypes::getInstance()->fromFilename($params['Key'])) + ) { + $params['ContentType'] = $type; + } + + try { + self::$client->putObject($params); + return true; + } catch (\Exception $e) { + return $this->triggerError($e->getMessage()); + } + } + + /** + * Read data from the underlying stream + * + * @param int $count Amount of bytes to read + * + * @return string + */ + public function stream_read($count) + { + return $this->body->read($count); + } + + /** + * Seek to a specific byte in the stream + * + * @param int $offset Seek offset + * @param int $whence Whence (SEEK_SET, SEEK_CUR, SEEK_END) + * + * @return bool + */ + public function stream_seek($offset, $whence = SEEK_SET) + { + return $this->body->seek($offset, $whence); + } + + /** + * Get the current position of the stream + * + * @return int Returns the current position in the stream + */ + public function stream_tell() + { + return $this->body->ftell(); + } + + /** + * Write data the to the stream + * + * @param string $data + * + * @return int Returns the number of bytes written to the stream + */ + public function stream_write($data) + { + return $this->body->write($data); + } + + /** + * Delete a specific object + * + * @param string $path + * @return bool + */ + public function unlink($path) + { + try { + $this->clearStatInfo($path); + self::$client->deleteObject($this->getParams($path)); + return true; + } catch (\Exception $e) { + return $this->triggerError($e->getMessage()); + } + } + + /** + * @return array + */ + public function stream_stat() + { + $stat = fstat($this->body->getStream()); + // Add the size of the underlying stream if it is known + if ($this->mode == 'r' && $this->body->getSize()) { + $stat[7] = $stat['size'] = $this->body->getSize(); + } + + return $stat; + } + + /** + * Provides information for is_dir, is_file, filesize, etc. Works on buckets, keys, and prefixes + * + * @param string $path + * @param int $flags + * + * @return array Returns an array of stat data + * @link http://www.php.net/manual/en/streamwrapper.url-stat.php + */ + public function url_stat($path, $flags) + { + // Check if this path is in the url_stat cache + if (isset(self::$nextStat[$path])) { + return self::$nextStat[$path]; + } + + $parts = $this->getParams($path); + + if (!$parts['Key']) { + // Stat "directories": buckets, or "s3://" + if (!$parts['Bucket'] || self::$client->doesBucketExist($parts['Bucket'])) { + return $this->formatUrlStat($path); + } else { + return $this->triggerError("File or directory not found: {$path}", $flags); + } + } + + try { + try { + $result = self::$client->headObject($parts)->toArray(); + if (substr($parts['Key'], -1, 1) == '/' && $result['ContentLength'] == 0) { + // Return as if it is a bucket to account for console bucket objects (e.g., zero-byte object "foo/") + return $this->formatUrlStat($path); + } else { + // Attempt to stat and cache regular object + return $this->formatUrlStat($result); + } + } catch (NoSuchKeyException $e) { + // Maybe this isn't an actual key, but a prefix. Do a prefix listing of objects to determine. + $result = self::$client->listObjects(array( + 'Bucket' => $parts['Bucket'], + 'Prefix' => rtrim($parts['Key'], '/') . '/', + 'MaxKeys' => 1 + )); + if (!$result['Contents'] && !$result['CommonPrefixes']) { + return $this->triggerError("File or directory not found: {$path}", $flags); + } + // This is a directory prefix + return $this->formatUrlStat($path); + } + } catch (\Exception $e) { + return $this->triggerError($e->getMessage(), $flags); + } + } + + /** + * Support for mkdir(). + * + * @param string $path Directory which should be created. + * @param int $mode Permissions. 700-range permissions map to ACL_PUBLIC. 600-range permissions map to + * ACL_AUTH_READ. All other permissions map to ACL_PRIVATE. Expects octal form. + * @param int $options A bitwise mask of values, such as STREAM_MKDIR_RECURSIVE. + * + * @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 + * + * @return bool true if directory was successfully removed + * @link http://www.php.net/manual/en/streamwrapper.rmdir.php + */ + public function rmdir($path) + { + $params = $this->getParams($path); + if (!$params['Bucket']) { + return $this->triggerError('You cannot delete s3://. Please specify a bucket.'); + } + + try { + + if (!$params['Key']) { + self::$client->deleteBucket(array('Bucket' => $params['Bucket'])); + $this->clearStatInfo($path); + return true; + } + + $result = self::$client->listObjects(array( + 'Bucket' => $params['Bucket'], + // Use a key that adds a trailing slash if needed. + 'Prefix' => rtrim($params['Key'], '/') . '/', + 'MaxKeys' => 1 + )); + + return $result['Contents'] || $result['CommonPrefixes'] + ? $this->triggerError('Pseudo directory is not empty') + : $this->unlink(rtrim($path, '/') . '/'); + + } catch (\Exception $e) { + return $this->triggerError($e->getMessage()); + } + } + + /** + * Support for opendir(). + * + * @param string $path The path to the directory (e.g. "s3://dir[]") + * @param string $options Whether or not to enforce safe_mode (0x04). Unused. + * + * @return bool true on success + * @see http://www.php.net/manual/en/function.opendir.php + */ + public function dir_opendir($path, $options) + { + // Reset the cache + $this->clearStatInfo(); + $params = $this->getParams($path); + $delimiter = $this->getOption('delimiter'); + + if ($delimiter === null) { + $delimiter = '/'; + } + + if ($params['Key']) { + $params['Key'] = rtrim($params['Key'], $delimiter) . $delimiter; + } + + $this->openedBucket = $params['Bucket']; + $this->openedBucketPrefix = $params['Key']; + $operationParams = array('Bucket' => $params['Bucket'], 'Prefix' => $params['Key']); + + if ($delimiter) { + $operationParams['Delimiter'] = $delimiter; + } + + $objectIterator = self::$client->getIterator('ListObjects', $operationParams, array( + 'return_prefixes' => true, + 'sort_results' => true + )); + + // Filter our "/" keys added by the console as directories + $this->objectIterator = new FilterIterator( + $objectIterator, + function ($key) { + // Each yielded results can contain a "Key" or "Prefix" + return !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. + self::$nextStat = array($key => $stat); + $this->objectIterator->next(); + + return $result; + } + + /** + * Called in response to rename() to rename a file or directory. Currently only supports renaming objects. + * + * @param string $path_from the path to the file to rename + * @param string $path_to the new path to the file + * + * @return bool true if file was successfully renamed + * @link http://www.php.net/manual/en/function.rename.php + */ + public function rename($path_from, $path_to) + { + $partsFrom = $this->getParams($path_from); + $partsTo = $this->getParams($path_to); + $this->clearStatInfo($path_from); + $this->clearStatInfo($path_to); + + if (!$partsFrom['Key'] || !$partsTo['Key']) { + return $this->triggerError('The Amazon S3 stream wrapper only supports copying objects'); + } + + try { + // Copy the object and allow overriding default parameters if desired, but by default copy metadata + self::$client->copyObject($this->getOptions() + array( + 'Bucket' => $partsTo['Bucket'], + 'Key' => $partsTo['Key'], + 'CopySource' => '/' . $partsFrom['Bucket'] . '/' . rawurlencode($partsFrom['Key']), + 'MetadataDirective' => 'COPY' + )); + // Delete the original object + self::$client->deleteObject(array( + 'Bucket' => $partsFrom['Bucket'], + 'Key' => $partsFrom['Key'] + ) + $this->getOptions()); + } catch (\Exception $e) { + return $this->triggerError($e->getMessage()); + } + + return true; + } + + /** + * Cast the stream to return the underlying file resource + * + * @param int $cast_as STREAM_CAST_FOR_SELECT or STREAM_CAST_AS_STREAM + * + * @return resource + */ + public function stream_cast($cast_as) + { + return $this->body->getStream(); + } + + /** + * Get the stream context options available to the current stream + * + * @return array + */ + protected function getOptions() + { + $context = $this->context ?: stream_context_get_default(); + $options = stream_context_get_options($context); + + return isset($options['s3']) ? $options['s3'] : array(); + } + + /** + * Get a specific stream context option + * + * @param string $name Name of the option to retrieve + * + * @return mixed|null + */ + protected function getOption($name) + { + $options = $this->getOptions(); + + return isset($options[$name]) ? $options[$name] : null; + } + + /** + * Get the bucket and key from the passed path (e.g. s3://bucket/key) + * + * @param string $path Path passed to the stream wrapper + * + * @return array Hash of 'Bucket', 'Key', and custom params + */ + protected function getParams($path) + { + $parts = explode('/', substr($path, 5), 2); + + $params = $this->getOptions(); + unset($params['seekable']); + + return array( + 'Bucket' => $parts[0], + 'Key' => isset($parts[1]) ? $parts[1] : null + ) + $params; + } + + /** + * Serialize and sign a command, returning a request object + * + * @param CommandInterface $command Command to sign + * + * @return RequestInterface + */ + protected function getSignedRequest($command) + { + $request = $command->prepare(); + $request->dispatch('request.before_send', array('request' => $request)); + + return $request; + } + + /** + * Initialize the stream wrapper for a read only stream + * + * @param array $params Operation parameters + * @param array $errors Any encountered errors to append to + * + * @return bool + */ + protected function openReadStream(array $params, array &$errors) + { + // Create the command and serialize the request + $request = $this->getSignedRequest(self::$client->getCommand('GetObject', $params)); + // Create a stream that uses the EntityBody object + $factory = $this->getOption('stream_factory') ?: new PhpStreamRequestFactory(); + $this->body = $factory->fromRequest($request, array(), array('stream_class' => 'Guzzle\Http\EntityBody')); + + // Wrap the body in a caching entity body if seeking is allowed + if ($this->getOption('seekable')) { + $this->body = new CachingEntityBody($this->body); + } + + return true; + } + + /** + * Initialize the stream wrapper for a write only stream + * + * @param array $params Operation parameters + * @param array $errors Any encountered errors to append to + * + * @return bool + */ + protected function openWriteStream(array $params, array &$errors) + { + $this->body = new EntityBody(fopen('php://temp', 'r+')); + } + + /** + * Initialize the stream wrapper for an append stream + * + * @param array $params Operation parameters + * @param array $errors Any encountered errors to append to + * + * @return bool + */ + protected function openAppendStream(array $params, array &$errors) + { + try { + // Get the body of the object + $this->body = self::$client->getObject($params)->get('Body'); + $this->body->seek(0, SEEK_END); + } catch (S3Exception $e) { + // The object does not exist, so use a simple write stream + $this->openWriteStream($params, $errors); + } + + return true; + } + + /** + * Trigger one or more errors + * + * @param string|array $errors Errors to trigger + * @param mixed $flags If set to STREAM_URL_STAT_QUIET, then no error or exception occurs + * + * @return bool Returns false + * @throws RuntimeException if throw_errors is true + */ + protected function triggerError($errors, $flags = null) + { + if ($flags === STREAM_URL_STAT_QUIET) { + // This is triggered with things like file_exists() + return false; + } elseif ($flags === (STREAM_URL_STAT_QUIET | STREAM_URL_STAT_LINK)) { + // This is triggered for things like is_link() + return $this->formatUrlStat(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) + { + self::$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 (self::$client->doesBucketExist($params['Bucket'])) { + return $this->triggerError("Directory already exists: {$path}"); + } + + try { + self::$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 (self::$client->doesObjectExist($params['Bucket'], $params['Key'])) { + return $this->triggerError("Directory already exists: {$path}"); + } + + try { + self::$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-sdk-php/src/Aws/S3/Sync/AbstractSync.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Sync/AbstractSync.php new file mode 100644 index 0000000..ac5bbbe --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/S3/Sync/AbstractSyncBuilder.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Sync/AbstractSyncBuilder.php new file mode 100644 index 0000000..5ad80fc --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/S3/Sync/AbstractSyncBuilder.php @@ -0,0 +1,426 @@ +bucket = $bucket; + + return $this; + } + + /** + * Set the Amazon S3 client object that will send requests + * + * @param S3Client $client Amazon S3 client + * + * @return self + */ + public function setClient(S3Client $client) + { + $this->client = $client; + + return $this; + } + + /** + * Set a custom iterator that returns \SplFileInfo objects for the source data + * + * @param \Iterator $iterator + * + * @return self + */ + public function setSourceIterator(\Iterator $iterator) + { + $this->sourceIterator = $iterator; + + return $this; + } + + /** + * Set a custom object key provider instead of building one internally + * + * @param FileNameConverterInterface $converter Filename to object key provider + * + * @return self + */ + public function setSourceFilenameConverter(FilenameConverterInterface $converter) + { + $this->sourceConverter = $converter; + + return $this; + } + + /** + * Set a custom object key provider instead of building one internally + * + * @param FileNameConverterInterface $converter Filename to object key provider + * + * @return self + */ + public function setTargetFilenameConverter(FilenameConverterInterface $converter) + { + $this->targetConverter = $converter; + + return $this; + } + + /** + * Set the base directory of the files being transferred. The base directory is removed from each file path before + * converting the file path to an object key or vice versa. + * + * @param string $baseDir Base directory, which will be deleted from each uploaded object key + * + * @return self + */ + public function setBaseDir($baseDir) + { + $this->baseDir = $baseDir; + + return $this; + } + + /** + * Specify a prefix to prepend to each Amazon S3 object key or the prefix where object are stored in a bucket + * + * Can be used to upload files to a pseudo sub-folder key or only download files from a pseudo sub-folder + * + * @param string $keyPrefix Prefix for each uploaded key + * + * @return self + */ + public function setKeyPrefix($keyPrefix) + { + // Removing leading slash + $this->keyPrefix = ltrim($keyPrefix, '/'); + + return $this; + } + + /** + * Specify the delimiter used for the targeted filesystem (default delimiter is "/") + * + * @param string $delimiter Delimiter to use to separate paths + * + * @return self + */ + public function setDelimiter($delimiter) + { + $this->delimiter = $delimiter; + + return $this; + } + + /** + * Specify an array of operation parameters to apply to each operation executed by the sync object + * + * @param array $params Associative array of PutObject (upload) GetObject (download) parameters + * + * @return self + */ + public function setOperationParams(array $params) + { + $this->params = $params; + + return $this; + } + + /** + * Set the number of files that can be transferred concurrently + * + * @param int $concurrency Number of concurrent transfers + * + * @return self + */ + public function setConcurrency($concurrency) + { + $this->concurrency = $concurrency; + + return $this; + } + + /** + * Set to true to force transfers even if a file already exists and has not changed + * + * @param bool $force Set to true to force transfers without checking if it has changed + * + * @return self + */ + public function force($force = false) + { + $this->forcing = (bool) $force; + + return $this; + } + + /** + * Enable debug mode + * + * @param bool|resource $enabledOrResource Set to true or false to enable or disable debug output. Pass an opened + * fopen resource to write to instead of writing to standard out. + * @return self + */ + public function enableDebugOutput($enabledOrResource = true) + { + $this->debug = $enabledOrResource; + + return $this; + } + + /** + * Add a filename filter that uses a regular expression to filter out files that you do not wish to transfer. + * + * @param string $search Regular expression search (in preg_match format). Any filename that matches this regex + * will not be transferred. + * @return self + */ + public function addRegexFilter($search) + { + $this->assertFileIteratorSet(); + $this->sourceIterator = new FilterIterator($this->sourceIterator, function ($i) use ($search) { + return !preg_match($search, (string) $i); + }); + $this->sourceIterator->rewind(); + + return $this; + } + + /** + * Builds a UploadSync or DownloadSync object + * + * @return AbstractSync + */ + public function build() + { + $this->validateRequirements(); + $this->sourceConverter = $this->sourceConverter ?: $this->getDefaultSourceConverter(); + $this->targetConverter = $this->targetConverter ?: $this->getDefaultTargetConverter(); + + // Only wrap the source iterator in a changed files iterator if we are not forcing the transfers + if (!$this->forcing) { + $this->sourceIterator->rewind(); + $this->sourceIterator = new ChangedFilesIterator( + new \NoRewindIterator($this->sourceIterator), + $this->getTargetIterator(), + $this->sourceConverter, + $this->targetConverter + ); + $this->sourceIterator->rewind(); + } + + $sync = $this->specificBuild(); + + if ($this->params) { + $this->addCustomParamListener($sync); + } + + if ($this->debug) { + $this->addDebugListener($sync, is_bool($this->debug) ? STDOUT : $this->debug); + } + + return $sync; + } + + /** + * Hook to implement in subclasses + * + * @return self + */ + abstract protected function specificBuild(); + + /** + * @return \Iterator + */ + abstract protected function getTargetIterator(); + + /** + * @return FilenameConverterInterface + */ + abstract protected function getDefaultSourceConverter(); + + /** + * @return FilenameConverterInterface + */ + abstract protected function getDefaultTargetConverter(); + + /** + * Add a listener to the sync object to output debug information while transferring + * + * @param AbstractSync $sync Sync object to listen to + * @param resource $resource Where to write debug messages + */ + abstract protected function addDebugListener(AbstractSync $sync, $resource); + + /** + * Validate that the builder has the minimal requirements + * + * @throws RuntimeException if the builder is not configured completely + */ + protected function validateRequirements() + { + if (!$this->client) { + throw new RuntimeException('No client was provided'); + } + if (!$this->bucket) { + throw new RuntimeException('No bucket was provided'); + } + $this->assertFileIteratorSet(); + } + + /** + * Ensure that the base file iterator has been provided + * + * @throws RuntimeException + */ + protected function assertFileIteratorSet() + { + // Interesting... Need to use isset because: Object of class GlobIterator could not be converted to boolean + if (!isset($this->sourceIterator)) { + throw new RuntimeException('A source file iterator must be specified'); + } + } + + /** + * Wraps a generated iterator in a filter iterator that removes directories + * + * @param \Iterator $iterator Iterator to wrap + * + * @return \Iterator + * @throws UnexpectedValueException + */ + protected function filterIterator(\Iterator $iterator) + { + $f = new FilterIterator($iterator, function ($i) { + if (!$i instanceof \SplFileInfo) { + throw new UnexpectedValueException('All iterators for UploadSync must return SplFileInfo objects'); + } + return $i->isFile(); + }); + + $f->rewind(); + + return $f; + } + + /** + * Add the custom param listener to a transfer object + * + * @param HasDispatcherInterface $sync + */ + protected function addCustomParamListener(HasDispatcherInterface $sync) + { + $params = $this->params; + $sync->getEventDispatcher()->addListener( + UploadSync::BEFORE_TRANSFER, + function (Event $e) use ($params) { + if ($e['command'] instanceof CommandInterface) { + $e['command']->overwriteWith($params); + } + } + ); + } + + /** + * Create an Amazon S3 file iterator based on the given builder settings + * + * @return OpendirIterator + */ + protected function createS3Iterator() + { + // Ensure that the stream wrapper is registered + $this->client->registerStreamWrapper(); + + // Calculate the opendir() bucket and optional key prefix location + $dir = "s3://{$this->bucket}"; + if ($this->keyPrefix) { + $dir .= '/' . ltrim($this->keyPrefix, '/ '); + } + + // Use opendir so that we can pass stream context to the iterator + $dh = opendir($dir, stream_context_create(array('s3' => array('delimiter' => '')))); + + // Add the trailing slash for the OpendirIterator concatenation + if (!$this->keyPrefix) { + $dir .= '/'; + } + + return $this->filterIterator(new \NoRewindIterator(new OpendirIterator($dh, $dir))); + } +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/S3/Sync/ChangedFilesIterator.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Sync/ChangedFilesIterator.php new file mode 100644 index 0000000..a39edce --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/S3/Sync/ChangedFilesIterator.php @@ -0,0 +1,125 @@ +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) + { + return $current->getRealPath() ?: (string) $current; + } + + private function cleanKey($key) + { + return ltrim($key, '/'); + } +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/S3/Sync/DownloadSync.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Sync/DownloadSync.php new file mode 100644 index 0000000..560ccdf --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/S3/Sync/DownloadSyncBuilder.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Sync/DownloadSyncBuilder.php new file mode 100644 index 0000000..b0a1e8c --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/S3/Sync/FilenameConverterInterface.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Sync/FilenameConverterInterface.php new file mode 100644 index 0000000..ded2cfb --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/S3/Sync/UploadSync.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Sync/UploadSync.php new file mode 100644 index 0000000..813e688 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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(); + + 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-sdk-php/src/Aws/S3/Sync/UploadSyncBuilder.php b/vendor/aws/aws-sdk-php/src/Aws/S3/Sync/UploadSyncBuilder.php new file mode 100644 index 0000000..ad6333d --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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 self + * @link http://www.php.net/manual/en/function.glob.php + */ + public function uploadFromGlob($glob) + { + $this->sourceIterator = $this->filterIterator( + new \GlobIterator($glob, FI::SKIP_DOTS | FI::UNIX_PATHS | FI::FOLLOW_SYMLINKS) + ); + + return $this; + } + + /** + * Set a canned ACL to apply to each uploaded object + * + * @param string $acl Canned ACL for each upload + * + * @return self + */ + public function setAcl($acl) + { + $this->acp = $acl; + + return $this; + } + + /** + * Set an Access Control Policy to apply to each uploaded object + * + * @param Acp $acp Access control policy + * + * @return self + */ + public function setAcp(Acp $acp) + { + $this->acp = $acp; + + return $this; + } + + /** + * Set the multipart upload size threshold. When the size of a file exceeds this value, the file will be uploaded + * using a multipart upload. + * + * @param int $size Size threshold + * + * @return self + */ + public function setMultipartUploadSize($size) + { + $this->multipartUploadSize = $size; + + return $this; + } + + protected function specificBuild() + { + $sync = new UploadSync(array( + 'client' => $this->client, + 'bucket' => $this->bucket, + 'iterator' => $this->sourceIterator, + 'source_converter' => $this->sourceConverter, + 'target_converter' => $this->targetConverter, + 'concurrency' => $this->concurrency, + 'multipart_upload_size' => $this->multipartUploadSize, + 'acl' => $this->acp + )); + + return $sync; + } + + protected function addCustomParamListener(HasDispatcherInterface $sync) + { + // Handle the special multi-part upload event + parent::addCustomParamListener($sync); + $params = $this->params; + $sync->getEventDispatcher()->addListener( + UploadSync::BEFORE_MULTIPART_BUILD, + function (Event $e) use ($params) { + foreach ($params as $k => $v) { + $e['builder']->setOption($k, $v); + } + } + ); + } + + protected function getTargetIterator() + { + return $this->createS3Iterator(); + } + + protected function getDefaultSourceConverter() + { + return new KeyConverter($this->baseDir, $this->keyPrefix . $this->delimiter, $this->delimiter); + } + + protected function getDefaultTargetConverter() + { + return new KeyConverter('s3://' . $this->bucket . '/', '', DIRECTORY_SEPARATOR); + } + + protected function addDebugListener(AbstractSync $sync, $resource) + { + $sync->getEventDispatcher()->addListener(UploadSync::BEFORE_TRANSFER, function (Event $e) use ($resource) { + + $c = $e['command']; + + if ($c instanceof CommandInterface) { + $uri = $c['Body']->getUri(); + $size = $c['Body']->getSize(); + fwrite($resource, "Uploading {$uri} -> {$c['Key']} ({$size} bytes)\n"); + return; + } + + // Multipart upload + $body = $c->getSource(); + $totalSize = $body->getSize(); + $progress = 0; + fwrite($resource, "Beginning multipart upload: " . $body->getUri() . ' -> '); + fwrite($resource, $c->getState()->getFromId('Key') . " ({$totalSize} bytes)\n"); + + $c->getEventDispatcher()->addListener( + AbstractTransfer::BEFORE_PART_UPLOAD, + function ($e) use (&$progress, $totalSize, $resource) { + $command = $e['command']; + $size = $command['Body']->getContentLength(); + $percentage = number_format(($progress / $totalSize) * 100, 2); + fwrite($resource, "- Part {$command['PartNumber']} ({$size} bytes, {$percentage}%)\n"); + $progress += $size; + } + ); + }); + } +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/Ses/Enum/IdentityType.php b/vendor/aws/aws-sdk-php/src/Aws/Ses/Enum/IdentityType.php new file mode 100644 index 0000000..30d3234 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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', + ), + '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-sdk-php/src/Aws/Ses/SesClient.php b/vendor/aws/aws-sdk-php/src/Aws/Ses/SesClient.php new file mode 100644 index 0000000..dceb149 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/SimpleDb/Exception/AttributeDoesNotExistException.php b/vendor/aws/aws-sdk-php/src/Aws/SimpleDb/Exception/AttributeDoesNotExistException.php new file mode 100644 index 0000000..f061ac0 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/SimpleDb/SimpleDbClient.php b/vendor/aws/aws-sdk-php/src/Aws/SimpleDb/SimpleDbClient.php new file mode 100644 index 0000000..ce58059 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Sns/Exception/AuthorizationErrorException.php b/vendor/aws/aws-sdk-php/src/Aws/Sns/Exception/AuthorizationErrorException.php new file mode 100644 index 0000000..fb44055 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Sns/MessageValidator/MessageValidator.php b/vendor/aws/aws-sdk-php/src/Aws/Sns/MessageValidator/MessageValidator.php new file mode 100644 index 0000000..3db051e --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/Sns/MessageValidator/MessageValidator.php @@ -0,0 +1,103 @@ +client = $client ?: new Client(); + } + + /** + * Validates a message from SNS to ensure that it was delivered by AWS + * + * @param Message $message The message to validate + * + * @throws CannotGetPublicKeyFromCertificateException If the certificate cannot be retrieved + * @throws CertificateFromUnrecognizedSourceException If the certificate's source cannot be verified + * @throws InvalidMessageSignatureException If the message's signature is invalid + */ + public function validate(Message $message) + { + // Get the cert's URL and ensure it is from AWS + $certUrl = Url::factory($message->get('SigningCertURL')); + if ('.amazonaws.com' != substr($certUrl->getHost(), -14)) { + throw new CertificateFromUnrecognizedSourceException(); + } + + // Get the cert itself and extract the public key + $certificate = $this->client->get((string) $certUrl)->send()->getBody(); + $publicKey = openssl_get_publickey($certificate); + if (!$publicKey) { + throw new CannotGetPublicKeyFromCertificateException(); + } + + // Verify the signature of the message + $stringToSign = $message->getStringToSign(); + $incomingSignature = base64_decode($message->get('Signature')); + if (!openssl_verify($stringToSign, $incomingSignature, $publicKey, OPENSSL_ALGO_SHA1)) { + throw new InvalidMessageSignatureException(); + } + } + + /** + * Determines if a message is valid and that is was delivered by AWS. This method does not throw exceptions and + * returns a simple boolean value. + * + * @param Message $message The message to validate + * + * @return bool + */ + public function isValid(Message $message) + { + try { + $this->validate($message); + return true; + } catch (SnsMessageValidatorException $e) { + return false; + } + } +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/Sns/Resources/sns-2010-03-31.php b/vendor/aws/aws-sdk-php/src/Aws/Sns/Resources/sns-2010-03-31.php new file mode 100644 index 0000000..7f86f24 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/Sns/Resources/sns-2010-03-31.php @@ -0,0 +1,1709 @@ + '2010-03-31', + 'endpointPrefix' => 'sns', + 'serviceFullName' => 'Amazon Simple Notification Service', + 'serviceAbbreviation' => 'Amazon SNS', + 'serviceType' => 'query', + 'resultWrapped' => true, + 'signatureVersion' => 'v4', + 'namespace' => 'Sns', + 'regions' => array( + 'us-east-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'sns.us-east-1.amazonaws.com', + ), + 'us-west-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'sns.us-west-1.amazonaws.com', + ), + 'us-west-2' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'sns.us-west-2.amazonaws.com', + ), + 'eu-west-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'sns.eu-west-1.amazonaws.com', + ), + 'ap-northeast-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'sns.ap-northeast-1.amazonaws.com', + ), + 'ap-southeast-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'sns.ap-southeast-1.amazonaws.com', + ), + 'ap-southeast-2' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'sns.ap-southeast-2.amazonaws.com', + ), + 'sa-east-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'sns.sa-east-1.amazonaws.com', + ), + 'cn-north-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'sns.cn-north-1.amazonaws.com.cn', + ), + 'us-gov-west-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'sns.us-gov-west-1.amazonaws.com', + ), + ), + 'operations' => array( + 'AddPermission' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'AddPermission', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-03-31', + ), + 'TopicArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Label' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'AWSAccountId' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'AWSAccountId.member', + 'items' => array( + 'name' => 'delegate', + 'type' => 'string', + ), + ), + 'ActionName' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'ActionName.member', + 'items' => array( + 'name' => 'action', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Indicates that the user has been denied access to the requested resource.', + 'class' => 'AuthorizationErrorException', + ), + array( + 'reason' => 'Indicates that the requested resource does not exist.', + 'class' => 'NotFoundException', + ), + ), + ), + 'ConfirmSubscription' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ConfirmSubscriptionResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ConfirmSubscription', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-03-31', + ), + 'TopicArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Token' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'AuthenticateOnUnsubscribe' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that the customer already owns the maximum allowed number of subscriptions.', + 'class' => 'SubscriptionLimitExceededException', + ), + array( + 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Indicates that the requested resource does not exist.', + 'class' => 'NotFoundException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Indicates that the user has been denied access to the requested resource.', + 'class' => 'AuthorizationErrorException', + ), + ), + ), + 'CreatePlatformApplication' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'CreatePlatformApplicationResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreatePlatformApplication', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-03-31', + ), + 'Name' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Platform' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Attributes' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'aws.query', + 'sentAs' => 'Attributes.entry', + 'additionalProperties' => array( + 'type' => 'string', + 'data' => array( + 'shape_name' => 'String', + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Indicates that the user has been denied access to the requested resource.', + 'class' => 'AuthorizationErrorException', + ), + ), + ), + 'CreatePlatformEndpoint' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'CreateEndpointResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreatePlatformEndpoint', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-03-31', + ), + 'PlatformApplicationArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Token' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'CustomUserData' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Attributes' => array( + 'type' => 'object', + 'location' => 'aws.query', + 'sentAs' => 'Attributes.entry', + 'additionalProperties' => array( + 'type' => 'string', + 'data' => array( + 'shape_name' => 'String', + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Indicates that the user has been denied access to the requested resource.', + 'class' => 'AuthorizationErrorException', + ), + array( + 'reason' => 'Indicates that the requested resource does not exist.', + 'class' => 'NotFoundException', + ), + ), + ), + 'CreateTopic' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'CreateTopicResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateTopic', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-03-31', + ), + 'Name' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Indicates that the customer already owns the maximum allowed number of topics.', + 'class' => 'TopicLimitExceededException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Indicates that the user has been denied access to the requested resource.', + 'class' => 'AuthorizationErrorException', + ), + ), + ), + 'DeleteEndpoint' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteEndpoint', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-03-31', + ), + 'EndpointArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Indicates that the user has been denied access to the requested resource.', + 'class' => 'AuthorizationErrorException', + ), + ), + ), + 'DeletePlatformApplication' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeletePlatformApplication', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-03-31', + ), + 'PlatformApplicationArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Indicates that the user has been denied access to the requested resource.', + 'class' => 'AuthorizationErrorException', + ), + ), + ), + 'DeleteTopic' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteTopic', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-03-31', + ), + 'TopicArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Indicates that the user has been denied access to the requested resource.', + 'class' => 'AuthorizationErrorException', + ), + array( + 'reason' => 'Indicates that the requested resource does not exist.', + 'class' => 'NotFoundException', + ), + ), + ), + 'GetEndpointAttributes' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'GetEndpointAttributesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'GetEndpointAttributes', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-03-31', + ), + 'EndpointArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Indicates that the user has been denied access to the requested resource.', + 'class' => 'AuthorizationErrorException', + ), + array( + 'reason' => 'Indicates that the requested resource does not exist.', + 'class' => 'NotFoundException', + ), + ), + ), + 'GetPlatformApplicationAttributes' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'GetPlatformApplicationAttributesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'GetPlatformApplicationAttributes', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-03-31', + ), + 'PlatformApplicationArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Indicates that the user has been denied access to the requested resource.', + 'class' => 'AuthorizationErrorException', + ), + array( + 'reason' => 'Indicates that the requested resource does not exist.', + 'class' => 'NotFoundException', + ), + ), + ), + 'GetSubscriptionAttributes' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'GetSubscriptionAttributesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'GetSubscriptionAttributes', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-03-31', + ), + 'SubscriptionArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Indicates that the requested resource does not exist.', + 'class' => 'NotFoundException', + ), + array( + 'reason' => 'Indicates that the user has been denied access to the requested resource.', + 'class' => 'AuthorizationErrorException', + ), + ), + ), + 'GetTopicAttributes' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'GetTopicAttributesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'GetTopicAttributes', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-03-31', + ), + 'TopicArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Indicates that the requested resource does not exist.', + 'class' => 'NotFoundException', + ), + array( + 'reason' => 'Indicates that the user has been denied access to the requested resource.', + 'class' => 'AuthorizationErrorException', + ), + ), + ), + 'ListEndpointsByPlatformApplication' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListEndpointsByPlatformApplicationResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListEndpointsByPlatformApplication', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-03-31', + ), + 'PlatformApplicationArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Indicates that the user has been denied access to the requested resource.', + 'class' => 'AuthorizationErrorException', + ), + array( + 'reason' => 'Indicates that the requested resource does not exist.', + 'class' => 'NotFoundException', + ), + ), + ), + 'ListPlatformApplications' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListPlatformApplicationsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListPlatformApplications', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-03-31', + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Indicates that the user has been denied access to the requested resource.', + 'class' => 'AuthorizationErrorException', + ), + ), + ), + 'ListSubscriptions' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListSubscriptionsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListSubscriptions', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-03-31', + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Indicates that the user has been denied access to the requested resource.', + 'class' => 'AuthorizationErrorException', + ), + ), + ), + 'ListSubscriptionsByTopic' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListSubscriptionsByTopicResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListSubscriptionsByTopic', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-03-31', + ), + 'TopicArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Indicates that the requested resource does not exist.', + 'class' => 'NotFoundException', + ), + array( + 'reason' => 'Indicates that the user has been denied access to the requested resource.', + 'class' => 'AuthorizationErrorException', + ), + ), + ), + 'ListTopics' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListTopicsResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListTopics', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-03-31', + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Indicates that the user has been denied access to the requested resource.', + 'class' => 'AuthorizationErrorException', + ), + ), + ), + 'Publish' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'PublishResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'Publish', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-03-31', + ), + 'TopicArn' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'TargetArn' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Message' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Subject' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + 'MessageStructure' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Indicates that the requested resource does not exist.', + 'class' => 'NotFoundException', + ), + array( + 'reason' => 'Exception error indicating endpoint disabled.', + 'class' => 'EndpointDisabledException', + ), + array( + 'reason' => 'Exception error indicating platform application disabled.', + 'class' => 'PlatformApplicationDisabledException', + ), + array( + 'reason' => 'Indicates that the user has been denied access to the requested resource.', + 'class' => 'AuthorizationErrorException', + ), + ), + ), + 'RemovePermission' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'RemovePermission', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-03-31', + ), + 'TopicArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Label' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Indicates that the user has been denied access to the requested resource.', + 'class' => 'AuthorizationErrorException', + ), + array( + 'reason' => 'Indicates that the requested resource does not exist.', + 'class' => 'NotFoundException', + ), + ), + ), + 'SetEndpointAttributes' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'SetEndpointAttributes', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-03-31', + ), + 'EndpointArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Attributes' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'aws.query', + 'sentAs' => 'Attributes.entry', + 'additionalProperties' => array( + 'type' => 'string', + 'data' => array( + 'shape_name' => 'String', + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Indicates that the user has been denied access to the requested resource.', + 'class' => 'AuthorizationErrorException', + ), + array( + 'reason' => 'Indicates that the requested resource does not exist.', + 'class' => 'NotFoundException', + ), + ), + ), + 'SetPlatformApplicationAttributes' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'SetPlatformApplicationAttributes', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-03-31', + ), + 'PlatformApplicationArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Attributes' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'aws.query', + 'sentAs' => 'Attributes.entry', + 'additionalProperties' => array( + 'type' => 'string', + 'data' => array( + 'shape_name' => 'String', + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Indicates that the user has been denied access to the requested resource.', + 'class' => 'AuthorizationErrorException', + ), + array( + 'reason' => 'Indicates that the requested resource does not exist.', + 'class' => 'NotFoundException', + ), + ), + ), + 'SetSubscriptionAttributes' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'SetSubscriptionAttributes', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-03-31', + ), + 'SubscriptionArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'AttributeName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'AttributeValue' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Indicates that the requested resource does not exist.', + 'class' => 'NotFoundException', + ), + array( + 'reason' => 'Indicates that the user has been denied access to the requested resource.', + 'class' => 'AuthorizationErrorException', + ), + ), + ), + 'SetTopicAttributes' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'SetTopicAttributes', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-03-31', + ), + 'TopicArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'AttributeName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'AttributeValue' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Indicates that the requested resource does not exist.', + 'class' => 'NotFoundException', + ), + array( + 'reason' => 'Indicates that the user has been denied access to the requested resource.', + 'class' => 'AuthorizationErrorException', + ), + ), + ), + 'Subscribe' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'SubscribeResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'Subscribe', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-03-31', + ), + 'TopicArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Protocol' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Endpoint' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that the customer already owns the maximum allowed number of subscriptions.', + 'class' => 'SubscriptionLimitExceededException', + ), + array( + 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Indicates that the requested resource does not exist.', + 'class' => 'NotFoundException', + ), + array( + 'reason' => 'Indicates that the user has been denied access to the requested resource.', + 'class' => 'AuthorizationErrorException', + ), + ), + ), + 'Unsubscribe' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'Unsubscribe', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2010-03-31', + ), + 'SubscriptionArn' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Indicates that a request parameter does not comply with the associated constraints.', + 'class' => 'InvalidParameterException', + ), + array( + 'reason' => 'Indicates an internal service error.', + 'class' => 'InternalErrorException', + ), + array( + 'reason' => 'Indicates that the user has been denied access to the requested resource.', + 'class' => 'AuthorizationErrorException', + ), + array( + 'reason' => 'Indicates that the requested resource does not exist.', + 'class' => 'NotFoundException', + ), + ), + ), + ), + 'models' => array( + 'EmptyOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + ), + 'ConfirmSubscriptionResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'SubscriptionArn' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'CreatePlatformApplicationResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'PlatformApplicationArn' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'CreateEndpointResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'EndpointArn' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'CreateTopicResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'TopicArn' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'GetEndpointAttributesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Attributes' => array( + 'type' => 'array', + 'location' => 'xml', + 'filters' => array( + array( + 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', + 'args' => array( + '@value', + 'entry', + 'key', + 'value', + ), + ), + ), + 'items' => array( + 'name' => 'entry', + 'type' => 'object', + 'sentAs' => 'entry', + 'additionalProperties' => true, + 'properties' => array( + 'key' => array( + 'type' => 'string', + ), + 'value' => array( + 'type' => 'string', + ), + ), + ), + 'additionalProperties' => false, + ), + ), + ), + 'GetPlatformApplicationAttributesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Attributes' => array( + 'type' => 'array', + 'location' => 'xml', + 'filters' => array( + array( + 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', + 'args' => array( + '@value', + 'entry', + 'key', + 'value', + ), + ), + ), + 'items' => array( + 'name' => 'entry', + 'type' => 'object', + 'sentAs' => 'entry', + 'additionalProperties' => true, + 'properties' => array( + 'key' => array( + 'type' => 'string', + ), + 'value' => array( + 'type' => 'string', + ), + ), + ), + 'additionalProperties' => false, + ), + ), + ), + 'GetSubscriptionAttributesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Attributes' => array( + 'type' => 'array', + 'location' => 'xml', + 'filters' => array( + array( + 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', + 'args' => array( + '@value', + 'entry', + 'key', + 'value', + ), + ), + ), + 'items' => array( + 'name' => 'entry', + 'type' => 'object', + 'sentAs' => 'entry', + 'additionalProperties' => true, + 'properties' => array( + 'key' => array( + 'type' => 'string', + ), + 'value' => array( + 'type' => 'string', + ), + ), + ), + 'additionalProperties' => false, + ), + ), + ), + 'GetTopicAttributesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Attributes' => array( + 'type' => 'array', + 'location' => 'xml', + 'filters' => array( + array( + 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', + 'args' => array( + '@value', + 'entry', + 'key', + 'value', + ), + ), + ), + 'items' => array( + 'name' => 'entry', + 'type' => 'object', + 'sentAs' => 'entry', + 'additionalProperties' => true, + 'properties' => array( + 'key' => array( + 'type' => 'string', + ), + 'value' => array( + 'type' => 'string', + ), + ), + ), + 'additionalProperties' => false, + ), + ), + ), + 'ListEndpointsByPlatformApplicationResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Endpoints' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'Endpoint', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'EndpointArn' => array( + 'type' => 'string', + ), + 'Attributes' => array( + 'type' => 'array', + 'filters' => array( + array( + 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', + 'args' => array( + '@value', + 'entry', + 'key', + 'value', + ), + ), + ), + 'items' => array( + 'name' => 'entry', + 'type' => 'object', + 'sentAs' => 'entry', + 'additionalProperties' => true, + 'properties' => array( + 'key' => array( + 'type' => 'string', + ), + 'value' => array( + 'type' => 'string', + ), + ), + ), + 'additionalProperties' => false, + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'ListPlatformApplicationsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'PlatformApplications' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'PlatformApplication', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'PlatformApplicationArn' => array( + 'type' => 'string', + ), + 'Attributes' => array( + 'type' => 'array', + 'filters' => array( + array( + 'method' => 'Aws\\Common\\Command\\XmlResponseLocationVisitor::xmlMap', + 'args' => array( + '@value', + 'entry', + 'key', + 'value', + ), + ), + ), + 'items' => array( + 'name' => 'entry', + 'type' => 'object', + 'sentAs' => 'entry', + 'additionalProperties' => true, + 'properties' => array( + 'key' => array( + 'type' => 'string', + ), + 'value' => array( + 'type' => 'string', + ), + ), + ), + 'additionalProperties' => false, + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'ListSubscriptionsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Subscriptions' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'Subscription', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'SubscriptionArn' => array( + 'type' => 'string', + ), + 'Owner' => array( + 'type' => 'string', + ), + 'Protocol' => array( + 'type' => 'string', + ), + 'Endpoint' => array( + 'type' => 'string', + ), + 'TopicArn' => array( + 'type' => 'string', + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'ListSubscriptionsByTopicResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Subscriptions' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'Subscription', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'SubscriptionArn' => array( + 'type' => 'string', + ), + 'Owner' => array( + 'type' => 'string', + ), + 'Protocol' => array( + 'type' => 'string', + ), + 'Endpoint' => array( + 'type' => 'string', + ), + 'TopicArn' => array( + 'type' => 'string', + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'ListTopicsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Topics' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'name' => 'Topic', + 'type' => 'object', + 'sentAs' => 'member', + 'properties' => array( + 'TopicArn' => array( + 'type' => 'string', + ), + ), + ), + ), + 'NextToken' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'PublishResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'MessageId' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + 'SubscribeResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'SubscriptionArn' => array( + 'type' => 'string', + 'location' => 'xml', + ), + ), + ), + ), + 'iterators' => array( + '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-sdk-php/src/Aws/Sns/SnsClient.php b/vendor/aws/aws-sdk-php/src/Aws/Sns/SnsClient.php new file mode 100644 index 0000000..3db843c --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Sqs/Enum/MessageAttribute.php b/vendor/aws/aws-sdk-php/src/Aws/Sqs/Enum/MessageAttribute.php new file mode 100644 index 0000000..dbf0b16 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Sqs/QueueUrlListener.php b/vendor/aws/aws-sdk-php/src/Aws/Sqs/QueueUrlListener.php new file mode 100644 index 0000000..0b1ceea --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Sqs/Resources/sqs-2012-11-05.php b/vendor/aws/aws-sdk-php/src/Aws/Sqs/Resources/sqs-2012-11-05.php new file mode 100644 index 0000000..4e7c5ed --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/Sqs/Resources/sqs-2012-11-05.php @@ -0,0 +1,1334 @@ + '2012-11-05', + 'endpointPrefix' => 'sqs', + 'serviceFullName' => 'Amazon Simple Queue Service', + 'serviceAbbreviation' => 'Amazon SQS', + 'serviceType' => 'query', + 'resultWrapped' => true, + 'signatureVersion' => 'v4', + 'namespace' => 'Sqs', + 'regions' => array( + 'us-east-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'sqs.us-east-1.amazonaws.com', + ), + 'us-west-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'sqs.us-west-1.amazonaws.com', + ), + 'us-west-2' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'sqs.us-west-2.amazonaws.com', + ), + 'eu-west-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'sqs.eu-west-1.amazonaws.com', + ), + 'ap-northeast-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'sqs.ap-northeast-1.amazonaws.com', + ), + 'ap-southeast-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'sqs.ap-southeast-1.amazonaws.com', + ), + 'ap-southeast-2' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'sqs.ap-southeast-2.amazonaws.com', + ), + 'sa-east-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'sqs.sa-east-1.amazonaws.com', + ), + 'cn-north-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'sqs.cn-north-1.amazonaws.com.cn', + ), + 'us-gov-west-1' => array( + 'http' => true, + 'https' => true, + 'hostname' => 'sqs.us-gov-west-1.amazonaws.com', + ), + ), + 'operations' => array( + 'AddPermission' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'AddPermission', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-11-05', + ), + 'QueueUrl' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Label' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'AWSAccountIds' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'AWSAccountId', + 'items' => array( + 'name' => 'AWSAccountId', + 'type' => 'string', + ), + ), + 'Actions' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'ActionName', + 'items' => array( + 'name' => 'ActionName', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The action that you requested would violate a limit. For example, ReceiveMessage returns this error if the maximum number of messages inflight has already been reached. AddPermission returns this error if the maximum number of permissions for the queue has already been reached.', + 'class' => 'OverLimitException', + ), + ), + ), + 'ChangeMessageVisibility' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ChangeMessageVisibility', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-11-05', + ), + 'QueueUrl' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'ReceiptHandle' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'VisibilityTimeout' => array( + 'required' => true, + 'type' => 'numeric', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The message referred to is not in flight.', + 'class' => 'MessageNotInflightException', + ), + array( + 'reason' => 'The receipt handle provided is not valid.', + 'class' => 'ReceiptHandleIsInvalidException', + ), + ), + ), + 'ChangeMessageVisibilityBatch' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ChangeMessageVisibilityBatchResult', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ChangeMessageVisibilityBatch', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-11-05', + ), + 'QueueUrl' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Entries' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'ChangeMessageVisibilityBatchRequestEntry', + 'items' => array( + 'name' => 'ChangeMessageVisibilityBatchRequestEntry', + 'type' => 'object', + 'properties' => array( + 'Id' => array( + 'required' => true, + 'type' => 'string', + ), + 'ReceiptHandle' => array( + 'required' => true, + 'type' => 'string', + ), + 'VisibilityTimeout' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Batch request contains more number of entries than permissible.', + 'class' => 'TooManyEntriesInBatchRequestException', + ), + array( + 'reason' => 'Batch request does not contain an entry.', + 'class' => 'EmptyBatchRequestException', + ), + array( + 'reason' => 'Two or more batch entries have the same Id in the request.', + 'class' => 'BatchEntryIdsNotDistinctException', + ), + array( + 'reason' => 'The Id of a batch entry in a batch request does not abide by the specification.', + 'class' => 'InvalidBatchEntryIdException', + ), + ), + ), + 'CreateQueue' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'CreateQueueResult', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'CreateQueue', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-11-05', + ), + 'QueueName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Attributes' => array( + 'type' => 'object', + 'location' => 'aws.query', + 'sentAs' => 'Attribute', + 'data' => array( + 'keyName' => 'Name', + 'valueName' => 'Value', + ), + 'additionalProperties' => array( + 'type' => 'string', + 'data' => array( + 'shape_name' => 'QueueAttributeName', + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'You must wait 60 seconds after deleting a queue before you can create another with the same name.', + 'class' => 'QueueDeletedRecentlyException', + ), + array( + 'reason' => 'A queue already exists with this name. Amazon SQS returns this error only if the request includes attributes whose values differ from those of the existing queue.', + 'class' => 'QueueNameExistsException', + ), + ), + ), + 'DeleteMessage' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteMessage', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-11-05', + ), + 'QueueUrl' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'ReceiptHandle' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The receipt handle is not valid for the current version.', + 'class' => 'InvalidIdFormatException', + ), + array( + 'reason' => 'The receipt handle provided is not valid.', + 'class' => 'ReceiptHandleIsInvalidException', + ), + ), + ), + 'DeleteMessageBatch' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'DeleteMessageBatchResult', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteMessageBatch', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-11-05', + ), + 'QueueUrl' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'Entries' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'DeleteMessageBatchRequestEntry', + 'items' => array( + 'name' => 'DeleteMessageBatchRequestEntry', + 'type' => 'object', + 'properties' => array( + 'Id' => array( + 'required' => true, + 'type' => 'string', + ), + 'ReceiptHandle' => array( + 'required' => true, + 'type' => 'string', + ), + ), + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Batch request contains more number of entries than permissible.', + 'class' => 'TooManyEntriesInBatchRequestException', + ), + array( + 'reason' => 'Batch request does not contain an entry.', + 'class' => 'EmptyBatchRequestException', + ), + array( + 'reason' => 'Two or more batch entries have the same Id in the request.', + 'class' => 'BatchEntryIdsNotDistinctException', + ), + array( + 'reason' => 'The Id of a batch entry in a batch request does not abide by the specification.', + 'class' => 'InvalidBatchEntryIdException', + ), + ), + ), + 'DeleteQueue' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'DeleteQueue', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-11-05', + ), + 'QueueUrl' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + ), + 'GetQueueAttributes' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'GetQueueAttributesResult', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'GetQueueAttributes', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-11-05', + ), + 'QueueUrl' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'AttributeNames' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'AttributeName', + 'items' => array( + 'name' => 'AttributeName', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The attribute referred to does not exist.', + 'class' => 'InvalidAttributeNameException', + ), + ), + ), + 'GetQueueUrl' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'GetQueueUrlResult', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'GetQueueUrl', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-11-05', + ), + 'QueueName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'QueueOwnerAWSAccountId' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The queue referred to does not exist.', + 'class' => 'QueueDoesNotExistException', + ), + ), + ), + 'ListDeadLetterSourceQueues' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListDeadLetterSourceQueuesResult', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListDeadLetterSourceQueues', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-11-05', + ), + 'QueueUrl' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'The queue referred to does not exist.', + 'class' => 'QueueDoesNotExistException', + ), + ), + ), + 'ListQueues' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ListQueuesResult', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ListQueues', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-11-05', + ), + 'QueueNamePrefix' => array( + 'type' => 'string', + 'location' => 'aws.query', + ), + ), + ), + 'ReceiveMessage' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\QueryCommand', + 'responseClass' => 'ReceiveMessageResult', + 'responseType' => 'model', + 'parameters' => array( + 'Action' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => 'ReceiveMessage', + ), + 'Version' => array( + 'static' => true, + 'location' => 'aws.query', + 'default' => '2012-11-05', + ), + 'QueueUrl' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'aws.query', + ), + 'AttributeNames' => array( + 'type' => 'array', + 'location' => 'aws.query', + 'sentAs' => 'AttributeName', + 'items' => array( + 'name' => 'AttributeName', + 'type' => 'string', + ), + ), + '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( + '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( + '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-sdk-php/src/Aws/Sqs/SqsClient.php b/vendor/aws/aws-sdk-php/src/Aws/Sqs/SqsClient.php new file mode 100644 index 0000000..a88300f --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/Sqs/SqsClient.php @@ -0,0 +1,95 @@ +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-sdk-php/src/Aws/StorageGateway/Enum/BandwidthType.php b/vendor/aws/aws-sdk-php/src/Aws/StorageGateway/Enum/BandwidthType.php new file mode 100644 index 0000000..485bfda --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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', + 'minimum' => 107374182400, + 'maximum' => 2748779069440, + ), + 'ClientToken' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 5, + 'maxLength' => 100, + ), + 'NumTapesToCreate' => array( + 'required' => true, + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 10, + ), + 'TapeBarcodePrefix' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 4, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'DeleteBandwidthRateLimit' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DeleteBandwidthRateLimitOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.DeleteBandwidthRateLimit', + ), + 'GatewayARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + 'BandwidthType' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 3, + 'maxLength' => 25, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'DeleteChapCredentials' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DeleteChapCredentialsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.DeleteChapCredentials', + ), + 'TargetARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 800, + ), + 'InitiatorName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 255, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'DeleteGateway' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DeleteGatewayOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.DeleteGateway', + ), + 'GatewayARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'DeleteSnapshotSchedule' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DeleteSnapshotScheduleOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.DeleteSnapshotSchedule', + ), + 'VolumeARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'DeleteTape' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DeleteTapeOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.DeleteTape', + ), + 'GatewayARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + 'TapeARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'DeleteTapeArchive' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DeleteTapeArchiveOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.DeleteTapeArchive', + ), + 'TapeARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'DeleteVolume' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DeleteVolumeOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.DeleteVolume', + ), + 'VolumeARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'DescribeBandwidthRateLimit' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeBandwidthRateLimitOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.DescribeBandwidthRateLimit', + ), + 'GatewayARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'DescribeCache' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeCacheOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.DescribeCache', + ), + 'GatewayARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'DescribeCachediSCSIVolumes' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeCachediSCSIVolumesOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.DescribeCachediSCSIVolumes', + ), + 'VolumeARNs' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'VolumeARN', + 'type' => 'string', + 'minLength' => 50, + 'maxLength' => 500, + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'DescribeChapCredentials' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeChapCredentialsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.DescribeChapCredentials', + ), + 'TargetARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 800, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'DescribeGatewayInformation' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeGatewayInformationOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.DescribeGatewayInformation', + ), + 'GatewayARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'DescribeMaintenanceStartTime' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeMaintenanceStartTimeOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.DescribeMaintenanceStartTime', + ), + 'GatewayARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'DescribeSnapshotSchedule' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeSnapshotScheduleOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.DescribeSnapshotSchedule', + ), + 'VolumeARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'DescribeStorediSCSIVolumes' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeStorediSCSIVolumesOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.DescribeStorediSCSIVolumes', + ), + 'VolumeARNs' => array( + 'required' => true, + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'VolumeARN', + 'type' => 'string', + 'minLength' => 50, + 'maxLength' => 500, + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'DescribeTapeArchives' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeTapeArchivesOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.DescribeTapeArchives', + ), + 'TapeARNs' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'TapeARN', + 'type' => 'string', + 'minLength' => 50, + 'maxLength' => 500, + ), + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 1000, + ), + 'Limit' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'DescribeTapeRecoveryPoints' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeTapeRecoveryPointsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.DescribeTapeRecoveryPoints', + ), + 'GatewayARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 1000, + ), + 'Limit' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'DescribeTapes' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeTapesOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.DescribeTapes', + ), + 'GatewayARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + 'TapeARNs' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'TapeARN', + 'type' => 'string', + 'minLength' => 50, + 'maxLength' => 500, + ), + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 1000, + ), + 'Limit' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'DescribeUploadBuffer' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeUploadBufferOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.DescribeUploadBuffer', + ), + 'GatewayARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'DescribeVTLDevices' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeVTLDevicesOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.DescribeVTLDevices', + ), + 'GatewayARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + 'VTLDeviceARNs' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'VTLDeviceARN', + 'type' => 'string', + 'minLength' => 50, + 'maxLength' => 500, + ), + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 1000, + ), + 'Limit' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'DescribeWorkingStorage' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeWorkingStorageOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.DescribeWorkingStorage', + ), + 'GatewayARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'DisableGateway' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DisableGatewayOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.DisableGateway', + ), + 'GatewayARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'ListGateways' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListGatewaysOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.ListGateways', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 1000, + ), + 'Limit' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'ListLocalDisks' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListLocalDisksOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.ListLocalDisks', + ), + 'GatewayARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'ListVolumeRecoveryPoints' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListVolumeRecoveryPointsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.ListVolumeRecoveryPoints', + ), + 'GatewayARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'ListVolumes' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ListVolumesOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.ListVolumes', + ), + 'GatewayARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 1000, + ), + 'Limit' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'RetrieveTapeArchive' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'RetrieveTapeArchiveOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.RetrieveTapeArchive', + ), + 'TapeARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + 'GatewayARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'RetrieveTapeRecoveryPoint' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'RetrieveTapeRecoveryPointOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.RetrieveTapeRecoveryPoint', + ), + 'TapeARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + 'GatewayARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'ShutdownGateway' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'ShutdownGatewayOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.ShutdownGateway', + ), + 'GatewayARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'StartGateway' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'StartGatewayOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.StartGateway', + ), + 'GatewayARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'UpdateBandwidthRateLimit' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'UpdateBandwidthRateLimitOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.UpdateBandwidthRateLimit', + ), + 'GatewayARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + 'AverageUploadRateLimitInBitsPerSec' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 51200, + ), + 'AverageDownloadRateLimitInBitsPerSec' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 102400, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'UpdateChapCredentials' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'UpdateChapCredentialsOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.UpdateChapCredentials', + ), + 'TargetARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 800, + ), + 'SecretToAuthenticateInitiator' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 12, + 'maxLength' => 16, + ), + 'InitiatorName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 255, + ), + 'SecretToAuthenticateTarget' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 12, + 'maxLength' => 16, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'UpdateGatewayInformation' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'UpdateGatewayInformationOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.UpdateGatewayInformation', + ), + 'GatewayARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + 'GatewayName' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 2, + 'maxLength' => 255, + ), + 'GatewayTimezone' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 3, + 'maxLength' => 10, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'UpdateGatewaySoftwareNow' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'UpdateGatewaySoftwareNowOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.UpdateGatewaySoftwareNow', + ), + 'GatewayARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'UpdateMaintenanceStartTime' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'UpdateMaintenanceStartTimeOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.UpdateMaintenanceStartTime', + ), + 'GatewayARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + 'HourOfDay' => array( + 'required' => true, + 'type' => 'numeric', + 'location' => 'json', + 'maximum' => 23, + ), + 'MinuteOfHour' => array( + 'required' => true, + 'type' => 'numeric', + 'location' => 'json', + 'maximum' => 59, + ), + 'DayOfWeek' => array( + 'required' => true, + 'type' => 'numeric', + 'location' => 'json', + 'maximum' => 6, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + 'UpdateSnapshotSchedule' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'UpdateSnapshotScheduleOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'StorageGateway_20130630.UpdateSnapshotSchedule', + ), + 'VolumeARN' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 50, + 'maxLength' => 500, + ), + 'StartAt' => array( + 'required' => true, + 'type' => 'numeric', + 'location' => 'json', + 'maximum' => 23, + ), + 'RecurrenceInHours' => array( + 'required' => true, + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 1, + 'maximum' => 24, + ), + 'Description' => array( + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 255, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An exception occurred because an invalid gateway request was issued to the service. See the error and message fields for more information.', + 'class' => 'InvalidGatewayRequestException', + ), + array( + 'reason' => 'An internal server error has occurred during the request. See the error and message fields for more information.', + 'class' => 'InternalServerErrorException', + ), + ), + ), + ), + 'models' => array( + 'ActivateGatewayOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'GatewayARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'AddCacheOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'GatewayARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'AddUploadBufferOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'GatewayARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'AddWorkingStorageOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'GatewayARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'CancelArchivalOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'TapeARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'CancelRetrievalOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'TapeARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'CreateCachediSCSIVolumeOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'VolumeARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'TargetARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'CreateSnapshotOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'VolumeARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'SnapshotId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'CreateSnapshotFromVolumeRecoveryPointOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'SnapshotId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'VolumeARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'VolumeRecoveryPointTime' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'CreateStorediSCSIVolumeOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'VolumeARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'VolumeSizeInBytes' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'TargetARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'CreateTapesOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'TapeARNs' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'TapeARN', + 'type' => 'string', + ), + ), + ), + ), + 'DeleteBandwidthRateLimitOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'GatewayARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DeleteChapCredentialsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'TargetARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'InitiatorName' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DeleteGatewayOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'GatewayARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DeleteSnapshotScheduleOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'VolumeARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DeleteTapeOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'TapeARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DeleteTapeArchiveOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'TapeARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DeleteVolumeOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'VolumeARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DescribeBandwidthRateLimitOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'GatewayARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'AverageUploadRateLimitInBitsPerSec' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'AverageDownloadRateLimitInBitsPerSec' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + ), + ), + 'DescribeCacheOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'GatewayARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'DiskIds' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'DiskId', + 'type' => 'string', + ), + ), + 'CacheAllocatedInBytes' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'CacheUsedPercentage' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'CacheDirtyPercentage' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'CacheHitPercentage' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'CacheMissPercentage' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + ), + ), + 'DescribeCachediSCSIVolumesOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'CachediSCSIVolumes' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'CachediSCSIVolume', + 'type' => 'object', + 'properties' => array( + 'VolumeARN' => array( + 'type' => 'string', + ), + 'VolumeId' => array( + 'type' => 'string', + ), + 'VolumeType' => array( + 'type' => 'string', + ), + 'VolumeStatus' => array( + 'type' => 'string', + ), + 'VolumeSizeInBytes' => array( + 'type' => 'numeric', + ), + 'VolumeProgress' => array( + 'type' => 'numeric', + ), + 'SourceSnapshotId' => array( + 'type' => 'string', + ), + 'VolumeiSCSIAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'TargetARN' => array( + 'type' => 'string', + ), + 'NetworkInterfaceId' => array( + 'type' => 'string', + ), + 'NetworkInterfacePort' => array( + 'type' => 'numeric', + ), + 'LunNumber' => array( + 'type' => 'numeric', + ), + 'ChapEnabled' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + ), + ), + ), + 'DescribeChapCredentialsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'ChapCredentials' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'ChapInfo', + 'type' => 'object', + 'properties' => array( + 'TargetARN' => array( + 'type' => 'string', + ), + 'SecretToAuthenticateInitiator' => array( + 'type' => 'string', + ), + 'InitiatorName' => array( + 'type' => 'string', + ), + 'SecretToAuthenticateTarget' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'DescribeGatewayInformationOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'GatewayARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'GatewayId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'GatewayTimezone' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'GatewayState' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'GatewayNetworkInterfaces' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'NetworkInterface', + 'type' => 'object', + 'properties' => array( + 'Ipv4Address' => array( + 'type' => 'string', + ), + 'MacAddress' => array( + 'type' => 'string', + ), + 'Ipv6Address' => array( + 'type' => 'string', + ), + ), + ), + ), + 'GatewayType' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'NextUpdateAvailabilityDate' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DescribeMaintenanceStartTimeOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'GatewayARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'HourOfDay' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'MinuteOfHour' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'DayOfWeek' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'Timezone' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DescribeSnapshotScheduleOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'VolumeARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'StartAt' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'RecurrenceInHours' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'Description' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Timezone' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DescribeStorediSCSIVolumesOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'StorediSCSIVolumes' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'StorediSCSIVolume', + 'type' => 'object', + 'properties' => array( + 'VolumeARN' => array( + 'type' => 'string', + ), + 'VolumeId' => array( + 'type' => 'string', + ), + 'VolumeType' => array( + 'type' => 'string', + ), + 'VolumeStatus' => array( + 'type' => 'string', + ), + 'VolumeSizeInBytes' => array( + 'type' => 'numeric', + ), + 'VolumeProgress' => array( + 'type' => 'numeric', + ), + 'VolumeDiskId' => array( + 'type' => 'string', + ), + 'SourceSnapshotId' => array( + 'type' => 'string', + ), + 'PreservedExistingData' => array( + 'type' => 'boolean', + ), + 'VolumeiSCSIAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'TargetARN' => array( + 'type' => 'string', + ), + 'NetworkInterfaceId' => array( + 'type' => 'string', + ), + 'NetworkInterfacePort' => array( + 'type' => 'numeric', + ), + 'LunNumber' => array( + 'type' => 'numeric', + ), + 'ChapEnabled' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + ), + ), + ), + 'DescribeTapeArchivesOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'TapeArchives' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'TapeArchive', + 'type' => 'object', + 'properties' => array( + 'TapeARN' => array( + 'type' => 'string', + ), + 'TapeBarcode' => array( + 'type' => 'string', + ), + 'TapeSizeInBytes' => array( + 'type' => 'numeric', + ), + 'CompletionTime' => array( + 'type' => 'string', + ), + 'RetrievedTo' => array( + 'type' => 'string', + ), + 'TapeStatus' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DescribeTapeRecoveryPointsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'GatewayARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'TapeRecoveryPointInfos' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'TapeRecoveryPointInfo', + 'type' => 'object', + 'properties' => array( + 'TapeARN' => array( + 'type' => 'string', + ), + 'TapeRecoveryPointTime' => array( + 'type' => 'string', + ), + 'TapeSizeInBytes' => array( + 'type' => 'numeric', + ), + 'TapeStatus' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DescribeTapesOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Tapes' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Tape', + 'type' => 'object', + 'properties' => array( + 'TapeARN' => array( + 'type' => 'string', + ), + 'TapeBarcode' => array( + 'type' => 'string', + ), + 'TapeSizeInBytes' => array( + 'type' => 'numeric', + ), + 'TapeStatus' => array( + 'type' => 'string', + ), + 'VTLDevice' => array( + 'type' => 'string', + ), + 'Progress' => array( + 'type' => 'numeric', + ), + ), + ), + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DescribeUploadBufferOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'GatewayARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'DiskIds' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'DiskId', + 'type' => 'string', + ), + ), + 'UploadBufferUsedInBytes' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'UploadBufferAllocatedInBytes' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + ), + ), + 'DescribeVTLDevicesOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'GatewayARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'VTLDevices' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'VTLDevice', + 'type' => 'object', + 'properties' => array( + 'VTLDeviceARN' => array( + 'type' => 'string', + ), + 'VTLDeviceType' => array( + 'type' => 'string', + ), + 'VTLDeviceVendor' => array( + 'type' => 'string', + ), + 'VTLDeviceProductIdentifier' => array( + 'type' => 'string', + ), + 'DeviceiSCSIAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'TargetARN' => array( + 'type' => 'string', + ), + 'NetworkInterfaceId' => array( + 'type' => 'string', + ), + 'NetworkInterfacePort' => array( + 'type' => 'numeric', + ), + 'ChapEnabled' => array( + 'type' => 'boolean', + ), + ), + ), + ), + ), + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DescribeWorkingStorageOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'GatewayARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'DiskIds' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'DiskId', + 'type' => 'string', + ), + ), + 'WorkingStorageUsedInBytes' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'WorkingStorageAllocatedInBytes' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + ), + ), + 'DisableGatewayOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'GatewayARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListGatewaysOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'Gateways' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'GatewayInfo', + 'type' => 'object', + 'properties' => array( + 'GatewayARN' => array( + 'type' => 'string', + ), + 'GatewayType' => array( + 'type' => 'string', + ), + 'GatewayOperationalState' => array( + 'type' => 'string', + ), + ), + ), + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ListLocalDisksOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'GatewayARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Disks' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Disk', + 'type' => 'object', + 'properties' => array( + 'DiskId' => array( + 'type' => 'string', + ), + 'DiskPath' => array( + 'type' => 'string', + ), + 'DiskNode' => array( + 'type' => 'string', + ), + 'DiskSizeInBytes' => array( + 'type' => 'numeric', + ), + 'DiskAllocationType' => array( + 'type' => 'string', + ), + 'DiskAllocationResource' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'ListVolumeRecoveryPointsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'GatewayARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'VolumeRecoveryPointInfos' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'VolumeRecoveryPointInfo', + 'type' => 'object', + 'properties' => array( + 'VolumeARN' => array( + 'type' => 'string', + ), + 'VolumeSizeInBytes' => array( + 'type' => 'numeric', + ), + 'VolumeUsageInBytes' => array( + 'type' => 'numeric', + ), + 'VolumeRecoveryPointTime' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'ListVolumesOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'GatewayARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'Marker' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'VolumeInfos' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'VolumeInfo', + 'type' => 'object', + 'properties' => array( + 'VolumeARN' => array( + 'type' => 'string', + ), + 'VolumeType' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'RetrieveTapeArchiveOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'TapeARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'RetrieveTapeRecoveryPointOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'TapeARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ShutdownGatewayOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'GatewayARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'StartGatewayOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'GatewayARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'UpdateBandwidthRateLimitOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'GatewayARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'UpdateChapCredentialsOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'TargetARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'InitiatorName' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'UpdateGatewayInformationOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'GatewayARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'UpdateGatewaySoftwareNowOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'GatewayARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'UpdateMaintenanceStartTimeOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'GatewayARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'UpdateSnapshotScheduleOutput' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'VolumeARN' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + ), + 'iterators' => array( + '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-sdk-php/src/Aws/StorageGateway/StorageGatewayClient.php b/vendor/aws/aws-sdk-php/src/Aws/StorageGateway/StorageGatewayClient.php new file mode 100644 index 0000000..2bd0c27 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/StorageGateway/StorageGatewayClient.php @@ -0,0 +1,114 @@ +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-sdk-php/src/Aws/Sts/Exception/ExpiredTokenException.php b/vendor/aws/aws-sdk-php/src/Aws/Sts/Exception/ExpiredTokenException.php new file mode 100644 index 0000000..50a5d99 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/src/Aws/Sts/StsClient.php b/vendor/aws/aws-sdk-php/src/Aws/Sts/StsClient.php new file mode 100644 index 0000000..bc85303 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/Sts/StsClient.php @@ -0,0 +1,114 @@ +setConfig($config) + ->setConfigDefaults(array( + Options::VERSION => self::LATEST_API_VERSION, + Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/sts-%s.php' + )) + ->build(); + + // Attach a listener to prevent AssumeRoleWithWebIdentity requests from being signed + $client->getEventDispatcher()->addListener('command.before_send', function(Event $event) { + /** @var AbstractCommand $command */ + $command = $event['command']; + if ($command->getName() === 'AssumeRoleWithWebIdentity') { + /** @var EventDispatcher $dispatcher */ + $dispatcher = $command->getRequest()->getEventDispatcher(); + foreach ($dispatcher->getListeners('request.before_send') as $listener) { + if (is_array($listener) && $listener[0] instanceof SignatureListener) { + $dispatcher->removeListener('request.before_send', $listener); + break; + } + } + } + }); + + return $client; + } + + /** + * Creates a credentials object from the credential data return by an STS operation + * + * @param Model $result The result of an STS operation + * + * @return Credentials + * @throws InvalidArgumentException if the result does not contain credential data + */ + public function createCredentials(Model $result) + { + if (!$result->hasKey('Credentials')) { + throw new InvalidArgumentException('The modeled result provided contained no credentials.'); + } + + return new Credentials( + $result->getPath('Credentials/AccessKeyId'), + $result->getPath('Credentials/SecretAccessKey'), + $result->getPath('Credentials/SessionToken'), + $result->getPath('Credentials/Expiration') + ); + } +} diff --git a/vendor/aws/aws-sdk-php/src/Aws/Support/Exception/CaseCreationLimitExceededException.php b/vendor/aws/aws-sdk-php/src/Aws/Support/Exception/CaseCreationLimitExceededException.php new file mode 100644 index 0000000..9eaa3c6 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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( + 'AddCommunicationToCase' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'AddCommunicationToCaseResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AWSSupport_20130415.AddCommunicationToCase', + ), + 'caseId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'communicationBody' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 8000, + ), + 'ccEmailAddresses' => array( + 'type' => 'array', + 'location' => 'json', + 'maxItems' => 10, + 'items' => array( + 'name' => 'CcEmailAddress', + 'type' => 'string', + ), + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An internal server error occurred.', + 'class' => 'InternalServerErrorException', + ), + array( + 'reason' => 'The requested CaseId could not be located.', + 'class' => 'CaseIdNotFoundException', + ), + ), + ), + 'CreateCase' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'CreateCaseResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AWSSupport_20130415.CreateCase', + ), + 'subject' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + ), + 'serviceCode' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'severityCode' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'categoryCode' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'communicationBody' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 8000, + ), + 'ccEmailAddresses' => array( + 'type' => 'array', + 'location' => 'json', + 'maxItems' => 10, + 'items' => array( + 'name' => 'CcEmailAddress', + 'type' => 'string', + ), + ), + 'language' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'issueType' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'An internal server error occurred.', + 'class' => 'InternalServerErrorException', + ), + array( + 'reason' => 'The case creation limit for the account has been exceeded.', + 'class' => 'CaseCreationLimitExceededException', + ), + ), + ), + 'DescribeCases' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'DescribeCasesResponse', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.1', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'AWSSupport_20130415.DescribeCases', + ), + 'caseIdList' => array( + 'type' => 'array', + 'location' => 'json', + 'maxItems' => 100, + 'items' => array( + 'name' => 'CaseId', + 'type' => 'string', + ), + ), + 'displayId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'afterTime' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'beforeTime' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'includeResolvedCases' => array( + 'type' => 'boolean', + 'format' => 'boolean-string', + 'location' => 'json', + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'maxResults' => array( + 'type' => 'numeric', + 'location' => 'json', + 'minimum' => 10, + 'maximum' => 100, + ), + 'language' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + 'errorResponses' => array( + array( + 'reason' => '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( + 'AddCommunicationToCaseResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'result' => array( + 'type' => 'boolean', + 'location' => 'json', + ), + ), + ), + 'CreateCaseResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'caseId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DescribeCasesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'cases' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'CaseDetails', + 'type' => 'object', + 'properties' => array( + 'caseId' => array( + 'type' => 'string', + ), + 'displayId' => array( + 'type' => 'string', + ), + 'subject' => array( + 'type' => 'string', + ), + 'status' => array( + 'type' => 'string', + ), + 'serviceCode' => array( + 'type' => 'string', + ), + 'categoryCode' => array( + 'type' => 'string', + ), + 'severityCode' => array( + 'type' => 'string', + ), + 'submittedBy' => array( + 'type' => 'string', + ), + 'timeCreated' => array( + 'type' => 'string', + ), + 'recentCommunications' => array( + 'type' => 'object', + 'properties' => array( + 'communications' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Communication', + 'type' => 'object', + 'properties' => array( + 'caseId' => array( + 'type' => 'string', + ), + 'body' => array( + 'type' => 'string', + ), + 'submittedBy' => array( + 'type' => 'string', + ), + 'timeCreated' => array( + 'type' => 'string', + ), + ), + ), + ), + 'nextToken' => array( + 'type' => 'string', + ), + ), + ), + 'ccEmailAddresses' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'CcEmailAddress', + 'type' => 'string', + ), + ), + 'language' => array( + 'type' => 'string', + ), + ), + ), + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DescribeCommunicationsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'communications' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Communication', + 'type' => 'object', + 'properties' => array( + 'caseId' => array( + 'type' => 'string', + ), + 'body' => array( + 'type' => 'string', + ), + 'submittedBy' => array( + 'type' => 'string', + ), + 'timeCreated' => array( + 'type' => 'string', + ), + ), + ), + ), + 'nextToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DescribeServicesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'services' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'Service', + 'type' => 'object', + 'properties' => array( + 'code' => array( + 'type' => 'string', + ), + 'name' => array( + 'type' => 'string', + ), + 'categories' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Category', + 'type' => 'object', + 'properties' => array( + 'code' => array( + 'type' => 'string', + ), + 'name' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'DescribeSeverityLevelsResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'severityLevels' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'SeverityLevel', + 'type' => 'object', + 'properties' => array( + 'code' => array( + 'type' => 'string', + ), + 'name' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'DescribeTrustedAdvisorCheckRefreshStatusesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'statuses' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'TrustedAdvisorCheckRefreshStatus', + 'type' => 'object', + 'properties' => array( + 'checkId' => array( + 'type' => 'string', + ), + 'status' => array( + 'type' => 'string', + ), + 'millisUntilNextRefreshable' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + 'DescribeTrustedAdvisorCheckResultResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'result' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'checkId' => array( + 'type' => 'string', + ), + 'timestamp' => array( + 'type' => 'string', + ), + 'status' => array( + 'type' => 'string', + ), + 'resourcesSummary' => array( + 'type' => 'object', + 'properties' => array( + 'resourcesProcessed' => array( + 'type' => 'numeric', + ), + 'resourcesFlagged' => array( + 'type' => 'numeric', + ), + 'resourcesIgnored' => array( + 'type' => 'numeric', + ), + 'resourcesSuppressed' => array( + 'type' => 'numeric', + ), + ), + ), + 'categorySpecificSummary' => array( + 'type' => 'object', + 'properties' => array( + 'costOptimizing' => array( + 'type' => 'object', + 'properties' => array( + 'estimatedMonthlySavings' => array( + 'type' => 'numeric', + ), + 'estimatedPercentMonthlySavings' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + 'flaggedResources' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'TrustedAdvisorResourceDetail', + 'type' => 'object', + 'properties' => array( + 'status' => array( + 'type' => 'string', + ), + 'region' => array( + 'type' => 'string', + ), + 'resourceId' => array( + 'type' => 'string', + ), + 'isSuppressed' => array( + 'type' => 'boolean', + ), + 'metadata' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'DescribeTrustedAdvisorCheckSummariesResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'summaries' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'TrustedAdvisorCheckSummary', + 'type' => 'object', + 'properties' => array( + 'checkId' => array( + 'type' => 'string', + ), + 'timestamp' => array( + 'type' => 'string', + ), + 'status' => array( + 'type' => 'string', + ), + 'hasFlaggedResources' => array( + 'type' => 'boolean', + ), + 'resourcesSummary' => array( + 'type' => 'object', + 'properties' => array( + 'resourcesProcessed' => array( + 'type' => 'numeric', + ), + 'resourcesFlagged' => array( + 'type' => 'numeric', + ), + 'resourcesIgnored' => array( + 'type' => 'numeric', + ), + 'resourcesSuppressed' => array( + 'type' => 'numeric', + ), + ), + ), + 'categorySpecificSummary' => array( + 'type' => 'object', + 'properties' => array( + 'costOptimizing' => array( + 'type' => 'object', + 'properties' => array( + 'estimatedMonthlySavings' => array( + 'type' => 'numeric', + ), + 'estimatedPercentMonthlySavings' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + ), + ), + ), + ), + ), + 'DescribeTrustedAdvisorChecksResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'checks' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'TrustedAdvisorCheckDescription', + 'type' => 'object', + 'properties' => array( + 'id' => array( + 'type' => 'string', + ), + 'name' => array( + 'type' => 'string', + ), + 'description' => array( + 'type' => 'string', + ), + 'category' => array( + 'type' => 'string', + ), + 'metadata' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'String', + 'type' => 'string', + ), + ), + ), + ), + ), + ), + ), + 'RefreshTrustedAdvisorCheckResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'status' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'checkId' => array( + 'type' => 'string', + ), + 'status' => array( + 'type' => 'string', + ), + 'millisUntilNextRefreshable' => array( + 'type' => 'numeric', + ), + ), + ), + ), + ), + 'ResolveCaseResponse' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'initialCaseStatus' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'finalCaseStatus' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + ), + 'iterators' => array( + '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-sdk-php/src/Aws/Support/SupportClient.php b/vendor/aws/aws-sdk-php/src/Aws/Support/SupportClient.php new file mode 100644 index 0000000..b59029f --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/Aws/Support/SupportClient.php @@ -0,0 +1,76 @@ +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-sdk-php/src/Aws/Swf/Enum/ActivityTaskTimeoutType.php b/vendor/aws/aws-sdk-php/src/Aws/Swf/Enum/ActivityTaskTimeoutType.php new file mode 100644 index 0000000..c3a591f --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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, + ), + ), + ), + 'defaultTaskScheduleToStartTimeout' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 8, + ), + 'defaultTaskScheduleToCloseTimeout' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 8, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if the type already exists in the specified domain. You will get this fault even if the existing type is in deprecated status. You can specify another version if the intent is to create a new distinct version of the type.', + 'class' => 'TypeAlreadyExistsException', + ), + array( + 'reason' => 'Returned by any operation if a system imposed limitation has been reached. To address this fault you should either clean up unused resources or increase the limit by contacting AWS.', + 'class' => 'LimitExceededException', + ), + array( + 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', + 'class' => 'UnknownResourceException', + ), + array( + 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', + 'class' => 'OperationNotPermittedException', + ), + ), + ), + 'RegisterDomain' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.0', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'SimpleWorkflowService.RegisterDomain', + ), + 'name' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'description' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'workflowExecutionRetentionPeriodInDays' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 8, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned if the specified domain already exists. You will get this fault even if the existing domain is in deprecated status.', + 'class' => 'DomainAlreadyExistsException', + ), + array( + 'reason' => 'Returned by any operation if a system imposed limitation has been reached. To address this fault you should either clean up unused resources or increase the limit by contacting AWS.', + 'class' => 'LimitExceededException', + ), + array( + 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', + 'class' => 'OperationNotPermittedException', + ), + ), + ), + 'RegisterWorkflowType' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.0', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'SimpleWorkflowService.RegisterWorkflowType', + ), + 'domain' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'name' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'version' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 64, + ), + 'description' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 1024, + ), + 'defaultTaskStartToCloseTimeout' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 8, + ), + 'defaultExecutionStartToCloseTimeout' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 8, + ), + 'defaultTaskList' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'name' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + ), + ), + 'defaultChildPolicy' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + '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, + ), + ), + ), + 'scheduleToStartTimeout' => array( + 'type' => 'string', + 'maxLength' => 8, + ), + 'startToCloseTimeout' => array( + 'type' => 'string', + 'maxLength' => 8, + ), + 'heartbeatTimeout' => array( + 'type' => 'string', + 'maxLength' => 8, + ), + ), + ), + 'requestCancelActivityTaskDecisionAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'activityId' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + ), + ), + 'completeWorkflowExecutionDecisionAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'result' => array( + 'type' => 'string', + 'maxLength' => 32768, + ), + ), + ), + 'failWorkflowExecutionDecisionAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'reason' => array( + 'type' => 'string', + 'maxLength' => 256, + ), + 'details' => array( + 'type' => 'string', + 'maxLength' => 32768, + ), + ), + ), + 'cancelWorkflowExecutionDecisionAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'details' => array( + 'type' => 'string', + 'maxLength' => 32768, + ), + ), + ), + 'continueAsNewWorkflowExecutionDecisionAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'input' => array( + 'type' => 'string', + 'maxLength' => 32768, + ), + 'executionStartToCloseTimeout' => array( + 'type' => 'string', + 'maxLength' => 8, + ), + 'taskList' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + ), + ), + 'taskStartToCloseTimeout' => array( + 'type' => 'string', + 'maxLength' => 8, + ), + 'childPolicy' => array( + 'type' => 'string', + ), + 'tagList' => array( + 'type' => 'array', + 'maxItems' => 5, + 'items' => array( + 'name' => 'Tag', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + ), + 'workflowTypeVersion' => array( + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 64, + ), + ), + ), + 'recordMarkerDecisionAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'markerName' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'details' => array( + 'type' => 'string', + 'maxLength' => 32768, + ), + ), + ), + 'startTimerDecisionAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'timerId' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'control' => array( + 'type' => 'string', + 'maxLength' => 32768, + ), + 'startToFireTimeout' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 8, + ), + ), + ), + 'cancelTimerDecisionAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'timerId' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + ), + ), + 'signalExternalWorkflowExecutionDecisionAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'runId' => array( + 'type' => 'string', + 'maxLength' => 64, + ), + 'signalName' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'input' => array( + 'type' => 'string', + 'maxLength' => 32768, + ), + 'control' => array( + 'type' => 'string', + 'maxLength' => 32768, + ), + ), + ), + 'requestCancelExternalWorkflowExecutionDecisionAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'runId' => array( + 'type' => 'string', + 'maxLength' => 64, + ), + 'control' => array( + 'type' => 'string', + 'maxLength' => 32768, + ), + ), + ), + 'startChildWorkflowExecutionDecisionAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'workflowType' => array( + 'required' => true, + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'version' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 64, + ), + ), + ), + 'workflowId' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'control' => array( + 'type' => 'string', + 'maxLength' => 32768, + ), + 'input' => array( + 'type' => 'string', + 'maxLength' => 32768, + ), + 'executionStartToCloseTimeout' => array( + 'type' => 'string', + 'maxLength' => 8, + ), + 'taskList' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + ), + ), + 'taskStartToCloseTimeout' => array( + 'type' => 'string', + 'maxLength' => 8, + ), + 'childPolicy' => array( + 'type' => 'string', + ), + 'tagList' => array( + 'type' => 'array', + 'maxItems' => 5, + 'items' => array( + 'name' => 'Tag', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + ), + ), + ), + ), + ), + ), + 'executionContext' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 32768, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', + 'class' => 'UnknownResourceException', + ), + array( + 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', + 'class' => 'OperationNotPermittedException', + ), + ), + ), + 'SignalWorkflowExecution' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'EmptyOutput', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.0', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'SimpleWorkflowService.SignalWorkflowExecution', + ), + 'domain' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'workflowId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'runId' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 64, + ), + 'signalName' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'input' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 32768, + ), + ), + 'errorResponses' => array( + array( + 'reason' => 'Returned when the named resource cannot be found with in the scope of this operation (region or domain). This could happen if the named resource was never created or is no longer available for this operation.', + 'class' => 'UnknownResourceException', + ), + array( + 'reason' => 'Returned when the caller does not have sufficient permissions to invoke the action.', + 'class' => 'OperationNotPermittedException', + ), + ), + ), + 'StartWorkflowExecution' => array( + 'httpMethod' => 'POST', + 'uri' => '/', + 'class' => 'Aws\\Common\\Command\\JsonCommand', + 'responseClass' => 'Run', + 'responseType' => 'model', + 'parameters' => array( + 'Content-Type' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'application/x-amz-json-1.0', + ), + 'command.expects' => array( + 'static' => true, + 'default' => 'application/json', + ), + 'X-Amz-Target' => array( + 'static' => true, + 'location' => 'header', + 'default' => 'SimpleWorkflowService.StartWorkflowExecution', + ), + 'domain' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'workflowId' => array( + 'required' => true, + 'type' => 'string', + 'location' => 'json', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'workflowType' => array( + 'required' => true, + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'name' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + 'version' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 64, + ), + ), + ), + 'taskList' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'name' => array( + 'required' => true, + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + ), + ), + 'input' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 32768, + ), + 'executionStartToCloseTimeout' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 8, + ), + 'tagList' => array( + 'type' => 'array', + 'location' => 'json', + 'maxItems' => 5, + 'items' => array( + 'name' => 'Tag', + 'type' => 'string', + 'minLength' => 1, + 'maxLength' => 256, + ), + ), + 'taskStartToCloseTimeout' => array( + 'type' => 'string', + 'location' => 'json', + 'maxLength' => 8, + ), + 'childPolicy' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + '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', + ), + ), + ), + 'defaultTaskScheduleToStartTimeout' => array( + 'type' => 'string', + ), + 'defaultTaskScheduleToCloseTimeout' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'DomainDetail' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'domainInfo' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'status' => array( + 'type' => 'string', + ), + 'description' => array( + 'type' => 'string', + ), + ), + ), + 'configuration' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'workflowExecutionRetentionPeriodInDays' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'WorkflowExecutionDetail' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'executionInfo' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'execution' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + ), + ), + 'workflowType' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + ), + ), + 'startTimestamp' => array( + 'type' => 'string', + ), + 'closeTimestamp' => array( + 'type' => 'string', + ), + 'executionStatus' => array( + 'type' => 'string', + ), + 'closeStatus' => array( + 'type' => 'string', + ), + 'parent' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + ), + ), + 'tagList' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'string', + ), + ), + 'cancelRequested' => array( + 'type' => 'boolean', + ), + ), + ), + 'executionConfiguration' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'taskStartToCloseTimeout' => array( + 'type' => 'string', + ), + 'executionStartToCloseTimeout' => array( + 'type' => 'string', + ), + 'taskList' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + ), + ), + 'childPolicy' => array( + 'type' => 'string', + ), + ), + ), + 'openCounts' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'openActivityTasks' => array( + 'type' => 'numeric', + ), + 'openDecisionTasks' => array( + 'type' => 'numeric', + ), + 'openTimers' => array( + 'type' => 'numeric', + ), + 'openChildWorkflowExecutions' => array( + 'type' => 'numeric', + ), + ), + ), + 'latestActivityTaskTimestamp' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'latestExecutionContext' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'WorkflowTypeDetail' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'typeInfo' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'workflowType' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + ), + ), + 'status' => array( + 'type' => 'string', + ), + 'description' => array( + 'type' => 'string', + ), + 'creationDate' => array( + 'type' => 'string', + ), + 'deprecationDate' => array( + 'type' => 'string', + ), + ), + ), + 'configuration' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'defaultTaskStartToCloseTimeout' => array( + 'type' => 'string', + ), + 'defaultExecutionStartToCloseTimeout' => array( + 'type' => 'string', + ), + 'defaultTaskList' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + ), + ), + 'defaultChildPolicy' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'History' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'events' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'HistoryEvent', + 'type' => 'object', + 'properties' => array( + 'eventTimestamp' => array( + 'type' => 'string', + ), + 'eventType' => array( + 'type' => 'string', + ), + 'eventId' => array( + 'type' => 'numeric', + ), + 'workflowExecutionStartedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'input' => array( + 'type' => 'string', + ), + 'executionStartToCloseTimeout' => array( + 'type' => 'string', + ), + 'taskStartToCloseTimeout' => array( + 'type' => 'string', + ), + 'childPolicy' => array( + 'type' => 'string', + ), + 'taskList' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + ), + ), + 'workflowType' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + ), + ), + 'tagList' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'string', + ), + ), + 'continuedExecutionRunId' => array( + 'type' => 'string', + ), + 'parentWorkflowExecution' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + ), + ), + 'parentInitiatedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'workflowExecutionCompletedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'result' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'completeWorkflowExecutionFailedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'cause' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'workflowExecutionFailedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'reason' => array( + 'type' => 'string', + ), + 'details' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'failWorkflowExecutionFailedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'cause' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'workflowExecutionTimedOutEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'timeoutType' => array( + 'type' => 'string', + ), + 'childPolicy' => array( + 'type' => 'string', + ), + ), + ), + 'workflowExecutionCanceledEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'details' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'cancelWorkflowExecutionFailedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'cause' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'workflowExecutionContinuedAsNewEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'input' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + 'newExecutionRunId' => array( + 'type' => 'string', + ), + 'executionStartToCloseTimeout' => array( + 'type' => 'string', + ), + 'taskList' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + ), + ), + 'taskStartToCloseTimeout' => array( + 'type' => 'string', + ), + 'childPolicy' => array( + 'type' => 'string', + ), + 'tagList' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'string', + ), + ), + 'workflowType' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'continueAsNewWorkflowExecutionFailedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'cause' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'workflowExecutionTerminatedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'reason' => array( + 'type' => 'string', + ), + 'details' => array( + 'type' => 'string', + ), + 'childPolicy' => array( + 'type' => 'string', + ), + 'cause' => array( + 'type' => 'string', + ), + ), + ), + 'workflowExecutionCancelRequestedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'externalWorkflowExecution' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + ), + ), + 'externalInitiatedEventId' => array( + 'type' => 'numeric', + ), + 'cause' => array( + 'type' => 'string', + ), + ), + ), + 'decisionTaskScheduledEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'taskList' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + ), + ), + 'startToCloseTimeout' => array( + 'type' => 'string', + ), + ), + ), + 'decisionTaskStartedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'identity' => array( + 'type' => 'string', + ), + 'scheduledEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'decisionTaskCompletedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'executionContext' => array( + 'type' => 'string', + ), + 'scheduledEventId' => array( + 'type' => 'numeric', + ), + 'startedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'decisionTaskTimedOutEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'timeoutType' => array( + 'type' => 'string', + ), + 'scheduledEventId' => array( + 'type' => 'numeric', + ), + 'startedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'activityTaskScheduledEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'activityType' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + ), + ), + 'activityId' => array( + 'type' => 'string', + ), + 'input' => array( + 'type' => 'string', + ), + 'control' => array( + 'type' => 'string', + ), + 'scheduleToStartTimeout' => array( + 'type' => 'string', + ), + 'scheduleToCloseTimeout' => array( + 'type' => 'string', + ), + 'startToCloseTimeout' => array( + 'type' => 'string', + ), + 'taskList' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + ), + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + 'heartbeatTimeout' => array( + 'type' => 'string', + ), + ), + ), + 'activityTaskStartedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'identity' => array( + 'type' => 'string', + ), + 'scheduledEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'activityTaskCompletedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'result' => array( + 'type' => 'string', + ), + 'scheduledEventId' => array( + 'type' => 'numeric', + ), + 'startedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'activityTaskFailedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'reason' => array( + 'type' => 'string', + ), + 'details' => array( + 'type' => 'string', + ), + 'scheduledEventId' => array( + 'type' => 'numeric', + ), + 'startedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'activityTaskTimedOutEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'timeoutType' => array( + 'type' => 'string', + ), + 'scheduledEventId' => array( + 'type' => 'numeric', + ), + 'startedEventId' => array( + 'type' => 'numeric', + ), + 'details' => array( + 'type' => 'string', + ), + ), + ), + 'activityTaskCanceledEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'details' => array( + 'type' => 'string', + ), + 'scheduledEventId' => array( + 'type' => 'numeric', + ), + 'startedEventId' => array( + 'type' => 'numeric', + ), + 'latestCancelRequestedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'activityTaskCancelRequestedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + 'activityId' => array( + 'type' => 'string', + ), + ), + ), + 'workflowExecutionSignaledEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'signalName' => array( + 'type' => 'string', + ), + 'input' => array( + 'type' => 'string', + ), + 'externalWorkflowExecution' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + ), + ), + 'externalInitiatedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'markerRecordedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'markerName' => array( + 'type' => 'string', + ), + 'details' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'recordMarkerFailedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'markerName' => array( + 'type' => 'string', + ), + 'cause' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'timerStartedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'timerId' => array( + 'type' => 'string', + ), + 'control' => array( + 'type' => 'string', + ), + 'startToFireTimeout' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'timerFiredEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'timerId' => array( + 'type' => 'string', + ), + 'startedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'timerCanceledEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'timerId' => array( + 'type' => 'string', + ), + 'startedEventId' => array( + 'type' => 'numeric', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'startChildWorkflowExecutionInitiatedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'workflowType' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + ), + ), + 'control' => array( + 'type' => 'string', + ), + 'input' => array( + 'type' => 'string', + ), + 'executionStartToCloseTimeout' => array( + 'type' => 'string', + ), + 'taskList' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + ), + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + 'childPolicy' => array( + 'type' => 'string', + ), + 'taskStartToCloseTimeout' => array( + 'type' => 'string', + ), + 'tagList' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'string', + ), + ), + ), + ), + 'childWorkflowExecutionStartedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'workflowExecution' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + ), + ), + 'workflowType' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + ), + ), + 'initiatedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'childWorkflowExecutionCompletedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'workflowExecution' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + ), + ), + 'workflowType' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + ), + ), + 'result' => array( + 'type' => 'string', + ), + 'initiatedEventId' => array( + 'type' => 'numeric', + ), + 'startedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'childWorkflowExecutionFailedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'workflowExecution' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + ), + ), + 'workflowType' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + ), + ), + 'reason' => array( + 'type' => 'string', + ), + 'details' => array( + 'type' => 'string', + ), + 'initiatedEventId' => array( + 'type' => 'numeric', + ), + 'startedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'childWorkflowExecutionTimedOutEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'workflowExecution' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + ), + ), + 'workflowType' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + ), + ), + 'timeoutType' => array( + 'type' => 'string', + ), + 'initiatedEventId' => array( + 'type' => 'numeric', + ), + 'startedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'childWorkflowExecutionCanceledEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'workflowExecution' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + ), + ), + 'workflowType' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + ), + ), + 'details' => array( + 'type' => 'string', + ), + 'initiatedEventId' => array( + 'type' => 'numeric', + ), + 'startedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'childWorkflowExecutionTerminatedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'workflowExecution' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + ), + ), + 'workflowType' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + ), + ), + 'initiatedEventId' => array( + 'type' => 'numeric', + ), + 'startedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'signalExternalWorkflowExecutionInitiatedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + 'signalName' => array( + 'type' => 'string', + ), + 'input' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + 'control' => array( + 'type' => 'string', + ), + ), + ), + 'externalWorkflowExecutionSignaledEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'workflowExecution' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + ), + ), + 'initiatedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'signalExternalWorkflowExecutionFailedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + 'cause' => array( + 'type' => 'string', + ), + 'initiatedEventId' => array( + 'type' => 'numeric', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + 'control' => array( + 'type' => 'string', + ), + ), + ), + 'externalWorkflowExecutionCancelRequestedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'workflowExecution' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + ), + ), + 'initiatedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'requestCancelExternalWorkflowExecutionInitiatedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + 'control' => array( + 'type' => 'string', + ), + ), + ), + 'requestCancelExternalWorkflowExecutionFailedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + 'cause' => array( + 'type' => 'string', + ), + 'initiatedEventId' => array( + 'type' => 'numeric', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + 'control' => array( + 'type' => 'string', + ), + ), + ), + 'scheduleActivityTaskFailedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'activityType' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + ), + ), + 'activityId' => array( + 'type' => 'string', + ), + 'cause' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'requestCancelActivityTaskFailedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'activityId' => array( + 'type' => 'string', + ), + 'cause' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'startTimerFailedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'timerId' => array( + 'type' => 'string', + ), + 'cause' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'cancelTimerFailedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'timerId' => array( + 'type' => 'string', + ), + 'cause' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'startChildWorkflowExecutionFailedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'workflowType' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + ), + ), + 'cause' => array( + 'type' => 'string', + ), + 'workflowId' => array( + 'type' => 'string', + ), + 'initiatedEventId' => array( + 'type' => 'numeric', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + 'control' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'nextPageToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ActivityTypeInfos' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'typeInfos' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'ActivityTypeInfo', + 'type' => 'object', + 'properties' => array( + 'activityType' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + ), + ), + 'status' => array( + 'type' => 'string', + ), + 'description' => array( + 'type' => 'string', + ), + 'creationDate' => array( + 'type' => 'string', + ), + 'deprecationDate' => array( + 'type' => 'string', + ), + ), + ), + ), + 'nextPageToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'WorkflowExecutionInfos' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'executionInfos' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'WorkflowExecutionInfo', + 'type' => 'object', + 'properties' => array( + 'execution' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + ), + ), + 'workflowType' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + ), + ), + 'startTimestamp' => array( + 'type' => 'string', + ), + 'closeTimestamp' => array( + 'type' => 'string', + ), + 'executionStatus' => array( + 'type' => 'string', + ), + 'closeStatus' => array( + 'type' => 'string', + ), + 'parent' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + ), + ), + 'tagList' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'string', + ), + ), + 'cancelRequested' => array( + 'type' => 'boolean', + ), + ), + ), + ), + 'nextPageToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DomainInfos' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'domainInfos' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'DomainInfo', + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'status' => array( + 'type' => 'string', + ), + 'description' => array( + 'type' => 'string', + ), + ), + ), + ), + 'nextPageToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'WorkflowTypeInfos' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'typeInfos' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'WorkflowTypeInfo', + 'type' => 'object', + 'properties' => array( + 'workflowType' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + ), + ), + 'status' => array( + 'type' => 'string', + ), + 'description' => array( + 'type' => 'string', + ), + 'creationDate' => array( + 'type' => 'string', + ), + 'deprecationDate' => array( + 'type' => 'string', + ), + ), + ), + ), + 'nextPageToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'ActivityTask' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'taskToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'activityId' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'startedEventId' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'workflowExecution' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + ), + ), + 'activityType' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + ), + ), + 'input' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + 'DecisionTask' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'taskToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'startedEventId' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + 'workflowExecution' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + ), + ), + 'workflowType' => array( + 'type' => 'object', + 'location' => 'json', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + ), + ), + 'events' => array( + 'type' => 'array', + 'location' => 'json', + 'items' => array( + 'name' => 'HistoryEvent', + 'type' => 'object', + 'properties' => array( + 'eventTimestamp' => array( + 'type' => 'string', + ), + 'eventType' => array( + 'type' => 'string', + ), + 'eventId' => array( + 'type' => 'numeric', + ), + 'workflowExecutionStartedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'input' => array( + 'type' => 'string', + ), + 'executionStartToCloseTimeout' => array( + 'type' => 'string', + ), + 'taskStartToCloseTimeout' => array( + 'type' => 'string', + ), + 'childPolicy' => array( + 'type' => 'string', + ), + 'taskList' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + ), + ), + 'workflowType' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + ), + ), + 'tagList' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'string', + ), + ), + 'continuedExecutionRunId' => array( + 'type' => 'string', + ), + 'parentWorkflowExecution' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + ), + ), + 'parentInitiatedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'workflowExecutionCompletedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'result' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'completeWorkflowExecutionFailedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'cause' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'workflowExecutionFailedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'reason' => array( + 'type' => 'string', + ), + 'details' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'failWorkflowExecutionFailedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'cause' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'workflowExecutionTimedOutEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'timeoutType' => array( + 'type' => 'string', + ), + 'childPolicy' => array( + 'type' => 'string', + ), + ), + ), + 'workflowExecutionCanceledEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'details' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'cancelWorkflowExecutionFailedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'cause' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'workflowExecutionContinuedAsNewEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'input' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + 'newExecutionRunId' => array( + 'type' => 'string', + ), + 'executionStartToCloseTimeout' => array( + 'type' => 'string', + ), + 'taskList' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + ), + ), + 'taskStartToCloseTimeout' => array( + 'type' => 'string', + ), + 'childPolicy' => array( + 'type' => 'string', + ), + 'tagList' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'string', + ), + ), + 'workflowType' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + 'continueAsNewWorkflowExecutionFailedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'cause' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'workflowExecutionTerminatedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'reason' => array( + 'type' => 'string', + ), + 'details' => array( + 'type' => 'string', + ), + 'childPolicy' => array( + 'type' => 'string', + ), + 'cause' => array( + 'type' => 'string', + ), + ), + ), + 'workflowExecutionCancelRequestedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'externalWorkflowExecution' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + ), + ), + 'externalInitiatedEventId' => array( + 'type' => 'numeric', + ), + 'cause' => array( + 'type' => 'string', + ), + ), + ), + 'decisionTaskScheduledEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'taskList' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + ), + ), + 'startToCloseTimeout' => array( + 'type' => 'string', + ), + ), + ), + 'decisionTaskStartedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'identity' => array( + 'type' => 'string', + ), + 'scheduledEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'decisionTaskCompletedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'executionContext' => array( + 'type' => 'string', + ), + 'scheduledEventId' => array( + 'type' => 'numeric', + ), + 'startedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'decisionTaskTimedOutEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'timeoutType' => array( + 'type' => 'string', + ), + 'scheduledEventId' => array( + 'type' => 'numeric', + ), + 'startedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'activityTaskScheduledEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'activityType' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + ), + ), + 'activityId' => array( + 'type' => 'string', + ), + 'input' => array( + 'type' => 'string', + ), + 'control' => array( + 'type' => 'string', + ), + 'scheduleToStartTimeout' => array( + 'type' => 'string', + ), + 'scheduleToCloseTimeout' => array( + 'type' => 'string', + ), + 'startToCloseTimeout' => array( + 'type' => 'string', + ), + 'taskList' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + ), + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + 'heartbeatTimeout' => array( + 'type' => 'string', + ), + ), + ), + 'activityTaskStartedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'identity' => array( + 'type' => 'string', + ), + 'scheduledEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'activityTaskCompletedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'result' => array( + 'type' => 'string', + ), + 'scheduledEventId' => array( + 'type' => 'numeric', + ), + 'startedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'activityTaskFailedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'reason' => array( + 'type' => 'string', + ), + 'details' => array( + 'type' => 'string', + ), + 'scheduledEventId' => array( + 'type' => 'numeric', + ), + 'startedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'activityTaskTimedOutEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'timeoutType' => array( + 'type' => 'string', + ), + 'scheduledEventId' => array( + 'type' => 'numeric', + ), + 'startedEventId' => array( + 'type' => 'numeric', + ), + 'details' => array( + 'type' => 'string', + ), + ), + ), + 'activityTaskCanceledEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'details' => array( + 'type' => 'string', + ), + 'scheduledEventId' => array( + 'type' => 'numeric', + ), + 'startedEventId' => array( + 'type' => 'numeric', + ), + 'latestCancelRequestedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'activityTaskCancelRequestedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + 'activityId' => array( + 'type' => 'string', + ), + ), + ), + 'workflowExecutionSignaledEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'signalName' => array( + 'type' => 'string', + ), + 'input' => array( + 'type' => 'string', + ), + 'externalWorkflowExecution' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + ), + ), + 'externalInitiatedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'markerRecordedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'markerName' => array( + 'type' => 'string', + ), + 'details' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'recordMarkerFailedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'markerName' => array( + 'type' => 'string', + ), + 'cause' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'timerStartedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'timerId' => array( + 'type' => 'string', + ), + 'control' => array( + 'type' => 'string', + ), + 'startToFireTimeout' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'timerFiredEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'timerId' => array( + 'type' => 'string', + ), + 'startedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'timerCanceledEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'timerId' => array( + 'type' => 'string', + ), + 'startedEventId' => array( + 'type' => 'numeric', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'startChildWorkflowExecutionInitiatedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'workflowType' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + ), + ), + 'control' => array( + 'type' => 'string', + ), + 'input' => array( + 'type' => 'string', + ), + 'executionStartToCloseTimeout' => array( + 'type' => 'string', + ), + 'taskList' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + ), + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + 'childPolicy' => array( + 'type' => 'string', + ), + 'taskStartToCloseTimeout' => array( + 'type' => 'string', + ), + 'tagList' => array( + 'type' => 'array', + 'items' => array( + 'name' => 'Tag', + 'type' => 'string', + ), + ), + ), + ), + 'childWorkflowExecutionStartedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'workflowExecution' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + ), + ), + 'workflowType' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + ), + ), + 'initiatedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'childWorkflowExecutionCompletedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'workflowExecution' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + ), + ), + 'workflowType' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + ), + ), + 'result' => array( + 'type' => 'string', + ), + 'initiatedEventId' => array( + 'type' => 'numeric', + ), + 'startedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'childWorkflowExecutionFailedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'workflowExecution' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + ), + ), + 'workflowType' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + ), + ), + 'reason' => array( + 'type' => 'string', + ), + 'details' => array( + 'type' => 'string', + ), + 'initiatedEventId' => array( + 'type' => 'numeric', + ), + 'startedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'childWorkflowExecutionTimedOutEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'workflowExecution' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + ), + ), + 'workflowType' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + ), + ), + 'timeoutType' => array( + 'type' => 'string', + ), + 'initiatedEventId' => array( + 'type' => 'numeric', + ), + 'startedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'childWorkflowExecutionCanceledEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'workflowExecution' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + ), + ), + 'workflowType' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + ), + ), + 'details' => array( + 'type' => 'string', + ), + 'initiatedEventId' => array( + 'type' => 'numeric', + ), + 'startedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'childWorkflowExecutionTerminatedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'workflowExecution' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + ), + ), + 'workflowType' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + ), + ), + 'initiatedEventId' => array( + 'type' => 'numeric', + ), + 'startedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'signalExternalWorkflowExecutionInitiatedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + 'signalName' => array( + 'type' => 'string', + ), + 'input' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + 'control' => array( + 'type' => 'string', + ), + ), + ), + 'externalWorkflowExecutionSignaledEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'workflowExecution' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + ), + ), + 'initiatedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'signalExternalWorkflowExecutionFailedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + 'cause' => array( + 'type' => 'string', + ), + 'initiatedEventId' => array( + 'type' => 'numeric', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + 'control' => array( + 'type' => 'string', + ), + ), + ), + 'externalWorkflowExecutionCancelRequestedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'workflowExecution' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + ), + ), + 'initiatedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'requestCancelExternalWorkflowExecutionInitiatedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + 'control' => array( + 'type' => 'string', + ), + ), + ), + 'requestCancelExternalWorkflowExecutionFailedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'workflowId' => array( + 'type' => 'string', + ), + 'runId' => array( + 'type' => 'string', + ), + 'cause' => array( + 'type' => 'string', + ), + 'initiatedEventId' => array( + 'type' => 'numeric', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + 'control' => array( + 'type' => 'string', + ), + ), + ), + 'scheduleActivityTaskFailedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'activityType' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + ), + ), + 'activityId' => array( + 'type' => 'string', + ), + 'cause' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'requestCancelActivityTaskFailedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'activityId' => array( + 'type' => 'string', + ), + 'cause' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'startTimerFailedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'timerId' => array( + 'type' => 'string', + ), + 'cause' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'cancelTimerFailedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'timerId' => array( + 'type' => 'string', + ), + 'cause' => array( + 'type' => 'string', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + ), + ), + 'startChildWorkflowExecutionFailedEventAttributes' => array( + 'type' => 'object', + 'properties' => array( + 'workflowType' => array( + 'type' => 'object', + 'properties' => array( + 'name' => array( + 'type' => 'string', + ), + 'version' => array( + 'type' => 'string', + ), + ), + ), + 'cause' => array( + 'type' => 'string', + ), + 'workflowId' => array( + 'type' => 'string', + ), + 'initiatedEventId' => array( + 'type' => 'numeric', + ), + 'decisionTaskCompletedEventId' => array( + 'type' => 'numeric', + ), + 'control' => array( + 'type' => 'string', + ), + ), + ), + ), + ), + ), + 'nextPageToken' => array( + 'type' => 'string', + 'location' => 'json', + ), + 'previousStartedEventId' => array( + 'type' => 'numeric', + 'location' => 'json', + ), + ), + ), + 'ActivityTaskStatus' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'cancelRequested' => array( + 'type' => 'boolean', + 'location' => 'json', + ), + ), + ), + 'Run' => array( + 'type' => 'object', + 'additionalProperties' => true, + 'properties' => array( + 'runId' => array( + 'type' => 'string', + 'location' => 'json', + ), + ), + ), + ), + 'iterators' => array( + '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-sdk-php/src/Aws/Swf/SwfClient.php b/vendor/aws/aws-sdk-php/src/Aws/Swf/SwfClient.php new file mode 100644 index 0000000..dc3a064 --- /dev/null +++ b/vendor/aws/aws-sdk-php/src/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-sdk-php/test_services.json.dist b/vendor/aws/aws-sdk-php/test_services.json.dist new file mode 100644 index 0000000..5a2778d --- /dev/null +++ b/vendor/aws/aws-sdk-php/test_services.json.dist @@ -0,0 +1,20 @@ +{ + "includes": ["_aws"], + "services": { + "default_settings": { + "params": { + "key": "change_me", + "secret": "change_me", + "region": "us-east-1", + "ssl.certificate_authority": true + } + }, + "cloudfront": { + "extends": "cloudfront", + "params": { + "private_key": "change_me", + "key_pair_id": "change_me" + } + } + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/AutoScaling/AutoScalingClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/AutoScaling/AutoScalingClientTest.php new file mode 100644 index 0000000..71c97ac --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/AutoScaling/AutoScalingClientTest.php @@ -0,0 +1,38 @@ + 'foo', + 'secret' => 'bar', + 'region' => 'us-west-2' + )); + + $this->assertInstanceOf('Aws\Common\Signature\SignatureV4', $client->getSignature()); + $this->assertInstanceOf('Aws\Common\Credentials\Credentials', $client->getCredentials()); + $this->assertEquals('https://autoscaling.us-west-2.amazonaws.com', $client->getBaseUrl()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/AutoScaling/Integration/AutoScaling_20110101_Test.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/AutoScaling/Integration/AutoScaling_20110101_Test.php new file mode 100644 index 0000000..7e916a5 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/AutoScaling/Integration/AutoScaling_20110101_Test.php @@ -0,0 +1,124 @@ +autoscaling = $this->getServiceBuilder()->get('autoscaling'); + } + + /** + * CreateLaunchConfiguration + * + * @example Aws\AutoScaling\AutoScalingClient::createLaunchConfiguration + * @example Aws\AutoScaling\AutoScalingClient::createLaunchConfiguration + */ + public function testCreateLaunchConfiguration() + { + $launchConfigName = self::LAUNCH_NAME; + $client = $this->autoscaling; + self::log('Create a launch configuration.'); + + // @begin + $client->createLaunchConfiguration(array( + 'LaunchConfigurationName' => $launchConfigName, + 'ImageId' => self::TEST_AMI, + 'InstanceType' => InstanceType::M1_SMALL, + )); + } + + /** + * Iterate over the results of DescribeLaunchConfigurations + * + * @example Aws\AutoScaling\AutoScalingClient::describeLaunchConfigurations + * @depends testCreateLaunchConfiguration + */ + public function testListsLaunchConfigs() + { + $client = $this->autoscaling; + self::log('Make sure iterators work by iterating launch configurations.'); + // @begin + $iterator = $client->getIterator('DescribeLaunchConfigurations'); + foreach ($iterator as $launchConfig) { + var_export($launchConfig); + } + // end + $iterator->rewind(); + $configs = $iterator->toArray(); + $this->assertGreaterThanOrEqual(1, $configs); + $this->assertArrayHasKey('LaunchConfigurationName', $configs[0]); + } + + /** + * @depends testListsLaunchConfigs + */ + public function testHandlesErrors() + { + $launchConfigName = self::LAUNCH_NAME; + $client = $this->autoscaling; + + // @begin + // Create a launch configuration with error handling + try { + $client->createLaunchConfiguration(array( + 'LaunchConfigurationName' => $launchConfigName, + 'ImageId' => self::TEST_AMI, + 'InstanceType' => InstanceType::M1_SMALL, + )); + $this->fail('An exception should have been thrown'); + } catch (\Aws\AutoScaling\Exception\AutoScalingException $e) { + if ($e->getCode() == 'AlreadyExists') { + $this->assertInstanceOf('Aws\AutoScaling\Exception\AlreadyExistsException', $e); + } else { + throw $e; + } + } + } + + /** + * Delete a launch configuration + * + * @example Aws\AutoScaling\AutoScalingClient::deleteLaunchConfiguration + * @depends testHandlesErrors + */ + public function testDeletesLaunchConfigs() + { + $launchConfigName = self::LAUNCH_NAME; + $client = $this->autoscaling; + self::log('Delete the launch configuration.'); + + // @begin + $client->deleteLaunchConfiguration(array( + 'LaunchConfigurationName' => $launchConfigName, + )); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudFormation/CloudFormationClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudFormation/CloudFormationClientTest.php new file mode 100644 index 0000000..dd10cc9 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudFormation/CloudFormationClientTest.php @@ -0,0 +1,38 @@ + 'foo', + 'secret' => 'bar', + 'region' => 'us-west-2' + )); + + $this->assertInstanceOf('Aws\Common\Signature\SignatureV4', $client->getSignature()); + $this->assertInstanceOf('Aws\Common\Credentials\Credentials', $client->getCredentials()); + $this->assertEquals('https://cloudformation.us-west-2.amazonaws.com', $client->getBaseUrl()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudFormation/Integration/CloudFormation_20100515_Test.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudFormation/Integration/CloudFormation_20100515_Test.php new file mode 100644 index 0000000..060fd83 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudFormation/Integration/CloudFormation_20100515_Test.php @@ -0,0 +1,81 @@ +client = $this->getServiceBuilder()->get('cloudformation', true); + } + + /** + * Ensures that the client marshals correctly + * + * @example Aws\CloudFormation\CloudFormationClient::estimateTemplateCost + */ + public function testEstimatesTemplateCosts() + { + self::log('Estimate a template\'s cost.'); + $client = $this->client; + $templateBody = file_get_contents(__DIR__ . '/template.json'); + + // @begin + $result = $client->estimateTemplateCost(array( + 'TemplateBody' => $templateBody, + 'Parameters' => array( + array('ParameterKey' => 'KeyName', 'ParameterValue' => 'keypair-name'), + ), + )); + + echo 'Result URL: ' . $result['Url'] . "\n"; + // @end + + $url = Url::factory($result['Url']); + $this->assertEquals('calculator.s3.amazonaws.com', $url->getHost()); + } + + /** + * Iterate over the results of a ListStacks operation + * + * @example Aws\CloudFormation\CloudFormationClient::listStacks + */ + public function testListStacksCommandAndIterator() + { + self::log('Execute a ListJobs command and iterator and verify that the results are the same.'); + $client = $this->client; + // @begin + $result = $this->client->listStacks(); + $stacks = $result['StackSummaries']; + + // Or load the stacks as an iterator + $iterator = $client->getIterator('ListStacks'); + $stacks = $iterator->toArray(); + // @end + $this->assertNotNull($stacks); + $this->assertEquals($result['StackSummaries'], $stacks); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudFormation/Integration/template.json b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudFormation/Integration/template.json new file mode 100644 index 0000000..2bc5414 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudFormation/Integration/template.json @@ -0,0 +1,176 @@ +{ + "AWSTemplateFormatVersion" : "2010-09-09", + + "Description" : "Create a multi-az, load balanced, Auto Scaled sample web site. The Auto Scaling trigger is based on the CPU utilization of the web servers. The AMI is chosen based on the region in which the stack is run. This example creates a web service running across all availability zones in a region. The instances are load balanced with a simple health check. The web site is available on port 80, however, the instances can be configured to listen on any port (8888 by default). **WARNING** This template creates one or more Amazon EC2 instances. You will be billed for the AWS resources used if you create a stack from this template.", + + "Parameters" : { + "InstanceType" : { + "Description" : "Type of EC2 instance to launch", + "Type" : "String", + "Default" : "m1.small" + }, + "WebServerPort" : { + "Description" : "The TCP port for the Web Server", + "Type" : "String", + "Default" : "8888" + }, + "KeyName" : { + "Description" : "The EC2 Key Pair to allow SSH access to the instances", + "Type" : "String" + } + }, + + "Mappings" : { + "AWSInstanceType2Arch" : { + "t1.micro" : { "Arch" : "64" }, + "m1.small" : { "Arch" : "32" }, + "m1.large" : { "Arch" : "64" }, + "m1.xlarge" : { "Arch" : "64" }, + "m2.xlarge" : { "Arch" : "64" }, + "m2.2xlarge" : { "Arch" : "64" }, + "m2.4xlarge" : { "Arch" : "64" }, + "c1.medium" : { "Arch" : "32" }, + "c1.xlarge" : { "Arch" : "64" }, + "cc1.4xlarge" : { "Arch" : "64" } + }, + "AWSRegionArch2AMI" : { + "us-east-1" : { "32" : "ami-6411e20d", "64" : "ami-7a11e213" }, + "us-west-1" : { "32" : "ami-c9c7978c", "64" : "ami-cfc7978a" }, + "eu-west-1" : { "32" : "ami-37c2f643", "64" : "ami-31c2f645" }, + "ap-southeast-1" : { "32" : "ami-66f28c34", "64" : "ami-60f28c32" }, + "ap-northeast-1" : { "32" : "ami-9c03a89d", "64" : "ami-a003a8a1" } + } + }, + + "Resources" : { + "WebServerGroup" : { + "Type" : "AWS::AutoScaling::AutoScalingGroup", + "Properties" : { + "AvailabilityZones" : { "Fn::GetAZs" : ""}, + "LaunchConfigurationName" : { "Ref" : "LaunchConfig" }, + "MinSize" : "1", + "MaxSize" : "3", + "LoadBalancerNames" : [ { "Ref" : "ElasticLoadBalancer" } ] + } + }, + + "LaunchConfig" : { + "Type" : "AWS::AutoScaling::LaunchConfiguration", + "Properties" : { + "KeyName" : { "Ref" : "KeyName" }, + "ImageId" : { "Fn::FindInMap" : [ "AWSRegionArch2AMI", { "Ref" : "AWS::Region" }, + { "Fn::FindInMap" : [ "AWSInstanceType2Arch", { "Ref" : "InstanceType" }, + "Arch" ] } ] }, + "UserData" : { "Fn::Base64" : { "Ref" : "WebServerPort" }}, + "SecurityGroups" : [ { "Ref" : "InstanceSecurityGroup" } ], + "InstanceType" : { "Ref" : "InstanceType" } + } + }, + + "WebServerScaleUpPolicy" : { + "Type" : "AWS::AutoScaling::ScalingPolicy", + "Properties" : { + "AdjustmentType" : "ChangeInCapacity", + "AutoScalingGroupName" : { "Ref" : "WebServerGroup" }, + "Cooldown" : "60", + "ScalingAdjustment" : "1" + } + }, + "WebServerScaleDownPolicy" : { + "Type" : "AWS::AutoScaling::ScalingPolicy", + "Properties" : { + "AdjustmentType" : "ChangeInCapacity", + "AutoScalingGroupName" : { "Ref" : "WebServerGroup" }, + "Cooldown" : "60", + "ScalingAdjustment" : "-1" + } + }, + + "CPUAlarmHigh": { + "Type": "AWS::CloudWatch::Alarm", + "Properties": { + "AlarmDescription": "Scale-up if CPU > 90% for 10 minutes", + "MetricName": "CPUUtilization", + "Namespace": "AWS/EC2", + "Statistic": "Average", + "Period": "300", + "EvaluationPeriods": "2", + "Threshold": "90", + "AlarmActions": [ { "Ref": "WebServerScaleUpPolicy" } ], + "Dimensions": [ + { + "Name": "AutoScalingGroupName", + "Value": { "Ref": "WebServerGroup" } + } + ], + "ComparisonOperator": "GreaterThanThreshold" + } + }, + "CPUAlarmLow": { + "Type": "AWS::CloudWatch::Alarm", + "Properties": { + "AlarmDescription": "Scale-down if CPU < 70% for 10 minutes", + "MetricName": "CPUUtilization", + "Namespace": "AWS/EC2", + "Statistic": "Average", + "Period": "300", + "EvaluationPeriods": "2", + "Threshold": "70", + "AlarmActions": [ { "Ref": "WebServerScaleDownPolicy" } ], + "Dimensions": [ + { + "Name": "AutoScalingGroupName", + "Value": { "Ref": "WebServerGroup" } + } + ], + "ComparisonOperator": "LessThanThreshold" + } + }, + + "ElasticLoadBalancer" : { + "Type" : "AWS::ElasticLoadBalancing::LoadBalancer", + "Properties" : { + "AvailabilityZones" : { "Fn::GetAZs" : "" }, + "Listeners" : [ { + "LoadBalancerPort" : "80", + "InstancePort" : { "Ref" : "WebServerPort" }, + "Protocol" : "HTTP" + } ], + "HealthCheck" : { + "Target" : { "Fn::Join" : [ "", ["HTTP:", { "Ref" : "WebServerPort" }, "/"]]}, + "HealthyThreshold" : "3", + "UnhealthyThreshold" : "5", + "Interval" : "30", + "Timeout" : "5" + } + } + }, + + "InstanceSecurityGroup" : { + "Type" : "AWS::EC2::SecurityGroup", + "Properties" : { + "GroupDescription" : "Enable SSH access and HTTP access on the inbound port", + "SecurityGroupIngress" : [ { + "IpProtocol" : "tcp", + "FromPort" : "22", + "ToPort" : "22", + "CidrIp" : "0.0.0.0/0" + }, + { + "IpProtocol" : "tcp", + "FromPort" : { "Ref" : "WebServerPort" }, + "ToPort" : { "Ref" : "WebServerPort" }, + "SourceSecurityGroupOwnerId" : {"Fn::GetAtt" : ["ElasticLoadBalancer", "SourceSecurityGroup.OwnerAlias"]}, + "SourceSecurityGroupName" : {"Fn::GetAtt" : ["ElasticLoadBalancer", "SourceSecurityGroup.GroupName"]} + } ] + } + } + }, + + "Outputs" : { + "URL" : { + "Description" : "The URL of the website", + "Value" : { "Fn::Join" : [ "", [ "http://", { "Fn::GetAtt" : [ "ElasticLoadBalancer", "DNSName" ]}]]} + } + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudFront/CloudFrontClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudFront/CloudFrontClientTest.php new file mode 100644 index 0000000..e964387 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudFront/CloudFrontClientTest.php @@ -0,0 +1,182 @@ + 'foo', + 'secret' => 'bar', + )); + $this->assertInstanceOf('Aws\Common\Signature\SignatureV4', $client->getSignature()); + $this->assertEquals('https://cloudfront.amazonaws.com', $client->getBaseUrl()); + } + + public function testCreatesSignedUrlsForHttp() + { + $ts = time() + 1000; + /** @var $client \Aws\CloudFront\CloudFrontClient */ + $client = $this->getServiceBuilder()->get('cloudfront'); + + if ($client->getConfig('private_key') == 'change_me') { + $this->markTestSkipped('CloudFront private_key not set'); + } + + $url = $client->getSignedUrl(array( + 'url' => 'http://abc.cloudfront.net/images/image.jpg?color=red', + 'expires' => $ts + )); + $urlObject = Url::factory($url); + $kp = $client->getConfig('key_pair_id'); + $this->assertStringStartsWith( + "http://abc.cloudfront.net/images/image.jpg?color=red&Expires={$ts}&Signature=", + $url + ); + $this->assertContains("Key-Pair-Id={$kp}", $url); + + $signature = $urlObject->getQuery('Signature'); + $this->assertNotContains('?', $signature); + $this->assertNotContains('=', $signature); + $this->assertNotContains('/', $signature); + $this->assertNotContains('&', $signature); + $this->assertNotContains('+', $signature); + } + + public function testCreatesSignedUrlsWithCustomPolicy() + { + /** @var $client \Aws\CloudFront\CloudFrontClient */ + $client = $this->getServiceBuilder()->get('cloudfront'); + + if ($client->getConfig('private_key') == 'change_me') { + $this->markTestSkipped('CloudFront private_key not set'); + } + + $url = $client->getSignedUrl(array( + 'url' => 'http://abc.cloudfront.net/images/image.jpg', + 'policy' => '{}' + )); + $policy = Url::factory($url)->getQuery()->get('Policy'); + $this->assertRegExp('/^[0-9a-zA-Z-_~]+$/', $policy); + } + + public function testCreatesSignedUrlsForRtmp() + { + $ts = time() + 1000; + /** @var $client \Aws\CloudFront\CloudFrontClient */ + $client = $this->getServiceBuilder()->get('cloudfront'); + if ($client->getConfig('private_key') == 'change_me') { + $this->markTestSkipped('CloudFront private_key not set'); + } + $url = $client->getSignedUrl(array( + 'url' => 'rtmp://foo.cloudfront.net/test.mp4', + 'expires' => $ts + )); + $kp = $client->getConfig('key_pair_id'); + $this->assertStringStartsWith("test.mp4?Expires={$ts}&Signature=", $url); + $this->assertContains("Key-Pair-Id={$kp}", $url); + } + + public function testCreatesCannedSignedUrlsForRtmpWhileStrippingFileExtension() + { + $client = $this->getServiceBuilder()->get('cloudfront'); + $m = new \ReflectionMethod($client, 'createCannedPolicy'); + $m->setAccessible(true); + $ts = time() + 1000; + // Try with no leading path + $result = $m->invoke($client, 'rtmp', 'rtmp://foo.cloudfront.net/test.mp4', $ts); + $this->assertEquals( + '{"Statement":[{"Resource":"test.mp4","Condition":{"DateLessThan":{"AWS:EpochTime":' . $ts . '}}}]}', + $result + ); + $this->assertInternalType('array', json_decode($result, true)); + // Try with nested path + $result = $m->invoke($client, 'rtmp', 'rtmp://foo.cloudfront.net/videos/test.mp4', $ts); + $this->assertEquals( + '{"Statement":[{"Resource":"videos/test.mp4","Condition":{"DateLessThan":{"AWS:EpochTime":' . $ts . '}}}]}', + $result + ); + } + + /** + * @expectedException \Aws\Common\Exception\InvalidArgumentException + * @expectedExceptionMessage An expires option is required + */ + public function testEnsuresExpiresIsSetWhenUsingCannedPolicy() + { + $client = $this->getServiceBuilder()->get('cloudfront'); + $url = $client->getSignedUrl(array('url' => 'http://abc.cloudfront.net/images/image.jpg?color=red')); + } + + /** + * @expectedException \Aws\Common\Exception\InvalidArgumentException + * @expectedExceptionMessage Invalid URI scheme + */ + public function testEnsuresUriSchemeIsValid() + { + $this->getServiceBuilder()->get('cloudfront')->getSignedUrl(array( + 'url' => 'foo://bar.com', + 'expires' => time() + 100 + )); + } + + /** + * @expectedException \Aws\Common\Exception\InvalidArgumentException + * @expectedExceptionMessage Invalid URL: bar.com + */ + public function testEnsuresUriSchemeIsPresent() + { + $this->getServiceBuilder()->get('cloudfront')->getSignedUrl(array( + 'url' => 'bar.com', + 'expires' => time() + 100 + )); + } + + /** + * @expectedException \Guzzle\Common\Exception\InvalidArgumentException + */ + public function testEnsuresKeyPairsAreSet() + { + $client = $this->getServiceBuilder()->get('cloudfront', true); + $client->getConfig()->remove('key_pair_id'); + $client->getSignedUrl(array('url' => 'http://bar.com', 'expires' => time() + 60)); + } + + public function dataForCorrectSignatureIsInstantiatedTest() + { + return array( + array(array(), 'Aws\Common\Signature\SignatureV4'), + array(array('version' => '2012-05-05'), 'Aws\CloudFront\CloudFrontSignature'), + ); + } + + /** + * @dataProvider dataForCorrectSignatureIsInstantiatedTest + */ + public function testCorrectSignatureIsInstantiated(array $config, $signatureClass) + { + $client = CloudFrontClient::factory($config); + $this->assertInstanceOf($signatureClass, $client->getSignature()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudFront/CloudFrontSignatureTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudFront/CloudFrontSignatureTest.php new file mode 100644 index 0000000..ae8aca4 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudFront/CloudFrontSignatureTest.php @@ -0,0 +1,54 @@ + 'Thu, 17 May 2012 17:08:48 GMT')); + $credentials = new Credentials('foo', 'bar'); + $signature = new CloudFrontSignature(); + $signature->signRequest($request, $credentials); + $this->assertEquals('AWS foo:H/oAmf/UKMC13D986NHtWlcWeqg=', (string) $request->getHeader('Authorization')); + } + + public function testSignsWithXAmzDateHeader() + { + $request = new Request('GET', 'http://www.foo.com', array('x-amz-date' => 'Thu, 17 May 2012 17:08:48 GMT')); + $credentials = new Credentials('foo', 'bar'); + $signature = new CloudFrontSignature(); + $signature->signRequest($request, $credentials); + $this->assertEquals('AWS foo:H/oAmf/UKMC13D986NHtWlcWeqg=', (string) $request->getHeader('Authorization')); + } + + public function testSignsWithInjectedDateHeader() + { + $request = new Request('GET', 'http://www.foo.com'); + $credentials = new Credentials('foo', 'bar'); + $signature = new CloudFrontSignature(); + $signature->signRequest($request, $credentials); + $this->assertTrue($request->hasHeader('Date')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudFront/Integration/CloudFront_20130512_Test.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudFront/Integration/CloudFront_20130512_Test.php new file mode 100644 index 0000000..f235a1d --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudFront/Integration/CloudFront_20130512_Test.php @@ -0,0 +1,269 @@ +get('s3'); + self::$bucketName = crc32(gethostname()) . '_cftest'; + + // Create the test bucket + self::log('Creating bucket for testing distributions: ' . self::$bucketName); + $s3->createBucket(array('Bucket' => self::$bucketName)); + $s3->waitUntil('bucket_exists', array('Bucket' => self::$bucketName)); + + // Add the test object + self::log('Bucket created, adding test object...'); + $s3->putObject(array( + 'Bucket' => self::$bucketName, + 'Key' => 'foo.txt', + 'ACL' => 'public-read', + 'Body' => 'hello!' + )); + $s3->waitUntil('object_exists', array('Bucket' => self::$bucketName, 'Key' => 'foo.txt')); + } + + public static function tearDownAfterClass() + { + $s3 = self::getServiceBuilder()->get('s3'); + self::log('Deleting test object'); + $s3->deleteObject(array( + 'Bucket' => self::$bucketName, + 'Key' => 'foo.txt' + )); + sleep(1); + self::log('Deleting test bucket'); + $s3->deleteBucket(array('Bucket' => self::$bucketName)); + + /** @var \Aws\CloudFront\CloudFrontClient $cf */ + $cf = self::getServiceBuilder()->get('cloudfront'); + + sleep(60); + + if (self::$originId) { + self::log('Deleting origin access identity'); + try { + $result = $cf->getCloudFrontOriginAccessIdentity(array('Id' => self::$originId)); + $cf->deleteCloudFrontOriginAccessIdentity(array( + 'Id' => self::$originId, + 'IfMatch' => $result['ETag'], + )); + } catch (\Exception $e) { + echo $e->getMessage() . "\n"; + } + } + + if (self::$distributionId) { + self::log('Deleting distribution'); + try { + $cf->deleteDistribution(array( + 'Id' => self::$distributionId, + )); + } catch (\Exception $e) { + echo $e->getMessage() . "\n"; + } + } + } + + public function setUp() + { + $this->client = self::getServiceBuilder()->get('cloudfront', true); + } + + /** + * Create an origin access identity + * + * @example Aws\CloudFront\CloudFrontClient::createCloudFrontOriginAccessIdentity + */ + public function testCreatesOrigins() + { + $client = $this->client; + // @begin + $result = $client->createCloudFrontOriginAccessIdentity(array( + 'CallerReference' => 'foo', + 'Comment' => 'Hello!' + )); + + echo $result['Id'] . ' - ' . $result['S3CanonicalUserId']; + // @end + + $this->assertInstanceOf('Guzzle\Service\Resource\Model', $result); + $result = $result->toArray(); + $this->assertArrayHasKey('Id', $result); + self::$originId = $result['Id']; + $this->assertArrayHasKey('S3CanonicalUserId', $result); + $this->assertArrayHasKey('CloudFrontOriginAccessIdentityConfig', $result); + $this->assertEquals(array( + 'CallerReference' => 'foo', + 'Comment' => 'Hello!' + ), $result['CloudFrontOriginAccessIdentityConfig']); + $this->assertArrayHasKey('Location', $result); + $this->assertArrayHasKey('ETag', $result); + + // Grant CF to read from the bucket + $s3 = $this->getServiceBuilder()->get('s3'); + $s3->putObjectAcl(array( + 'Bucket' => self::$bucketName, + 'Key' => 'foo.txt', + 'GrantRead' => 'id="' . $result['S3CanonicalUserId'] . '"' + )); + } + + /** + * Create a distribution + * + * @depends testCreatesOrigins + * @example Aws\CloudFront\CloudFrontClient::createDistribution + */ + public function testCreatesDistribution() + { + if (!self::$originId) { + $this->fail('No originId was set'); + } + + self::log("Creating a distribution"); + + $client = $this->client; + $originId = self::$originId; + $bucketName = self::$bucketName; + + // @begin + $result = $client->createDistribution(array( + 'Aliases' => array('Quantity' => 0), + 'CacheBehaviors' => array('Quantity' => 0), + 'Comment' => 'Testing... 123', + 'Enabled' => true, + 'CallerReference' => 'BazBar-' . time(), + 'DefaultCacheBehavior' => array( + 'MinTTL' => 3600, + 'ViewerProtocolPolicy' => 'allow-all', + 'TargetOriginId' => $originId, + 'TrustedSigners' => array( + 'Enabled' => true, + 'Quantity' => 1, + 'Items' => array('self') + ), + 'ForwardedValues' => array( + 'QueryString' => false, + 'Cookies' => array( + 'Forward' => 'all' + ) + ) + ), + 'DefaultRootObject' => 'foo.txt', + 'Logging' => array( + 'Enabled' => false, + 'Bucket' => '', + 'Prefix' => '', + 'IncludeCookies' => true, + ), + 'Origins' => array( + 'Quantity' => 1, + 'Items' => array( + array( + 'Id' => $originId, + 'DomainName' => "{$bucketName}.s3.amazonaws.com", + 'S3OriginConfig' => array( + 'OriginAccessIdentity' => 'origin-access-identity/cloudfront/' . $originId + ) + ) + ) + ), + 'PriceClass' => 'PriceClass_All', + )); + + printf('%s - %s', $result['Status'], $result['Location']) . "\n"; + // @end + + $result = $result->toArray(); + self::$distributionId = $result['Id']; + $this->assertArrayHasKey('Status', $result); + $this->assertArrayHasKey('Location', $result); + self::$distributionUrl = $result['DomainName']; + $this->assertArrayHasKey('ETag', $result); + $this->assertEquals(1, $result['DistributionConfig']['Origins']['Quantity']); + $this->assertArrayHasKey(0, $result['DistributionConfig']['Origins']['Items']); + $this->assertEquals(self::$bucketName . '.s3.amazonaws.com', $result['DistributionConfig']['Origins']['Items'][0]['DomainName']); + + return $result['Id']; + } + + /** + * List distributions + * + * @depends testCreatesDistribution + */ + public function testListsDistributions($id) + { + $client = $this->client; + // @begin + $result = $client->listDistributions(); + foreach ($result['Items'] as $item) { + echo $item['Id'] . "\n"; + } + // @end + $this->assertGreaterThan(0, $result['Quantity']); + $this->assertContains($id, $this->getActualOutput()); + } + + /** + * Create a pre-signed URL + * + * @depends testListsDistributions + * @example Aws\CloudFront\CloudFrontClient::getSignedUrl + */ + public function testCreatesSignedUrls() + { + $client = $this->client; + self::log('Waiting until the distribution becomes active'); + $client->waitUntil('DistributionDeployed', array('Id' => self::$distributionId)); + $distributionUrl = self::$distributionUrl; + + // @begin + // Create a signed URL that expires in 1 hour + $url = $client->getSignedUrl(array( + 'url' => 'https://' . $distributionUrl . '/foo.txt', + 'expires' => time() + 3600 + )); + // @end + + self::log('URL: ' . $url); + try { + $c = new HttpClient(); + $this->assertEquals('hello!', $c->get($url)->send()->getBody(true)); + } catch (\Exception $e) { + $this->markTestIncomplete($e->getMessage()); + } + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudFront/Integration/IteratorsTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudFront/Integration/IteratorsTest.php new file mode 100644 index 0000000..d7dd658 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudFront/Integration/IteratorsTest.php @@ -0,0 +1,55 @@ +getServiceBuilder()->get('cloudfront'); + $this->setMockResponse($client, array( + 'cloudfront/ListDistributions_page_1', + 'cloudfront/ListDistributions_page_2' + )); + $iterator = $client->getIterator('ListDistributions'); + $this->assertInstanceOf('Aws\Common\Iterator\AwsResourceIterator', $iterator); + $result = iterator_to_array($iterator); + $this->assertEquals(3, count($result)); + $this->assertEquals('EXAMPLE1', $result[0]['Id']); + $this->assertEquals('EXAMPLE2', $result[1]['Id']); + $this->assertEquals('EXAMPLE3', $result[2]['Id']); + } + + public function testListStreamingDistributionsIterator() + { + $client = $this->getServiceBuilder()->get('cloudfront'); + $this->setMockResponse($client, array( + 'cloudfront/ListStreamingDistributions_page_1', + 'cloudfront/ListStreamingDistributions_page_2' + )); + $iterator = $client->getIterator('ListStreamingDistributions'); + $this->assertInstanceOf('Aws\Common\Iterator\AwsResourceIterator', $iterator); + $result = iterator_to_array($iterator); + $this->assertEquals(3, count($result)); + $this->assertEquals('EXAMPLE1', $result[0]['Id']); + $this->assertEquals('EXAMPLE2', $result[1]['Id']); + $this->assertEquals('EXAMPLE3', $result[2]['Id']); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudFront/Waiter/DistributionDeployedTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudFront/Waiter/DistributionDeployedTest.php new file mode 100644 index 0000000..9a0bd6d --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudFront/Waiter/DistributionDeployedTest.php @@ -0,0 +1,42 @@ +getServiceBuilder()->get('cloudfront'); + $this->setMockResponse($client, array( + 'cloudfront/GetDistribution_InProgress', + 'cloudfront/GetDistribution_Deployed' + )); + $client->waitUntil('distribution_deployed', array('Id' => 'bar', 'waiter.interval' => 0)); + } + + /** + * @expectedException \Aws\Common\Exception\RuntimeException + */ + public function testDoesNotBufferOtherExceptions() + { + $client = $this->getServiceBuilder()->get('cloudfront'); + $this->setMockResponse($client, array(new Response(404))); + $client->waitUntil('distribution_deployed', array('Id' => 'bar')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudFront/Waiter/InvalidationCompletedTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudFront/Waiter/InvalidationCompletedTest.php new file mode 100644 index 0000000..767a88e --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudFront/Waiter/InvalidationCompletedTest.php @@ -0,0 +1,57 @@ +getServiceBuilder()->get('cloudfront'); + $client->waitUntil('InvalidationCompleted', array('Id' => 'foo')); + } + + public function testReturnsTrueIfDeployed() + { + $client = $this->getServiceBuilder()->get('cloudfront'); + $this->setMockResponse($client, array( + 'cloudfront/GetInvalidation_InProgress', + 'cloudfront/GetInvalidation_Completed' + )); + $client->waitUntil( + 'InvalidationCompleted', + array('DistributionId' => 'foo', 'Id' => 'bar', 'waiter.interval' => 0) + ); + $requests = $this->getMockedRequests(); + $this->assertEquals(2, count($requests)); + $this->assertContains('/distribution/foo/invalidation/bar', $requests[0]->getUrl()); + } + + /** + * @expectedException \Aws\Common\Exception\RuntimeException + */ + public function testDoesNotBufferOtherExceptions() + { + $client = $this->getServiceBuilder()->get('cloudfront'); + $this->setMockResponse($client, array(new Response(404))); + $client->waitUntil('invalidation_completed', array('DistributionId' => 'foo', 'Id' => 'bar')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudFront/Waiter/StreamingDistributionDeployedTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudFront/Waiter/StreamingDistributionDeployedTest.php new file mode 100644 index 0000000..b489f09 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudFront/Waiter/StreamingDistributionDeployedTest.php @@ -0,0 +1,42 @@ +getServiceBuilder()->get('cloudfront'); + $this->setMockResponse($client, array( + 'cloudfront/GetStreamingDistribution_InProgress', + 'cloudfront/GetStreamingDistribution_Deployed' + )); + $client->waitUntil('streaming_distribution_deployed', array('Id' => 'foo', 'waiter.interval' => 0)); + } + + /** + * @expectedException \Aws\Common\Exception\RuntimeException + */ + public function testDoesNotBufferOtherExceptions() + { + $client = $this->getServiceBuilder()->get('cloudfront'); + $this->setMockResponse($client, array(new Response(404))); + $client->waitUntil('streaming_distribution_deployed', array('Id' => 'foo')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudSearch/CloudSearchClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudSearch/CloudSearchClientTest.php new file mode 100644 index 0000000..c4c5b89 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudSearch/CloudSearchClientTest.php @@ -0,0 +1,38 @@ + 'foo', + 'secret' => 'bar', + 'region' => 'us-east-1' + )); + + $this->assertInstanceOf('Aws\Common\Signature\SignatureV4', $this->readAttribute($client, 'signature')); + $this->assertInstanceOf('Aws\Common\Credentials\Credentials', $client->getCredentials()); + $this->assertEquals('https://cloudsearch.us-east-1.amazonaws.com', $client->getBaseUrl()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudSearch/Integration/IntegrationTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudSearch/Integration/IntegrationTest.php new file mode 100644 index 0000000..06d36e9 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudSearch/Integration/IntegrationTest.php @@ -0,0 +1,86 @@ +client = $this->getServiceBuilder()->get('cloudsearch'); + } + + public static function tearDownAfterClass() + { + self::log('Cleaning up'); + $client = self::getServiceBuilder()->get('cloudsearch'); + try { + $client->deleteDomain(array('DomainName' => 'integdomain')); + } catch (\Exception $e) {} + } + + /** + * Create a domain + * + * @example Aws\CloudSearch\CloudSearchClient::createDomain + */ + public function testCreatesDomains() + { + $client = $this->client; + self::log('Creating test domain'); + // @begin + $result = $client->createDomain(array( + 'DomainName' => 'integdomain' + )); + // @end + $result = $result->toArray(); + $this->assertArrayHasKey('DomainStatus', $result); + $this->assertArrayHasKey('DomainId', $result['DomainStatus']); + $this->assertArrayHasKey('DomainName', $result['DomainStatus']); + $this->assertTrue($result['DomainStatus']['Created']); + } + + /** + * List domains + * + * @depends testCreatesDomains + * @example Aws\CloudSearch\CloudSearchClient::describeDomains + */ + public function testListsDomains() + { + self::log('Listing domains'); + $client = $this->client; + + // @begin + $iterator = $client->getDescribeDomainsIterator(); + foreach ($iterator as $domain) { + echo $domain['DomainName'] . "\n"; + } + // @end + + $this->assertContains('integdomain', $this->getActualOutput()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudTrail/CloudTrailClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudTrail/CloudTrailClientTest.php new file mode 100644 index 0000000..8db7672 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudTrail/CloudTrailClientTest.php @@ -0,0 +1,38 @@ + 'foo', + 'secret' => 'bar', + 'region' => 'us-west-2' + )); + + $this->assertInstanceOf('Aws\Common\Signature\SignatureV4', $client->getSignature()); + $this->assertInstanceOf('Aws\Common\Credentials\Credentials', $client->getCredentials()); + $this->assertEquals('https://cloudtrail.us-west-2.amazonaws.com', $client->getBaseUrl()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudTrail/Integration/IntegrationTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudTrail/Integration/IntegrationTest.php new file mode 100644 index 0000000..89e8790 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudTrail/Integration/IntegrationTest.php @@ -0,0 +1,170 @@ +getServiceBuilder(); + + $this->cloudtrail = $aws->get('cloudtrail'); + $this->s3 = $aws->get('s3'); + } + + /** + * Execute the CreateTrail operation + * + * @example Aws\CloudTrail\CloudTrailClient::createTrail + * @example Aws\S3\S3Client::putBucketPolicy + * @example Aws\S3\S3Client::waitUntilBucketExists + */ + public function testCreateTrail() + { + $client = $this->cloudtrail; + $s3 = $this->s3; + $bucket = 'php-' . $this->getResourcePrefix() . '-cloudtrail'; + + self::log('Delete existing trails.'); + foreach ($client->getDescribeTrailsIterator() as $trail) { + $client->deleteTrail(array('Name' => $trail['Name'])); + } + + self::log('Create an S3 bucket and a CloudTrail trail that logs to that bucket.'); + + // @begin + // Create a bucket in S3 to store the logs and configure the policy + $s3->createBucket(array('Bucket' => $bucket)); + $s3->waitUntilBucketExists(array('Bucket' => $bucket)); + $s3->putBucketPolicy(array( + 'Bucket' => $bucket, + 'Policy' => json_encode(array( + 'Statement' => array( + array( + 'Sid' => 'cloudtrail-to-s3', + 'Action' => array( + 's3:GetBucketAcl', + 's3:PutObject' + ), + 'Effect' => 'Allow', + 'Resource' => array( + "arn:aws:s3:::{$bucket}", + "arn:aws:s3:::{$bucket}/AWSLogs/*" + ), + 'Principal' => array( + 'AWS' => array( + // Documented CloudTrail Principal ARNs + 'arn:aws:iam::086441151436:root', + 'arn:aws:iam::113285607260:root' + ) + ) + ) + ) + )) + )); + + // Create a CloudTrail trail and set the bucket to use + $client->createTrail(array( + 'Name' => 'test-trail', + 'S3BucketName' => $bucket, + )); + + // @end + return $bucket; + } + + /** + * Execute the StartLogging operations + * + * @example Aws\CloudTrail\CloudTrailClient::startLogging + * @depends testCreateTrail + */ + public function testStartLogging($bucket) + { + $client = $this->cloudtrail; + + // @begin + $client->startLogging(array( + 'Name' => 'test-trail' + )); + + // @end + return $bucket; + } + + /** + * Execute the StopLogging operations + * + * @example Aws\CloudTrail\CloudTrailClient::stopLogging + * @depends testStartLogging + */ + public function testStopLogging($bucket) + { + $client = $this->cloudtrail; + + // @begin + $client->stopLogging(array( + 'Name' => 'test-trail' + )); + + // @end + return $bucket; + } + + /** + * Execute the DescribeTrails and DeleteTrail operations + * + * @example Aws\CloudTrail\CloudTrailClient::deleteTrail + * @example Aws\CloudTrail\CloudTrailClient::getDescribeTrailsIterator + * @depends testStopLogging + */ + public function testDeleteTrails($bucket) + { + $client = $this->cloudtrail; + + // @begin + // List and delete all of the trails + $trails = $client->getDescribeTrailsIterator(); + foreach ($trails as $trail) { + $client->deleteTrail(array('Name' => $trail['Name'])); + echo "Deleted trail {$trail['Name']}.\n"; + } + + // @end + $this->assertEquals("Deleted trail test-trail.\n", $this->getActualOutput()); + + // Clean up test bucket + sleep(5); + if ($this->s3->doesBucketExist($bucket)) { + $this->s3->clearBucket($bucket); + $this->s3->deleteBucket(array('Bucket' => $bucket)); + } + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudTrail/LogFileIteratorTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudTrail/LogFileIteratorTest.php new file mode 100644 index 0000000..8e30a5e --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudTrail/LogFileIteratorTest.php @@ -0,0 +1,146 @@ +getMockS3Client(); + $cloudTrailClient = CloudTrailClient::factory(array( + 'key' => 'foo', + 'secret' => 'bar', + 'region' => 'us-west-2', + )); + $json = '{"trailList":[{"IncludeGlobalServiceEvents":true,"Name":"Default","S3BucketName":"log-bucket"}]}'; + $cloudTrailClient->addSubscriber(new MockPlugin(array(new Response(200, null, $json)))); + $files = LogFileIterator::forTrail($s3Client, $cloudTrailClient); + $this->assertInstanceOf('Aws\CloudTrail\LogFileIterator', $files); + } + + /** + * @covers Aws\CloudTrail\LogFileIterator::forTrail + */ + public function testFactoryErrorsOnUnknownBucket() + { + $this->setExpectedException('InvalidArgumentException'); + $s3Client = $this->getMockS3Client(); + $cloudTrailClient = CloudTrailClient::factory(array( + 'key' => 'foo', + 'secret' => 'bar', + 'region' => 'us-west-2', + )); + $cloudTrailClient->addSubscriber(new MockPlugin(array(new Response(200, null, '{"trailList":[]}')))); + $files = LogFileIterator::forTrail($s3Client, $cloudTrailClient); + } + + /** + * @covers Aws\CloudTrail\LogFileIterator::__construct + * @covers Aws\CloudTrail\LogFileIterator::buildListObjectsIterator + */ + public function testConstructorWorksWithMinimumParams() + { + $s3Client = $this->getMockS3Client(); + $files = new LogFileIterator($s3Client, 'test-bucket'); + + $this->assertInstanceOf('Aws\CloudTrail\LogFileIterator', $files); + } + + /** + * @covers Aws\CloudTrail\LogFileIterator::normalizeDateValue + * @covers Aws\CloudTrail\LogFileIterator::determineDateForPrefix + * @covers Aws\CloudTrail\LogFileIterator::applyDateFilter + */ + public function testConstructorWorksWithDates() + { + $s3Client = $this->getMockS3Client(); + $files = new LogFileIterator($s3Client, 'test-bucket', array( + LogFileIterator::START_DATE => new \DateTime('2013-11-01'), + LogFileIterator::END_DATE => '2013-12-01', + )); + + $this->assertInstanceOf('Aws\CloudTrail\LogFileIterator', $files); + } + + /** + * @covers Aws\CloudTrail\LogFileIterator::normalizeDateValue + */ + public function testConstructorErrorsOnInvalidDate() + { + $this->setExpectedException('InvalidArgumentException'); + + $s3Client = $this->getMockS3Client(); + $files = new LogFileIterator($s3Client, 'test-bucket', array( + LogFileIterator::START_DATE => true, + LogFileIterator::END_DATE => false, + )); + } + + /** + * @covers Aws\CloudTrail\LogFileIterator::applyDateFilter + * @covers Aws\CloudTrail\LogFileIterator::applyRegexFilter + * @covers Aws\CloudTrail\LogFileIterator::current + */ + public function testCanIterateThroughFiles() + { + $s3Client = $this->getMockS3Client(); + $files = new LogFileIterator($s3Client, 'test-bucket', array( + LogFileIterator::START_DATE => new \DateTime('2013-11-01'), + LogFileIterator::END_DATE => '2013-12-01', + )); + + $innerIterator = $files->getInnerIterator(); + $this->assertInstanceOf('Guzzle\Iterator\FilterIterator', $innerIterator); + + $this->assertFalse($files->current()); + $files = iterator_to_array($files); + $this->assertCount(3, $files, print_r($files, true)); + } + + /** + * @return S3Client + */ + private function getMockS3Client() + { + // Setup ListObjects response + $xml = << + + test-bucket + + + 1000 + false + + AWSLogs/12345/CloudTrail/us-east-1/2013/11/15/foo-20131115T1453Z-log.json.gz + + + AWSLogs/12345/CloudTrail/us-east-1/2013/11/28/foo-20131128T1822Z-log.json.gz + + + AWSLogs/12345/CloudTrail/us-east-1/2013/12/01/foo-20131129T0311Z-log.json.gz + + + AWSLogs/12345/CloudTrail/us-east-1/2013/12/01/foo-20131225T0000Z-log.json.gz + + +XML; + + $client = S3Client::factory(array( + 'key' => 'foo', + 'secret' => 'bar', + )); + $client->addSubscriber(new MockPlugin(array(new Response(200, null, $xml)))); + + return $client; + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudTrail/LogFileReaderTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudTrail/LogFileReaderTest.php new file mode 100644 index 0000000..2e6be77 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudTrail/LogFileReaderTest.php @@ -0,0 +1,38 @@ + 'foo', + 'secret' => 'bar', + )); + $s3Client->addSubscriber(new MockPlugin(array(new Response(200, null, $responseBody)))); + + $reader = new LogFileReader($s3Client); + $records = $reader->read('test-bucket', 'test-key'); + + $this->assertCount($recordCount, $records); + } + + public function dataForLogReadingTest() + { + return array( + array('{"Records":[{"foo":"1"},{"bar":"2"},{"baz":"3"}]}', 3), + array('{"Records":[]}', 0), + array('', 0), + ); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudTrail/LogRecordIteratorTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudTrail/LogRecordIteratorTest.php new file mode 100644 index 0000000..2d22d02 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudTrail/LogRecordIteratorTest.php @@ -0,0 +1,123 @@ + 'foo', + 'secret' => 'bar', + )); + $cloudTrailClient = CloudTrailClient::factory(array( + 'key' => 'foo', + 'secret' => 'bar', + 'region' => 'us-west-2', + )); + $json = '{"trailList":[{"IncludeGlobalServiceEvents":true,"Name":"Default","S3BucketName":"log-bucket"}]}'; + $cloudTrailClient->addSubscriber(new MockPlugin(array(new Response(200, null, $json)))); + + $records = LogRecordIterator::forTrail($s3Client, $cloudTrailClient); + $this->assertInstanceOf('Aws\CloudTrail\LogRecordIterator', $records); + } + + /** + * @covers Aws\CloudTrail\LogRecordIterator::forBucket + */ + public function testFactoryCanCreateForBucket() + { + $s3Client = $s3Client = S3Client::factory(array( + 'key' => 'foo', + 'secret' => 'bar', + )); + + $records = LogRecordIterator::forBucket($s3Client, 'test-bucket'); + $this->assertInstanceOf('Aws\CloudTrail\LogRecordIterator', $records); + } + + /** + * @covers Aws\CloudTrail\LogRecordIterator::forFile + */ + public function testFactoryCanCreateForFile() + { + $s3Client = $s3Client = S3Client::factory(array( + 'key' => 'foo', + 'secret' => 'bar', + )); + + $records = LogRecordIterator::forFile($s3Client, 'test-bucket', 'test-key'); + $this->assertInstanceOf('Aws\CloudTrail\LogRecordIterator', $records); + } + + /** + * @covers Aws\CloudTrail\LogRecordIterator::__construct + * @covers Aws\CloudTrail\LogRecordIterator::current + * @covers Aws\CloudTrail\LogRecordIterator::key + * @covers Aws\CloudTrail\LogRecordIterator::valid + * @covers Aws\CloudTrail\LogRecordIterator::getInnerIterator + */ + public function testIteratorBehavesCorrectlyBeforeRewind() + { + $logFileReader = $this->getMockBuilder('Aws\CloudTrail\LogFileReader') + ->disableOriginalConstructor() + ->getMock(); + $logFileIterator = new \ArrayIterator; + + $records = new LogRecordIterator($logFileReader, $logFileIterator); + $this->assertNull($records->key()); + $this->assertFalse($records->current()); + $this->assertInstanceOf('ArrayIterator', $records->getInnerIterator()); + } + + /** + * @covers Aws\CloudTrail\LogRecordIterator::loadRecordsFromCurrentLogFile + * @covers Aws\CloudTrail\LogRecordIterator::current + * @covers Aws\CloudTrail\LogRecordIterator::key + * @covers Aws\CloudTrail\LogRecordIterator::next + * @covers Aws\CloudTrail\LogRecordIterator::rewind + * @covers Aws\CloudTrail\LogRecordIterator::valid + */ + public function testCanIterateThroughRecords() + { + $logFileReader = new LogFileReader($this->getMockS3Client()); + $logFileIterator = new \ArrayIterator(array( + array('Bucket' => 'test-bucket', 'Key' => 'test-key-1'), + array('Bucket' => 'test-bucket', 'Key' => 'test-key-2'), + array('Bucket' => 'test-bucket', 'Key' => 'test-key-3'), + )); + + $records = new LogRecordIterator($logFileReader, $logFileIterator); + $records = iterator_to_array($records); + $this->assertCount(5, $records); + } + + /** + * @return S3Client + */ + private function getMockS3Client() + { + $mock = new MockPlugin(array( + new Response(200, null, '{"Records":[{"r1":"r1"},{"r2":"r2"},{"r3":"r3"}]}'), + new Response(200, null, '{}'), + new Response(200, null, '{"Records":[{"r4":"r4"},{"r5":"r5"}]}'), + )); + $client = S3Client::factory(array( + 'key' => 'foo', + 'secret' => 'bar', + )); + $client->addSubscriber($mock); + + return $client; + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudWatch/CloudWatchClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudWatch/CloudWatchClientTest.php new file mode 100644 index 0000000..19da04e --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudWatch/CloudWatchClientTest.php @@ -0,0 +1,38 @@ + 'foo', + 'secret' => 'bar', + 'region' => 'us-west-2' + )); + + $this->assertInstanceOf('Aws\Common\Signature\SignatureV4', $client->getSignature()); + $this->assertInstanceOf('Aws\Common\Credentials\Credentials', $client->getCredentials()); + $this->assertEquals('https://monitoring.us-west-2.amazonaws.com', $client->getBaseUrl()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudWatch/Integration/IntegrationTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudWatch/Integration/IntegrationTest.php new file mode 100644 index 0000000..2583a59 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/CloudWatch/Integration/IntegrationTest.php @@ -0,0 +1,133 @@ +cloudwatch = $this->getServiceBuilder()->get('cloudwatch'); + } + + /** + * Execute the PutMetricData operation + * + * @example Aws\CloudWatch\CloudWatchClient::putMetricData + */ + public function testPutsMetricData() + { + $prefix = $this->getResourcePrefix(); + $client = $this->cloudwatch; + self::log('Put some data to a metric.'); + + // @begin + $dimensions = array( + array('Name' => 'Prefix', 'Value' => $prefix), + ); + + $client->putMetricData(array( + 'Namespace' => 'AWSSDKPHP', + 'MetricData' => array( + array( + 'MetricName' => 'CloudWatchTests', + 'Timestamp' => time(), + 'Value' => rand(1, 20) + rand(1, 59) / 100, + 'Unit' => 'Kilobytes', + 'Dimensions' => $dimensions + ), + ), + )); + } + + /** + * Lists metrics + * + * @example Aws\CloudWatch\CloudWatchClient::listMetrics + * @depends testPutsMetricData + */ + public function testListsMetrics() + { + self::log('Make sure the metric exists.'); + $client = $this->cloudwatch; + + // @begin + $iterator = $client->getIterator('ListMetrics', array( + 'Namespace' => 'AWSSDKPHP' + )); + + foreach ($iterator as $metric) { + echo $metric['MetricName'] . ' - ' + . $metric['Dimensions'][0]['Name'] . ' - ' + . $metric['Dimensions'][0]['Value'] . "\n"; + } + + // @end + + echo 'CloudWatchTests - Prefix - ' . $this->getResourcePrefix() . "\n"; + $found = false !== strpos('CloudWatchTests - Prefix - ' . $this->getResourcePrefix(), $this->getActualOutput()); + + return $found; + } + + /** + * GetMetricStatistics + * + * @depends testListsMetrics + * @example Aws\CloudWatch\CloudWatchClient::getMetricStatistics + */ + public function testGetsMetricStatistics($found) + { + if (!$found) { + $this->markTestSkipped('The CloudWatch metric you created has not yet been picked up by CloudWatch. This ' + . 'can take up to 15 minutes to occur. Please run this test again later.'); + } + + $prefix = $this->getResourcePrefix(); + $client = $this->cloudwatch; + self::log('Verify the statistics of the data that has been put.'); + + // @begin + $dimensions = array( + array('Name' => 'Prefix', 'Value' => $prefix), + ); + + $result = $client->getMetricStatistics(array( + 'Namespace' => 'AWSSDKPHP', + 'MetricName' => 'CloudWatchTests', + 'Dimensions' => $dimensions, + 'StartTime' => strtotime('-1 days'), + 'EndTime' => strtotime('now'), + 'Period' => 3000, + 'Statistics' => array('Maximum', 'Minimum'), + )); + // @end + + $min = min($result->getPath('Datapoints/*/Minimum')); + $max = max($result->getPath('Datapoints/*/Maximum')); + $this->assertGreaterThan(1, $min); + $this->assertLessThan(22, $max); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/AwsTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/AwsTest.php new file mode 100644 index 0000000..4cf924b --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/AwsTest.php @@ -0,0 +1,56 @@ +assertTrue($builder->offsetExists('dynamodb')); + $this->assertTrue($builder->offsetExists('sts')); + $this->assertArrayHasKey('s3', $builder->getConfig()); + } + + public function testTreatsArrayInFirstArgAsGlobalParametersUsingDefaultConfigFile() + { + $builder = Aws::factory(array( + 'key' => 'foo', + 'secret' => 'bar', + 'region' => 'us-east-1' + )); + + $this->assertEquals('foo', $builder->get('dynamodb')->getConfig('key')); + $this->assertEquals('bar', $builder->get('dynamodb')->getConfig('secret')); + } + + public function testReturnsDefaultConfigPath() + { + $this->assertContains('aws-config.php', Aws::getDefaultServiceDefinition()); + } + + public function testCanEnableFacades() + { + Aws::factory()->enableFacades(); + $this->assertTrue(class_exists('DynamoDb')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Client/AbstractClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Client/AbstractClientTest.php new file mode 100644 index 0000000..584d168 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Client/AbstractClientTest.php @@ -0,0 +1,293 @@ +getMockBuilder('Aws\Common\Client\AbstractClient') + ->setConstructorArgs(array($credentials, $signature, $config)) + ->getMockForAbstractClass(); + + $this->assertSame($signature, $client->getSignature()); + $this->assertSame($credentials, $client->getCredentials()); + $this->assertSame($config, $client->getConfig()); + + // Ensure a signature event dispatcher was added + $this->assertGreaterThan(0, array_filter( + $client->getEventDispatcher()->getListeners('request.before_send'), + function($e) { + return $e[0] instanceof SignatureListener; + } + )); + + // Ensure that the user agent string is correct + $expectedUserAgent = 'aws-sdk-php2/' . Aws::VERSION; + $actualUserAgent = $this->readAttribute($client, 'userAgent'); + $this->assertRegExp("@^{$expectedUserAgent}@", $actualUserAgent); + } + + public function testUsesDefaultWaiterFactory() + { + $client = $this->getMockBuilder('Aws\Common\Client\AbstractClient') + ->disableOriginalConstructor() + ->getMockForAbstractClass(); + + try { + $client->waitUntil('foo', array('baz' => 'bar')); + } catch (\Exception $e) {} + + try { + $client->getWaiter('foo', array('baz' => 'bar')); + } catch (\Exception $e) {} + } + + public function testAllowsWaiterFactoryInjection() + { + $client = $this->getMockBuilder('Aws\Common\Client\AbstractClient') + ->disableOriginalConstructor() + ->getMockForAbstractClass(); + + $waiter = $this->getMockBuilder('Aws\Common\Waiter\ResourceWaiterInterface') + ->setMethods(array('wait', 'setResource', 'setConfig', 'setClient')) + ->getMockForAbstractClass(); + + $waiter->expects($this->once()) + ->method('wait') + ->will($this->returnValue($client)); + + $waiter->expects($this->once()) + ->method('setConfig') + ->will($this->returnValue($waiter)); + + $waiter->expects($this->once()) + ->method('setClient') + ->will($this->returnValue($waiter)); + + $factory = $this->getMockBuilder('Aws\Common\Waiter\WaiterFactoryInterface') + ->setMethods(array('build', 'canBuild')) + ->getMock(); + + $factory->expects($this->once()) + ->method('build') + ->will($this->returnValue($waiter)); + + $client->setWaiterFactory($factory); + $this->assertSame($factory, $client->getWaiterFactory()); + + $this->assertSame($client, $client->waitUntil('foo', array('baz' => 'bar'))); + } + + public function testClientUpperCasesMagicMethodCallsToCommands() + { + $client = $this->getMockBuilder('Aws\Common\Client\AbstractClient') + ->disableOriginalConstructor() + ->getMockForAbstractClass(); + + $factory = $this->getMockBuilder('Guzzle\Service\Command\Factory\FactoryInterface') + ->getMock(); + + $factory->expects($this->once()) + ->method('factory') + ->with('FooBar') + ->will($this->returnValue(null)); + + $client->setCommandFactory($factory); + + try { + $client->fooBar(); + } catch (\Exception $e) {} + } + + public function testSetRegionUpdatesBaseUrlAndSignature() + { + /** @var $client AwsClientInterface */ + $client = $this->getServiceBuilder()->get('dynamodb', true); + $client->getConfig()->set('scheme', 'https'); + foreach (array_keys($client->getRegions()) as $region) { + $suffix = (strpos($region, 'cn-') === 0) ? '.cn' : ''; + $client->setRegion($region); + $this->assertEquals("https://dynamodb.{$region}.amazonaws.com{$suffix}", (string) $client->getBaseUrl()); + $this->assertEquals("https://dynamodb.{$region}.amazonaws.com{$suffix}", $client->getConfig('base_url')); + $this->assertEquals($region, $client->getRegion()); + $this->assertEquals($region, $this->readAttribute($client->getSignature(), 'regionName')); + } + + /** @var $client AwsClientInterface */ + $client = $this->getServiceBuilder()->get('sts', true); + $client->getConfig()->set('scheme', 'https'); + foreach (array_keys($client->getRegions()) as $region) { + $client->setRegion($region); + $this->assertEquals("https://sts.amazonaws.com", (string) $client->getBaseUrl()); + $this->assertEquals("https://sts.amazonaws.com", $client->getConfig('base_url')); + $this->assertEquals(Region::US_EAST_1, $client->getRegion()); + $this->assertEquals(Region::US_EAST_1, $this->readAttribute($client->getSignature(), 'regionName')); + } + } + + public function testAllowsMagicWaiters() + { + /** @var $client AbstractClient */ + $client = $this->getMockBuilder('Aws\Common\Client\AbstractClient') + ->setConstructorArgs(array( + new Credentials('test', '123'), + new SignatureV4(), + new Collection() + )) + ->setMethods(array('waitUntil')) + ->getMockForAbstractClass(); + $client->expects($this->once()) + ->method('waitUntil') + ->with('Foo', array('baz' => 'bar')); + $client->waitUntilFoo(array('baz' => 'bar')); + } + + public function testAllowsMagicIterators() + { + /** @var $client AbstractClient */ + $client = $this->getMockBuilder('Aws\Common\Client\AbstractClient') + ->setConstructorArgs(array( + new Credentials('test', '123'), + new SignatureV4(), + new Collection() + )) + ->setMethods(array('getIterator')) + ->getMockForAbstractClass(); + $client->expects($this->once()) + ->method('getIterator') + ->with('Foo', array('baz' => 'bar')); + $client->getFooIterator(array('baz' => 'bar')); + } + + /** + * @expectedException \Aws\Common\Exception\InvalidArgumentException + * @expectedExceptionMessage No regions + */ + public function testEnsuresRegionsAreSetWhenCreatingEndpoints() + { + AbstractClient::getEndpoint(ServiceDescription::factory(array()), 'foo', 'baz'); + } + + /** + * @expectedException \Aws\Common\Exception\InvalidArgumentException + * @expectedExceptionMessage foo is not a valid region + */ + public function testEnsuresRegionIsValidWhenCreatingEndpoints() + { + AbstractClient::getEndpoint(ServiceDescription::factory(array( + 'regions' => array( + 'baz' => array() + ) + )), 'foo', 'baz'); + } + + /** + * @expectedException \Aws\Common\Exception\InvalidArgumentException + * @expectedExceptionMessage http is not a valid URI scheme for + */ + public function testEnsuresSchemeIsValidWhenCreatingEndpoints() + { + AbstractClient::getEndpoint(ServiceDescription::factory(array( + 'regions' => array( + 'baz' => array( + 'http' => false + ) + ) + )), 'baz', 'http'); + } + + public function testCreatesEndpoints() + { + $this->assertEquals('http://test.com', AbstractClient::getEndpoint(ServiceDescription::factory(array( + 'regions' => array( + 'baz' => array( + 'http' => true, + 'hostname' => 'test.com' + ) + ) + )), 'baz', 'http')); + } + + public function testChangeRegionAndCredentialsEvents() + { + /** @var $client \Aws\Common\Client\AbstractClient */ + $client = $this->getServiceBuilder()->get('dynamodb', true); + + $this->assertContains('client.region_changed', $client::getAllEvents()); + $this->assertContains('client.credentials_changed', $client::getAllEvents()); + + $regionChanged = false; + $client->getEventDispatcher()->addListener('client.region_changed', function () use (&$regionChanged) { + $regionChanged = true; + }); + + $credentialsChanged = false; + $client->getEventDispatcher()->addListener('client.credentials_changed', function () use (&$credentialsChanged) { + $credentialsChanged = true; + }); + + $this->assertFalse($regionChanged); + $client->setRegion('us-west-1'); + $this->assertTrue($regionChanged); + + $this->assertFalse($credentialsChanged); + $client->setCredentials(new Credentials('foo', 'bar')); + $this->assertTrue($credentialsChanged); + } + + public function testHasApiVersion() + { + $client = $this->getServiceBuilder()->get('dynamodb', true); + $this->assertNotNull($client->getApiVersion()); + } + + /** + * @expectedException \Aws\Common\Exception\TransferException + */ + public function testWrapsCurlExceptions() + { + $this->getServiceBuilder()->get('dynamodb', true); + $client = DynamoDbClient::factory(array( + 'key' => 'foo', + 'secret' => 'bar', + 'region' => 'us-west-1', + 'client.backoff' => false, + 'base_url' => 'http://localhost:123', + 'curl.options' => array(CURLOPT_TIMEOUT_MS => 1) + )); + $client->listTables(); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Client/ClientBuilderTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Client/ClientBuilderTest.php new file mode 100644 index 0000000..23edb61 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Client/ClientBuilderTest.php @@ -0,0 +1,358 @@ +dynamoDbDescription = __DIR__ . '/../../../../../src/Aws/DynamoDb/Resources/dynamodb-2012-08-10.php'; + $this->stsDescription = __DIR__ . '/../../../../../src/Aws/Sts/Resources/sts-2011-06-15.php'; + } + + public function testBuild() + { + $client = ClientBuilder::factory('Aws\\DynamoDb') + ->setConfig(array()) + ->setConfigDefaults(array( + 'scheme' => 'https', + 'region' => 'us-east-1', + 'service' => 'dynamodb', + 'service.description' => $this->dynamoDbDescription + )) + ->setConfigRequirements(array('scheme')) + ->setExceptionParser(new JsonQueryExceptionParser()) + ->setIteratorsConfig(array('input_token' => 'foo')) + ->build(); + + $this->assertInstanceOf('Aws\DynamoDb\DynamoDbClient', $client); + } + + public function testUsesGlobalEndpoint() + { + $client = ClientBuilder::factory('Aws\\Sts') + ->setConfig(array()) + ->setConfigDefaults(array( + 'service' => 'sts', + 'service.description' => $this->stsDescription + )) + ->build(); + + $this->assertInstanceOf('Aws\Sts\StsClient', $client); + } + + public function testBuildAlternate() + { + $client = ClientBuilder::factory('Aws\\DynamoDb') + ->setConfigDefaults(array( + 'scheme' => 'https', + 'region' => 'us-west-1', + 'service' => 'dynamodb', + 'service.description' => $this->dynamoDbDescription, + 'credentials' => Credentials::factory(array('key' => 'foo', 'secret' => 'bar')), + 'client.backoff' => BackoffPLugin::getExponentialBackoff() + )) + ->build(); + + $this->assertInstanceOf('Aws\DynamoDb\DynamoDbClient', $client); + } + + public function getDataForProcessArrayTest() + { + return array( + array( + array('foo' => 'bar', 'bar' => 'baz'), + array('foo' => 'bar', 'bar' => 'baz'), + ), + array( + new Collection(array('foo' => 'bar', 'bar' => 'baz')), + array('foo' => 'bar', 'bar' => 'baz'), + ), + array( + 'foo', + null + ) + ); + } + + /** + * @dataProvider getDataForProcessArrayTest + */ + public function testProcessArrayProcessesCorrectly($input, $expected) + { + $builder = ClientBuilder::factory('Aws\\DynamoDb'); + + try { + $builder->setConfig($input); + $actual = $this->readAttribute($builder, 'config'); + } catch (\InvalidArgumentException $e) { + $actual = null; + } + + $this->assertEquals($expected, $actual); + } + + /** + * @expectedException \InvalidArgumentException + * @expectedExceptionMessage No regions found in the + */ + public function testEnsuresDescriptionsContainRegions() + { + ClientBuilder::factory('Aws\\DynamoDb') + ->setConfig(array('service.description' => array('signatureVersion' => 'v2'))) + ->build(); + } + + /** + * @expectedException \InvalidArgumentException + * @expectedExceptionMessage The provided signature is not a signature version string or an instance of Aws\Common\Signature\SignatureInterface + */ + public function testEnsuresSignatureIsProvided() + { + ClientBuilder::factory('Aws\\DynamoDb') + ->setConfig(array( + 'region' => 'us-west-1', + 'service' => 'dynamodb', + 'scheme' => 'http', + 'service.description' => array( + 'regions' => array('us-west-1' => array('hostname' => 'foo', 'http' => true)) + ) + )) + ->build(); + } + + public function signatureVersionProvider() + { + return array( + array('v4', 'Aws\\Common\\Signature\\SignatureV4'), + array('v2', 'Aws\\Common\\Signature\\SignatureV2'), + array('v3https', 'Aws\\Common\\Signature\\SignatureV3Https'), + array('foo', false) + ); + } + + /** + * @dataProvider signatureVersionProvider + */ + public function testCanCreateSignaturesBasedOnSignatureStringIdentifier($str, $type) + { + try { + $client = ClientBuilder::factory() + ->setConfig(array( + 'service' => 'foo', + 'region' => 'us-east-1', + 'signature' => $str, + 'service.description' => array( + 'signatureVersion' => 'v2', + 'regions' => array('us-east-1' => array('https' => true, 'hostname' => 'baz')) + ) + )) + ->build(); + $this->assertInstanceOf($type, $client->getSignature()); + } catch (\InvalidArgumentException $e) { + if ($type !== false) { + throw $e; + } + } + } + + /** + * @expectedException \InvalidArgumentException + * @expectedExceptionMessage A region is required + */ + public function testEnsuresExceptionIsThrownWhenMissingRequiredRegion() + { + ClientBuilder::factory('Aws\\DynamoDb') + ->setConfig(array( + 'service' => 'dynamodb', + 'service.description' => array( + 'signatureVersion' => 'v2', + 'regions' => array('us-east-1' => array()) + ) + )) + ->build(); + } + + public function testAddsDefaultCredentials() + { + $_SERVER['HOME'] = '/tmp'; + + $creds = Credentials::factory(array('key' => 'foo', 'secret' => 'bar')); + $config = array( + 'service' => 'dynamodb', + 'region' => 'us-east-1', + 'credentials' => $creds, + 'service.description' => array( + 'signatureVersion' => 'v2', + 'regions' => array('us-east-1' => array('https' => true, 'hostname' => 'foo.com')) + ) + ); + + // Ensure that specific credentials can be used + $client1 = ClientBuilder::factory('Aws\\DynamoDb')->setConfig($config)->build(); + $this->assertSame($creds, $client1->getCredentials()); + unset($config['credentials']); + + // Ensure that the instance metadata service is called when no credentials are supplied + $client2 = ClientBuilder::factory('Aws\\DynamoDb')->setConfig($config)->build(); + try { + $client2->getCredentials()->getAccessKeyId(); + $this->fail('An InstanceProfileCredentialsException should have been thrown.'); + } catch (\Exception $e) { + $this->assertInstanceOf('Aws\Common\Exception\InstanceProfileCredentialsException', $e); + } + + // Ensure that environment credentials are picked up if supplied via $_SERVER + $_SERVER[Credentials::ENV_KEY] = 'server-key'; + $_SERVER[Credentials::ENV_SECRET] = 'server-secret'; + $client3 = ClientBuilder::factory('Aws\\DynamoDb')->setConfig($config)->build(); + $this->assertEquals('server-key', $client3->getCredentials()->getAccessKeyId()); + $this->assertEquals('server-secret', $client3->getCredentials()->getSecretKey()); + unset($_SERVER[Credentials::ENV_KEY], $_SERVER[Credentials::ENV_SECRET]); + + // Ensure that environment credentials are picked up if supplied via AWS_SECRET_ACCESS_KEY + $_SERVER[Credentials::ENV_KEY] = 'server-key'; + // Remove the old key name + unset($_SERVER[Credentials::ENV_SECRET]); + putenv(Credentials::ENV_SECRET); + $_SERVER[Credentials::ENV_SECRET_ACCESS_KEY] = 'server-secret'; + $client4 = ClientBuilder::factory('Aws\\DynamoDb')->setConfig($config)->build(); + $this->assertEquals('server-key', $client4->getCredentials()->getAccessKeyId()); + $this->assertEquals('server-secret', $client4->getCredentials()->getSecretKey()); + unset($_SERVER[Credentials::ENV_KEY], $_SERVER[Credentials::ENV_SECRET]); + putenv(Credentials::ENV_SECRET_ACCESS_KEY); + + // Ensure that environment credentials are picked up if supplied via putenv + putenv(Credentials::ENV_KEY . '=env-key'); + putenv(Credentials::ENV_SECRET . '=env-secret'); + $client5 = ClientBuilder::factory('Aws\\DynamoDb')->setConfig($config)->build(); + $this->assertEquals('env-key', $client5->getCredentials()->getAccessKeyId()); + $this->assertEquals('env-secret', $client5->getCredentials()->getSecretKey()); + putenv(Credentials::ENV_KEY); putenv(Credentials::ENV_SECRET); + } + + public function testAddsDefaultBackoffPluginIfNeeded() + { + $config = array( + 'service' => 'dynamodb', + 'region' => 'us-east-1', + 'service.description' => array( + 'signatureVersion' => 'v2', + 'regions' => array('us-east-1' => array('https' => true, 'hostname' => 'foo.com')) + ) + ); + + // Ensure that a default plugin is set + $client = ClientBuilder::factory('Aws\\DynamoDb')->setConfig($config)->build(); + $this->assertInstanceOf('Guzzle\Plugin\Backoff\BackoffPlugin', $client->getConfig(Options::BACKOFF)); + // Ensure that the plugin is set + $this->assertTrue($this->hasSubscriber($client, $client->getConfig(Options::BACKOFF))); + + // Ensure that a specific plugin can be used + $plugin = BackoffPlugin::getExponentialBackoff(); + $config[Options::BACKOFF] = $plugin; + $client = ClientBuilder::factory('Aws\\DynamoDb')->setConfig($config)->build(); + $this->assertSame($plugin, $client->getConfig(Options::BACKOFF)); + // Ensure that the plugin is set + $this->assertTrue($this->hasSubscriber($client, $plugin)); + } + + public function testUsesBackoffLoggerWithDebug() + { + $config = array( + 'service' => 'dynamodb', + 'region' => 'us-east-1', + 'service.description' => array( + 'signatureVersion' => 'v2', + 'regions' => array('us-east-1' => array('https' => true, 'hostname' => 'foo.com')) + ), + Options::BACKOFF_LOGGER => 'debug', + Options::BACKOFF_LOGGER_TEMPLATE => '[{ts}] {url}' + ); + $client = ClientBuilder::factory('Aws\\DynamoDb')->setConfig($config)->build(); + $plugin = $client->getConfig(Options::BACKOFF); + $this->assertInstanceOf('Guzzle\Plugin\Backoff\BackoffPlugin', $plugin); + $subscribers = $plugin->getEventDispatcher()->getListeners('plugins.backoff.retry'); + $this->assertInstanceOf('Guzzle\Plugin\Backoff\BackoffLogger', $subscribers[0][0]); + $logger = $subscribers[0][0]; + $formatter = $this->readAttribute($logger, 'formatter'); + $this->assertEquals('[{ts}] {url}', $this->readAttribute($formatter, 'template')); + } + + public function testAllowsValidationToBeDisabled() + { + $config = array( + 'service' => 'dynamodb', + 'region' => 'us-east-1', + 'service.description' => array( + 'signatureVersion' => 'v2', + 'regions' => array('us-east-1' => array('https' => true, 'hostname' => 'foo.com')) + ), + 'validation' => false + ); + + $client = ClientBuilder::factory('Aws\\DynamoDb')->setConfig($config)->build(); + $params = $client->getConfig('command.params'); + $this->assertTrue($params['command.disable_validation']); + } + + public function testAllowsBackoffDisabling() + { + $config = array( + 'service' => 'dynamodb', + 'region' => 'us-east-1', + 'service.description' => array( + 'signatureVersion' => 'v2', + 'regions' => array('us-east-1' => array('https' => true, 'hostname' => 'foo.com')) + ), + 'client.backoff' => false + ); + + $client = ClientBuilder::factory('Aws\\DynamoDb')->setConfig($config)->build(); + $this->assertFalse($client->getConfig('client.backoff')); + } + + public function testInjectsVersionIntoServiceDescriptionFileName() + { + $config = array( + 'service' => 'dynamodb', + 'region' => 'us-east-1', + 'version' => DynamoDbClient::LATEST_API_VERSION, + 'service.description' => __DIR__ . '/../../../../../src/Aws/DynamoDb/Resources/dynamodb-%s.php' + ); + + $client = ClientBuilder::factory('Aws\\DynamoDb')->setConfig($config)->build(); + $this->assertNotNull($client->getDescription()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Client/DefaultClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Client/DefaultClientTest.php new file mode 100644 index 0000000..b084e5f --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Client/DefaultClientTest.php @@ -0,0 +1,39 @@ +getMock('Aws\Common\Credentials\CredentialsInterface'); + $client = DefaultClient::factory(array( + Options::CREDENTIALS => $credentials, + Options::SERVICE_DESCRIPTION => __DIR__ . '/../../../../../src/Aws/Sts/Resources/sts-2011-06-15.php' + )); + $this->assertInstanceOf('Aws\Common\Signature\SignatureInterface', $client->getSignature()); + $this->assertInstanceOf('Aws\Common\Credentials\CredentialsInterface', $client->getCredentials()); + $this->assertSame($credentials, $client->getCredentials()); + $this->assertEquals('https://sts.amazonaws.com', $client->getBaseUrl()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Client/ExpiredCredentialsChecker.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Client/ExpiredCredentialsChecker.php new file mode 100644 index 0000000..1670479 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Client/ExpiredCredentialsChecker.php @@ -0,0 +1,132 @@ +assertFalse($checker->getBackoffPeriod(0, new Request('GET', 'http://example.com'), new Response(200))); + } + + public function testOnlyListensForCompletedRequests() + { + $checker = new ExpiredCredentialsChecker(new DefaultXmlExceptionParser()); + $this->assertFalse($checker->getBackoffPeriod(0, new Request('GET', 'http://example.com'))); + } + + public function testOnlyListensForRequestsWithClient() + { + $checker = new ExpiredCredentialsChecker(new DefaultXmlExceptionParser()); + $this->assertFalse($checker->getBackoffPeriod(0, new Request('GET', 'http://example.com'), new Response(403))); + } + + public function dataForRetryableErrorTest() + { + $xmlBody1 = <<< XMLBODY + + + RequestExpired + baz + DUMMY_REQUEST_ID + DUMMY_BUCKET_NAME + DUMMY_HOST_ID + s3.amazonaws.com + +XMLBODY; + + $xmlBody2 = <<< XMLBODY + + + Foo + baz + DUMMY_REQUEST_ID + DUMMY_BUCKET_NAME + DUMMY_HOST_ID + s3.amazonaws.com + +XMLBODY; + $headers = array('Content-Type' => 'application/xml'); + + return array( + array(new Response(403, $headers, $xmlBody1), true), + array(new Response(403, $headers, $xmlBody2), false), + ); + } + + /** + * @dataProvider dataForRetryableErrorTest + */ + public function testReturnsTrueForRetryableErrors(Response $response, $retry) + { + $client = $this->getServiceBuilder()->get('s3', true); + $lines = array(); + $log = new LogPlugin(new ClosureLogAdapter(function ($message) use (&$lines) { + $lines[] = $message; + }), "{request}"); + $client->addSubscriber($log); + $imc = InstanceMetadataClient::factory(array()); + $imc->setBaseUrl('http://localhost:123'); + $credentials = new RefreshableInstanceProfileCredentials( + new Credentials('foo', 'baz', 'bar', time() + 10000), + $imc + ); + $mock = $this->setMockResponse($imc, array( + 'metadata/iam_security_credentials', + 'metadata/iam_security_credentials_webapp' + )); + + $client->setCredentials($credentials); + $this->setMockResponse($client, array( + $response, + new Response(200) + )); + + $request = $client->get('/'); + + try { + $request->send(); + if (!$retry) { + $this->fail('Should have thrown an exception'); + } + // Ensure that the instance profile client sent two requests + $this->assertEquals(2, count($mock->getReceivedRequests())); + $this->assertEquals(2, count($lines)); + $this->assertContains('x-amz-security-token: bar', $lines[0]); + $this->assertContains('x-amz-security-token: AxCusEXAMPLEFooBarBaz', $lines[1]); + } catch (\Exception $e) { + if ($retry) { + $this->fail('Threw exception when not expected: ' . $e->getMessage()); + } + $this->assertCount(0, $mock->getReceivedRequests()); + } + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Client/ThrottlingErrorCheckerTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Client/ThrottlingErrorCheckerTest.php new file mode 100644 index 0000000..e099761 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Client/ThrottlingErrorCheckerTest.php @@ -0,0 +1,93 @@ +assertFalse($checker->getBackoffPeriod(0, $request, $response)); + } + + public function testOnlyListensForCompletedRequests() + { + $request = new Request('GET', 'http://example.com'); + $checker = new ThrottlingErrorChecker(new DefaultXmlExceptionParser()); + $this->assertFalse($checker->getBackoffPeriod(0, $request)); + } + + public function dataForRetryableErrorTest() + { + $xmlBody = <<< XMLBODY + + + + + Throttling + You Got Throttled! + + + xyz + +XMLBODY; + + $jsonBody = <<< JSONBODY +{"__type":"com.amazonaws.dynamodb.v20111205#ProvisionedThroughputExceededException", +"message":"The level of configured provisioned throughput for the table was exceeded."} +JSONBODY; + + return array( + array('application/xml', $xmlBody, new DefaultXmlExceptionParser()), + array('application/x-amz-json-1.0', $jsonBody, new JsonQueryExceptionParser()), + ); + } + + /** + * @dataProvider dataForRetryableErrorTest + */ + public function testReturnsTrueForRetryableErrors($contentType, $contentBody, $exceptionParser) + { + $request = new Request('GET', 'http://example.com'); + $response = new Response(400, array('content-type' => $contentType), $contentBody); + $checker = new ThrottlingErrorChecker($exceptionParser); + $this->assertEquals(0, $checker->getBackoffPeriod(1, $request, $response)); + // Ensure it plays well with the chain + $checker->setNext(new ExponentialBackoffStrategy()); + $this->assertEquals(8, $checker->getBackoffPeriod(3, $request, $response)); + } + + public function testBehavesProperlyAsChainLink() + { + $s = new ExponentialBackoffStrategy(); + $checker = new ThrottlingErrorChecker(new DefaultXmlExceptionParser(), $s); + $this->assertTrue($checker->makesDecision()); + $this->assertSame($s, $checker->getNext()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Client/UploadBodyListenerTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Client/UploadBodyListenerTest.php new file mode 100644 index 0000000..1fe0085 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Client/UploadBodyListenerTest.php @@ -0,0 +1,56 @@ +assertInternalType('array', UploadBodyListener::getSubscribedEvents()); + + $client = $this->getServiceBuilder()->get('s3', true); + $command = $client->getCommand('PutObject', array( + 'Bucket' => 'foo', + 'Key' => 'bar', + 'SourceFile' => __FILE__ + )); + + $command->prepare(); + + $this->assertInstanceOf('Guzzle\Http\EntityBody', $command->get('Body')); + $this->assertNull($command->get('Source')); + } + + public function testFileHandlesGetConvertedToBodies() + { + $client = $this->getServiceBuilder()->get('s3', true); + $command = $client->getCommand('PutObject', array( + 'Bucket' => 'foo', + 'Key' => 'bar', + 'Body' => fopen(__FILE__, 'r') + )); + + $request = $command->prepare(); + $this->assertInstanceOf('Guzzle\Http\EntityBody', $command->get('Body')); + $this->assertEquals('text/x-php', (string) $request->getHeader('Content-Type')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Client/UserAgentListenerTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Client/UserAgentListenerTest.php new file mode 100644 index 0000000..5fa68d5 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Client/UserAgentListenerTest.php @@ -0,0 +1,52 @@ +assertInternalType('array', UserAgentListener::getSubscribedEvents()); + + $listener = new UserAgentListener(); + $request = RequestFactory::getInstance()->create('GET', 'http://www.foo.com', array( + 'User-Agent' => 'Aws/Foo Baz/Bar' + )); + + $command = $this->getMockBuilder('Aws\Common\Command\JsonCommand') + ->setMethods(array('getRequest')) + ->getMock(); + + $command->expects($this->any()) + ->method('getRequest') + ->will($this->returnValue($request)); + + $command->add(UserAgentListener::OPTION, 'Test/123') + ->add(UserAgentListener::OPTION, 'Other/456'); + + $event = new Event(array('command' => $command)); + $listener->onBeforeSend($event); + $this->assertEquals('Aws/Foo Baz/Bar Test/123 Other/456', (string) $request->getHeader('User-Agent')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Command/AwsQueryVisitorTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Command/AwsQueryVisitorTest.php new file mode 100644 index 0000000..d225eea --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Command/AwsQueryVisitorTest.php @@ -0,0 +1,287 @@ +visit($command, $request, $param, $value); + + $fields = $request->getPostFields()->getAll(); + asort($fields); + + $this->assertEquals($result, $fields); + } + + public function testAppliesTopLevelScalarParams() + { + $operation = new Operation(array( + 'parameters' => array( + 'Foo' => array( + 'location' => 'aws.query', + 'type' => 'string', + ) + ) + )); + $command = new QueryCommand(array('Foo' => 'test'), $operation); + $command->setClient(new Client()); + $request = $command->prepare(); + $fields = $request->getPostFields()->getAll(); + $this->assertEquals(array('Foo' => 'test'), $fields); + } + + public function dataForQueryNormalization() + { + $data = array(); + + // Use Case 1 + $data[0] = array(); + // Parameter + $data[0][0] = new Parameter(array( + 'name' => 'IpPermissions', + 'location' => 'aws.query', + 'data' => array('offset' => 1), + 'type' => 'array', + 'items' => array( + 'data' => array('offset' => 1), + 'type' => 'object', + 'properties' => array( + 'IpProtocol' => array('type' => 'string'), + 'FromPort' => array('type' => 'numeric'), + 'ToPort' => array('type' => 'numeric'), + 'Groups' => array( + 'type' => 'array', + 'data' => array('offset' => 1), + 'items' => array( + 'type' => 'object', + 'properties' => array( + 'UserId' => array('type' => 'string'), + 'GroupName' => array('type' => 'string'), + 'GroupId' => array('type' => 'string') + ) + ) + ), + 'IpRanges' => array( + 'type' => 'array', + 'data' => array('offset' => 1), + 'items' => array( + 'type' => 'object', + 'properties' => array( + 'CidrIp' => array('type' => 'string') + ) + ) + ), + 'Foo' => array( + 'type' => 'array', + 'sentAs' => 'Foo.member', + 'data' => array('offset' => 10), + 'items' => array('type' => 'string') + ) + ) + ) + )); + // Value + $data[0][1] = array( + array( + 'IpProtocol' => 'tcp', + 'FromPort' => 20, + 'Groups' => array( + array('UserId' => '123', 'GroupName' => 'Foo', 'GroupId' => 'Bar'), + array('UserId' => '456', 'GroupName' => 'Oof', 'GroupId' => 'Rab') + ), + 'IpRanges' => array( + array('CidrIp' => 'test'), + array('CidrIp' => 'other') + ), + 'Foo' => array('test', 'other') + ) + ); + // Result + $data[0][2] = array( + 'IpPermissions.1.FromPort' => 20, + 'IpPermissions.1.Groups.1.UserId' => '123', + 'IpPermissions.1.Groups.2.UserId' => '456', + 'IpPermissions.1.Groups.1.GroupId' => 'Bar', + 'IpPermissions.1.Groups.1.GroupName' => 'Foo', + 'IpPermissions.1.Groups.2.GroupName' => 'Oof', + 'IpPermissions.1.Groups.2.GroupId' => 'Rab', + 'IpPermissions.1.Foo.member.11' => 'other', + 'IpPermissions.1.IpRanges.2.CidrIp' => 'other', + 'IpPermissions.1.IpProtocol' => 'tcp', + 'IpPermissions.1.IpRanges.1.CidrIp' => 'test', + 'IpPermissions.1.Foo.member.10' => 'test', + ); + + // Use Case 2 + $data[1] = array(); + // Parameter + $data[1][0] = new Parameter(array( + 'name' => 'Attributes', + 'type' => 'object', + 'location' => 'aws.query', + 'sentAs' => 'Attribute', + 'data' => array( + 'keyName' => 'Name', + 'valueName' => 'Value' + ), + 'additionalProperties' => array( + 'type' => 'string', + ), + )); + // Value + $data[1][1] = array( + 'ReceiveMessageWaitTimeSeconds' => 50, + 'DelaySeconds' => 25, + ); + // Result + $data[1][2] = array( + 'Attribute.1.Name' => 'ReceiveMessageWaitTimeSeconds', + 'Attribute.1.Value' => 50, + 'Attribute.2.Name' => 'DelaySeconds', + 'Attribute.2.Value' => 25, + ); + + // Use Case 3 + $data[2] = array(); + // Parameter + $data[2][0] = new Parameter(array( + 'name' => 'Attributes', + 'type' => 'object', + 'location' => 'aws.query', + 'sentAs' => 'Attribute', + 'data' => array( + 'keyName' => 'Name', + 'valueName' => 'Value' + ), + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'Foo' => array('type' => 'string'), + 'Bar' => array('type' => 'string'), + 'Baz' => array('type' => 'string'), + ) + ), + )); + // Value + $data[2][1] = array( + 'Param1' => array( + 'Foo' => 'foo1', + 'Bar' => 'bar1', + 'Baz' => 'baz1', + ), + 'Param2' => array( + 'Foo' => 'foo2', + 'Bar' => 'bar2', + 'Baz' => 'baz2', + ), + ); + // Result + $data[2][2] = array( + 'Attribute.1.Name' => 'Param1', + 'Attribute.1.Value.Foo' => 'foo1', + 'Attribute.1.Value.Bar' => 'bar1', + 'Attribute.1.Value.Baz' => 'baz1', + 'Attribute.2.Name' => 'Param2', + 'Attribute.2.Value.Foo' => 'foo2', + 'Attribute.2.Value.Bar' => 'bar2', + 'Attribute.2.Value.Baz' => 'baz2', + ); + + // Use Case 4 + $data[3] = array(); + // Parameter + $data[3][0] = new Parameter(array( + 'name' => 'Attributes', + 'type' => 'object', + 'location' => 'aws.query', + 'sentAs' => 'Attribute.entry', + 'additionalProperties' => array( + 'type' => 'string', + ), + )); + // Value + $data[3][1] = array( + 'Foo' => 10, + 'Bar' => 20, + ); + // Result + $data[3][2] = array( + 'Attribute.entry.1.key' => 'Foo', + 'Attribute.entry.1.value' => 10, + 'Attribute.entry.2.key' => 'Bar', + 'Attribute.entry.2.value' => 20, + ); + + return $data; + } + + public function testSerializesEmptyLists() + { + $operation = new Operation(array('name' => 'UpdateStack')); + $command = new OperationCommand(array(), $operation); + $request = new EntityEnclosingRequest('POST', 'http://foo.com'); + $visitor = new AwsQueryVisitor(); + $visitor->visit($command, $request, new Parameter(array( + 'name' => 'foo', + 'type' => 'object', + 'location' => 'aws.query', + 'properties' => array( + 'test' => array( + 'type' => 'array' + ), + 'bar' => array( + 'type' => 'object', + 'properties' => array( + 'bam' => array( + 'type' => 'array' + ), + 'boo' => array( + 'type' => 'string' + ) + ) + ) + ) + )), array( + 'test' => array(), + 'bar' => array( + 'bam' => array(), + 'boo' => 'hi' + ) + )); + $fields = $request->getPostFields(); + $this->assertEquals('foo.test=&foo.bar.bam=&foo.bar.boo=hi', (string) $fields); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Command/JsonCommandTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Command/JsonCommandTest.php new file mode 100644 index 0000000..d0671d9 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Command/JsonCommandTest.php @@ -0,0 +1,92 @@ + 'foobar', + 'httpMethod' => 'POST', + 'parameters' => array( + 'test' => array('location' => 'json'), + 'named' => array('location' => 'json', 'sentAs' => 'Foo'), + 'ignore_me' => array('location' => 'header') + ) + )); + + $command = new JsonCommand(array('test' => '123', 'named' => 'abc'), $api); + $command->setClient(new Client()); + $request = $command->prepare(); + $json = json_decode((string) $request->getBody(), true); + $this->assertEquals('123', $json['test']); + $this->assertEquals('abc', $json['Foo']); + } + + public function testAllowsToArrayParameters() + { + $api = new Operation(array( + 'name' => 'foo', + 'httpMethod' => 'POST', + 'parameters' => array( + 'test' => array('location' => 'json'), + 'foo' => array( + 'location' => 'json', + 'type' => 'object', + 'properties' => array( + 'baz' => array( + 'type' => 'string' + ) + ) + ) + ) + )); + + $command = new JsonCommand(array( + 'test' => 'hello', + 'foo' => $this + ), $api); + + $command->setClient(new Client()); + $request = $command->prepare(); + $json = json_decode((string) $request->getBody(), true); + $this->assertEquals('hello', $json['test']); + $this->assertEquals(array('baz' => 'bar'), $json['foo']); + } + + public function testEnsuresThatBodyIsAlwaysSet() + { + $command = new JsonCommand(); + $command->setClient(new Client()); + $request = $command->prepare(); + $this->assertEquals('{}', (string) $request->getBody()); + } + + public function toArray() + { + return array('baz' => 'bar'); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Command/XmlResponseLocationVisitorTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Command/XmlResponseLocationVisitorTest.php new file mode 100644 index 0000000..59d55ba --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Command/XmlResponseLocationVisitorTest.php @@ -0,0 +1,49 @@ +markTestIncomplete(); + } + + public function testHandlesWrappedMembers() + { + $this->markTestIncomplete(); + } + + public function testHandlesXmlMaps() + { + $result = XmlResponseLocationVisitor::xmlMap(array( + array('key' => 'a', 'value' => 1), + array('key' => 'b', 'value' => 2), + array('key' => 'c', 'value' => 3) + ), 'item', 'key', 'value'); + $this->assertEquals(array( + 'a' => '1', + 'b' => '2', + 'c' => '3' + ), $result); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Credentials/.aws/credentials b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Credentials/.aws/credentials new file mode 100644 index 0000000..2c08c0b --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Credentials/.aws/credentials @@ -0,0 +1,6 @@ +[default] +aws_access_key_id=foo +aws_secret_access_key=bar +[test] +aws_access_key_id=fizz +aws_secret_access_key=buzz \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Credentials/AbstractCredentialsDecoratorTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Credentials/AbstractCredentialsDecoratorTest.php new file mode 100644 index 0000000..f3ed621 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Credentials/AbstractCredentialsDecoratorTest.php @@ -0,0 +1,53 @@ +assertEquals('a', $c->getAccessKeyId()); + $this->assertEquals('b', $c->getSecretKey()); + $this->assertEquals('c', $c->getSecurityToken()); + $this->assertEquals(1000, $c->getExpiration()); + + $this->assertSame($c, $c->setAccessKeyId('foo')); + $this->assertSame($c, $c->setSecretKey('baz')); + $this->assertSame($c, $c->setSecurityToken('bar')); + $this->assertSame($c, $c->setExpiration(500)); + + $this->assertEquals('foo', $c->getAccessKeyId()); + $this->assertEquals('baz', $c->getSecretKey()); + $this->assertEquals('bar', $c->getSecurityToken()); + $this->assertEquals(500, $c->getExpiration()); + + $this->assertTrue($c->isExpired()); + + $this->assertSame($c->serialize(), $credentials->serialize()); + $this->assertEquals(unserialize(serialize($c)), $c); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Credentials/AbstractRefreshableCredentialsTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Credentials/AbstractRefreshableCredentialsTest.php new file mode 100644 index 0000000..19af136 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Credentials/AbstractRefreshableCredentialsTest.php @@ -0,0 +1,44 @@ +getMockBuilder('Aws\\Common\\Credentials\\AbstractRefreshableCredentials') + ->setConstructorArgs(array($c)) + ->setMethods(array('refresh')) + ->getMock(); + + $mock->expects($this->exactly(4)) + ->method('refresh'); + + /** @var $mock \Aws\Common\Credentials\AbstractRefreshableCredentials */ + $mock->getAccessKeyId(); + $mock->getSecretKey(); + $mock->getSecurityToken(); + $mock->serialize(); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Credentials/CacheableCredentialsTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Credentials/CacheableCredentialsTest.php new file mode 100644 index 0000000..3434629 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Credentials/CacheableCredentialsTest.php @@ -0,0 +1,97 @@ +getCache(); + + // Seed the cache with some credentials + $c = new Credentials('a', 'b', 'c', time() + 100000); + $cache->save('foo', $c, 10000); + + // Create expired credentials + $c = new Credentials('', '', '', 1); + $creds = new CacheableCredentials($c, $cache, 'foo'); + + // Should get a cache hit + $this->assertEquals('a', $creds->getAccessKeyId()); + $this->assertEquals('b', $creds->getSecretKey()); + $this->assertEquals('c', $creds->getSecurityToken()); + } + + public function testDiscardsExpiredCachedData() + { + $cache = $this->getCache(); + + // Seed the cache with some credentials + $c = new Credentials('a', 'b', 'c', 1); + $cache->save('foo', $c, 10000); + + // Create more expired credentials + $c = new Credentials('foo', 'baz', 'bar', 1); + $creds = new CacheableCredentials($c, $cache, 'foo'); + + // should ignore the expired cached data + $this->assertEquals('foo', $creds->getAccessKeyId()); + $this->assertEquals('baz', $creds->getSecretKey()); + $this->assertEquals('bar', $creds->getSecurityToken()); + } + + public function testSavesCredentialsToCache() + { + $cache = $this->getCache(); + + $mock = $this->getMockBuilder('Aws\\Common\\Credentials\\Credentials') + ->setConstructorArgs(array('foo', 'baz', 'bar', 1)) + ->setMethods(array('isExpired')) + ->getMock(); + + $count = 0; + $callback = function () use (&$count) { + return ++$count == 1; + }; + + // First return true, then false + $mock->expects($this->any()) + ->method('isExpired') + ->will($this->returnCallback($callback)); + + $creds = new CacheableCredentials($mock, $cache, 'foo'); + + // should ignore the expired cached data + $this->assertEquals('foo', $creds->getAccessKeyId()); + + // Ensure that the credentials were cached + $this->assertTrue($cache->contains('foo')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Credentials/CredentialsTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Credentials/CredentialsTest.php new file mode 100644 index 0000000..6207043 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Credentials/CredentialsTest.php @@ -0,0 +1,243 @@ +assertEquals('abc', $c->getAccessKeyId()); + $this->assertEquals('123', $c->getSecretKey()); + $this->assertNull($c->getSecurityToken()); + } + + /** + * @covers Aws\Common\Credentials\Credentials::__construct + * @covers Aws\Common\Credentials\Credentials::getExpiration + */ + public function testOwnsTokenAndExpiration() + { + $c = new Credentials('1', '2', 'a', 123); + $this->assertEquals('a', $c->getSecurityToken()); + $this->assertEquals(123, $c->getExpiration()); + } + + /** + * @covers Aws\Common\Credentials\Credentials::isExpired + */ + public function testCredentialsDoNotExpireByDefault() + { + $c = new Credentials('abc', '123'); + $this->assertFalse($c->isExpired()); + } + + /** + * @covers Aws\Common\Credentials\Credentials::getExpiration + */ + public function testCredentialProvideExpirationDetails() + { + $c = new Credentials('abc', '123'); + $this->assertEquals('abc', $c->getAccessKeyId()); + $this->assertEquals('123', $c->getSecretKey()); + } + + /** + * @covers Aws\Common\Credentials\Credentials::serialize + * @covers Aws\Common\Credentials\Credentials::unserialize + */ + public function testCredentialsCanBeSerialized() + { + $c = new Credentials('a', 'b', 'c'); + + $json = json_decode($c->serialize(), true); + $this->assertEquals('a', $json['key']); + $this->assertEquals('b', $json['secret']); + $this->assertEquals('c', $json['token']); + $this->assertArrayHasKey('token.ttd', $json); + + $c2 = clone $c; + $c2->unserialize($c->serialize()); + $this->assertEquals('a', $c2->getAccessKeyId()); + $this->assertEquals('b', $c2->getSecretKey()); + $this->assertEquals('c', $c2->getSecurityToken()); + } + + public function testCanSetNewValues() + { + $c = new Credentials('', ''); + $c->setAccessKeyId('foo')->setSecretKey('baz')->setSecurityToken('bar')->setExpiration(123); + $this->assertEquals('foo', $c->getAccessKeyId()); + $this->assertEquals('baz', $c->getSecretKey()); + $this->assertEquals(123, $c->getExpiration()); + } + + /** + * @covers Aws\Common\Credentials\Credentials::getConfigDefaults + */ + public function testProvidesListOfCredentialsOptions() + { + $this->assertInternalType('array', Credentials::getConfigDefaults()); + } + + /** + * @covers Aws\Common\Credentials\Credentials::factory + * @covers Aws\Common\Credentials\Credentials::createFromEnvironment + */ + public function testFactoryCreatesBasicCredentials() + { + $credentials = Credentials::factory(array( + 'key' => 'foo', + 'secret' => 'baz', + 'token' => 'bar', + 'token.ttd' => 123 + )); + + $this->assertInstanceOf('Aws\\Common\\Credentials\\Credentials', $credentials); + $this->assertEquals('foo', $credentials->getAccessKeyId()); + $this->assertEquals('baz', $credentials->getSecretKey()); + $this->assertEquals('bar', $credentials->getSecurityToken()); + $this->assertEquals(123, $credentials->getExpiration()); + } + + /** + * @covers Aws\Common\Credentials\Credentials::factory + * @covers Aws\Common\Credentials\Credentials::createFromEnvironment + */ + public function testFactoryCreatesInstanceProfileWhenNoKeysAreProvided() + { + $credentials = Credentials::factory(); + $this->assertInstanceOf('Aws\Common\Credentials\RefreshableInstanceProfileCredentials', $credentials); + } + + /** + * @covers Aws\Common\Credentials\Credentials::factory + * @covers Aws\Common\Credentials\Credentials::createFromEnvironment + */ + public function testFactoryCreatesCredentialsFromEnvCredentials() + { + $_SERVER[Credentials::ENV_KEY] = 'foo'; + $_SERVER[Credentials::ENV_SECRET] = 'bar'; + $credentials = Credentials::factory(); + $this->assertEquals('foo', $credentials->getAccessKeyId()); + $this->assertEquals('bar', $credentials->getSecretKey()); + unset($_SERVER[Credentials::ENV_KEY]); + unset($_SERVER[Credentials::ENV_SECRET]); + } + + /** + * @covers Aws\Common\Credentials\Credentials::factory + * @covers Aws\Common\Credentials\Credentials::createCache + */ + public function testFactoryCreatesCacheWhenSetToTrue() + { + if (!extension_loaded('apc')) { + $this->markTestSkipped('APC is not installed'); + } + + $credentials = Credentials::factory(array( + 'key' => 'foo', + 'secret' => 'bar', + 'credentials.cache' => true + )); + + $this->assertInstanceOf('Aws\Common\Credentials\CacheableCredentials', $credentials); + $this->assertInstanceOf('Guzzle\Cache\DoctrineCacheAdapter', $this->readAttribute($credentials, 'cache')); + $this->assertEquals('credentials_foo', $this->readAttribute($credentials, 'cacheKey')); + } + + /** + * @covers Aws\Common\Credentials\Credentials::factory + * @covers Aws\Common\Credentials\Credentials::createCache + */ + public function testFactoryUsesExplicitlyProvidedCache() + { + $cache = new DoctrineCacheAdapter(new ArrayCache()); + $credentials = Credentials::factory(array( + 'credentials.cache' => $cache + )); + $this->assertInstanceOf('Aws\Common\Credentials\CacheableCredentials', $credentials); + $this->assertInstanceOf('Guzzle\Cache\DoctrineCacheAdapter', $this->readAttribute($credentials, 'cache')); + } + + /** + * @covers Aws\Common\Credentials\Credentials::factory + * @covers Aws\Common\Credentials\Credentials::createCache + * @expectedException \Aws\Common\Exception\InvalidArgumentException + * @expectedExceptionMessage Unable to utilize caching with the specified options + */ + public function testFactoryBailsWhenCacheCannotBeDetermined() + { + Credentials::factory(array('credentials.cache' => 'foo')); + } + + /** + * @covers Aws\Common\Credentials\Credentials::fromIni + * @covers Aws\Common\Credentials\Credentials::getHomeDir + * @dataProvider getDataForCredentialFileTest + */ + public function testFactoryCreatesCredentialsFromCredentialFile( + array $envVars = array(), + $expKey = null, + $expSecret = null, + $profile = null + ) { + foreach ($envVars as $key => $value) { + $_SERVER[$key] = $value; + } + + if (!$expKey && !$expSecret) { + $this->setExpectedException('RuntimeException'); + } + $credentials = Credentials::fromIni($profile); + + $this->assertEquals($expKey, $credentials->getAccessKeyId()); + $this->assertEquals($expSecret, $credentials->getSecretKey()); + } + + public function getDataForCredentialFileTest() + { + return array( + array(array('HOME' => __DIR__), 'foo', 'bar'), + array(array('HOMEDRIVE' => '/', 'HOMEPATH' => __DIR__), 'foo', 'bar'), + array(), + array(array('HOME' => __DIR__), null, null, 'invalid'), + array(array('HOME' => __DIR__), 'fizz', 'buzz', 'test'), + array(array('HOME' => __DIR__, Credentials::ENV_PROFILE => 'test'), 'fizz', 'buzz'), + ); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Credentials/RefreshableInstanceProfileCredentialsIntegrationTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Credentials/RefreshableInstanceProfileCredentialsIntegrationTest.php new file mode 100644 index 0000000..295d8a7 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Credentials/RefreshableInstanceProfileCredentialsIntegrationTest.php @@ -0,0 +1,137 @@ + $client + )); + + $this->assertInstanceOf('Aws\Common\Credentials\RefreshableInstanceProfileCredentials', $credentials); + $this->assertSame($client, $this->readAttribute($credentials, 'client')); + + return array($credentials, $client); + } + + /** + * Ensures that instance profile credentials are refreshed when they expire + * + * @depends testUsesInstanceProfileCredentialsByDefault + */ + public function testRefreshesExpiredCredentials(array $creds) + { + $this->skipIfNotEc2(); + + list($credentials, $client) = $creds; + + // Expire the credentials + $credentials->setExpiration(0); + + if ($this->useMocks()) { + $this->setMockResponse($client, array('metadata/iam_security_credentials', 'metadata/iam_security_credentials_webapp')); + } + + $this->assertNotEmpty($credentials->getAccessKeyId()); + + if ($this->useMocks()) { + $this->assertEquals(2, count($this->getMockedRequests())); + } + } + + /** + * Ensures that clients use instance profile credentials by default + */ + public function testClientsUseInstanceProfileCredentialsByDefault() + { + $client = DynamoDbClient::factory(array( + 'region' => 'us-east-1' + )); + $this->assertInstanceOf('Aws\Common\Credentials\RefreshableInstanceProfileCredentials', $client->getCredentials()); + } + + /** + * @depends testUsesInstanceProfileCredentialsByDefault + */ + public function testClientsUseInstanceProfileCredentials(array $creds) + { + $this->skipIfNotEc2(); + + list($credentials, $client) = $creds; + + $dynamo = DynamoDbClient::factory(array( + 'credentials' => $credentials + )); + + // Ensure that the correct credentials object and client are being used + $this->assertSame($credentials, $dynamo->getCredentials()); + + if ($this->useMocks()) { + $this->setMockResponse($client, array('metadata/iam_security_credentials', 'metadata/iam_security_credentials_webapp')); + $this->setMockResponse($dynamo, 'dynamodb/list_tables_final'); + } + + // Expire the credentials + $credentials->setExpiration(0); + // List a table, causing a credential refresh and list table request + $this->assertInternalType('array', $dynamo->listTables()); + } + + public function testCredentialsUsesApcCacheWhenCacheIsTrue() + { + if (!extension_loaded('apc')) { + $this->markTestSkipped('APC is not installed'); + } + + $client = InstanceMetadataClient::factory(); + $credentials = Credentials::factory(array( + 'credentials.client' => $client, + 'credentials.cache' => true + )); + + $this->assertInstanceOf('Aws\Common\Credentials\CacheableCredentials', $credentials); + $this->assertInstanceOf('Guzzle\Cache\DoctrineCacheAdapter', $this->readAttribute($credentials, 'cache')); + } + + public function testCredentialsCanInjectCacheAndUsesHostnameBasedKey() + { + $cache = new DoctrineCacheAdapter(new ArrayCache()); + $cache->save('credentials_' . crc32(gethostname()), new Credentials('ABC', '123', 'Listen to me', time() + 10000)); + $credentials = Credentials::factory(array( + 'credentials.cache' => $cache + )); + + $this->assertInstanceOf('Aws\Common\Credentials\CacheableCredentials', $credentials); + $this->assertSame($cache, $this->readAttribute($credentials, 'cache')); + $this->assertEquals('ABC', $credentials->getAccessKeyId()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Credentials/RefreshableInstanceProfileCredentialsTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Credentials/RefreshableInstanceProfileCredentialsTest.php new file mode 100644 index 0000000..c80adfb --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Credentials/RefreshableInstanceProfileCredentialsTest.php @@ -0,0 +1,84 @@ +assertInstanceOf('Aws\\Common\\InstanceMetadata\\InstanceMetadataClient', $this->readAttribute($credentials, 'client')); + } + + public function testMetadataCredentialsCanBeRefreshed() + { + list($client, $credentials) = $this->getMetadataCredentials(); + $mock = $this->setMockResponse($client, array( + 'metadata/iam_security_credentials', + 'metadata/iam_security_credentials_webapp' + )); + + $credentials->getSecurityToken(); + + $mockedRequests = $mock->getReceivedRequests(); + $this->assertEquals(2, count($mockedRequests)); + $this->assertContains('/webapp', (string) $mockedRequests[1]->getUrl()); + } + + /** + * @expectedException \Aws\Common\Exception\InstanceProfileCredentialsException + * @expectedExceptionMessage Error retrieving credentials from the instance profile metadata server + */ + public function testExceptionsAreWrapped() + { + list($client, $credentials) = $this->getMetadataCredentials(); + $mock = new MockPlugin(array( + new Response(400) + )); + $client->getEventDispatcher()->addSubscriber($mock); + $credentials->getSecurityToken(); + } + + /** + * @expectedException \Aws\Common\Exception\InstanceProfileCredentialsException + * @expectedExceptionMessage Unexpected response code: InstanceProfileNotFound + */ + public function testEnsuresResponseCodeIsSuccess() + { + list($client, $credentials) = $this->getMetadataCredentials(); + $mock = new MockPlugin(array( + $this->getMockResponse('metadata/iam_security_credentials'), + new Response(200, null, '{ "Code": "InstanceProfileNotFound" }') + )); + $client->getEventDispatcher()->addSubscriber($mock); + $credentials->getSecurityToken(); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/EnumTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/EnumTest.php new file mode 100644 index 0000000..1571302 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/EnumTest.php @@ -0,0 +1,69 @@ +assertEquals(array(), Enum::values()); + } + + /** + * @covers Aws\Common\Enum + */ + public function testAbstractEnumKeysShouldBeEmpty() + { + $this->assertEquals(array(), Enum::keys()); + } + + /** + * @covers Aws\Common\Enum + */ + public function testConcreteEnumValuesAreCorrect() + { + $expected = array( + 'A' => 1, + 'B' => 2, + 'C' => 3, + ); + + $this->assertSame($expected, ConcreteEnum::values()); + } + + /** + * @covers Aws\Common\Enum + */ + public function testConcreteEnumConstantNamesAreCorrect() + { + $expected = array('A', 'B', 'C'); + + $this->assertSame($expected, ConcreteEnum::keys()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Exception/ExceptionListenerTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Exception/ExceptionListenerTest.php new file mode 100644 index 0000000..f05fd27 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Exception/ExceptionListenerTest.php @@ -0,0 +1,60 @@ +assertArrayHasKey('request.error', ExceptionListener::getSubscribedEvents()); + } + + public function testThrowsServiceSpecificExceptions() + { + $e = new ServiceResponseException('Foo'); + $request = new Request('POST', 'http://www.example.com'); + $response = new Response(200); + + $factory = $this->getMockBuilder('Aws\Common\Exception\ExceptionFactoryInterface') + ->setMethods(array('fromResponse')) + ->getMock(); + + $factory->expects($this->once()) + ->method('fromResponse') + ->with($request, $response) + ->will($this->returnValue($e)); + + $listener = new ExceptionListener($factory); + $event = new Event(array('request' => $request, 'response' => $response)); + + try { + $listener->onRequestError($event); + $this->fail('Did not throw expected exception'); + } catch (ServiceResponseException $thrown) { + $this->assertSame($e, $thrown); + } + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Exception/InstanceProfileCredentialsExceptionTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Exception/InstanceProfileCredentialsExceptionTest.php new file mode 100644 index 0000000..635b771 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Exception/InstanceProfileCredentialsExceptionTest.php @@ -0,0 +1,34 @@ +assertNull($e->getStatusCode()); + $e->setStatusCode('Bar'); + $this->assertEquals('Bar', $e->getStatusCode()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Exception/NamespaceExceptionFactoryTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Exception/NamespaceExceptionFactoryTest.php new file mode 100644 index 0000000..687e0d6 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Exception/NamespaceExceptionFactoryTest.php @@ -0,0 +1,58 @@ +assertInstanceOf( + 'Aws\Common\Exception\ServiceResponseException', + $factory->fromResponse($request, $response) + ); + } + + public function testThrowsNamespacedExceptionsThatAreNotServiceExceptions() + { + $request = new Request('POST', 'http://example.com'); + $response = new Response(200, array(), '{ "__type": "runtimeException", "code": "foo", "message": "bar" }'); + $factory = new NamespaceExceptionFactory(new JsonQueryExceptionParser(), 'Aws\Common\Exception'); + $this->assertInstanceOf('Aws\Common\Exception\RuntimeException', $factory->fromResponse($request, $response)); + } + + public function testThrowsNamespacedServiceResponseExceptions() + { + $request = new Request('POST', 'http://example.com'); + $response = new Response(400, array(), '{ "__type": "abc#ServiceResponse", "message": "bar" }'); + $factory = new NamespaceExceptionFactory(new JsonQueryExceptionParser(), 'Aws\Common\Exception'); + $exception = $factory->fromResponse($request, $response); + $this->assertInstanceOf('Aws\Common\Exception\ServiceResponseException', $exception); + $this->assertEquals('ServiceResponse', $exception->getExceptionCode()); + $this->assertEquals('client', $exception->getExceptionType()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Exception/Parser/DefaultXmlExceptionParserTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Exception/Parser/DefaultXmlExceptionParserTest.php new file mode 100644 index 0000000..fb23a86 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Exception/Parser/DefaultXmlExceptionParserTest.php @@ -0,0 +1,104 @@ +' . "\n" . + '' . + ' ' . + ' ' . + ' Error code text' . + ' Error message' . + ' ' . + ' ' . + ' xyz' . + '' + ), + array( + '' . "\n" . + '' . + ' Error code text' . + ' Error message' . + ' Foo' . + ' xyz' . + '' + ), + array( + '' . + ' ' . + ' Error code text' . + ' Error code text' . + ' Error message' . + ' ' . + ' xyz' . + '' + ) + ); + } + + /** + * @dataProvider xmlDataProvider + */ + public function testParsesResponses($xml) + { + $request = new Request('GET', 'http://example.com'); + $response = Response::fromMessage("HTTP/1.1 400 Bad Request\r\n\r\n{$xml}"); + $parser = new DefaultXmlExceptionParser(); + $result = $parser->parse($request, $response); + $this->assertInternalType('array', $result); + $this->assertEquals('client', $result['type']); + $this->assertEquals('Error code text', $result['code']); + $this->assertEquals('Error message', $result['message']); + $this->assertEquals('xyz', $result['request_id']); + $this->assertInstanceOf('SimpleXMLElement', $result['parsed']); + } + + public function testParsesResponsesWithNoBodyAndNoRequestId() + { + $request = new Request('GET', 'http://example.com'); + $response = Response::fromMessage("HTTP/1.1 400 Bad Request\r\n\r\n"); + $parser = new DefaultXmlExceptionParser(); + $result = $parser->parse($request, $response); + $this->assertEquals('400 Bad Request', $result['message']); + $this->assertNull($result['parsed']); + } + + public function testParsesResponsesWithNoBody() + { + $request = new Request('GET', 'http://example.com'); + $response = Response::fromMessage("HTTP/1.1 400 Bad Request\r\nX-Amz-Request-ID: Foo\r\n\r\n"); + $parser = new DefaultXmlExceptionParser(); + $result = $parser->parse($request, $response); + $this->assertEquals('400 Bad Request (Request-ID: Foo)', $result['message']); + $this->assertEquals('Foo', $result['request_id']); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Exception/Parser/JsonQueryExceptionParserTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Exception/Parser/JsonQueryExceptionParserTest.php new file mode 100644 index 0000000..36d9804 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Exception/Parser/JsonQueryExceptionParserTest.php @@ -0,0 +1,72 @@ +assertEquals(array( + 'code' => 'foo', + 'message' => 'lorem ipsum', + 'type' => 'client', + 'request_id' => 'xyz', + 'parsed' => array( + '__type' => 'foo', + 'message' => 'lorem ipsum' + ) + ), $parser->parse($request, $response)); + } + + public function testParsesServerErrorResponsesWithMixedCasing() + { + $request = new Request('GET', 'http://example.com'); + $response = Response::fromMessage( + "HTTP/1.1 500 Internal Server Error\r\n" . + "x-amzn-requestid: 123\r\n\r\n" . + '{ "__Type": "abc#bazFault", "Message": "dolor" }' + ); + + $parser = new JsonQueryExceptionParser(); + $this->assertEquals(array( + 'code' => 'baz', + 'message' => 'dolor', + 'type' => 'server', + 'request_id' => '123', + 'parsed' => array( + '__type' => 'abc#bazFault', + 'message' => 'dolor' + ) + ), $parser->parse($request, $response)); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Exception/Parser/JsonRestExceptionParserTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Exception/Parser/JsonRestExceptionParserTest.php new file mode 100644 index 0000000..142ccb4 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Exception/Parser/JsonRestExceptionParserTest.php @@ -0,0 +1,72 @@ +assertEquals(array( + 'code' => 'foo', + 'message' => 'lorem ipsum', + 'type' => 'client', + 'request_id' => 'xyz', + 'parsed' => array( + 'type' => 'client', + 'message' => 'lorem ipsum', + 'code' => 'foo' + ) + ), $parser->parse($request, $response)); + } + + public function testParsesClientErrorResponseWithCodeInHeader() + { + $request = new Request('GET', 'http://example.com'); + $response = Response::fromMessage( + "HTTP/1.1 400 Bad Request\r\n" . + "x-amzn-RequestId: xyz\r\n" . + "x-amzn-ErrorType: foo:bar\r\n\r\n" . + '{ "message": "lorem ipsum"}' + ); + + $parser = new JsonRestExceptionParser(); + $this->assertEquals(array( + 'code' => 'foo', + 'message' => 'lorem ipsum', + 'type' => 'client', + 'request_id' => 'xyz', + 'parsed' => array( + 'message' => 'lorem ipsum', + ) + ), $parser->parse($request, $response)); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Exception/ServiceResponseExceptionTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Exception/ServiceResponseExceptionTest.php new file mode 100644 index 0000000..e3529fa --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Exception/ServiceResponseExceptionTest.php @@ -0,0 +1,57 @@ +setExceptionCode('foo'); + $this->assertEquals('foo', $e->getExceptionCode()); + $e->setExceptionType('client'); + $this->assertEquals('client', $e->getExceptionType()); + $e->setRequestId('xyz'); + $this->assertEquals('xyz', $e->getRequestId()); + + $response = new Response(200); + $e->setResponse($response); + $this->assertSame($response, $e->getResponse()); + + $this->assertEquals('Aws\Common\Exception\ServiceResponseException: AWS Error Code: foo, Status Code: 200, AWS Request ID: xyz, AWS Error Type: client, AWS Error Message: Foo!', (string) $e); + } + + public function testAddsUserAgentIfAvailable() + { + $request = new Request('GET', 'http://www.foo.com', array('User-Agent' => 'Foo/Bar')); + $response = new Response(200); + $e = new ServiceResponseException('Foo!'); + $e->setExceptionCode('foo'); + $e->setExceptionType('client'); + $e->setRequestId('xyz'); + $e->setRequest($request); + $e->setResponse($response); + $this->assertEquals('Aws\Common\Exception\ServiceResponseException: AWS Error Code: foo, Status Code: 200, AWS Request ID: xyz, AWS Error Type: client, AWS Error Message: Foo!, User-Agent: Foo/Bar', (string) $e); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Facade/FacadeTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Facade/FacadeTest.php new file mode 100644 index 0000000..ee7cd93 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Facade/FacadeTest.php @@ -0,0 +1,54 @@ +getServiceBuilder()); + $this->assertTrue(class_exists('S3')); + $this->assertInstanceOf('Aws\S3\Command\S3Command', \S3::getCommand('ListBuckets')); + } + + public function testCanMountAndUseFacadesToArbitraryNamespaces() + { + Facade::mountFacades($this->getServiceBuilder(), 'Foo'); + $this->assertTrue(class_exists('Foo\\S3')); + $this->assertInstanceOf('Aws\S3\Command\S3Command', \Foo\S3::getCommand('ListBuckets')); + } + + public function testCanAccessMockedClientFromFacade() + { + $aws = clone $this->getServiceBuilder(); + $aws->enableFacades('Foo\Bar'); + + $mockS3Client = $this->getMockBuilder('Aws\S3\S3Client') + ->disableOriginalConstructor() + ->getMock(); + $aws->set('s3', $mockS3Client); + + $retrievedS3Client = \Foo\Bar\S3::getClient(); + $this->assertSame($mockS3Client, $retrievedS3Client); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Hash/ChunkHashTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Hash/ChunkHashTest.php new file mode 100644 index 0000000..37a79a1 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Hash/ChunkHashTest.php @@ -0,0 +1,77 @@ +assertTrue(is_resource($this->readAttribute($chunkHash, 'context'))); + } + + public function testHashingIsHappeningCorrectly() + { + $content = 'foo'; + $hashHex = hash('sha256', $content); + $hashBin = hash('sha256', $content, true); + + $chunkHash = new ChunkHash('sha256'); + $chunkHash->addData($content); + + $this->assertEquals($hashHex, $chunkHash->getHash()); + $this->assertEquals($hashBin, $chunkHash->getHash(true)); + } + + /** + * @expectedException \LogicException + */ + public function testCannotAddDataAfterHashCalculation() + { + $chunkHash = new ChunkHash('sha256'); + $chunkHash->addData('foo'); + $chunkHash->getHash(); + + $chunkHash->addData('bar'); + } + + public function testCloneMakesCopyOfHashContext() + { + $chunkHash1 = new ChunkHash('sha256'); + $chunkHash1->addData('foo'); + + $chunkHash2 = clone $chunkHash1; + + $this->assertEquals(hash('sha256', 'foo'), $chunkHash1->getHash()); + + $chunkHash2->addData('bar'); + $this->assertEquals(hash('sha256', 'foobar'), $chunkHash2->getHash()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Hash/HashUtilsTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Hash/HashUtilsTest.php new file mode 100644 index 0000000..1a5e5ea --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Hash/HashUtilsTest.php @@ -0,0 +1,47 @@ +assertEquals($hex, HashUtils::binToHex($bin)); + $this->assertEquals($bin, HashUtils::hexToBin($hex)); + } + + /** + * @expectedException \InvalidArgumentException + */ + public function testThrowsExceptionForInvalidAlgorithm() + { + HashUtils::validateAlgorithm('foobar'); + } + + public function testReturnsTrueForValidAlgorithm() + { + $this->assertTrue(HashUtils::validateAlgorithm('md5')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Hash/TreeHashTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Hash/TreeHashTest.php new file mode 100644 index 0000000..82d7a09 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Hash/TreeHashTest.php @@ -0,0 +1,132 @@ +chunks = array(str_repeat('x', Size::MB), 'foobar'); + $data->content = join('', $data->chunks); + $data->binHashes = $getHashedChunks($data->chunks, true); + $data->hexHashes = $getHashedChunks($data->chunks, false); + $data->checksum = hash('sha256', join('', $data->binHashes)); + $data->binChecksum = hash('sha256', join('', $data->binHashes), true); + + return $data; + } + + /** + * @covers Aws\Common\Hash\TreeHash::fromChecksums + */ + public function testTreeHashingChecksumsWorksCorrectly() + { + $d = $this->getTestData(); + $this->assertEquals($d->checksum, TreeHash::fromChecksums($d->binHashes, true)->getHash()); + $this->assertEquals($d->checksum, TreeHash::fromChecksums($d->hexHashes)->getHash()); + } + + /** + * @covers Aws\Common\Hash\TreeHash::fromContent + */ + public function testTreeHashingContentWorksCorrectly() + { + $d = $this->getTestData(); + $this->assertEquals($d->checksum, TreeHash::fromContent($d->content)->getHash()); + } + + /** + * @covers Aws\Common\Hash\TreeHash::validateChecksum + */ + public function testValidatingChecksumWorksCorrectly() + { + $d = $this->getTestData(); + $this->assertTrue(TreeHash::validateChecksum($d->content, $d->checksum)); + } + + /** + * @expectedException \InvalidArgumentException + * @covers Aws\Common\Hash\TreeHash::__construct + */ + public function testThrowsExceptionForInvalidAlgorithm() + { + $treeHash = new TreeHash('foobar'); + } + + /** + * @covers Aws\Common\Hash\TreeHash::__construct + * @covers Aws\Common\Hash\TreeHash::addData + * @covers Aws\Common\Hash\TreeHash::addChecksum + * @covers Aws\Common\Hash\TreeHash::getHash + */ + public function testHashingIsHappeningCorrectly() + { + $d = $this->getTestData(); + $treeHash = new TreeHash('sha256'); + $treeHash->addData($d->chunks[0]); + $treeHash->addChecksum($d->hexHashes[1]); + + $this->assertEquals($d->checksum, $treeHash->getHash()); + $this->assertEquals($d->binChecksum, $treeHash->getHash(true)); + } + + /** + * @expectedException \LogicException + * @covers Aws\Common\Hash\TreeHash::addData + */ + public function testCannotAddDataAfterHashCalculation() + { + $chunkHash = new TreeHash('sha256'); + $chunkHash->addData('foo'); + $chunkHash->getHash(); + + $chunkHash->addData('bar'); + } + + /** + * @expectedException \InvalidArgumentException + * @covers Aws\Common\Hash\TreeHash::addData + */ + public function testCannotAddDataChunksLargerThanOneMegabyte() + { + $chunkHash = new TreeHash('sha256'); + $chunkHash->addData(str_repeat('foo', 1.2 * Size::MB)); + } + + /** + * @expectedException \LogicException + * @covers Aws\Common\Hash\TreeHash::addChecksum + */ + public function testCannotAddChecksumsAfterHashCalculation() + { + $chunkHash = new TreeHash('sha256'); + $chunkHash->addData('foo'); + $chunkHash->getHash(); + + $chunkHash->addChecksum('bar'); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/HostNameUtilsTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/HostNameUtilsTest.php new file mode 100644 index 0000000..3602e15 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/HostNameUtilsTest.php @@ -0,0 +1,78 @@ +assertEquals($service, HostNameUtils::parseServiceName($url), 'Service name mismatch'); + $this->assertEquals($region, HostNameUtils::parseRegionName($url), 'Region mismatch'); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/InstanceMetadata/InstanceMetadataClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/InstanceMetadata/InstanceMetadataClientTest.php new file mode 100644 index 0000000..6a9fa0f --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/InstanceMetadata/InstanceMetadataClientTest.php @@ -0,0 +1,89 @@ + 'foo' + )); + + $this->assertEquals('http://169.254.169.254/foo/', $client->getBaseUrl()); + } + + /** + * @covers Aws\Common\InstanceMetadata\InstanceMetadataClient::getCredentials + */ + public function testCredentialsAreNull() + { + $client = InstanceMetadataClient::factory(); + $this->assertNull($client->getCredentials()); + } + + public function testRetrievesMetadataCredentials() + { + $client = InstanceMetadataClient::factory(); + $mock = $this->setMockResponse($client, array( + 'metadata/iam_security_credentials', + 'metadata/iam_security_credentials_webapp' + )); + $credentials = $client->getInstanceProfileCredentials(); + $this->assertEquals('AKIAIEXAMPLEEXAMPLEA', $credentials->getAccessKeyId()); + $this->assertEquals('EXAMPLErUcddCyEXAMPLEnG3vwyGTnFZ4EXAMPLE', $credentials->getSecretKey()); + $this->assertEquals('AxCusEXAMPLEFooBarBaz...', $credentials->getSecurityToken()); + $this->assertEquals(2535752140, $credentials->getExpiration()); + $mockedRequests = $mock->getReceivedRequests(); + $this->assertEquals(2, count($mockedRequests)); + $this->assertContains('/webapp', (string) $mockedRequests[1]->getUrl()); + } + + /** + * @expectedException \Aws\Common\Exception\InstanceProfileCredentialsException + * @expectedExceptionMessage Error retrieving credentials from the instance profile metadata server + */ + public function testExceptionsAreWrapped() + { + $client = InstanceMetadataClient::factory(); + $mock = new MockPlugin(array(new Response(400))); + $client->getEventDispatcher()->addSubscriber($mock); + $client->getInstanceProfileCredentials(); + } + + /** + * @expectedException \Aws\Common\Exception\InstanceProfileCredentialsException + * @expectedExceptionMessage Unexpected response code: InstanceProfileNotFound + */ + public function testEnsuresResponseCodeIsSuccess() + { + $client = InstanceMetadataClient::factory(); + $mock = new MockPlugin(array( + $this->getMockResponse('metadata/iam_security_credentials'), + new Response(200, null, '{ "Code": "InstanceProfileNotFound" }') + )); + $client->getEventDispatcher()->addSubscriber($mock); + $client->getInstanceProfileCredentials(); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Integration/ClientIntegrationTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Integration/ClientIntegrationTest.php new file mode 100644 index 0000000..0968757 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Integration/ClientIntegrationTest.php @@ -0,0 +1,157 @@ +getServiceBuilder()->get('dynamodb', true); + $credentials = $dynamodb->getCredentials(); + $dynamodb = new \ReflectionClass('Aws\DynamoDb\DynamoDbClient'); + $description = require dirname($dynamodb->getFileName()) . '/Resources/dynamodb-2011-12-05.php'; + + /** @var $client DefaultClient */ + $client = DefaultClient::factory(array( + 'credentials' => $credentials, + 'signature' => new SignatureV4(), + 'service.description' => $description, + 'service' => 'dynamodb', + 'region' => 'us-east-1', + )); + + $command = $client->getCommand('ListTables'); + $command->execute(); + + $this->assertEquals(200, $command->getResponse()->getStatusCode()); + } + + public function testCanChangeRegions() + { + /** @var $s3 \Aws\S3\S3Client */ + $s3 = $this->getServiceBuilder()->get('s3', true); + $scheme = $s3->getConfig(Options::SCHEME); + + // Switch to 3 different regions and validate that each switch worked + foreach (array(Region::US_EAST_1, Region::EU_WEST_1, Region::AP_NORTHEAST_1) as $region) { + $s3->setRegion($region); + $endpoint = Url::factory(AbstractClient::getEndpoint($s3->getDescription(), $region, 'https')); + $command = $s3->getCommand('ListBuckets'); + $request = $command->prepare(); + $this->assertEquals((string) $endpoint, $request->getScheme() . '://' . $request->getHost()); + $this->assertEquals((string) $endpoint, $s3->getConfig(Options::BASE_URL)); + $this->assertEquals($region, $s3->getConfig(Options::REGION)); + $this->assertEquals(200, $command->getResponse()->getStatusCode()); + } + } + + public function testCanInstantiateRegionlessClientsWithoutParameters() + { + $config = array('key' => 'foo', 'secret' => 'bar'); + + try { + // Instantiate all of the clients that do not require a region + \Aws\S3\S3Client::factory($config); + \Aws\CloudFront\CloudFrontClient::factory($config); + \Aws\Route53\Route53Client::factory($config); + \Aws\Sts\StsClient::factory($config); + } catch (\InvalidArgumentException $e) { + $this->fail('All of the above clients should have been instantiated without errors: ' . $e->getMessage()); + } + } + + /** + * @dataProvider dataForClientRegionSituationsTest + */ + public function testClientRegionSituations($service, $region, $expectedGetRegion, $expectedGetSignatureRegion) + { + try { + $config = array('key' => 'test-key', 'secret' => 'test-secret'); + if ($region) { + $config['region'] = $region; + } + + $clientFqcn = "Aws\\{$service}\\{$service}Client"; + $client = $clientFqcn::factory($config); + + // Get results + $actualGetRegion = $client->getRegion(); + if ($client->getSignature() instanceof EndpointSignatureInterface) { + $actualGetSignatureRegion = $this->readAttribute($client->getSignature(), 'regionName'); + } else { + $actualGetSignatureRegion = self::REGION_NOT_SIGV4; + } + } catch (\InvalidArgumentException $e) { + // Get results + $actualGetRegion = self::REGION_ERROR; + $actualGetSignatureRegion = self::REGION_ERROR; + } + + $this->assertEquals($expectedGetRegion, $actualGetRegion); + $this->assertEquals($expectedGetSignatureRegion, $actualGetSignatureRegion); + } + + public function dataForClientRegionSituationsTest() + { + return array( + // Services with multiple regional endpoints (e.g., DynamoDB, EC2, CloudFormation) + array('DynamoDB', self::REGION_MISSING, self::REGION_ERROR, self::REGION_ERROR), + array('DynamoDB', Region::US_EAST_1, Region::US_EAST_1, Region::US_EAST_1), + array('DynamoDB', Region::US_WEST_2, Region::US_WEST_2, Region::US_WEST_2), + array('Ec2', self::REGION_MISSING, self::REGION_ERROR, self::REGION_ERROR), + array('Ec2', Region::US_EAST_1, Region::US_EAST_1, self::REGION_NOT_SIGV4), + array('Ec2', Region::US_WEST_2, Region::US_WEST_2, self::REGION_NOT_SIGV4), + + // Services with a single/few regional endpoint (e.g., Data Pipeline, SES, Redshift) + array('DataPipeline', self::REGION_MISSING, self::REGION_ERROR, self::REGION_ERROR), + array('DataPipeline', Region::US_EAST_1, Region::US_EAST_1, Region::US_EAST_1), + array('Redshift', self::REGION_MISSING, self::REGION_ERROR, self::REGION_ERROR), + array('Redshift', Region::US_EAST_1, Region::US_EAST_1, Region::US_EAST_1), + + // Services with a global endpoint (e.g., Sts, Iam, Route53) + array('Sts', self::REGION_MISSING, Region::US_EAST_1, Region::US_EAST_1), + array('Sts', Region::US_EAST_1, Region::US_EAST_1, Region::US_EAST_1), + array('Sts', Region::US_WEST_2, Region::US_EAST_1, Region::US_EAST_1), + array('Route53', self::REGION_MISSING, Region::US_EAST_1, self::REGION_NOT_SIGV4), + array('Route53', Region::US_EAST_1, Region::US_EAST_1, self::REGION_NOT_SIGV4), + array('Route53', Region::US_WEST_2, Region::US_EAST_1, self::REGION_NOT_SIGV4), + + // Services with a global endpoint AND multiple regional endpoints (e.g., S3 only) + array('S3', self::REGION_MISSING, Region::US_EAST_1, self::REGION_NOT_SIGV4), + array('S3', Region::US_EAST_1, Region::US_EAST_1, self::REGION_NOT_SIGV4), + array('S3', Region::US_WEST_2, Region::US_WEST_2, self::REGION_NOT_SIGV4), + ); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Integration/SignatureV2IntegrationTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Integration/SignatureV2IntegrationTest.php new file mode 100644 index 0000000..25927b5 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Integration/SignatureV2IntegrationTest.php @@ -0,0 +1,50 @@ +getServiceBuilder()->serialize(), true); + $default = $data['default_settings']['params']; + $credentials = new Credentials($default['key'], $default['secret']); + + return array($client, $signature, $credentials); + } + + public function testSignsGet2Requests() + { + list($client, $signature, $credentials) = $this->getClasses(); + $request = $client->get('https://sdb.amazonaws.com/?Action=ListDomains&Version=2009-04-15'); + $signature->signRequest($request, $credentials); + $request->send(); + $this->assertNotNull($request->getQuery()->get('Signature')); + $this->assertNotNull($request->getQuery()->get('Timestamp')); + $this->assertInstanceOf('SimpleXMLElement', $request->getResponse()->xml()); + } + + public function testSignsPostRequests() + { + list($client, $signature, $credentials) = $this->getClasses(); + $request = $client->post('https://sdb.amazonaws.com'); + $request->addPostFields(array( + 'Action' => 'ListDomains', + 'Version' => '2009-04-15' + )); + $signature->signRequest($request, $credentials); + $request->send(); + $this->assertNotNull($request->getPostField('Signature')); + $this->assertNotNull($request->getPostField('Timestamp')); + $this->assertInstanceOf('SimpleXMLElement', $request->getResponse()->xml()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Iterator/AwsResourceIteratorFactoryTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Iterator/AwsResourceIteratorFactoryTest.php new file mode 100644 index 0000000..04bb5c7 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Iterator/AwsResourceIteratorFactoryTest.php @@ -0,0 +1,147 @@ + array()), + array('foo' => array( + 'input_token' => null, + 'output_token' => null, + 'limit_key' => null, + 'result_key' => null, + 'more_results' => null, + )) + ), + array( + array('foo' => array( + 'input_token' => 'a', + 'output_token' => 'b', + )), + array('foo' => array( + 'input_token' => 'a', + 'output_token' => 'b', + 'limit_key' => null, + 'result_key' => null, + 'more_results' => null, + )), + ), + ); + } + + /** + * @dataProvider getDataForOperationsTest + */ + public function testOperationsAreDiscoveredInConstructor(array $config, $expectedResult) + { + $factory = new AwsResourceIteratorFactory($config); + $actualResult = $this->readAttribute($factory, 'config'); + $this->assertEquals($expectedResult, $actualResult); + } + + public function getDataForBuildTest() + { + $command = $this->getMockBuilder('Guzzle\Service\Command\CommandInterface') + ->disableOriginalConstructor() + ->getMock(); + $command->expects($this->any()) + ->method('getName') + ->will($this->returnValue('FooBar')); + + $iterator = $this->getMockBuilder('Aws\Common\Iterator\AwsResourceIterator') + ->disableOriginalConstructor() + ->getMock(); + + $primaryFactory = $this->getMockBuilder('Guzzle\Service\Resource\ResourceIteratorFactoryInterface') + ->disableOriginalConstructor() + ->getMock(); + $primaryFactory->expects($this->any()) + ->method('build') + ->will($this->returnValue($iterator)); + $primaryFactory->expects($this->any()) + ->method('canBuild') + ->will($this->returnValue(true)); + + return array( + array($command, array('FooBar' => array()), null, true), + array($command, array(), null, false), + array($command, array(), $primaryFactory, true), + ); + } + + /** + * @dataProvider getDataForBuildTest + */ + public function testBuildCreatesIterator($command, array $operations, $otherFactory, $successExpected) + { + $factory = new AwsResourceIteratorFactory($operations, $otherFactory); + + try { + $iterator = $factory->build($command); + $success = $iterator instanceof AwsResourceIterator; + } catch (\InvalidArgumentException $e) { + $success = false; + } + + $this->assertEquals($successExpected, $factory->canBuild($command)); + $this->assertEquals($successExpected, $success); + } + + public function testLegacyOptionsAreHandled() + { + $command = $this->getMockBuilder('Guzzle\Service\Command\CommandInterface') + ->disableOriginalConstructor() + ->getMock(); + $command->expects($this->any()) + ->method('getName') + ->will($this->returnValue('FooBar')); + + $providedOptions = array( + 'token_param' => 'a', + 'token_key' => 'b', + 'limit_param' => 'c', + 'result_key' => 'd', + 'more_key' => 'e', + ); + + $expectedOptions = array( + 'input_token' => 'a', + 'output_token' => 'b', + 'limit_key' => 'c', + 'result_key' => 'd', + 'more_results' => 'e', + ); + + $factory = new AwsResourceIteratorFactory(array('FooBar' => array())); + $iterator = $factory->build($command, $providedOptions); + $actualOptions = $this->readAttribute($iterator, 'data'); + + $this->assertEquals($expectedOptions, $actualOptions); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Iterator/AwsResourceIteratorTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Iterator/AwsResourceIteratorTest.php new file mode 100644 index 0000000..31f6b0c --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Iterator/AwsResourceIteratorTest.php @@ -0,0 +1,254 @@ +getMockedCommand(); + if ($limit) { + $command->set($limitKey, $limit); + } + + $iterator = new AwsResourceIterator($command, array('limit_key' => $limitKey)); + if ($pageSize) { + $iterator->setPageSize($pageSize); + } + + $property = new \ReflectionProperty($iterator, 'command'); + $property->setAccessible(true); + $property->setValue($iterator, $command); + + $prepareRequest = new \ReflectionMethod($iterator, 'prepareRequest'); + $prepareRequest->setAccessible(true); + $prepareRequest->invoke($iterator); + + $this->assertEquals($resultingLimit, $command->get($limitKey)); + } + + public function getDataForApplyNextTokenTest() + { + return array( + array(null, null, null, false), + array(null, '[MARKER]', null, false), + array('Marker', '[MARKER]', '[MARKER]', false), + array('Marker', array('value1', 'value2'), array('value1', 'value2'), false), + array(array('marker1', 'marker2'), array('value1', 'value2'), array('value1', 'value2'), false), + array(array('marker1', 'marker2', 'marker3'), array('value1', 'value2'), self::EXCEPTION, true), + ); + } + + /** + * @dataProvider getDataForApplyNextTokenTest + */ + public function testApplyNextTokenSetsTokenCorrectly($inputToken, $nextToken, $resultingToken, $expectException) + { + $command = $this->getMockedCommand(); + $iterator = new AwsResourceIterator($command, array('input_token' => $inputToken)); + + $property = new \ReflectionProperty($iterator, 'command'); + $property->setAccessible(true); + $property->setValue($iterator, $command); + + $property = new \ReflectionProperty($iterator, 'nextToken'); + $property->setAccessible(true); + $property->setValue($iterator, $nextToken); + + $applyNextToken = new \ReflectionMethod($iterator, 'applyNextToken'); + $applyNextToken->setAccessible(true); + + try { + $applyNextToken->invoke($iterator); + + // Get results + if (is_array($inputToken)) { + $result = array(); + foreach ($inputToken as $token) { + $result[] = $command->get($token); + } + } else { + $result = $command->get($inputToken); + } + } catch (\RuntimeException $e) { + if ($expectException) { + $result = self::EXCEPTION; + } else { + throw $e; + } + } + + $this->assertEquals($resultingToken, $result); + } + + public function getDataForHandleResultsTest() + { + return array( + array(null, '*', 0), + array('Foo', array(1, 2, 3), 3), + array('Foo', null, 0), + ); + } + + /** + * @dataProvider getDataForHandleResultsTest + */ + public function testResultsAreHandledCorrectly($resultKey, $resultValue, $expectedCount) + { + $model = new Model(array($resultKey => $resultValue)); + $command = $this->getMockedCommand(); + $iterator = new AwsResourceIterator($command, array('result_key' => $resultKey)); + + $handleResults = new \ReflectionMethod($iterator, 'handleResults'); + $handleResults->setAccessible(true); + $this->assertCount($expectedCount, $handleResults->invoke($iterator, $model)); + } + + public function getDataForDetermineNextTokenTest() + { + return array( + array(null, null, null, array()), + array(null, 'NextToken', '[TOKEN]', array( + 'NextToken' => '[TOKEN]' + )), + array('HasMore', 'NextToken', null, array( + 'HasMore' => null, + 'NextToken' => '[TOKEN]' + )), + array('HasMore', 'NextToken', '[TOKEN]', array( + 'HasMore' => '[MORE]', + 'NextToken' => '[TOKEN]' + )), + array('HasMore', null, null, array( + 'HasMore' => '[MORE]' + )), + array('HasMore', array('NextToken1', 'NextToken2'), array('[TOKEN1]', '[TOKEN2]'), array( + 'HasMore' => '[MORE]', + 'NextToken1' => '[TOKEN1]', + 'NextToken2' => '[TOKEN2]' + )) + ); + } + + /** + * @dataProvider getDataForDetermineNextTokenTest + */ + public function testCanDetermineNextTokenCorrectly( + $moreResults, + $outputToken, + $nextToken, + array $data + ) { + $model = new Model($data); + $command = $this->getMockedCommand(); + $iterator = new AwsResourceIterator($command, array( + 'more_results' => $moreResults, + 'output_token' => $outputToken, + )); + + $method = new \ReflectionMethod($iterator, 'determineNextToken'); + $method->setAccessible(true); + $method->invoke($iterator, $model); + + $this->assertEquals($nextToken, $this->readAttribute($iterator, 'nextToken')); + } + + public function testSendRequest() + { + $model1 = new Model(array('NextToken' => 'token')); + $model2 = new Model(array()); + $command = $this->getMockedCommand(); + $command->expects($this->any()) + ->method('getResult') + ->will($this->onConsecutiveCalls($model1, $model2)); + + $iterator = new AwsResourceIterator($command, array( + 'output_token' => 'NextToken', + 'result_key' => 'Results' + )); + + // Setup state + $property = new \ReflectionProperty($iterator, 'nextToken'); + $property->setAccessible(true); + $property->setValue($iterator, 'foo'); + + $property = new \ReflectionProperty($iterator, 'originalCommand'); + $property->setAccessible(true); + $property->setValue($iterator, $command); + + $property = new \ReflectionProperty($iterator, 'command'); + $property->setAccessible(true); + $property->setValue($iterator, $command); + + // Execute method under test + $sendRequest = new \ReflectionMethod($iterator, 'sendRequest'); + $sendRequest->setAccessible(true); + $result = $sendRequest->invoke($iterator); + + $this->assertEquals(array(), $result); + $this->assertSame($model2, $iterator->getLastResult()); + } + + /** + * @return AbstractCommand + */ + protected function getMockedCommand() + { + $command = $this->getMockBuilder('Guzzle\Service\Command\OperationCommand') + ->disableOriginalConstructor() + ->setMethods(array('getResult', 'getName', '__clone')) + ->getMock(); + + $command->expects($this->any()) + ->method('getName') + ->will($this->returnValue('FooBar')); + $command->expects($this->any()) + ->method('__clone') + ->will($this->returnSelf()); + + $command->set('foo', 'bar'); + + return $command; + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Model/MultipartUpload/AbstractTransferStateTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Model/MultipartUpload/AbstractTransferStateTest.php new file mode 100644 index 0000000..fd009f3 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Model/MultipartUpload/AbstractTransferStateTest.php @@ -0,0 +1,128 @@ +mockUploadId = $this->getMockBuilder('Aws\Common\Model\MultipartUpload\AbstractUploadId') + ->setMethods(array('toParams')) + ->getMock(); + $this->mockUploadId->expects($this->any()) + ->method('toParams') + ->will($this->returnValue(array( + 'accountId' => '-', + 'vaultName' => 'foo', + 'uploadId' => 'bar' + ) + )); + } + + protected function getMockedPart($number) + { + $part = $this->getMockForAbstractClass('Aws\Common\Model\MultipartUpload\AbstractUploadPart'); + $r = new \ReflectionClass('Aws\Common\Model\MultipartUpload\AbstractUploadPart'); + $p = $r->getProperty('partNumber'); + $p->setAccessible(true); + $p->setValue($part, $number); + + return $part; + } + + public function testConstructorInitializesState() + { + $state = $this->getMockForAbstractClass('Aws\Common\Model\MultipartUpload\AbstractTransferState', + array($this->mockUploadId) + ); + + $this->assertSame($this->mockUploadId, $state->getUploadId()); + } + + public function testHandlesParts() + { + $state = $this->getMockForAbstractClass('Aws\Common\Model\MultipartUpload\AbstractTransferState', + array($this->mockUploadId) + ); + + $part1 = $this->getMockedPart(1); + $part2 = $this->getMockedPart(2); + $this->assertSame($state, $state->addPart($part1)); + $this->assertSame($state, $state->addPart($part2)); + $this->assertTrue($state->hasPart(1)); + $this->assertTrue($state->hasPart(2)); + $this->assertSame($part1, $state->getPart(1)); + $this->assertSame($part2, $state->getPart(2)); + $this->assertEquals(2, count($state)); + $this->assertEquals(array(1, 2), $state->getPartNumbers()); + $this->assertInstanceOf('ArrayIterator', $state->getIterator()); + } + + public function testCanMarkStateAsAborted() + { + $state = $this->getMockForAbstractClass('Aws\Common\Model\MultipartUpload\AbstractTransferState', + array($this->mockUploadId) + ); + + $this->assertSame($state, $state->setAborted(true)); + $this->assertTrue($state->isAborted()); + $this->assertSame($state, $state->setAborted(false)); + $this->assertFalse($state->isAborted()); + } + + public function testSerializationWorks() + { + $state1 = $this->getMockForAbstractClass('Aws\Common\Model\MultipartUpload\AbstractTransferState', + array($this->mockUploadId) + ); + + $this->assertInstanceOf('Aws\Common\Model\MultipartUpload\AbstractUploadId', $state1->getUploadId()); + $this->assertEquals(array(), $state1->getPartNumbers()); + $this->assertFalse($state1->isAborted()); + + $serialized = serialize($state1); + $state2 = unserialize($serialized); + + $this->assertInstanceOf('Aws\Common\Model\MultipartUpload\AbstractUploadId', $state2->getUploadId()); + $this->assertEquals(array(), $state2->getPartNumbers()); + $this->assertFalse($state2->isAborted()); + } + + /** + * @expectedException \RuntimeException + */ + public function testSerializationFailsWhenPropertyIsMissing() + { + $state1 = $this->getMockForAbstractClass('Aws\Common\Model\MultipartUpload\AbstractTransferState', + array($this->mockUploadId) + ); + + $serialized = str_replace('uploadId', 'xxxxxxxx', serialize($state1)); + unserialize($serialized); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Model/MultipartUpload/AbstractTransferTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Model/MultipartUpload/AbstractTransferTest.php new file mode 100644 index 0000000..eb61997 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Model/MultipartUpload/AbstractTransferTest.php @@ -0,0 +1,149 @@ +getMockBuilder('Aws\Common\Model\MultipartUpload\AbstractTransferState') + ->disableOriginalConstructor() + ->getMockForAbstractClass(); + $transfer = $this->getMockBuilder('Aws\Common\Model\MultipartUpload\AbstractTransfer') + ->setConstructorArgs(array( + $this->getMockBuilder('Aws\Common\Client\AbstractClient') + ->disableOriginalConstructor() + ->getMockForAbstractClass(), + $state, + EntityBody::factory(), + array('foo' => 'bar') + )) + ->getMockForAbstractClass(); + + if ($closure) { + $closure($transfer, $state); + } + + return $transfer; + } + + public function testHasEvents() + { + $this->assertInternalType('array', AbstractTransfer::getAllEvents()); + } + + public function testHasGetters() + { + $transfer = $this->getMockedTransfer(); + + $this->assertInstanceOf('Aws\Common\Model\MultipartUpload\AbstractTransferState', $transfer->getState()); + $this->assertInternalType('array', $transfer->getOptions()); + $this->assertArrayHasKey('foo', $transfer->getOptions()); + } + + public function testCanAbortUpload() + { + + $transfer = $this->getMockedTransfer(); + $model = $this->getMockBuilder('Guzzle\Service\Resource\Model') + ->disableOriginalConstructor() + ->getMock(); + $command = $this->getMockBuilder('Guzzle\Service\Command\OperationCommand') + ->disableOriginalConstructor() + ->getMock(); + $command->expects($this->any()) + ->method('getResult') + ->will($this->returnValue($model)); + $transfer->expects($this->any()) + ->method('getAbortCommand') + ->will($this->returnValue($command)); + + $transfer->abort(); + $this->assertTrue($this->readAttribute($transfer, 'stopped')); + } + + /** + * @expectedException Aws\Common\Exception\RuntimeException + * @expectedExceptionMessage The transfer has been aborted and cannot be uploaded + */ + public function testThrowsExceptionWhenAttemptingToUploadAbortedTransfer() + { + $transfer = $this->getMockedTransfer(function ($transfer, $state) { + $state->setAborted(true); + }); + + $transfer->upload(); + } + + /** + * @expectedException Aws\Common\Exception\MultipartUploadException + */ + public function testWrapsExceptionsThrownDuringUpload() + { + $transfer = $this->getMockedTransfer(); + $e = new \Exception('foo'); + $transfer->expects($this->once()) + ->method('transfer') + ->will($this->throwException($e)); + + $transfer->upload(); + } + + public function testCompletesUploadAndDispatchesEvents() + { + $transfer = $this->getMockedTransfer(); + $model = $this->getMockBuilder('Guzzle\Service\Resource\Model') + ->disableOriginalConstructor() + ->getMock(); + $transfer->expects($this->once()) + ->method('complete') + ->will($this->returnValue($model)); + + $observer = $this->getWildcardObserver($transfer); + $this->assertInstanceOf('Guzzle\Service\Resource\Model', $transfer->upload()); + $this->assertEquals(array( + $transfer::AFTER_UPLOAD, + $transfer::AFTER_COMPLETE + ), array_keys($observer->getGrouped())); + } + + public function testStoppingReturnsState() + { + $transfer = $this->getMockedTransfer(); + $state = null; + $transfer->getEventDispatcher()->addListener($transfer::BEFORE_UPLOAD, function ($event) use (&$state) { + $state = $event['transfer']->stop(); + }); + $transfer->upload(); + $this->assertInstanceOf('Aws\Common\Model\MultipartUpload\AbstractTransferState', $state); + } + + public function testIsInvokable() + { + $transfer = $this->getMockedTransfer(); + $transfer->expects($this->once()) + ->method('transfer'); + $transfer(); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Model/MultipartUpload/AbstractUploadBuilderTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Model/MultipartUpload/AbstractUploadBuilderTest.php new file mode 100644 index 0000000..e4bfb6c --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Model/MultipartUpload/AbstractUploadBuilderTest.php @@ -0,0 +1,82 @@ +className = 'Aws\Common\Model\MultipartUpload\AbstractUploadBuilder'; + $this->mockBuilder = $this->getMockForAbstractClass($this->className); + } + + public function testHasChainableMethodToInstantiate() + { + $uploadBuilder = $this->mockBuilder; + $this->assertInstanceOf($this->className, $uploadBuilder::newInstance()); + } + + public function testCanUploadFromFilename() + { + $b = $this->mockBuilder->setSource(__FILE__); + $this->assertEquals(__FILE__, $this->readAttribute($b, 'source')->getUri()); + } + + /** + * @expectedException \Aws\Common\Exception\InvalidArgumentException + * @expectedExceptionMessage File does not exist + */ + public function testEnsuresFilesExistsWhenSettingSource() + { + $this->mockBuilder->setSource('/path/to/missing/file/yall'); + } + + /** + * @expectedException \Aws\Common\Exception\InvalidArgumentException + * @expectedExceptionMessage Empty body provided to upload builder + */ + public function testEnsuresFileIsNotEmptyWhenSettingSource() + { + $this->mockBuilder->setSource(EntityBody::factory('')); + } + + public function testHasChainableSetterMethods() + { + $client = $this->getServiceBuilder()->get('s3', true); + $body = EntityBody::factory('foo'); + $b = $this->mockBuilder + ->resumeFrom('foo') + ->setClient($client) + ->setSource($body) + ->setHeaders(array( + 'Foo' => 'Bar' + )); + + $this->assertEquals('foo', $this->readAttribute($b, 'state')); + $this->assertSame($client, $this->readAttribute($b, 'client')); + $this->assertSame($body, $this->readAttribute($b, 'source')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Model/MultipartUpload/AbstractUploadIdTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Model/MultipartUpload/AbstractUploadIdTest.php new file mode 100644 index 0000000..479d359 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Model/MultipartUpload/AbstractUploadIdTest.php @@ -0,0 +1,52 @@ + null, 'bar' => null); +} + +/** + * @covers Aws\Common\Model\MultipartUpload\AbstractUploadId + */ +class AbstractUploadIdTest extends \Guzzle\Tests\GuzzleTestCase +{ + public function testUploadIdCorrectlyManagesData() + { + $startingParams = array('foo' => 1, 'bar' => 2); + $uploadId = UploadId::fromParams($startingParams); + $serialized = serialize($uploadId); + $unserialized = unserialize($serialized); + $endingParams = $unserialized->toParams(); + + $this->assertEquals($startingParams, $endingParams); + } + + /** + * @expectedException \InvalidArgumentException + */ + public function testThrowsExceptionWhenMissingData() + { + UploadId::fromParams(array('wrongKey' => 'dummyData')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Model/MultipartUpload/AbstractUploadPartTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Model/MultipartUpload/AbstractUploadPartTest.php new file mode 100644 index 0000000..4b79a4d --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Model/MultipartUpload/AbstractUploadPartTest.php @@ -0,0 +1,54 @@ + 'partNumber', 'fOObAR' => 'fooBar'); + protected $fooBar; +} + +/** + * @covers Aws\Common\Model\MultipartUpload\AbstractUploadPart + */ +class AbstractUploadPartTest extends \Guzzle\Tests\GuzzleTestCase +{ + public function testUploadPartCorrectlyManagesData() + { + $startingData = array('PARTNUMBER' => 5, 'fOObAR' => 10); + $uploadPart = UploadPart::fromArray($startingData); + $this->assertEquals(5, $uploadPart->getPartNumber()); + $serialized = serialize($uploadPart); + $unserialized = unserialize($serialized); + $endingData = $unserialized->toArray(); + + $this->assertEquals($startingData, $endingData); + } + + /** + * @expectedException \InvalidArgumentException + */ + public function testThrowsExceptionWhenMissingData() + { + UploadPart::fromArray(array('wrongKey' => 'dummyData')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/AbstractSignatureTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/AbstractSignatureTest.php new file mode 100644 index 0000000..46957b9 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/AbstractSignatureTest.php @@ -0,0 +1,36 @@ +getMockBuilder('Aws\Common\Signature\AbstractSignature') + ->getMockForAbstractClass(); + + $method = new \ReflectionMethod('Aws\Common\Signature\AbstractSignature', 'getTimestamp'); + $method->setAccessible(true); + + // Ensure that the timestamp is the same when cached + $t = $method->invoke($signature); + $this->assertEquals($t, $method->invoke($signature)); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/SignatureListenerTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/SignatureListenerTest.php new file mode 100644 index 0000000..f00835c --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/SignatureListenerTest.php @@ -0,0 +1,76 @@ +getEventDispatcher(); + $credentials = new Credentials('a', 'b'); + $signature = $this->getMock('Aws\Common\Signature\SignatureV4'); + + // Ensure that signing the request occurred once with the correct args + $signature->expects($this->once()) + ->method('signRequest') + ->with($this->equalTo($request), $this->equalTo($credentials)); + + $listener = new SignatureListener($credentials, $signature); + + // Create a mock event + $event = new Event(array( + 'request' => $request + )); + + $listener->onRequestBeforeSend($event); + } + + public function testCredentialsGetUpdated() + { + $credentials = new Credentials('access-key-one', 'secret'); + $signature = $this->getMock('Aws\Common\Signature\SignatureV4'); + $config = new Collection(); + + $client = new \Aws\S3\S3Client($credentials, $signature, $config); + $listener = new SignatureListener($credentials, $signature); + $client->addSubscriber($listener); + + $this->assertEquals('access-key-one', $this->readAttribute($listener, 'credentials')->getAccessKeyId()); + $client->setCredentials(new Credentials('access-key-two', 'secret')); + $this->assertEquals('access-key-two', $this->readAttribute($listener, 'credentials')->getAccessKeyId()); + } + + /** + * @covers Aws\Common\Signature\SignatureListener::getSubscribedEvents + */ + public function testSubscribesToEvents() + { + $events = SignatureListener::getSubscribedEvents(); + $this->assertArrayHasKey('request.before_send', $events); + $this->assertArrayHasKey('client.credentials_changed', $events); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/SignatureV2Test.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/SignatureV2Test.php new file mode 100644 index 0000000..2a6fce7 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/SignatureV2Test.php @@ -0,0 +1,121 @@ +getMock('Aws\Common\Signature\SignatureV2', array('getTimestamp')); + + // Hack the shared timestamp + $signature->expects($this->any()) + ->method('getTimestamp') + ->will($this->returnValue(strtotime(self::DEFAULT_DATETIME))); + + return $signature; + } + + public function testSignsRequestsWithSecurityToken() + { + $request = RequestFactory::getInstance()->create('POST', 'http://foo.com'); + $request->addPostFields(array('Test' => '123')); + $request->removeHeader('User-Agent')->removeHeader('Content-Length'); + $credentials = new Credentials(self::DEFAULT_KEY, self::DEFAULT_SECRET, 'foo'); + $signature = $this->getSignature(); + $signature->signRequest($request, $credentials); + $this->assertEquals( + "POST\nfoo.com\n/\nAWSAccessKeyId=AKIDEXAMPLE&SecurityToken=foo&SignatureMethod=HmacSHA256&SignatureVersion=2&Test=123&Timestamp=2011-09-09T23%3A36%3A00%2B00%3A00", + $request->getParams()->get('aws.string_to_sign') + ); + } + + /** + * @dataProvider testSuiteProvider + * @covers Aws\Common\Signature\SignatureV2 + */ + public function testSignsRequestsProperly($request, $stringToSign, $postFields, $mocksignature) + { + // Create a request based on the request + $request = RequestFactory::getInstance()->fromMessage($request); + if (!empty($postFields)) { + $request->addPostFields($postFields); + } + + // Sanitize the request + $request->removeHeader('User-Agent')->removeHeader('Content-Length'); + + // Sign the request using the test credentials + $credentials = new Credentials(self::DEFAULT_KEY, self::DEFAULT_SECRET); + // Get a mock signature object + $signature = $this->getSignature(); + + // Sign the request + $signature->signRequest($request, $credentials); + + // Test that the string to sign is correct + $this->assertEquals($stringToSign, $request->getParams()->get('aws.string_to_sign')); + + // Test that the signature is correct + if (!empty($postFields)) { + $this->assertEquals($mocksignature, $request->getPostField('Signature')); + } else { + $this->assertEquals($mocksignature, $request->getQuery()->get('Signature')); + } + } + + /** + * @return array + */ + public function testSuiteProvider() + { + $date = self::DEFAULT_DATETIME; + $timestamp = rawurlencode(gmdate('c', strtotime($date))); + $key = self::DEFAULT_KEY; + + return array( + array( + "POST / HTTP/1.1\r\nHost: sdb.us-west-2.amazonaws.com\r\nContent-Length: 155\r\nContent-Type: application/x-www-form-urlencoded\r\n\r\nSignatureVersion=2&AWSAccessKeyId=$key&Action=ListDomains&Version=2009-04-15&SignatureMethod=HmacSHA256&Timestamp=$timestamp", + "POST\nsdb.us-west-2.amazonaws.com\n/\nAWSAccessKeyId=$key&Action=ListDomains&SignatureMethod=HmacSHA256&SignatureVersion=2&Timestamp=$timestamp&Version=2009-04-15", + array( + 'Version' => '2009-04-15', + 'Action' => 'ListDomains' + ), + "f69jqJCuCMIhB8TiQhWGsEVxa8cs4Yrxw4IhK/yZa68=" + ), + array( + "GET /?SignatureVersion=2&AWSAccessKeyId=$key&Action=ListDomains&Version=2009-04-15&SignatureMethod=HmacSHA256&Timestamp=$timestamp HTTP/1.1\r\nHost: sdb.us-west-2.amazonaws.com", + "GET\nsdb.us-west-2.amazonaws.com\n/\nAWSAccessKeyId=$key&Action=ListDomains&SignatureMethod=HmacSHA256&SignatureVersion=2&Timestamp=$timestamp&Version=2009-04-15", + array(), + "74xJjWQP2QHN4C7c+NoYqGaBQEfjm3FEzAJXJMh78HI=" + ) + ); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/SignatureV3HttpsTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/SignatureV3HttpsTest.php new file mode 100644 index 0000000..1f12f89 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/SignatureV3HttpsTest.php @@ -0,0 +1,103 @@ +getMock('Aws\Common\Signature\SignatureV3Https', array('getTimestamp')); + + // Hack the shared timestamp + $signature->expects($this->any()) + ->method('getTimestamp') + ->will($this->returnValue(strtotime(self::DEFAULT_DATETIME))); + + return $signature; + } + + /** + * @dataProvider testSuiteProvider + * @covers Aws\Common\Signature\SignatureV3Https + */ + public function testSignsRequestsProperly($request) + { + // Create a request based on the request + $request = RequestFactory::getInstance()->fromMessage($request); + + // Sanitize the request + $request->removeHeader('User-Agent')->removeHeader('Content-Length'); + + // Sign the request using the test credentials + $credentials = new Credentials(self::DEFAULT_KEY, self::DEFAULT_SECRET); + + // Get a mock signature object + $signature = $this->getSignature(); + + // Sign the request + $signature->signRequest($request, $credentials); + + // Test that the string to sign is correct + $stringToSign = self::DEFAULT_DATETIME; + $this->assertEquals($stringToSign, $request->getParams()->get('aws.string_to_sign')); + + // Test that the signature is correct + $expectedHeader = 'AWS3-HTTPS AWSAccessKeyId=AKIDEXAMPLE,Algorithm=HmacSHA256,Signature=2xkne78+c4e7JzUxDAADvn9vECImgCcEaBDkYw3Wk+w='; + $this->assertEquals($expectedHeader, $request->getHeader('x-amzn-authorization', true)); + } + + /** + * @return array + */ + public function testSuiteProvider() + { + $date = self::DEFAULT_DATETIME; + return array( + array("GET / HTTP/1.1\r\nHost: example.com\r\n\r\n"), + array("GET / HTTP/1.1\r\nHost: example.com\r\nDate: {$date}\r\n\r\n"), + array("GET / HTTP/1.1\r\nHost: example.com\r\nx-amz-date: {$date}\r\n\r\n"), + ); + } + + /** + * @covers Aws\Common\Signature\SignatureV3Https::signRequest + */ + public function testUsesSecurityTokensWhenAvailable() + { + $signature = $this->getSignature(); + $request = new Request('GET', 'http://www.example.com'); + + // Create a credentials object with a token + $credentials = new Credentials('a', 'b', 'c', time() + 10000); + + $signature->signRequest($request, $credentials); + $this->assertEquals('c', $request->getHeader('x-amz-security-token', true)); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/SignatureV4Test.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/SignatureV4Test.php new file mode 100644 index 0000000..d427e68 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/SignatureV4Test.php @@ -0,0 +1,358 @@ +getMock('Aws\Common\Signature\SignatureV4', array('getTimestamp', 'getDateTime')); + + // Hack the shared timestamp + $signature->expects($this->any()) + ->method('getTimestamp') + ->will($this->returnValue(strtotime(self::DEFAULT_DATETIME))); + + // Hack the date time to deal with the wrong date in the example files + $signature->expects($this->any()) + ->method('getDateTime') + ->will($this->returnValueMap(array( + array(DateFormat::RFC1123, 'Mon, 09 Sep 2011 23:36:00 GMT'), + array(DateFormat::ISO8601, '20110909T233600Z'), + array(DateFormat::SHORT, '20110909') + ))); + + return $signature; + } + + /** + * @dataProvider testSuiteProvider + * @covers Aws\Common\Signature\SignatureV4 + * @covers Aws\Common\Signature\AbstractSignature + */ + public function testSignsRequestsProperly($group) + { + $parser = ParserRegistry::getInstance()->getParser('url'); + $parser->setUtf8Support(true); + + // Create a request based on the '.req' file + $requestString = file_get_contents($group['req']); + $request = RequestFactory::getInstance()->fromMessage($requestString); + + // Sanitize the request + $request->removeHeader('User-Agent'); + $request->removeHeader('Content-Length'); + + // Sign the request using the test credentials + $credentials = new Credentials(self::DEFAULT_KEY, self::DEFAULT_SECRET); + // Get a mock signature object + $signature = $this->getSignature(); + + // Sign the request + $signature->signRequest($request, $credentials); + + // Get debug signature information + $context = $request->getParams()->get('aws.signature'); + + // Test that the canonical request is correct + $this->assertEquals(str_replace("\r", '', file_get_contents($group['creq'])), $context['canonical_request']); + + // Test that the string to sign is correct + $this->assertEquals(str_replace("\r", '', file_get_contents($group['sts'])), $context['string_to_sign']); + + // Test that the authorization header is correct + $this->assertEquals(str_replace("\r", '', file_get_contents($group['authz'])), $request->getHeader('Authorization')); + + $parser->setUtf8Support(false); + } + + /** + * @return array + */ + public function testSuiteProvider() + { + // Gather a list of files sorted by name + $files = glob(__DIR__ . DIRECTORY_SEPARATOR . 'aws4_testsuite' . DIRECTORY_SEPARATOR . '*'); + sort($files); + + // Skip the get-header-key-duplicate.* and get-header-value-order.authz.* test files for now; + // they are believed to be invalid tests. See https://github.com/aws/aws-sdk-php/issues/161 + $files = array_filter($files, function($file) { + return ((strpos($file, 'get-header-key-duplicate.') === false) && + (strpos($file, 'get-header-value-order.' ) === false)); + }); + sort($files); + + $groups = array(); + + // Break the files up into groups of five for each test case + $group = array(); + for ($i = 0, $c = count($files); $i < $c; $i++) { + $types = explode('.', $files[$i]); + $type = end($types); + $group[$type] = $files[$i]; + if (count($group) == 5) { + $groups[] = array($group); + $group = array(); + } + } + + return $groups; + } + + /** + * @covers Aws\Common\Signature\SignatureV4::signRequest + * @covers Aws\Common\Signature\SignatureV4::createSigningContext + * @covers Aws\Common\Signature\SignatureV4::getSigningKey + */ + public function testSignsRequestsWithContentHashCorrectly() + { + $credentials = new Credentials(self::DEFAULT_KEY, self::DEFAULT_SECRET); + $signature = $this->getSignature(); + $request = RequestFactory::getInstance()->fromMessage("GET / HTTP/1.1\r\nx-amz-date: Mon, 09 Sep 2011 23:36:00 GMT\r\nHost: foo.com\r\n\r\n"); + + $contentHash = hash('sha256', 'foobar'); + $request->setHeader('x-amz-content-sha256', $contentHash); + + $signature->signRequest($request, $credentials); + $context = $request->getParams()->get('aws.signature'); + $this->assertContains($contentHash, $context['canonical_request']); + } + + /** + * @covers Aws\Common\Signature\SignatureV4::signRequest + */ + public function testSignsRequestsThatUseXamzdateHeaders() + { + $credentials = new Credentials(self::DEFAULT_KEY, self::DEFAULT_SECRET); + $signature = $this->getSignature(); + $request = RequestFactory::getInstance()->fromMessage("GET / HTTP/1.1\r\nx-amz-date: Mon, 09 Sep 2011 23:36:00 GMT\r\nHost: foo.com\r\n\r\n"); + + $signature->signRequest($request, $credentials); + $context = $request->getParams()->get('aws.signature'); + $this->assertContains("\nx-amz-date:20110909T233600Z", $context['canonical_request']); + $this->assertNotContains("\ndate:20110909T233600Z", $context['canonical_request']); + } + + /** + * @covers Aws\Common\Signature\SignatureV4::signRequest + */ + public function testUsesSecurityTokensWhenAvailable() + { + $signature = $this->getSignature(); + $request = new Request('GET', 'http://www.example.com'); + // Create a credentials object with a token + $credentials = new Credentials('a', 'b', 'c', time() + 10000); + $signature->signRequest($request, $credentials); + $this->assertEquals('c', (string) $request->getHeader('x-amz-security-token')); + } + + /** + * @covers Aws\Common\Signature\SignatureV4::setServiceName + * @covers Aws\Common\Signature\SignatureV4::setRegionName + */ + public function testCanExplicitlySetServiceAndRegionName() + { + $signature = $this->getSignature(); + $signature->setServiceName('foo'); + $signature->setRegionName('bar'); + $request = new Request('GET', 'http://www.example.com'); + $credentials = new Credentials('fizz', 'buzz'); + $signature->signRequest($request, $credentials); + $context = $request->getParams()->get('aws.signature'); + $this->assertContains('/foo/aws4_request', $context['string_to_sign']); + } + + /** + * @covers Aws\Common\Signature\SignatureV4::setMaxCacheSize + * @covers Aws\Common\Signature\SignatureV4::signRequest + * @covers Aws\Common\Signature\SignatureV4::getSigningKey + */ + public function testMaintainsCappedCache() + { + $signature = $this->getSignature(); + $signature->setMaxCacheSize(3); + $request = new Request('GET', 'http://www.example.com'); + + $credentials = new Credentials('fizz', 'buzz'); + $signature->signRequest($request, $credentials); + $this->assertEquals(1, count($this->readAttribute($signature, 'hashCache'))); + + $credentials = new Credentials('fizz', 'baz'); + $signature->signRequest($request, $credentials); + $this->assertEquals(2, count($this->readAttribute($signature, 'hashCache'))); + + $credentials = new Credentials('fizz', 'paz'); + $signature->signRequest($request, $credentials); + $this->assertEquals(3, count($this->readAttribute($signature, 'hashCache'))); + + $credentials = new Credentials('fizz', 'foobar'); + $signature->signRequest($request, $credentials); + $this->assertEquals(1, count($this->readAttribute($signature, 'hashCache'))); + } + + public function queryStringProvider() + { + return array( + + array(array(), ''), + + array(array( + 'X-Amz-Signature' => 'foo' + ), ''), + + array(array( + 'Foo' => '123', + 'Bar' => '456' + ), 'Bar=456&Foo=123'), + + array(array( + 'Foo' => array('b', 'a'), + 'a' => 'bc' + ), 'Foo=a&Foo=b&a=bc'), + + array(array( + 'Foo' => '', + 'a' => 'b' + ), 'Foo=&a=b') + ); + } + + /** + * @covers Aws\Common\Signature\SignatureV4::getCanonicalizedQueryString + * @dataProvider queryStringProvider + */ + public function testCreatesCanonicalizedQueryString($headers, $string) + { + // Make the method publicly callable + $method = new \ReflectionMethod('Aws\Common\Signature\SignatureV4', 'getCanonicalizedQueryString'); + $method->setAccessible(true); + + // Create a request and replace the headers with the test headers + $request = new Request('GET', 'http://www.example.com'); + $request->getQuery()->replace($headers); + + $signature = $this->getMockBuilder('Aws\Common\Signature\SignatureV4') + ->getMockForAbstractClass(); + + $this->assertEquals($string, $method->invoke($signature, $request)); + } + + private function getFixtures() + { + $request = new Request('GET', 'http://foo.com'); + $credentials = new Credentials('foo', 'bar'); + $signature = new SignatureV4('service', 'region'); + $ref = new \ReflectionMethod($signature, 'convertExpires'); + $ref->setAccessible(true); + + return array($request, $credentials, $signature, $ref); + } + + public function testCreatesPresignedDatesFromDateTime() + { + $_SERVER['override_v4_time'] = true; + list($request, $credentials, $signature, $ref) = $this->getFixtures(); + $this->assertEquals(518400, $ref->invoke($signature, new \DateTime('December 11, 2013 00:00:00 UTC'))); + } + + public function testCreatesPresignedDatesFromUnixTimestamp() + { + $_SERVER['override_v4_time'] = true; + list($request, $credentials, $signature, $ref) = $this->getFixtures(); + $this->assertEquals(518400, $ref->invoke($signature, 1386720000)); + } + + public function testCreatesPresignedDateFromStrtotime() + { + $_SERVER['override_v4_time'] = true; + list($request, $credentials, $signature, $ref) = $this->getFixtures(); + $this->assertEquals(518400, $ref->invoke($signature, 'December 11, 2013 00:00:00 UTC')); + } + + public function testAddsSecurityTokenIfPresent() + { + $_SERVER['override_v4_time'] = true; + list($request, $credentials, $signature) = $this->getFixtures(); + $credentials->setSecurityToken('123'); + $url = $signature->createPresignedUrl($request, $credentials, 1386720000); + $this->assertContains('X-Amz-Security-Token=123', $url); + $this->assertContains('X-Amz-Expires=518400', $url); + } + + /** + * @expectedException \InvalidArgumentException + */ + public function testEnsuresSigV4DurationIsLessThanOneWeek() + { + $_SERVER['override_v4_time'] = true; + list($request, $credentials, $signature) = $this->getFixtures(); + $signature->createPresignedUrl($request, $credentials, 'December 31, 2013 00:00:00 UTC'); + } + + public function testConvertsPostToGet() + { + $request = new EntityEnclosingRequest('POST', 'http://foo.com'); + $request->setPostField('foo', 'bar'); + $request->setPostField('baz', 'bam'); + $request = SignatureV4::convertPostToGet($request); + $this->assertEquals('GET', $request->getMethod()); + $this->assertEquals('bar', $request->getQuery()->get('foo')); + $this->assertEquals('bam', $request->getQuery()->get('baz')); + } + + /** + * @expectedException \InvalidArgumentException + */ + public function testEnsuresMethodIsPost() + { + $request = new EntityEnclosingRequest('PUT', 'http://foo.com'); + SignatureV4::convertPostToGet($request); + } +} +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-key-duplicate.authz b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-key-duplicate.authz new file mode 100755 index 0000000..ac05e35 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-key-duplicate.authz @@ -0,0 +1 @@ +AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host;zoo, Signature=54afcaaf45b331f81cd2edb974f7b824ff4dd594cbbaa945ed636b48477368ed \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-key-duplicate.creq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-key-duplicate.creq new file mode 100755 index 0000000..57e0862 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-key-duplicate.creq @@ -0,0 +1,9 @@ +POST +/ + +date:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com +zoo:foobar,zoobar,zoobar + +date;host;zoo +e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-key-duplicate.req b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-key-duplicate.req new file mode 100755 index 0000000..eb3a429 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-key-duplicate.req @@ -0,0 +1,7 @@ +POST / http/1.1 +DATE:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com +ZOO:zoobar +zoo:foobar +zoo:zoobar + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-key-duplicate.sreq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-key-duplicate.sreq new file mode 100755 index 0000000..5c464f3 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-key-duplicate.sreq @@ -0,0 +1,8 @@ +POST / http/1.1 +DATE:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com +ZOO:zoobar +zoo:foobar +zoo:zoobar +Authorization: AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host;zoo, Signature=54afcaaf45b331f81cd2edb974f7b824ff4dd594cbbaa945ed636b48477368ed + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-key-duplicate.sts b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-key-duplicate.sts new file mode 100755 index 0000000..7b11b51 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-key-duplicate.sts @@ -0,0 +1,4 @@ +AWS4-HMAC-SHA256 +20110909T233600Z +20110909/us-east-1/host/aws4_request +3c52f0eaae2b61329c0a332e3fa15842a37bc5812cf4d80eb64784308850e313 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-value-order.authz b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-value-order.authz new file mode 100755 index 0000000..c80262a --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-value-order.authz @@ -0,0 +1 @@ +AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host;p, Signature=d2973954263943b11624a11d1c963ca81fb274169c7868b2858c04f083199e3d \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-value-order.creq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-value-order.creq new file mode 100755 index 0000000..9b61ef5 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-value-order.creq @@ -0,0 +1,9 @@ +POST +/ + +date:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com +p:a,a,p,z + +date;host;p +e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-value-order.req b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-value-order.req new file mode 100755 index 0000000..ea30500 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-value-order.req @@ -0,0 +1,8 @@ +POST / http/1.1 +DATE:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com +p:z +p:a +p:p +p:a + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-value-order.sreq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-value-order.sreq new file mode 100755 index 0000000..536ab04 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-value-order.sreq @@ -0,0 +1,9 @@ +POST / http/1.1 +DATE:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com +p:z +p:a +p:p +p:a +Authorization: AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host;p, Signature=d2973954263943b11624a11d1c963ca81fb274169c7868b2858c04f083199e3d + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-value-order.sts b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-value-order.sts new file mode 100755 index 0000000..d80190a --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-value-order.sts @@ -0,0 +1,4 @@ +AWS4-HMAC-SHA256 +20110909T233600Z +20110909/us-east-1/host/aws4_request +94c0389fefe0988cbbedc8606f0ca0b485b48da010d09fc844b45b697c8924fe \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-value-trim.authz b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-value-trim.authz new file mode 100755 index 0000000..2d870cc --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-value-trim.authz @@ -0,0 +1 @@ +AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host;p, Signature=debf546796015d6f6ded8626f5ce98597c33b47b9164cf6b17b4642036fcb592 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-value-trim.creq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-value-trim.creq new file mode 100755 index 0000000..43b4a85 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-value-trim.creq @@ -0,0 +1,9 @@ +POST +/ + +date:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com +p:phfft + +date;host;p +e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-value-trim.req b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-value-trim.req new file mode 100755 index 0000000..e148363 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-value-trim.req @@ -0,0 +1,5 @@ +POST / http/1.1 +DATE:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com +p: phfft + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-value-trim.sreq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-value-trim.sreq new file mode 100755 index 0000000..ab33a91 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-value-trim.sreq @@ -0,0 +1,6 @@ +POST / http/1.1 +DATE:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com +p: phfft +Authorization: AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host;p, Signature=debf546796015d6f6ded8626f5ce98597c33b47b9164cf6b17b4642036fcb592 + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-value-trim.sts b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-value-trim.sts new file mode 100755 index 0000000..7b7ead8 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-header-value-trim.sts @@ -0,0 +1,4 @@ +AWS4-HMAC-SHA256 +20110909T233600Z +20110909/us-east-1/host/aws4_request +dddd1902add08da1ac94782b05f9278c08dc7468db178a84f8950d93b30b1f35 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-space.authz b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-space.authz new file mode 100755 index 0000000..4f8ec5e --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-space.authz @@ -0,0 +1 @@ +AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host, Signature=f309cfbd10197a230c42dd17dbf5cca8a0722564cb40a872d25623cfa758e374 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-space.creq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-space.creq new file mode 100755 index 0000000..e34ff1a --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-space.creq @@ -0,0 +1,8 @@ +GET +/%20/foo + +date:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com + +date;host +e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-space.req b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-space.req new file mode 100755 index 0000000..0c64446 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-space.req @@ -0,0 +1,4 @@ +GET /%20/foo http/1.1 +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-space.sreq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-space.sreq new file mode 100755 index 0000000..3fde5d2 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-space.sreq @@ -0,0 +1,5 @@ +GET /%20/foo http/1.1 +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com +Authorization: AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host, Signature=f309cfbd10197a230c42dd17dbf5cca8a0722564cb40a872d25623cfa758e374 + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-space.sts b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-space.sts new file mode 100755 index 0000000..48b7200 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-space.sts @@ -0,0 +1,4 @@ +AWS4-HMAC-SHA256 +20110909T233600Z +20110909/us-east-1/host/aws4_request +69c45fb9fe3fd76442b5086e50b2e9fec8298358da957b293ef26e506fdfb54b \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-unreserved.authz b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-unreserved.authz new file mode 100755 index 0000000..99d2016 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-unreserved.authz @@ -0,0 +1 @@ +AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host, Signature=830cc36d03f0f84e6ee4953fbe701c1c8b71a0372c63af9255aa364dd183281e \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-unreserved.creq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-unreserved.creq new file mode 100755 index 0000000..a0c0c2b --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-unreserved.creq @@ -0,0 +1,8 @@ +GET +/-._~0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz + +date:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com + +date;host +e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-unreserved.req b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-unreserved.req new file mode 100755 index 0000000..d88a5d7 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-unreserved.req @@ -0,0 +1,4 @@ +GET /-._~0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz http/1.1 +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-unreserved.sreq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-unreserved.sreq new file mode 100755 index 0000000..8e9280b --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-unreserved.sreq @@ -0,0 +1,5 @@ +GET /-._~0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz http/1.1 +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com +Authorization: AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host, Signature=830cc36d03f0f84e6ee4953fbe701c1c8b71a0372c63af9255aa364dd183281e + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-unreserved.sts b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-unreserved.sts new file mode 100755 index 0000000..c02109b --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-unreserved.sts @@ -0,0 +1,4 @@ +AWS4-HMAC-SHA256 +20110909T233600Z +20110909/us-east-1/host/aws4_request +df63ee3247c0356c696a3b21f8d8490b01fa9cd5bc6550ef5ef5f4636b7b8901 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-utf8.authz b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-utf8.authz new file mode 100755 index 0000000..a8b8492 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-utf8.authz @@ -0,0 +1 @@ +AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host, Signature=8d6634c189aa8c75c2e51e106b6b5121bed103fdb351f7d7d4381c738823af74 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-utf8.creq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-utf8.creq new file mode 100755 index 0000000..65946cb --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-utf8.creq @@ -0,0 +1,8 @@ +GET +/%E1%88%B4 + +date:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com + +date;host +e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-utf8.req b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-utf8.req new file mode 100755 index 0000000..83291e8 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-utf8.req @@ -0,0 +1,4 @@ +GET /%E1%88%B4 http/1.1 +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-utf8.sreq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-utf8.sreq new file mode 100755 index 0000000..1d69c23 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-utf8.sreq @@ -0,0 +1,5 @@ +GET /%E1%88%B4 http/1.1 +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com +Authorization: AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host, Signature=8d6634c189aa8c75c2e51e106b6b5121bed103fdb351f7d7d4381c738823af74 + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-utf8.sts b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-utf8.sts new file mode 100755 index 0000000..63871e5 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-utf8.sts @@ -0,0 +1,4 @@ +AWS4-HMAC-SHA256 +20110909T233600Z +20110909/us-east-1/host/aws4_request +27ba31df5dbc6e063d8f87d62eb07143f7f271c5330a917840586ac1c85b6f6b \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-empty-query-key.authz b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-empty-query-key.authz new file mode 100755 index 0000000..cb7a1cc --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-empty-query-key.authz @@ -0,0 +1 @@ +AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host, Signature=56c054473fd260c13e4e7393eb203662195f5d4a1fada5314b8b52b23f985e9f \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-empty-query-key.creq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-empty-query-key.creq new file mode 100755 index 0000000..1efbecf --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-empty-query-key.creq @@ -0,0 +1,8 @@ +GET +/ +foo=bar +date:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com + +date;host +e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-empty-query-key.req b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-empty-query-key.req new file mode 100755 index 0000000..fac3491 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-empty-query-key.req @@ -0,0 +1,4 @@ +GET /?foo=bar http/1.1 +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-empty-query-key.sreq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-empty-query-key.sreq new file mode 100755 index 0000000..71d5463 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-empty-query-key.sreq @@ -0,0 +1,5 @@ +GET /?foo=bar http/1.1 +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com +Authorization: AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host, Signature=56c054473fd260c13e4e7393eb203662195f5d4a1fada5314b8b52b23f985e9f + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-empty-query-key.sts b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-empty-query-key.sts new file mode 100755 index 0000000..785c7e5 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-empty-query-key.sts @@ -0,0 +1,4 @@ +AWS4-HMAC-SHA256 +20110909T233600Z +20110909/us-east-1/host/aws4_request +0846c2945b0832deb7a463c66af5c4f8bd54ec28c438e67a214445b157c9ddf8 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-key-case.authz b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-key-case.authz new file mode 100755 index 0000000..10fe960 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-key-case.authz @@ -0,0 +1 @@ +AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host, Signature=be7148d34ebccdc6423b19085378aa0bee970bdc61d144bd1a8c48c33079ab09 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-key-case.creq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-key-case.creq new file mode 100755 index 0000000..f1e99d1 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-key-case.creq @@ -0,0 +1,8 @@ +GET +/ +foo=Zoo&foo=aha +date:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com + +date;host +e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-key-case.req b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-key-case.req new file mode 100755 index 0000000..d5e81df --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-key-case.req @@ -0,0 +1,4 @@ +GET /?foo=Zoo&foo=aha http/1.1 +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-key-case.sreq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-key-case.sreq new file mode 100755 index 0000000..a438d93 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-key-case.sreq @@ -0,0 +1,5 @@ +GET /?foo=Zoo&foo=aha http/1.1 +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com +Authorization: AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host, Signature=be7148d34ebccdc6423b19085378aa0bee970bdc61d144bd1a8c48c33079ab09 + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-key-case.sts b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-key-case.sts new file mode 100755 index 0000000..4d255cc --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-key-case.sts @@ -0,0 +1,4 @@ +AWS4-HMAC-SHA256 +20110909T233600Z +20110909/us-east-1/host/aws4_request +e25f777ba161a0f1baf778a87faf057187cf5987f17953320e3ca399feb5f00d \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-key.authz b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-key.authz new file mode 100755 index 0000000..bc5463e --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-key.authz @@ -0,0 +1 @@ +AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host, Signature=0dc122f3b28b831ab48ba65cb47300de53fbe91b577fe113edac383730254a3b \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-key.creq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-key.creq new file mode 100755 index 0000000..46b1c0f --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-key.creq @@ -0,0 +1,8 @@ +GET +/ +a=foo&b=foo +date:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com + +date;host +e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-key.req b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-key.req new file mode 100755 index 0000000..f1b75b1 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-key.req @@ -0,0 +1,4 @@ +GET /?a=foo&b=foo http/1.1 +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-key.sreq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-key.sreq new file mode 100755 index 0000000..7cb2519 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-key.sreq @@ -0,0 +1,5 @@ +GET /?a=foo&b=foo http/1.1 +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com +Authorization: AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host, Signature=0dc122f3b28b831ab48ba65cb47300de53fbe91b577fe113edac383730254a3b + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-key.sts b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-key.sts new file mode 100755 index 0000000..e791351 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-key.sts @@ -0,0 +1,4 @@ +AWS4-HMAC-SHA256 +20110909T233600Z +20110909/us-east-1/host/aws4_request +2f23d14fe13caebf6dfda346285c6d9c14f49eaca8f5ec55c627dd7404f7a727 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-value.authz b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-value.authz new file mode 100755 index 0000000..9b96017 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-value.authz @@ -0,0 +1 @@ +AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host, Signature=feb926e49e382bec75c9d7dcb2a1b6dc8aa50ca43c25d2bc51143768c0875acc \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-value.creq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-value.creq new file mode 100755 index 0000000..3c0d516 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-value.creq @@ -0,0 +1,8 @@ +GET +/ +foo=a&foo=b +date:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com + +date;host +e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-value.req b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-value.req new file mode 100755 index 0000000..004f153 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-value.req @@ -0,0 +1,4 @@ +GET /?foo=b&foo=a http/1.1 +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-value.sreq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-value.sreq new file mode 100755 index 0000000..61bd549 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-value.sreq @@ -0,0 +1,5 @@ +GET /?foo=b&foo=a http/1.1 +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com +Authorization: AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host, Signature=feb926e49e382bec75c9d7dcb2a1b6dc8aa50ca43c25d2bc51143768c0875acc + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-value.sts b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-value.sts new file mode 100755 index 0000000..95becb2 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-order-value.sts @@ -0,0 +1,4 @@ +AWS4-HMAC-SHA256 +20110909T233600Z +20110909/us-east-1/host/aws4_request +33dffc220e89131f8f6157a35c40903daa658608d9129ff9489e5cf5bbd9b11b \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-unreserved.authz b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-unreserved.authz new file mode 100755 index 0000000..bc28668 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-unreserved.authz @@ -0,0 +1 @@ +AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host, Signature=f1498ddb4d6dae767d97c466fb92f1b59a2c71ca29ac954692663f9db03426fb \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-unreserved.creq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-unreserved.creq new file mode 100755 index 0000000..4a43670 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-unreserved.creq @@ -0,0 +1,8 @@ +GET +/ +-._~0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz=-._~0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz +date:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com + +date;host +e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-unreserved.req b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-unreserved.req new file mode 100755 index 0000000..72f6173 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-unreserved.req @@ -0,0 +1,4 @@ +GET /?-._~0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz=-._~0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz http/1.1 +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-unreserved.sreq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-unreserved.sreq new file mode 100755 index 0000000..a18d653 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-unreserved.sreq @@ -0,0 +1,5 @@ +GET /?-._~0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz=-._~0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz http/1.1 +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com +Authorization: AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host, Signature=f1498ddb4d6dae767d97c466fb92f1b59a2c71ca29ac954692663f9db03426fb + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-unreserved.sts b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-unreserved.sts new file mode 100755 index 0000000..b454387 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query-unreserved.sts @@ -0,0 +1,4 @@ +AWS4-HMAC-SHA256 +20110909T233600Z +20110909/us-east-1/host/aws4_request +d2578f3156d4c9d180713d1ff20601d8a3eed0dd35447d24603d7d67414bd6b5 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query.authz b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query.authz new file mode 100755 index 0000000..06bd813 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query.authz @@ -0,0 +1 @@ +AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host, Signature=b27ccfbfa7df52a200ff74193ca6e32d4b48b8856fab7ebf1c595d0670a7e470 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query.creq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query.creq new file mode 100755 index 0000000..8519923 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query.creq @@ -0,0 +1,8 @@ +GET +/ + +date:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com + +date;host +e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query.req b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query.req new file mode 100755 index 0000000..77b339a --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query.req @@ -0,0 +1,4 @@ +GET / http/1.1 +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query.sreq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query.sreq new file mode 100755 index 0000000..bd1f8f2 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query.sreq @@ -0,0 +1,5 @@ +GET / http/1.1 +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com +Authorization: AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host, Signature=b27ccfbfa7df52a200ff74193ca6e32d4b48b8856fab7ebf1c595d0670a7e470 + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query.sts b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query.sts new file mode 100755 index 0000000..c7bcc67 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla-query.sts @@ -0,0 +1,4 @@ +AWS4-HMAC-SHA256 +20110909T233600Z +20110909/us-east-1/host/aws4_request +366b91fb121d72a00f46bbe8d395f53a102b06dfb7e79636515208ed3fa606b1 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla.authz b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla.authz new file mode 100755 index 0000000..06bd813 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla.authz @@ -0,0 +1 @@ +AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host, Signature=b27ccfbfa7df52a200ff74193ca6e32d4b48b8856fab7ebf1c595d0670a7e470 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla.creq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla.creq new file mode 100755 index 0000000..8519923 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla.creq @@ -0,0 +1,8 @@ +GET +/ + +date:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com + +date;host +e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla.req b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla.req new file mode 100755 index 0000000..77b339a --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla.req @@ -0,0 +1,4 @@ +GET / http/1.1 +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla.sreq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla.sreq new file mode 100755 index 0000000..bd1f8f2 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla.sreq @@ -0,0 +1,5 @@ +GET / http/1.1 +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com +Authorization: AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host, Signature=b27ccfbfa7df52a200ff74193ca6e32d4b48b8856fab7ebf1c595d0670a7e470 + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla.sts b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla.sts new file mode 100755 index 0000000..c7bcc67 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/get-vanilla.sts @@ -0,0 +1,4 @@ +AWS4-HMAC-SHA256 +20110909T233600Z +20110909/us-east-1/host/aws4_request +366b91fb121d72a00f46bbe8d395f53a102b06dfb7e79636515208ed3fa606b1 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-key-case.authz b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-key-case.authz new file mode 100755 index 0000000..a6a7cbb --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-key-case.authz @@ -0,0 +1 @@ +AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host, Signature=22902d79e148b64e7571c3565769328423fe276eae4b26f83afceda9e767f726 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-key-case.creq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-key-case.creq new file mode 100755 index 0000000..a1c8480 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-key-case.creq @@ -0,0 +1,8 @@ +POST +/ + +date:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com + +date;host +e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-key-case.req b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-key-case.req new file mode 100755 index 0000000..67d74a3 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-key-case.req @@ -0,0 +1,4 @@ +POST / http/1.1 +DATE:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-key-case.sreq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-key-case.sreq new file mode 100755 index 0000000..97875f9 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-key-case.sreq @@ -0,0 +1,5 @@ +POST / http/1.1 +DATE:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com +Authorization: AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host, Signature=22902d79e148b64e7571c3565769328423fe276eae4b26f83afceda9e767f726 + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-key-case.sts b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-key-case.sts new file mode 100755 index 0000000..30fb98a --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-key-case.sts @@ -0,0 +1,4 @@ +AWS4-HMAC-SHA256 +20110909T233600Z +20110909/us-east-1/host/aws4_request +05da62cee468d24ae84faff3c39f1b85540de60243c1bcaace39c0a2acc7b2c4 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-key-sort.authz b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-key-sort.authz new file mode 100755 index 0000000..fdcbdd9 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-key-sort.authz @@ -0,0 +1 @@ +AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host;zoo, Signature=b7a95a52518abbca0964a999a880429ab734f35ebbf1235bd79a5de87756dc4a \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-key-sort.creq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-key-sort.creq new file mode 100755 index 0000000..7cea8ea --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-key-sort.creq @@ -0,0 +1,9 @@ +POST +/ + +date:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com +zoo:zoobar + +date;host;zoo +e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-key-sort.req b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-key-sort.req new file mode 100755 index 0000000..61c73de --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-key-sort.req @@ -0,0 +1,5 @@ +POST / http/1.1 +DATE:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com +ZOO:zoobar + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-key-sort.sreq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-key-sort.sreq new file mode 100755 index 0000000..a645b45 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-key-sort.sreq @@ -0,0 +1,6 @@ +POST / http/1.1 +DATE:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com +ZOO:zoobar +Authorization: AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host;zoo, Signature=b7a95a52518abbca0964a999a880429ab734f35ebbf1235bd79a5de87756dc4a + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-key-sort.sts b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-key-sort.sts new file mode 100755 index 0000000..3cf1dd7 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-key-sort.sts @@ -0,0 +1,4 @@ +AWS4-HMAC-SHA256 +20110909T233600Z +20110909/us-east-1/host/aws4_request +34e1bddeb99e76ee01d63b5e28656111e210529efeec6cdfd46a48e4c734545d \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-value-case.authz b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-value-case.authz new file mode 100755 index 0000000..651c954 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-value-case.authz @@ -0,0 +1 @@ +AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host;zoo, Signature=273313af9d0c265c531e11db70bbd653f3ba074c1009239e8559d3987039cad7 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-value-case.creq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-value-case.creq new file mode 100755 index 0000000..e97491d --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-value-case.creq @@ -0,0 +1,9 @@ +POST +/ + +date:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com +zoo:ZOOBAR + +date;host;zoo +e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-value-case.req b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-value-case.req new file mode 100755 index 0000000..f687230 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-value-case.req @@ -0,0 +1,5 @@ +POST / http/1.1 +DATE:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com +zoo:ZOOBAR + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-value-case.sreq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-value-case.sreq new file mode 100755 index 0000000..5f95618 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-value-case.sreq @@ -0,0 +1,6 @@ +POST / http/1.1 +DATE:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com +zoo:ZOOBAR +Authorization: AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host;zoo, Signature=273313af9d0c265c531e11db70bbd653f3ba074c1009239e8559d3987039cad7 + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-value-case.sts b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-value-case.sts new file mode 100755 index 0000000..e67301c --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-header-value-case.sts @@ -0,0 +1,4 @@ +AWS4-HMAC-SHA256 +20110909T233600Z +20110909/us-east-1/host/aws4_request +3aae6d8274b8c03e2cc96fc7d6bda4b9bd7a0a184309344470b2c96953e124aa \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-empty-query-value.authz b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-empty-query-value.authz new file mode 100755 index 0000000..acfa0fe --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-empty-query-value.authz @@ -0,0 +1 @@ +AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host, Signature=b6e3b79003ce0743a491606ba1035a804593b0efb1e20a11cba83f8c25a57a92 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-empty-query-value.creq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-empty-query-value.creq new file mode 100755 index 0000000..f46634d --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-empty-query-value.creq @@ -0,0 +1,8 @@ +POST +/ +foo=bar +date:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com + +date;host +e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-empty-query-value.req b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-empty-query-value.req new file mode 100755 index 0000000..1351de5 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-empty-query-value.req @@ -0,0 +1,4 @@ +POST /?foo=bar http/1.1 +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-empty-query-value.sreq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-empty-query-value.sreq new file mode 100755 index 0000000..662dd6b --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-empty-query-value.sreq @@ -0,0 +1,5 @@ +POST /?foo=bar http/1.1 +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com +Authorization: AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host, Signature=b6e3b79003ce0743a491606ba1035a804593b0efb1e20a11cba83f8c25a57a92 + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-empty-query-value.sts b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-empty-query-value.sts new file mode 100755 index 0000000..fddcbb7 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-empty-query-value.sts @@ -0,0 +1,4 @@ +AWS4-HMAC-SHA256 +20110909T233600Z +20110909/us-east-1/host/aws4_request +cd4f39132d8e60bb388831d734230460872b564871c47f5de62e62d1a68dbe1e \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-query-space.authz b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-query-space.authz new file mode 100755 index 0000000..59ccfcb --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-query-space.authz @@ -0,0 +1 @@ +AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host, Signature=b7eb653abe5f846e7eee4d1dba33b15419dc424aaf215d49b1240732b10cc4ca \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-query-space.creq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-query-space.creq new file mode 100755 index 0000000..0cb49e5 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-query-space.creq @@ -0,0 +1,8 @@ +POST +/ +f= +date:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com + +date;host +e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-query-space.req b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-query-space.req new file mode 100755 index 0000000..fca4e4a --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-query-space.req @@ -0,0 +1,4 @@ +POST /?f oo=b ar http/1.1 +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-query-space.sreq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-query-space.sreq new file mode 100755 index 0000000..f9d2f73 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-query-space.sreq @@ -0,0 +1,5 @@ +POST /?f oo=b ar http/1.1 +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com +Authorization: AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host, Signature=b7eb653abe5f846e7eee4d1dba33b15419dc424aaf215d49b1240732b10cc4ca + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-query-space.sts b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-query-space.sts new file mode 100755 index 0000000..bff0d26 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-query-space.sts @@ -0,0 +1,4 @@ +AWS4-HMAC-SHA256 +20110909T233600Z +20110909/us-east-1/host/aws4_request +0d5f8ed88e9cd0a2a093e1719fff945e3718d30a6b240b9de994cdf9442c89f5 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-query.authz b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-query.authz new file mode 100755 index 0000000..acfa0fe --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-query.authz @@ -0,0 +1 @@ +AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host, Signature=b6e3b79003ce0743a491606ba1035a804593b0efb1e20a11cba83f8c25a57a92 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-query.creq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-query.creq new file mode 100755 index 0000000..f46634d --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-query.creq @@ -0,0 +1,8 @@ +POST +/ +foo=bar +date:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com + +date;host +e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-query.req b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-query.req new file mode 100755 index 0000000..1351de5 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-query.req @@ -0,0 +1,4 @@ +POST /?foo=bar http/1.1 +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-query.sreq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-query.sreq new file mode 100755 index 0000000..662dd6b --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-query.sreq @@ -0,0 +1,5 @@ +POST /?foo=bar http/1.1 +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com +Authorization: AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host, Signature=b6e3b79003ce0743a491606ba1035a804593b0efb1e20a11cba83f8c25a57a92 + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-query.sts b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-query.sts new file mode 100755 index 0000000..fddcbb7 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla-query.sts @@ -0,0 +1,4 @@ +AWS4-HMAC-SHA256 +20110909T233600Z +20110909/us-east-1/host/aws4_request +cd4f39132d8e60bb388831d734230460872b564871c47f5de62e62d1a68dbe1e \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla.authz b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla.authz new file mode 100755 index 0000000..a6a7cbb --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla.authz @@ -0,0 +1 @@ +AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host, Signature=22902d79e148b64e7571c3565769328423fe276eae4b26f83afceda9e767f726 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla.creq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla.creq new file mode 100755 index 0000000..a1c8480 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla.creq @@ -0,0 +1,8 @@ +POST +/ + +date:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com + +date;host +e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla.req b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla.req new file mode 100755 index 0000000..b072b83 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla.req @@ -0,0 +1,4 @@ +POST / http/1.1 +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla.sreq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla.sreq new file mode 100755 index 0000000..f2f199a --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla.sreq @@ -0,0 +1,5 @@ +POST / http/1.1 +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com +Authorization: AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=date;host, Signature=22902d79e148b64e7571c3565769328423fe276eae4b26f83afceda9e767f726 + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla.sts b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla.sts new file mode 100755 index 0000000..30fb98a --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-vanilla.sts @@ -0,0 +1,4 @@ +AWS4-HMAC-SHA256 +20110909T233600Z +20110909/us-east-1/host/aws4_request +05da62cee468d24ae84faff3c39f1b85540de60243c1bcaace39c0a2acc7b2c4 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-x-www-form-urlencoded-parameters.authz b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-x-www-form-urlencoded-parameters.authz new file mode 100755 index 0000000..438b01c --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-x-www-form-urlencoded-parameters.authz @@ -0,0 +1 @@ +AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=content-type;date;host, Signature=b105eb10c6d318d2294de9d49dd8b031b55e3c3fe139f2e637da70511e9e7b71 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-x-www-form-urlencoded-parameters.creq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-x-www-form-urlencoded-parameters.creq new file mode 100755 index 0000000..56a9b26 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-x-www-form-urlencoded-parameters.creq @@ -0,0 +1,9 @@ +POST +/ + +content-type:application/x-www-form-urlencoded; charset=utf8 +date:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com + +content-type;date;host +3ba8907e7a252327488df390ed517c45b96dead033600219bdca7107d1d3f88a \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-x-www-form-urlencoded-parameters.req b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-x-www-form-urlencoded-parameters.req new file mode 100755 index 0000000..b537b64 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-x-www-form-urlencoded-parameters.req @@ -0,0 +1,6 @@ +POST / http/1.1 +Content-Type:application/x-www-form-urlencoded; charset=utf8 +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com + +foo=bar \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-x-www-form-urlencoded-parameters.sreq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-x-www-form-urlencoded-parameters.sreq new file mode 100755 index 0000000..4c351dd --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-x-www-form-urlencoded-parameters.sreq @@ -0,0 +1,7 @@ +POST / http/1.1 +Content-Type:application/x-www-form-urlencoded; charset=utf8 +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com +Authorization: AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=content-type;date;host, Signature=b105eb10c6d318d2294de9d49dd8b031b55e3c3fe139f2e637da70511e9e7b71 + +foo=bar \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-x-www-form-urlencoded-parameters.sts b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-x-www-form-urlencoded-parameters.sts new file mode 100755 index 0000000..df165ed --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-x-www-form-urlencoded-parameters.sts @@ -0,0 +1,4 @@ +AWS4-HMAC-SHA256 +20110909T233600Z +20110909/us-east-1/host/aws4_request +c4115f9e54b5cecf192b1eaa23b8e88ed8dc5391bd4fde7b3fff3d9c9fe0af1f \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-x-www-form-urlencoded.authz b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-x-www-form-urlencoded.authz new file mode 100755 index 0000000..73b6478 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-x-www-form-urlencoded.authz @@ -0,0 +1 @@ +AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=content-type;date;host, Signature=5a15b22cf462f047318703b92e6f4f38884e4a7ab7b1d6426ca46a8bd1c26cbc \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-x-www-form-urlencoded.creq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-x-www-form-urlencoded.creq new file mode 100755 index 0000000..e4c5127 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-x-www-form-urlencoded.creq @@ -0,0 +1,9 @@ +POST +/ + +content-type:application/x-www-form-urlencoded +date:Mon, 09 Sep 2011 23:36:00 GMT +host:host.foo.com + +content-type;date;host +3ba8907e7a252327488df390ed517c45b96dead033600219bdca7107d1d3f88a \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-x-www-form-urlencoded.req b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-x-www-form-urlencoded.req new file mode 100755 index 0000000..fd58d79 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-x-www-form-urlencoded.req @@ -0,0 +1,6 @@ +POST / http/1.1 +Content-Type:application/x-www-form-urlencoded +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com + +foo=bar \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-x-www-form-urlencoded.sreq b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-x-www-form-urlencoded.sreq new file mode 100755 index 0000000..3c66800 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-x-www-form-urlencoded.sreq @@ -0,0 +1,7 @@ +POST / http/1.1 +Content-Type:application/x-www-form-urlencoded +Date:Mon, 09 Sep 2011 23:36:00 GMT +Host:host.foo.com +Authorization: AWS4-HMAC-SHA256 Credential=AKIDEXAMPLE/20110909/us-east-1/host/aws4_request, SignedHeaders=content-type;date;host, Signature=5a15b22cf462f047318703b92e6f4f38884e4a7ab7b1d6426ca46a8bd1c26cbc + +foo=bar \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-x-www-form-urlencoded.sts b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-x-www-form-urlencoded.sts new file mode 100755 index 0000000..b6661a3 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/aws4_testsuite/post-x-www-form-urlencoded.sts @@ -0,0 +1,4 @@ +AWS4-HMAC-SHA256 +20110909T233600Z +20110909/us-east-1/host/aws4_request +4c5c6e4b52fb5fb947a8733982a8a5a61b14f04345cbfe6e739236c76dd48f74 \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/sigv4_hack.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/sigv4_hack.php new file mode 100644 index 0000000..4fbbc2a --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Signature/sigv4_hack.php @@ -0,0 +1,31 @@ + 'Mon, 09 Sep 2011 23:36:00 GMT', + DateFormat::ISO8601 => '20110909T233600Z', + DateFormat::SHORT => '20110909' + ); + + return $mapping[$format]; + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Waiter/AbstractResourceWaiterTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Waiter/AbstractResourceWaiterTest.php new file mode 100644 index 0000000..4d0bd7c --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Waiter/AbstractResourceWaiterTest.php @@ -0,0 +1,59 @@ +getMockBuilder('Aws\Common\Waiter\AbstractResourceWaiter') + ->getMockForAbstractClass(); + $waiter->wait(); + } + + public function testCanWait() + { + $waiter = $this->getMockBuilder('Aws\Common\Waiter\AbstractResourceWaiter') + ->setMethods(array('wait')) + ->getMockForAbstractClass(); + + $client = InstanceMetadataClient::factory(); + $waiter->setClient($client); + $this->assertSame($client, $this->readAttribute($waiter, 'client')); + + $config = array('baz' => 'bar'); + $waiter->setConfig($config); + $this->assertSame($config, $this->readAttribute($waiter, 'config')); + + $resource = array('foo' => 'bar'); + $waiter->setConfig($resource); + $this->assertSame($resource, $this->readAttribute($waiter, 'config')); + + try { + $waiter->wait(); + } catch (\Exception $e) {} + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Waiter/AbstractWaiterTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Waiter/AbstractWaiterTest.php new file mode 100644 index 0000000..8b16dc8 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Waiter/AbstractWaiterTest.php @@ -0,0 +1,149 @@ +getMockBuilder('Aws\Common\Waiter\AbstractWaiter') + ->getMockForAbstractClass(); + + $waiter->setInterval(10); + $this->assertEquals(10, $waiter->getInterval()); + + $waiter->setMaxAttempts(5); + $this->assertEquals(5, $waiter->getMaxAttempts()); + } + + public function testPerformsWait() + { + $waiter = $this->getMockBuilder('Aws\Common\Waiter\AbstractWaiter') + ->setMethods(array('doWait')) + ->getMockForAbstractClass(); + + $count = 0; + $waiter->expects($this->exactly(2)) + ->method('doWait') + ->will($this->returnCallback(function () use (&$count) { + return ++$count == 2; + })); + + $waiter->wait(); + } + + public function testPerformsWaitWithInterval() + { + $waiter = $this->getMockBuilder('Aws\Common\Waiter\AbstractWaiter') + ->setMethods(array('doWait')) + ->getMockForAbstractClass(); + + $waiter->setInterval(0.001); + + $count = 0; + $waiter->expects($this->exactly(2)) + ->method('doWait') + ->will($this->returnCallback(function () use (&$count) { + return ++$count == 2; + })); + + $waiter->wait(); + } + + /** + * @expectedException \Aws\Common\Exception\RuntimeException + * @expectedExceptionMessage Wait method never resolved to true after 1 attempts + */ + public function testPerformsWaitUntilMaxAttempts() + { + $waiter = $this->getMockBuilder('Aws\Common\Waiter\AbstractWaiter') + ->setMethods(array('doWait')) + ->getMockForAbstractClass(); + + $waiter->setMaxAttempts(1); + + $waiter->expects($this->exactly(1)) + ->method('doWait') + ->will($this->returnValue(false)); + + $waiter->wait(); + } + + public function testAllowsConfigOverrides() + { + $waiter = $this->getMockBuilder('Aws\Common\Waiter\AbstractWaiter') + ->getMockForAbstractClass(); + $waiter->setConfig(array('waiter.interval' => 100, 'waiter.max_attempts' => 50)); + $this->assertEquals(100, $waiter->getInterval()); + $this->assertEquals(50, $waiter->getMaxAttempts()); + } + + public function testPerformsWaitWithEvents() + { + $result = ''; + + $waiter = $this->getMockBuilder('Aws\Common\Waiter\AbstractWaiter') + ->setMethods(array('doWait')) + ->getMockForAbstractClass(); + $waiter->getEventDispatcher()->addListener('waiter.before_attempt', function () use (&$result) { + $result .= 'a'; + }); + $waiter->getEventDispatcher()->addListener('waiter.before_wait', function () use (&$result) { + $result .= 'c'; + }); + + $count = 0; + $waiter->expects($this->exactly(3)) + ->method('doWait') + ->will($this->returnCallback(function () use (&$count, &$result) { + $result .= 'b'; + return ++$count == 3; + })); + + $waiter->wait(); + + $this->assertEquals('abcabcab', $result); + } + + public function testWaiterEventConfigSettings() + { + $beforeAttemptCalled = 0; + $beforeWaitCalled = 0; + $waiter = $this->getMockBuilder('Aws\Common\Waiter\AbstractWaiter') + ->setMethods(array('doWait')) + ->getMockForAbstractClass(); + $waiter->setConfig(array( + 'waiter.before_attempt' => function () use (&$beforeAttemptCalled) { $beforeAttemptCalled++; }, + 'waiter.before_wait' => function () use (&$beforeWaitCalled) { $beforeWaitCalled++; }, + )); + + $iterations = 0; + $waiter->expects($this->any()) + ->method('doWait') + ->will($this->returnCallback(function () use (&$iterations) { + return ++$iterations == 3; + })); + + $waiter->wait(); + + $this->assertEquals(3, $beforeAttemptCalled); + $this->assertEquals(2, $beforeWaitCalled); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Waiter/CallableWaiterTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Waiter/CallableWaiterTest.php new file mode 100644 index 0000000..69bd724 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Waiter/CallableWaiterTest.php @@ -0,0 +1,63 @@ +setCallable('foo'); + } + + /** + * @expectedException \Aws\Common\Exception\RuntimeException + */ + public function testEnsureCallableIsSetBeforeWaiting() + { + $w = new CallableWaiter(); + $w->wait(); + } + + public function testUsesCallbackForWaiter() + { + $total = 0; + $f = function ($attempts, $data) use (&$total) { + $data['object']->value = 2; + return ++$total == 3; + }; + + $o = new \StdClass(); + $o->value = 1; + $c = array('object' => $o); + + $w = new CallableWaiter(); + $w->setCallable($f); + $w->setContext($c); + $w->wait(); + $this->assertEquals(3, $total); + $this->assertEquals(2, $o->value); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Waiter/CompositeWaiterFactoryTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Waiter/CompositeWaiterFactoryTest.php new file mode 100644 index 0000000..7488dd6 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Waiter/CompositeWaiterFactoryTest.php @@ -0,0 +1,35 @@ +assertFalse($factory->canBuild('foo')); + $factory->build('foo'); + } + + public function testBuildsWaiters() + { + $f1 = new WaiterConfigFactory(array('Boo' => array('test'))); + $f2 = new WaiterConfigFactory(array('foo' => array('max_attempts' => 10))); + $factory = new CompositeWaiterFactory(array($f1)); + $factory->addFactory($f2); + $this->assertInstanceOf('Aws\Common\Waiter\ConfigResourceWaiter', $factory->build('foo')); + $this->assertInstanceOf('Aws\Common\Waiter\ConfigResourceWaiter', $factory->build('Boo')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Waiter/ConfigResourceWaiterTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Waiter/ConfigResourceWaiterTest.php new file mode 100644 index 0000000..1efc6df --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Waiter/ConfigResourceWaiterTest.php @@ -0,0 +1,108 @@ + 3, + 'interval' => 5 + )); + $w = new ConfigResourceWaiter($c); + $this->assertSame($c, $w->getWaiterConfig()); + $this->assertEquals(3, $w->getMaxAttempts()); + $this->assertEquals(5, $w->getInterval()); + } + + public function testWaiterConfigsCanBeSetInSetConfig() + { + $c = new WaiterConfig(); + $w = new ConfigResourceWaiter($c); + $w->setConfig(array( + 'waiter.foo' => 'baz', + 'waiter.success.path' => 'test/*' + )); + $this->assertEquals('baz', $c->get('foo')); + $this->assertEquals('test/*', $c->get('success.path')); + } + + public function testWaiterCanIgnoreExceptions() + { + $client = $this->getServiceBuilder()->get('s3', true); + $this->setMockResponse($client, array('s3/head_failure', 's3/head_success')); + $client->waitUntil('bucket_exists', array('Bucket' => 'foo', 'waiter.interval' => 0)); + $this->assertEquals(2, count($this->getMockedRequests())); + } + + /** + * @expectedException \Aws\S3\Exception\S3Exception + */ + public function testWaiterDoesNotIgnoreAllExceptions() + { + $client = $this->getServiceBuilder()->get('s3', true); + $this->setMockResponse($client, array(new Response(409))); + $client->waitUntil('bucket_not_exists', array('Bucket' => 'foo', 'waiter.interval' => 0)); + } + + public function testWaiterCanSucceedOnException() + { + $client = $this->getServiceBuilder()->get('s3', true); + $this->setMockResponse($client, array('s3/head_failure')); + $client->waitUntil('bucket_not_exists', array('Bucket' => 'foo')); + } + + public function testWaiterCanSucceedOnOutput() + { + $client = $this->getServiceBuilder()->get('ec2', true); + $this->setMockResponse($client, array( + 'ec2/describe_instances_no_reservations', + 'ec2/describe_instances_two_instances_different_state', + 'ec2/describe_instances_two_instances_same_state' + )); + $client->waitUntil('instance_running', array('InstanceIds' => array('i-xxxxxxx1'), 'waiter.interval' => 0)); + } + + /** + * @expectedException \RuntimeException + * @expectedExceptionMessage A resource entered into an invalid state of "pending" while waiting with the "InstanceStopped" waiter. + */ + public function testWaiterCanFastFailOnOutputResult() + { + $client = $this->getServiceBuilder()->get('ec2', true); + $this->setMockResponse($client, array('ec2/describe_instances_two_instances_different_state')); + $client->waitUntil('instance_stopped', array('InstanceIds' => array('i-xxxxxxx1'), 'waiter.interval' => 0)); + } + + /** + * @expectedException \InvalidArgumentException + * @expectedExceptionMessage InstanceStopped waiter validation failed: Validation errors: [InstanceIds] must be of type array + */ + public function testWaiterProvidesHelpfulMessageWhenValidationFails() + { + $client = $this->getServiceBuilder()->get('ec2', true); + $client->waitUntil('instance_stopped', array('InstanceIds' => 'i-xxxxxxx1')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Waiter/WaiterClassFactoryTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Waiter/WaiterClassFactoryTest.php new file mode 100644 index 0000000..883cbd1 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Waiter/WaiterClassFactoryTest.php @@ -0,0 +1,47 @@ +registerNamespace('Foo'); + $factory->build('bar'); + } + + public function testCreatesWaiter() + { + $factory = new WaiterClassFactory(); + $factory->registerNamespace('Aws\Common\InstanceMetadata\Waiter'); + $factory->registerNamespace('Foo\Bar'); + + $expectedClass = 'Aws\Common\InstanceMetadata\Waiter\ServiceAvailable'; + $this->assertTrue($factory->canBuild('service_available')); + $this->assertInstanceOf($expectedClass, $factory->build('service_available')); + $this->assertInstanceOf($expectedClass, $factory->build('ServiceAvailable')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Waiter/WaiterConfigFactoryTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Waiter/WaiterConfigFactoryTest.php new file mode 100644 index 0000000..3bc0fb0 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Waiter/WaiterConfigFactoryTest.php @@ -0,0 +1,97 @@ + array( + 'acceptor.path' => 'Foo/Baz', + 'acceptor.type' => 'output', + 'max_attempts' => 10 + ), + 'Test' => array( + 'success.value' => 'foo', + 'ignore_errors' => array('1', '2') + ), + 'Extending' => array( + 'extends' => 'Test', + 'failure.value' => 'fail' + ), + 'Overwrite' => array( + 'extends' => 'Extending', + 'max_attempts' => 20, + 'success.value' => 'abc', + 'failure.type' => 'baz' + ) + ); + + /** + * @expectedException \Aws\Common\Exception\InvalidArgumentException + */ + public function testEnsuresConfigExists() + { + $factory = new WaiterConfigFactory(array()); + $factory->build('bar'); + } + + public function testUsesDefaultValuesToo() + { + $factory = new WaiterConfigFactory($this->data); + $config = $factory->build('Test')->getWaiterConfig(); + $this->assertEquals('Foo/Baz', $config['success.path']); + $this->assertEquals('Foo/Baz', $config['failure.path']); + $this->assertEquals('output', $config['success.type']); + $this->assertEquals('output', $config['failure.type']); + $this->assertEquals(10, $config['max_attempts']); + $this->assertEquals('foo', $config['success.value']); + $this->assertEquals(array('1', '2'), $config['ignore_errors']); + } + + public function testAllowsExtending() + { + $factory = new WaiterConfigFactory($this->data); + $config = $factory->build('Extending')->getWaiterConfig(); + $this->assertEquals('Foo/Baz', $config['success.path']); + $this->assertEquals('Foo/Baz', $config['failure.path']); + $this->assertEquals('output', $config['success.type']); + $this->assertEquals('output', $config['failure.type']); + $this->assertEquals(10, $config['max_attempts']); + $this->assertEquals('foo', $config['success.value']); + $this->assertEquals('fail', $config['failure.value']); + $this->assertEquals(array('1', '2'), $config['ignore_errors']); + } + + public function testAllowsExtendingToOverwrite() + { + $factory = new WaiterConfigFactory($this->data); + $config = $factory->build('Overwrite')->getWaiterConfig(); + $this->assertEquals('Foo/Baz', $config['success.path']); + $this->assertEquals('Foo/Baz', $config['failure.path']); + $this->assertEquals('output', $config['success.type']); + $this->assertEquals('baz', $config['failure.type']); + $this->assertEquals(20, $config['max_attempts']); + $this->assertEquals('abc', $config['success.value']); + $this->assertEquals('fail', $config['failure.value']); + $this->assertEquals(array('1', '2'), $config['ignore_errors']); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Waiter/WaiterConfigTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Waiter/WaiterConfigTest.php new file mode 100644 index 0000000..be21d6a --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Common/Waiter/WaiterConfigTest.php @@ -0,0 +1,42 @@ + 'baz', + 'acceptor.bar' => 'baz', + 'success.foo' => 'bar', + 'failure.test' => 'bam' + )); + $this->assertEquals(array( + 'success.foo' => 'bar', + 'failure.test' => 'bam', + 'failure.foo' => 'baz', + 'success.bar' => 'baz', + 'failure.bar' => 'baz' + ), $config->toArray()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DataPipeline/DataPipelineClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DataPipeline/DataPipelineClientTest.php new file mode 100644 index 0000000..1d9f98a --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DataPipeline/DataPipelineClientTest.php @@ -0,0 +1,39 @@ + 'foo', + ClientOptions::SECRET => 'bar', + ClientOptions::REGION => 'us-east-1' + )); + + $this->assertInstanceOf('Aws\Common\Signature\SignatureV4', $client->getSignature()); + $this->assertInstanceOf('Aws\Common\Credentials\Credentials', $client->getCredentials()); + $this->assertEquals('https://datapipeline.us-east-1.amazonaws.com', $client->getBaseUrl()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DataPipeline/Integration/IntegrationTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DataPipeline/Integration/IntegrationTest.php new file mode 100644 index 0000000..1f369e3 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DataPipeline/Integration/IntegrationTest.php @@ -0,0 +1,166 @@ +get('datapipeline'); + foreach ($dp->getIterator('ListPipelines') as $pipeline) { + if (strpos($pipeline['name'], 'php-test-pipeline') === 0) { + $dp->getCommand('DeletePipeline', array('pipelineId' => $pipeline['id']))->execute(); + } + } + sleep(3); + } + + public function setUp() + { + $this->dataPipeline = self::getServiceBuilder()->get('datapipeline'); + } + + public function testCrudOperationsForPipelines() + { + self::log('Create 3 pipelines.'); + $pipelineIds = array(); + foreach (range(1, 3) as $index) { + $name = "php-test-pipeline-{$index}"; + $result = $this->dataPipeline->getCommand('CreatePipeline', array( + 'name' => $name, + 'uniqueId' => $name, + ))->getResult(); + $pipelineIds[] = $result['pipelineId']; + } + + self::log('List the pipelines and make sure the ones we added are there.'); + foreach ($this->dataPipeline->getIterator('ListPipelines') as $pipeline) { + if (strpos($pipeline['name'], 'php-test-pipeline') === 0) { + $this->assertContains($pipeline['id'], $pipelineIds); + } + } + + self::log('Describe the pipelines and make sure the ones we added are still there.'); + $result = $this->dataPipeline->getCommand('DescribePipelines', array( + 'pipelineIds' => $pipelineIds, + ))->getResult(); + $this->assertCount(3, $result['pipelineDescriptionList']); + foreach ($result['pipelineDescriptionList'] as $pipeline) { + $this->assertContains($pipeline['pipelineId'], $pipelineIds); + } + + self::log('Test putting a pipeline definition.'); + $definition = array( + 'pipelineId' => $pipelineIds[0], + 'pipelineObjects' => array( + array( + 'id' => 'Default', + 'name' => 'Default', + 'fields' => array( + array( + 'key' => 'workerGroup', + 'stringValue' => 'workerGroup' + ) + ) + ), + array( + 'id' => 'Schedule', + 'name' => 'Schedule', + 'fields' => array( + array( + 'key' => 'startDateTime', + 'stringValue' => '2012-12-12T00:00:00' + ), + array( + 'key' => 'type', + 'stringValue' => 'Schedule' + ), + array( + 'key' => 'period', + 'stringValue' => '1 hour' + ), + array( + 'key' => 'endDateTime', + 'stringValue' => '2012-12-21T18:00:00' + ), + ) + ), + array( + 'id' => 'SayHello', + 'name' => 'SayHello', + 'fields' => array( + array( + 'key' => 'type', + 'stringValue' => 'ShellCommandActivity' + ), + array( + 'key' => 'command', + 'stringValue' => 'echo hello' + ), + array( + 'key' => 'parent', + 'refValue' => 'Default' + ), + array( + 'key' => 'schedule', + 'refValue' => 'Schedule' + ) + ) + ) + ) + ); + $result = $this->dataPipeline->getCommand('ValidatePipelineDefinition', $definition)->getResult(); + $this->assertFalse($result->get('errored')); + $result = $this->dataPipeline->getCommand('PutPipelineDefinition', $definition)->getResult(); + $this->assertFalse($result->get('errored')); + + self::log('Get a pipeline definition.'); + $response = $this->dataPipeline->getCommand('GetPipelineDefinition', array( + 'pipelineId' => $pipelineIds[0], + ))->getResponse(); + $this->assertEquals(200, $response->getStatusCode()); + + self::log('Delete the pipelines we created.'); + foreach ($pipelineIds as $pipelineId) { + $response = $this->dataPipeline->getCommand('DeletePipeline', array( + 'pipelineId' => $pipelineId, + ))->getResponse(); + $this->assertEquals(200, $response->getStatusCode()); + } + + self::log('Sleep to let delete calls propagate.'); + sleep(5); + + self::log('List the pipelines and make sure the ones we deleted are gone.'); + foreach ($this->dataPipeline->getIterator('ListPipelines') as $pipeline) { + if (strpos($pipeline['name'], 'php-test-pipeline') === 0) { + $this->fail("The pipeline {$pipeline['name']} was not deleted."); + } + } + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DirectConnect/DirectConnectClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DirectConnect/DirectConnectClientTest.php new file mode 100644 index 0000000..ddc2f98 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DirectConnect/DirectConnectClientTest.php @@ -0,0 +1,38 @@ + 'foo', + 'secret' => 'bar', + 'region' => 'us-west-2' + )); + + $this->assertInstanceOf('Aws\Common\Signature\SignatureV4', $client->getSignature()); + $this->assertInstanceOf('Aws\Common\Credentials\Credentials', $client->getCredentials()); + $this->assertEquals('https://directconnect.us-west-2.amazonaws.com', $client->getBaseUrl()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DirectConnect/Integration/IntegrationTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DirectConnect/Integration/IntegrationTest.php new file mode 100644 index 0000000..e3e9755 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DirectConnect/Integration/IntegrationTest.php @@ -0,0 +1,99 @@ +getServiceBuilder()->get('directconnect', true); + $client->getEventDispatcher()->addSubscriber(LogPlugin::getDebugPlugin()); + + self::log('Create a connection'); + + // @begin + $result = $client->createConnection(array( + 'bandwidth' => '1Gbps', + 'connectionName' => 'PHPTest', + 'location' => 'EqDC2' + )); + + $connectionId = $result['connectionId']; + // @end + + $this->assertEquals(ConnectionState::REQUESTED, $result['connectionState']); + + return $connectionId; + } + + /** + * DescribeConnections operation example + * + * @depends testCreatesConnection + * @example Aws\DirectConnect\DirectConnectClient::describeConnections + */ + public function testDescribesConnections($connectionId) + { + self::log('Iterate through the connections and make sure the new one is there.'); + $client = $this->getServiceBuilder()->get('directconnect', true); + + // @begin + $iterator = $client->getDescribeConnectionsIterator(); + + foreach ($iterator as $connection) { + echo $connection['connectionId'] . "\n"; + } + // @end + $this->assertContains($connectionId, $this->getActualOutput()); + + return $connectionId; + } + + /** + * DeleteConnection operation example + * + * @depends testDescribesConnections + * @example Aws\DirectConnect\DirectConnectClient::deleteConnection + */ + public function testDeletesConnection($connectionId) + { + $client = $this->getServiceBuilder()->get('directconnect', true); + self::log('Delete the connection and make sure it is in the deleted state.'); + + // @begin + $result = $client->deleteConnection(array( + 'connectionId' => $connectionId + )); + + echo $result['connectionState']; + // @end + + $this->assertEquals('deleted', $this->getActualOutput()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Crc32ErrorCheckerTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Crc32ErrorCheckerTest.php new file mode 100644 index 0000000..423147b --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Crc32ErrorCheckerTest.php @@ -0,0 +1,62 @@ +assertFalse($checker->getBackoffPeriod(0, $request, $response)); + } + + public function testOnlyListensForCompletedRequests() + { + $request = new Request('GET', 'http://example.com'); + $checker = new Crc32ErrorChecker(); + $this->assertFalse($checker->getBackoffPeriod(0, $request)); + } + + public function testReturnsTrueForMismatchedChecksums() + { + $request = new Request('GET', 'http://example.com'); + $response = new Response(200, array( + 'content-type' => 'application/x-amz-json-1.0', + 'x-amz-crc32' => 123 + ), '{"foo":"bar"}' + ); + $checker = new Crc32ErrorChecker(); + $this->assertSame(0, $checker->getBackoffPeriod(1, $request, $response)); + } + + public function testReturnsFalseWhenCrc32Matches() + { + $request = new Request('GET', 'http://example.com'); + $response = new Response(200, array('x-amz-crc32' => '3632233996'), 'test'); + $checker = new Crc32ErrorChecker(); + $this->assertFalse($checker->getBackoffPeriod(1, $request, $response)); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/DynamoDbClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/DynamoDbClientTest.php new file mode 100644 index 0000000..7549409 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/DynamoDbClientTest.php @@ -0,0 +1,136 @@ +getServiceBuilder()->get('dynamodb', true); + $expected = array(Type::NUMBER => '100'); + $actual = $client->formatValue(100); + + $this->assertSame($expected, $actual); + } + + /** + * @covers Aws\DynamoDb\DynamoDbClient::formatAttributes + */ + public function testFormatAttributesProducesCorrectArrayStructure() + { + $client = $this->getServiceBuilder()->get('dynamodb', true); + $expected = array( + 'number' => array(Type::NUMBER => '100'), + 'string' => array(Type::STRING => 'foo'), + ); + + $actual = $client->formatAttributes(array( + 'number' => 100, + 'string' => 'foo', + )); + + $this->assertSame($expected, $actual); + } + + /** + * This was an issue in earlier DynamoDB clients from several programming + * languages + * + * @covers Aws\DynamoDb\DynamoDbClient::formatAttributes + */ + public function testFormatAttributesWorksWithTypesAsKeys() + { + $client = $this->getServiceBuilder()->get('dynamodb', true); + $expected = array( + 'N' => array('N' => '1'), + 'S' => array('S' => 'S'), + 'NS' => array('NS' => array('1', '2', '3', '4')), + 'SS' => array('SS' => array('N', 'S', 'NS', 'SS')), + ); + + $actual = $client->formatAttributes(array( + 'N' => 1, + 'S' => 'S', + 'NS' => array(1, 2, 3, 4), + 'SS' => array('N', 'S', 'NS', 'SS'), + )); + + $this->assertSame($expected, $actual); + } + + /** + * @covers Aws\DynamoDb\DynamoDbClient::factory + * @covers Aws\DynamoDb\DynamoDbClient::createBackoffPlugin + */ + public function testFactoryInitializesClient() + { + $client = DynamoDbClient::factory(array( + 'key' => 'foo', + 'secret' => 'bar', + 'region' => 'us-east-1' + )); + + $this->assertInstanceOf('Aws\Common\Signature\SignatureV4', $client->getSignature()); + $this->assertInstanceOf('Aws\Common\Credentials\Credentials', $client->getCredentials()); + $this->assertEquals('https://dynamodb.us-east-1.amazonaws.com', $client->getBaseUrl()); + } + + /** + * @covers Aws\DynamoDb\DynamoDbClient::calculateRetryDelay + */ + public function testHasCustomRetryDelay() + { + $client = DynamoDbClient::factory(array( + 'key' => 'foo', + 'secret' => 'bar', + 'region' => 'us-west-1' + )); + + $this->assertEquals(0, $client->calculateRetryDelay(0)); + $this->assertEquals(0.05, $client->calculateRetryDelay(1)); + $this->assertEquals(0.1, $client->calculateRetryDelay(2)); + $this->assertEquals(0.2, $client->calculateRetryDelay(3)); + $this->assertEquals(0.4, $client->calculateRetryDelay(4)); + $this->assertEquals(0.8, $client->calculateRetryDelay(5)); + $this->assertEquals(1.6, $client->calculateRetryDelay(6)); + $this->assertEquals(3.2, $client->calculateRetryDelay(7)); + $this->assertEquals(6.4, $client->calculateRetryDelay(8)); + $this->assertEquals(12.8, $client->calculateRetryDelay(9)); + $this->assertEquals(25.6, $client->calculateRetryDelay(10)); + $this->assertEquals(51.2, $client->calculateRetryDelay(11)); + } + + /** + * @covers Aws\DynamoDb\DynamoDbClient::registerSessionHandler + */ + public function testCanRegisterSessionHandlerFromClient() + { + $client = DynamoDbClient::factory(array( + 'key' => 'foo', + 'secret' => 'bar', + 'region' => 'us-west-1' + )); + + $this->assertInstanceOf('Aws\DynamoDb\Session\SessionHandler', $client->registerSessionHandler()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Exception/UnprocessedWriteRequestsExceptionTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Exception/UnprocessedWriteRequestsExceptionTest.php new file mode 100644 index 0000000..f8f569d --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Exception/UnprocessedWriteRequestsExceptionTest.php @@ -0,0 +1,45 @@ +getMock($interface); + $unprocessed2 = $this->getMock($interface); + + $exception + ->addItem($unprocessed1) + ->addItem($unprocessed2); + + try { + throw $exception; + } catch (UnprocessedWriteRequestsException $e) { + $this->assertEquals(2, count($e)); + $this->assertInstanceOf('\ArrayIterator', $e->getIterator()); + } + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Integration/DynamoDb_20111205_Test.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Integration/DynamoDb_20111205_Test.php new file mode 100644 index 0000000..5ede0cc --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Integration/DynamoDb_20111205_Test.php @@ -0,0 +1,478 @@ +get('dynamodb', array('version' => '2011-12-05')); + + // Delete the table if it exists + try { + $client->deleteTable(array('TableName' => 'errors')); + $client->waitUntilTableNotExists(array('TableName' => 'errors')); + } catch (\Exception $e) {} + } + + public function setUp() + { + $this->client = $this->getServiceBuilder()->get('dynamodb', array('version' => '2011-12-05')); + } + + /** + * Create a table with an optional RangeKeyElement + * + * @example Aws\DynamoDb\DynamoDbClient::createTable 2011-12-05 + */ + public function testCreateTable() + { + $client = $this->client; + // @begin + + // Create an "errors" table + $client->createTable(array( + 'TableName' => 'errors', + 'KeySchema' => array( + 'HashKeyElement' => array( + 'AttributeName' => 'id', + 'AttributeType' => 'N' + ), + 'RangeKeyElement' => array( + 'AttributeName' => 'time', + 'AttributeType' => 'N' + ) + ), + 'ProvisionedThroughput' => array( + 'ReadCapacityUnits' => 10, + 'WriteCapacityUnits' => 20 + ) + )); + } + + /** + * @depends testCreateTable + */ + public function testWaitUntilTableExists() + { + $client = $this->client; + // @begin + + // Wait until the table is created and active + $client->waitUntil('TableExists', array( + 'TableName' => 'errors' + )); + } + + /** + * Update a table to change the provisioned throughput + * + * @depends testWaitUntilTableExists + * @example Aws\DynamoDb\DynamoDbClient::updateTable 2011-12-05 + */ + public function testUpdateTable() + { + $client = $this->client; + // @begin + + // Update the provisioned throughput capacity of the table + $client->updateTable(array( + 'TableName' => 'errors', + 'ProvisionedThroughput' => array( + 'ReadCapacityUnits' => 15, + 'WriteCapacityUnits' => 25 + ) + )); + + // Wait until the table is active again after updating + $client->waitUntil('TableExists', array( + 'TableName' => 'errors' + )); + } + + /** + * Describe a table and grab data from the output + * + * @depends testUpdateTable + * @example Aws\DynamoDb\DynamoDbClient::describeTable 2011-12-05 + */ + public function testDescribeTable() + { + $client = $this->client; + $this->expectOutputString("0\n15\n"); + // @begin + + $result = $client->describeTable(array( + 'TableName' => 'errors' + )); + + // The result of an operation can be used like an array + echo $result['Table']['ItemCount'] . "\n"; + //> 0 + + // Use the getPath() method to retrieve deeply nested array key values + echo $result->getPath('Table/ProvisionedThroughput/ReadCapacityUnits') . "\n"; + //> 15 + } + + /** + * List the first page of results of tables owned by your account + * + * @depends testDescribeTable + * @example Aws\DynamoDb\DynamoDbClient::listTables 2011-12-05 + */ + public function testListTables() + { + $client = $this->client; + // @begin + + $result = $client->listTables(); + + // TableNames contains an array of table names + foreach ($result['TableNames'] as $tableName) { + echo $tableName . "\n"; + } + + // @end + $this->assertContains("errors\n", $this->getActualOutput()); + } + + /** + * List all of the tables owned by your account using a ListTables iterator + * + * @depends testListTables + * @example Aws\DynamoDb\DynamoDbClient::listTable 2011-12-05 + */ + public function testListTablesWithIterator() + { + $client = $this->client; + // @begin + + $iterator = $client->getIterator('ListTables'); + + foreach ($iterator as $tableName) { + echo $tableName . "\n"; + } + + // @end + $this->assertContains("errors\n", $this->getActualOutput()); + } + + /** + * Put an item in a table using the formatAttributes() client helper method + * + * @depends testListTablesWithIterator + * @example Aws\DynamoDb\DynamoDbClient::putItem 2011-12-05 + * @example Aws\DynamoDb\DynamoDbClient::formatAttributes 2011-12-05 + */ + public function testAddItem() + { + $client = $this->client; + // @begin + + $time = time(); + + $result = $client->putItem(array( + 'TableName' => 'errors', + 'Item' => $client->formatAttributes(array( + 'id' => 1201, + 'time' => $time, + 'error' => 'Executive overflow', + 'message' => 'no vacant areas' + )) + )); + + // The result will always contain ConsumedCapacityUnits + echo $result['ConsumedCapacityUnits'] . "\n"; + + // @end + $this->assertNotEmpty($this->getActualOutput()); + return $time; + } + + /** + * Put an item in a table + * + * @depends testAddItem + * @example Aws\DynamoDb\DynamoDbClient::putItem 2011-12-05 + */ + public function testAddItemWithoutHelperMethod($time) + { + $client = $this->client; + // @begin + + $result = $client->putItem(array( + 'TableName' => 'errors', + 'Item' => array( + 'id' => array('N' => '1201'), + 'time' => array('N' => $time), + 'error' => array('S' => 'Executive overflow'), + 'message' => array('S' => 'no vacant areas') + ) + )); + + // @end + return $time; + } + + /** + * Get an item from a table and interact with the response + * + * @depends testAddItemWithoutHelperMethod + * @example Aws\DynamoDb\DynamoDbClient::getItem 2011-12-05 + */ + public function testGetItem($time) + { + $client = $this->client; + $this->expectOutputString("1201\n1201\nExecutive overflow\nno vacant areas\n"); + // @begin + + $result = $client->getItem(array( + 'ConsistentRead' => true, + 'TableName' => 'errors', + 'Key' => array( + 'HashKeyElement' => array('N' => '1201'), + 'RangeKeyElement' => array('N' => $time) + ) + )); + + // Grab value from the result object like an array + echo $result['Item']['id']['N'] . "\n"; + //> 1201 + echo $result->getPath('Item/id/N') . "\n"; + //> 1201 + echo $result['Item']['error']['S'] . "\n"; + //> Executive overflow + echo $result['Item']['message']['S'] . "\n"; + //> no vacant areas + } + + /** + * Get all results of a Query operation using a Query iterator + * + * @depends testGetItem + * @example Aws\DynamoDb\DynamoDbClient::query 2011-12-05 + */ + public function testQuery() + { + $client = $this->client; + // @begin + + $iterator = $client->getIterator('Query', array( + 'TableName' => 'errors', + 'HashKeyValue' => array('N' => '1201'), + 'RangeKeyCondition' => array( + 'AttributeValueList' => array( + array('N' => strtotime("-15 minutes")) + ), + 'ComparisonOperator' => 'GT' + ) + )); + + // Each item will contain the attributes we added + foreach ($iterator as $item) { + // Grab the time number value + echo $item['time']['N'] . "\n"; + // Grab the error string value + echo $item['error']['S'] . "\n"; + } + + // @end + $this->assertNotEmpty($this->getActualOutput()); + } + + /** + * Get all of the results of a Scan operation using a Scan iterator + * + * @depends testQuery + * @example Aws\DynamoDb\DynamoDbClient::scan 2011-12-05 + */ + public function testScan() + { + $client = $this->client; + // @begin + + $iterator = $client->getIterator('Scan', array( + 'TableName' => 'errors', + 'ScanFilter' => array( + 'error' => array( + 'AttributeValueList' => array(array('S' => 'overflow')), + 'ComparisonOperator' => 'CONTAINS' + ), + 'time' => array( + 'AttributeValueList' => array( + array('N' => strtotime('-15 minutes')) + ), + 'ComparisonOperator' => 'GT' + ) + ) + )); + + // Each item will contain the attributes we added + foreach ($iterator as $item) { + // Grab the time number value + echo $item['time']['N'] . "\n"; + // Grab the error string value + echo $item['error']['S'] . "\n"; + } + + // @end + $this->assertNotEmpty($this->getActualOutput()); + } + + /** + * Put and get an item with a binary attribute + * + * @depends testScan + * @example Aws\DynamoDb\DynamoDbClient::putItem 2011-12-05 + * @example Aws\DynamoDb\DynamoDbClient::getItem 2011-12-05 + */ + public function testBinaryType() + { + $client = $this->client; + // @begin + + $data = '¡™£¢∞§¶•ªº'; + $time = time(); + + $client->putItem(array( + 'TableName' => 'errors', + 'Item' => array( + 'id' => array('N' => '3000'), + 'time' => array('N' => $time), + 'error' => array('S' => 'Out of bounds'), + 'data' => array('B' => $data) + ) + )); + + $result = $client->getItem(array( + 'ConsistentRead' => true, + 'TableName' => 'errors', + 'Key' => array( + 'HashKeyElement' => array('N' => '3000'), + 'RangeKeyElement' => array('N' => $time) + ) + )); + + var_dump($result['Item']['data']['B'] == base64_decode($data)); + //> bool(true) + } + + /** + * Get batches of items + * + * @depends testBinaryType + * @example Aws\DynamoDb\DynamoDbClient::batchGetItem 2011-12-05 + */ + public function testBatchGetItem() + { + $client = $this->client; + + $keyValues = array(); + $scan = $client->getIterator('Scan', array('TableName' => 'errors')); + foreach ($scan as $item) { + $keyValues[] = array($item['id']['N'], $item['time']['N']); + } + // @begin + + $tableName = 'errors'; + $keys = array(); + + // Given that $keyValues contains a list of your hash and range keys: + // array(array(, ), ...) + // Build the array for the "Keys" parameter + foreach ($keyValues as $values) { + list($hashKeyValue, $rangeKeyValue) = $values; + $keys[] = array( + 'HashKeyElement' => array('N' => $hashKeyValue), + 'RangeKeyElement' => array('N' => $rangeKeyValue) + ); + } + + // Get multiple items by key in a BatchGetItem request + $result = $client->batchGetItem(array( + 'RequestItems' => array( + $tableName => array( + 'Keys' => $keys, + 'ConsistentRead' => true + ) + ) + )); + $items = $result->getPath("Responses/{$tableName}"); + // @end + + $this->assertEquals(count($keys), count($items)); + } + + /** + * Delete an item + * + * @depends testBatchGetItem + * @example Aws\DynamoDb\DynamoDbClient::deleteItem 2011-12-05 + * @example Aws\DynamoDb\DynamoDbClient::scan 2011-12-05 + */ + public function testDeleteItem() + { + $client = $this->client; + // @begin + + // Delete every key in the table + $scan = $client->getIterator('Scan', array('TableName' => 'errors')); + foreach ($scan as $item) { + $client->deleteItem(array( + 'TableName' => 'errors', + 'Key' => array( + 'HashKeyElement' => array('N' => $item['id']['N']), + 'RangeKeyElement' => array('N' => $item['time']['N']) + ) + )); + } + } + + /** + * Delete a table + * + * @depends testDeleteItem + * @example Aws\DynamoDb\DynamoDbClient::deleteTable 2011-12-05 + */ + public function testDeleteTable() + { + $client = $this->client; + // @begin + + $client->deleteTable(array( + 'TableName' => 'errors' + )); + + $client->waitUntilTableNotExists(array( + 'TableName' => 'errors' + )); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Integration/DynamoDb_20120810_Test.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Integration/DynamoDb_20120810_Test.php new file mode 100644 index 0000000..2cd52ba --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Integration/DynamoDb_20120810_Test.php @@ -0,0 +1,741 @@ +get('dynamodb', array('version' => '2012-08-10')); + + // Delete the errors table if it exists + try { + $client->deleteTable(array('TableName' => 'errors')); + $client->waitUntilTableNotExists(array('TableName' => 'errors')); + } catch (\Exception $e) {} + + // Delete the Orders table if it exists + try { + $client->deleteTable(array('TableName' => 'Orders')); + $client->waitUntilTableNotExists(array('TableName' => 'Orders')); + } catch (\Exception $e) {} + } + + public function setUp() + { + $this->client = $this->getServiceBuilder()->get('dynamodb', array('version' => '2012-08-10')); + } + + /** + * Create a table with a hash key and range key + * + * @example Aws\DynamoDb\DynamoDbClient::createTable 2012-08-10 + */ + public function testCreateTable() + { + $client = $this->client; + // @begin + + // Create an "errors" table + $client->createTable(array( + 'TableName' => 'errors', + 'AttributeDefinitions' => array( + array( + 'AttributeName' => 'id', + 'AttributeType' => 'N' + ), + array( + 'AttributeName' => 'time', + 'AttributeType' => 'N' + ) + ), + 'KeySchema' => array( + array( + 'AttributeName' => 'id', + 'KeyType' => 'HASH' + ), + array( + 'AttributeName' => 'time', + 'KeyType' => 'RANGE' + ) + ), + 'ProvisionedThroughput' => array( + 'ReadCapacityUnits' => 10, + 'WriteCapacityUnits' => 20 + ) + )); + } + + /** + * @depends testCreateTable + * @example Aws\DynamoDb\DynamoDbClient::waitUntilTableExists 2012-08-10 + */ + public function testWaitUntilTableExists() + { + $client = $this->client; + // @begin + + // Wait until the table is created and active + $client->waitUntil('TableExists', array( + 'TableName' => 'errors' + )); + } + + /** + * Update a table to change the provisioned throughput + * + * @depends testWaitUntilTableExists + * @example Aws\DynamoDb\DynamoDbClient::updateTable 2012-08-10 + * @example Aws\DynamoDb\DynamoDbClient::waitUntilTableExists 2012-08-10 + */ + public function testUpdateTable() + { + $client = $this->client; + // @begin + + // Update the provisioned throughput capacity of the table + $client->updateTable(array( + 'TableName' => 'errors', + 'ProvisionedThroughput' => array( + 'ReadCapacityUnits' => 15, + 'WriteCapacityUnits' => 25 + ) + )); + + // Wait until the table is active again after updating + $client->waitUntil('TableExists', array( + 'TableName' => 'errors' + )); + } + + /** + * Describe a table and grab data from the output + * + * @depends testUpdateTable + * @example Aws\DynamoDb\DynamoDbClient::describeTable 2012-08-10 + */ + public function testDescribeTable() + { + $client = $this->client; + $this->expectOutputString("0\n15\n"); + // @begin + + $result = $client->describeTable(array( + 'TableName' => 'errors' + )); + + // The result of an operation can be used like an array + echo $result['Table']['ItemCount'] . "\n"; + //> 0 + + // Use the getPath() method to retrieve deeply nested array key values + echo $result->getPath('Table/ProvisionedThroughput/ReadCapacityUnits') . "\n"; + //> 15 + } + + /** + * List the first page of results of tables owned by your account + * + * @depends testDescribeTable + * @example Aws\DynamoDb\DynamoDbClient::listTables 2012-08-10 + */ + public function testListTables() + { + $client = $this->client; + // @begin + + $result = $client->listTables(); + + // TableNames contains an array of table names + foreach ($result['TableNames'] as $tableName) { + echo $tableName . "\n"; + } + + // @end + $this->assertContains("errors\n", $this->getActualOutput()); + } + + /** + * List all of the tables owned by your account using a ListTables iterator + * + * @depends testListTables + * @example Aws\DynamoDb\DynamoDbClient::listTable 2012-08-10 + */ + public function testListTablesWithIterator() + { + $client = $this->client; + // @begin + + $iterator = $client->getIterator('ListTables'); + + foreach ($iterator as $tableName) { + echo $tableName . "\n"; + } + + // @end + $this->assertContains("errors\n", $this->getActualOutput()); + } + + /** + * Put an item in a table using the formatAttributes() client helper method + * + * @depends testListTablesWithIterator + * @example Aws\DynamoDb\DynamoDbClient::putItem 2012-08-10 + * @example Aws\DynamoDb\DynamoDbClient::formatAttributes 2012-08-10 + */ + public function testAddItem() + { + $client = $this->client; + // @begin + + $time = time(); + + $result = $client->putItem(array( + 'TableName' => 'errors', + 'Item' => $client->formatAttributes(array( + 'id' => 1201, + 'time' => $time, + 'error' => 'Executive overflow', + 'message' => 'no vacant areas' + )), + 'ReturnConsumedCapacity' => 'TOTAL' + )); + + // The result will always contain ConsumedCapacityUnits + echo $result->getPath('ConsumedCapacity/CapacityUnits') . "\n"; + + // @end + $this->assertNotEmpty($this->getActualOutput()); + return $time; + } + + /** + * Put an item in a table + * + * @depends testAddItem + * @example Aws\DynamoDb\DynamoDbClient::putItem 2012-08-10 + */ + public function testAddItemWithoutHelperMethod($time) + { + $client = $this->client; + // @begin + + $result = $client->putItem(array( + 'TableName' => 'errors', + 'Item' => array( + 'id' => array('N' => '1201'), + 'time' => array('N' => $time), + 'error' => array('S' => 'Executive overflow'), + 'message' => array('S' => 'no vacant areas') + ) + )); + + // @end + return $time; + } + + /** + * Get an item from a table and interact with the response + * + * @depends testAddItemWithoutHelperMethod + * @example Aws\DynamoDb\DynamoDbClient::getItem 2012-08-10 + */ + public function testGetItem($time) + { + $client = $this->client; + $this->expectOutputString("1201\n1201\nExecutive overflow\nno vacant areas\n"); + // @begin + + $result = $client->getItem(array( + 'ConsistentRead' => true, + 'TableName' => 'errors', + 'Key' => array( + 'id' => array('N' => '1201'), + 'time' => array('N' => $time) + ) + )); + + // Grab value from the result object like an array + echo $result['Item']['id']['N'] . "\n"; + //> 1201 + echo $result->getPath('Item/id/N') . "\n"; + //> 1201 + echo $result['Item']['error']['S'] . "\n"; + //> Executive overflow + echo $result['Item']['message']['S'] . "\n"; + //> no vacant areas + } + + /** + * Get all results of a Query operation using a Query iterator + * + * @depends testGetItem + * @example Aws\DynamoDb\DynamoDbClient::query 2012-08-10 + */ + public function testQuery() + { + $client = $this->client; + // @begin + + $iterator = $client->getIterator('Query', array( + 'TableName' => 'errors', + 'KeyConditions' => array( + 'id' => array( + 'AttributeValueList' => array( + array('N' => '1201') + ), + 'ComparisonOperator' => 'EQ' + ), + 'time' => array( + 'AttributeValueList' => array( + array('N' => strtotime("-15 minutes")) + ), + 'ComparisonOperator' => 'GT' + ) + ) + )); + + // Each item will contain the attributes we added + foreach ($iterator as $item) { + // Grab the time number value + echo $item['time']['N'] . "\n"; + // Grab the error string value + echo $item['error']['S'] . "\n"; + } + + // @end + $this->assertNotEmpty($this->getActualOutput()); + } + + /** + * Get all of the results of a Scan operation using a Scan iterator + * + * @depends testQuery + * @example Aws\DynamoDb\DynamoDbClient::scan 2012-08-10 + */ + public function testScan() + { + $client = $this->client; + // @begin + + $iterator = $client->getIterator('Scan', array( + 'TableName' => 'errors', + 'ScanFilter' => array( + 'error' => array( + 'AttributeValueList' => array( + array('S' => 'overflow') + ), + 'ComparisonOperator' => 'CONTAINS' + ), + 'time' => array( + 'AttributeValueList' => array( + array('N' => strtotime('-15 minutes')) + ), + 'ComparisonOperator' => 'GT' + ) + ) + )); + + // Each item will contain the attributes we added + foreach ($iterator as $item) { + // Grab the time number value + echo $item['time']['N'] . "\n"; + // Grab the error string value + echo $item['error']['S'] . "\n"; + } + + // @end + $this->assertNotEmpty($this->getActualOutput()); + } + + /** + * Get normalized results of a Scan operation using a Scan iterator with an ItemIterator + * + * @depends testScan + * @example Aws\DynamoDb\DynamoDbClient::scan 2012-08-10 + * @example Aws\DynamoDb\Iterator\ItemIterator + */ + public function testScanWithItemIterator() + { + $client = $this->client; + // @begin + + $iterator = new ItemIterator($client->getIterator('Scan', array( + 'TableName' => 'errors' + ))); + + // Each item will contain the attributes we added + foreach ($iterator as $item) { + // Grab the time number value + echo $item['time'] . "\n"; + // Grab the error string value + echo $item->get('error') . "\n"; + } + + // @end + $this->assertNotEmpty($this->getActualOutput()); + } + + /** + * Perform a parallel scan of multiple table segments + * + * @depends testScanWithItemIterator + * @example Aws\DynamoDb\DynamoDbClient::scan 2012-08-10 + */ + public function testParallelScan() + { + $client = $this->client; + // @begin + + $params = array( + 'TableName' => 'errors', + 'ScanFilter' => array( + 'error' => array( + 'AttributeValueList' => array( + array('S' => 'overflow') + ), + 'ComparisonOperator' => 'CONTAINS' + ), + ), + 'TotalSegments' => 2 + ); + + $scanCommands = array(); + $scanCommands[] = $client->getCommand('Scan', array('Segment' => 0) + $params); + $scanCommands[] = $client->getCommand('Scan', array('Segment' => 1) + $params); + $client->execute($scanCommands); + + foreach ($scanCommands as $scanCommand) { + $result = $scanCommand->getResult(); + foreach ($result->get('Items') as $item) { + echo $item['error']['S'] . "\n"; + } + } + + // @end + $this->assertNotEmpty($this->getActualOutput()); + } + + /** + * Put and get an item with a binary attribute + * + * @depends testParallelScan + * @example Aws\DynamoDb\DynamoDbClient::putItem 2012-08-10 + * @example Aws\DynamoDb\DynamoDbClient::getItem 2012-08-10 + */ + public function testBinaryType() + { + $client = $this->client; + // @begin + + $data = '¡™£¢∞§¶•ªº'; + $time = time(); + + $client->putItem(array( + 'TableName' => 'errors', + 'Item' => array( + 'id' => array('N' => '3000'), + 'time' => array('N' => $time), + 'error' => array('S' => 'Out of bounds'), + 'data' => array('B' => $data) + ) + )); + + $result = $client->getItem(array( + 'ConsistentRead' => true, + 'TableName' => 'errors', + 'Key' => array( + 'id' => array('N' => '3000'), + 'time' => array('N' => $time) + ) + )); + + if (base64_decode($result['Item']['data']['B']) == $data) { + echo 'Data was stored and retrieved correctly.'; + } else { + echo 'Uh oh...'; + } + //> Data was stored and retrieved correctly. + + // @end + $this->assertEquals('Data was stored and retrieved correctly.', $this->getActualOutput()); + } + + /** + * Get batches of items + * + * @depends testBinaryType + * @example Aws\DynamoDb\DynamoDbClient::batchGetItem 2012-08-10 + */ + public function testBatchGetItem() + { + $client = $this->client; + + $keyValues = array(); + $scan = $client->getIterator('Scan', array('TableName' => 'errors')); + foreach ($scan as $item) { + $keyValues[] = array($item['id']['N'], $item['time']['N']); + } + // @begin + + $tableName = 'errors'; + $keys = array(); + + // Given that $keyValues contains a list of your hash and range keys: + // array(array(, ), ...) + // Build the array for the "Keys" parameter + foreach ($keyValues as $values) { + list($hashKeyValue, $rangeKeyValue) = $values; + $keys[] = array( + 'id' => array('N' => $hashKeyValue), + 'time' => array('N' => $rangeKeyValue) + ); + } + + // Get multiple items by key in a BatchGetItem request + $result = $client->batchGetItem(array( + 'RequestItems' => array( + $tableName => array( + 'Keys' => $keys, + 'ConsistentRead' => true + ) + ) + )); + $items = $result->getPath("Responses/{$tableName}"); + // @end + + $this->assertEquals(count($keys), count($items)); + + // Also check the iterator to make sure it works the same + $iterator = $client->getIterator('BatchGetItem', array( + 'RequestItems' => array( + $tableName => array( + 'Keys' => $keys + ) + ) + )); + $iteratedItems = iterator_to_array($iterator); + print_r($iteratedItems); + $this->assertEquals(count($keys), count($iteratedItems)); + } + + /** + * Delete an item + * + * @depends testBatchGetItem + * @example Aws\DynamoDb\DynamoDbClient::deleteItem 2012-08-10 + * @example Aws\DynamoDb\DynamoDbClient::scan 2012-08-10 + */ + public function testDeleteItem() + { + $client = $this->client; + // @begin + + $scan = $client->getIterator('Scan', array('TableName' => 'errors')); + foreach ($scan as $item) { + $client->deleteItem(array( + 'TableName' => 'errors', + 'Key' => array( + 'id' => array('N' => $item['id']['N']), + 'time' => array('N' => $item['time']['N']) + ) + )); + } + } + + /** + * Delete a table + * + * @depends testDeleteItem + * @example Aws\DynamoDb\DynamoDbClient::deleteTable 2012-08-10 + */ + public function testDeleteTable() + { + $client = $this->client; + // @begin + + $client->deleteTable(array( + 'TableName' => 'errors' + )); + + $client->waitUntil('TableNotExists', array( + 'TableName' => 'errors' + )); + } + + /** + * Create a table with a local secondary index + * + * @example Aws\DynamoDb\DynamoDbClient::createTable 2012-08-10 + */ + public function testCreateTableWithLocalSecondaryIndexes() + { + $client = $this->client; + // @begin + + // Create an "Orders" table + $client->createTable(array( + 'TableName' => 'Orders', + 'AttributeDefinitions' => array( + array('AttributeName' => 'CustomerId', 'AttributeType' => 'N'), + array('AttributeName' => 'OrderId', 'AttributeType' => 'N'), + array('AttributeName' => 'OrderDate', 'AttributeType' => 'N'), + ), + 'KeySchema' => array( + array('AttributeName' => 'CustomerId', 'KeyType' => 'HASH'), + array('AttributeName' => 'OrderId', 'KeyType' => 'RANGE'), + ), + 'LocalSecondaryIndexes' => array( + array( + 'IndexName' => 'OrderDateIndex', + 'KeySchema' => array( + array('AttributeName' => 'CustomerId', 'KeyType' => 'HASH'), + array('AttributeName' => 'OrderDate', 'KeyType' => 'RANGE'), + ), + 'Projection' => array( + 'ProjectionType' => 'KEYS_ONLY', + ), + ), + ), + 'ProvisionedThroughput' => array( + 'ReadCapacityUnits' => 10, + 'WriteCapacityUnits' => 20 + ) + )); + + $client->waitUntil('TableExists', array('TableName' => 'Orders')); + } + + /** + * Use BatchWriteItem to put multiple items at once + * + * @depends testCreateTableWithLocalSecondaryIndexes + * @example Aws\DynamoDb\DynamoDbClient::batchWriteItem 2012-08-10 + */ + public function testBatchWriteItem() + { + $client = $this->client; + // @begin + + $result = $client->batchWriteItem(array( + 'RequestItems' => array( + 'Orders' => array( + array( + 'PutRequest' => array( + 'Item' => array( + 'CustomerId' => array('N' => 1041), + 'OrderId' => array('N' => 6), + 'OrderDate' => array('N' => strtotime('-5 days')), + 'ItemId' => array('N' => 25336) + ) + ) + ), + array( + 'PutRequest' => array( + 'Item' => array( + 'CustomerId' => array('N' => 941), + 'OrderId' => array('N' => 8), + 'OrderDate' => array('N' => strtotime('-3 days')), + 'ItemId' => array('N' => 15596) + ) + ) + ), + array( + 'PutRequest' => array( + 'Item' => array( + 'CustomerId' => array('N' => 941), + 'OrderId' => array('N' => 2), + 'OrderDate' => array('N' => strtotime('-12 days')), + 'ItemId' => array('N' => 38449) + ) + ) + ), + array( + 'PutRequest' => array( + 'Item' => array( + 'CustomerId' => array('N' => 941), + 'OrderId' => array('N' => 3), + 'OrderDate' => array('N' => strtotime('-1 days')), + 'ItemId' => array('N' => 25336) + ) + ) + ) + ) + ) + )); + } + + /** + * Get results of a Query operation with a local secondary index on the table + * + * @depends testBatchWriteItem + * @example Aws\DynamoDb\DynamoDbClient::query 2012-08-10 + */ + public function testQueryWithLocalSecondaryIndexes() + { + $client = $this->client; + // @begin + + // Find the number of orders made by customer 941 in the last 10 days + $result = $client->query(array( + 'TableName' => 'Orders', + 'IndexName' => 'OrderDateIndex', + 'Select' => 'COUNT', + 'KeyConditions' => array( + 'CustomerId' => array( + 'AttributeValueList' => array( + array('N' => '941') + ), + 'ComparisonOperator' => 'EQ' + ), + 'OrderDate' => array( + 'AttributeValueList' => array( + array('N' => strtotime("-10 days")) + ), + 'ComparisonOperator' => 'GE' + ) + ) + )); + + $numOrders = $result['Count']; + + // @end + $this->assertEquals(2, $numOrders); + } + + /** + * @depends testQueryWithLocalSecondaryIndexes + */ + public function testDeleteIndexedTable() + { + $this->client->deleteTable(array( + 'TableName' => 'Orders' + )); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Integration/IteratorsTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Integration/IteratorsTest.php new file mode 100644 index 0000000..e5de771 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Integration/IteratorsTest.php @@ -0,0 +1,145 @@ +getServiceBuilder()->get('dynamodb'); + $mock = $this->setMockResponse($client, array( + 'dynamodb/batch_get_item_has_more', + 'dynamodb/batch_get_item_empty_has_more', + 'dynamodb/batch_get_item_final' + )); + + $iterator = $client->getIterator('BatchGetItem', array( + 'RequestItems' => array( + 'Table1' => array( + 'Keys' => array( + array( + 'AttributeName1' => array('S' => 'KeyValue1'), + 'AttributeName2' => array('N' => '2') + ), + array( + 'AttributeName1' => array('S' => 'KeyValue3'), + 'AttributeName2' => array('N' => '4') + ), + array( + 'AttributeName1' => array('S' => 'KeyValue5'), + 'AttributeName2' => array('N' => '6') + ) + ), + 'AttributesToGet' => array('AttributeName1', 'AttributeName2', 'AttributeName3') + ), + 'Table2' => array( + 'Keys' => array( + array('AttributeName1' => array('S' => 'KeyValue4')), + array('AttributeName2' => array('S' => 'KeyValue5')) + ), + 'AttributesToGet' => array('AttributeName4', 'AttributeName5', 'AttributeName6') + ) + ) + )); + + foreach ($iterator as $item) { + $this->assertInternalType('array', $item); + } + + $requests = $mock->getReceivedRequests(); + $this->assertEquals(3, count($requests)); + } + + public function testIteratesListTableCommand() + { + $client = $this->getServiceBuilder()->get('dynamodb'); + $mock = $this->setMockResponse($client, array( + 'dynamodb/list_tables_has_more', + 'dynamodb/list_tables_final' + )); + + $iterator = $client->getIterator('ListTables'); + + $this->assertEquals(array('Table1', 'Table2', 'Table3', 'Table4', 'Table5'), $iterator->toArray()); + + $requests = $mock->getReceivedRequests(); + $this->assertEquals(2, count($requests)); + $json = json_decode((string) $requests[1]->getBody(), true); + $this->assertEquals('Table3', $json['ExclusiveStartTableName']); + } + + public function testIteratesQueryCommand() + { + $client = $this->getServiceBuilder()->get('dynamodb'); + $mock = $this->setMockResponse($client, array( + 'dynamodb/query_has_more', + 'dynamodb/query_final', + )); + + $iterator = $client->getIterator('Query', array( + 'TableName' => 'foo', + 'AttributeName1' => array( + 'S' => 'AttributeValue1' + ) + )); + + $data = $iterator->toArray(); + $this->assertEquals(3, count($data)); + + $requests = $mock->getReceivedRequests(); + $this->assertEquals(2, count($requests)); + $json = json_decode((string) $requests[1]->getBody(), true); + $this->assertArrayHasKey('ExclusiveStartKey', $json); + } + + public function testIteratesScanCommand() + { + $client = $this->getServiceBuilder()->get('dynamodb'); + $mock = $this->setMockResponse($client, array( + 'dynamodb/scan_has_more', + 'dynamodb/scan_empty_has_more', + 'dynamodb/scan_final', + )); + + $iterator = $client->getIterator('Scan', array( + 'TableName' => 'foo' + )); + + $data = $iterator->toArray(); + $this->assertEquals(3, count($data)); + + $requests = $mock->getReceivedRequests(); + $this->assertEquals(3, count($requests)); + $json = json_decode((string) $requests[1]->getBody(), true); + $this->assertArrayHasKey('ExclusiveStartKey', $json); + + $this->assertEquals(207, $iterator->getScannedCount()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Integration/PerformanceTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Integration/PerformanceTest.php new file mode 100644 index 0000000..5b460da --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Integration/PerformanceTest.php @@ -0,0 +1,151 @@ +get('dynamodb'); + + // Get a list of tables in your account + self::log('Checking if the ' . self::getTableName() . ' table exists'); + $tables = $client->getIterator('ListTables')->toArray(); + + // If the table does not exist, then create it + if (!in_array(self::getTableName(), $tables)) { + self::log('Table does not exist. Creating now.'); + $client->createTable(array( + 'TableName' => self::getTableName(), + 'AttributeDefinitions' => array( + array('AttributeName' => 'foo', 'AttributeType' => 'S'), + array('AttributeName' => 'bar', 'AttributeType' => 'N'), + ), + 'KeySchema' => array( + array('AttributeName' => 'foo', 'KeyType' => 'HASH'), + array('AttributeName' => 'bar', 'KeyType' => 'RANGE'), + ), + 'ProvisionedThroughput' => array( + 'ReadCapacityUnits' => self::READ_CAPACITY, + 'WriteCapacityUnits' => 5 + ) + )); + } + + // Wait until the table is created and active + $client->waitUntil('TableExists', array('TableName' => self::getTableName())); + sleep(5); + + try { + self::log('Creating the test item'); + $client->putItem(array( + 'TableName' => self::getTableName(), + 'Item' => $client->formatAttributes(array( + 'foo' => 'fizz', + 'bar' => 1, + 'attr1' => 42, + 'attr2' => array('a', 'b', 'c', 'd') + )) + )); + } catch (DynamoDbException $e) { + echo $e->getResponse()->getRequest(); + echo $e->getResponse(); + echo $e->getMessage(); + throw $e; + } + + self::log('Initialization process completed'); + } + + /** + * @return array + */ + public function perfDataProvider() + { + $client = self::getServiceBuilder()->get('dynamodb'); + + return array( + array( + self::TOTAL_REQUESTS, + $client->getCommand('PutItem', array( + 'TableName' => self::getTableName(), + 'Item' => $client->formatAttributes(array( + 'foo' => 'fizz', + 'bar' => 1, + 'attr1' => 42, + 'attr2' => array('a', 'b', 'c', 'd') + )) + ) + )), + array( + self::TOTAL_REQUESTS, + $client->getCommand('GetItem', array( + 'TableName' => self::getTableName(), + 'Key' => array( + 'foo' => array('S' => 'abcdefghijklm' . implode('-', range('a', 'z'))), + 'bar' => array('N' => '1') + ) + )) + ) + ); + } + + /** + * @dataProvider perfDataProvider + */ + public function testIssuesMultipleOperationsSerially($totalRequests, $command) + { + $retries = 0; + $this->log('Beginning ' . $command->getName() . ' performance test'); + $s = microtime(true); + + for ($i = 0; $i < $totalRequests; $i++) { + try { + $command->execute(); + } catch (\Exception $e) { + echo $command->getRequest(); + echo $command->getResponse(); + throw $e; + } + $params = $command->getRequest()->getParams(); + $retries += $params->get('plugins.exponential_backoff.retry_count'); + $params->set('plugins.exponential_backoff.retry_count', 0); + } + + $elapsed = microtime(true) - $s; + + $speed = $totalRequests / $elapsed; + $perRequest = $elapsed / $totalRequests; + $this->log( + "Executed {$totalRequests} " . $command->getName() . " requests in {$elapsed} seconds from a " + . self::READ_CAPACITY . " table with {$retries} retries ({$perRequest}/request, {$speed}/second)" + ); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Integration/WriteRequestBatch_20111205_Test.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Integration/WriteRequestBatch_20111205_Test.php new file mode 100644 index 0000000..5f9580c --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Integration/WriteRequestBatch_20111205_Test.php @@ -0,0 +1,135 @@ +get('dynamodb', array('version' => '2011-12-05')); + + try { + $client->deleteTable(array('TableName' => 'batch-write-test')); + } catch (\Exception $e) {} + $client->waitUntilTableNotExists(array('TableName' => 'batch-write-test')); + } + + public static function tearDownAfterClass() + { + self::setUpBeforeClass(); + } + + /** + * Use WriteRequestBatch to batch several PutItem requests + */ + public function testWriteRequestBatchForPuts() + { + /** @var $client DynamoDbClient */ + $client = self::getServiceBuilder()->get('dynamodb', array('version' => '2011-12-05')); + $tableName = 'batch-write-test'; + + try { + $client->describeTable(array('TableName' => $tableName)); + self::log("The {$tableName} table exists."); + } catch (ResourceNotFoundException $e) { + self::log("Create the {$tableName} table."); + $client->createTable(array( + 'TableName' => $tableName, + 'KeySchema' => array( + 'HashKeyElement' => array( + 'AttributeName' => 'id', + 'AttributeType' => 'S' + ), + ), + 'ProvisionedThroughput' => array( + 'ReadCapacityUnits' => 20, + 'WriteCapacityUnits' => 20 + ) + )); + } + + self::log("Wait until the {$tableName} table's status is ACTIVE..."); + $client->waitUntilTableExists(array('TableName' => $tableName)); + + self::log("Test writing items in batches using WriteRequestBatch."); + // @begin + $tableName = 'batch-write-test'; // This table has a HashKey named "id" + $itemIds = array(); + + // Put 55 items into the table + $putBatch = WriteRequestBatch::factory($client); + for ($i = 0; $i < 55; $i++) { + $itemIds[] = $itemId = uniqid(); + $item = Item::fromArray(array( + 'id' => $itemId, + 'timestamp' => time(), + )); + $putBatch->add(new PutRequest($item, $tableName)); + } + $putBatch->flush(); + // @end + + self::log("Assert that all the items made it into the table."); + $scan = $client->getIterator('Scan', array('TableName' => $tableName)); + $this->assertGreaterThanOrEqual(55, iterator_count($scan), 'Not all of the items were inserted.'); + + return array($client, $tableName, $itemIds); + } + + /** + * Use WriteRequestBatch to batch several DeleteItem requests + * + * @depends testWriteRequestBatchForPuts + * @example Aws\DynamoDb\Model\BatchRequest\DeleteRequest::__construct 2011-12-05 + */ + public function testWriteRequestBatchForDeletes(array $state) + { + /** @var $client DynamoDbClient */ + /** @var $tableName string */ + /** @var $itemIds array */ + list($client, $tableName, $itemIds) = $state; + + self::log("Test deleting items in batches using WriteRequestBatch."); + // @begin + + // Remove items from the table + $deleteBatch = WriteRequestBatch::factory($client); + foreach ($itemIds as $itemId) { + $key = array('HashKeyElement' => array('S' => $itemId)); + $deleteBatch->add(new DeleteRequest($key, $tableName)); + } + $deleteBatch->flush(); + // @end + + self::log("Assert that all the items have been deleted from the table"); + $scanner = $client->getIterator('Scan', array('TableName' => $tableName)); + $this->assertEquals(0, iterator_count($scanner), 'Not all of the items were deleted.'); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Integration/WriteRequestBatch_20120810_Test.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Integration/WriteRequestBatch_20120810_Test.php new file mode 100644 index 0000000..110daef --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Integration/WriteRequestBatch_20120810_Test.php @@ -0,0 +1,146 @@ +get('dynamodb', array('version' => '2012-08-10')); + + try { + $client->deleteTable(array('TableName' => 'batch-write-test')); + } catch (\Exception $e) {} + $client->waitUntilTableNotExists(array('TableName' => 'batch-write-test')); + } + + public static function tearDownAfterClass() + { + self::setUpBeforeClass(); + } + + /** + * Use WriteRequestBatch to batch several PutItem requests + * + * @example Aws\DynamoDb\Model\BatchRequest\WriteRequestBatch::factory + * @example Aws\DynamoDb\Model\BatchRequest\WriteRequestBatch::add + * @example Aws\DynamoDb\Model\BatchRequest\PutRequest::__construct + * @example Aws\DynamoDb\Model\Item::fromArray + */ + public function testWriteRequestBatchForPuts() + { + /** @var $client DynamoDbClient */ + $client = self::getServiceBuilder()->get('dynamodb', array('version' => '2012-08-10')); + $tableName = 'batch-write-test'; + + try { + $client->describeTable(array('TableName' => $tableName)); + self::log("The {$tableName} table exists."); + } catch (ResourceNotFoundException $e) { + self::log("Create the {$tableName} table."); + $client->createTable(array( + 'TableName' => $tableName, + 'AttributeDefinitions' => array( + array( + 'AttributeName' => 'id', + 'AttributeType' => 'S' + ) + ), + 'KeySchema' => array( + array( + 'AttributeName' => 'id', + 'KeyType' => 'HASH' + ), + ), + 'ProvisionedThroughput' => array( + 'ReadCapacityUnits' => 20, + 'WriteCapacityUnits' => 20 + ) + )); + } + + self::log("Wait until the {$tableName} table's status is ACTIVE..."); + $client->waitUntilTableExists(array('TableName' => $tableName)); + + self::log("Test writing items in batches using WriteRequestBatch."); + // @begin + $tableName = 'batch-write-test'; // This table has a HashKey named "id" + $itemIds = array(); + + // Put 55 items into the table + $putBatch = WriteRequestBatch::factory($client); + for ($i = 0; $i < 55; $i++) { + $itemIds[] = $itemId = uniqid(); + $item = Item::fromArray(array( + 'id' => $itemId, + 'timestamp' => time(), + )); + $putBatch->add(new PutRequest($item, $tableName)); + } + $putBatch->flush(); + // @end + + self::log("Assert that all the items made it into the table."); + $scan = $client->getIterator('Scan', array('TableName' => $tableName)); + $this->assertGreaterThanOrEqual(55, iterator_count($scan), 'Not all of the items were inserted.'); + + return array($client, $tableName, $itemIds); + } + + /** + * Use WriteRequestBatch to batch several DeleteItem requests + * + * @depends testWriteRequestBatchForPuts + * @example Aws\DynamoDb\Model\BatchRequest\DeleteRequest::__construct 2012-08-10 + */ + public function testWriteRequestBatchForDeletes(array $state) + { + /** @var $client DynamoDbClient */ + /** @var $tableName string */ + /** @var $itemIds array */ + list($client, $tableName, $itemIds) = $state; + + self::log("Test deleting items in batches using WriteRequestBatch."); + // @begin + + // Remove items from the table + $deleteBatch = WriteRequestBatch::factory($client); + foreach ($itemIds as $itemId) { + $key = array('id' => array('S' => $itemId)); + $deleteBatch->add(new DeleteRequest($key, $tableName)); + } + $deleteBatch->flush(); + // @end + + self::log("Assert that all the items have been deleted from the table"); + $scanner = $client->getIterator('Scan', array('TableName' => $tableName)); + $this->assertEquals(0, iterator_count($scanner), 'Not all of the items were deleted.'); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Iterator/ItemIteratorTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Iterator/ItemIteratorTest.php new file mode 100644 index 0000000..4270124 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Iterator/ItemIteratorTest.php @@ -0,0 +1,194 @@ + array('S' => 'a1'), + 'b' => array('N' => 1), + ), + array( + 'a' => array('S' => 'a2'), + 'b' => array('N' => 2), + ), + array( + 'a' => array('S' => 'a3'), + 'c' => array('B' => base64_encode('c3')), + ), + array( + 'a' => array('S' => 'a4'), + 'd' => array('SS' => array('d4a', 'd4b')), + ), + array( + 'a' => array('S' => 'a5'), + 'e' => array('BS' => array(base64_encode('e5a'), base64_encode('e5b'))), + ) + ); + + $targetItems = array( + new Collection(array( + 'a' => 'a1', + 'b' => 1, + )), + new Collection(array( + 'a' => 'a2', + 'b' => 2, + )), + new Collection(array( + 'a' => 'a3', + 'c' => 'c3', + )), + new Collection(array( + 'a' => 'a4', + 'd' => array('d4a', 'd4b'), + )), + new Collection(array( + 'a' => 'a5', + 'e' => array('e5a', 'e5b'), + )) + ); + + $iterator = new ItemIterator(new \ArrayIterator($originalItems)); + $this->assertCount(5, $iterator); + $actualItems = $iterator->toArray(); + foreach ($actualItems as $index => $item) { + $this->assertInstanceOf('Guzzle\Common\Collection', $item); + $this->assertEquals($item->toArray(), $targetItems[$index]->toArray()); + } + + } + + /** + * @expectedException \InvalidArgumentException + */ + public function testFailsOnNonCountableIterator() + { + $inner = new \InfiniteIterator(new \ArrayIterator(range(0, 9))); + $items = new ItemIterator($inner); + } + + public function dataForFromResultsTest() + { + return array( + // Scan/Query results + array( + array( + 'Items' => array( + array('a' => array('S' => 'a1'), 'b' => array('S' => 'b1')), + array('a' => array('S' => 'a2'), 'b' => array('S' => 'b2')), + ) + ), + array( + array('a' => 'a1', 'b' => 'b1'), + array('a' => 'a2', 'b' => 'b2'), + ) + ), + + // GetItem results + array( + array( + 'Item' => array( + 'a' => array('S' => 'a3'), + 'b' => array('S' => 'b3') + ), + ), + array( + array('a' => 'a3', 'b' => 'b3') + ) + ), + + // UpdateItem/PutItem results + array( + array( + 'Attributes' => array( + 'a' => array('S' => 'a4'), + 'b' => array('S' => 'b4') + ), + ), + array( + array('a' => 'a4', 'b' => 'b4') + ) + ), + + // BatchGetItem results + array( + array( + 'Responses' => array( + 'foo' => array( + array('a' => array('S' => 'a5'), 'b' => array('S' => 'b5')), + array('a' => array('S' => 'a6'), 'b' => array('S' => 'b6')), + ), + 'bar' => array( + array('a' => array('S' => 'a7'), 'b' => array('S' => 'b7')), + array('a' => array('S' => 'a8'), 'b' => array('S' => 'b8')), + ), + ) + ), + array( + array('a' => 'a5', 'b' => 'b5'), + array('a' => 'a6', 'b' => 'b6'), + array('a' => 'a7', 'b' => 'b7'), + array('a' => 'a8', 'b' => 'b8'), + ) + ), + + // ListTables result + array( + array('TableNames' => array('foo', 'bar', 'baz')), + array() + ), + ); + } + + /** + * @dataProvider dataForFromResultsTest + */ + public function testCanGetItemsFromDifferentKindsOfResults(array $result, array $expectedItems) + { + $actualItems = array_map(function (Collection $item) { + return $item->toArray(); + }, ItemIterator::fromResult(new Model($result))->toArray()); + + $this->assertEquals($expectedItems, $actualItems); + } + + public function testGetFirstWorksNoMatterWhereTheCursorIs() + { + $iterator = new ItemIterator(new \ArrayIterator(array( + array('letter' => array('S' => 'a')), + array('letter' => array('S' => 'b')), + array('letter' => array('S' => 'c')), + ))); + + $this->assertEquals('a', $iterator->getFirst()->get('letter')); + + $iterator->next(); + $this->assertEquals('b', $iterator->current()->get('letter')); + $this->assertEquals('a', $iterator->getFirst()->get('letter')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Iterator/ScanIteratorTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Iterator/ScanIteratorTest.php new file mode 100644 index 0000000..faec562 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Iterator/ScanIteratorTest.php @@ -0,0 +1,50 @@ +getMock('Guzzle\Service\Command\CommandInterface'); + $iterator = new ScanIterator($command, array('result_key' => 'Items')); + $model = new Model(array( + 'Items' => array(1, 2, 3), + 'ScannedCount' => 4 + )); + + $class = new \ReflectionObject($iterator); + $method = $class->getMethod('handleResults'); + $method->setAccessible(true); + $items = $method->invoke($iterator, $model); + + $this->assertEquals(4, $iterator->getScannedCount()); + $this->assertCount(3, $items); + + Version::$emitWarnings = $emitWarnings; + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Model/AttributeTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Model/AttributeTest.php new file mode 100644 index 0000000..10017f3 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Model/AttributeTest.php @@ -0,0 +1,172 @@ +setExpectedException('\\Aws\\Common\\Exception\\InvalidArgumentException'); + } + + $attribute = Attribute::factory($value); + + $this->assertSame($expected, json_encode($attribute->getFormatted())); + } + + public function testFactoryUsesValueIfAlreadyAttribute() + { + $a = Attribute::factory(array( + 'foo' => 'bar' + )); + + $this->assertSame($a, Attribute::factory($a)); + } + + public function testSettersAndGettersWorkAsExpected() + { + /** @var $attribute \Aws\DynamoDb\Model\Attribute */ + $attribute = $this->getMockForAbstractClass('Aws\DynamoDb\Model\Attribute', array('foo')); + $this->assertSame($attribute, $attribute->setValue('100')); + $this->assertSame($attribute, $attribute->setType(Type::NUMBER)); + $this->assertSame('100', $attribute->getValue()); + $this->assertSame(Type::NUMBER, $attribute->getType()); + } + + /** + * @expectedException \Aws\Common\Exception\InvalidArgumentException + */ + public function testSetValueFailsOnBadValue() + { + /** @var $attribute \Aws\DynamoDb\Model\Attribute */ + $attribute = $this->getMockForAbstractClass('Aws\DynamoDb\Model\Attribute', array('foo')); + $attribute->setValue(100); + } + + /** + * @expectedException \Aws\Common\Exception\InvalidArgumentException + */ + public function testSetTypeFailsOnBadType() + { + /** @var $attribute \Aws\DynamoDb\Model\Attribute */ + $attribute = $this->getMockForAbstractClass('Aws\DynamoDb\Model\Attribute', array('foo')); + $attribute->setType('foo'); + } + + public function testGetFormattedProducesCorrectArrayStructure() + { + /** @var $attribute \Aws\DynamoDb\Model\Attribute */ + $attribute = $this->getMockForAbstractClass('Aws\DynamoDb\Model\Attribute', array('foo')); + $attribute->setValue('100'); + $attribute->setType(Type::NUMBER); + + $putArray = array(Type::NUMBER => '100'); + $updateArray = array('Value' => array(Type::NUMBER => '100')); + + $this->assertSame($putArray, $attribute->getFormatted()); + $this->assertSame($putArray, $attribute->getFormatted(Attribute::FORMAT_PUT)); + $this->assertSame($updateArray, $attribute->getFormatted(Attribute::FORMAT_UPDATE)); + $this->assertSame($updateArray, $attribute->getFormatted(Attribute::FORMAT_EXPECTED)); + } + + public function testCanBeCastToString() + { + /** @var $attribute \Aws\DynamoDb\Model\Attribute */ + $attribute = $this->getMockForAbstractClass('Aws\DynamoDb\Model\Attribute', array('foo')); + $attribute->setValue(array('baz', 'bar')); + $attribute->setType(Type::STRING_SET); + + $this->assertEquals('baz, bar', (string) $attribute); + } + + public function testCanBeCastToArray() + { + /** @var $attribute \Aws\DynamoDb\Model\Attribute */ + $attribute = $this->getMockForAbstractClass('Aws\DynamoDb\Model\Attribute', array('foo')); + $attribute->setValue(array('baz', 'bar')); + $attribute->setType(Type::STRING_SET); + $this->assertEquals(array('SS' => array('baz', 'bar')), $attribute->toArray()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Model/BatchRequest/AbstractWriteRequestTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Model/BatchRequest/AbstractWriteRequestTest.php new file mode 100644 index 0000000..798ed32 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Model/BatchRequest/AbstractWriteRequestTest.php @@ -0,0 +1,35 @@ +getMockForAbstractClass('Aws\DynamoDb\Model\BatchRequest\AbstractWriteRequest'); + $reflected = new \ReflectionProperty('Aws\DynamoDb\Model\BatchRequest\AbstractWriteRequest', 'tableName'); + $reflected->setAccessible(true); + $reflected->setValue($writeRequest, 'table'); + + $this->assertSame('table', $writeRequest->getTableName()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Model/BatchRequest/DeleteRequestTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Model/BatchRequest/DeleteRequestTest.php new file mode 100644 index 0000000..08ccefd --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Model/BatchRequest/DeleteRequestTest.php @@ -0,0 +1,87 @@ + array('S' => 'foo')); + + $deleteRequest = new DeleteRequest($key, 'table'); + + $this->assertSame($key, $deleteRequest->getKey()); + } + + public function testCanConvertToArray() + { + $key = array( + 'HashKeyElement' => Attribute::factory('foo'), + 'RangeKeyElement' => Attribute::factory(123) + ); + + $deleteRequest = new DeleteRequest($key, 'table'); + $this->assertEquals(array( + 'DeleteRequest' => array( + 'Key' => array( + 'HashKeyElement' => array('S' => 'foo'), + 'RangeKeyElement' => array('N' => '123') + ) + ) + ), $deleteRequest->toArray()); + } + + public function getTestCasesForCreateFromCommandTest() + { + /** @var $client \Aws\DynamoDb\DynamoDbClient */ + $client = self::getServiceBuilder()->get('dynamodb'); + + return array( + array( + $client->getCommand('ListTables'), + 'Aws\Common\Exception\InvalidArgumentException' + ), + array( + $client->getCommand('DeleteItem', array( + 'TableName' => 'foo', + 'Key' => array('HashKeyElement' => array('S' => 'foo')) + )), + 'Aws\DynamoDb\Model\BatchRequest\DeleteRequest' + ) + ); + } + + /** + * @dataProvider getTestCasesForCreateFromCommandTest + */ + public function testCanCreateFromCommand($command, $expectedObjectType) + { + try { + $result = DeleteRequest::fromCommand($command); + } catch (\InvalidArgumentException $e) { + $result = $e; + } + + $this->assertEquals($expectedObjectType, get_class($result)); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Model/BatchRequest/PutRequestTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Model/BatchRequest/PutRequestTest.php new file mode 100644 index 0000000..dadc73e --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Model/BatchRequest/PutRequestTest.php @@ -0,0 +1,108 @@ +getMock('Aws\DynamoDb\Model\Item'); + + $putRequest = new PutRequest($item, 'table'); + + $this->assertSame($item, $putRequest->getItem()); + } + + public function testConstructorSetsValuesWhenItemContainsTable() + { + $item = $this->getMock('Aws\DynamoDb\Model\Item'); + $item->expects($this->any()) + ->method('getTableName') + ->will($this->returnValue('table')); + + $putRequest = new PutRequest($item); + + $this->assertSame($item, $putRequest->getItem()); + } + + /** + * @expectedException Aws\Common\Exception\InvalidArgumentException + */ + public function testConstructorThrowsExceptionWithoutTable() + { + $item = $this->getMock('Aws\DynamoDb\Model\Item'); + + $putRequest = new PutRequest($item);; + } + + public function testCanConvertToArray() + { + $putRequest = new PutRequest(Item::fromArray(array( + 'foo' => 'bar', + 'baz' => 123, + )), 'table'); + + $this->assertEquals(array( + 'PutRequest' => array( + 'Item' => array( + 'foo' => array('S' => 'bar'), + 'baz' => array('N' => '123') + ) + ) + ), $putRequest->toArray()); + } + + public function getTestCasesForCreateFromCommandTest() + { + /** @var $client \Aws\DynamoDb\DynamoDbClient */ + $client = self::getServiceBuilder()->get('dynamodb'); + + return array( + array( + $client->getCommand('ListTables'), + 'Aws\Common\Exception\InvalidArgumentException' + ), + array( + $client->getCommand('PutItem', array( + 'TableName' => 'foo', + 'Item' => array('foo' => array('S' => 'bar')) + )), + 'Aws\DynamoDb\Model\BatchRequest\PutRequest' + ) + ); + } + + /** + * @dataProvider getTestCasesForCreateFromCommandTest + */ + public function testCanCreateFromCommand($command, $expectedObjectType) + { + try { + $result = PutRequest::fromCommand($command); + } catch (\InvalidArgumentException $e) { + $result = $e; + } + + $this->assertEquals($expectedObjectType, get_class($result)); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Model/BatchRequest/UnprocessedRequestTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Model/BatchRequest/UnprocessedRequestTest.php new file mode 100644 index 0000000..337c998 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Model/BatchRequest/UnprocessedRequestTest.php @@ -0,0 +1,34 @@ + 'bar'); + $unprocessedRequest = new UnprocessedRequest($data, 'table'); + + $this->assertSame($data, $unprocessedRequest->toArray()); + $this->assertSame('table', $unprocessedRequest->getTableName()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Model/BatchRequest/WriteRequestBatchTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Model/BatchRequest/WriteRequestBatchTest.php new file mode 100644 index 0000000..39202b5 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Model/BatchRequest/WriteRequestBatchTest.php @@ -0,0 +1,175 @@ +getMockBuilder('Aws\DynamoDb\DynamoDbClient') + ->disableOriginalConstructor() + ->getMock(); + } + + /** + * @param \PHPUnit_Framework_MockObject_Stub_Return $will + * + * @return FlushingBatch + */ + protected function getWriteRequestBatchWithMockedBatch($will) + { + $batch = $this->getMock('Guzzle\Batch\BatchInterface'); + $batch->expects($this->any()) + ->method('isEmpty') + ->will($this->onConsecutiveCalls(false, true)); + $batch->expects($this->any()) + ->method('flush') + ->will($will); + $batch = new FlushingBatch(new WriteRequestBatch($batch), 5); + + return $batch; + } + + public function testFactoryCreatesCorrectBatch() + { + $batch = WriteRequestBatch::factory($this->getMockedClient()); + $decorators = array(); + foreach ($batch->getDecorators() as $decorator) { + $decorators[] = get_class($decorator); + } + + $this->assertEquals(array( + 'Guzzle\Batch\FlushingBatch', + 'Aws\DynamoDb\Model\BatchRequest\WriteRequestBatch', + ), $decorators); + } + + public function testFactoryCanAddNotifyingBatchDecorator() + { + $batch = WriteRequestBatch::factory($this->getMockedClient(), 10, function () {}); + $decorators = array_map('get_class', $batch->getDecorators()); + $this->assertContains('Guzzle\Batch\NotifyingBatch', $decorators); + } + + public function getAddItemData() + { + $client = $this->getServiceBuilder()->get('dynamodb'); + $data = array(); + + // Exception when not a write request or command + $data[] = array(null, true); + + // Works with a delete_item command + $data[] = array( + $client->getCommand('DeleteItem') + ->set('TableName', 'foo') + ->set('Key', array( + 'HashKeyElement' => array('S' => 'bar') + )), + false + ); + + // Works with a put_item command + $data[] = array( + $client->getCommand('PutItem') + ->set('TableName', 'foo') + ->set('Item', array( + 'id' => array('S' => 'bar') + )), + false + ); + + // Exception with a arbitrary command + $data[] = array($client->getCommand('ListTables'), true); + + // Works with a write request + $data[] = array($this->getMock('Aws\DynamoDb\Model\BatchRequest\WriteRequestInterface'), false); + + return $data; + } + + /** + * @dataProvider getAddItemData + */ + public function testAddItem($item, $isEmpty) + { + $batch = WriteRequestBatch::factory($this->getMockedClient()); + + try { + $batch->add($item); + } catch (\Aws\Common\Exception\InvalidArgumentException $e) { + // Silently fail + } + + $this->assertSame($isEmpty, $batch->isEmpty()); + } + + public function testFlush() + { + $batch = $this->getWriteRequestBatchWithMockedBatch($this->returnValue(array())); + + $this->assertEquals(array(), $batch->flush()); + } + + public function testFlushUnprocessedItems() + { + // Prepare the unprocessed items exception + $item = new UnprocessedRequest(array('foo'), 'foo'); + $exceptionUnprocessed = new UnprocessedWriteRequestsException; + $exceptionUnprocessed->addItem($item); + $exceptionBatchTransfer = new BatchTransferException( + array($item), + array(), + $exceptionUnprocessed, + $this->getMock('Guzzle\Batch\BatchTransferInterface'), + $this->getMock('Guzzle\Batch\BatchDivisorInterface') + ); + + $batch = $this->getWriteRequestBatchWithMockedBatch($this->throwException($exceptionBatchTransfer)); + + $this->assertEquals(array(), $batch->flush()); + } + + /** + * @expectedException \Guzzle\Batch\Exception\BatchTransferException + */ + public function testFlushRandomExceptionFails() + { + $exceptionBatchTransfer = new \Guzzle\Batch\Exception\BatchTransferException( + array($this->getMock('Aws\DynamoDb\Model\BatchRequest\WriteRequestInterface')), + array(), + $this->getMock('\Exception'), + $this->getMock('Guzzle\Batch\BatchTransferInterface'), + $this->getMock('Guzzle\Batch\BatchDivisorInterface') + ); + + $batch = $this->getWriteRequestBatchWithMockedBatch($this->throwException($exceptionBatchTransfer)); + $batch->flush(); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Model/BatchRequest/WriteRequestBatchTransferTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Model/BatchRequest/WriteRequestBatchTransferTest.php new file mode 100755 index 0000000..e6ab9c0 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Model/BatchRequest/WriteRequestBatchTransferTest.php @@ -0,0 +1,180 @@ +getMockBuilder('Aws\DynamoDb\DynamoDbClient') + ->disableOriginalConstructor() + ->getMock(); + } + + public function testDoesNotTransfersEmptyBatches() + { + $client = $this->getMockedClient(); + $batch = new WriteRequestBatchTransfer($client); + $batch->transfer(array()); + } + + /** + * @return array Data for testTransfersBatches + */ + public function getTransferBatchesData() + { + // Mock objects for 3rd test case + $mockRequest = $this->getMockBuilder('Guzzle\Http\Message\EntityEnclosingRequestInterface') + ->disableOriginalConstructor() + ->getMock(); + $mockRequest->expects($this->any()) + ->method('getBody') + ->will($this->onConsecutiveCalls( + '{"RequestItems":{"foo":[{"PutRequest":{}},{"PutRequest":{}}]}}', + '{"RequestItems":{}}', + '{"RequestItems":{}}' + )); + $mockResponse = $this->getMockBuilder('Guzzle\Http\Message\Response') + ->disableOriginalConstructor() + ->getMock(); + $mockResponse->expects($this->any()) + ->method('getStatusCode') + ->will($this->returnValue(413)); + + $tooBigException = new DynamoDbException(); + $tooBigException->setResponse($mockResponse); + $tooBigException->setRequest($mockRequest); + $exceptionCollection = new ExceptionCollection(); + $exceptionCollection->add($tooBigException); + + // Mock objects for 4th use case + $exceptionCollectionWithDummy = new ExceptionCollection(); + $exceptionCollectionWithDummy->add(new \RuntimeException); + + // Provisioned throughput exceeded use case (#6) + $throughputExceededException = new DynamoDbException(); + $throughputExceededException->setExceptionCode('ProvisionedThroughputExceededException'); + $mockRequestPTE = $this->getMockBuilder('Guzzle\Http\Message\EntityEnclosingRequestInterface') + ->disableOriginalConstructor() + ->getMock(); + $mockRequestPTE->expects($this->any()) + ->method('getBody') + ->will($this->returnValue( + '{"RequestItems":{"foo":[{"PutRequest":{}},{"PutRequest":{}}]}}' + )); + $throughputExceededException->setRequest($mockRequestPTE); + $exceptionCollectionThroughput = new ExceptionCollection(); + $exceptionCollectionThroughput->add($throughputExceededException); + + return array( + array( + array('UnprocessedItems' => array()), + null, + 'all-items-transferred' + ), + array( + array('UnprocessedItems' => array('foo' => array(array('foo')))), + null, + 'some-unprocessed-items' + ), + array( + array('UnprocessedItems' => array()), + $this->throwException($exceptionCollection), + 'all-items-transferred' + ), + array( + array('UnprocessedItems' => array()), + $this->throwException($exceptionCollectionWithDummy), + 'exceptions-thrown' + ), + array( + array('UnprocessedItems' => array()), + $this->throwException($exceptionCollectionWithDummy), + 'exceptions-thrown' + ), + array( + array('UnprocessedItems' => array()), + $this->throwException($exceptionCollectionThroughput), + 'some-unprocessed-items' + ), + ); + } + + /** + * @dataProvider getTransferBatchesData + */ + public function testTransfersBatches($commandResult, $executeResult, $expectedMessage) + { + // Prep mock DeleteRequests + $requests = array( + $this->getMockBuilder('Aws\DynamoDb\Model\BatchRequest\DeleteRequest') + ->disableOriginalConstructor() + ->getMock() + ); + $requests[0]->expects($this->any()) + ->method('getTableName') + ->will($this->returnValue('foo')); + $requests[0]->expects($this->any()) + ->method('toArray') + ->will($this->returnValue(array('foo'))); + + // Prep the mock command execution and results + $command = $this->getMock('Aws\Common\Command\JsonCommand', array(), array(array())); + $command->expects($this->any()) + ->method('set') + ->will($this->returnValue($command)); + $command->expects($this->any()) + ->method('isExecuted') + ->will($this->returnValue(true)); + $command->expects($this->any()) + ->method('getResult') + ->will($this->returnValue($commandResult)); + + // Add the mocked command into the mock client + $client = $this->getMockedClient(); + $client->expects($this->any()) + ->method('getCommand') + ->will($this->returnValue($command)); + $client->expects($this->any()) + ->method('execute') + ->will($executeResult ?: $this->returnValue(array($command))); + + // Do transfer and decide the message + try { + $batch = new WriteRequestBatchTransfer($client); + $batch->transfer($requests); + $actualMessage = 'all-items-transferred'; + } catch (UnprocessedWriteRequestsException $e) { + $actualMessage = 'some-unprocessed-items'; + } catch (ExceptionCollection $e) { + $actualMessage = 'exceptions-thrown'; + } + + $this->assertEquals($expectedMessage, $actualMessage); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Model/Foo.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Model/Foo.php new file mode 100644 index 0000000..55e97e4 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Model/Foo.php @@ -0,0 +1,25 @@ + array('S' => 'bar'), + 'baz' => array('SS' => array('yo', 'to')) + )); + } + + /** + * @covers Aws\DynamoDb\Model\Item::__construct + * @covers Aws\DynamoDb\Model\Item::replace + * @covers Aws\DynamoDb\Model\Item::add + * @covers Aws\DynamoDb\Model\Item::toArray + */ + public function testConstructorInitializesAttributes() + { + $item = $this->getItem(); + + $this->assertEquals(array( + 'foo' => array( + 'S' => 'bar' + ), + 'baz' => array( + 'SS' => array('yo', 'to') + ) + ), $item->toArray()); + } + + /** + * @covers Aws\DynamoDb\Model\Item::fromArray + */ + public function testCanCreateFromArray() + { + $item = Item::fromArray(array( + 'foo' => 'bar', + 'baz' => array(1, 2, 3), + 'list' => array('foo', 'bar'), + 'test' => 2 + )); + + $this->assertEquals('S', $item->get('foo')->getType()); + $this->assertEquals('bar', $item['foo']); + + $this->assertEquals('NS', $item->get('baz')->getType()); + $this->assertEquals(array(1, 2, 3), $item['baz']->getValue()); + + $this->assertEquals('SS', $item->get('list')->getType()); + $this->assertEquals(array('foo', 'bar'), $item['list']->getValue()); + + $this->assertEquals('N', $item->get('test')->getType()); + $this->assertEquals(2, $item['test']->getValue()); + } + + /** + * @covers Aws\DynamoDb\Model\Item::count + * @covers Aws\DynamoDb\Model\Item::getIterator + * @covers Aws\DynamoDb\Model\Item::offsetExists + * @covers Aws\DynamoDb\Model\Item::offsetSet + * @covers Aws\DynamoDb\Model\Item::offsetUnset + * @covers Aws\DynamoDb\Model\Item::offsetGet + */ + public function testItemCanBeUsedAsAnArray() + { + $item = $this->getItem(); + $this->assertEquals(2, count($item)); + $this->assertEquals(2, count($item->getIterator())); + $this->assertEquals('bar', $item['foo']); + $this->assertEquals(array('yo', 'to'), $item['baz']->getValue()); + $this->assertFalse($item->offsetExists('dingo')); + + $item->offsetSet('test', 'Cool'); + $this->assertEquals('Cool', $item['test']); + + $item->offsetUnset('foo'); + $this->assertNull($item['foo']); + } + + /** + * @covers Aws\DynamoDb\Model\Item::getTableName + * @covers Aws\DynamoDb\Model\Item::setTableName + */ + public function testItemOwnsTable() + { + $item = $this->getItem(); + $this->assertNull($item->getTableName()); + $this->assertSame($item, $item->setTableName('foo')); + $this->assertEquals('foo', $item->getTableName()); + } + + /** + * @covers Aws\DynamoDb\Model\Item::get + * @covers Aws\DynamoDb\Model\Item::has + * @covers Aws\DynamoDb\Model\Item::add + * @covers Aws\DynamoDb\Model\Item::all + * @covers Aws\DynamoDb\Model\Item::remove + * @covers Aws\DynamoDb\Model\Item::keys + */ + public function testCanAccessAttributes() + { + $item = $this->getItem(); + $this->assertEquals(array('foo', 'baz'), $item->keys()); + + $this->assertInstanceOf('Aws\\DynamoDb\\Model\\Attribute', $item->get('foo')); + $this->assertTrue($item->has('foo')); + $this->assertFalse($item->has('fooooooo')); + $this->assertNull($item->get('fooooo')); + + $all = $item->all(); + foreach ($all as $k => $v) { + $this->assertInternalType('string', $k); + $this->assertInstanceOf('Aws\\DynamoDb\\Model\\Attribute', $v); + } + + $this->assertSame($item, $item->remove('foo')); + $this->assertFalse($item->has('foo')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Session/AbstractSessionTestCase.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Session/AbstractSessionTestCase.php new file mode 100644 index 0000000..54c6be6 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Session/AbstractSessionTestCase.php @@ -0,0 +1,72 @@ +getMockBuilder('Aws\DynamoDb\DynamoDbClient') + ->disableOriginalConstructor() + ->getMock(); + + $description = $this->getMockBuilder('Guzzle\Service\Description\ServiceDescription') + ->disableOriginalConstructor() + ->getMock(); + + $description->expects($this->any()) + ->method('getApiVersion') + ->will($this->returnValue('2012-08-10')); + + $client->expects($this->any()) + ->method('getDescription') + ->will($this->returnValue($description)); + + return $client; + } + + /** + * @return \Aws\DynamoDb\Session\SessionHandlerConfig + */ + public function getMockedConfig() + { + $config = $this->getMockBuilder('Aws\DynamoDb\Session\SessionHandlerConfig') + ->disableOriginalConstructor() + ->getMock(); + + return $config; + } + + /** + * @return \Aws\Common\Command\JsonCommand + */ + public function getMockedCommand(DynamoDbClient $client) + { + $command = $this->getMock('Aws\Common\Command\JsonCommand'); + $client->expects($this->any()) + ->method('getCommand') + ->will($this->returnValue($command)); + + return $command; + } + +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Session/Integration/IntegrationTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Session/Integration/IntegrationTest.php new file mode 100644 index 0000000..c15363c --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Session/Integration/IntegrationTest.php @@ -0,0 +1,295 @@ +table = self::getResourcePrefix() . '-php-sessions-test'; + $this->hashKey = 'id'; + $this->client = self::getServiceBuilder()->get('dynamodb'); + } + + /** + * Ensures that a DynamoDB table for sessions can be created + */ + public function testCreatesTable() + { + $sh = SessionHandler::factory(array( + 'dynamodb_client' => $this->client, + 'table_name' => $this->table, + )); + + self::log("Creating sessions table {$this->table}"); + $sh->createSessionsTable(25, 25); + + self::log("Ensuring the table {$this->table} was created"); + $result = $this->client->describeTable(array('TableName' => $this->table)); + $this->assertEquals($this->table, $result['Table']['TableName']); + } + + /** + * Ensures that session storage is working properly + */ + public function testGeneralSessionStorage() + { + session_id('example'); + $sh = SessionHandler::factory(array( + 'dynamodb_client' => $this->client, + 'table_name' => $this->table, + 'hash_key' => $this->hashKey, + )); + + self::log('Start with an empty session, add data, and commit'); + $this->simulateSessionStart($sh); + $this->assertEquals(array(), $_SESSION, '[1] The session was not empty.'); + $_SESSION['foo'] = 'bar'; + $this->simulateSessionCommit($sh); + $this->assertEquals(array('foo' => 'bar'), $_SESSION, '[2] The data was not stored in $_SESSION.'); + $_SESSION = array(); + + self::log('Check if session data made it into DynamoDB'); + $result = $this->client->getCommand('GetItem', array( + 'TableName' => $this->table, + 'Key' => array( + $this->hashKey => array( + 'S' => 'test_example' + ) + ) + ))->execute(); + $data = unserialize($result['Item']['data']['S']); + $this->assertArrayHasKey('foo', $data, '[3] The session data was not saved in DynamoDB.'); + + self::log('Check if the data was preserved, then destroy the session'); + $this->simulateSessionStart($sh); + $this->assertEquals(array('foo' => 'bar'), $_SESSION, '[4] The session data was not retrieved.'); + $this->simulateSessionDestroy($sh); + + self::log('Check if session data was deleted in DynamoDB'); + try + { + $result = $this->client->getCommand('GetItem', array( + 'TableName' => $this->table, + 'Key' => array( + $this->hashKey => array( + 'S' => 'test_example' + ) + ) + ))->execute(); + $result = isset($result['Item']); + } catch (\Exception $e) { + $result = false; + } + $this->assertFalse($result, '[5] The session data was not deleted from DynamoDB.'); + + self::log('Make sure the data does not return after destroying'); + $this->simulateSessionStart($sh); + $this->assertEquals(array(), $_SESSION, '[6] The session was not properly destroyed.'); + + // Clean up + $this->simulateSessionDestroy($sh); + } + + /** + * Ensures that pessimistic locking is really happening correctly + */ + public function testLockingStrategyDifferences() + { + session_id('example'); + + self::log('Create 4 instances of the session handler'); + $shNull1 = SessionHandler::factory(array( + 'dynamodb_client' => $this->client, + 'table_name' => $this->table + )); + + $shNull2 = SessionHandler::factory(array( + 'dynamodb_client' => $this->client, + 'table_name' => $this->table + )); + + $shPessimistic1 = SessionHandler::factory(array( + 'dynamodb_client' => $this->client, + 'table_name' => $this->table, + 'locking_strategy' => 'pessimistic', + 'max_lock_wait_time' => 6, + )); + + $shPessimistic2 = SessionHandler::factory(array( + 'dynamodb_client' => $this->client, + 'table_name' => $this->table, + 'locking_strategy' => 'pessimistic', + 'max_lock_wait_time' => 6, + )); + + self::log('Store some session data for reading'); + $this->simulateSessionStart($shNull1); + $_SESSION['foo'] = 'bar'; + $this->simulateSessionCommit($shNull1); + + self::log('Non-locking, simultaneous reads should happen fast'); + $shNullTime = microtime(true); + $this->simulateSessionStart($shNull1); + $this->simulateSessionStart($shNull2); + $this->simulateSessionCommit($shNull1); + $shNullTime = microtime(true) - $shNullTime; + $this->assertLessThan(3, $shNullTime, 'Null locking strategy took longer than expected.'); + + self::log('Locking, simultaneous reads should block and timeout'); + $shPessimisticTime = microtime(true); + $this->simulateSessionStart($shPessimistic1); + $this->simulateSessionStart($shPessimistic2); + $this->simulateSessionCommit($shPessimistic1); + $shPessimisticTime = microtime(true) - $shPessimisticTime; + $this->assertGreaterThan(5, $shPessimisticTime, 'Pessimistic locking strategy operated faster than expected. Locking may not be occurring.'); + + // Clean up + $this->simulateSessionStart($shNull1); + $this->simulateSessionDestroy($shNull1); + } + + /** + * Ensures that garbage collection functionality is working correctly + */ + public function testGarbageCollection() + { + $currentCount = iterator_count($this->client->getIterator('Scan', array( + 'TableName' => $this->table + ))); + + self::log('Put 10 expired items into the sessions table'); + $writeBatch = WriteRequestBatch::factory($this->client); + for ($i = 1; $i <= 10; $i++) { + $writeBatch->add(new PutRequest(Item::fromArray(array( + 'id' => "example_{$i}", + 'expires' => time() - 5 * Time::SECONDS + )), $this->table)); + } + $writeBatch->flush(); + + self::log('Assert that all 10 items made it into the sessions table'); + $result = $this->client->getCommand('Scan', array( + 'TableName' => $this->table + ))->execute(); + $this->assertEquals(10 + $currentCount, $result['Count'], 'Not all of the items were inserted.'); + + self::log('Create a session handler to use with a lower batch size'); + $sh = SessionHandler::factory(array( + 'dynamodb_client' => $this->client, + 'table_name' => $this->table, + 'gc_batch_size' => 3, // Smaller batches to test batching works + 'gc_operation_delay' => 3, // Sleep 3 seconds in between operations + )); + + self::log('Run the garbage collection'); + $gcTime = microtime(true); + $sh->garbageCollect(); + $gcTime = microtime(true) - $gcTime; + $this->assertGreaterThan(12, $gcTime, 'The entire garbage collection process should take ~15+ seconds.'); + + self::log('Assert that all 10 items were deleted from the sessions table'); + $result = $this->client->getCommand('Scan', array( + 'TableName' => $this->table + ))->execute(); + $this->assertEquals(0, $result['Count'], 'Not all of the items were removed.'); + } + + protected function simulateSessionStart(SessionHandler $handler) + { + $handler->open('dummy', 'test'); + $data = $handler->read('example'); + $_SESSION = unserialize($data) ?: array(); // Instead of session_decode + } + + protected function simulateSessionCommit(SessionHandler $handler) + { + $data = serialize($_SESSION); // Instead of session_encode + $handler->write('example', $data); + $handler->close(); + } + + protected function simulateSessionDestroy(SessionHandler $handler) + { + $handler->destroy('example'); + $handler->close(); + } + + protected static function deleteSessionsTable() + { + $table = self::getResourcePrefix() . '-php-sessions-test'; + $client = self::getServiceBuilder()->get('dynamodb'); + + self::log("# Attempting to delete {$table}"); + + try { + $client->describeTable(array('TableName' => $table)); + // Wait until the table is active + self::log('Table exists. Waiting until the status is ACTIVE'); + $client->waitUntil('table_exists', array('TableName' => $table)); + // Delete the table to clear out its contents + self::log('Deleting the table'); + $client->deleteTable(array('TableName' => $table)); + $client->waitUntil('table_not_exists', array('TableName' => $table)); + } catch (ResourceNotFoundException $e) { + // The table does not exist so we are good + } + + self::log("{$table} has been deleted."); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Session/LockingStrategy/AbstractLockingStrategyTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Session/LockingStrategy/AbstractLockingStrategyTest.php new file mode 100644 index 0000000..ae10891 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Session/LockingStrategy/AbstractLockingStrategyTest.php @@ -0,0 +1,94 @@ +getMockedClient(); + $config = $this->getMockedConfig(); + $command = $this->getMockedCommand($client); + + if ($commandResult instanceof \Exception) { + $will = $this->throwException($commandResult); + } else { + $will = $this->returnValue($commandResult); + } + $command->expects($this->any()) + ->method('execute') + ->will($will); + + // Test the doRead method + $strategy = $this->getMockForAbstractClass( + 'Aws\DynamoDb\Session\LockingStrategy\AbstractLockingStrategy', + array($client, $config) + ); + $item = $strategy->doDestroy('test'); + $this->assertSame($expectedItem, $item); + } + + /** + * @covers Aws\DynamoDb\Session\LockingStrategy\AbstractLockingStrategy::doWrite + * @dataProvider getTestCases + */ + public function testDoWriteWorksCorrectly($commandResult, $expectedItem) + { + // Prepare mocks + $client = $this->getMockedClient(); + $config = $this->getMockedConfig(); + $command = $this->getMockedCommand($client); + + if ($commandResult instanceof \Exception) { + $will = $this->throwException($commandResult); + } else { + $will = $this->returnValue($commandResult); + } + $command->expects($this->any()) + ->method('execute') + ->will($will); + + // Test the doRead method + $strategy = $this->getMockForAbstractClass( + 'Aws\DynamoDb\Session\LockingStrategy\AbstractLockingStrategy', + array($client, $config) + ); + $strategy->expects($this->any()) + ->method('getExtraAttributes') + ->will($this->returnValue(array())); + + $item = $strategy->doWrite('test', 'ANYTHING', true); + $this->assertSame($expectedItem, $item); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Session/LockingStrategy/LockingStrategyFactoryTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Session/LockingStrategy/LockingStrategyFactoryTest.php new file mode 100644 index 0000000..96a0e2d --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Session/LockingStrategy/LockingStrategyFactoryTest.php @@ -0,0 +1,62 @@ +getMockedConfig(); + $client = $this->getMockedClient(); + $config->expects($this->any()) + ->method('get') + ->will($this->returnCallback(function ($key) use ($client) { + return ($key === 'dynamodb_client') ? $client : null; + })); + + $factory = new LockingStrategyFactory('Aws\DynamoDb\Session\LockingStrategy'); + + try { + $strategy = $factory->factory($strategyName, $config); + } catch (\Aws\Common\Exception\InvalidArgumentException $e) { + $strategy = $e; + } + + $this->assertInstanceOf($class, $strategy); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Session/LockingStrategy/NullLockingStrategyTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Session/LockingStrategy/NullLockingStrategyTest.php new file mode 100644 index 0000000..efaf81b --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Session/LockingStrategy/NullLockingStrategyTest.php @@ -0,0 +1,73 @@ + array( + 'foo' => array( + 'S' => 'bar' + ) + ), + ), + array( + 'foo' => 'bar' + ) + ), + // Test case 2 + array( + new \Aws\DynamoDb\Exception\DynamoDbException, + array() + ) + ); + } + + /** + * @covers Aws\DynamoDb\Session\LockingStrategy\NullLockingStrategy::doRead + * @dataProvider getDoReadTestCases + */ + public function testDoReadWorksCorrectly($commandResult, $expectedItem) + { + // Prepare mocks + $client = $this->getMockedClient(); + $config = $this->getMockedConfig(); + $command = $this->getMockedCommand($client); + + if ($commandResult instanceof \Exception) { + $will = $this->throwException($commandResult); + } else { + $will = $this->returnValue($commandResult); + } + $command->expects($this->any()) + ->method('execute') + ->will($will); + + // Test the doRead method + $strategy = new NullLockingStrategy($client, $config); + $item = $strategy->doRead('test'); + $this->assertSame($expectedItem, $item); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Session/LockingStrategy/PessimisticLockingStrategyTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Session/LockingStrategy/PessimisticLockingStrategyTest.php new file mode 100644 index 0000000..5fdc503 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Session/LockingStrategy/PessimisticLockingStrategyTest.php @@ -0,0 +1,84 @@ +getMockedClient(); + $config = $this->getMockedConfig(); + $command = $this->getMockedCommand($client); + + $config->expects($this->any()) + ->method('get') + ->will($this->returnCallback(function ($key) { + return ($key === 'max_lock_wait_time') ? 10 : null; + })); + + $command->expects($this->any()) + ->method('execute') + ->will($this->returnCallback(function () { + static $calls = 0; + + // Simulate lock acquisition failures + if ($calls++ < 5) { + throw new \Aws\DynamoDb\Exception\ConditionalCheckFailedException; + } else { + return array( + 'Attributes' => array( + 'foo' => array( + 'S' => 'bar' + ) + ), + ); + } + })); + + // Test the doRead method + $strategy = new PessimisticLockingStrategy($client, $config); + $item = $strategy->doRead('test'); + $this->assertSame(array('foo' => 'bar'), $item); + } + + /** + * @covers Aws\DynamoDb\Session\LockingStrategy\PessimisticLockingStrategy::doRead + * @expectedException Aws\DynamoDb\Exception/AccessDeniedException + */ + public function testReadFailsForOther400Errors() + { + // Prepare mocks + $client = $this->getMockedClient(); + $config = $this->getMockedConfig(); + $command = $this->getMockedCommand($client); + $command->expects($this->any()) + ->method('execute') + ->will($this->throwException(new \Aws\DynamoDb\Exception\AccessDeniedException())); + + // Test the doRead method + $strategy = new PessimisticLockingStrategy($client, $config); + $strategy->doRead('test'); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Session/SessionHandlerConfigTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Session/SessionHandlerConfigTest.php new file mode 100644 index 0000000..a19b5b9 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Session/SessionHandlerConfigTest.php @@ -0,0 +1,69 @@ + $this->getMockedClient() + ), + 'Aws\DynamoDb\Session\SessionHandlerConfig' + ), + array( + array(), + 'Aws\Common\Exception\InvalidArgumentException' + ) + ); + } + + /** + * @dataProvider getConstructorTestCases + */ + public function testConstructorProperlyCreatesConfig(array $data, $expectedClass) + { + try { + $config = new SessionHandlerConfig($data); + } catch (\Aws\Common\Exception\InvalidArgumentException $e) { + $config = $e; + } + + $this->assertInstanceOf($expectedClass, $config); + } + + public function testAddDefaultsPerformsMergeProperly() + { + $config = new SessionHandlerConfig(array( + 'dynamodb_client' => $this->getMockedClient() + )); + + $this->assertNull($config->get('foo_bar')); + $config->addDefaults(array('foo_bar' => 'baz')); + $this->assertEquals('baz', $config->get('foo_bar')); + $config->addDefaults(array('foo_bar' => 'CHANGED')); + $this->assertEquals('baz', $config->get('foo_bar')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Session/SessionHandlerTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Session/SessionHandlerTest.php new file mode 100644 index 0000000..d152261 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Session/SessionHandlerTest.php @@ -0,0 +1,142 @@ +getMockedClient(); + $strategy = $this->getMock('Aws\DynamoDb\Session\LockingStrategy\LockingStrategyInterface'); + $this->handler = SessionHandler::factory(array( + 'dynamodb_client' => $client, + 'locking_strategy' => $strategy, + )); + + $command = $this->getMockedCommand($client); + $command->expects($this->any()) + ->method('execute') + ->will($this->returnValue(array('foo' => 'bar'))); + + $client->expects($this->any()) + ->method('getIterator') + ->will($this->returnValue(array())); + + $strategy->expects($this->any()) + ->method('doRead') + ->will($this->returnValue(array( + 'expires' => time() - 5, + 'data' => 'ANYTHING' + ))); + $strategy->expects($this->any()) + ->method('doWrite') + ->will($this->returnValue(true)); + $strategy->expects($this->any()) + ->method('doDestroy') + ->will($this->returnValue(true)); + } + + public function testFactoryCreatesInstanceCorrectly() + { + $client = $this->getMockedClient(); + $strategy = $this->getMock('Aws\DynamoDb\Session\LockingStrategy\LockingStrategyInterface'); + + $sh1 = SessionHandler::factory(array( + 'dynamodb_client' => $client + )); + $this->assertInstanceOf('Aws\DynamoDb\Session\SessionHandler', $sh1); + + $sh2 = SessionHandler::factory(array( + 'dynamodb_client' => $client, + 'locking_strategy' => $strategy + )); + $this->assertInstanceOf('Aws\DynamoDb\Session\SessionHandler', $sh2); + } + + public function testRegisterSetsSessionSaveHandlerAndIniSettings() + { + ini_set('session.gc_probability', '0'); + + $handler = SessionHandler::factory(array( + 'dynamodb_client' => $this->getMockedClient(), + 'automatic_gc' => true + )); + + $this->assertTrue($handler->register()); + $this->assertEquals('1', ini_get('session.gc_probability')); + + ini_set('session.gc_probability', '0'); + } + + public function testCreateSessionsTable() + { + // For code coverage's sake. See integration test. + $result = $this->handler->createSessionsTable(10, 5); + $this->assertEquals(array('foo' => 'bar'), $result); + } + + public function testSessionOpenAndCloseAreSuccessful() + { + session_id('test'); + $this->assertFalse($this->handler->isSessionOpen()); + $this->assertTrue($this->handler->open('test', 'example')); + $this->assertTrue($this->handler->isSessionOpen()); + $this->assertTrue($this->handler->close()); + $this->assertFalse($this->handler->isSessionOpen()); + } + + public function testSessionReadAndDeleteExpiredItem() + { + $this->assertTrue($this->handler->open('test', 'example')); + $this->assertSame('', $this->handler->read('test')); + } + + public function testSessionWriteData() + { + $this->assertTrue($this->handler->open('test', 'example')); + $this->assertTrue($this->handler->write('test', 'ANYTHING')); + } + + public function testSessionGarbageCollection() + { + $this->assertTrue($this->handler->gc('ANYTHING')); + } + + public function testSessionGarbageCollectionReturnsFalseOnException() + { + $handler = $this->getMockBuilder('Aws\DynamoDb\Session\SessionHandler') + ->disableOriginalConstructor() + ->setMethods(array('garbageCollect')) + ->getMock(); + $handler->expects($this->any()) + ->method('garbageCollect') + ->will($this->throwException(new \Exception)); + + $this->assertFalse($handler->gc('ANYTHING')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Waiter/AbstractWaiterTestCase.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Waiter/AbstractWaiterTestCase.php new file mode 100644 index 0000000..5ae69b7 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Waiter/AbstractWaiterTestCase.php @@ -0,0 +1,34 @@ +getServiceBuilder()->get('dynamodb', true); + $client->getCredentials() + ->setSecurityToken('foo') + ->setExpiration(time() + 1000); + + return $client; + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Waiter/TableExistsTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Waiter/TableExistsTest.php new file mode 100644 index 0000000..4ceb11c --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Waiter/TableExistsTest.php @@ -0,0 +1,58 @@ +getClient(); + $this->setMockResponse($client, 'dynamodb/describe_table'); + $client->waitUntil('table_exists', array('TableName' => 'foo')); + } + + public function testReturnsTrueIfTableExistsAndHasStatusMatching() + { + $client = $this->getClient(); + $this->setMockResponse($client, 'dynamodb/describe_table'); + $client->waitUntil('table_exists', array('TableName' => 'foo')); + } + + public function testBuffersResourceNotFoundExceptions() + { + $client = $this->getClient(); + $this->setMockResponse($client, array('dynamodb/describe_table_not_found', 'dynamodb/describe_table')); + $client->waitUntil('table_exists', array('TableName' => 'foobazbar', 'waiter.interval' => 0)); + $this->assertEquals(2, count($this->getMockedRequests())); + } + + /** + * @expectedException \Aws\Common\Exception\RuntimeException + */ + public function testDoesNotBufferOtherExceptions() + { + $client = $this->getClient(); + $mock = new MockPlugin(array( + new Response(404) + )); + $client->getEventDispatcher()->addSubscriber($mock); + $client->waitUntil('table_exists', array('TableName' => 'foo')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Waiter/TableNotExistsTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Waiter/TableNotExistsTest.php new file mode 100644 index 0000000..8767cd6 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/DynamoDb/Waiter/TableNotExistsTest.php @@ -0,0 +1,43 @@ +getClient(); + $this->setMockResponse($client, array('dynamodb/describe_table', 'dynamodb/describe_table_not_found')); + $client->waitUntil('table_not_exists', array('TableName' => 'foo', 'waiter.interval' => 0)); + } + + /** + * @expectedException \Aws\Common\Exception\RuntimeException + */ + public function testDoesNotBufferExceptions() + { + $client = $this->getClient(); + $mock = new MockPlugin(array( + new Response(404) + )); + $client->getEventDispatcher()->addSubscriber($mock); + $client->waitUntil('table_not_exists', array('TableName' => 'foo')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Ec2/CopySnapshotListenerTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Ec2/CopySnapshotListenerTest.php new file mode 100644 index 0000000..79832f9 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Ec2/CopySnapshotListenerTest.php @@ -0,0 +1,33 @@ +getServiceBuilder()->get('ec2'); + $client->setRegion('us-east-1'); + $command = $client->getCommand('CopySnapshot', array( + 'SourceRegion' => 'eu-west-1', + 'SourceSnapshotId' => 'foo' + )); + $request = $command->prepare(); + $r = (string) $request; + $this->assertContains('DestinationRegion=us-east-1', $r); + $this->assertContains('SourceRegion%3Deu-west-1', $r); + $this->assertContains('PresignedUrl=https%3A%2F%2Fec2.eu-west-1.amazonaws.com', $r); + } + + public function testIgnoresOtherOperations() + { + $client = $this->getServiceBuilder()->get('ec2'); + $command = $client->getCommand('DescribeInstances'); + $request = $command->prepare(); + $r = (string) $request; + $this->assertNotContains('PresignedUrl=', $r); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Ec2/Ec2ClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Ec2/Ec2ClientTest.php new file mode 100644 index 0000000..815a4a8 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Ec2/Ec2ClientTest.php @@ -0,0 +1,62 @@ + 'foo', + 'secret' => 'bar', + 'region' => 'ap-southeast-1' + )); + + $this->assertEquals('https://ec2.ap-southeast-1.amazonaws.com', $client->getBaseUrl()); + $this->assertInstanceOf('Aws\Common\Signature\SignatureV2', $client->getSignature()); + $this->assertInstanceOf('Aws\Common\Credentials\Credentials', $client->getCredentials()); + } + + public function testFactoryUsesSigV4InCnRegions() + { + $description = array ( + 'apiVersion' => '2013-10-15', + 'endpointPrefix' => 'ec2', + 'serviceType' => 'query', + 'signatureVersion' => 'v2', + 'namespace' => 'Ec2', + 'regions' => array( + 'cn-north-1' => array('http' => true, 'https' => true, 'hostname' => 'foo.aws.com') + ) + ); + + $client = Ec2Client::factory(array( + 'key' => 'foo', + 'secret' => 'bar', + 'region' => 'cn-north-1', + ClientOptions::SERVICE_DESCRIPTION => $description + )); + + $this->assertInstanceOf('Aws\Common\Signature\SignatureV4', $client->getSignature()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Ec2/Integration/BasicOperationsTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Ec2/Integration/BasicOperationsTest.php new file mode 100644 index 0000000..2281be8 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Ec2/Integration/BasicOperationsTest.php @@ -0,0 +1,216 @@ +client = self::getServiceBuilder()->get('ec2', true); + } + + public function testBasicDescribeIteratorWithFilters() + { + self::log("\n[#1] Test a basic iterator and make sure deep structures like filters are marshaled correctly."); + + self::log('Set the region to US-WEST-2.'); + $this->client->setRegion(Region::US_WEST_2); + + self::log('Call DescribeImages via the iterator with some filters and a limit of 5.'); + $images = $this->client->getIterator('DescribeImages', array( + 'Owners' => array('amazon'), + 'Filters' => array( + array('Name' => 'architecture', 'Values' => array('x86_64')), + array('Name' => 'image-type', 'Values' => array('machine')), + ) + ), array( + 'limit' => 5 + )); + + self::log('Verify that the iterator returns only 5.'); + $this->assertEquals(5, iterator_count($images)); + + self::log('Verify that the AMI IDs are in the right place and that items actually match the filters.'); + foreach ($images as $ami) { + $this->assertEquals('x86_64', $ami['Architecture']); + $this->assertRegExp('/^ami\-[a-f0-9]{8}/', $ami['ImageId']); + } + } + + public function testBasicInstanceOperations() + { + self::log("\n[#2] Test basic run and terminate operations of instances, including waiting for state changes."); + + self::log('Launch two instances.'); + $result = $this->client->getCommand('RunInstances', array( + 'ImageId' => self::TEST_AMI, + 'MinCount' => 2, + 'MaxCount' => 2, + 'InstanceType' => InstanceType::T1_MICRO, + ))->getResult(); + + self::log('Get the IDs of those two instances.'); + $instanceIds = array(); + foreach ($result['Instances'] as $instance) { + $this->assertRegExp('/^i\-[a-f0-9]{8}/', $instance['InstanceId']); + $instanceIds[] = $instance['InstanceId']; + } + $this->assertCount(2, $instanceIds); + + self::log('Wait until they are running.'); + $this->client->waitUntilInstanceRunning(array('InstanceIds' => $instanceIds)); + + self::log('Terminate the instances and verify that they are shutting-down.'); + $result = $this->client->getCommand('TerminateInstances', array( + 'InstanceIds' => $instanceIds, + ))->getResult(); + $this->assertEquals(InstanceStateName::SHUTTING_DOWN, $result->getPath('TerminatingInstances/0/CurrentState/Name')); + $this->assertEquals(InstanceStateName::SHUTTING_DOWN, $result->getPath('TerminatingInstances/1/CurrentState/Name')); + + self::log('Wait until they are terminated.'); + $this->client->waitUntilInstanceTerminated(array('InstanceIds' => $instanceIds)); + + self::log('Verify that the instances are terminated using the DescribeInstances iterator.'); + $instances = $this->client->getIterator('DescribeInstances', array( + 'InstanceIds' => $instanceIds, + )); + foreach ($instances as $instance) { + $this->assertEquals(InstanceStateName::TERMINATED, $instance['State']['Name']); + } + } + + public function testBasicAddressOperations() + { + self::log("\n[#3] Test basic operations for address."); + + $instanceId = $this->runAnInstance(); + + self::log('Allocate a new Elastic IP address.'); + $result = $this->client->getCommand('AllocateAddress')->getResult(); + $publicIp = $result->get('PublicIp'); + + self::log('Associate the address with the instance.'); + $this->client->getCommand('AssociateAddress', array( + 'PublicIp' => $publicIp, + 'InstanceId' => $instanceId, + ))->execute(); + + self::log('Make sure the address and instance are associated.'); + $result = $this->client->getCommand('DescribeAddresses')->getResult(); + $publicIps = $result->getPath('Addresses/*/PublicIp'); + $instanceIds = $result->getPath('Addresses/*/InstanceId'); + $this->assertContains($publicIp, $publicIps); + $this->assertContains($instanceId, $instanceIds); + + self::log('Disassociate the address with from instance.'); + $this->client->getCommand('DisassociateAddress', array( + 'PublicIp' => $publicIp, + ))->execute(); + + self::log('Release the Elastic IP address.'); + $this->client->getCommand('ReleaseAddress', array( + 'PublicIp' => $publicIp, + ))->execute(); + + $this->terminateAnInstance($instanceId); + } + + public function testModifyingAnInstanceAttribute() + { + self::log("\n[#4] Modify the attributes of an instance."); + + $instanceId = $this->runAnInstance(); + + self::log('Stop the instance.'); + $this->client->getCommand('StopInstances', array( + 'InstanceIds' => array($instanceId), + ))->execute(); + + self::log('Wait until the instance is stopped.'); + $this->client->waitUntilInstanceStopped(array( + 'InstanceIds' => array($instanceId), + )); + + self::log('Change the stopped instance from a micro to a small.'); + $this->client->getCommand('ModifyInstanceAttribute', array( + 'InstanceId' => $instanceId, + 'Attribute' => 'instanceType', + 'Value' => InstanceType::M1_SMALL + ))->execute(); + + self::log('Start the instance back up.'); + $this->client->getCommand('StartInstances', array( + 'InstanceIds' => array($instanceId), + ))->execute(); + + self::log('Wait until the instance is running.'); + $this->client->waitUntilInstanceRunning(array( + 'InstanceIds' => array($instanceId), + )); + + $this->terminateAnInstance($instanceId); + } + + /** + * @return string The ID of a running instance + */ + protected function runAnInstance() + { + self::log('Launch an instance.'); + $result = $this->client->getCommand('RunInstances', array( + 'ImageId' => self::TEST_AMI, + 'MinCount' => 1, + 'MaxCount' => 1, + 'InstanceType' => InstanceType::T1_MICRO, + ))->getResult(); + $instanceId = current($result->getPath('Instances/*/InstanceId')); + + self::log('Wait until the instance is running.'); + $this->client->waitUntilInstanceRunning(array('InstanceIds' => array($instanceId))); + + return $instanceId; + } + + /** + * @param string $instanceId The ID of a running instance to terminate + */ + protected function terminateAnInstance($instanceId) + { + self::log('Terminate the instance.'); + $this->client->getCommand('TerminateInstances', array( + 'InstanceIds' => array($instanceId), + ))->execute(); + + self::log('Wait until the instance is terminated.'); + $this->client->waitUntilInstanceTerminated(array('InstanceIds' => array($instanceId))); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Ec2/Integration/IteratorTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Ec2/Integration/IteratorTest.php new file mode 100644 index 0000000..bc352ab --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Ec2/Integration/IteratorTest.php @@ -0,0 +1,113 @@ +client = self::getServiceBuilder()->get('ec2', true); + } + + public function testBasicDescribeInstanceStatusWithFilters() + { + $statuses = $this->client->getIterator('DescribeInstanceStatus', array( + 'Owners' => array('amazon'), + 'Filters' => array( + array('Name' => 'system-status.reachability', 'Values' => array('passed')), + array('Name' => 'instance-status.status', 'Values' => array('ok')), + ) + ), array( + 'limit' => 5 + )); + + self::log('Verify that the iterator returns less than or equal to 5.'); + $this->assertLessThanOrEqual(5, iterator_count($statuses)); + + self::log('Verify that the status is in the right place and filters applied.'); + foreach ($statuses as $status) { + $this->assertEquals('passed', $status['InstanceStatus']['Details'][0]['Status']); + } + } + + /** + * This test is not with the other similar tests to ensure that some basic response parsing is correct + */ + public function testDescribeReservedInstancesOfferings() + { + $result = $this->client->getIterator('DescribeReservedInstancesOfferings', null, array('limit' => 25)); + $this->assertLessThanOrEqual(25, iterator_count($result)); + foreach ($result as $offering) { + $this->assertArrayHasKey('ReservedInstancesOfferingId', $offering); + $this->assertArrayHasKey('InstanceType', $offering); + $this->assertInternalType('array', $offering['RecurringCharges']); + $this->assertInternalType('array', $offering['PricingDetails']); + } + } + + public function iteratorProvider() + { + $iterators = array(); + $c = self::getServiceBuilder()->get('ec2', true); + foreach ($c->getDescription()->getOperations() as $o) { + if (strpos($o->getName(), 'Describe') !== false) { + if ($o->hasParam('NextToken')) { + continue; + } + foreach ($o->getParams() as $p) { + if ($p->getType() == 'array' && $p->getItems() && !in_array($o, $iterators, true)) { + $iterators[] = $o; + } + } + } + } + + return array_map(function ($a) { return array($a); }, $iterators); + } + + /** + * @dataProvider iteratorProvider + */ + public function testDescribeIteratorTest(Operation $operation) + { + switch ($operation->getName()) { + case 'DescribeImages': + case 'DescribeReservedInstancesListings': + case 'DescribeLicenses': + self::log('Not running ' . $operation->getName()); + return; + } + + self::log('Testing iterator: ' . $operation->getName()); + $iterator = $this->client->getIterator($operation->getName(), null, array('limit' => 25)); + $this->assertLessThanOrEqual(25, iterator_count($iterator)); + foreach ($iterator as $result) { + $this->assertInternalType('array', $result); + } + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Ec2/Iterator/DescribeInstancesIteratorTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Ec2/Iterator/DescribeInstancesIteratorTest.php new file mode 100644 index 0000000..38ac49a --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Ec2/Iterator/DescribeInstancesIteratorTest.php @@ -0,0 +1,76 @@ +getMock('Guzzle\Service\Command\CommandInterface'); + $iterator = new DescribeInstancesIterator($command); + $model = new Model(array( + 'Reservations' => array( + array( + 'ReservationId' => 'R1', + 'Instances' => array( + array('InstanceId' => 'R1I1'), + array('InstanceId' => 'R1I2'), + ) + ), + array( + 'ReservationId' => 'R2', + 'Instances' => array( + array('InstanceId' => 'R2I1'), + array('InstanceId' => 'R2I2'), + ) + ) + ) + )); + + $class = new \ReflectionObject($iterator); + $method = $class->getMethod('handleResults'); + $method->setAccessible(true); + $items = $method->invoke($iterator, $model); + + // We should get an inverted structure based on how the concrete handles the results + $this->assertSame(array( + array( + 'InstanceId' => 'R1I1', + 'Reservation' => array('ReservationId' => 'R1'), + ), + array( + 'InstanceId' => 'R1I2', + 'Reservation' => array('ReservationId' => 'R1'), + ), + array( + 'InstanceId' => 'R2I1', + 'Reservation' => array('ReservationId' => 'R2'), + ), + array( + 'InstanceId' => 'R2I2', + 'Reservation' => array('ReservationId' => 'R2'), + ), + ), $items); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Ec2/WaiterTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Ec2/WaiterTest.php new file mode 100644 index 0000000..d584f14 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Ec2/WaiterTest.php @@ -0,0 +1,63 @@ +client = self::getServiceBuilder()->get('ec2', true); + } + + public function testIteratesUntilInSpecifiedState() + { + $this->client = $this->getServiceBuilder()->get('ec2', true); + $this->setMockResponse($this->client, array( + 'ec2/describe_instances_no_reservations', + 'ec2/describe_instances_two_instances_different_state', + 'ec2/describe_instances_two_instances_same_state' + )); + $this->client->waitUntil('__InstanceState', array( + 'InstanceIds' => array('i-xxxxxxx1', 'i-xxxxxxx2'), + 'waiter.success.value' => InstanceStateName::RUNNING, + 'waiter.interval' => 0 + )); + $this->assertEquals(3, count($this->getMockedRequests())); + } + + public function testWaitsForSnapshots() + { + $this->setMockResponse($this->client, array( + 'ec2/describe_snapshots_pending', + 'ec2/describe_snapshots_completed', + 'ec2/describe_instances_two_instances_same_state' + )); + $this->client->waitUntil('SnapshotCompleted', array( + 'SnapshotIds' => array('snap-1a2b3c4d'), + 'waiter.interval' => 0 + )); + $this->assertEquals(2, count($this->getMockedRequests())); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/ElastiCache/ElastiCacheClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/ElastiCache/ElastiCacheClientTest.php new file mode 100644 index 0000000..bf18a6e --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/ElastiCache/ElastiCacheClientTest.php @@ -0,0 +1,38 @@ + 'foo', + 'secret' => 'bar', + 'region' => 'us-west-2' + )); + + $this->assertInstanceOf('Aws\Common\Signature\SignatureV4', $client->getSignature()); + $this->assertInstanceOf('Aws\Common\Credentials\Credentials', $client->getCredentials()); + $this->assertEquals('https://elasticache.us-west-2.amazonaws.com', $client->getBaseUrl()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/ElastiCache/Integration/IntegrationTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/ElastiCache/Integration/IntegrationTest.php new file mode 100644 index 0000000..a5b31c2 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/ElastiCache/Integration/IntegrationTest.php @@ -0,0 +1,104 @@ +get('elasticache'); + try { + $client->deleteCacheSecurityGroup(array('CacheSecurityGroupName' => self::SECURITY_GROUP_NAME)); + } catch (\Exception $e) { + // Ignore + } + } + + /** + * @var ElastiCacheClient + */ + protected $client; + + public function setUp() + { + $this->client = $this->getServiceBuilder()->get('elasticache'); + } + + public function testEnsuresListsAreParsedCorrectly() + { + $results = $this->client->getIterator('DescribeEvents'); + foreach ($results as $result) { + $this->assertArrayHasKey('Message', $result); + } + } + + /** + * @expectedException \Aws\ElastiCache\Exception\CacheClusterNotFoundException + */ + public function testParsesErrors() + { + $this->client->deleteCacheCluster(array( + 'CacheClusterId' => 'notarealcachecluster' + )); + } + + public function testCreatesSecurityGroup() + { + self::log('Create a cache security group'); + $result = $this->client->createCacheSecurityGroup(array( + 'CacheSecurityGroupName' => self::SECURITY_GROUP_NAME, + 'Description' => 'PHP Integ Test Cache Security Group', + )); + $this->assertTrue($result->hasKey('OwnerId')); + $this->assertTrue($result->hasKey('EC2SecurityGroups')); + $this->assertTrue($result->hasKey('ResponseMetadata')); + } + + /** + * @depends testCreatesSecurityGroup + */ + public function testListsSecurityGroups() + { + self::log('List cache security groups'); + $found = false; + foreach ($this->client->getIterator('DescribeCacheSecurityGroups') as $group) { + if ($group['CacheSecurityGroupName'] == self::SECURITY_GROUP_NAME) { + $found = true; + break; + } + } + $this->assertTrue($found, 'Did not find cache security group ' . self::SECURITY_GROUP_NAME); + } + + /** + * @depends testListsSecurityGroups + */ + public function testDeletesSecurityGroups() + { + self::log('Delete cache security group'); + $this->client->deleteCacheSecurityGroup(array('CacheSecurityGroupName' => self::SECURITY_GROUP_NAME)); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/ElasticBeanstalk/ElasticBeanstalkClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/ElasticBeanstalk/ElasticBeanstalkClientTest.php new file mode 100644 index 0000000..b7bf9b2 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/ElasticBeanstalk/ElasticBeanstalkClientTest.php @@ -0,0 +1,38 @@ + 'foo', + 'secret' => 'bar', + 'region' => 'us-west-2' + )); + + $this->assertInstanceOf('Aws\Common\Signature\SignatureV4', $client->getSignature()); + $this->assertInstanceOf('Aws\Common\Credentials\Credentials', $client->getCredentials()); + $this->assertEquals('https://elasticbeanstalk.us-west-2.amazonaws.com', $client->getBaseUrl()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/ElasticBeanstalk/Integration/IntegrationTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/ElasticBeanstalk/Integration/IntegrationTest.php new file mode 100644 index 0000000..5a9d915 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/ElasticBeanstalk/Integration/IntegrationTest.php @@ -0,0 +1,75 @@ +client = $this->getServiceBuilder()->get('elasticbeanstalk'); + } + + public function testListsApplications() + { + $command = $this->client->getCommand('DescribeApplications'); + $result = $command->execute(); + $this->assertNotNull($result->getPath('ResponseMetadata/RequestId')); + $this->assertInternalType('array', $result['Applications']); + + // Gather a list of IDs and pass them to testAllowsMemberedListsInInputs + $ids = array(); + + if (count($result['Applications'])) { + foreach ($result['Applications'] as $app) { + // Ensure that versions is an enumerated array and not a hash + $this->assertInternalType('array', $app['Versions']); + $this->assertArrayHasKey(0, $app['Versions']); + $this->assertInternalType('string', $app['Versions'][0]); + $this->assertInternalType('string', $app['ApplicationName']); + $this->assertInternalType('array', $app['ConfigurationTemplates']); + $ids[] = $app['ApplicationName']; + } + } + + return $ids; + } + + /** + * @depends testListsApplications + */ + public function testAllowsMemberedListsInInputs(array $ids = array()) + { + if (!count($ids)) { + $this->markTestSkipped('No applications found on your account'); + return; + } + + $command = $this->client->getCommand('DescribeApplications', array( + 'ApplicationNames' => $ids + )); + $result = $command->execute(); + $this->assertEquals(count($ids), count($result['Applications'])); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/ElasticLoadBalancing/ElasticLoadBalancingClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/ElasticLoadBalancing/ElasticLoadBalancingClientTest.php new file mode 100644 index 0000000..a29dbde --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/ElasticLoadBalancing/ElasticLoadBalancingClientTest.php @@ -0,0 +1,38 @@ + 'foo', + 'secret' => 'bar', + 'region' => 'us-west-2' + )); + + $this->assertInstanceOf('Aws\Common\Signature\SignatureV4', $client->getSignature()); + $this->assertInstanceOf('Aws\Common\Credentials\Credentials', $client->getCredentials()); + $this->assertEquals('https://elasticloadbalancing.us-west-2.amazonaws.com', $client->getBaseUrl()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/ElasticLoadBalancing/Integration/IntegrationTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/ElasticLoadBalancing/Integration/IntegrationTest.php new file mode 100644 index 0000000..c234372 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/ElasticLoadBalancing/Integration/IntegrationTest.php @@ -0,0 +1,98 @@ +client = $this->getServiceBuilder()->get('elasticloadbalancing'); + } + + public function testDescribesLoadBalancers() + { + $command = $this->client->getCommand('DescribeLoadBalancers'); + $result = $command->execute(); + $this->assertNotNull($result->getPath('ResponseMetadata/RequestId')); + $this->assertInternalType('array', $result['LoadBalancerDescriptions']); + + // Gather a list of IDs and pass them to the next test + $ids = array(); + + if (count($result['LoadBalancerDescriptions'])) { + foreach ($result['LoadBalancerDescriptions'] as $i => $app) { + // Ensure that the list is enumerated + $this->assertInternalType('integer', $i); + $this->assertInternalType('array', $app['SecurityGroups']); + $this->assertArrayHasKey(0, $app['AvailabilityZones']); + $this->assertInternalType('string', $app['AvailabilityZones'][0]); + $this->assertInternalType('string', $app['Scheme']); + $this->assertInternalType('array', $app['Policies']); + $ids[] = $app['LoadBalancerName']; + } + } + + return $ids; + } + + /** + * @depends testDescribesLoadBalancers + */ + public function testAllowsMemberedListsInInputs(array $ids = array()) + { + if (!count($ids)) { + $this->markTestSkipped('No load balancers were found on your account'); + return; + } + + $command = $this->client->getCommand('DescribeLoadBalancers', array('LoadBalancerNames' => $ids)); + $result = $command->execute(); + + if ($result['NextMarker']) { + $this->assertGreaterThan(0, count($result['LoadBalancerDescriptions'])); + } else { + $this->assertEquals(count($ids), count($result['LoadBalancerDescriptions'])); + } + } + + public function testDescribesLoadBalancerPolicyTypes() + { + $command = $this->client->getCommand('DescribeLoadBalancerPolicies'); + $result = $command->execute(); + $this->assertNotNull($result->getPath('ResponseMetadata/RequestId')); + $this->assertInternalType('array', $result['PolicyDescriptions']); + + if (count($result['PolicyDescriptions'])) { + foreach ($result['PolicyDescriptions'] as $i => $p) { + // Ensure that the list is enumerated + $this->assertInternalType('integer', $i); + $this->assertInternalType('string', $p['PolicyName']); + $this->assertInternalType('string', $p['PolicyTypeName']); + $this->assertInternalType('array', $p['PolicyAttributeDescriptions']); + $this->assertArrayHasKey(0, $p['PolicyAttributeDescriptions']); + } + } + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/ElasticTranscoder/ElasticTranscoderClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/ElasticTranscoder/ElasticTranscoderClientTest.php new file mode 100644 index 0000000..378e83d --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/ElasticTranscoder/ElasticTranscoderClientTest.php @@ -0,0 +1,38 @@ + 'foo', + 'secret' => 'bar', + 'region' => 'us-east-1' + )); + + $this->assertInstanceOf('Aws\Common\Signature\SignatureV4', $client->getSignature()); + $this->assertInstanceOf('Aws\Common\Credentials\Credentials', $client->getCredentials()); + $this->assertEquals('https://elastictranscoder.us-east-1.amazonaws.com', $client->getBaseUrl()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/ElasticTranscoder/Integration/IntegrationTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/ElasticTranscoder/Integration/IntegrationTest.php new file mode 100644 index 0000000..8fbd429 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/ElasticTranscoder/Integration/IntegrationTest.php @@ -0,0 +1,162 @@ +transcoder = $this->getServiceBuilder()->get('ElasticTranscoder'); + $this->iam = $this->getServiceBuilder()->get('Iam'); + $this->s3 = $this->getServiceBuilder()->get('S3'); + } + + public function testBasicOperations() + { + $inputBucket = 'php-integ-transcoder-test-bucket-input'; + $outputBucket = 'php-integ-transcoder-test-bucket-output'; + $roleName = 'php-integ-transcoder-test-role'; + $policyName = 'php-integ-transcoder-test-policy'; + $pipelineName = 'php-integ-transcoder-test-pipeline'; + + self::log('Create input and output buckets for the Elastic Transcoder pipeline.'); + $commands = array(); + $commands[] = $this->s3->getCommand('CreateBucket', array( + 'Bucket' => $inputBucket, + )); + $commands[] = $this->s3->getCommand('CreateBucket', array( + 'Bucket' => $outputBucket, + )); + $this->s3->execute($commands); + + self::log('Create an IAM Role for the Elastic Transcoder pipeline.'); + $result = $this->iam->getCommand('CreateRole', array( + 'RoleName' => $roleName, + 'AssumeRolePolicyDocument' => self::DUMMY_IAM_POLICY_ASSUME_ROLE, + ))->getResult(); + $roleArn = $result->getPath('Role/Arn'); + + self::log('Put a policy on the IAM Role for the Elastic Transcoder pipeline.'); + $result = $this->iam->getCommand('PutRolePolicy', array( + 'PolicyName' => $policyName, + 'RoleName' => $roleName, + 'PolicyDocument' => self::DUMMY_IAM_POLICY_ALLOW_S3, + ))->getResult(); + + self::log('Use TestRole to validate our pipeline inputs. NOTE: Ours are not valid on purpose.'); + $result = $this->transcoder->getCommand('TestRole', array( + 'InputBucket' => $inputBucket, + 'OutputBucket' => $outputBucket, + 'Role' => $roleArn, + 'Topics' => array(), + ))->getResult(); + $this->assertEquals('false', $result['Success']); + + self::log('Create an Elastic Transcoder pipeline.'); + $result = $this->transcoder->getCommand('CreatePipeline', array( + 'Name' => $pipelineName, + 'InputBucket' => $inputBucket, + 'OutputBucket' => $outputBucket, + 'Role' => $roleArn, + 'Notifications' => array_fill_keys(array('Progressing', 'Completed', 'Warning', 'Error'), ''), + ))->getResult(); + $pipelineId = $result->getPath('Pipeline/Id'); + + self::log('Make sure created Elastic Transcoder pipeline is in the list of pipelines.'); + $result = $this->transcoder->getCommand('ListPipelines')->getResult(); + $pipelineNames = $result->getPath('Pipelines/*/Name'); + $this->assertContains($pipelineName, $pipelineNames); + + self::log('Make sure ListPipelines iterator works.'); + $found = false; + foreach ($this->transcoder->getIterator('ListPipelines') as $pipeline) { + if ($pipeline['Name'] == $pipelineName) { + $found = true; + break; + } + } + if (!$found) { + $this->fail('Did not find the pipeline in the iterator results.'); + } + + self::log('Make sure created Elastic Transcoder pipeline can be read.'); + $result = $this->transcoder->getCommand('ReadPipeline', array( + 'Id' => $pipelineId, + ))->getResult();; + $this->assertEquals($pipelineName, $result->getPath('Pipeline/Name')); + + self::log('Delete the Elastic Transcoder pipeline.'); + $response = $this->transcoder->getCommand('DeletePipeline', array( + 'Id' => $pipelineId, + ))->getResponse(); + $this->assertEquals(202, $response->getStatusCode()); + + self::log('Delete the policy from the IAM Role for the Elastic Transcoder pipeline.'); + $result = $this->iam->getCommand('DeleteRolePolicy', array( + 'PolicyName' => $policyName, + 'RoleName' => $roleName, + ))->getResult(); + + self::log('Delete the IAM Role for the Elastic Transcoder pipeline.'); + $result = $this->iam->getCommand('DeleteRole', array( + 'RoleName' => $roleName, + ))->getResult(); + + self::log('Delete the input and output buckets for the Elastic Transcoder pipeline.'); + $commands = array(); + $commands[] = $this->s3->getCommand('DeleteBucket', array( + 'Bucket' => $inputBucket + )); + $commands[] = $this->s3->getCommand('DeleteBucket', array( + 'Bucket' => $outputBucket + )); + $this->s3->execute($commands); + } + + /** + * @expectedException \Aws\ElasticTranscoder\Exception\ResourceNotFoundException + */ + public function testErrorParsing() + { + $this->transcoder->cancelJob(array('Id' => '1111111111111-abcdef')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Emr/EmrClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Emr/EmrClientTest.php new file mode 100644 index 0000000..5e6786f --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Emr/EmrClientTest.php @@ -0,0 +1,38 @@ + 'foo', + 'secret' => 'bar', + 'region' => 'us-west-2' + )); + + $this->assertInstanceOf('Aws\Common\Signature\SignatureV4', $client->getSignature()); + $this->assertInstanceOf('Aws\Common\Credentials\Credentials', $client->getCredentials()); + $this->assertEquals('https://elasticmapreduce.us-west-2.amazonaws.com', $client->getBaseUrl()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Emr/Integration/IntegrationTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Emr/Integration/IntegrationTest.php new file mode 100644 index 0000000..08cc091 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Emr/Integration/IntegrationTest.php @@ -0,0 +1,74 @@ +client = $this->getServiceBuilder()->get('emr'); + } + + public function testCreateAndDeleteJobFlow() + { + self::log('Create a job flow'); + $jobFlowName = 'php-integ-test-job-flow'; + $result = $this->client->getCommand('RunJobFlow', array( + 'Name' => $jobFlowName, + 'Instances' => array( + 'InstanceCount' => 2, + 'KeepJobFlowAliveWhenNoSteps' => true, + 'MasterInstanceType' => InstanceType::M1_SMALL, + 'SlaveInstanceType' => InstanceType::M1_SMALL, + ), + ))->getResult(); + $jobFlowId = $result->get('JobFlowId'); + + self::log('Describe the job flows and make sure the job flow is there'); + $found = false; + foreach ($this->client->getIterator('DescribeJobFlows', array( + 'CreatedAfter' => '-10 minutes' + )) as $jobFlow) { + if ($jobFlow['Name'] === $jobFlowName) { + $found = true; + break; + } + } + $this->assertTrue($found); + + self::log('Delete the job flow'); + $this->client->getCommand('TerminateJobFlows', array( + 'JobFlowIds' => array($jobFlowId) + ))->execute(); + + self::log('Describe the job flows again and make sure the job flow is no longer there'); + $state = $this->client->getCommand('DescribeJobFlows')->getResult()->getPath('JobFlows/0/ExecutionStatusDetail/State'); + $this->assertContains($state, array(JobFlowExecutionState::SHUTTING_DOWN, JobFlowExecutionState::TERMINATED)); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/GlacierClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/GlacierClientTest.php new file mode 100644 index 0000000..600610e --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/GlacierClientTest.php @@ -0,0 +1,39 @@ + 'foo', + 'secret' => 'bar', + 'region' => 'us-west-2' + )); + + $this->assertInstanceOf('Aws\Common\Signature\SignatureV4', $client->getSignature()); + $this->assertInstanceOf('Aws\Common\Credentials\Credentials', $client->getCredentials()); + $this->assertEquals('https://glacier.us-west-2.amazonaws.com', $client->getBaseUrl()); + $this->assertEquals('-', $client->getCommand('ListVaults')->get('accountId')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/GlacierUploadListenerTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/GlacierUploadListenerTest.php new file mode 100644 index 0000000..479981e --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/GlacierUploadListenerTest.php @@ -0,0 +1,73 @@ +getServiceBuilder()->get('glacier'); + $command = $client->getCommand('UploadArchive', array_merge(array( + 'vaultName' => 'foo', + 'body' => EntityBody::factory(fopen(__FILE__, 'r')) + ), $params)); + $command->prepare(); + + $listener = new GlacierUploadListener(); + $event = new Event(array('command' => $command)); + $listener->onCommandBeforeSend($event); + + return $command; + } + + public function testContentHashGetsAddedToRequestHeaders() + { + // Make sure the subscriber returns its subscriptions + $this->assertInternalType('array', GlacierUploadListener::getSubscribedEvents()); + + // Get an upload archive command, prepare it, and execute the upload listener + $command = $this->prepareUploadArchiveCommand(array( + 'ContentSHA256' => hash('sha256', 'foo') + )); + $request = $command->getRequest(); + + // Content hash should be set, but tree hash should be empty because the content hash was explicit + $this->assertNotEmpty($request->getHeader('x-amz-content-sha256', true)); + $this->assertEmpty($request->getHeader('x-amz-sha256-tree-hash', true)); + } + + public function testBothHashesGetGeneratedAndAddedToRequestHeaders() + { + // Get an upload archive command, prepare it, and execute the upload listener + $request = $this->prepareUploadArchiveCommand()->getRequest(); + + // Both the content and tree hash should be set since we did not provide anything + $this->assertNotEmpty($request->getHeader('x-amz-content-sha256', true)); + $this->assertNotEmpty($request->getHeader('x-amz-sha256-tree-hash', true)); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Integration/IntegrationTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Integration/IntegrationTest.php new file mode 100644 index 0000000..07cbe92 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Integration/IntegrationTest.php @@ -0,0 +1,202 @@ +get('glacier'); + $glacier->createVault(array('vaultName' => self::TEST_VAULT)); + } + + public function setUp() + { + $this->client = $this->getServiceBuilder()->get('glacier'); + } + + public function testCrudVaults() + { + // Create vault names + $vaultPrefix = self::getResourcePrefix() . '-php-glacier-test-'; + $vaults = array(); + for ($i = 1; $i <= 5; $i++) { + $vaults[] = $vaultPrefix . $i; + } + + // Establish vault filter + $getVaultList = function ($vault) use ($vaultPrefix) { + return (strpos($vault['VaultName'], $vaultPrefix) === 0); + }; + + // Create vaults and verify existence + foreach ($vaults as $vault) { + $this->client->createVault(array('vaultName' => $vault)); + $this->client->waitUntil('VaultExists', array('vaultName' => $vault, 'waiter.max_attempts' => 3)); + } + $listVaults = $this->client->getIterator('ListVaults', array('limit' => '5')); + $vaultList = array_filter(iterator_to_array($listVaults), $getVaultList); + $this->assertCount(5, $vaultList); + + // Delete vaults and verify deletion + foreach ($vaults as $vault) { + $this->client->deleteVault(array('vaultName' => $vault)); + $this->client->waitUntil('VaultNotExists', array('vaultName' => $vault)); + } + $listVaults = $this->client->getIterator('ListVaults'); + $vaultList = array_filter(iterator_to_array($listVaults), $getVaultList); + $this->assertCount(0, $vaultList); + } + + public function testUploadAndDeleteArchives() + { + self::log('Create a 6MB+ string of test data to upload.'); + $length = 6 * Size::MB + 425; + $content = EntityBody::factory(str_repeat('x', $length)); + $partSize = 4 * Size::MB; + + self::log('Perform a single upload.'); + $archiveId = $this->client->uploadArchive(array( + 'vaultName' => self::TEST_VAULT, + 'archiveDescription' => 'Foo bar 1', + 'body' => $content, + ))->get('archiveId'); + $this->assertNotEmpty($archiveId); + + self::log('Delete the archive that was just uploaded.'); + $this->client->deleteArchive(array( + 'vaultName' => self::TEST_VAULT, + 'archiveId' => $archiveId + )); + + sleep(3); + + self::log('Initiate a multipart upload with a part size of ' . $partSize . ' bytes.'); + $generator = UploadPartGenerator::factory($content, $partSize); + $this->assertEquals($length, $generator->getArchiveSize()); + $uploadId = $this->client->initiateMultipartUpload(array( + 'vaultName' => self::TEST_VAULT, + 'archiveDescription' => 'Foo bar 2', + 'partSize' => $partSize, + ))->get('uploadId'); + /** @var $part UploadPart */ + foreach ($generator as $part) { + self::log('Upload bytes ' . join('-', $part->getRange()) . '.'); + $this->client->uploadMultipartPart(array( + 'vaultName' => self::TEST_VAULT, + 'uploadId' => $uploadId, + 'range' => $part->getFormattedRange(), + 'checksum' => $part->getChecksum(), + 'ContentSHA256' => $part->getContentHash(), + 'body' => new ReadLimitEntityBody($content, $part->getSize(), $part->getOffset()), + )); + sleep(3); + } + self::log('Complete the multipart upload.'); + $archiveId = $this->client->completeMultipartUpload(array( + 'vaultName' => self::TEST_VAULT, + 'uploadId' => $uploadId, + 'archiveSize' => $generator->getArchiveSize(), + 'checksum' => $generator->getRootChecksum(), + ))->get('archiveId'); + $this->assertNotEmpty($archiveId); + + self::log('Delete the archive that was just uploaded in parts.'); + $this->client->deleteArchive(array( + 'vaultName' => self::TEST_VAULT, + 'archiveId' => $archiveId + )); + } + + public function testMultipartUploadAbstractions() + { + $source = EntityBody::factory(str_repeat('x', 6 * Size::MB + 425)); + + /** @var $transfer Transfer */ + $transfer = UploadBuilder::newInstance() + ->setClient($this->client) + ->setSource($source) + ->setVaultName(self::TEST_VAULT) + ->setPartSize(Size::MB) + ->setArchiveDescription('Foo bar 3') + ->build(); + + $transfer->getEventDispatcher()->addListener($transfer::BEFORE_PART_UPLOAD, function ($event) { + static $count = 0; + if ($count > 2) { + throw new \Exception; + } + $count++; + }); + + try { + $transfer->upload(); + $serializedState = null; + $this->fail('Unexpected code execution - exit point 1'); + } catch (MultipartUploadException $e) { + $serializedState = serialize($e->getState()); + } + + $state = unserialize($serializedState); + $this->assertInstanceOf('Aws\Glacier\Model\MultipartUpload\TransferState', $state); + + /** @var $transfer Transfer */ + $transfer = UploadBuilder::newInstance() + ->setClient($this->client) + ->setSource($source) + ->setVaultName(self::TEST_VAULT) + ->resumeFrom($state) + ->build(); + + try { + $result = $transfer->upload(); + } catch (MultipartUploadException $e) { + $result = null; + $this->fail('Unexpected code execution - exit point 2'); + } + + $this->assertNotEmpty($result['archiveId']); + $this->assertEquals($result['checksum'], $transfer->getState()->getPartGenerator()->getRootChecksum()); + + $this->client->deleteArchive(array( + 'vaultName' => self::TEST_VAULT, + 'archiveId' => $result['archiveId'] + )); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Model/MultipartUpload/AbstractTransferTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Model/MultipartUpload/AbstractTransferTest.php new file mode 100644 index 0000000..154edbc --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Model/MultipartUpload/AbstractTransferTest.php @@ -0,0 +1,145 @@ +getMockBuilder('Aws\Glacier\Model\MultipartUpload\UploadId') + ->setMethods(array('toParams')) + ->getMock(); + $uploadId->expects($this->any()) + ->method('toParams') + ->will($this->returnValue(array( + 'accountId' => '-', + 'vaultName' => 'foo', + 'uploadId' => 'bar' + ) + )); + + $generator = $this->getMockBuilder('Aws\Glacier\Model\MultipartUpload\UploadPartGenerator') + ->disableOriginalConstructor() + ->getMock(); + $generator->expects($this->any()) + ->method('getPartSize') + ->will($this->returnValue(1024 * 1024)); + + $body = EntityBody::factory(fopen(__FILE__, 'r')); + + if ($useRealClient) { + $client = $this->getServiceBuilder()->get('glacier', true); + } else { + $client = $this->getMockBuilder('Aws\Glacier\GlacierClient') + ->disableOriginalConstructor() + ->getMock(); + } + + $state = $this->getMockBuilder('Aws\Glacier\Model\MultipartUpload\TransferState') + ->disableOriginalConstructor() + ->getMock(); + $state->expects($this->any()) + ->method('getUploadId') + ->will($this->returnValue($uploadId)); + $state->expects($this->any()) + ->method('getPartGenerator') + ->will($this->returnValue($generator)); + + $this->client = $client; + $this->transfer = $this->getMockForAbstractClass('Aws\Glacier\Model\MultipartUpload\AbstractTransfer', array( + $client, $state, $body + )); + } + + protected function callProtectedMethod($object, $method, array $args = array()) + { + $reflectedObject = new \ReflectionObject($object); + $reflectedMethod = $reflectedObject->getMethod($method); + $reflectedMethod->setAccessible(true); + + return $reflectedMethod->invokeArgs($object, $args); + } + + public function testCanGetPartSize() + { + $this->prepareTransfer(); + $this->assertEquals(1024 * 1024, $this->callProtectedMethod($this->transfer, 'calculatePartSize')); + } + + public function testCanCompleteMultipartUpload() + { + $this->prepareTransfer(); + + $model = $this->getMockBuilder('Guzzle\Service\Resource\Model') + ->disableOriginalConstructor() + ->getMock(); + $command = $this->getMockBuilder('Guzzle\Service\Command\OperationCommand') + ->disableOriginalConstructor() + ->getMock(); + $command->expects($this->any()) + ->method('getResult') + ->will($this->returnValue($model)); + $this->client->expects($this->any()) + ->method('getCommand') + ->will($this->returnValue($command)); + + $this->assertInstanceOf( + 'Guzzle\Service\Resource\Model', + $this->callProtectedMethod($this->transfer, 'complete') + ); + } + + public function testCanGetAbortCommand() + { + $this->prepareTransfer(true); + + $abortCommand = $this->callProtectedMethod($this->transfer, 'getAbortCommand'); + $this->assertInstanceOf('Guzzle\Service\Command\OperationCommand', $abortCommand); + $this->assertEquals('foo', $abortCommand->get('vaultName')); + } + + public function testCanGetCommandForUploadPart() + { + $this->prepareTransfer(true); + + $part = UploadPart::fromArray(array( + 'partNumber' => 1, + 'checksum' => 'foo', + 'contentHash' => 'bar', + 'size' => 10, + 'offset' => 5 + )); + + $command = $this->callProtectedMethod($this->transfer, 'getCommandForPart', array($part, true)); + $this->assertInstanceOf('Guzzle\Service\Command\OperationCommand', $command); + $this->assertEquals('foo', $command->get('checksum')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Model/MultipartUpload/ParallelTransferTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Model/MultipartUpload/ParallelTransferTest.php new file mode 100644 index 0000000..b6c6fd3 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Model/MultipartUpload/ParallelTransferTest.php @@ -0,0 +1,127 @@ +partSize = 1024; + parent::generateUploadParts($body); + } +} + +/** + * @covers Aws\Glacier\Model\MultipartUpload\ParallelTransfer + */ +class ParallelTransferTest extends \Guzzle\Tests\GuzzleTestCase +{ + protected function getMockUploadId() + { + $uploadId = $this->getMockBuilder('Aws\Glacier\Model\MultipartUpload\UploadId') + ->setMethods(array('toParams')) + ->getMock(); + $uploadId->expects($this->any()) + ->method('toParams') + ->will($this->returnValue(array( + 'accountId' => '-', + 'vaultName' => 'foo', + 'uploadId' => 'bar' + ) + )); + + return $uploadId; + } + + protected function prepComponents() + { + $uploadId = $this->getMockUploadId(); + $body = EntityBody::factory(fopen(__FILE__, 'r')); + + $generator = SpecialUploadPartGenerator::factory($body, 1024 * 1024); + $client = $this->getServiceBuilder()->get('glacier', true); + $state = new TransferState($uploadId); + $state->setPartGenerator($generator); + $transfer = new ParallelTransfer($client, $state, $body, array('concurrency' => 2)); + + return array($transfer, $client, $state); + } + + public function testSuccessfulTransfer() + { + list($transfer, $client) = $this->prepComponents(); + + $mocks = array(); + for ($i = 0; $i < intval(ceil(filesize(__FILE__) / 1024)); $i++) { + $mocks[] = 'glacier/upload_part'; + } + $mocks[] = 'glacier/complete_multipart_upload'; + $mock = $this->setMockResponse($client, $mocks); + + $result = $transfer->upload(); + + $requests = $mock->getReceivedRequests(); + $this->assertEquals($i + 1, count($requests)); + for ($j = 0; $j < $i; $j++) { + $this->assertEquals('PUT', $requests[$j]->getMethod()); + } + $this->assertEquals('PUT', $requests[4]->getMethod()); + $this->assertInstanceOf('Guzzle\Service\Resource\Model', $result); + } + + public function testStoppingWillStopTransfer() + { + list($transfer) = $this->prepComponents(); + + $transfer->getEventDispatcher()->addListener(ParallelTransfer::BEFORE_PART_UPLOAD, function($event) { + $event['transfer']->stop(); + }); + + $result = $transfer->upload(); + + $this->assertNull($result); + } + + /** + * @expectedException Aws\Common\Exception\RuntimeException + */ + public function testEnsuresTheFileIsLocalAndSeekable() + { + $transfer = new ParallelTransfer( + $this->getServiceBuilder()->get('glacier'), + new TransferState($this->getMockUploadId()), + EntityBody::factory('foo') + ); + } + + /** + * @expectedException Aws\Common\Exception\RuntimeException + */ + public function testEnsuresConcurrencyIsSpecified() + { + $transfer = new ParallelTransfer( + $this->getServiceBuilder()->get('glacier'), + new TransferState($this->getMockUploadId()), + EntityBody::factory(fopen(__FILE__, 'r')) + ); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Model/MultipartUpload/SerialTransferTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Model/MultipartUpload/SerialTransferTest.php new file mode 100644 index 0000000..1558020 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Model/MultipartUpload/SerialTransferTest.php @@ -0,0 +1,85 @@ +getMockBuilder('Aws\Glacier\Model\MultipartUpload\UploadId') + ->setMethods(array('toParams')) + ->getMock(); + $uploadId->expects($this->any()) + ->method('toParams') + ->will($this->returnValue(array( + 'accountId' => '-', + 'vaultName' => 'foo', + 'uploadId' => 'bar' + ) + )); + + $body = EntityBody::factory(str_repeat('x', 1024 * 1024 + 1024)); + $generator = UploadPartGenerator::factory($body, 1024 * 1024); + $client = $this->getServiceBuilder()->get('glacier', true); + $state = new TransferState($uploadId); + $state->setPartGenerator($generator); + $transfer = new SerialTransfer($client, $state, $body); + + return array($transfer, $client, $state); + } + + public function testSuccessfulTransfer() + { + list($transfer, $client) = $this->prepComponents(); + + $mock = $this->setMockResponse($client, array( + 'glacier/upload_part', + 'glacier/upload_part', + 'glacier/complete_multipart_upload' + )); + + $result = $transfer->upload(); + + $requests = $mock->getReceivedRequests(); + $this->assertEquals(3, count($requests)); + $this->assertEquals('PUT', $requests[0]->getMethod()); + $this->assertEquals('PUT', $requests[1]->getMethod()); + $this->assertEquals('POST', $requests[2]->getMethod()); + $this->assertInstanceOf('Guzzle\Service\Resource\Model', $result); + } + + public function testStoppingWillStopTransfer() + { + list($transfer) = $this->prepComponents(); + + $transfer->getEventDispatcher()->addListener(SerialTransfer::BEFORE_PART_UPLOAD, function($event) { + $event['transfer']->stop(); + }); + + $result = $transfer->upload(); + + $this->assertNull($result); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Model/MultipartUpload/TransferStateTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Model/MultipartUpload/TransferStateTest.php new file mode 100644 index 0000000..f3c9cc3 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Model/MultipartUpload/TransferStateTest.php @@ -0,0 +1,60 @@ +getMockBuilder('Aws\Glacier\Model\MultipartUpload\UploadId') + ->setMethods(array('toParams')) + ->getMock(); + $uploadId->expects($this->any()) + ->method('toParams') + ->will($this->returnValue(array( + 'accountId' => '-', + 'vaultName' => 'foo', + 'uploadId' => 'bar' + ) + )); + + $client = $this->getServiceBuilder()->get('glacier'); + $mock = $this->setMockResponse($client, array('glacier/list_parts')); + + $state = TransferState::fromUploadId($client, $uploadId); + $this->assertInstanceOf('Aws\Glacier\Model\MultipartUpload\TransferState', $state); + $this->assertEquals(1, count($mock->getReceivedRequests())); + } + + public function testGettersAndSetters() + { + $uploadId = $this->getMock('Aws\Glacier\Model\MultipartUpload\UploadId'); + $generator = $this->getMockBuilder('Aws\Glacier\Model\MultipartUpload\UploadPartGenerator') + ->disableOriginalConstructor() + ->getMock(); + + $state = new TransferState($uploadId); + $state->setPartGenerator($generator); + $this->assertSame($generator, $state->getPartGenerator()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Model/MultipartUpload/UploadBuilderTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Model/MultipartUpload/UploadBuilderTest.php new file mode 100644 index 0000000..199f6d7 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Model/MultipartUpload/UploadBuilderTest.php @@ -0,0 +1,170 @@ +assertInstanceOf('Aws\Glacier\Model\MultipartUpload\UploadBuilder', UploadBuilder::newInstance()); + } + + public function testHasChainableSetterMethods() + { + /** @var $builder UploadBuilder */ + $builder = UploadBuilder::newInstance(); + $builder->setAccountId('foo') + ->setVaultName('bar') + ->setPartGenerator(UploadPartGenerator::factory(EntityBody::factory('foo'), 1024 * 1024)) + ->setConcurrency(1) + ->setPartSize(1024 * 1024) + ->setArchiveDescription('abc'); + + $this->assertEquals('foo', $this->readAttribute($builder, 'accountId')); + $this->assertEquals('bar', $this->readAttribute($builder, 'vaultName')); + $this->assertEquals('abc', $this->readAttribute($builder, 'archiveDescription')); + $this->assertEquals(1, $this->readAttribute($builder, 'concurrency')); + $this->assertEquals(1024 * 1024, $this->readAttribute($builder, 'partSize')); + $this->assertInstanceOf( + 'Aws\Glacier\Model\MultipartUpload\UploadPartGenerator', + $this->readAttribute($builder, 'partGenerator') + ); + } + + /** + * @expectedException \Aws\Common\Exception\InvalidArgumentException + * @expectedExceptionMessage You must specify a vault name, client, and source. + */ + public function testValidatesThatRequiredFieldsAreSet() + { + UploadBuilder::newInstance()->build(); + } + + /** + * @expectedException \Aws\Common\Exception\InvalidArgumentException + * @expectedExceptionMessage You cannot upload from a non-seekable source. + */ + public function testValidatesThatNonSeekableStreamsCannotBeResumed() + { + $source = $this->getMockBuilder('Guzzle\Http\EntityBody') + ->setMethods(array('isSeekable')) + ->disableOriginalConstructor() + ->getMock(); + + $source->expects($this->any()) + ->method('isSeekable') + ->will($this->returnValue(false)); + + UploadBuilder::newInstance() + ->setVaultName('foo') + ->setSource($source) + ->resumeFrom('abc') + ->setClient($this->getServiceBuilder()->get('glacier')) + ->build(); + } + + public function testCanResumeStateByLoadingFromGlacier() + { + $generator = $this->getMockBuilder('Aws\Glacier\Model\MultipartUpload\UploadPartGenerator') + ->disableOriginalConstructor() + ->getMock(); + + $client = $this->getServiceBuilder()->get('glacier'); + $mock = $this->setMockResponse($client, array('glacier/list_parts')); + + $transfer = UploadBuilder::newInstance() + ->setVaultName('foo') + ->resumeFrom('abc') + ->setClient($client) + ->setSource(EntityBody::factory('foo')) + ->setPartGenerator($generator) + ->build(); + + $this->assertEquals(1, count($mock->getReceivedRequests())); + $this->assertEquals(2, count($transfer->getState())); + } + + /** + * @expectedException \Aws\Common\Exception\InvalidArgumentException + */ + public function testResumeThrowsExceptionIfNoPartGenerator() + { + $client = $this->getServiceBuilder()->get('glacier'); + $transfer = UploadBuilder::newInstance() + ->setVaultName('foo') + ->resumeFrom('abc') + ->setClient($client) + ->setSource(EntityBody::factory('foo')) + ->build(); + } + + public function testCanCreateNewStateByInitiatingMultipartUpload() + { + $generator = $this->getMockBuilder('Aws\Glacier\Model\MultipartUpload\UploadPartGenerator') + ->disableOriginalConstructor() + ->getMock(); + + $client = $this->getServiceBuilder()->get('glacier'); + $mock = $this->setMockResponse($client, array('glacier/initiate_multipart_upload')); + $transfer = UploadBuilder::newInstance() + ->setVaultName('foo') + ->setClient($client) + ->setSource(EntityBody::factory('foo')) + ->setPartGenerator($generator) + ->build(); + $requests = $mock->getReceivedRequests(); + $this->assertEquals(1, count($requests)); + $this->assertInstanceOf('Aws\Glacier\Model\MultipartUpload\TransferState', $transfer->getState()); + } + + public function testBuildsDifferentUploaderBasedOnConcurrency() + { + $generator = $this->getMockBuilder('Aws\Glacier\Model\MultipartUpload\UploadPartGenerator') + ->setMethods(array('getPartSize')) + ->disableOriginalConstructor() + ->getMock(); + $generator->expects($this->any()) + ->method('getPartSize') + ->will($this->returnValue(1024 * 1024)); + $state = new TransferState(UploadId::fromParams(array( + 'accountId' => 'foo', + 'vaultName' => 'baz', + 'uploadId' => 'bar' + ))); + $state->setPartGenerator($generator); + + $b = UploadBuilder::newInstance() + ->setVaultName('foo') + ->setPartGenerator($generator) + ->setClient($this->getServiceBuilder()->get('glacier')) + ->resumeFrom($state) + ->setSource(EntityBody::factory(fopen(__FILE__, 'r'))); + + $this->assertInstanceOf('Aws\Glacier\Model\MultipartUpload\SerialTransfer', $b->build()); + $b->setConcurrency(2); + $this->assertInstanceOf('Aws\Glacier\Model\MultipartUpload\ParallelTransfer', $b->build()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Model/MultipartUpload/UploadPartContextTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Model/MultipartUpload/UploadPartContextTest.php new file mode 100644 index 0000000..1ed0085 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Model/MultipartUpload/UploadPartContextTest.php @@ -0,0 +1,175 @@ +assertEquals(10, $this->readAttribute($context, 'maxSize')); + $this->assertEquals(5, $this->readAttribute($context, 'offset')); + $this->assertEquals(0, $this->readAttribute($context, 'size')); + $this->assertInstanceOf('Aws\Common\Hash\TreeHash', $this->readAttribute($context, 'treeHash')); + $this->assertInstanceOf('Aws\Common\Hash\ChunkHash', $this->readAttribute($context, 'chunkHash')); + } + + /** + * @covers Aws\Glacier\Model\MultipartUpload\UploadPartContext::isEmpty + * @covers Aws\Glacier\Model\MultipartUpload\UploadPartContext::isFull + */ + public function testIsEmptyAndFullAsExpected() + { + $context = new UploadPartContext(10); + + $this->assertTrue($context->isEmpty()); + $this->assertFalse($context->isFull()); + $this->assertEquals(0, $this->readAttribute($context, 'size')); + + $context->addData('abcde'); + + $this->assertFalse($context->isEmpty()); + $this->assertFalse($context->isFull()); + $this->assertEquals(5, $this->readAttribute($context, 'size')); + + $context->addData('fghij'); + + $this->assertFalse($context->isEmpty()); + $this->assertTrue($context->isFull()); + $this->assertEquals(10, $this->readAttribute($context, 'size')); + } + + public function testCanCreateUploadPart() + { + $context = new UploadPartContext(10); + $context->addData('abcdefghij'); + $part = $context->generatePart(); + + $this->assertInstanceOf('Aws\Glacier\Model\MultipartUpload\UploadPart', $part); + } + +// /** +// * @covers Aws\Glacier\Model\UploadPartContext::addData +// * @covers Aws\Glacier\Model\UploadPartContext::finalize +// * @covers Aws\Glacier\Model\UploadPartContext::getChecksum +// * @covers Aws\Glacier\Model\UploadPartContext::getContentHash +// * @covers Aws\Glacier\Model\UploadPartContext::getRange +// * @covers Aws\Glacier\Model\UploadPartContext::getSize +// */ +// public function testCanRetrieveFinalHashes() +// { +// $context = new UploadContext(6); +// $context->addData('foobar'); +// $context->finalize(); +// +// $this->assertInternalType('string', $context->getChecksum()); +// $this->assertInternalType('string', $context->getContentHash()); +// $this->assertEquals(array(0, 5), $context->getRange()); +// $this->assertEquals(6, $context->getSize()); +// } +// +// /** +// * @covers Aws\Glacier\Model\UploadPartContext::serialize +// * @covers Aws\Glacier\Model\UploadPartContext::unserialize +// */ +// public function testCanSerializeAndUnserialize() +// { +// $getArray = function (UploadContext $context) { +// return array( +// $context->getChecksum(), +// $context->getContentHash(), +// $context->getSize(), +// $context->getOffset(), +// $context->getRange() +// ); +// }; +// +// $context1 = new UploadContext(3); +// $context1->addData('foo'); +// $context1->finalize(); +// $array1 = $getArray($context1); +// +// $context2 = unserialize(serialize($context1)); +// $array2 = $getArray($context2); +// +// $this->assertEquals($array1, $array2); +// } + + /** + * @expectedException \LogicException + * @covers Aws\Glacier\Model\MultipartUpload\UploadPartContext::addData + */ + public function testCannotAddDataAfterFinalized() + { + $context = new UploadPartContext(6); + $context->addData('foo'); + $context->generatePart(); + + $context->addData('bar'); + } + + /** + * @expectedException \LogicException + * @covers Aws\Glacier\Model\MultipartUpload\UploadPartContext::addData + */ + public function testCannotAddTooMuchData() + { + $context = new UploadPartContext(3); + $context->addData('foo'); + $context->addData('bar'); + } + +// /** +// * @expectedException \LogicException +// * @covers Aws\Glacier\Model\UploadPartContext::getChecksum +// */ +// public function testCannotGetChecksumBeforeItIsCalculated() +// { +// $context = new UploadContext(3); +// $context->getChecksum(); +// } +// +// /** +// * @expectedException \LogicException +// * @covers Aws\Glacier\Model\UploadPartContext::getContentHash +// */ +// public function testCannotGetContextHashBeforeItIsCalculated() +// { +// $context = new UploadContext(3); +// $context->getContentHash(); +// } +// +// /** +// * @covers Aws\Glacier\Model\UploadPartContext::serialize +// */ +// public function testCannotSerializeUntilItsFinalized() +// { +// $context = new UploadContext(3); +// try { +// serialize($context); +// $this->fail(); +// } catch (\Exception $e) { +// // Success! +// } +// } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Model/MultipartUpload/UploadPartGeneratorTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Model/MultipartUpload/UploadPartGeneratorTest.php new file mode 100644 index 0000000..0e27847 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Model/MultipartUpload/UploadPartGeneratorTest.php @@ -0,0 +1,125 @@ +bodySize = intval(1.25 * Size::MB); + $this->bodyContent = str_repeat('x', $this->bodySize); + } + + public function testCanGenerateUploadPartData() + { + $generator = UploadPartGenerator::factory($this->bodyContent, Size::MB); + $parts = $generator->getAllParts(); + + $this->assertInstanceOf('Aws\Glacier\Model\MultipartUpload\UploadPartGenerator', $generator); + $this->assertInstanceOf('Aws\Glacier\Model\MultipartUpload\UploadPart', $generator->getUploadPart(1)); + $this->assertInstanceOf('Aws\Glacier\Model\MultipartUpload\UploadPart', $parts[0]); + $this->assertSame($parts[0], $generator->getUploadPart(1)); + $this->assertCount(2, $parts); + $this->assertCount(2, $generator); + $this->assertCount(2, $generator->getIterator()); + $this->assertInternalType('string', $generator->getRootChecksum()); + $this->assertEquals($this->bodySize, $generator->getArchiveSize()); + $this->assertEquals(Size::MB, $generator->getPartSize()); + } + + /** + * @expectedException \InvalidArgumentException + */ + public function testExceptionWhenPartSizeInvalid() + { + $generator = UploadPartGenerator::factory($this->bodyContent, 13.2 * Size::MB); + } + + /** + * @expectedException \InvalidArgumentException + */ + public function testExceptionWhenBodyIsNotSeekable() + { + $stream = fopen('php://temp', 'r+'); + fwrite($stream, $this->bodyContent); + rewind($stream); + + $body = $this->getMock('Guzzle\Http\EntityBody', array('isSeekable'), array($stream)); + $body->expects($this->any()) + ->method('isSeekable') + ->will($this->returnValue(false)); + + UploadPartGenerator::factory($body, Size::MB); + } + + /** + * @expectedException \InvalidArgumentException + */ + public function testExceptionWhenBodyIsTooSmall() + { + UploadPartGenerator::factory('', Size::MB); + } + + /** + * @expectedException \RuntimeException + */ + public function testExceptionUnserializationIsUnsuccessful() + { + $generator = UploadPartGenerator::factory($this->bodyContent, Size::MB); + $serialized = str_replace('partSize', 'xxxxxxxx', serialize($generator)); + unserialize($serialized); + } + + /** + * @expectedException \OutOfBoundsException + */ + public function testExceptionWhenUploadIndexDoesntExist() + { + $generator = UploadPartGenerator::factory($this->bodyContent, Size::MB); + $generator->getUploadPart(10); + } + + public function testCanCreateSinglePart() + { + $part = UploadPartGenerator::createSingleUploadPart($this->bodyContent); + $this->assertInstanceOf('Aws\Glacier\Model\MultipartUpload\UploadPart', $part); + $this->assertEquals($this->bodySize, $part->getSize()); + } + + public function testSerializationAndUnserializationWorks() + { + $generator = UploadPartGenerator::factory($this->bodyContent, Size::MB); + $startingSize = $generator->getArchiveSize(); + + $serialized = serialize($generator); + + $newGenerator = unserialize($serialized); + $endingSize = $newGenerator->getArchiveSize(); + + $this->assertEquals($startingSize, $endingSize); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Model/MultipartUpload/UploadPartTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Model/MultipartUpload/UploadPartTest.php new file mode 100644 index 0000000..a4656ec --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Model/MultipartUpload/UploadPartTest.php @@ -0,0 +1,45 @@ + 3, + 'checksum' => 'aaa', + 'contentHash' => 'bbb', + 'size' => 5, + 'offset' => 2 + )); + + $this->assertEquals(3, $part->getPartNumber()); + $this->assertEquals('aaa', $part->getChecksum()); + $this->assertEquals('bbb', $part->getContentHash()); + $this->assertEquals(5, $part->getSize()); + $this->assertEquals(2, $part->getOffset()); + $this->assertEquals(array(2, 6), $part->getRange()); + $this->assertEquals('bytes 2-6/*', $part->getFormattedRange()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Waiter/VaultExistsTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Waiter/VaultExistsTest.php new file mode 100644 index 0000000..4a33309 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Waiter/VaultExistsTest.php @@ -0,0 +1,36 @@ +getServiceBuilder()->get('glacier', true); + $this->setMockResponse($client, 'glacier/describe_vault'); + $client->waitUntil('VaultExists', array('vaultName' => 'foo')); + $this->assertEquals(1, count($this->getMockedRequests())); + } + + public function testRetriesUntilVaultExists() + { + $client = $this->getServiceBuilder()->get('glacier', true); + $this->setMockResponse($client, array('glacier/describe_vault_error', 'glacier/describe_vault_error', 'glacier/describe_vault')); + $client->waitUntil('VaultExists', array('vaultName' => 'foo', 'waiter.interval' => 0)); + $this->assertEquals(3, count($this->getMockedRequests())); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Waiter/VaultNotExistsTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Waiter/VaultNotExistsTest.php new file mode 100644 index 0000000..e1c8d45 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Glacier/Waiter/VaultNotExistsTest.php @@ -0,0 +1,36 @@ +getServiceBuilder()->get('glacier', true); + $this->setMockResponse($client, 'glacier/describe_vault_error'); + $client->waitUntil('VaultNotExists', array('vaultName' => 'foo')); + $this->assertEquals(1, count($this->getMockedRequests())); + } + + public function testRetriesUntilVaultNotExists() + { + $client = $this->getServiceBuilder()->get('glacier', true); + $this->setMockResponse($client, array('glacier/describe_vault', 'glacier/describe_vault', 'glacier/describe_vault_error')); + $client->waitUntil('VaultNotExists', array('vaultName' => 'foo', 'waiter.interval' => 0)); + $this->assertEquals(3, count($this->getMockedRequests())); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Iam/IamClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Iam/IamClientTest.php new file mode 100644 index 0000000..3cec788 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Iam/IamClientTest.php @@ -0,0 +1,35 @@ + 'foo', + 'secret' => 'bar' + )); + $this->assertEquals('https://iam.amazonaws.com', $c->getBaseUrl()); + $this->assertNotNull($c->getDescription()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Iam/Integration/IntegrationTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Iam/Integration/IntegrationTest.php new file mode 100644 index 0000000..3bf8549 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Iam/Integration/IntegrationTest.php @@ -0,0 +1,124 @@ +iam = $this->getServiceBuilder()->get('iam'); + } + + public static function cleanUp() + { + $iam = self::getServiceBuilder()->get('iam'); + foreach (self::$policies as $policy) { + try { + $iam->deleteRolePolicy(array( + 'PolicyName' => $policy, + 'RoleName' => self::$roleName, + )); + } catch (\Exception $e) {} + } + + try { + $iam->deleteRole(array('RoleName' => self::$roleName)); + } catch (\Exception $e) {} + } + + public static function setUpBeforeClass() + { + self::cleanUp(); + } + + public static function tearDownAfterClass() + { + self::cleanUp(); + } + + public function testGetsAccountSummary() + { + $result = $this->iam->getAccountSummary(); + // Ensure that the XML map was converted correctly + $this->assertArrayHasKey('SummaryMap', $result->toArray()); + } + + public function testWorkingWithRoles() + { + $roleName = 'php-integ-iam-test-role'; + + self::log('Create an IAM Role.'); + $result = $this->iam->getCommand('CreateRole', array( + 'RoleName' => $roleName, + 'AssumeRolePolicyDocument' => self::IAM_POLICY_ASSUME_ROLE, + ))->getResult(); + $roleArn = $result->getPath('Role/Arn'); + + self::log('Put a policy on the IAM Role.'); + $result = $this->iam->getCommand('PutRolePolicy', array( + 'PolicyName' => self::$policies[0], + 'RoleName' => $roleName, + 'PolicyDocument' => self::IAM_POLICY_ALLOW_S3, + ))->getResult(); + + self::log('Put another policy on the IAM Role.'); + $result = $this->iam->getCommand('PutRolePolicy', array( + 'PolicyName' => self::$policies[1], + 'RoleName' => $roleName, + 'PolicyDocument' => self::IAM_POLICY_ALLOW_S3, + ))->getResult(); + + self::log('make sure the IAM Role exists.'); + // @TODO do a ListRoles-related assertion + + self::log('Make sure the policies are there.'); + //print_r($this->iam->listRolePolicies(array('RoleName' => $roleName))->toArray()); + $policies = $this->iam->getIterator('ListRolePolicies', array('RoleName' => $roleName)); + $this->assertEquals(self::$policies, iterator_to_array($policies)); + + self::log('Delete the policies from the IAM Role.'); + $commands = array(); + foreach (self::$policies as $policy) { + $commands[] = $this->iam->getCommand('DeleteRolePolicy', array( + 'PolicyName' => $policy, + 'RoleName' => $roleName, + )); + } + $this->iam->execute($commands); + + self::log('Delete the IAM Role.'); + $result = $this->iam->getCommand('DeleteRole', array( + 'RoleName' => $roleName, + ))->getResult(); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/ImportExport/ImportExportClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/ImportExport/ImportExportClientTest.php new file mode 100644 index 0000000..e7718ea --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/ImportExport/ImportExportClientTest.php @@ -0,0 +1,37 @@ + 'foo', + 'secret' => 'bar', + )); + + $this->assertInstanceOf('Aws\Common\Signature\SignatureV2', $client->getSignature()); + $this->assertInstanceOf('Aws\Common\Credentials\Credentials', $client->getCredentials()); + $this->assertEquals('https://importexport.amazonaws.com', $client->getBaseUrl()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/ImportExport/Integration/IntegrationTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/ImportExport/Integration/IntegrationTest.php new file mode 100644 index 0000000..20af847 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/ImportExport/Integration/IntegrationTest.php @@ -0,0 +1,72 @@ +client = $this->getServiceBuilder()->get('importexport'); + } + + /** + * @expectedException \Aws\ImportExport\Exception\MissingManifestFieldException + */ + public function testCreateJobFailsWithIncompleteManifest() + { + $this->client->createJob(array( + 'JobType' => JobType::IMPORT, + 'Manifest' => 'foo: bar', + 'ValidateOnly' => true, + )); + } + + /** + * @expectedException \Aws\ImportExport\Exception\MissingManifestFieldException + */ + public function testCreateJobFailsWithIncompleteArrayFormattedManifest() + { + if (!class_exists('Symfony\Component\Yaml\Yaml')) { + $this->markTestSkipped('You must have the the Symfony YAML component installed to run this test.'); + } + + $this->client->createJob(array( + 'JobType' => JobType::IMPORT, + 'Manifest' => array('foo' => 'bar'), + 'ValidateOnly' => true, + )); + } + + public function testListJobsCommandAndIterator() + { + $commandResults = $this->client->listJobs()->toArray(); + $this->assertArrayHasKey('Jobs', $commandResults); + + $iteratorResults = $this->client->getIterator('ListJobs')->toArray(); + $this->assertEquals($commandResults['Jobs'], $iteratorResults); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/ImportExport/JobManifestListenerTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/ImportExport/JobManifestListenerTest.php new file mode 100644 index 0000000..ef02826 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/ImportExport/JobManifestListenerTest.php @@ -0,0 +1,62 @@ +sampleManifest = <<getServiceBuilder()->get('importexport'); + $command = $client->getCommand('CreateJob', array( + 'JobType' => 'IMPORT', + 'ValidateOnly' => true, + 'Manifest' => array( + 'foo' => 'bar', + 'bar' => array('foo', 'bar', 'baz'), + 'baz' => 'foo', + ), + )); + + $listener = new JobManifestListener(); + $this->assertArrayHasKey('command.before_prepare', $listener->getSubscribedEvents()); + + $event = new Event(array('command' => $command)); + $listener->onCommandBeforePrepare($event); + $this->assertEquals($this->sampleManifest, $command->get('Manifest')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/ImportExport/ListJobsIteratorTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/ImportExport/ListJobsIteratorTest.php new file mode 100644 index 0000000..68ea4eb --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/ImportExport/ListJobsIteratorTest.php @@ -0,0 +1,37 @@ +getServiceBuilder()->get('importexport', true); + $this->setMockResponse($client, array( + 'importexport/list_jobs_1', + 'importexport/list_jobs_2', + )); + + /** @var \Aws\Common\Iterator\AwsResourceIterator $iterator */ + $iterator = $client->getIterator('ListJobs'); + $jobs = iterator_to_array($iterator); + + $this->assertCount(4, $jobs); + $this->assertEquals(2, $iterator->getRequestCount()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/IntegrationTestCase.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/IntegrationTestCase.php new file mode 100644 index 0000000..483277f --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/IntegrationTestCase.php @@ -0,0 +1,87 @@ +useMocks()) { + $errno = $errstr = ''; + $fp = @fsockopen('http://169.254.169.254', 80, $errno, $errstr, 0.1); + if (!$fp) { + $this->markTestSkipped('Not on EC2'); + } else { + fclose($fp); + } + } + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Kinesis/Integration/Kinesis_20131104_Test.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Kinesis/Integration/Kinesis_20131104_Test.php new file mode 100644 index 0000000..d47fddf --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Kinesis/Integration/Kinesis_20131104_Test.php @@ -0,0 +1,65 @@ +client = $this->getServiceBuilder()->get('kinesis'); + } + + /** + * Execute the CreateStream operation + * + * @example Aws\Kinesis\KinesisClient::createStream + */ + public function testCreateStream() + { + $client = $this->client; + + // @begin + $client->createStream(array( + 'StreamName' => 'php-test-stream', + 'ShardCount' => 1, + )); + } + + /** + * Execute the DeleteStream operation + * + * @example Aws\Kinesis\KinesisClient::deleteStream + */ + public function testDeleteStream() + { + $client = $this->client; + + // @begin + $client->deleteStream(array( + 'StreamName' => 'php-test-stream', + )); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Kinesis/KinesisClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Kinesis/KinesisClientTest.php new file mode 100644 index 0000000..dd1b535 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Kinesis/KinesisClientTest.php @@ -0,0 +1,57 @@ + 'foo', + 'secret' => 'bar', + 'region' => 'us-east-1', + )); + + $this->assertInstanceOf('Aws\Common\Signature\SignatureV4', $client->getSignature()); + $this->assertInstanceOf('Aws\Common\Credentials\Credentials', $client->getCredentials()); + $this->assertEquals('https://kinesis.us-east-1.amazonaws.com', $client->getBaseUrl()); + } + + public function testTheGetShardIteratorOperationWorksViaMagicCall() + { + $client = KinesisClient::factory(array( + 'key' => 'foo', + 'secret' => 'bar', + 'region' => 'us-east-1', + )); + $client->addSubscriber(new MockPlugin(array(new Response(200, null, '{"ShardIterator":"foobar"}')))); + + $result = $client->getShardIterator(array( + 'StreamName' => 'test', + 'ShardId' => 'test', + 'ShardIteratorType' => 'AT_SEQUENCE_NUMBER', + )); + $this->assertEquals('foobar', $result['ShardIterator']); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/OpsWorks/Integration/IntegrationTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/OpsWorks/Integration/IntegrationTest.php new file mode 100644 index 0000000..11ee03f --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/OpsWorks/Integration/IntegrationTest.php @@ -0,0 +1,61 @@ +client = $this->getServiceBuilder()->get('opsworks'); + } + + public function testDescribesStacks() + { + self::log('Describing stacks'); + $result = $this->client->describeStacks()->toArray(); + $this->assertArrayHasKey('Stacks', $result); + } + + public function testListsStacks() + { + self::log('Iterating stacks'); + $stacks = $this->client->getIterator('DescribeStacks')->toArray(); + $this->assertInternalType('array', $stacks); + foreach ($stacks as $stack) { + $this->assertArrayHasKey('Name', $stack); + } + } + + /** + * @expectedException \Aws\OpsWorks\Exception\ResourceNotFoundException + */ + public function testParsesErrors() + { + self::log('Ensuring errors are parsed correctly'); + $this->client->deleteApp(array('AppId' => 'does-not-exist-foo-123')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/OpsWorks/OpsWorksClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/OpsWorks/OpsWorksClientTest.php new file mode 100644 index 0000000..0dfd201 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/OpsWorks/OpsWorksClientTest.php @@ -0,0 +1,38 @@ + 'foo', + 'secret' => 'bar', + 'region' => 'us-east-1' + )); + + $this->assertInstanceOf('Aws\Common\Signature\SignatureV4', $client->getSignature()); + $this->assertInstanceOf('Aws\Common\Credentials\Credentials', $client->getCredentials()); + $this->assertEquals('https://opsworks.us-east-1.amazonaws.com', $client->getBaseUrl()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Rds/Integration/IntegrationTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Rds/Integration/IntegrationTest.php new file mode 100644 index 0000000..fc9d4be --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Rds/Integration/IntegrationTest.php @@ -0,0 +1,109 @@ +get('rds'); + try { + $result = $client->deleteDBSecurityGroup(array( + 'DBSecurityGroupName' => self::TEST_GROUP + )); + } catch (\Exception $e) { + // Ignore + } + } + + public function setUp() + { + $this->client = $this->getServiceBuilder()->get('rds'); + } + + public function testEnsuresListsAreParsedCorrectly() + { + $results = $this->client->getIterator('DescribeDBEngineVersions'); + foreach ($results as $result) { + $this->assertArrayHasKey('DBParameterGroupFamily', $result); + } + } + + /** + * @expectedException \Aws\Rds\Exception\DBInstanceNotFoundException + * @expectedExceptionMessage DBInstance foo-123-na not found + */ + public function testParsesErrors() + { + $this->client->deleteDBInstance(array( + 'DBInstanceIdentifier' => 'foo-123-na' + )); + } + + public function testCreatesSecurityGroup() + { + self::log('Creating a DB security group'); + $result = $this->client->createDBSecurityGroup(array( + 'DBSecurityGroupName' => self::TEST_GROUP, + 'DBSecurityGroupDescription' => 'Integ test' + )); + $this->assertArrayHasKey('OwnerId', $result->toArray()); + $this->assertArrayHasKey('EC2SecurityGroups', $result->toArray()); + $this->assertArrayHasKey('ResponseMetadata', $result->toArray()); + } + + /** + * @depends testCreatesSecurityGroup + */ + public function testListsSecurityGroups() + { + self::log('Listing security group'); + $iterator = $this->client->getIterator('DescribeDBSecurityGroups'); + $found = false; + foreach ($iterator as $group) { + if ($group['DBSecurityGroupName'] == self::TEST_GROUP) { + $found = true; + break; + } + } + if (!$found) { + $this->fail('Did not find security group ' . self::TEST_GROUP); + } + } + + /** + * @depends testListsSecurityGroups + */ + public function testDeletesSecurityGroups() + { + self::log('Cleaning up security group'); + $this->client->deleteDBSecurityGroup(array('DBSecurityGroupName' => self::TEST_GROUP)); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Rds/RdsClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Rds/RdsClientTest.php new file mode 100644 index 0000000..bc065d2 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Rds/RdsClientTest.php @@ -0,0 +1,38 @@ + 'foo', + 'secret' => 'bar', + 'region' => 'us-west-2' + )); + + $this->assertInstanceOf('Aws\Common\Signature\SignatureV4', $client->getSignature()); + $this->assertInstanceOf('Aws\Common\Credentials\Credentials', $client->getCredentials()); + $this->assertEquals('https://rds.us-west-2.amazonaws.com', $client->getBaseUrl()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Rds/Waiter/DBAvailableTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Rds/Waiter/DBAvailableTest.php new file mode 100644 index 0000000..a8aefba --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Rds/Waiter/DBAvailableTest.php @@ -0,0 +1,35 @@ +client = $this->getServiceBuilder()->get('rds', true); + $this->setMockResponse($this->client, 'rds/describe_db_instances'); + $this->client->waitUntil('__DBInstanceState', array( + 'DBInstanceIdentifier' => 'foo', + 'waiter.success.value' => "available", + 'waiter.interval' => 0)); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Redshift/Integration/IntegrationTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Redshift/Integration/IntegrationTest.php new file mode 100644 index 0000000..f0200b3 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Redshift/Integration/IntegrationTest.php @@ -0,0 +1,143 @@ +redshift = $this->getServiceBuilder()->get('redshift'); + } + + public function testCreatesSecurityGroup() + { + self::log('Create a cluster security group'); + $result = $this->redshift->createClusterSecurityGroup(array( + 'ClusterSecurityGroupName' => self::SECURITY_GROUP_NAME, + 'Description' => 'PHP Integ Test Cluster Security Group', + )); + $this->assertEquals(self::SECURITY_GROUP_NAME, $result->get('ClusterSecurityGroupName')); + $this->assertTrue($result->hasKey('EC2SecurityGroups')); + $this->assertTrue($result->hasKey('ResponseMetadata')); + } + + /** + * @depends testCreatesSecurityGroup + */ + public function testListsSecurityGroups() + { + self::log('List cluster security groups'); + $found = false; + foreach ($this->redshift->getIterator('DescribeClusterSecurityGroups') as $group) { + if ($group['ClusterSecurityGroupName'] == self::SECURITY_GROUP_NAME) { + $found = true; + break; + } + } + $this->assertTrue($found, 'Did not find cluster security group ' . self::SECURITY_GROUP_NAME); + } + + /** + * @depends testListsSecurityGroups + */ + public function testDeletesSecurityGroups() + { + self::log('Delete cluster security group'); + $this->redshift->deleteClusterSecurityGroup(array('ClusterSecurityGroupName' => self::SECURITY_GROUP_NAME)); + } + + public function testDescribeEventsIterator() + { + $maxRecords = 25; + $events = $this->redshift->getIterator('DescribeEvents', array( + 'StartTime' => strtotime('-13 days'), + 'EndTime' => strtotime('now'), + 'MaxRecords' => $maxRecords, + )); + $total = iterator_count($events); + $expected = ceil($total / $maxRecords); + $this->assertEquals($expected ?: 1, $events->getRequestCount()); + } + + public function exampleTestBasicClusterOperations() + { + $clusterId = 'php-integ-redshift-cluster-' . time(); + $snapshotId = 'php-integ-redshift-snapshot-' . time(); + + self::log('Launch a cluster.'); + $this->redshift->getCommand('CreateCluster', array( + 'ClusterIdentifier' => $clusterId, + 'ClusterType' => 'multi-node', + 'MasterUsername' => 'phpinteguser', + 'MasterUserPassword' => 'PHPint3gu$er', + 'NodeType' => 'dw.hs1.xlarge', + 'NumberOfNodes' => 2, + ))->execute(); + + self::log('Get a list of all of the clusters and make sure there is at least one.'); + $clusters = $this->redshift->getIterator('DescribeClusters'); + $this->assertGreaterThanOrEqual(1, iterator_count($clusters)); + + self::log('Make sure the new cluster exists.'); + $result = $this->redshift->getCommand('DescribeClusters', array( + 'ClusterIdentifier' => $clusterId, + ))->getResult(); + $this->assertCount(1, $result->get('Clusters')); + + self::log('Wait until the cluster exists. This can take around 20 minutes.'); + $this->redshift->waitUntilClusterAvailable(array( + 'ClusterIdentifier' => $clusterId + )); + + self::log('Create a snapshot of the cluster and wait until it is available.'); + $this->redshift->getCommand('CreateClusterSnapshot', array( + 'ClusterIdentifier' => $clusterId, + 'SnapshotIdentifier' => $snapshotId, + ))->execute(); + $this->redshift->waitUntilSnapshotAvailable(array( + 'SnapshotIdentifier' => $snapshotId + )); + + self::log('Delete the snapshot.'); + $this->redshift->getCommand('DeleteClusterSnapshot', array( + 'SnapshotIdentifier' => $snapshotId, + ))->execute(); + + self::log('Delete the cluster.'); + $this->redshift->getCommand('DeleteCluster', array( + 'ClusterIdentifier' => $clusterId, + 'SkipFinalClusterSnapshot' => true, + ))->execute(); + + self::log('Wait until the cluster is deleted.'); + $this->redshift->waitUntilClusterDeleted(array( + 'ClusterIdentifier' => $clusterId, + )); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Redshift/RedshiftClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Redshift/RedshiftClientTest.php new file mode 100644 index 0000000..43e322d --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Redshift/RedshiftClientTest.php @@ -0,0 +1,38 @@ + 'foo', + 'secret' => 'bar', + 'region' => 'us-east-1' + )); + + $this->assertEquals('https://redshift.us-east-1.amazonaws.com', $client->getBaseUrl()); + $this->assertInstanceOf('Aws\Common\Signature\SignatureV4', $client->getSignature()); + $this->assertInstanceOf('Aws\Common\Credentials\Credentials', $client->getCredentials()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Route53/Integration/BasicOperationsTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Route53/Integration/BasicOperationsTest.php new file mode 100644 index 0000000..0bb7c1a --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Route53/Integration/BasicOperationsTest.php @@ -0,0 +1,213 @@ +route53 = $this->getServiceBuilder()->get('route53'); + } + + public function testHostedZoneOperations() + { + self::log('Create a hosted zone.'); + $result = $this->route53->getCommand('CreateHostedZone', array( + 'Name' => 'integroute53' . self::getResourcePrefix() . '.com', + 'CallerReference' => uniqid('aws-sdk-php-hz-'), + ))->getResult(); + $zoneId = $result->getPath('HostedZone/Id'); + $this->assertStringStartsWith('/hostedzone/', $zoneId); + + self::log('List the hosted zones and verify the one we created is there.'); + $zoneIds = array(); + foreach ($this->route53->getIterator('ListHostedZones') as $zone) { + $zoneIds[] = $zone['Id']; + } + $this->assertContains($zoneId, $zoneIds); + + self::log('Get the hosted zone we created by its ID.'); + $result = $this->route53->getCommand('GetHostedZone', array( + 'Id' => $zoneId, + ))->getResult(); + $this->assertEquals($zoneId, $result->getPath('HostedZone/Id')); + $nameServers = $result->getPath('DelegationSet/NameServers'); + $this->assertInternalType('array', $nameServers); + $this->assertSame($nameServers, array_values($nameServers)); + + self::log('Creating an S3 static website bucket'); + $s3 = $this->getServiceBuilder()->get('s3'); + $bucketName = 'integroute53' . self::getResourcePrefix(); + if (!$s3->doesBucketExist($bucketName)) { + $s3->createBucket(array('Bucket' => $bucketName)); + $s3->waitUntil('BucketExists', array('Bucket' => $bucketName)); + } + + self::log('Setting website config on bucket'); + $s3->putBucketWebsite(array( + 'Bucket' => $bucketName, + 'IndexDocument' => array('Suffix' => 'index.html') + )); + + self::log('Create a resource record set for the zone'); + $this->route53->changeResourceRecordSets(array( + 'HostedZoneId' => $zoneId, + 'ChangeBatch' => array( + 'Changes' => array( + array( + 'Action' => 'CREATE', + 'ResourceRecordSet' => array( + 'Name' => 'foo.' . $bucketName . '.com', + 'Type' => 'CNAME', + 'TTL' => 300, + 'ResourceRecords' => array( + array('Value' => '192.0.2.3') + ) + ) + ) + ) + ) + )); + + self::log('Get the resource record set'); + $set = $this->route53->listResourceRecordSets(array( + 'HostedZoneId' => $zoneId + )); + + $record = null; + foreach ($set['ResourceRecordSets'] as $resource) { + if ($resource['Type'] == 'CNAME') { + $record = $resource; + break; + } + } + + if (!$record) { + $this->fail('Did not find the created CNAME record'); + } + + self::log('Update the resource record set'); + $originalRecord = $record; + $record['ResourceRecords'][0]['Value'] = '192.0.2.4'; + + $this->route53->changeResourceRecordSets(array( + 'HostedZoneId' => $zoneId, + 'ChangeBatch' => array( + 'Changes' => array( + array( + 'Action' => 'DELETE', + 'ResourceRecordSet' => $originalRecord + ), + array( + 'Action' => 'CREATE', + 'ResourceRecordSet' => $record + ) + ) + ) + )); + + self::log('Ensuring that the record was updated'); + $set = $this->route53->listResourceRecordSets(array( + 'HostedZoneId' => $zoneId + )); + foreach ($set['ResourceRecordSets'] as $resource) { + if ($resource['Type'] == 'CNAME') { + if ($resource['ResourceRecords'][0]['Value'] != '192.0.2.4') { + $this->fail('Did not update record'); + } + break; + } + } + + self::log('Delete the resource record set'); + $this->route53->changeResourceRecordSets(array( + 'HostedZoneId' => $zoneId, + 'ChangeBatch' => array( + 'Changes' => array( + array( + 'Action' => 'DELETE', + 'ResourceRecordSet' => array( + 'Name' => 'foo.' . $bucketName . '.com', + 'Type' => 'CNAME', + 'TTL' => 300, + 'ResourceRecords' => array( + array('Value' => '192.0.2.4') + ) + ) + ) + ) + ) + )); + + self::log('Delete the bucket'); + $s3->deleteBucket(array('Bucket' => $bucketName)); + + self::log('Delete the hosted zone created.'); + $result = $this->route53->getCommand('DeleteHostedZone', array( + 'Id' => $zoneId, + ))->getResult(); + $changeId = $result->getPath('ChangeInfo/Id'); + $this->assertStringStartsWith('/change/', $changeId); + $this->assertEquals(Status::PENDING, $result->getPath('ChangeInfo/Status')); + + self::log('Get the change record and verify that it is being deleted.'); + $result = $this->route53->getCommand('GetChange', array( + 'Id' => $changeId, + ))->getResult(); + $this->assertEquals(Status::PENDING, $result->getPath('ChangeInfo/Status')); + } + + public function testHealthCheckOperations() + { + self::log('Create a health check.'); + $result = $this->route53->getCommand('CreateHealthCheck', array( + 'CallerReference' => uniqid('aws-sdk-php-hc-'), + 'HealthCheckConfig' => array( + 'IPAddress' => gethostbyname('aws.amazon.com'), + 'Port' => '80', + 'Type' => HealthCheckType::TCP, + ), + ))->getResult(); + $healthCheckId = $result->getPath('HealthCheck/Id'); + + self::log('List the health checks.'); + $result = $this->route53->getCommand('ListHealthChecks')->getResult(); + $this->assertCount(1, $result->get('HealthChecks')); + $this->assertContains($healthCheckId, $result->getPath('HealthChecks/*/Id')); + + self::log('Delete the health checks.'); + foreach ($this->route53->getIterator('ListHealthChecks') as $healthCheck) { + $this->route53->getCommand('DeleteHealthCheck', array( + 'HealthCheckId' => $healthCheck['Id'], + ))->execute(); + } + $result = $this->route53->getCommand('ListHealthChecks')->getResult(); + $this->assertCount(0, $result->get('HealthChecks')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Route53/Integration/IteratorsTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Route53/Integration/IteratorsTest.php new file mode 100644 index 0000000..45235ea --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Route53/Integration/IteratorsTest.php @@ -0,0 +1,52 @@ +getServiceBuilder()->get('route53'); + $mock = $this->setMockResponse($client, array( + 'route53/list_rrs_page_1', + 'route53/list_rrs_page_2', + 'route53/list_rrs_page_3', + )); + + $resourceRecordSets = $client->getIterator('ListResourceRecordSets', array( + 'HostedZoneId' => '0123456789' + )); + + $resourceRecords = array(); + foreach ($resourceRecordSets as $resourceRecordSet) { + $this->assertEquals('www.example.com.', $resourceRecordSet['Name']); + foreach ($resourceRecordSet['ResourceRecords'] as $resourceRecord) { + $resourceRecords[] = $resourceRecord['Value']; + } + } + + $this->assertSame(array('a', 'b', 'c', 'd', 'e', 'f'), $resourceRecords); + + $requests = $mock->getReceivedRequests(); + $this->assertEquals(3, count($requests)); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Route53/Route53ClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Route53/Route53ClientTest.php new file mode 100644 index 0000000..75b7bb2 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Route53/Route53ClientTest.php @@ -0,0 +1,73 @@ + 'foo', + 'secret' => 'bar', + )); + + $this->assertInstanceOf('Aws\Common\Signature\SignatureV3Https', $client->getSignature()); + $this->assertInstanceOf('Aws\Common\Credentials\Credentials', $client->getCredentials()); + $this->assertEquals('https://route53.amazonaws.com', $client->getBaseUrl()); + } + + /** + * @covers Aws\Route53\Route53Client::getServerTime + */ + public function testGetServerTimeReturnsTimeForBoth200And400Responses() + { + $client = Route53Client::factory(array( + 'key' => 'foo', + 'secret' => 'bar', + )); + + $this->setMockResponse($client, array( + 'route53/server_time_1', + 'route53/server_time_2', + )); + + $time = $client->getServerTime(); + $this->assertInstanceOf('DateTime', $time); + $this->assertEquals('11-19-2009', $time->format('m-d-Y')); + + $time = $client->getServerTime(); + $this->assertInstanceOf('DateTime', $time); + $this->assertEquals('11-20-2009', $time->format('m-d-Y')); + } + + /** + * @covers Aws\Route53\Route53Client::cleanId + */ + public function testCanCleanId() + { + $original = array('/hostedzone/1', '2', '/change/3'); + $expected = array('1', '2', '3'); + $actual = array_map('Aws\Route53\Route53Client::cleanId', $original); + + $this->assertSame($expected, $actual); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/AcpListenerTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/AcpListenerTest.php new file mode 100644 index 0000000..29105c5 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/AcpListenerTest.php @@ -0,0 +1,116 @@ +assertNotEmpty(AcpListener::getSubscribedEvents()); + } + + /** + * @expectedException \Aws\Common\Exception\InvalidArgumentException + * @expectedExceptionMessage ACP must be an instance of Aws\S3\Model\Acp + */ + public function testThrowsExceptionWhenAcpIsInvalid() + { + $s3 = $this->getServiceBuilder()->get('s3'); + $s3->getCommand('PutObject', array( + 'Bucket' => 'test', + 'Key' => 'key', + 'Body' => 'hello', + 'ACP' => new \stdClass() + ))->prepare(); + } + + /** + * @expectedException \Aws\Common\Exception\InvalidArgumentException + * @expectedExceptionMessage Use either the ACP parameter or the Grants parameter + */ + public function testThrowsExceptionWhenBothAcpAndGrantsAreSet() + { + $s3 = $this->getServiceBuilder()->get('s3'); + $s3->getCommand('PutObject', array( + 'Bucket' => 'test', + 'Key' => 'key', + 'Body' => 'hello', + 'ACP' => new Acp(new Grantee('123')), + 'Grants' => array() + ))->prepare(); + } + + public function testIgnoresOperationsWhereAcpIsNotPresent() + { + $s3 = $this->getServiceBuilder()->get('s3'); + $s3->getCommand('GetObject', array( + 'Bucket' => 'test', + 'Key' => 'key', + 'ACP' => new Acp(new Grantee('123')), + 'Grants' => array() + ))->prepare(); + } + + public function testAppliesAcpHeadersToCommand() + { + $acp = $this->getAcp(); + $s3 = $this->getServiceBuilder()->get('s3'); + $command = $s3->getCommand('PutObject', array( + 'Bucket' => 'test', + 'Key' => 'key', + 'Body' => 'hello', + 'ACP' => $acp + )); + $command->prepare(); + $this->assertEquals('emailAddress="test@example.com", emailAddress="baz@example.com"', $command['GrantRead']); + $this->assertEquals('emailAddress="jar@jar.com"', $command['GrantWrite']); + $this->assertEquals('uri="http://acs.amazonaws.com/groups/global/AllUsers"', $command['GrantReadACP']); + } + + public function testAppliesAcpBodyToCommand() + { + $acp = $this->getAcp(); + $s3 = $this->getServiceBuilder()->get('s3'); + $command = $s3->getCommand('PutObjectAcl', array( + 'Bucket' => 'test', + 'Key' => 'key', + 'ACP' => $acp + )); + $request = $command->prepare(); + $this->assertContains('Grantee', (string) $request->getBody()); + } + + protected function getAcp() + { + return AcpBuilder::newInstance() + ->setOwner('test') + ->addGrantForEmail('READ', 'test@example.com') + ->addGrantForEmail('READ', 'baz@example.com') + ->addGrantForEmail('WRITE', 'jar@jar.com') + ->addGrantForGroup('READ_ACP', Group::ALL_USERS) + ->build(); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/BucketStyleListenerTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/BucketStyleListenerTest.php new file mode 100644 index 0000000..4e50843 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/BucketStyleListenerTest.php @@ -0,0 +1,81 @@ +assertNotEmpty(BucketStyleListener::getSubscribedEvents()); + } + + public function testUsesPathStyleWhenHttpsContainsDots() + { + $s3 = $this->getServiceBuilder()->get('s3'); + $this->setMockResponse($s3, array(new Response(200))); + $command = $s3->getCommand('GetObject', array( + 'Bucket' => 'test.123', + 'Key' => 'Bar' + )); + $command->execute(); + $this->assertEquals('s3.amazonaws.com', $command->getRequest()->getHost()); + $this->assertEquals('/test.123/Bar', $command->getRequest()->getResource()); + } + + public function testUsesPathStyleWhenNotDnsCompatible() + { + $s3 = $this->getServiceBuilder()->get('s3'); + $this->setMockResponse($s3, array(new Response(200))); + $command = $s3->getCommand('GetObject', array( + 'Bucket' => '_baz_!', + 'Key' => 'Bar' + )); + $command->execute(); + $this->assertEquals('s3.amazonaws.com', $command->getRequest()->getHost()); + $this->assertEquals('/_baz_%21/Bar', $command->getRequest()->getResource()); + } + + public function testUsesPathStyleWhenForced() + { + $s3 = $this->getServiceBuilder()->get('s3'); + $this->setMockResponse($s3, array(new Response(200))); + $command = $s3->getCommand('GetObject', array( + 'Bucket' => 'foo', + 'Key' => 'Bar', + 'PathStyle' => true + )); + $command->execute(); + $this->assertEquals('s3.amazonaws.com', $command->getRequest()->getHost()); + $this->assertEquals('/foo/Bar', $command->getRequest()->getResource()); + } + + public function testUsesVirtualHostedWhenPossible() + { + $s3 = $this->getServiceBuilder()->get('s3'); + $this->setMockResponse($s3, array(new Response(200))); + $command = $s3->getCommand('GetObject', array('Bucket' => 'foo', 'Key' => 'Bar')); + $command->execute(); + $this->assertEquals('foo.s3.amazonaws.com', $command->getRequest()->getHost()); + $this->assertEquals('/Bar', $command->getRequest()->getResource()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Command/S3CommandTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Command/S3CommandTest.php new file mode 100644 index 0000000..677ae9f --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Command/S3CommandTest.php @@ -0,0 +1,70 @@ +getServiceBuilder()->get('s3'); + $command = $client->getCommand('GetObject', array( + 'Bucket' => 'foobazbar', + 'Key' => 'test' + )); + $url = $command->createPresignedUrl('+100'); + $this->assertContains('foobazbar', $url); + $this->assertContains('test', $url); + $this->assertContains('AWSAccessKeyId', $url); + $this->assertContains('Expires', $url); + $this->assertContains('Signature', $url); + } + + public function testAddsUrlToPutObject() + { + $client = $this->getServiceBuilder()->get('s3'); + $command = $client->getCommand('PutObject', array( + 'Bucket' => 'foobazbar', + 'Key' => 'test', + 'Body' => 'test' + )); + $this->setMockResponse($client, array( + new Response(200) + )); + $result = $command->execute(); + $this->assertEquals('https://foobazbar.s3.amazonaws.com/test', $result['ObjectURL']); + } + + /** + * @expectedException \Aws\S3\Exception\PermanentRedirectException + */ + public function testExceptionThrownOn301Redirect() + { + $client = $this->getServiceBuilder()->get('s3'); + $command = $client->getCommand('GetObject', array( + 'Bucket' => 'foobazbar', + 'Key' => 'test', + )); + $response = new Response(301, null, 'PermanentRedirectThe bucket you are attempting to access must be addressed using the specified endpoint. Please send all future requests to this endpoint.DUMMY_REQUEST_IDDUMMY_BUCKET_NAMEDUMMY_HOST_IDs3.amazonaws.com'); + $this->setMockResponse($client, array($response)); + $command->execute(); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Exception/DeleteMultipleObjectsExceptionTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Exception/DeleteMultipleObjectsExceptionTest.php new file mode 100644 index 0000000..903e5a5 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Exception/DeleteMultipleObjectsExceptionTest.php @@ -0,0 +1,36 @@ + 'abc') + )); + + $this->assertEquals(array( + array('Key' => 'abc') + ), $e->getErrors()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Exception/Parser/S3ExceptionParserTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Exception/Parser/S3ExceptionParserTest.php new file mode 100644 index 0000000..c70929e --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Exception/Parser/S3ExceptionParserTest.php @@ -0,0 +1,65 @@ +parse($request, $response); + $this->assertEquals($code, $result['code']); + } + + public function testParsesResponseWith301() + { + $request = new Request('HEAD', 'http://example.com'); + $response = Response::fromMessage("HTTP/1.1 301 Moved Permanently\r\n\r\nPermanentRedirectThe bucket you are attempting to access must be addressed using the specified endpoint. Please send all future requests to this endpoint.DUMMY_REQUEST_IDDUMMY_BUCKET_NAMEDUMMY_HOST_IDs3.amazonaws.com"); + $parser = new S3ExceptionParser(); + $result = $parser->parse($request, $response); + $this->assertEquals('PermanentRedirect', $result['code']); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Integration/AccessControlPolicySample.xml b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Integration/AccessControlPolicySample.xml new file mode 100644 index 0000000..7fa81f4 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Integration/AccessControlPolicySample.xml @@ -0,0 +1,28 @@ + + + + owner-id + owner-display-name + + + + + user-id + user-display-name + + READ + + + + foo@example.com + + WRITE + + + + http://acs.amazonaws.com/groups/global/AuthenticatedUsers + + FULL_CONTROL + + + diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Integration/IntegrationTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Integration/IntegrationTest.php new file mode 100644 index 0000000..985d918 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Integration/IntegrationTest.php @@ -0,0 +1,742 @@ +get('s3'); + $bucket = self::getResourcePrefix() . '-s3-test'; + self::log("Creating the {$bucket} bucket"); + $client->createBucket(array('Bucket' => $bucket)); + // Create the bucket + self::log("Waiting for the bucket to exist"); + $client->waitUntil('bucket_exists', array('Bucket' => $bucket)); + sleep(5); + // Create the bucket + self::log("Getting owner id and display name"); + $result = $client->listBuckets(); + self::$ownerId = $result['Owner']['ID']; + self::$displayName = $result['Owner']['DisplayName']; + } + + public static function tearDownAfterClass() + { + unlink(self::LARGE_OBJECT); + $client = self::getServiceBuilder()->get('s3'); + $bucket = self::getResourcePrefix() . '-s3-test'; + self::log("Clearing the contents of the {$bucket} bucket"); + // Delete the bucket + $clear = new ClearBucket($client, $bucket); + $clear->clear(); + self::log("Deleting the {$bucket} bucket"); + $client->deleteBucket(array('Bucket' => $bucket)); + self::log("Waiting for {$bucket} to not exist"); + $client->waitUntil('bucket_not_exists', array('Bucket' => $bucket)); + // Delete the other bucket + $bucket = self::getResourcePrefix() . '_path'; + $clear = new ClearBucket($client, $bucket); + $clear->clear(); + self::log("Deleting the {$bucket} bucket"); + $client->deleteBucket(array('Bucket' => $bucket)); + self::log("Waiting for {$bucket} to not exist"); + $client->waitUntil('bucket_not_exists', array('Bucket' => $bucket)); + } + + public function setUp() + { + $this->bucket = self::getResourcePrefix() . '-s3-test'; + $this->client = $this->getServiceBuilder()->get('s3', true); + $this->acp = AcpBuilder::newInstance() + ->setOwner(self::$ownerId, self::$displayName) + ->addGrantForGroup(Permission::READ, Group::AUTHENTICATED_USERS) + ->addGrantForGroup(Permission::READ_ACP, Group::ALL_USERS) + ->build(); + } + + public function testSignsPathBucketsCorrectly() + { + try { + $client = self::getServiceBuilder()->get('s3'); + $bucket = self::getResourcePrefix() . '_path'; + self::log("Creating the {$bucket} bucket"); + $client->createBucket(array('Bucket' => $bucket)); + // Create the bucket + self::log("Waiting for the bucket to exist"); + $client->waitUntil('bucket_exists', array('Bucket' => $bucket)); + $this->client->putObject(array( + 'Bucket' => $bucket, + 'Key' => self::TEST_KEY, + 'Body' => '123' + )); + $this->client->waitUntil('bucket_exists', array('Bucket' => $bucket)); + $this->client->getBucketLocation(array('Bucket' => $bucket)); + } catch (\Aws\S3\Exception\SignatureDoesNotMatchException $e) { + echo $e->getResponse()->getRequest()->getParams()->get('aws.string_to_sign') . "\n"; + echo $e->getResponse() . "\n"; + throw $e; + } + } + + public function testHeadBucket() + { + $result = $this->client->headBucket(array('Bucket' => $this->bucket)); + $this->assertNotNull($result['RequestId']); + } + + /** + * @depends testHeadBucket + */ + public function testGetService() + { + $result = $this->client->listBuckets(); + $this->assertNotEmpty($result['Owner']); + $this->assertNotEmpty($result['Owner']['ID']); + $this->assertNotEmpty($result['Owner']['DisplayName']); + $this->assertNotEmpty($result['Buckets']); + $found = false; + foreach ($result['Buckets'] as $bucket) { + if ($bucket['Name'] == $this->bucket) { + $found = true; + break; + } + } + $this->assertTrue($found); + } + + /** + * @depends testHeadBucket + * @expectedException \Aws\S3\Exception\NoSuchCORSConfigurationException + */ + public function testGetBucketCors() + { + $this->log(__METHOD__); + $this->client->getBucketCors(array('Bucket' => $this->bucket)); + } + + /** + * @depends testHeadBucket + * @expectedException \Aws\S3\Exception\NoSuchLifecycleConfigurationException + */ + public function testGetBucketLifecycle() + { + $this->log(__METHOD__); + $this->client->getBucketLifecycle(array('Bucket' => $this->bucket)); + } + + /** + * @depends testHeadBucket + */ + public function testGetBucketLocation() + { + $this->log(__METHOD__); + $result = $this->client->getBucketLocation(array('Bucket' => $this->bucket)); + $this->assertSame('', $result['Location']); + } + + /** + * @depends testHeadBucket + */ + public function testPutBucketLocation() + { + $this->log(__METHOD__); + $bucketName = self::getResourcePrefix() . '-s3eutest'; + try { + $this->client->headBucket(array('Bucket' => $bucketName)); + } catch (\Exception $e) { + $this->client->createBucket(array( + 'Bucket' => $bucketName, + 'LocationConstraint' => 'EU' + )); + } + $this->client->waitUntil('bucket_exists', array('Bucket' => $bucketName)); + $result = $this->client->getBucketLocation(array('Bucket' => $bucketName)); + $this->assertEquals('EU', $result['Location']); + $this->client->deleteBucket(array('Bucket' => $bucketName)); + } + + /** + * @depends testHeadBucket + */ + public function testGetBucketLogging() + { + $this->log(__METHOD__); + $result = $this->client->getBucketLogging(array('Bucket' => $this->bucket)); + $this->assertNull($result['LoggingEnabled']); + } + + /** + * @depends testHeadBucket + */ + public function testGetBucketNotification() + { + $this->log(__METHOD__); + $this->client->getBucketNotification(array('Bucket' => $this->bucket)); + } + + /** + * @depends testHeadBucket + * @expectedException \Aws\S3\Exception\NoSuchBucketPolicyException + */ + public function testGetBucketPolicy() + { + $this->log(__METHOD__); + $this->client->getBucketPolicy(array('Bucket' => $this->bucket)); + } + + /** + * @depends testHeadBucket + */ + public function testGetBucketRequestPayment() + { + $this->log(__METHOD__); + $result = $this->client->getBucketRequestPayment(array('Bucket' => $this->bucket)); + $this->assertEquals('BucketOwner', $result['Payer']); + } + + /** + * @depends testHeadBucket + */ + public function testGetBucketVersioning() + { + $this->log(__METHOD__); + $this->client->getBucketVersioning(array('Bucket' => $this->bucket)); + } + + /** + * @depends testHeadBucket + * @expectedException \Aws\S3\Exception\NoSuchWebsiteConfigurationException + */ + public function testGetBucketWebsite() + { + $this->log(__METHOD__); + $this->client->getBucketWebsite(array('Bucket' => $this->bucket)); + } + + /** + * @depends testHeadBucket + */ + public function testPutAndListObjects() + { + $this->client->waitUntil('bucket_exists', array('Bucket' => $this->bucket)); + $command = $this->client->getCommand('PutObject', array( + 'Bucket' => $this->bucket, + 'Key' => self::TEST_KEY, + 'ContentMD5' => true, + 'Body' => 'åbc 123', + 'ContentType' => 'application/foo', + 'ACP' => $this->acp, + 'Metadata' => array( + 'test' => '123', + 'abc' => '@pples', + 'foo' => '', + 'null' => null, + 'space' => ' ', + 'zero' => '0', + 'trim' => ' hi ' + ) + )); + + self::log("Uploading an object"); + $result = $command->execute(); + // make sure the expect header wasn't sent + $this->assertNull($command->getRequest()->getHeader('Expect')); + $this->assertInstanceOf('Guzzle\Service\Resource\Model', $result); + $this->assertNotEmpty($result['ETag']); + $this->client->waitUntil('object_exists', array('Bucket' => $this->bucket, 'Key' => self::TEST_KEY)); + + self::log("HEAD the object"); + $result = $this->client->headObject(array( + 'Bucket' => $this->bucket, + 'Key' => self::TEST_KEY + )); + $this->assertEquals('application/foo', $result['ContentType']); + $this->assertEquals('123', $result['Metadata']['test']); + $this->assertEquals('@pples', $result['Metadata']['abc']); + + // Ensure the object was created correctly + self::log("GETting the object"); + $result = $this->client->getObject(array( + 'Bucket' => $this->bucket, + 'Key' => self::TEST_KEY + )); + $this->assertInstanceOf('Guzzle\Service\Resource\Model', $result); + $this->assertInstanceOf('Guzzle\Http\EntityBody', $result['Body']); + $this->assertEquals('åbc 123', (string) $result['Body']); + $this->assertEquals('application/foo', $result['ContentType']); + $this->assertEquals('123', $result['Metadata']['test']); + $this->assertEquals('@pples', $result['Metadata']['abc']); + + // Ensure the object was created and we can find it in the iterator + self::log("Checking if the item is in the ListObjects results"); + $iterator = $this->client->getIterator('ListObjects', array( + 'Bucket' => $this->bucket, + 'Prefix' => self::TEST_KEY + )); + $objects = $iterator->toArray(); + $this->assertEquals(1, count($objects)); + $this->assertEquals('foo', $objects[0]['Key']); + } + + /** + * @depends testPutAndListObjects + * @depends testSignsPathBucketsCorrectly + */ + public function testCanSendRawHttpRequests() + { + $this->client->waitUntil('bucket_exists', array('Bucket' => $this->bucket)); + $this->assertEquals(200, $this->client->get('/')->send()->getStatusCode()); + $this->assertEquals(200, $this->client->put('/' . $this->bucket . '/hello', array(), 'testing')->send()->getStatusCode()); + $this->client->get('/' . self::getResourcePrefix() . '_path')->send(); + $path = self::getResourcePrefix() . '_path/' . self::TEST_KEY; + $this->client->get("/{$path}")->send(); + } + + /** + * @depends testPutAndListObjects + */ + public function testPutObjectAcl() + { + self::log("Setting a custom object ACL"); + $this->client->waitUntil('bucket_exists', array('Bucket' => $this->bucket)); + $command = $this->client->getCommand('PutObjectAcl', array( + 'Bucket' => $this->bucket, + 'Key' => self::TEST_KEY, + 'ACP' => $this->acp + )); + $result = $command->execute(); + $this->assertContains('Grantee', (string) $command->getRequest()->getBody()); + $this->assertEquals(array('RequestId'), array_keys($result->toArray())); + // Ensure that the RequestId model value is being populated correctly + $this->assertEquals((string) $command->getResponse()->getHeader('x-amz-request-id'), $result['RequestId']); + } + + /** + * @depends testPutAndListObjects + */ + public function testGetObjectAcl() + { + self::log("Getting the object's ACL"); + $model = $this->client->getObjectAcl(array( + 'Bucket' => $this->bucket, + 'Key' => self::TEST_KEY + )); + + $data = array(); + foreach (Acp::fromArray($model->toArray()) as $grant) { + $grantee = $grant->getGrantee(); + $data[$grantee->getGroupUri()] = array($grantee->getType(), $grant->getPermission()); + } + + $this->assertEquals(2, count($data)); + $this->assertArrayHasKey('http://acs.amazonaws.com/groups/global/AllUsers', $data); + $this->assertArrayHasKey('http://acs.amazonaws.com/groups/global/AuthenticatedUsers', $data); + $this->assertEquals(array('Group', 'READ_ACP'), $data['http://acs.amazonaws.com/groups/global/AllUsers']); + $this->assertEquals(array('Group', 'READ'), $data['http://acs.amazonaws.com/groups/global/AuthenticatedUsers']); + } + + /** + * @depends testPutAndListObjects + */ + public function testUploadsObjectsWithKeysMatchingBucketName() + { + self::log("Uploading an object with a name the same as the bucket"); + $this->client->waitUntil('bucket_exists', array('Bucket' => $this->bucket)); + $key = $this->bucket . '-foo'; + $command = $this->client->getCommand('PutObject', array( + 'Bucket' => $this->bucket, + 'Key' => $key, + 'Body' => 'hi' + )); + $command->execute(); + $this->assertEquals("/{$this->bucket}-foo", $command->getRequest()->getPath()); + $this->assertEquals("{$this->bucket}.s3.amazonaws.com", $command->getRequest()->getHost()); + $this->client->waitUntil('object_exists', array('Bucket' => $this->bucket, 'Key' => $key)); + } + + /** + * @depends testPutAndListObjects + */ + public function testPutObjectsWithUtf8Keys() + { + self::log("Uploading an object with a UTF-8 key"); + $this->client->waitUntil('bucket_exists', array('Bucket' => $this->bucket)); + $key = 'åbc'; + + try { + $result = $this->client->putObject(array( + 'Bucket' => $this->bucket, + 'Key' => $key, + 'Body' => 'hi' + )); + $this->assertContains($this->bucket, $result['ObjectURL']); + } catch (\Aws\S3\Exception\SignatureDoesNotMatchException $e) { + echo $e->getResponse()->getRequest()->getParams()->get('aws.string_to_sign') . "\n"; + echo $e->getResponse() . "\n"; + throw $e; + } + $this->client->waitUntil('object_exists', array('Bucket' => $this->bucket, 'Key' => $key)); + } + + /** + * @depends testPutAndListObjects + */ + public function testPutObjectGuessesContentType() + { + self::log("Uploading an object and guessing Content-Type"); + $this->client->waitUntil('bucket_exists', array('Bucket' => $this->bucket)); + $key = 'file'; + $command = $this->client->getCommand('PutObject', array( + 'Bucket' => $this->bucket, + 'Key' => $key, + 'Body' => fopen(__FILE__, 'r') + )); + $command->execute(); + $this->assertEquals('text/x-php', (string) $command->getRequest()->getHeader('Content-Type')); + } + + /** + * @depends testPutObjectsWithUtf8Keys + */ + public function testCopiesObjects() + { + self::log("Copying the object"); + $result = $this->client->copyObject(array( + 'Bucket' => $this->bucket, + 'Key' => 'copy-key', + 'CopySource' => $this->bucket . '/' . self::TEST_KEY, + 'MetadataDirective' => 'COPY', + 'ServerSideEncryption' => 'AES256' + )); + $this->assertNotEmpty($result['ETag']); + $this->assertEquals('AES256', $result['ServerSideEncryption']); + $this->assertNotEmpty($result['LastModified']); + $this->client->waitUntil('object_exists', array('Bucket' => $this->bucket, 'Key' => 'copy-key')); + } + + /** + * @depends testPutObjectsWithUtf8Keys + */ + public function testMultipartUploads() + { + $this->client->waitUntil('bucket_exists', array('Bucket' => $this->bucket)); + $this->log('Initiating an upload'); + $result = $this->client->createMultipartUpload(array( + 'Bucket' => $this->bucket, + 'Key' => 'big', + 'Metadata' => array('foo' => 'bar') + )); + $this->assertNotEmpty($result['UploadId']); + $this->assertNotEmpty($result['Key']); + $this->assertNotEmpty($result['Bucket']); + $uploadId = $result['UploadId']; + sleep(1); + + $this->log('Getting uploads'); + $command = $this->client->getCommand('ListMultipartUploads', array( + 'Bucket' => $this->bucket, + 'UploadId' => $uploadId + )); + $result = $command->execute(); + $this->assertEquals($this->bucket, $result['Bucket']); + $this->assertInternalType('array', $result['Uploads']); + $this->assertSame(false, $result['IsTruncated']); + $this->log('Aborting the upload'); + sleep(2); + $this->client->waitUntil('bucket_exists', array('Bucket' => $this->bucket)); + $command = $this->client->getCommand('AbortMultipartUpload', array( + 'Bucket' => $this->bucket, + 'Key' => 'big', + 'UploadId' => $uploadId + )); + $result = $command->execute(); + $this->assertEquals(array('RequestId'), array_keys($result->toArray())); + } + + /** + * @depends testPutAndListObjects + */ + public function testPutBucketTagging() + { + self::log("Adding tags to a bucket"); + $this->client->waitUntil('bucket_exists', array('Bucket' => $this->bucket)); + $command = $this->client->getCommand('PutBucketTagging', array( + 'Bucket' => $this->bucket, + 'TagSet' => array( + array( + 'Key' => 'Foo', + 'Value' => 'Bar' + ), + array( + 'Key' => 'Baz', + 'Value' => 'Boo' + ) + ) + )); + $command->execute(); + $this->assertNull($command->getRequest()->getHeader('Expect')); + } + + /** + * @depends testPutBucketTagging + */ + public function testGetBucketTagging() + { + $this->log(__METHOD__); + $result = $this->client->getBucketTagging(array('Bucket' => $this->bucket)); + $this->assertNotEmpty($result['TagSet']); + } + + public function testPostObjectProducesCorrectParametersForPost() + { + $key = 'dummy.txt'; + + // Create the PostObject and fetch the data + $post = new PostObject($this->client, $this->bucket); + $post->prepareData(); + $form = $post->getFormAttributes(); + $data = $post->getFormInputs(); + + // Use Guzzle to simulate a browser POST upload to S3 + $http = new Client(array('ssl.certificate_authority' => false)); + /** @var $response \Guzzle\Http\Message\Response */ + $response = $http->post($form['action'], null, $data) + ->addPostFiles(array('file' => __DIR__ . DIRECTORY_SEPARATOR . $key)) + ->send(); + + // Verify that the response is as expected + $this->assertEquals(204, $response->getStatusCode()); + $this->assertEquals("https://{$this->bucket}.s3.amazonaws.com/{$key}", $response->getLocation()); + + // Delete the object + $this->client->deleteObject(array('Bucket' => $this->bucket, 'Key' => $key)); + } + + public function testUsesTieredStorage() + { + self::log("Uploading an object then placing in Glacier"); + $this->client->waitUntil('bucket_exists', array('Bucket' => $this->bucket)); + $key = 'abc'; + $this->client->putObject(array( + 'Bucket' => $this->bucket, + 'Key' => $key, + 'Body' => 'hi' + )); + self::log("Waiting until the object exists"); + $this->client->waitUntil('object_exists', array('Bucket' => $this->bucket, 'Key' => $key)); + self::log("Moving the object to glacier by setting a lifecycle policy on the object"); + $this->client->waitUntil('bucket_exists', array('Bucket' => $this->bucket)); + $command = $this->client->getCommand('PutBucketLifecycle', array( + 'Bucket' => $this->bucket, + 'Rules' => array( + array( + 'ID' => 'foo-rule', + 'Status' => 'Enabled', + 'Prefix' => 'a', + 'Transition' => array( + 'Days' => 0, + 'StorageClass' => 'GLACIER' + ) + ) + ) + )); + + $result = $command->execute(); + $this->assertNotNull($result['RequestId']); + $this->assertContains( + '0GLACIER', + (string) $command->getRequest() + ); + } + + public function testMultipartUpload() + { + $this->client->waitUntil('bucket_exists', array('Bucket' => $this->bucket)); + self::log('Creating a 100MB object in /tmp/large-object.jpg'); + $handle = fopen('/tmp/large-object.jpg', 'w+'); + $part = str_repeat('.', 1000); + for ($i = 0; $i < (1024 * 1024 * 5) / 1000; $i++) { + fwrite($handle, $part); + } + fclose($handle); + + $history = new HistoryPlugin(); + $this->client->addSubscriber($history); + + self::log('Initiating transfer'); + $transfer = UploadBuilder::newInstance() + ->setBucket($this->bucket) + ->setKey('large_key') + ->setSource(self::LARGE_OBJECT) + ->calculateMd5(true) + ->calculatePartMd5(true) + ->setOption('ACL', 'public-read') + ->setClient($this->client) + ->build(); + + $this->assertEquals(1, $history->count()); + $this->assertTrue($history->getLastRequest()->getQuery()->hasKey('uploads')); + $this->assertEquals('image/jpeg', (string) $history->getLastRequest()->getHeader('Content-Type')); + $history->clear(); + + self::log('Uploading parts'); + $transfer->upload(); + $this->assertEquals(3, $history->count()); + $requests = $history->getIterator()->getArrayCopy(); + $this->assertEquals('PUT', $requests[0]->getMethod()); + $this->assertEquals('PUT', $requests[1]->getMethod()); + $this->assertEquals('POST', $requests[2]->getMethod()); + } + + public function prefixKeyProvider() + { + return array( + array('foo /baz/bar!', 'foo /baz/bar!', '/foo%20/baz/bar%21'), + array('/foo', 'foo', '/foo') + ); + } + + /** + * @depends testPutAndListObjects + * @dataProvider prefixKeyProvider + */ + public function testWorksWithPrefixKeys($key, $cleaned, $encoded) + { + $this->client->waitUntil('bucket_exists', array('Bucket' => $this->bucket)); + $command = $this->client->getCommand('PutObject', array( + 'Bucket' => $this->bucket, + 'Key' => $key, + 'SourceFile' => __FILE__ + )); + $command->execute(); + // Ensure the path is correct + $this->assertEquals($encoded, $command->getRequest()->getPath()); + // Ensure the key is not an array and is returned to it's previous value + $this->assertEquals($key, $command['Key']); + + $this->client->waitUntil('object_exists', array('Bucket' => $this->bucket, 'Key' => $key)); + $result = $this->client->getObject(array('Bucket' => $this->bucket, 'Key' => $key)); + $this->assertEquals(file_get_contents(__FILE__), (string) $result['Body']); + + // Test using path style hosting + $command = $this->client->getCommand('DeleteObject', array( + 'Bucket' => $this->bucket, + 'Key' => $key, + 'PathStyle' => true + )); + $command->execute(); + $this->assertEquals('/' . $this->bucket . $encoded, $command->getRequest()->getPath()); + } + + /** + * @depends testPutAndListObjects + */ + public function testPreSignedUrlAllowsLiterals() + { + self::log('Uploading an object with a space in the key and literals'); + $this->client->waitUntil('bucket_exists', array('Bucket' => $this->bucket)); + $key = 'foo baz%20bar!'; + $this->client->putObject(array( + 'Bucket' => $this->bucket, + 'Key' => $key, + 'Body' => 'hi' + )); + $this->client->waitUntil('object_exists', array('Bucket' => $this->bucket, 'Key' => $key)); + self::log('Creating an downloading using a pre-signed URL'); + $extra = urlencode("attachment; filename=\"{$key}\""); + $encodedKey = rawurlencode($key); + $request = $this->client->get("{$this->bucket}/{$encodedKey}?response-content-disposition={$extra}"); + $url = $this->client->createPresignedUrl($request, '+10 minutes'); + self::log($url); + $client = new Client(); + $this->assertEquals('hi', file_get_contents($url)); + $this->assertEquals('hi', $client->get($url)->send()->getBody(true)); + } + + /** + * @depends testPutAndListObjects + */ + public function testPreSignedUrlAllowsSpecialCharacters() + { + self::log('Uploading an object with a space in the key'); + $this->client->waitUntil('bucket_exists', array('Bucket' => $this->bucket)); + $key = 'foo baz bar!'; + $this->client->putObject(array( + 'Bucket' => $this->bucket, + 'Key' => $key, + 'Body' => 'hi' + )); + $this->client->waitUntil('object_exists', array('Bucket' => $this->bucket, 'Key' => $key)); + + self::log('Creating an downloading using a pre-signed URL with command'); + $command = $this->client->getCommand('GetObject', array( + 'Bucket' => $this->bucket, + 'Key' => $key + )); + $url = $command->createPresignedUrl('+100 minutes'); + self::log($url); + $this->assertEquals('hi', file_get_contents($url)); + + self::log('Creating an downloading using a pre-signed URL'); + $extra = urlencode("attachment; filename=\"{$key}\""); + $request = $this->client->get("{$this->bucket}/{$key}?response-content-disposition={$extra}"); + $url = $this->client->createPresignedUrl($request, '+10 minutes'); + self::log($url); + $client = new Client(); + $this->assertEquals('hi', file_get_contents($url)); + $this->assertEquals('hi', $client->get($url)->send()->getBody(true)); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Integration/IteratorsTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Integration/IteratorsTest.php new file mode 100644 index 0000000..e0f5753 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Integration/IteratorsTest.php @@ -0,0 +1,192 @@ +getServiceBuilder()->get('s3'); + $mock = $this->setMockResponse($client, array('s3/list_buckets')); + + // Create an iterator that will exercise the most code paths + $iterator = $client->getIterator('ListBuckets', null, array('names_only' => true)); + + // Verify that we got back everything back + $expectedObjects = array('bucket-1', 'bucket-2'); + $this->assertSame($expectedObjects, $iterator->toArray()); + + // Verify that the number of requests are as expected + $requests = $mock->getReceivedRequests(); + $this->assertEquals(1, count($requests)); + $this->assertEquals(1, $iterator->getRequestCount()); + } + + public function testIteratesListObjectsCommand() + { + /** @var $client \Guzzle\Service\ClientInterface */ + $client = $this->getServiceBuilder()->get('s3'); + $mock = $this->setMockResponse($client, array( + 's3/list_objects_page_1', + 's3/list_objects_page_2', + 's3/list_objects_page_3', + 's3/list_objects_page_4', + 's3/list_objects_page_5' + )); + + // Create an iterator that will exercise the most code paths + $iterator = $client->getIterator('ListObjects', array( + 'Bucket' => 'foo', + 'MaxKeys' => 5, + 'Delimiter' => '/' + ), array( + 'page_size' => 2, + 'return_prefixes' => true, + 'names_only' => true, + 'sort_results' => true + )); + + // Verify that we got back everything back + $expectedObjects = array('a/', 'b/', 'c', 'd/', 'e', 'f', 'g/'); + $this->assertSame($expectedObjects, $iterator->toArray()); + + // Verify that 5 HTTP requests were made + $requests = $mock->getReceivedRequests(); + $this->assertEquals(5, count($requests)); + + // Verify that only 4 iterations (not 5) were made + $this->assertEquals(4, $iterator->getRequestCount()); + } + + public function testIteratesGetBucketObjectVersionsCommand() + { + /** @var $client \Guzzle\Service\ClientInterface */ + $client = $this->getServiceBuilder()->get('s3'); + $mock = $this->setMockResponse($client, array( + 's3/get_bucket_object_versions_page_1', + 's3/get_bucket_object_versions_page_2' + )); + + // Create an iterator that will exercise the most code paths + $iterator = $client->getIterator('ListObjectVersions', array( + 'Bucket' => 'bucket-1', + 'Delimiter' => '/' + ), array( + 'return_prefixes' => true + )); + + // Verify that we got back everything back + $actualKeys = array(); + $expectedKeys = array( + 'key-1|version-id-1', + 'key-2|version-id-1', + 'key-1|version-id-2', + 'key-2|version-id-2', + 'prefix-1/', + 'prefix-2/' + ); + foreach ($iterator as $item) { + if (isset($item['Key'])) { + $actualKeys[] = "$item[Key]|$item[VersionId]"; + } else { + $actualKeys[] = $item['Prefix']; + } + } + $this->assertSame($expectedKeys, $actualKeys); + + // Verify that the number of requests are as expected + $requests = $mock->getReceivedRequests(); + $this->assertEquals(2, count($requests)); + $this->assertEquals(1, $iterator->getRequestCount()); + } + + public function testIteratesListPartsCommand() + { + /** @var $client \Guzzle\Service\ClientInterface */ + $client = $this->getServiceBuilder()->get('s3'); + $mock = $this->setMockResponse($client, array( + 's3/list_parts_page_1', + 's3/list_parts_page_2' + )); + + // Create an iterator that will exercise the most code paths + $iterator = $client->getIterator('ListParts', array( + 'Bucket' => 'bucket-1', + 'Key' => 'object-1', + 'UploadId' => 'upload-id-1', + )); + + // Verify that we got back everything back + $actualParts = array(); + $expectedParts = array(1, 2); + foreach ($iterator as $part) { + $actualParts[] = (int) $part['PartNumber']; + } + $this->assertSame($expectedParts, $actualParts); + + // Verify that the number of requests are as expected + $requests = $mock->getReceivedRequests(); + $this->assertEquals(2, count($requests)); + $this->assertEquals(1, $iterator->getRequestCount()); + } + + public function testIteratesListMultipartUploadsCommand() + { + /** @var $client \Guzzle\Service\ClientInterface */ + $client = $this->getServiceBuilder()->get('s3'); + $mock = $this->setMockResponse($client, array( + 's3/list_multipart_uploads_page_1', + 's3/list_multipart_uploads_page_2' + )); + + // Create an iterator that will exercise the most code paths + $iterator = $client->getIterator('ListMultipartUploads', array( + 'Bucket' => 'bucket-1', + 'Delimiter' => '/' + ), array( + 'return_prefixes' => true + )); + + // Verify that we got back everything back + $actualUploads = array(); + $expectedUploads = array( + 'object-1|upload-id-1', + 'object-1|upload-id-2', + 'object-2|upload-id-1', + 'object-2|upload-id-2', + 'prefix-1/', + 'prefix-2/' + ); + foreach ($iterator as $upload) { + if (isset($upload['Key'])) { + $actualUploads[] = "$upload[Key]|$upload[UploadId]"; + } else { + $actualUploads[] = $upload['Prefix']; + } + } + $this->assertSame($expectedUploads, $actualUploads); + + // Verify that the number of requests are as expected + $requests = $mock->getReceivedRequests(); + $this->assertEquals(2, count($requests)); + $this->assertEquals(1, $iterator->getRequestCount()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Integration/S3_20060301_Test.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Integration/S3_20060301_Test.php new file mode 100644 index 0000000..805224c --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Integration/S3_20060301_Test.php @@ -0,0 +1,653 @@ +get('s3', true); + $client->setRegion('us-west-2'); + + // Delete the bucket if it exists + try { + self::log('Clearing bucket ' . $bucket); + $clear = new ClearBucket($client, $bucket); + $clear->clear(); + self::log('Deleting bucket'); + $client->deleteBucket(array('Bucket' => $bucket)); + self::log('Bucket deleted'); + } catch (\Exception $e) { + self::log($e->getMessage()); + } + + // Wait until the bucket does not exist before starting the test + self::log('Waiting until the bucket does not exist and sleeping for a few seconds'); + $client->waitUntilBucketNotExists(array('Bucket' => $bucket)); + sleep(5); + self::log('Beginning test'); + } + + public function setUp() + { + $this->client = $this->getServiceBuilder()->get('s3', true); + $this->bucket = self::getResourcePrefix() . '-s3-test'; + $this->client->setRegion('us-west-2'); + } + + /** + * Create an Amazon S3 bucket + * + * @expectedException \Aws\S3\Exception\BucketAlreadyExistsException + * @example Aws\S3\S3Client::createBucket + */ + public function testBucketAlreadyExists() + { + $client = $this->client; + $client->setRegion('us-east-1'); + // @begin + + $client->createBucket(array('Bucket' => 'mybucket')); + } + + /** + * Create a bucket in a specific region + * + * @depends testBucketAlreadyExists + * @example Aws\S3\S3Client::createBucket + */ + public function testCreateBucketInRegion() + { + $client = $this->client; + $bucket = $this->bucket; + + // Don't run if the bucket exists + if ($client->doesBucketExist($bucket)) { + return self::log('Bucket already exists'); + } + + // @begin + + // Create a valid bucket and use a LocationConstraint + $result = $client->createBucket(array( + 'Bucket' => $bucket, + 'LocationConstraint' => \Aws\Common\Enum\Region::US_WEST_2 + )); + + // Get the Location header of the response + echo $result['Location'] . "\n"; + + // Get the request ID + echo $result['RequestId'] . "\n"; + + // @end + $this->assertContains($this->bucket, $this->getActualOutput()); + $this->assertNotEmpty($result['RequestId']); + } + + /** + * Poll a bucket until it exists + * + * @depends testCreateBucketInRegion + * @example Aws\S3\S3Client::waitUntilBucketExists + */ + public function testWaitUntilBucketExists() + { + $client = $this->client; + $bucket = $this->bucket; + + // @begin + // Poll the bucket until it is accessible + $client->waitUntil('BucketExists', array('Bucket' => $bucket)); + } + + /** + * Upload an object to a bucket using a string for the object body + * + * @depends testWaitUntilBucketExists + * @example Aws\S3\S3Client::putObject + */ + public function testPutObject() + { + $this->client->waitUntilBucketExists(array('Bucket' => $this->bucket)); + $client = $this->client; + $bucket = $this->bucket; + // @begin + + // Upload an object to Amazon S3 + $result = $client->putObject(array( + 'Bucket' => $bucket, + 'Key' => 'data.txt', + 'Body' => 'Hello!' + )); + + // Access parts of the result object + echo $result['Expiration'] . "\n"; + echo $result['ServerSideEncryption'] . "\n"; + echo $result['ETag'] . "\n"; + echo $result['VersionId'] . "\n"; + echo $result['RequestId'] . "\n"; + + // Get the URL the object can be downloaded from + echo $result['ObjectURL'] . "\n"; + + // @end + $this->assertContains( + 'https://' . $this->bucket . '.s3-us-west-2.amazonaws.com/data.txt', + $this->getActualOutput() + ); + } + + /** + * Upload an object by streaming the contents of a file + * + * @depends testPutObject + * @example Aws\S3\S3Client::putObject + */ + public function testPutObjectFromFile() + { + $this->client->waitUntilBucketExists(array('Bucket' => $this->bucket)); + $client = $this->client; + $bucket = $this->bucket; + $pathToFile = __FILE__; + // @begin + + // Upload an object by streaming the contents of a file + // $pathToFile should be absolute path to a file on disk + $result = $client->putObject(array( + 'Bucket' => $bucket, + 'Key' => 'data_from_file.txt', + 'SourceFile' => $pathToFile, + 'Metadata' => array( + 'Foo' => 'abc', + 'Baz' => '123' + ) + )); + + // We can poll the object until it is accessible + $client->waitUntil('ObjectExists', array( + 'Bucket' => $this->bucket, + 'Key' => 'data_from_file.txt' + )); + + // @end + + // Ensure that the file was uploaded correctly + $this->assertEquals( + file_get_contents(__FILE__), + (string) $client->getObject(array( + 'Bucket' => $this->bucket, + 'Key' => 'data_from_file.txt' + ))->get('Body') + ); + } + + /** + * Upload an object by streaming the contents of a PHP stream + * + * @depends testPutObjectFromFile + * @example Aws\S3\S3Client::putObject + */ + public function testPutObjectFromStream() + { + $this->client->waitUntilBucketExists(array('Bucket' => $this->bucket)); + $client = $this->client; + $bucket = $this->bucket; + $pathToFile = __FILE__; + // @begin + + // Upload an object by streaming the contents of a PHP stream. + // Note: You must supply a "ContentLength" parameter to an + // operation if the steam does not respond to fstat() or if the + // fstat() of stream does not provide a valid the 'size' attribute. + // For example, the "http" stream wrapper will require a ContentLength + // parameter because it does not respond to fstat(). + $client->putObject(array( + 'Bucket' => $bucket, + 'Key' => 'data_from_stream.txt', + 'Body' => fopen($pathToFile, 'r+') + )); + + // @end + $client->waitUntilObjectExists(array( + 'Bucket' => $this->bucket, + 'Key' => 'data_from_stream.txt' + )); + + // Ensure that the file was uploaded correctly + $this->assertEquals( + file_get_contents(__FILE__), + (string) $client->getObject(array( + 'Bucket' => $this->bucket, + 'Key' => 'data_from_stream.txt' + ))->get('Body') + ); + } + + /** + * Upload an object by streaming the contents of a Guzzle\Http\EntityBodyInterface object + * + * @depends testPutObjectFromStream + * @example Aws\S3\S3Client::putObject + */ + public function testPutObjectFromEntityBody() + { + $this->client->waitUntilBucketExists(array('Bucket' => $this->bucket)); + $client = $this->client; + $bucket = $this->bucket; + $pathToFile = __FILE__; + // @begin + + // Be sure to add a use statement at the beginning of you script: + // use Guzzle\Http\EntityBody; + + // Upload an object by streaming the contents of an EntityBody object + $client->putObject(array( + 'Bucket' => $bucket, + 'Key' => 'data_from_entity_body.txt', + 'Body' => EntityBody::factory(fopen($pathToFile, 'r+')) + )); + + // @end + $client->waitUntilObjectExists(array( + 'Bucket' => $this->bucket, + 'Key' => 'data_from_entity_body.txt' + )); + + // Ensure that the file was uploaded correctly + $this->assertEquals( + file_get_contents(__FILE__), + (string) $client->getObject(array( + 'Bucket' => $this->bucket, + 'Key' => 'data_from_entity_body.txt' + ))->get('Body') + ); + } + + /** + * Send a ListBuckets request + * + * @depends testPutObjectFromEntityBody + * @example Aws\S3\S3Client::listBuckets + */ + public function testListBuckets() + { + $this->client->waitUntilBucketExists(array('Bucket' => $this->bucket)); + $client = $this->client; + // @begin + + $result = $client->listBuckets(); + + foreach ($result['Buckets'] as $bucket) { + // Each Bucket value will contain a Name and CreationDate + echo "{$bucket['Name']} - {$bucket['CreationDate']}\n"; + } + + // @end + $this->assertContains($this->bucket, $this->getActualOutput()); + } + + /** + * Send a ListBuckets request and use the getPath() method to grab nested data from the response model + * + * @depends testListBuckets + * @example Aws\S3\S3Client::listBuckets + */ + public function testListBucketsWithGetPath() + { + $this->client->waitUntilBucketExists(array('Bucket' => $this->bucket)); + $client = $this->client; + // @begin + + // Grab the nested Owner/ID value from the result model using getPath() + $result = $client->listBuckets(); + echo $result->getPath('Owner/ID') . "\n"; + + // @end + $this->assertNotEmpty($this->getActualOutput()); + } + + /** + * List all objects in a bucket using a ListObjects iterator + * + * @depends testListBucketsWithGetPath + * @example Aws\S3\S3Client::listObjects + */ + public function testListObjectsWithIterator() + { + $this->client->waitUntilBucketExists(array('Bucket' => $this->bucket)); + $client = $this->client; + $bucket = $this->bucket; + // @begin + + $iterator = $client->getIterator('ListObjects', array( + 'Bucket' => $bucket + )); + + foreach ($iterator as $object) { + echo $object['Key'] . "\n"; + } + + // @end + + // Ensure that the objects that have been uploaded so far are in the results + $this->assertContains('data_from_entity_body.txt', $this->getActualOutput()); + $this->assertContains('data_from_stream.txt', $this->getActualOutput()); + $this->assertContains('data.txt', $this->getActualOutput()); + } + + /** + * Get an object from a bucket + * + * @depends testListObjectsWithIterator + * @example Aws\S3\S3Client::getObject + */ + public function testGetObject() + { + $this->client->waitUntilBucketExists(array('Bucket' => $this->bucket)); + $client = $this->client; + $bucket = $this->bucket; + // @begin + + // Get an object using the getObject operation + $result = $client->getObject(array( + 'Bucket' => $bucket, + 'Key' => 'data.txt' + )); + + // The 'Body' value of the result is an EntityBody object + echo get_class($result['Body']) . "\n"; + // > Guzzle\Http\EntityBody + + // The 'Body' value can be cast to a string + echo $result['Body'] . "\n"; + // > Hello! + + // @end + $this->assertEquals("Guzzle\\Http\\EntityBody\nHello!\n", $this->getActualOutput()); + } + + /** + * Get an object from a bucket and interact with the body of the object + * + * @depends testGetObject + * @example Aws\S3\S3Client::getObject + */ + public function testGetObjectUsingEntityBody() + { + $this->client->waitUntilBucketExists(array('Bucket' => $this->bucket)); + $client = $this->client; + $bucket = $this->bucket; + + // Get an object using the getObject operation + $result = $client->getObject(array( + 'Bucket' => $bucket, + 'Key' => 'data.txt' + )); + + // @begin + + // Seek to the beginning of the stream + $result['Body']->rewind(); + + // Read the body off of the underlying stream in chunks + while ($data = $result['Body']->read(1024)) { + echo $data; + } + + // Cast the body to a primitive string + // Warning: This loads the entire contents into memory! + $bodyAsString = (string) $result['Body']; + + // @end + $this->assertEquals('Hello!', $this->getActualOutput()); + $this->assertEquals('Hello!', $bodyAsString); + } + + /** + * Get an object from a bucket and save the object directly to a file + * + * @depends testGetObjectUsingEntityBody + * @example Aws\S3\S3Client::getObject + */ + public function testGetObjectWithSaveAs() + { + $this->client->waitUntilBucketExists(array('Bucket' => $this->bucket)); + $client = $this->client; + $bucket = $this->bucket; + // @begin + + $result = $client->getObject(array( + 'Bucket' => $bucket, + 'Key' => 'data.txt', + 'SaveAs' => '/tmp/data.txt' + )); + + // Contains an EntityBody that wraps a file resource of /tmp/data.txt + echo $result['Body']->getUri() . "\n"; + // > /tmp/data.txt + + // @end + $this->assertEquals("/tmp/data.txt\n", $this->getActualOutput()); + } + + /** + * Create a presigned URL with a command object + * + * @depends testGetObjectWithSaveAs + * @example Aws\S3\S3Client::createPresignedUrl + * @example Aws\S3\Command\S3Command::createPresignedUrl + */ + public function testCreatePresignedUrlFromCommand() + { + $this->client->waitUntilBucketExists(array('Bucket' => $this->bucket)); + $client = $this->client; + $bucket = $this->bucket; + // @begin + + // Get a command object from the client and pass in any options + // available in the GetObject command (e.g. ResponseContentDisposition) + $command = $client->getCommand('GetObject', array( + 'Bucket' => $bucket, + 'Key' => 'data.txt', + 'ResponseContentDisposition' => 'attachment; filename="data.txt"' + )); + + // Create a signed URL from the command object that will last for + // 10 minutes from the current time + $signedUrl = $command->createPresignedUrl('+10 minutes'); + + echo file_get_contents($signedUrl); + // > Hello! + + // @end + $this->assertEquals('Hello!', $this->getActualOutput()); + } + + /** + * Create a presigned URL from a custom request object + * + * @depends testCreatePresignedUrlFromCommand + * @example Aws\S3\S3Client::createPresignedUrl + */ + public function testCreatePresignedUrl() + { + $this->client->waitUntilBucketExists(array('Bucket' => $this->bucket)); + $client = $this->client; + $bucket = $this->bucket; + // @begin + + $key = 'data.txt'; + $url = "{$bucket}/{$key}"; + + // get() returns a Guzzle\Http\Message\Request object + $request = $client->get($url); + + // Create a signed URL from a completely custom HTTP request that + // will last for 10 minutes from the current time + $signedUrl = $client->createPresignedUrl($request, '+10 minutes'); + + echo file_get_contents($signedUrl); + // > Hello! + + // @end + $this->assertEquals('Hello!', $this->getActualOutput()); + } + + /** + * Create plain and presigned URLs for an object + * + * @depends testCreatePresignedUrl + * @example Aws\S3\S3Client::getObjectUrl + */ + public function testGetObjectUrl() + { + $this->client->waitUntilBucketExists(array('Bucket' => $this->bucket)); + $client = $this->client; + $bucket = $this->bucket; + // @begin + + // Get a plain URL for an Amazon S3 object + $plainUrl = $client->getObjectUrl($bucket, 'data.txt'); + // > https://my-bucket.s3.amazonaws.com/data.txt + + // Get a pre-signed URL for an Amazon S3 object + $signedUrl = $client->getObjectUrl($bucket, 'data.txt', '+10 minutes'); + // > https://my-bucket.s3.amazonaws.com/data.txt?AWSAccessKeyId=[...]&Expires=[...]&Signature=[...] + + // Create a vanilla Guzzle HTTP client for accessing the URLs + $http = new \Guzzle\Http\Client; + + // Try to get the plain URL. This should result in a 403 since the object is private + try { + $response = $http->get($plainUrl)->send(); + } catch (\Guzzle\Http\Exception\ClientErrorResponseException $e) { + $response = $e->getResponse(); + } + echo $response->getStatusCode(); + // > 403 + + // Get the contents of the object using the pre-signed URL + $response = $http->get($signedUrl)->send(); + echo $response->getBody(); + // > Hello! + + // @end + $this->assertEquals('403Hello!', $this->getActualOutput()); + } + + /** + * Create presigned URLs for an object with temporary credentials + * + * @depends testGetObjectUrl + * @example Aws\S3\S3Client::getObjectUrl + */ + public function testGetObjectUrlWithSessionCredentials() + { + $this->client->waitUntilBucketExists(array('Bucket' => $this->bucket)); + $bucket = $this->bucket; + /** @var $stsClient \Aws\Sts\StsClient */ + $stsClient = $this->getServiceBuilder()->get('sts'); + // @begin + + // Create a credentials object using temporary credentials retrieved from STS + $tempCredentials = $stsClient->createCredentials($stsClient->getSessionToken()); + + // Create an S3 client using the temporary credentials + $s3Client = \Aws\S3\S3Client::factory()->setCredentials($tempCredentials); + + // Get a presigned URL for an Amazon S3 object + $signedUrl = $s3Client->getObjectUrl($bucket, 'data.txt', '+10 minutes'); + + echo file_get_contents($signedUrl); + // > Hello! + + // @end + $this->assertEquals('Hello!', $this->getActualOutput()); + } + + /** + * Create a presigned URL with a command object that has x-amz-* headers. + * + * @depends testGetObjectWithSaveAs + */ + public function testCreatePresignedUrlWithAcl() + { + $this->client->waitUntilBucketExists(array('Bucket' => $this->bucket)); + $client = $this->client; + $bucket = $this->bucket; + + $command = $client->getCommand('PutObject', array( + 'Bucket' => $bucket, + 'Key' => 'preput', + 'ACL' => 'public-read', + 'Content-Type' => 'plain/text', + 'Body' => '' + )); + + $signedUrl = $command->createPresignedUrl('+10 minutes'); + + $ch = curl_init($signedUrl); + curl_setopt($ch, CURLOPT_HTTPHEADER, array( + 'Content-Type: plain/text' + )); + curl_setopt($ch, CURLOPT_CUSTOMREQUEST, 'PUT'); + curl_setopt($ch, CURLOPT_POSTFIELDS, 'abc123'); + curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); + curl_exec($ch); + } + + /** + * Clear the contents and delete a bucket + * + * @depends testGetObjectUrlWithSessionCredentials + * @example Aws\S3\S3Client::clearBucket + * @example Aws\S3\S3Client::deleteBucket + * @example Aws\S3\S3Client::waitUntilBucketNotExists + */ + public function testCleanUpBucket() + { + $client = $this->client; + $bucket = $this->bucket; + $client->waitUntilBucketExists(array('Bucket' => $bucket)); + // @begin + + // Delete the objects in the bucket before attempting to delete + // the bucket + $clear = new ClearBucket($client, $bucket); + $clear->clear(); + + // Delete the bucket + $client->deleteBucket(array('Bucket' => $bucket)); + + // Wait until the bucket is not accessible + $client->waitUntilBucketNotExists(array('Bucket' => $bucket)); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Integration/StreamWrapperTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Integration/StreamWrapperTest.php new file mode 100644 index 0000000..2cb4041 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Integration/StreamWrapperTest.php @@ -0,0 +1,326 @@ +doesBucketExist($bucket)) { + self::log($bucket . ' exists... Deleting'); + $client->clearBucket($bucket); + $client->deleteBucket(array('Bucket' => $bucket)); + self::log($bucket . ' deleted'); + return true; + } + + return false; + } + + public static function setUpBeforeClass() + { + $bucket = self::getResourcePrefix() . 'stream'; + $client = self::getServiceBuilder()->get('s3', true); + $client->registerStreamWrapper(); + if (self::cleanup($client, $bucket)) { + sleep(10); + } + self::log('Creating bucket ' . $bucket); + mkdir('s3://' . $bucket); + sleep(3); + } + + public static function tearDownAfterClass() + { + $bucket = self::getResourcePrefix() . 'stream'; + $client = self::getServiceBuilder()->get('s3', true); + self::cleanup($client, $bucket); + } + + public function setUp() + { + $this->bucket = $this->getResourcePrefix() . 'stream'; + $client = self::getServiceBuilder()->get('s3'); + $client->waitUntilBucketExists(array('Bucket' => $this->bucket)); + } + + public function testChecksIfThingsExist() + { + $this->assertTrue(is_dir('s3://' . $this->bucket . '/')); + $this->assertFalse(is_dir('s3://wefwefwe' . $this->bucket)); + $this->assertFalse(is_file('s3://wefwefwe' . $this->bucket . '/wefweewegr')); + } + + public function testMkdirs() + { + $path = 's3://' . $this->bucket . '/subdir'; + $this->assertTrue(mkdir($path)); + sleep(1); + $this->assertTrue(is_dir($path)); + unlink($path); + } + + /** + * @depends testChecksIfThingsExist + */ + public function testUploadsFile() + { + self::log('Uploading a simple file'); + $path = $this->getKey('simple'); + file_put_contents($path, 'testing!'); + $this->assertEquals('testing!', file_get_contents($path)); + + return $path; + } + + /** + * @depends testUploadsFile + */ + public function testDoesFileExist($path) + { + $this->assertTrue(file_exists($path)); + $this->assertTrue(is_file($path)); + + return $path; + } + + /** + * @depends testDoesFileExist + */ + public function testDeletesFiles($path) + { + unlink($path); + sleep(1); + $this->assertFalse(file_exists($path)); + } + + /** + * @depends testDoesFileExist + */ + public function testOpensStreams() + { + self::log('Testing streaming'); + $path = $this->getKey('stream'); + file_put_contents($path, 'testing'); + $h = fopen($path, 'r'); + $this->assertEquals('te', fread($h, 2)); + $this->assertEquals('sting', fread($h, 1000)); + $stat = fstat($h); + $this->assertEquals(7, $stat['size']); + fclose($h); + } + + /** + * @depends testOpensStreams + */ + public function testDoesNotRaiseErrorForMissingFile() + { + self::log('Testing invalid file'); + $this->assertFalse(is_file('s3://ewfwefwfeweff/' . uniqid('foo'))); + $this->assertFalse(is_link('s3://ewfwefwfeweff/' . uniqid('foo'))); + try { + lstat('s3://ewfwefwfeweff/' . uniqid('foo')); + $this->fail('Did not trigger a warning'); + } catch (\PHPUnit_Framework_Error_Warning $e) {} + } + + /** + * @depends testOpensStreams + */ + public function testUploadsDir() + { + self::log('Uploading test directory under a prefix'); + $client = self::getServiceBuilder()->get('s3', true); + $client->uploadDirectory(dirname(__DIR__), $this->bucket, 'foo', array('debug' => true)); + sleep(5); + $path = 's3://' . $this->bucket; + $this->assertContains('foo', scandir($path)); + + return $path . '/foo'; + } + + /** + * @depends testUploadsDir + */ + public function testNoTrailingSlashes($path) + { + $results = scandir($path); + $this->assertNotEmpty($results); + // Ensure trailing slashes are not added + foreach ($results as $f) { + $this->assertNotContains('/', $f); + } + } + + /** + * @depends testUploadsDir + */ + public function testUploadsRelativeDir() + { + $dir = getcwd(); + chdir(__DIR__); + self::log('Uploading test directory under a prefix using a relative dir'); + $client = self::getServiceBuilder()->get('s3', true); + $client->uploadDirectory('../Exception', $this->bucket, 'rel-foo', array('debug' => true)); + $path = 's3://' . $this->bucket . '/rel-foo'; + $this->assertContains('Parser', scandir($path)); + chdir($dir); + } + + /** + * @depends testUploadsRelativeDir + */ + public function testUploadsOnlyChanged() + { + self::log('Upload only what has changed'); + $debug = fopen('php://temp', 'r+'); + $client = self::getServiceBuilder()->get('s3', true); + $client->uploadDirectory(__DIR__ . '/', $this->bucket, '', array('debug' => $debug)); + rewind($debug); + $this->assertNotEmpty(stream_get_contents($debug)); + fclose($debug); + $debug = fopen('php://temp', 'r+'); + $client->uploadDirectory(__DIR__ . '/', $this->bucket, '', array('debug' => $debug)); + rewind($debug); + $this->assertEmpty(stream_get_contents($debug)); + } + + /** + * @depends testUploadsRelativeDir + */ + public function testUploadsOnlyChangedWithPrefix() + { + self::log('Upload only what has changed with prefix'); + $client = self::getServiceBuilder()->get('s3', true); + + $debug = fopen('php://temp', 'r+'); + $client->uploadDirectory(__DIR__, $this->bucket, 'splat', array('debug' => $debug)); + rewind($debug); + $contents = stream_get_contents($debug); + $this->assertNotEmpty($contents); + fclose($debug); + + $debug = fopen('php://temp', 'r+'); + $client->uploadDirectory(__DIR__, $this->bucket, 'splat', array('debug' => $debug)); + rewind($debug); + $contents = stream_get_contents($debug); + $this->assertEmpty($contents, 'Not empty: ' . $contents); + fclose($debug); + } + + /** + * Ensures that the list of files returned from S3 is equal to the local list of files + * + * @depends testUploadsDir + */ + public function testCanRecursivelyListFiles($path) + { + $testFiles = $this->getTestFiles(dirname(__DIR__)); + sort($testFiles); + $s3Files = $this->getS3Files('foo'); + sort($s3Files); + $this->assertEquals(array_values($testFiles), array_values($s3Files)); + } + + /** + * @depends testCanRecursivelyListFiles + */ + public function testCanDownloadByPrefix() + { + self::log('Downloading test directory under a prefix'); + $client = self::getServiceBuilder()->get('s3', true); + exec('rm -rf /tmp/swtest'); + $client->downloadBucket('/tmp/swtest', $this->bucket, 'foo', array('debug' => true)); + $expected = $this->getTestFiles(dirname(__DIR__)); + foreach ($testFiles = $this->getTestFiles('/tmp/swtest') as $i => $file) { + $this->assertStringStartsWith('/foo/', $file); + $this->assertContains($expected[$i], $file); + unlink('/tmp/swtest' . $file); + } + } + + /** + * @depends testCanRecursivelyListFiles + */ + public function testCanDownloadToRelativeDir() + { + $dir = getcwd(); + chdir(__DIR__); + self::log('Downloading test directory under a prefix'); + $client = self::getServiceBuilder()->get('s3', true); + $client->downloadBucket('../streamtest', $this->bucket, 'foo/Exception/', array('debug' => true)); + $expected = $this->getTestFiles(dirname(__DIR__) . '/Exception'); + foreach ($testFiles = $this->getTestFiles('../streamtest') as $i => $file) { + $this->assertStringStartsWith('/foo/', $file); + $this->assertContains($expected[$i], $file); + $this->assertFileExists(realpath('../streamtest' . $file)); + unlink('../streamtest' . $file); + } + chdir($dir); + } + + public function testCanListWithEmptyDirs() + { + $file = 's3://' . $this->bucket . '/empty/'; + file_put_contents($file, ''); + file_put_contents($file . 'bar', 'hello'); + $this->assertEquals(array('bar'), scandir($file)); + } + + private function getS3Files($prefix) + { + $path = 's3://' . $this->bucket; + if ($prefix) { + $path .= '/' . $prefix; + } + + return array_values(array_map(function ($f) use ($path) { + return str_replace($path, '', $f); + }, iterator_to_array( + new \RecursiveIteratorIterator( + new \RecursiveDirectoryIterator( + $path, + \RecursiveDirectoryIterator::SKIP_DOTS + ) + ) + ))); + } + + private function getTestFiles($dir) + { + return array_values(array_map(function ($f) use ($dir) { + return str_replace($dir, '', $f); + }, iterator_to_array( + new \RecursiveIteratorIterator( + new \RecursiveDirectoryIterator( + $dir, + \RecursiveDirectoryIterator::SKIP_DOTS + ) + ) + ))); + } + + private function getKey($name) + { + return 's3://' . $this->bucket . '/' . $name; + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Integration/dummy.txt b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Integration/dummy.txt new file mode 100644 index 0000000..88f8ce5 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Integration/dummy.txt @@ -0,0 +1 @@ +THIS IS A FILE THAT MY INTEGRATION TEST UPLOADED TO S3 VIA POST. diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Iterator/ListBucketsIteratorTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Iterator/ListBucketsIteratorTest.php new file mode 100644 index 0000000..77fb52b --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Iterator/ListBucketsIteratorTest.php @@ -0,0 +1,47 @@ +getMock('Guzzle\Service\Command\CommandInterface'); + $iterator = new ListBucketsIterator($command, array('names_only' => true)); + $model = new Model(array( + 'Buckets' => array( + array('Name' => 'Foo'), + array('Name' => 'Bar'), + array('Name' => 'Baz'), + ) + )); + + $class = new \ReflectionObject($iterator); + $method = $class->getMethod('handleResults'); + $method->setAccessible(true); + $items = $method->invoke($iterator, $model); + + $this->assertCount(3, $items); + $this->assertEquals(array('Foo', 'Bar', 'Baz'), $items); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Iterator/ListMultipartUploadsIteratorTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Iterator/ListMultipartUploadsIteratorTest.php new file mode 100644 index 0000000..9b3a021 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Iterator/ListMultipartUploadsIteratorTest.php @@ -0,0 +1,46 @@ +getMock('Guzzle\Service\Command\CommandInterface'); + $iterator = new ListMultipartUploadsIterator($command, array( + 'return_prefixes' => true + )); + $model = new Model(array( + 'Uploads' => array(1, 2), + 'CommonPrefixes' => array(3, 4) + )); + + $class = new \ReflectionObject($iterator); + $method = $class->getMethod('handleResults'); + $method->setAccessible(true); + $items = $method->invoke($iterator, $model); + + $this->assertCount(4, $items); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Iterator/ListObjectVersionsIteratorTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Iterator/ListObjectVersionsIteratorTest.php new file mode 100644 index 0000000..e46c678 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Iterator/ListObjectVersionsIteratorTest.php @@ -0,0 +1,47 @@ +getMock('Guzzle\Service\Command\CommandInterface'); + $iterator = new ListObjectVersionsIterator($command, array( + 'return_prefixes' => true + )); + $model = new Model(array( + 'Versions' => array(1, 2), + 'DeleteMarkers' => array(3, 4), + 'CommonPrefixes' => array(5, 6) + )); + + $class = new \ReflectionObject($iterator); + $method = $class->getMethod('handleResults'); + $method->setAccessible(true); + $items = $method->invoke($iterator, $model); + + $this->assertCount(6, $items); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Iterator/ListObjectsIteratorTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Iterator/ListObjectsIteratorTest.php new file mode 100644 index 0000000..6859d68 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Iterator/ListObjectsIteratorTest.php @@ -0,0 +1,61 @@ +getMock('Guzzle\Service\Command\CommandInterface'); + $iterator = new ListObjectsIterator($command, array( + 'names_only' => true, + 'return_prefixes' => true, + 'sort_results' => true, + 'input_token' => 'Marker', + 'output_token' => 'NextMarker', + )); + $model = new Model(array( + 'Contents' => array( + array('Key' => 'Foo'), + array('Key' => 'Bar'), + array('Key' => 'Baz'), + ), + 'CommonPrefixes' => array( + array('Prefix' => 'Fizz'), + array('Prefix' => 'Buzz'), + ) + )); + + $class = new \ReflectionObject($iterator); + $method = $class->getMethod('handleResults'); + $method->setAccessible(true); + $items = $method->invoke($iterator, $model); + + // We should get the names of all objects and prefixes in a sorted array + $this->assertSame(array('Bar', 'Baz', 'Buzz', 'Fizz', 'Foo'), $items, print_r($items, true)); + + // The last key should be set as the NextMarker in the result + $this->assertEquals('Baz', $model->get('NextMarker')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Iterator/OpendirIteratorTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Iterator/OpendirIteratorTest.php new file mode 100644 index 0000000..7e50c96 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Iterator/OpendirIteratorTest.php @@ -0,0 +1,40 @@ +assertInstanceOf('SplFileInfo', $file); + $this->assertContains(__DIR__, (string) $file); + if ($file == __FILE__) { + $found = true; + } + } + $this->assertTrue($found); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/AcpBuilderTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/AcpBuilderTest.php new file mode 100644 index 0000000..03a5c3c --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/AcpBuilderTest.php @@ -0,0 +1,79 @@ +assertSame($builder, $builder->setOwner('1234567890')); + $this->assertInstanceOf( + 'Aws\S3\Model\Grantee', + $this->readAttribute($builder, 'owner') + ); + } + + public function testCanAddUserGrant() + { + $builder = AcpBuilder::newInstance(); + $after = $builder->addGrantForUser(Permission::READ, '12345'); + $this->assertSame($builder, $after); + + $grants = $this->readAttribute($builder, 'grants'); + $this->assertInstanceOf('Aws\S3\Model\Grant', $grants[0]); + $this->assertTrue($grants[0]->getGrantee()->isCanonicalUser()); + } + + public function testCanAddEmailGrant() + { + $builder = AcpBuilder::newInstance(); + $after = $builder->addGrantForEmail(Permission::READ, 'foo@example.com'); + $this->assertSame($builder, $after); + + $grants = $this->readAttribute($builder, 'grants'); + $this->assertInstanceOf('Aws\S3\Model\Grant', $grants[0]); + $this->assertTrue($grants[0]->getGrantee()->isAmazonCustomerByEmail()); + } + + public function testCanAddGroupGrant() + { + $builder = AcpBuilder::newInstance(); + $after = $builder->addGrantForGroup(Permission::READ, Group::ALL_USERS); + $this->assertSame($builder, $after); + + $grants = $this->readAttribute($builder, 'grants'); + $this->assertInstanceOf('Aws\S3\Model\Grant', $grants[0]); + $this->assertTrue($grants[0]->getGrantee()->isGroup()); + } + + public function testCanBuildAnAcp() + { + $acl = AcpBuilder::newInstance()->setOwner('1234567890') + ->addGrantForEmail(Permission::READ, 'foo@example.com') + ->build(); + + $this->assertInstanceOf('Aws\S3\Model\Acp', $acl); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/AcpTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/AcpTest.php new file mode 100644 index 0000000..e04fe08 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/AcpTest.php @@ -0,0 +1,286 @@ +getMockBuilder('Aws\S3\Model\Grantee') + ->disableOriginalConstructor() + ->getMock(); + $owner->expects($this->any()) + ->method('isCanonicalUser') + ->will($this->returnValue(true)); + + return $owner; + } + + protected function getMockedGrants($count) + { + $grant = $this->getMockBuilder('Aws\S3\Model\Grant') + ->disableOriginalConstructor() + ->getMock(); + $grant->expects($this->any()) + ->method('toArray') + ->will($this->returnValue(array())); + + $grants = array(); + for ($i = 0; $i < $count; $i++) { + $grants[] = clone $grant; + } + + return $grants; + } + + public function testCanConstructAcpAndGetValues() + { + $owner = $this->getMockedOwner(); + $grants = $this->getMockedGrants(3); + + $acp = new Acp($owner, $grants); + $this->assertSame($owner, $acp->getOwner()); + $this->assertInstanceOf('SplObjectStorage', $acp->getGrants()); + $this->assertInstanceOf('SplObjectStorage', $acp->getIterator()); + $this->assertEquals(3, count($acp)); + } + + public function testCanSetGrantsWithTraversable() + { + $owner = $this->getMockedOwner(); + $grants = new \ArrayObject(); + + for ($i = 0; $i < 3; $i++) { + $grants->append($this->getMockBuilder('Aws\S3\Model\Grant') + ->disableOriginalConstructor() + ->getMock() + ); + } + + $acp = new Acp($owner); + $acp->setGrants($grants); + + $this->assertEquals(3, count($acp)); + } + + /** + * @expectedException \InvalidArgumentException + */ + public function testThrowsExceptionWhenProvidedGrantsAreInvalid() + { + $owner = $this->getMockedOwner(); + $grants = 'foo'; + $acp = new Acp($owner, $grants); + } + + /** + * @expectedException \InvalidArgumentException + */ + public function testThrowsExceptionOwnerIsNotUserGrantee() + { + $owner = $this->getMockBuilder('Aws\S3\Model\Grantee') + ->disableOriginalConstructor() + ->getMock(); + + $acp = new Acp($owner); + } + + /** + * @expectedException \OverflowException + */ + public function testThrowsExceptionIfMoreThan100Grants() + { + $owner = $this->getMockedOwner(); + $grants = $this->getMockedGrants(100); + $acp = new Acp($owner, $grants); + $this->assertInstanceOf('Aws\S3\Model\Acp', $acp); + + $grants = array_merge($grants, $this->getMockedGrants(1)); + $acp = new Acp($owner, $grants); + } + + public function testAcpIsTraversable() + { + $owner = $this->getMockedOwner(); + $grants = $this->getMockedGrants(3); + + $acp = new Acp($owner, $grants); + $array = iterator_to_array($acp); + + $this->assertEquals(3, count($array)); + } + + public function testConvertsToAndFromArray() + { + $acp = new Acp(new Grantee('foo'), array( + new Grant(new Grantee('baz'), Permission::READ), + new Grant(new Grantee('bar'), Permission::READ), + new Grant(new Grantee('baz'), Permission::WRITE), + new Grant(new Grantee('baz'), Permission::READ_ACP) + )); + + $data = array( + 'Owner' => array( + 'ID' => 'foo', + 'DisplayName' => 'foo' + ), + 'Grants' => array( + array ( + 'Grantee' => array( + 'Type' => 'CanonicalUser', + 'ID' => 'baz', + 'DisplayName' => 'baz' + ), + 'Permission' => 'READ' + ), + array( + 'Grantee' => array( + 'Type' => 'CanonicalUser', + 'ID' => 'bar', + 'DisplayName' => 'bar' + ), + 'Permission' => 'READ' + ), + array( + 'Grantee' => array( + 'Type' => 'CanonicalUser', + 'ID' => 'baz', + 'DisplayName' => 'baz' + ), + 'Permission' => 'WRITE' + ), + array( + 'Grantee' => array( + 'Type' => 'CanonicalUser', + 'ID' => 'baz', + 'DisplayName' => 'baz' + ), + 'Permission' => 'READ_ACP' + ) + ) + ); + + $this->assertEquals($data, $acp->toArray()); + $acp2 = Acp::fromArray($data); + $this->assertEquals($data, $acp2->toArray()); + } + + public function testAssumesGrantTypesFromContext() + { + $data = array( + 'Owner' => array( + 'ID' => 'foo', + 'DisplayName' => 'foo' + ), + 'Grants' => array( + array( + 'Grantee' => array( + 'ID' => 'baz', + 'DisplayName' => 'baz' + ), + 'Permission' => 'READ' + ), + array( + 'Grantee' => array( + 'URI' => Group::AUTHENTICATED_USERS + ), + 'Permission' => 'READ' + ), + array( + 'Grantee' => array( + 'EmailAddress' => 'foo@bar.com', + ), + 'Permission' => 'WRITE' + ) + ) + ); + + $acp = Acp::fromArray($data); + $this->assertEquals(array( + 'Owner' => array( + 'ID' => 'foo', + 'DisplayName' => 'foo', + ), + 'Grants' => array( + array( + 'Grantee' => array( + 'Type' => 'CanonicalUser', + 'ID' => 'baz', + 'DisplayName' => 'baz', + ), + 'Permission' => 'READ', + ), + array( + 'Grantee' => array( + 'Type' => 'Group', + 'URI' => 'http://acs.amazonaws.com/groups/global/AuthenticatedUsers', + ), + 'Permission' => 'READ', + ), + array( + 'Grantee' => array( + 'Type' => 'AmazonCustomerByEmail', + 'EmailAddress' => 'foo@bar.com', + ), + 'Permission' => 'WRITE', + ), + ), + ), $acp->toArray()); + } + + public function testCanUpdateCommandHeaders() + { + // Build up mock grants via cloning + $grant = $this->getMockBuilder('Aws\S3\Model\Grant') + ->disableOriginalConstructor() + ->getMock(); + $g1 = clone $grant; + $g1->expects($this->any()) + ->method('getParameterArray') + ->will($this->returnValue(array( + 'GrantRead' => 'id="user-id-1"' + ))); + $g2 = clone $grant; + $g2->expects($this->any()) + ->method('getParameterArray') + ->will($this->returnValue(array( + 'GrantRead' => 'id="user-id-2"' + ))); + $g3 = clone $grant; + $g3->expects($this->any()) + ->method('getParameterArray') + ->will($this->returnValue(array( + 'GrantWrite' => 'id="user-id-3"' + ))); + + $s3 = $this->getServiceBuilder()->get('s3'); + $acp = new Acp($this->getMockedOwner(), array($g1, $g2, $g3)); + $cmd = $s3->getCommand('PutObject'); + $acp->updateCommand($cmd); + $this->assertEquals('id="user-id-1", id="user-id-2"', $cmd->get('GrantRead')); + $this->assertEquals('id="user-id-3"', $cmd->get('GrantWrite')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/ClearBucketTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/ClearBucketTest.php new file mode 100644 index 0000000..cacbd69 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/ClearBucketTest.php @@ -0,0 +1,117 @@ +getServiceBuilder()->get('s3'), 'foo'); + $this->assertSame($this->getServiceBuilder()->get('s3'), $this->readAttribute($clear, 'client')); + + // Ensure that the bucket can be changed + $this->assertEquals('foo', $this->readAttribute($clear, 'bucket')); + $clear->setBucket('bar'); + $this->assertEquals('bar', $this->readAttribute($clear, 'bucket')); + + // Ensure that an MFA token can be set + $clear->setMfa('test'); + $this->assertEquals('test', $this->readAttribute($clear, 'mfa')); + + // Ensure that the iterator can set explicitly + $iterator = $this->getMockForAbstractClass('Aws\Common\Iterator\AwsResourceIterator', array(), '', false); + $clear->setIterator($iterator); + $this->assertSame($iterator, $clear->getIterator()); + } + + public function testCreatesDefaultIterator() + { + $clear = new ClearBucket($this->getServiceBuilder()->get('s3'), 'foo'); + $this->assertInstanceOf('Aws\Common\Iterator\AwsResourceIterator', $clear->getIterator()); + } + + public function testHasEvents() + { + $this->assertInternalType('array', ClearBucket::getAllEvents()); + } + + public function testClearsBucketUsingDefaultIterator() + { + $client = $this->getServiceBuilder()->get('s3'); + $this->setMockResponse($client, array( + 's3/list_objects_page_3', + 's3/list_objects_page_4', + 's3/list_objects_page_5', + 's3/delete_multiple_objects' + )); + $clear = new ClearBucket($client, 'foo'); + $clear->setIterator($client->getIterator('ListObjects', array( + 'Bucket' => 'foo' + ))); + $this->assertEquals(2, $clear->clear()); + } + + public function testClearsBucketUsingRegularListBucketIterator() + { + $client = $this->getServiceBuilder()->get('s3'); + $mock = $this->setMockResponse($client, array( + 's3/get_bucket_object_versions_page_2', + 's3/delete_multiple_objects' + )); + + $clear = new ClearBucket($client, 'foo'); + $this->assertEquals(4, $clear->clear()); + + $requests = $mock->getReceivedRequests(); + foreach ($requests as $request) { + $this->assertEquals('foo.s3.amazonaws.com', $request->getHost()); + } + $this->assertEquals(2, count($requests)); + $this->assertTrue($requests[0]->getQuery()->hasKey('versions')); + $this->assertTrue($requests[1]->getQuery()->hasKey('delete')); + } + + public function testClearsBucketAndBuffersExceptions() + { + $client = $this->getServiceBuilder()->get('s3'); + $mock = $this->setMockResponse($client, array( + 's3/get_bucket_object_versions_page_2', + 's3/delete_multiple_objects_errors' + )); + + $clear = new ClearBucket($client, 'foo'); + + try { + $clear->clear(); + $this->fail('Did not throw expected exception'); + } catch (ExceptionCollection $e) { + $requests = $mock->getReceivedRequests(); + $this->assertEquals(2, count($requests)); + $this->assertEquals(1, count($e)); + foreach ($e->getIterator() as $ee) { + $this->assertEquals(1, count($ee->getErrors())); + } + } + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/DeleteObjectsBatchTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/DeleteObjectsBatchTest.php new file mode 100644 index 0000000..5f023a9 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/DeleteObjectsBatchTest.php @@ -0,0 +1,81 @@ +getServiceBuilder()->get('s3'), 'foo'); + $this->assertInstanceOf('Aws\S3\Model\DeleteObjectsBatch', $batch); + } + + public function testAddsKeys() + { + $batch = DeleteObjectsBatch::factory($this->getServiceBuilder()->get('s3'), 'foo'); + $batch->addKey('foo', 'bar'); + $decorated = $this->readAttribute($batch, 'decoratedBatch'); + $queue = $this->readAttribute($decorated, 'queue'); + $this->assertEquals(1, count($queue)); + $this->assertEquals(array( + 'Key' => 'foo', + 'VersionId' => 'bar' + ), $queue->pop()); + } + + /** + * @expectedException \Aws\Common\Exception\InvalidArgumentException + */ + public function testValidatesInput() + { + $batch = DeleteObjectsBatch::factory($this->getServiceBuilder()->get('s3'), 'foo'); + $batch->add('foo'); + } + + /** + * @expectedException \Aws\Common\Exception\InvalidArgumentException + */ + public function testValidatesCommandName() + { + $client = $this->getServiceBuilder()->get('s3'); + $batch = DeleteObjectsBatch::factory($client, 'foo'); + $batch->add($client->getCommand('CreateBucket')); + } + + public function testConvertsDeleteObjectCommandsToArrays() + { + $client = $this->getServiceBuilder()->get('s3'); + $batch = DeleteObjectsBatch::factory($client, 'foo'); + $batch->add($client->getCommand('DeleteObject', array( + 'Bucket' => 'bucket', + 'Key' => 'foo', + 'VersionId' => 'bar' + ))); + + $decorated = $this->readAttribute($batch, 'decoratedBatch'); + $queue = $this->readAttribute($decorated, 'queue'); + $this->assertEquals(array( + 'Key' => 'foo', + 'VersionId' => 'bar' + ), $queue->pop()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/DeleteObjectsTransferTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/DeleteObjectsTransferTest.php new file mode 100644 index 0000000..3a632ad --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/DeleteObjectsTransferTest.php @@ -0,0 +1,90 @@ +getBatch(); + $transfer->transfer(array('foo')); + } + + public function testIgnoresEmptyBatches() + { + list($client, $transfer) = $this->getBatch(); + $transfer->transfer(array()); + } + + public function testThrowsExceptionWhenKeysHaveErrors() + { + list($client, $transfer) = $this->getBatch(); + $mock = $this->setMockResponse($client, array('s3/delete_multiple_objects_errors')); + + try { + $transfer->transfer(array(array('Key' => 'foo'))); + $this->fail('Did not throw expected exception'); + } catch (DeleteMultipleObjectsException $e) { + $errors = $e->getErrors(); + $this->assertEquals(1, count($errors)); + $this->assertEquals('sample2.txt', $errors[0]['Key']); + $this->assertEquals('AccessDenied', $errors[0]['Code']); + $this->assertEquals('Access Denied', $errors[0]['Message']); + } + } + + public function testDeletesUsingCommands() + { + list($client, $transfer) = $this->getBatch(); + $transfer->setMfa('foo'); + $mock = $this->setMockResponse($client, array('s3/delete_multiple_objects')); + $transfer->transfer(array(array('Key' => 'foo'))); + $requests = $mock->getReceivedRequests(); + $this->assertEquals(1, count($requests)); + $this->assertContains('foo', (string) $requests[0]->getBody()); + $this->assertEquals('foo', (string) $requests[0]->getHeader('x-amz-mfa')); + } + + /** + * @expectedException \Aws\Common\Exception\OverflowException + */ + public function testEnsuresBatchSizeIsLessThan1000() + { + list($client, $transfer) = $this->getBatch(); + $transfer->transfer(range(0, 1001)); + } + + /** + * @return array + */ + protected function getBatch() + { + $client = $this->getServiceBuilder()->get('s3'); + $transfer = new DeleteObjectsTransfer($client, 'foo'); + + return array($client, $transfer); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/GrantTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/GrantTest.php new file mode 100644 index 0000000..06fce3d --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/GrantTest.php @@ -0,0 +1,73 @@ +getMockBuilder('Aws\S3\Model\Grantee')->disableOriginalConstructor()->getMock(); + $grant = new Grant($grantee, Permission::WRITE); + $this->assertSame($grantee, $grant->getGrantee()); + $this->assertSame(Permission::WRITE, $grant->getPermission()); + + $anotherGrantee = $this->getMockBuilder('Aws\S3\Model\Grantee')->disableOriginalConstructor()->getMock(); + $this->assertSame($grant, $grant->setGrantee($anotherGrantee)); + $this->assertSame($grant, $grant->setPermission(Permission::READ)); + + $this->assertSame($anotherGrantee, $grant->getGrantee()); + $this->assertSame(Permission::READ, $grant->getPermission()); + } + + /** + * @expectedException \InvalidArgumentException + */ + public function testPermissionSetterFailsOnInvalidValue() + { + $grantee = $this->getMockBuilder('Aws\S3\Model\Grantee')->disableOriginalConstructor()->getMock(); + $grant = new Grant($grantee, 'foo'); + } + + public function testKnowsCommandParameters() + { + $grantee = new Grantee('foo@example.com'); + $grant = new Grant($grantee, Permission::WRITE); + $this->assertEquals(array ( + 'GrantWrite' => 'emailAddress="foo@example.com"', + ), $grant->getParameterArray()); + } + + public function testCanConvertToArray() + { + $grantee = new Grantee('foo@example.com'); + $grant = new Grant($grantee, Permission::WRITE); + $this->assertEquals(array( + 'Grantee' => array( + 'Type' => 'AmazonCustomerByEmail', + 'EmailAddress' => 'foo@example.com' + ), + 'Permission' => 'WRITE' + ), $grant->toArray()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/GranteeTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/GranteeTest.php new file mode 100644 index 0000000..bbfaa04 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/GranteeTest.php @@ -0,0 +1,137 @@ +assertEquals('1234567890', $grantee->getId()); + $this->assertEquals('foo', $grantee->getDisplayName()); + $this->assertTrue($grantee->isCanonicalUser()); + $this->assertFalse($grantee->isAmazonCustomerByEmail()); + $this->assertFalse($grantee->isGroup()); + $this->assertEquals(GranteeType::USER, $grantee->getType()); + } + + public function testCanCreateEmailAddressGrantee() + { + $grantee = new Grantee('foo@example.com'); + + $this->assertEquals('foo@example.com', $grantee->getId()); + $this->assertEquals('foo@example.com', $grantee->getEmailAddress()); + $this->assertNull($grantee->getDisplayName()); + $this->assertFalse($grantee->isCanonicalUser()); + $this->assertTrue($grantee->isAmazonCustomerByEmail()); + $this->assertFalse($grantee->isGroup()); + $this->assertEquals(GranteeType::EMAIL, $grantee->getType()); + } + + public function testCanCreateGroupGrantee() + { + $grantee = new Grantee(Group::ALL_USERS); + + $this->assertEquals(Group::ALL_USERS, $grantee->getId()); + $this->assertEquals(Group::ALL_USERS, $grantee->getGroupUri()); + $this->assertNull($grantee->getDisplayName()); + $this->assertFalse($grantee->isCanonicalUser()); + $this->assertFalse($grantee->isAmazonCustomerByEmail()); + $this->assertTrue($grantee->isGroup()); + $this->assertEquals(GranteeType::GROUP, $grantee->getType()); + } + + /** + * @expectedException \InvalidArgumentException + */ + public function testThrowsExceptionWhenGranteeIdNotValid() + { + $grantee = new Grantee(100); + } + + /** + * @expectedException \UnexpectedValueException + */ + public function testThrowsExceptionWhenTypeDoesntMatch() + { + $grantee = new Grantee('foo@example.com', null, GranteeType::GROUP); + } + + /** + * @expectedException \LogicException + */ + public function testThrowsExceptionWhenSettingDisplayNameForWrongTypes() + { + $grantee = new Grantee('foo@example.com'); + $grantee->setDisplayName('FooBar'); + } + + public function testDisplayNameSetToIdWhenNotSpecified() + { + $grantee = new Grantee('1234567890'); + $this->assertEquals('1234567890', $grantee->getId()); + $this->assertEquals('1234567890', $grantee->getDisplayName()); + } + + public function getDataForHeaderValueTest() + { + return array( + array('user-id', 'id="user-id"'), + array('foo@example.com', 'emailAddress="foo@example.com"'), + array(GROUP::ALL_USERS, 'uri="' . GROUP::ALL_USERS . '"'), + ); + } + + /** + * @dataProvider getDataForHeaderValueTest + */ + public function testGetHeaderValueProducesExpectedResult($id, $value) + { + $grant = new Grantee($id); + $this->assertSame($value, $grant->getHeaderValue()); + } + + public function testCanConvertToArray() + { + $grantee = new Grantee('foo@example.com'); + $this->assertEquals(array( + 'Type' => 'AmazonCustomerByEmail', + 'EmailAddress' => 'foo@example.com', + ), $grantee->toArray()); + + $grantee = new Grantee('12345'); + $this->assertEquals(array( + 'Type' => 'CanonicalUser', + 'ID' => '12345', + 'DisplayName' => '12345', + ), $grantee->toArray()); + + $grantee = new Grantee(Group::ALL_USERS); + $this->assertEquals(array( + 'Type' => 'Group', + 'URI' => 'http://acs.amazonaws.com/groups/global/AllUsers', + ), $grantee->toArray()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/MultipartUpload/AbstractTransferTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/MultipartUpload/AbstractTransferTest.php new file mode 100644 index 0000000..081a78d --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/MultipartUpload/AbstractTransferTest.php @@ -0,0 +1,167 @@ +getMockBuilder('Aws\S3\Model\MultipartUpload\UploadId') + ->setMethods(array('toParams')) + ->getMock(); + $uploadId->expects($this->any()) + ->method('toParams') + ->will($this->returnValue(array( + 'Bucket' => 'foo', + 'Key' => 'bar', + 'UploadId' => 'baz' + ) + )); + + $body = $this->getMockBuilder('Guzzle\Http\EntityBody') + ->disableOriginalConstructor() + ->setMethods(array('getContentLength')) + ->getMock(); + $body->expects($this->any()) + ->method('getContentLength') + ->will($this->returnValue($contentLength)); + + if ($useRealClient) { + $client = $this->getServiceBuilder()->get('s3', true); + } else { + $client = $this->getMockBuilder('Aws\S3\S3Client') + ->disableOriginalConstructor() + ->getMock(); + } + + $state = $this->getMockBuilder('Aws\S3\Model\MultipartUpload\TransferState') + ->disableOriginalConstructor() + ->getMock(); + $state->expects($this->any()) + ->method('getUploadId') + ->will($this->returnValue($uploadId)); + $state->expects($this->any()) + ->method('getIterator') + ->will($this->returnValue(new \ArrayIterator(array( + UploadPart::fromArray(array( + 'PartNumber' => 1, + 'ETag' => 'aaa', + 'LastModified' => gmdate(DateFormat::RFC2822), + 'Size' => 5 + )), + UploadPart::fromArray(array( + 'PartNumber' => 2, + 'ETag' => 'bbb', + 'LastModified' => gmdate(DateFormat::RFC2822), + 'Size' => 5 + )) + )))); + + $this->client = $client; + $this->transfer = $this->getMockForAbstractClass('Aws\S3\Model\MultipartUpload\AbstractTransfer', array( + $client, $state, $body, array('min_part_size' => $partLength) + )); + } + + protected function callProtectedMethod($object, $method, array $args = array()) + { + $reflectedObject = new \ReflectionObject($object); + $reflectedMethod = $reflectedObject->getMethod($method); + $reflectedMethod->setAccessible(true); + + return $reflectedMethod->invokeArgs($object, $args); + } + + public function partSizeDataProvider() + { + return array( + array(8242880, null, 5242880), + array(8242880, 7242880, 7242880), + array(false, 7242880, 7242880), + array(false, 200, 5242880), + array(false, 72428800000, 5368709120), + array(false, null, null, 'Aws\Common\Exception\RuntimeException') + ); + } + + /** + * @dataProvider partSizeDataProvider + */ + public function testCalculatesPartSize($length, $partLength, $size, $throwException = null) + { + try { + $this->prepareTransfer(false, $length, $partLength); + $this->assertEquals($size, $this->readAttribute($this->transfer, 'partSize')); + } catch (\Exception $e) { + if (!$throwException) { + throw $e; + } else { + $this->assertInstanceOf($throwException, $e); + } + } + } + + public function testCanCompleteMultipartUpload() + { + $this->prepareTransfer(); + + $model = $this->getMockBuilder('Guzzle\Service\Resource\Model') + ->disableOriginalConstructor() + ->getMock(); + $command = $this->getMockBuilder('Guzzle\Service\Command\OperationCommand') + ->disableOriginalConstructor() + ->getMock(); + $command->expects($this->any()) + ->method('getResult') + ->will($this->returnValue($model)); + $this->client->expects($this->any()) + ->method('getCommand') + ->will($this->returnValue($command)); + + $this->assertInstanceOf( + 'Guzzle\Service\Resource\Model', + $this->callProtectedMethod($this->transfer, 'complete') + ); + } + + public function testCanGetAbortCommand() + { + $this->prepareTransfer(true); + + $abortCommand = $this->callProtectedMethod($this->transfer, 'getAbortCommand'); + $this->assertInstanceOf('Guzzle\Service\Command\OperationCommand', $abortCommand); + $this->assertEquals('foo', $abortCommand->get('Bucket')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/MultipartUpload/ParallelTransferTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/MultipartUpload/ParallelTransferTest.php new file mode 100644 index 0000000..0a585cf --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/MultipartUpload/ParallelTransferTest.php @@ -0,0 +1,120 @@ +getMockBuilder('Aws\S3\Model\MultipartUpload\UploadId') + ->setMethods(array('toParams')) + ->getMock(); + $uploadId->expects($this->any()) + ->method('toParams') + ->will($this->returnValue(array( + 'Bucket' => 'foo', + 'Key' => 'bar', + 'UploadId' => 'baz' + ) + )); + + return $uploadId; + } + + protected function prepComponents() + { + $uploadId = $this->getMockUploadId(); + $body = EntityBody::factory(fopen(__FILE__, 'r')); + + $client = $this->getServiceBuilder()->get('s3', true); + $state = new TransferState($uploadId); + $transfer = new ParallelTransfer($client, $state, $body, array('concurrency' => 2)); + + $refClass = new \ReflectionClass($transfer); + $property = $refClass->getProperty('partSize'); + $property->setAccessible(true); + $property->setValue($transfer, 1024); + + return array($transfer, $client, $state); + } + + public function testSuccessfulTransfer() + { + list($transfer, $client) = $this->prepComponents(); + + $mocks = array(); + for ($i = 0; $i < intval(ceil(filesize(__FILE__) / 1024)); $i++) { + $mocks[] = 's3/upload_part'; + } + $mocks[] = 's3/complete_multipart_upload'; + $mock = $this->setMockResponse($client, $mocks); + + $result = $transfer->upload(); + + $requests = $mock->getReceivedRequests(); + $this->assertEquals($i + 1, count($requests)); + for ($j = 0; $j < $i; $j++) { + $this->assertEquals('PUT', $requests[$j]->getMethod()); + } + $this->assertEquals('POST', $requests[4]->getMethod()); + $this->assertInstanceOf('Guzzle\Service\Resource\Model', $result); + } + + public function testStoppingWillStopTransfer() + { + list($transfer) = $this->prepComponents(); + + $transfer->getEventDispatcher()->addListener(ParallelTransfer::BEFORE_PART_UPLOAD, function($event) { + $event['transfer']->stop(); + }); + + $result = $transfer->upload(); + + $this->assertNull($result); + } + + /** + * @expectedException Aws\Common\Exception\RuntimeException + */ + public function testEnsuresTheFileIsLocalAndSeekable() + { + $transfer = new ParallelTransfer( + $this->getServiceBuilder()->get('s3'), + new TransferState($this->getMockUploadId()), + EntityBody::factory('foo') + ); + } + + /** + * @expectedException Aws\Common\Exception\RuntimeException + */ + public function testEnsuresConcurrencyIsSpecified() + { + $transfer = new ParallelTransfer( + $this->getServiceBuilder()->get('s3'), + new TransferState($this->getMockUploadId()), + EntityBody::factory(fopen(__FILE__, 'r')) + ); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/MultipartUpload/SerialTransferTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/MultipartUpload/SerialTransferTest.php new file mode 100644 index 0000000..67636b1 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/MultipartUpload/SerialTransferTest.php @@ -0,0 +1,112 @@ +getMockBuilder('Aws\S3\Model\MultipartUpload\UploadId') + ->setMethods(array('toParams')) + ->getMock(); + $uploadId->expects($this->any()) + ->method('toParams') + ->will($this->returnValue(array( + 'Bucket' => 'foo', + 'Key' => 'bar', + 'UploadId' => 'baz' + ) + )); + + if ($seekable) { + $body = EntityBody::factory('abc123'); + } else { + $stream = fopen('php://temp', 'rw'); + fwrite($stream, 'abc123'); + fseek($stream, 0); + $body = $this->getMockBuilder('Guzzle\Http\EntityBody') + ->setMethods(array('isSeekable')) + ->setConstructorArgs(array($stream)) + ->getMock(); + $body->expects($this->any()) + ->method('isSeekable') + ->will($this->returnValue(false)); + } + + $client = $this->getServiceBuilder()->get('s3', true); + $state = new TransferState($uploadId); + $transfer = new SerialTransfer($client, $state, $body); + + // Modify the partSize for the test + $refClass = new \ReflectionClass($transfer); + $property = $refClass->getProperty('partSize'); + $property->setAccessible(true); + $property->setValue($transfer, 3); + + return array($transfer, $client, $state); + } + + public function dataForTransferTest() + { + return array(array(true), array(false)); + } + + /** + * @dataProvider dataForTransferTest + */ + public function testSuccessfulTransfer($seekable) + { + list($transfer, $client) = $this->prepComponents($seekable); + + $mock = $this->setMockResponse($client, array( + 's3/upload_part', + 's3/upload_part', + 's3/complete_multipart_upload' + ))->readBodies(true); + + $result = $transfer->upload(); + + $requests = $mock->getReceivedRequests(); + $this->assertEquals(3, count($requests)); + $this->assertEquals('PUT', $requests[0]->getMethod()); + $this->assertEquals('abc', (string) $requests[0]->getBody()); + $this->assertEquals('PUT', $requests[1]->getMethod()); + $this->assertEquals('123', (string) $requests[1]->getBody()); + $this->assertEquals('POST', $requests[2]->getMethod()); + $this->assertInstanceOf('Guzzle\Service\Resource\Model', $result); + } + + public function testStoppingWillStopTransfer() + { + list($transfer) = $this->prepComponents(); + + $transfer->getEventDispatcher()->addListener(SerialTransfer::BEFORE_PART_UPLOAD, function($event) { + $event['transfer']->stop(); + }); + + $result = $transfer->upload(); + + $this->assertNull($result); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/MultipartUpload/TransferStateTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/MultipartUpload/TransferStateTest.php new file mode 100644 index 0000000..a724c0f --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/MultipartUpload/TransferStateTest.php @@ -0,0 +1,48 @@ +getMockBuilder('Aws\S3\Model\MultipartUpload\UploadId') + ->setMethods(array('toParams')) + ->getMock(); + $uploadId->expects($this->any()) + ->method('toParams') + ->will($this->returnValue(array( + 'Bucket' => 'foo', + 'Key' => 'bar', + 'UploadId' => 'baz' + ) + )); + + $client = $this->getServiceBuilder()->get('s3'); + $mock = $this->setMockResponse($client, array('s3/list_parts_page_2')); + + $state = TransferState::fromUploadId($client, $uploadId); + $this->assertInstanceOf('Aws\S3\Model\MultipartUpload\TransferState', $state); + $this->assertEquals(1, count($mock->getReceivedRequests())); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/MultipartUpload/UploadBuilderTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/MultipartUpload/UploadBuilderTest.php new file mode 100644 index 0000000..cc0b72a --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/MultipartUpload/UploadBuilderTest.php @@ -0,0 +1,207 @@ +assertInstanceOf('Aws\S3\Model\MultipartUpload\UploadBuilder', UploadBuilder::newInstance()); + } + + public function testHasChainableSetterMethods() + { + $acp = new Acp(new Grantee('123')); + $b = UploadBuilder::newInstance(); + $b->setBucket('foo') + ->setKey('bar') + ->setConcurrency(1) + ->setMd5('abc') + ->calculateMd5(false) + ->calculatePartMd5(true) + ->setMinPartSize(10000) + ->setAcp($acp) + ->setOption('Metadata', array('Foo' => 'Baz')) + ->setOption('Test', '123'); + + $options = $this->readAttribute($b, 'commandOptions'); + $this->assertEquals('foo', $options['Bucket']); + $this->assertEquals('bar', $options['Key']); + $this->assertSame($acp, $options['ACP']); + $this->assertEquals(array('Foo' => 'Baz'), $options['Metadata']); + $this->assertEquals('123', $options['Test']); + $this->assertEquals(1, $this->readAttribute($b, 'concurrency')); + $this->assertEquals('abc', $this->readAttribute($b, 'md5')); + $this->assertTrue($this->readAttribute($b, 'calculatePartMd5')); + $this->assertFalse($this->readAttribute($b, 'calculateEntireMd5')); + $this->assertEquals(AbstractTransfer::MIN_PART_SIZE, $this->readAttribute($b, 'minPartSize')); + } + + /** + * @expectedException \Aws\Common\Exception\InvalidArgumentException + * @expectedExceptionMessage You must specify a Bucket, Key, client, and source. + */ + public function testValidatesThatRequiredFieldsAreSet() + { + UploadBuilder::newInstance()->build(); + } + + /** + * @expectedException Aws\Common\Exception\InvalidArgumentException + * @expectedExceptionMessage You cannot resume a transfer using a non-seekable source. + */ + public function testValidatesThatNonSeekableStreamsCannotBeResumed() + { + $source = $this->getMockBuilder('Guzzle\Http\EntityBody') + ->setMethods(array('isSeekable')) + ->disableOriginalConstructor() + ->getMock(); + $source->expects($this->any()) + ->method('isSeekable') + ->will($this->returnValue(false)); + + UploadBuilder::newInstance() + ->setBucket('foo') + ->setKey('bar') + ->setSource($source) + ->resumeFrom('abc') + ->setClient($this->getServiceBuilder()->get('s3')) + ->build(); + } + + public function testAllowsForExplicitStateObject() + { + $state = new TransferState(UploadId::fromParams(array( + 'Bucket' => 'foo', + 'Key' => 'bar', + 'UploadId' => 'baz' + ))); + + $uploader = UploadBuilder::newInstance() + ->resumeFrom($state) + ->setClient($this->getServiceBuilder()->get('s3')) + ->setSource(EntityBody::factory('test')) + ->build(); + $this->assertSame($state, $uploader->getState()); + } + + public function testCanResumeStateByLoadingFromS3() + { + $client = $this->getServiceBuilder()->get('s3'); + $mock = $this->setMockResponse($client, array('s3/list_parts_page_2')); + $transfer = UploadBuilder::newInstance() + ->setBucket('foo') + ->setKey('bar') + ->resumeFrom('abc') + ->setClient($client) + ->setSource(EntityBody::factory('test')) + ->build(); + $this->assertEquals(1, count($mock->getReceivedRequests())); + $this->assertEquals(2, count($transfer->getState())); + } + + public function testCanCreateNewStateByInitiatingMultipartUpload() + { + $acl = new Acp(new Grantee('123')); + $acl->addGrant(new Grant(new Grantee('123'), Permission::READ)); + $client = $this->getServiceBuilder()->get('s3'); + $mock = $this->setMockResponse($client, array('s3/initiate_multipart_upload')); + $expires = time() + 1000; + $transfer = UploadBuilder::newInstance() + ->setBucket('foo') + ->setKey('bar') + ->setClient($client) + ->setSource(__FILE__) + ->setHeaders(array('Foo' => 'Bar')) + ->setOption('Expires', $expires) + ->setAcp($acl) + ->calculateMd5(true) + ->build(); + $requests = $mock->getReceivedRequests(); + $this->assertEquals(1, count($requests)); + $this->assertEquals('/bar?uploads', $requests[0]->getResource()); + $this->assertEquals('Bar', (string) $requests[0]->getHeader('Foo')); + $this->assertEquals($expires, strtotime((string) $requests[0]->getHeader('Expires'))); + $this->assertEquals('text/x-php', (string) $requests[0]->getHeader('Content-Type')); + $this->assertNotEmpty((string) $requests[0]->getHeader('x-amz-meta-x-amz-Content-MD5')); + $this->assertEquals('id="123"', (string) $requests[0]->getHeader('x-amz-grant-read')); + $this->assertTrue($requests[0]->hasHeader('x-amz-grant-read')); + } + + public function testBuildsDifferentUploaderBasedOnConcurrency() + { + $state = new TransferState(UploadId::fromParams(array( + 'Bucket' => 'foo', + 'Key' => 'bar', + 'UploadId' => 'baz' + ))); + + $b = UploadBuilder::newInstance() + ->setClient($this->getServiceBuilder()->get('s3')) + ->setSource(EntityBody::factory(fopen(__FILE__, 'r'))) + ->resumeFrom($state); + + $this->assertInstanceOf('Aws\S3\Model\MultipartUpload\SerialTransfer', $b->build()); + $b->setConcurrency(2); + $this->assertInstanceOf('Aws\S3\Model\MultipartUpload\ParallelTransfer', $b->build()); + } + + public function testDoesNotClobberContentTypeParam() + { + $client = $this->getServiceBuilder()->get('s3', true); + $mock = $this->setMockResponse($client, array('s3/initiate_multipart_upload')); + $transfer = UploadBuilder::newInstance() + ->setBucket('foo') + ->setKey('bar') + ->setClient($client) + ->setSource(__FILE__) + ->setOption('ContentType', 'x-foo') + ->build(); + $requests = $mock->getReceivedRequests(); + $this->assertEquals(1, count($requests)); + $this->assertEquals('x-foo', (string) $requests[0]->getHeader('Content-Type')); + } + + public function testDoesNotClobberContentTypeHeader() + { + $client = $this->getServiceBuilder()->get('s3', true); + $mock = $this->setMockResponse($client, array('s3/initiate_multipart_upload')); + $transfer = UploadBuilder::newInstance() + ->setBucket('foo') + ->setKey('bar') + ->setClient($client) + ->setSource(__FILE__) + ->setHeaders(array('Content-Type' => 'x-foo')) + ->build(); + $requests = $mock->getReceivedRequests(); + $this->assertEquals(1, count($requests)); + $this->assertEquals('x-foo', (string) $requests[0]->getHeader('Content-Type')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/MultipartUpload/UploadPartTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/MultipartUpload/UploadPartTest.php new file mode 100644 index 0000000..9517e22 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/MultipartUpload/UploadPartTest.php @@ -0,0 +1,44 @@ + 3, + 'ETag' => 'aaa', + 'LastModified' => $date, + 'Size' => 5 + )); + + $this->assertEquals(3, $part->getPartNumber()); + $this->assertEquals('aaa', $part->getETag()); + $this->assertEquals($date, $part->getLastModified()); + $this->assertEquals(5, $part->getSize()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/PostObjectTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/PostObjectTest.php new file mode 100644 index 0000000..2851a08 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Model/PostObjectTest.php @@ -0,0 +1,150 @@ +getMockBuilder('Aws\Common\Credentials\Credentials') + ->disableOriginalConstructor() + ->getMock(); + $credentials->expects($this->any()) + ->method('getAccessKeyId') + ->will($this->returnValue('AKIAXXXXXXXXXXXXXXX')); + $credentials->expects($this->any()) + ->method('getSecretKey') + ->will($this->returnValue('XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX')); + + /** @var $client S3Client */ + $client = $this->getServiceBuilder()->get('s3', array('credentials' => $credentials)); + + $this->client = $client; + } + + public function getDataForPostObjectTest() + { + $cases = array(); + + // Inputs capturing starts-with and success_action_status behaviors + $cases[] = array( + // Options + array( + 'Content-Type' => '^text/', + 'ttd' => 'Nov 24, 1984, midnight GMT', + 'acl' => CannedAcl::PRIVATE_ACCESS, + 'success_action_status' => 201, + 'key' => '^foo/bar/${filename}' + ), + // Expected Results + array( + 'attributes' => array( + 'action' => 'https://foo.s3.amazonaws.com', + 'method' => 'POST', + 'enctype' => 'multipart/form-data' + ), + 'inputs' => array( + 'AWSAccessKeyId' => 'AKIAXXXXXXXXXXXXXXX', + 'success_action_status' => '201', + 'key' => 'foo/bar/${filename}', + 'Content-Type' => 'text/', + 'acl' => 'private', + 'policy' => 'eyJleHBpcmF0aW9uIjoiMTk4NC0xMS0yNFQwMDowMDowMFoiLCJjb25kaXRpb25zIjpbeyJidWNrZXQiOiJmb28ifSx7InN1Y2Nlc3NfYWN0aW9uX3N0YXR1cyI6IjIwMSJ9LFsic3RhcnRzLXdpdGgiLCIkQ29udGVudC1UeXBlIiwidGV4dFwvIl0seyJhY2wiOiJwcml2YXRlIn0sWyJzdGFydHMtd2l0aCIsIiRrZXkiLCJmb29cL2JhclwvIl1dfQ==', + 'signature' => 'FHY919PP/ZzL/IRw8QX6Yd/i7hw=' + ), + 'policy' => '{"expiration":"1984-11-24T00:00:00Z","conditions":[{"bucket":"foo"},{"success_action_status":"201"},["starts-with","$Content-Type","text\/"],{"acl":"private"},["starts-with","$key","foo\/bar\/"]]}' + ) + ); + + // Passing in a raw policy + $cases[] = array( + // Options + array( + 'policy' => '{"expiration":"1984-11-24T00:00:00Z","conditions":[{"bucket":"foo"},{"success_action_stat' + . 'us":"201"},["starts-with","$key","foo\\/bar\\/"],["starts-with","$Content-Type","text\\/"]]}' + ), + // Expected Results + array( + 'attributes' => array( + 'action' => 'https://foo.s3.amazonaws.com', + 'method' => 'POST', + 'enctype' => 'multipart/form-data' + ), + 'inputs' => array( + 'AWSAccessKeyId' => 'AKIAXXXXXXXXXXXXXXX', + 'key' => '${filename}', + 'policy' => 'eyJleHBpcmF0aW9uIjoiMTk4NC0xMS0yNFQwMDowMDowMFoiLCJjb25kaXRpb25zIjpbeyJidWNrZXQiOiJmb' + . '28ifSx7InN1Y2Nlc3NfYWN0aW9uX3N0YXR1cyI6IjIwMSJ9LFsic3RhcnRzLXdpdGgiLCIka2V5IiwiZm9vXC9iYXJc' + . 'LyJdLFsic3RhcnRzLXdpdGgiLCIkQ29udGVudC1UeXBlIiwidGV4dFwvIl1dfQ==', + 'signature' => 'h92mKuUkaKTNmJMqnHDZ51+2+GY=' + ), + 'policy' => '{"expiration":"1984-11-24T00:00:00Z","conditions":[{"bucket":"foo"},{"success_action_stat' + . 'us":"201"},["starts-with","$key","foo\\/bar\\/"],["starts-with","$Content-Type","text\\/"]]}' + ) + ); + + return $cases; + } + + /** + * @dataProvider getDataForPostObjectTest + */ + public function testGetPostObjectData(array $options, array $expected) + { + $postObject = new PostObject($this->client, 'foo', $options); + $postObject->prepareData(); + + $this->assertEquals($expected['attributes'], $postObject->getFormAttributes()); + $this->assertEquals($expected['inputs'], $postObject->getFormInputs()); + $this->assertEquals($expected['policy'], $postObject->getJsonPolicy()); + } + + public function testClientAndBucketGettersAndSetters() + { + $postObject = new PostObject($this->client, 'foo'); + $client2 = $this->getServiceBuilder()->get('s3'); + + $this->assertSame($this->client, $postObject->getClient()); + $this->assertSame('foo', $postObject->getBucket()); + + $postObject->setClient($client2)->setBucket('bar'); + + $this->assertSame($client2, $postObject->getClient()); + $this->assertSame('bar', $postObject->getBucket()); + } + + public function testCanHandleDomainsWithDots() + { + $postObject = new PostObject($this->client, 'foo.bar'); + $postObject->prepareData(); + + $formAttrs = $postObject->getFormAttributes(); + $this->assertEquals('https://s3.amazonaws.com/foo.bar', $formAttrs['action']); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/ResumableDownloadTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/ResumableDownloadTest.php new file mode 100644 index 0000000..e6d25de --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/ResumableDownloadTest.php @@ -0,0 +1,75 @@ +getServiceBuilder()->get('s3'); + new ResumableDownload($client, 'test', 'key', '/does/not/exist/foo'); + } + + public function testDownloadsUsingRangeRequests() + { + $client = $this->getServiceBuilder()->get('s3', true); + $mock = new MockPlugin(array(new Response(200, array('Content-Length' => 9)), new Response(200, array('Content-Length' => 5), '_test'))); + $client->addSubscriber($mock); + $target = EntityBody::factory('test'); + $target->seek(0, SEEK_END); + $resumable = new ResumableDownload($client, 'test', 'key', $target); + $resumable(); + + $mocked = $mock->getReceivedRequests(); + $this->assertCount(2, $mocked); + $this->assertEquals('HEAD', $mocked[0]->getMethod()); + $this->assertEquals('GET', $mocked[1]->getMethod()); + $this->assertEquals('bytes=4-8', (string) $mocked[1]->getHeader('Range')); + } + + /** + * @expectedException \Aws\Common\Exception\UnexpectedValueException + * @expectedExceptionMessage Message integrity check failed. Expected 5032561e973f16047f3109e6a3f7f173 but got 4ba36d23a78c7393b4900ef38019d8ff + */ + public function testEnsuresMd5Match() + { + $client = $this->getServiceBuilder()->get('s3'); + $mock = new MockPlugin(array( + new Response(200, array( + 'Content-Length' => 15, + 'Content-MD5' => '5032561e973f16047f3109e6a3f7f173' + )), + new Response(200, array('Content-Length' => 1), '1') + )); + $client->addSubscriber($mock); + $target = EntityBody::factory('11111111111111'); + $target->seek(0, SEEK_END); + $resumable = new ResumableDownload($client, 'test', 'key', $target); + $resumable(); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/S3ClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/S3ClientTest.php new file mode 100644 index 0000000..3f8bc47 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/S3ClientTest.php @@ -0,0 +1,489 @@ +assertEquals($isValid, s3Client::isValidBucketName($bucketName)); + } + + /** + * @covers Aws\S3\S3Client::factory + */ + public function testFactoryInitializesClient() + { + $client = S3Client::factory(array( + 'scheme' => 'http', + 'region' => 'ap-southeast-1' + )); + $this->assertEquals('http://s3-ap-southeast-1.amazonaws.com', $client->getBaseUrl()); + } + + /** + * @covers Aws\S3\S3Client::createPresignedUrl + */ + public function testCreatesPresignedUrls() + { + /** @var $client S3Client */ + $client = $this->getServiceBuilder()->get('s3', true); + $request = $client->get('/foobar'); + $original = (string) $request; + $url = $client->createPresignedUrl($request, 1342138769); + $this->assertContains('https://s3.amazonaws.com/foobar?AWSAccessKeyId=', $url); + $this->assertContains('Expires=', $url); + $this->assertContains('Signature=', $url); + $this->assertSame($original, (string) $request); + } + + /** + * @covers Aws\S3\S3Client::createPresignedUrl + */ + public function testCreatesPresignedUrlsWithSpecialCharacters() + { + /** @var $client S3Client */ + $client = $this->getServiceBuilder()->get('s3', true); + $request = $client->get('/foobar test: abc/+%.a'); + $url = $client->createPresignedUrl($request, 1342138769); + $this->assertContains('https://s3.amazonaws.com/foobar%20test%3A%20abc/%2B%25.a?AWSAccessKeyId=', $url); + } + + public function testCreatesPresignedUrlsWithStrtotime() + { + /** @var $client S3Client */ + $client = $this->getServiceBuilder()->get('s3', true); + $url = Url::factory($client->createPresignedUrl($client->get('/foobar'), '10 minutes')); + $this->assertTrue(time() < $url->getQuery()->get('Expires')); + } + + public function testCreatesPresignedUrlsWithDateTime() + { + /** @var $client S3Client */ + $client = $this->getServiceBuilder()->get('s3', true); + $url = Url::factory($client->createPresignedUrl($client->get('/foobar'), new \DateTime('+10 minutes'))); + $this->assertTrue(time() < $url->getQuery()->get('Expires')); + } + + public function testCreatesPresignedUrlsWithSessionToken() + { + /** @var $client S3Client */ + $client = $this->getServiceBuilder()->get('s3', true); + $client->setCredentials(new Credentials('foo', 'bar', 'baz')); + $url = Url::factory($client->createPresignedUrl($client->get('/foobar'), '10 minutes')); + $this->assertEquals('baz', $url->getQuery()->get('x-amz-security-token')); + } + + /** + * @expectedException InvalidArgumentException + * @expectedExceptionMessage The request object must be associated with the client + */ + public function testValidatesRequestObjectWhenCreatingPreSignedUrl() + { + $client = $this->getServiceBuilder()->get('s3', true); + $client->createPresignedUrl(new Request('GET', 'http://foo.com'), '+10 minutes'); + } + + public function testDoesBucketExistReturnsCorrectBooleanValue() + { + /** @var $client S3Client */ + $client = $this->getServiceBuilder()->get('s3', true); + $this->setMockResponse($client, array( + 's3/head_success', + 's3/head_access_denied', + 's3/head_failure' + )); + + $this->assertTrue($client->doesBucketExist('bucket')); + $this->assertTrue($client->doesBucketExist('bucket')); + $this->assertFalse($client->doesBucketExist('bucket')); + } + + public function testDoesObjectExistReturnsCorrectBooleanValue() + { + /** @var $client S3Client */ + $client = $this->getServiceBuilder()->get('s3', true); + $this->setMockResponse($client, array( + 's3/head_success', + 's3/head_access_denied', + 's3/head_failure' + )); + + $this->assertTrue($client->doesObjectExist('bucket', 'key')); + $this->assertFalse($client->doesObjectExist('bucket', 'key')); + $this->assertFalse($client->doesObjectExist('bucket', 'key')); + } + + public function testDoesBucketPolicyExistReturnsCorrectBooleanValue() + { + /** @var $client S3Client */ + $client = $this->getServiceBuilder()->get('s3', true); + $this->setMockResponse($client, array( + 's3/get_bucket_policy_success', + 's3/get_bucket_policy_failure' + )); + + $this->assertTrue($client->doesBucketPolicyExist('bucket')); + $this->assertFalse($client->doesBucketPolicyExist('bucket')); + } + + public function testClearsBucketHelperAndUsesSubResources() + { + $client = $this->getServiceBuilder()->get('s3', true); + $mock = $this->setMockResponse($client, array( + 's3/get_bucket_object_versions_page_2', + 's3/delete_multiple_objects' + )); + $client->clearBucket('foo'); + $requests = $mock->getReceivedRequests(); + foreach ($requests as $request) { + $this->assertEquals('foo.s3.amazonaws.com', $request->getHost()); + } + $this->assertEquals(2, count($requests)); + $this->assertTrue($requests[0]->getQuery()->hasKey('versions')); + $this->assertTrue($requests[1]->getQuery()->hasKey('delete')); + } + + public function testProperlyEncodesPrefixKeys() + { + $this->assertEquals('/foo/baz%20/bar%21', S3Client::encodeKey('/foo/baz /bar!')); + $client = $this->getServiceBuilder()->get('s3', true); + $command = $client->getCommand('PutObject', array( + 'Key' => 'foo/baz /bar!', + 'Bucket' => 'test', + 'Body' => '' + )); + $command->prepare(); + $this->assertEquals('/foo/baz%20/bar%21', $command->getRequest()->getPath()); + $this->assertEquals('test.s3.amazonaws.com', $command->getRequest()->getHost()); + } + + public function testExplodesKeys() + { + $this->assertEquals(array('foo', 'baz ', 'bar!'), S3Client::explodeKey('foo/baz /bar!')); + $this->assertEquals(array('foo', 'baz ', 'bar!'), S3Client::explodeKey('/foo/baz /bar!')); + $this->assertEquals(array(''), S3Client::explodeKey('')); + $this->assertEquals(array(''), S3Client::explodeKey(null)); + } + + public function dataForCanCreateObjectUrlsTest() + { + return array( + array(null, array(), 'https://foo.s3.amazonaws.com/bar'), + array('+1 hour', array(), '#^https\://foo\.s3\.amazonaws\.com/bar\?.*AWSAccessKeyId.*Expires.*Signature.*$#'), + array(null, array('Scheme' => 'http'), 'http://foo.s3.amazonaws.com/bar'), + array(null, array('Scheme' => 'ftp'), 'ftp://foo.s3.amazonaws.com/bar'), + array(null, array('Scheme' => ''), '://foo.s3.amazonaws.com/bar'), + array(null, array('Scheme' => null), '//foo.s3.amazonaws.com/bar'), + array(null, array('ResponseContentType' => 'image/png'), 'https://foo.s3.amazonaws.com/bar?response-content-type=' . urlencode('image/png')), + ); + } + + /** + * @dataProvider dataForCanCreateObjectUrlsTest + */ + public function testCanCreateObjectUrls($expires, array $args, $expectedUrl) + { + /** @var $client S3Client */ + $client = $this->getServiceBuilder()->get('s3', true); + $actualUrl = $client->getObjectUrl('foo', 'bar', $expires, $args); + if (strpos($expectedUrl, '#^') === 0) { + $this->assertRegExp($expectedUrl, $actualUrl); + } else { + $this->assertEquals($expectedUrl, $actualUrl); + } + } + + /** + * @expectedException \Aws\Common\Exception\RuntimeException + */ + public function testDeletesMatchingObjectsEnsuresPrefixOrRegex() + { + $client = $this->getServiceBuilder()->get('s3', true); + $client->deleteMatchingObjects('foo', '', ''); + } + + public function testDeletesMatchingObjects() + { + $client = $this->getServiceBuilder()->get('s3', true); + $history = new HistoryPlugin(); + $client->addSubscriber($history); + + $this->setMockResponse($client, array( + 's3/list_objects_page_1', + 's3/list_objects_page_2', + 's3/list_objects_page_3', + 's3/list_objects_page_4', + 's3/list_objects_page_5', + 's3/delete_multiple_objects' + )); + + $event = null; + // Delete objects from the foo bucket under the baz key that are a single lowercase letter + $result = $client->deleteMatchingObjects('foo', 'baz', '/(c|f)/', array( + 'before_delete' => function ($e) use (&$event) { + $event = $e; + } + )); + + $this->assertEquals(2, $result); + $this->assertEquals(6, count($history)); + $this->assertEquals('POST', $history->getLastRequest()->getMethod()); + $this->assertEquals('/?delete', $history->getLastRequest()->getResource()); + $this->assertContains('c', (string) $history->getLastRequest()->getBody()); + $this->assertContains('f', (string) $history->getLastRequest()->getBody()); + $this->assertNotContains('e', (string) $history->getLastRequest()->getBody()); + $this->assertInstanceOf('Guzzle\Common\Event', $event); + } + + public function testUploadsSmallerObjectsUsingPutObject() + { + $client = $this->getServiceBuilder()->get('s3', true); + $mock = new MockPlugin(array(new Response(206))); + $client->addSubscriber($mock); + $history = new HistoryPlugin(); + $client->addSubscriber($history); + $result = $client->upload('test', 'key', 'test', 'public-read', array( + 'params' => array( + 'Metadata' => array('Foo' => 'Bar') + ) + )); + $this->assertInstanceOf('Guzzle\Service\Resource\Model', $result); + $this->assertCount(1, $history); + $request = $history->getLastRequest(); + $this->assertEquals('PUT', $request->getMethod()); + $this->assertEquals('/key', $request->getResource()); + $this->assertEquals('test.s3.amazonaws.com', $request->getHost()); + $this->assertEquals('public-read', (string) $request->getHeader('x-amz-acl')); + $this->assertEquals('Bar', (string) $request->getHeader('x-amz-meta-Foo')); + $this->assertEquals('test', (string) $request->getBody()); + } + + public function testUploadsLargerObjectsUsingMultipartUploads() + { + $client = $this->getServiceBuilder()->get('s3', true); + $this->setMockResponse($client, array( + 's3/initiate_multipart_upload', + 's3/upload_part', + 's3/upload_part', + 's3/complete_multipart_upload' + )); + $history = new HistoryPlugin(); + $client->addSubscriber($history); + $result = $client->upload('test', 'key', fopen(__FILE__, 'r'), 'public-read', array( + 'min_part_size' => 4, + 'params' => array('Metadata' => array('Foo' => 'Bar')) + )); + $this->assertInstanceOf('Guzzle\Service\Resource\Model', $result); + $this->assertCount(3, $history); + $request = $history->getLastRequest(); + $this->assertEquals('POST', $request->getMethod()); + $this->assertStringStartsWith('/key?uploadId=', $request->getResource()); + $this->assertEquals('application/xml', $request->getHeader('Content-Type')); + $this->assertContains('1', (string) $request->getBody()); + } + + public function testUploadsDirectories() + { + $client = $this->getServiceBuilder()->get('s3', true); + $history = new HistoryPlugin(); + $client->addSubscriber($history); + $params = array('foo' => 'bar'); + + $mockBuild = $this->getMockBuilder('Aws\S3\Sync\UploadSync') + ->disableOriginalConstructor() + ->setMethods(array('transfer')) + ->getMock(); + + $mockBuild->expects($this->once()) + ->method('transfer'); + + $mock = $this->getMockBuilder('Aws\S3\Sync\UploadSyncBuilder') + ->setMethods(array('uploadFromDirectory', 'setClient', 'setBucket', 'setKeyPrefix', + 'setConcurrency', 'setBaseDir', 'force', 'setOperationParams', 'enableDebugOutput', + 'setMultipartUploadSize', 'build')) + ->getMock(); + + $mock->expects($this->once())->method('uploadFromDirectory')->with('/path')->will($this->returnSelf()); + $mock->expects($this->once())->method('setClient')->with($client)->will($this->returnSelf()); + $mock->expects($this->once())->method('setBucket')->with('bucket')->will($this->returnSelf()); + $mock->expects($this->once())->method('setKeyPrefix')->with('prefix')->will($this->returnSelf()); + $mock->expects($this->once())->method('setBaseDir')->with('/path')->will($this->returnSelf()); + $mock->expects($this->once())->method('setConcurrency')->with(20)->will($this->returnSelf()); + $mock->expects($this->once())->method('setOperationParams')->with($params)->will($this->returnSelf()); + $mock->expects($this->once())->method('enableDebugOutput')->with(true)->will($this->returnSelf()); + $mock->expects($this->once())->method('force')->with(false)->will($this->returnSelf()); + $mock->expects($this->once())->method('build')->will($this->returnValue($mockBuild)); + $mock->expects($this->once())->method('setMultipartUploadSize')->with(10)->will($this->returnValue($mockBuild)); + + $client->uploadDirectory('/path', 'bucket', 'prefix', array( + 'concurrency' => 20, + 'builder' => $mock, + 'params' => $params, + 'debug' => true, + 'multipart_upload_size' => 10 + )); + } + + public function testDownloadsBuckets() + { + $client = $this->getServiceBuilder()->get('s3', true); + $history = new HistoryPlugin(); + $client->addSubscriber($history); + $params = array('foo' => 'bar'); + + $mockBuild = $this->getMockBuilder('Aws\S3\Sync\DownloadSync') + ->disableOriginalConstructor() + ->setMethods(array('transfer')) + ->getMock(); + + $mockBuild->expects($this->once()) + ->method('transfer'); + + $mock = $this->getMockBuilder('Aws\S3\Sync\DownloadSyncBuilder') + ->setMethods(array('setDirectory', 'setClient', 'setBucket', 'setKeyPrefix', 'allowResumableDownloads', + 'setConcurrency', 'force', 'setOperationParams', 'enableDebugOutput', 'build')) + ->getMock(); + + $mock->expects($this->once())->method('setDirectory')->with('/path')->will($this->returnSelf()); + $mock->expects($this->once())->method('setClient')->with($client)->will($this->returnSelf()); + $mock->expects($this->once())->method('setBucket')->with('bucket')->will($this->returnSelf()); + $mock->expects($this->once())->method('setKeyPrefix')->with('prefix')->will($this->returnSelf()); + $mock->expects($this->once())->method('setConcurrency')->with(20)->will($this->returnSelf()); + $mock->expects($this->once())->method('setOperationParams')->with($params)->will($this->returnSelf()); + $mock->expects($this->once())->method('enableDebugOutput')->with(true)->will($this->returnSelf()); + $mock->expects($this->once())->method('force')->with(false)->will($this->returnSelf()); + $mock->expects($this->once())->method('allowResumableDownloads')->will($this->returnSelf()); + $mock->expects($this->once())->method('build')->will($this->returnValue($mockBuild)); + + $client->downloadBucket('/path', 'bucket', 'prefix', array( + 'concurrency' => 20, + 'builder' => $mock, + 'params' => $params, + 'debug' => true, + 'allow_resumable' => true + )); + } + + /** + * @expectedException \Aws\Common\Exception\InvalidArgumentException + */ + public function testEnsuresSigV4HasRegion() + { + $sig = $this->getMockBuilder('Aws\S3\S3SignatureV4') + ->disableOriginalConstructor() + ->getMock(); + $s3 = S3Client::factory(array(Options::SIGNATURE => $sig)); + $this->assertSame($sig, $s3->getSignature()); + } + + public function testCanForceS3Signature() + { + $sig = $this->getMockBuilder('Aws\S3\S3Signature') + ->disableOriginalConstructor() + ->getMock(); + $s3 = S3Client::factory(array( + Options::SIGNATURE => $sig, + Options::REGION => 'cn-north-1' + )); + $this->assertSame($sig, $s3->getSignature()); + } + + public function testCanForceS3SignatureUsingString() + { + $s3 = S3Client::factory(array( + Options::SIGNATURE => 's3', + Options::REGION => 'cn-north-1' + )); + $this->assertInstanceOf('Aws\S3\S3Signature', $s3->getSignature()); + } + + public function testCanForceSigV4Signature() + { + $sig = $this->getMockBuilder('Aws\S3\S3SignatureV4') + ->disableOriginalConstructor() + ->getMock(); + $s3 = S3Client::factory(array( + Options::SIGNATURE => $sig, + Options::REGION => 'us-east-1' + )); + $this->assertSame($sig, $s3->getSignature()); + } + + /** + * @expectedException \Aws\Common\Exception\InvalidArgumentException + * @expectedExceptionMessage A region must be specified when using signature version 4 + */ + public function testEnsuresRegionIsSetWhenUsingV4() + { + $s3 = S3Client::factory(array(Options::SIGNATURE => 'v4')); + $this->assertInstanceOf('Aws\S3\S3SignatureV4', $s3->getSignature()); + } + + public function testCanForceS3SignatureV4UsingString() + { + $s3 = S3Client::factory(array(Options::SIGNATURE => 'v4', 'region' => 'us-west-2')); + $this->assertInstanceOf('Aws\S3\S3SignatureV4', $s3->getSignature()); + } + + public function testUsesSigV4SignatureInSpecificRegions() + { + $s3 = S3Client::factory(array(Options::REGION => 'cn-north-1')); + $this->assertInstanceOf('Aws\S3\S3SignatureV4', $s3->getSignature()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/S3Md5ListenerTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/S3Md5ListenerTest.php new file mode 100644 index 0000000..e5c0307 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/S3Md5ListenerTest.php @@ -0,0 +1,194 @@ +getMockBuilder('Guzzle\Service\Description\Operation') + ->disableOriginalConstructor() + ->setMethods(array('getData', 'hasParam')) + ->getMockForAbstractClass(); + + $operation->expects($this->once()) + ->method('getData') + ->with('contentMd5') + ->will($this->returnValue($contentMd5Data)); + + if (!$contentMd5Data) { + $operation->expects($this->once()) + ->method('hasParam') + ->with('ContentMD5') + ->will($this->returnValue(true)); + } + + $request = $this->getMockBuilder('Guzzle\Http\Message\EntityEnclosingRequest') + ->setConstructorArgs(array('PUT', 'http://foo.com')) + ->setMethods(array('getBody')) + ->getMock(); + + $body = null; + if ($useBody) { + $stream = fopen('php://temp', 'r+'); + fwrite($stream, 'f'); + rewind($stream); + $body = $this->getMockBuilder('Guzzle\Http\EntityBody') + ->setConstructorArgs(array($stream, $bodySize)) + ->setMethods(array('getContentMd5')) + ->getMock(); + $body->expects($this->any()) + ->method('getContentMd5') + ->with(true, true) + ->will($this->returnValue($md5)); + } + + $request->expects($this->any()) + ->method('getBody') + ->will($this->returnValue($body)); + + $data = array(); + if ($md5Param) { + if ($md5Param === 1) { + $data = array('ContentMD5' => true); + } elseif ($md5Param === 2) { + $data = array('ContentMD5' => null); + } elseif ($md5Param === 3) { + $data = array('ContentMD5' => false); + } else { + $this->fail('Invalid md5Param value'); + } + } + + $command = $this->getMockBuilder('Guzzle\Service\Command\AbstractCommand') + ->setConstructorArgs(array($data, $operation)) + ->setMethods(array('getRequest')) + ->getMockForAbstractClass(); + + $command->expects($this->any()) + ->method('getRequest') + ->will($this->returnValue($request)); + + return array($command, $request); + } + + public function testAddsMd5WhenDataAttributeIsPresent() + { + list($command, $request) = $this->getCommand(true, false, true, 'abcd'); + $event = new Event(array('command' => $command)); + $signature = new S3SignatureV4(); + $listener = new S3Md5Listener($signature); + $listener->onCommandAfterPrepare($event); + $this->assertEquals('abcd', $request->getHeader('Content-MD5')); + } + + public function testDoesNotAddWhenMd5CannotBeAdded() + { + list($command, $request) = $this->getCommand(true, false, true, false); + $event = new Event(array('command' => $command)); + $signature = new S3SignatureV4(); + $listener = new S3Md5Listener($signature); + $listener->onCommandAfterPrepare($event); + $this->assertNull($request->getHeader('Content-MD5')); + } + + public function testAddsContentMd5WhenSetToTrue() + { + list($command, $request) = $this->getCommand(false, 1, true, 'abcd'); + $event = new Event(array('command' => $command)); + $signature = new S3SignatureV4(); + $listener = new S3Md5Listener($signature); + $listener->onCommandAfterPrepare($event); + $this->assertEquals('abcd', $request->getHeader('Content-MD5')); + } + + public function testDoesNotAddContentMd5WhenSetToNullAndSigV4() + { + list($command, $request) = $this->getCommand(false, 2, true, 'abcd'); + $event = new Event(array('command' => $command)); + $signature = new S3SignatureV4(); + $listener = new S3Md5Listener($signature); + $listener->onCommandAfterPrepare($event); + $this->assertNull($request->getHeader('Content-MD5')); + } + + public function testAddsContentMd5WhenSetToNull() + { + list($command, $request) = $this->getCommand(false, 2, true, 'abcd'); + $event = new Event(array('command' => $command)); + $signature = new S3Signature(); + $listener = new S3Md5Listener($signature); + $listener->onCommandAfterPrepare($event); + $this->assertEquals('abcd', $request->getHeader('Content-MD5')); + } + + public function testDoesNotAddContentMd5WhenSetToFalse() + { + list($command, $request) = $this->getCommand(false, 3, false, 'abcd'); + $event = new Event(array('command' => $command)); + $signature = new S3Signature(); + $listener = new S3Md5Listener($signature); + $listener->onCommandAfterPrepare($event); + $this->assertNull($request->getHeader('Content-MD5')); + } + + public function testDoesNotAddContentMd5WhenNoBodyIsSet() + { + list($command, $request) = $this->getCommand(false, 1, false, 'abcd'); + $event = new Event(array('command' => $command)); + $signature = new S3Signature(); + $listener = new S3Md5Listener($signature); + $listener->onCommandAfterPrepare($event); + $this->assertNull($request->getHeader('Content-MD5')); + } + + public function testDoesNotAddContentMd5WhenBodyIsZeroLength() + { + list($command, $request) = $this->getCommand(false, 1, true, null, 0); + $event = new Event(array('command' => $command)); + $signature = new S3Signature(); + $listener = new S3Md5Listener($signature); + $listener->onCommandAfterPrepare($event); + $this->assertNull($request->getHeader('Content-MD5')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/S3SignatureTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/S3SignatureTest.php new file mode 100644 index 0000000..a561524 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/S3SignatureTest.php @@ -0,0 +1,294 @@ + 'PUT', + 'path' => '/db-backup.dat.gz', + 'headers' => array( + 'User-Agent' => 'curl/7.15.5', + 'Host' => 'static.johnsmith.net:8080', + 'Date' => 'Tue, 27 Mar 2007 21:06:08 +0000', + 'x-amz-acl' => 'public-read', + 'content-type' => 'application/x-download', + 'Content-MD5' => '4gJE4saaMU4BqNR0kLY+lw==', + 'X-Amz-Meta-ReviewedBy' => 'joe@johnsmith.net,jane@johnsmith.net', + 'X-Amz-Meta-FileChecksum' => '0x02661779', + 'X-Amz-Meta-ChecksumAlgorithm' => 'crc32', + 'Content-Disposition' => 'attachment; filename=database.dat', + 'Content-Encoding' => 'gzip', + 'Content-Length' => '5913339' + ) + ), "PUT\n4gJE4saaMU4BqNR0kLY+lw==\napplication/x-download\nTue, 27 Mar 2007 21:06:08 +0000\nx-amz-acl:public-read\nx-amz-meta-checksumalgorithm:crc32\nx-amz-meta-filechecksum:0x02661779\nx-amz-meta-reviewedby:joe@johnsmith.net,jane@johnsmith.net\n/static.johnsmith.net/db-backup.dat.gz" + ), + // Use two subresources to set the ACL of a specific version and + // make sure subresources are sorted correctly + array( + array( + 'verb' => 'PUT', + 'path' => '/key?versionId=1234&acl=', + 'headers' => array( + 'Host' => 'test.s3.amazonaws.com', + 'Date' => 'Tue, 27 Mar 2007 21:06:08 +0000', + 'Content-Length' => '15' + ) + ), + "PUT\n\n\nTue, 27 Mar 2007 21:06:08 +0000\n/test/key?acl&versionId=1234" + ), + // DELETE a path hosted object with a folder prefix and custom headers + array( + array( + 'verb' => 'DELETE', + 'path' => '/johnsmith/photos/puppy.jpg', + 'headers' => array( + 'User-Agent' => 'dotnet', + 'Host' => 's3.amazonaws.com', + 'x-amz-date' => 'Tue, 27 Mar 2007 21:20:26 +0000' + ) + ), "DELETE\n\n\n\nx-amz-date:Tue, 27 Mar 2007 21:20:26 +0000\n/johnsmith/photos/puppy.jpg" + ), + // List buckets + array( + array( + 'verb' => 'GET', + 'path' => '/', + 'headers' => array( + 'Host' => 's3.amazonaws.com', + 'Date' => 'Wed, 28 Mar 2007 01:29:59 +0000' + ) + ), "GET\n\n\nWed, 28 Mar 2007 01:29:59 +0000\n/" + ), + // GET the ACL of a virtual hosted bucket + array( + array( + 'verb' => 'GET', + 'path' => '/?acl=', + 'headers' => array( + 'Host' => 'johnsmith.s3.amazonaws.com', + 'Date' => 'Tue, 27 Mar 2007 19:44:46 +0000' + ) + ), "GET\n\n\nTue, 27 Mar 2007 19:44:46 +0000\n/johnsmith/?acl" + ), + // GET the contents of a bucket using parameters + array( + array( + 'verb' => 'GET', + 'path' => '/?prefix=photos&max-keys=50&marker=puppy', + 'headers' => array( + 'User-Agent' => 'Mozilla/5.0', + 'Host' => 'johnsmith.s3.amazonaws.com', + 'Date' => 'Tue, 27 Mar 2007 19:42:41 +0000' + ) + ), "GET\n\n\nTue, 27 Mar 2007 19:42:41 +0000\n/johnsmith/" + ), + // PUT an object with a folder prefix from a virtual hosted bucket + array( + array( + 'verb' => 'PUT', + 'path' => '/photos/puppy.jpg', + 'headers' => array( + 'Content-Type' => 'image/jpeg', + 'Content-Length' => '94328', + 'Host' => 'johnsmith.s3.amazonaws.com', + 'Date' => 'Tue, 27 Mar 2007 21:15:45 +0000' + ) + ), "PUT\n\nimage/jpeg\nTue, 27 Mar 2007 21:15:45 +0000\n/johnsmith/photos/puppy.jpg" + ), + // GET an object with a folder prefix from a virtual hosted bucket + array( + array( + 'verb' => 'GET', + 'path' => '/photos/puppy.jpg', + 'headers' => array( + 'Host' => 'johnsmith.s3.amazonaws.com', + 'Date' => 'Tue, 27 Mar 2007 19:36:42 +0000' + ) + ), "GET\n\n\nTue, 27 Mar 2007 19:36:42 +0000\n/johnsmith/photos/puppy.jpg" + ), + // Set the ACL of an object + array( + array( + 'verb' => 'PUT', + 'path' => '/photos/puppy.jpg?acl=', + 'headers' => array( + 'Host' => 'johnsmith.s3.amazonaws.com', + 'Date' => 'Tue, 27 Mar 2007 19:36:42 +0000' + ) + ), "PUT\n\n\nTue, 27 Mar 2007 19:36:42 +0000\n/johnsmith/photos/puppy.jpg?acl" + ), + // Set the ACL of an object with no prefix + array( + array( + 'verb' => 'PUT', + 'path' => '/photos/puppy?acl=', + 'headers' => array( + 'Host' => 'johnsmith.s3.amazonaws.com', + 'Date' => 'Tue, 27 Mar 2007 19:36:42 +0000' + ) + ), "PUT\n\n\nTue, 27 Mar 2007 19:36:42 +0000\n/johnsmith/photos/puppy?acl" + ), + // Set the ACL of an object with no prefix in a path hosted bucket + array( + array( + 'verb' => 'PUT', + 'path' => '/johnsmith/photos/puppy?acl=', + 'headers' => array( + 'Host' => 's3.amazonaws.com', + 'Date' => 'Tue, 27 Mar 2007 19:36:42 +0000' + ) + ), "PUT\n\n\nTue, 27 Mar 2007 19:36:42 +0000\n/johnsmith/photos/puppy?acl" + ), + // Set the ACL of a path hosted bucket + array( + array( + 'verb' => 'PUT', + 'path' => '/johnsmith?acl=', + 'headers' => array( + 'Host' => 's3.amazonaws.com', + 'Date' => 'Tue, 27 Mar 2007 19:36:42 +0000' + ) + ), "PUT\n\n\nTue, 27 Mar 2007 19:36:42 +0000\n/johnsmith?acl" + ), + // Set the ACL of a path hosted bucket with an erroneous path value + array( + array( + 'verb' => 'PUT', + 'path' => '/johnsmith?acl=', + 'headers' => array( + 'Host' => 's3.amazonaws.com', + 'Date' => 'Tue, 27 Mar 2007 19:36:42 +0000' + ), + ), "PUT\n\n\nTue, 27 Mar 2007 19:36:42 +0000\n/johnsmith?acl" + ), + // Send a request to the EU region + array( + array( + 'verb' => 'GET', + 'path' => '/johnsmith', + 'headers' => array( + 'Host' => 'test.s3-eu-west-1.amazonaws.com', + 'Date' => 'Tue, 27 Mar 2007 19:36:42 +0000' + ), + ), "GET\n\n\nTue, 27 Mar 2007 19:36:42 +0000\n/test/johnsmith" + ), + // Use a bucket with hyphens and a region + array( + array( + 'verb' => 'GET', + 'path' => '/bar', + 'headers' => array( + 'Host' => 'foo-s3-test-bucket.s3-eu-west-1.amazonaws.com', + 'Date' => 'Tue, 27 Mar 2007 19:36:42 +0000' + ), + ), "GET\n\n\nTue, 27 Mar 2007 19:36:42 +0000\n/foo-s3-test-bucket/bar" + ), + // Use a bucket with hyphens and the default region + array( + array( + 'verb' => 'GET', + 'path' => '/bar', + 'headers' => array( + 'Host' => 'foo-s3-test-bucket.s3.amazonaws.com', + 'Date' => 'Tue, 27 Mar 2007 19:36:42 +0000' + ), + ), "GET\n\n\nTue, 27 Mar 2007 19:36:42 +0000\n/foo-s3-test-bucket/bar" + ), + ); + } + + /** + * @dataProvider signatureDataProvider + */ + public function testCreatesCanonicalizedString($input, $result, $expires = null) + { + $signature = new S3Signature(); + $request = \Guzzle\Http\Message\RequestFactory::getInstance()->create( + $input['verb'], + 'http://' . $input['headers']['Host'] . $input['path'], + $input['headers'] + ); + $request->setClient($this->getServiceBuilder()->get('s3')); + $this->assertEquals($result, $signature->createCanonicalizedString($request), $expires); + } + + public function requestDataProvider() + { + $results = array(); + + $client = $this->getServiceBuilder()->get('s3', true); + $client->getCredentials()->setSecurityToken('foo'); + $results[] = array($client, $client->get('/', array('Date' => gmdate('r')))); + + $client = $this->getServiceBuilder()->get('s3', true); + $results[] = array($client, $client->get('/')); + + return $results; + } + + /** + * @dataProvider requestDataProvider + */ + public function testSignsGenericRequest($client, $request) + { + $client->getSignature()->signRequest($request, $client->getCredentials()); + $this->assertTrue($request->hasHeader('Date')); + $this->assertTrue($request->hasHeader('Authorization')); + $this->assertContains( + $client->getCredentials()->getAccessKeyId() . ':', + (string) $request->getHeader('Authorization') + ); + if ($token = $client->getCredentials()->getSecurityToken()) { + $this->assertEquals($token, $request->getHeader('x-amz-security-token')); + } else { + $this->assertFalse($request->hasHeader('x-amz-security-token')); + } + } + + public function testCreatesPreSignedUrlWithXAmzHeaders() + { + $signature = new S3Signature(); + $request = new Request('GET', 'https://s3.amazonaws.com', array( + 'X-Amz-Acl' => 'public-read' + )); + $c = $this->getServiceBuilder()->get('s3'); + $request->setClient($c); + $this->assertContains( + 'x-amz-acl:public-read', + $signature->createCanonicalizedString($request, time()) + ); + $this->assertContains( + '&x-amz-acl=public-read', + $signature->createPresignedUrl( + $request, + $c->getCredentials(), + time() + ) + ); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/S3SignatureV4Test.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/S3SignatureV4Test.php new file mode 100644 index 0000000..e4b8d47 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/S3SignatureV4Test.php @@ -0,0 +1,76 @@ +setBody('foo'); + $credentials = new Credentials('foo', 'bar'); + $signature = new S3SignatureV4('service', 'region'); + $signature->signRequest($request, $credentials); + $this->assertEquals(hash('sha256', 'foo'), $request->getHeader('x-amz-content-sha256')); + } + + public function testDoesNotRemoveDotSegments() + { + list($request, $credentials, $signature) = $this->getFixtures(); + $request->setPath('/.././foo'); + $signature->signRequest($request, $credentials); + $context = $request->getParams()->get('aws.signature'); + $this->assertStringStartsWith("GET\n/.././foo", $context['canonical_request']); + } + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/SocketTimeoutCheckerTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/SocketTimeoutCheckerTest.php new file mode 100644 index 0000000..93fcbf7 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/SocketTimeoutCheckerTest.php @@ -0,0 +1,72 @@ +message = '' . "\n" + . 'RequestTimeoutYour socket connection to the server was not read from or ' + . 'written to within the timeout period. Idle connections will be closed.' + . 'FOOBar'; + } + + public function testOnlyListensFor400Errors() + { + $request = new Request('GET', 'http://example.com'); + $response = new Response(200); + $checker = new SocketTimeoutChecker(); + $this->assertFalse($checker->getBackoffPeriod(0, $request, $response)); + } + + public function testOnlyListensForCompletedRequests() + { + $request = new Request('GET', 'http://example.com'); + $checker = new SocketTimeoutChecker(); + $this->assertFalse($checker->getBackoffPeriod(0, $request)); + } + + public function testReturnsTrueForRetryableErrors() + { + $request = new Request('GET', 'http://example.com'); + $response = new Response(400, array('content-type' => 'application/xml'), $this->message); + $checker = new SocketTimeoutChecker(); + $this->assertEquals(0, $checker->getBackoffPeriod(1, $request, $response)); + // Ensure it plays well with the chain + $checker->setNext(new ExponentialBackoffStrategy()); + $this->assertEquals(8, $checker->getBackoffPeriod(3, $request, $response)); + } + + public function testBehavesProperlyAsChainLink() + { + $s = new ExponentialBackoffStrategy(); + $checker = new SocketTimeoutChecker($s); + $this->assertTrue($checker->makesDecision()); + $this->assertSame($s, $checker->getNext()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/StreamWrapperTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/StreamWrapperTest.php new file mode 100644 index 0000000..fe62680 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/StreamWrapperTest.php @@ -0,0 +1,639 @@ +client = $this->getServiceBuilder()->get('s3', true); + StreamWrapper::register($this->client); + } + + public function tearDown() + { + stream_wrapper_unregister('s3'); + } + + public function testRegistersStreamWrapper() + { + StreamWrapper::register($this->client); + $this->assertContains('s3', stream_get_wrappers()); + // Ensure no error is thrown for registering twice + StreamWrapper::register($this->client); + } + + /** + * @expectedException PHPUnit_Framework_Error_Warning + * @expectedExceptionMessage Cannot open a bucket + */ + public function testCannotOpenBuckets() + { + fopen('s3://bucket', 'r'); + } + + /** + * @expectedException PHPUnit_Framework_Error_Warning + * @expectedExceptionMessage simultaneous reading and writing + */ + public function testCannotReadWriteStreams() + { + fopen('s3://bucket/key', 'r+'); + } + + /** + * @expectedException PHPUnit_Framework_Error_Warning + * @expectedExceptionMessage Mode not supported + */ + public function testSupportsOnlyReadWriteXA() + { + fopen('s3://bucket/key', 'c'); + } + + /** + * @expectedException PHPUnit_Framework_Error_Warning + * @expectedExceptionMessage s3://bucket/key already exists on Amazon S3 + */ + public function testValidatesXMode() + { + $this->setMockResponse($this->client, array(new Response(200))); + fopen('s3://bucket/key', 'x'); + } + + public function testSuccessfulXMode() + { + $this->setMockResponse($this->client, array(new Response(404), new Response(200))); + $r = fopen('s3://bucket/key', 'x'); + fclose($r); + } + + /** + * @expectedException \PHPUnit_Framework_Error_Warning + * @expectedExceptionMessage The Amazon S3 stream wrapper does not allow simultaneous reading and writing. + */ + public function testCanThrowExceptionsInsteadOfErrors() + { + fopen('s3://bucket/key', 'r+', false, stream_context_create(array( + 's3' => array('throw_exceptions' => true) + ))); + } + + public function testOpensNonSeekableReadStream() + { + $stream = fopen('php://temp', 'r+'); + fwrite($stream, 'testing 123'); + fseek($stream, 0); + + $mock = $this->getMockBuilder('Guzzle\Http\EntityBody') + ->setConstructorArgs(array($stream)) + ->setMethods(array('seek')) + ->getMock(); + + $mock->expects($this->any()) + ->method('seek') + ->will($this->returnValue(false)); + + $f = $this->getMockBuilder('Guzzle\Stream\PhpStreamRequestFactory') + ->setMethods(array('createStream')) + ->getMock(); + $f->expects($this->once()) + ->method('createStream') + ->will($this->returnValue($mock)); + + $s = fopen('s3://bucket/ket', 'r', false, stream_context_create(array( + 's3' => array('stream_factory' => $f) + ))); + + $this->assertEquals(0, ftell($s)); + $this->assertFalse(feof($s)); + $this->assertEquals('test', fread($s, 4)); + $this->assertEquals(4, ftell($s)); + $this->assertEquals(-1, fseek($s, 0)); + $this->assertEquals('', stream_get_contents($s)); + $this->assertTrue(feof($s)); + $this->assertTrue(fclose($s)); + } + + public function testOpensSeekableReadStream() + { + $stream = fopen('php://temp', 'r+'); + fwrite($stream, 'testing 123'); + fseek($stream, 0); + + $mock = $this->getMockBuilder('Guzzle\Http\EntityBody') + ->setConstructorArgs(array($stream)) + ->setMethods(array('seek')) + ->getMock(); + + $mock->expects($this->any()) + ->method('seek') + ->will($this->returnValue(false)); + + $f = $this->getMockBuilder('Guzzle\Stream\PhpStreamRequestFactory') + ->setMethods(array('createStream')) + ->getMock(); + $f->expects($this->once()) + ->method('createStream') + ->will($this->returnValue($mock)); + + $s = fopen('s3://bucket/ket', 'r', false, stream_context_create(array( + 's3' => array('stream_factory' => $f, 'seekable' => true) + ))); + + $this->assertEquals(0, ftell($s)); + $this->assertFalse(feof($s)); + $this->assertEquals('test', fread($s, 4)); + $this->assertEquals(4, ftell($s)); + $this->assertEquals(0, fseek($s, 0)); + $this->assertEquals('testing 123', stream_get_contents($s)); + $this->assertTrue(feof($s)); + $this->assertTrue(fclose($s)); + } + + public function testAttemptsToGuessTheContentType() + { + $this->setMockResponse($this->client, array(new Response(200))); + file_put_contents('s3://foo/bar.txt', 'test'); + $requests = $this->getMockedRequests(); + $this->assertEquals('text/plain', $requests[0]->getHeader('Content-Type')); + } + + public function testCanOpenWriteOnlyStreams() + { + $this->setMockResponse($this->client, array(new Response(204))); + + $s = fopen('s3://bucket/key', 'w'); + $this->assertEquals(4, fwrite($s, 'test')); + $this->assertTrue(fclose($s)); + + // Ensure that the stream was flushed and sent the upload + $requests = $this->getMockedRequests(); + $this->assertEquals(1, count($requests)); + $this->assertEquals('PUT', $requests[0]->getMethod()); + $this->assertEquals('test', (string) $requests[0]->getBody()); + $this->assertEquals(4, (string) $requests[0]->getHeader('Content-Length')); + } + + /** + * @expectedException PHPUnit_Framework_Error_Warning + * @expectedExceptionMessage 403 Forbidden + */ + public function testTriggersErrorInsteadOfExceptionWhenWriteFlushFails() + { + $this->setMockResponse($this->client, array(new Response(403))); + $s = fopen('s3://bucket/key', 'w'); + fwrite($s, 'test'); + fclose($s); + } + + public function testCanOpenAppendStreamsWithOriginalFile() + { + // Queue the 200 response that will load the original, and queue the 204 flush response + $this->setMockResponse($this->client, array( + new Response(200, null, 'test'), + new Response(204) + )); + + $s = fopen('s3://bucket/key', 'a'); + $this->assertEquals(4, ftell($s)); + $this->assertEquals(3, fwrite($s, 'ing')); + $this->assertTrue(fclose($s)); + + // Ensure that the stream was flushed and sent the upload + $requests = $this->getMockedRequests(); + $this->assertEquals(2, count($requests)); + $this->assertEquals('GET', $requests[0]->getMethod()); + $this->assertEquals('/key', $requests[0]->getResource()); + $this->assertEquals('PUT', $requests[1]->getMethod()); + $this->assertEquals('/key', $requests[1]->getResource()); + $this->assertEquals('testing', (string) $requests[1]->getBody()); + $this->assertEquals(7, (string) $requests[1]->getHeader('Content-Length')); + } + + public function testCanOpenAppendStreamsWithMissingFile() + { + $this->setMockResponse($this->client, array( + new Response(404), + new Response(204) + )); + + $s = fopen('s3://bucket/key', 'a'); + $this->assertEquals(0, ftell($s)); + $this->assertTrue(fclose($s)); + } + + public function testCanUnlinkFiles() + { + $this->setMockResponse($this->client, array(new Response(204))); + $this->assertTrue(unlink('s3://bucket/key')); + $requests = $this->getMockedRequests(); + $this->assertEquals(1, count($requests)); + $this->assertEquals('DELETE', $requests[0]->getMethod()); + $this->assertEquals('/key', $requests[0]->getResource()); + $this->assertEquals('bucket.s3.amazonaws.com', $requests[0]->getHost()); + } + + /** + * @expectedException PHPUnit_Framework_Error_Warning + * @expectedExceptionMessage 403 Forbidden + */ + public function testThrowsErrorsWhenUnlinkFails() + { + $this->setMockResponse($this->client, array(new Response(403))); + $this->assertFalse(unlink('s3://bucket/key')); + } + + public function testCreatingBucketWithNoBucketReturnsFalse() + { + $this->assertFalse(mkdir('s3://')); + } + + /** + * @expectedExceptionMessage Directory already exists: s3://already-existing-bucket + * @expectedException \PHPUnit_Framework_Error_Warning + */ + public function testCreatingAlreadyExistingBucketRaisesError() + { + $this->setMockResponse($this->client, new Response(200)); + mkdir('s3://already-existing-bucket'); + } + + /** + * @expectedExceptionMessage Directory already exists: s3://already-existing-bucket/key + * @expectedException \PHPUnit_Framework_Error_Warning + */ + public function testCreatingAlreadyExistingBucketForKeyRaisesError() + { + $this->setMockResponse($this->client, array( + new Response(200), // HEAD object response + )); + mkdir('s3://already-existing-bucket/key'); + } + + public function testCreatingBucketWithKeyReturnsTrue() + { + $this->setMockResponse($this->client, array( + new Response(404), // headObject + new Response(200) // putObject + )); + $this->assertTrue(mkdir('s3://foo/bar')); + } + + /** + * @expectedException \PHPUnit_Framework_Error_Warning + * @expectedExceptionMessage 403 Forbidden + */ + public function testCreatingBucketWithExceptionRaisesError() + { + $this->setMockResponse($this->client, array( + new Response(404), + new Response(403)) + ); + mkdir('s3://bucket'); + } + + public function testCreatingBucketsSetsAclBasedOnPermissions() + { + $this->setMockResponse($this->client, array( + new Response(404), new Response(204), // mkdir #1 + new Response(404), new Response(204), // mkdir #2 + new Response(404), new Response(204), // mkdir #3 + )); + $this->assertTrue(mkdir('s3://bucket', 0777)); + $this->assertTrue(mkdir('s3://bucket', 0601)); + $this->assertTrue(mkdir('s3://bucket', 0500)); + $requests = $this->getMockedRequests(); + $this->assertEquals(6, count($requests)); + + $this->assertEquals('HEAD', $requests[0]->getMethod()); + $this->assertEquals('HEAD', $requests[2]->getMethod()); + $this->assertEquals('HEAD', $requests[4]->getMethod()); + + $this->assertEquals('PUT', $requests[1]->getMethod()); + $this->assertEquals('/', $requests[1]->getResource()); + $this->assertEquals('bucket.s3.amazonaws.com', $requests[1]->getHost()); + $this->assertContains('public-read', (string) $requests[1]); + $this->assertContains('authenticated-read', (string) $requests[3]); + $this->assertContains('private', (string) $requests[5]); + } + + /** + * @expectedException PHPUnit_Framework_Error_Warning + * @expectedExceptionMessage Please specify a bucket + */ + public function testCannotDeleteS3() + { + rmdir('s3://'); + } + + /** + * @expectedException PHPUnit_Framework_Error_Warning + * @expectedExceptionMessage 403 Forbidden + */ + public function testRmDirWithExceptionTriggersError() + { + $this->setMockResponse($this->client, array(new Response(403))); + rmdir('s3://bucket'); + } + + public function testCanDeleteBucketWithRmDir() + { + $this->setMockResponse($this->client, array(new Response(204))); + $this->assertTrue(rmdir('s3://bucket')); + $requests = $this->getMockedRequests(); + $this->assertEquals(1, count($requests)); + $this->assertEquals('DELETE', $requests[0]->getMethod()); + $this->assertEquals('/', $requests[0]->getResource()); + $this->assertEquals('bucket.s3.amazonaws.com', $requests[0]->getHost()); + } + + public function rmdirProvider() + { + return array( + array('s3://bucket/object/'), + array('s3://bucket/object'), + ); + } + + /** + * @dataProvider rmdirProvider + */ + public function testCanDeleteObjectWithRmDir($path) + { + $this->setMockResponse($this->client, array(new Response(200), new Response(204))); + $this->assertTrue(rmdir($path)); + $requests = $this->getMockedRequests(); + $this->assertEquals(2, count($requests)); + $this->assertEquals('GET', $requests[0]->getMethod()); + $this->assertEquals('DELETE', $requests[1]->getMethod()); + $this->assertEquals('/object/', $requests[1]->getResource()); + $this->assertEquals('object/', $requests[0]->getQuery()->get('prefix')); + $this->assertEquals('bucket.s3.amazonaws.com', $requests[1]->getHost()); + } + + /** + * @expectedException PHPUnit_Framework_Error_Warning + * @expectedExceptionMessage The Amazon S3 stream wrapper only supports copying objects + */ + public function testRenameEnsuresKeyIsSet() + { + rename('s3://foo/bar', 's3://baz'); + } + + /** + * @expectedException PHPUnit_Framework_Error_Warning + * @expectedExceptionMessage Forbidden + */ + public function testRenameWithExceptionThrowsError() + { + $this->setMockResponse($this->client, array(new Response(403))); + rename('s3://foo/bar', 's3://baz/bar'); + } + + public function testCanRenameObjects() + { + $this->setMockResponse($this->client, array(new Response(204), new Response(204))); + $this->assertTrue(rename('s3://bucket/key', 's3://other/new_key')); + $requests = $this->getMockedRequests(); + $this->assertEquals(2, count($requests)); + $this->assertEquals('PUT', $requests[0]->getMethod()); + $this->assertEquals('/new_key', $requests[0]->getResource()); + $this->assertEquals('other.s3.amazonaws.com', $requests[0]->getHost()); + $this->assertEquals('/bucket/key', (string) $requests[0]->getHeader('x-amz-copy-source')); + $this->assertEquals('COPY', (string) $requests[0]->getHeader('x-amz-metadata-directive')); + $this->assertEquals('DELETE', $requests[1]->getMethod()); + $this->assertEquals('/key', $requests[1]->getResource()); + $this->assertEquals('bucket.s3.amazonaws.com', $requests[1]->getHost()); + } + + public function testCanRenameObjectsWithCustomSettings() + { + $this->setMockResponse($this->client, array(new Response(204), new Response(204))); + $this->assertTrue(rename('s3://bucket/key', 's3://other/new_key', stream_context_create(array( + 's3' => array('MetadataDirective' => 'REPLACE') + )))); + $requests = $this->getMockedRequests(); + $this->assertEquals(2, count($requests)); + $this->assertEquals('PUT', $requests[0]->getMethod()); + $this->assertEquals('/new_key', $requests[0]->getResource()); + $this->assertEquals('other.s3.amazonaws.com', $requests[0]->getHost()); + $this->assertEquals('/bucket/key', (string) $requests[0]->getHeader('x-amz-copy-source')); + $this->assertEquals('REPLACE', (string) $requests[0]->getHeader('x-amz-metadata-directive')); + } + + public function testProvidesDirectoriesForS3() + { + $this->setMockResponse($this->client, array( + 's3/list_objects_page_1', + 's3/list_objects_page_2', + 's3/list_objects_page_3', + 's3/list_objects_page_4', + 's3/list_objects_page_5', + 's3/list_objects_page_1', + 's3/list_objects_page_2', + 's3/list_objects_page_3', + 's3/list_objects_page_4', + 's3/list_objects_page_5' + )); + + $c = null; + $this->client->getEventDispatcher()->addListener('client.command.create', function ($e) use (&$c) { + $c = $e['command']; + }); + + $dir = 's3://bucket/key/'; + $r = opendir($dir); + $this->assertInternalType('resource', $r); + + // Ensure that the command was created correctly + $this->assertEquals('bucket', $c['Bucket']); + $this->assertEquals('/', $c['Delimiter']); + $this->assertEquals('key/', $c['Prefix']); + + $files = array(); + while (($file = readdir($r)) !== false) { + $files[] = $file; + } + + // This is the order that the mock responses should provide + $expected = array('a', 'b', 'c', 'd', 'e', 'f', 'g'); + + $this->assertEquals($expected, $files); + $this->assertEquals(5, count($this->getMockedRequests())); + + rewinddir($r); + $files = array(); + while (($file = readdir($r)) !== false) { + $files[] = $file; + } + $this->assertEquals($expected, $files); + $this->assertEquals(10, count($this->getMockedRequests())); + + closedir($r); + } + + public function testCanSetDelimiterStreamContext() + { + $this->setMockResponse($this->client, array('s3/list_objects_page_5')); + + $c = null; + $this->client->getEventDispatcher()->addListener('client.command.create', function ($e) use (&$c) { + $c = $e['command']; + }); + + $dir = 's3://bucket'; + $r = opendir($dir, stream_context_create(array('s3' => array('delimiter' => '')))); + + $this->assertEquals('bucket', $c['Bucket']); + $this->assertEquals('', $c['Delimiter']); + $this->assertEquals('', $c['Prefix']); + + closedir($r); + } + + public function testStatS3andBuckets() + { + clearstatcache('s3://'); + $stat = stat('s3://'); + $this->assertEquals(0040777, $stat['mode']); + + $this->setMockResponse($this->client, array(new Response(200))); + clearstatcache('s3://bucket'); + $stat = stat('s3://bucket'); + $this->assertEquals(0040777, $stat['mode']); + } + + /** + * @expectedException PHPUnit_Framework_Error_Warning + * @expectedExceptionMessage Forbidden + */ + public function testFailingStatTriggersError() + { + $this->setMockResponse($this->client, array(new Response(403))); + clearstatcache('s3://bucket/key'); + stat('s3://bucket/key'); + } + + /** + * @expectedException PHPUnit_Framework_Error_Warning + * @expectedExceptionMessage File or directory not found: s3://bucket + */ + public function testBucketNotFoundTriggersError() + { + $this->setMockResponse($this->client, array(new Response(404))); + $this->setMockResponse($this->client, array(new Response(404))); + clearstatcache('s3://bucket'); + stat('s3://bucket'); + } + + public function testStatsRegularObjects() + { + $ts = strtotime('Tuesday, April 9 2013'); + $this->setMockResponse($this->client, array(new Response(200, array( + 'Content-Length' => 5, + 'Last-Modified' => gmdate('r', $ts) + )))); + clearstatcache('s3://bucket/key'); + $stat = stat('s3://bucket/key'); + $this->assertEquals(0100777, $stat['mode']); + $this->assertEquals(5, $stat['size']); + $this->assertEquals($ts, $stat['mtime']); + $this->assertEquals($ts, $stat['ctime']); + } + + public function testCanStatPrefix() + { + $this->setMockResponse($this->client, array('s3/head_failure', 's3/list_objects_page_5')); + clearstatcache('s3://bucket/prefix'); + $stat = stat('s3://bucket/prefix'); + $this->assertEquals(0040777, $stat['mode']); + } + + /** + * @expectedException PHPUnit_Framework_Error_Warning + * @expectedExceptionMessage File or directory not found: s3://bucket/prefix + */ + public function testCannotStatPrefixWithNoResults() + { + $this->setMockResponse($this->client, array('s3/head_failure', 's3/head_success')); + clearstatcache('s3://bucket/prefix'); + stat('s3://bucket/prefix'); + } + + public function fileTypeProvider() + { + return array( + array('s3://', array(), 'dir'), + array('s3://t123', array(new Response(200)), 'dir'), + array('s3://t123/', array(new Response(200)), 'dir'), + array('s3://t123', array(new Response(404)), 'error'), + array('s3://t123/', array(new Response(404)), 'error'), + array('s3://t123/abc', array(new Response(200)), 'file'), + array('s3://t123/abc/', array(new Response(200)), 'dir'), + // "s3/list_objects_page_3" contains several keys, so this is a key + // prefix which means it is a directory + array('s3://t123/abc/', array( + new Response(404), + $this->getMockResponse('s3/list_objects_page_3') + ), 'dir'), + // No valid keys were found in the list objects call, so it's not + // a file, directory, or key prefix. + array('s3://t123/abc/', array( + new Response(404), + $this->getMockResponse('s3/list_objects_page_4') + ), 'error'), + ); + } + + /** + * @dataProvider fileTypeProvider + */ + public function testDeterminesIfFileOrDir($uri, $responses, $result) + { + if ($responses) { + $this->setMockResponse($this->client, $responses); + } + + clearstatcache(); + if ($result == 'error') { + $err = false; + set_error_handler(function ($e) use (&$err) { $err = true; }); + $actual = filetype($uri); + restore_error_handler(); + $this->assertFalse($actual); + $this->assertTrue($err); + } else { + $actual = filetype($uri); + $this->assertSame($actual, $result); + } + + $this->assertEquals(count($responses), count($this->getMockedRequests())); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Sync/AbstractSyncBuilderTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Sync/AbstractSyncBuilderTest.php new file mode 100644 index 0000000..d4be384 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Sync/AbstractSyncBuilderTest.php @@ -0,0 +1,115 @@ +getMockBuilder('Aws\S3\Sync\AbstractSyncBuilder') + ->getMockForAbstractClass(); + $i = new \ArrayIterator(array('foo', 'test')); + $c1 = new KeyConverter(); + /** @var $b AbstractSyncBuilder */ + $b->enableDebugOutput(true) + ->force(true) + ->setBaseDir('/base') + ->setBucket('bucket') + ->setClient($this->getServiceBuilder()->get('s3')) + ->setConcurrency(2) + ->setDelimiter('\\') + ->setKeyPrefix('/prefix/') + ->setOperationParams(array('foo' => 'bar')) + ->setSourceFilenameConverter($c1) + ->setTargetFilenameConverter($c1) + ->setSourceIterator($i) + ->addRegexFilter('/foo/'); + + $this->assertSame(true, $this->readAttribute($b, 'forcing')); + $this->assertSame('/base', $this->readAttribute($b, 'baseDir')); + $this->assertSame('bucket', $this->readAttribute($b, 'bucket')); + $this->assertSame(2, $this->readAttribute($b, 'concurrency')); + $this->assertSame('\\', $this->readAttribute($b, 'delimiter')); + $this->assertSame('prefix/', $this->readAttribute($b, 'keyPrefix')); + $this->assertSame(array('foo' => 'bar'), $this->readAttribute($b, 'params')); + $this->assertSame($c1, $this->readAttribute($b, 'sourceConverter')); + $this->assertSame($c1, $this->readAttribute($b, 'targetConverter')); + $this->assertSame($this->getServiceBuilder()->get('s3'), $this->readAttribute($b, 'client')); + + $it = $this->readAttribute($b, 'sourceIterator'); + $this->assertInstanceOf('Guzzle\Iterator\FilterIterator', $it); + $this->assertSame($i, $it->getInnerIterator()); + $this->assertEquals(array('test'), array_values(iterator_to_array($it))); + } + + /** + * @expectedException \Aws\Common\Exception\RuntimeException + */ + public function testEnsuresSourceIteratorWhenSettingRegex() + { + $b = $this->getMockBuilder('Aws\S3\Sync\AbstractSyncBuilder')->getMockForAbstractClass(); + $b->addRegexFilter('/foo/'); + } + + /** + * @expectedException \Aws\Common\Exception\RuntimeException + */ + public function testEnsuresClientIsSet() + { + $b = $this->getMockBuilder('Aws\S3\Sync\AbstractSyncBuilder')->getMockForAbstractClass(); + $b->build(); + } + + /** + * @expectedException \Aws\Common\Exception\RuntimeException + */ + public function testEnsuresBucketIsSet() + { + $b = $this->getMockBuilder('Aws\S3\Sync\AbstractSyncBuilder')->getMockForAbstractClass(); + $b->setClient($this->getServiceBuilder()->get('s3'))->build(); + } + + public function testBuildsUsingSubClasses() + { + $a = new \ArrayIterator(); + $mockSync = $this->getMockBuilder('Aws\S3\Sync\AbstractSync') + ->disableOriginalConstructor() + ->getMockForAbstractClass(); + $b = $this->getMockBuilder('Aws\S3\Sync\AbstractSyncBuilder') + ->setMethods(array('specificBuild', 'getTargetIterator')) + ->getMockForAbstractClass(); + $b->expects($this->once()) + ->method('specificBuild') + ->will($this->returnValue($mockSync)); + $b->expects($this->once()) + ->method('getTargetIterator') + ->will($this->returnValue($a)); + $b->setClient($this->getServiceBuilder()->get('s3')) + ->setSourceIterator($a) + ->enableDebugOutput() + ->setSourceFilenameConverter(new KeyConverter) + ->setTargetFilenameConverter(new KeyConverter) + ->setBucket('foo'); + $this->assertSame($mockSync, $b->build()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Sync/AbstractSyncTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Sync/AbstractSyncTest.php new file mode 100644 index 0000000..3040dd9 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Sync/AbstractSyncTest.php @@ -0,0 +1,126 @@ +getMockBuilder('Aws\S3\Sync\AbstractSync') + ->setConstructorArgs(array(array())) + ->getMockForAbstractClass(); + } + + public function testHasEvents() + { + $this->assertCount(2, AbstractSync::getAllEvents()); + } + + public function testSendsParallelCommands() + { + $ai = new \ArrayIterator(array(1, 2, 3, 4, 5, 6, 7, 8, 9)); + $s = $this->getMockBuilder('Aws\S3\Sync\AbstractSync') + ->setConstructorArgs(array( + array('client' => '', 'bucket' => '', 'iterator' => $ai, 'source_converter' => '', 'concurrency' => 4) + )) + ->setMethods(array('transferFiles')) + ->getMockForAbstractClass(); + $called = array(); + $s->expects($this->exactly(3)) + ->method('transferFiles') + ->will($this->returnCallback(function ($data) use (&$called) { + $called[] = $data; + })); + $s->transfer(); + $this->assertEquals(array(array(1, 2, 3, 4), array(5, 6, 7, 8), array(9)), $called); + } + + public function testTransfersActions() + { + $command = $this->getMockBuilder('Guzzle\Service\Command\CommandInterface') + ->getMockForAbstractClass(); + $client = $this->getMockBuilder('Guzzle\Service\Client') + ->setMethods(array('execute')) + ->getMock(); + $client->expects($this->atLeastOnce()) + ->method('execute') + ->with($this->equalTo(array($command))); + + $a = $this->getMockBuilder('SplFileinfo') + ->disableOriginalConstructor() + ->getMock(); + + $b = $this->getMockBuilder('SplFileinfo') + ->disableOriginalConstructor() + ->getMock(); + + $ai = new \ArrayIterator(array($a, $b)); + + $s = $this->getMockBuilder('Aws\S3\Sync\AbstractSync') + ->setConstructorArgs(array( + array( + 'client' => $client, + 'bucket' => '', + 'iterator' => $ai, + 'source_converter' => '', + ) + )) + ->setMethods(array('createTransferAction')) + ->getMockForAbstractClass(); + + $events = array(); + $s->getEventDispatcher()->addListener(AbstractSync::BEFORE_TRANSFER, function ($e) use (&$events) { + $events[] = $e; + }); + $s->getEventDispatcher()->addListener(AbstractSync::AFTER_TRANSFER, function ($e) use (&$events) { + $events[] = $e; + }); + + $called = array(); + + $s->expects($this->exactly(2)) + ->method('createTransferAction') + ->will($this->returnCallback(function ($file) use (&$called, $a, $command) { + if ($file === $a) { + return function () use (&$called) { $called['a'] = true; }; + } else { + $called['b'] = true; + return $command; + } + })); + + $s->transfer(); + + $this->assertTrue($called['a']); + $this->assertTrue($called['b']); + + $this->assertCount(4, $events); + foreach ($events as $e) { + $this->assertSame($s, $e['sync']); + $this->assertSame($client, $e['client']); + $this->assertNotNull($e['command']); + } + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Sync/ChangedFilesIteratorTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Sync/ChangedFilesIteratorTest.php new file mode 100644 index 0000000..fe06bf1 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Sync/ChangedFilesIteratorTest.php @@ -0,0 +1,117 @@ +getMockBuilder('SplFileinfo') + ->setMethods(array('getSize', 'getMTime', '__toString')) + ->disableOriginalConstructor() + ->getMock(); + $a->expects($this->any())->method('getSize')->will($this->returnValue(10)); + $a->expects($this->any())->method('getMTime')->will($this->returnValue($ctime)); + $a->expects($this->any())->method('__toString')->will($this->returnValue('')); + + $b = $this->getMockBuilder('SplFileinfo') + ->setMethods(array('getSize', 'getMTime', '__toString')) + ->disableOriginalConstructor() + ->getMock(); + $b->expects($this->any())->method('getSize')->will($this->returnValue(11)); + $b->expects($this->any())->method('getMTime')->will($this->returnValue($ctime)); + $a->expects($this->any())->method('__toString')->will($this->returnValue('')); + + $c = 0; + $converter = $this->getMockBuilder('Aws\S3\Sync\KeyConverter') + ->setMethods(array('convert')) + ->getMock(); + $converter->expects($this->any()) + ->method('convert') + ->will($this->returnCallback(function () use (&$c) { + if (++$c == 1) { + return 'foo'; + } else { + return 'bar'; + } + })); + + $targetIterator = new \ArrayIterator(array($b, $a)); + $targetIterator->rewind(); + $changed = new ChangedFilesIterator($targetIterator, $targetIterator, $converter, $converter); + $ref = new \ReflectionMethod($changed, 'getTargetData'); + $ref->setAccessible(true); + $this->assertEquals(array(10, $ctime), $ref->invoke($changed, 'bar')); + $this->assertEquals(array(11, $ctime), $ref->invoke($changed, 'foo')); + $this->assertFalse($ref->invoke($changed, 'baz')); + } + + public function compareDataProvider() + { + $t = strtotime('January 1, 2013'); + + return array( + array(10, $t, array(10, $t), false), + array(10, $t, array(11, $t), true), + array(10, $t + 10, array(10, $t), true), + array(10, $t, false, true), + ); + } + + /** + * @dataProvider compareDataProvider + */ + public function testComparesData($size1, $time1, $returnValue, $present) + { + $a = $this->getMockBuilder('SplFileinfo') + ->setMethods(array('getSize', 'getMTime', '__toString')) + ->disableOriginalConstructor() + ->getMock(); + $a->expects($this->any())->method('getSize')->will($this->returnValue($size1)); + $a->expects($this->any())->method('getMTime')->will($this->returnValue($time1)); + $a->expects($this->any())->method('__toString')->will($this->returnValue('')); + + $i1 = new \ArrayIterator(array($a)); + $i2 = new \ArrayIterator(array()); + $converter = new KeyConverter(); + + $iterator = $this->getMockBuilder('Aws\S3\Sync\ChangedFilesIterator') + ->setMethods(array('getTargetData')) + ->setConstructorArgs(array($i1, $i2, $converter, $converter)) + ->getMock(); + $iterator->expects($this->once()) + ->method('getTargetData') + ->will($this->returnValue($returnValue)); + + $results = iterator_to_array($iterator); + + if ($present) { + $this->assertCount(1, $results); + } else { + $this->assertCount(0, $results); + $this->assertCount(0, $iterator->getUnmatched()); + } + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Sync/DownloadSyncBuilderTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Sync/DownloadSyncBuilderTest.php new file mode 100644 index 0000000..51f08ac --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Sync/DownloadSyncBuilderTest.php @@ -0,0 +1,96 @@ +getServiceBuilder()->get('s3', true); + // Set a list object response and a HeadObject response to satisfy the stream wrapper + $this->setMockResponse($client, array('s3/list_objects_empty')); + $b = DownloadSyncBuilder::getInstance(); + $b->setClient($client) + ->setDirectory(__DIR__) + ->setBucket('foo') + ->allowResumableDownloads(true) + ->setOperationParams(array('Foo' => 'Bar')) + ->build(); + } + + /** + * @expectedException \Aws\Common\Exception\RuntimeException + * @expectedExceptionMessage directory is required + */ + public function testEnsuresDirectoryIsSet() + { + $client = $this->getServiceBuilder()->get('s3', true); + $this->setMockResponse($client, array('s3/list_objects_empty')); + $b = DownloadSyncBuilder::getInstance(); + $b->setClient($client)->setBucket('foo')->build(); + } + + protected function getDebugSync() + { + $out = fopen('php://temp', 'r+'); + $sync = DownloadSyncBuilder::getInstance() + ->enableDebugOutput($out) + ->setClient($this->getServiceBuilder()->get('s3', true)) + ->setBucket('Foo') + ->setDirectory(__DIR__) + ->setSourceIterator(new \ArrayIterator(array(new \SplFileInfo(__FILE__)))) + ->build(); + + return array($sync, $out); + } + + public function testAddsDebugListenerForCommand() + { + list($sync, $out) = $this->getDebugSync(); + $command = new S3Command(array( + 'Bucket' => 'Foo', + 'Key' => 'Bar', + 'SaveAs' => __FILE__ + )); + $sync->dispatch(DownloadSync::BEFORE_TRANSFER, array('command' => $command)); + rewind($out); + $this->assertContains('Downloading Foo/Bar -> ' . __FILE__, stream_get_contents($out)); + } + + public function testAddsDebugListenerForResumable() + { + list($sync, $out) = $this->getDebugSync(); + $r = new ResumableDownload($this->getServiceBuilder()->get('s3', true), 'Foo', 'Bar', __FILE__); + $sync->dispatch(DownloadSync::BEFORE_TRANSFER, array('command' => $r)); + rewind($out); + $this->assertContains('Resuming Foo/Bar -> ' . __FILE__, stream_get_contents($out)); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Sync/DownloadSyncTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Sync/DownloadSyncTest.php new file mode 100644 index 0000000..dec5866 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Sync/DownloadSyncTest.php @@ -0,0 +1,187 @@ +getMockBuilder('SplFileInfo') + ->setMethods(array('getPathName')) + ->disableOriginalConstructor() + ->getMock(); + $file->expects($this->once()) + ->method('getPathName') + ->will($this->returnValue($filename)); + + return $file; + } + + public function testCreatesSimpleCommand() + { + $converter = $this->getMockBuilder('Aws\S3\Sync\KeyConverter') + ->setMethods(array('convert')) + ->getMock(); + + $converter->expects($this->once()) + ->method('convert') + ->with('s3://foo/baz') + ->will($this->returnValue('/foo/bar')); + + $sync = $this->getMockBuilder('Aws\S3\Sync\DownloadSync') + ->setConstructorArgs(array( + array( + 'client' => $this->getServiceBuilder()->get('s3'), + 'bucket' => 'foo', + 'iterator' => null, + 'source_converter' => $converter + ) + )) + ->setMethods(array('createDirectory')) + ->getMock(); + + $sync->expects($this->once()) + ->method('createDirectory') + ->with('/foo/bar'); + + $ref = new \ReflectionMethod($sync, 'createTransferAction'); + $ref->setAccessible(true); + $command = $ref->invoke($sync, $this->getSplFile('s3://foo/baz')); + $this->assertEquals('foo', $command['Bucket']); + $this->assertEquals('baz', $command['Key']); + $this->assertEquals('/foo/bar', $command['SaveAs']); + } + + public function keyConverterProvider() + { + return array( + // base dir prefix given key result + array('C:/foo/bar', '', 's3://foo/baz', 's3://foo/baz'), + array('C:\\foo\\bar', '', 's3://foo/baz', 's3://foo/baz'), + array('/foo/bar', '', 's3://foo/baz', 's3://foo/baz'), + array('', '', 's3://foo/baz', 's3://foo/baz'), + array('', '', 's3://foo//baz', 's3://foo/baz'), + array('', 'foo/', '../../tmp/test', 'foo/../../tmp/test'), + array('../', 'foo/', '../../tmp/test', 'foo/../tmp/test'), + array('', 'a', '//foo/baz', 'a/foo/baz'), + ); + } + + /** + * @dataProvider keyConverterProvider + */ + public function testDoesNotAddLeadingSlash($base, $prefix, $path, $result) + { + $converter = new KeyConverter($base, $prefix); + $sync = $this->getMockBuilder('Aws\S3\Sync\DownloadSync') + ->setConstructorArgs(array( + array( + 'client' => $this->getServiceBuilder()->get('s3', true), + 'bucket' => 'foo', + 'iterator' => null, + 'source_converter' => $converter + ) + )) + ->setMethods(array('createDirectory')) + ->getMock(); + + $sync->expects($this->any()) + ->method('createDirectory') + ->will($this->returnCallback(function() { + throw new \Exception(func_get_arg(0)); + })); + + $ref = new \ReflectionMethod($sync, 'createTransferAction'); + $ref->setAccessible(true); + + try { + $ref->invoke($sync, $this->getSplFile($path)); + $this->fail('Did not throw'); + } catch (\Exception $e) { + $this->assertEquals($result, $e->getMessage()); + } + } + + public function testCreatesResumableDownloadWhenFileExists() + { + $converter = $this->getMockBuilder('Aws\S3\Sync\KeyConverter') + ->setMethods(array('convert')) + ->getMock(); + + $converter->expects($this->once()) + ->method('convert') + ->with('s3://foo/baz') + ->will($this->returnValue(__FILE__)); + + $sync = $this->getMockBuilder('Aws\S3\Sync\DownloadSync') + ->setConstructorArgs(array( + array( + 'client' => $this->getServiceBuilder()->get('s3'), + 'bucket' => 'foo', + 'iterator' => null, + 'source_converter' => $converter, + 'resumable' => true + ) + )) + ->setMethods(array('createDirectory')) + ->getMock(); + + $sync->expects($this->once()) + ->method('createDirectory') + ->with(__FILE__); + + $ref = new \ReflectionMethod($sync, 'createTransferAction'); + $ref->setAccessible(true); + $result = $ref->invoke($sync, $this->getSplFile('s3://foo/baz')); + $this->assertInstanceOf('Aws\S3\ResumableDownload', $result); + } + + public function testDoesNotTransferFilesInBatchWithSameNameAsDir() + { + $client = $this->getServiceBuilder()->get('s3', true); + + $actualCommands = array( + $client->getCommand('GetObject', array('Bucket' => 'foo', 'Key' => 'bar', 'SaveAs' => '/tmp/test')), + $client->getCommand('GetObject', array('Bucket' => 'foo', 'Key' => 'bar', 'SaveAs' => '/tmp/foo')), + $client->getCommand('GetObject', array('Bucket' => 'foo', 'Key' => 'bar', 'SaveAs' => '/tmp/foo/bar.jpg')), + $client->getCommand('GetObject', array('Bucket' => 'foo', 'Key' => 'bar', 'SaveAs' => '/tmp/foo/baz/bam')), + $client->getCommand('GetObject', array('Bucket' => 'foo', 'Key' => 'bar', 'SaveAs' => '/tmp/foo/baz/bam/a')) + ); + + $sync = $this->getMockBuilder('Aws\S3\Sync\DownloadSync') + ->disableOriginalConstructor() + ->getMock(); + + $ref = new \ReflectionMethod($sync, 'filterCommands'); + $ref->setAccessible(true); + $result = array_values(array_map(function ($command) { + return $command['SaveAs']; + }, $ref->invoke($sync, $actualCommands))); + $this->assertEquals(array( + '/tmp/test', + '/tmp/foo/bar.jpg', + '/tmp/foo/baz/bam/a' + ), $result); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Sync/KeyConverterTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Sync/KeyConverterTest.php new file mode 100644 index 0000000..2fe783d --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Sync/KeyConverterTest.php @@ -0,0 +1,37 @@ +assertEquals('/foo|abc|123', $c->convert('/test/123/abc/123')); + } + + public function testDoesNotStripLeadingSlash() + { + $c = new KeyConverter('/test', '../foo/'); + $this->assertEquals('../foo/123/abc', $c->convert('/test/123/abc')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Sync/UploadSyncBuilderTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Sync/UploadSyncBuilderTest.php new file mode 100644 index 0000000..a78f4ae --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Sync/UploadSyncBuilderTest.php @@ -0,0 +1,134 @@ +getServiceBuilder()->get('s3', true); + $this->setMockResponse($client, array('s3/list_objects_empty')); + + return $client; + } + + public function testUploadsFromDirectory() + { + $b = UploadSyncBuilder::getInstance() + ->uploadFromDirectory(__DIR__)->setBucket('foo')->setClient($this->getPreparedClient())->build(); + $i = $this->readAttribute($b, 'options')->get('iterator'); + $this->assertInstanceOf('Aws\S3\Sync\ChangedFilesIterator', $i); + $this->assertInstanceOf('\NoRewindIterator', $i->getInnerIterator()); + $i = $i->getInnerIterator()->getInnerIterator(); + $this->assertInstanceOf('Guzzle\Iterator\FilterIterator', $i); + $this->assertInstanceOf('RecursiveIteratorIterator', $i->getInnerIterator()); + $filenames = array_filter(iterator_to_array($i), function ($f) { return (string) $f; }); + $this->assertContains(__FILE__, $filenames); + } + + public function testUploadsFromGlob() + { + $b = UploadSyncBuilder::getInstance() + ->uploadFromGlob(__DIR__ . '/*.php')->setBucket('foo')->setClient($this->getPreparedClient())->build(); + $i = $this->readAttribute($b, 'options')->get('iterator'); + $this->assertInstanceOf('Aws\S3\Sync\ChangedFilesIterator', $i); + $this->assertInstanceOf('\NoRewindIterator', $i->getInnerIterator()); + $i = $i->getInnerIterator()->getInnerIterator(); + $this->assertInstanceOf('Guzzle\Iterator\FilterIterator', $i); + $this->assertInstanceOf('GlobIterator', $i->getInnerIterator()); + $filenames = array_filter(iterator_to_array($i), function ($f) { return (string) $f; }); + $this->assertContains(__FILE__, $filenames); + } + + public function testCanSetAclOnPutObject() + { + $client = $this->getServiceBuilder()->get('s3', true); + $this->setMockResponse($client, array('s3/list_objects_empty', 's3/head_success')); + $i = new \ArrayIterator(array(new \SplFileInfo(__FILE__))); + $out = fopen('php://temp', 'r+'); + $b = UploadSyncBuilder::getInstance() + ->setBaseDir(__DIR__) + ->setSourceIterator($i) + ->setBucket('foo') + ->setClient($client) + ->enableDebugOutput($out) + ->setAcl('public-read') + ->build(); + $b->transfer(); + $requests = $this->getMockedRequests(); + $this->assertCount(2, $requests); + $put = $requests[1]; + $this->assertEquals('PUT', $put->getMethod()); + $this->assertEquals('/UploadSyncBuilderTest.php', $put->getResource()); + $this->assertEquals('public-read', $put->getHeader('x-amz-acl')); + $this->assertEquals('foo.s3.amazonaws.com', $put->getHost()); + $this->assertNotNull($put->getHeader('Content-MD5')); + + rewind($out); + $this->assertContains('Uploading ' . __FILE__ . ' -> /UploadSyncBuilderTest.php (', stream_get_contents($out)); + } + + public function testCanSetAcpOnMultipartUploadsAndEmitsDebug() + { + $client = $this->getServiceBuilder()->get('s3', true); + $this->setMockResponse($client, array( + 's3/list_objects_empty', + 's3/initiate_multipart_upload', + 's3/upload_part', + 's3/complete_multipart_upload' + )); + + $out = fopen('php://temp', 'r+'); + + UploadSyncBuilder::getInstance() + ->setBucket('foo') + ->setClient($client) + ->setBaseDir(__DIR__) + ->enableDebugOutput($out) + ->setSourceIterator(new \ArrayIterator(array(new \SplFileInfo(__FILE__)))) + ->setOperationParams(array('Metadata' => array('foo' => 'bar'))) + ->setMultipartUploadSize(filesize(__FILE__) - 1) + ->setAcp(AcpBuilder::newInstance()->setOwner('123')->addGrantForEmail('READ_ACP', 'foo@baz.com')->build()) + ->build() + ->transfer(); + + $requests = $this->getMockedRequests(); + $this->assertCount(4, $requests); + $this->assertEquals('POST', $requests[1]->getMethod()); + $this->assertContains('?uploads', $requests[1]->getResource()); + $this->assertNotNull($requests[1]->getHeader('x-amz-grant-read-acp')); + $this->assertEquals('bar', (string) $requests[1]->getHeader('x-amz-meta-foo')); + $this->assertEquals('PUT', $requests[2]->getMethod()); + $this->assertEquals('POST', $requests[3]->getMethod()); + $this->assertContains('uploadId=', $requests[3]->getResource()); + + rewind($out); + $contents = stream_get_contents($out); + $this->assertContains( + 'Beginning multipart upload: ' . __FILE__ . ' -> /UploadSyncBuilderTest.php (', + $contents + ); + $this->assertContains('- Part 1 (', $contents); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Sync/UploadSyncTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Sync/UploadSyncTest.php new file mode 100644 index 0000000..1ea0ab7 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Sync/UploadSyncTest.php @@ -0,0 +1,134 @@ +tmpFile = null; + } + + public function tearDown() + { + if ($this->tmpFile) { + unlink($this->tmpFile); + } + } + + /** + * @expectedException \PHPUnit_Framework_Error_Warning + * @expectedExceptionMessage failed to open stream + */ + public function testEnsuresFileExists() + { + $sync = $this->getMockBuilder('Aws\S3\Sync\UploadSync') + ->setConstructorArgs(array( + array( + 'client' => $this->getServiceBuilder()->get('s3'), + 'bucket' => 'foo', + 'iterator' => null, + 'source_converter' => new KeyConverter() + ) + )) + ->getMock(); + $ref = new \ReflectionMethod($sync, 'createTransferAction'); + $ref->setAccessible(true); + $ref->invoke($sync, $this->getSplFile('/path/to/does/not/exist')); + } + + public function testCreatesSimpleCommand() + { + $result = $this->getAction($this->getUploadSync(1000, $this->getServiceBuilder()->get('s3', true))); + $this->assertEquals('foo', $result['Bucket']); + $this->assertNotNull($result['Key']); + $this->assertEquals('test', (string) $result['Body']); + } + + public function testCreatesMultipartUpload() + { + $client = $this->getServiceBuilder()->get('s3', true); + $this->setMockResponse($client, 's3/initiate_multipart_upload'); + $result = $this->getAction($this->getUploadSync(2, $client)); + $this->assertInstanceOf('Aws\S3\Model\MultipartUpload\AbstractTransfer', $result); + } + + public function testEmitsBeforeMultipartUpload() + { + $client = $this->getServiceBuilder()->get('s3', true); + $this->setMockResponse($client, 's3/initiate_multipart_upload'); + $builder = $this->getUploadSync(2, $client); + $ev = null; + $builder->getEventDispatcher()->addListener(UploadSync::BEFORE_MULTIPART_BUILD, function (Event $event) use (&$ev) { + $ev = $event; + }); + $result = $this->getAction($builder); + $this->assertInstanceOf('Aws\S3\Model\MultipartUpload\AbstractTransfer', $result); + $this->assertInstanceOf('Symfony\Component\EventDispatcher\Event', $ev); + $this->assertInstanceOf('Aws\S3\Model\MultipartUpload\UploadBuilder', $ev['builder']); + $this->assertInstanceOf('SplFileInfo', $ev['file']); + } + + protected function getSplFile($filename, $size = 4) + { + $file = $this->getMockBuilder('SplFileInfo') + ->setMethods(array('getPathName', 'getRealPath', 'getSize')) + ->disableOriginalConstructor() + ->getMock(); + $file->expects($this->once()) + ->method('getRealPath') + ->will($this->returnValue($filename)); + $file->expects($this->any()) + ->method('getSize') + ->will($this->returnValue($size)); + + return $file; + } + + protected function getUploadSync($size, $client) + { + return new UploadSync(array( + 'client' => $client, + 'bucket' => 'foo', + 'iterator' => null, + 'source_converter' => new KeyConverter(), + 'multipart_upload_size' => $size + )); + } + + protected function getAction($sync) + { + $path = tempnam('/tmp', 'test_simple'); + file_put_contents($path, 'test'); + $ref = new \ReflectionMethod($sync, 'createTransferAction'); + $ref->setAccessible(true); + $result = $ref->invoke($sync, $this->getSplFile($path)); + $this->tmpFile = $path; + + return $result; + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Waiter/BucketExistsTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Waiter/BucketExistsTest.php new file mode 100644 index 0000000..3cfe641 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Waiter/BucketExistsTest.php @@ -0,0 +1,48 @@ +getServiceBuilder()->get('s3', true); + $this->setMockResponse($client, 's3/head_success'); + $client->waitUntil('bucket_exists', array('Bucket' => 'foo')); + $this->assertEquals(1, count($this->getMockedRequests())); + } + + public function testRetriesUntilBucketExists() + { + $client = $this->getServiceBuilder()->get('s3', true); + $this->setMockResponse($client, array('s3/head_failure', 's3/head_success')); + $client->waitUntil('bucket_exists', array('Bucket' => 'foo', 'waiter.interval' => 0)); + $this->assertEquals(2, count($this->getMockedRequests())); + } + + /** + * @expectedException \Aws\Common\Exception\RuntimeException + */ + public function testDoesNotBuffer500Exceptions() + { + $client = $this->getServiceBuilder()->get('s3', true); + $this->setMockResponse($client, array(new Response(501))); + $client->waitUntil('bucket_exists', array('Bucket' => 'foo', 'waiter.interval' => 0)); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Waiter/BucketNotExistsTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Waiter/BucketNotExistsTest.php new file mode 100644 index 0000000..59b44c3 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Waiter/BucketNotExistsTest.php @@ -0,0 +1,48 @@ +getServiceBuilder()->get('s3', true); + $this->setMockResponse($client, 's3/head_failure'); + $client->waitUntil('bucket_not_exists', array('Bucket' => 'foo')); + $this->assertEquals(1, count($this->getMockedRequests())); + } + + public function testRetriesUntilBucketNotExists() + { + $client = $this->getServiceBuilder()->get('s3', true); + $this->setMockResponse($client, array('s3/head_success', 's3/head_failure')); + $client->waitUntil('bucket_not_exists', array('Bucket' => 'foo', 'waiter.interval' => 0)); + $this->assertEquals(2, count($this->getMockedRequests())); + } + + /** + * @expectedException \Aws\Common\Exception\RuntimeException + */ + public function testDoesNotBuffer500Exceptions() + { + $client = $this->getServiceBuilder()->get('s3', true); + $this->setMockResponse($client, array(new Response(501))); + $client->waitUntil('bucket_not_exists', array('Bucket' => 'foo', 'waiter.interval' => 0)); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Waiter/ObjectExistsWaiterTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Waiter/ObjectExistsWaiterTest.php new file mode 100644 index 0000000..0beb991 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/S3/Waiter/ObjectExistsWaiterTest.php @@ -0,0 +1,39 @@ +getServiceBuilder()->get('s3', true); + $mock = $this->setMockResponse($client, 's3/head_success'); + $client->waitUntil('object_exists', array('Bucket' => 'foo', 'Key' => 'bar')); + $this->assertEquals(1, count($this->getMockedRequests())); + $requests = $mock->getReceivedRequests(); + $this->assertEquals('foo.s3.amazonaws.com', $requests[0]->getHost()); + $this->assertEquals('/bar', $requests[0]->getPath()); + } + + public function testRetriesUntilObjectExists() + { + $client = $this->getServiceBuilder()->get('s3', true); + $this->setMockResponse($client, array('s3/head_failure', 's3/head_success')); + $client->waitUntil('object_exists', array('Bucket' => 'foo', 'Key' => 'bar', 'waiter.interval' => 0)); + $this->assertEquals(2, count($this->getMockedRequests())); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Ses/Integration/IntegrationTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Ses/Integration/IntegrationTest.php new file mode 100644 index 0000000..093afef --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Ses/Integration/IntegrationTest.php @@ -0,0 +1,155 @@ +get('ses'); + try { + $result = $ses->getIdentityVerificationAttributes(array( + 'Identities' => array($emailAddress), + )); + $status = $result->getPath("VerificationAttributes/{$emailAddress}/VerificationStatus"); + if ($status === VerificationStatus::SUCCESS) { + self::log('Good! The provided email address is a verified email identity for SES.'); + } else { + self::log('Uh oh! The provided email address is NOT a verified email identity for SES.'); + $emailAddress = null; + } + } catch (\Exception $e) { + self::log('There was an error checking if the email address provided in your phpunit.functional.xml is verified.'); + $emailAddress = null; + } + } else { + self::log('No verified email address was provided in your phpunit.functional.xml.'); + $emailAddress = null; + } + + self::$verifiedEmail = $emailAddress; + } + + public function setUp() + { + $this->ses = $this->getServiceBuilder()->get('ses'); + if (!self::$verifiedEmail) { + $this->markTestSkipped(); + } + } + + public function testBasicIdentityCrudOperations() + { + $emailAddress = 'noreply@amazon.com'; + + self::log('Create a new identity.'); + $this->ses->getCommand('VerifyEmailIdentity', array('EmailAddress' => $emailAddress))->execute(); + $this->ses->waitUntilIdentityExists(array('Identities' => array($emailAddress))); + + self::log('Check the status and make sure it\'s pending.'); + $result = $this->ses->getCommand('GetIdentityVerificationAttributes', array( + 'Identities' => array($emailAddress), + ))->getResult(); + $this->assertEquals(VerificationStatus::PENDING, $result->getPath("VerificationAttributes/{$emailAddress}/VerificationStatus")); + + self::log('Make sure the identity is in the identity list.'); + $identities = $this->ses->getIterator('ListIdentities', array( + 'IdentityType' => IdentityType::EMAIL_ADDRESS + )); + $this->assertContains($emailAddress, iterator_to_array($identities)); + + self::log('Delete the identity.'); + $this->ses->getCommand('DeleteIdentity', array('Identity' => $emailAddress))->execute(); + self::log('Sleep after deleting to allow propagation of delete.'); + sleep(5); + + self::log('Make sure the identity is no longer in the identity list.'); + $identities = $this->ses->getIterator('ListIdentities', array( + 'IdentityType' => IdentityType::EMAIL_ADDRESS + )); + $this->assertNotContains($emailAddress, iterator_to_array($identities)); + } + + public function testSendEmail() + { + $this->ses->getCommand('SendEmail', array( + 'Source' => self::$verifiedEmail, + 'Destination' => array( + 'ToAddresses' => array(MailboxSimulator::SUCCESS) + ), + 'Message' => array( + 'Subject' => array( + 'Data' => 'Test Email', + ), + 'Body' => array( + 'Text' => array( + 'Data' => 'This is a test email.', + ), + ), + ), + ))->execute(); + } + + /** + * @expectedException \Aws\Ses\Exception\MessageRejectedException + */ + public function testSendErroneousEmailToBlacklistedAddress() + { + $this->ses->getCommand('SendEmail', array( + 'Source' => self::$verifiedEmail, + 'Destination' => array( + 'ToAddresses' => array(MailboxSimulator::BLACKLIST) + ), + 'Message' => array( + 'Subject' => array( + 'Data' => 'Test Email', + ), + 'Body' => array( + 'Text' => array( + 'Data' => 'This is a test email.', + ), + ), + ), + ))->execute(); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Ses/SesClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Ses/SesClientTest.php new file mode 100644 index 0000000..e6bbe53 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Ses/SesClientTest.php @@ -0,0 +1,38 @@ + 'foo', + 'secret' => 'bar', + 'region' => 'us-east-1' + )); + + $this->assertInstanceOf('Aws\Common\Signature\SignatureV4', $client->getSignature()); + $this->assertInstanceOf('Aws\Common\Credentials\Credentials', $client->getCredentials()); + $this->assertEquals('https://email.us-east-1.amazonaws.com', $client->getBaseUrl()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/SimpleDb/Integration/IntegrationTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/SimpleDb/Integration/IntegrationTest.php new file mode 100644 index 0000000..e7a54b6 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/SimpleDb/Integration/IntegrationTest.php @@ -0,0 +1,160 @@ +client = $this->getServiceBuilder()->get('sdb'); + $this->domainName = 'foo123'; + } + + public function testCreatesDomain() + { + $this->client->createDomain(array('DomainName' => $this->domainName)); + } + + /** + * @depends testCreatesDomain + */ + public function testListsDomainsResultIsProcessedCorrectly() + { + $result = $this->client->listDomains(); + $this->assertInternalType('array', $result['DomainNames']); + $this->assertNull($result['DomainName']); + + $found = false; + foreach ($result['DomainNames'] as $n) { + if ($n == $this->domainName) { + $found = true; + break; + } + } + + if (!$found) { + $this->fail('Did not find ' . $this->domainName . ' in domain list'); + } + + // Ensure that the iterator works + $i = $this->client->getIterator('ListDomains'); + $found = false; + foreach ($i as $n) { + if ($n == $this->domainName) { + $found = true; + break; + } + } + + if (!$found) { + $this->fail('Did not find ' . $this->domainName . ' in domain list'); + } + } + + /** + * @depends testCreatesDomain + */ + public function testAddsItem() + { + $this->client->putAttributes(array( + 'DomainName' => $this->domainName, + 'ItemName' => 'test', + 'Attributes' => array( + array('Name' => 'a', 'Value' => 1, 'Replace' => true), + array('Name' => 'b', 'Value' => 2), + ) + )); + + $result = $this->client->getAttributes(array( + 'DomainName' => $this->domainName, + 'ItemName' => 'test', + 'Attributes' => array( + 'a', 'b' + ), + 'ConsistentRead' => true + )); + + $this->assertEquals('b', $result->getPath('Attributes/0/Name')); + $this->assertEquals('2', $result->getPath('Attributes/0/Value')); + $this->assertEquals('a', $result->getPath('Attributes/1/Name')); + $this->assertEquals('1', $result->getPath('Attributes/1/Value')); + $this->assertArrayHasKey('ResponseMetadata', $result->toArray()); + } + + /** + * @depends testAddsItem + */ + public function testSelectsItems() + { + $result = $this->client->select(array( + 'SelectExpression' => 'select * from ' . $this->domainName, + 'ConsistentRead' => true + )); + $this->assertCount(1, $result['Items']); + $this->assertEquals(array( + 'Name' => 'test', + 'Attributes' => array( + array( + 'Name' => 'b', + 'Value' => '2', + ), + array( + 'Name' => 'a', + 'Value' => '1', + ), + ), + ), $result['Items'][0]); + + // Ensure that the select iterator works + $i = $this->client->getIterator('Select', array( + 'SelectExpression' => 'select * from ' . $this->domainName, + 'ConsistentRead' => true + )); + $this->assertEquals(array( + array( + 'Name' => 'test', + 'Attributes' => array( + array( + 'Name' => 'b', + 'Value' => '2', + ), + array( + 'Name' => 'a', + 'Value' => '1', + ), + ), + ) + ), iterator_to_array($i)); + } + + /** + * @depends testSelectsItems + */ + public function testDeleteDomains() + { + $this->client->deleteDomain(array('DomainName' => $this->domainName)); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/SimpleDb/SimpleDbClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/SimpleDb/SimpleDbClientTest.php new file mode 100644 index 0000000..de0dec2 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/SimpleDb/SimpleDbClientTest.php @@ -0,0 +1,36 @@ + 'foo', + 'secret' => 'bar', + 'region' => 'us-east-1' + )); + $this->assertEquals('https://sdb.amazonaws.com', $c->getBaseUrl()); + $this->assertNotNull($c->getDescription()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sns/Integration/IntegrationTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sns/Integration/IntegrationTest.php new file mode 100644 index 0000000..56d984e --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sns/Integration/IntegrationTest.php @@ -0,0 +1,163 @@ +sns = $this->getServiceBuilder()->get('sns'); + $this->sqs = $this->getServiceBuilder()->get('sqs'); + } + + public static function setUpBeforeClass() + { + self::$topic .= time(); + self::$queueName .= time(); + } + + public static function tearDownAfterClass() + { + // Delete the topic if it was created + if (self::$topicArn) { + try { + self::getServiceBuilder()->get('sns')->deleteTopic(array('TopicArn' => self::$topicArn)); + } catch (\Exception $e) {} + } + + // Delete the queue if it was created + if (self::$queueUrl) { + try { + self::getServiceBuilder()->get('sqs')->deleteQueue(array('QueueUrl' => self::$queueUrl)); + } catch (\Exception $e) {} + } + } + + public function testCreatesTopic() + { + self::log('Creating topic'); + $result = $this->sns->createTopic(array('Name' => self::$topic)); + $this->assertArrayHasKey('TopicArn', $result->toArray()); + $this->assertArrayHasKey('ResponseMetadata', $result->toArray()); + self::$topicArn = $result['TopicArn']; + + return self::$topicArn; + } + + /** + * @depends testCreatesTopic + */ + public function testListsTopics() + { + self::log('Listing topics'); + $iterator = $this->sns->getIterator('ListTopics'); + $topics = iterator_to_array($iterator); + $this->assertContains(self::$topicArn, $topics); + } + + /** + * @depends testCreatesTopic + */ + public function testSubscribesToTopic($topicArn) + { + // Create an SQS queue for the test + self::log('Creating a SQS queue'); + $result = $this->sqs->createQueue(array('QueueName' => self::$queueName)); + self::$queueUrl = $result['QueueUrl']; + $queueArn = $this->sqs->getQueueArn(self::$queueUrl); + + // Subscribe to the SNS topic using an SQS queue + self::log('Subscribing to the topic using the queue'); + $result = $this->sns->subscribe(array( + 'TopicArn' => self::$topicArn, + 'Endpoint' => $queueArn, + 'Protocol' => 'sqs' + )); + + // Ensure that the result has a SubscriptionArn + self::log('Subscribe result: ' . var_export($result->toArray(), true)); + $this->assertArrayHasKey('SubscriptionArn', $result->toArray()); + self::$subscriptionArn = $result['SubscriptionArn']; + + return self::$subscriptionArn; + } + + /** + * @depends testSubscribesToTopic + */ + public function testListsSubscriptions($subscriptionArn) + { + self::log('List subscriptions'); + $i = $this->sns->getIterator('ListSubscriptionsByTopic', array('TopicArn' => self::$topicArn)); + $data = iterator_to_array($i); + self::log('Found the following subscriptions: ' . var_export($data, true)); + foreach ($data as $sub) { + if ($sub['SubscriptionArn'] == self::$subscriptionArn) { + return true; + } + } + $this->fail('Did not find the subscription ARN of ' . self::$subscriptionArn); + } + + /** + * @depends testSubscribesToTopic + */ + public function testPublishesTopic($subscriptionArn) + { + $result = $this->sns->publish(array( + 'Message' => '{"default":"test","foo":"baz"}', + 'Subject' => 'Testing', + 'TopicArn' => self::$topicArn + )); + $this->assertArrayHasKey('MessageId', $result->toArray()); + self::log('Published a message: ' . $result['MessageId']); + } + + /** + * @depends testCreatesTopic + */ + public function testListsTopicAttributes($topicArn) + { + $result = $this->sns->getTopicAttributes(array('TopicArn' => $topicArn)); + $result = $result->toArray(); + // Ensure that the map was deserialized correctly + $this->assertArrayHasKey('TopicArn', $result['Attributes']); + $this->assertArrayHasKey('Policy', $result['Attributes']); + $this->assertArrayHasKey('Owner', $result['Attributes']); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sns/MessageValidator/MessageTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sns/MessageValidator/MessageTest.php new file mode 100644 index 0000000..69fcd50 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sns/MessageValidator/MessageTest.php @@ -0,0 +1,157 @@ + 'a', + 'MessageId' => 'b', + 'Timestamp' => 'c', + 'TopicArn' => 'd', + 'Type' => 'e', + 'Subject' => 'f', + 'Signature' => 'g', + 'SigningCertURL' => 'h', + 'SubscribeURL' => 'i', + 'Token' => 'j', + ); + + public function testGetters() + { + $message = new Message(new Collection($this->messageData)); + + $this->assertInstanceOf('Guzzle\Common\Collection', $message->getData()); + + foreach ($this->messageData as $key => $expectedValue) { + $this->assertEquals($expectedValue, $message->get($key)); + } + } + + public function testFactorySucceedsWithGoodData() + { + $this->assertInstanceOf("Aws\\Sns\\MessageValidator\\Message", Message::fromArray($this->messageData)); + } + + public function testFactoryFailsWithNoType() + { + $this->setExpectedException('Aws\Common\Exception\InvalidArgumentException'); + $data = $this->messageData; + unset($data['Type']); + Message::fromArray($data); + } + + public function testFactoryFailsWithMissingData() + { + $this->setExpectedException('Guzzle\Common\Exception\InvalidArgumentException'); + Message::fromArray(array('Type' => 'Notification')); + } + + public function testCanCreateFromRawPost() + { + // Prep php://input with mocked data + MockPhpStream::setStartingData(json_encode($this->messageData)); + stream_wrapper_unregister('php'); + stream_wrapper_register('php', __NAMESPACE__ . '\MockPhpStream'); + + $message = Message::fromRawPostData(); + $this->assertInstanceOf('Aws\Sns\MessageValidator\Message', $message); + + stream_wrapper_restore("php"); + } + + public function testCreateFromRawPostFailsWithMissingData() + { + $this->setExpectedException('Aws\Common\Exception\UnexpectedValueException'); + Message::fromRawPostData(); + } + + /** + * @dataProvider getDataForStringToSignTest + */ + public function testBuildsStringToSignCorrectly(array $messageData, $expectedSubject, $expectedStringToSign) + { + $message = new Message(new Collection($messageData)); + $this->assertEquals($expectedSubject, $message->get('Subject')); + $this->assertEquals($expectedStringToSign, $message->getStringToSign()); + } + + public function getDataForStringToSignTest() + { + $testCases = array(); + + // Test case where one key is not signable + $testCases[0] = array(); + $testCases[0][] = array( + 'TopicArn' => 'd', + 'Message' => 'a', + 'Timestamp' => 'c', + 'Type' => 'e', + 'MessageId' => 'b', + 'FooBar' => 'f', + ); + $testCases[0][] = null; + $testCases[0][] = <<< STRINGTOSIGN +Message +a +MessageId +b +Timestamp +c +TopicArn +d +Type +e + +STRINGTOSIGN; + + // Test case where all keys are signable + $testCases[1] = array(); + $testCases[1][] = array( + 'TopicArn' => 'e', + 'Message' => 'a', + 'Timestamp' => 'd', + 'Type' => 'f', + 'MessageId' => 'b', + 'Subject' => 'c', + ); + $testCases[1][] = 'c'; + $testCases[1][] = <<< STRINGTOSIGN +Message +a +MessageId +b +Subject +c +Timestamp +d +TopicArn +e +Type +f + +STRINGTOSIGN; + + return $testCases; + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sns/MessageValidator/MessageValidatorTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sns/MessageValidator/MessageValidatorTest.php new file mode 100644 index 0000000..8152e76 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sns/MessageValidator/MessageValidatorTest.php @@ -0,0 +1,141 @@ +markTestSkipped('The OpenSSL extension is required to run the tests for MessageValidator.'); + } + } + + public function testIsValidReturnsFalseOnFailedValidation() + { + $validator = new MessageValidator(); + $message = new Message(new Collection()); + $this->assertFalse($validator->isValid($message)); + } + + public function testValidateFailsWhenCertUrlDoesNotMatchAws() + { + $this->setExpectedException('Aws\Sns\MessageValidator\Exception\CertificateFromUnrecognizedSourceException'); + + $validator = new MessageValidator(); + $message = new Message(new Collection()); + $validator->validate($message); + } + + public function testValidateFailsWhenCannotDeterminePublicKey() + { + $this->setExpectedException('Aws\Sns\MessageValidator\Exception\CannotGetPublicKeyFromCertificateException'); + + // Create the validator with a mock HTTP client + $client = $this->getMockClient(); + $validator = new MessageValidator($client); + + $message = new Message(new Collection(array('SigningCertURL' => 'https://foo.amazonaws.com/bar'))); + $validator->validate($message); + } + + public function testValidateFailsWhenMessageIsInvalid() + { + $this->setExpectedException('Aws\Sns\MessageValidator\Exception\InvalidMessageSignatureException'); + + // Get the signature for some dummy data + list($signature, $certificate) = $this->getSignature('foo'); + + // Create the validator with a mock HTTP client that will respond with the certificate + $client = $this->getMockClient(new Response(200, null, $certificate)); + $validator = new MessageValidator($client); + + $message = new Message(new Collection(array( + 'SigningCertURL' => 'https://foo.amazonaws.com/bar', + 'Signature' => $signature, + ))); + $validator->validate($message); + } + + public function testValidateSucceedsWhenMessageIsValid() + { + // Create a real message + $message = Message::fromArray(array( + 'Message' => 'foo', + 'MessageId' => 'bar', + 'Timestamp' => time(), + 'TopicArn' => 'baz', + 'Type' => 'Notification', + 'SigningCertURL' => 'https://foo.amazonaws.com/bar', + 'Signature' => '', + )); + + // Get the signature for a real message + list($signature, $certificate) = $this->getSignature($message->getStringToSign()); + $message->getData()->set('Signature', $signature); + + // Create the validator with a mock HTTP client that will respond with the certificate + $client = $this->getMockClient(new Response(200, null, $certificate)); + $validator = new MessageValidator($client); + + // The message should validate + $this->assertTrue($validator->isValid($message)); + } + + protected function getMockClient(Response $response = null) + { + $response = $response ?: new Response(200); + + $plugin = new MockPlugin(); + $plugin->addResponse($response); + + $client = new Client(); + $client->addSubscriber($plugin); + + return $client; + } + + protected function getSignature($stringToSign) + { + // Generate a new Certificate Signing Request and public/private keypair + $csr = openssl_csr_new(array(), $keypair); + + // Create the self-signed certificate + $x509 = openssl_csr_sign($csr, null, $keypair, 1); + openssl_x509_export($x509, $certificate); + + // Create the signature + $privateKey = openssl_get_privatekey($keypair); + openssl_sign($stringToSign, $signature, $privateKey); + + // Free the openssl resources used + openssl_pkey_free($keypair); + openssl_x509_free($x509); + + return array(base64_encode($signature), $certificate); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sns/MessageValidator/MockPhpStream.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sns/MessageValidator/MockPhpStream.php new file mode 100644 index 0000000..7da5fb3 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sns/MessageValidator/MockPhpStream.php @@ -0,0 +1,75 @@ +data = self::$startingData; + $this->index = 0; + $this->length = strlen(self::$startingData); + } + + public function stream_open($path, $mode, $options, &$opened_path) + { + return true; + } + + public function stream_close() + { + } + + public function stream_stat() + { + return array(); + } + + public function stream_flush() + { + return true; + } + + public function stream_read($count) + { + $length = min($count, $this->length - $this->index); + $data = substr($this->data, $this->index); + $this->index = $this->index + $length; + + return $data; + } + + public function stream_eof() + { + return ($this->index >= $this->length); + } + + public function stream_write($data) + { + return 0; + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sns/SnsClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sns/SnsClientTest.php new file mode 100644 index 0000000..735f6ed --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sns/SnsClientTest.php @@ -0,0 +1,74 @@ + 'foo', + 'secret' => 'bar', + 'region' => 'us-east-1' + )); + + $this->assertInstanceOf('Aws\Common\Signature\SignatureV4', $client->getSignature()); + $this->assertInstanceOf('Aws\Common\Credentials\Credentials', $client->getCredentials()); + $this->assertEquals('https://sns.us-east-1.amazonaws.com', $client->getBaseUrl()); + } + + public function testAttributesSerializeCorrectly() + { + $client = SnsClient::factory(array( + 'key' => 'foo', + 'secret' => 'bar', + 'region' => 'us-east-1' + )); + + // Mock the response so no request is sent to the service + $mockPlugin = new MockPlugin(); + $mockPlugin->addResponse(new Response(200)); + $client->addSubscriber($mockPlugin); + + // Listener to grab the request body about to be sent + $client->getEventDispatcher()->addListener('request.before_send', function ($event) use (&$actualRequestBody) { + list(, $actualRequestBody) = explode("\r\n\r\n", $event['request']); + }, -255); + + // Expected serialization; extracted from service API documentation + $expectedRequestBody = 'Action=SetPlatformApplicationAttributes&Version=2010-03-31&PlatformApplicationArn=arn%3' + . 'Aaws%3Asns%3Aus-west-2%3A123456789012%3Aapp%2FGCM%2Fgcmpushapp&Attributes.entry.1.key=EventEndpointCreat' + . 'ed&Attributes.entry.1.value=arn%3Aaws%3Asns%3Aus-west-2%3A123456789012%3Atopicarn'; + + // Perform the operation + $client->setPlatformApplicationAttributes(array( + 'PlatformApplicationArn' => 'arn:aws:sns:us-west-2:123456789012:app/GCM/gcmpushapp', + 'Attributes' => array( + 'EventEndpointCreated' => urldecode('arn:aws:sns:us-west-2:123456789012:topicarn'), + ) + )); + + $this->assertEquals($expectedRequestBody, $actualRequestBody); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sqs/Integration/IntegrationTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sqs/Integration/IntegrationTest.php new file mode 100644 index 0000000..f0efde8 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sqs/Integration/IntegrationTest.php @@ -0,0 +1,173 @@ +sqs = $this->getServiceBuilder()->get('sqs'); + } + + public function testBasicOperations() + { + // Create a queue and make sure everything goes OK + + $queueName = 'php-integ-sqs-queue-' . time(); + self::log('Create an SQS queue.'); + $result = $this->sqs->getCommand('CreateQueue', array( + 'QueueName' => $queueName, + 'Attributes' => array( + QueueAttribute::RECEIVE_MESSAGE_WAIT_TIME_SECONDS => 20, + QueueAttribute::DELAY_SECONDS => 10, + ), + ))->getResult(); + $createdQueueUrl = $result->get('QueueUrl'); + + self::log('Get the queue URL.'); + do { + try { + $result = $this->sqs->getCommand('GetQueueUrl', array( + 'QueueName' => $queueName + ))->getResult(); + $queueUrl = $result->get('QueueUrl'); + } catch (SqsException $e) { + $queueUrl = null; + sleep(2); + } + } while (!$queueUrl); + $this->assertEquals($createdQueueUrl, $queueUrl); + + self::log('Get the queue attributes.'); + $result = $this->sqs->getCommand('GetQueueAttributes', array( + 'QueueUrl' => $queueUrl, + 'AttributeNames' => array(QueueAttribute::ALL) + ))->getResult(); + $this->assertEquals(20, $result->getPath('Attributes/' . QueueAttribute::RECEIVE_MESSAGE_WAIT_TIME_SECONDS)); + $this->assertEquals(10, $result->getPath('Attributes/' . QueueAttribute::DELAY_SECONDS)); + + self::log('Make sure the custom ARN-calculating logic returns the actual ARN.'); + $this->assertEquals( + $this->sqs->getQueueArn($queueUrl), + $result->getPath('Attributes/' . QueueAttribute::QUEUE_ARN) + ); + + // Send, receive, and delete messages + + $messagesToDelete = array(); + + self::log('Send a message with no delay to the queue.'); + $this->sqs->getCommand('SendMessage', array( + 'QueueUrl' => $queueUrl, + 'MessageBody' => 'test message 1', + 'DelaySeconds' => 0, + 'VisibilityTimeout' => 300 + ))->execute(); + + self::log('Receive a message from the queue.'); + $result = $this->sqs->getCommand('ReceiveMessage', array( + 'QueueUrl' => $queueUrl, + 'AttributeNames' => array(MessageAttribute::ALL), + ))->getResult(); + $messages = $result->get('Messages'); + $this->assertCount(1, $messages); + $message = $messages[0]; + $this->assertEquals('test message 1', $message['Body']); + $this->assertCount(4, $message['Attributes']); // Make sure attributes are unmarshalled correctly + $messagesToDelete[] = array( + 'Id' => str_replace(' ', '-', $message['Body']), + 'ReceiptHandle' => $message['ReceiptHandle'], + ); + + self::log('Send and receive a delayed message and make sure long polling is working. Please wait.'); + $startTime = microtime(true); + $this->sqs->getCommand('SendMessage', array( + 'QueueUrl' => $queueUrl, + 'MessageBody' => 'test message 2', + ))->execute(); + $result = $this->sqs->getCommand('ReceiveMessage', array( + 'QueueUrl' => $queueUrl, + ))->getResult(); + $endTime = microtime(true); + $this->assertGreaterThan(5, $endTime - $startTime); + $this->assertGreaterThanOrEqual(1, count($result->get('Messages'))); + $message = $result->getPath('Messages/0'); + $messagesToDelete[] = array( + 'Id' => str_replace(' ', '-', $message['Body']), + 'ReceiptHandle' => $message['ReceiptHandle'], + ); + + self::log('Delete the messages using batch delete and verify that the deletions are successful.'); + $result = $this->sqs->getCommand('DeleteMessageBatch', array( + 'QueueUrl' => $queueUrl, + 'Entries' => $messagesToDelete, + ))->getResult(); + $deletions = $result['Successful']; + $this->assertCount(2, $deletions); + foreach ($deletions as $deletion) { + $this->assertRegExp('/^test\-message\-\d$/', $deletion['Id']); + } + + // Delete the queue + + self::log('Delete the queue.'); + $this->sqs->getCommand('DeleteQueue', array( + 'QueueUrl' => $queueUrl + ))->execute(); + } + + /** + * @expectedException \Aws\Sqs\Exception\SqsException + */ + public function testErrorParsing() + { + $this->sqs->getQueueUrl(array('QueueName' => 'php-fake-queue')); + } + + protected static function cleanUpQueues() + { + self::log('Cleanup any existing queues from other integ tests.'); + $sqs = self::getServiceBuilder()->get('sqs'); + foreach ($sqs->getIterator('ListQueues', array('QueueNamePrefix' => 'php-integ-sqs-')) as $queueUrl) { + $sqs->deleteQueue(array('QueueUrl' => $queueUrl)); + sleep(3); + } + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sqs/Md5ValidatorListenerTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sqs/Md5ValidatorListenerTest.php new file mode 100644 index 0000000..e11f78c --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sqs/Md5ValidatorListenerTest.php @@ -0,0 +1,67 @@ + array( + array('MD5OfBody' => 'foo', 'Body' => 'Bar') + ) + )); + + $command = $this->getMockBuilder('Guzzle\Tests\Service\Mock\MockCommand') + ->setMethods(array('getName', 'getResult')) + ->getMock(); + $command->expects($this->once())->method('getName')->will($this->returnValue('ReceiveMessage')); + $command->expects($this->once())->method('getResult')->will($this->returnValue($model)); + + $v = new Md5ValidatorListener(); + $v->onCommandBeforeSend(new Event(array('command' => $command))); + } + + public function testValidatesMd5() + { + $model = new Model(array( + 'Messages' => array( + array('MD5OfBody' => 'fafb00f5732ab283681e124bf8747ed1', 'Body' => 'This is a test message') + ) + )); + + $command = $this->getMockBuilder('Guzzle\Tests\Service\Mock\MockCommand') + ->setMethods(array('getName', 'getResult')) + ->getMock(); + $command->expects($this->once())->method('getName')->will($this->returnValue('ReceiveMessage')); + $command->expects($this->once())->method('getResult')->will($this->returnValue($model)); + + $v = new Md5ValidatorListener(); + $v->onCommandBeforeSend(new Event(array('command' => $command))); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sqs/QueueUrlListenerTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sqs/QueueUrlListenerTest.php new file mode 100644 index 0000000..ae07da9 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sqs/QueueUrlListenerTest.php @@ -0,0 +1,51 @@ +getSubscribedEvents(); + $this->assertArrayHasKey('command.before_send', $events); + + // Setup state of command/request + $newUrl = 'https://queue.amazonaws.com/stuff/in/the/path'; + $client = $this->getServiceBuilder()->get('s3', true); + $command = $client->getCommand('ListBuckets'); + $request = $command->prepare(); + $command->set('QueueUrl', $newUrl); + $request->getParams()->set('QueueUrl', $newUrl); + $event = new Event(array('command' => $command)); + + // Execute the listener and confirm effects + $listener->onCommandBeforeSend($event); + $this->assertEquals($newUrl, $request->getUrl()); + $this->assertFalse($request->getParams()->hasKey('QueueUrl')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sqs/SqsClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sqs/SqsClientTest.php new file mode 100644 index 0000000..66dfce8 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sqs/SqsClientTest.php @@ -0,0 +1,76 @@ + 'foo', + 'secret' => 'bar', + 'region' => 'us-east-1' + )); + + $this->assertInstanceOf('Aws\Common\Signature\SignatureV4', $client->getSignature()); + $this->assertInstanceOf('Aws\Common\Credentials\Credentials', $client->getCredentials()); + $this->assertEquals('https://sqs.us-east-1.amazonaws.com', $client->getBaseUrl()); + } + + public function testGetQueueArn() + { + $url = 'https://sqs.us-east-1.amazonaws.com/057737625318/php-integ-sqs-queue-1359765974'; + $arn = 'arn:aws:sqs:us-east-1:057737625318:php-integ-sqs-queue-1359765974'; + $sqs = SqsClient::factory(array('region' => 'us-east-1')); + + $this->assertEquals($arn, $sqs->getQueueArn($url)); + } + + /** + * @expectedException \Aws\Sqs\Exception\SqsException + * @expectedExceptionMessage Body MD5 mismatch for + */ + public function testValidatesSuccessfulMd5OfBody() + { + $mock = new MockPlugin(array( + Response::fromMessage("HTTP/1.1 200 OK\r\nContent-Type: application/xml\r\n\r\n" . + " + + + fooo + This is a test message + + + " + ) + )); + $sqs = SqsClient::factory(array( + 'key' => 'abc', + 'secret' => '123', + 'region' => 'us-east-1' + )); + $sqs->addSubscriber($mock); + $sqs->receiveMessage(array('QueueUrl' => 'http://foo.com')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/StorageGateway/Integration/IntegrationTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/StorageGateway/Integration/IntegrationTest.php new file mode 100644 index 0000000..f0a8711 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/StorageGateway/Integration/IntegrationTest.php @@ -0,0 +1,60 @@ +sg = $this->getServiceBuilder()->get('storagegateway'); + $this->sg->setRegion(Region::US_WEST_2); + } + + public function testListOperation() + { + $result = $this->sg->listGateways(); + $this->assertArrayHasKey('Gateways', $result->toArray()); + } + + /** + * @expectedException \Aws\StorageGateway\Exception\InvalidGatewayRequestException + * @expectedExceptionMessage The specified activation key was not found. + */ + public function testFailsToActivateInvalidGateway() + { + $this->sg->activateGateway(array( + 'ActivationKey' => 'fooV1-barV9-VVIUB-NKT0I-LRO6V', + 'GatewayName' => 'mygateway', + 'GatewayTimezone' => GatewayTimezone::GMT_MINUS_1200, + 'GatewayRegion' => Region::US_WEST_2, + 'GatewayType' => GatewayType::CACHED, + )); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/StorageGateway/StorageGatewayClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/StorageGateway/StorageGatewayClientTest.php new file mode 100644 index 0000000..141da1e --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/StorageGateway/StorageGatewayClientTest.php @@ -0,0 +1,38 @@ + 'foo', + 'secret' => 'bar', + 'region' => 'us-west-2' + )); + + $this->assertInstanceOf('Aws\Common\Signature\SignatureV4', $client->getSignature()); + $this->assertInstanceOf('Aws\Common\Credentials\Credentials', $client->getCredentials()); + $this->assertEquals('https://storagegateway.us-west-2.amazonaws.com', $client->getBaseUrl()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sts/Integration/IntegrationTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sts/Integration/IntegrationTest.php new file mode 100644 index 0000000..9633e7f --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sts/Integration/IntegrationTest.php @@ -0,0 +1,111 @@ +client = $client = $this->getServiceBuilder()->get('sts'); + } + + public function testRetrievesFederatedToken() + { + $command = $this->client->getCommand('GetFederationToken', array( + 'DurationSeconds' => 3609, + 'Name' => 'foo', + 'Policy' => json_encode(array( + 'Statement' => array( + array( + 'Effect' => 'Deny', + 'Action' => 's3:GetObject', + 'Resource' => 'arn:aws:s3:::mybucket/federated/Jill/*' + ) + ) + )) + )); + + try { + $command->execute(); + } catch (\Aws\Sts\Exception\StsException $e) { + echo $e->getMessage() . "\n"; + echo var_export($e->getResponse()->getRequest()->getParams()->get('aws.signed_headers'), true). "\n"; + echo $e->getResponse()->getRequest()->getParams()->get('aws.canonical_request') . "\n"; + echo $e->getResponse()->getRequest()->getParams()->get('aws.string_to_sign') . "\n"; + die(); + } + + // Ensure the query string variables were set correctly + $this->assertEquals('foo', $command->getRequest()->getPostField('Name')); + $this->assertEquals('GetFederationToken', $command->getRequest()->getPostField('Action')); + $this->assertNotEmpty($command->getRequest()->getPostField('Policy')); + $this->assertEquals(3609, $command->getRequest()->getPostField('DurationSeconds')); + + // Ensure that the result is an array + $this->assertInstanceOf('Guzzle\Service\Resource\Model', $command->getResult()); + $this->assertNotNull($command->getResult()->get('Credentials')); + $this->assertNotNull($command->getResult()->get('ResponseMetadata')); + } + + public function testRetrievesSessionTokenWithDefaultDuration() + { + $command = $this->client->getCommand('GetSessionToken'); + $this->assertInstanceOf('Guzzle\Service\Resource\Model', $command->getResult()); + } + + public function testRetrievesSessionTokenWithCustomDuration() + { + $command = $this->client->getCommand('GetSessionToken', array( + 'DurationSeconds' => 5000 + )); + + $this->assertInstanceOf('Guzzle\Service\Resource\Model', $command->getResult()); + $this->assertEquals('GetSessionToken', $command->getRequest()->getPostField('Action')); + $this->assertEquals(5000, $command->getRequest()->getPostField('DurationSeconds')); + } + + /** + * @expectedException \Aws\Sts\Exception\StsException + * @expectedExceptionMessage Not authorized to perform sts:AssumeRoleWithWebIdentity + */ + public function testFailsOnBadWebIdentity() + { + $this->client->assumeRoleWithWebIdentity(array( + 'RoleArn' => 'arn:aws:iam::123123123123:role/DummyRole.', + 'RoleSessionName' => 'dummy-session-name', + 'WebIdentityToken' => 'dummy-oauth-token', + 'ProviderId' => 'dummy-provider-name', + 'Policy' => json_encode(array( + 'Statement' => array( + array( + 'Effect' => 'Deny', + 'Action' => 's3:GetObject', + 'Resource' => 'arn:aws:s3:::mybucket/dummy/*' + ) + ) + )), + )); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sts/StsClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sts/StsClientTest.php new file mode 100644 index 0000000..70c3b62 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Sts/StsClientTest.php @@ -0,0 +1,104 @@ + 'foo', + 'secret' => 'bar', + 'region' => 'us-west-1' + )); + + $this->assertInstanceOf('Aws\Common\Credentials\Credentials', $client->getCredentials()); + $this->assertEquals('https://sts.amazonaws.com', $client->getBaseUrl()); + $this->assertInstanceOf('Aws\Common\Signature\SignatureV4', $client->getSignature()); + $this->assertTrue($client->getDescription()->hasOperation('GetSessionToken')); + } + + /** + * @expectedException \Aws\Common\Exception\InvalidArgumentException + */ + public function testRequiresLongTermCredentials() + { + StsClient::factory(array( + 'key' => 'foo', + 'secret' => 'bar', + 'token' => 'foo', + 'region' => 'us-west-1' + )); + } + + public function testCanCreateCredentialsObjectFromStsResult() + { + $result = new Model(array( + 'Credentials' => array( + 'AccessKeyId' => 'foo', + 'SecretAccessKey' => 'bar', + 'SessionToken' => 'baz', + 'Expiration' => 30, + ) + )); + + $client = StsClient::factory(); + $credentials = $client->createCredentials($result); + + $this->assertInstanceOf('Aws\Common\Credentials\Credentials', $credentials); + $this->assertEquals('foo', $credentials->getAccessKeyId()); + $this->assertEquals('bar', $credentials->getSecretKey()); + $this->assertEquals('baz', $credentials->getSecurityToken()); + $this->assertEquals(30, $credentials->getExpiration()); + } + + /** + * @expectedException \Aws\Common\Exception\InvalidArgumentException + */ + public function testThrowsExceptionWhenCreatingCredentialsFromInvalidInput() + { + $client = StsClient::factory(); + $credentials = $client->createCredentials(new Model(array())); + } + + public function testThatAssumeRoleWithWebIdentityRequestsDoNotGetSigned() + { + $client = StsClient::factory(); + + $mock = new MockPlugin(); + $mock->addResponse(new Response(200)); + $client->addSubscriber($mock); + + $command = $client->getCommand('AssumeRoleWithWebIdentity', array( + 'RoleArn' => 'xxxxxxxxxxxxxxxxxxxxxx', + 'RoleSessionName' => 'xx', + 'WebIdentityToken' => 'xxxx' + )); + $request = $command->prepare(); + $command->execute(); + + $this->assertFalse($request->hasHeader('Authorization')); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Support/Integration/Support_20121215_Test.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Support/Integration/Support_20121215_Test.php new file mode 100644 index 0000000..3994a86 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Support/Integration/Support_20121215_Test.php @@ -0,0 +1,187 @@ +client = $this->getServiceBuilder()->get('support', true); + } + + /** + * Describe the services that can be referenced in AWS Support cases + * + * @example Aws\Support\SupportClient::describeServices + */ + public function testDescribeServices() + { + $client = $this->client; + // @begin + + $result = $client->describeServices(); + $service = $result['services'][5]; + + // @end + $this->assertArrayHasKey('name', $service); + $this->assertArrayHasKey('categories', $service); + + return array($service); + } + + /** + * Describe the severity levels that can be referenced in AWS Support cases + * + * @depends testDescribeServices + * @example Aws\Support\SupportClient::describeSeverityLevels + */ + public function testDescribeSeverityLevels(array $data) + { + $client = $this->client; + // @begin + + $result = $client->describeSeverityLevels(); + $level = $result['severityLevels'][0]; + + // @end + $this->assertArrayHasKey('name', $level); + $this->assertArrayHasKey('code', $level); + + $data[] = $level; + + return $data; + } + + /** + * Create a support case + * + * @depends testDescribeSeverityLevels + * @example Aws\Support\SupportClient::createCase + */ + public function testCreateCase(array $data) + { + $client = $this->client; + list ($service, $level) = $data; + // @begin + + $result = $client->createCase(array( + 'subject' => 'Test Case', + 'serviceCode' => $service['code'], // (e.g., amazon-dynamodb) + 'severityCode' => $level['code'], //(e.g., low) + 'categoryCode' => $service['categories'][0]['code'], // (e.g., feature-request) + 'communicationBody' => 'Initial Message.', + )); + $caseId = $result['caseId']; + + // @end + $this->assertNotEmpty($caseId); + + return $caseId; + } + + /** + * Add communications to a support case + * + * @depends testCreateCase + * @example Aws\Support\SupportClient::addCommunicationToCase + */ + public function testAddCommunicationToCase($caseId) + { + $client = $this->client; + // @begin + + $client->addCommunicationToCase(array( + 'caseId' => $caseId, + 'communicationBody' => 'Message one.', + )); + + $client->addCommunicationToCase(array( + 'caseId' => $caseId, + 'communicationBody' => 'Message two.', + )); + + $client->addCommunicationToCase(array( + 'caseId' => $caseId, + 'communicationBody' => 'Message three.', + )); + + // @end + return $caseId; + } + + /** + * Describe communications + * + * @depends testAddCommunicationToCase + * @example Aws\Support\SupportClient::describeCommunications + */ + public function testDescribeCommunications($caseId) + { + $client = $this->client; + // @begin + + $numberOfCommunications = 0; + $communications = $client->getIterator('DescribeCommunications', array('caseId' => $caseId)); + foreach ($communications as $communication) { + echo $communication['body']; + $numberOfCommunications++; + } + //> Message three. Message two. Message one. Initial Message. + + echo $numberOfCommunications; + //> 4 + + // @end + $this->assertEquals( + "Message three.\n\nMessage two.\n\nMessage one.\n\nInitial Message.\n\n4", + $this->getActualOutput() + ); + + return $caseId; + } + + /** + * Resolve a support case + * + * @depends testDescribeCommunications + * @example Aws\Support\SupportClient::resolveCase + */ + public function testResolveCase($caseId) + { + $client = $this->client; + // @begin + + $result = $client->resolveCase(array( + 'caseId' => $caseId + )); + echo "The initial case status was: {$result['initialCaseStatus']}.\n"; + echo "The final case status was: {$result['finalCaseStatus']}.\n"; + + // @end + $this->assertNotEmpty($this->getActualOutput()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Support/SupportClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Support/SupportClientTest.php new file mode 100644 index 0000000..13aa925 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Support/SupportClientTest.php @@ -0,0 +1,40 @@ + 'foo', + 'secret' => 'bar', + 'region' => 'us-east-1' + )); + + $this->assertInstanceOf('Aws\Common\Signature\SignatureV4', $client->getSignature()); + $this->assertInstanceOf('Aws\Common\Credentials\Credentials', $client->getCredentials()); + $this->assertEquals('https://support.us-east-1.amazonaws.com', $client->getBaseUrl()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Swf/Integration/IntegrationTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Swf/Integration/IntegrationTest.php new file mode 100644 index 0000000..b3c85ed --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Swf/Integration/IntegrationTest.php @@ -0,0 +1,112 @@ +swf = $this->getServiceBuilder()->get('swf'); + } + + public function testBasicOperations() + { + $registeredDomain = 'php-integ-swf-domain'; + $deprecatedDomain = 'php-integ-swf-domain-deprecated'; + + self::log('Create a SWF domain to use for testing.'); + try { + $this->swf->getCommand('RegisterDomain', array( + 'name' => $registeredDomain, + 'description' => 'For integration testing in the AWS SDK for PHP', + 'workflowExecutionRetentionPeriodInDays' => '10' + ))->execute(); + } catch (DomainAlreadyExistsException $e) { + self::log('The domain is already created.'); + } + + self::log('Make sure the domain is there with the correct status.'); + $result = $this->swf->getCommand('DescribeDomain', array( + 'name' => $registeredDomain, + ))->getResult(); + $this->assertEquals(RegistrationStatus::REGISTERED, $result->getPath('domainInfo/status')); + + self::log('Create a second SWF domain to use for testing.'); + try { + $this->swf->getCommand('RegisterDomain', array( + 'name' => $deprecatedDomain, + 'description' => 'For integration testing in the AWS SDK for PHP', + 'workflowExecutionRetentionPeriodInDays' => '10' + ))->execute(); + } catch (DomainAlreadyExistsException $e) { + self::log('The second domain is already created.'); + } + + self::log('Deprecate the second SWF domain for testing.'); + try { + $this->swf->getCommand('DeprecateDomain', array( + 'name' => $deprecatedDomain, + ))->execute(); + } catch (DomainDeprecatedException $e) { + self::log('The second domain is already deprecated.'); + } + + self::log('Make sure the second domain is there with the correct deprecated status.'); + $result = $this->swf->getCommand('DescribeDomain', array( + 'name' => $deprecatedDomain, + ))->getResult(); + $this->assertEquals(RegistrationStatus::DEPRECATED, $result->getPath('domainInfo/status')); + + self::log('List the domains using iterators and make sure the two domains are there.'); + $domains = new AppendIterator(); + $domains->append($this->swf->getIterator('ListDomains', array( + 'reverseOrder' => true, + 'registrationStatus' => RegistrationStatus::REGISTERED, + ))); + $domains->append($this->swf->getIterator('ListDomains', array( + 'registrationStatus' => RegistrationStatus::DEPRECATED, + ))); + $domains = new FilterIterator($domains, function (array $domain) { + return (strpos($domain['name'], 'php-integ-swf') === 0); + }); + $domains = new MapIterator($domains, function (array $domain) { + return $domain['name']; + }); + $this->assertEquals(2, iterator_count($domains)); + $domainNames = array(); + foreach ($domains as $domain) { + $domainNames[] = $domain; + } + $this->assertEquals(array($registeredDomain, $deprecatedDomain), $domainNames); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/Aws/Tests/Swf/SwfClientTest.php b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Swf/SwfClientTest.php new file mode 100644 index 0000000..c78019c --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/Aws/Tests/Swf/SwfClientTest.php @@ -0,0 +1,38 @@ + 'foo', + 'secret' => 'bar', + 'region' => 'us-west-2' + )); + + $this->assertInstanceOf('Aws\Common\Signature\SignatureV4', $client->getSignature()); + $this->assertInstanceOf('Aws\Common\Credentials\Credentials', $client->getCredentials()); + $this->assertEquals('https://swf.us-west-2.amazonaws.com', $client->getBaseUrl()); + } +} diff --git a/vendor/aws/aws-sdk-php/tests/bootstrap.php b/vendor/aws/aws-sdk-php/tests/bootstrap.php new file mode 100644 index 0000000..9197aea --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/bootstrap.php @@ -0,0 +1,75 @@ +add('Aws\\Test', __DIR__); + +// Register services with the GuzzleTestCase +Guzzle\Tests\GuzzleTestCase::setMockBasePath(__DIR__ . '/mock'); + +// Allow command line overrides +if (get_cfg_var('CONFIG')) { + $_SERVER['CONFIG'] = get_cfg_var('CONFIG'); +} + +// Set the service configuration file if it was not provided from the CLI +if (!isset($_SERVER['CONFIG'])) { + $serviceConfig = $_SERVER['CONFIG'] = dirname(__DIR__) . '/test_services.json'; + $_SERVER['CONFIG'] = $serviceConfig; + if (!file_exists($serviceConfig)) { + copy($serviceConfig . '.dist', $serviceConfig); + } +} + +if (!is_readable($_SERVER['CONFIG'])) { + die("Unable to read service configuration from '{$_SERVER['CONFIG']}'\n"); +} + +// If the global prefix is hostname, then use the crc32() of gethostname() +if (!isset($_SERVER['PREFIX']) || $_SERVER['PREFIX'] == 'hostname') { + $_SERVER['PREFIX'] = crc32(gethostname()); +} + +// Instantiate the service builder +$aws = Aws\Common\Aws::factory($_SERVER['CONFIG']); + +// Turn on wire logging if configured +$aws->getEventDispatcher()->addListener('service_builder.create_client', function (\Guzzle\Common\Event $event) { + if (isset($_SERVER['WIRE_LOGGING']) && $_SERVER['WIRE_LOGGING']) { + $event['client']->addSubscriber(Guzzle\Plugin\Log\LogPlugin::getDebugPlugin()); + } +}); + +// Configure the tests to ise the instantiated AWS service builder +Guzzle\Tests\GuzzleTestCase::setServiceBuilder($aws); + +// Emit deprecation warnings +Guzzle\Common\Version::$emitWarnings = true; diff --git a/vendor/aws/aws-sdk-php/tests/mock/cloudfront/GetDistribution_Deployed b/vendor/aws/aws-sdk-php/tests/mock/cloudfront/GetDistribution_Deployed new file mode 100644 index 0000000..68d7df8 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/cloudfront/GetDistribution_Deployed @@ -0,0 +1,130 @@ +HTTP/1.1 200 OK +x-amz-request-id: XYZ +Date: Wed, 30 Nov 2011 03:39:32 GMT +Content-Type: application/xml + + + + EDFDVBD6EXAMPLE + Deployed + 2012-05-19T19:37:58Z + 1 + d111111abcdef8.cloudfront.net + + 3 + + + self + + 1 + + APKA9ONS7QCOWEXAMPLE + + + + + 111122223333 + + 2 + APKAI72T5DYBXEXAMPLE + APKAU72D8DYNXEXAMPLE + + + + 444455556666 + + 0 + + + + + + example.com2012-04-11-5:09pm + + 1 + + www.example.com + + + index.html + + 2 + + + example-Amazon S3-origin + myawsbucket.s3.amazonaws.com + + origin-access-identity/cloudfront/E74FTE3AEXAMPLE + + + + example-custom-origin + example.com + + 80 + 443 + match-viewer + + + + + + example-Amazon S3-origin + + true + + whitelist + + 1 + + example-cookie + + + + + + true + 3 + + self + 111122223333 + 444455556666 + + + https-only + 0 + + + 1 + + *.jpg + example-custom-origin + + false + + all + + + + true + 2 + + self + 111122223333 + + + allow-all + 86400 + + + example comment + + true + true + myawslogbucket.s3.amazonaws.com + example.com. + + PriceClass_All + true + + diff --git a/vendor/aws/aws-sdk-php/tests/mock/cloudfront/GetDistribution_InProgress b/vendor/aws/aws-sdk-php/tests/mock/cloudfront/GetDistribution_InProgress new file mode 100644 index 0000000..7a69226 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/cloudfront/GetDistribution_InProgress @@ -0,0 +1,130 @@ +HTTP/1.1 200 OK +x-amz-request-id: XYZ +Date: Wed, 30 Nov 2011 03:39:32 GMT +Content-Type: application/xml + + + + EDFDVBD6EXAMPLE + InProgress + 2012-05-19T19:37:58Z + 1 + d111111abcdef8.cloudfront.net + + 3 + + + self + + 1 + + APKA9ONS7QCOWEXAMPLE + + + + + 111122223333 + + 2 + APKAI72T5DYBXEXAMPLE + APKAU72D8DYNXEXAMPLE + + + + 444455556666 + + 0 + + + + + + example.com2012-04-11-5:09pm + + 1 + + www.example.com + + + index.html + + 2 + + + example-Amazon S3-origin + myawsbucket.s3.amazonaws.com + + origin-access-identity/cloudfront/E74FTE3AEXAMPLE + + + + example-custom-origin + example.com + + 80 + 443 + match-viewer + + + + + + example-Amazon S3-origin + + true + + whitelist + + 1 + + example-cookie + + + + + + true + 3 + + self + 111122223333 + 444455556666 + + + https-only + 0 + + + 1 + + *.jpg + example-custom-origin + + false + + all + + + + true + 2 + + self + 111122223333 + + + allow-all + 86400 + + + example comment + + true + true + myawslogbucket.s3.amazonaws.com + example.com. + + PriceClass_All + true + + diff --git a/vendor/aws/aws-sdk-php/tests/mock/cloudfront/GetInvalidation_Completed b/vendor/aws/aws-sdk-php/tests/mock/cloudfront/GetInvalidation_Completed new file mode 100644 index 0000000..552d4e1 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/cloudfront/GetInvalidation_Completed @@ -0,0 +1,19 @@ +HTTP/1.1 200 OK +Content-Type: text/xml + + + IDFDVBD632BHDS5 + Completed + 2009-11-19T19:37:58Z + + + 3 + + /image1.jpg + /image2.jpg + /videos/movie.flv + + + 20120301090001 + + diff --git a/vendor/aws/aws-sdk-php/tests/mock/cloudfront/GetInvalidation_InProgress b/vendor/aws/aws-sdk-php/tests/mock/cloudfront/GetInvalidation_InProgress new file mode 100644 index 0000000..2fb3e29 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/cloudfront/GetInvalidation_InProgress @@ -0,0 +1,19 @@ +HTTP/1.1 200 OK +Content-Type: text/xml + + + IDFDVBD632BHDS5 + InProgress + 2009-11-19T19:37:58Z + + + 3 + + /image1.jpg + /image2.jpg + /videos/movie.flv + + + 20120301090001 + + diff --git a/vendor/aws/aws-sdk-php/tests/mock/cloudfront/GetStreamingDistribution_Deployed b/vendor/aws/aws-sdk-php/tests/mock/cloudfront/GetStreamingDistribution_Deployed new file mode 100644 index 0000000..2b9abaa --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/cloudfront/GetStreamingDistribution_Deployed @@ -0,0 +1,69 @@ +HTTP/1.1 200 OK +x-amz-request-id: XYZ +Date: Wed, 30 Nov 2011 03:39:32 GMT +Content-Type: application/xml + + + + EGTXBD79EXAMPLE + Deployed + 2012-05-19T19:37:58Z + s5c39gqb8ow64r.cloudfront.net + + 3 + + + self + + 1 + + APKA9ONS7QCOWEXAMPLE + + + + + 111122223333 + + 2 + APKAI72T5DYBXEXAMPLE + APKAU72D8DYNXEXAMPLE + + + + 444455556666 + + 0 + + + + + + 20120229090000 + + mystreamingbucket.s3.amazonaws.com + origin-access-identity/cloudfront/E74FTE3AEXAMPLE + + + 1 + + www.example.com + + + example comment + + true + myawslogbucket.s3.amazonaws.com + myprefix/ + + + 3 + + self + 111122223333 + 444455556666 + + + PriceClass_All + true + + diff --git a/vendor/aws/aws-sdk-php/tests/mock/cloudfront/GetStreamingDistribution_InProgress b/vendor/aws/aws-sdk-php/tests/mock/cloudfront/GetStreamingDistribution_InProgress new file mode 100644 index 0000000..eb9abd1 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/cloudfront/GetStreamingDistribution_InProgress @@ -0,0 +1,69 @@ +HTTP/1.1 200 OK +x-amz-request-id: XYZ +Date: Wed, 30 Nov 2011 03:39:32 GMT +Content-Type: application/xml + + + + EGTXBD79EXAMPLE + InProgress + 2012-05-19T19:37:58Z + s5c39gqb8ow64r.cloudfront.net + + 3 + + + self + + 1 + + APKA9ONS7QCOWEXAMPLE + + + + + 111122223333 + + 2 + APKAI72T5DYBXEXAMPLE + APKAU72D8DYNXEXAMPLE + + + + 444455556666 + + 0 + + + + + + 20120229090000 + + mystreamingbucket.s3.amazonaws.com + origin-access-identity/cloudfront/E74FTE3AEXAMPLE + + + 1 + + www.example.com + + + example comment + + true + myawslogbucket.s3.amazonaws.com + myprefix/ + + + 3 + + self + 111122223333 + 444455556666 + + + PriceClass_All + true + + diff --git a/vendor/aws/aws-sdk-php/tests/mock/cloudfront/ListDistributions_page_1 b/vendor/aws/aws-sdk-php/tests/mock/cloudfront/ListDistributions_page_1 new file mode 100644 index 0000000..31b0da1 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/cloudfront/ListDistributions_page_1 @@ -0,0 +1,99 @@ +HTTP/1.1 200 OK +x-amz-request-id: XYZ +Date: Wed, 30 Nov 2011 03:39:32 GMT +Content-Type: application/xml + + + + + ABC + true + 3 + + + EXAMPLE1 + Deployed + 2012-05-19T19:37:58Z + d111111abcdef8.cloudfront.net + + 1 + + www.example.com + + + + 2 + + + example-Amazon S3-origin + myawsbucket.s3.amazonaws.com + + origin-access-identity/cloudfront/E74FTE3AEXAMPLE + + + + example-custom-origin + example.com + + 80 + 443 + match-viewer + + + + + + example-Amazon S3-origin + + true + + whitelist + + 1 + + example-cookie + + + + + + true + 3 + + self + 111122223333 + 444455556666 + + + https-only + 0 + + + 1 + + *.jpg + example-custom-origin + + false + + all + + + + true + 2 + + self + 111122223333 + + + allow-all + 86400 + + + example comment + PriceClass_All + true + + + diff --git a/vendor/aws/aws-sdk-php/tests/mock/cloudfront/ListDistributions_page_2 b/vendor/aws/aws-sdk-php/tests/mock/cloudfront/ListDistributions_page_2 new file mode 100644 index 0000000..96254aa --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/cloudfront/ListDistributions_page_2 @@ -0,0 +1,184 @@ +HTTP/1.1 200 OK +x-amz-request-id: XYZ +Date: Wed, 30 Nov 2011 03:39:32 GMT +Content-Type: application/xml + + + + ABC + + false + 3 + + + EXAMPLE2 + Deployed + 2012-05-19T19:37:58Z + d111111abcdef8.cloudfront.net + + 1 + + www.example.com + + + + 2 + + + example-Amazon S3-origin + myawsbucket.s3.amazonaws.com + + origin-access-identity/cloudfront/E74FTE3AEXAMPLE + + + + example-custom-origin + example.com + + 80 + 443 + match-viewer + + + + + + example-Amazon S3-origin + + true + + whitelist + + 1 + + example-cookie + + + + + + true + 3 + + self + 111122223333 + 444455556666 + + + https-only + 0 + + + 1 + + *.jpg + example-custom-origin + + false + + all + + + + true + 2 + + self + 111122223333 + + + allow-all + 86400 + + + example comment + PriceClass_All + true + + + EXAMPLE3 + Deployed + 2012-05-19T19:37:58Z + d111111abcdef8.cloudfront.net + + 1 + + www.example.com + + + + 2 + + + example-Amazon S3-origin + myawsbucket.s3.amazonaws.com + + origin-access-identity/cloudfront/E74FTE3AEXAMPLE + + + + example-custom-origin + example.com + + 80 + 443 + match-viewer + + + + + + example-Amazon S3-origin + + true + + whitelist + + 1 + + example-cookie + + + + + + true + 3 + + self + 111122223333 + 444455556666 + + + https-only + 0 + + + 1 + + *.jpg + example-custom-origin + + false + + all + + + + true + 2 + + self + 111122223333 + + + allow-all + 86400 + + + example comment + PriceClass_All + true + + + diff --git a/vendor/aws/aws-sdk-php/tests/mock/cloudfront/ListStreamingDistributions_page_1 b/vendor/aws/aws-sdk-php/tests/mock/cloudfront/ListStreamingDistributions_page_1 new file mode 100644 index 0000000..72fcd84 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/cloudfront/ListStreamingDistributions_page_1 @@ -0,0 +1,29 @@ +HTTP/1.1 200 OK +x-amz-request-id: XYZ +Date: Wed, 30 Nov 2011 03:39:32 GMT +Content-Type: application/xml + + + + EGTXBD79EXAMPLE + ED4L98SBEXAMPLE + 1 + true + 3 + + + EXAMPLE1 + Deployed + 2012-05-19T19:37:58Z + s5c39gqb8ow64r.cloudfront.net + + mystreamingbucket.s3.amazonaws.com + + www.example.com + product.example.com + First distribution + PriceClass_All + true + + + diff --git a/vendor/aws/aws-sdk-php/tests/mock/cloudfront/ListStreamingDistributions_page_2 b/vendor/aws/aws-sdk-php/tests/mock/cloudfront/ListStreamingDistributions_page_2 new file mode 100644 index 0000000..88bfafd --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/cloudfront/ListStreamingDistributions_page_2 @@ -0,0 +1,43 @@ +HTTP/1.1 200 OK +x-amz-request-id: XYZ +Date: Wed, 30 Nov 2011 03:39:32 GMT +Content-Type: application/xml + + + + EGTXBD79EXAMPLE + ED4L98SBEXAMPLE + 3 + false + 3 + + + EXAMPLE2 + Deployed + 2012-05-19T19:37:58Z + s5c39gqb8ow64r.cloudfront.net + + mystreamingbucket.s3.amazonaws.com + + www.example.com + product.example.com + First distribution + PriceClass_All + true + + + EXAMPLE3 + Deployed + 2012-05-19T19:37:58Z + s5c39gqb8ow64r.cloudfront.net + + mystreamingbucket.s3.amazonaws.com + + www.example.com + product.example.com + First distribution + PriceClass_All + true + + + diff --git a/vendor/aws/aws-sdk-php/tests/mock/dynamodb/batch_get_item_empty_has_more b/vendor/aws/aws-sdk-php/tests/mock/dynamodb/batch_get_item_empty_has_more new file mode 100644 index 0000000..20e3c8d --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/dynamodb/batch_get_item_empty_has_more @@ -0,0 +1,17 @@ +HTTP/1.1 200 OK +x-amzn-RequestId: GTPQVRM4VJS792J1UFJTKUBVV4KQNSO5AEMVJF66Q9ASUAAJG +content-type: application/x-amz-json-1.0 +Date: Fri, 02 Sep 2011 23:07:39 GMT + +{ + "UnprocessedKeys": { + "Table3": { + "Keys": [ + {"AttributeName1": {"S":"KeyValue1"}, "AttributeName2":{"N":"2"}}, + {"AttributeName1": {"S":"KeyValue3"}, "AttributeName2":{"N":"4"}}, + {"AttributeName1": {"S":"KeyValue5"}, "AttributeName2":{"N":"6"}} + ], + "AttributesToGet":["AttributeName1", "AttributeName2", "AttributeName3"] + } + } +} diff --git a/vendor/aws/aws-sdk-php/tests/mock/dynamodb/batch_get_item_final b/vendor/aws/aws-sdk-php/tests/mock/dynamodb/batch_get_item_final new file mode 100644 index 0000000..44ce481 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/dynamodb/batch_get_item_final @@ -0,0 +1,19 @@ +HTTP/1.1 200 OK +x-amzn-RequestId: GTPQVRM4VJS792J1UFJTKUBVV4KQNSO5AEMVJF66Q9ASUAAJG +content-type: application/x-amz-json-1.0 +Date: Fri, 02 Sep 2011 23:07:39 GMT + +{ + "Responses": { + "Table1": [ + {"status":{"S":"online"},"user":{"S":"Casey"}}, + {"status":{"S":"working"},"user":{"S":"Riley"}}, + {"status":{"S":"running"},"user":{"S":"Dave"}} + ], + "Table2": [ + {"friends":{"SS":["Elisabeth", "Peter"]},"user":{"S":"Mingus"}}, + {"friends":{"SS":["Dave", "Peter"]},"user":{"S":"Julie"}} + ] + }, + "UnprocessedKeys":{} +} diff --git a/vendor/aws/aws-sdk-php/tests/mock/dynamodb/batch_get_item_has_more b/vendor/aws/aws-sdk-php/tests/mock/dynamodb/batch_get_item_has_more new file mode 100644 index 0000000..450a899 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/dynamodb/batch_get_item_has_more @@ -0,0 +1,26 @@ +HTTP/1.1 200 OK +x-amzn-RequestId: 8966d095-71e9-11e0-a498-71d736f27375 +content-type: application/x-amz-json-1.0 + +{ + "Responses": { + "Table1": [ + {"AttributeName1": {"S":"AttributeValue"}, "AttributeName2": {"N":"11"}, "AttributeName3": {"SS":["AttributeValue", "AttributeValue", "AttributeValue"]}}, + {"AttributeName1": {"S": "AttributeValue"}, "AttributeName2": {"S": "AttributeValue"}, "AttributeName3": {"NS": ["11", "12", "13"]}} + ], + "Table2": [ + {"AttributeName1": {"S":"AttributeValue"}, "AttributeName2": {"N":"21"}, "AttributeName3": {"SS":["AttributeValue", "AttributeValue", "AttributeValue"]}}, + {"AttributeName1": {"S": "AttributeValue"}, "AttributeName2": {"S": "AttributeValue"}, "AttributeName3": {"NS": ["21", "22","23"]}} + ] + }, + "UnprocessedKeys": { + "Table3": { + "Keys": [ + {"AttributeName1": {"S":"KeyValue1"}, "AttributeName2":{"N":"2"}}, + {"AttributeName1": {"S":"KeyValue3"}, "AttributeName2":{"N":"4"}}, + {"AttributeName1": {"S":"KeyValue5"}, "AttributeName2":{"N":"6"}} + ], + "AttributesToGet": ["AttributeName1", "AttributeName2", "AttributeName3"] + } + } +} diff --git a/vendor/aws/aws-sdk-php/tests/mock/dynamodb/describe_table b/vendor/aws/aws-sdk-php/tests/mock/dynamodb/describe_table new file mode 100644 index 0000000..b0870e7 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/dynamodb/describe_table @@ -0,0 +1,28 @@ +HTTP/1.1 200 OK +x-amzn-RequestId: TM8TFIHM2RGRTJGKTKRQ0JJL1FOOKQNSO5AEMVJFBAZ9ASUABAR +Content-Type: application/x-amz-json-1.0 +Date: Tue, 29 May 2012 02:56:49 GMT + +{ + "Table": { + "CreationDateTime": 1.328567569381E9, + "ItemCount": 22, + "KeySchema": { + "bar": { + "AttributeName": "id", + "AttributeType": "S" + }, + "baz": { + "AttributeName": "id", + "AttributeType": "S" + } + }, + "ProvisionedThroughput": { + "ReadCapacityUnits": 10, + "WriteCapacityUnits": 5 + }, + "TableName": "foo", + "TableSizeBytes": 414, + "TableStatus": "ACTIVE" + } +} diff --git a/vendor/aws/aws-sdk-php/tests/mock/dynamodb/describe_table_not_found b/vendor/aws/aws-sdk-php/tests/mock/dynamodb/describe_table_not_found new file mode 100644 index 0000000..e8d44f2 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/dynamodb/describe_table_not_found @@ -0,0 +1,9 @@ +HTTP/1.1 400 Bad Request +x-amzn-RequestId: TM8TFIHM2RGRTJGKTKRQ0JJL1FOOKQNSO5AEMVJFBAZ9ASUABAR +Content-Type: application/x-amz-json-1.0 +Date: Tue, 29 May 2012 02:56:49 GMT + +{ + "__type": "com.amazonaws.dynamodb.v20111205#ResourceNotFoundException", + "message": "Requested resource not found: Table: foobazbar not found" +} diff --git a/vendor/aws/aws-sdk-php/tests/mock/dynamodb/get_item b/vendor/aws/aws-sdk-php/tests/mock/dynamodb/get_item new file mode 100644 index 0000000..070900d --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/dynamodb/get_item @@ -0,0 +1,16 @@ +HTTP/1.1 200 OK +x-amzn-RequestId: TM8TFIHM2RGRTJGKTKRQ0JJL1FOOKQNSO5AEMVJFBAZ9ASUABAR +Content-Type: application/x-amz-json-1.0 +Date: Tue, 29 May 2012 02:56:49 GMT + +{ + "Item": { + "friends": { + "SS": ["Lynda, Aaron"] + }, + "status": { + "S":"online" + } + }, + "ConsumedCapacityUnits": 1 +} diff --git a/vendor/aws/aws-sdk-php/tests/mock/dynamodb/list_tables_final b/vendor/aws/aws-sdk-php/tests/mock/dynamodb/list_tables_final new file mode 100644 index 0000000..6e521ca --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/dynamodb/list_tables_final @@ -0,0 +1,6 @@ +HTTP/1.1 200 OK +x-amzn-RequestId: S1LEK2DPQP8OJNHVHL8OU2M7KRVV4KQNSO5AEMVJF66Q9ASUAAJG +content-type: application/x-amz-json-1.0 +Date: Fri, 21 Oct 2011 20:35:38 GMT + +{"TableNames":["Table4","Table5"]} diff --git a/vendor/aws/aws-sdk-php/tests/mock/dynamodb/list_tables_has_more b/vendor/aws/aws-sdk-php/tests/mock/dynamodb/list_tables_has_more new file mode 100644 index 0000000..2f23723 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/dynamodb/list_tables_has_more @@ -0,0 +1,6 @@ +HTTP/1.1 200 OK +x-amzn-RequestId: S1LEK2DPQP8OJNHVHL8OU2M7KRVV4KQNSO5AEMVJF66Q9ASUAAJG +content-type: application/x-amz-json-1.0 +Date: Fri, 21 Oct 2011 20:35:38 GMT + +{"TableNames":["Table1","Table2","Table3"], "LastEvaluatedTableName":"Table3"} diff --git a/vendor/aws/aws-sdk-php/tests/mock/dynamodb/query_final b/vendor/aws/aws-sdk-php/tests/mock/dynamodb/query_final new file mode 100644 index 0000000..8cebf5b --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/dynamodb/query_final @@ -0,0 +1,12 @@ +HTTP/1.1 200 OK +x-amzn-RequestId: 8966d095-71e9-11e0-a498-71d736f27375 +content-type: application/x-amz-json-1.0 + +{ + "Count": 1, + "Items": [{ + "Test": { "S": "Abc" }, + "Test2": { "N": "123" } + }], + "ConsumedCapacityUnits": 1 +} diff --git a/vendor/aws/aws-sdk-php/tests/mock/dynamodb/query_has_more b/vendor/aws/aws-sdk-php/tests/mock/dynamodb/query_has_more new file mode 100644 index 0000000..5bee23a --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/dynamodb/query_has_more @@ -0,0 +1,37 @@ +HTTP/1.1 200 OK +x-amzn-RequestId: 8966d095-71e9-11e0-a498-71d736f27375 +content-type: application/x-amz-json-1.0 + +{ + "Count": 2, + "Items": [{ + "AttributeName1": { + "S": "AttributeValue1" + }, + "AttributeName2": { + "N": "AttributeValue2" + }, + "AttributeName3": { + "S": "AttributeValue3" + } + }, { + "AttributeName1": { + "S": "AttributeValue3" + }, + "AttributeName2": { + "N": "AttributeValue4" + }, + "AttributeName3": { + "S": "AttributeValue3" + } + }], + "LastEvaluatedKey": { + "AttributeName1": { + "AttributeValue3": "S" + }, + "AttributeName2": { + "AttributeValue4": "N" + } + }, + "ConsumedCapacityUnits": 1 +} diff --git a/vendor/aws/aws-sdk-php/tests/mock/dynamodb/scan_empty_has_more b/vendor/aws/aws-sdk-php/tests/mock/dynamodb/scan_empty_has_more new file mode 100644 index 0000000..c2911b9 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/dynamodb/scan_empty_has_more @@ -0,0 +1,18 @@ +HTTP/1.1 200 OK +x-amzn-RequestId: 8966d095-71e9-11e0-a498-71d736f27375 +content-type: application/x-amz-json-1.0 + +{ + "Count": 0, + "Items": [], + "LastEvaluatedKey": { + "AttributeName1": { + "S": "AttributeName1" + }, + "AttributeName2": { + "N": "2" + } + }, + "ConsumedCapacityUnits": 1, + "ScannedCount": 200 +} diff --git a/vendor/aws/aws-sdk-php/tests/mock/dynamodb/scan_final b/vendor/aws/aws-sdk-php/tests/mock/dynamodb/scan_final new file mode 100644 index 0000000..f194407 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/dynamodb/scan_final @@ -0,0 +1,20 @@ +HTTP/1.1 200 OK +x-amzn-RequestId: 8966d095-71e9-11e0-a498-71d736f27375 +content-type: application/x-amz-json-1.0 + +{ + "Count": 1, + "Items": [{ + "AttributeName1": { + "S": "Hi" + }, + "AttributeName2": { + "S": "There" + }, + "AttributeName3": { + "S": "Test!" + } + }], + "ConsumedCapacityUnits": 1, + "ScannedCount": 5 +} diff --git a/vendor/aws/aws-sdk-php/tests/mock/dynamodb/scan_has_more b/vendor/aws/aws-sdk-php/tests/mock/dynamodb/scan_has_more new file mode 100644 index 0000000..0edd9f6 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/dynamodb/scan_has_more @@ -0,0 +1,38 @@ +HTTP/1.1 200 OK +x-amzn-RequestId: 8966d095-71e9-11e0-a498-71d736f27375 +content-type: application/x-amz-json-1.0 + +{ + "Count": 2, + "Items": [{ + "AttributeName1": { + "S": "AttributeValue1" + }, + "AttributeName2": { + "S": "AttributeValue2" + }, + "AttributeName3": { + "S": "AttributeValue3" + } + }, { + "AttributeName1": { + "S": "AttributeValue4" + }, + "AttributeName2": { + "S": "AttributeValue5" + }, + "AttributeName3": { + "S": "AttributeValue6" + } + }], + "LastEvaluatedKey": { + "AttributeName1": { + "S": "AttributeName1" + }, + "AttributeName2": { + "N": "2" + } + }, + "ConsumedCapacityUnits": 1, + "ScannedCount": 2 +} diff --git a/vendor/aws/aws-sdk-php/tests/mock/ec2/describe_instances_no_reservations b/vendor/aws/aws-sdk-php/tests/mock/ec2/describe_instances_no_reservations new file mode 100644 index 0000000..3dd0115 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/ec2/describe_instances_no_reservations @@ -0,0 +1,11 @@ +HTTP/1.1 200 OK +Content-Type: text/xml;charset=UTF-8 +Transfer-Encoding: chunked +Date: Wed, 19 Dec 2012 19:42:10 GMT +Server: AmazonEC2 + + + + efooa5c2-1960-4c86-92ae-f5example2dc + + diff --git a/vendor/aws/aws-sdk-php/tests/mock/ec2/describe_instances_two_instances_different_state b/vendor/aws/aws-sdk-php/tests/mock/ec2/describe_instances_two_instances_different_state new file mode 100644 index 0000000..33f0e77 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/ec2/describe_instances_two_instances_different_state @@ -0,0 +1,30 @@ +HTTP/1.1 200 OK +Content-Type: text/xml;charset=UTF-8 +Transfer-Encoding: chunked +Date: Wed, 19 Dec 2012 19:42:10 GMT +Server: AmazonEC2 + + + + efooa5c2-1960-4c86-92ae-f5example2dc + + + + + i-xxxxxxx1 + + 0 + pending + + + + i-xxxxxxx2 + + 16 + running + + + + + + diff --git a/vendor/aws/aws-sdk-php/tests/mock/ec2/describe_instances_two_instances_same_state b/vendor/aws/aws-sdk-php/tests/mock/ec2/describe_instances_two_instances_same_state new file mode 100644 index 0000000..d13930f --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/ec2/describe_instances_two_instances_same_state @@ -0,0 +1,30 @@ +HTTP/1.1 200 OK +Content-Type: text/xml;charset=UTF-8 +Transfer-Encoding: chunked +Date: Wed, 19 Dec 2012 19:42:10 GMT +Server: AmazonEC2 + + + + efooa5c2-1960-4c86-92ae-f5example2dc + + + + + i-xxxxxxx1 + + 16 + running + + + + i-xxxxxxx2 + + 16 + running + + + + + + diff --git a/vendor/aws/aws-sdk-php/tests/mock/ec2/describe_snapshots_completed b/vendor/aws/aws-sdk-php/tests/mock/ec2/describe_snapshots_completed new file mode 100644 index 0000000..fde7e1c --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/ec2/describe_snapshots_completed @@ -0,0 +1,22 @@ +HTTP/1.1 200 OK +Content-Type: text/xml;charset=UTF-8 +Transfer-Encoding: chunked +Date: Wed, 19 Dec 2012 19:42:10 GMT +Server: AmazonEC2 + + + 59dbff89-35bd-4eac-99ed-be587EXAMPLE + + + snap-1a2b3c4d + vol-1a2b3c4d + completed + YYYY-MM-DDTHH:MM:SS.SSSZ + 80% + 111122223333 + 15 + Daily Backup + + + + diff --git a/vendor/aws/aws-sdk-php/tests/mock/ec2/describe_snapshots_pending b/vendor/aws/aws-sdk-php/tests/mock/ec2/describe_snapshots_pending new file mode 100644 index 0000000..45c01b1 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/ec2/describe_snapshots_pending @@ -0,0 +1,22 @@ +HTTP/1.1 200 OK +Content-Type: text/xml;charset=UTF-8 +Transfer-Encoding: chunked +Date: Wed, 19 Dec 2012 19:42:10 GMT +Server: AmazonEC2 + + + 59dbff89-35bd-4eac-99ed-be587EXAMPLE + + + snap-1a2b3c4d + vol-1a2b3c4d + pending + YYYY-MM-DDTHH:MM:SS.SSSZ + 80% + 111122223333 + 15 + Daily Backup + + + + diff --git a/vendor/aws/aws-sdk-php/tests/mock/glacier/complete_multipart_upload b/vendor/aws/aws-sdk-php/tests/mock/glacier/complete_multipart_upload new file mode 100644 index 0000000..2fcb661 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/glacier/complete_multipart_upload @@ -0,0 +1,5 @@ +HTTP/1.1 201 Created +x-amzn-RequestId: AAABZpJrTyioEXAMPLEHae8EZp_uBSJr6cnGOLKqEXAMPLE +Date: Sun, 25 Mar 2012 12:00:00 GMT +Location: /111122223333/vaults/examplevault/archives/NkbByEejwEggmBz2fTHgJrg0XBoDfjP4q6iu87-TjhqG6eGoOY9Z8i1_AUyUsuhPAdTqLHy8pTl5nfCFJmDl2yEZONi5L26Omw12vcs01MNGntHEQL8MBfGlqrEXAMPLEArchiveId +x-amz-archive-id: NkbByEejwEggmBz2fTHgJrg0XBoDfjP4q6iu87-TjhqG6eGoOY9Z8i1_AUyUsuhPAdTqLHy8pTl5nfCFJmDl2yEZONi5L26Omw12vcs01MNGntHEQL8MBfGlqrEXAMPLEArchiveId diff --git a/vendor/aws/aws-sdk-php/tests/mock/glacier/describe_vault b/vendor/aws/aws-sdk-php/tests/mock/glacier/describe_vault new file mode 100644 index 0000000..1508a6d --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/glacier/describe_vault @@ -0,0 +1,7 @@ +HTTP/1.1 200 OK +x-amzn-RequestId: ClRIoB1FOOlxAZBAR3NUtc4FOOXh6iQx6BARkSsjSKKTEST +Content-Type: application/json +Content-Length: 241 +Date: Sat, 29 Sep 2012 07:21:34 GMT + +{"CreationDate":"2012-09-17T17:25:43.708Z","LastInventoryDate":"2012-09-28T08:20:46.791Z","NumberOfArchives":5,"SizeInBytes":164000,"VaultARN":"arn:aws:glacier-gamma:us-east-1:599169143985:vaults/foo","VaultName":"foo"} diff --git a/vendor/aws/aws-sdk-php/tests/mock/glacier/describe_vault_error b/vendor/aws/aws-sdk-php/tests/mock/glacier/describe_vault_error new file mode 100644 index 0000000..1ebf23c --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/glacier/describe_vault_error @@ -0,0 +1,7 @@ +HTTP/1.1 404 Not Found +x-amzn-RequestId: cRTFOOvHtBARDMbFOO6GtBAR_aKFOOXt05BARIRVO_TEST +Content-Type: application/json +Content-Length: 145 +Date: Sat, 29 Sep 2012 07:25:57 GMT + +{"code":"ResourceNotFoundException","message":"Vault not found for ARN: arn:aws:glacier-gamma:us-east-1:599169622985:vaults/foo","type":"Client"} diff --git a/vendor/aws/aws-sdk-php/tests/mock/glacier/initiate_multipart_upload b/vendor/aws/aws-sdk-php/tests/mock/glacier/initiate_multipart_upload new file mode 100644 index 0000000..c6d4813 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/glacier/initiate_multipart_upload @@ -0,0 +1,5 @@ +HTTP/1.1 201 Created +x-amzn-RequestId: AAABZpJFOOioDC_HsOmBAR8EZp_uFOOr6cnGOBAR_XJCFOO +Date: Sun, 25 Mar 2012 12:00:00 GMT +Location: /111122223333/vaults/foo/multipart-uploads/EXAMPLEVylEpFEMM9_HpKowEXAMPLE5sSL39_3EXAMPLEFUWVrnRHaPjUJddQ5EXAMPLEYtrN47NBZ-khxOjyEXAMPLE +x-amz-multipart-upload-id: EXAMPLEVylEpFEMM9_HpKowEXAMPLE5sSL39_3EXAMPLEFUWVrnRHaPjUJddQ5EXAMPLEYtrN47NBZ-khxOjyEXAMPLE diff --git a/vendor/aws/aws-sdk-php/tests/mock/glacier/list_parts b/vendor/aws/aws-sdk-php/tests/mock/glacier/list_parts new file mode 100644 index 0000000..178bafb --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/glacier/list_parts @@ -0,0 +1,23 @@ +HTTP/1.1 200 OK +x-amzn-RequestId: AAABZEXAMPLEsOe8EEXAMPLEnGOLKEXAMPLEl-Q +Date: Sun, 25 Mar 2012 12:00:00 GMT +Content-Type: application/json +Content-Length: 411 + +{ + "ArchiveDescription" : "archive description", + "CreationDate" : "2012-03-20T17:03:43.221Z", + "Marker": null, + "MultipartUploadId" : "OW2fM5iVylEpFEMM9_FOOowRapC3vn5sSL39_396UW9zBARWVrnRHaPjUFOOQ5OxSHVXjYtrN4BARZ-khxOjyEXAMPLE", + "PartSizeInBytes" : 4194304, + "Parts" : + [ { + "RangeInBytes" : "0-4194303", + "SHA256TreeHash" : "01d34dabf7be316472c93b1ef80721f5d4" + }, + { + "RangeInBytes" : "4194304-8388607", + "SHA256TreeHash" : "0195875365afda349fc21c84c099987164" + }], + "VaultARN" : "arn:aws:glacier:us-east-1:012345678901:vaults/demo-vault" +} diff --git a/vendor/aws/aws-sdk-php/tests/mock/glacier/upload_part b/vendor/aws/aws-sdk-php/tests/mock/glacier/upload_part new file mode 100644 index 0000000..577e6f8 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/glacier/upload_part @@ -0,0 +1,4 @@ +HTTP/1.1 204 No Content +x-amzn-RequestId: AAABZpJrEXAMPLEsOmHae8EZp_uBSJr6cnGOLKeQEXAMPLE +x-amz-sha256-tree-hash: c06f7cd4baacb0FOO02a99a5fBARf953 +Date: Sun, 25 Mar 2012 12:00:00 GMT diff --git a/vendor/aws/aws-sdk-php/tests/mock/importexport/list_jobs_1 b/vendor/aws/aws-sdk-php/tests/mock/importexport/list_jobs_1 new file mode 100644 index 0000000..87d054e --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/importexport/list_jobs_1 @@ -0,0 +1,33 @@ +HTTP/1.1 200 OK +x-amzn-RequestId: fe4ea09a-9a37-11e1-ba08-c397bc3419cf +Content-Type: text/xml +Date: Thu, 10 May 2012 00:35:07 GMT + + + + + + Import + 2010-04-21T22:21:51Z + false + ADP7B + + + Import + 2010-04-21T22:19:05Z + false + AVEYF + + + Import + 2010-04-21T22:18:51Z + false + AF47B + + + true + + + cc6ea8c0-4da9-11df-81c3-e94d3ca214a8 + + diff --git a/vendor/aws/aws-sdk-php/tests/mock/importexport/list_jobs_2 b/vendor/aws/aws-sdk-php/tests/mock/importexport/list_jobs_2 new file mode 100644 index 0000000..a278367 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/importexport/list_jobs_2 @@ -0,0 +1,21 @@ +HTTP/1.1 200 OK +x-amzn-RequestId: fe4ea09a-9a37-11e1-ba08-c397bc3419cf +Content-Type: text/xml +Date: Thu, 10 May 2012 00:35:07 GMT + + + + + + Import + 2010-04-21T22:21:51Z + false + BBBBB + + + false + + + cc6ea8c0-4da9-11df-81c3-e94d3ca214a8 + + diff --git a/vendor/aws/aws-sdk-php/tests/mock/metadata/iam_security_credentials b/vendor/aws/aws-sdk-php/tests/mock/metadata/iam_security_credentials new file mode 100644 index 0000000..6b0ed37 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/metadata/iam_security_credentials @@ -0,0 +1,10 @@ +HTTP/1.0 200 OK +Content-Type: text/plain +Accept-Ranges: bytes +Last-Modified: Tue, 01 May 2012 23:50:50 GMT +Content-Length: 6 +Connection: close +Date: Thu, 10 May 2012 23:45:26 GMT +Server: EC2ws + +webapp diff --git a/vendor/aws/aws-sdk-php/tests/mock/metadata/iam_security_credentials_webapp b/vendor/aws/aws-sdk-php/tests/mock/metadata/iam_security_credentials_webapp new file mode 100644 index 0000000..977f7c4 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/metadata/iam_security_credentials_webapp @@ -0,0 +1,16 @@ +HTTP/1.0 200 OK +Content-Type: text/plain +Accept-Ranges: bytes +Last-Modified: Tue, 01 May 2012 23:50:50 GMT +Connection: close +Date: Thu, 10 May 2012 23:45:26 GMT +Server: EC2ws + +{"Code":"Success", + "Type":"AWS-HMAC", + "AccessKeyId":"AKIAIEXAMPLEEXAMPLEA", + "SecretAccessKey":"EXAMPLErUcddCyEXAMPLEnG3vwyGTnFZ4EXAMPLE", + "Token":"AxCusEXAMPLEFooBarBaz...", + "Expiration":"2050-05-09T23:35:40Z", + "LastUpdated":"2050-05-09T15:35:40Z" +} diff --git a/vendor/aws/aws-sdk-php/tests/mock/rds/create_db_security_group b/vendor/aws/aws-sdk-php/tests/mock/rds/create_db_security_group new file mode 100644 index 0000000..ba7748b --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/rds/create_db_security_group @@ -0,0 +1,20 @@ +HTTP/1.1 200 OK +x-amzn-RequestId: 5939f157-76f9-11e2-aaa9-**** +Content-Type: text/xml +Content-Length: 546 +Date: Thu, 14 Feb 2013 22:53:29 GMT + + + + + + Integ test + + 123456 + integfoo + + + + 5939f157-76f9-11e2-aaa9-**** + + diff --git a/vendor/aws/aws-sdk-php/tests/mock/rds/describe_db_instances b/vendor/aws/aws-sdk-php/tests/mock/rds/describe_db_instances new file mode 100644 index 0000000..1cd4ec8 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/rds/describe_db_instances @@ -0,0 +1,52 @@ +HTTP/1.1 200 OK +x-amzn-RequestId: 5939f157-76f9-11e2-aaa9-**** +Content-Type: text/xml +Content-Length: 2144 +Date: Thu, 14 Feb 2013 22:53:29 GMT + + + + + + foo + db.m1.small + mysql + available + utilityuser + xxxxxxxx + +
    xxxxxxxx.eu-west-1.rds.amazonaws.com
    + 3306 +
    + 20 + 2011-08-10T18:43:15.278Z + 22:30-23:00 + 3 + + + xxxxxxx + active + + + + + generic-5-5 + in-sync + + + eu-west-1b + sat:03:30-sat:04:00 + + 2013-04-22T14:00:01Z + true + 5.5.27 + true + + general-public-license +
    +
    +
    + + 5939f157-76f9-11e2-aaa9-**** + +
    \ No newline at end of file diff --git a/vendor/aws/aws-sdk-php/tests/mock/route53/list_rrs_page_1 b/vendor/aws/aws-sdk-php/tests/mock/route53/list_rrs_page_1 new file mode 100644 index 0000000..0263ae5 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/route53/list_rrs_page_1 @@ -0,0 +1,8 @@ +HTTP/1.1 200 OK +x-amzn-RequestId: effoobac-4a7e-11e2-8e0e-95example0c0 +Content-Type: text/xml +Content-Length: 536 +Date: Thu, 20 Dec 2012 08:26:21 GMT + + +www.example.com.NSabtrue1example.com.SOA diff --git a/vendor/aws/aws-sdk-php/tests/mock/route53/list_rrs_page_2 b/vendor/aws/aws-sdk-php/tests/mock/route53/list_rrs_page_2 new file mode 100644 index 0000000..712c0d8 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/route53/list_rrs_page_2 @@ -0,0 +1,8 @@ +HTTP/1.1 200 OK +x-amzn-RequestId: effoobac-4a7e-11e2-8e0e-95example0c0 +Content-Type: text/xml +Content-Length: 506 +Date: Thu, 20 Dec 2012 08:26:21 GMT + + +www.example.com.NScdtrue1identifier diff --git a/vendor/aws/aws-sdk-php/tests/mock/route53/list_rrs_page_3 b/vendor/aws/aws-sdk-php/tests/mock/route53/list_rrs_page_3 new file mode 100644 index 0000000..b72d1e5 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/route53/list_rrs_page_3 @@ -0,0 +1,8 @@ +HTTP/1.1 200 OK +x-amzn-RequestId: effoobac-4a7e-11e2-8e0e-95example0c0 +Content-Type: text/xml +Content-Length: 459 +Date: Thu, 20 Dec 2012 08:26:21 GMT + + +www.example.com.SOAeffalse1 diff --git a/vendor/aws/aws-sdk-php/tests/mock/route53/server_time_1 b/vendor/aws/aws-sdk-php/tests/mock/route53/server_time_1 new file mode 100644 index 0000000..525f978 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/route53/server_time_1 @@ -0,0 +1,4 @@ +HTTP/1.1 200 OK +x-amz-request-id: 69C40696342A9E1BEXAMPLE +Date: Thu, 19 Nov 2009 19:37:58 GMT +Content-Type: text/plain diff --git a/vendor/aws/aws-sdk-php/tests/mock/route53/server_time_2 b/vendor/aws/aws-sdk-php/tests/mock/route53/server_time_2 new file mode 100644 index 0000000..85626ad --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/route53/server_time_2 @@ -0,0 +1,4 @@ +HTTP/1.1 400 Bad Request +x-amz-request-id: 69C40696342A9E1BEXAMPLE +Date: Fri, 20 Nov 2009 19:37:58 GMT +Content-Type: text/plain diff --git a/vendor/aws/aws-sdk-php/tests/mock/s3/complete_multipart_upload b/vendor/aws/aws-sdk-php/tests/mock/s3/complete_multipart_upload new file mode 100644 index 0000000..32d5f2f --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/s3/complete_multipart_upload @@ -0,0 +1,14 @@ +HTTP/1.1 200 OK +x-amz-id-2: Uuag1LuByRx9e6j5Onimru9pO4ZVKnJ2Qz7/C1NPcfTWAtRPfTaOFg== +x-amz-request-id: 656c76696e6727732072657175657374 +Date: Mon, 1 Nov 2010 20:34:56 GMT +Connection: close +Server: AmazonS3 + + + + http://Example-Bucket.s3.amazonaws.com/Example-Object + Example-Bucket + Example-Object + "3858f62230ac3c915f300c664312c11f-9" + diff --git a/vendor/aws/aws-sdk-php/tests/mock/s3/delete_multiple_objects b/vendor/aws/aws-sdk-php/tests/mock/s3/delete_multiple_objects new file mode 100644 index 0000000..99466d4 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/s3/delete_multiple_objects @@ -0,0 +1,16 @@ +HTTP/1.1 200 OK +x-amz-id-2: XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX +x-amz-request-id: XXXXXXXXXXXXXXXX +Date: Wed, 30 Nov 2011 03:39:32 GMT +Content-Type: application/xml +Server: AmazonS3 +Content-Length: 276 + + + + + SampleDocument.txt + true + NeQt5xeFTfgPJD8B4CGWnkSLtluMr11s + + diff --git a/vendor/aws/aws-sdk-php/tests/mock/s3/delete_multiple_objects_errors b/vendor/aws/aws-sdk-php/tests/mock/s3/delete_multiple_objects_errors new file mode 100644 index 0000000..f042394 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/s3/delete_multiple_objects_errors @@ -0,0 +1,18 @@ +HTTP/1.1 200 OK +x-amz-id-2: XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX +x-amz-request-id: XXXXXXXXXXXXXXXX +Date: Fri, 02 Dec 2011 01:53:42 GMT +Content-Type: application/xml +Server: AmazonS3 + + + + + sample1.txt + + + sample2.txt + AccessDenied + Access Denied + + diff --git a/vendor/aws/aws-sdk-php/tests/mock/s3/get_bucket_object_versions_page_1 b/vendor/aws/aws-sdk-php/tests/mock/s3/get_bucket_object_versions_page_1 new file mode 100644 index 0000000..8ff16ff --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/s3/get_bucket_object_versions_page_1 @@ -0,0 +1,19 @@ +HTTP/1.1 200 OK +x-amz-id-2: XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX +x-amz-request-id: XXXXXXXXXXXXXXXX +Date: Mon, 30 Jul 2012 20:01:57 GMT +Content-Type: application/xml +Transfer-Encoding: chunked +Server: AmazonS3 + + + + bucket-1 + + + + key-1 + version-id-1 + + true + diff --git a/vendor/aws/aws-sdk-php/tests/mock/s3/get_bucket_object_versions_page_2 b/vendor/aws/aws-sdk-php/tests/mock/s3/get_bucket_object_versions_page_2 new file mode 100644 index 0000000..dd5c41f --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/s3/get_bucket_object_versions_page_2 @@ -0,0 +1,69 @@ +HTTP/1.1 200 OK +x-amz-id-2: XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX +x-amz-request-id: XXXXXXXXXXXXXXXX +Date: Mon, 30 Jul 2012 20:01:57 GMT +Content-Type: application/xml +Transfer-Encoding: chunked +Server: AmazonS3 + + + + bucket-1 + + + + + false + + key-1 + version-id-1 + true + 2009-10-12T17:50:30.000Z + "fba9dede5f27731c9771645a39863328" + 434234 + STANDARD + + XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX + XXXXXX + + + + key-1 + version-id-2 + true + 2009-11-12T17:50:30.000Z + + XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX + XXXXXX + + + + key-2 + version-id-1 + false + 2009-10-10T17:50:30.000Z + "9b2cf535f27731c974343645a3985328" + 166434 + STANDARD + + XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX + XXXXXX + + + + key-2 + version-id-2 + true + 2009-10-15T17:50:30.000Z + + XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX + XXXXXX + + + + prefix-1/ + + + prefix-2/ + + diff --git a/vendor/aws/aws-sdk-php/tests/mock/s3/get_bucket_policy_failure b/vendor/aws/aws-sdk-php/tests/mock/s3/get_bucket_policy_failure new file mode 100644 index 0000000..12a2daa --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/s3/get_bucket_policy_failure @@ -0,0 +1,10 @@ +HTTP/1.1 404 Not Found +x-amz-request-id: 1DD8C98820A88D8A +x-amz-id-2: c9mX563FVLa+z1W2nTWGnpUn8axTdapNAGrmLBSvvAey1mBxVzqOPnArkz7NupSf +Content-Type: application/xml +Transfer-Encoding: chunked +Date: Tue, 24 Jul 2012 22:59:04 GMT +Server: AmazonS3 + + +NoSuchBucketPolicyThe bucket policy does not existjust-peachy1DD8C98820A88D8Ac9mX563FVLa+z1W2nTWGnpUn8axTdapNAGrmLBSvvAey1mBxVzqOPnArkz7NupSf diff --git a/vendor/aws/aws-sdk-php/tests/mock/s3/get_bucket_policy_success b/vendor/aws/aws-sdk-php/tests/mock/s3/get_bucket_policy_success new file mode 100644 index 0000000..a36f285 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/s3/get_bucket_policy_success @@ -0,0 +1,9 @@ +HTTP/1.1 200 OK +x-amz-id-2: qq+Sp6WAQTaNRZsyO8DhGj3WnFT42ll8BoZzL6DYJkdxiFpFqi+uP2QucwXL26Xa +x-amz-request-id: 69C40696342A9E1B +Date: Tue, 24 Jul 2012 21:01:14 GMT +Content-Type: application/json +Content-Length: 13 +Server: AmazonS3 + +{"foo":"bar"} diff --git a/vendor/aws/aws-sdk-php/tests/mock/s3/head_access_denied b/vendor/aws/aws-sdk-php/tests/mock/s3/head_access_denied new file mode 100644 index 0000000..1745309 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/s3/head_access_denied @@ -0,0 +1,7 @@ +HTTP/1.1 403 Access Denied +x-amz-id-2: qq+Sp6WAQTaNRZsyO8DhGj3WnFT42ll8BoZzL6DYJkdxiFpFqi+uP2QucwXL26Xa +x-amz-request-id: 69C40696342A9E1B +Date: Tue, 24 Jul 2012 21:01:14 GMT +Content-Type: application/xml +Transfer-Encoding: chunked +Server: AmazonS3 diff --git a/vendor/aws/aws-sdk-php/tests/mock/s3/head_failure b/vendor/aws/aws-sdk-php/tests/mock/s3/head_failure new file mode 100644 index 0000000..0862db0 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/s3/head_failure @@ -0,0 +1,7 @@ +HTTP/1.1 404 Not Found +x-amz-id-2: qq+Sp6WAQTaNRZsyO8DhGj3WnFT42ll8BoZzL6DYJkdxiFpFqi+uP2QucwXL26Xa +x-amz-request-id: 69C40696342A9E1B +Date: Tue, 24 Jul 2012 21:01:14 GMT +Content-Type: application/xml +Transfer-Encoding: chunked +Server: AmazonS3 diff --git a/vendor/aws/aws-sdk-php/tests/mock/s3/head_success b/vendor/aws/aws-sdk-php/tests/mock/s3/head_success new file mode 100644 index 0000000..a0bd37d --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/s3/head_success @@ -0,0 +1,7 @@ +HTTP/1.1 200 OK +x-amz-id-2: qq+Sp6WAQTaNRZsyO8DhGj3WnFT42ll8BoZzL6DYJkdxiFpFqi+uP2QucwXL26Xa +x-amz-request-id: 69C40696342A9E1B +Date: Tue, 24 Jul 2012 21:01:14 GMT +Content-Type: application/xml +Transfer-Encoding: chunked +Server: AmazonS3 diff --git a/vendor/aws/aws-sdk-php/tests/mock/s3/initiate_multipart_upload b/vendor/aws/aws-sdk-php/tests/mock/s3/initiate_multipart_upload new file mode 100644 index 0000000..af19a99 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/s3/initiate_multipart_upload @@ -0,0 +1,14 @@ +HTTP/1.1 200 OK +x-amz-id-2: Uuag1LuByRx9e6j5Onimru9pO4ZVKnJ2Qz7/C1NPcfTWAtRPfTaOFg== +x-amz-request-id: 656c76696e6727732072657175657374 +Date: Mon, 1 Nov 2010 20:34:56 GMT +Content-Length: 197 +Connection: keep-alive +Server: AmazonS3 + + + + example-bucket + example-object + VXBsb2FkIElEIGZvciA2aWWpbmcncyBteS1tb3ZpZS5tMnRzIHVwbG9hZA + diff --git a/vendor/aws/aws-sdk-php/tests/mock/s3/list_buckets b/vendor/aws/aws-sdk-php/tests/mock/s3/list_buckets new file mode 100644 index 0000000..12acb00 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/s3/list_buckets @@ -0,0 +1,10 @@ +HTTP/1.1 200 OK +x-amz-id-2: XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX +x-amz-request-id: XXXXXXXXXXXXXXXX +Date: Mon, 30 Jul 2012 20:01:57 GMT +Content-Type: application/xml +Transfer-Encoding: chunked +Server: AmazonS3 + + +XXXXXXXXXXXXbucket-12011-03-17T01:24:07.000Zbucket-22010-04-02T22:23:21.000Z diff --git a/vendor/aws/aws-sdk-php/tests/mock/s3/list_multipart_uploads_page_1 b/vendor/aws/aws-sdk-php/tests/mock/s3/list_multipart_uploads_page_1 new file mode 100644 index 0000000..82e9cb0 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/s3/list_multipart_uploads_page_1 @@ -0,0 +1,20 @@ +HTTP/1.1 200 OK +x-amz-id-2: XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX +x-amz-request-id: XXXXXXXXXXXXXXXX +Date: Mon, 30 Jul 2012 20:01:57 GMT +Content-Type: application/xml +Transfer-Encoding: chunked +Server: AmazonS3 + + + + bucket-1 + + + object-1 + upload-id-1 + / + + 1000 + true + diff --git a/vendor/aws/aws-sdk-php/tests/mock/s3/list_multipart_uploads_page_2 b/vendor/aws/aws-sdk-php/tests/mock/s3/list_multipart_uploads_page_2 new file mode 100644 index 0000000..c82b805 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/s3/list_multipart_uploads_page_2 @@ -0,0 +1,82 @@ +HTTP/1.1 200 OK +x-amz-id-2: XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX +x-amz-request-id: XXXXXXXXXXXXXXXX +Date: Mon, 30 Jul 2012 20:01:57 GMT +Content-Type: application/xml +Transfer-Encoding: chunked +Server: AmazonS3 + + + + bucket-1 + object-1 + upload-id-1 + + + / + + 1000 + false + + object-1 + upload-id-1 + + XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX + XXXXXX + + + XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX + XXXXXX + + STANDARD + 2010-11-26T19:24:17.000Z + + + object-1 + upload-id-2 + + XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX + XXXXXX + + + XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX + XXXXXX + + STANDARD + 2010-11-26T19:24:17.000Z + + + object-2 + upload-id-1 + + XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX + XXXXXX + + + XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX + XXXXXX + + STANDARD + 2010-11-26T19:24:17.000Z + + + object-2 + upload-id-2 + + XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX + XXXXXX + + + XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX + XXXXXX + + STANDARD + 2010-11-26T19:24:17.000Z + + + prefix-1/ + + + prefix-2/ + + diff --git a/vendor/aws/aws-sdk-php/tests/mock/s3/list_objects_empty b/vendor/aws/aws-sdk-php/tests/mock/s3/list_objects_empty new file mode 100644 index 0000000..5b4693b --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/s3/list_objects_empty @@ -0,0 +1,17 @@ +HTTP/1.1 200 OK +x-amz-id-2: XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX +x-amz-request-id: XXXXXXXXXXXXXXXX +Date: Thu, 04 Jul 2012 12:00:00 GMT +Content-Type: application/xml +Transfer-Encoding: chunked +Server: AmazonS3 + + + + bucket-1 + + + + / + false + diff --git a/vendor/aws/aws-sdk-php/tests/mock/s3/list_objects_page_1 b/vendor/aws/aws-sdk-php/tests/mock/s3/list_objects_page_1 new file mode 100644 index 0000000..77174e6 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/s3/list_objects_page_1 @@ -0,0 +1,24 @@ +HTTP/1.1 200 OK +x-amz-id-2: XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX +x-amz-request-id: XXXXXXXXXXXXXXXX +Date: Thu, 04 Jul 2012 12:00:00 GMT +Content-Type: application/xml +Transfer-Encoding: chunked +Server: AmazonS3 + + + + foo + + + b/ + + / + true + + a/ + + + b/ + + diff --git a/vendor/aws/aws-sdk-php/tests/mock/s3/list_objects_page_2 b/vendor/aws/aws-sdk-php/tests/mock/s3/list_objects_page_2 new file mode 100644 index 0000000..f24cdd5 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/s3/list_objects_page_2 @@ -0,0 +1,32 @@ +HTTP/1.1 200 OK +x-amz-id-2: XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX +x-amz-request-id: XXXXXXXXXXXXXXXX +Date: Thu, 04 Jul 2012 12:00:00 GMT +Content-Type: application/xml +Transfer-Encoding: chunked +Server: AmazonS3 + + + + foo + + + d/ + + / + true + + c + 2012-04-07T12:00:00.000Z + "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX" + 0 + + XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX + XXXXXXXXXX + + STANDARD + + + d/ + + diff --git a/vendor/aws/aws-sdk-php/tests/mock/s3/list_objects_page_3 b/vendor/aws/aws-sdk-php/tests/mock/s3/list_objects_page_3 new file mode 100644 index 0000000..1630a00 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/s3/list_objects_page_3 @@ -0,0 +1,39 @@ +HTTP/1.1 200 OK +x-amz-id-2: XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX +x-amz-request-id: XXXXXXXXXXXXXXXX +Date: Thu, 04 Jul 2012 12:00:00 GMT +Content-Type: application/xml +Transfer-Encoding: chunked +Server: AmazonS3 + + + + bucket-1 + + + + / + true + + e + 2012-04-07T12:00:00.000Z + "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX" + 0 + + XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX + XXXXXXXXXX + + STANDARD + + + f + 2012-04-07T12:00:00.000Z + "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX" + 0 + + XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX + XXXXXXXXXX + + STANDARD + + diff --git a/vendor/aws/aws-sdk-php/tests/mock/s3/list_objects_page_4 b/vendor/aws/aws-sdk-php/tests/mock/s3/list_objects_page_4 new file mode 100644 index 0000000..b1ba2c3 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/s3/list_objects_page_4 @@ -0,0 +1,18 @@ +HTTP/1.1 200 OK +x-amz-id-2: XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX +x-amz-request-id: XXXXXXXXXXXXXXXX +Date: Thu, 04 Jul 2012 12:00:00 GMT +Content-Type: application/xml +Transfer-Encoding: chunked +Server: AmazonS3 + + + + bucket-1 + + + DUMMY/ + + / + true + diff --git a/vendor/aws/aws-sdk-php/tests/mock/s3/list_objects_page_5 b/vendor/aws/aws-sdk-php/tests/mock/s3/list_objects_page_5 new file mode 100644 index 0000000..c97a23c --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/s3/list_objects_page_5 @@ -0,0 +1,20 @@ +HTTP/1.1 200 OK +x-amz-id-2: XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX +x-amz-request-id: XXXXXXXXXXXXXXXX +Date: Thu, 04 Jul 2012 12:00:00 GMT +Content-Type: application/xml +Transfer-Encoding: chunked +Server: AmazonS3 + + + + bucket-1 + + + + / + false + + g/ + + diff --git a/vendor/aws/aws-sdk-php/tests/mock/s3/list_parts_page_1 b/vendor/aws/aws-sdk-php/tests/mock/s3/list_parts_page_1 new file mode 100644 index 0000000..372fba7 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/s3/list_parts_page_1 @@ -0,0 +1,26 @@ +HTTP/1.1 200 OK +x-amz-id-2: XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX +x-amz-request-id: XXXXXXXXXXXXXXXX +Date: Mon, 30 Jul 2012 20:01:57 GMT +Content-Type: application/xml +Server: AmazonS3 + + + + bucket-1 + object-1 + upload-id-1 + + XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX + XXXXXX + + + XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX + XXXXXX + + STANDARD + 1 + 1 + + true + diff --git a/vendor/aws/aws-sdk-php/tests/mock/s3/list_parts_page_2 b/vendor/aws/aws-sdk-php/tests/mock/s3/list_parts_page_2 new file mode 100644 index 0000000..145354d --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/s3/list_parts_page_2 @@ -0,0 +1,39 @@ +HTTP/1.1 200 OK +x-amz-id-2: XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX +x-amz-request-id: XXXXXXXXXXXXXXXX +Date: Mon, 30 Jul 2012 20:01:57 GMT +Content-Type: application/xml +Transfer-Encoding: chunked +Server: AmazonS3 + + + + bucket-1 + object-1 + upload-id-1 + + XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX + XXXXXX + + + XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX + XXXXXX + + STANDARD + 1 + + + false + + 1 + 2010-11-10T20:48:34.000Z + "7778aef83f66abc1fa1e8477f296d394" + 10485760 + + + 2 + 2010-11-10T20:48:33.000Z + "aaaa18db4cc2f85cedef654fccc4a4x8" + 10485760 + + diff --git a/vendor/aws/aws-sdk-php/tests/mock/s3/list_parts_single b/vendor/aws/aws-sdk-php/tests/mock/s3/list_parts_single new file mode 100644 index 0000000..aefadf2 --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/s3/list_parts_single @@ -0,0 +1,33 @@ +HTTP/1.1 200 OK +x-amz-id-2: XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX +x-amz-request-id: XXXXXXXXXXXXXXXX +Date: Mon, 30 Jul 2012 20:01:57 GMT +Content-Type: application/xml +Transfer-Encoding: chunked +Server: AmazonS3 + + + + bucket-1 + object-1 + upload-id-1 + + XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX + XXXXXX + + + XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX + XXXXXX + + STANDARD + 1 + + + false + + 1 + 2010-11-10T20:48:34.000Z + "7778aef83f66abc1fa1e8477f296d394" + 10485760 + + diff --git a/vendor/aws/aws-sdk-php/tests/mock/s3/upload_part b/vendor/aws/aws-sdk-php/tests/mock/s3/upload_part new file mode 100644 index 0000000..84e8fdb --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/s3/upload_part @@ -0,0 +1,8 @@ +HTTP/1.1 200 OK +x-amz-id-2: Vvag1LuByRx9e6j5Onimru9pO4ZVKnJ2Qz7/C1NPcfTWAtRPfTaOFg== +x-amz-request-id: 656c76696e6727732072657175657374 +Date: Mon, 1 Nov 2010 20:34:56 GMT +ETag: "b54357faf0632cce46e942fa68356b38" +Content-Length: 0 +Connection: keep-alive +Server: AmazonS3 diff --git a/vendor/aws/aws-sdk-php/tests/mock/sts/get_session_token b/vendor/aws/aws-sdk-php/tests/mock/sts/get_session_token new file mode 100644 index 0000000..e72c88d --- /dev/null +++ b/vendor/aws/aws-sdk-php/tests/mock/sts/get_session_token @@ -0,0 +1,25 @@ +HTTP/1.1 200 OK +x-amzn-RequestId: fe4ea09a-9a37-11e1-ba08-c397bc3419cf +Content-Type: text/xml +Date: Thu, 10 May 2012 00:35:07 GMT + + + + + + AQoEXAMPLEH4aoAH0gNCAPyJxz4BlCFFxWNE1OPTgk5TthT+FvwqnKwRcOIfrRh3c/L + To6UDdyJwOOvEVPvLXCrrrUtdnniCEXAMPLE/IvU1dYUg2RVAJBanLiHb4IgRmpRV3z + rkuWJOgQs8IZZaIv2BXIa2R4OlgkBN9bkUDNCJiBeb/AXlzBBko7b15fjrBs2+cTQtp + Z3CYWFXG8C5zqx37wnOE49mRl/+OtkIKGO7fAE + + + wJalrXUtnFEMI/K7MDENG/bPxRfiCYzEXAMPLEKEY + + 2011-07-11T19:55:29.611Z + AKIAIOSFODNN7EXAMPLE + + + + 58c5dbae-abef-11e0-8cfe-09039844ac7d + + diff --git a/vendor/composer/ClassLoader.php b/vendor/composer/ClassLoader.php new file mode 100644 index 0000000..a710555 --- /dev/null +++ b/vendor/composer/ClassLoader.php @@ -0,0 +1,378 @@ + + * Jordi Boggiano + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Composer\Autoload; + +/** + * ClassLoader implements a PSR-0 class loader + * + * See https://github.com/php-fig/fig-standards/blob/master/accepted/PSR-0.md + * + * $loader = new \Composer\Autoload\ClassLoader(); + * + * // register classes with namespaces + * $loader->add('Symfony\Component', __DIR__.'/component'); + * $loader->add('Symfony', __DIR__.'/framework'); + * + * // activate the autoloader + * $loader->register(); + * + * // to enable searching the include path (eg. for PEAR packages) + * $loader->setUseIncludePath(true); + * + * In this example, if you try to use a class in the Symfony\Component + * namespace or one of its children (Symfony\Component\Console for instance), + * the autoloader will first look for the class under the component/ + * directory, and it will then fallback to the framework/ directory if not + * found before giving up. + * + * This class is loosely based on the Symfony UniversalClassLoader. + * + * @author Fabien Potencier + * @author Jordi Boggiano + */ +class ClassLoader +{ + // PSR-4 + private $prefixLengthsPsr4 = array(); + private $prefixDirsPsr4 = array(); + private $fallbackDirsPsr4 = array(); + + // PSR-0 + private $prefixesPsr0 = array(); + private $fallbackDirsPsr0 = array(); + + private $useIncludePath = false; + private $classMap = array(); + + public function getPrefixes() + { + return call_user_func_array('array_merge', $this->prefixesPsr0); + } + + public function getPrefixesPsr4() + { + return $this->prefixDirsPsr4; + } + + public function getFallbackDirs() + { + return $this->fallbackDirsPsr0; + } + + public function getFallbackDirsPsr4() + { + return $this->fallbackDirsPsr4; + } + + public function getClassMap() + { + return $this->classMap; + } + + /** + * @param array $classMap Class to filename map + */ + public function addClassMap(array $classMap) + { + if ($this->classMap) { + $this->classMap = array_merge($this->classMap, $classMap); + } else { + $this->classMap = $classMap; + } + } + + /** + * Registers a set of PSR-0 directories for a given prefix, either + * appending or prepending to the ones previously set for this prefix. + * + * @param string $prefix The prefix + * @param array|string $paths The PSR-0 root directories + * @param bool $prepend Whether to prepend the directories + */ + public function add($prefix, $paths, $prepend = false) + { + if (!$prefix) { + if ($prepend) { + $this->fallbackDirsPsr0 = array_merge( + (array) $paths, + $this->fallbackDirsPsr0 + ); + } else { + $this->fallbackDirsPsr0 = array_merge( + $this->fallbackDirsPsr0, + (array) $paths + ); + } + + return; + } + + $first = $prefix[0]; + if (!isset($this->prefixesPsr0[$first][$prefix])) { + $this->prefixesPsr0[$first][$prefix] = (array) $paths; + + return; + } + if ($prepend) { + $this->prefixesPsr0[$first][$prefix] = array_merge( + (array) $paths, + $this->prefixesPsr0[$first][$prefix] + ); + } else { + $this->prefixesPsr0[$first][$prefix] = array_merge( + $this->prefixesPsr0[$first][$prefix], + (array) $paths + ); + } + } + + /** + * Registers a set of PSR-4 directories for a given namespace, either + * appending or prepending to the ones previously set for this namespace. + * + * @param string $prefix The prefix/namespace, with trailing '\\' + * @param array|string $paths The PSR-0 base directories + * @param bool $prepend Whether to prepend the directories + */ + public function addPsr4($prefix, $paths, $prepend = false) + { + if (!$prefix) { + // Register directories for the root namespace. + if ($prepend) { + $this->fallbackDirsPsr4 = array_merge( + (array) $paths, + $this->fallbackDirsPsr4 + ); + } else { + $this->fallbackDirsPsr4 = array_merge( + $this->fallbackDirsPsr4, + (array) $paths + ); + } + } elseif (!isset($this->prefixDirsPsr4[$prefix])) { + // Register directories for a new namespace. + $length = strlen($prefix); + if ('\\' !== $prefix[$length - 1]) { + throw new \InvalidArgumentException("A non-empty PSR-4 prefix must end with a namespace separator."); + } + $this->prefixLengthsPsr4[$prefix[0]][$prefix] = $length; + $this->prefixDirsPsr4[$prefix] = (array) $paths; + } elseif ($prepend) { + // Prepend directories for an already registered namespace. + $this->prefixDirsPsr4[$prefix] = array_merge( + (array) $paths, + $this->prefixDirsPsr4[$prefix] + ); + } else { + // Append directories for an already registered namespace. + $this->prefixDirsPsr4[$prefix] = array_merge( + $this->prefixDirsPsr4[$prefix], + (array) $paths + ); + } + } + + /** + * Registers a set of PSR-0 directories for a given prefix, + * replacing any others previously set for this prefix. + * + * @param string $prefix The prefix + * @param array|string $paths The PSR-0 base directories + */ + public function set($prefix, $paths) + { + if (!$prefix) { + $this->fallbackDirsPsr0 = (array) $paths; + } else { + $this->prefixesPsr0[$prefix[0]][$prefix] = (array) $paths; + } + } + + /** + * Registers a set of PSR-4 directories for a given namespace, + * replacing any others previously set for this namespace. + * + * @param string $prefix The prefix/namespace, with trailing '\\' + * @param array|string $paths The PSR-4 base directories + */ + public function setPsr4($prefix, $paths) { + if (!$prefix) { + $this->fallbackDirsPsr4 = (array) $paths; + } else { + $length = strlen($prefix); + if ('\\' !== $prefix[$length - 1]) { + throw new \InvalidArgumentException("A non-empty PSR-4 prefix must end with a namespace separator."); + } + $this->prefixLengthsPsr4[$prefix[0]][$prefix] = $length; + $this->prefixDirsPsr4[$prefix] = (array) $paths; + } + } + + /** + * Turns on searching the include path for class files. + * + * @param bool $useIncludePath + */ + public function setUseIncludePath($useIncludePath) + { + $this->useIncludePath = $useIncludePath; + } + + /** + * Can be used to check if the autoloader uses the include path to check + * for classes. + * + * @return bool + */ + public function getUseIncludePath() + { + return $this->useIncludePath; + } + + /** + * Registers this instance as an autoloader. + * + * @param bool $prepend Whether to prepend the autoloader or not + */ + public function register($prepend = false) + { + spl_autoload_register(array($this, 'loadClass'), true, $prepend); + } + + /** + * Unregisters this instance as an autoloader. + */ + public function unregister() + { + spl_autoload_unregister(array($this, 'loadClass')); + } + + /** + * Loads the given class or interface. + * + * @param string $class The name of the class + * @return bool|null True if loaded, null otherwise + */ + public function loadClass($class) + { + if ($file = $this->findFile($class)) { + includeFile($file); + + return true; + } + } + + /** + * Finds the path to the file where the class is defined. + * + * @param string $class The name of the class + * + * @return string|false The path if found, false otherwise + */ + public function findFile($class) + { + // work around for PHP 5.3.0 - 5.3.2 https://bugs.php.net/50731 + if ('\\' == $class[0]) { + $class = substr($class, 1); + } + + // class map lookup + if (isset($this->classMap[$class])) { + return $this->classMap[$class]; + } + + $file = $this->findFileWithExtension($class, '.php'); + + // Search for Hack files if we are running on HHVM + if ($file === null && defined('HHVM_VERSION')) { + $file = $this->findFileWithExtension($class, '.hh'); + } + + if ($file === null) { + // Remember that this class does not exist. + return $this->classMap[$class] = false; + } + + return $file; + } + + private function findFileWithExtension($class, $ext) + { + // PSR-4 lookup + $logicalPathPsr4 = strtr($class, '\\', DIRECTORY_SEPARATOR) . $ext; + + $first = $class[0]; + if (isset($this->prefixLengthsPsr4[$first])) { + foreach ($this->prefixLengthsPsr4[$first] as $prefix => $length) { + if (0 === strpos($class, $prefix)) { + foreach ($this->prefixDirsPsr4[$prefix] as $dir) { + if (file_exists($file = $dir . DIRECTORY_SEPARATOR . substr($logicalPathPsr4, $length))) { + return $file; + } + } + } + } + } + + // PSR-4 fallback dirs + foreach ($this->fallbackDirsPsr4 as $dir) { + if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr4)) { + return $file; + } + } + + // PSR-0 lookup + if (false !== $pos = strrpos($class, '\\')) { + // namespaced class name + $logicalPathPsr0 = substr($logicalPathPsr4, 0, $pos + 1) + . strtr(substr($logicalPathPsr4, $pos + 1), '_', DIRECTORY_SEPARATOR); + } else { + // PEAR-like class name + $logicalPathPsr0 = strtr($class, '_', DIRECTORY_SEPARATOR) . $ext; + } + + if (isset($this->prefixesPsr0[$first])) { + foreach ($this->prefixesPsr0[$first] as $prefix => $dirs) { + if (0 === strpos($class, $prefix)) { + foreach ($dirs as $dir) { + if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr0)) { + return $file; + } + } + } + } + } + + // PSR-0 fallback dirs + foreach ($this->fallbackDirsPsr0 as $dir) { + if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr0)) { + return $file; + } + } + + // PSR-0 include paths. + if ($this->useIncludePath && $file = stream_resolve_include_path($logicalPathPsr0)) { + return $file; + } + } +} + +/** + * Scope isolated include. + * + * Prevents access to $this/self from included files. + */ +function includeFile($file) +{ + include $file; +} diff --git a/vendor/composer/autoload_classmap.php b/vendor/composer/autoload_classmap.php new file mode 100644 index 0000000..7a91153 --- /dev/null +++ b/vendor/composer/autoload_classmap.php @@ -0,0 +1,9 @@ + array($vendorDir . '/symfony/event-dispatcher'), + 'Guzzle\\Tests' => array($vendorDir . '/guzzle/guzzle/tests'), + 'Guzzle' => array($vendorDir . '/guzzle/guzzle/src'), + 'Aws' => array($vendorDir . '/aws/aws-sdk-php/src'), +); diff --git a/vendor/composer/autoload_psr4.php b/vendor/composer/autoload_psr4.php new file mode 100644 index 0000000..b265c64 --- /dev/null +++ b/vendor/composer/autoload_psr4.php @@ -0,0 +1,9 @@ + $path) { + $loader->set($namespace, $path); + } + + $map = require __DIR__ . '/autoload_psr4.php'; + foreach ($map as $namespace => $path) { + $loader->setPsr4($namespace, $path); + } + + $classMap = require __DIR__ . '/autoload_classmap.php'; + if ($classMap) { + $loader->addClassMap($classMap); + } + + $loader->register(true); + + return $loader; + } +} + +function composerRequireeb49ef51662df50d308262c00ce7193e($file) +{ + require $file; +} diff --git a/vendor/composer/installed.json b/vendor/composer/installed.json new file mode 100644 index 0000000..c25ab70 --- /dev/null +++ b/vendor/composer/installed.json @@ -0,0 +1,227 @@ +[ + { + "name": "symfony/event-dispatcher", + "version": "v2.5.0", + "version_normalized": "2.5.0.0", + "target-dir": "Symfony/Component/EventDispatcher", + "source": { + "type": "git", + "url": "https://github.com/symfony/EventDispatcher.git", + "reference": "cb62ec8dd05893fc8e4f0e6e21e326e1fc731fe8" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/symfony/EventDispatcher/zipball/cb62ec8dd05893fc8e4f0e6e21e326e1fc731fe8", + "reference": "cb62ec8dd05893fc8e4f0e6e21e326e1fc731fe8", + "shasum": "" + }, + "require": { + "php": ">=5.3.3" + }, + "require-dev": { + "psr/log": "~1.0", + "symfony/config": "~2.0", + "symfony/dependency-injection": "~2.0", + "symfony/stopwatch": "~2.2" + }, + "suggest": { + "symfony/dependency-injection": "", + "symfony/http-kernel": "" + }, + "time": "2014-04-29 10:13:57", + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "2.5-dev" + } + }, + "installation-source": "dist", + "autoload": { + "psr-0": { + "Symfony\\Component\\EventDispatcher\\": "" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com", + "homepage": "http://fabien.potencier.org", + "role": "Lead Developer" + }, + { + "name": "Symfony Community", + "homepage": "http://symfony.com/contributors" + } + ], + "description": "Symfony EventDispatcher Component", + "homepage": "http://symfony.com" + }, + { + "name": "guzzle/guzzle", + "version": "v3.9.1", + "version_normalized": "3.9.1.0", + "source": { + "type": "git", + "url": "https://github.com/guzzle/guzzle3.git", + "reference": "92d9934f2fca1da15178c91239576ae26e505e60" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/guzzle/guzzle3/zipball/92d9934f2fca1da15178c91239576ae26e505e60", + "reference": "92d9934f2fca1da15178c91239576ae26e505e60", + "shasum": "" + }, + "require": { + "ext-curl": "*", + "php": ">=5.3.3", + "symfony/event-dispatcher": "~2.1" + }, + "replace": { + "guzzle/batch": "self.version", + "guzzle/cache": "self.version", + "guzzle/common": "self.version", + "guzzle/http": "self.version", + "guzzle/inflection": "self.version", + "guzzle/iterator": "self.version", + "guzzle/log": "self.version", + "guzzle/parser": "self.version", + "guzzle/plugin": "self.version", + "guzzle/plugin-async": "self.version", + "guzzle/plugin-backoff": "self.version", + "guzzle/plugin-cache": "self.version", + "guzzle/plugin-cookie": "self.version", + "guzzle/plugin-curlauth": "self.version", + "guzzle/plugin-error-response": "self.version", + "guzzle/plugin-history": "self.version", + "guzzle/plugin-log": "self.version", + "guzzle/plugin-md5": "self.version", + "guzzle/plugin-mock": "self.version", + "guzzle/plugin-oauth": "self.version", + "guzzle/service": "self.version", + "guzzle/stream": "self.version" + }, + "require-dev": { + "doctrine/cache": "~1.3", + "monolog/monolog": "~1.0", + "phpunit/phpunit": "3.7.*", + "psr/log": "~1.0", + "symfony/class-loader": "~2.1", + "zendframework/zend-cache": "2.*,<2.3", + "zendframework/zend-log": "2.*,<2.3" + }, + "time": "2014-05-07 17:04:22", + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "3.8-dev" + } + }, + "installation-source": "dist", + "autoload": { + "psr-0": { + "Guzzle": "src/", + "Guzzle\\Tests": "tests/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "MIT" + ], + "authors": [ + { + "name": "Michael Dowling", + "email": "mtdowling@gmail.com", + "homepage": "https://github.com/mtdowling" + }, + { + "name": "Guzzle Community", + "homepage": "https://github.com/guzzle/guzzle/contributors" + } + ], + "description": "Guzzle is a PHP HTTP client library and framework for building RESTful web service clients", + "homepage": "http://guzzlephp.org/", + "keywords": [ + "client", + "curl", + "framework", + "http", + "http client", + "rest", + "web service" + ] + }, + { + "name": "aws/aws-sdk-php", + "version": "2.6.6", + "version_normalized": "2.6.6.0", + "source": { + "type": "git", + "url": "https://github.com/aws/aws-sdk-php.git", + "reference": "37d5572e2408c5ea7104c361b64a187b1a0a53bd" + }, + "dist": { + "type": "zip", + "url": "https://api.github.com/repos/aws/aws-sdk-php/zipball/37d5572e2408c5ea7104c361b64a187b1a0a53bd", + "reference": "37d5572e2408c5ea7104c361b64a187b1a0a53bd", + "shasum": "" + }, + "require": { + "guzzle/guzzle": ">=3.7.0,<=3.9.9", + "php": ">=5.3.3" + }, + "require-dev": { + "doctrine/cache": "~1.0", + "ext-openssl": "*", + "monolog/monolog": "1.4.*", + "phpunit/phpunit": "3.7.*", + "symfony/class-loader": "2.*", + "symfony/yaml": "2.*" + }, + "suggest": { + "doctrine/cache": "Adds support for caching of credentials and responses", + "ext-apc": "Allows service description opcode caching, request and response caching, and credentials caching", + "ext-openssl": "Allows working with CloudFront private distributions and verifying received SNS messages", + "monolog/monolog": "Adds support for logging HTTP requests and responses", + "symfony/yaml": "Eases the ability to write manifests for creating jobs in AWS Import/Export" + }, + "time": "2014-05-29 18:57:57", + "type": "library", + "extra": { + "branch-alias": { + "dev-master": "2.6.x-dev" + } + }, + "installation-source": "dist", + "autoload": { + "psr-0": { + "Aws": "src/" + } + }, + "notification-url": "https://packagist.org/downloads/", + "license": [ + "Apache-2.0" + ], + "authors": [ + { + "name": "Amazon Web Services", + "homepage": "http://aws.amazon.com" + } + ], + "description": "AWS SDK for PHP - Use Amazon Web Services in your PHP project", + "homepage": "http://aws.amazon.com/sdkforphp", + "keywords": [ + "amazon", + "aws", + "cloud", + "dynamodb", + "ec2", + "glacier", + "s3", + "sdk" + ] + } +] diff --git a/vendor/guzzle/guzzle/.gitignore b/vendor/guzzle/guzzle/.gitignore new file mode 100644 index 0000000..893035d --- /dev/null +++ b/vendor/guzzle/guzzle/.gitignore @@ -0,0 +1,27 @@ +# Ingore common cruft +.DS_STORE +coverage +.idea + +# Ignore binary files +guzzle.phar +guzzle-min.phar + +# Ignore potentially sensitive phpunit file +phpunit.xml + +# Ignore composer generated files +composer.phar +composer.lock +composer-test.lock +vendor/ + +# Ignore build files +build/ +phing/build.properties + +# Ignore subsplit working directory +.subsplit + +docs/_build +docs/*.pyc diff --git a/vendor/guzzle/guzzle/.travis.yml b/vendor/guzzle/guzzle/.travis.yml new file mode 100644 index 0000000..56d2838 --- /dev/null +++ b/vendor/guzzle/guzzle/.travis.yml @@ -0,0 +1,30 @@ +language: php + +php: + - 5.3 + - 5.4 + - 5.5 + - 5.6 + - hhvm + +before_script: + - curl --version + - pear config-set php_ini ~/.phpenv/versions/`php -r 'echo phpversion();'`/etc/php.ini + - echo 'Installing pecl_http' + - wget --quiet http://pecl.php.net/get/pecl_http-1.7.6.tgz + - tar -xzf pecl_http-1.7.6.tgz + - sh -c "cd pecl_http-1.7.6 && phpize && ./configure && make && sudo make install" > /dev/null + - echo "extension=http.so" >> `php --ini | grep "Loaded Configuration" | sed -e "s|.*:\s*||"` + - pecl install uri_template-beta + - phpenv rehash + - composer install --dev + - echo 'Ensuring the correct version of node is running' + - ~/.nvm/nvm.sh install v0.6.14 + +script: vendor/bin/phpunit + +matrix: + allow_failures: + - php: 5.6 + - php: hhvm + fast_finish: true diff --git a/vendor/guzzle/guzzle/CHANGELOG.md b/vendor/guzzle/guzzle/CHANGELOG.md new file mode 100644 index 0000000..a1ba31f --- /dev/null +++ b/vendor/guzzle/guzzle/CHANGELOG.md @@ -0,0 +1,788 @@ +CHANGELOG +========= + +3.9.1 (2014-05-07) +------------------ + +* Added a fix to ReadLimitEntityBody to ensure it doesn't infinitely loop. +* Added a fix to the stream checksum function so that when the first read + returns a falsey value, it still continues to consume the stream until EOF. + +3.9.0 (2014-04-23) +------------------ + +* `null`, `false`, and `"_guzzle_blank_"` all now serialize as an empty value + with no trailing "=". See dc1d824277. +* No longer performing an MD5 check on the cacert each time the phar is used, + but rather copying the cacert to the temp directory. +* `"0"` can now be added as a URL path +* Deleting cookies that are set to empty +* If-Modified-Since is no longer unnecessarily added to the CachePlugin +* Cookie path matching now follows RFC 6265 s5.1.4 +* Updated service descriptions are now added to a service client's composite + factory. +* MockPlugin now throws an exception if the queue is empty. +* Properly parsing URLs that start with "http" but are not absolute +* Added the ability to configure the curl_multi_select timeout setting +* OAuth parameters are now sorted using lexicographical byte value ordering +* Fixing invalid usage of an out of range PHP feature in the ErrorResponsePlugin + +3.8.1 (2014-01-28) +------------------ + +* Bug: Always using GET requests when redirecting from a 303 response +* Bug: CURLOPT_SSL_VERIFYHOST is now correctly set to false when setting `$certificateAuthority` to false in + `Guzzle\Http\ClientInterface::setSslVerification()` +* Bug: RedirectPlugin now uses strict RFC 3986 compliance when combining a base URL with a relative URL +* Bug: The body of a request can now be set to `"0"` +* Sending PHP stream requests no longer forces `HTTP/1.0` +* Adding more information to ExceptionCollection exceptions so that users have more context, including a stack trace of + each sub-exception +* Updated the `$ref` attribute in service descriptions to merge over any existing parameters of a schema (rather than + clobbering everything). +* Merging URLs will now use the query string object from the relative URL (thus allowing custom query aggregators) +* Query strings are now parsed in a way that they do no convert empty keys with no value to have a dangling `=`. + For example `foo&bar=baz` is now correctly parsed and recognized as `foo&bar=baz` rather than `foo=&bar=baz`. +* Now properly escaping the regular expression delimiter when matching Cookie domains. +* Network access is now disabled when loading XML documents + +3.8.0 (2013-12-05) +------------------ + +* Added the ability to define a POST name for a file +* JSON response parsing now properly walks additionalProperties +* cURL error code 18 is now retried automatically in the BackoffPlugin +* Fixed a cURL error when URLs contain fragments +* Fixed an issue in the BackoffPlugin retry event where it was trying to access all exceptions as if they were + CurlExceptions +* CURLOPT_PROGRESS function fix for PHP 5.5 (69fcc1e) +* Added the ability for Guzzle to work with older versions of cURL that do not support `CURLOPT_TIMEOUT_MS` +* Fixed a bug that was encountered when parsing empty header parameters +* UriTemplate now has a `setRegex()` method to match the docs +* The `debug` request parameter now checks if it is truthy rather than if it exists +* Setting the `debug` request parameter to true shows verbose cURL output instead of using the LogPlugin +* Added the ability to combine URLs using strict RFC 3986 compliance +* Command objects can now return the validation errors encountered by the command +* Various fixes to cache revalidation (#437 and 29797e5) +* Various fixes to the AsyncPlugin +* Cleaned up build scripts + +3.7.4 (2013-10-02) +------------------ + +* Bug fix: 0 is now an allowed value in a description parameter that has a default value (#430) +* Bug fix: SchemaFormatter now returns an integer when formatting to a Unix timestamp + (see https://github.com/aws/aws-sdk-php/issues/147) +* Bug fix: Cleaned up and fixed URL dot segment removal to properly resolve internal dots +* Minimum PHP version is now properly specified as 5.3.3 (up from 5.3.2) (#420) +* Updated the bundled cacert.pem (#419) +* OauthPlugin now supports adding authentication to headers or query string (#425) + +3.7.3 (2013-09-08) +------------------ + +* Added the ability to get the exception associated with a request/command when using `MultiTransferException` and + `CommandTransferException`. +* Setting `additionalParameters` of a response to false is now honored when parsing responses with a service description +* Schemas are only injected into response models when explicitly configured. +* No longer guessing Content-Type based on the path of a request. Content-Type is now only guessed based on the path of + an EntityBody. +* Bug fix: ChunkedIterator can now properly chunk a \Traversable as well as an \Iterator. +* Bug fix: FilterIterator now relies on `\Iterator` instead of `\Traversable`. +* Bug fix: Gracefully handling malformed responses in RequestMediator::writeResponseBody() +* Bug fix: Replaced call to canCache with canCacheRequest in the CallbackCanCacheStrategy of the CachePlugin +* Bug fix: Visiting XML attributes first before visting XML children when serializing requests +* Bug fix: Properly parsing headers that contain commas contained in quotes +* Bug fix: mimetype guessing based on a filename is now case-insensitive + +3.7.2 (2013-08-02) +------------------ + +* Bug fix: Properly URL encoding paths when using the PHP-only version of the UriTemplate expander + See https://github.com/guzzle/guzzle/issues/371 +* Bug fix: Cookie domains are now matched correctly according to RFC 6265 + See https://github.com/guzzle/guzzle/issues/377 +* Bug fix: GET parameters are now used when calculating an OAuth signature +* Bug fix: Fixed an issue with cache revalidation where the If-None-Match header was being double quoted +* `Guzzle\Common\AbstractHasDispatcher::dispatch()` now returns the event that was dispatched +* `Guzzle\Http\QueryString::factory()` now guesses the most appropriate query aggregator to used based on the input. + See https://github.com/guzzle/guzzle/issues/379 +* Added a way to add custom domain objects to service description parsing using the `operation.parse_class` event. See + https://github.com/guzzle/guzzle/pull/380 +* cURL multi cleanup and optimizations + +3.7.1 (2013-07-05) +------------------ + +* Bug fix: Setting default options on a client now works +* Bug fix: Setting options on HEAD requests now works. See #352 +* Bug fix: Moving stream factory before send event to before building the stream. See #353 +* Bug fix: Cookies no longer match on IP addresses per RFC 6265 +* Bug fix: Correctly parsing header parameters that are in `<>` and quotes +* Added `cert` and `ssl_key` as request options +* `Host` header can now diverge from the host part of a URL if the header is set manually +* `Guzzle\Service\Command\LocationVisitor\Request\XmlVisitor` was rewritten to change from using SimpleXML to XMLWriter +* OAuth parameters are only added via the plugin if they aren't already set +* Exceptions are now thrown when a URL cannot be parsed +* Returning `false` if `Guzzle\Http\EntityBody::getContentMd5()` fails +* Not setting a `Content-MD5` on a command if calculating the Content-MD5 fails via the CommandContentMd5Plugin + +3.7.0 (2013-06-10) +------------------ + +* See UPGRADING.md for more information on how to upgrade. +* Requests now support the ability to specify an array of $options when creating a request to more easily modify a + request. You can pass a 'request.options' configuration setting to a client to apply default request options to + every request created by a client (e.g. default query string variables, headers, curl options, etc). +* Added a static facade class that allows you to use Guzzle with static methods and mount the class to `\Guzzle`. + See `Guzzle\Http\StaticClient::mount`. +* Added `command.request_options` to `Guzzle\Service\Command\AbstractCommand` to pass request options to requests + created by a command (e.g. custom headers, query string variables, timeout settings, etc). +* Stream size in `Guzzle\Stream\PhpStreamRequestFactory` will now be set if Content-Length is returned in the + headers of a response +* Added `Guzzle\Common\Collection::setPath($path, $value)` to set a value into an array using a nested key + (e.g. `$collection->setPath('foo/baz/bar', 'test'); echo $collection['foo']['bar']['bar'];`) +* ServiceBuilders now support storing and retrieving arbitrary data +* CachePlugin can now purge all resources for a given URI +* CachePlugin can automatically purge matching cached items when a non-idempotent request is sent to a resource +* CachePlugin now uses the Vary header to determine if a resource is a cache hit +* `Guzzle\Http\Message\Response` now implements `\Serializable` +* Added `Guzzle\Cache\CacheAdapterFactory::fromCache()` to more easily create cache adapters +* `Guzzle\Service\ClientInterface::execute()` now accepts an array, single command, or Traversable +* Fixed a bug in `Guzzle\Http\Message\Header\Link::addLink()` +* Better handling of calculating the size of a stream in `Guzzle\Stream\Stream` using fstat() and caching the size +* `Guzzle\Common\Exception\ExceptionCollection` now creates a more readable exception message +* Fixing BC break: Added back the MonologLogAdapter implementation rather than extending from PsrLog so that older + Symfony users can still use the old version of Monolog. +* Fixing BC break: Added the implementation back in for `Guzzle\Http\Message\AbstractMessage::getTokenizedHeader()`. + Now triggering an E_USER_DEPRECATED warning when used. Use `$message->getHeader()->parseParams()`. +* Several performance improvements to `Guzzle\Common\Collection` +* Added an `$options` argument to the end of the following methods of `Guzzle\Http\ClientInterface`: + createRequest, head, delete, put, patch, post, options, prepareRequest +* Added an `$options` argument to the end of `Guzzle\Http\Message\Request\RequestFactoryInterface::createRequest()` +* Added an `applyOptions()` method to `Guzzle\Http\Message\Request\RequestFactoryInterface` +* Changed `Guzzle\Http\ClientInterface::get($uri = null, $headers = null, $body = null)` to + `Guzzle\Http\ClientInterface::get($uri = null, $headers = null, $options = array())`. You can still pass in a + resource, string, or EntityBody into the $options parameter to specify the download location of the response. +* Changed `Guzzle\Common\Collection::__construct($data)` to no longer accepts a null value for `$data` but a + default `array()` +* Added `Guzzle\Stream\StreamInterface::isRepeatable` +* Removed `Guzzle\Http\ClientInterface::setDefaultHeaders(). Use + $client->getConfig()->setPath('request.options/headers/{header_name}', 'value')`. or + $client->getConfig()->setPath('request.options/headers', array('header_name' => 'value'))`. +* Removed `Guzzle\Http\ClientInterface::getDefaultHeaders(). Use $client->getConfig()->getPath('request.options/headers')`. +* Removed `Guzzle\Http\ClientInterface::expandTemplate()` +* Removed `Guzzle\Http\ClientInterface::setRequestFactory()` +* Removed `Guzzle\Http\ClientInterface::getCurlMulti()` +* Removed `Guzzle\Http\Message\RequestInterface::canCache` +* Removed `Guzzle\Http\Message\RequestInterface::setIsRedirect` +* Removed `Guzzle\Http\Message\RequestInterface::isRedirect` +* Made `Guzzle\Http\Client::expandTemplate` and `getUriTemplate` protected methods. +* You can now enable E_USER_DEPRECATED warnings to see if you are using a deprecated method by setting + `Guzzle\Common\Version::$emitWarnings` to true. +* Marked `Guzzle\Http\Message\Request::isResponseBodyRepeatable()` as deprecated. Use + `$request->getResponseBody()->isRepeatable()` instead. +* Marked `Guzzle\Http\Message\Request::canCache()` as deprecated. Use + `Guzzle\Plugin\Cache\DefaultCanCacheStrategy->canCacheRequest()` instead. +* Marked `Guzzle\Http\Message\Request::canCache()` as deprecated. Use + `Guzzle\Plugin\Cache\DefaultCanCacheStrategy->canCacheRequest()` instead. +* Marked `Guzzle\Http\Message\Request::setIsRedirect()` as deprecated. Use the HistoryPlugin instead. +* Marked `Guzzle\Http\Message\Request::isRedirect()` as deprecated. Use the HistoryPlugin instead. +* Marked `Guzzle\Cache\CacheAdapterFactory::factory()` as deprecated +* Marked 'command.headers', 'command.response_body' and 'command.on_complete' as deprecated for AbstractCommand. + These will work through Guzzle 4.0 +* Marked 'request.params' for `Guzzle\Http\Client` as deprecated. Use [request.options][params]. +* Marked `Guzzle\Service\Client::enableMagicMethods()` as deprecated. Magic methods can no longer be disabled on a Guzzle\Service\Client. +* Marked `Guzzle\Service\Client::getDefaultHeaders()` as deprecated. Use $client->getConfig()->getPath('request.options/headers')`. +* Marked `Guzzle\Service\Client::setDefaultHeaders()` as deprecated. Use $client->getConfig()->setPath('request.options/headers/{header_name}', 'value')`. +* Marked `Guzzle\Parser\Url\UrlParser` as deprecated. Just use PHP's `parse_url()` and percent encode your UTF-8. +* Marked `Guzzle\Common\Collection::inject()` as deprecated. +* Marked `Guzzle\Plugin\CurlAuth\CurlAuthPlugin` as deprecated. Use `$client->getConfig()->setPath('request.options/auth', array('user', 'pass', 'Basic|Digest');` +* CacheKeyProviderInterface and DefaultCacheKeyProvider are no longer used. All of this logic is handled in a + CacheStorageInterface. These two objects and interface will be removed in a future version. +* Always setting X-cache headers on cached responses +* Default cache TTLs are now handled by the CacheStorageInterface of a CachePlugin +* `CacheStorageInterface::cache($key, Response $response, $ttl = null)` has changed to `cache(RequestInterface + $request, Response $response);` +* `CacheStorageInterface::fetch($key)` has changed to `fetch(RequestInterface $request);` +* `CacheStorageInterface::delete($key)` has changed to `delete(RequestInterface $request);` +* Added `CacheStorageInterface::purge($url)` +* `DefaultRevalidation::__construct(CacheKeyProviderInterface $cacheKey, CacheStorageInterface $cache, CachePlugin + $plugin)` has changed to `DefaultRevalidation::__construct(CacheStorageInterface $cache, + CanCacheStrategyInterface $canCache = null)` +* Added `RevalidationInterface::shouldRevalidate(RequestInterface $request, Response $response)` + +3.6.0 (2013-05-29) +------------------ + +* ServiceDescription now implements ToArrayInterface +* Added command.hidden_params to blacklist certain headers from being treated as additionalParameters +* Guzzle can now correctly parse incomplete URLs +* Mixed casing of headers are now forced to be a single consistent casing across all values for that header. +* Messages internally use a HeaderCollection object to delegate handling case-insensitive header resolution +* Removed the whole changedHeader() function system of messages because all header changes now go through addHeader(). +* Specific header implementations can be created for complex headers. When a message creates a header, it uses a + HeaderFactory which can map specific headers to specific header classes. There is now a Link header and + CacheControl header implementation. +* Removed from interface: Guzzle\Http\ClientInterface::setUriTemplate +* Removed from interface: Guzzle\Http\ClientInterface::setCurlMulti() +* Removed Guzzle\Http\Message\Request::receivedRequestHeader() and implemented this functionality in + Guzzle\Http\Curl\RequestMediator +* Removed the optional $asString parameter from MessageInterface::getHeader(). Just cast the header to a string. +* Removed the optional $tryChunkedTransfer option from Guzzle\Http\Message\EntityEnclosingRequestInterface +* Removed the $asObjects argument from Guzzle\Http\Message\MessageInterface::getHeaders() +* Removed Guzzle\Parser\ParserRegister::get(). Use getParser() +* Removed Guzzle\Parser\ParserRegister::set(). Use registerParser(). +* All response header helper functions return a string rather than mixing Header objects and strings inconsistently +* Removed cURL blacklist support. This is no longer necessary now that Expect, Accept, etc are managed by Guzzle + directly via interfaces +* Removed the injecting of a request object onto a response object. The methods to get and set a request still exist + but are a no-op until removed. +* Most classes that used to require a ``Guzzle\Service\Command\CommandInterface` typehint now request a + `Guzzle\Service\Command\ArrayCommandInterface`. +* Added `Guzzle\Http\Message\RequestInterface::startResponse()` to the RequestInterface to handle injecting a response + on a request while the request is still being transferred +* The ability to case-insensitively search for header values +* Guzzle\Http\Message\Header::hasExactHeader +* Guzzle\Http\Message\Header::raw. Use getAll() +* Deprecated cache control specific methods on Guzzle\Http\Message\AbstractMessage. Use the CacheControl header object + instead. +* `Guzzle\Service\Command\CommandInterface` now extends from ToArrayInterface and ArrayAccess +* Added the ability to cast Model objects to a string to view debug information. + +3.5.0 (2013-05-13) +------------------ + +* Bug: Fixed a regression so that request responses are parsed only once per oncomplete event rather than multiple times +* Bug: Better cleanup of one-time events accross the board (when an event is meant to fire once, it will now remove + itself from the EventDispatcher) +* Bug: `Guzzle\Log\MessageFormatter` now properly writes "total_time" and "connect_time" values +* Bug: Cloning an EntityEnclosingRequest now clones the EntityBody too +* Bug: Fixed an undefined index error when parsing nested JSON responses with a sentAs parameter that reference a + non-existent key +* Bug: All __call() method arguments are now required (helps with mocking frameworks) +* Deprecating Response::getRequest() and now using a shallow clone of a request object to remove a circular reference + to help with refcount based garbage collection of resources created by sending a request +* Deprecating ZF1 cache and log adapters. These will be removed in the next major version. +* Deprecating `Response::getPreviousResponse()` (method signature still exists, but it'sdeprecated). Use the + HistoryPlugin for a history. +* Added a `responseBody` alias for the `response_body` location +* Refactored internals to no longer rely on Response::getRequest() +* HistoryPlugin can now be cast to a string +* HistoryPlugin now logs transactions rather than requests and responses to more accurately keep track of the requests + and responses that are sent over the wire +* Added `getEffectiveUrl()` and `getRedirectCount()` to Response objects + +3.4.3 (2013-04-30) +------------------ + +* Bug fix: Fixing bug introduced in 3.4.2 where redirect responses are duplicated on the final redirected response +* Added a check to re-extract the temp cacert bundle from the phar before sending each request + +3.4.2 (2013-04-29) +------------------ + +* Bug fix: Stream objects now work correctly with "a" and "a+" modes +* Bug fix: Removing `Transfer-Encoding: chunked` header when a Content-Length is present +* Bug fix: AsyncPlugin no longer forces HEAD requests +* Bug fix: DateTime timezones are now properly handled when using the service description schema formatter +* Bug fix: CachePlugin now properly handles stale-if-error directives when a request to the origin server fails +* Setting a response on a request will write to the custom request body from the response body if one is specified +* LogPlugin now writes to php://output when STDERR is undefined +* Added the ability to set multiple POST files for the same key in a single call +* application/x-www-form-urlencoded POSTs now use the utf-8 charset by default +* Added the ability to queue CurlExceptions to the MockPlugin +* Cleaned up how manual responses are queued on requests (removed "queued_response" and now using request.before_send) +* Configuration loading now allows remote files + +3.4.1 (2013-04-16) +------------------ + +* Large refactoring to how CurlMulti handles work. There is now a proxy that sits in front of a pool of CurlMulti + handles. This greatly simplifies the implementation, fixes a couple bugs, and provides a small performance boost. +* Exceptions are now properly grouped when sending requests in parallel +* Redirects are now properly aggregated when a multi transaction fails +* Redirects now set the response on the original object even in the event of a failure +* Bug fix: Model names are now properly set even when using $refs +* Added support for PHP 5.5's CurlFile to prevent warnings with the deprecated @ syntax +* Added support for oauth_callback in OAuth signatures +* Added support for oauth_verifier in OAuth signatures +* Added support to attempt to retrieve a command first literally, then ucfirst, the with inflection + +3.4.0 (2013-04-11) +------------------ + +* Bug fix: URLs are now resolved correctly based on http://tools.ietf.org/html/rfc3986#section-5.2. #289 +* Bug fix: Absolute URLs with a path in a service description will now properly override the base URL. #289 +* Bug fix: Parsing a query string with a single PHP array value will now result in an array. #263 +* Bug fix: Better normalization of the User-Agent header to prevent duplicate headers. #264. +* Bug fix: Added `number` type to service descriptions. +* Bug fix: empty parameters are removed from an OAuth signature +* Bug fix: Revalidating a cache entry prefers the Last-Modified over the Date header +* Bug fix: Fixed "array to string" error when validating a union of types in a service description +* Bug fix: Removed code that attempted to determine the size of a stream when data is written to the stream +* Bug fix: Not including an `oauth_token` if the value is null in the OauthPlugin. +* Bug fix: Now correctly aggregating successful requests and failed requests in CurlMulti when a redirect occurs. +* The new default CURLOPT_TIMEOUT setting has been increased to 150 seconds so that Guzzle works on poor connections. +* Added a feature to EntityEnclosingRequest::setBody() that will automatically set the Content-Type of the request if + the Content-Type can be determined based on the entity body or the path of the request. +* Added the ability to overwrite configuration settings in a client when grabbing a throwaway client from a builder. +* Added support for a PSR-3 LogAdapter. +* Added a `command.after_prepare` event +* Added `oauth_callback` parameter to the OauthPlugin +* Added the ability to create a custom stream class when using a stream factory +* Added a CachingEntityBody decorator +* Added support for `additionalParameters` in service descriptions to define how custom parameters are serialized. +* The bundled SSL certificate is now provided in the phar file and extracted when running Guzzle from a phar. +* You can now send any EntityEnclosingRequest with POST fields or POST files and cURL will handle creating bodies +* POST requests using a custom entity body are now treated exactly like PUT requests but with a custom cURL method. This + means that the redirect behavior of POST requests with custom bodies will not be the same as POST requests that use + POST fields or files (the latter is only used when emulating a form POST in the browser). +* Lots of cleanup to CurlHandle::factory and RequestFactory::createRequest + +3.3.1 (2013-03-10) +------------------ + +* Added the ability to create PHP streaming responses from HTTP requests +* Bug fix: Running any filters when parsing response headers with service descriptions +* Bug fix: OauthPlugin fixes to allow for multi-dimensional array signing, and sorting parameters before signing +* Bug fix: Removed the adding of default empty arrays and false Booleans to responses in order to be consistent across + response location visitors. +* Bug fix: Removed the possibility of creating configuration files with circular dependencies +* RequestFactory::create() now uses the key of a POST file when setting the POST file name +* Added xmlAllowEmpty to serialize an XML body even if no XML specific parameters are set + +3.3.0 (2013-03-03) +------------------ + +* A large number of performance optimizations have been made +* Bug fix: Added 'wb' as a valid write mode for streams +* Bug fix: `Guzzle\Http\Message\Response::json()` now allows scalar values to be returned +* Bug fix: Fixed bug in `Guzzle\Http\Message\Response` where wrapping quotes were stripped from `getEtag()` +* BC: Removed `Guzzle\Http\Utils` class +* BC: Setting a service description on a client will no longer modify the client's command factories. +* BC: Emitting IO events from a RequestMediator is now a parameter that must be set in a request's curl options using + the 'emit_io' key. This was previously set under a request's parameters using 'curl.emit_io' +* BC: `Guzzle\Stream\Stream::getWrapper()` and `Guzzle\Stream\Stream::getSteamType()` are no longer converted to + lowercase +* Operation parameter objects are now lazy loaded internally +* Added ErrorResponsePlugin that can throw errors for responses defined in service description operations' errorResponses +* Added support for instantiating responseType=class responseClass classes. Classes must implement + `Guzzle\Service\Command\ResponseClassInterface` +* Added support for additionalProperties for top-level parameters in responseType=model responseClasses. These + additional properties also support locations and can be used to parse JSON responses where the outermost part of the + JSON is an array +* Added support for nested renaming of JSON models (rename sentAs to name) +* CachePlugin + * Added support for stale-if-error so that the CachePlugin can now serve stale content from the cache on error + * Debug headers can now added to cached response in the CachePlugin + +3.2.0 (2013-02-14) +------------------ + +* CurlMulti is no longer reused globally. A new multi object is created per-client. This helps to isolate clients. +* URLs with no path no longer contain a "/" by default +* Guzzle\Http\QueryString does no longer manages the leading "?". This is now handled in Guzzle\Http\Url. +* BadResponseException no longer includes the full request and response message +* Adding setData() to Guzzle\Service\Description\ServiceDescriptionInterface +* Adding getResponseBody() to Guzzle\Http\Message\RequestInterface +* Various updates to classes to use ServiceDescriptionInterface type hints rather than ServiceDescription +* Header values can now be normalized into distinct values when multiple headers are combined with a comma separated list +* xmlEncoding can now be customized for the XML declaration of a XML service description operation +* Guzzle\Http\QueryString now uses Guzzle\Http\QueryAggregator\QueryAggregatorInterface objects to add custom value + aggregation and no longer uses callbacks +* The URL encoding implementation of Guzzle\Http\QueryString can now be customized +* Bug fix: Filters were not always invoked for array service description parameters +* Bug fix: Redirects now use a target response body rather than a temporary response body +* Bug fix: The default exponential backoff BackoffPlugin was not giving when the request threshold was exceeded +* Bug fix: Guzzle now takes the first found value when grabbing Cache-Control directives + +3.1.2 (2013-01-27) +------------------ + +* Refactored how operation responses are parsed. Visitors now include a before() method responsible for parsing the + response body. For example, the XmlVisitor now parses the XML response into an array in the before() method. +* Fixed an issue where cURL would not automatically decompress responses when the Accept-Encoding header was sent +* CURLOPT_SSL_VERIFYHOST is never set to 1 because it is deprecated (see 5e0ff2ef20f839e19d1eeb298f90ba3598784444) +* Fixed a bug where redirect responses were not chained correctly using getPreviousResponse() +* Setting default headers on a client after setting the user-agent will not erase the user-agent setting + +3.1.1 (2013-01-20) +------------------ + +* Adding wildcard support to Guzzle\Common\Collection::getPath() +* Adding alias support to ServiceBuilder configs +* Adding Guzzle\Service\Resource\CompositeResourceIteratorFactory and cleaning up factory interface + +3.1.0 (2013-01-12) +------------------ + +* BC: CurlException now extends from RequestException rather than BadResponseException +* BC: Renamed Guzzle\Plugin\Cache\CanCacheStrategyInterface::canCache() to canCacheRequest() and added CanCacheResponse() +* Added getData to ServiceDescriptionInterface +* Added context array to RequestInterface::setState() +* Bug: Removing hard dependency on the BackoffPlugin from Guzzle\Http +* Bug: Adding required content-type when JSON request visitor adds JSON to a command +* Bug: Fixing the serialization of a service description with custom data +* Made it easier to deal with exceptions thrown when transferring commands or requests in parallel by providing + an array of successful and failed responses +* Moved getPath from Guzzle\Service\Resource\Model to Guzzle\Common\Collection +* Added Guzzle\Http\IoEmittingEntityBody +* Moved command filtration from validators to location visitors +* Added `extends` attributes to service description parameters +* Added getModels to ServiceDescriptionInterface + +3.0.7 (2012-12-19) +------------------ + +* Fixing phar detection when forcing a cacert to system if null or true +* Allowing filename to be passed to `Guzzle\Http\Message\Request::setResponseBody()` +* Cleaning up `Guzzle\Common\Collection::inject` method +* Adding a response_body location to service descriptions + +3.0.6 (2012-12-09) +------------------ + +* CurlMulti performance improvements +* Adding setErrorResponses() to Operation +* composer.json tweaks + +3.0.5 (2012-11-18) +------------------ + +* Bug: Fixing an infinite recursion bug caused from revalidating with the CachePlugin +* Bug: Response body can now be a string containing "0" +* Bug: Using Guzzle inside of a phar uses system by default but now allows for a custom cacert +* Bug: QueryString::fromString now properly parses query string parameters that contain equal signs +* Added support for XML attributes in service description responses +* DefaultRequestSerializer now supports array URI parameter values for URI template expansion +* Added better mimetype guessing to requests and post files + +3.0.4 (2012-11-11) +------------------ + +* Bug: Fixed a bug when adding multiple cookies to a request to use the correct glue value +* Bug: Cookies can now be added that have a name, domain, or value set to "0" +* Bug: Using the system cacert bundle when using the Phar +* Added json and xml methods to Response to make it easier to parse JSON and XML response data into data structures +* Enhanced cookie jar de-duplication +* Added the ability to enable strict cookie jars that throw exceptions when invalid cookies are added +* Added setStream to StreamInterface to actually make it possible to implement custom rewind behavior for entity bodies +* Added the ability to create any sort of hash for a stream rather than just an MD5 hash + +3.0.3 (2012-11-04) +------------------ + +* Implementing redirects in PHP rather than cURL +* Added PECL URI template extension and using as default parser if available +* Bug: Fixed Content-Length parsing of Response factory +* Adding rewind() method to entity bodies and streams. Allows for custom rewinding of non-repeatable streams. +* Adding ToArrayInterface throughout library +* Fixing OauthPlugin to create unique nonce values per request + +3.0.2 (2012-10-25) +------------------ + +* Magic methods are enabled by default on clients +* Magic methods return the result of a command +* Service clients no longer require a base_url option in the factory +* Bug: Fixed an issue with URI templates where null template variables were being expanded + +3.0.1 (2012-10-22) +------------------ + +* Models can now be used like regular collection objects by calling filter, map, etc +* Models no longer require a Parameter structure or initial data in the constructor +* Added a custom AppendIterator to get around a PHP bug with the `\AppendIterator` + +3.0.0 (2012-10-15) +------------------ + +* Rewrote service description format to be based on Swagger + * Now based on JSON schema + * Added nested input structures and nested response models + * Support for JSON and XML input and output models + * Renamed `commands` to `operations` + * Removed dot class notation + * Removed custom types +* Broke the project into smaller top-level namespaces to be more component friendly +* Removed support for XML configs and descriptions. Use arrays or JSON files. +* Removed the Validation component and Inspector +* Moved all cookie code to Guzzle\Plugin\Cookie +* Magic methods on a Guzzle\Service\Client now return the command un-executed. +* Calling getResult() or getResponse() on a command will lazily execute the command if needed. +* Now shipping with cURL's CA certs and using it by default +* Added previousResponse() method to response objects +* No longer sending Accept and Accept-Encoding headers on every request +* Only sending an Expect header by default when a payload is greater than 1MB +* Added/moved client options: + * curl.blacklist to curl.option.blacklist + * Added ssl.certificate_authority +* Added a Guzzle\Iterator component +* Moved plugins from Guzzle\Http\Plugin to Guzzle\Plugin +* Added a more robust backoff retry strategy (replaced the ExponentialBackoffPlugin) +* Added a more robust caching plugin +* Added setBody to response objects +* Updating LogPlugin to use a more flexible MessageFormatter +* Added a completely revamped build process +* Cleaning up Collection class and removing default values from the get method +* Fixed ZF2 cache adapters + +2.8.8 (2012-10-15) +------------------ + +* Bug: Fixed a cookie issue that caused dot prefixed domains to not match where popular browsers did + +2.8.7 (2012-09-30) +------------------ + +* Bug: Fixed config file aliases for JSON includes +* Bug: Fixed cookie bug on a request object by using CookieParser to parse cookies on requests +* Bug: Removing the path to a file when sending a Content-Disposition header on a POST upload +* Bug: Hardening request and response parsing to account for missing parts +* Bug: Fixed PEAR packaging +* Bug: Fixed Request::getInfo +* Bug: Fixed cases where CURLM_CALL_MULTI_PERFORM return codes were causing curl transactions to fail +* Adding the ability for the namespace Iterator factory to look in multiple directories +* Added more getters/setters/removers from service descriptions +* Added the ability to remove POST fields from OAuth signatures +* OAuth plugin now supports 2-legged OAuth + +2.8.6 (2012-09-05) +------------------ + +* Added the ability to modify and build service descriptions +* Added the use of visitors to apply parameters to locations in service descriptions using the dynamic command +* Added a `json` parameter location +* Now allowing dot notation for classes in the CacheAdapterFactory +* Using the union of two arrays rather than an array_merge when extending service builder services and service params +* Ensuring that a service is a string before doing strpos() checks on it when substituting services for references + in service builder config files. +* Services defined in two different config files that include one another will by default replace the previously + defined service, but you can now create services that extend themselves and merge their settings over the previous +* The JsonLoader now supports aliasing filenames with different filenames. This allows you to alias something like + '_default' with a default JSON configuration file. + +2.8.5 (2012-08-29) +------------------ + +* Bug: Suppressed empty arrays from URI templates +* Bug: Added the missing $options argument from ServiceDescription::factory to enable caching +* Added support for HTTP responses that do not contain a reason phrase in the start-line +* AbstractCommand commands are now invokable +* Added a way to get the data used when signing an Oauth request before a request is sent + +2.8.4 (2012-08-15) +------------------ + +* Bug: Custom delay time calculations are no longer ignored in the ExponentialBackoffPlugin +* Added the ability to transfer entity bodies as a string rather than streamed. This gets around curl error 65. Set `body_as_string` in a request's curl options to enable. +* Added a StreamInterface, EntityBodyInterface, and added ftell() to Guzzle\Common\Stream +* Added an AbstractEntityBodyDecorator and a ReadLimitEntityBody decorator to transfer only a subset of a decorated stream +* Stream and EntityBody objects will now return the file position to the previous position after a read required operation (e.g. getContentMd5()) +* Added additional response status codes +* Removed SSL information from the default User-Agent header +* DELETE requests can now send an entity body +* Added an EventDispatcher to the ExponentialBackoffPlugin and added an ExponentialBackoffLogger to log backoff retries +* Added the ability of the MockPlugin to consume mocked request bodies +* LogPlugin now exposes request and response objects in the extras array + +2.8.3 (2012-07-30) +------------------ + +* Bug: Fixed a case where empty POST requests were sent as GET requests +* Bug: Fixed a bug in ExponentialBackoffPlugin that caused fatal errors when retrying an EntityEnclosingRequest that does not have a body +* Bug: Setting the response body of a request to null after completing a request, not when setting the state of a request to new +* Added multiple inheritance to service description commands +* Added an ApiCommandInterface and added ``getParamNames()`` and ``hasParam()`` +* Removed the default 2mb size cutoff from the Md5ValidatorPlugin so that it now defaults to validating everything +* Changed CurlMulti::perform to pass a smaller timeout to CurlMulti::executeHandles + +2.8.2 (2012-07-24) +------------------ + +* Bug: Query string values set to 0 are no longer dropped from the query string +* Bug: A Collection object is no longer created each time a call is made to ``Guzzle\Service\Command\AbstractCommand::getRequestHeaders()`` +* Bug: ``+`` is now treated as an encoded space when parsing query strings +* QueryString and Collection performance improvements +* Allowing dot notation for class paths in filters attribute of a service descriptions + +2.8.1 (2012-07-16) +------------------ + +* Loosening Event Dispatcher dependency +* POST redirects can now be customized using CURLOPT_POSTREDIR + +2.8.0 (2012-07-15) +------------------ + +* BC: Guzzle\Http\Query + * Query strings with empty variables will always show an equal sign unless the variable is set to QueryString::BLANK (e.g. ?acl= vs ?acl) + * Changed isEncodingValues() and isEncodingFields() to isUrlEncoding() + * Changed setEncodeValues(bool) and setEncodeFields(bool) to useUrlEncoding(bool) + * Changed the aggregation functions of QueryString to be static methods + * Can now use fromString() with querystrings that have a leading ? +* cURL configuration values can be specified in service descriptions using ``curl.`` prefixed parameters +* Content-Length is set to 0 before emitting the request.before_send event when sending an empty request body +* Cookies are no longer URL decoded by default +* Bug: URI template variables set to null are no longer expanded + +2.7.2 (2012-07-02) +------------------ + +* BC: Moving things to get ready for subtree splits. Moving Inflection into Common. Moving Guzzle\Http\Parser to Guzzle\Parser. +* BC: Removing Guzzle\Common\Batch\Batch::count() and replacing it with isEmpty() +* CachePlugin now allows for a custom request parameter function to check if a request can be cached +* Bug fix: CachePlugin now only caches GET and HEAD requests by default +* Bug fix: Using header glue when transferring headers over the wire +* Allowing deeply nested arrays for composite variables in URI templates +* Batch divisors can now return iterators or arrays + +2.7.1 (2012-06-26) +------------------ + +* Minor patch to update version number in UA string +* Updating build process + +2.7.0 (2012-06-25) +------------------ + +* BC: Inflection classes moved to Guzzle\Inflection. No longer static methods. Can now inject custom inflectors into classes. +* BC: Removed magic setX methods from commands +* BC: Magic methods mapped to service description commands are now inflected in the command factory rather than the client __call() method +* Verbose cURL options are no longer enabled by default. Set curl.debug to true on a client to enable. +* Bug: Now allowing colons in a response start-line (e.g. HTTP/1.1 503 Service Unavailable: Back-end server is at capacity) +* Guzzle\Service\Resource\ResourceIteratorApplyBatched now internally uses the Guzzle\Common\Batch namespace +* Added Guzzle\Service\Plugin namespace and a PluginCollectionPlugin +* Added the ability to set POST fields and files in a service description +* Guzzle\Http\EntityBody::factory() now accepts objects with a __toString() method +* Adding a command.before_prepare event to clients +* Added BatchClosureTransfer and BatchClosureDivisor +* BatchTransferException now includes references to the batch divisor and transfer strategies +* Fixed some tests so that they pass more reliably +* Added Guzzle\Common\Log\ArrayLogAdapter + +2.6.6 (2012-06-10) +------------------ + +* BC: Removing Guzzle\Http\Plugin\BatchQueuePlugin +* BC: Removing Guzzle\Service\Command\CommandSet +* Adding generic batching system (replaces the batch queue plugin and command set) +* Updating ZF cache and log adapters and now using ZF's composer repository +* Bug: Setting the name of each ApiParam when creating through an ApiCommand +* Adding result_type, result_doc, deprecated, and doc_url to service descriptions +* Bug: Changed the default cookie header casing back to 'Cookie' + +2.6.5 (2012-06-03) +------------------ + +* BC: Renaming Guzzle\Http\Message\RequestInterface::getResourceUri() to getResource() +* BC: Removing unused AUTH_BASIC and AUTH_DIGEST constants from +* BC: Guzzle\Http\Cookie is now used to manage Set-Cookie data, not Cookie data +* BC: Renaming methods in the CookieJarInterface +* Moving almost all cookie logic out of the CookiePlugin and into the Cookie or CookieJar implementations +* Making the default glue for HTTP headers ';' instead of ',' +* Adding a removeValue to Guzzle\Http\Message\Header +* Adding getCookies() to request interface. +* Making it easier to add event subscribers to HasDispatcherInterface classes. Can now directly call addSubscriber() + +2.6.4 (2012-05-30) +------------------ + +* BC: Cleaning up how POST files are stored in EntityEnclosingRequest objects. Adding PostFile class. +* BC: Moving ApiCommand specific functionality from the Inspector and on to the ApiCommand +* Bug: Fixing magic method command calls on clients +* Bug: Email constraint only validates strings +* Bug: Aggregate POST fields when POST files are present in curl handle +* Bug: Fixing default User-Agent header +* Bug: Only appending or prepending parameters in commands if they are specified +* Bug: Not requiring response reason phrases or status codes to match a predefined list of codes +* Allowing the use of dot notation for class namespaces when using instance_of constraint +* Added any_match validation constraint +* Added an AsyncPlugin +* Passing request object to the calculateWait method of the ExponentialBackoffPlugin +* Allowing the result of a command object to be changed +* Parsing location and type sub values when instantiating a service description rather than over and over at runtime + +2.6.3 (2012-05-23) +------------------ + +* [BC] Guzzle\Common\FromConfigInterface no longer requires any config options. +* [BC] Refactoring how POST files are stored on an EntityEnclosingRequest. They are now separate from POST fields. +* You can now use an array of data when creating PUT request bodies in the request factory. +* Removing the requirement that HTTPS requests needed a Cache-Control: public directive to be cacheable. +* [Http] Adding support for Content-Type in multipart POST uploads per upload +* [Http] Added support for uploading multiple files using the same name (foo[0], foo[1]) +* Adding more POST data operations for easier manipulation of POST data. +* You can now set empty POST fields. +* The body of a request is only shown on EntityEnclosingRequest objects that do not use POST files. +* Split the Guzzle\Service\Inspector::validateConfig method into two methods. One to initialize when a command is created, and one to validate. +* CS updates + +2.6.2 (2012-05-19) +------------------ + +* [Http] Better handling of nested scope requests in CurlMulti. Requests are now always prepares in the send() method rather than the addRequest() method. + +2.6.1 (2012-05-19) +------------------ + +* [BC] Removing 'path' support in service descriptions. Use 'uri'. +* [BC] Guzzle\Service\Inspector::parseDocBlock is now protected. Adding getApiParamsForClass() with cache. +* [BC] Removing Guzzle\Common\NullObject. Use https://github.com/mtdowling/NullObject if you need it. +* [BC] Removing Guzzle\Common\XmlElement. +* All commands, both dynamic and concrete, have ApiCommand objects. +* Adding a fix for CurlMulti so that if all of the connections encounter some sort of curl error, then the loop exits. +* Adding checks to EntityEnclosingRequest so that empty POST files and fields are ignored. +* Making the method signature of Guzzle\Service\Builder\ServiceBuilder::factory more flexible. + +2.6.0 (2012-05-15) +------------------ + +* [BC] Moving Guzzle\Service\Builder to Guzzle\Service\Builder\ServiceBuilder +* [BC] Executing a Command returns the result of the command rather than the command +* [BC] Moving all HTTP parsing logic to Guzzle\Http\Parsers. Allows for faster C implementations if needed. +* [BC] Changing the Guzzle\Http\Message\Response::setProtocol() method to accept a protocol and version in separate args. +* [BC] Moving ResourceIterator* to Guzzle\Service\Resource +* [BC] Completely refactored ResourceIterators to iterate over a cloned command object +* [BC] Moved Guzzle\Http\UriTemplate to Guzzle\Http\Parser\UriTemplate\UriTemplate +* [BC] Guzzle\Guzzle is now deprecated +* Moving Guzzle\Common\Guzzle::inject to Guzzle\Common\Collection::inject +* Adding Guzzle\Version class to give version information about Guzzle +* Adding Guzzle\Http\Utils class to provide getDefaultUserAgent() and getHttpDate() +* Adding Guzzle\Curl\CurlVersion to manage caching curl_version() data +* ServiceDescription and ServiceBuilder are now cacheable using similar configs +* Changing the format of XML and JSON service builder configs. Backwards compatible. +* Cleaned up Cookie parsing +* Trimming the default Guzzle User-Agent header +* Adding a setOnComplete() method to Commands that is called when a command completes +* Keeping track of requests that were mocked in the MockPlugin +* Fixed a caching bug in the CacheAdapterFactory +* Inspector objects can be injected into a Command object +* Refactoring a lot of code and tests to be case insensitive when dealing with headers +* Adding Guzzle\Http\Message\HeaderComparison for easy comparison of HTTP headers using a DSL +* Adding the ability to set global option overrides to service builder configs +* Adding the ability to include other service builder config files from within XML and JSON files +* Moving the parseQuery method out of Url and on to QueryString::fromString() as a static factory method. + +2.5.0 (2012-05-08) +------------------ + +* Major performance improvements +* [BC] Simplifying Guzzle\Common\Collection. Please check to see if you are using features that are now deprecated. +* [BC] Using a custom validation system that allows a flyweight implementation for much faster validation. No longer using Symfony2 Validation component. +* [BC] No longer supporting "{{ }}" for injecting into command or UriTemplates. Use "{}" +* Added the ability to passed parameters to all requests created by a client +* Added callback functionality to the ExponentialBackoffPlugin +* Using microtime in ExponentialBackoffPlugin to allow more granular backoff strategies. +* Rewinding request stream bodies when retrying requests +* Exception is thrown when JSON response body cannot be decoded +* Added configurable magic method calls to clients and commands. This is off by default. +* Fixed a defect that added a hash to every parsed URL part +* Fixed duplicate none generation for OauthPlugin. +* Emitting an event each time a client is generated by a ServiceBuilder +* Using an ApiParams object instead of a Collection for parameters of an ApiCommand +* cache.* request parameters should be renamed to params.cache.* +* Added the ability to set arbitrary curl options on requests (disable_wire, progress, etc). See CurlHandle. +* Added the ability to disable type validation of service descriptions +* ServiceDescriptions and ServiceBuilders are now Serializable diff --git a/vendor/guzzle/guzzle/LICENSE b/vendor/guzzle/guzzle/LICENSE new file mode 100644 index 0000000..d51aa69 --- /dev/null +++ b/vendor/guzzle/guzzle/LICENSE @@ -0,0 +1,19 @@ +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. diff --git a/vendor/guzzle/guzzle/README.md b/vendor/guzzle/guzzle/README.md new file mode 100644 index 0000000..e1fc0cc --- /dev/null +++ b/vendor/guzzle/guzzle/README.md @@ -0,0 +1,36 @@ +Guzzle, PHP HTTP client and webservice framework +================================================ + +[![Composer Downloads](https://poser.pugx.org/guzzle/guzzle/d/total.png)](https://packagist.org/packages/guzzle/guzzle) + [![Build Status](https://secure.travis-ci.org/guzzle/guzzle3.png?branch=master)](http://travis-ci.org/guzzle/guzzle3) + +Guzzle is a PHP HTTP client and framework for building RESTful web service clients. + +- Extremely powerful API provides all the power of cURL with a simple interface. +- Truly take advantage of HTTP/1.1 with persistent connections, connection pooling, and parallel requests. +- Service description DSL allows you build awesome web service clients faster. +- Symfony2 event-based plugin system allows you to completely modify the behavior of a request. + +Get answers with: [Documentation](http://guzzle3.readthedocs.org/en/latest/), [Forums](https://groups.google.com/forum/?hl=en#!forum/guzzle), IRC ([#guzzlephp](irc://irc.freenode.net/#guzzlephp) @ irc.freenode.net) + +### Installing via Composer + +The recommended way to install Guzzle is through [Composer](http://getcomposer.org). + +```bash +# Install Composer +curl -sS https://getcomposer.org/installer | php + +# Add Guzzle as a dependency +php composer.phar require guzzle/guzzle:~3.9 +``` + +After installing, you need to require Composer's autoloader: + +```php +require 'vendor/autoload.php'; +``` + +# This is an older version + +This repository is for Guzzle 3.x. Guzzle 4.0, the new version of Guzzle has been released and is available at https://github.com/guzzle/guzzle. diff --git a/vendor/guzzle/guzzle/UPGRADING.md b/vendor/guzzle/guzzle/UPGRADING.md new file mode 100644 index 0000000..f58bf11 --- /dev/null +++ b/vendor/guzzle/guzzle/UPGRADING.md @@ -0,0 +1,537 @@ +Guzzle Upgrade Guide +==================== + +3.6 to 3.7 +---------- + +### Deprecations + +- You can now enable E_USER_DEPRECATED warnings to see if you are using any deprecated methods.: + +```php +\Guzzle\Common\Version::$emitWarnings = true; +``` + +The following APIs and options have been marked as deprecated: + +- Marked `Guzzle\Http\Message\Request::isResponseBodyRepeatable()` as deprecated. Use `$request->getResponseBody()->isRepeatable()` instead. +- Marked `Guzzle\Http\Message\Request::canCache()` as deprecated. Use `Guzzle\Plugin\Cache\DefaultCanCacheStrategy->canCacheRequest()` instead. +- Marked `Guzzle\Http\Message\Request::canCache()` as deprecated. Use `Guzzle\Plugin\Cache\DefaultCanCacheStrategy->canCacheRequest()` instead. +- Marked `Guzzle\Http\Message\Request::setIsRedirect()` as deprecated. Use the HistoryPlugin instead. +- Marked `Guzzle\Http\Message\Request::isRedirect()` as deprecated. Use the HistoryPlugin instead. +- Marked `Guzzle\Cache\CacheAdapterFactory::factory()` as deprecated +- Marked `Guzzle\Service\Client::enableMagicMethods()` as deprecated. Magic methods can no longer be disabled on a Guzzle\Service\Client. +- Marked `Guzzle\Parser\Url\UrlParser` as deprecated. Just use PHP's `parse_url()` and percent encode your UTF-8. +- Marked `Guzzle\Common\Collection::inject()` as deprecated. +- Marked `Guzzle\Plugin\CurlAuth\CurlAuthPlugin` as deprecated. Use + `$client->getConfig()->setPath('request.options/auth', array('user', 'pass', 'Basic|Digest|NTLM|Any'));` or + `$client->setDefaultOption('auth', array('user', 'pass', 'Basic|Digest|NTLM|Any'));` + +3.7 introduces `request.options` as a parameter for a client configuration and as an optional argument to all creational +request methods. When paired with a client's configuration settings, these options allow you to specify default settings +for various aspects of a request. Because these options make other previous configuration options redundant, several +configuration options and methods of a client and AbstractCommand have been deprecated. + +- Marked `Guzzle\Service\Client::getDefaultHeaders()` as deprecated. Use `$client->getDefaultOption('headers')`. +- Marked `Guzzle\Service\Client::setDefaultHeaders()` as deprecated. Use `$client->setDefaultOption('headers/{header_name}', 'value')`. +- Marked 'request.params' for `Guzzle\Http\Client` as deprecated. Use `$client->setDefaultOption('params/{param_name}', 'value')` +- Marked 'command.headers', 'command.response_body' and 'command.on_complete' as deprecated for AbstractCommand. These will work through Guzzle 4.0 + + $command = $client->getCommand('foo', array( + 'command.headers' => array('Test' => '123'), + 'command.response_body' => '/path/to/file' + )); + + // Should be changed to: + + $command = $client->getCommand('foo', array( + 'command.request_options' => array( + 'headers' => array('Test' => '123'), + 'save_as' => '/path/to/file' + ) + )); + +### Interface changes + +Additions and changes (you will need to update any implementations or subclasses you may have created): + +- Added an `$options` argument to the end of the following methods of `Guzzle\Http\ClientInterface`: + createRequest, head, delete, put, patch, post, options, prepareRequest +- Added an `$options` argument to the end of `Guzzle\Http\Message\Request\RequestFactoryInterface::createRequest()` +- Added an `applyOptions()` method to `Guzzle\Http\Message\Request\RequestFactoryInterface` +- Changed `Guzzle\Http\ClientInterface::get($uri = null, $headers = null, $body = null)` to + `Guzzle\Http\ClientInterface::get($uri = null, $headers = null, $options = array())`. You can still pass in a + resource, string, or EntityBody into the $options parameter to specify the download location of the response. +- Changed `Guzzle\Common\Collection::__construct($data)` to no longer accepts a null value for `$data` but a + default `array()` +- Added `Guzzle\Stream\StreamInterface::isRepeatable` +- Made `Guzzle\Http\Client::expandTemplate` and `getUriTemplate` protected methods. + +The following methods were removed from interfaces. All of these methods are still available in the concrete classes +that implement them, but you should update your code to use alternative methods: + +- Removed `Guzzle\Http\ClientInterface::setDefaultHeaders(). Use + `$client->getConfig()->setPath('request.options/headers/{header_name}', 'value')`. or + `$client->getConfig()->setPath('request.options/headers', array('header_name' => 'value'))` or + `$client->setDefaultOption('headers/{header_name}', 'value')`. or + `$client->setDefaultOption('headers', array('header_name' => 'value'))`. +- Removed `Guzzle\Http\ClientInterface::getDefaultHeaders(). Use `$client->getConfig()->getPath('request.options/headers')`. +- Removed `Guzzle\Http\ClientInterface::expandTemplate()`. This is an implementation detail. +- Removed `Guzzle\Http\ClientInterface::setRequestFactory()`. This is an implementation detail. +- Removed `Guzzle\Http\ClientInterface::getCurlMulti()`. This is a very specific implementation detail. +- Removed `Guzzle\Http\Message\RequestInterface::canCache`. Use the CachePlugin. +- Removed `Guzzle\Http\Message\RequestInterface::setIsRedirect`. Use the HistoryPlugin. +- Removed `Guzzle\Http\Message\RequestInterface::isRedirect`. Use the HistoryPlugin. + +### Cache plugin breaking changes + +- CacheKeyProviderInterface and DefaultCacheKeyProvider are no longer used. All of this logic is handled in a + CacheStorageInterface. These two objects and interface will be removed in a future version. +- Always setting X-cache headers on cached responses +- Default cache TTLs are now handled by the CacheStorageInterface of a CachePlugin +- `CacheStorageInterface::cache($key, Response $response, $ttl = null)` has changed to `cache(RequestInterface + $request, Response $response);` +- `CacheStorageInterface::fetch($key)` has changed to `fetch(RequestInterface $request);` +- `CacheStorageInterface::delete($key)` has changed to `delete(RequestInterface $request);` +- Added `CacheStorageInterface::purge($url)` +- `DefaultRevalidation::__construct(CacheKeyProviderInterface $cacheKey, CacheStorageInterface $cache, CachePlugin + $plugin)` has changed to `DefaultRevalidation::__construct(CacheStorageInterface $cache, + CanCacheStrategyInterface $canCache = null)` +- Added `RevalidationInterface::shouldRevalidate(RequestInterface $request, Response $response)` + +3.5 to 3.6 +---------- + +* Mixed casing of headers are now forced to be a single consistent casing across all values for that header. +* Messages internally use a HeaderCollection object to delegate handling case-insensitive header resolution +* Removed the whole changedHeader() function system of messages because all header changes now go through addHeader(). + For example, setHeader() first removes the header using unset on a HeaderCollection and then calls addHeader(). + Keeping the Host header and URL host in sync is now handled by overriding the addHeader method in Request. +* Specific header implementations can be created for complex headers. When a message creates a header, it uses a + HeaderFactory which can map specific headers to specific header classes. There is now a Link header and + CacheControl header implementation. +* Moved getLinks() from Response to just be used on a Link header object. + +If you previously relied on Guzzle\Http\Message\Header::raw(), then you will need to update your code to use the +HeaderInterface (e.g. toArray(), getAll(), etc). + +### Interface changes + +* Removed from interface: Guzzle\Http\ClientInterface::setUriTemplate +* Removed from interface: Guzzle\Http\ClientInterface::setCurlMulti() +* Removed Guzzle\Http\Message\Request::receivedRequestHeader() and implemented this functionality in + Guzzle\Http\Curl\RequestMediator +* Removed the optional $asString parameter from MessageInterface::getHeader(). Just cast the header to a string. +* Removed the optional $tryChunkedTransfer option from Guzzle\Http\Message\EntityEnclosingRequestInterface +* Removed the $asObjects argument from Guzzle\Http\Message\MessageInterface::getHeaders() + +### Removed deprecated functions + +* Removed Guzzle\Parser\ParserRegister::get(). Use getParser() +* Removed Guzzle\Parser\ParserRegister::set(). Use registerParser(). + +### Deprecations + +* The ability to case-insensitively search for header values +* Guzzle\Http\Message\Header::hasExactHeader +* Guzzle\Http\Message\Header::raw. Use getAll() +* Deprecated cache control specific methods on Guzzle\Http\Message\AbstractMessage. Use the CacheControl header object + instead. + +### Other changes + +* All response header helper functions return a string rather than mixing Header objects and strings inconsistently +* Removed cURL blacklist support. This is no longer necessary now that Expect, Accept, etc are managed by Guzzle + directly via interfaces +* Removed the injecting of a request object onto a response object. The methods to get and set a request still exist + but are a no-op until removed. +* Most classes that used to require a ``Guzzle\Service\Command\CommandInterface` typehint now request a + `Guzzle\Service\Command\ArrayCommandInterface`. +* Added `Guzzle\Http\Message\RequestInterface::startResponse()` to the RequestInterface to handle injecting a response + on a request while the request is still being transferred +* `Guzzle\Service\Command\CommandInterface` now extends from ToArrayInterface and ArrayAccess + +3.3 to 3.4 +---------- + +Base URLs of a client now follow the rules of http://tools.ietf.org/html/rfc3986#section-5.2.2 when merging URLs. + +3.2 to 3.3 +---------- + +### Response::getEtag() quote stripping removed + +`Guzzle\Http\Message\Response::getEtag()` no longer strips quotes around the ETag response header + +### Removed `Guzzle\Http\Utils` + +The `Guzzle\Http\Utils` class was removed. This class was only used for testing. + +### Stream wrapper and type + +`Guzzle\Stream\Stream::getWrapper()` and `Guzzle\Stream\Stream::getSteamType()` are no longer converted to lowercase. + +### curl.emit_io became emit_io + +Emitting IO events from a RequestMediator is now a parameter that must be set in a request's curl options using the +'emit_io' key. This was previously set under a request's parameters using 'curl.emit_io' + +3.1 to 3.2 +---------- + +### CurlMulti is no longer reused globally + +Before 3.2, the same CurlMulti object was reused globally for each client. This can cause issue where plugins added +to a single client can pollute requests dispatched from other clients. + +If you still wish to reuse the same CurlMulti object with each client, then you can add a listener to the +ServiceBuilder's `service_builder.create_client` event to inject a custom CurlMulti object into each client as it is +created. + +```php +$multi = new Guzzle\Http\Curl\CurlMulti(); +$builder = Guzzle\Service\Builder\ServiceBuilder::factory('/path/to/config.json'); +$builder->addListener('service_builder.create_client', function ($event) use ($multi) { + $event['client']->setCurlMulti($multi); +} +}); +``` + +### No default path + +URLs no longer have a default path value of '/' if no path was specified. + +Before: + +```php +$request = $client->get('http://www.foo.com'); +echo $request->getUrl(); +// >> http://www.foo.com/ +``` + +After: + +```php +$request = $client->get('http://www.foo.com'); +echo $request->getUrl(); +// >> http://www.foo.com +``` + +### Less verbose BadResponseException + +The exception message for `Guzzle\Http\Exception\BadResponseException` no longer contains the full HTTP request and +response information. You can, however, get access to the request and response object by calling `getRequest()` or +`getResponse()` on the exception object. + +### Query parameter aggregation + +Multi-valued query parameters are no longer aggregated using a callback function. `Guzzle\Http\Query` now has a +setAggregator() method that accepts a `Guzzle\Http\QueryAggregator\QueryAggregatorInterface` object. This object is +responsible for handling the aggregation of multi-valued query string variables into a flattened hash. + +2.8 to 3.x +---------- + +### Guzzle\Service\Inspector + +Change `\Guzzle\Service\Inspector::fromConfig` to `\Guzzle\Common\Collection::fromConfig` + +**Before** + +```php +use Guzzle\Service\Inspector; + +class YourClient extends \Guzzle\Service\Client +{ + public static function factory($config = array()) + { + $default = array(); + $required = array('base_url', 'username', 'api_key'); + $config = Inspector::fromConfig($config, $default, $required); + + $client = new self( + $config->get('base_url'), + $config->get('username'), + $config->get('api_key') + ); + $client->setConfig($config); + + $client->setDescription(ServiceDescription::factory(__DIR__ . DIRECTORY_SEPARATOR . 'client.json')); + + return $client; + } +``` + +**After** + +```php +use Guzzle\Common\Collection; + +class YourClient extends \Guzzle\Service\Client +{ + public static function factory($config = array()) + { + $default = array(); + $required = array('base_url', 'username', 'api_key'); + $config = Collection::fromConfig($config, $default, $required); + + $client = new self( + $config->get('base_url'), + $config->get('username'), + $config->get('api_key') + ); + $client->setConfig($config); + + $client->setDescription(ServiceDescription::factory(__DIR__ . DIRECTORY_SEPARATOR . 'client.json')); + + return $client; + } +``` + +### Convert XML Service Descriptions to JSON + +**Before** + +```xml + + + + + + Get a list of groups + + + Uses a search query to get a list of groups + + + + Create a group + + + + + Delete a group by ID + + + + + + + Update a group + + + + + + +``` + +**After** + +```json +{ + "name": "Zendesk REST API v2", + "apiVersion": "2012-12-31", + "description":"Provides access to Zendesk views, groups, tickets, ticket fields, and users", + "operations": { + "list_groups": { + "httpMethod":"GET", + "uri": "groups.json", + "summary": "Get a list of groups" + }, + "search_groups":{ + "httpMethod":"GET", + "uri": "search.json?query=\"{query} type:group\"", + "summary": "Uses a search query to get a list of groups", + "parameters":{ + "query":{ + "location": "uri", + "description":"Zendesk Search Query", + "type": "string", + "required": true + } + } + }, + "create_group": { + "httpMethod":"POST", + "uri": "groups.json", + "summary": "Create a group", + "parameters":{ + "data": { + "type": "array", + "location": "body", + "description":"Group JSON", + "filters": "json_encode", + "required": true + }, + "Content-Type":{ + "type": "string", + "location":"header", + "static": "application/json" + } + } + }, + "delete_group": { + "httpMethod":"DELETE", + "uri": "groups/{id}.json", + "summary": "Delete a group", + "parameters":{ + "id":{ + "location": "uri", + "description":"Group to delete by ID", + "type": "integer", + "required": true + } + } + }, + "get_group": { + "httpMethod":"GET", + "uri": "groups/{id}.json", + "summary": "Get a ticket", + "parameters":{ + "id":{ + "location": "uri", + "description":"Group to get by ID", + "type": "integer", + "required": true + } + } + }, + "update_group": { + "httpMethod":"PUT", + "uri": "groups/{id}.json", + "summary": "Update a group", + "parameters":{ + "id": { + "location": "uri", + "description":"Group to update by ID", + "type": "integer", + "required": true + }, + "data": { + "type": "array", + "location": "body", + "description":"Group JSON", + "filters": "json_encode", + "required": true + }, + "Content-Type":{ + "type": "string", + "location":"header", + "static": "application/json" + } + } + } +} +``` + +### Guzzle\Service\Description\ServiceDescription + +Commands are now called Operations + +**Before** + +```php +use Guzzle\Service\Description\ServiceDescription; + +$sd = new ServiceDescription(); +$sd->getCommands(); // @returns ApiCommandInterface[] +$sd->hasCommand($name); +$sd->getCommand($name); // @returns ApiCommandInterface|null +$sd->addCommand($command); // @param ApiCommandInterface $command +``` + +**After** + +```php +use Guzzle\Service\Description\ServiceDescription; + +$sd = new ServiceDescription(); +$sd->getOperations(); // @returns OperationInterface[] +$sd->hasOperation($name); +$sd->getOperation($name); // @returns OperationInterface|null +$sd->addOperation($operation); // @param OperationInterface $operation +``` + +### Guzzle\Common\Inflection\Inflector + +Namespace is now `Guzzle\Inflection\Inflector` + +### Guzzle\Http\Plugin + +Namespace is now `Guzzle\Plugin`. Many other changes occur within this namespace and are detailed in their own sections below. + +### Guzzle\Http\Plugin\LogPlugin and Guzzle\Common\Log + +Now `Guzzle\Plugin\Log\LogPlugin` and `Guzzle\Log` respectively. + +**Before** + +```php +use Guzzle\Common\Log\ClosureLogAdapter; +use Guzzle\Http\Plugin\LogPlugin; + +/** @var \Guzzle\Http\Client */ +$client; + +// $verbosity is an integer indicating desired message verbosity level +$client->addSubscriber(new LogPlugin(new ClosureLogAdapter(function($m) { echo $m; }, $verbosity = LogPlugin::LOG_VERBOSE); +``` + +**After** + +```php +use Guzzle\Log\ClosureLogAdapter; +use Guzzle\Log\MessageFormatter; +use Guzzle\Plugin\Log\LogPlugin; + +/** @var \Guzzle\Http\Client */ +$client; + +// $format is a string indicating desired message format -- @see MessageFormatter +$client->addSubscriber(new LogPlugin(new ClosureLogAdapter(function($m) { echo $m; }, $format = MessageFormatter::DEBUG_FORMAT); +``` + +### Guzzle\Http\Plugin\CurlAuthPlugin + +Now `Guzzle\Plugin\CurlAuth\CurlAuthPlugin`. + +### Guzzle\Http\Plugin\ExponentialBackoffPlugin + +Now `Guzzle\Plugin\Backoff\BackoffPlugin`, and other changes. + +**Before** + +```php +use Guzzle\Http\Plugin\ExponentialBackoffPlugin; + +$backoffPlugin = new ExponentialBackoffPlugin($maxRetries, array_merge( + ExponentialBackoffPlugin::getDefaultFailureCodes(), array(429) + )); + +$client->addSubscriber($backoffPlugin); +``` + +**After** + +```php +use Guzzle\Plugin\Backoff\BackoffPlugin; +use Guzzle\Plugin\Backoff\HttpBackoffStrategy; + +// Use convenient factory method instead -- see implementation for ideas of what +// you can do with chaining backoff strategies +$backoffPlugin = BackoffPlugin::getExponentialBackoff($maxRetries, array_merge( + HttpBackoffStrategy::getDefaultFailureCodes(), array(429) + )); +$client->addSubscriber($backoffPlugin); +``` + +### Known Issues + +#### [BUG] Accept-Encoding header behavior changed unintentionally. + +(See #217) (Fixed in 09daeb8c666fb44499a0646d655a8ae36456575e) + +In version 2.8 setting the `Accept-Encoding` header would set the CURLOPT_ENCODING option, which permitted cURL to +properly handle gzip/deflate compressed responses from the server. In versions affected by this bug this does not happen. +See issue #217 for a workaround, or use a version containing the fix. diff --git a/vendor/guzzle/guzzle/build.xml b/vendor/guzzle/guzzle/build.xml new file mode 100644 index 0000000..2aa62ba --- /dev/null +++ b/vendor/guzzle/guzzle/build.xml @@ -0,0 +1,45 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/vendor/guzzle/guzzle/composer.json b/vendor/guzzle/guzzle/composer.json new file mode 100644 index 0000000..d6e9a96 --- /dev/null +++ b/vendor/guzzle/guzzle/composer.json @@ -0,0 +1,74 @@ +{ + "name": "guzzle/guzzle", + "type": "library", + "description": "Guzzle is a PHP HTTP client library and framework for building RESTful web service clients", + "keywords": ["framework", "http", "rest", "web service", "curl", "client", "HTTP client"], + "homepage": "http://guzzlephp.org/", + "license": "MIT", + + "authors": [ + { + "name": "Michael Dowling", + "email": "mtdowling@gmail.com", + "homepage": "https://github.com/mtdowling" + }, + { + "name": "Guzzle Community", + "homepage": "https://github.com/guzzle/guzzle/contributors" + } + ], + + "replace": { + "guzzle/batch": "self.version", + "guzzle/cache": "self.version", + "guzzle/common": "self.version", + "guzzle/http": "self.version", + "guzzle/inflection": "self.version", + "guzzle/iterator": "self.version", + "guzzle/log": "self.version", + "guzzle/parser": "self.version", + "guzzle/plugin": "self.version", + "guzzle/plugin-async": "self.version", + "guzzle/plugin-backoff": "self.version", + "guzzle/plugin-cache": "self.version", + "guzzle/plugin-cookie": "self.version", + "guzzle/plugin-curlauth": "self.version", + "guzzle/plugin-error-response": "self.version", + "guzzle/plugin-history": "self.version", + "guzzle/plugin-log": "self.version", + "guzzle/plugin-md5": "self.version", + "guzzle/plugin-mock": "self.version", + "guzzle/plugin-oauth": "self.version", + "guzzle/service": "self.version", + "guzzle/stream": "self.version" + }, + + "require": { + "php": ">=5.3.3", + "ext-curl": "*", + "symfony/event-dispatcher": "~2.1" + }, + + "autoload": { + "psr-0": { + "Guzzle": "src/", + "Guzzle\\Tests": "tests/" + } + }, + + "require-dev": { + "doctrine/cache": "~1.3", + "symfony/class-loader": "~2.1", + "monolog/monolog": "~1.0", + "psr/log": "~1.0", + "zendframework/zend-cache": "2.*,<2.3", + "zendframework/zend-log": "2.*,<2.3", + "phpunit/phpunit": "3.7.*" + }, + + "extra": { + "branch-alias": { + "dev-master": "3.8-dev" + } + } +} diff --git a/vendor/guzzle/guzzle/docs/Makefile b/vendor/guzzle/guzzle/docs/Makefile new file mode 100644 index 0000000..d92e03f --- /dev/null +++ b/vendor/guzzle/guzzle/docs/Makefile @@ -0,0 +1,153 @@ +# Makefile for Sphinx documentation +# + +# You can set these variables from the command line. +SPHINXOPTS = +SPHINXBUILD = sphinx-build +PAPER = +BUILDDIR = _build + +# Internal variables. +PAPEROPT_a4 = -D latex_paper_size=a4 +PAPEROPT_letter = -D latex_paper_size=letter +ALLSPHINXOPTS = -d $(BUILDDIR)/doctrees $(PAPEROPT_$(PAPER)) $(SPHINXOPTS) . +# the i18n builder cannot share the environment and doctrees with the others +I18NSPHINXOPTS = $(PAPEROPT_$(PAPER)) $(SPHINXOPTS) . + +.PHONY: help clean html dirhtml singlehtml pickle json htmlhelp qthelp devhelp epub latex latexpdf text man changes linkcheck doctest gettext + +help: + @echo "Please use \`make ' where is one of" + @echo " html to make standalone HTML files" + @echo " dirhtml to make HTML files named index.html in directories" + @echo " singlehtml to make a single large HTML file" + @echo " pickle to make pickle files" + @echo " json to make JSON files" + @echo " htmlhelp to make HTML files and a HTML help project" + @echo " qthelp to make HTML files and a qthelp project" + @echo " devhelp to make HTML files and a Devhelp project" + @echo " epub to make an epub" + @echo " latex to make LaTeX files, you can set PAPER=a4 or PAPER=letter" + @echo " latexpdf to make LaTeX files and run them through pdflatex" + @echo " text to make text files" + @echo " man to make manual pages" + @echo " texinfo to make Texinfo files" + @echo " info to make Texinfo files and run them through makeinfo" + @echo " gettext to make PO message catalogs" + @echo " changes to make an overview of all changed/added/deprecated items" + @echo " linkcheck to check all external links for integrity" + @echo " doctest to run all doctests embedded in the documentation (if enabled)" + +clean: + -rm -rf $(BUILDDIR)/* + +html: + $(SPHINXBUILD) -b html $(ALLSPHINXOPTS) $(BUILDDIR)/html + @echo + @echo "Build finished. The HTML pages are in $(BUILDDIR)/html." + +dirhtml: + $(SPHINXBUILD) -b dirhtml $(ALLSPHINXOPTS) $(BUILDDIR)/dirhtml + @echo + @echo "Build finished. The HTML pages are in $(BUILDDIR)/dirhtml." + +singlehtml: + $(SPHINXBUILD) -b singlehtml $(ALLSPHINXOPTS) $(BUILDDIR)/singlehtml + @echo + @echo "Build finished. The HTML page is in $(BUILDDIR)/singlehtml." + +pickle: + $(SPHINXBUILD) -b pickle $(ALLSPHINXOPTS) $(BUILDDIR)/pickle + @echo + @echo "Build finished; now you can process the pickle files." + +json: + $(SPHINXBUILD) -b json $(ALLSPHINXOPTS) $(BUILDDIR)/json + @echo + @echo "Build finished; now you can process the JSON files." + +htmlhelp: + $(SPHINXBUILD) -b htmlhelp $(ALLSPHINXOPTS) $(BUILDDIR)/htmlhelp + @echo + @echo "Build finished; now you can run HTML Help Workshop with the" \ + ".hhp project file in $(BUILDDIR)/htmlhelp." + +qthelp: + $(SPHINXBUILD) -b qthelp $(ALLSPHINXOPTS) $(BUILDDIR)/qthelp + @echo + @echo "Build finished; now you can run "qcollectiongenerator" with the" \ + ".qhcp project file in $(BUILDDIR)/qthelp, like this:" + @echo "# qcollectiongenerator $(BUILDDIR)/qthelp/Guzzle.qhcp" + @echo "To view the help file:" + @echo "# assistant -collectionFile $(BUILDDIR)/qthelp/Guzzle.qhc" + +devhelp: + $(SPHINXBUILD) -b devhelp $(ALLSPHINXOPTS) $(BUILDDIR)/devhelp + @echo + @echo "Build finished." + @echo "To view the help file:" + @echo "# mkdir -p $$HOME/.local/share/devhelp/Guzzle" + @echo "# ln -s $(BUILDDIR)/devhelp $$HOME/.local/share/devhelp/Guzzle" + @echo "# devhelp" + +epub: + $(SPHINXBUILD) -b epub $(ALLSPHINXOPTS) $(BUILDDIR)/epub + @echo + @echo "Build finished. The epub file is in $(BUILDDIR)/epub." + +latex: + $(SPHINXBUILD) -b latex $(ALLSPHINXOPTS) $(BUILDDIR)/latex + @echo + @echo "Build finished; the LaTeX files are in $(BUILDDIR)/latex." + @echo "Run \`make' in that directory to run these through (pdf)latex" \ + "(use \`make latexpdf' here to do that automatically)." + +latexpdf: + $(SPHINXBUILD) -b latex $(ALLSPHINXOPTS) $(BUILDDIR)/latex + @echo "Running LaTeX files through pdflatex..." + $(MAKE) -C $(BUILDDIR)/latex all-pdf + @echo "pdflatex finished; the PDF files are in $(BUILDDIR)/latex." + +text: + $(SPHINXBUILD) -b text $(ALLSPHINXOPTS) $(BUILDDIR)/text + @echo + @echo "Build finished. The text files are in $(BUILDDIR)/text." + +man: + $(SPHINXBUILD) -b man $(ALLSPHINXOPTS) $(BUILDDIR)/man + @echo + @echo "Build finished. The manual pages are in $(BUILDDIR)/man." + +texinfo: + $(SPHINXBUILD) -b texinfo $(ALLSPHINXOPTS) $(BUILDDIR)/texinfo + @echo + @echo "Build finished. The Texinfo files are in $(BUILDDIR)/texinfo." + @echo "Run \`make' in that directory to run these through makeinfo" \ + "(use \`make info' here to do that automatically)." + +info: + $(SPHINXBUILD) -b texinfo $(ALLSPHINXOPTS) $(BUILDDIR)/texinfo + @echo "Running Texinfo files through makeinfo..." + make -C $(BUILDDIR)/texinfo info + @echo "makeinfo finished; the Info files are in $(BUILDDIR)/texinfo." + +gettext: + $(SPHINXBUILD) -b gettext $(I18NSPHINXOPTS) $(BUILDDIR)/locale + @echo + @echo "Build finished. The message catalogs are in $(BUILDDIR)/locale." + +changes: + $(SPHINXBUILD) -b changes $(ALLSPHINXOPTS) $(BUILDDIR)/changes + @echo + @echo "The overview file is in $(BUILDDIR)/changes." + +linkcheck: + $(SPHINXBUILD) -b linkcheck $(ALLSPHINXOPTS) $(BUILDDIR)/linkcheck + @echo + @echo "Link check complete; look for any errors in the above output " \ + "or in $(BUILDDIR)/linkcheck/output.txt." + +doctest: + $(SPHINXBUILD) -b doctest $(ALLSPHINXOPTS) $(BUILDDIR)/doctest + @echo "Testing of doctests in the sources finished, look at the " \ + "results in $(BUILDDIR)/doctest/output.txt." diff --git a/vendor/guzzle/guzzle/docs/_downloads/guzzle-schema-1.0.json b/vendor/guzzle/guzzle/docs/_downloads/guzzle-schema-1.0.json new file mode 100644 index 0000000..1405950 --- /dev/null +++ b/vendor/guzzle/guzzle/docs/_downloads/guzzle-schema-1.0.json @@ -0,0 +1,176 @@ +{ + "additionalProperties": true, + "name": { + "type": "string", + "description": "Name of the web service" + }, + "apiVersion": { + "type": ["string", "number"], + "description": "Version identifier that the service description is compatible with" + }, + "baseUrl": { + "type": "string", + "description": "Base URL of the web service. Any relative URI specified in an operation will be merged with the baseUrl using the process defined in RFC 2396" + }, + "basePath": { + "type": "string", + "description": "Alias of baseUrl" + }, + "_description": { + "type": "string", + "description": "Short summary of the web service. This is actually called 'description' but this JSON schema wont validate using just description." + }, + "operations": { + "description": "Operations of the web service", + "type": "object", + "properties": { + "extends": { + "type": "string", + "description": "Extend from another operation by name. The parent operation must be defined before the child." + }, + "httpMethod": { + "type": "string", + "description": "HTTP method used with the operation (e.g. GET, POST, PUT, DELETE, PATCH, etc)" + }, + "uri": { + "type": "string", + "description": "URI of the operation. The uri attribute can contain URI templates. The variables of the URI template are parameters of the operation with a location value of uri" + }, + "summary": { + "type": "string", + "description": "Short summary of what the operation does" + }, + "class": { + "type": "string", + "description": "Custom class to instantiate instead of the default Guzzle\\Service\\Command\\OperationCommand" + }, + "responseClass": { + "type": "string", + "description": "This is what is returned from the method. Can be a primitive, class name, or model name." + }, + "responseNotes": { + "type": "string", + "description": "A description of the response returned by the operation" + }, + "responseType": { + "type": "string", + "description": "The type of response that the operation creates. If not specified, this value will be automatically inferred based on whether or not there is a model matching the name, if a matching class name is found, or set to 'primitive' by default.", + "enum": [ "primitive", "class", "model", "documentation" ] + }, + "deprecated": { + "type": "boolean", + "description": "Whether or not the operation is deprecated" + }, + "errorResponses": { + "description": "Errors that could occur while executing the operation", + "type": "array", + "items": { + "type": "object", + "properties": { + "code": { + "type": "number", + "description": "HTTP response status code of the error" + }, + "phrase": { + "type": "string", + "description": "Response reason phrase or description of the error" + }, + "class": { + "type": "string", + "description": "A custom exception class that would be thrown if the error is encountered" + } + } + } + }, + "data": { + "type": "object", + "additionalProperties": "true" + }, + "parameters": { + "$ref": "parameters", + "description": "Parameters of the operation. Parameters are used to define how input data is serialized into a HTTP request." + }, + "additionalParameters": { + "$ref": "parameters", + "description": "Validation and serialization rules for any parameter supplied to the operation that was not explicitly defined." + } + } + }, + "models": { + "description": "Schema models that can be referenced throughout the service description. Models can be used to define how an HTTP response is parsed into a Guzzle\\Service\\Resource\\Model object.", + "type": "object", + "properties": { + "$ref": "parameters", + "description": "Parameters of the model. When a model is referenced in a responseClass attribute of an operation, parameters define how a HTTP response message is parsed into a Guzzle\\Service\\Resource\\Model." + } + }, + "includes": { + "description": "Service description files to include and extend from (can be a .json, .js, or .php file)", + "type": "array", + "items": { + "type": "string", + "pattern": ".+\\.(js|json|php)$" + } + }, + "definitions": { + "parameters": { + "extends": "http://json-schema.org/schema", + "id": "parameters", + "name": { + "type": "string", + "description": "Unique name of the parameter" + }, + "type": { + "type": ["string", "array"], + "description": "Type of variable (string, number, integer, boolean, object, array, numeric, null, any). Types are using for validation and determining the structure of a parameter. You can use a union type by providing an array of simple types. If one of the union types matches the provided value, then the value is valid." + }, + "instanceOf": { + "type": "string", + "description": "When the type is an object, you can specify the class that the object must implement" + }, + "required": { + "type": "boolean", + "description": "Whether or not the parameter is required" + }, + "default": { + "description": "Default value to use if no value is supplied" + }, + "static": { + "type": "bool", + "description": "Set to true to specify that the parameter value cannot be changed from the default setting" + }, + "description": { + "type": "string", + "description": "Documentation of the parameter" + }, + "location": { + "type": "string", + "description": "The location of a request used to apply a parameter. Custom locations can be registered with a command, but the defaults are uri, query, statusCode, reasonPhrase, header, body, json, xml, postField, postFile, responseBody" + }, + "sentAs": { + "type": "string", + "description": "Specifies how the data being modeled is sent over the wire. For example, you may wish to include certain headers in a response model that have a normalized casing of FooBar, but the actual header is x-foo-bar. In this case, sentAs would be set to x-foo-bar." + }, + "filters": { + "type": "array", + "description": "Array of static method names to to run a parameter value through. Each value in the array must be a string containing the full class path to a static method or an array of complex filter information. You can specify static methods of classes using the full namespace class name followed by ‘::’ (e.g. FooBar::baz()). Some filters require arguments in order to properly filter a value. For complex filters, use a hash containing a ‘method’ key pointing to a static method, and an ‘args’ key containing an array of positional arguments to pass to the method. Arguments can contain keywords that are replaced when filtering a value: '@value‘ is replaced with the value being validated, '@api‘ is replaced with the Parameter object.", + "items": { + "type": ["string", { + "object": { + "properties": { + "method": { + "type": "string", + "description": "PHP function to call", + "required": true + }, + "args": { + "type": "array" + } + } + } + }] + } + } + } + } +} diff --git a/vendor/guzzle/guzzle/docs/_static/guzzle-icon.png b/vendor/guzzle/guzzle/docs/_static/guzzle-icon.png new file mode 100644 index 0000000..f1017f7 Binary files /dev/null and b/vendor/guzzle/guzzle/docs/_static/guzzle-icon.png differ diff --git a/vendor/guzzle/guzzle/docs/_static/homepage.css b/vendor/guzzle/guzzle/docs/_static/homepage.css new file mode 100644 index 0000000..70c46d8 --- /dev/null +++ b/vendor/guzzle/guzzle/docs/_static/homepage.css @@ -0,0 +1,122 @@ +/* Hero unit on homepage */ + +.hero-unit h1 { + font-size: 49px; + margin-bottom: 12px; +} + +.hero-unit { + padding: 40px; +} + +.hero-unit p { + font-size: 17px; +} + +.masthead img { + float: left; + margin-right: 17px; +} + +.hero-unit ul li { + margin-left: 220px; +} + +.hero-unit .buttons { + text-align: center; +} + +.jumbotron { + position: relative; + padding: 40px 0; + color: #fff; + text-shadow: 0 1px 3px rgba(0,0,0,.4), 0 0 30px rgba(0,0,0,.075); + background: #00312F; + background: -moz-linear-gradient(45deg, #002F31 0%, #335A6D 100%); + background: -webkit-gradient(linear, left bottom, right top, color-stop(0%,#00312D), color-stop(100%,#33566D)); + background: -webkit-linear-gradient(45deg, #020031 0%,#334F6D 100%); + background: -o-linear-gradient(45deg, #002D31 0%,#334D6D 100%); + background: -ms-linear-gradient(45deg, #002F31 0%,#33516D 100%); + background: linear-gradient(45deg, #020031 0%,#33516D 100%); + filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#020031', endColorstr='#6d3353',GradientType=1 ); + -webkit-box-shadow: inset 0 3px 7px rgba(0, 0, 0, .2), inset 0 -3px 7px rgba(0, 0, 0, .2); + -moz-box-shadow: inset 0 3px 7px rgba(0,0,0,.2), inset 0 -3px 7px rgba(0,0,0,.2); + box-shadow: inset 0 3px 7px rgba(0, 0, 0, .2), inset 0 -3px 7px rgba(0, 0, 0, .2); +} + +.jumbotron h1 { + font-size: 80px; + font-weight: bold; + letter-spacing: -1px; + line-height: 1; +} + +.jumbotron p { + font-size: 24px; + font-weight: 300; + line-height: 1.25; + margin-bottom: 30px; +} + +.masthead { + padding: 40px 0 30px; + margin-bottom: 0; + color: #fff; + margin-top: -19px; +} + +.masthead h1 { + display: none; +} + +.masthead p { + font-size: 40px; + font-weight: 200; + line-height: 1.25; + margin: 12px 0 0 0; +} + +.masthead .btn { + padding: 19px 24px; + font-size: 24px; + font-weight: 200; + border: 0; +} + +/* Social bar on homepage */ + +.social { + padding: 2px 0; + text-align: center; + background-color: #f5f5f5; + border-top: 1px solid #fff; + border-bottom: 1px solid #ddd; + margin: 0 0 20px 0; +} + +.social ul { + margin-top: 0; +} + +.social-buttons { + margin-left: 0; + margin-bottom: 0; + padding-left: 0; + list-style: none; +} + +.social-buttons li { + display: inline-block; + padding: 5px 8px; + line-height: 1; + *display: inline; + *zoom: 1; +} + +.center-announcement { + padding: 10px; + background-color: rgb(238, 243, 255); + border-radius: 8px; + text-align: center; + margin: 24px 0; +} diff --git a/vendor/guzzle/guzzle/docs/_static/logo.png b/vendor/guzzle/guzzle/docs/_static/logo.png new file mode 100644 index 0000000..ecc40ac Binary files /dev/null and b/vendor/guzzle/guzzle/docs/_static/logo.png differ diff --git a/vendor/guzzle/guzzle/docs/_static/prettify.css b/vendor/guzzle/guzzle/docs/_static/prettify.css new file mode 100644 index 0000000..4d410b1 --- /dev/null +++ b/vendor/guzzle/guzzle/docs/_static/prettify.css @@ -0,0 +1,41 @@ +.com { + color: #93A1A1; +} +.lit { + color: #195F91; +} +.pun, .opn, .clo { + color: #93A1A1; +} +.fun { + color: #DC322F; +} +.str, .atv { + color: #DD1144; +} +.kwd, .linenums .tag { + color: #1E347B; +} +.typ, .atn, .dec, .var { + color: teal; +} +.pln { + color: #48484C; +} +.prettyprint { + background-color: #F7F7F9; + border: 1px solid #E1E1E8; + padding: 8px; +} +.prettyprint.linenums { + box-shadow: 40px 0 0 #FBFBFC inset, 41px 0 0 #ECECF0 inset; +} +ol.linenums { + margin: 0 0 0 33px; +} +ol.linenums li { + color: #BEBEC5; + line-height: 18px; + padding-left: 12px; + text-shadow: 0 1px 0 #FFFFFF; +} diff --git a/vendor/guzzle/guzzle/docs/_static/prettify.js b/vendor/guzzle/guzzle/docs/_static/prettify.js new file mode 100644 index 0000000..eef5ad7 --- /dev/null +++ b/vendor/guzzle/guzzle/docs/_static/prettify.js @@ -0,0 +1,28 @@ +var q=null;window.PR_SHOULD_USE_CONTINUATION=!0; +(function(){function L(a){function m(a){var f=a.charCodeAt(0);if(f!==92)return f;var b=a.charAt(1);return(f=r[b])?f:"0"<=b&&b<="7"?parseInt(a.substring(1),8):b==="u"||b==="x"?parseInt(a.substring(2),16):a.charCodeAt(1)}function e(a){if(a<32)return(a<16?"\\x0":"\\x")+a.toString(16);a=String.fromCharCode(a);if(a==="\\"||a==="-"||a==="["||a==="]")a="\\"+a;return a}function h(a){for(var f=a.substring(1,a.length-1).match(/\\u[\dA-Fa-f]{4}|\\x[\dA-Fa-f]{2}|\\[0-3][0-7]{0,2}|\\[0-7]{1,2}|\\[\S\s]|[^\\]/g),a= +[],b=[],o=f[0]==="^",c=o?1:0,i=f.length;c122||(d<65||j>90||b.push([Math.max(65,j)|32,Math.min(d,90)|32]),d<97||j>122||b.push([Math.max(97,j)&-33,Math.min(d,122)&-33]))}}b.sort(function(a,f){return a[0]-f[0]||f[1]-a[1]});f=[];j=[NaN,NaN];for(c=0;ci[0]&&(i[1]+1>i[0]&&b.push("-"),b.push(e(i[1])));b.push("]");return b.join("")}function y(a){for(var f=a.source.match(/\[(?:[^\\\]]|\\[\S\s])*]|\\u[\dA-Fa-f]{4}|\\x[\dA-Fa-f]{2}|\\\d+|\\[^\dux]|\(\?[!:=]|[()^]|[^()[\\^]+/g),b=f.length,d=[],c=0,i=0;c=2&&a==="["?f[c]=h(j):a!=="\\"&&(f[c]=j.replace(/[A-Za-z]/g,function(a){a=a.charCodeAt(0);return"["+String.fromCharCode(a&-33,a|32)+"]"}));return f.join("")}for(var t=0,s=!1,l=!1,p=0,d=a.length;p=5&&"lang-"===b.substring(0,5))&&!(o&&typeof o[1]==="string"))c=!1,b="src";c||(r[f]=b)}i=d;d+=f.length;if(c){c=o[1];var j=f.indexOf(c),k=j+c.length;o[2]&&(k=f.length-o[2].length,j=k-c.length);b=b.substring(5);B(l+i,f.substring(0,j),e,p);B(l+i+j,c,C(b,c),p);B(l+i+k,f.substring(k),e,p)}else p.push(l+i,b)}a.e=p}var h={},y;(function(){for(var e=a.concat(m), +l=[],p={},d=0,g=e.length;d=0;)h[n.charAt(k)]=r;r=r[1];n=""+r;p.hasOwnProperty(n)||(l.push(r),p[n]=q)}l.push(/[\S\s]/);y=L(l)})();var t=m.length;return e}function u(a){var m=[],e=[];a.tripleQuotedStrings?m.push(["str",/^(?:'''(?:[^'\\]|\\[\S\s]|''?(?=[^']))*(?:'''|$)|"""(?:[^"\\]|\\[\S\s]|""?(?=[^"]))*(?:"""|$)|'(?:[^'\\]|\\[\S\s])*(?:'|$)|"(?:[^"\\]|\\[\S\s])*(?:"|$))/,q,"'\""]):a.multiLineStrings?m.push(["str",/^(?:'(?:[^'\\]|\\[\S\s])*(?:'|$)|"(?:[^"\\]|\\[\S\s])*(?:"|$)|`(?:[^\\`]|\\[\S\s])*(?:`|$))/, +q,"'\"`"]):m.push(["str",/^(?:'(?:[^\n\r'\\]|\\.)*(?:'|$)|"(?:[^\n\r"\\]|\\.)*(?:"|$))/,q,"\"'"]);a.verbatimStrings&&e.push(["str",/^@"(?:[^"]|"")*(?:"|$)/,q]);var h=a.hashComments;h&&(a.cStyleComments?(h>1?m.push(["com",/^#(?:##(?:[^#]|#(?!##))*(?:###|$)|.*)/,q,"#"]):m.push(["com",/^#(?:(?:define|elif|else|endif|error|ifdef|include|ifndef|line|pragma|undef|warning)\b|[^\n\r]*)/,q,"#"]),e.push(["str",/^<(?:(?:(?:\.\.\/)*|\/?)(?:[\w-]+(?:\/[\w-]+)+)?[\w-]+\.h|[a-z]\w*)>/,q])):m.push(["com",/^#[^\n\r]*/, +q,"#"]));a.cStyleComments&&(e.push(["com",/^\/\/[^\n\r]*/,q]),e.push(["com",/^\/\*[\S\s]*?(?:\*\/|$)/,q]));a.regexLiterals&&e.push(["lang-regex",/^(?:^^\.?|[!+-]|!=|!==|#|%|%=|&|&&|&&=|&=|\(|\*|\*=|\+=|,|-=|->|\/|\/=|:|::|;|<|<<|<<=|<=|=|==|===|>|>=|>>|>>=|>>>|>>>=|[?@[^]|\^=|\^\^|\^\^=|{|\||\|=|\|\||\|\|=|~|break|case|continue|delete|do|else|finally|instanceof|return|throw|try|typeof)\s*(\/(?=[^*/])(?:[^/[\\]|\\[\S\s]|\[(?:[^\\\]]|\\[\S\s])*(?:]|$))+\/)/]);(h=a.types)&&e.push(["typ",h]);a=(""+a.keywords).replace(/^ | $/g, +"");a.length&&e.push(["kwd",RegExp("^(?:"+a.replace(/[\s,]+/g,"|")+")\\b"),q]);m.push(["pln",/^\s+/,q," \r\n\t\xa0"]);e.push(["lit",/^@[$_a-z][\w$@]*/i,q],["typ",/^(?:[@_]?[A-Z]+[a-z][\w$@]*|\w+_t\b)/,q],["pln",/^[$_a-z][\w$@]*/i,q],["lit",/^(?:0x[\da-f]+|(?:\d(?:_\d+)*\d*(?:\.\d*)?|\.\d\+)(?:e[+-]?\d+)?)[a-z]*/i,q,"0123456789"],["pln",/^\\[\S\s]?/,q],["pun",/^.[^\s\w"-$'./@\\`]*/,q]);return x(m,e)}function D(a,m){function e(a){switch(a.nodeType){case 1:if(k.test(a.className))break;if("BR"===a.nodeName)h(a), +a.parentNode&&a.parentNode.removeChild(a);else for(a=a.firstChild;a;a=a.nextSibling)e(a);break;case 3:case 4:if(p){var b=a.nodeValue,d=b.match(t);if(d){var c=b.substring(0,d.index);a.nodeValue=c;(b=b.substring(d.index+d[0].length))&&a.parentNode.insertBefore(s.createTextNode(b),a.nextSibling);h(a);c||a.parentNode.removeChild(a)}}}}function h(a){function b(a,d){var e=d?a.cloneNode(!1):a,f=a.parentNode;if(f){var f=b(f,1),g=a.nextSibling;f.appendChild(e);for(var h=g;h;h=g)g=h.nextSibling,f.appendChild(h)}return e} +for(;!a.nextSibling;)if(a=a.parentNode,!a)return;for(var a=b(a.nextSibling,0),e;(e=a.parentNode)&&e.nodeType===1;)a=e;d.push(a)}var k=/(?:^|\s)nocode(?:\s|$)/,t=/\r\n?|\n/,s=a.ownerDocument,l;a.currentStyle?l=a.currentStyle.whiteSpace:window.getComputedStyle&&(l=s.defaultView.getComputedStyle(a,q).getPropertyValue("white-space"));var p=l&&"pre"===l.substring(0,3);for(l=s.createElement("LI");a.firstChild;)l.appendChild(a.firstChild);for(var d=[l],g=0;g=0;){var h=m[e];A.hasOwnProperty(h)?window.console&&console.warn("cannot override language handler %s",h):A[h]=a}}function C(a,m){if(!a||!A.hasOwnProperty(a))a=/^\s*=o&&(h+=2);e>=c&&(a+=2)}}catch(w){"console"in window&&console.log(w&&w.stack?w.stack:w)}}var v=["break,continue,do,else,for,if,return,while"],w=[[v,"auto,case,char,const,default,double,enum,extern,float,goto,int,long,register,short,signed,sizeof,static,struct,switch,typedef,union,unsigned,void,volatile"], +"catch,class,delete,false,import,new,operator,private,protected,public,this,throw,true,try,typeof"],F=[w,"alignof,align_union,asm,axiom,bool,concept,concept_map,const_cast,constexpr,decltype,dynamic_cast,explicit,export,friend,inline,late_check,mutable,namespace,nullptr,reinterpret_cast,static_assert,static_cast,template,typeid,typename,using,virtual,where"],G=[w,"abstract,boolean,byte,extends,final,finally,implements,import,instanceof,null,native,package,strictfp,super,synchronized,throws,transient"], +H=[G,"as,base,by,checked,decimal,delegate,descending,dynamic,event,fixed,foreach,from,group,implicit,in,interface,internal,into,is,lock,object,out,override,orderby,params,partial,readonly,ref,sbyte,sealed,stackalloc,string,select,uint,ulong,unchecked,unsafe,ushort,var"],w=[w,"debugger,eval,export,function,get,null,set,undefined,var,with,Infinity,NaN"],I=[v,"and,as,assert,class,def,del,elif,except,exec,finally,from,global,import,in,is,lambda,nonlocal,not,or,pass,print,raise,try,with,yield,False,True,None"], +J=[v,"alias,and,begin,case,class,def,defined,elsif,end,ensure,false,in,module,next,nil,not,or,redo,rescue,retry,self,super,then,true,undef,unless,until,when,yield,BEGIN,END"],v=[v,"case,done,elif,esac,eval,fi,function,in,local,set,then,until"],K=/^(DIR|FILE|vector|(de|priority_)?queue|list|stack|(const_)?iterator|(multi)?(set|map)|bitset|u?(int|float)\d*)/,N=/\S/,O=u({keywords:[F,H,w,"caller,delete,die,do,dump,elsif,eval,exit,foreach,for,goto,if,import,last,local,my,next,no,our,print,package,redo,require,sub,undef,unless,until,use,wantarray,while,BEGIN,END"+ +I,J,v],hashComments:!0,cStyleComments:!0,multiLineStrings:!0,regexLiterals:!0}),A={};k(O,["default-code"]);k(x([],[["pln",/^[^]*(?:>|$)/],["com",/^<\!--[\S\s]*?(?:--\>|$)/],["lang-",/^<\?([\S\s]+?)(?:\?>|$)/],["lang-",/^<%([\S\s]+?)(?:%>|$)/],["pun",/^(?:<[%?]|[%?]>)/],["lang-",/^]*>([\S\s]+?)<\/xmp\b[^>]*>/i],["lang-js",/^]*>([\S\s]*?)(<\/script\b[^>]*>)/i],["lang-css",/^]*>([\S\s]*?)(<\/style\b[^>]*>)/i],["lang-in.tag",/^(<\/?[a-z][^<>]*>)/i]]), +["default-markup","htm","html","mxml","xhtml","xml","xsl"]);k(x([["pln",/^\s+/,q," \t\r\n"],["atv",/^(?:"[^"]*"?|'[^']*'?)/,q,"\"'"]],[["tag",/^^<\/?[a-z](?:[\w-.:]*\w)?|\/?>$/i],["atn",/^(?!style[\s=]|on)[a-z](?:[\w:-]*\w)?/i],["lang-uq.val",/^=\s*([^\s"'>]*(?:[^\s"'/>]|\/(?=\s)))/],["pun",/^[/<->]+/],["lang-js",/^on\w+\s*=\s*"([^"]+)"/i],["lang-js",/^on\w+\s*=\s*'([^']+)'/i],["lang-js",/^on\w+\s*=\s*([^\s"'>]+)/i],["lang-css",/^style\s*=\s*"([^"]+)"/i],["lang-css",/^style\s*=\s*'([^']+)'/i],["lang-css", +/^style\s*=\s*([^\s"'>]+)/i]]),["in.tag"]);k(x([],[["atv",/^[\S\s]+/]]),["uq.val"]);k(u({keywords:F,hashComments:!0,cStyleComments:!0,types:K}),["c","cc","cpp","cxx","cyc","m"]);k(u({keywords:"null,true,false"}),["json"]);k(u({keywords:H,hashComments:!0,cStyleComments:!0,verbatimStrings:!0,types:K}),["cs"]);k(u({keywords:G,cStyleComments:!0}),["java"]);k(u({keywords:v,hashComments:!0,multiLineStrings:!0}),["bsh","csh","sh"]);k(u({keywords:I,hashComments:!0,multiLineStrings:!0,tripleQuotedStrings:!0}), +["cv","py"]);k(u({keywords:"caller,delete,die,do,dump,elsif,eval,exit,foreach,for,goto,if,import,last,local,my,next,no,our,print,package,redo,require,sub,undef,unless,until,use,wantarray,while,BEGIN,END",hashComments:!0,multiLineStrings:!0,regexLiterals:!0}),["perl","pl","pm"]);k(u({keywords:J,hashComments:!0,multiLineStrings:!0,regexLiterals:!0}),["rb"]);k(u({keywords:w,cStyleComments:!0,regexLiterals:!0}),["js"]);k(u({keywords:"all,and,by,catch,class,else,extends,false,finally,for,if,in,is,isnt,loop,new,no,not,null,of,off,on,or,return,super,then,true,try,unless,until,when,while,yes", +hashComments:3,cStyleComments:!0,multilineStrings:!0,tripleQuotedStrings:!0,regexLiterals:!0}),["coffee"]);k(x([],[["str",/^[\S\s]+/]]),["regex"]);window.prettyPrintOne=function(a,m,e){var h=document.createElement("PRE");h.innerHTML=a;e&&D(h,e);E({g:m,i:e,h:h});return h.innerHTML};window.prettyPrint=function(a){function m(){for(var e=window.PR_SHOULD_USE_CONTINUATION?l.now()+250:Infinity;p=0){var k=k.match(g),f,b;if(b= +!k){b=n;for(var o=void 0,c=b.firstChild;c;c=c.nextSibling)var i=c.nodeType,o=i===1?o?b:c:i===3?N.test(c.nodeValue)?b:o:o;b=(f=o===b?void 0:o)&&"CODE"===f.tagName}b&&(k=f.className.match(g));k&&(k=k[1]);b=!1;for(o=n.parentNode;o;o=o.parentNode)if((o.tagName==="pre"||o.tagName==="code"||o.tagName==="xmp")&&o.className&&o.className.indexOf("prettyprint")>=0){b=!0;break}b||((b=(b=n.className.match(/\blinenums\b(?::(\d+))?/))?b[1]&&b[1].length?+b[1]:!0:!1)&&D(n,b),d={g:k,h:n,i:b},E(d))}}p + + + +
    +
    + guzzle +

    Guzzle

    +

    Guzzle is a PHP HTTP client
    & framework for building RESTful web service clients.

    +

    + View Guzzle on GitHub + Read the docs +

    +
    +
    + + + +
    + +

    Introducing Guzzle

    + +

    Guzzle takes the pain out of sending HTTP requests and the redundancy out of creating web service clients. It's + a framework that includes the tools needed to create a robust web service client, including: + Service descriptions for defining the inputs and outputs of an API, resource iterators for traversing + paginated resources, batching for sending a large number of requests as efficiently as possible.

    + +
      +
    • All the power of cURL with a simple interface.
    • +
    • Persistent connections and parallel requests.
    • +
    • Streams request and response bodies
    • +
    • Service descriptions for quickly building clients.
    • +
    • Powered by the Symfony2 EventDispatcher.
    • +
    • Use all of the code or only specific components.
    • +
    • Plugins for caching, logging, OAuth, mocks, and more
    • +
    • Includes a custom node.js webserver to test your clients.
    • +
    + +
    + Guzzle is now part of Drupal 8 core and powers the official AWS SDK for PHP +
    + +

    GitHub Example

    + +
    <?php
    +require_once 'vendor/autoload.php';
    +use Guzzle\Http\Client;
    +
    +// Create a client and provide a base URL
    +$client = new Client('https://api.github.com');
    +// Create a request with basic Auth
    +$request = $client->get('/user')->setAuth('user', 'pass');
    +// Send the request and get the response
    +$response = $request->send();
    +echo $response->getBody();
    +// >>> {"type":"User", ...
    +echo $response->getHeader('Content-Length');
    +// >>> 792
    +
    + +

    Twitter Example

    +
    <?php
    +// Create a client to work with the Twitter API
    +$client = new Client('https://api.twitter.com/{version}', array(
    +    'version' => '1.1'
    +));
    +
    +// Sign all requests with the OauthPlugin
    +$client->addSubscriber(new Guzzle\Plugin\Oauth\OauthPlugin(array(
    +    'consumer_key'  => '***',
    +    'consumer_secret' => '***',
    +    'token'       => '***',
    +    'token_secret'  => '***'
    +)));
    +
    +echo $client->get('statuses/user_timeline.json')->send()->getBody();
    +// >>> {"public_gists":6,"type":"User" ...
    +
    +// Create a tweet using POST
    +$request = $client->post('statuses/update.json', null, array(
    +    'status' => 'Tweeted with Guzzle, http://guzzlephp.org'
    +));
    +
    +// Send the request and parse the JSON response into an array
    +$data = $request->send()->json();
    +echo $data['text'];
    +// >>> Tweeted with Guzzle, http://t.co/kngJMfRk
    +
    +
    + + diff --git a/vendor/guzzle/guzzle/docs/_templates/leftbar.html b/vendor/guzzle/guzzle/docs/_templates/leftbar.html new file mode 100644 index 0000000..e69de29 diff --git a/vendor/guzzle/guzzle/docs/_templates/nav_links.html b/vendor/guzzle/guzzle/docs/_templates/nav_links.html new file mode 100644 index 0000000..d4f2165 --- /dev/null +++ b/vendor/guzzle/guzzle/docs/_templates/nav_links.html @@ -0,0 +1,5 @@ +
  • Docs
  • +
  • API
  • +
  • GitHub
  • +
  • Forum
  • +
  • IRC
  • diff --git a/vendor/guzzle/guzzle/docs/batching/batching.rst b/vendor/guzzle/guzzle/docs/batching/batching.rst new file mode 100644 index 0000000..57f04d8 --- /dev/null +++ b/vendor/guzzle/guzzle/docs/batching/batching.rst @@ -0,0 +1,183 @@ +======== +Batching +======== + +Guzzle provides a fairly generic and very customizable batching framework that allows developers to efficiently +transfer requests in parallel. + +Sending requests and commands in parallel +----------------------------------------- + +You can send HTTP requests in parallel by passing an array of ``Guzzle\Http\Message\RequestInterface`` objects to +``Guzzle\Http\Client::send()``: + +.. code-block:: php + + $responses = $client->send(array( + $client->get('http://www.example.com/foo'), + $client->get('http://www.example.com/baz') + $client->get('http://www.example.com/bar') + )); + +You can send commands in parallel by passing an array of ``Guzzle\Service\Command\CommandInterface`` objects +``Guzzle\Service\Client::execute()``: + +.. code-block:: php + + $commands = $client->execute(array( + $client->getCommand('foo'), + $client->getCommand('baz'), + $client->getCommand('bar') + )); + +These approaches work well for most use-cases. When you need more control over the requests that are sent in +parallel or you need to send a large number of requests, you need to use the functionality provided in the +``Guzzle\Batch`` namespace. + +Batching overview +----------------- + +The batch object, ``Guzzle\Batch\Batch``, is a queue. You add requests to the queue until you are ready to transfer +all of the requests. In order to efficiently transfer the items in the queue, the batch object delegates the +responsibility of dividing the queue into manageable parts to a divisor (``Guzzle\Batch\BatchDivisorInterface``). +The batch object then iterates over each array of items created by the divisor and sends them to the batch object's +``Guzzle\Batch\BatchTransferInterface``. + +.. code-block:: php + + use Guzzle\Batch\Batch; + use Guzzle\Http\BatchRequestTransfer; + + // BatchRequestTransfer acts as both the divisor and transfer strategy + $transferStrategy = new BatchRequestTransfer(10); + $divisorStrategy = $transferStrategy; + + $batch = new Batch($transferStrategy, $divisorStrategy); + + // Add some requests to the batch queue + $batch->add($request1) + ->add($request2) + ->add($request3); + + // Flush the queue and retrieve the flushed items + $arrayOfTransferredRequests = $batch->flush(); + +.. note:: + + You might find that your transfer strategy will need to act as both the divisor and transfer strategy. + +Using the BatchBuilder +---------------------- + +The ``Guzzle\Batch\BatchBuilder`` makes it easier to create batch objects. The batch builder also provides an easier +way to add additional behaviors to your batch object. + +Transferring requests +~~~~~~~~~~~~~~~~~~~~~ + +The ``Guzzle\Http\BatchRequestTransfer`` class efficiently transfers HTTP requests in parallel by grouping batches of +requests by the curl_multi handle that is used to transfer the requests. + +.. code-block:: php + + use Guzzle\Batch\BatchBuilder; + + $batch = BatchBuilder::factory() + ->transferRequests(10) + ->build(); + +Transferring commands +~~~~~~~~~~~~~~~~~~~~~ + +The ``Guzzle\Service\Command\BatchCommandTransfer`` class efficiently transfers service commands by grouping commands +by the client that is used to transfer them. You can add commands to a batch object that are transferred by different +clients, and the batch will handle the rest. + +.. code-block:: php + + use Guzzle\Batch\BatchBuilder; + + $batch = BatchBuilder::factory() + ->transferCommands(10) + ->build(); + + $batch->add($client->getCommand('foo')) + ->add($client->getCommand('baz')) + ->add($client->getCommand('bar')); + + $commands = $batch->flush(); + +Batch behaviors +--------------- + +You can add various behaviors to your batch that allow for more customizable transfers. + +Automatically flushing a queue +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Use the ``Guzzle\Batch\FlushingBatch`` decorator when you want to pump a large number of items into a batch queue and +have the queue automatically flush when the size of the queue reaches a certain threshold. + +.. code-block:: php + + use Guzzle\Batch\BatchBuilder; + + $batch = BatchBuilder::factory() + ->transferRequests(10) + ->autoFlushAt(10) + ->build(); + +Batch builder method: ``autoFlushAt($threshold)`` + +Notifying on flush +~~~~~~~~~~~~~~~~~~ + +Use the ``Guzzle\Batch\NotifyingBatch`` decorator if you want a function to be notified each time the batch queue is +flushed. This is useful when paired with the flushing batch decorator. Pass a callable to the ``notify()`` method of +a batch builder to use this decorator with the builder. + +.. code-block:: php + + use Guzzle\Batch\BatchBuilder; + + $batch = BatchBuilder::factory() + ->transferRequests(10) + ->autoFlushAt(10) + ->notify(function (array $transferredItems) { + echo 'Transferred ' . count($transferredItems) . "items\n"; + }) + ->build(); + +Batch builder method:: ``notify(callable $callback)`` + +Keeping a history +~~~~~~~~~~~~~~~~~ + +Use the ``Guzzle\Batch\HistoryBatch`` decorator if you want to maintain a history of all the items transferred with +the batch queue. + +.. code-block:: php + + use Guzzle\Batch\BatchBuilder; + + $batch = BatchBuilder::factory() + ->transferRequests(10) + ->keepHistory() + ->build(); + +After transferring items, you can use the ``getHistory()`` of a batch to retrieve an array of transferred items. Be +sure to periodically clear the history using ``clearHistory()``. + +Batch builder method: ``keepHistory()`` + +Exception buffering +~~~~~~~~~~~~~~~~~~~ + +Use the ``Guzzle\Batch\ExceptionBufferingBatch`` decorator to buffer exceptions during a transfer so that you can +transfer as many items as possible then deal with the errored batches after the transfer completes. After transfer, +use the ``getExceptions()`` method of a batch to retrieve an array of +``Guzzle\Batch\Exception\BatchTransferException`` objects. You can use these exceptions to attempt to retry the +failed batches. Be sure to clear the buffered exceptions when you are done with them by using the +``clearExceptions()`` method. + +Batch builder method: ``bufferExceptions()`` diff --git a/vendor/guzzle/guzzle/docs/conf.py b/vendor/guzzle/guzzle/docs/conf.py new file mode 100644 index 0000000..92bc46b --- /dev/null +++ b/vendor/guzzle/guzzle/docs/conf.py @@ -0,0 +1,94 @@ +import sys, os +from sphinx.highlighting import lexers +from pygments.lexers.web import PhpLexer + +lexers['php'] = PhpLexer(startinline=True, linenos=1) +lexers['php-annotations'] = PhpLexer(startinline=True, linenos=1) +primary_domain = 'php' + +# -- General configuration ----------------------------------------------------- + +extensions = [] +templates_path = ['_templates'] +source_suffix = '.rst' +master_doc = 'index' + +project = u'Guzzle' +copyright = u'2012, Michael Dowling' +version = '3.0.0' +release = '3.0.0' + +exclude_patterns = ['_build'] + +# -- Options for HTML output --------------------------------------------------- + +# The name for this set of Sphinx documents. If None, it defaults to +# " v documentation". +html_title = "Guzzle documentation" +html_short_title = "Guzzle" + +# Add any paths that contain custom static files (such as style sheets) here, +# relative to this directory. They are copied after the builtin static files, +# so a file named "default.css" will overwrite the builtin "default.css". +html_static_path = ['_static'] + +# Custom sidebar templates, maps document names to template names. +html_sidebars = { + '**': ['localtoc.html', 'leftbar.html', 'searchbox.html'] +} + +# Output file base name for HTML help builder. +htmlhelp_basename = 'Guzzledoc' + +# -- Guzzle Sphinx theme setup ------------------------------------------------ + +sys.path.insert(0, '/Users/dowling/projects/guzzle_sphinx_theme') + +import guzzle_sphinx_theme +html_translator_class = 'guzzle_sphinx_theme.HTMLTranslator' +html_theme_path = guzzle_sphinx_theme.html_theme_path() +html_theme = 'guzzle_sphinx_theme' + +# Guzzle theme options (see theme.conf for more information) +html_theme_options = { + "index_template": "index.html", + "project_nav_name": "Guzzle", + "github_user": "guzzle", + "github_repo": "guzzle", + "disqus_comments_shortname": "guzzle", + "google_analytics_account": "UA-22752917-1" +} + +# -- Options for LaTeX output -------------------------------------------------- + +latex_elements = {} + +# Grouping the document tree into LaTeX files. List of tuples +# (source start file, target name, title, author, documentclass [howto/manual]). +latex_documents = [ + ('index', 'Guzzle.tex', u'Guzzle Documentation', + u'Michael Dowling', 'manual'), +] + +# -- Options for manual page output -------------------------------------------- + +# One entry per manual page. List of tuples +# (source start file, name, description, authors, manual section). +man_pages = [ + ('index', 'guzzle', u'Guzzle Documentation', + [u'Michael Dowling'], 1) +] + +# If true, show URL addresses after external links. +#man_show_urls = False + +# -- Options for Texinfo output ------------------------------------------------ + +# Grouping the document tree into Texinfo files. List of tuples +# (source start file, target name, title, author, +# dir menu entry, description, category) +texinfo_documents = [ + ('index', 'Guzzle', u'Guzzle Documentation', + u'Michael Dowling', 'Guzzle', 'One line description of project.', + 'Miscellaneous'), +] diff --git a/vendor/guzzle/guzzle/docs/docs.rst b/vendor/guzzle/guzzle/docs/docs.rst new file mode 100644 index 0000000..cf87908 --- /dev/null +++ b/vendor/guzzle/guzzle/docs/docs.rst @@ -0,0 +1,73 @@ +.. title:: Guzzle | PHP HTTP client and framework for consuming RESTful web services + +==================== +Guzzle Documentation +==================== + +Getting started +--------------- + +.. toctree:: + :maxdepth: 1 + + getting-started/overview + getting-started/installation + getting-started/faq + +The HTTP client +--------------- + +.. toctree:: + :maxdepth: 2 + + http-client/client + http-client/request + http-client/response + http-client/entity-bodies + http-client/http-redirects + http-client/uri-templates + +Plugins +------- + +.. toctree:: + :maxdepth: 1 + + plugins/plugins-overview + plugins/creating-plugins + plugins/async-plugin + plugins/backoff-plugin + plugins/cache-plugin + plugins/cookie-plugin + plugins/curl-auth-plugin + plugins/history-plugin + plugins/log-plugin + plugins/md5-validator-plugin + plugins/mock-plugin + plugins/oauth-plugin + +The web service client +---------------------- + +.. toctree:: + :maxdepth: 1 + + webservice-client/webservice-client + webservice-client/using-the-service-builder + webservice-client/guzzle-service-descriptions + batching/batching + iterators/resource-iterators + iterators/guzzle-iterators + +Testing +------- + +.. toctree:: + :maxdepth: 2 + + testing/unit-testing + +API Docs +-------- + +`Read the API docs `_ diff --git a/vendor/guzzle/guzzle/docs/getting-started/faq.rst b/vendor/guzzle/guzzle/docs/getting-started/faq.rst new file mode 100644 index 0000000..a0a3fdb --- /dev/null +++ b/vendor/guzzle/guzzle/docs/getting-started/faq.rst @@ -0,0 +1,29 @@ +=== +FAQ +=== + +What should I do if I get this error: Fatal error: Maximum function nesting level of '100' reached, aborting! +------------------------------------------------------------------------------------------------------------- + +You could run into this error if you have the XDebug extension installed and you execute a lot of requests in +callbacks. This error message comes specifically from the XDebug extension. PHP itself does not have a function +nesting limit. Change this setting in your php.ini to increase the limit:: + + xdebug.max_nesting_level = 1000 + +[`source `_] + +How can I speed up my client? +----------------------------- + +There are several things you can do to speed up your client: + +1. Utilize a C based HTTP message parser (e.g. ``Guzzle\Parser\Message\PeclHttpMessageParser``) +2. Disable operation validation by setting the ``command.disable_validation`` option to true on a command + +Why am I getting a 417 error response? +-------------------------------------- + +This can occur for a number of reasons, but if you are sending PUT, POST, or PATCH requests with an +``Expect: 100-Continue`` header, a server that does not support this header will return a 417 response. You can work +around this by calling ``$request->removeHeader('Expect');`` after setting the entity body of a request. diff --git a/vendor/guzzle/guzzle/docs/getting-started/installation.rst b/vendor/guzzle/guzzle/docs/getting-started/installation.rst new file mode 100644 index 0000000..77d4001 --- /dev/null +++ b/vendor/guzzle/guzzle/docs/getting-started/installation.rst @@ -0,0 +1,154 @@ +============ +Installation +============ + +Requirements +------------ + +#. PHP 5.3.3+ compiled with the cURL extension +#. A recent version of cURL 7.16.2+ compiled with OpenSSL and zlib + +Installing Guzzle +----------------- + +Composer +~~~~~~~~ + +The recommended way to install Guzzle is with `Composer `_. Composer is a dependency +management tool for PHP that allows you to declare the dependencies your project needs and installs them into your +project. + +.. code-block:: bash + + # Install Composer + curl -sS https://getcomposer.org/installer | php + + # Add Guzzle as a dependency + php composer.phar require guzzle/guzzle:~3.9 + +After installing, you need to require Composer's autoloader: + +.. code-block:: php + + require 'vendor/autoload.php'; + +You can find out more on how to install Composer, configure autoloading, and other best-practices for defining +dependencies at `getcomposer.org `_. + +Using only specific parts of Guzzle +^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +While you can always just rely on ``guzzle/guzzle``, Guzzle provides several smaller parts of Guzzle as individual +packages available through Composer. + ++-----------------------------------------------------------------------------------------------+------------------------------------------+ +| Package name | Description | ++===============================================================================================+==========================================+ +| `guzzle/common `_ | Provides ``Guzzle\Common`` | ++-----------------------------------------------------------------------------------------------+------------------------------------------+ +| `guzzle/http `_ | Provides ``Guzzle\Http`` | ++-----------------------------------------------------------------------------------------------+------------------------------------------+ +| `guzzle/parser `_ | Provides ``Guzzle\Parser`` | ++-----------------------------------------------------------------------------------------------+------------------------------------------+ +| `guzzle/batch `_ | Provides ``Guzzle\Batch`` | ++-----------------------------------------------------------------------------------------------+------------------------------------------+ +| `guzzle/cache `_ | Provides ``Guzzle\Cache`` | ++-----------------------------------------------------------------------------------------------+------------------------------------------+ +| `guzzle/inflection `_ | Provides ``Guzzle\Inflection`` | ++-----------------------------------------------------------------------------------------------+------------------------------------------+ +| `guzzle/iterator `_ | Provides ``Guzzle\Iterator`` | ++-----------------------------------------------------------------------------------------------+------------------------------------------+ +| `guzzle/log `_ | Provides ``Guzzle\Log`` | ++-----------------------------------------------------------------------------------------------+------------------------------------------+ +| `guzzle/plugin `_ | Provides ``Guzzle\Plugin`` (all plugins) | ++-----------------------------------------------------------------------------------------------+------------------------------------------+ +| `guzzle/plugin-async `_ | Provides ``Guzzle\Plugin\Async`` | ++-----------------------------------------------------------------------------------------------+------------------------------------------+ +| `guzzle/plugin-backoff `_ | Provides ``Guzzle\Plugin\BackoffPlugin`` | ++-----------------------------------------------------------------------------------------------+------------------------------------------+ +| `guzzle/plugin-cache `_ | Provides ``Guzzle\Plugin\Cache`` | ++-----------------------------------------------------------------------------------------------+------------------------------------------+ +| `guzzle/plugin-cookie `_ | Provides ``Guzzle\Plugin\Cookie`` | ++-----------------------------------------------------------------------------------------------+------------------------------------------+ +| `guzzle/plugin-error-response `_ | Provides ``Guzzle\Plugin\ErrorResponse`` | ++-----------------------------------------------------------------------------------------------+------------------------------------------+ +| `guzzle/plugin-history `_ | Provides ``Guzzle\Plugin\History`` | ++-----------------------------------------------------------------------------------------------+------------------------------------------+ +| `guzzle/plugin-log `_ | Provides ``Guzzle\Plugin\Log`` | ++-----------------------------------------------------------------------------------------------+------------------------------------------+ +| `guzzle/plugin-md5 `_ | Provides ``Guzzle\Plugin\Md5`` | ++-----------------------------------------------------------------------------------------------+------------------------------------------+ +| `guzzle/plugin-mock `_ | Provides ``Guzzle\Plugin\Mock`` | ++-----------------------------------------------------------------------------------------------+------------------------------------------+ +| `guzzle/plugin-oauth `_ | Provides ``Guzzle\Plugin\Oauth`` | ++-----------------------------------------------------------------------------------------------+------------------------------------------+ +| `guzzle/service `_ | Provides ``Guzzle\Service`` | ++-----------------------------------------------------------------------------------------------+------------------------------------------+ +| `guzzle/stream `_ | Provides ``Guzzle\Stream`` | ++-----------------------------------------------------------------------------------------------+------------------------------------------+ + +Bleeding edge +^^^^^^^^^^^^^ + +During your development, you can keep up with the latest changes on the master branch by setting the version +requirement for Guzzle to ``dev-master``. + +.. code-block:: js + + { + "require": { + "guzzle/guzzle": "dev-master" + } + } + +PEAR +~~~~ + +Guzzle can be installed through PEAR: + +.. code-block:: bash + + pear channel-discover guzzlephp.org/pear + pear install guzzle/guzzle + +You can install a specific version of Guzzle by providing a version number suffix: + +.. code-block:: bash + + pear install guzzle/guzzle-3.9.0 + +Contributing to Guzzle +---------------------- + +In order to contribute, you'll need to checkout the source from GitHub and install Guzzle's dependencies using +Composer: + +.. code-block:: bash + + git clone https://github.com/guzzle/guzzle.git + cd guzzle && curl -s http://getcomposer.org/installer | php && ./composer.phar install --dev + +Guzzle is unit tested with PHPUnit. You will need to create your own phpunit.xml file in order to run the unit tests +(or just copy phpunit.xml.dist to phpunit.xml). Run the tests using the vendored PHPUnit binary: + +.. code-block:: bash + + vendor/bin/phpunit + +You'll need to install node.js v0.5.0 or newer in order to test the cURL implementation. + +Framework integrations +---------------------- + +Using Guzzle with Symfony +~~~~~~~~~~~~~~~~~~~~~~~~~ + +Bundles are available on GitHub: + +- `DdeboerGuzzleBundle `_ for Guzzle 2 +- `MisdGuzzleBundle `_ for Guzzle 3 + +Using Guzzle with Silex +~~~~~~~~~~~~~~~~~~~~~~~ + +A `Guzzle Silex service provider `_ is available on GitHub. diff --git a/vendor/guzzle/guzzle/docs/getting-started/overview.rst b/vendor/guzzle/guzzle/docs/getting-started/overview.rst new file mode 100644 index 0000000..505b409 --- /dev/null +++ b/vendor/guzzle/guzzle/docs/getting-started/overview.rst @@ -0,0 +1,85 @@ +================= +Welcome to Guzzle +================= + +What is Guzzle? +~~~~~~~~~~~~~~~ + +Guzzle is a PHP HTTP client and framework for building web service clients. Guzzle takes the pain out of sending HTTP +requests and the redundancy out of creating web service clients. + +Features at a glance +-------------------- + +- All the power of cURL with a simple interface. +- Persistent connections and parallel requests. +- Streams request and response bodies +- Service descriptions for quickly building clients. +- Powered by the Symfony2 EventDispatcher. +- Use all of the code or only specific components. +- Plugins for caching, logging, OAuth, mocks, and more +- Includes a custom node.js webserver to test your clients. +- Service descriptions for defining the inputs and outputs of an API +- Resource iterators for traversing paginated resources +- Batching for sending a large number of requests as efficiently as possible + +.. code-block:: php + + // Really simple using a static facade + Guzzle\Http\StaticClient::mount(); + $response = Guzzle::get('http://guzzlephp.org'); + + // More control using a client class + $client = new \Guzzle\Http\Client('http://guzzlephp.org'); + $request = $client->get('/'); + $response = $request->send(); + +License +------- + +Licensed using the `MIT license `_. + + Copyright (c) 2013 Michael Dowling + + 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. + +Contributing +------------ + +Guidelines +~~~~~~~~~~ + +This is still a work in progress, but there are only a few rules: + +1. Guzzle follows PSR-0, PSR-1, and PSR-2 +2. All pull requests must include unit tests to ensure the change works as expected and to prevent future regressions + +Reporting a security vulnerability +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +We want to ensure that Guzzle is a secure HTTP client library for everyone. If you've discovered a security +vulnerability in Guzzle, we appreciate your help in disclosing it to us in a +`responsible manner `_. + +Publicly disclosing a vulnerability can put the entire community at risk. If you've discovered a security concern, +please email us at security@guzzlephp.org. We'll work with you to make sure that we understand the scope of the issue, +and that we fully address your concern. We consider correspondence sent to security@guzzlephp.org our highest priority, +and work to address any issues that arise as quickly as possible. + +After a security vulnerability has been corrected, a security hotfix release will be deployed as soon as possible. diff --git a/vendor/guzzle/guzzle/docs/http-client/client.rst b/vendor/guzzle/guzzle/docs/http-client/client.rst new file mode 100644 index 0000000..723d729 --- /dev/null +++ b/vendor/guzzle/guzzle/docs/http-client/client.rst @@ -0,0 +1,569 @@ +====================== +The Guzzle HTTP client +====================== + +Guzzle gives PHP developers complete control over HTTP requests while utilizing HTTP/1.1 best practices. Guzzle's HTTP +functionality is a robust framework built on top of the `PHP libcurl bindings `_. + +The three main parts of the Guzzle HTTP client are: + ++--------------+-------------------------------------------------------------------------------------------------------+ +| Clients | ``Guzzle\Http\Client`` (creates and sends requests, associates a response with a request) | ++--------------+-------------------------------------------------------------------------------------------------------+ +| Requests | ``Guzzle\Http\Message\Request`` (requests with no body), | +| | ``Guzzle\Http\Message\EntityEnclosingRequest`` (requests with a body) | ++--------------+-------------------------------------------------------------------------------------------------------+ +| Responses | ``Guzzle\Http\Message\Response`` | ++--------------+-------------------------------------------------------------------------------------------------------+ + +Creating a Client +----------------- + +Clients create requests, send requests, and set responses on a request object. When instantiating a client object, +you can pass an optional "base URL" and optional array of configuration options. A base URL is a +:doc:`URI template ` that contains the URL of a remote server. When creating requests with a relative +URL, the base URL of a client will be merged into the request's URL. + +.. code-block:: php + + use Guzzle\Http\Client; + + // Create a client and provide a base URL + $client = new Client('https://api.github.com'); + + $request = $client->get('/user'); + $request->setAuth('user', 'pass'); + echo $request->getUrl(); + // >>> https://api.github.com/user + + // You must send a request in order for the transfer to occur + $response = $request->send(); + + echo $response->getBody(); + // >>> {"type":"User", ... + + echo $response->getHeader('Content-Length'); + // >>> 792 + + $data = $response->json(); + echo $data['type']; + // >>> User + +Base URLs +~~~~~~~~~ + +Notice that the URL provided to the client's ``get()`` method is relative. Relative URLs will always merge into the +base URL of the client. There are a few rules that control how the URLs are merged. + +.. tip:: + + Guzzle follows `RFC 3986 `_ when merging base URLs and + relative URLs. + +In the above example, we passed ``/user`` to the ``get()`` method of the client. This is a relative URL, so it will +merge into the base URL of the client-- resulting in the derived URL of ``https://api.github.com/users``. + +``/user`` is a relative URL but uses an absolute path because it contains the leading slash. Absolute paths will +overwrite any existing path of the base URL. If an absolute path is provided (e.g. ``/path/to/something``), then the +path specified in the base URL of the client will be replaced with the absolute path, and the query string provided +by the relative URL will replace the query string of the base URL. + +Omitting the leading slash and using relative paths will add to the path of the base URL of the client. So using a +client base URL of ``https://api.twitter.com/v1.1`` and creating a GET request with ``statuses/user_timeline.json`` +will result in a URL of ``https://api.twitter.com/v1.1/statuses/user_timeline.json``. If a relative path and a query +string are provided, then the relative path will be appended to the base URL path, and the query string provided will +be merged into the query string of the base URL. + +If an absolute URL is provided (e.g. ``http://httpbin.org/ip``), then the request will completely use the absolute URL +as-is without merging in any of the URL parts specified in the base URL. + +Configuration options +~~~~~~~~~~~~~~~~~~~~~ + +The second argument of the client's constructor is an array of configuration data. This can include URI template data +or special options that alter the client's behavior: + ++-------------------------------+-------------------------------------------------------------------------------------+ +| ``request.options`` | Associative array of :ref:`Request options ` to apply to every | +| | request created by the client. | ++-------------------------------+-------------------------------------------------------------------------------------+ +| ``redirect.disable`` | Disable HTTP redirects for every request created by the client. | ++-------------------------------+-------------------------------------------------------------------------------------+ +| ``curl.options`` | Associative array of cURL options to apply to every request created by the client. | +| | if either the key or value of an entry in the array is a string, Guzzle will | +| | attempt to find a matching defined cURL constant automatically (e.g. | +| | "CURLOPT_PROXY" will be converted to the constant ``CURLOPT_PROXY``). | ++-------------------------------+-------------------------------------------------------------------------------------+ +| ``ssl.certificate_authority`` | Set to true to use the Guzzle bundled SSL certificate bundle (this is used by | +| | default, 'system' to use the bundle on your system, a string pointing to a file to | +| | use a specific certificate file, a string pointing to a directory to use multiple | +| | certificates, or ``false`` to disable SSL validation (not recommended). | +| | | +| | When using Guzzle inside of a phar file, the bundled SSL certificate will be | +| | extracted to your system's temp folder, and each time a client is created an MD5 | +| | check will be performed to ensure the integrity of the certificate. | ++-------------------------------+-------------------------------------------------------------------------------------+ +| ``command.params`` | When using a ``Guzzle\Service\Client`` object, this is an associative array of | +| | default options to set on each command created by the client. | ++-------------------------------+-------------------------------------------------------------------------------------+ + +Here's an example showing how to set various configuration options, including default headers to send with each request, +default query string parameters to add to each request, a default auth scheme for each request, and a proxy to use for +each request. Values can be injected into the client's base URL using variables from the configuration array. + +.. code-block:: php + + use Guzzle\Http\Client; + + $client = new Client('https://api.twitter.com/{version}', array( + 'version' => 'v1.1', + 'request.options' => array( + 'headers' => array('Foo' => 'Bar'), + 'query' => array('testing' => '123'), + 'auth' => array('username', 'password', 'Basic|Digest|NTLM|Any'), + 'proxy' => 'tcp://localhost:80' + ) + )); + +Setting a custom User-Agent +~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +The default Guzzle User-Agent header is ``Guzzle/ curl/ PHP/``. You can +customize the User-Agent header of a client by calling the ``setUserAgent()`` method of a Client object. + +.. code-block:: php + + // Completely override the default User-Agent + $client->setUserAgent('Test/123'); + + // Prepend a string to the default User-Agent + $client->setUserAgent('Test/123', true); + +Creating requests with a client +------------------------------- + +A Client object exposes several methods used to create Request objects: + +* Create a custom HTTP request: ``$client->createRequest($method, $uri, array $headers, $body, $options)`` +* Create a GET request: ``$client->get($uri, array $headers, $options)`` +* Create a HEAD request: ``$client->head($uri, array $headers, $options)`` +* Create a DELETE request: ``$client->delete($uri, array $headers, $body, $options)`` +* Create a POST request: ``$client->post($uri, array $headers, $postBody, $options)`` +* Create a PUT request: ``$client->put($uri, array $headers, $body, $options)`` +* Create a PATCH request: ``$client->patch($uri, array $headers, $body, $options)`` + +.. code-block:: php + + use Guzzle\Http\Client; + + $client = new Client('http://baseurl.com/api/v1'); + + // Create a GET request using Relative to base URL + // URL of the request: http://baseurl.com/api/v1/path?query=123&value=abc) + $request = $client->get('path?query=123&value=abc'); + $response = $request->send(); + + // Create HEAD request using a relative URL with an absolute path + // URL of the request: http://baseurl.com/path?query=123&value=abc + $request = $client->head('/path?query=123&value=abc'); + $response = $request->send(); + + // Create a DELETE request using an absolute URL + $request = $client->delete('http://www.example.com/path?query=123&value=abc'); + $response = $request->send(); + + // Create a PUT request using the contents of a PHP stream as the body + // Specify custom HTTP headers + $request = $client->put('http://www.example.com/upload', array( + 'X-Header' => 'My Header' + ), fopen('http://www.test.com/', 'r')); + $response = $request->send(); + + // Create a POST request and add the POST files manually + $request = $client->post('http://localhost:8983/solr/update') + ->addPostFiles(array('file' => '/path/to/documents.xml')); + $response = $request->send(); + + // Check if a resource supports the DELETE method + $supportsDelete = $client->options('/path')->send()->isMethodAllowed('DELETE'); + $response = $request->send(); + +Client objects create Request objects using a request factory (``Guzzle\Http\Message\RequestFactoryInterface``). +You can inject a custom request factory into the Client using ``$client->setRequestFactory()``, but you can typically +rely on a Client's default request factory. + +Static clients +-------------- + +You can use Guzzle's static client facade to more easily send simple HTTP requests. + +.. code-block:: php + + // Mount the client so that you can access it at \Guzzle + Guzzle\Http\StaticClient::mount(); + $response = Guzzle::get('http://guzzlephp.org'); + +Each request method of the static client (e.g. ``get()``, ``post()`, ``put()``, etc) accepts an associative array of request +options to apply to the request. + +.. code-block:: php + + $response = Guzzle::post('http://test.com', array( + 'headers' => array('X-Foo' => 'Bar'), + 'body' => array('Test' => '123'), + 'timeout' => 10 + )); + +.. _request-options: + +Request options +--------------- + +Request options can be specified when creating a request or in the ``request.options`` parameter of a client. These +options can control various aspects of a request including: headers to send, query string data, where the response +should be downloaded, proxies, auth, etc. + +headers +~~~~~~~ + +Associative array of headers to apply to the request. When specified in the ``$options`` argument of a client creational +method (e.g. ``get()``, ``post()``, etc), the headers in the ``$options`` array will overwrite headers specified in the +``$headers`` array. + +.. code-block:: php + + $request = $client->get($url, array(), array( + 'headers' => array('X-Foo' => 'Bar') + )); + +Headers can be specified on a client to add default headers to every request sent by a client. + +.. code-block:: php + + $client = new Guzzle\Http\Client(); + + // Set a single header using path syntax + $client->setDefaultOption('headers/X-Foo', 'Bar'); + + // Set all headers + $client->setDefaultOption('headers', array('X-Foo' => 'Bar')); + +.. note:: + + In addition to setting request options when creating requests or using the ``setDefaultOption()`` method, any + default client request option can be set using a client's config object: + + .. code-block:: php + + $client->getConfig()->setPath('request.options/headers/X-Foo', 'Bar'); + +query +~~~~~ + +Associative array of query string parameters to the request. When specified in the ``$options`` argument of a client +creational method, the query string parameters in the ``$options`` array will overwrite query string parameters +specified in the `$url`. + +.. code-block:: php + + $request = $client->get($url, array(), array( + 'query' => array('abc' => '123') + )); + +Query string parameters can be specified on a client to add default query string parameters to every request sent by a +client. + +.. code-block:: php + + $client = new Guzzle\Http\Client(); + + // Set a single query string parameter using path syntax + $client->setDefaultOption('query/abc', '123'); + + // Set an array of default query string parameters + $client->setDefaultOption('query', array('abc' => '123')); + +body +~~~~ + +Sets the body of a request. The value supplied to the body option can be a ``Guzzle\Http\EntityBodyInterface``, string, +fopen resource, or array when sending POST requests. When a ``body`` request option is supplied, the option value will +overwrite the ``$body`` argument of a client creational method. + +auth +~~~~ + +Specifies and array of HTTP authorization parameters parameters to use with the request. The array must contain the +username in index [0], the password in index [1], and can optionally contain the authentication type in index [2]. +The available authentication types are: "Basic" (default), "Digest", "NTLM", or "Any". + +.. code-block:: php + + $request = $client->get($url, array(), array( + 'auth' => array('username', 'password', 'Digest') + )); + + // You can add auth headers to every request of a client + $client->setDefaultOption('auth', array('username', 'password', 'Digest')); + +cookies +~~~~~~~ + +Specifies an associative array of cookies to add to the request. + +allow_redirects +~~~~~~~~~~~~~~~ + +Specifies whether or not the request should follow redirects. Requests will follow redirects by default. Set +``allow_redirects`` to ``false`` to disable redirects. + +save_to +~~~~~~~ + +The ``save_to`` option specifies where the body of a response is downloaded. You can pass the path to a file, an fopen +resource, or a ``Guzzle\Http\EntityBodyInterface`` object. + +See :ref:`Changing where a response is downloaded ` for more information on setting the +`save_to` option. + +events +~~~~~~ + +The `events` option makes it easy to attach listeners to the various events emitted by a request object. The `events` +options must be an associative array mapping an event name to a Closure or array the contains a Closure and the +priority of the event. + +.. code-block:: php + + $request = $client->get($url, array(), array( + 'events' => array( + 'request.before_send' => function (\Guzzle\Common\Event $e) { + echo 'About to send ' . $e['request']; + } + ) + )); + + // Using the static client: + Guzzle::get($url, array( + 'events' => array( + 'request.before_send' => function (\Guzzle\Common\Event $e) { + echo 'About to send ' . $e['request']; + } + ) + )); + +plugins +~~~~~~~ + +The `plugins` options makes it easy to attach an array of plugins to a request. + +.. code-block:: php + + // Using the static client: + Guzzle::get($url, array( + 'plugins' => array( + new Guzzle\Plugin\Cache\CachePlugin(), + new Guzzle\Plugin\Cookie\CookiePlugin() + ) + )); + +exceptions +~~~~~~~~~~ + +The `exceptions` option can be used to disable throwing exceptions for unsuccessful HTTP response codes +(e.g. 404, 500, etc). Set `exceptions` to false to not throw exceptions. + +params +~~~~~~ + +The `params` options can be used to specify an associative array of data parameters to add to a request. Note that +these are not query string parameters. + +timeout / connect_timeout +~~~~~~~~~~~~~~~~~~~~~~~~~ + +You can specify the maximum number of seconds to allow for an entire transfer to take place before timing out using +the `timeout` request option. You can specify the maximum number of seconds to wait while trying to connect using the +`connect_timeout` request option. Set either of these options to 0 to wait indefinitely. + +.. code-block:: php + + $request = $client->get('http://www.example.com', array(), array( + 'timeout' => 20, + 'connect_timeout' => 1.5 + )); + +verify +~~~~~~ + +Set to true to enable SSL certificate validation (the default), false to disable SSL certificate validation, or supply +the path to a CA bundle to enable verification using a custom certificate. + +cert +~~~~ + +The `cert` option lets you specify a PEM formatted SSL client certificate to use with servers that require one. If the +certificate requires a password, provide an array with the password as the second item. + +This would typically be used in conjunction with the `ssl_key` option. + +.. code-block:: php + + $request = $client->get('https://www.example.com', array(), array( + 'cert' => '/etc/pki/client_certificate.pem' + ) + + $request = $client->get('https://www.example.com', array(), array( + 'cert' => array('/etc/pki/client_certificate.pem', 's3cr3tp455w0rd') + ) + +ssl_key +~~~~~~~ + +The `ssl_key` option lets you specify a file containing your PEM formatted private key, optionally protected by a password. +Note: your password is sensitive, keep the PHP script containing it safe. + +This would typically be used in conjunction with the `cert` option. + +.. code-block:: php + + $request = $client->get('https://www.example.com', array(), array( + 'ssl_key' => '/etc/pki/private_key.pem' + ) + + $request = $client->get('https://www.example.com', array(), array( + 'ssl_key' => array('/etc/pki/private_key.pem', 's3cr3tp455w0rd') + ) + +proxy +~~~~~ + +The `proxy` option is used to specify an HTTP proxy (e.g. `http://username:password@192.168.16.1:10`). + +debug +~~~~~ + +The `debug` option is used to show verbose cURL output for a transfer. + +stream +~~~~~~ + +When using a static client, you can set the `stream` option to true to return a `Guzzle\Stream\Stream` object that can +be used to pull data from a stream as needed (rather than have cURL download the entire contents of a response to a +stream all at once). + +.. code-block:: php + + $stream = Guzzle::get('http://guzzlephp.org', array('stream' => true)); + while (!$stream->feof()) { + echo $stream->readLine(); + } + +Sending requests +---------------- + +Requests can be sent by calling the ``send()`` method of a Request object, but you can also send requests using the +``send()`` method of a Client. + +.. code-block:: php + + $request = $client->get('http://www.amazon.com'); + $response = $client->send($request); + +Sending requests in parallel +~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +The Client's ``send()`` method accept a single ``Guzzle\Http\Message\RequestInterface`` object or an array of +RequestInterface objects. When an array is specified, the requests will be sent in parallel. + +Sending many HTTP requests serially (one at a time) can cause an unnecessary delay in a script's execution. Each +request must complete before a subsequent request can be sent. By sending requests in parallel, a pool of HTTP +requests can complete at the speed of the slowest request in the pool, significantly reducing the amount of time +needed to execute multiple HTTP requests. Guzzle provides a wrapper for the curl_multi functions in PHP. + +Here's an example of sending three requests in parallel using a client object: + +.. code-block:: php + + use Guzzle\Common\Exception\MultiTransferException; + + try { + $responses = $client->send(array( + $client->get('http://www.google.com/'), + $client->head('http://www.google.com/'), + $client->get('https://www.github.com/') + )); + } catch (MultiTransferException $e) { + + echo "The following exceptions were encountered:\n"; + foreach ($e as $exception) { + echo $exception->getMessage() . "\n"; + } + + echo "The following requests failed:\n"; + foreach ($e->getFailedRequests() as $request) { + echo $request . "\n\n"; + } + + echo "The following requests succeeded:\n"; + foreach ($e->getSuccessfulRequests() as $request) { + echo $request . "\n\n"; + } + } + +If the requests succeed, an array of ``Guzzle\Http\Message\Response`` objects are returned. A single request failure +will not cause the entire pool of requests to fail. Any exceptions thrown while transferring a pool of requests will +be aggregated into a ``Guzzle\Common\Exception\MultiTransferException`` exception. + +Plugins and events +------------------ + +Guzzle provides easy to use request plugins that add behavior to requests based on signal slot event notifications +powered by the +`Symfony2 Event Dispatcher component `_. Any +event listener or subscriber attached to a Client object will automatically be attached to each request created by the +client. + +Using the same cookie session for each request +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Attach a ``Guzzle\Plugin\Cookie\CookiePlugin`` to a client which will in turn add support for cookies to every request +created by a client, and each request will use the same cookie session: + +.. code-block:: php + + use Guzzle\Plugin\Cookie\CookiePlugin; + use Guzzle\Plugin\Cookie\CookieJar\ArrayCookieJar; + + // Create a new cookie plugin + $cookiePlugin = new CookiePlugin(new ArrayCookieJar()); + + // Add the cookie plugin to the client + $client->addSubscriber($cookiePlugin); + +.. _client-events: + +Events emitted from a client +~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +A ``Guzzle\Http\Client`` object emits the following events: + ++------------------------------+--------------------------------------------+------------------------------------------+ +| Event name | Description | Event data | ++==============================+============================================+==========================================+ +| client.create_request | Called when a client creates a request | * client: The client | +| | | * request: The created request | ++------------------------------+--------------------------------------------+------------------------------------------+ + +.. code-block:: php + + use Guzzle\Common\Event; + use Guzzle\Http\Client; + + $client = new Client(); + + // Add a listener that will echo out requests as they are created + $client->getEventDispatcher()->addListener('client.create_request', function (Event $e) { + echo 'Client object: ' . spl_object_hash($e['client']) . "\n"; + echo "Request object: {$e['request']}\n"; + }); diff --git a/vendor/guzzle/guzzle/docs/http-client/entity-bodies.rst b/vendor/guzzle/guzzle/docs/http-client/entity-bodies.rst new file mode 100644 index 0000000..823b0c0 --- /dev/null +++ b/vendor/guzzle/guzzle/docs/http-client/entity-bodies.rst @@ -0,0 +1,151 @@ +=========================== +Request and response bodies +=========================== + +`Entity body `_ is the term used for the body of an HTTP +message. The entity body of requests and responses is inherently a +`PHP stream `_ in Guzzle. The body of the request can be either a string or +a PHP stream which are converted into a ``Guzzle\Http\EntityBody`` object using its factory method. When using a +string, the entity body is stored in a `temp PHP stream `_. The use of +temp PHP streams helps to protect your application from running out of memory when sending or receiving large entity +bodies in your messages. When more than 2MB of data is stored in a temp stream, it automatically stores the data on +disk rather than in memory. + +EntityBody objects provide a great deal of functionality: compression, decompression, calculate the Content-MD5, +calculate the Content-Length (when the resource is repeatable), guessing the Content-Type, and more. Guzzle doesn't +need to load an entire entity body into a string when sending or retrieving data; entity bodies are streamed when +being uploaded and downloaded. + +Here's an example of gzip compressing a text file then sending the file to a URL: + +.. code-block:: php + + use Guzzle\Http\EntityBody; + + $body = EntityBody::factory(fopen('/path/to/file.txt', 'r+')); + echo $body->read(1024); + $body->seek(0, SEEK_END); + $body->write('foo'); + echo $body->ftell(); + $body->rewind(); + + // Send a request using the body + $response = $client->put('http://localhost:8080/uploads', null, $body)->send(); + +The body of the request can be specified in the ``Client::put()`` or ``Client::post()`` method, or, you can specify +the body of the request by calling the ``setBody()`` method of any +``Guzzle\Http\Message\EntityEnclosingRequestInterface`` object. + +Compression +----------- + +You can compress the contents of an EntityBody object using the ``compress()`` method. The compress method accepts a +filter that must match to one of the supported +`PHP stream filters `_ on your system (e.g. `zlib.deflate`, +``bzip2.compress``, etc). Compressing an entity body will stream the entire entity body through a stream compression +filter into a temporary PHP stream. You can uncompress an entity body using the ``uncompress()`` method and passing +the PHP stream filter to use when decompressing the stream (e.g. ``zlib.inflate``). + +.. code-block:: php + + use Guzzle\Http\EntityBody; + + $body = EntityBody::factory(fopen('/tmp/test.txt', 'r+')); + echo $body->getSize(); + // >>> 1048576 + + // Compress using the default zlib.deflate filter + $body->compress(); + echo $body->getSize(); + // >>> 314572 + + // Decompress the stream + $body->uncompress(); + echo $body->getSize(); + // >>> 1048576 + +Decorators +---------- + +Guzzle provides several EntityBody decorators that can be used to add functionality to an EntityBody at runtime. + +IoEmittingEntityBody +~~~~~~~~~~~~~~~~~~~~ + +This decorator will emit events when data is read from a stream or written to a stream. Add an event subscriber to the +entity body's ``body.read`` or ``body.write`` methods to receive notifications when data data is transferred. + +.. code-block:: php + + use Guzzle\Common\Event; + use Guzzle\Http\EntityBody; + use Guzzle\Http\IoEmittingEntityBody; + + $original = EntityBody::factory(fopen('/tmp/test.txt', 'r+')); + $body = new IoEmittingEntityBody($original); + + // Listen for read events + $body->getEventDispatcher()->addListener('body.read', function (Event $e) { + // Grab data from the event + $entityBody = $e['body']; + // Amount of data retrieved from the body + $lengthOfData = $e['length']; + // The actual data that was read + $data = $e['read']; + }); + + // Listen for write events + $body->getEventDispatcher()->addListener('body.write', function (Event $e) { + // Grab data from the event + $entityBody = $e['body']; + // The data that was written + $data = $e['write']; + // The actual amount of data that was written + $data = $e['read']; + }); + +ReadLimitEntityBody +~~~~~~~~~~~~~~~~~~~ + +The ReadLimitEntityBody decorator can be used to transfer a subset or slice of an existing EntityBody object. This can +be useful for breaking a large file into smaller pieces to be sent in chunks (e.g. Amazon S3's multipart upload API). + +.. code-block:: php + + use Guzzle\Http\EntityBody; + use Guzzle\Http\ReadLimitEntityBody; + + $original = EntityBody::factory(fopen('/tmp/test.txt', 'r+')); + echo $original->getSize(); + // >>> 1048576 + + // Limit the size of the body to 1024 bytes and start reading from byte 2048 + $body = new ReadLimitEntityBody($original, 1024, 2048); + echo $body->getSize(); + // >>> 1024 + echo $body->ftell(); + // >>> 0 + +CachingEntityBody +~~~~~~~~~~~~~~~~~ + +The CachingEntityBody decorator is used to allow seeking over previously read bytes on non-seekable read streams. This +can be useful when transferring a non-seekable entity body fails due to needing to rewind the stream (for example, +resulting from a redirect). Data that is read from the remote stream will be buffered in a PHP temp stream so that +previously read bytes are cached first in memory, then on disk. + +.. code-block:: php + + use Guzzle\Http\EntityBody; + use Guzzle\Http\CachingEntityBody; + + $original = EntityBody::factory(fopen('http://www.google.com', 'r')); + $body = new CachingEntityBody($original); + + $body->read(1024); + echo $body->ftell(); + // >>> 1024 + + $body->seek(0); + echo $body->ftell(); + // >>> 0 diff --git a/vendor/guzzle/guzzle/docs/http-client/http-redirects.rst b/vendor/guzzle/guzzle/docs/http-client/http-redirects.rst new file mode 100644 index 0000000..32ba268 --- /dev/null +++ b/vendor/guzzle/guzzle/docs/http-client/http-redirects.rst @@ -0,0 +1,99 @@ +============== +HTTP redirects +============== + +By default, Guzzle will automatically follow redirects using the non-RFC compliant implementation used by most web +browsers. This means that redirects for POST requests are followed by a GET request. You can force RFC compliance by +enabling the strict mode on a request's parameter object: + +.. code-block:: php + + // Set per request + $request = $client->post(); + $request->getParams()->set('redirect.strict', true); + + // You can set globally on a client so all requests use strict redirects + $client->getConfig()->set('request.params', array( + 'redirect.strict' => true + )); + +By default, Guzzle will redirect up to 5 times before throwing a ``Guzzle\Http\Exception\TooManyRedirectsException``. +You can raise or lower this value using the ``redirect.max`` parameter of a request object: + +.. code-block:: php + + $request->getParams()->set('redirect.max', 2); + +Redirect history +---------------- + +You can get the number of redirects of a request using the resulting response object's ``getRedirectCount()`` method. +Similar to cURL's ``effective_url`` property, Guzzle provides the effective URL, or the last redirect URL that returned +the request, in a response's ``getEffectiveUrl()`` method. + +When testing or debugging, it is often useful to see a history of redirects for a particular request. This can be +achieved using the HistoryPlugin. + +.. code-block:: php + + $request = $client->get('/'); + $history = new Guzzle\Plugin\History\HistoryPlugin(); + $request->addSubscriber($history); + $response = $request->send(); + + // Get the last redirect URL or the URL of the request that received + // this response + echo $response->getEffectiveUrl(); + + // Get the number of redirects + echo $response->getRedirectCount(); + + // Iterate over each sent request and response + foreach ($history->getAll() as $transaction) { + // Request object + echo $transaction['request']->getUrl() . "\n"; + // Response object + echo $transaction['response']->getEffectiveUrl() . "\n"; + } + + // Or, simply cast the HistoryPlugin to a string to view each request and response + echo $history; + +Disabling redirects +------------------- + +You can disable redirects on a client by passing a configuration option in the client's constructor: + +.. code-block:: php + + $client = new Client(null, array('redirect.disable' => true)); + +You can also disable redirects per request: + +.. code-block:: php + + $request = $client->get($url, array(), array('allow_redirects' => false)); + +Redirects and non-repeatable streams +------------------------------------ + +If you are redirected when sending data from a non-repeatable stream and some of the data has been read off of the +stream, then you will get a ``Guzzle\Http\Exception\CouldNotRewindStreamException``. You can get around this error by +adding a custom rewind method to the entity body object being sent in the request. + +.. code-block:: php + + $request = $client->post( + 'http://httpbin.com/redirect/2', + null, + fopen('http://httpbin.com/get', 'r') + ); + + // Add a custom function that can be used to rewind the stream + // (reopen in this example) + $request->getBody()->setRewindFunction(function ($body) { + $body->setStream(fopen('http://httpbin.com/get', 'r')); + return true; + ); + + $response = $client->send(); diff --git a/vendor/guzzle/guzzle/docs/http-client/request.rst b/vendor/guzzle/guzzle/docs/http-client/request.rst new file mode 100644 index 0000000..a8387a9 --- /dev/null +++ b/vendor/guzzle/guzzle/docs/http-client/request.rst @@ -0,0 +1,667 @@ +===================== +Using Request objects +===================== + +HTTP request messages +--------------------- + +Request objects are all about building an HTTP message. Each part of an HTTP request message can be set individually +using methods on the request object or set in bulk using the ``setUrl()`` method. Here's the format of an HTTP request +with each part of the request referencing the method used to change it:: + + PUT(a) /path(b)?query=123(c) HTTP/1.1(d) + X-Header(e): header + Content-Length(e): 4 + + data(f) + ++-------------------------+---------------------------------------------------------------------------------+ +| a. **Method** | The request method can only be set when instantiating a request | ++-------------------------+---------------------------------------------------------------------------------+ +| b. **Path** | ``$request->setPath('/path');`` | ++-------------------------+---------------------------------------------------------------------------------+ +| c. **Query** | ``$request->getQuery()->set('query', '123');`` | ++-------------------------+---------------------------------------------------------------------------------+ +| d. **Protocol version** | ``$request->setProtocolVersion('1.1');`` | ++-------------------------+---------------------------------------------------------------------------------+ +| e. **Header** | ``$request->setHeader('X-Header', 'header');`` | ++-------------------------+---------------------------------------------------------------------------------+ +| f. **Entity Body** | ``$request->setBody('data'); // Only available with PUT, POST, PATCH, DELETE`` | ++-------------------------+---------------------------------------------------------------------------------+ + +Creating requests with a client +------------------------------- + +Client objects are responsible for creating HTTP request objects. + +GET requests +~~~~~~~~~~~~ + +`GET requests `_ are the most common form of HTTP +requests. When you visit a website in your browser, the HTML of the website is downloaded using a GET request. GET +requests are idempotent requests that are typically used to download content (an entity) identified by a request URL. + +.. code-block:: php + + use Guzzle\Http\Client; + + $client = new Client(); + + // Create a request that has a query string and an X-Foo header + $request = $client->get('http://www.amazon.com?a=1', array('X-Foo' => 'Bar')); + + // Send the request and get the response + $response = $request->send(); + +You can change where the body of a response is downloaded on any request using the +``$request->setResponseBody(string|EntityBodyInterface|resource)`` method of a request. You can also set the ``save_to`` +option of a request: + +.. code-block:: php + + // Send the response body to a file + $request = $client->get('http://test.com', array(), array('save_to' => '/path/to/file')); + + // Send the response body to an fopen resource + $request = $client->get('http://test.com', array(), array('save_to' => fopen('/path/to/file', 'w'))); + +HEAD requests +~~~~~~~~~~~~~ + +`HEAD requests `_ work exactly like GET requests except +that they do not actually download the response body (entity) of the response message. HEAD requests are useful for +retrieving meta information about an entity identified by a Request-URI. + +.. code-block:: php + + $client = new Guzzle\Http\Client(); + $request = $client->head('http://www.amazon.com'); + $response = $request->send(); + echo $response->getContentLength(); + // >>> Will output the Content-Length header value + +DELETE requests +~~~~~~~~~~~~~~~ + +A `DELETE method `_ requests that the origin server +delete the resource identified by the Request-URI. + +.. code-block:: php + + $client = new Guzzle\Http\Client(); + $request = $client->delete('http://example.com'); + $response = $request->send(); + +POST requests +~~~~~~~~~~~~~ + +While `POST requests `_ can be used for a number of +reasons, POST requests are often used when submitting HTML form data to a website. POST requests can include an entity +body in the HTTP request. + +POST requests in Guzzle are sent with an ``application/x-www-form-urlencoded`` Content-Type header if POST fields are +present but no files are being sent in the POST. If files are specified in the POST request, then the Content-Type +header will become ``multipart/form-data``. + +The ``post()`` method of a client object accepts four arguments: the URL, optional headers, post fields, and an array of +request options. To send files in the POST request, prepend the ``@`` symbol to the array value (just like you would if +you were using the PHP ``curl_setopt`` function). + +Here's how to create a multipart/form-data POST request containing files and fields: + +.. code-block:: php + + $request = $client->post('http://httpbin.org/post', array(), array( + 'custom_field' => 'my custom value', + 'file_field' => '@/path/to/file.xml' + )); + + $response = $request->send(); + +.. note:: + + Remember to **always** sanitize user input when sending POST requests: + + .. code-block:: php + + // Prevent users from accessing sensitive files by sanitizing input + $_POST = array('firstname' => '@/etc/passwd'); + $request = $client->post('http://www.example.com', array(), array ( + 'firstname' => str_replace('@', '', $_POST['firstname']) + )); + +You can alternatively build up the contents of a POST request. + +.. code-block:: php + + $request = $client->post('http://httpbin.org/post') + ->setPostField('custom_field', 'my custom value') + ->addPostFile('file', '/path/to/file.xml'); + + $response = $request->send(); + +Raw POST data +^^^^^^^^^^^^^ + +POST requests can also contain raw POST data that is not related to HTML forms. + +.. code-block:: php + + $request = $client->post('http://httpbin.org/post', array(), 'this is the body'); + $response = $request->send(); + +You can set the body of POST request using the ``setBody()`` method of the +``Guzzle\Http\Message\EntityEnclosingRequest`` object. This method accepts a string, a resource returned from +``fopen``, or a ``Guzzle\Http\EntityBodyInterface`` object. + +.. code-block:: php + + $request = $client->post('http://httpbin.org/post'); + // Set the body of the POST to stream the contents of /path/to/large_body.txt + $request->setBody(fopen('/path/to/large_body.txt', 'r')); + $response = $request->send(); + +PUT requests +~~~~~~~~~~~~ + +The `PUT method `_ requests that the enclosed entity be +stored under the supplied Request-URI. PUT requests are similar to POST requests in that they both can send an entity +body in the request message. + +The body of a PUT request (any any ``Guzzle\Http\Message\EntityEnclosingRequestInterface`` object) is always stored as +a ``Guzzle\Http\Message\EntityBodyInterface`` object. This allows a great deal of flexibility when sending data to a +remote server. For example, you can stream the contents of a stream returned by fopen, stream the contents of a +callback function, or simply send a string of data. + +.. code-block:: php + + $request = $client->put('http://httpbin.org/put', array(), 'this is the body'); + $response = $request->send(); + +Just like with POST, PATH, and DELETE requests, you can set the body of a PUT request using the ``setBody()`` method. + +.. code-block:: php + + $request = $client->put('http://httpbin.org/put'); + $request->setBody(fopen('/path/to/large_body.txt', 'r')); + $response = $request->send(); + +PATCH requests +~~~~~~~~~~~~~~ + +`PATCH requests `_ are used to modify a resource. + +.. code-block:: php + + $request = $client->patch('http://httpbin.org', array(), 'this is the body'); + $response = $request->send(); + +OPTIONS requests +~~~~~~~~~~~~~~~~ + +The `OPTIONS method `_ represents a request for +information about the communication options available on the request/response chain identified by the Request-URI. + +.. code-block:: php + + $request = $client->options('http://httpbin.org'); + $response = $request->send(); + + // Check if the PUT method is supported by this resource + var_export($response->isMethodAllows('PUT')); + +Custom requests +~~~~~~~~~~~~~~~ + +You can create custom HTTP requests that use non-standard HTTP methods using the ``createRequest()`` method of a +client object. + +.. code-block:: php + + $request = $client->createRequest('COPY', 'http://example.com/foo', array( + 'Destination' => 'http://example.com/bar', + 'Overwrite' => 'T' + )); + $response = $request->send(); + +Query string parameters +----------------------- + +Query string parameters of a request are owned by a request's ``Guzzle\Http\Query`` object that is accessible by +calling ``$request->getQuery()``. The Query class extends from ``Guzzle\Common\Collection`` and allows you to set one +or more query string parameters as key value pairs. You can set a parameter on a Query object using the +``set($key, $value)`` method or access the query string object like an associative array. Any previously specified +value for a key will be overwritten when using ``set()``. Use ``add($key, $value)`` to add a value to query string +object, and in the event of a collision with an existing value at a specific key, the value will be converted to an +array that contains all of the previously set values. + +.. code-block:: php + + $request = new Guzzle\Http\Message\Request('GET', 'http://www.example.com?foo=bar&abc=123'); + + $query = $request->getQuery(); + echo "{$query}\n"; + // >>> foo=bar&abc=123 + + $query->remove('abc'); + echo "{$query}\n"; + // >>> foo=bar + + $query->set('foo', 'baz'); + echo "{$query}\n"; + // >>> foo=baz + + $query->add('foo', 'bar'); + echo "{$query}\n"; + // >>> foo%5B0%5D=baz&foo%5B1%5D=bar + +Whoah! What happened there? When ``foo=bar`` was added to the existing ``foo=baz`` query string parameter, the +aggregator associated with the Query object was used to help convert multi-value query string parameters into a string. +Let's disable URL-encoding to better see what's happening. + +.. code-block:: php + + $query->useUrlEncoding(false); + echo "{$query}\n"; + // >>> foo[0]=baz&foo[1]=bar + +.. note:: + + URL encoding can be disabled by passing false, enabled by passing true, set to use RFC 1738 by passing + ``Query::FORM_URLENCODED`` (internally uses PHP's ``urlencode`` function), or set to RFC 3986 by passing + ``Query::RFC_3986`` (this is the default and internally uses PHP's ``rawurlencode`` function). + +As you can see, the multiple values were converted into query string parameters following the default PHP convention of +adding numerically indexed square bracket suffixes to each key (``foo[0]=baz&foo[1]=bar``). The strategy used to convert +multi-value parameters into a string can be customized using the ``setAggregator()`` method of the Query class. Guzzle +ships with the following query string aggregators by default: + +1. ``Guzzle\Http\QueryAggregator\PhpAggregator``: Aggregates using PHP style brackets (e.g. ``foo[0]=baz&foo[1]=bar``) +2. ``Guzzle\Http\QueryAggregator\DuplicateAggregator``: Performs no aggregation and allows for key value pairs to be + repeated in a URL (e.g. ``foo=baz&foo=bar``) +3. ``Guzzle\Http\QueryAggregator\CommaAggregator``: Aggregates using commas (e.g. ``foo=baz,bar``) + +.. _http-message-headers: + +HTTP Message Headers +-------------------- + +HTTP message headers are case insensitive, multiple occurrences of any header can be present in an HTTP message +(whether it's valid or not), and some servers require specific casing of particular headers. Because of this, request +and response headers are stored in ``Guzzle\Http\Message\Header`` objects. The Header object can be cast as a string, +counted, or iterated to retrieve each value from the header. Casting a Header object to a string will return all of +the header values concatenated together using a glue string (typically ", "). + +A request (and response) object have several methods that allow you to retrieve and modify headers. + +* ``getHeaders()``: Get all of the headers of a message as a ``Guzzle\Http\Message\Header\HeaderCollection`` object. +* ``getHeader($header)``: Get a specific header from a message. If the header exists, you'll get a + ``Guzzle\Http\Message\Header`` object. If the header does not exist, this methods returns ``null``. +* ``hasHeader($header)``: Returns true or false based on if the message has a particular header. +* ``setHeader($header, $value)``: Set a header value and overwrite any previously set value for this header. +* ``addHeader($header, $value)``: Add a header with a particular name. If a previous value was already set by the same, + then the header will contain multiple values. +* ``removeHeader($header)``: Remove a header by name from the message. + +.. code-block:: php + + $request = new Request('GET', 'http://httpbin.com/cookies'); + // addHeader will set and append to any existing header values + $request->addHeader('Foo', 'bar'); + $request->addHeader('foo', 'baz'); + // setHeader overwrites any existing values + $request->setHeader('Test', '123'); + + // Request headers can be cast as a string + echo $request->getHeader('Foo'); + // >>> bar, baz + echo $request->getHeader('Test'); + // >>> 123 + + // You can count the number of headers of a particular case insensitive name + echo count($request->getHeader('foO')); + // >>> 2 + + // You can iterate over Header objects + foreach ($request->getHeader('foo') as $header) { + echo $header . "\n"; + } + + // You can get all of the request headers as a Guzzle\Http\Message\Header\HeaderCollection object + $headers = $request->getHeaders(); + + // Missing headers return NULL + var_export($request->getHeader('Missing')); + // >>> null + + // You can see all of the different variations of a header by calling raw() on the Header + var_export($request->getHeader('foo')->raw()); + +Setting the body of a request +----------------------------- + +Requests that can send a body (e.g. PUT, POST, DELETE, PATCH) are instances of +``Guzzle\Http\Message\EntityEnclosingRequestInterface``. Entity enclosing requests contain several methods that allow +you to specify the body to send with a request. + +Use the ``setBody()`` method of a request to set the body that will be sent with a request. This method accepts a +string, a resource returned by ``fopen()``, an array, or an instance of ``Guzzle\Http\EntityBodyInterface``. The body +will then be streamed from the underlying ``EntityBodyInterface`` object owned by the request. When setting the body +of the request, you can optionally specify a Content-Type header and whether or not to force the request to use +chunked Transfer-Encoding. + +.. code-block:: php + + $request = $client->put('/user.json'); + $request->setBody('{"foo":"baz"}', 'application/json'); + +Content-Type header +~~~~~~~~~~~~~~~~~~~ + +Guzzle will automatically add a Content-Type header to a request if the Content-Type can be guessed based on the file +extension of the payload being sent or the file extension present in the path of a request. + +.. code-block:: php + + $request = $client->put('/user.json', array(), '{"foo":"bar"}'); + // The Content-Type was guessed based on the path of the request + echo $request->getHeader('Content-Type'); + // >>> application/json + + $request = $client->put('/user.json'); + $request->setBody(fopen('/tmp/user_data.json', 'r')); + // The Content-Type was guessed based on the path of the entity body + echo $request->getHeader('Content-Type'); + // >>> application/json + +Transfer-Encoding: chunked header +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +When sending HTTP requests that contain a payload, you must let the remote server know how to determine when the entire +message has been sent. This usually is done by supplying a ``Content-Length`` header that tells the origin server the +size of the body that is to be sent. In some cases, the size of the payload being sent in a request cannot be known +before initiating the transfer. In these cases (when using HTTP/1.1), you can use the ``Transfer-Encoding: chunked`` +header. + +If the Content-Length cannot be determined (i.e. using a PHP ``http://`` stream), then Guzzle will automatically add +the ``Transfer-Encoding: chunked`` header to the request. + +.. code-block:: php + + $request = $client->put('/user.json'); + $request->setBody(fopen('http://httpbin.org/get', 'r')); + + // The Content-Length could not be determined + echo $request->getHeader('Transfer-Encoding'); + // >>> chunked + +See :doc:`/http-client/entity-bodies` for more information on entity bodies. + +Expect: 100-Continue header +~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +The ``Expect: 100-Continue`` header is used to help a client prevent sending a large payload to a server that will +reject the request. This allows clients to fail fast rather than waste bandwidth sending an erroneous payload. Guzzle +will automatically add the ``Expect: 100-Continue`` header to a request when the size of the payload exceeds 1MB or if +the body of the request is not seekable (this helps to prevent errors when a non-seekable body request is redirected). + +.. note:: + + If you find that your larger requests are taking too long to complete, you should first check if the + ``Expect: 100-Continue`` header is being sent with the request. Some servers do not respond well to this header, + which causes cURL to sleep for `1 second `_. + +POST fields and files +~~~~~~~~~~~~~~~~~~~~~ + +Any entity enclosing request can send POST style fields and files. This includes POST, PUT, PATCH, and DELETE requests. +Any request that has set POST fields or files will use cURL's POST message functionality. + +.. code-block:: php + + $request = $client->post('/post'); + // Set an overwrite any previously specified value + $request->setPostField('foo', 'bar'); + // Append a value to any existing values + $request->getPostFields()->add('foo', 'baz'); + // Remove a POST field by name + $request->removePostField('fizz'); + + // Add a file to upload (forces multipart/form-data) + $request->addPostFile('my_file', '/path/to/file', 'plain/text'); + // Remove a POST file by POST key name + $request->removePostFile('my_other_file'); + +.. tip:: + + Adding a large number of POST fields to a POST request is faster if you use the ``addPostFields()`` method so that + you can add and process multiple fields with a single call. Adding multiple POST files is also faster using + ``addPostFiles()``. + +Working with cookies +-------------------- + +Cookies can be modified and retrieved from a request using the following methods: + +.. code-block:: php + + $request->addCookie($name, $value); + $request->removeCookie($name); + $value = $request->getCookie($name); + $valueArray = $request->getCookies(); + +Use the :doc:`cookie plugin ` if you need to reuse cookies between requests. + +.. _request-set-response-body: + +Changing where a response is downloaded +---------------------------------------- + +When a request is sent, the body of the response will be stored in a PHP temp stream by default. You can change the +location in which the response will be downloaded using ``$request->setResponseBody($body)`` or the ``save_to`` request +option. This can be useful for downloading the contents of a URL to a specific file. + +Here's an example of using request options: + +.. code-block:: php + + $request = $this->client->get('http://example.com/large.mov', array(), array( + 'save_to' => '/tmp/large_file.mov' + )); + $request->send(); + var_export(file_exists('/tmp/large_file.mov')); + // >>> true + +Here's an example of using ``setResponseBody()``: + +.. code-block:: php + + $body = fopen('/tmp/large_file.mov', 'w'); + $request = $this->client->get('http://example.com/large.mov'); + $request->setResponseBody($body); + + // You can more easily specify the name of a file to save the contents + // of the response to by passing a string to ``setResponseBody()``. + + $request = $this->client->get('http://example.com/large.mov'); + $request->setResponseBody('/tmp/large_file.mov'); + +Custom cURL options +------------------- + +Most of the functionality implemented in the libcurl bindings has been simplified and abstracted by Guzzle. Developers +who need access to `cURL specific functionality `_ can still add cURL handle +specific behavior to Guzzle HTTP requests by modifying the cURL options collection of a request: + +.. code-block:: php + + $request->getCurlOptions()->set(CURLOPT_LOW_SPEED_LIMIT, 200); + +Other special options that can be set in the ``curl.options`` array include: + ++-------------------------+---------------------------------------------------------------------------------+ +| debug | Adds verbose cURL output to a temp stream owned by the cURL handle object | ++-------------------------+---------------------------------------------------------------------------------+ +| progress | Instructs cURL to emit events when IO events occur. This allows you to be | +| | notified when bytes are transferred over the wire by subscribing to a request's | +| | ``curl.callback.read``, ``curl.callback.write``, and ``curl.callback.progress`` | +| | events. | ++-------------------------+---------------------------------------------------------------------------------+ + +Request options +--------------- + +Requests options can be specified when creating a request or in the ``request.options`` parameter of a client. These +options can control various aspects of a request including: headers to send, query string data, where the response +should be downloaded, proxies, auth, etc. + +.. code-block:: php + + $request = $client->get($url, $headers, array('proxy' => 'http://proxy.com')); + +See :ref:`Request options ` for more information. + +Working with errors +------------------- + +HTTP errors +~~~~~~~~~~~ + +Requests that receive a 4xx or 5xx response will throw a ``Guzzle\Http\Exception\BadResponseException``. More +specifically, 4xx errors throw a ``Guzzle\Http\Exception\ClientErrorResponseException``, and 5xx errors throw a +``Guzzle\Http\Exception\ServerErrorResponseException``. You can catch the specific exceptions or just catch the +BadResponseException to deal with either type of error. Here's an example of catching a generic BadResponseException: + +.. code-block:: php + + try { + $response = $client->get('/not_found.xml')->send(); + } catch (Guzzle\Http\Exception\BadResponseException $e) { + echo 'Uh oh! ' . $e->getMessage(); + echo 'HTTP request URL: ' . $e->getRequest()->getUrl() . "\n"; + echo 'HTTP request: ' . $e->getRequest() . "\n"; + echo 'HTTP response status: ' . $e->getResponse()->getStatusCode() . "\n"; + echo 'HTTP response: ' . $e->getResponse() . "\n"; + } + +Throwing an exception when a 4xx or 5xx response is encountered is the default behavior of Guzzle requests. This +behavior can be overridden by adding an event listener with a higher priority than -255 that stops event propagation. +You can subscribe to ``request.error`` to receive notifications any time an unsuccessful response is received. + +You can change the response that will be associated with the request by calling ``setResponse()`` on the +``$event['request']`` object passed into your listener, or by changing the ``$event['response']`` value of the +``Guzzle\Common\Event`` object that is passed to your listener. Transparently changing the response associated with a +request by modifying the event allows you to retry failed requests without complicating the code that uses the client. +This might be useful for sending requests to a web service that has expiring auth tokens. When a response shows that +your token has expired, you can get a new token, retry the request with the new token, and return the successful +response to the user. + +Here's an example of retrying a request using updated authorization credentials when a 401 response is received, +overriding the response of the original request with the new response, and still allowing the default exception +behavior to be called when other non-200 response status codes are encountered: + +.. code-block:: php + + // Add custom error handling to any request created by this client + $client->getEventDispatcher()->addListener('request.error', function(Event $event) { + + if ($event['response']->getStatusCode() == 401) { + + $newRequest = $event['request']->clone(); + $newRequest->setHeader('X-Auth-Header', MyApplication::getNewAuthToken()); + $newResponse = $newRequest->send(); + + // Set the response object of the request without firing more events + $event['response'] = $newResponse; + + // You can also change the response and fire the normal chain of + // events by calling $event['request']->setResponse($newResponse); + + // Stop other events from firing when you override 401 responses + $event->stopPropagation(); + } + + }); + +cURL errors +~~~~~~~~~~~ + +Connection problems and cURL specific errors can also occur when transferring requests using Guzzle. When Guzzle +encounters cURL specific errors while transferring a single request, a ``Guzzle\Http\Exception\CurlException`` is +thrown with an informative error message and access to the cURL error message. + +A ``Guzzle\Http\Exception\MultiTransferException`` exception is thrown when a cURL specific error occurs while +transferring multiple requests in parallel. You can then iterate over all of the exceptions encountered during the +transfer. + +Plugins and events +------------------ + +Guzzle request objects expose various events that allow you to hook in custom logic. A request object owns a +``Symfony\Component\EventDispatcher\EventDispatcher`` object that can be accessed by calling +``$request->getEventDispatcher()``. You can use the event dispatcher to add listeners (a simple callback function) or +event subscribers (classes that listen to specific events of a dispatcher). You can add event subscribers to a request +directly by just calling ``$request->addSubscriber($mySubscriber);``. + +.. _request-events: + +Events emitted from a request +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +A ``Guzzle\Http\Message\Request`` and ``Guzzle\Http\Message\EntityEnclosingRequest`` object emit the following events: + ++------------------------------+--------------------------------------------+------------------------------------------+ +| Event name | Description | Event data | ++==============================+============================================+==========================================+ +| request.before_send | About to send request | * request: Request to be sent | ++------------------------------+--------------------------------------------+------------------------------------------+ +| request.sent | Sent the request | * request: Request that was sent | +| | | * response: Received response | ++------------------------------+--------------------------------------------+------------------------------------------+ +| request.complete | Completed a full HTTP transaction | * request: Request that was sent | +| | | * response: Received response | ++------------------------------+--------------------------------------------+------------------------------------------+ +| request.success | Completed a successful request | * request: Request that was sent | +| | | * response: Received response | ++------------------------------+--------------------------------------------+------------------------------------------+ +| request.error | Completed an unsuccessful request | * request: Request that was sent | +| | | * response: Received response | ++------------------------------+--------------------------------------------+------------------------------------------+ +| request.exception | An unsuccessful response was | * request: Request | +| | received. | * response: Received response | +| | | * exception: BadResponseException | ++------------------------------+--------------------------------------------+------------------------------------------+ +| request.receive.status_line | Received the start of a response | * line: Full response start line | +| | | * status_code: Status code | +| | | * reason_phrase: Reason phrase | +| | | * previous_response: (e.g. redirect) | ++------------------------------+--------------------------------------------+------------------------------------------+ +| curl.callback.progress | cURL progress event (only dispatched when | * handle: CurlHandle | +| | ``emit_io`` is set on a request's curl | * download_size: Total download size | +| | options) | * downloaded: Bytes downloaded | +| | | * upload_size: Total upload bytes | +| | | * uploaded: Bytes uploaded | ++------------------------------+--------------------------------------------+------------------------------------------+ +| curl.callback.write | cURL event called when data is written to | * request: Request | +| | an outgoing stream | * write: Data being written | ++------------------------------+--------------------------------------------+------------------------------------------+ +| curl.callback.read | cURL event called when data is written to | * request: Request | +| | an incoming stream | * read: Data being read | ++------------------------------+--------------------------------------------+------------------------------------------+ + +Creating a request event listener +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Here's an example that listens to the ``request.complete`` event of a request and prints the request and response. + +.. code-block:: php + + use Guzzle\Common\Event; + + $request = $client->get('http://www.google.com'); + + // Echo out the response that was received + $request->getEventDispatcher()->addListener('request.complete', function (Event $e) { + echo $e['request'] . "\n\n"; + echo $e['response']; + }); diff --git a/vendor/guzzle/guzzle/docs/http-client/response.rst b/vendor/guzzle/guzzle/docs/http-client/response.rst new file mode 100644 index 0000000..ba48731 --- /dev/null +++ b/vendor/guzzle/guzzle/docs/http-client/response.rst @@ -0,0 +1,141 @@ +====================== +Using Response objects +====================== + +Sending a request will return a ``Guzzle\Http\Message\Response`` object. You can view the raw HTTP response message by +casting the Response object to a string. Casting the response to a string will return the entity body of the response +as a string too, so this might be an expensive operation if the entity body is stored in a file or network stream. If +you only want to see the response headers, you can call ``getRawHeaders()``. + +Response status line +-------------------- + +The different parts of a response's `status line `_ +(the first line of the response HTTP message) are easily retrievable. + +.. code-block:: php + + $response = $client->get('http://www.amazon.com')->send(); + + echo $response->getStatusCode(); // >>> 200 + echo $response->getReasonPhrase(); // >>> OK + echo $response->getProtocol(); // >>> HTTP + echo $response->getProtocolVersion(); // >>> 1.1 + +You can determine the type of the response using several helper methods: + +.. code-block:: php + + $response->isSuccessful(); // true + $response->isInformational(); + $response->isRedirect(); + $response->isClientError(); + $response->isServerError(); + +Response headers +---------------- + +The Response object contains helper methods for retrieving common response headers. These helper methods normalize the +variations of HTTP response headers. + +.. code-block:: php + + $response->getCacheControl(); + $response->getContentType(); + $response->getContentLength(); + $response->getContentEncoding(); + $response->getContentMd5(); + $response->getEtag(); + // etc... There are methods for every known response header + +You can interact with the Response headers using the same exact methods used to interact with Request headers. See +:ref:`http-message-headers` for more information. + +.. code-block:: php + + echo $response->getHeader('Content-Type'); + echo $response->getHeader('Content-Length'); + echo $response->getHeaders()['Content-Type']; // PHP 5.4 + +Response body +------------- + +The entity body object of a response can be retrieved by calling ``$response->getBody()``. The response EntityBody can +be cast to a string, or you can pass ``true`` to this method to retrieve the body as a string. + +.. code-block:: php + + $request = $client->get('http://www.amazon.com'); + $response = $request->send(); + echo $response->getBody(); + +See :doc:`/http-client/entity-bodies` for more information on entity bodies. + +JSON Responses +~~~~~~~~~~~~~~ + +You can easily parse and use a JSON response as an array using the ``json()`` method of a response. This method will +always return an array if the response is valid JSON or if the response body is empty. You will get an exception if you +call this method and the response is not valid JSON. + +.. code-block:: php + + $data = $response->json(); + echo gettype($data); + // >>> array + +XML Responses +~~~~~~~~~~~~~ + +You can easily parse and use a XML response as SimpleXMLElement object using the ``xml()`` method of a response. This +method will always return a SimpleXMLElement object if the response is valid XML or if the response body is empty. You +will get an exception if you call this method and the response is not valid XML. + +.. code-block:: php + + $xml = $response->xml(); + echo $xml->foo; + // >>> Bar! + +Streaming responses +------------------- + +Some web services provide streaming APIs that allow a client to keep a HTTP request open for an extended period of +time while polling and reading. Guzzle provides a simple way to convert HTTP request messages into +``Guzzle\Stream\Stream`` objects so that you can send the initial headers of a request, read the response headers, and +pull in the response body manually as needed. + +Here's an example using the Twitter Streaming API to track the keyword "bieber": + +.. code-block:: php + + use Guzzle\Http\Client; + use Guzzle\Stream\PhpStreamRequestFactory; + + $client = new Client('https://stream.twitter.com/1'); + + $request = $client->post('statuses/filter.json', null, array( + 'track' => 'bieber' + )); + + $request->setAuth('myusername', 'mypassword'); + + $factory = new PhpStreamRequestFactory(); + $stream = $factory->fromRequest($request); + + // Read until the stream is closed + while (!$stream->feof()) { + // Read a line from the stream + $line = $stream->readLine(); + // JSON decode the line of data + $data = json_decode($line, true); + } + +You can use the ``stream`` request option when using a static client to more easily create a streaming response. + +.. code-block:: php + + $stream = Guzzle::get('http://guzzlephp.org', array('stream' => true)); + while (!$stream->feof()) { + echo $stream->readLine(); + } diff --git a/vendor/guzzle/guzzle/docs/http-client/uri-templates.rst b/vendor/guzzle/guzzle/docs/http-client/uri-templates.rst new file mode 100644 index 0000000..c18ac3e --- /dev/null +++ b/vendor/guzzle/guzzle/docs/http-client/uri-templates.rst @@ -0,0 +1,52 @@ +============= +URI templates +============= + +The ``$uri`` passed to one of the client's request creational methods or the base URL of a client can utilize URI +templates. Guzzle supports the entire `URI templates RFC `_. URI templates add a +special syntax to URIs that replace template place holders with user defined variables. + +Every request created by a Guzzle HTTP client passes through a URI template so that URI template expressions are +automatically expanded: + +.. code-block:: php + + $client = new Guzzle\Http\Client('https://example.com/', array('a' => 'hi')); + $request = $client->get('/{a}'); + +Because of URI template expansion, the URL of the above request will become ``https://example.com/hi``. Notice that +the template was expanded using configuration variables of the client. You can pass in custom URI template variables +by passing the URI of your request as an array where the first index of the array is the URI template and the second +index of the array are template variables that are merged into the client's configuration variables. + +.. code-block:: php + + $request = $client->get(array('/test{?a,b}', array('b' => 'there'))); + +The URL for this request will become ``https://test.com?a=hi&b=there``. URI templates aren't limited to just simple +variable replacements; URI templates can provide an enormous amount of flexibility when creating request URIs. + +.. code-block:: php + + $request = $client->get(array('http://example.com{+path}{/segments*}{?query,data*}', array( + 'path' => '/foo/bar', + 'segments' => array('one', 'two'), + 'query' => 'test', + 'data' => array( + 'more' => 'value' + ) + ))); + +The resulting URL would become ``http://example.com/foo/bar/one/two?query=test&more=value``. + +By default, URI template expressions are enclosed in an opening and closing brace (e.g. ``{var}``). If you are working +with a web service that actually uses braces (e.g. Solr), then you can specify a custom regular expression to use to +match URI template expressions. + +.. code-block:: php + + $client->getUriTemplate()->setRegex('/\<\$(.+)\>/'); + $client->get('/<$a>'); + +You can learn about all of the different features of URI templates by reading the +`URI templates RFC `_. diff --git a/vendor/guzzle/guzzle/docs/index.rst b/vendor/guzzle/guzzle/docs/index.rst new file mode 100644 index 0000000..f76f3bb --- /dev/null +++ b/vendor/guzzle/guzzle/docs/index.rst @@ -0,0 +1,5 @@ +.. title:: Guzzle | PHP HTTP client and framework for consuming RESTful web services +.. toctree:: + :hidden: + + docs.rst diff --git a/vendor/guzzle/guzzle/docs/iterators/guzzle-iterators.rst b/vendor/guzzle/guzzle/docs/iterators/guzzle-iterators.rst new file mode 100644 index 0000000..a5c7fd3 --- /dev/null +++ b/vendor/guzzle/guzzle/docs/iterators/guzzle-iterators.rst @@ -0,0 +1,97 @@ +================ +Guzzle iterators +================ + +Guzzle provides several SPL iterators that can be used with other SPL iterators, including Guzzle resource iterators. +Guzzle's ``guzzle/iterator`` component can also be used independently of the rest of Guzzle through Packagist and +Composer: https://packagist.org/packages/guzzle/iterator + +ChunkedIterator +--------------- + +Pulls out multiple values from an inner iterator and yields and array of values for each outer iteration -- essentially +pulling out chunks of values from the inner iterator. + +.. code-block:: php + + use Guzzle\Iterator\ChunkedIterator; + + $inner = new ArrayIterator(range(0, 8)); + $chunkedIterator = new ChunkedIterator($inner, 2); + + foreach ($chunkedIterator as $chunk) { + echo implode(', ', $chunk) . "\n"; + } + + // >>> 0, 1 + // >>> 2, 3 + // >>> 4, 5 + // >>> 6, 7 + // >>> 8 + +FilterIterator +-------------- + +This iterator is used to filter values out of the inner iterator. This iterator can be used when PHP 5.4's +CallbackFilterIterator is not available. + +.. code-block:: php + + use Guzzle\Iterator\FilterIterator; + + $inner = new ArrayIterator(range(1, 10)); + $filterIterator = new FilterIterator($inner, function ($value) { + return $value % 2; + }); + + foreach ($filterIterator as $value) { + echo $value . "\n"; + } + + // >>> 2 + // >>> 4 + // >>> 6 + // >>> 8 + // >>> 10 + +MapIterator +----------- + +This iterator modifies the values of the inner iterator before yielding. + +.. code-block:: php + + use Guzzle\Iterator\MapIterator; + + $inner = new ArrayIterator(range(0, 3)); + + $mapIterator = new MapIterator($inner, function ($value) { + return $value * 10; + }); + + foreach ($mapIterator as $value) { + echo $value . "\n"; + } + + // >>> 0 + // >>> 10 + // >>> 20 + // >>> 30 + +MethodProxyIterator +------------------- + +This decorator is useful when you need to expose a specific method from an inner iterator that might be wrapper +by one or more iterator decorators. This decorator proxies missing method calls to each inner iterator until one +of the inner iterators can fulfill the call. + +.. code-block:: php + + use Guzzle\Iterator\MethodProxyIterator; + + $inner = new \ArrayIterator(); + $proxy = new MethodProxyIterator($inner); + + // Proxy method calls to the ArrayIterator + $proxy->append('a'); + $proxy->append('b'); diff --git a/vendor/guzzle/guzzle/docs/iterators/resource-iterators.rst b/vendor/guzzle/guzzle/docs/iterators/resource-iterators.rst new file mode 100644 index 0000000..ce0bee5 --- /dev/null +++ b/vendor/guzzle/guzzle/docs/iterators/resource-iterators.rst @@ -0,0 +1,149 @@ +================== +Resource iterators +================== + +Web services often implement pagination in their responses which requires the end-user to issue a series of consecutive +requests in order to fetch all of the data they asked for. Users of your web service client should not be responsible +for implementing the logic involved in iterating through pages of results. Guzzle provides a simple resource iterator +foundation to make it easier on web service client developers to offer a useful abstraction layer. + +Getting an iterator from a client +--------------------------------- + + ResourceIteratorInterface Guzzle\Service\Client::getIterator($command [, array $commandOptions, array $iteratorOptions ]) + +The ``getIterator`` method of a ``Guzzle\Service\ClientInterface`` object provides a convenient interface for +instantiating a resource iterator for a specific command. This method implicitly uses a +``Guzzle\Service\Resource\ResourceIteratorFactoryInterface`` object to create resource iterators. Pass an +instantiated command object or the name of a command in the first argument. When passing the name of a command, the +command factory of the client will create the command by name using the ``$commandOptions`` array. The third argument +may be used to pass an array of options to the constructor of the instantiated ``ResourceIteratorInterface`` object. + +.. code-block:: php + + $iterator = $client->getIterator('get_users'); + + foreach ($iterator as $user) { + echo $user['name'] . ' age ' . $user['age'] . PHP_EOL; + } + +The above code sample might execute a single request or a thousand requests. As a consumer of a web service, I don't +care. I just want to iterate over all of the users. + +Iterator options +~~~~~~~~~~~~~~~~ + +The two universal options that iterators should support are ``limit`` and ``page_size``. Using the ``limit`` option +tells the resource iterator to attempt to limit the total number of iterated resources to a specific amount. Keep in +mind that this is not always possible due to limitations that may be inherent to a web service. The ``page_size`` +option is used to tell a resource iterator how many resources to request per page of results. Much like the ``limit`` +option, you can not rely on getting back exactly the number of resources your specify in the ``page_size`` option. + +.. note:: + + The ``limit`` and ``page_size`` options can also be specified on an iterator using the ``setLimit($limit)`` and + ``setPageSize($pageSize)`` methods. + +Resolving iterator class names +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +The default resource iterator factory of a client object expects that your iterators are stored under the ``Model`` +folder of your client and that an iterator is names after the CamelCase name of a command followed by the word +"Iterator". For example, if you wanted to create an iterator for the ``get_users`` command, then your iterator class +would be ``Model\GetUsersIterator`` and would be stored in ``Model/GetUsersIterator.php``. + +Creating an iterator +-------------------- + +While not required, resource iterators in Guzzle typically iterate using a ``Guzzle\Service\Command\CommandInterface`` +object. ``Guzzle\Service\Resource\ResourceIterator``, the default iterator implementation that you should extend, +accepts a command object and array of iterator options in its constructor. The command object passed to the resource +iterator is expected to be ready to execute and not previously executed. The resource iterator keeps a reference of +this command and clones the original command each time a subsequent request needs to be made to fetch more data. + +Implement the sendRequest method +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +The most important thing (and usually the only thing) you need to do when creating a resource iterator is to implement +the ``sendRequest()`` method of the resource iterator. The ``sendRequest()`` method is called when you begin +iterating or if there are no resources left to iterate and it you expect to retrieve more resources by making a +subsequent request. The ``$this->command`` property of the resource iterator is updated with a cloned copy of the +original command object passed into the constructor of the iterator. Use this command object to issue your subsequent +requests. + +The ``sendRequest()`` method must return an array of the resources you retrieved from making the subsequent call. +Returning an empty array will stop the iteration. If you suspect that your web service client will occasionally return +an empty result set but still requires further iteration, then you must implement a sort of loop in your +``sendRequest()`` method that will continue to issue subsequent requests until your reach the end of the paginated +result set or until additional resources are retrieved from the web service. + +Update the nextToken property +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Beyond fetching more results, the ``sendRequest()`` method is responsible for updating the ``$this->nextToken`` +property of the iterator. Setting this property to anything other than null tells the iterator that issuing a +subsequent request using the nextToken value will probably return more results. You must continually update this +value in your ``sendRequest()`` method as each response is received from the web service. + +Example iterator +---------------- + +Let's say you want to implement a resource iterator for the ``get_users`` command of your web service. The +``get_users`` command receives a response that contains a list of users, and if there are more pages of results to +retrieve, returns a value called ``next_user``. This return value is known as the **next token** and should be used to +issue subsequent requests. + +Assume the response to a ``get_users`` command returns JSON data that looks like this: + +.. code-block:: javascript + + { + "users": [ + { "name": "Craig Johnson", "age": 10 }, + { "name": "Tom Barker", "age": 20 }, + { "name": "Bob Mitchell", "age": 74 } + ], + "next_user": "Michael Dowling" + } + +Assume that because there is a ``next_user`` value, there will be more users if a subsequent request is issued. If the +``next_user`` value is missing or null, then we know there are no more results to fetch. Let's implement a resource +iterator for this command. + +.. code-block:: php + + namespace MyService\Model; + + use Guzzle\Service\Resource\ResourceIterator; + + /** + * Iterate over a get_users command + */ + class GetUsersIterator extends ResourceIterator + { + protected function sendRequest() + { + // If a next token is set, then add it to the command + if ($this->nextToken) { + $this->command->set('next_user', $this->nextToken); + } + + // Execute the command and parse the result + $result = $this->command->execute(); + + // Parse the next token + $this->nextToken = isset($result['next_user']) ? $result['next_user'] : false; + + return $result['users']; + } + } + +As you can see, it's pretty simple to implement an iterator. There are a few things that you should notice from this +example: + +1. You do not need to create a new command in the ``sendRequest()`` method. A new command object is cloned from the + original command passed into the constructor of the iterator before the ``sendRequest()`` method is called. + Remember that the resource iterator expects a command that has not been executed. +2. When the ``sendRequest()`` method is first called, you will not have a ``$this->nextToken`` value, so always check + before setting it on a command. Notice that the next token is being updated each time a request is sent. +3. After fetching more resources from the service, always return an array of resources. diff --git a/vendor/guzzle/guzzle/docs/plugins/async-plugin.rst b/vendor/guzzle/guzzle/docs/plugins/async-plugin.rst new file mode 100644 index 0000000..9bd8f42 --- /dev/null +++ b/vendor/guzzle/guzzle/docs/plugins/async-plugin.rst @@ -0,0 +1,18 @@ +============ +Async plugin +============ + +The AsyncPlugin allows you to send requests that do not wait on a response. This is handled through cURL by utilizing +the progress event. When a request has sent all of its data to the remote server, Guzzle adds a 1ms timeout on the +request and instructs cURL to not download the body of the response. The async plugin then catches the exception and +adds a mock response to the request, along with an X-Guzzle-Async header to let you know that the response was not +fully downloaded. + +.. code-block:: php + + use Guzzle\Http\Client; + use Guzzle\Plugin\Async\AsyncPlugin; + + $client = new Client('http://www.example.com'); + $client->addSubscriber(new AsyncPlugin()); + $response = $client->get()->send(); diff --git a/vendor/guzzle/guzzle/docs/plugins/backoff-plugin.rst b/vendor/guzzle/guzzle/docs/plugins/backoff-plugin.rst new file mode 100644 index 0000000..5a76941 --- /dev/null +++ b/vendor/guzzle/guzzle/docs/plugins/backoff-plugin.rst @@ -0,0 +1,22 @@ +==================== +Backoff retry plugin +==================== + +The ``Guzzle\Plugin\Backoff\BackoffPlugin`` automatically retries failed HTTP requests using custom backoff strategies: + +.. code-block:: php + + use Guzzle\Http\Client; + use Guzzle\Plugin\Backoff\BackoffPlugin; + + $client = new Client('http://www.test.com/'); + // Use a static factory method to get a backoff plugin using the exponential backoff strategy + $backoffPlugin = BackoffPlugin::getExponentialBackoff(); + + // Add the backoff plugin to the client object + $client->addSubscriber($backoffPlugin); + +The BackoffPlugin's constructor accepts a ``Guzzle\Plugin\Backoff\BackoffStrategyInterface`` object that is used to +determine when a retry should be issued and how long to delay between retries. The above code example shows how to +attach a BackoffPlugin to a client that is pre-configured to retry failed 500 and 503 responses using truncated +exponential backoff (emulating the behavior of Guzzle 2's ExponentialBackoffPlugin). diff --git a/vendor/guzzle/guzzle/docs/plugins/cache-plugin.rst b/vendor/guzzle/guzzle/docs/plugins/cache-plugin.rst new file mode 100644 index 0000000..d2fd5df --- /dev/null +++ b/vendor/guzzle/guzzle/docs/plugins/cache-plugin.rst @@ -0,0 +1,169 @@ +================= +HTTP Cache plugin +================= + +Guzzle can leverage HTTP's caching specifications using the ``Guzzle\Plugin\Cache\CachePlugin``. The CachePlugin +provides a private transparent proxy cache that caches HTTP responses. The caching logic, based on +`RFC 2616 `_, uses HTTP headers to control caching behavior, +cache lifetime, and supports Vary, ETag, and Last-Modified based revalidation: + +.. code-block:: php + + use Guzzle\Http\Client; + use Doctrine\Common\Cache\FilesystemCache; + use Guzzle\Cache\DoctrineCacheAdapter; + use Guzzle\Plugin\Cache\CachePlugin; + use Guzzle\Plugin\Cache\DefaultCacheStorage; + + $client = new Client('http://www.test.com/'); + + $cachePlugin = new CachePlugin(array( + 'storage' => new DefaultCacheStorage( + new DoctrineCacheAdapter( + new FilesystemCache('/path/to/cache/files') + ) + ) + )); + + // Add the cache plugin to the client object + $client->addSubscriber($cachePlugin); + $client->get('http://www.wikipedia.org/')->send(); + + // The next request will revalidate against the origin server to see if it + // has been modified. If a 304 response is received the response will be + // served from cache + $client->get('http://www.wikipedia.org/')->send(); + +The cache plugin intercepts GET and HEAD requests before they are actually transferred to the origin server. The cache +plugin then generates a hash key based on the request method and URL, and checks to see if a response exists in the cache. If +a response exists in the cache, the cache adapter then checks to make sure that the caching rules associated with the response +satisfy the request, and ensures that response still fresh. If the response is acceptable for the request any required +revalidation, then the cached response is served instead of contacting the origin server. + +Vary +---- + +Cache keys are derived from a request method and a request URL. Multiple responses can map to the same cache key and +stored in Guzzle's underlying cache storage object. You should use the ``Vary`` HTTP header to tell the cache storage +object that the cache response must have been cached for a request that matches the headers specified in the Vary header +of the request. This allows you to have specific cache entries for the same request URL but variations in a request's +headers determine which cache entry is served. Please see the http://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html#sec14.44 +for more information. + +Cache options +------------- + +There are several options you can add to requests or clients to modify the behavior of the cache plugin. + +Override cache TTL +~~~~~~~~~~~~~~~~~~ + +You can override the number of seconds a cacheable response is stored in the cache by setting the +``cache.override_ttl`` parameter on the params object of a request: + +.. code-block:: php + + // If the response to the request is cacheable, then the response will be cached for 100 seconds + $request->getParams()->set('cache.override_ttl', 100); + +If a response doesn't specify any freshness policy, it will be kept in cache for 3600 seconds by default. + +Custom caching decision +~~~~~~~~~~~~~~~~~~~~~~~ + +If the service you are interacting with does not return caching headers or returns responses that are normally +something that would not be cached, you can set a custom ``can_cache`` object on the constructor of the CachePlugin +and provide a ``Guzzle\Plugin\Cache\CanCacheInterface`` object. You can use the +``Guzzle\Plugin\Cache\CallbackCanCacheStrategy`` to easily make a caching decision based on an HTTP request and +response. + +Revalidation options +~~~~~~~~~~~~~~~~~~~~ + +You can change the revalidation behavior of a request using the ``cache.revalidate`` parameter. Setting this +parameter to ``never`` will ensure that a revalidation request is never sent, and the response is always served from +the origin server. Setting this parameter to ``skip`` will never revalidate and uses the response stored in the cache. + +Normalizing requests for caching +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Use the ``cache.key_filter`` parameter if you wish to strip certain query string parameters from your +request before creating a unique hash for the request. This parameter can be useful if your requests have query +string values that cause each request URL to be unique (thus preventing a cache hit). The ``cache.key_filter`` +format is simply a comma separated list of query string values to remove from the URL when creating a cache key. +For example, here we are saying that the ``a`` and ``q`` query string variables should be ignored when generating a +cache key for the request: + +.. code-block:: php + + $request->getParams()->set('cache.key_filter', 'a, q'); + +Other options +~~~~~~~~~~~~~ + +There are many other options available to the CachePlugin that can meet almost any caching requirement, including +custom revalidation implementations, custom cache key generators, custom caching decision strategies, and custom +cache storage objects. Take a look the constructor of ``Guzzle\Plugin\Cache\CachePlugin`` for more information. + +Setting Client-wide cache settings +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +You can specify cache settings for every request created by a client by adding cache settings to the configuration +options of a client. + +.. code-block:: php + + $client = new Guzzle\Http\Client('http://www.test.com', array( + 'request.params' => array( + 'cache.override_ttl' => 3600, + 'params.cache.revalidate' => 'never' + ) + )); + + echo $client->get('/')->getParams()->get('cache.override_ttl'); + // >>> 3600 + + echo $client->get('/')->getParams()->get('cache.revalidate'); + // >>> never + +Cache revalidation +------------------ + +If the cache plugin determines that a response to a GET request needs revalidation, a conditional GET is transferred +to the origin server. If the origin server returns a 304 response, then a response containing the merged headers of +the cached response with the new response and the entity body of the cached response is returned. Custom revalidation +strategies can be injected into a CachePlugin if needed. + +Cache adapters +-------------- + +Guzzle doesn't try to reinvent the wheel when it comes to caching or logging. Plenty of other frameworks have +excellent solutions in place that you are probably already using in your applications. Guzzle uses adapters for +caching and logging. The cache plugin requires a cache adapter so that is can store responses in a cache. Guzzle +currently supports cache adapters for `Doctrine 2.0 `_ and the +`Zend Framework `_. + +Doctrine cache adapter +~~~~~~~~~~~~~~~~~~~~~~ + +.. code-block:: php + + use Doctrine\Common\Cache\ArrayCache; + use Guzzle\Cache\DoctrineCacheAdapter; + use Guzzle\Plugin\Cache\CachePlugin; + + $backend = new ArrayCache(); + $adapter = new DoctrineCacheAdapter($backend); + $cache = new CachePlugin($adapter); + +Zend Framework cache adapter +~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +.. code-block:: php + + use Guzzle\Cache\ZendCacheAdapter; + use Zend\Cache\Backend\TestBackend; + + $backend = new TestBackend(); + $adapter = new ZendCacheAdapter($backend); + $cache = new CachePlugin($adapter); diff --git a/vendor/guzzle/guzzle/docs/plugins/cookie-plugin.rst b/vendor/guzzle/guzzle/docs/plugins/cookie-plugin.rst new file mode 100644 index 0000000..a6cc7d9 --- /dev/null +++ b/vendor/guzzle/guzzle/docs/plugins/cookie-plugin.rst @@ -0,0 +1,33 @@ +============= +Cookie plugin +============= + +Some web services require a Cookie in order to maintain a session. The ``Guzzle\Plugin\Cookie\CookiePlugin`` will add +cookies to requests and parse cookies from responses using a CookieJar object: + +.. code-block:: php + + use Guzzle\Http\Client; + use Guzzle\Plugin\Cookie\CookiePlugin; + use Guzzle\Plugin\Cookie\CookieJar\ArrayCookieJar; + + $cookiePlugin = new CookiePlugin(new ArrayCookieJar()); + + // Add the cookie plugin to a client + $client = new Client('http://www.test.com/'); + $client->addSubscriber($cookiePlugin); + + // Send the request with no cookies and parse the returned cookies + $client->get('http://www.yahoo.com/')->send(); + + // Send the request again, noticing that cookies are being sent + $request = $client->get('http://www.yahoo.com/'); + $request->send(); + + echo $request; + +You can disable cookies per-request by setting the ``cookies.disable`` value to true on a request's params object. + +.. code-block:: php + + $request->getParams()->set('cookies.disable', true); diff --git a/vendor/guzzle/guzzle/docs/plugins/creating-plugins.rst b/vendor/guzzle/guzzle/docs/plugins/creating-plugins.rst new file mode 100644 index 0000000..0870155 --- /dev/null +++ b/vendor/guzzle/guzzle/docs/plugins/creating-plugins.rst @@ -0,0 +1,93 @@ +================ +Creating plugins +================ + +.. highlight:: php + +Guzzle is extremely extensible because of the behavioral modifications that can be added to requests, clients, and +commands using an event system. Before and after the majority of actions are taken in the library, an event is emitted +with the name of the event and context surrounding the event. Observers can subscribe to a subject and modify the +subject based on the events received. Guzzle's event system utilizes the Symfony2 EventDispatcher and is the backbone +of its plugin architecture. + +Overview +-------- + +Plugins must implement the ``Symfony\Component\EventDispatcher\EventSubscriberInterface`` interface. The +``EventSubscriberInterface`` requires that your class implements a static method, ``getSubscribedEvents()``, that +returns an associative array mapping events to methods on the object. See the +`Symfony2 documentation `_ for more information. + +Plugins can be attached to any subject, or object in Guzzle that implements that +``Guzzle\Common\HasDispatcherInterface``. + +Subscribing to a subject +~~~~~~~~~~~~~~~~~~~~~~~~ + +You can subscribe an instantiated observer to an event by calling ``addSubscriber`` on a subject. + +.. code-block:: php + + $testPlugin = new TestPlugin(); + $client->addSubscriber($testPlugin); + +You can also subscribe to only specific events using a closure:: + + $client->getEventDispatcher()->addListener('request.create', function(Event $event) { + echo $event->getName(); + echo $event['request']; + }); + +``Guzzle\Common\Event`` objects are passed to notified functions. The Event object has a ``getName()`` method which +return the name of the emitted event and may contain contextual information that can be accessed like an array. + +Knowing what events to listen to +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Any class that implements the ``Guzzle\Common\HasDispatcherInterface`` must implement a static method, +``getAllEvents()``, that returns an array of the events that are emitted from the object. You can browse the source +to see each event, or you can call the static method directly in your code to get a list of available events. + +Event hooks +----------- + +* :ref:`client-events` +* :ref:`service-client-events` +* :ref:`request-events` +* ``Guzzle\Http\Curl\CurlMulti``: +* :ref:`service-builder-events` + +Examples of the event system +---------------------------- + +Simple Echo plugin +~~~~~~~~~~~~~~~~~~ + +This simple plugin prints a string containing the request that is about to be sent by listening to the +``request.before_send`` event:: + + use Symfony\Component\EventDispatcher\EventSubscriberInterface; + + class EchoPlugin implements EventSubscriberInterface + { + public static function getSubscribedEvents() + { + return array('request.before_send' => 'onBeforeSend'); + } + + public function onBeforeSend(Guzzle\Common\Event $event) + { + echo 'About to send a request: ' . $event['request'] . "\n"; + } + } + + $client = new Guzzle\Service\Client('http://www.test.com/'); + + // Create the plugin and add it as an event subscriber + $plugin = new EchoPlugin(); + $client->addSubscriber($plugin); + + // Send a request and notice that the request is printed to the screen + $client->get('/')->send(); + +Running the above code will print a string containing the HTTP request that is about to be sent. diff --git a/vendor/guzzle/guzzle/docs/plugins/curl-auth-plugin.rst b/vendor/guzzle/guzzle/docs/plugins/curl-auth-plugin.rst new file mode 100644 index 0000000..66d4a01 --- /dev/null +++ b/vendor/guzzle/guzzle/docs/plugins/curl-auth-plugin.rst @@ -0,0 +1,32 @@ +========================== +cURL authentication plugin +========================== + +.. warning:: + + The CurlAuthPlugin is deprecated. You should use the `auth` parameter of a client to add authorization headers to + every request created by a client. + + .. code-block:: php + + $client->setDefaultOption('auth', array('username', 'password', 'Basic|Digest|NTLM|Any')); + +If your web service client requires basic authorization, then you can use the CurlAuthPlugin to easily add an +Authorization header to each request sent by the client. + +.. code-block:: php + + use Guzzle\Http\Client; + use Guzzle\Plugin\CurlAuth\CurlAuthPlugin; + + $client = new Client('http://www.test.com/'); + + // Add the auth plugin to the client object + $authPlugin = new CurlAuthPlugin('username', 'password'); + $client->addSubscriber($authPlugin); + + $response = $client->get('projects/1/people')->send(); + $xml = new SimpleXMLElement($response->getBody(true)); + foreach ($xml->person as $person) { + echo $person->email . "\n"; + } diff --git a/vendor/guzzle/guzzle/docs/plugins/history-plugin.rst b/vendor/guzzle/guzzle/docs/plugins/history-plugin.rst new file mode 100644 index 0000000..b96befe --- /dev/null +++ b/vendor/guzzle/guzzle/docs/plugins/history-plugin.rst @@ -0,0 +1,24 @@ +============== +History plugin +============== + +The history plugin tracks all of the requests and responses sent through a request or client. This plugin can be +useful for crawling or unit testing. By default, the history plugin stores up to 10 requests and responses. + +.. code-block:: php + + use Guzzle\Http\Client; + use Guzzle\Plugin\History\HistoryPlugin; + + $client = new Client('http://www.test.com/'); + + // Add the history plugin to the client object + $history = new HistoryPlugin(); + $history->setLimit(5); + $client->addSubscriber($history); + + $client->get('http://www.yahoo.com/')->send(); + + echo $history->getLastRequest(); + echo $history->getLastResponse(); + echo count($history); diff --git a/vendor/guzzle/guzzle/docs/plugins/log-plugin.rst b/vendor/guzzle/guzzle/docs/plugins/log-plugin.rst new file mode 100644 index 0000000..3e2b229 --- /dev/null +++ b/vendor/guzzle/guzzle/docs/plugins/log-plugin.rst @@ -0,0 +1,69 @@ +========== +Log plugin +========== + +Use the ``Guzzle\Plugin\Log\LogPlugin`` to view all data sent over the wire, including entity bodies and redirects. + +.. code-block:: php + + use Guzzle\Http\Client; + use Guzzle\Log\Zf1LogAdapter; + use Guzzle\Plugin\Log\LogPlugin; + use Guzzle\Log\MessageFormatter; + + $client = new Client('http://www.test.com/'); + + $adapter = new Zf1LogAdapter( + new \Zend_Log(new \Zend_Log_Writer_Stream('php://output')) + ); + $logPlugin = new LogPlugin($adapter, MessageFormatter::DEBUG_FORMAT); + + // Attach the plugin to the client, which will in turn be attached to all + // requests generated by the client + $client->addSubscriber($logPlugin); + + $response = $client->get('http://google.com')->send(); + +The code sample above wraps a ``Zend_Log`` object using a ``Guzzle\Log\Zf1LogAdapter``. After attaching the plugin to +the client, all data sent over the wire will be logged to stdout. + +The first argument of the LogPlugin's constructor accepts a ``Guzzle\Log\LogAdapterInterface`` object. This object is +an adapter that allows you to use the logging capabilities of your favorite log implementation. The second argument of +the constructor accepts a ``Guzzle\Log\MessageFormatter`` or a log messaged format string. The format string uses +variable substitution and allows you to define the log data that is important to your application. The different +variables that can be injected are as follows: + +================== ==================================================================================== +Variable Substitution +================== ==================================================================================== +{request} Full HTTP request message +{response} Full HTTP response message +{ts} Timestamp +{host} Host of the request +{method} Method of the request +{url} URL of the request +{host} Host of the request +{protocol} Request protocol +{version} Protocol version +{resource} Resource of the request (path + query + fragment) +{port} Port of the request +{hostname} Hostname of the machine that sent the request +{code} Status code of the response (if available) +{phrase} Reason phrase of the response (if available) +{curl_error} Curl error message (if available) +{curl_code} Curl error code (if available) +{curl_stderr} Curl standard error (if available) +{connect_time} Time in seconds it took to establish the connection (if available) +{total_time} Total transaction time in seconds for last transfer (if available) +{req_header_*} Replace `*` with the lowercased name of a request header to add to the message +{res_header_*} Replace `*` with the lowercased name of a response header to add to the message +{req_body} Request body +{res_body} Response body +================== ==================================================================================== + +The LogPlugin has a helper method that can be used when debugging that will output the full HTTP request and +response of a transaction: + +.. code-block:: php + + $client->addSubscriber(LogPlugin::getDebugPlugin()); diff --git a/vendor/guzzle/guzzle/docs/plugins/md5-validator-plugin.rst b/vendor/guzzle/guzzle/docs/plugins/md5-validator-plugin.rst new file mode 100644 index 0000000..1b1cfa8 --- /dev/null +++ b/vendor/guzzle/guzzle/docs/plugins/md5-validator-plugin.rst @@ -0,0 +1,29 @@ +==================== +MD5 validator plugin +==================== + +Entity bodies can sometimes be modified over the wire due to a faulty TCP transport or misbehaving proxy. If an HTTP +response contains a Content-MD5 header, then a MD5 hash of the entity body of a response can be compared against the +Content-MD5 header of the response to determine if the response was delivered intact. The +``Guzzle\Plugin\Md5\Md5ValidatorPlugin`` will throw an ``UnexpectedValueException`` if the calculated MD5 hash does +not match the Content-MD5 header value: + +.. code-block:: php + + use Guzzle\Http\Client; + use Guzzle\Plugin\Md5\Md5ValidatorPlugin; + + $client = new Client('http://www.test.com/'); + + $md5Plugin = new Md5ValidatorPlugin(); + + // Add the md5 plugin to the client object + $client->addSubscriber($md5Plugin); + + $request = $client->get('http://www.yahoo.com/'); + $request->send(); + +Calculating the MD5 hash of a large entity body or an entity body that was transferred using a Content-Encoding is an +expensive operation. When working in high performance applications, you might consider skipping the MD5 hash +validation for entity bodies bigger than a certain size or Content-Encoded entity bodies +(see ``Guzzle\Plugin\Md5\Md5ValidatorPlugin`` for more information). diff --git a/vendor/guzzle/guzzle/docs/plugins/mock-plugin.rst b/vendor/guzzle/guzzle/docs/plugins/mock-plugin.rst new file mode 100644 index 0000000..4900cb5 --- /dev/null +++ b/vendor/guzzle/guzzle/docs/plugins/mock-plugin.rst @@ -0,0 +1,27 @@ +=========== +Mock plugin +=========== + +The mock plugin is useful for testing Guzzle clients. The mock plugin allows you to queue an array of responses that +will satisfy requests sent from a client by consuming the request queue in FIFO order. + +.. code-block:: php + + use Guzzle\Http\Client; + use Guzzle\Plugin\Mock\MockPlugin; + use Guzzle\Http\Message\Response; + + $client = new Client('http://www.test.com/'); + + $mock = new MockPlugin(); + $mock->addResponse(new Response(200)) + ->addResponse(new Response(404)); + + // Add the mock plugin to the client object + $client->addSubscriber($mock); + + // The following request will receive a 200 response from the plugin + $client->get('http://www.example.com/')->send(); + + // The following request will receive a 404 response from the plugin + $client->get('http://www.test.com/')->send(); diff --git a/vendor/guzzle/guzzle/docs/plugins/oauth-plugin.rst b/vendor/guzzle/guzzle/docs/plugins/oauth-plugin.rst new file mode 100644 index 0000000..e67eaba --- /dev/null +++ b/vendor/guzzle/guzzle/docs/plugins/oauth-plugin.rst @@ -0,0 +1,30 @@ +============ +OAuth plugin +============ + +Guzzle ships with an OAuth 1.0 plugin that can sign requests using a consumer key, consumer secret, OAuth token, +and OAuth secret. Here's an example showing how to send an authenticated request to the Twitter REST API: + +.. code-block:: php + + use Guzzle\Http\Client; + use Guzzle\Plugin\Oauth\OauthPlugin; + + $client = new Client('http://api.twitter.com/1'); + $oauth = new OauthPlugin(array( + 'consumer_key' => 'my_key', + 'consumer_secret' => 'my_secret', + 'token' => 'my_token', + 'token_secret' => 'my_token_secret' + )); + $client->addSubscriber($oauth); + + $response = $client->get('statuses/public_timeline.json')->send(); + +If you need to use a custom signing method, you can pass a ``signature_method`` configuration option in the +constructor of the OAuth plugin. The ``signature_method`` option must be a callable variable that accepts a string to +sign and signing key and returns a signed string. + +.. note:: + + You can omit the ``token`` and ``token_secret`` options to use two-legged OAuth. diff --git a/vendor/guzzle/guzzle/docs/plugins/plugins-list.rst.inc b/vendor/guzzle/guzzle/docs/plugins/plugins-list.rst.inc new file mode 100644 index 0000000..8d6d09b --- /dev/null +++ b/vendor/guzzle/guzzle/docs/plugins/plugins-list.rst.inc @@ -0,0 +1,9 @@ +* :doc:`/plugins/async-plugin` +* :doc:`/plugins/backoff-plugin` +* :doc:`/plugins/cache-plugin` +* :doc:`/plugins/cookie-plugin` +* :doc:`/plugins/history-plugin` +* :doc:`/plugins/log-plugin` +* :doc:`/plugins/md5-validator-plugin` +* :doc:`/plugins/mock-plugin` +* :doc:`/plugins/oauth-plugin` diff --git a/vendor/guzzle/guzzle/docs/plugins/plugins-overview.rst b/vendor/guzzle/guzzle/docs/plugins/plugins-overview.rst new file mode 100644 index 0000000..19ae57e --- /dev/null +++ b/vendor/guzzle/guzzle/docs/plugins/plugins-overview.rst @@ -0,0 +1,59 @@ +====================== +Plugin system overview +====================== + +The workflow of sending a request and parsing a response is driven by Guzzle's event system, which is powered by the +`Symfony2 Event Dispatcher component `_. + +Any object in Guzzle that emits events will implement the ``Guzzle\Common\HasEventDispatcher`` interface. You can add +event subscribers directly to these objects using the ``addSubscriber()`` method, or you can grab the +``Symfony\Component\EventDispatcher\EventDispatcher`` object owned by the object using ``getEventDispatcher()`` and +add a listener or event subscriber. + +Adding event subscribers to clients +----------------------------------- + +Any event subscriber or event listener attached to the EventDispatcher of a ``Guzzle\Http\Client`` or +``Guzzle\Service\Client`` object will automatically be attached to all request objects created by the client. This +allows you to attach, for example, a HistoryPlugin to a client object, and from that point on, every request sent +through that client will utilize the HistoryPlugin. + +.. code-block:: php + + use Guzzle\Plugin\History\HistoryPlugin; + use Guzzle\Service\Client; + + $client = new Client(); + + // Create a history plugin and attach it to the client + $history = new HistoryPlugin(); + $client->addSubscriber($history); + + // Create and send a request. This request will also utilize the HistoryPlugin + $client->get('http://httpbin.org')->send(); + + // Echo out the last sent request by the client + echo $history->getLastRequest(); + +.. tip:: + + :doc:`Create event subscribers `, or *plugins*, to implement reusable logic that can be + shared across clients. Event subscribers are also easier to test than anonymous functions. + +Pre-Built plugins +----------------- + +Guzzle provides easy to use request plugins that add behavior to requests based on signal slot event notifications +powered by the Symfony2 Event Dispatcher component. + +* :doc:`async-plugin` +* :doc:`backoff-plugin` +* :doc:`cache-plugin` +* :doc:`cookie-plugin` +* :doc:`curl-auth-plugin` +* :doc:`history-plugin` +* :doc:`log-plugin` +* :doc:`md5-validator-plugin` +* :doc:`mock-plugin` +* :doc:`oauth-plugin` + diff --git a/vendor/guzzle/guzzle/docs/requirements.txt b/vendor/guzzle/guzzle/docs/requirements.txt new file mode 100644 index 0000000..f62e318 --- /dev/null +++ b/vendor/guzzle/guzzle/docs/requirements.txt @@ -0,0 +1,2 @@ +Sphinx>=1.2b1 +guzzle_sphinx_theme>=0.5.0 diff --git a/vendor/guzzle/guzzle/docs/testing/unit-testing.rst b/vendor/guzzle/guzzle/docs/testing/unit-testing.rst new file mode 100644 index 0000000..f4297af --- /dev/null +++ b/vendor/guzzle/guzzle/docs/testing/unit-testing.rst @@ -0,0 +1,201 @@ +=========================== +Unit Testing Guzzle clients +=========================== + +Guzzle provides several tools that will enable you to easily unit test your web service clients. + +* PHPUnit integration +* Mock responses +* node.js web server for integration testing + +PHPUnit integration +------------------- + +Guzzle is unit tested using `PHPUnit `_. Your web service client's unit tests should extend +``Guzzle\Tests\GuzzleTestCase`` so that you can take advantage of some of the built in helpers. + +In order to unit test your client, a developer would need to copy phpunit.xml.dist to phpunit.xml and make any needed +modifications. As a best practice and security measure for you and your contributors, it is recommended to add an +ignore statement to your SCM so that phpunit.xml is ignored. + +Bootstrapping +~~~~~~~~~~~~~ + +Your web service client should have a tests/ folder that contains a bootstrap.php file. The bootstrap.php file +responsible for autoloading and configuring a ``Guzzle\Service\Builder\ServiceBuilder`` that is used throughout your +unit tests for loading a configured client. You can add custom parameters to your phpunit.xml file that expects users +to provide the path to their configuration data. + +.. code-block:: php + + Guzzle\Tests\GuzzleTestCase::setServiceBuilder(Aws\Common\Aws::factory($_SERVER['CONFIG'])); + + Guzzle\Tests\GuzzleTestCase::setServiceBuilder(Guzzle\Service\Builder\ServiceBuilder::factory(array( + 'test.unfuddle' => array( + 'class' => 'Guzzle.Unfuddle.UnfuddleClient', + 'params' => array( + 'username' => 'test_user', + 'password' => '****', + 'subdomain' => 'test' + ) + ) + ))); + +The above code registers a service builder that can be used throughout your unit tests. You would then be able to +retrieve an instantiated and configured Unfuddle client by calling ``$this->getServiceBuilder()->get('test.unfuddle)``. +The above code assumes that ``$_SERVER['CONFIG']`` contains the path to a file that stores service description +configuration. + +Unit testing remote APIs +------------------------ + +Mock responses +~~~~~~~~~~~~~~ + +One of the benefits of unit testing is the ability to quickly determine if there are errors in your code. If your +unit tests run slowly, then they become tedious and will likely be run less frequently. Guzzle's philosophy on unit +testing web service clients is that no network access should be required to run the unit tests. This means that +responses are served from mock responses or local servers. By adhering to this principle, tests will run much faster +and will not require an external resource to be available. The problem with this approach is that your mock responses +must first be gathered and then subsequently updated each time the remote API changes. + +Integration testing over the internet +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +You can perform integration testing with a web service over the internet by making calls directly to the service. If +the web service you are requesting uses a complex signing algorithm or some other specific implementation, then you +may want to include at least one actual network test that can be run specifically through the command line using +`PHPUnit group annotations `_. + +@group internet annotation +^^^^^^^^^^^^^^^^^^^^^^^^^^ + +When creating tests that require an internet connection, it is recommended that you add ``@group internet`` annotations +to your unit tests to specify which tests require network connectivity. + +You can then `run PHPUnit tests `_ that exclude the @internet +group by running ``phpunit --exclude-group internet``. + +API credentials +^^^^^^^^^^^^^^^ + +If API credentials are required to run your integration tests, you must add ```` parameters to your +phpunit.xml.dist file and extract these parameters in your bootstrap.php file. + +.. code-block:: xml + + + + + + + + + + + + + ./Tests + + + + +You can then extract the ``server`` variables in your bootstrap.php file by grabbing them from the ``$_SERVER`` +superglobal: ``$apiUser = $_SERVER['API_USER'];`` + +Further reading +^^^^^^^^^^^^^^^ + +A good discussion on the topic of testing remote APIs can be found in Sebastian Bergmann's +`Real-World Solutions for Developing High-Quality PHP Frameworks and Applications `_. + +Queueing Mock responses +----------------------- + +Mock responses can be used to test if requests are being generated correctly and responses and handled correctly by +your client. Mock responses can be queued up for a client using the ``$this->setMockResponse($client, $path)`` method +of your test class. Pass the client you are adding mock responses to and a single path or array of paths to mock +response files relative to the ``/tests/mock/ folder``. This will queue one or more mock responses for your client by +creating a simple observer on the client. Mock response files must contain a full HTTP response message: + +.. code-block:: none + + HTTP/1.1 200 OK + Date: Wed, 25 Nov 2009 12:00:00 GMT + Connection: close + Server: AmazonS3 + Content-Type: application/xml + + + EU + +After queuing mock responses for a client, you can get an array of the requests that were sent by the client that +were issued a mock response by calling ``$this->getMockedRequests()``. + +You can also use the ``Guzzle\Plugin\Mock\MockPlugin`` object directly with your clients. + +.. code-block:: php + + $plugin = new Guzzle\Plugin\Mock\MockPlugin(); + $plugin->addResponse(new Guzzle\Http\Message\Response(200)); + $client = new Guzzle\Http\Client(); + $client->addSubscriber($plugin); + + // The following request will get the mock response from the plugin in FIFO order + $request = $client->get('http://www.test.com/'); + $request->send(); + + // The MockPlugin maintains a list of requests that were mocked + $this->assertContainsOnly($request, $plugin->getReceivedRequests()); + +node.js web server for integration testing +------------------------------------------ + +Using mock responses is usually enough when testing a web service client. If your client needs to add custom cURL +options to requests, then you should use the node.js test web server to ensure that your HTTP request message is +being created correctly. + +Guzzle is based around PHP's libcurl bindings. cURL sometimes modifies an HTTP request message based on +``CURLOPT_*`` options. Headers that are added to your request by cURL will not be accounted for if you inject mock +responses into your tests. Additionally, some request entity bodies cannot be loaded by the client before transmitting +it to the sever (for example, when using a client as a sort of proxy and streaming content from a remote server). You +might also need to inspect the entity body of a ``multipart/form-data`` POST request. + +.. note:: + + You can skip all of the tests that require the node.js test web server by excluding the ``server`` group: + ``phpunit --exclude-group server`` + +Using the test server +~~~~~~~~~~~~~~~~~~~~~ + +The node.js test server receives requests and returns queued responses. The test server exposes a simple API that is +used to enqueue responses and inspect the requests that it has received. + +Retrieve the server object by calling ``$this->getServer()``. If the node.js server is not running, it will be +started as a forked process and an object that interfaces with the server will be returned. (note: stopping the +server is handled internally by Guzzle.) + +You can queue an HTTP response or an array of responses by calling ``$this->getServer()->enqueue()``: + +.. code-block:: php + + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n"); + +The above code queues a single 200 response with an empty body. Responses are queued using a FIFO order; this +response will be returned by the server when it receives the first request and then removed from the queue. If a +request is received by a server with no queued responses, an exception will be thrown in your unit test. + +You can inspect the requests that the server has retrieved by calling ``$this->getServer()->getReceivedRequests()``. +This method accepts an optional ``$hydrate`` parameter that specifies if you are retrieving an array of string HTTP +requests or an array of ``Guzzle\Http\RequestInterface`` subclassed objects. "Hydrating" the requests will allow +greater flexibility in your unit tests so that you can easily assert the state of the various parts of a request. + +You will need to modify the base_url of your web service client in order to use it against the test server. + +.. code-block:: php + + $client = $this->getServiceBuilder()->get('my_client'); + $client->setBaseUrl($this->getServer()->getUrl()); + +After running the above code, all calls made from the ``$client`` object will be sent to the test web server. diff --git a/vendor/guzzle/guzzle/docs/webservice-client/guzzle-service-descriptions.rst b/vendor/guzzle/guzzle/docs/webservice-client/guzzle-service-descriptions.rst new file mode 100644 index 0000000..a91b69c --- /dev/null +++ b/vendor/guzzle/guzzle/docs/webservice-client/guzzle-service-descriptions.rst @@ -0,0 +1,619 @@ +=========================== +Guzzle service descriptions +=========================== + +Guzzle allows you to serialize HTTP requests and parse HTTP responses using a DSL called a service descriptions. +Service descriptions define web service APIs by documenting each operation, the operation's parameters, validation +options for each parameter, an operation's response, how the response is parsed, and any errors that can be raised for +an operation. Writing a service description for a web service allows you to more quickly consume a web service than +writing concrete commands for each web service operation. + +Guzzle service descriptions can be representing using a PHP array or JSON document. Guzzle's service descriptions are +heavily inspired by `Swagger `_. + +Service description schema +========================== + +A Guzzle Service description must match the following JSON schema document. This document can also serve as a guide when +implementing a Guzzle service description. + +Download the schema here: :download:`Guzzle JSON schema document ` + +.. class:: overflow-height-500px + + .. literalinclude:: ../_downloads/guzzle-schema-1.0.json + :language: json + +Top-level attributes +-------------------- + +Service descriptions are comprised of the following top-level attributes: + +.. code-block:: json + + { + "name": "string", + "apiVersion": "string|number", + "baseUrl": "string", + "description": "string", + "operations": {}, + "models": {}, + "includes": ["string.php", "string.json"] + } + ++-----------------------------------------+-------------------------+-----------------------------------------------------------------------------------------------------------------------+ +| Property Name | Value | Description | ++=========================================+=========================+=======================================================================================================================+ +| name | string | Name of the web service | ++-----------------------------------------+-------------------------+-----------------------------------------------------------------------------------------------------------------------+ +| apiVersion | string|number | Version identifier that the service description is compatible with | ++-----------------------------------------+-------------------------+-----------------------------------------------------------------------------------------------------------------------+ +| baseUrl or basePath | string | Base URL of the web service. Any relative URI specified in an operation will be merged with the baseUrl using the | +| | | process defined in RFC 2396. Some clients require custom logic to determine the baseUrl. In those cases, it is best | +| | | to not include a baseUrl in the service description, but rather allow the factory method of the client to configure | +| | | the client’s baseUrl. | ++-----------------------------------------+-------------------------+-----------------------------------------------------------------------------------------------------------------------+ +| description | string | Short summary of the web service | ++-----------------------------------------+-------------------------+-----------------------------------------------------------------------------------------------------------------------+ +| operations | object containing | Operations of the service. The key is the name of the operation and value is the attributes of the operation. | +| | :ref:`operation-schema` | | +| | | | ++-----------------------------------------+-------------------------+-----------------------------------------------------------------------------------------------------------------------+ +| models | object containing | Schema models that can be referenced throughout the service description. Models can be used to define how an HTTP | +| | :ref:`model-schema` | response is parsed into a ``Guzzle\Service\Resource\Model`` object when an operation uses a ``model`` ``responseType``| ++-----------------------------------------+-------------------------+-----------------------------------------------------------------------------------------------------------------------+ +| includes | array of .js, | Service description files to include and extend from (can be a .json, .js, or .php file) | +| | .json, or .php | | +| | files. | | ++-----------------------------------------+-------------------------+-----------------------------------------------------------------------------------------------------------------------+ +| (any additional properties) | mixed | Any additional properties specified as top-level attributes are allowed and will be treated as arbitrary data | ++-----------------------------------------+-------------------------+-----------------------------------------------------------------------------------------------------------------------+ + +.. _operation-schema: + +Operations +---------- + +Operations are the actions that can be taken on a service. Each operation is given a unique name and has a distinct +endpoint and HTTP method. If an API has a ``DELETE /users/:id`` operation, a satisfactory operation name might be +``DeleteUser`` with a parameter of ``id`` that is inserted into the URI. + +.. class:: overflow-height-250px + + .. code-block:: json + + { + "operations": { + "operationName": { + "extends": "string", + "httpMethod": "GET|POST|PUT|DELETE|PATCH|string", + "uri": "string", + "summary": "string", + "class": "string", + "responseClass": "string", + "responseNotes": "string", + "type": "string", + "description": "string", + "responseType": "primitive|class|(model by name)|documentation|(string)", + "deprecated": false, + "errorResponses": [ + { + "code": 500, + "phrase": "Unexpected Error", + "class": "string" + } + ], + "data": { + "foo": "bar", + "baz": "bam" + }, + "parameters": {} + } + } + } + +.. csv-table:: + :header: "Property Name", "Value", "Description" + :widths: 20, 15, 65 + + "extends", "string", "Extend from another operation by name. The parent operation must be defined before the child." + "httpMethod", "string", "HTTP method used with the operation (e.g. GET, POST, PUT, DELETE, PATCH, etc)" + "uri", "string", "URI of the operation. The uri attribute can contain URI templates. The variables of the URI template are parameters of the operation with a location value of uri" + "summary", "string", "Short summary of what the operation does" + "class", "string", "Custom class to instantiate instead of the default Guzzle\\Service\\Command\\OperationCommand. Using this attribute allows you to define an operation using a service description, but allows more customized logic to be implemented in user-land code." + "responseClass", "string", "Defined what is returned from the method. Can be a primitive, class name, or model name. You can specify the name of a class to return a more customized result from the operation (for example, a domain model object). When using the name of a PHP class, the class must implement ``Guzzle\Service\Command\ResponseClassInterface``." + "responseNotes", "string", "A description of the response returned by the operation" + "responseType", "string", "The type of response that the operation creates: 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 class name is found, or set to 'primitive' by default." + "deprecated", "boolean", "Whether or not the operation is deprecated" + "errorResponses", "array", "Errors that could occur while executing the operation. Each item of the array is an object that can contain a 'code' (HTTP response status code of the error), 'phrase' (reason phrase or description of the error), and 'class' (an exception class that will be raised when this error is encountered)" + "data", "object", "Any arbitrary data to associate with the operation" + "parameters", "object containing :ref:`parameter-schema` objects", "Parameters of the operation. Parameters are used to define how input data is serialized into a HTTP request." + "additionalParameters", "A single :ref:`parameter-schema` object", "Validation and serialization rules for any parameter supplied to the operation that was not explicitly defined." + +additionalParameters +~~~~~~~~~~~~~~~~~~~~ + +When a webservice offers a large number of parameters that all are set in the same location (for example the query +string or a JSON document), defining each parameter individually can require a lot of time and repetition. Furthermore, +some web services allow for completely arbitrary parameters to be supplied for an operation. The +``additionalParameters`` attribute can be used to solve both of these issues. + +As an example, we can define a Twitter API operation quite easily using ``additionalParameters``. The +GetMentions operation accepts a large number of query string parameters. Defining each of these parameters +is ideal because it provide much more introspection for the client and opens the possibility to use the description with +other tools (e.g. a documentation generator). However, you can very quickly provide a "catch-all" serialization rule +that will place any custom parameters supplied to an operation the generated request's query string parameters. + +.. class:: overflow-height-250px + + .. code-block:: json + + { + "name": "Twitter", + "apiVersion": "1.1", + "baseUrl": "https://api.twitter.com/1.1", + "operations": { + "GetMentions": { + "httpMethod": "GET", + "uri": "statuses/mentions_timeline.json", + "responseClass": "GetMentionsOutput", + "additionalParameters": { + "location": "query" + } + } + }, + "models": { + "GetMentionsOutput": { + "type": "object", + "additionalProperties": { + "location": "json" + } + } + } + } + +responseClass +~~~~~~~~~~~~~ + +The ``responseClass`` attribute is used to define the return value of an operation (what is returned by calling the +``getResult()`` method of a command object). The value set in the responseClass attribute can be one of "primitive" +(meaning the result with be primitive type like a string), a class name meaning the result will be an instance of a +specific user-land class, or a model name meaning the result will be a ``Guzzle\Service\Resource\Model`` object that +uses a :ref:`model schema ` to define how the HTTP response is parsed. + +.. note:: + + Using a class name with a ``responseClass`` will only work if it is supported by the ``class`` that is instantiated + for the operation. Keep this in mind when specifying a custom ``class`` attribute that points to a custom + ``Guzzle\Service\Command\CommandInterface`` class. The default ``class``, + ``Guzzle\Service\Command\OperationCommand``, does support setting custom ``class`` attributes. + +You can specify the name of a class to return a more customized result from the operation (for example, a domain model +object). When using the name of a PHP class, the class must implement ``Guzzle\Service\Command\ResponseClassInterface``. +Here's a very simple example of implementing a custom responseClass object. + +.. code-block:: json + + { + "operations": { + "test": { + "responseClass": "MyApplication\\User" + } + } + } + +.. code-block:: php + + namespace MyApplication; + + use Guzzle\Service\Command\ResponseClassInterface; + use Guzzle\Service\Command\OperationCommand; + + class User implements ResponseClassInterface + { + protected $name; + + public static function fromCommand(OperationCommand $command) + { + $response = $command->getResponse(); + $xml = $response->xml(); + + return new self((string) $xml->name); + } + + public function __construct($name) + { + $this->name = $name; + } + } + +errorResponses +~~~~~~~~~~~~~~ + +``errorResponses`` is an array containing objects that define the errors that could occur while executing the +operation. Each item of the array is an object that can contain a 'code' (HTTP response status code of the error), +'phrase' (reason phrase or description of the error), and 'class' (an exception class that will be raised when this +error is encountered). + +ErrorResponsePlugin +^^^^^^^^^^^^^^^^^^^ + +Error responses are by default only used for documentation. If you don't need very complex exception logic for your web +service errors, then you can use the ``Guzzle\Plugin\ErrorResponse\ErrorResponsePlugin`` to automatically throw defined +exceptions when one of the ``errorResponse`` rules are matched. The error response plugin will listen for the +``request.complete`` event of a request created by a command object. Every response (including a successful response) is +checked against the list of error responses for an exact match using the following order of checks: + +1. Does the errorResponse have a defined ``class``? +2. Is the errorResponse ``code`` equal to the status code of the response? +3. Is the errorResponse ``phrase`` equal to the reason phrase of the response? +4. Throw the exception stored in the ``class`` attribute of the errorResponse. + +The ``class`` attribute must point to a class that implements +``Guzzle\Plugin\ErrorResponse\ErrorResponseExceptionInterface``. This interface requires that an error response class +implements ``public static function fromCommand(CommandInterface $command, Response $response)``. This method must +return an object that extends from ``\Exception``. After an exception is returned, it is thrown by the plugin. + +.. _parameter-schema: + +Parameter schema +---------------- + +Parameters in both operations and models are represented using the +`JSON schema `_ syntax. + +.. csv-table:: + :header: "Property Name", "Value", "Description" + :widths: 20, 15, 65 + + "name", "string", "Unique name of the parameter" + "type", "string|array", "Type of variable (string, number, integer, boolean, object, array, numeric, null, any). Types are using for validation and determining the structure of a parameter. You can use a union type by providing an array of simple types. If one of the union types matches the provided value, then the value is valid." + "instanceOf", "string", "When the type is an object, you can specify the class that the object must implement" + "required", "boolean", "Whether or not the parameter is required" + "default", "mixed", "Default value to use if no value is supplied" + "static", "boolean", "Set to true to specify that the parameter value cannot be changed from the default setting" + "description", "string", "Documentation of the parameter" + "location", "string", "The location of a request used to apply a parameter. Custom locations can be registered with a command, but the defaults are uri, query, statusCode, reasonPhrase, header, body, json, xml, postField, postFile, responseBody" + "sentAs", "string", "Specifies how the data being modeled is sent over the wire. For example, you may wish to include certain headers in a response model that have a normalized casing of FooBar, but the actual header is x-foo-bar. In this case, sentAs would be set to x-foo-bar." + "filters", "array", "Array of functions to to run a parameter value through." + +filters +~~~~~~~ + +Each value in the array must be a string containing the full class path to a static method or an array of complex +filter information. You can specify static methods of classes using the full namespace class name followed by +"::" (e.g. ``FooBar::baz()``). Some filters require arguments in order to properly filter a value. For complex filters, +use an object containing a ``method`` attribute pointing to a function, and an ``args`` attribute containing an +array of positional arguments to pass to the function. Arguments can contain keywords that are replaced when filtering +a value: ``@value`` is replaced with the value being filtered, and ``@api`` is replaced with the actual Parameter +object. + +.. code-block:: json + + { + "filters": [ + "strtolower", + { + "method": "MyClass::convertString", + "args": [ "test", "@value", "@api" ] + } + ] + } + +The above example will filter a parameter using ``strtolower``. It will then call the ``convertString`` static method +of ``MyClass``, passing in "test", the actual value of the parameter, and a ``Guzzle\Service\Description\Parameter`` +object. + +Operation parameter location attributes +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +The location field of top-level parameters control how a parameter is serialized when generating a request. + +uri location +^^^^^^^^^^^^ + +Parameters are injected into the ``uri`` attribute of the operation using +`URI-template expansion `_. + +.. code-block:: json + + { + "operations": { + "uriTest": { + "uri": "/test/{testValue}", + "parameters": { + "testValue": { + "location": "uri" + } + } + } + } + } + +query location +^^^^^^^^^^^^^^ + +Parameters are injected into the query string of a request. Query values can be nested, which would result in a PHP +style nested query string. The name of a parameter is the default name of the query string parameter added to the +request. You can override this behavior by specifying the ``sentAs`` attribute on the parameter. + +.. code-block:: json + + { + "operations": { + "queryTest": { + "parameters": { + "testValue": { + "location": "query", + "sentAs": "test_value" + } + } + } + } + } + +header location +^^^^^^^^^^^^^^^ + +Parameters are injected as headers on an HTTP request. The name of the parameter is used as the name of the header by +default. You can change the name of the header created by the parameter using the ``sentAs`` attribute. + +Headers that are of type ``object`` will be added as multiple headers to a request using the key of the input array as +the header key. Setting a ``sentAs`` attribute along with a type ``object`` will use the value of ``sentAs`` as a +prefix for each header key. + +body location +^^^^^^^^^^^^^ + +Parameters are injected as the body of a request. The input of these parameters may be anything that can be cast to a +string or a ``Guzzle\Http\EntityBodyInterface`` object. + +postField location +^^^^^^^^^^^^^^^^^^ + +Parameters are inserted as POST fields in a request. Nested values may be supplied and will be represented using +PHP style nested query strings. The POST field name is the same as the parameter name by default. You can use the +``sentAs`` parameter to override the POST field name. + +postFile location +^^^^^^^^^^^^^^^^^ + +Parameters are added as POST files. A postFile value may be a string pointing to a local filename or a +``Guzzle\Http\Message\PostFileInterface`` object. The name of the POST file will be the name of the parameter by +default. You can use a custom POST file name by using the ``sentAs`` attribute. + +Supports "string" and "array" types. + +json location +^^^^^^^^^^^^^ + +Parameters are added to the body of a request as top level keys of a JSON document. Nested values may be specified, +with any number of nested ``Guzzle\Common\ToArrayInterface`` objects. When JSON parameters are specified, the +``Content-Type`` of the request will change to ``application/json`` if a ``Content-Type`` has not already been specified +on the request. + +xml location +^^^^^^^^^^^^ + +Parameters are added to the body of a request as top level nodes of an XML document. Nested values may be specified, +with any number of nested ``Guzzle\Common\ToArrayInterface`` objects. When XML parameters are specified, the +``Content-Type`` of the request will change to ``application/xml`` if a ``Content-Type`` has not already been specified +on the request. + +responseBody location +^^^^^^^^^^^^^^^^^^^^^ + +Specifies the EntityBody of a response. This can be used to download the response body to a file or a custom Guzzle +EntityBody object. + +No location +^^^^^^^^^^^ + +If a parameter has no location attribute, then the parameter is simply used as a data value. + +Other locations +^^^^^^^^^^^^^^^ + +Custom locations can be registered as new locations or override default locations if needed. + +.. _model-schema: + +Model Schema +------------ + +Models are used in service descriptions to provide generic JSON schema definitions that can be extended from or used in +``$ref`` attributes. Models can also be referenced in a ``responseClass`` attribute to provide valuable output to an +operation. Models are JSON schema documents and use the exact syntax and attributes used in parameters. + +Response Models +~~~~~~~~~~~~~~~ + +Response models describe how a response is parsed into a ``Guzzle\Service\Resource\Model`` object. Response models are +always modeled as JSON schema objects. When an HTTP response is parsed using a response model, the rules specified on +each property of a response model will translate 1:1 as keys in a PHP associative array. When a ``sentAs`` attribute is +found in response model parameters, the value retrieved from the HTTP response is retrieved using the ``sentAs`` +parameter but stored in the response model using the name of the parameter. + +The location field of top-level parameters in a response model tell response parsers how data is retrieved from a +response. + +statusCode location +^^^^^^^^^^^^^^^^^^^ + +Retrieves the status code of the response. + +reasonPhrase location +^^^^^^^^^^^^^^^^^^^^^ + +Retrieves the reason phrase of the response. + +header location +^^^^^^^^^^^^^^^ + +Retrieves a header from the HTTP response. + +body location +^^^^^^^^^^^^^ + +Retrieves the body of an HTTP response. + +json location +^^^^^^^^^^^^^ + +Retrieves a top-level parameter from a JSON document contained in an HTTP response. + +You can use ``additionalProperties`` if the JSON document is wrapped in an outer array. This allows you to parse the +contents of each item in the array using the parsing rules defined in the ``additionalProperties`` schema. + +xml location +^^^^^^^^^^^^ + +Retrieves a top-level node value from an XML document contained in an HTTP response. + +Other locations +^^^^^^^^^^^^^^^ + +Custom locations can be registered as new locations or override default locations if needed. + +Example service description +--------------------------- + +Let's say you're interacting with a web service called 'Foo' that allows for the following routes and methods:: + + GET/POST /users + GET/DELETE /users/:id + +The following JSON service description implements this simple web service: + +.. class:: overflow-height-500px + + .. code-block:: json + + { + "name": "Foo", + "apiVersion": "2012-10-14", + "baseUrl": "http://api.foo.com", + "description": "Foo is an API that allows you to Baz Bar", + "operations": { + "GetUsers": { + "httpMethod": "GET", + "uri": "/users", + "summary": "Gets a list of users", + "responseClass": "GetUsersOutput" + }, + "CreateUser": { + "httpMethod": "POST", + "uri": "/users", + "summary": "Creates a new user", + "responseClass": "CreateUserOutput", + "parameters": { + "name": { + "location": "json", + "type": "string" + }, + "age": { + "location": "json", + "type": "integer" + } + } + }, + "GetUser": { + "httpMethod": "GET", + "uri": "/users/{id}", + "summary": "Retrieves a single user", + "responseClass": "GetUserOutput", + "parameters": { + "id": { + "location": "uri", + "description": "User to retrieve by ID", + "required": true + } + } + }, + "DeleteUser": { + "httpMethod": "DELETE", + "uri": "/users/{id}", + "summary": "Deletes a user", + "responseClass": "DeleteUserOutput", + "parameters": { + "id": { + "location": "uri", + "description": "User to delete by ID", + "required": true + } + } + } + }, + "models": { + "GetUsersOutput": { + "type": "array", + "items": { + "type": "object", + "properties": { + "name": { + "location": "json", + "type": "string" + }, + "age": { + "location": "json", + "type": "integer" + } + } + } + }, + "CreateUserOutput": { + "type": "object", + "properties": { + "id": { + "location": "json", + "type": "string" + }, + "location": { + "location": "header", + "sentAs": "Location", + "type": "string" + } + } + }, + "GetUserOutput": { + "type": "object", + "properties": { + "name": { + "location": "json", + "type": "string" + }, + "age": { + "location": "json", + "type": "integer" + } + } + }, + "DeleteUserOutput": { + "type": "object", + "properties": { + "status": { + "location": "statusCode", + "type": "integer" + } + } + } + } + } + +If you attach this service description to a client, you would completely configure the client to interact with the +Foo web service and provide valuable response models for each operation. + +.. code-block:: php + + use Guzzle\Service\Description\ServiceDescription; + + $description = ServiceDescription::factory('/path/to/client.json'); + $client->setDescription($description); + + $command = $client->getCommand('DeleteUser', array('id' => 123)); + $responseModel = $client->execute($command); + echo $responseModel['status']; + +.. note:: + + You can add the service description to your client's factory method or constructor. diff --git a/vendor/guzzle/guzzle/docs/webservice-client/using-the-service-builder.rst b/vendor/guzzle/guzzle/docs/webservice-client/using-the-service-builder.rst new file mode 100644 index 0000000..b7113d6 --- /dev/null +++ b/vendor/guzzle/guzzle/docs/webservice-client/using-the-service-builder.rst @@ -0,0 +1,316 @@ +======================= +Using a service builder +======================= + +The best way to instantiate Guzzle web service clients is to let Guzzle handle building the clients for you using a +ServiceBuilder. A ServiceBuilder is responsible for creating concrete client objects based on configuration settings +and helps to manage credentials for different environments. + +You don't have to use a service builder, but they help to decouple your application from concrete classes and help to +share configuration data across multiple clients. Consider the following example. Here we are creating two clients that +require the same API public key and secret key. The clients are created using their ``factory()`` methods. + +.. code-block:: php + + use MyService\FooClient; + use MyService\BarClient; + + $foo = FooClient::factory(array( + 'key' => 'abc', + 'secret' => '123', + 'custom' => 'and above all' + )); + + $bar = BarClient::factory(array( + 'key' => 'abc', + 'secret' => '123', + 'custom' => 'listen to me' + )); + +The redundant specification of the API keys can be removed using a service builder. + +.. code-block:: php + + use Guzzle\Service\Builder\ServiceBuilder; + + $builder = ServiceBuilder::factory(array( + 'services' => array( + 'abstract_client' => array( + 'params' => array( + 'key' => 'abc', + 'secret' => '123' + ) + ), + 'foo' => array( + 'extends' => 'abstract_client', + 'class' => 'MyService\FooClient', + 'params' => array( + 'custom' => 'and above all' + ) + ), + 'bar' => array( + 'extends' => 'abstract_client', + 'class' => 'MyService\FooClient', + 'params' => array( + 'custom' => 'listen to me' + ) + ) + ) + )); + + $foo = $builder->get('foo'); + $bar = $builder->get('bar'); + +You can make managing your API keys even easier by saving the service builder configuration in a JSON format in a +.json file. + +Creating a service builder +-------------------------- + +A ServiceBuilder can source information from an array, an PHP include file that returns an array, or a JSON file. + +.. code-block:: php + + use Guzzle\Service\Builder\ServiceBuilder; + + // Source service definitions from a JSON file + $builder = ServiceBuilder::factory('services.json'); + +Sourcing data from an array +~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +Data can be source from a PHP array. The array must contain an associative ``services`` array that maps the name of a +client to the configuration information used by the service builder to create the client. Clients are given names +which are used to identify how a client is retrieved from a service builder. This can be useful for using multiple +accounts for the same service or creating development clients vs. production clients. + +.. code-block:: php + + $services = array( + 'includes' => array( + '/path/to/other/services.json', + '/path/to/other/php_services.php' + ), + 'services' => array( + 'abstract.foo' => array( + 'params' => array( + 'username' => 'foo', + 'password' => 'bar' + ) + ), + 'bar' => array( + 'extends' => 'abstract.foo', + 'class' => 'MyClientClass', + 'params' => array( + 'other' => 'abc' + ) + ) + ) + ); + +A service builder configuration array contains two top-level array keys: + ++------------+---------------------------------------------------------------------------------------------------------+ +| Key | Description | ++============+=========================================================================================================+ +| includes | Array of paths to JSON or PHP include files to include in the configuration. | ++------------+---------------------------------------------------------------------------------------------------------+ +| services | Associative array of defined services that can be created by the service builder. Each service can | +| | contain the following keys: | +| | | +| | +------------+----------------------------------------------------------------------------------------+ | +| | | Key | Description | | +| | +============+========================================================================================+ | +| | | class | The concrete class to instantiate that implements the | | +| | | | ``Guzzle\Common\FromConfigInterface``. | | +| | +------------+----------------------------------------------------------------------------------------+ | +| | | extends | The name of a previously defined service to extend from | | +| | +------------+----------------------------------------------------------------------------------------+ | +| | | params | Associative array of parameters to pass to the factory method of the service it is | | +| | | | instantiated | | +| | +------------+----------------------------------------------------------------------------------------+ | +| | | alias | An alias that can be used in addition to the array key for retrieving a client from | | +| | | | the service builder. | | +| | +------------+----------------------------------------------------------------------------------------+ | ++------------+---------------------------------------------------------------------------------------------------------+ + +The first client defined, ``abstract.foo``, is used as a placeholder of shared configuration values. Any service +extending abstract.foo will inherit its params. As an example, this can be useful when clients share the same username +and password. + +The next client, ``bar``, extends from ``abstract.foo`` using the ``extends`` attribute referencing the client from +which to extend. Additional parameters can be merged into the original service definition when extending a parent +service. + +.. important:: + + Each client that you intend to instantiate must specify a ``class`` attribute that references the full class name + of the client being created. The class referenced in the ``class`` parameter must implement a static ``factory()`` + method that accepts an array or ``Guzzle\Common\Collection`` object and returns an instantiated object. + +Sourcing from a PHP include +~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +You can create service builder configurations using a PHP include file. This can be useful if you wish to take +advantage of an opcode cache like APC to speed up the process of loading and processing the configuration. The PHP +include file is the same format as an array, but you simply create a PHP script that returns an array and save the +file with the .php file extension. + +.. code-block:: php + + '...'); + // Saved as config.php + +This configuration file can then be used with a service builder. + +.. code-block:: php + + $builder = ServiceBuilder::factory('/path/to/config.php'); + +Sourcing from a JSON document +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +You can use JSON documents to serialize your service descriptions. The JSON format uses the exact same structure as +the PHP array syntax, but it's just serialized using JSON. + +.. code-block:: javascript + + { + "includes": ["/path/to/other/services.json", "/path/to/other/php_services.php"], + "services": { + "abstract.foo": { + "params": { + "username": "foo", + "password": "bar" + } + }, + "bar": { + "extends": "abstract.foo", + "class": "MyClientClass", + "params": { + "other": "abc" + } + } + } + } + +Referencing other clients in parameters +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +If one of your clients depends on another client as one of its parameters, you can reference that client by name by +enclosing the client's reference key in ``{}``. + +.. code-block:: javascript + + { + "services": { + "token": { + "class": "My\Token\TokenFactory", + "params": { + "access_key": "xyz" + } + }, + "client": { + "class": "My\Client", + "params": { + "token_client": "{token}", + "version": "1.0" + } + } + } + } + +When ``client`` is constructed by the service builder, the service builder will first create the ``token`` service +and then inject the token service into ``client``'s factory method in the ``token_client`` parameter. + +Retrieving clients from a service builder +----------------------------------------- + +Clients are referenced using a customizable name you provide in your service definition. The ServiceBuilder is a sort +of multiton object-- it will only instantiate a client once and return that client for subsequent retrievals. Clients +are retrieved by name (the array key used in the configuration) or by the ``alias`` setting of a service. + +Here's an example of retrieving a client from your ServiceBuilder: + +.. code-block:: php + + $client = $builder->get('foo'); + + // You can also use the ServiceBuilder object as an array + $client = $builder['foo']; + +Creating throwaway clients +~~~~~~~~~~~~~~~~~~~~~~~~~~ + +You can get a "throwaway" client (a client that is not persisted by the ServiceBuilder) by passing ``true`` in the +second argument of ``ServiceBuilder::get()``. This allows you to create a client that will not be returned by other +parts of your code that use the service builder. Instead of passing ``true``, you can pass an array of configuration +settings that will override the configuration settings specified in the service builder. + +.. code-block:: php + + // Get a throwaway client and overwrite the "custom" setting of the client + $foo = $builder->get('foo', array( + 'custom' => 'in this world there are rules' + )); + +Getting raw configuration settings +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +You can get the raw configuration settings provided to the service builder for a specific service using the +``getData($name)`` method of a service builder. This method will null if the service was not found in the service +builder or an array of configuration settings if the service was found. + +.. code-block:: php + + $data = $builder->getData('foo'); + echo $data['key'] . "\n"; + echo $data['secret'] . "\n"; + echo $data['custom'] . "\n"; + +Adding a plugin to all clients +------------------------------ + +You can add a plugin to all clients created by a service builder using the ``addGlobalPlugin($plugin)`` method of a +service builder and passing a ``Symfony\Component\EventDispatcher\EventSubscriberInterface`` object. The service builder +will then attach each global plugin to every client as it is created. This allows you to, for example, add a LogPlugin +to every request created by a service builder for easy debugging. + +.. code-block:: php + + use Guzzle\Plugin\Log\LogPlugin; + + // Add a debug log plugin to every client as it is created + $builder->addGlobalPlugin(LogPlugin::getDebugPlugin()); + + $foo = $builder->get('foo'); + $foo->get('/')->send(); + // Should output all of the data sent over the wire + +.. _service-builder-events: + +Events emitted from a service builder +------------------------------------- + +A ``Guzzle\Service\Builder\ServiceBuilder`` object emits the following events: + ++-------------------------------+--------------------------------------------+-----------------------------------------+ +| Event name | Description | Event data | ++===============================+============================================+=========================================+ +| service_builder.create_client | Called when a client is created | * client: The created client object | ++-------------------------------+--------------------------------------------+-----------------------------------------+ + +.. code-block:: php + + use Guzzle\Common\Event; + use Guzzle\Service\Builder\ServiceBuilder; + + $builder = ServiceBuilder::factory('/path/to/config.json'); + + // Add an event listener to print out each client client as it is created + $builder->getEventDispatcher()->addListener('service_builder.create_client', function (Event $e) { + echo 'Client created: ' . get_class($e['client']) . "\n"; + }); + + $foo = $builder->get('foo'); + // Should output the class used for the "foo" client diff --git a/vendor/guzzle/guzzle/docs/webservice-client/webservice-client.rst b/vendor/guzzle/guzzle/docs/webservice-client/webservice-client.rst new file mode 100644 index 0000000..7ec771e --- /dev/null +++ b/vendor/guzzle/guzzle/docs/webservice-client/webservice-client.rst @@ -0,0 +1,659 @@ +====================== +The web service client +====================== + +The ``Guzzle\Service`` namespace contains various abstractions that help to make it easier to interact with a web +service API, including commands, service descriptions, and resource iterators. + +In this chapter, we'll build a simple `Twitter API client `_. + +Creating a client +================= + +A class that extends from ``Guzzle\Service\Client`` or implements ``Guzzle\Service\ClientInterface`` must implement a +``factory()`` method in order to be used with a :doc:`service builder `. + +Factory method +-------------- + +You can use the ``factory()`` method of a client directly if you do not need a service builder. + +.. code-block:: php + + use mtdowling\TwitterClient; + + // Create a client and pass an array of configuration data + $twitter = TwitterClient::factory(array( + 'consumer_key' => '****', + 'consumer_secret' => '****', + 'token' => '****', + 'token_secret' => '****' + )); + +.. note:: + + If you'd like to follow along, here's how to get your Twitter API credentials: + + 1. Visit https://dev.twitter.com/apps + 2. Click on an application that you've created + 3. Click on the "OAuth tool" tab + 4. Copy all of the settings under "OAuth Settings" + +Implementing a factory method +----------------------------- + +Creating a client and its factory method is pretty simple. You just need to implement ``Guzzle\Service\ClientInterface`` +or extend from ``Guzzle\Service\Client``. + +.. code-block:: php + + namespace mtdowling; + + use Guzzle\Common\Collection; + use Guzzle\Plugin\Oauth\OauthPlugin; + use Guzzle\Service\Client; + use Guzzle\Service\Description\ServiceDescription; + + /** + * A simple Twitter API client + */ + class TwitterClient extends Client + { + public static function factory($config = array()) + { + // Provide a hash of default client configuration options + $default = array('base_url' => 'https://api.twitter.com/1.1'); + + // The following values are required when creating the client + $required = array( + 'base_url', + 'consumer_key', + 'consumer_secret', + 'token', + 'token_secret' + ); + + // Merge in default settings and validate the config + $config = Collection::fromConfig($config, $default, $required); + + // Create a new Twitter client + $client = new self($config->get('base_url'), $config); + + // Ensure that the OauthPlugin is attached to the client + $client->addSubscriber(new OauthPlugin($config->toArray())); + + return $client; + } + } + +Service Builder +--------------- + +A service builder is used to easily create web service clients, provides a simple configuration driven approach to +creating clients, and allows you to share configuration settings across multiple clients. You can find out more about +Guzzle's service builder in :doc:`using-the-service-builder`. + +.. code-block:: php + + use Guzzle\Service\Builder\ServiceBuilder; + + // Create a service builder and provide client configuration data + $builder = ServiceBuilder::factory('/path/to/client_config.json'); + + // Get the client from the service builder by name + $twitter = $builder->get('twitter'); + +The above example assumes you have JSON data similar to the following stored in "/path/to/client_config.json": + +.. code-block:: json + + { + "services": { + "twitter": { + "class": "mtdowling\\TwitterClient", + "params": { + "consumer_key": "****", + "consumer_secret": "****", + "token": "****", + "token_secret": "****" + } + } + } + } + +.. note:: + + A service builder becomes much more valuable when using multiple web service clients in a single application or + if you need to utilize the same client with varying configuration settings (e.g. multiple accounts). + +Commands +======== + +Commands are a concept in Guzzle that helps to hide the underlying implementation of an API by providing an easy to use +parameter driven object for each action of an API. A command is responsible for accepting an array of configuration +parameters, serializing an HTTP request, and parsing an HTTP response. Following the +`command pattern `_, commands in Guzzle offer a greater level of +flexibility when implementing and utilizing a web service client. + +Executing commands +------------------ + +You must explicitly execute a command after creating a command using the ``getCommand()`` method. A command has an +``execute()`` method that may be called, or you can use the ``execute()`` method of a client object and pass in the +command object. Calling either of these execute methods will return the result value of the command. The result value is +the result of parsing the HTTP response with the ``process()`` method. + +.. code-block:: php + + // Get a command from the client and pass an array of parameters + $command = $twitter->getCommand('getMentions', array( + 'count' => 5 + )); + + // Other parameters can be set on the command after it is created + $command['trim_user'] = false; + + // Execute the command using the command object. + // The result value contains an array of JSON data from the response + $result = $command->execute(); + + // You can retrieve the result of the command later too + $result = $command->getResult(). + +Command object also contains methods that allow you to inspect the HTTP request and response that was utilized with +the command. + +.. code-block:: php + + $request = $command->getRequest(); + $response = $command->getResponse(); + +.. note:: + + The format and notation used to retrieve commands from a client can be customized by injecting a custom command + factory, ``Guzzle\Service\Command\Factory\FactoryInterface``, on the client using ``$client->setCommandFactory()``. + +Executing with magic methods +~~~~~~~~~~~~~~~~~~~~~~~~~~~~ + +When using method missing magic methods with a command, the command will be executed right away and the result of the +command is returned. + +.. code-block:: php + + $jsonData = $twitter->getMentions(array( + 'count' => 5, + 'trim_user' => true + )); + +Creating commands +----------------- + +Commands are created using either the ``getCommand()`` method of a client or a magic missing method of a client. Using +the ``getCommand()`` method allows you to create a command without executing it, allowing for customization of the +command or the request serialized by the command. + +When a client attempts to create a command, it uses the client's ``Guzzle\Service\Command\Factory\FactoryInterface``. +By default, Guzzle will utilize a command factory that first looks for a concrete class for a particular command +(concrete commands) followed by a command defined by a service description (operation commands). We'll learn more about +concrete commands and operation commands later in this chapter. + +.. code-block:: php + + // Get a command from the twitter client. + $command = $twitter->getCommand('getMentions'); + $result = $command->execute(); + +Unless you've skipped ahead, running the above code will throw an exception. + + PHP Fatal error: Uncaught exception 'Guzzle\Common\Exception\InvalidArgumentException' with message + 'Command was not found matching getMentions' + +This exception was thrown because the "getMentions" command has not yet been implemented. Let's implement one now. + +Concrete commands +~~~~~~~~~~~~~~~~~ + +Commands can be created in one of two ways: create a concrete command class that extends +``Guzzle\Service\Command\AbstractCommand`` or +:doc:`create an OperationCommand based on a service description `. The recommended +approach is to use a service description to define your web service, but you can use concrete commands when custom +logic must be implemented for marshaling or unmarshaling a HTTP message. + +Commands are the method in which you abstract away the underlying format of the requests that need to be sent to take +action on a web service. Commands in Guzzle are meant to be built by executing a series of setter methods on a command +object. Commands are only validated right before they are executed. A ``Guzzle\Service\Client`` object is responsible +for executing commands. Commands created for your web service must implement +``Guzzle\Service\Command\CommandInterface``, but it's easier to extend the ``Guzzle\Service\Command\AbstractCommand`` +class, implement the ``build()`` method, and optionally implement the ``process()`` method. + +Serializing requests +^^^^^^^^^^^^^^^^^^^^ + +The ``build()`` method of a command is responsible for using the arguments of the command to build and serialize a +HTTP request and set the request on the ``$request`` property of the command object. This step is usually taken care of +for you when using a service description driven command that uses the default +``Guzzle\Service\Command\OperationCommand``. You may wish to implement the process method yourself when you aren't +using a service description or need to implement more complex request serialization. + +.. important:::: + + When implementing a custom ``build()`` method, be sure to set the class property of ``$this->request`` to an + instantiated and ready to send request. + +The following example shows how to implement the ``getMentions`` +`Twitter API `_ method using a concrete command. + +.. code-block:: php + + namespace mtdowling\Twitter\Command; + + use Guzzle\Service\Command\AbstractCommand; + + class GetMentions extends AbstractCommand + { + protected function build() + { + // Create the request property of the command + $this->request = $this->client->get('statuses/mentions_timeline.json'); + + // Grab the query object of the request because we will use it for + // serializing command parameters on the request + $query = $this->request->getQuery(); + + if ($this['count']) { + $query->set('count', $this['count']); + } + + if ($this['since_id']) { + $query->set('since_id', $this['since_id']); + } + + if ($this['max_id']) { + $query->set('max_id', $this['max_id']); + } + + if ($this['trim_user'] !== null) { + $query->set('trim_user', $this['trim_user'] ? 'true' : 'false'); + } + + if ($this['contributor_details'] !== null) { + $query->set('contributor_details', $this['contributor_details'] ? 'true' : 'false'); + } + + if ($this['include_entities'] !== null) { + $query->set('include_entities', $this['include_entities'] ? 'true' : 'false'); + } + } + } + +By default, a client will attempt to find concrete command classes under the ``Command`` namespace of a client. First +the client will attempt to find an exact match for the name of the command to the name of the command class. If an +exact match is not found, the client will calculate a class name using inflection. This is calculated based on the +folder hierarchy of a command and converting the CamelCased named commands into snake_case. Here are some examples on +how the command names are calculated: + +#. ``Foo\Command\JarJar`` **->** jar_jar +#. ``Foo\Command\Test`` **->** test +#. ``Foo\Command\People\GetCurrentPerson`` **->** people.get_current_person + +Notice how any sub-namespace beneath ``Command`` is converted from ``\`` to ``.`` (a period). CamelCasing is converted +to lowercased snake_casing (e.g. JarJar == jar_jar). + +Parsing responses +^^^^^^^^^^^^^^^^^ + +The ``process()`` method of a command is responsible for converting an HTTP response into something more useful. For +example, a service description operation that has specified a model object in the ``responseClass`` attribute of the +operation will set a ``Guzzle\Service\Resource\Model`` object as the result of the command. This behavior can be +completely modified as needed-- even if you are using operations and responseClass models. Simply implement a custom +``process()`` method that sets the ``$this->result`` class property to whatever you choose. You can reuse parts of the +default Guzzle response parsing functionality or get inspiration from existing code by using +``Guzzle\Service\Command\OperationResponseParser`` and ``Guzzle\Service\Command\DefaultResponseParser`` classes. + +If you do not implement a custom ``process()`` method and are not using a service description, then Guzzle will attempt +to guess how a response should be processed based on the Content-Type header of the response. Because the Twitter API +sets a ``Content-Type: application/json`` header on this response, we do not need to implement any custom response +parsing. + +Operation commands +~~~~~~~~~~~~~~~~~~ + +Operation commands are commands in which the serialization of an HTTP request and the parsing of an HTTP response are +driven by a Guzzle service description. Because request serialization, validation, and response parsing are +described using a DSL, creating operation commands is a much faster process than writing concrete commands. + +Creating operation commands for our Twitter client can remove a great deal of redundancy from the previous concrete +command, and allows for a deeper runtime introspection of the API. Here's an example service description we can use to +create the Twitter API client: + +.. code-block:: json + + { + "name": "Twitter", + "apiVersion": "1.1", + "baseUrl": "https://api.twitter.com/1.1", + "description": "Twitter REST API client", + "operations": { + "GetMentions": { + "httpMethod": "GET", + "uri": "statuses/mentions_timeline.json", + "summary": "Returns the 20 most recent mentions for the authenticating user.", + "responseClass": "GetMentionsOutput", + "parameters": { + "count": { + "description": "Specifies the number of tweets to try and retrieve", + "type": "integer", + "location": "query" + }, + "since_id": { + "description": "Returns results with an ID greater than the specified ID", + "type": "integer", + "location": "query" + }, + "max_id": { + "description": "Returns results with an ID less than or equal to the specified ID.", + "type": "integer", + "location": "query" + }, + "trim_user": { + "description": "Limits the amount of data returned for each user", + "type": "boolean", + "location": "query" + }, + "contributor_details": { + "description": "Adds more data to contributor elements", + "type": "boolean", + "location": "query" + }, + "include_entities": { + "description": "The entities node will be disincluded when set to false.", + "type": "boolean", + "location": "query" + } + } + } + }, + "models": { + "GetMentionsOutput": { + "type": "object", + "additionalProperties": { + "location": "json" + } + } + } + } + +If you're lazy, you can define the API in a less descriptive manner using ``additionalParameters``. +``additionalParameters`` define the serialization and validation rules of parameters that are not explicitly defined +in a service description. + +.. code-block:: json + + { + "name": "Twitter", + "apiVersion": "1.1", + "baseUrl": "https://api.twitter.com/1.1", + "description": "Twitter REST API client", + "operations": { + "GetMentions": { + "httpMethod": "GET", + "uri": "statuses/mentions_timeline.json", + "summary": "Returns the 20 most recent mentions for the authenticating user.", + "responseClass": "GetMentionsOutput", + "additionalParameters": { + "location": "query" + } + } + }, + "models": { + "GetMentionsOutput": { + "type": "object", + "additionalProperties": { + "location": "json" + } + } + } + } + +You should attach the service description to the client at the end of the client's factory method: + +.. code-block:: php + + // ... + class TwitterClient extends Client + { + public static function factory($config = array()) + { + // ... same code as before ... + + // Set the service description + $client->setDescription(ServiceDescription::factory('path/to/twitter.json')); + + return $client; + } + } + +The client can now use operations defined in the service description instead of requiring you to create concrete +command classes. Feel free to delete the concrete command class we created earlier. + +.. code-block:: php + + $jsonData = $twitter->getMentions(array( + 'count' => 5, + 'trim_user' => true + )); + +Executing commands in parallel +------------------------------ + +Much like HTTP requests, Guzzle allows you to send multiple commands in parallel. You can send commands in parallel by +passing an array of command objects to a client's ``execute()`` method. The client will serialize each request and +send them all in parallel. If an error is encountered during the transfer, then a +``Guzzle\Service\Exception\CommandTransferException`` is thrown, which allows you to retrieve a list of commands that +succeeded and a list of commands that failed. + +.. code-block:: php + + use Guzzle\Service\Exception\CommandTransferException; + + $commands = array(); + $commands[] = $twitter->getCommand('getMentions'); + $commands[] = $twitter->getCommand('otherCommandName'); + // etc... + + try { + $result = $client->execute($commands); + foreach ($result as $command) { + echo $command->getName() . ': ' . $command->getResponse()->getStatusCode() . "\n"; + } + } catch (CommandTransferException $e) { + // Get an array of the commands that succeeded + foreach ($e->getSuccessfulCommands() as $command) { + echo $command->getName() . " succeeded\n"; + } + // Get an array of the commands that failed + foreach ($e->getFailedCommands() as $command) { + echo $command->getName() . " failed\n"; + } + } + +.. note:: + + All commands executed from a client using an array must originate from the same client. + +Special command options +----------------------- + +Guzzle exposes several options that help to control how commands are validated, serialized, and parsed. +Command options can be specified when creating a command or in the ``command.params`` parameter in the +``Guzzle\Service\Client``. + +=========================== ============================================================================================ +command.request_options Option used to add :ref:`Request options ` to the request created by a + command +command.hidden_params An array of the names of parameters ignored by the ``additionalParameters`` parameter schema +command.disable_validation Set to true to disable JSON schema validation of the command's input parameters +command.response_processing Determines how the default response parser will parse the command. One of "raw" no parsing, + "model" (the default method used to parse commands using response models defined in service + descriptions) +command.headers (deprecated) Option used to specify custom headers. Use ``command.request_options`` instead +command.on_complete (deprecated) Option used to add an onComplete method to a command. Use + ``command.after_send`` event instead +command.response_body (deprecated) Option used to change the entity body used to store a response. + Use ``command.request_options`` instead +=========================== ============================================================================================ + +Advanced client configuration +============================= + +Default command parameters +-------------------------- + +When creating a client object, you can specify default command parameters to pass into all commands. Any key value pair +present in the ``command.params`` settings of a client will be added as default parameters to any command created +by the client. + +.. code-block:: php + + $client = new Guzzle\Service\Client(array( + 'command.params' => array( + 'default_1' => 'foo', + 'another' => 'bar' + ) + )); + +Magic methods +------------- + +Client objects will, by default, attempt to create and execute commands when a missing method is invoked on a client. +This powerful concept applies to both concrete commands and operation commands powered by a service description. This +makes it appear to the end user that you have defined actual methods on a client object, when in fact, the methods are +invoked using PHP's magic ``__call`` method. + +The ``__call`` method uses the ``getCommand()`` method of a client, which uses the client's internal +``Guzzle\Service\Command\Factory\FactoryInterface`` object. The default command factory allows you to instantiate +operations defined in a client's service description. The method in which a client determines which command to +execute is defined as follows: + +1. The client will first try to find a literal match for an operation in the service description. +2. If the literal match is not found, the client will try to uppercase the first character of the operation and find + the match again. +3. If a match is still not found, the command factory will inflect the method name from CamelCase to snake_case and + attempt to find a matching command. +4. If a command still does not match, an exception is thrown. + +.. code-block:: php + + // Use the magic method + $result = $twitter->getMentions(); + + // This is exactly the same as: + $result = $twitter->getCommand('getMentions')->execute(); + +You can disable magic methods on a client by passing ``false`` to the ``enableMagicMethod()`` method. + +Custom command factory +---------------------- + +A client by default uses the ``Guzzle\Service\Command\Factory\CompositeFactory`` which allows multiple command +factories to attempt to create a command by a certain name. The default CompositeFactory uses a ``ConcreteClassFactory`` +and a ``ServiceDescriptionFactory`` if a service description is specified on a client. You can specify a custom +command factory if your client requires custom command creation logic using the ``setCommandFactory()`` method of +a client. + +Custom resource Iterator factory +-------------------------------- + +Resource iterators can be retrieved from a client using the ``getIterator($name)`` method of a client. This method uses +a client's internal ``Guzzle\Service\Resource\ResourceIteratorFactoryInterface`` object. A client by default uses a +``Guzzle\Service\Resource\ResourceIteratorClassFactory`` to attempt to find concrete classes that implement resource +iterators. The default factory will first look for matching iterators in the ``Iterator`` subdirectory of the client +followed by the ``Model`` subdirectory of a client. Use the ``setResourceIteratorFactory()`` method of a client to +specify a custom resource iterator factory. + +Plugins and events +================== + +``Guzzle\Service\Client`` exposes various events that allow you to hook in custom logic. A client object owns a +``Symfony\Component\EventDispatcher\EventDispatcher`` object that can be accessed by calling +``$client->getEventDispatcher()``. You can use the event dispatcher to add listeners (a simple callback function) or +event subscribers (classes that listen to specific events of a dispatcher). + +.. _service-client-events: + +Events emitted from a Service Client +------------------------------------ + +A ``Guzzle\Service\Client`` object emits the following events: + ++------------------------------+--------------------------------------------+------------------------------------------+ +| Event name | Description | Event data | ++==============================+============================================+==========================================+ +| client.command.create | The client created a command object | * client: Client object | +| | | * command: Command object | ++------------------------------+--------------------------------------------+------------------------------------------+ +| command.before_prepare | Before a command is validated and built. | * command: Command being prepared | +| | This is also before a request is created. | | ++------------------------------+--------------------------------------------+------------------------------------------+ +| command.after_prepare | After a command instantiates and | * command: Command that was prepared | +| | configures its request object. | | ++------------------------------+--------------------------------------------+------------------------------------------+ +| command.before_send | The client is about to execute a prepared | * command: Command to execute | +| | command | | ++------------------------------+--------------------------------------------+------------------------------------------+ +| command.after_send | The client successfully completed | * command: The command that was executed | +| | executing a command | | ++------------------------------+--------------------------------------------+------------------------------------------+ +| command.parse_response | Called when ``responseType`` is ``class`` | * command: The command with a response | +| | and the response is about to be parsed. | about to be parsed. | ++------------------------------+--------------------------------------------+------------------------------------------+ + +.. code-block:: php + + use Guzzle\Common\Event; + use Guzzle\Service\Client; + + $client = new Client(); + + // create an event listener that operates on request objects + $client->getEventDispatcher()->addListener('command.after_prepare', function (Event $event) { + $command = $event['command']; + $request = $command->getRequest(); + + // do something with request + }); + +.. code-block:: php + + use Guzzle\Common\Event; + use Guzzle\Common\Client; + use Symfony\Component\EventDispatcher\EventSubscriberInterface; + + class EventSubscriber implements EventSubscriberInterface + { + public static function getSubscribedEvents() + { + return array( + 'client.command.create' => 'onCommandCreate', + 'command.parse_response' => 'onParseResponse' + ); + } + + public function onCommandCreate(Event $event) + { + $client = $event['client']; + $command = $event['command']; + // operate on client and command + } + + public function onParseResponse(Event $event) + { + $command = $event['command']; + // operate on the command + } + } + + $client = new Client(); + + $client->addSubscriber(new EventSubscriber()); diff --git a/vendor/guzzle/guzzle/phar-stub.php b/vendor/guzzle/guzzle/phar-stub.php new file mode 100644 index 0000000..504dfe0 --- /dev/null +++ b/vendor/guzzle/guzzle/phar-stub.php @@ -0,0 +1,28 @@ +registerNamespaces(array( + 'Guzzle' => 'phar://guzzle.phar/src', + 'Symfony\\Component\\EventDispatcher' => 'phar://guzzle.phar/vendor/symfony/event-dispatcher', + 'Doctrine' => 'phar://guzzle.phar/vendor/doctrine/common/lib', + 'Monolog' => 'phar://guzzle.phar/vendor/monolog/monolog/src' +)); +$classLoader->register(); + +// Copy the cacert.pem file from the phar if it is not in the temp folder. +$from = 'phar://guzzle.phar/src/Guzzle/Http/Resources/cacert.pem'; +$certFile = sys_get_temp_dir() . '/guzzle-cacert.pem'; + +// Only copy when the file size is different +if (!file_exists($certFile) || filesize($certFile) != filesize($from)) { + if (!copy($from, $certFile)) { + throw new RuntimeException("Could not copy {$from} to {$certFile}: " + . var_export(error_get_last(), true)); + } +} + +__HALT_COMPILER(); diff --git a/vendor/guzzle/guzzle/phing/build.properties.dist b/vendor/guzzle/guzzle/phing/build.properties.dist new file mode 100644 index 0000000..c60d3d9 --- /dev/null +++ b/vendor/guzzle/guzzle/phing/build.properties.dist @@ -0,0 +1,16 @@ +# you may need to update this if you're working on a fork. +guzzle.remote=git@github.com:guzzle/guzzle.git + +# github credentials -- only used by GitHub API calls to create subtree repos +github.basicauth=username:password +# for the subtree split and testing +github.org=guzzle + +# your git path +cmd.git=git + +# your composer command +cmd.composer=composer + +# test server start +cmd.testserver=node diff --git a/vendor/guzzle/guzzle/phing/imports/dependencies.xml b/vendor/guzzle/guzzle/phing/imports/dependencies.xml new file mode 100644 index 0000000..e40e037 --- /dev/null +++ b/vendor/guzzle/guzzle/phing/imports/dependencies.xml @@ -0,0 +1,33 @@ + + + + + + + + + + + + + + + + + using git at ${cmd.git} + + + + found git at ${cmd.git} + + + + + + + + + + diff --git a/vendor/guzzle/guzzle/phing/imports/deploy.xml b/vendor/guzzle/guzzle/phing/imports/deploy.xml new file mode 100644 index 0000000..109e5ec --- /dev/null +++ b/vendor/guzzle/guzzle/phing/imports/deploy.xml @@ -0,0 +1,142 @@ + + + + + + + + + + + + On branch ${head} + + + + + + + + + + working directory clean + + + ${git.status} + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + ChangeLog Match: ${version.changelog} + Guzzle\Common\Version Match: ${version.version} + + + + releasing: phing -Dnew.version=3.0.x -Dhead=master release + -- + + + + + + + + + + + + + + + BEGINNING RELEASE FOR ${new.version} + + + + + + + + + + + + + + + + + + + + + + + + Tip: to create a new release, do: phing -Dnew.version=[TAG] -Dhead=[BRANCH] release + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/vendor/guzzle/guzzle/phing/tasks/ComposerLintTask.php b/vendor/guzzle/guzzle/phing/tasks/ComposerLintTask.php new file mode 100644 index 0000000..3b70409 --- /dev/null +++ b/vendor/guzzle/guzzle/phing/tasks/ComposerLintTask.php @@ -0,0 +1,152 @@ + + * @license http://claylo.mit-license.org/2012/ MIT License + */ + +require_once 'phing/Task.php'; + +class ComposerLintTask extends Task +{ + protected $dir = null; + protected $file = null; + protected $passthru = false; + protected $composer = null; + + /** + * The setter for the dir + * + * @param string $str Directory to crawl recursively for composer files + */ + public function setDir($str) + { + $this->dir = $str; + } + + /** + * The setter for the file + * + * @param string $str Individual file to validate + */ + public function setFile($str) + { + $this->file = $str; + } + + /** + * Whether to use PHP's passthru() function instead of exec() + * + * @param boolean $passthru If passthru shall be used + */ + public function setPassthru($passthru) + { + $this->passthru = (bool) $passthru; + } + + /** + * Composer to execute. If unset, will attempt composer.phar in project + * basedir, and if that fails, will attempt global composer + * installation. + * + * @param string $str Individual file to validate + */ + public function setComposer($str) + { + $this->file = $str; + } + + /** + * The init method: do init steps + */ + public function init() + { + // nothing needed here + } + + /** + * The main entry point + */ + public function main() + { + if ($this->composer === null) { + $this->findComposer(); + } + + $files = array(); + if (!empty($this->file) && file_exists($this->file)) { + $files[] = $this->file; + } + + if (!empty($this->dir)) { + $found = $this->findFiles(); + foreach ($found as $file) { + $files[] = $this->dir . DIRECTORY_SEPARATOR . $file; + } + } + + foreach ($files as $file) { + + $cmd = $this->composer . ' validate ' . $file; + $cmd = escapeshellcmd($cmd); + + if ($this->passthru) { + $retval = null; + passthru($cmd, $retval); + if ($retval == 1) { + throw new BuildException('invalid composer.json'); + } + } else { + $out = array(); + $retval = null; + exec($cmd, $out, $retval); + if ($retval == 1) { + $err = join("\n", $out); + throw new BuildException($err); + } else { + $this->log($out[0]); + } + } + + } + + } + + /** + * Find the composer.json files using Phing's directory scanner + * + * @return array + */ + protected function findFiles() + { + $ds = new DirectoryScanner(); + $ds->setBasedir($this->dir); + $ds->setIncludes(array('**/composer.json')); + $ds->scan(); + return $ds->getIncludedFiles(); + } + + /** + * Find composer installation + * + */ + protected function findComposer() + { + $basedir = $this->project->getBasedir(); + $php = $this->project->getProperty('php.interpreter'); + + if (file_exists($basedir . '/composer.phar')) { + $this->composer = "$php $basedir/composer.phar"; + } else { + $out = array(); + exec('which composer', $out); + if (empty($out)) { + throw new BuildException( + 'Could not determine composer location.' + ); + } + $this->composer = $out[0]; + } + } +} diff --git a/vendor/guzzle/guzzle/phing/tasks/GuzzlePearPharPackageTask.php b/vendor/guzzle/guzzle/phing/tasks/GuzzlePearPharPackageTask.php new file mode 100644 index 0000000..f72a6b5 --- /dev/null +++ b/vendor/guzzle/guzzle/phing/tasks/GuzzlePearPharPackageTask.php @@ -0,0 +1,338 @@ + + * @license http://claylo.mit-license.org/2012/ MIT License + */ + +require_once 'phing/Task.php'; +require_once 'PEAR/PackageFileManager2.php'; +require_once 'PEAR/PackageFileManager/File.php'; +require_once 'PEAR/Packager.php'; + +class GuzzlePearPharPackageTask extends Task +{ + private $version; + private $deploy = true; + private $makephar = true; + + private $subpackages = array(); + + public function setVersion($str) + { + $this->version = $str; + } + + public function getVersion() + { + return $this->version; + } + + public function setDeploy($deploy) + { + $this->deploy = (bool) $deploy; + } + + public function getDeploy() + { + return $this->deploy; + } + + public function setMakephar($makephar) + { + $this->makephar = (bool) $makephar; + } + + public function getMakephar() + { + return $this->makephar; + } + + private $basedir; + private $guzzleinfo; + private $changelog_release_date; + private $changelog_notes = '-'; + + public function main() + { + $this->basedir = $this->getProject()->getBasedir(); + + if (!is_dir((string) $this->basedir.'/.subsplit')) { + throw new BuildException('PEAR packaging requires .subsplit directory'); + } + + // main composer file + $composer_file = file_get_contents((string) $this->basedir.'/.subsplit/composer.json'); + $this->guzzleinfo = json_decode($composer_file, true); + + // make sure we have a target + $pearwork = (string) $this->basedir . '/build/pearwork'; + if (!is_dir($pearwork)) { + mkdir($pearwork, 0777, true); + } + $pearlogs = (string) $this->basedir . '/build/artifacts/logs'; + if (!is_dir($pearlogs)) { + mkdir($pearlogs, 0777, true); + } + + $version = $this->getVersion(); + $this->grabChangelog(); + if ($version[0] == '2') { + $this->log('building single PEAR package'); + $this->buildSinglePackage(); + } else { + // $this->log("building PEAR subpackages"); + // $this->createSubPackages(); + // $this->log("building PEAR bundle package"); + $this->buildSinglePackage(); + } + + if ($this->getMakephar()) { + $this->log("building PHAR"); + $this->getProject()->executeTarget('package-phar'); + } + + if ($this->getDeploy()) { + $this->doDeployment(); + } + } + + public function doDeployment() + { + $basedir = (string) $this->basedir; + $this->log('beginning PEAR/PHAR deployment'); + + chdir($basedir . '/build/pearwork'); + if (!is_dir('./channel')) { + mkdir('./channel'); + } + + // Pull the PEAR channel down locally + passthru('aws s3 sync s3://pear.guzzlephp.org ./channel'); + + // add PEAR packages + foreach (scandir('./') as $file) { + if (substr($file, -4) == '.tgz') { + passthru('pirum add ./channel ' . $file); + } + } + + // if we have a new phar, add it + if ($this->getMakephar() && file_exists($basedir . '/build/artifacts/guzzle.phar')) { + rename($basedir . '/build/artifacts/guzzle.phar', './channel/guzzle.phar'); + } + + // Sync up with the S3 bucket + chdir($basedir . '/build/pearwork/channel'); + passthru('aws s3 sync . s3://pear.guzzlephp.org'); + } + + public function buildSinglePackage() + { + $v = $this->getVersion(); + $apiversion = $v[0] . '.0.0'; + + $opts = array( + 'packagedirectory' => (string) $this->basedir . '/.subsplit/src/', + 'filelistgenerator' => 'file', + 'ignore' => array('*composer.json'), + 'baseinstalldir' => '/', + 'packagefile' => 'package.xml' + //'outputdirectory' => (string) $this->basedir . '/build/pearwork/' + ); + $pfm = new PEAR_PackageFileManager2(); + $pfm->setOptions($opts); + $pfm->addRole('md', 'doc'); + $pfm->addRole('pem', 'php'); + $pfm->setPackage('Guzzle'); + $pfm->setSummary("Object-oriented PHP HTTP Client for PHP 5.3+"); + $pfm->setDescription($this->guzzleinfo['description']); + $pfm->setPackageType('php'); + $pfm->setChannel('guzzlephp.org/pear'); + $pfm->setAPIVersion($apiversion); + $pfm->setReleaseVersion($this->getVersion()); + $pfm->setAPIStability('stable'); + $pfm->setReleaseStability('stable'); + $pfm->setNotes($this->changelog_notes); + $pfm->setPackageType('php'); + $pfm->setLicense('MIT', 'http://github.com/guzzle/guzzle/blob/master/LICENSE'); + $pfm->addMaintainer('lead', 'mtdowling', 'Michael Dowling', 'mtdowling@gmail.com', 'yes'); + $pfm->setDate($this->changelog_release_date); + $pfm->generateContents(); + + $phpdep = $this->guzzleinfo['require']['php']; + $phpdep = str_replace('>=', '', $phpdep); + $pfm->setPhpDep($phpdep); + $pfm->addExtensionDep('required', 'curl'); + $pfm->setPearinstallerDep('1.4.6'); + $pfm->addPackageDepWithChannel('required', 'EventDispatcher', 'pear.symfony.com', '2.1.0'); + if (!empty($this->subpackages)) { + foreach ($this->subpackages as $package) { + $pkg = dirname($package); + $pkg = str_replace('/', '_', $pkg); + $pfm->addConflictingPackageDepWithChannel($pkg, 'guzzlephp.org/pear', false, $apiversion); + } + } + + ob_start(); + $startdir = getcwd(); + chdir((string) $this->basedir . '/build/pearwork'); + + echo "DEBUGGING GENERATED PACKAGE FILE\n"; + $result = $pfm->debugPackageFile(); + if ($result) { + $out = $pfm->writePackageFile(); + echo "\n\n\nWRITE PACKAGE FILE RESULT:\n"; + var_dump($out); + // load up package file and build package + $packager = new PEAR_Packager(); + echo "\n\n\nBUILDING PACKAGE FROM PACKAGE FILE:\n"; + $dest_package = $packager->package($opts['packagedirectory'].'package.xml'); + var_dump($dest_package); + } else { + echo "\n\n\nDEBUGGING RESULT:\n"; + var_dump($result); + } + echo "removing package.xml"; + unlink($opts['packagedirectory'].'package.xml'); + $log = ob_get_clean(); + file_put_contents((string) $this->basedir . '/build/artifacts/logs/pear_package.log', $log); + chdir($startdir); + } + + public function createSubPackages() + { + $this->findComponents(); + + foreach ($this->subpackages as $package) { + $baseinstalldir = dirname($package); + $dir = (string) $this->basedir.'/.subsplit/src/' . $baseinstalldir; + $composer_file = file_get_contents((string) $this->basedir.'/.subsplit/src/'. $package); + $package_info = json_decode($composer_file, true); + $this->log('building ' . $package_info['target-dir'] . ' subpackage'); + $this->buildSubPackage($dir, $baseinstalldir, $package_info); + } + } + + public function buildSubPackage($dir, $baseinstalldir, $info) + { + $package = str_replace('/', '_', $baseinstalldir); + $opts = array( + 'packagedirectory' => $dir, + 'filelistgenerator' => 'file', + 'ignore' => array('*composer.json', '*package.xml'), + 'baseinstalldir' => '/' . $info['target-dir'], + 'packagefile' => 'package.xml' + ); + $pfm = new PEAR_PackageFileManager2(); + $pfm->setOptions($opts); + $pfm->setPackage($package); + $pfm->setSummary($info['description']); + $pfm->setDescription($info['description']); + $pfm->setPackageType('php'); + $pfm->setChannel('guzzlephp.org/pear'); + $pfm->setAPIVersion('3.0.0'); + $pfm->setReleaseVersion($this->getVersion()); + $pfm->setAPIStability('stable'); + $pfm->setReleaseStability('stable'); + $pfm->setNotes($this->changelog_notes); + $pfm->setPackageType('php'); + $pfm->setLicense('MIT', 'http://github.com/guzzle/guzzle/blob/master/LICENSE'); + $pfm->addMaintainer('lead', 'mtdowling', 'Michael Dowling', 'mtdowling@gmail.com', 'yes'); + $pfm->setDate($this->changelog_release_date); + $pfm->generateContents(); + + $phpdep = $this->guzzleinfo['require']['php']; + $phpdep = str_replace('>=', '', $phpdep); + $pfm->setPhpDep($phpdep); + $pfm->setPearinstallerDep('1.4.6'); + + foreach ($info['require'] as $type => $version) { + if ($type == 'php') { + continue; + } + if ($type == 'symfony/event-dispatcher') { + $pfm->addPackageDepWithChannel('required', 'EventDispatcher', 'pear.symfony.com', '2.1.0'); + } + if ($type == 'ext-curl') { + $pfm->addExtensionDep('required', 'curl'); + } + if (substr($type, 0, 6) == 'guzzle') { + $gdep = str_replace('/', ' ', $type); + $gdep = ucwords($gdep); + $gdep = str_replace(' ', '_', $gdep); + $pfm->addPackageDepWithChannel('required', $gdep, 'guzzlephp.org/pear', $this->getVersion()); + } + } + + // can't have main Guzzle package AND sub-packages + $pfm->addConflictingPackageDepWithChannel('Guzzle', 'guzzlephp.org/pear', false, $apiversion); + + ob_start(); + $startdir = getcwd(); + chdir((string) $this->basedir . '/build/pearwork'); + + echo "DEBUGGING GENERATED PACKAGE FILE\n"; + $result = $pfm->debugPackageFile(); + if ($result) { + $out = $pfm->writePackageFile(); + echo "\n\n\nWRITE PACKAGE FILE RESULT:\n"; + var_dump($out); + // load up package file and build package + $packager = new PEAR_Packager(); + echo "\n\n\nBUILDING PACKAGE FROM PACKAGE FILE:\n"; + $dest_package = $packager->package($opts['packagedirectory'].'/package.xml'); + var_dump($dest_package); + } else { + echo "\n\n\nDEBUGGING RESULT:\n"; + var_dump($result); + } + echo "removing package.xml"; + unlink($opts['packagedirectory'].'/package.xml'); + $log = ob_get_clean(); + file_put_contents((string) $this->basedir . '/build/artifacts/logs/pear_package_'.$package.'.log', $log); + chdir($startdir); + } + + public function findComponents() + { + $ds = new DirectoryScanner(); + $ds->setBasedir((string) $this->basedir.'/.subsplit/src'); + $ds->setIncludes(array('**/composer.json')); + $ds->scan(); + $files = $ds->getIncludedFiles(); + $this->subpackages = $files; + } + + public function grabChangelog() + { + $cl = file((string) $this->basedir.'/.subsplit/CHANGELOG.md'); + $notes = ''; + $in_version = false; + $release_date = null; + + foreach ($cl as $line) { + $line = trim($line); + if (preg_match('/^\* '.$this->getVersion().' \(([0-9\-]+)\)$/', $line, $matches)) { + $release_date = $matches[1]; + $in_version = true; + continue; + } + if ($in_version && empty($line) && empty($notes)) { + continue; + } + if ($in_version && ! empty($line)) { + $notes .= $line."\n"; + } + if ($in_version && empty($line) && !empty($notes)) { + $in_version = false; + } + } + $this->changelog_release_date = $release_date; + + if (! empty($notes)) { + $this->changelog_notes = $notes; + } + } +} diff --git a/vendor/guzzle/guzzle/phing/tasks/GuzzleSubSplitTask.php b/vendor/guzzle/guzzle/phing/tasks/GuzzleSubSplitTask.php new file mode 100644 index 0000000..5d56a5b --- /dev/null +++ b/vendor/guzzle/guzzle/phing/tasks/GuzzleSubSplitTask.php @@ -0,0 +1,385 @@ + + * @license http://claylo.mit-license.org/2012/ MIT License + */ + +require_once 'phing/tasks/ext/git/GitBaseTask.php'; + +// base - base of tree to split out +// subIndicatorFile - composer.json, package.xml? +class GuzzleSubSplitTask extends GitBaseTask +{ + /** + * What git repository to pull from and publish to + */ + protected $remote = null; + + /** + * Publish for comma-separated heads instead of all heads + */ + protected $heads = null; + + /** + * Publish for comma-separated tags instead of all tags + */ + protected $tags = null; + + /** + * Base of the tree RELATIVE TO .subsplit working dir + */ + protected $base = null; + + /** + * The presence of this file will indicate that the directory it resides + * in is at the top level of a split. + */ + protected $subIndicatorFile = 'composer.json'; + + /** + * Do everything except actually send the update. + */ + protected $dryRun = null; + + /** + * Do not sync any heads. + */ + protected $noHeads = false; + + /** + * Do not sync any tags. + */ + protected $noTags = false; + + /** + * The splits we found in the heads + */ + protected $splits; + + public function setRemote($str) + { + $this->remote = $str; + } + + public function getRemote() + { + return $this->remote; + } + + public function setHeads($str) + { + $this->heads = explode(',', $str); + } + + public function getHeads() + { + return $this->heads; + } + + public function setTags($str) + { + $this->tags = explode(',', $str); + } + + public function getTags() + { + return $this->tags; + } + + public function setBase($str) + { + $this->base = $str; + } + + public function getBase() + { + return $this->base; + } + + public function setSubIndicatorFile($str) + { + $this->subIndicatorFile = $str; + } + + public function getSubIndicatorFile() + { + return $this->subIndicatorFile; + } + + public function setDryRun($bool) + { + $this->dryRun = (bool) $bool; + } + + public function getDryRun() + { + return $this->dryRun; + } + + public function setNoHeads($bool) + { + $this->noHeads = (bool) $bool; + } + + public function getNoHeads() + { + return $this->noHeads; + } + + public function setNoTags($bool) + { + $this->noTags = (bool) $bool; + } + + public function getNoTags() + { + return $this->noTags; + } + + /** + * GitClient from VersionControl_Git + */ + protected $client = null; + + /** + * The main entry point + */ + public function main() + { + $repo = $this->getRepository(); + if (empty($repo)) { + throw new BuildException('"repository" is a required parameter'); + } + + $remote = $this->getRemote(); + if (empty($remote)) { + throw new BuildException('"remote" is a required parameter'); + } + + chdir($repo); + $this->client = $this->getGitClient(false, $repo); + + // initalized yet? + if (!is_dir('.subsplit')) { + $this->subsplitInit(); + } else { + // update + $this->subsplitUpdate(); + } + + // find all splits based on heads requested + $this->findSplits(); + + // check that GitHub has the repos + $this->verifyRepos(); + + // execute the subsplits + $this->publish(); + } + + public function publish() + { + $this->log('DRY RUN ONLY FOR NOW'); + $base = $this->getBase(); + $base = rtrim($base, '/') . '/'; + $org = $this->getOwningTarget()->getProject()->getProperty('github.org'); + + $splits = array(); + + $heads = $this->getHeads(); + foreach ($heads as $head) { + foreach ($this->splits[$head] as $component => $meta) { + $splits[] = $base . $component . ':git@github.com:'. $org.'/'.$meta['repo']; + } + + $cmd = 'git subsplit publish '; + $cmd .= escapeshellarg(implode(' ', $splits)); + + if ($this->getNoHeads()) { + $cmd .= ' --no-heads'; + } else { + $cmd .= ' --heads='.$head; + } + + if ($this->getNoTags()) { + $cmd .= ' --no-tags'; + } else { + if ($this->getTags()) { + $cmd .= ' --tags=' . escapeshellarg(implode(' ', $this->getTags())); + } + } + + passthru($cmd); + } + } + + /** + * Runs `git subsplit update` + */ + public function subsplitUpdate() + { + $repo = $this->getRepository(); + $this->log('git-subsplit update...'); + $cmd = $this->client->getCommand('subsplit'); + $cmd->addArgument('update'); + try { + $cmd->execute(); + } catch (Exception $e) { + throw new BuildException('git subsplit update failed'. $e); + } + chdir($repo . '/.subsplit'); + passthru('php ../composer.phar update --dev'); + chdir($repo); + } + + /** + * Runs `git subsplit init` based on the remote repository. + */ + public function subsplitInit() + { + $remote = $this->getRemote(); + $cmd = $this->client->getCommand('subsplit'); + $this->log('running git-subsplit init ' . $remote); + + $cmd->setArguments(array( + 'init', + $remote + )); + + try { + $output = $cmd->execute(); + } catch (Exception $e) { + throw new BuildException('git subsplit init failed'. $e); + } + $this->log(trim($output), Project::MSG_INFO); + $repo = $this->getRepository(); + chdir($repo . '/.subsplit'); + passthru('php ../composer.phar install --dev'); + chdir($repo); + } + + /** + * Find the composer.json files using Phing's directory scanner + * + * @return array + */ + protected function findSplits() + { + $this->log("checking heads for subsplits"); + $repo = $this->getRepository(); + $base = $this->getBase(); + + $splits = array(); + $heads = $this->getHeads(); + + if (!empty($base)) { + $base = '/' . ltrim($base, '/'); + } else { + $base = '/'; + } + + chdir($repo . '/.subsplit'); + foreach ($heads as $head) { + $splits[$head] = array(); + + // check each head requested *BEFORE* the actual subtree split command gets it + passthru("git checkout '$head'"); + $ds = new DirectoryScanner(); + $ds->setBasedir($repo . '/.subsplit' . $base); + $ds->setIncludes(array('**/'.$this->subIndicatorFile)); + $ds->scan(); + $files = $ds->getIncludedFiles(); + + // Process the files we found + foreach ($files as $file) { + $pkg = file_get_contents($repo . '/.subsplit' . $base .'/'. $file); + $pkg_json = json_decode($pkg, true); + $name = $pkg_json['name']; + $component = str_replace('/composer.json', '', $file); + // keep this for split cmd + $tmpreponame = explode('/', $name); + $reponame = $tmpreponame[1]; + $splits[$head][$component]['repo'] = $reponame; + $nscomponent = str_replace('/', '\\', $component); + $splits[$head][$component]['desc'] = "[READ ONLY] Subtree split of $nscomponent: " . $pkg_json['description']; + } + } + + // go back to how we found it + passthru("git checkout master"); + chdir($repo); + $this->splits = $splits; + } + + /** + * Based on list of repositories we determined we *should* have, talk + * to GitHub and make sure they're all there. + * + */ + protected function verifyRepos() + { + $this->log('verifying GitHub target repos'); + $github_org = $this->getOwningTarget()->getProject()->getProperty('github.org'); + $github_creds = $this->getOwningTarget()->getProject()->getProperty('github.basicauth'); + + if ($github_creds == 'username:password') { + $this->log('Skipping GitHub repo checks. Update github.basicauth in build.properties to verify repos.', 1); + return; + } + + $ch = curl_init('https://api.github.com/orgs/'.$github_org.'/repos?type=all'); + curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); + curl_setopt($ch, CURLOPT_USERPWD, $github_creds); + // change this when we know we can use our bundled CA bundle! + curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); + $result = curl_exec($ch); + curl_close($ch); + $repos = json_decode($result, true); + $existing_repos = array(); + + // parse out the repos we found on GitHub + foreach ($repos as $repo) { + $tmpreponame = explode('/', $repo['full_name']); + $reponame = $tmpreponame[1]; + $existing_repos[$reponame] = $repo['description']; + } + + $heads = $this->getHeads(); + foreach ($heads as $head) { + foreach ($this->splits[$head] as $component => $meta) { + + $reponame = $meta['repo']; + + if (!isset($existing_repos[$reponame])) { + $this->log("Creating missing repo $reponame"); + $payload = array( + 'name' => $reponame, + 'description' => $meta['desc'], + 'homepage' => 'http://www.guzzlephp.org/', + 'private' => true, + 'has_issues' => false, + 'has_wiki' => false, + 'has_downloads' => true, + 'auto_init' => false + ); + $ch = curl_init('https://api.github.com/orgs/'.$github_org.'/repos'); + curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); + curl_setopt($ch, CURLOPT_USERPWD, $github_creds); + curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-Type: application/json')); + curl_setopt($ch, CURLOPT_POST, 1); + curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($payload)); + // change this when we know we can use our bundled CA bundle! + curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); + $result = curl_exec($ch); + echo "Response code: ".curl_getinfo($ch, CURLINFO_HTTP_CODE)."\n"; + curl_close($ch); + } else { + $this->log("Repo $reponame exists", 2); + } + } + } + } +} diff --git a/vendor/guzzle/guzzle/phpunit.xml.dist b/vendor/guzzle/guzzle/phpunit.xml.dist new file mode 100644 index 0000000..208fdc0 --- /dev/null +++ b/vendor/guzzle/guzzle/phpunit.xml.dist @@ -0,0 +1,48 @@ + + + + + + ./tests/Guzzle/Tests + + + + + + + + + + ./src/Guzzle + + ./src/Guzzle + ./src/Guzzle/Common/Exception/GuzzleException.php + ./src/Guzzle/Http/Exception/HttpException.php + ./src/Guzzle/Http/Exception/ServerErrorResponseException.php + ./src/Guzzle/Http/Exception/ClientErrorResponseException.php + ./src/Guzzle/Http/Exception/TooManyRedirectsException.php + ./src/Guzzle/Http/Exception/CouldNotRewindStreamException.php + ./src/Guzzle/Common/Exception/BadMethodCallException.php + ./src/Guzzle/Common/Exception/InvalidArgumentException.php + ./src/Guzzle/Common/Exception/RuntimeException.php + ./src/Guzzle/Common/Exception/UnexpectedValueException.php + ./src/Guzzle/Service/Exception/ClientNotFoundException.php + ./src/Guzzle/Service/Exception/CommandException.php + ./src/Guzzle/Service/Exception/DescriptionBuilderException.php + ./src/Guzzle/Service/Exception/ServiceBuilderException.php + ./src/Guzzle/Service/Exception/ServiceNotFoundException.php + ./src/Guzzle/Service/Exception/ValidationException.php + ./src/Guzzle/Service/Exception/JsonException.php + + + + + diff --git a/vendor/guzzle/guzzle/src/Guzzle/Batch/AbstractBatchDecorator.php b/vendor/guzzle/guzzle/src/Guzzle/Batch/AbstractBatchDecorator.php new file mode 100644 index 0000000..0625d71 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Batch/Batch.php b/vendor/guzzle/guzzle/src/Guzzle/Batch/Batch.php new file mode 100644 index 0000000..4d41c54 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Batch/BatchBuilder.php b/vendor/guzzle/guzzle/src/Guzzle/Batch/BatchBuilder.php new file mode 100644 index 0000000..ea99b4d --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Batch/BatchClosureDivisor.php b/vendor/guzzle/guzzle/src/Guzzle/Batch/BatchClosureDivisor.php new file mode 100644 index 0000000..e0a2d95 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Batch/BatchClosureTransfer.php b/vendor/guzzle/guzzle/src/Guzzle/Batch/BatchClosureTransfer.php new file mode 100644 index 0000000..9cbf1ab --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Batch/BatchCommandTransfer.php b/vendor/guzzle/guzzle/src/Guzzle/Batch/BatchCommandTransfer.php new file mode 100644 index 0000000..d55ac7d --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Batch/BatchDivisorInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Batch/BatchDivisorInterface.php new file mode 100644 index 0000000..0214f05 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Batch/BatchSizeDivisor.php b/vendor/guzzle/guzzle/src/Guzzle/Batch/BatchSizeDivisor.php new file mode 100644 index 0000000..67f90a5 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Batch/BatchTransferInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Batch/BatchTransferInterface.php new file mode 100644 index 0000000..2e0b60d --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Batch/ExceptionBufferingBatch.php b/vendor/guzzle/guzzle/src/Guzzle/Batch/ExceptionBufferingBatch.php new file mode 100644 index 0000000..d7a8928 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Batch/FlushingBatch.php b/vendor/guzzle/guzzle/src/Guzzle/Batch/FlushingBatch.php new file mode 100644 index 0000000..367b684 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Batch/HistoryBatch.php b/vendor/guzzle/guzzle/src/Guzzle/Batch/HistoryBatch.php new file mode 100644 index 0000000..e345fdc --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Batch/NotifyingBatch.php b/vendor/guzzle/guzzle/src/Guzzle/Batch/NotifyingBatch.php new file mode 100644 index 0000000..96d04da --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Batch/composer.json b/vendor/guzzle/guzzle/src/Guzzle/Batch/composer.json new file mode 100644 index 0000000..12404d3 --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Batch/composer.json @@ -0,0 +1,31 @@ +{ + "name": "guzzle/batch", + "description": "Guzzle batch component for batching requests, commands, or custom transfers", + "homepage": "http://guzzlephp.org/", + "keywords": ["batch", "HTTP", "REST", "guzzle"], + "license": "MIT", + "authors": [ + { + "name": "Michael Dowling", + "email": "mtdowling@gmail.com", + "homepage": "https://github.com/mtdowling" + } + ], + "require": { + "php": ">=5.3.2", + "guzzle/common": "self.version" + }, + "autoload": { + "psr-0": { "Guzzle\\Batch": "" } + }, + "suggest": { + "guzzle/http": "self.version", + "guzzle/service": "self.version" + }, + "target-dir": "Guzzle/Batch", + "extra": { + "branch-alias": { + "dev-master": "3.7-dev" + } + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Cache/AbstractCacheAdapter.php b/vendor/guzzle/guzzle/src/Guzzle/Cache/AbstractCacheAdapter.php new file mode 100644 index 0000000..a5c5271 --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Cache/AbstractCacheAdapter.php @@ -0,0 +1,21 @@ +cache; + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Cache/CacheAdapterFactory.php b/vendor/guzzle/guzzle/src/Guzzle/Cache/CacheAdapterFactory.php new file mode 100644 index 0000000..94e6234 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Cache/CacheAdapterInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Cache/CacheAdapterInterface.php new file mode 100644 index 0000000..970c9e2 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Cache/DoctrineCacheAdapter.php b/vendor/guzzle/guzzle/src/Guzzle/Cache/DoctrineCacheAdapter.php new file mode 100644 index 0000000..321dd6b --- /dev/null +++ b/vendor/guzzle/guzzle/src/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); + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Cache/NullCacheAdapter.php b/vendor/guzzle/guzzle/src/Guzzle/Cache/NullCacheAdapter.php new file mode 100644 index 0000000..68bd4af --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Cache/Zf2CacheAdapter.php b/vendor/guzzle/guzzle/src/Guzzle/Cache/Zf2CacheAdapter.php new file mode 100644 index 0000000..1fc18a5 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Cache/composer.json b/vendor/guzzle/guzzle/src/Guzzle/Cache/composer.json new file mode 100644 index 0000000..a5d999b --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Cache/composer.json @@ -0,0 +1,27 @@ +{ + "name": "guzzle/cache", + "description": "Guzzle cache adapter component", + "homepage": "http://guzzlephp.org/", + "keywords": ["cache", "adapter", "zf", "doctrine", "guzzle"], + "license": "MIT", + "authors": [ + { + "name": "Michael Dowling", + "email": "mtdowling@gmail.com", + "homepage": "https://github.com/mtdowling" + } + ], + "require": { + "php": ">=5.3.2", + "guzzle/common": "self.version" + }, + "autoload": { + "psr-0": { "Guzzle\\Cache": "" } + }, + "target-dir": "Guzzle/Cache", + "extra": { + "branch-alias": { + "dev-master": "3.7-dev" + } + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Common/AbstractHasDispatcher.php b/vendor/guzzle/guzzle/src/Guzzle/Common/AbstractHasDispatcher.php new file mode 100644 index 0000000..d1e842b --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Common/Collection.php b/vendor/guzzle/guzzle/src/Guzzle/Common/Collection.php new file mode 100644 index 0000000..5cb1535 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Common/Event.php b/vendor/guzzle/guzzle/src/Guzzle/Common/Event.php new file mode 100644 index 0000000..fad76a9 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Common/Exception/BadMethodCallException.php b/vendor/guzzle/guzzle/src/Guzzle/Common/Exception/BadMethodCallException.php new file mode 100644 index 0000000..08d1c72 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Common/Exception/GuzzleException.php b/vendor/guzzle/guzzle/src/Guzzle/Common/Exception/GuzzleException.php new file mode 100644 index 0000000..458e6f2 --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Common/Exception/GuzzleException.php @@ -0,0 +1,8 @@ +=5.3.2", + "symfony/event-dispatcher": ">=2.1" + }, + "autoload": { + "psr-0": { "Guzzle\\Common": "" } + }, + "target-dir": "Guzzle/Common", + "extra": { + "branch-alias": { + "dev-master": "3.7-dev" + } + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Http/AbstractEntityBodyDecorator.php b/vendor/guzzle/guzzle/src/Guzzle/Http/AbstractEntityBodyDecorator.php new file mode 100644 index 0000000..5005a88 --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Http/AbstractEntityBodyDecorator.php @@ -0,0 +1,221 @@ +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/guzzle/guzzle/src/Guzzle/Http/CachingEntityBody.php b/vendor/guzzle/guzzle/src/Guzzle/Http/CachingEntityBody.php new file mode 100644 index 0000000..c65c136 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Http/Client.php b/vendor/guzzle/guzzle/src/Guzzle/Http/Client.php new file mode 100644 index 0000000..22df2ec --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Http/Client.php @@ -0,0 +1,490 @@ +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 = sys_get_temp_dir() . '/guzzle-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'; + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Http/ClientInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Http/ClientInterface.php new file mode 100644 index 0000000..10e4de2 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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 ($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/guzzle/guzzle/src/Guzzle/Http/Curl/CurlMulti.php b/vendor/guzzle/guzzle/src/Guzzle/Http/Curl/CurlMulti.php new file mode 100644 index 0000000..e8301be --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Http/Curl/CurlMulti.php @@ -0,0 +1,367 @@ + 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) { + // Add the request curl handle to the multi handle + $handle = $this->createCurlHandle($request)->getHandle(); + $this->checkCurlResult(curl_multi_add_handle($this->multiHandle, $handle)); + } else { + // Requests might decide they don't need to be sent just before transfer (e.g. CachePlugin) + $this->remove($request); + if ($state == RequestInterface::STATE_COMPLETE) { + $this->successful[] = $request; + } + } + } catch (\Exception $e) { + // Queue the exception to be thrown when sent + $this->removeErroredRequest($request, $e); + } + } + + /** + * Create a curl handle for a request + * + * @param RequestInterface $request Request + * + * @return CurlHandle + */ + protected function createCurlHandle(RequestInterface $request) + { + $wrapper = CurlHandle::factory($request); + $this->handles[$request] = $wrapper; + $this->resourceHash[(int) $wrapper->getHandle()] = $request; + + return $wrapper; + } + + /** + * Get the data from the multi handle + */ + protected function perform() + { + $event = new Event(array('curl_multi' => $this)); + + while ($this->requests) { + // Notify each request as polling + $blocking = $total = 0; + foreach ($this->requests as $request) { + ++$total; + $event['request'] = $request; + $request->getEventDispatcher()->dispatch(self::POLLING_REQUEST, $event); + // The blocking variable just has to be non-falsey to block the loop + if ($request->getParams()->hasKey(self::BLOCKING)) { + ++$blocking; + } + } + if ($blocking == $total) { + // Sleep to prevent eating CPU because no requests are actually pending a select call + usleep(500); + } else { + $this->executeHandles(); + } + } + } + + /** + * Execute and select curl handles + */ + private function executeHandles() + { + // The first curl_multi_select often times out no matter what, but is usually required for fast transfers + $selectTimeout = 0.001; + $active = false; + do { + while (($mrc = curl_multi_exec($this->multiHandle, $active)) == CURLM_CALL_MULTI_PERFORM); + $this->checkCurlResult($mrc); + $this->processMessages(); + if ($active && curl_multi_select($this->multiHandle, $selectTimeout) === -1) { + // Perform a usleep if a select returns -1: https://bugs.php.net/bug.php?id=61141 + usleep(150); + } + $selectTimeout = $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) { + $state = $request->setState(RequestInterface::STATE_COMPLETE, array('handle' => $handle)); + // Only remove the request if it wasn't resent as a result of the state change + if ($state != RequestInterface::STATE_TRANSFER) { + $this->remove($request); + } + } else { + // Set the state of the request to an error + $state = $request->setState(RequestInterface::STATE_ERROR, array('exception' => $curlException)); + // Allow things to ignore the error if possible + if ($state != RequestInterface::STATE_TRANSFER) { + $this->remove($request); + } + // The error was not handled, so fail + if ($state == RequestInterface::STATE_ERROR) { + /** @var CurlException $curlException */ + throw $curlException; + } + } + } + + /** + * Remove a curl handle from the curl multi object + * + * @param RequestInterface $request Request that owns the handle + */ + protected function removeHandle(RequestInterface $request) + { + if (isset($this->handles[$request])) { + $handle = $this->handles[$request]; + curl_multi_remove_handle($this->multiHandle, $handle->getHandle()); + unset($this->handles[$request]); + unset($this->resourceHash[(int) $handle->getHandle()]); + $handle->close(); + } + } + + /** + * Check if a cURL transfer resulted in what should be an exception + * + * @param RequestInterface $request Request to check + * @param CurlHandle $handle Curl handle object + * @param array $curl Array returned from curl_multi_info_read + * + * @return CurlException|bool + */ + private function isCurlException(RequestInterface $request, CurlHandle $handle, array $curl) + { + if (CURLM_OK == $curl['result'] || CURLM_CALL_MULTI_PERFORM == $curl['result']) { + return false; + } + + $handle->setErrorNo($curl['result']); + $e = new CurlException(sprintf('[curl] %s: %s [url] %s', + $handle->getErrorNo(), $handle->getError(), $handle->getUrl())); + $e->setCurlHandle($handle) + ->setRequest($request) + ->setCurlInfo($handle->getInfo()) + ->setError($handle->getError(), $handle->getErrorNo()); + + return $e; + } + + /** + * Throw an exception for a cURL multi response if needed + * + * @param int $code Curl response code + * @throws CurlException + */ + private function checkCurlResult($code) + { + if ($code != CURLM_OK && $code != CURLM_CALL_MULTI_PERFORM) { + throw new CurlException(isset($this->multiErrors[$code]) + ? "cURL error: {$code} ({$this->multiErrors[$code][0]}): cURL message: {$this->multiErrors[$code][1]}" + : 'Unexpected cURL error: ' . $code + ); + } + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Http/Curl/CurlMultiInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Http/Curl/CurlMultiInterface.php new file mode 100644 index 0000000..0ead757 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Http/Curl/CurlVersion.php b/vendor/guzzle/guzzle/src/Guzzle/Http/Curl/CurlVersion.php new file mode 100644 index 0000000..c3f99dd --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Http/Curl/RequestMediator.php b/vendor/guzzle/guzzle/src/Guzzle/Http/Curl/RequestMediator.php new file mode 100644 index 0000000..5d1a0cd --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Http/EntityBody.php b/vendor/guzzle/guzzle/src/Guzzle/Http/EntityBody.php new file mode 100644 index 0000000..b60d170 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Http/EntityBodyInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Http/EntityBodyInterface.php new file mode 100644 index 0000000..e640f57 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Http/Exception/ClientErrorResponseException.php b/vendor/guzzle/guzzle/src/Guzzle/Http/Exception/ClientErrorResponseException.php new file mode 100644 index 0000000..04d7ddc --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Http/Exception/HttpException.php b/vendor/guzzle/guzzle/src/Guzzle/Http/Exception/HttpException.php new file mode 100644 index 0000000..ee87295 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Http/Exception/RequestException.php b/vendor/guzzle/guzzle/src/Guzzle/Http/Exception/RequestException.php new file mode 100644 index 0000000..274df2c --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Http/Exception/ServerErrorResponseException.php b/vendor/guzzle/guzzle/src/Guzzle/Http/Exception/ServerErrorResponseException.php new file mode 100644 index 0000000..f0f7cfe --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Http/Message/AbstractMessage.php b/vendor/guzzle/guzzle/src/Guzzle/Http/Message/AbstractMessage.php new file mode 100644 index 0000000..0d066ff --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Http/Message/EntityEnclosingRequest.php b/vendor/guzzle/guzzle/src/Guzzle/Http/Message/EntityEnclosingRequest.php new file mode 100644 index 0000000..212850a --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Http/Message/EntityEnclosingRequestInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Http/Message/EntityEnclosingRequestInterface.php new file mode 100644 index 0000000..49ad459 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Http/Message/Header.php b/vendor/guzzle/guzzle/src/Guzzle/Http/Message/Header.php new file mode 100644 index 0000000..50597b2 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Http/Message/Header/CacheControl.php b/vendor/guzzle/guzzle/src/Guzzle/Http/Message/Header/CacheControl.php new file mode 100644 index 0000000..77789e5 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Http/Message/Header/HeaderCollection.php b/vendor/guzzle/guzzle/src/Guzzle/Http/Message/Header/HeaderCollection.php new file mode 100644 index 0000000..8c7f6ae --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Http/Message/Header/HeaderFactory.php b/vendor/guzzle/guzzle/src/Guzzle/Http/Message/Header/HeaderFactory.php new file mode 100644 index 0000000..0273be5 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Http/Message/Header/HeaderFactoryInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Http/Message/Header/HeaderFactoryInterface.php new file mode 100644 index 0000000..9457cf6 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Http/Message/MessageInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Http/Message/MessageInterface.php new file mode 100644 index 0000000..62bcd43 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Http/Message/PostFileInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Http/Message/PostFileInterface.php new file mode 100644 index 0000000..7f0779d --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Http/Message/RequestFactory.php b/vendor/guzzle/guzzle/src/Guzzle/Http/Message/RequestFactory.php new file mode 100644 index 0000000..598a2f6 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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' || $method == 'OPTIONS') { + // Handle non-entity-enclosing request methods + $request = new $this->requestClass($method, $url, $headers); + if ($body) { + // The body is where the response body will be stored + $type = gettype($body); + if ($type == 'string' || $type == 'resource' || $type == 'object') { + $request->setResponseBody($body); + } + } + } else { + // Create an entity enclosing request by default + $request = new $this->entityEnclosingRequestClass($method, $url, $headers); + if ($body || $body === '0') { + // Add POST fields and files to an entity enclosing request if an array is used + if (is_array($body) || $body instanceof Collection) { + // Normalize PHP style cURL uploads with a leading '@' symbol + foreach ($body as $key => $value) { + if (is_string($value) && substr($value, 0, 1) == '@') { + $request->addPostFile($key, $value); + unset($body[$key]); + } + } + // Add the fields if they are still present and not all files + $request->addPostFields($body); + } else { + // Add a raw entity body body to the request + $request->setBody($body, (string) $request->getHeader('Content-Type')); + if ((string) $request->getHeader('Transfer-Encoding') == 'chunked') { + $request->removeHeader('Content-Length'); + } + } + } + } + + if ($options) { + $this->applyOptions($request, $options); + } + + return $request; + } + + /** + * Clone a request while changing the method. Emulates the behavior of + * {@see Guzzle\Http\Message\Request::clone}, but can change the HTTP method. + * + * @param RequestInterface $request Request to clone + * @param string $method Method to set + * + * @return RequestInterface + */ + public function cloneRequestWithMethod(RequestInterface $request, $method) + { + // Create the request with the same client if possible + if ($request->getClient()) { + $cloned = $request->getClient()->createRequest($method, $request->getUrl(), $request->getHeaders()); + } else { + $cloned = $this->create($method, $request->getUrl(), $request->getHeaders()); + } + + $cloned->getCurlOptions()->replace($request->getCurlOptions()->toArray()); + $cloned->setEventDispatcher(clone $request->getEventDispatcher()); + // Ensure that that the Content-Length header is not copied if changing to GET or HEAD + if (!($cloned instanceof EntityEnclosingRequestInterface)) { + $cloned->removeHeader('Content-Length'); + } elseif ($request instanceof EntityEnclosingRequestInterface) { + $cloned->setBody($request->getBody()); + } + $cloned->getParams()->replace($request->getParams()->toArray()); + $cloned->dispatch('request.clone', array('request' => $cloned)); + + return $cloned; + } + + public function applyOptions(RequestInterface $request, array $options = array(), $flags = self::OPTIONS_NONE) + { + // Iterate over each key value pair and attempt to apply a config using function visitors + foreach ($options as $key => $value) { + $method = "visit_{$key}"; + if (isset($this->methods[$method])) { + $this->{$method}($request, $value, $flags); + } + } + } + + protected function visit_headers(RequestInterface $request, $value, $flags) + { + if (!is_array($value)) { + throw new InvalidArgumentException('headers value must be an array'); + } + + if ($flags & self::OPTIONS_AS_DEFAULTS) { + // Merge headers in but do not overwrite existing values + foreach ($value as $key => $header) { + if (!$request->hasHeader($key)) { + $request->setHeader($key, $header); + } + } + } else { + $request->addHeaders($value); + } + } + + protected function visit_body(RequestInterface $request, $value, $flags) + { + if ($request instanceof EntityEnclosingRequestInterface) { + $request->setBody($value); + } else { + throw new InvalidArgumentException('Attempting to set a body on a non-entity-enclosing request'); + } + } + + protected function visit_allow_redirects(RequestInterface $request, $value, $flags) + { + if ($value === false) { + $request->getParams()->set(RedirectPlugin::DISABLE, true); + } + } + + protected function visit_auth(RequestInterface $request, $value, $flags) + { + if (!is_array($value)) { + throw new InvalidArgumentException('auth value must be an array'); + } + + $request->setAuth($value[0], isset($value[1]) ? $value[1] : null, isset($value[2]) ? $value[2] : 'basic'); + } + + protected function visit_query(RequestInterface $request, $value, $flags) + { + if (!is_array($value)) { + throw new InvalidArgumentException('query value must be an array'); + } + + if ($flags & self::OPTIONS_AS_DEFAULTS) { + // Merge query string values in but do not overwrite existing values + $query = $request->getQuery(); + $query->overwriteWith(array_diff_key($value, $query->toArray())); + } else { + $request->getQuery()->overwriteWith($value); + } + } + + protected function visit_cookies(RequestInterface $request, $value, $flags) + { + if (!is_array($value)) { + throw new InvalidArgumentException('cookies value must be an array'); + } + + foreach ($value as $name => $v) { + $request->addCookie($name, $v); + } + } + + protected function visit_events(RequestInterface $request, $value, $flags) + { + if (!is_array($value)) { + throw new InvalidArgumentException('events value must be an array'); + } + + foreach ($value as $name => $method) { + if (is_array($method)) { + $request->getEventDispatcher()->addListener($name, $method[0], $method[1]); + } else { + $request->getEventDispatcher()->addListener($name, $method); + } + } + } + + protected function visit_plugins(RequestInterface $request, $value, $flags) + { + if (!is_array($value)) { + throw new InvalidArgumentException('plugins value must be an array'); + } + + foreach ($value as $plugin) { + $request->addSubscriber($plugin); + } + } + + protected function visit_exceptions(RequestInterface $request, $value, $flags) + { + if ($value === false || $value === 0) { + $dispatcher = $request->getEventDispatcher(); + foreach ($dispatcher->getListeners('request.error') as $listener) { + if (is_array($listener) && $listener[0] == 'Guzzle\Http\Message\Request' && $listener[1] = 'onRequestError') { + $dispatcher->removeListener('request.error', $listener); + break; + } + } + } + } + + protected function visit_save_to(RequestInterface $request, $value, $flags) + { + $request->setResponseBody($value); + } + + protected function visit_params(RequestInterface $request, $value, $flags) + { + if (!is_array($value)) { + throw new InvalidArgumentException('params value must be an array'); + } + + $request->getParams()->overwriteWith($value); + } + + protected function visit_timeout(RequestInterface $request, $value, $flags) + { + if (defined('CURLOPT_TIMEOUT_MS')) { + $request->getCurlOptions()->set(CURLOPT_TIMEOUT_MS, $value * 1000); + } else { + $request->getCurlOptions()->set(CURLOPT_TIMEOUT, $value); + } + } + + protected function visit_connect_timeout(RequestInterface $request, $value, $flags) + { + if (defined('CURLOPT_CONNECTTIMEOUT_MS')) { + $request->getCurlOptions()->set(CURLOPT_CONNECTTIMEOUT_MS, $value * 1000); + } else { + $request->getCurlOptions()->set(CURLOPT_CONNECTTIMEOUT, $value); + } + } + + protected function visit_debug(RequestInterface $request, $value, $flags) + { + if ($value) { + $request->getCurlOptions()->set(CURLOPT_VERBOSE, true); + } + } + + protected function visit_verify(RequestInterface $request, $value, $flags) + { + $curl = $request->getCurlOptions(); + if ($value === true || is_string($value)) { + $curl[CURLOPT_SSL_VERIFYHOST] = 2; + $curl[CURLOPT_SSL_VERIFYPEER] = true; + if ($value !== true) { + $curl[CURLOPT_CAINFO] = $value; + } + } elseif ($value === false) { + unset($curl[CURLOPT_CAINFO]); + $curl[CURLOPT_SSL_VERIFYHOST] = 0; + $curl[CURLOPT_SSL_VERIFYPEER] = false; + } + } + + protected function visit_proxy(RequestInterface $request, $value, $flags) + { + $request->getCurlOptions()->set(CURLOPT_PROXY, $value, $flags); + } + + protected function visit_cert(RequestInterface $request, $value, $flags) + { + if (is_array($value)) { + $request->getCurlOptions()->set(CURLOPT_SSLCERT, $value[0]); + $request->getCurlOptions()->set(CURLOPT_SSLCERTPASSWD, $value[1]); + } else { + $request->getCurlOptions()->set(CURLOPT_SSLCERT, $value); + } + } + + protected function visit_ssl_key(RequestInterface $request, $value, $flags) + { + if (is_array($value)) { + $request->getCurlOptions()->set(CURLOPT_SSLKEY, $value[0]); + $request->getCurlOptions()->set(CURLOPT_SSLKEYPASSWD, $value[1]); + } else { + $request->getCurlOptions()->set(CURLOPT_SSLKEY, $value); + } + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Http/Message/RequestFactoryInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Http/Message/RequestFactoryInterface.php new file mode 100644 index 0000000..6088f10 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Http/Mimetypes.php b/vendor/guzzle/guzzle/src/Guzzle/Http/Mimetypes.php new file mode 100644 index 0000000..d71586a --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Http/QueryAggregator/CommaAggregator.php b/vendor/guzzle/guzzle/src/Guzzle/Http/QueryAggregator/CommaAggregator.php new file mode 100644 index 0000000..4b4e49d --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Http/QueryAggregator/DuplicateAggregator.php b/vendor/guzzle/guzzle/src/Guzzle/Http/QueryAggregator/DuplicateAggregator.php new file mode 100644 index 0000000..1bf1730 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Http/QueryAggregator/PhpAggregator.php b/vendor/guzzle/guzzle/src/Guzzle/Http/QueryAggregator/PhpAggregator.php new file mode 100644 index 0000000..133ea2b --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Http/QueryAggregator/QueryAggregatorInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Http/QueryAggregator/QueryAggregatorInterface.php new file mode 100644 index 0000000..72bee62 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Http/ReadLimitEntityBody.php b/vendor/guzzle/guzzle/src/Guzzle/Http/ReadLimitEntityBody.php new file mode 100644 index 0000000..a34893a --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Http/ReadLimitEntityBody.php @@ -0,0 +1,106 @@ +setLimit($limit)->setOffset($offset); + } + + /** + * Returns only a subset of the decorated entity body when cast as a string + * {@inheritdoc} + */ + public function __toString() + { + return substr((string) $this->body, $this->offset, $this->limit) ?: ''; + } + + public function isConsumed() + { + return $this->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/guzzle/guzzle/src/Guzzle/Http/RedirectPlugin.php b/vendor/guzzle/guzzle/src/Guzzle/Http/RedirectPlugin.php new file mode 100644 index 0000000..1a824b8 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Http/Resources/cacert.pem b/vendor/guzzle/guzzle/src/Guzzle/Http/Resources/cacert.pem new file mode 100644 index 0000000..67f696a --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Http/Resources/cacert.pem @@ -0,0 +1,3785 @@ +## +## ca-bundle.crt -- Bundle of CA Root Certificates +## +## Certificate data from Mozilla as of: Tue Jan 28 09:38:07 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://mxr.mozilla.org/mozilla-release/source/security/nss/lib/ckfw/builtins/certdata.txt?raw=1 +## +## It contains the certificates in PEM format and therefore +## can be directly used with curl / libcurl / php_curl, or with +## an Apache+mod_ssl webserver for SSL client authentication. +## Just configure this file as the SSLCACertificateFile. +## + + +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----- +MIIFtzCCA5+gAwIBAgICBQkwDQYJKoZIhvcNAQEFBQAwRTELMAkGA1UEBhMCQk0xGTAXBgNVBAoT +EFF1b1ZhZGlzIExpbWl0ZWQxGzAZBgNVBAMTElF1b1ZhZGlzIFJvb3QgQ0EgMjAeFw0wNjExMjQx +ODI3MDBaFw0zMTExMjQxODIzMzNaMEUxCzAJBgNVBAYTAkJNMRkwFwYDVQQKExBRdW9WYWRpcyBM +aW1pdGVkMRswGQYDVQQDExJRdW9WYWRpcyBSb290IENBIDIwggIiMA0GCSqGSIb3DQEBAQUAA4IC +DwAwggIKAoICAQCaGMpLlA0ALa8DKYrwD4HIrkwZhR0In6spRIXzL4GtMh6QRr+jhiYaHv5+HBg6 +XJxgFyo6dIMzMH1hVBHL7avg5tKifvVrbxi3Cgst/ek+7wrGsxDp3MJGF/hd/aTa/55JWpzmM+Yk +lvc/ulsrHHo1wtZn/qtmUIttKGAr79dgw8eTvI02kfN/+NsRE8Scd3bBrrcCaoF6qUWD4gXmuVbB +lDePSHFjIuwXZQeVikvfj8ZaCuWw419eaxGrDPmF60Tp+ARz8un+XJiM9XOva7R+zdRcAitMOeGy +lZUtQofX1bOQQ7dsE/He3fbE+Ik/0XX1ksOR1YqI0JDs3G3eicJlcZaLDQP9nL9bFqyS2+r+eXyt +66/3FsvbzSUr5R/7mp/iUcw6UwxI5g69ybR2BlLmEROFcmMDBOAENisgGQLodKcftslWZvB1Jdxn +wQ5hYIizPtGo/KPaHbDRsSNU30R2be1B2MGyIrZTHN81Hdyhdyox5C315eXbyOD/5YDXC2Og/zOh +D7osFRXql7PSorW+8oyWHhqPHWykYTe5hnMz15eWniN9gqRMgeKh0bpnX5UHoycR7hYQe7xFSkyy +BNKr79X9DFHOUGoIMfmR2gyPZFwDwzqLID9ujWc9Otb+fVuIyV77zGHcizN300QyNQliBJIWENie +J0f7OyHj+OsdWwIDAQABo4GwMIGtMA8GA1UdEwEB/wQFMAMBAf8wCwYDVR0PBAQDAgEGMB0GA1Ud +DgQWBBQahGK8SEwzJQTU7tD2A8QZRtGUazBuBgNVHSMEZzBlgBQahGK8SEwzJQTU7tD2A8QZRtGU +a6FJpEcwRTELMAkGA1UEBhMCQk0xGTAXBgNVBAoTEFF1b1ZhZGlzIExpbWl0ZWQxGzAZBgNVBAMT +ElF1b1ZhZGlzIFJvb3QgQ0EgMoICBQkwDQYJKoZIhvcNAQEFBQADggIBAD4KFk2fBluornFdLwUv +Z+YTRYPENvbzwCYMDbVHZF34tHLJRqUDGCdViXh9duqWNIAXINzng/iN/Ae42l9NLmeyhP3ZRPx3 +UIHmfLTJDQtyU/h2BwdBR5YM++CCJpNVjP4iH2BlfF/nJrP3MpCYUNQ3cVX2kiF495V5+vgtJodm +VjB3pjd4M1IQWK4/YY7yarHvGH5KWWPKjaJW1acvvFYfzznB4vsKqBUsfU16Y8Zsl0Q80m/DShcK ++JDSV6IZUaUtl0HaB0+pUNqQjZRG4T7wlP0QADj1O+hA4bRuVhogzG9Yje0uRY/W6ZM/57Es3zrW +IozchLsib9D45MY56QSIPMO661V6bYCZJPVsAfv4l7CUW+v90m/xd2gNNWQjrLhVoQPRTUIZ3Ph1 +WVaj+ahJefivDrkRoHy3au000LYmYjgahwz46P0u05B/B5EqHdZ+XIWDmbA4CD/pXvk1B+TJYm5X +f6dQlfe6yJvmjqIBxdZmv3lh8zwc4bmCXF2gw+nYSL0ZohEUGW6yhhtoPkg3Goi3XZZenMfvJ2II +4pEZXNLxId26F0KCl3GBUzGpn/Z9Yr9y4aOTHcyKJloJONDO1w2AFrR4pTqHTI2KpdVGl/IsELm8 +VCLAAVBpQ570su9t+Oza8eOx79+Rj1QqCyXBJhnEUhAFZdWCEOrCMc0u +-----END CERTIFICATE----- + +QuoVadis Root CA 3 +================== +-----BEGIN CERTIFICATE----- +MIIGnTCCBIWgAwIBAgICBcYwDQYJKoZIhvcNAQEFBQAwRTELMAkGA1UEBhMCQk0xGTAXBgNVBAoT +EFF1b1ZhZGlzIExpbWl0ZWQxGzAZBgNVBAMTElF1b1ZhZGlzIFJvb3QgQ0EgMzAeFw0wNjExMjQx +OTExMjNaFw0zMTExMjQxOTA2NDRaMEUxCzAJBgNVBAYTAkJNMRkwFwYDVQQKExBRdW9WYWRpcyBM +aW1pdGVkMRswGQYDVQQDExJRdW9WYWRpcyBSb290IENBIDMwggIiMA0GCSqGSIb3DQEBAQUAA4IC +DwAwggIKAoICAQDMV0IWVJzmmNPTTe7+7cefQzlKZbPoFog02w1ZkXTPkrgEQK0CSzGrvI2RaNgg +DhoB4hp7Thdd4oq3P5kazethq8Jlph+3t723j/z9cI8LoGe+AaJZz3HmDyl2/7FWeUUrH556VOij +KTVopAFPD6QuN+8bv+OPEKhyq1hX51SGyMnzW9os2l2ObjyjPtr7guXd8lyyBTNvijbO0BNO/79K +DDRMpsMhvVAEVeuxu537RR5kFd5VAYwCdrXLoT9CabwvvWhDFlaJKjdhkf2mrk7AyxRllDdLkgbv +BNDInIjbC3uBr7E9KsRlOni27tyAsdLTmZw67mtaa7ONt9XOnMK+pUsvFrGeaDsGb659n/je7Mwp +p5ijJUMv7/FfJuGITfhebtfZFG4ZM2mnO4SJk8RTVROhUXhA+LjJou57ulJCg54U7QVSWllWp5f8 +nT8KKdjcT5EOE7zelaTfi5m+rJsziO+1ga8bxiJTyPbH7pcUsMV8eFLI8M5ud2CEpukqdiDtWAEX +MJPpGovgc2PZapKUSU60rUqFxKMiMPwJ7Wgic6aIDFUhWMXhOp8q3crhkODZc6tsgLjoC2SToJyM +Gf+z0gzskSaHirOi4XCPLArlzW1oUevaPwV/izLmE1xr/l9A4iLItLRkT9a6fUg+qGkM17uGcclz +uD87nSVL2v9A6wIDAQABo4IBlTCCAZEwDwYDVR0TAQH/BAUwAwEB/zCB4QYDVR0gBIHZMIHWMIHT +BgkrBgEEAb5YAAMwgcUwgZMGCCsGAQUFBwICMIGGGoGDQW55IHVzZSBvZiB0aGlzIENlcnRpZmlj +YXRlIGNvbnN0aXR1dGVzIGFjY2VwdGFuY2Ugb2YgdGhlIFF1b1ZhZGlzIFJvb3QgQ0EgMyBDZXJ0 +aWZpY2F0ZSBQb2xpY3kgLyBDZXJ0aWZpY2F0aW9uIFByYWN0aWNlIFN0YXRlbWVudC4wLQYIKwYB +BQUHAgEWIWh0dHA6Ly93d3cucXVvdmFkaXNnbG9iYWwuY29tL2NwczALBgNVHQ8EBAMCAQYwHQYD +VR0OBBYEFPLAE+CCQz777i9nMpY1XNu4ywLQMG4GA1UdIwRnMGWAFPLAE+CCQz777i9nMpY1XNu4 +ywLQoUmkRzBFMQswCQYDVQQGEwJCTTEZMBcGA1UEChMQUXVvVmFkaXMgTGltaXRlZDEbMBkGA1UE +AxMSUXVvVmFkaXMgUm9vdCBDQSAzggIFxjANBgkqhkiG9w0BAQUFAAOCAgEAT62gLEz6wPJv92ZV +qyM07ucp2sNbtrCD2dDQ4iH782CnO11gUyeim/YIIirnv6By5ZwkajGxkHon24QRiSemd1o417+s +hvzuXYO8BsbRd2sPbSQvS3pspweWyuOEn62Iix2rFo1bZhfZFvSLgNLd+LJ2w/w4E6oM3kJpK27z +POuAJ9v1pkQNn1pVWQvVDVJIxa6f8i+AxeoyUDUSly7B4f/xI4hROJ/yZlZ25w9Rl6VSDE1JUZU2 +Pb+iSwwQHYaZTKrzchGT5Or2m9qoXadNt54CrnMAyNojA+j56hl0YgCUyyIgvpSnWbWCar6ZeXqp +8kokUvd0/bpO5qgdAm6xDYBEwa7TIzdfu4V8K5Iu6H6li92Z4b8nby1dqnuH/grdS/yO9SbkbnBC +bjPsMZ57k8HkyWkaPcBrTiJt7qtYTcbQQcEr6k8Sh17rRdhs9ZgC06DYVYoGmRmioHfRMJ6szHXu +g/WwYjnPbFfiTNKRCw51KBuav/0aQ/HKd/s7j2G4aSgWQgRecCocIdiP4b0jWy10QJLZYxkNc91p +vGJHvOB0K7Lrfb5BG7XARsWhIstfTsEokt4YutUqKLsRixeTmJlglFwjz1onl14LBQaTNx47aTbr +qZ5hHY8y2o4M1nQ+ewkk2gF3R8Q7zTSMmfXK4SVhM7JZG+Ju1zdXtg2pEto= +-----END CERTIFICATE----- + +Security Communication Root CA +============================== +-----BEGIN CERTIFICATE----- +MIIDWjCCAkKgAwIBAgIBADANBgkqhkiG9w0BAQUFADBQMQswCQYDVQQGEwJKUDEYMBYGA1UEChMP +U0VDT00gVHJ1c3QubmV0MScwJQYDVQQLEx5TZWN1cml0eSBDb21tdW5pY2F0aW9uIFJvb3RDQTEw +HhcNMDMwOTMwMDQyMDQ5WhcNMjMwOTMwMDQyMDQ5WjBQMQswCQYDVQQGEwJKUDEYMBYGA1UEChMP +U0VDT00gVHJ1c3QubmV0MScwJQYDVQQLEx5TZWN1cml0eSBDb21tdW5pY2F0aW9uIFJvb3RDQTEw +ggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCzs/5/022x7xZ8V6UMbXaKL0u/ZPtM7orw +8yl89f/uKuDp6bpbZCKamm8sOiZpUQWZJtzVHGpxxpp9Hp3dfGzGjGdnSj74cbAZJ6kJDKaVv0uM +DPpVmDvY6CKhS3E4eayXkmmziX7qIWgGmBSWh9JhNrxtJ1aeV+7AwFb9Ms+k2Y7CI9eNqPPYJayX +5HA49LY6tJ07lyZDo6G8SVlyTCMwhwFY9k6+HGhWZq/NQV3Is00qVUarH9oe4kA92819uZKAnDfd +DJZkndwi92SL32HeFZRSFaB9UslLqCHJxrHty8OVYNEP8Ktw+N/LTX7s1vqr2b1/VPKl6Xn62dZ2 +JChzAgMBAAGjPzA9MB0GA1UdDgQWBBSgc0mZaNyFW2XjmygvV5+9M7wHSDALBgNVHQ8EBAMCAQYw +DwYDVR0TAQH/BAUwAwEB/zANBgkqhkiG9w0BAQUFAAOCAQEAaECpqLvkT115swW1F7NgE+vGkl3g +0dNq/vu+m22/xwVtWSDEHPC32oRYAmP6SBbvT6UL90qY8j+eG61Ha2POCEfrUj94nK9NrvjVT8+a +mCoQQTlSxN3Zmw7vkwGusi7KaEIkQmywszo+zenaSMQVy+n5Bw+SUEmK3TGXX8npN6o7WWWXlDLJ +s58+OmJYxUmtYg5xpTKqL8aJdkNAExNnPaJUJRDL8Try2frbSVa7pv6nQTXD4IhhyYjH3zYQIphZ +6rBK+1YWc26sTfcioU+tHXotRSflMMFe8toTyyVCUZVHA4xsIcx0Qu1T/zOLjw9XARYvz6buyXAi +FL39vmwLAw== +-----END CERTIFICATE----- + +Sonera Class 2 Root CA +====================== +-----BEGIN CERTIFICATE----- +MIIDIDCCAgigAwIBAgIBHTANBgkqhkiG9w0BAQUFADA5MQswCQYDVQQGEwJGSTEPMA0GA1UEChMG +U29uZXJhMRkwFwYDVQQDExBTb25lcmEgQ2xhc3MyIENBMB4XDTAxMDQwNjA3Mjk0MFoXDTIxMDQw +NjA3Mjk0MFowOTELMAkGA1UEBhMCRkkxDzANBgNVBAoTBlNvbmVyYTEZMBcGA1UEAxMQU29uZXJh +IENsYXNzMiBDQTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAJAXSjWdyvANlsdE+hY3 +/Ei9vX+ALTU74W+oZ6m/AxxNjG8yR9VBaKQTBME1DJqEQ/xcHf+Js+gXGM2RX/uJ4+q/Tl18GybT +dXnt5oTjV+WtKcT0OijnpXuENmmz/V52vaMtmdOQTiMofRhj8VQ7Jp12W5dCsv+u8E7s3TmVToMG +f+dJQMjFAbJUWmYdPfz56TwKnoG4cPABi+QjVHzIrviQHgCWctRUz2EjvOr7nQKV0ba5cTppCD8P +tOFCx4j1P5iop7oc4HFx71hXgVB6XGt0Rg6DA5jDjqhu8nYybieDwnPz3BjotJPqdURrBGAgcVeH +nfO+oJAjPYok4doh28MCAwEAAaMzMDEwDwYDVR0TAQH/BAUwAwEB/zARBgNVHQ4ECgQISqCqWITT +XjwwCwYDVR0PBAQDAgEGMA0GCSqGSIb3DQEBBQUAA4IBAQBazof5FnIVV0sd2ZvnoiYw7JNn39Yt +0jSv9zilzqsWuasvfDXLrNAPtEwr/IDva4yRXzZ299uzGxnq9LIR/WFxRL8oszodv7ND6J+/3DEI +cbCdjdY0RzKQxmUk96BKfARzjzlvF4xytb1LyHr4e4PDKE6cCepnP7JnBBvDFNr450kkkdAdavph +Oe9r5yF1BgfYErQhIHBCcYHaPJo2vqZbDWpsmh+Re/n570K6Tk6ezAyNlNzZRZxe7EJQY670XcSx +EtzKO6gunRRaBXW37Ndj4ro1tgQIkejanZz2ZrUYrAqmVCY0M9IbwdR/GjqOC6oybtv8TyWf2TLH +llpwrN9M +-----END CERTIFICATE----- + +Staat der Nederlanden Root CA +============================= +-----BEGIN CERTIFICATE----- +MIIDujCCAqKgAwIBAgIEAJiWijANBgkqhkiG9w0BAQUFADBVMQswCQYDVQQGEwJOTDEeMBwGA1UE +ChMVU3RhYXQgZGVyIE5lZGVybGFuZGVuMSYwJAYDVQQDEx1TdGFhdCBkZXIgTmVkZXJsYW5kZW4g +Um9vdCBDQTAeFw0wMjEyMTcwOTIzNDlaFw0xNTEyMTYwOTE1MzhaMFUxCzAJBgNVBAYTAk5MMR4w +HAYDVQQKExVTdGFhdCBkZXIgTmVkZXJsYW5kZW4xJjAkBgNVBAMTHVN0YWF0IGRlciBOZWRlcmxh +bmRlbiBSb290IENBMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAmNK1URF6gaYUmHFt +vsznExvWJw56s2oYHLZhWtVhCb/ekBPHZ+7d89rFDBKeNVU+LCeIQGv33N0iYfXCxw719tV2U02P +jLwYdjeFnejKScfST5gTCaI+Ioicf9byEGW07l8Y1Rfj+MX94p2i71MOhXeiD+EwR+4A5zN9RGca +C1Hoi6CeUJhoNFIfLm0B8mBF8jHrqTFoKbt6QZ7GGX+UtFE5A3+y3qcym7RHjm+0Sq7lr7HcsBth +vJly3uSJt3omXdozSVtSnA71iq3DuD3oBmrC1SoLbHuEvVYFy4ZlkuxEK7COudxwC0barbxjiDn6 +22r+I/q85Ej0ZytqERAhSQIDAQABo4GRMIGOMAwGA1UdEwQFMAMBAf8wTwYDVR0gBEgwRjBEBgRV +HSAAMDwwOgYIKwYBBQUHAgEWLmh0dHA6Ly93d3cucGtpb3ZlcmhlaWQubmwvcG9saWNpZXMvcm9v +dC1wb2xpY3kwDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBSofeu8Y6R0E3QA7Jbg0zTBLL9s+DAN +BgkqhkiG9w0BAQUFAAOCAQEABYSHVXQ2YcG70dTGFagTtJ+k/rvuFbQvBgwp8qiSpGEN/KtcCFtR +EytNwiphyPgJWPwtArI5fZlmgb9uXJVFIGzmeafR2Bwp/MIgJ1HI8XxdNGdphREwxgDS1/PTfLbw +MVcoEoJz6TMvplW0C5GUR5z6u3pCMuiufi3IvKwUv9kP2Vv8wfl6leF9fpb8cbDCTMjfRTTJzg3y +nGQI0DvDKcWy7ZAEwbEpkcUwb8GpcjPM/l0WFywRaed+/sWDCN+83CI6LiBpIzlWYGeQiy52OfsR +iJf2fL1LuCAWZwWN4jvBcj+UlTfHXbme2JOhF4//DGYVwSR8MnwDHTuhWEUykw== +-----END CERTIFICATE----- + +TDC Internet Root CA +==================== +-----BEGIN CERTIFICATE----- +MIIEKzCCAxOgAwIBAgIEOsylTDANBgkqhkiG9w0BAQUFADBDMQswCQYDVQQGEwJESzEVMBMGA1UE +ChMMVERDIEludGVybmV0MR0wGwYDVQQLExRUREMgSW50ZXJuZXQgUm9vdCBDQTAeFw0wMTA0MDUx +NjMzMTdaFw0yMTA0MDUxNzAzMTdaMEMxCzAJBgNVBAYTAkRLMRUwEwYDVQQKEwxUREMgSW50ZXJu +ZXQxHTAbBgNVBAsTFFREQyBJbnRlcm5ldCBSb290IENBMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8A +MIIBCgKCAQEAxLhAvJHVYx/XmaCLDEAedLdInUaMArLgJF/wGROnN4NrXceO+YQwzho7+vvOi20j +xsNuZp+Jpd/gQlBn+h9sHvTQBda/ytZO5GhgbEaqHF1j4QeGDmUApy6mcca8uYGoOn0a0vnRrEvL +znWv3Hv6gXPU/Lq9QYjUdLP5Xjg6PEOo0pVOd20TDJ2PeAG3WiAfAzc14izbSysseLlJ28TQx5yc +5IogCSEWVmb/Bexb4/DPqyQkXsN/cHoSxNK1EKC2IeGNeGlVRGn1ypYcNIUXJXfi9i8nmHj9eQY6 +otZaQ8H/7AQ77hPv01ha/5Lr7K7a8jcDR0G2l8ktCkEiu7vmpwIDAQABo4IBJTCCASEwEQYJYIZI +AYb4QgEBBAQDAgAHMGUGA1UdHwReMFwwWqBYoFakVDBSMQswCQYDVQQGEwJESzEVMBMGA1UEChMM +VERDIEludGVybmV0MR0wGwYDVQQLExRUREMgSW50ZXJuZXQgUm9vdCBDQTENMAsGA1UEAxMEQ1JM +MTArBgNVHRAEJDAigA8yMDAxMDQwNTE2MzMxN1qBDzIwMjEwNDA1MTcwMzE3WjALBgNVHQ8EBAMC +AQYwHwYDVR0jBBgwFoAUbGQBx/2FbazI2p5QCIUItTxWqFAwHQYDVR0OBBYEFGxkAcf9hW2syNqe +UAiFCLU8VqhQMAwGA1UdEwQFMAMBAf8wHQYJKoZIhvZ9B0EABBAwDhsIVjUuMDo0LjADAgSQMA0G +CSqGSIb3DQEBBQUAA4IBAQBOQ8zR3R0QGwZ/t6T609lN+yOfI1Rb5osvBCiLtSdtiaHsmGnc540m +gwV5dOy0uaOXwTUA/RXaOYE6lTGQ3pfphqiZdwzlWqCE/xIWrG64jcN7ksKsLtB9KOy282A4aW8+ +2ARVPp7MVdK6/rtHBNcK2RYKNCn1WBPVT8+PVkuzHu7TmHnaCB4Mb7j4Fifvwm899qNLPg7kbWzb +O0ESm70NRyN/PErQr8Cv9u8btRXE64PECV90i9kR+8JWsTz4cMo0jUNAE4z9mQNUecYu6oah9jrU +Cbz0vGbMPVjQV0kK7iXiQe4T+Zs4NNEA9X7nlB38aQNiuJkFBT1reBK9sG9l +-----END CERTIFICATE----- + +UTN DATACorp SGC Root CA +======================== +-----BEGIN CERTIFICATE----- +MIIEXjCCA0agAwIBAgIQRL4Mi1AAIbQR0ypoBqmtaTANBgkqhkiG9w0BAQUFADCBkzELMAkGA1UE +BhMCVVMxCzAJBgNVBAgTAlVUMRcwFQYDVQQHEw5TYWx0IExha2UgQ2l0eTEeMBwGA1UEChMVVGhl +IFVTRVJUUlVTVCBOZXR3b3JrMSEwHwYDVQQLExhodHRwOi8vd3d3LnVzZXJ0cnVzdC5jb20xGzAZ +BgNVBAMTElVUTiAtIERBVEFDb3JwIFNHQzAeFw05OTA2MjQxODU3MjFaFw0xOTA2MjQxOTA2MzBa +MIGTMQswCQYDVQQGEwJVUzELMAkGA1UECBMCVVQxFzAVBgNVBAcTDlNhbHQgTGFrZSBDaXR5MR4w +HAYDVQQKExVUaGUgVVNFUlRSVVNUIE5ldHdvcmsxITAfBgNVBAsTGGh0dHA6Ly93d3cudXNlcnRy +dXN0LmNvbTEbMBkGA1UEAxMSVVROIC0gREFUQUNvcnAgU0dDMIIBIjANBgkqhkiG9w0BAQEFAAOC +AQ8AMIIBCgKCAQEA3+5YEKIrblXEjr8uRgnn4AgPLit6E5Qbvfa2gI5lBZMAHryv4g+OGQ0SR+ys +raP6LnD43m77VkIVni5c7yPeIbkFdicZD0/Ww5y0vpQZY/KmEQrrU0icvvIpOxboGqBMpsn0GFlo +wHDyUwDAXlCCpVZvNvlK4ESGoE1O1kduSUrLZ9emxAW5jh70/P/N5zbgnAVssjMiFdC04MwXwLLA +9P4yPykqlXvY8qdOD1R8oQ2AswkDwf9c3V6aPryuvEeKaq5xyh+xKrhfQgUL7EYw0XILyulWbfXv +33i+Ybqypa4ETLyorGkVl73v67SMvzX41MPRKA5cOp9wGDMgd8SirwIDAQABo4GrMIGoMAsGA1Ud +DwQEAwIBxjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBRTMtGzz3/64PGgXYVOktKeRR20TzA9 +BgNVHR8ENjA0MDKgMKAuhixodHRwOi8vY3JsLnVzZXJ0cnVzdC5jb20vVVROLURBVEFDb3JwU0dD +LmNybDAqBgNVHSUEIzAhBggrBgEFBQcDAQYKKwYBBAGCNwoDAwYJYIZIAYb4QgQBMA0GCSqGSIb3 +DQEBBQUAA4IBAQAnNZcAiosovcYzMB4p/OL31ZjUQLtgyr+rFywJNn9Q+kHcrpY6CiM+iVnJowft +Gzet/Hy+UUla3joKVAgWRcKZsYfNjGjgaQPpxE6YsjuMFrMOoAyYUJuTqXAJyCyjj98C5OBxOvG0 +I3KgqgHf35g+FFCgMSa9KOlaMCZ1+XtgHI3zzVAmbQQnmt/VDUVHKWss5nbZqSl9Mt3JNjy9rjXx +EZ4du5A/EkdOjtd+D2JzHVImOBwYSf0wdJrE5SIv2MCN7ZF6TACPcn9d2t0bi0Vr591pl6jFVkwP +DPafepE39peC4N1xaf92P2BNPM/3mfnGV/TJVTl4uix5yaaIK/QI +-----END CERTIFICATE----- + +UTN USERFirst Hardware Root CA +============================== +-----BEGIN CERTIFICATE----- +MIIEdDCCA1ygAwIBAgIQRL4Mi1AAJLQR0zYq/mUK/TANBgkqhkiG9w0BAQUFADCBlzELMAkGA1UE +BhMCVVMxCzAJBgNVBAgTAlVUMRcwFQYDVQQHEw5TYWx0IExha2UgQ2l0eTEeMBwGA1UEChMVVGhl +IFVTRVJUUlVTVCBOZXR3b3JrMSEwHwYDVQQLExhodHRwOi8vd3d3LnVzZXJ0cnVzdC5jb20xHzAd +BgNVBAMTFlVUTi1VU0VSRmlyc3QtSGFyZHdhcmUwHhcNOTkwNzA5MTgxMDQyWhcNMTkwNzA5MTgx +OTIyWjCBlzELMAkGA1UEBhMCVVMxCzAJBgNVBAgTAlVUMRcwFQYDVQQHEw5TYWx0IExha2UgQ2l0 +eTEeMBwGA1UEChMVVGhlIFVTRVJUUlVTVCBOZXR3b3JrMSEwHwYDVQQLExhodHRwOi8vd3d3LnVz +ZXJ0cnVzdC5jb20xHzAdBgNVBAMTFlVUTi1VU0VSRmlyc3QtSGFyZHdhcmUwggEiMA0GCSqGSIb3 +DQEBAQUAA4IBDwAwggEKAoIBAQCx98M4P7Sof885glFn0G2f0v9Y8+efK+wNiVSZuTiZFvfgIXlI +wrthdBKWHTxqctU8EGc6Oe0rE81m65UJM6Rsl7HoxuzBdXmcRl6Nq9Bq/bkqVRcQVLMZ8Jr28bFd +tqdt++BxF2uiiPsA3/4aMXcMmgF6sTLjKwEHOG7DpV4jvEWbe1DByTCP2+UretNb+zNAHqDVmBe8 +i4fDidNdoI6yqqr2jmmIBsX6iSHzCJ1pLgkzmykNRg+MzEk0sGlRvfkGzWitZky8PqxhvQqIDsjf +Pe58BEydCl5rkdbux+0ojatNh4lz0G6k0B4WixThdkQDf2Os5M1JnMWS9KsyoUhbAgMBAAGjgbkw +gbYwCwYDVR0PBAQDAgHGMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFKFyXyYbKJhDlV0HN9WF +lp1L0sNFMEQGA1UdHwQ9MDswOaA3oDWGM2h0dHA6Ly9jcmwudXNlcnRydXN0LmNvbS9VVE4tVVNF +UkZpcnN0LUhhcmR3YXJlLmNybDAxBgNVHSUEKjAoBggrBgEFBQcDAQYIKwYBBQUHAwUGCCsGAQUF +BwMGBggrBgEFBQcDBzANBgkqhkiG9w0BAQUFAAOCAQEARxkP3nTGmZev/K0oXnWO6y1n7k57K9cM +//bey1WiCuFMVGWTYGufEpytXoMs61quwOQt9ABjHbjAbPLPSbtNk28GpgoiskliCE7/yMgUsogW +XecB5BKV5UU0s4tpvc+0hY91UZ59Ojg6FEgSxvunOxqNDYJAB+gECJChicsZUN/KHAG8HQQZexB2 +lzvukJDKxA4fFm517zP4029bHpbj4HR3dHuKom4t3XbWOTCC8KucUvIqx69JXn7HaOWCgchqJ/kn +iCrVWFCVH/A7HFe7fRQ5YiuayZSSKqMiDP+JJn1fIytH1xUdqWqeUQ0qUZ6B+dQ7XnASfxAynB67 +nfhmqA== +-----END CERTIFICATE----- + +Camerfirma Chambers of Commerce Root +==================================== +-----BEGIN CERTIFICATE----- +MIIEvTCCA6WgAwIBAgIBADANBgkqhkiG9w0BAQUFADB/MQswCQYDVQQGEwJFVTEnMCUGA1UEChMe +QUMgQ2FtZXJmaXJtYSBTQSBDSUYgQTgyNzQzMjg3MSMwIQYDVQQLExpodHRwOi8vd3d3LmNoYW1i +ZXJzaWduLm9yZzEiMCAGA1UEAxMZQ2hhbWJlcnMgb2YgQ29tbWVyY2UgUm9vdDAeFw0wMzA5MzAx +NjEzNDNaFw0zNzA5MzAxNjEzNDRaMH8xCzAJBgNVBAYTAkVVMScwJQYDVQQKEx5BQyBDYW1lcmZp +cm1hIFNBIENJRiBBODI3NDMyODcxIzAhBgNVBAsTGmh0dHA6Ly93d3cuY2hhbWJlcnNpZ24ub3Jn +MSIwIAYDVQQDExlDaGFtYmVycyBvZiBDb21tZXJjZSBSb290MIIBIDANBgkqhkiG9w0BAQEFAAOC +AQ0AMIIBCAKCAQEAtzZV5aVdGDDg2olUkfzIx1L4L1DZ77F1c2VHfRtbunXF/KGIJPov7coISjlU +xFF6tdpg6jg8gbLL8bvZkSM/SAFwdakFKq0fcfPJVD0dBmpAPrMMhe5cG3nCYsS4No41XQEMIwRH +NaqbYE6gZj3LJgqcQKH0XZi/caulAGgq7YN6D6IUtdQis4CwPAxaUWktWBiP7Zme8a7ileb2R6jW +DA+wWFjbw2Y3npuRVDM30pQcakjJyfKl2qUMI/cjDpwyVV5xnIQFUZot/eZOKjRa3spAN2cMVCFV +d9oKDMyXroDclDZK9D7ONhMeU+SsTjoF7Nuucpw4i9A5O4kKPnf+dQIBA6OCAUQwggFAMBIGA1Ud +EwEB/wQIMAYBAf8CAQwwPAYDVR0fBDUwMzAxoC+gLYYraHR0cDovL2NybC5jaGFtYmVyc2lnbi5v +cmcvY2hhbWJlcnNyb290LmNybDAdBgNVHQ4EFgQU45T1sU3p26EpW1eLTXYGduHRooowDgYDVR0P +AQH/BAQDAgEGMBEGCWCGSAGG+EIBAQQEAwIABzAnBgNVHREEIDAegRxjaGFtYmVyc3Jvb3RAY2hh +bWJlcnNpZ24ub3JnMCcGA1UdEgQgMB6BHGNoYW1iZXJzcm9vdEBjaGFtYmVyc2lnbi5vcmcwWAYD +VR0gBFEwTzBNBgsrBgEEAYGHLgoDATA+MDwGCCsGAQUFBwIBFjBodHRwOi8vY3BzLmNoYW1iZXJz +aWduLm9yZy9jcHMvY2hhbWJlcnNyb290Lmh0bWwwDQYJKoZIhvcNAQEFBQADggEBAAxBl8IahsAi +fJ/7kPMa0QOx7xP5IV8EnNrJpY0nbJaHkb5BkAFyk+cefV/2icZdp0AJPaxJRUXcLo0waLIJuvvD +L8y6C98/d3tGfToSJI6WjzwFCm/SlCgdbQzALogi1djPHRPH8EjX1wWnz8dHnjs8NMiAT9QUu/wN +UPf6s+xCX6ndbcj0dc97wXImsQEcXCz9ek60AcUFV7nnPKoF2YjpB0ZBzu9Bga5Y34OirsrXdx/n +ADydb47kMgkdTXg0eDQ8lJsm7U9xxhl6vSAiSFr+S30Dt+dYvsYyTnQeaN2oaFuzPu5ifdmA6Ap1 +erfutGWaIZDgqtCYvDi1czyL+Nw= +-----END CERTIFICATE----- + +Camerfirma Global Chambersign Root +================================== +-----BEGIN CERTIFICATE----- +MIIExTCCA62gAwIBAgIBADANBgkqhkiG9w0BAQUFADB9MQswCQYDVQQGEwJFVTEnMCUGA1UEChMe +QUMgQ2FtZXJmaXJtYSBTQSBDSUYgQTgyNzQzMjg3MSMwIQYDVQQLExpodHRwOi8vd3d3LmNoYW1i +ZXJzaWduLm9yZzEgMB4GA1UEAxMXR2xvYmFsIENoYW1iZXJzaWduIFJvb3QwHhcNMDMwOTMwMTYx +NDE4WhcNMzcwOTMwMTYxNDE4WjB9MQswCQYDVQQGEwJFVTEnMCUGA1UEChMeQUMgQ2FtZXJmaXJt +YSBTQSBDSUYgQTgyNzQzMjg3MSMwIQYDVQQLExpodHRwOi8vd3d3LmNoYW1iZXJzaWduLm9yZzEg +MB4GA1UEAxMXR2xvYmFsIENoYW1iZXJzaWduIFJvb3QwggEgMA0GCSqGSIb3DQEBAQUAA4IBDQAw +ggEIAoIBAQCicKLQn0KuWxfH2H3PFIP8T8mhtxOviteePgQKkotgVvq0Mi+ITaFgCPS3CU6gSS9J +1tPfnZdan5QEcOw/Wdm3zGaLmFIoCQLfxS+EjXqXd7/sQJ0lcqu1PzKY+7e3/HKE5TWH+VX6ox8O +by4o3Wmg2UIQxvi1RMLQQ3/bvOSiPGpVeAp3qdjqGTK3L/5cPxvusZjsyq16aUXjlg9V9ubtdepl +6DJWk0aJqCWKZQbua795B9Dxt6/tLE2Su8CoX6dnfQTyFQhwrJLWfQTSM/tMtgsL+xrJxI0DqX5c +8lCrEqWhz0hQpe/SyBoT+rB/sYIcd2oPX9wLlY/vQ37mRQklAgEDo4IBUDCCAUwwEgYDVR0TAQH/ +BAgwBgEB/wIBDDA/BgNVHR8EODA2MDSgMqAwhi5odHRwOi8vY3JsLmNoYW1iZXJzaWduLm9yZy9j +aGFtYmVyc2lnbnJvb3QuY3JsMB0GA1UdDgQWBBRDnDafsJ4wTcbOX60Qq+UDpfqpFDAOBgNVHQ8B +Af8EBAMCAQYwEQYJYIZIAYb4QgEBBAQDAgAHMCoGA1UdEQQjMCGBH2NoYW1iZXJzaWducm9vdEBj +aGFtYmVyc2lnbi5vcmcwKgYDVR0SBCMwIYEfY2hhbWJlcnNpZ25yb290QGNoYW1iZXJzaWduLm9y +ZzBbBgNVHSAEVDBSMFAGCysGAQQBgYcuCgEBMEEwPwYIKwYBBQUHAgEWM2h0dHA6Ly9jcHMuY2hh +bWJlcnNpZ24ub3JnL2Nwcy9jaGFtYmVyc2lnbnJvb3QuaHRtbDANBgkqhkiG9w0BAQUFAAOCAQEA +PDtwkfkEVCeR4e3t/mh/YV3lQWVPMvEYBZRqHN4fcNs+ezICNLUMbKGKfKX0j//U2K0X1S0E0T9Y +gOKBWYi+wONGkyT+kL0mojAt6JcmVzWJdJYY9hXiryQZVgICsroPFOrGimbBhkVVi76SvpykBMdJ +PJ7oKXqJ1/6v/2j1pReQvayZzKWGVwlnRtvWFsJG8eSpUPWP0ZIV018+xgBJOm5YstHRJw0lyDL4 +IBHNfTIzSJRUTN3cecQwn+uOuFW114hcxWokPbLTBQNRxgfvzBRydD1ucs4YKIxKoHflCStFREes +t2d/AYoFWpO+ocH/+OcOZ6RHSXZddZAa9SaP8A== +-----END CERTIFICATE----- + +NetLock Notary (Class A) Root +============================= +-----BEGIN CERTIFICATE----- +MIIGfTCCBWWgAwIBAgICAQMwDQYJKoZIhvcNAQEEBQAwga8xCzAJBgNVBAYTAkhVMRAwDgYDVQQI +EwdIdW5nYXJ5MREwDwYDVQQHEwhCdWRhcGVzdDEnMCUGA1UEChMeTmV0TG9jayBIYWxvemF0Yml6 +dG9uc2FnaSBLZnQuMRowGAYDVQQLExFUYW51c2l0dmFueWtpYWRvazE2MDQGA1UEAxMtTmV0TG9j +ayBLb3pqZWd5em9pIChDbGFzcyBBKSBUYW51c2l0dmFueWtpYWRvMB4XDTk5MDIyNDIzMTQ0N1oX +DTE5MDIxOTIzMTQ0N1owga8xCzAJBgNVBAYTAkhVMRAwDgYDVQQIEwdIdW5nYXJ5MREwDwYDVQQH +EwhCdWRhcGVzdDEnMCUGA1UEChMeTmV0TG9jayBIYWxvemF0Yml6dG9uc2FnaSBLZnQuMRowGAYD +VQQLExFUYW51c2l0dmFueWtpYWRvazE2MDQGA1UEAxMtTmV0TG9jayBLb3pqZWd5em9pIChDbGFz +cyBBKSBUYW51c2l0dmFueWtpYWRvMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAvHSM +D7tM9DceqQWC2ObhbHDqeLVu0ThEDaiDzl3S1tWBxdRL51uUcCbbO51qTGL3cfNk1mE7PetzozfZ +z+qMkjvN9wfcZnSX9EUi3fRc4L9t875lM+QVOr/bmJBVOMTtplVjC7B4BPTjbsE/jvxReB+SnoPC +/tmwqcm8WgD/qaiYdPv2LD4VOQ22BFWoDpggQrOxJa1+mm9dU7GrDPzr4PN6s6iz/0b2Y6LYOph7 +tqyF/7AlT3Rj5xMHpQqPBffAZG9+pyeAlt7ULoZgx2srXnN7F+eRP2QM2EsiNCubMvJIH5+hCoR6 +4sKtlz2O1cH5VqNQ6ca0+pii7pXmKgOM3wIDAQABo4ICnzCCApswDgYDVR0PAQH/BAQDAgAGMBIG +A1UdEwEB/wQIMAYBAf8CAQQwEQYJYIZIAYb4QgEBBAQDAgAHMIICYAYJYIZIAYb4QgENBIICURaC +Ak1GSUdZRUxFTSEgRXplbiB0YW51c2l0dmFueSBhIE5ldExvY2sgS2Z0LiBBbHRhbGFub3MgU3pv +bGdhbHRhdGFzaSBGZWx0ZXRlbGVpYmVuIGxlaXJ0IGVsamFyYXNvayBhbGFwamFuIGtlc3p1bHQu +IEEgaGl0ZWxlc2l0ZXMgZm9seWFtYXRhdCBhIE5ldExvY2sgS2Z0LiB0ZXJtZWtmZWxlbG9zc2Vn +LWJpenRvc2l0YXNhIHZlZGkuIEEgZGlnaXRhbGlzIGFsYWlyYXMgZWxmb2dhZGFzYW5hayBmZWx0 +ZXRlbGUgYXogZWxvaXJ0IGVsbGVub3J6ZXNpIGVsamFyYXMgbWVndGV0ZWxlLiBBeiBlbGphcmFz +IGxlaXJhc2EgbWVndGFsYWxoYXRvIGEgTmV0TG9jayBLZnQuIEludGVybmV0IGhvbmxhcGphbiBh +IGh0dHBzOi8vd3d3Lm5ldGxvY2submV0L2RvY3MgY2ltZW4gdmFneSBrZXJoZXRvIGF6IGVsbGVu +b3J6ZXNAbmV0bG9jay5uZXQgZS1tYWlsIGNpbWVuLiBJTVBPUlRBTlQhIFRoZSBpc3N1YW5jZSBh +bmQgdGhlIHVzZSBvZiB0aGlzIGNlcnRpZmljYXRlIGlzIHN1YmplY3QgdG8gdGhlIE5ldExvY2sg +Q1BTIGF2YWlsYWJsZSBhdCBodHRwczovL3d3dy5uZXRsb2NrLm5ldC9kb2NzIG9yIGJ5IGUtbWFp +bCBhdCBjcHNAbmV0bG9jay5uZXQuMA0GCSqGSIb3DQEBBAUAA4IBAQBIJEb3ulZv+sgoA0BO5TE5 +ayZrU3/b39/zcT0mwBQOxmd7I6gMc90Bu8bKbjc5VdXHjFYgDigKDtIqpLBJUsY4B/6+CgmM0ZjP +ytoUMaFP0jn8DxEsQ8Pdq5PHVT5HfBgaANzze9jyf1JsIPQLX2lS9O74silg6+NJMSEN1rUQQeJB +CWziGppWS3cC9qCbmieH6FUpccKQn0V4GuEVZD3QDtigdp+uxdAu6tYPVuxkf1qbFFgBJ34TUMdr +KuZoPL9coAob4Q566eKAw+np9v1sEZ7Q5SgnK1QyQhSCdeZK8CtmdWOMovsEPoMOmzbwGOQmIMOM +8CgHrTwXZoi1/baI +-----END CERTIFICATE----- + +NetLock Business (Class B) Root +=============================== +-----BEGIN CERTIFICATE----- +MIIFSzCCBLSgAwIBAgIBaTANBgkqhkiG9w0BAQQFADCBmTELMAkGA1UEBhMCSFUxETAPBgNVBAcT +CEJ1ZGFwZXN0MScwJQYDVQQKEx5OZXRMb2NrIEhhbG96YXRiaXp0b25zYWdpIEtmdC4xGjAYBgNV +BAsTEVRhbnVzaXR2YW55a2lhZG9rMTIwMAYDVQQDEylOZXRMb2NrIFV6bGV0aSAoQ2xhc3MgQikg +VGFudXNpdHZhbnlraWFkbzAeFw05OTAyMjUxNDEwMjJaFw0xOTAyMjAxNDEwMjJaMIGZMQswCQYD +VQQGEwJIVTERMA8GA1UEBxMIQnVkYXBlc3QxJzAlBgNVBAoTHk5ldExvY2sgSGFsb3phdGJpenRv +bnNhZ2kgS2Z0LjEaMBgGA1UECxMRVGFudXNpdHZhbnlraWFkb2sxMjAwBgNVBAMTKU5ldExvY2sg +VXpsZXRpIChDbGFzcyBCKSBUYW51c2l0dmFueWtpYWRvMIGfMA0GCSqGSIb3DQEBAQUAA4GNADCB +iQKBgQCx6gTsIKAjwo84YM/HRrPVG/77uZmeBNwcf4xKgZjupNTKihe5In+DCnVMm8Bp2GQ5o+2S +o/1bXHQawEfKOml2mrriRBf8TKPV/riXiK+IA4kfpPIEPsgHC+b5sy96YhQJRhTKZPWLgLViqNhr +1nGTLbO/CVRY7QbrqHvcQ7GhaQIDAQABo4ICnzCCApswEgYDVR0TAQH/BAgwBgEB/wIBBDAOBgNV +HQ8BAf8EBAMCAAYwEQYJYIZIAYb4QgEBBAQDAgAHMIICYAYJYIZIAYb4QgENBIICURaCAk1GSUdZ +RUxFTSEgRXplbiB0YW51c2l0dmFueSBhIE5ldExvY2sgS2Z0LiBBbHRhbGFub3MgU3pvbGdhbHRh +dGFzaSBGZWx0ZXRlbGVpYmVuIGxlaXJ0IGVsamFyYXNvayBhbGFwamFuIGtlc3p1bHQuIEEgaGl0 +ZWxlc2l0ZXMgZm9seWFtYXRhdCBhIE5ldExvY2sgS2Z0LiB0ZXJtZWtmZWxlbG9zc2VnLWJpenRv +c2l0YXNhIHZlZGkuIEEgZGlnaXRhbGlzIGFsYWlyYXMgZWxmb2dhZGFzYW5hayBmZWx0ZXRlbGUg +YXogZWxvaXJ0IGVsbGVub3J6ZXNpIGVsamFyYXMgbWVndGV0ZWxlLiBBeiBlbGphcmFzIGxlaXJh +c2EgbWVndGFsYWxoYXRvIGEgTmV0TG9jayBLZnQuIEludGVybmV0IGhvbmxhcGphbiBhIGh0dHBz +Oi8vd3d3Lm5ldGxvY2submV0L2RvY3MgY2ltZW4gdmFneSBrZXJoZXRvIGF6IGVsbGVub3J6ZXNA +bmV0bG9jay5uZXQgZS1tYWlsIGNpbWVuLiBJTVBPUlRBTlQhIFRoZSBpc3N1YW5jZSBhbmQgdGhl +IHVzZSBvZiB0aGlzIGNlcnRpZmljYXRlIGlzIHN1YmplY3QgdG8gdGhlIE5ldExvY2sgQ1BTIGF2 +YWlsYWJsZSBhdCBodHRwczovL3d3dy5uZXRsb2NrLm5ldC9kb2NzIG9yIGJ5IGUtbWFpbCBhdCBj +cHNAbmV0bG9jay5uZXQuMA0GCSqGSIb3DQEBBAUAA4GBAATbrowXr/gOkDFOzT4JwG06sPgzTEdM +43WIEJessDgVkcYplswhwG08pXTP2IKlOcNl40JwuyKQ433bNXbhoLXan3BukxowOR0w2y7jfLKR +stE3Kfq51hdcR0/jHTjrn9V7lagonhVK0dHQKwCXoOKSNitjrFgBazMpUIaD8QFI +-----END CERTIFICATE----- + +NetLock Express (Class C) Root +============================== +-----BEGIN CERTIFICATE----- +MIIFTzCCBLigAwIBAgIBaDANBgkqhkiG9w0BAQQFADCBmzELMAkGA1UEBhMCSFUxETAPBgNVBAcT +CEJ1ZGFwZXN0MScwJQYDVQQKEx5OZXRMb2NrIEhhbG96YXRiaXp0b25zYWdpIEtmdC4xGjAYBgNV +BAsTEVRhbnVzaXR2YW55a2lhZG9rMTQwMgYDVQQDEytOZXRMb2NrIEV4cHJlc3N6IChDbGFzcyBD +KSBUYW51c2l0dmFueWtpYWRvMB4XDTk5MDIyNTE0MDgxMVoXDTE5MDIyMDE0MDgxMVowgZsxCzAJ +BgNVBAYTAkhVMREwDwYDVQQHEwhCdWRhcGVzdDEnMCUGA1UEChMeTmV0TG9jayBIYWxvemF0Yml6 +dG9uc2FnaSBLZnQuMRowGAYDVQQLExFUYW51c2l0dmFueWtpYWRvazE0MDIGA1UEAxMrTmV0TG9j +ayBFeHByZXNzeiAoQ2xhc3MgQykgVGFudXNpdHZhbnlraWFkbzCBnzANBgkqhkiG9w0BAQEFAAOB +jQAwgYkCgYEA6+ywbGGKIyWvYCDj2Z/8kwvbXY2wobNAOoLO/XXgeDIDhlqGlZHtU/qdQPzm6N3Z +W3oDvV3zOwzDUXmbrVWg6dADEK8KuhRC2VImESLH0iDMgqSaqf64gXadarfSNnU+sYYJ9m5tfk63 +euyucYT2BDMIJTLrdKwWRMbkQJMdf60CAwEAAaOCAp8wggKbMBIGA1UdEwEB/wQIMAYBAf8CAQQw +DgYDVR0PAQH/BAQDAgAGMBEGCWCGSAGG+EIBAQQEAwIABzCCAmAGCWCGSAGG+EIBDQSCAlEWggJN +RklHWUVMRU0hIEV6ZW4gdGFudXNpdHZhbnkgYSBOZXRMb2NrIEtmdC4gQWx0YWxhbm9zIFN6b2xn +YWx0YXRhc2kgRmVsdGV0ZWxlaWJlbiBsZWlydCBlbGphcmFzb2sgYWxhcGphbiBrZXN6dWx0LiBB +IGhpdGVsZXNpdGVzIGZvbHlhbWF0YXQgYSBOZXRMb2NrIEtmdC4gdGVybWVrZmVsZWxvc3NlZy1i +aXp0b3NpdGFzYSB2ZWRpLiBBIGRpZ2l0YWxpcyBhbGFpcmFzIGVsZm9nYWRhc2FuYWsgZmVsdGV0 +ZWxlIGF6IGVsb2lydCBlbGxlbm9yemVzaSBlbGphcmFzIG1lZ3RldGVsZS4gQXogZWxqYXJhcyBs +ZWlyYXNhIG1lZ3RhbGFsaGF0byBhIE5ldExvY2sgS2Z0LiBJbnRlcm5ldCBob25sYXBqYW4gYSBo +dHRwczovL3d3dy5uZXRsb2NrLm5ldC9kb2NzIGNpbWVuIHZhZ3kga2VyaGV0byBheiBlbGxlbm9y +emVzQG5ldGxvY2submV0IGUtbWFpbCBjaW1lbi4gSU1QT1JUQU5UISBUaGUgaXNzdWFuY2UgYW5k +IHRoZSB1c2Ugb2YgdGhpcyBjZXJ0aWZpY2F0ZSBpcyBzdWJqZWN0IHRvIHRoZSBOZXRMb2NrIENQ +UyBhdmFpbGFibGUgYXQgaHR0cHM6Ly93d3cubmV0bG9jay5uZXQvZG9jcyBvciBieSBlLW1haWwg +YXQgY3BzQG5ldGxvY2submV0LjANBgkqhkiG9w0BAQQFAAOBgQAQrX/XDDKACtiG8XmYta3UzbM2 +xJZIwVzNmtkFLp++UOv0JhQQLdRmF/iewSf98e3ke0ugbLWrmldwpu2gpO0u9f38vf5NNwgMvOOW +gyL1SRt/Syu0VMGAfJlOHdCM7tCs5ZL6dVb+ZKATj7i4Fp1hBWeAyNDYpQcCNJgEjTME1A== +-----END CERTIFICATE----- + +XRamp Global CA Root +==================== +-----BEGIN CERTIFICATE----- +MIIEMDCCAxigAwIBAgIQUJRs7Bjq1ZxN1ZfvdY+grTANBgkqhkiG9w0BAQUFADCBgjELMAkGA1UE +BhMCVVMxHjAcBgNVBAsTFXd3dy54cmFtcHNlY3VyaXR5LmNvbTEkMCIGA1UEChMbWFJhbXAgU2Vj +dXJpdHkgU2VydmljZXMgSW5jMS0wKwYDVQQDEyRYUmFtcCBHbG9iYWwgQ2VydGlmaWNhdGlvbiBB +dXRob3JpdHkwHhcNMDQxMTAxMTcxNDA0WhcNMzUwMTAxMDUzNzE5WjCBgjELMAkGA1UEBhMCVVMx +HjAcBgNVBAsTFXd3dy54cmFtcHNlY3VyaXR5LmNvbTEkMCIGA1UEChMbWFJhbXAgU2VjdXJpdHkg +U2VydmljZXMgSW5jMS0wKwYDVQQDEyRYUmFtcCBHbG9iYWwgQ2VydGlmaWNhdGlvbiBBdXRob3Jp +dHkwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCYJB69FbS638eMpSe2OAtp87ZOqCwu +IR1cRN8hXX4jdP5efrRKt6atH67gBhbim1vZZ3RrXYCPKZ2GG9mcDZhtdhAoWORlsH9KmHmf4MMx +foArtYzAQDsRhtDLooY2YKTVMIJt2W7QDxIEM5dfT2Fa8OT5kavnHTu86M/0ay00fOJIYRyO82FE +zG+gSqmUsE3a56k0enI4qEHMPJQRfevIpoy3hsvKMzvZPTeL+3o+hiznc9cKV6xkmxnr9A8ECIqs +AxcZZPRaJSKNNCyy9mgdEm3Tih4U2sSPpuIjhdV6Db1q4Ons7Be7QhtnqiXtRYMh/MHJfNViPvry +xS3T/dRlAgMBAAGjgZ8wgZwwEwYJKwYBBAGCNxQCBAYeBABDAEEwCwYDVR0PBAQDAgGGMA8GA1Ud +EwEB/wQFMAMBAf8wHQYDVR0OBBYEFMZPoj0GY4QJnM5i5ASsjVy16bYbMDYGA1UdHwQvMC0wK6Ap +oCeGJWh0dHA6Ly9jcmwueHJhbXBzZWN1cml0eS5jb20vWEdDQS5jcmwwEAYJKwYBBAGCNxUBBAMC +AQEwDQYJKoZIhvcNAQEFBQADggEBAJEVOQMBG2f7Shz5CmBbodpNl2L5JFMn14JkTpAuw0kbK5rc +/Kh4ZzXxHfARvbdI4xD2Dd8/0sm2qlWkSLoC295ZLhVbO50WfUfXN+pfTXYSNrsf16GBBEYgoyxt +qZ4Bfj8pzgCT3/3JknOJiWSe5yvkHJEs0rnOfc5vMZnT5r7SHpDwCRR5XCOrTdLaIR9NmXmd4c8n +nxCbHIgNsIpkQTG4DmyQJKSbXHGPurt+HBvbaoAPIbzp26a3QPSyi6mx5O+aGtA9aZnuqCij4Tyz +8LIRnM98QObd50N9otg6tamN8jSZxNQQ4Qb9CYQQO+7ETPTsJ3xCwnR8gooJybQDJbw= +-----END CERTIFICATE----- + +Go Daddy Class 2 CA +=================== +-----BEGIN CERTIFICATE----- +MIIEADCCAuigAwIBAgIBADANBgkqhkiG9w0BAQUFADBjMQswCQYDVQQGEwJVUzEhMB8GA1UEChMY +VGhlIEdvIERhZGR5IEdyb3VwLCBJbmMuMTEwLwYDVQQLEyhHbyBEYWRkeSBDbGFzcyAyIENlcnRp +ZmljYXRpb24gQXV0aG9yaXR5MB4XDTA0MDYyOTE3MDYyMFoXDTM0MDYyOTE3MDYyMFowYzELMAkG +A1UEBhMCVVMxITAfBgNVBAoTGFRoZSBHbyBEYWRkeSBHcm91cCwgSW5jLjExMC8GA1UECxMoR28g +RGFkZHkgQ2xhc3MgMiBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTCCASAwDQYJKoZIhvcNAQEBBQAD +ggENADCCAQgCggEBAN6d1+pXGEmhW+vXX0iG6r7d/+TvZxz0ZWizV3GgXne77ZtJ6XCAPVYYYwhv +2vLM0D9/AlQiVBDYsoHUwHU9S3/Hd8M+eKsaA7Ugay9qK7HFiH7Eux6wwdhFJ2+qN1j3hybX2C32 +qRe3H3I2TqYXP2WYktsqbl2i/ojgC95/5Y0V4evLOtXiEqITLdiOr18SPaAIBQi2XKVlOARFmR6j +YGB0xUGlcmIbYsUfb18aQr4CUWWoriMYavx4A6lNf4DD+qta/KFApMoZFv6yyO9ecw3ud72a9nmY +vLEHZ6IVDd2gWMZEewo+YihfukEHU1jPEX44dMX4/7VpkI+EdOqXG68CAQOjgcAwgb0wHQYDVR0O +BBYEFNLEsNKR1EwRcbNhyz2h/t2oatTjMIGNBgNVHSMEgYUwgYKAFNLEsNKR1EwRcbNhyz2h/t2o +atTjoWekZTBjMQswCQYDVQQGEwJVUzEhMB8GA1UEChMYVGhlIEdvIERhZGR5IEdyb3VwLCBJbmMu +MTEwLwYDVQQLEyhHbyBEYWRkeSBDbGFzcyAyIENlcnRpZmljYXRpb24gQXV0aG9yaXR5ggEAMAwG +A1UdEwQFMAMBAf8wDQYJKoZIhvcNAQEFBQADggEBADJL87LKPpH8EsahB4yOd6AzBhRckB4Y9wim +PQoZ+YeAEW5p5JYXMP80kWNyOO7MHAGjHZQopDH2esRU1/blMVgDoszOYtuURXO1v0XJJLXVggKt +I3lpjbi2Tc7PTMozI+gciKqdi0FuFskg5YmezTvacPd+mSYgFFQlq25zheabIZ0KbIIOqPjCDPoQ +HmyW74cNxA9hi63ugyuV+I6ShHI56yDqg+2DzZduCLzrTia2cyvk0/ZM/iZx4mERdEr/VxqHD3VI +Ls9RaRegAhJhldXRQLIQTO7ErBBDpqWeCtWVYpoNz4iCxTIM5CufReYNnyicsbkqWletNw+vHX/b +vZ8= +-----END CERTIFICATE----- + +Starfield Class 2 CA +==================== +-----BEGIN CERTIFICATE----- +MIIEDzCCAvegAwIBAgIBADANBgkqhkiG9w0BAQUFADBoMQswCQYDVQQGEwJVUzElMCMGA1UEChMc +U3RhcmZpZWxkIFRlY2hub2xvZ2llcywgSW5jLjEyMDAGA1UECxMpU3RhcmZpZWxkIENsYXNzIDIg +Q2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMDQwNjI5MTczOTE2WhcNMzQwNjI5MTczOTE2WjBo +MQswCQYDVQQGEwJVUzElMCMGA1UEChMcU3RhcmZpZWxkIFRlY2hub2xvZ2llcywgSW5jLjEyMDAG +A1UECxMpU3RhcmZpZWxkIENsYXNzIDIgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwggEgMA0GCSqG +SIb3DQEBAQUAA4IBDQAwggEIAoIBAQC3Msj+6XGmBIWtDBFk385N78gDGIc/oav7PKaf8MOh2tTY +bitTkPskpD6E8J7oX+zlJ0T1KKY/e97gKvDIr1MvnsoFAZMej2YcOadN+lq2cwQlZut3f+dZxkqZ +JRRU6ybH838Z1TBwj6+wRir/resp7defqgSHo9T5iaU0X9tDkYI22WY8sbi5gv2cOj4QyDvvBmVm +epsZGD3/cVE8MC5fvj13c7JdBmzDI1aaK4UmkhynArPkPw2vCHmCuDY96pzTNbO8acr1zJ3o/WSN +F4Azbl5KXZnJHoe0nRrA1W4TNSNe35tfPe/W93bC6j67eA0cQmdrBNj41tpvi/JEoAGrAgEDo4HF +MIHCMB0GA1UdDgQWBBS/X7fRzt0fhvRbVazc1xDCDqmI5zCBkgYDVR0jBIGKMIGHgBS/X7fRzt0f +hvRbVazc1xDCDqmI56FspGowaDELMAkGA1UEBhMCVVMxJTAjBgNVBAoTHFN0YXJmaWVsZCBUZWNo +bm9sb2dpZXMsIEluYy4xMjAwBgNVBAsTKVN0YXJmaWVsZCBDbGFzcyAyIENlcnRpZmljYXRpb24g +QXV0aG9yaXR5ggEAMAwGA1UdEwQFMAMBAf8wDQYJKoZIhvcNAQEFBQADggEBAAWdP4id0ckaVaGs +afPzWdqbAYcaT1epoXkJKtv3L7IezMdeatiDh6GX70k1PncGQVhiv45YuApnP+yz3SFmH8lU+nLM +PUxA2IGvd56Deruix/U0F47ZEUD0/CwqTRV/p2JdLiXTAAsgGh1o+Re49L2L7ShZ3U0WixeDyLJl +xy16paq8U4Zt3VekyvggQQto8PT7dL5WXXp59fkdheMtlb71cZBDzI0fmgAKhynpVSJYACPq4xJD +KVtHCN2MQWplBqjlIapBtJUhlbl90TSrE9atvNziPTnNvT51cKEYWQPJIrSPnNVeKtelttQKbfi3 +QBFGmh95DmK/D5fs4C8fF5Q= +-----END CERTIFICATE----- + +StartCom Certification Authority +================================ +-----BEGIN CERTIFICATE----- +MIIHyTCCBbGgAwIBAgIBATANBgkqhkiG9w0BAQUFADB9MQswCQYDVQQGEwJJTDEWMBQGA1UEChMN +U3RhcnRDb20gTHRkLjErMCkGA1UECxMiU2VjdXJlIERpZ2l0YWwgQ2VydGlmaWNhdGUgU2lnbmlu +ZzEpMCcGA1UEAxMgU3RhcnRDb20gQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMDYwOTE3MTk0 +NjM2WhcNMzYwOTE3MTk0NjM2WjB9MQswCQYDVQQGEwJJTDEWMBQGA1UEChMNU3RhcnRDb20gTHRk +LjErMCkGA1UECxMiU2VjdXJlIERpZ2l0YWwgQ2VydGlmaWNhdGUgU2lnbmluZzEpMCcGA1UEAxMg +U3RhcnRDb20gQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAw +ggIKAoICAQDBiNsJvGxGfHiflXu1M5DycmLWwTYgIiRezul38kMKogZkpMyONvg45iPwbm2xPN1y +o4UcodM9tDMr0y+v/uqwQVlntsQGfQqedIXWeUyAN3rfOQVSWff0G0ZDpNKFhdLDcfN1YjS6LIp/ +Ho/u7TTQEceWzVI9ujPW3U3eCztKS5/CJi/6tRYccjV3yjxd5srhJosaNnZcAdt0FCX+7bWgiA/d +eMotHweXMAEtcnn6RtYTKqi5pquDSR3l8u/d5AGOGAqPY1MWhWKpDhk6zLVmpsJrdAfkK+F2PrRt +2PZE4XNiHzvEvqBTViVsUQn3qqvKv3b9bZvzndu/PWa8DFaqr5hIlTpL36dYUNk4dalb6kMMAv+Z +6+hsTXBbKWWc3apdzK8BMewM69KN6Oqce+Zu9ydmDBpI125C4z/eIT574Q1w+2OqqGwaVLRcJXrJ +osmLFqa7LH4XXgVNWG4SHQHuEhANxjJ/GP/89PrNbpHoNkm+Gkhpi8KWTRoSsmkXwQqQ1vp5Iki/ +untp+HDH+no32NgN0nZPV/+Qt+OR0t3vwmC3Zzrd/qqc8NSLf3Iizsafl7b4r4qgEKjZ+xjGtrVc +UjyJthkqcwEKDwOzEmDyei+B26Nu/yYwl/WL3YlXtq09s68rxbd2AvCl1iuahhQqcvbjM4xdCUsT +37uMdBNSSwIDAQABo4ICUjCCAk4wDAYDVR0TBAUwAwEB/zALBgNVHQ8EBAMCAa4wHQYDVR0OBBYE +FE4L7xqkQFulF2mHMMo0aEPQQa7yMGQGA1UdHwRdMFswLKAqoCiGJmh0dHA6Ly9jZXJ0LnN0YXJ0 +Y29tLm9yZy9zZnNjYS1jcmwuY3JsMCugKaAnhiVodHRwOi8vY3JsLnN0YXJ0Y29tLm9yZy9zZnNj +YS1jcmwuY3JsMIIBXQYDVR0gBIIBVDCCAVAwggFMBgsrBgEEAYG1NwEBATCCATswLwYIKwYBBQUH +AgEWI2h0dHA6Ly9jZXJ0LnN0YXJ0Y29tLm9yZy9wb2xpY3kucGRmMDUGCCsGAQUFBwIBFilodHRw +Oi8vY2VydC5zdGFydGNvbS5vcmcvaW50ZXJtZWRpYXRlLnBkZjCB0AYIKwYBBQUHAgIwgcMwJxYg +U3RhcnQgQ29tbWVyY2lhbCAoU3RhcnRDb20pIEx0ZC4wAwIBARqBl0xpbWl0ZWQgTGlhYmlsaXR5 +LCByZWFkIHRoZSBzZWN0aW9uICpMZWdhbCBMaW1pdGF0aW9ucyogb2YgdGhlIFN0YXJ0Q29tIENl +cnRpZmljYXRpb24gQXV0aG9yaXR5IFBvbGljeSBhdmFpbGFibGUgYXQgaHR0cDovL2NlcnQuc3Rh +cnRjb20ub3JnL3BvbGljeS5wZGYwEQYJYIZIAYb4QgEBBAQDAgAHMDgGCWCGSAGG+EIBDQQrFilT +dGFydENvbSBGcmVlIFNTTCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTANBgkqhkiG9w0BAQUFAAOC +AgEAFmyZ9GYMNPXQhV59CuzaEE44HF7fpiUFS5Eyweg78T3dRAlbB0mKKctmArexmvclmAk8jhvh +3TaHK0u7aNM5Zj2gJsfyOZEdUauCe37Vzlrk4gNXcGmXCPleWKYK34wGmkUWFjgKXlf2Ysd6AgXm +vB618p70qSmD+LIU424oh0TDkBreOKk8rENNZEXO3SipXPJzewT4F+irsfMuXGRuczE6Eri8sxHk +fY+BUZo7jYn0TZNmezwD7dOaHZrzZVD1oNB1ny+v8OqCQ5j4aZyJecRDjkZy42Q2Eq/3JR44iZB3 +fsNrarnDy0RLrHiQi+fHLB5LEUTINFInzQpdn4XBidUaePKVEFMy3YCEZnXZtWgo+2EuvoSoOMCZ +EoalHmdkrQYuL6lwhceWD3yJZfWOQ1QOq92lgDmUYMA0yZZwLKMS9R9Ie70cfmu3nZD0Ijuu+Pwq +yvqCUqDvr0tVk+vBtfAii6w0TiYiBKGHLHVKt+V9E9e4DGTANtLJL4YSjCMJwRuCO3NJo2pXh5Tl +1njFmUNj403gdy3hZZlyaQQaRwnmDwFWJPsfvw55qVguucQJAX6Vum0ABj6y6koQOdjQK/W/7HW/ +lwLFCRsI3FU34oH7N4RDYiDK51ZLZer+bMEkkyShNOsF/5oirpt9P/FlUQqmMGqz9IgcgA38coro +g14= +-----END CERTIFICATE----- + +Taiwan GRCA +=========== +-----BEGIN CERTIFICATE----- +MIIFcjCCA1qgAwIBAgIQH51ZWtcvwgZEpYAIaeNe9jANBgkqhkiG9w0BAQUFADA/MQswCQYDVQQG +EwJUVzEwMC4GA1UECgwnR292ZXJubWVudCBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MB4X +DTAyMTIwNTEzMjMzM1oXDTMyMTIwNTEzMjMzM1owPzELMAkGA1UEBhMCVFcxMDAuBgNVBAoMJ0dv +dmVybm1lbnQgUm9vdCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTCCAiIwDQYJKoZIhvcNAQEBBQAD +ggIPADCCAgoCggIBAJoluOzMonWoe/fOW1mKydGGEghU7Jzy50b2iPN86aXfTEc2pBsBHH8eV4qN +w8XRIePaJD9IK/ufLqGU5ywck9G/GwGHU5nOp/UKIXZ3/6m3xnOUT0b3EEk3+qhZSV1qgQdW8or5 +BtD3cCJNtLdBuTK4sfCxw5w/cP1T3YGq2GN49thTbqGsaoQkclSGxtKyyhwOeYHWtXBiCAEuTk8O +1RGvqa/lmr/czIdtJuTJV6L7lvnM4T9TjGxMfptTCAtsF/tnyMKtsc2AtJfcdgEWFelq16TheEfO +htX7MfP6Mb40qij7cEwdScevLJ1tZqa2jWR+tSBqnTuBto9AAGdLiYa4zGX+FVPpBMHWXx1E1wov +J5pGfaENda1UhhXcSTvxls4Pm6Dso3pdvtUqdULle96ltqqvKKyskKw4t9VoNSZ63Pc78/1Fm9G7 +Q3hub/FCVGqY8A2tl+lSXunVanLeavcbYBT0peS2cWeqH+riTcFCQP5nRhc4L0c/cZyu5SHKYS1t +B6iEfC3uUSXxY5Ce/eFXiGvviiNtsea9P63RPZYLhY3Naye7twWb7LuRqQoHEgKXTiCQ8P8NHuJB +O9NAOueNXdpm5AKwB1KYXA6OM5zCppX7VRluTI6uSw+9wThNXo+EHWbNxWCWtFJaBYmOlXqYwZE8 +lSOyDvR5tMl8wUohAgMBAAGjajBoMB0GA1UdDgQWBBTMzO/MKWCkO7GStjz6MmKPrCUVOzAMBgNV +HRMEBTADAQH/MDkGBGcqBwAEMTAvMC0CAQAwCQYFKw4DAhoFADAHBgVnKgMAAAQUA5vwIhP/lSg2 +09yewDL7MTqKUWUwDQYJKoZIhvcNAQEFBQADggIBAECASvomyc5eMN1PhnR2WPWus4MzeKR6dBcZ +TulStbngCnRiqmjKeKBMmo4sIy7VahIkv9Ro04rQ2JyftB8M3jh+Vzj8jeJPXgyfqzvS/3WXy6Tj +Zwj/5cAWtUgBfen5Cv8b5Wppv3ghqMKnI6mGq3ZW6A4M9hPdKmaKZEk9GhiHkASfQlK3T8v+R0F2 +Ne//AHY2RTKbxkaFXeIksB7jSJaYV0eUVXoPQbFEJPPB/hprv4j9wabak2BegUqZIJxIZhm1AHlU +D7gsL0u8qV1bYH+Mh6XgUmMqvtg7hUAV/h62ZT/FS9p+tXo1KaMuephgIqP0fSdOLeq0dDzpD6Qz +DxARvBMB1uUO07+1EqLhRSPAzAhuYbeJq4PjJB7mXQfnHyA+z2fI56wwbSdLaG5LKlwCCDTb+Hbk +Z6MmnD+iMsJKxYEYMRBWqoTvLQr/uB930r+lWKBi5NdLkXWNiYCYfm3LU05er/ayl4WXudpVBrkk +7tfGOB5jGxI7leFYrPLfhNVfmS8NVVvmONsuP3LpSIXLuykTjx44VbnzssQwmSNOXfJIoRIM3BKQ +CZBUkQM8R+XVyWXgt0t97EfTsws+rZ7QdAAO671RrcDeLMDDav7v3Aun+kbfYNucpllQdSNpc5Oy ++fwC00fmcc4QAu4njIT/rEUNE1yDMuAlpYYsfPQS +-----END CERTIFICATE----- + +Firmaprofesional Root CA +======================== +-----BEGIN CERTIFICATE----- +MIIEVzCCAz+gAwIBAgIBATANBgkqhkiG9w0BAQUFADCBnTELMAkGA1UEBhMCRVMxIjAgBgNVBAcT +GUMvIE11bnRhbmVyIDI0NCBCYXJjZWxvbmExQjBABgNVBAMTOUF1dG9yaWRhZCBkZSBDZXJ0aWZp +Y2FjaW9uIEZpcm1hcHJvZmVzaW9uYWwgQ0lGIEE2MjYzNDA2ODEmMCQGCSqGSIb3DQEJARYXY2FA +ZmlybWFwcm9mZXNpb25hbC5jb20wHhcNMDExMDI0MjIwMDAwWhcNMTMxMDI0MjIwMDAwWjCBnTEL +MAkGA1UEBhMCRVMxIjAgBgNVBAcTGUMvIE11bnRhbmVyIDI0NCBCYXJjZWxvbmExQjBABgNVBAMT +OUF1dG9yaWRhZCBkZSBDZXJ0aWZpY2FjaW9uIEZpcm1hcHJvZmVzaW9uYWwgQ0lGIEE2MjYzNDA2 +ODEmMCQGCSqGSIb3DQEJARYXY2FAZmlybWFwcm9mZXNpb25hbC5jb20wggEiMA0GCSqGSIb3DQEB +AQUAA4IBDwAwggEKAoIBAQDnIwNvbyOlXnjOlSztlB5uCp4Bx+ow0Syd3Tfom5h5VtP8c9/Qit5V +j1H5WuretXDE7aTt/6MNbg9kUDGvASdYrv5sp0ovFy3Tc9UTHI9ZpTQsHVQERc1ouKDAA6XPhUJH +lShbz++AbOCQl4oBPB3zhxAwJkh91/zpnZFx/0GaqUC1N5wpIE8fUuOgfRNtVLcK3ulqTgesrBlf +3H5idPayBQC6haD9HThuy1q7hryUZzM1gywfI834yJFxzJeL764P3CkDG8A563DtwW4O2GcLiam8 +NeTvtjS0pbbELaW+0MOUJEjb35bTALVmGotmBQ/dPz/LP6pemkr4tErvlTcbAgMBAAGjgZ8wgZww +KgYDVR0RBCMwIYYfaHR0cDovL3d3dy5maXJtYXByb2Zlc2lvbmFsLmNvbTASBgNVHRMBAf8ECDAG +AQH/AgEBMCsGA1UdEAQkMCKADzIwMDExMDI0MjIwMDAwWoEPMjAxMzEwMjQyMjAwMDBaMA4GA1Ud +DwEB/wQEAwIBBjAdBgNVHQ4EFgQUMwugZtHq2s7eYpMEKFK1FH84aLcwDQYJKoZIhvcNAQEFBQAD +ggEBAEdz/o0nVPD11HecJ3lXV7cVVuzH2Fi3AQL0M+2TUIiefEaxvT8Ub/GzR0iLjJcG1+p+o1wq +u00vR+L4OQbJnC4xGgN49Lw4xiKLMzHwFgQEffl25EvXwOaD7FnMP97/T2u3Z36mhoEyIwOdyPdf +wUpgpZKpsaSgYMN4h7Mi8yrrW6ntBas3D7Hi05V2Y1Z0jFhyGzflZKG+TQyTmAyX9odtsz/ny4Cm +7YjHX1BiAuiZdBbQ5rQ58SfLyEDW44YQqSMSkuBpQWOnryULwMWSyx6Yo1q6xTMPoJcB3X/ge9YG +VM+h4k0460tQtcsm9MracEpqoeJ5quGnM/b9Sh/22WA= +-----END CERTIFICATE----- + +Swisscom Root CA 1 +================== +-----BEGIN CERTIFICATE----- +MIIF2TCCA8GgAwIBAgIQXAuFXAvnWUHfV8w/f52oNjANBgkqhkiG9w0BAQUFADBkMQswCQYDVQQG +EwJjaDERMA8GA1UEChMIU3dpc3Njb20xJTAjBgNVBAsTHERpZ2l0YWwgQ2VydGlmaWNhdGUgU2Vy +dmljZXMxGzAZBgNVBAMTElN3aXNzY29tIFJvb3QgQ0EgMTAeFw0wNTA4MTgxMjA2MjBaFw0yNTA4 +MTgyMjA2MjBaMGQxCzAJBgNVBAYTAmNoMREwDwYDVQQKEwhTd2lzc2NvbTElMCMGA1UECxMcRGln +aXRhbCBDZXJ0aWZpY2F0ZSBTZXJ2aWNlczEbMBkGA1UEAxMSU3dpc3Njb20gUm9vdCBDQSAxMIIC +IjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEA0LmwqAzZuz8h+BvVM5OAFmUgdbI9m2BtRsiM +MW8Xw/qabFbtPMWRV8PNq5ZJkCoZSx6jbVfd8StiKHVFXqrWW/oLJdihFvkcxC7mlSpnzNApbjyF +NDhhSbEAn9Y6cV9Nbc5fuankiX9qUvrKm/LcqfmdmUc/TilftKaNXXsLmREDA/7n29uj/x2lzZAe +AR81sH8A25Bvxn570e56eqeqDFdvpG3FEzuwpdntMhy0XmeLVNxzh+XTF3xmUHJd1BpYwdnP2IkC +b6dJtDZd0KTeByy2dbcokdaXvij1mB7qWybJvbCXc9qukSbraMH5ORXWZ0sKbU/Lz7DkQnGMU3nn +7uHbHaBuHYwadzVcFh4rUx80i9Fs/PJnB3r1re3WmquhsUvhzDdf/X/NTa64H5xD+SpYVUNFvJbN +cA78yeNmuk6NO4HLFWR7uZToXTNShXEuT46iBhFRyePLoW4xCGQMwtI89Tbo19AOeCMgkckkKmUp +WyL3Ic6DXqTz3kvTaI9GdVyDCW4pa8RwjPWd1yAv/0bSKzjCL3UcPX7ape8eYIVpQtPM+GP+HkM5 +haa2Y0EQs3MevNP6yn0WR+Kn1dCjigoIlmJWbjTb2QK5MHXjBNLnj8KwEUAKrNVxAmKLMb7dxiNY +MUJDLXT5xp6mig/p/r+D5kNXJLrvRjSq1xIBOO0CAwEAAaOBhjCBgzAOBgNVHQ8BAf8EBAMCAYYw +HQYDVR0hBBYwFDASBgdghXQBUwABBgdghXQBUwABMBIGA1UdEwEB/wQIMAYBAf8CAQcwHwYDVR0j +BBgwFoAUAyUv3m+CATpcLNwroWm1Z9SM0/0wHQYDVR0OBBYEFAMlL95vggE6XCzcK6FptWfUjNP9 +MA0GCSqGSIb3DQEBBQUAA4ICAQA1EMvspgQNDQ/NwNurqPKIlwzfky9NfEBWMXrrpA9gzXrzvsMn +jgM+pN0S734edAY8PzHyHHuRMSG08NBsl9Tpl7IkVh5WwzW9iAUPWxAaZOHHgjD5Mq2eUCzneAXQ +MbFamIp1TpBcahQq4FJHgmDmHtqBsfsUC1rxn9KVuj7QG9YVHaO+htXbD8BJZLsuUBlL0iT43R4H +VtA4oJVwIHaM190e3p9xxCPvgxNcoyQVTSlAPGrEqdi3pkSlDfTgnXceQHAm/NrZNuR55LU/vJtl +vrsRls/bxig5OgjOR1tTWsWZ/l2p3e9M1MalrQLmjAcSHm8D0W+go/MpvRLHUKKwf4ipmXeascCl +OS5cfGniLLDqN2qk4Vrh9VDlg++luyqI54zb/W1elxmofmZ1a3Hqv7HHb6D0jqTsNFFbjCYDcKF3 +1QESVwA12yPeDooomf2xEG9L/zgtYE4snOtnta1J7ksfrK/7DZBaZmBwXarNeNQk7shBoJMBkpxq +nvy5JMWzFYJ+vq6VK+uxwNrjAWALXmmshFZhvnEX/h0TD/7Gh0Xp/jKgGg0TpJRVcaUWi7rKibCy +x/yP2FS1k2Kdzs9Z+z0YzirLNRWCXf9UIltxUvu3yf5gmwBBZPCqKuy2QkPOiWaByIufOVQDJdMW +NY6E0F/6MBr1mmz0DlP5OlvRHA== +-----END CERTIFICATE----- + +DigiCert Assured ID Root CA +=========================== +-----BEGIN CERTIFICATE----- +MIIDtzCCAp+gAwIBAgIQDOfg5RfYRv6P5WD8G/AwOTANBgkqhkiG9w0BAQUFADBlMQswCQYDVQQG +EwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNlcnQuY29tMSQw +IgYDVQQDExtEaWdpQ2VydCBBc3N1cmVkIElEIFJvb3QgQ0EwHhcNMDYxMTEwMDAwMDAwWhcNMzEx +MTEwMDAwMDAwWjBlMQswCQYDVQQGEwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQL +ExB3d3cuZGlnaWNlcnQuY29tMSQwIgYDVQQDExtEaWdpQ2VydCBBc3N1cmVkIElEIFJvb3QgQ0Ew +ggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCtDhXO5EOAXLGH87dg+XESpa7cJpSIqvTO +9SA5KFhgDPiA2qkVlTJhPLWxKISKityfCgyDF3qPkKyK53lTXDGEKvYPmDI2dsze3Tyoou9q+yHy +UmHfnyDXH+Kx2f4YZNISW1/5WBg1vEfNoTb5a3/UsDg+wRvDjDPZ2C8Y/igPs6eD1sNuRMBhNZYW +/lmci3Zt1/GiSw0r/wty2p5g0I6QNcZ4VYcgoc/lbQrISXwxmDNsIumH0DJaoroTghHtORedmTpy +oeb6pNnVFzF1roV9Iq4/AUaG9ih5yLHa5FcXxH4cDrC0kqZWs72yl+2qp/C3xag/lRbQ/6GW6whf +GHdPAgMBAAGjYzBhMA4GA1UdDwEB/wQEAwIBhjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBRF +66Kv9JLLgjEtUYunpyGd823IDzAfBgNVHSMEGDAWgBRF66Kv9JLLgjEtUYunpyGd823IDzANBgkq +hkiG9w0BAQUFAAOCAQEAog683+Lt8ONyc3pklL/3cmbYMuRCdWKuh+vy1dneVrOfzM4UKLkNl2Bc +EkxY5NM9g0lFWJc1aRqoR+pWxnmrEthngYTffwk8lOa4JiwgvT2zKIn3X/8i4peEH+ll74fg38Fn +SbNd67IJKusm7Xi+fT8r87cmNW1fiQG2SVufAQWbqz0lwcy2f8Lxb4bG+mRo64EtlOtCt/qMHt1i +8b5QZ7dsvfPxH2sMNgcWfzd8qVttevESRmCD1ycEvkvOl77DZypoEd+A5wwzZr8TDRRu838fYxAe ++o0bJW1sj6W3YQGx0qMmoRBxna3iw/nDmVG3KwcIzi7mULKn+gpFL6Lw8g== +-----END CERTIFICATE----- + +DigiCert Global Root CA +======================= +-----BEGIN CERTIFICATE----- +MIIDrzCCApegAwIBAgIQCDvgVpBCRrGhdWrJWZHHSjANBgkqhkiG9w0BAQUFADBhMQswCQYDVQQG +EwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNlcnQuY29tMSAw +HgYDVQQDExdEaWdpQ2VydCBHbG9iYWwgUm9vdCBDQTAeFw0wNjExMTAwMDAwMDBaFw0zMTExMTAw +MDAwMDBaMGExCzAJBgNVBAYTAlVTMRUwEwYDVQQKEwxEaWdpQ2VydCBJbmMxGTAXBgNVBAsTEHd3 +dy5kaWdpY2VydC5jb20xIDAeBgNVBAMTF0RpZ2lDZXJ0IEdsb2JhbCBSb290IENBMIIBIjANBgkq +hkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA4jvhEXLeqKTTo1eqUKKPC3eQyaKl7hLOllsBCSDMAZOn +TjC3U/dDxGkAV53ijSLdhwZAAIEJzs4bg7/fzTtxRuLWZscFs3YnFo97nh6Vfe63SKMI2tavegw5 +BmV/Sl0fvBf4q77uKNd0f3p4mVmFaG5cIzJLv07A6Fpt43C/dxC//AH2hdmoRBBYMql1GNXRor5H +4idq9Joz+EkIYIvUX7Q6hL+hqkpMfT7PT19sdl6gSzeRntwi5m3OFBqOasv+zbMUZBfHWymeMr/y +7vrTC0LUq7dBMtoM1O/4gdW7jVg/tRvoSSiicNoxBN33shbyTApOB6jtSj1etX+jkMOvJwIDAQAB +o2MwYTAOBgNVHQ8BAf8EBAMCAYYwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUA95QNVbRTLtm +8KPiGxvDl7I90VUwHwYDVR0jBBgwFoAUA95QNVbRTLtm8KPiGxvDl7I90VUwDQYJKoZIhvcNAQEF +BQADggEBAMucN6pIExIK+t1EnE9SsPTfrgT1eXkIoyQY/EsrhMAtudXH/vTBH1jLuG2cenTnmCmr +EbXjcKChzUyImZOMkXDiqw8cvpOp/2PV5Adg06O/nVsJ8dWO41P0jmP6P6fbtGbfYmbW0W5BjfIt +tep3Sp+dWOIrWcBAI+0tKIJFPnlUkiaY4IBIqDfv8NZ5YBberOgOzW6sRBc4L0na4UU+Krk2U886 +UAb3LujEV0lsYSEY1QSteDwsOoBrp+uvFRTp2InBuThs4pFsiv9kuXclVzDAGySj4dzp30d8tbQk +CAUw7C29C79Fv1C5qfPrmAESrciIxpg0X40KPMbp1ZWVbd4= +-----END CERTIFICATE----- + +DigiCert High Assurance EV Root CA +================================== +-----BEGIN CERTIFICATE----- +MIIDxTCCAq2gAwIBAgIQAqxcJmoLQJuPC3nyrkYldzANBgkqhkiG9w0BAQUFADBsMQswCQYDVQQG +EwJVUzEVMBMGA1UEChMMRGlnaUNlcnQgSW5jMRkwFwYDVQQLExB3d3cuZGlnaWNlcnQuY29tMSsw +KQYDVQQDEyJEaWdpQ2VydCBIaWdoIEFzc3VyYW5jZSBFViBSb290IENBMB4XDTA2MTExMDAwMDAw +MFoXDTMxMTExMDAwMDAwMFowbDELMAkGA1UEBhMCVVMxFTATBgNVBAoTDERpZ2lDZXJ0IEluYzEZ +MBcGA1UECxMQd3d3LmRpZ2ljZXJ0LmNvbTErMCkGA1UEAxMiRGlnaUNlcnQgSGlnaCBBc3N1cmFu +Y2UgRVYgUm9vdCBDQTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAMbM5XPm+9S75S0t +Mqbf5YE/yc0lSbZxKsPVlDRnogocsF9ppkCxxLeyj9CYpKlBWTrT3JTWPNt0OKRKzE0lgvdKpVMS +OO7zSW1xkX5jtqumX8OkhPhPYlG++MXs2ziS4wblCJEMxChBVfvLWokVfnHoNb9Ncgk9vjo4UFt3 +MRuNs8ckRZqnrG0AFFoEt7oT61EKmEFBIk5lYYeBQVCmeVyJ3hlKV9Uu5l0cUyx+mM0aBhakaHPQ +NAQTXKFx01p8VdteZOE3hzBWBOURtCmAEvF5OYiiAhF8J2a3iLd48soKqDirCmTCv2ZdlYTBoSUe +h10aUAsgEsxBu24LUTi4S8sCAwEAAaNjMGEwDgYDVR0PAQH/BAQDAgGGMA8GA1UdEwEB/wQFMAMB +Af8wHQYDVR0OBBYEFLE+w2kD+L9HAdSYJhoIAu9jZCvDMB8GA1UdIwQYMBaAFLE+w2kD+L9HAdSY +JhoIAu9jZCvDMA0GCSqGSIb3DQEBBQUAA4IBAQAcGgaX3NecnzyIZgYIVyHbIUf4KmeqvxgydkAQ +V8GK83rZEWWONfqe/EW1ntlMMUu4kehDLI6zeM7b41N5cdblIZQB2lWHmiRk9opmzN6cN82oNLFp +myPInngiK3BD41VHMWEZ71jFhS9OMPagMRYjyOfiZRYzy78aG6A9+MpeizGLYAiJLQwGXFK3xPkK +mNEVX58Svnw2Yzi9RKR/5CYrCsSXaQ3pjOLAEFe4yHYSkVXySGnYvCoCWw9E1CAx2/S6cCZdkGCe +vEsXCS+0yx5DaMkHJ8HSXPfqIbloEpw8nL+e/IBcm2PN7EeqJSdnoDfzAIJ9VNep+OkuE6N36B9K +-----END CERTIFICATE----- + +Certplus Class 2 Primary CA +=========================== +-----BEGIN CERTIFICATE----- +MIIDkjCCAnqgAwIBAgIRAIW9S/PY2uNp9pTXX8OlRCMwDQYJKoZIhvcNAQEFBQAwPTELMAkGA1UE +BhMCRlIxETAPBgNVBAoTCENlcnRwbHVzMRswGQYDVQQDExJDbGFzcyAyIFByaW1hcnkgQ0EwHhcN +OTkwNzA3MTcwNTAwWhcNMTkwNzA2MjM1OTU5WjA9MQswCQYDVQQGEwJGUjERMA8GA1UEChMIQ2Vy +dHBsdXMxGzAZBgNVBAMTEkNsYXNzIDIgUHJpbWFyeSBDQTCCASIwDQYJKoZIhvcNAQEBBQADggEP +ADCCAQoCggEBANxQltAS+DXSCHh6tlJw/W/uz7kRy1134ezpfgSN1sxvc0NXYKwzCkTsA18cgCSR +5aiRVhKC9+Ar9NuuYS6JEI1rbLqzAr3VNsVINyPi8Fo3UjMXEuLRYE2+L0ER4/YXJQyLkcAbmXuZ +Vg2v7tK8R1fjeUl7NIknJITesezpWE7+Tt9avkGtrAjFGA7v0lPubNCdEgETjdyAYveVqUSISnFO +YFWe2yMZeVYHDD9jC1yw4r5+FfyUM1hBOHTE4Y+L3yasH7WLO7dDWWuwJKZtkIvEcupdM5i3y95e +e++U8Rs+yskhwcWYAqqi9lt3m/V+llU0HGdpwPFC40es/CgcZlUCAwEAAaOBjDCBiTAPBgNVHRME +CDAGAQH/AgEKMAsGA1UdDwQEAwIBBjAdBgNVHQ4EFgQU43Mt38sOKAze3bOkynm4jrvoMIkwEQYJ +YIZIAYb4QgEBBAQDAgEGMDcGA1UdHwQwMC4wLKAqoCiGJmh0dHA6Ly93d3cuY2VydHBsdXMuY29t +L0NSTC9jbGFzczIuY3JsMA0GCSqGSIb3DQEBBQUAA4IBAQCnVM+IRBnL39R/AN9WM2K191EBkOvD +P9GIROkkXe/nFL0gt5o8AP5tn9uQ3Nf0YtaLcF3n5QRIqWh8yfFC82x/xXp8HVGIutIKPidd3i1R +TtMTZGnkLuPT55sJmabglZvOGtd/vjzOUrMRFcEPF80Du5wlFbqidon8BvEY0JNLDnyCt6X09l/+ +7UCmnYR0ObncHoUW2ikbhiMAybuJfm6AiB4vFLQDJKgybwOaRywwvlbGp0ICcBvqQNi6BQNwB6SW +//1IMwrh3KWBkJtN3X3n57LNXMhqlfil9o3EXXgIvnsG1knPGTZQIy4I5p4FTUcY1Rbpsda2ENW7 +l7+ijrRU +-----END CERTIFICATE----- + +DST Root CA X3 +============== +-----BEGIN CERTIFICATE----- +MIIDSjCCAjKgAwIBAgIQRK+wgNajJ7qJMDmGLvhAazANBgkqhkiG9w0BAQUFADA/MSQwIgYDVQQK +ExtEaWdpdGFsIFNpZ25hdHVyZSBUcnVzdCBDby4xFzAVBgNVBAMTDkRTVCBSb290IENBIFgzMB4X +DTAwMDkzMDIxMTIxOVoXDTIxMDkzMDE0MDExNVowPzEkMCIGA1UEChMbRGlnaXRhbCBTaWduYXR1 +cmUgVHJ1c3QgQ28uMRcwFQYDVQQDEw5EU1QgUm9vdCBDQSBYMzCCASIwDQYJKoZIhvcNAQEBBQAD +ggEPADCCAQoCggEBAN+v6ZdQCINXtMxiZfaQguzH0yxrMMpb7NnDfcdAwRgUi+DoM3ZJKuM/IUmT +rE4Orz5Iy2Xu/NMhD2XSKtkyj4zl93ewEnu1lcCJo6m67XMuegwGMoOifooUMM0RoOEqOLl5CjH9 +UL2AZd+3UWODyOKIYepLYYHsUmu5ouJLGiifSKOeDNoJjj4XLh7dIN9bxiqKqy69cK3FCxolkHRy +xXtqqzTWMIn/5WgTe1QLyNau7Fqckh49ZLOMxt+/yUFw7BZy1SbsOFU5Q9D8/RhcQPGX69Wam40d +utolucbY38EVAjqr2m7xPi71XAicPNaDaeQQmxkqtilX4+U9m5/wAl0CAwEAAaNCMEAwDwYDVR0T +AQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFMSnsaR7LHH62+FLkHX/xBVghYkQ +MA0GCSqGSIb3DQEBBQUAA4IBAQCjGiybFwBcqR7uKGY3Or+Dxz9LwwmglSBd49lZRNI+DT69ikug +dB/OEIKcdBodfpga3csTS7MgROSR6cz8faXbauX+5v3gTt23ADq1cEmv8uXrAvHRAosZy5Q6XkjE +GB5YGV8eAlrwDPGxrancWYaLbumR9YbK+rlmM6pZW87ipxZzR8srzJmwN0jP41ZL9c8PDHIyh8bw +RLtTcm1D9SZImlJnt1ir/md2cXjbDaJWFBM5JDGFoqgCWjBH4d1QB7wCCZAA62RjYJsWvIjJEubS +fZGL+T0yjWW06XyxV3bqxbYoOb8VZRzI9neWagqNdwvYkQsEjgfbKbYK7p2CNTUQ +-----END CERTIFICATE----- + +DST ACES CA X6 +============== +-----BEGIN CERTIFICATE----- +MIIECTCCAvGgAwIBAgIQDV6ZCtadt3js2AdWO4YV2TANBgkqhkiG9w0BAQUFADBbMQswCQYDVQQG +EwJVUzEgMB4GA1UEChMXRGlnaXRhbCBTaWduYXR1cmUgVHJ1c3QxETAPBgNVBAsTCERTVCBBQ0VT +MRcwFQYDVQQDEw5EU1QgQUNFUyBDQSBYNjAeFw0wMzExMjAyMTE5NThaFw0xNzExMjAyMTE5NTha +MFsxCzAJBgNVBAYTAlVTMSAwHgYDVQQKExdEaWdpdGFsIFNpZ25hdHVyZSBUcnVzdDERMA8GA1UE +CxMIRFNUIEFDRVMxFzAVBgNVBAMTDkRTVCBBQ0VTIENBIFg2MIIBIjANBgkqhkiG9w0BAQEFAAOC +AQ8AMIIBCgKCAQEAuT31LMmU3HWKlV1j6IR3dma5WZFcRt2SPp/5DgO0PWGSvSMmtWPuktKe1jzI +DZBfZIGxqAgNTNj50wUoUrQBJcWVHAx+PhCEdc/BGZFjz+iokYi5Q1K7gLFViYsx+tC3dr5BPTCa +pCIlF3PoHuLTrCq9Wzgh1SpL11V94zpVvddtawJXa+ZHfAjIgrrep4c9oW24MFbCswKBXy314pow +GCi4ZtPLAZZv6opFVdbgnf9nKxcCpk4aahELfrd755jWjHZvwTvbUJN+5dCOHze4vbrGn2zpfDPy +MjwmR/onJALJfh1biEITajV8fTXpLmaRcpPVMibEdPVTo7NdmvYJywIDAQABo4HIMIHFMA8GA1Ud +EwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgHGMB8GA1UdEQQYMBaBFHBraS1vcHNAdHJ1c3Rkc3Qu +Y29tMGIGA1UdIARbMFkwVwYKYIZIAWUDAgEBATBJMEcGCCsGAQUFBwIBFjtodHRwOi8vd3d3LnRy +dXN0ZHN0LmNvbS9jZXJ0aWZpY2F0ZXMvcG9saWN5L0FDRVMtaW5kZXguaHRtbDAdBgNVHQ4EFgQU +CXIGThhDD+XWzMNqizF7eI+og7gwDQYJKoZIhvcNAQEFBQADggEBAKPYjtay284F5zLNAdMEA+V2 +5FYrnJmQ6AgwbN99Pe7lv7UkQIRJ4dEorsTCOlMwiPH1d25Ryvr/ma8kXxug/fKshMrfqfBfBC6t +Fr8hlxCBPeP/h40y3JTlR4peahPJlJU90u7INJXQgNStMgiAVDzgvVJT11J8smk/f3rPanTK+gQq +nExaBqXpIK1FZg9p8d2/6eMyi/rgwYZNcjwu2JN4Cir42NInPRmJX1p7ijvMDNpRrscL9yuwNwXs +vFcj4jjSm2jzVhKIT0J8uDHEtdvkyCE06UgRNe76x5JXxZ805Mf29w4LTJxoeHtxMcfrHuBnQfO3 +oKfN5XozNmr6mis= +-----END CERTIFICATE----- + +TURKTRUST Certificate Services Provider Root 1 +============================================== +-----BEGIN CERTIFICATE----- +MIID+zCCAuOgAwIBAgIBATANBgkqhkiG9w0BAQUFADCBtzE/MD0GA1UEAww2VMOcUktUUlVTVCBF +bGVrdHJvbmlrIFNlcnRpZmlrYSBIaXptZXQgU2HEn2xhecSxY8Sxc8SxMQswCQYDVQQGDAJUUjEP +MA0GA1UEBwwGQU5LQVJBMVYwVAYDVQQKDE0oYykgMjAwNSBUw5xSS1RSVVNUIEJpbGdpIMSwbGV0 +acWfaW0gdmUgQmlsacWfaW0gR8O8dmVubGnEn2kgSGl6bWV0bGVyaSBBLsWeLjAeFw0wNTA1MTMx +MDI3MTdaFw0xNTAzMjIxMDI3MTdaMIG3MT8wPQYDVQQDDDZUw5xSS1RSVVNUIEVsZWt0cm9uaWsg +U2VydGlmaWthIEhpem1ldCBTYcSfbGF5xLFjxLFzxLExCzAJBgNVBAYMAlRSMQ8wDQYDVQQHDAZB +TktBUkExVjBUBgNVBAoMTShjKSAyMDA1IFTDnFJLVFJVU1QgQmlsZ2kgxLBsZXRpxZ9pbSB2ZSBC +aWxpxZ9pbSBHw7x2ZW5sacSfaSBIaXptZXRsZXJpIEEuxZ4uMIIBIjANBgkqhkiG9w0BAQEFAAOC +AQ8AMIIBCgKCAQEAylIF1mMD2Bxf3dJ7XfIMYGFbazt0K3gNfUW9InTojAPBxhEqPZW8qZSwu5GX +yGl8hMW0kWxsE2qkVa2kheiVfrMArwDCBRj1cJ02i67L5BuBf5OI+2pVu32Fks66WJ/bMsW9Xe8i +Si9BB35JYbOG7E6mQW6EvAPs9TscyB/C7qju6hJKjRTP8wrgUDn5CDX4EVmt5yLqS8oUBt5CurKZ +8y1UiBAG6uEaPj1nH/vO+3yC6BFdSsG5FOpU2WabfIl9BJpiyelSPJ6c79L1JuTm5Rh8i27fbMx4 +W09ysstcP4wFjdFMjK2Sx+F4f2VsSQZQLJ4ywtdKxnWKWU51b0dewQIDAQABoxAwDjAMBgNVHRME +BTADAQH/MA0GCSqGSIb3DQEBBQUAA4IBAQAV9VX/N5aAWSGk/KEVTCD21F/aAyT8z5Aa9CEKmu46 +sWrv7/hg0Uw2ZkUd82YCdAR7kjCo3gp2D++Vbr3JN+YaDayJSFvMgzbC9UZcWYJWtNX+I7TYVBxE +q8Sn5RTOPEFhfEPmzcSBCYsk+1Ql1haolgxnB2+zUEfjHCQo3SqYpGH+2+oSN7wBGjSFvW5P55Fy +B0SFHljKVETd96y5y4khctuPwGkplyqjrhgjlxxBKot8KsF8kOipKMDTkcatKIdAaLX/7KfS0zgY +nNN9aV3wxqUeJBujR/xpB2jn5Jq07Q+hh4cCzofSSE7hvP/L8XKSRGQDJereW26fyfJOrN3H +-----END CERTIFICATE----- + +TURKTRUST Certificate Services Provider Root 2 +============================================== +-----BEGIN CERTIFICATE----- +MIIEPDCCAySgAwIBAgIBATANBgkqhkiG9w0BAQUFADCBvjE/MD0GA1UEAww2VMOcUktUUlVTVCBF +bGVrdHJvbmlrIFNlcnRpZmlrYSBIaXptZXQgU2HEn2xhecSxY8Sxc8SxMQswCQYDVQQGEwJUUjEP +MA0GA1UEBwwGQW5rYXJhMV0wWwYDVQQKDFRUw5xSS1RSVVNUIEJpbGdpIMSwbGV0acWfaW0gdmUg +QmlsacWfaW0gR8O8dmVubGnEn2kgSGl6bWV0bGVyaSBBLsWeLiAoYykgS2FzxLFtIDIwMDUwHhcN +MDUxMTA3MTAwNzU3WhcNMTUwOTE2MTAwNzU3WjCBvjE/MD0GA1UEAww2VMOcUktUUlVTVCBFbGVr +dHJvbmlrIFNlcnRpZmlrYSBIaXptZXQgU2HEn2xhecSxY8Sxc8SxMQswCQYDVQQGEwJUUjEPMA0G +A1UEBwwGQW5rYXJhMV0wWwYDVQQKDFRUw5xSS1RSVVNUIEJpbGdpIMSwbGV0acWfaW0gdmUgQmls +acWfaW0gR8O8dmVubGnEn2kgSGl6bWV0bGVyaSBBLsWeLiAoYykgS2FzxLFtIDIwMDUwggEiMA0G +CSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCpNn7DkUNMwxmYCMjHWHtPFoylzkkBH3MOrHUTpvqe +LCDe2JAOCtFp0if7qnefJ1Il4std2NiDUBd9irWCPwSOtNXwSadktx4uXyCcUHVPr+G1QRT0mJKI +x+XlZEdhR3n9wFHxwZnn3M5q+6+1ATDcRhzviuyV79z/rxAc653YsKpqhRgNF8k+v/Gb0AmJQv2g +QrSdiVFVKc8bcLyEVK3BEx+Y9C52YItdP5qtygy/p1Zbj3e41Z55SZI/4PGXJHpsmxcPbe9TmJEr +5A++WXkHeLuXlfSfadRYhwqp48y2WBmfJiGxxFmNskF1wK1pzpwACPI2/z7woQ8arBT9pmAPAgMB +AAGjQzBBMB0GA1UdDgQWBBTZN7NOBf3Zz58SFq62iS/rJTqIHDAPBgNVHQ8BAf8EBQMDBwYAMA8G +A1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQEFBQADggEBAHJglrfJ3NgpXiOFX7KzLXb7iNcX/ntt +Rbj2hWyfIvwqECLsqrkw9qtY1jkQMZkpAL2JZkH7dN6RwRgLn7Vhy506vvWolKMiVW4XSf/SKfE4 +Jl3vpao6+XF75tpYHdN0wgH6PmlYX63LaL4ULptswLbcoCb6dxriJNoaN+BnrdFzgw2lGh1uEpJ+ +hGIAF728JRhX8tepb1mIvDS3LoV4nZbcFMMsilKbloxSZj2GFotHuFEJjOp9zYhys2AzsfAKRO8P +9Qk3iCQOLGsgOqL6EfJANZxEaGM7rDNvY7wsu/LSy3Z9fYjYHcgFHW68lKlmjHdxx/qR+i9Rnuk5 +UrbnBEI= +-----END CERTIFICATE----- + +SwissSign Gold CA - G2 +====================== +-----BEGIN CERTIFICATE----- +MIIFujCCA6KgAwIBAgIJALtAHEP1Xk+wMA0GCSqGSIb3DQEBBQUAMEUxCzAJBgNVBAYTAkNIMRUw +EwYDVQQKEwxTd2lzc1NpZ24gQUcxHzAdBgNVBAMTFlN3aXNzU2lnbiBHb2xkIENBIC0gRzIwHhcN +MDYxMDI1MDgzMDM1WhcNMzYxMDI1MDgzMDM1WjBFMQswCQYDVQQGEwJDSDEVMBMGA1UEChMMU3dp +c3NTaWduIEFHMR8wHQYDVQQDExZTd2lzc1NpZ24gR29sZCBDQSAtIEcyMIICIjANBgkqhkiG9w0B +AQEFAAOCAg8AMIICCgKCAgEAr+TufoskDhJuqVAtFkQ7kpJcyrhdhJJCEyq8ZVeCQD5XJM1QiyUq +t2/876LQwB8CJEoTlo8jE+YoWACjR8cGp4QjK7u9lit/VcyLwVcfDmJlD909Vopz2q5+bbqBHH5C +jCA12UNNhPqE21Is8w4ndwtrvxEvcnifLtg+5hg3Wipy+dpikJKVyh+c6bM8K8vzARO/Ws/BtQpg +vd21mWRTuKCWs2/iJneRjOBiEAKfNA+k1ZIzUd6+jbqEemA8atufK+ze3gE/bk3lUIbLtK/tREDF +ylqM2tIrfKjuvqblCqoOpd8FUrdVxyJdMmqXl2MT28nbeTZ7hTpKxVKJ+STnnXepgv9VHKVxaSvR +AiTysybUa9oEVeXBCsdtMDeQKuSeFDNeFhdVxVu1yzSJkvGdJo+hB9TGsnhQ2wwMC3wLjEHXuend +jIj3o02yMszYF9rNt85mndT9Xv+9lz4pded+p2JYryU0pUHHPbwNUMoDAw8IWh+Vc3hiv69yFGkO +peUDDniOJihC8AcLYiAQZzlG+qkDzAQ4embvIIO1jEpWjpEA/I5cgt6IoMPiaG59je883WX0XaxR +7ySArqpWl2/5rX3aYT+YdzylkbYcjCbaZaIJbcHiVOO5ykxMgI93e2CaHt+28kgeDrpOVG2Y4OGi +GqJ3UM/EY5LsRxmd6+ZrzsECAwEAAaOBrDCBqTAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/BAUw +AwEB/zAdBgNVHQ4EFgQUWyV7lqRlUX64OfPAeGZe6Drn8O4wHwYDVR0jBBgwFoAUWyV7lqRlUX64 +OfPAeGZe6Drn8O4wRgYDVR0gBD8wPTA7BglghXQBWQECAQEwLjAsBggrBgEFBQcCARYgaHR0cDov +L3JlcG9zaXRvcnkuc3dpc3NzaWduLmNvbS8wDQYJKoZIhvcNAQEFBQADggIBACe645R88a7A3hfm +5djV9VSwg/S7zV4Fe0+fdWavPOhWfvxyeDgD2StiGwC5+OlgzczOUYrHUDFu4Up+GC9pWbY9ZIEr +44OE5iKHjn3g7gKZYbge9LgriBIWhMIxkziWMaa5O1M/wySTVltpkuzFwbs4AOPsF6m43Md8AYOf +Mke6UiI0HTJ6CVanfCU2qT1L2sCCbwq7EsiHSycR+R4tx5M/nttfJmtS2S6K8RTGRI0Vqbe/vd6m +Gu6uLftIdxf+u+yvGPUqUfA5hJeVbG4bwyvEdGB5JbAKJ9/fXtI5z0V9QkvfsywexcZdylU6oJxp +mo/a77KwPJ+HbBIrZXAVUjEaJM9vMSNQH4xPjyPDdEFjHFWoFN0+4FFQz/EbMFYOkrCChdiDyyJk +vC24JdVUorgG6q2SpCSgwYa1ShNqR88uC1aVVMvOmttqtKay20EIhid392qgQmwLOM7XdVAyksLf +KzAiSNDVQTglXaTpXZ/GlHXQRf0wl0OPkKsKx4ZzYEppLd6leNcG2mqeSz53OiATIgHQv2ieY2Br +NU0LbbqhPcCT4H8js1WtciVORvnSFu+wZMEBnunKoGqYDs/YYPIvSbjkQuE4NRb0yG5P94FW6Lqj +viOvrv1vA+ACOzB2+httQc8Bsem4yWb02ybzOqR08kkkW8mw0FfB+j564ZfJ +-----END CERTIFICATE----- + +SwissSign Silver CA - G2 +======================== +-----BEGIN CERTIFICATE----- +MIIFvTCCA6WgAwIBAgIITxvUL1S7L0swDQYJKoZIhvcNAQEFBQAwRzELMAkGA1UEBhMCQ0gxFTAT +BgNVBAoTDFN3aXNzU2lnbiBBRzEhMB8GA1UEAxMYU3dpc3NTaWduIFNpbHZlciBDQSAtIEcyMB4X +DTA2MTAyNTA4MzI0NloXDTM2MTAyNTA4MzI0NlowRzELMAkGA1UEBhMCQ0gxFTATBgNVBAoTDFN3 +aXNzU2lnbiBBRzEhMB8GA1UEAxMYU3dpc3NTaWduIFNpbHZlciBDQSAtIEcyMIICIjANBgkqhkiG +9w0BAQEFAAOCAg8AMIICCgKCAgEAxPGHf9N4Mfc4yfjDmUO8x/e8N+dOcbpLj6VzHVxumK4DV644 +N0MvFz0fyM5oEMF4rhkDKxD6LHmD9ui5aLlV8gREpzn5/ASLHvGiTSf5YXu6t+WiE7brYT7QbNHm ++/pe7R20nqA1W6GSy/BJkv6FCgU+5tkL4k+73JU3/JHpMjUi0R86TieFnbAVlDLaYQ1HTWBCrpJH +6INaUFjpiou5XaHc3ZlKHzZnu0jkg7Y360g6rw9njxcH6ATK72oxh9TAtvmUcXtnZLi2kUpCe2Uu +MGoM9ZDulebyzYLs2aFK7PayS+VFheZteJMELpyCbTapxDFkH4aDCyr0NQp4yVXPQbBH6TCfmb5h +qAaEuSh6XzjZG6k4sIN/c8HDO0gqgg8hm7jMqDXDhBuDsz6+pJVpATqJAHgE2cn0mRmrVn5bi4Y5 +FZGkECwJMoBgs5PAKrYYC51+jUnyEEp/+dVGLxmSo5mnJqy7jDzmDrxHB9xzUfFwZC8I+bRHHTBs +ROopN4WSaGa8gzj+ezku01DwH/teYLappvonQfGbGHLy9YR0SslnxFSuSGTfjNFusB3hB48IHpmc +celM2KX3RxIfdNFRnobzwqIjQAtz20um53MGjMGg6cFZrEb65i/4z3GcRm25xBWNOHkDRUjvxF3X +CO6HOSKGsg0PWEP3calILv3q1h8CAwEAAaOBrDCBqTAOBgNVHQ8BAf8EBAMCAQYwDwYDVR0TAQH/ +BAUwAwEB/zAdBgNVHQ4EFgQUF6DNweRBtjpbO8tFnb0cwpj6hlgwHwYDVR0jBBgwFoAUF6DNweRB +tjpbO8tFnb0cwpj6hlgwRgYDVR0gBD8wPTA7BglghXQBWQEDAQEwLjAsBggrBgEFBQcCARYgaHR0 +cDovL3JlcG9zaXRvcnkuc3dpc3NzaWduLmNvbS8wDQYJKoZIhvcNAQEFBQADggIBAHPGgeAn0i0P +4JUw4ppBf1AsX19iYamGamkYDHRJ1l2E6kFSGG9YrVBWIGrGvShpWJHckRE1qTodvBqlYJ7YH39F +kWnZfrt4csEGDyrOj4VwYaygzQu4OSlWhDJOhrs9xCrZ1x9y7v5RoSJBsXECYxqCsGKrXlcSH9/L +3XWgwF15kIwb4FDm3jH+mHtwX6WQ2K34ArZv02DdQEsixT2tOnqfGhpHkXkzuoLcMmkDlm4fS/Bx +/uNncqCxv1yL5PqZIseEuRuNI5c/7SXgz2W79WEE790eslpBIlqhn10s6FvJbakMDHiqYMZWjwFa +DGi8aRl5xB9+lwW/xekkUV7U1UtT7dkjWjYDZaPBA61BMPNGG4WQr2W11bHkFlt4dR2Xem1ZqSqP +e97Dh4kQmUlzeMg9vVE1dCrV8X5pGyq7O70luJpaPXJhkGaH7gzWTdQRdAtq/gsD/KNVV4n+Ssuu +WxcFyPKNIzFTONItaj+CuY0IavdeQXRuwxF+B6wpYJE/OMpXEA29MC/HpeZBoNquBYeaoKRlbEwJ +DIm6uNO5wJOKMPqN5ZprFQFOZ6raYlY+hAhm0sQ2fac+EPyI4NSA5QC9qvNOBqN6avlicuMJT+ub +DgEj8Z+7fNzcbBGXJbLytGMU0gYqZ4yD9c7qB9iaah7s5Aq7KkzrCWA5zspi2C5u +-----END CERTIFICATE----- + +GeoTrust Primary Certification Authority +======================================== +-----BEGIN CERTIFICATE----- +MIIDfDCCAmSgAwIBAgIQGKy1av1pthU6Y2yv2vrEoTANBgkqhkiG9w0BAQUFADBYMQswCQYDVQQG +EwJVUzEWMBQGA1UEChMNR2VvVHJ1c3QgSW5jLjExMC8GA1UEAxMoR2VvVHJ1c3QgUHJpbWFyeSBD +ZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAeFw0wNjExMjcwMDAwMDBaFw0zNjA3MTYyMzU5NTlaMFgx +CzAJBgNVBAYTAlVTMRYwFAYDVQQKEw1HZW9UcnVzdCBJbmMuMTEwLwYDVQQDEyhHZW9UcnVzdCBQ +cmltYXJ5IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIB +CgKCAQEAvrgVe//UfH1nrYNke8hCUy3f9oQIIGHWAVlqnEQRr+92/ZV+zmEwu3qDXwK9AWbK7hWN +b6EwnL2hhZ6UOvNWiAAxz9juapYC2e0DjPt1befquFUWBRaa9OBesYjAZIVcFU2Ix7e64HXprQU9 +nceJSOC7KMgD4TCTZF5SwFlwIjVXiIrxlQqD17wxcwE07e9GceBrAqg1cmuXm2bgyxx5X9gaBGge +RwLmnWDiNpcB3841kt++Z8dtd1k7j53WkBWUvEI0EME5+bEnPn7WinXFsq+W06Lem+SYvn3h6YGt +tm/81w7a4DSwDRp35+MImO9Y+pyEtzavwt+s0vQQBnBxNQIDAQABo0IwQDAPBgNVHRMBAf8EBTAD +AQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQULNVQQZcVi/CPNmFbSvtr2ZnJM5IwDQYJKoZI +hvcNAQEFBQADggEBAFpwfyzdtzRP9YZRqSa+S7iq8XEN3GHHoOo0Hnp3DwQ16CePbJC/kRYkRj5K +Ts4rFtULUh38H2eiAkUxT87z+gOneZ1TatnaYzr4gNfTmeGl4b7UVXGYNTq+k+qurUKykG/g/CFN +NWMziUnWm07Kx+dOCQD32sfvmWKZd7aVIl6KoKv0uHiYyjgZmclynnjNS6yvGaBzEi38wkG6gZHa +Floxt/m0cYASSJlyc1pZU8FjUjPtp8nSOQJw+uCxQmYpqptR7TBUIhRf2asdweSU8Pj1K/fqynhG +1riR/aYNKxoUAT6A8EKglQdebc3MS6RFjasS6LPeWuWgfOgPIh1a6Vk= +-----END CERTIFICATE----- + +thawte Primary Root CA +====================== +-----BEGIN CERTIFICATE----- +MIIEIDCCAwigAwIBAgIQNE7VVyDV7exJ9C/ON9srbTANBgkqhkiG9w0BAQUFADCBqTELMAkGA1UE +BhMCVVMxFTATBgNVBAoTDHRoYXd0ZSwgSW5jLjEoMCYGA1UECxMfQ2VydGlmaWNhdGlvbiBTZXJ2 +aWNlcyBEaXZpc2lvbjE4MDYGA1UECxMvKGMpIDIwMDYgdGhhd3RlLCBJbmMuIC0gRm9yIGF1dGhv +cml6ZWQgdXNlIG9ubHkxHzAdBgNVBAMTFnRoYXd0ZSBQcmltYXJ5IFJvb3QgQ0EwHhcNMDYxMTE3 +MDAwMDAwWhcNMzYwNzE2MjM1OTU5WjCBqTELMAkGA1UEBhMCVVMxFTATBgNVBAoTDHRoYXd0ZSwg +SW5jLjEoMCYGA1UECxMfQ2VydGlmaWNhdGlvbiBTZXJ2aWNlcyBEaXZpc2lvbjE4MDYGA1UECxMv +KGMpIDIwMDYgdGhhd3RlLCBJbmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxHzAdBgNVBAMT +FnRoYXd0ZSBQcmltYXJ5IFJvb3QgQ0EwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCs +oPD7gFnUnMekz52hWXMJEEUMDSxuaPFsW0hoSVk3/AszGcJ3f8wQLZU0HObrTQmnHNK4yZc2AreJ +1CRfBsDMRJSUjQJib+ta3RGNKJpchJAQeg29dGYvajig4tVUROsdB58Hum/u6f1OCyn1PoSgAfGc +q/gcfomk6KHYcWUNo1F77rzSImANuVud37r8UVsLr5iy6S7pBOhih94ryNdOwUxkHt3Ph1i6Sk/K +aAcdHJ1KxtUvkcx8cXIcxcBn6zL9yZJclNqFwJu/U30rCfSMnZEfl2pSy94JNqR32HuHUETVPm4p +afs5SSYeCaWAe0At6+gnhcn+Yf1+5nyXHdWdAgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wDgYD +VR0PAQH/BAQDAgEGMB0GA1UdDgQWBBR7W0XPr87Lev0xkhpqtvNG61dIUDANBgkqhkiG9w0BAQUF +AAOCAQEAeRHAS7ORtvzw6WfUDW5FvlXok9LOAz/t2iWwHVfLHjp2oEzsUHboZHIMpKnxuIvW1oeE +uzLlQRHAd9mzYJ3rG9XRbkREqaYB7FViHXe4XI5ISXycO1cRrK1zN44veFyQaEfZYGDm/Ac9IiAX +xPcW6cTYcvnIc3zfFi8VqT79aie2oetaupgf1eNNZAqdE8hhuvU5HIe6uL17In/2/qxAeeWsEG89 +jxt5dovEN7MhGITlNgDrYyCZuen+MwS7QcjBAvlEYyCegc5C09Y/LHbTY5xZ3Y+m4Q6gLkH3LpVH +z7z9M/P2C2F+fpErgUfCJzDupxBdN49cOSvkBPB7jVaMaA== +-----END CERTIFICATE----- + +VeriSign Class 3 Public Primary Certification Authority - G5 +============================================================ +-----BEGIN CERTIFICATE----- +MIIE0zCCA7ugAwIBAgIQGNrRniZ96LtKIVjNzGs7SjANBgkqhkiG9w0BAQUFADCByjELMAkGA1UE +BhMCVVMxFzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMR8wHQYDVQQLExZWZXJpU2lnbiBUcnVzdCBO +ZXR3b3JrMTowOAYDVQQLEzEoYykgMjAwNiBWZXJpU2lnbiwgSW5jLiAtIEZvciBhdXRob3JpemVk +IHVzZSBvbmx5MUUwQwYDVQQDEzxWZXJpU2lnbiBDbGFzcyAzIFB1YmxpYyBQcmltYXJ5IENlcnRp +ZmljYXRpb24gQXV0aG9yaXR5IC0gRzUwHhcNMDYxMTA4MDAwMDAwWhcNMzYwNzE2MjM1OTU5WjCB +yjELMAkGA1UEBhMCVVMxFzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMR8wHQYDVQQLExZWZXJpU2ln +biBUcnVzdCBOZXR3b3JrMTowOAYDVQQLEzEoYykgMjAwNiBWZXJpU2lnbiwgSW5jLiAtIEZvciBh +dXRob3JpemVkIHVzZSBvbmx5MUUwQwYDVQQDEzxWZXJpU2lnbiBDbGFzcyAzIFB1YmxpYyBQcmlt +YXJ5IENlcnRpZmljYXRpb24gQXV0aG9yaXR5IC0gRzUwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAw +ggEKAoIBAQCvJAgIKXo1nmAMqudLO07cfLw8RRy7K+D+KQL5VwijZIUVJ/XxrcgxiV0i6CqqpkKz +j/i5Vbext0uz/o9+B1fs70PbZmIVYc9gDaTY3vjgw2IIPVQT60nKWVSFJuUrjxuf6/WhkcIzSdhD +Y2pSS9KP6HBRTdGJaXvHcPaz3BJ023tdS1bTlr8Vd6Gw9KIl8q8ckmcY5fQGBO+QueQA5N06tRn/ +Arr0PO7gi+s3i+z016zy9vA9r911kTMZHRxAy3QkGSGT2RT+rCpSx4/VBEnkjWNHiDxpg8v+R70r +fk/Fla4OndTRQ8Bnc+MUCH7lP59zuDMKz10/NIeWiu5T6CUVAgMBAAGjgbIwga8wDwYDVR0TAQH/ +BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwbQYIKwYBBQUHAQwEYTBfoV2gWzBZMFcwVRYJaW1hZ2Uv +Z2lmMCEwHzAHBgUrDgMCGgQUj+XTGoasjY5rw8+AatRIGCx7GS4wJRYjaHR0cDovL2xvZ28udmVy +aXNpZ24uY29tL3ZzbG9nby5naWYwHQYDVR0OBBYEFH/TZafC3ey78DAJ80M5+gKvMzEzMA0GCSqG +SIb3DQEBBQUAA4IBAQCTJEowX2LP2BqYLz3q3JktvXf2pXkiOOzEp6B4Eq1iDkVwZMXnl2YtmAl+ +X6/WzChl8gGqCBpH3vn5fJJaCGkgDdk+bW48DW7Y5gaRQBi5+MHt39tBquCWIMnNZBU4gcmU7qKE +KQsTb47bDN0lAtukixlE0kF6BWlKWE9gyn6CagsCqiUXObXbf+eEZSqVir2G3l6BFoMtEMze/aiC +Km0oHw0LxOXnGiYZ4fQRbxC1lfznQgUy286dUV4otp6F01vvpX1FQHKOtw5rDgb7MzVIcbidJ4vE +ZV8NhnacRHr2lVz2XTIIM6RUthg/aFzyQkqFOFSDX9HoLPKsEdao7WNq +-----END CERTIFICATE----- + +SecureTrust CA +============== +-----BEGIN CERTIFICATE----- +MIIDuDCCAqCgAwIBAgIQDPCOXAgWpa1Cf/DrJxhZ0DANBgkqhkiG9w0BAQUFADBIMQswCQYDVQQG +EwJVUzEgMB4GA1UEChMXU2VjdXJlVHJ1c3QgQ29ycG9yYXRpb24xFzAVBgNVBAMTDlNlY3VyZVRy +dXN0IENBMB4XDTA2MTEwNzE5MzExOFoXDTI5MTIzMTE5NDA1NVowSDELMAkGA1UEBhMCVVMxIDAe +BgNVBAoTF1NlY3VyZVRydXN0IENvcnBvcmF0aW9uMRcwFQYDVQQDEw5TZWN1cmVUcnVzdCBDQTCC +ASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAKukgeWVzfX2FI7CT8rU4niVWJxB4Q2ZQCQX +OZEzZum+4YOvYlyJ0fwkW2Gz4BERQRwdbvC4u/jep4G6pkjGnx29vo6pQT64lO0pGtSO0gMdA+9t +DWccV9cGrcrI9f4Or2YlSASWC12juhbDCE/RRvgUXPLIXgGZbf2IzIaowW8xQmxSPmjL8xk037uH +GFaAJsTQ3MBv396gwpEWoGQRS0S8Hvbn+mPeZqx2pHGj7DaUaHp3pLHnDi+BeuK1cobvomuL8A/b +01k/unK8RCSc43Oz969XL0Imnal0ugBS8kvNU3xHCzaFDmapCJcWNFfBZveA4+1wVMeT4C4oFVmH +ursCAwEAAaOBnTCBmjATBgkrBgEEAYI3FAIEBh4EAEMAQTALBgNVHQ8EBAMCAYYwDwYDVR0TAQH/ +BAUwAwEB/zAdBgNVHQ4EFgQUQjK2FvoE/f5dS3rD/fdMQB1aQ68wNAYDVR0fBC0wKzApoCegJYYj +aHR0cDovL2NybC5zZWN1cmV0cnVzdC5jb20vU1RDQS5jcmwwEAYJKwYBBAGCNxUBBAMCAQAwDQYJ +KoZIhvcNAQEFBQADggEBADDtT0rhWDpSclu1pqNlGKa7UTt36Z3q059c4EVlew3KW+JwULKUBRSu +SceNQQcSc5R+DCMh/bwQf2AQWnL1mA6s7Ll/3XpvXdMc9P+IBWlCqQVxyLesJugutIxq/3HcuLHf +mbx8IVQr5Fiiu1cprp6poxkmD5kuCLDv/WnPmRoJjeOnnyvJNjR7JLN4TJUXpAYmHrZkUjZfYGfZ +nMUFdAvnZyPSCPyI6a6Lf+Ew9Dd+/cYy2i2eRDAwbO4H3tI0/NL/QPZL9GZGBlSm8jIKYyYwa5vR +3ItHuuG51WLQoqD0ZwV4KWMabwTW+MZMo5qxN7SN5ShLHZ4swrhovO0C7jE= +-----END CERTIFICATE----- + +Secure Global CA +================ +-----BEGIN CERTIFICATE----- +MIIDvDCCAqSgAwIBAgIQB1YipOjUiolN9BPI8PjqpTANBgkqhkiG9w0BAQUFADBKMQswCQYDVQQG +EwJVUzEgMB4GA1UEChMXU2VjdXJlVHJ1c3QgQ29ycG9yYXRpb24xGTAXBgNVBAMTEFNlY3VyZSBH +bG9iYWwgQ0EwHhcNMDYxMTA3MTk0MjI4WhcNMjkxMjMxMTk1MjA2WjBKMQswCQYDVQQGEwJVUzEg +MB4GA1UEChMXU2VjdXJlVHJ1c3QgQ29ycG9yYXRpb24xGTAXBgNVBAMTEFNlY3VyZSBHbG9iYWwg +Q0EwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCvNS7YrGxVaQZx5RNoJLNP2MwhR/jx +YDiJiQPpvepeRlMJ3Fz1Wuj3RSoC6zFh1ykzTM7HfAo3fg+6MpjhHZevj8fcyTiW89sa/FHtaMbQ +bqR8JNGuQsiWUGMu4P51/pinX0kuleM5M2SOHqRfkNJnPLLZ/kG5VacJjnIFHovdRIWCQtBJwB1g +8NEXLJXr9qXBkqPFwqcIYA1gBBCWeZ4WNOaptvolRTnIHmX5k/Wq8VLcmZg9pYYaDDUz+kulBAYV +HDGA76oYa8J719rO+TMg1fW9ajMtgQT7sFzUnKPiXB3jqUJ1XnvUd+85VLrJChgbEplJL4hL/VBi +0XPnj3pDAgMBAAGjgZ0wgZowEwYJKwYBBAGCNxQCBAYeBABDAEEwCwYDVR0PBAQDAgGGMA8GA1Ud +EwEB/wQFMAMBAf8wHQYDVR0OBBYEFK9EBMJBfkiD2045AuzshHrmzsmkMDQGA1UdHwQtMCswKaAn +oCWGI2h0dHA6Ly9jcmwuc2VjdXJldHJ1c3QuY29tL1NHQ0EuY3JsMBAGCSsGAQQBgjcVAQQDAgEA +MA0GCSqGSIb3DQEBBQUAA4IBAQBjGghAfaReUw132HquHw0LURYD7xh8yOOvaliTFGCRsoTciE6+ +OYo68+aCiV0BN7OrJKQVDpI1WkpEXk5X+nXOH0jOZvQ8QCaSmGwb7iRGDBezUqXbpZGRzzfTb+cn +CDpOGR86p1hcF895P4vkp9MmI50mD1hp/Ed+stCNi5O/KU9DaXR2Z0vPB4zmAve14bRDtUstFJ/5 +3CYNv6ZHdAbYiNE6KTCEztI5gGIbqMdXSbxqVVFnFUq+NQfk1XWYN3kwFNspnWzFacxHVaIw98xc +f8LDmBxrThaA63p4ZUWiABqvDA1VZDRIuJK58bRQKfJPIx/abKwfROHdI3hRW8cW +-----END CERTIFICATE----- + +COMODO Certification Authority +============================== +-----BEGIN CERTIFICATE----- +MIIEHTCCAwWgAwIBAgIQToEtioJl4AsC7j41AkblPTANBgkqhkiG9w0BAQUFADCBgTELMAkGA1UE +BhMCR0IxGzAZBgNVBAgTEkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4GA1UEBxMHU2FsZm9yZDEaMBgG +A1UEChMRQ09NT0RPIENBIExpbWl0ZWQxJzAlBgNVBAMTHkNPTU9ETyBDZXJ0aWZpY2F0aW9uIEF1 +dGhvcml0eTAeFw0wNjEyMDEwMDAwMDBaFw0yOTEyMzEyMzU5NTlaMIGBMQswCQYDVQQGEwJHQjEb +MBkGA1UECBMSR3JlYXRlciBNYW5jaGVzdGVyMRAwDgYDVQQHEwdTYWxmb3JkMRowGAYDVQQKExFD +T01PRE8gQ0EgTGltaXRlZDEnMCUGA1UEAxMeQ09NT0RPIENlcnRpZmljYXRpb24gQXV0aG9yaXR5 +MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA0ECLi3LjkRv3UcEbVASY06m/weaKXTuH ++7uIzg3jLz8GlvCiKVCZrts7oVewdFFxze1CkU1B/qnI2GqGd0S7WWaXUF601CxwRM/aN5VCaTww +xHGzUvAhTaHYujl8HJ6jJJ3ygxaYqhZ8Q5sVW7euNJH+1GImGEaaP+vB+fGQV+useg2L23IwambV +4EajcNxo2f8ESIl33rXp+2dtQem8Ob0y2WIC8bGoPW43nOIv4tOiJovGuFVDiOEjPqXSJDlqR6sA +1KGzqSX+DT+nHbrTUcELpNqsOO9VUCQFZUaTNE8tja3G1CEZ0o7KBWFxB3NH5YoZEr0ETc5OnKVI +rLsm9wIDAQABo4GOMIGLMB0GA1UdDgQWBBQLWOWLxkwVN6RAqTCpIb5HNlpW/zAOBgNVHQ8BAf8E +BAMCAQYwDwYDVR0TAQH/BAUwAwEB/zBJBgNVHR8EQjBAMD6gPKA6hjhodHRwOi8vY3JsLmNvbW9k +b2NhLmNvbS9DT01PRE9DZXJ0aWZpY2F0aW9uQXV0aG9yaXR5LmNybDANBgkqhkiG9w0BAQUFAAOC +AQEAPpiem/Yb6dc5t3iuHXIYSdOH5EOC6z/JqvWote9VfCFSZfnVDeFs9D6Mk3ORLgLETgdxb8CP +OGEIqB6BCsAvIC9Bi5HcSEW88cbeunZrM8gALTFGTO3nnc+IlP8zwFboJIYmuNg4ON8qa90SzMc/ +RxdMosIGlgnW2/4/PEZB31jiVg88O8EckzXZOFKs7sjsLjBOlDW0JB9LeGna8gI4zJVSk/BwJVmc +IGfE7vmLV2H0knZ9P4SNVbfo5azV8fUZVqZa+5Acr5Pr5RzUZ5ddBA6+C4OmF4O5MBKgxTMVBbkN ++8cFduPYSo38NBejxiEovjBFMR7HeL5YYTisO+IBZQ== +-----END CERTIFICATE----- + +Network Solutions Certificate Authority +======================================= +-----BEGIN CERTIFICATE----- +MIID5jCCAs6gAwIBAgIQV8szb8JcFuZHFhfjkDFo4DANBgkqhkiG9w0BAQUFADBiMQswCQYDVQQG +EwJVUzEhMB8GA1UEChMYTmV0d29yayBTb2x1dGlvbnMgTC5MLkMuMTAwLgYDVQQDEydOZXR3b3Jr +IFNvbHV0aW9ucyBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkwHhcNMDYxMjAxMDAwMDAwWhcNMjkxMjMx +MjM1OTU5WjBiMQswCQYDVQQGEwJVUzEhMB8GA1UEChMYTmV0d29yayBTb2x1dGlvbnMgTC5MLkMu +MTAwLgYDVQQDEydOZXR3b3JrIFNvbHV0aW9ucyBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkwggEiMA0G +CSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDkvH6SMG3G2I4rC7xGzuAnlt7e+foS0zwzc7MEL7xx +jOWftiJgPl9dzgn/ggwbmlFQGiaJ3dVhXRncEg8tCqJDXRfQNJIg6nPPOCwGJgl6cvf6UDL4wpPT +aaIjzkGxzOTVHzbRijr4jGPiFFlp7Q3Tf2vouAPlT2rlmGNpSAW+Lv8ztumXWWn4Zxmuk2GWRBXT +crA/vGp97Eh/jcOrqnErU2lBUzS1sLnFBgrEsEX1QV1uiUV7PTsmjHTC5dLRfbIR1PtYMiKagMnc +/Qzpf14Dl847ABSHJ3A4qY5usyd2mFHgBeMhqxrVhSI8KbWaFsWAqPS7azCPL0YCorEMIuDTAgMB +AAGjgZcwgZQwHQYDVR0OBBYEFCEwyfsA106Y2oeqKtCnLrFAMadMMA4GA1UdDwEB/wQEAwIBBjAP +BgNVHRMBAf8EBTADAQH/MFIGA1UdHwRLMEkwR6BFoEOGQWh0dHA6Ly9jcmwubmV0c29sc3NsLmNv +bS9OZXR3b3JrU29sdXRpb25zQ2VydGlmaWNhdGVBdXRob3JpdHkuY3JsMA0GCSqGSIb3DQEBBQUA +A4IBAQC7rkvnt1frf6ott3NHhWrB5KUd5Oc86fRZZXe1eltajSU24HqXLjjAV2CDmAaDn7l2em5Q +4LqILPxFzBiwmZVRDuwduIj/h1AcgsLj4DKAv6ALR8jDMe+ZZzKATxcheQxpXN5eNK4CtSbqUN9/ +GGUsyfJj4akH/nxxH2szJGoeBfcFaMBqEssuXmHLrijTfsK0ZpEmXzwuJF/LWA/rKOyvEZbz3Htv +wKeI8lN3s2Berq4o2jUsbzRF0ybh3uxbTydrFny9RAQYgrOJeRcQcT16ohZO9QHNpGxlaKFJdlxD +ydi8NmdspZS11My5vWo1ViHe2MPr+8ukYEywVaCge1ey +-----END CERTIFICATE----- + +WellsSecure Public Root Certificate Authority +============================================= +-----BEGIN CERTIFICATE----- +MIIEvTCCA6WgAwIBAgIBATANBgkqhkiG9w0BAQUFADCBhTELMAkGA1UEBhMCVVMxIDAeBgNVBAoM +F1dlbGxzIEZhcmdvIFdlbGxzU2VjdXJlMRwwGgYDVQQLDBNXZWxscyBGYXJnbyBCYW5rIE5BMTYw +NAYDVQQDDC1XZWxsc1NlY3VyZSBQdWJsaWMgUm9vdCBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkwHhcN +MDcxMjEzMTcwNzU0WhcNMjIxMjE0MDAwNzU0WjCBhTELMAkGA1UEBhMCVVMxIDAeBgNVBAoMF1dl +bGxzIEZhcmdvIFdlbGxzU2VjdXJlMRwwGgYDVQQLDBNXZWxscyBGYXJnbyBCYW5rIE5BMTYwNAYD +VQQDDC1XZWxsc1NlY3VyZSBQdWJsaWMgUm9vdCBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkwggEiMA0G +CSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDub7S9eeKPCCGeOARBJe+rWxxTkqxtnt3CxC5FlAM1 +iGd0V+PfjLindo8796jE2yljDpFoNoqXjopxaAkH5OjUDk/41itMpBb570OYj7OeUt9tkTmPOL13 +i0Nj67eT/DBMHAGTthP796EfvyXhdDcsHqRePGj4S78NuR4uNuip5Kf4D8uCdXw1LSLWwr8L87T8 +bJVhHlfXBIEyg1J55oNjz7fLY4sR4r1e6/aN7ZVyKLSsEmLpSjPmgzKuBXWVvYSV2ypcm44uDLiB +K0HmOFafSZtsdvqKXfcBeYF8wYNABf5x/Qw/zE5gCQ5lRxAvAcAFP4/4s0HvWkJ+We/SlwxlAgMB +AAGjggE0MIIBMDAPBgNVHRMBAf8EBTADAQH/MDkGA1UdHwQyMDAwLqAsoCqGKGh0dHA6Ly9jcmwu +cGtpLndlbGxzZmFyZ28uY29tL3dzcHJjYS5jcmwwDgYDVR0PAQH/BAQDAgHGMB0GA1UdDgQWBBQm +lRkQ2eihl5H/3BnZtQQ+0nMKajCBsgYDVR0jBIGqMIGngBQmlRkQ2eihl5H/3BnZtQQ+0nMKaqGB +i6SBiDCBhTELMAkGA1UEBhMCVVMxIDAeBgNVBAoMF1dlbGxzIEZhcmdvIFdlbGxzU2VjdXJlMRww +GgYDVQQLDBNXZWxscyBGYXJnbyBCYW5rIE5BMTYwNAYDVQQDDC1XZWxsc1NlY3VyZSBQdWJsaWMg +Um9vdCBDZXJ0aWZpY2F0ZSBBdXRob3JpdHmCAQEwDQYJKoZIhvcNAQEFBQADggEBALkVsUSRzCPI +K0134/iaeycNzXK7mQDKfGYZUMbVmO2rvwNa5U3lHshPcZeG1eMd/ZDJPHV3V3p9+N701NX3leZ0 +bh08rnyd2wIDBSxxSyU+B+NemvVmFymIGjifz6pBA4SXa5M4esowRBskRDPQ5NHcKDj0E0M1NSlj +qHyita04pO2t/caaH/+Xc/77szWnk4bGdpEA5qxRFsQnMlzbc9qlk1eOPm01JghZ1edE13YgY+es +E2fDbbFwRnzVlhE9iW9dqKHrjQrawx0zbKPqZxmamX9LPYNRKh3KL4YMon4QLSvUFpULB6ouFJJJ +tylv2G0xffX8oRAHh84vWdw+WNs= +-----END CERTIFICATE----- + +COMODO ECC Certification Authority +================================== +-----BEGIN CERTIFICATE----- +MIICiTCCAg+gAwIBAgIQH0evqmIAcFBUTAGem2OZKjAKBggqhkjOPQQDAzCBhTELMAkGA1UEBhMC +R0IxGzAZBgNVBAgTEkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4GA1UEBxMHU2FsZm9yZDEaMBgGA1UE +ChMRQ09NT0RPIENBIExpbWl0ZWQxKzApBgNVBAMTIkNPTU9ETyBFQ0MgQ2VydGlmaWNhdGlvbiBB +dXRob3JpdHkwHhcNMDgwMzA2MDAwMDAwWhcNMzgwMTE4MjM1OTU5WjCBhTELMAkGA1UEBhMCR0Ix +GzAZBgNVBAgTEkdyZWF0ZXIgTWFuY2hlc3RlcjEQMA4GA1UEBxMHU2FsZm9yZDEaMBgGA1UEChMR +Q09NT0RPIENBIExpbWl0ZWQxKzApBgNVBAMTIkNPTU9ETyBFQ0MgQ2VydGlmaWNhdGlvbiBBdXRo +b3JpdHkwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAAQDR3svdcmCFYX7deSRFtSrYpn1PlILBs5BAH+X +4QokPB0BBO490o0JlwzgdeT6+3eKKvUDYEs2ixYjFq0JcfRK9ChQtP6IHG4/bC8vCVlbpVsLM5ni +wz2J+Wos77LTBumjQjBAMB0GA1UdDgQWBBR1cacZSBm8nZ3qQUfflMRId5nTeTAOBgNVHQ8BAf8E +BAMCAQYwDwYDVR0TAQH/BAUwAwEB/zAKBggqhkjOPQQDAwNoADBlAjEA7wNbeqy3eApyt4jf/7VG +FAkK+qDmfQjGGoe9GKhzvSbKYAydzpmfz1wPMOG+FDHqAjAU9JM8SaczepBGR7NjfRObTrdvGDeA +U/7dIOA1mjbRxwG55tzd8/8dLDoWV9mSOdY= +-----END CERTIFICATE----- + +IGC/A +===== +-----BEGIN CERTIFICATE----- +MIIEAjCCAuqgAwIBAgIFORFFEJQwDQYJKoZIhvcNAQEFBQAwgYUxCzAJBgNVBAYTAkZSMQ8wDQYD +VQQIEwZGcmFuY2UxDjAMBgNVBAcTBVBhcmlzMRAwDgYDVQQKEwdQTS9TR0ROMQ4wDAYDVQQLEwVE +Q1NTSTEOMAwGA1UEAxMFSUdDL0ExIzAhBgkqhkiG9w0BCQEWFGlnY2FAc2dkbi5wbS5nb3V2LmZy +MB4XDTAyMTIxMzE0MjkyM1oXDTIwMTAxNzE0MjkyMlowgYUxCzAJBgNVBAYTAkZSMQ8wDQYDVQQI +EwZGcmFuY2UxDjAMBgNVBAcTBVBhcmlzMRAwDgYDVQQKEwdQTS9TR0ROMQ4wDAYDVQQLEwVEQ1NT +STEOMAwGA1UEAxMFSUdDL0ExIzAhBgkqhkiG9w0BCQEWFGlnY2FAc2dkbi5wbS5nb3V2LmZyMIIB +IjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAsh/R0GLFMzvABIaIs9z4iPf930Pfeo2aSVz2 +TqrMHLmh6yeJ8kbpO0px1R2OLc/mratjUMdUC24SyZA2xtgv2pGqaMVy/hcKshd+ebUyiHDKcMCW +So7kVc0dJ5S/znIq7Fz5cyD+vfcuiWe4u0dzEvfRNWk68gq5rv9GQkaiv6GFGvm/5P9JhfejcIYy +HF2fYPepraX/z9E0+X1bF8bc1g4oa8Ld8fUzaJ1O/Id8NhLWo4DoQw1VYZTqZDdH6nfK0LJYBcNd +frGoRpAxVs5wKpayMLh35nnAvSk7/ZR3TL0gzUEl4C7HG7vupARB0l2tEmqKm0f7yd1GQOGdPDPQ +tQIDAQABo3cwdTAPBgNVHRMBAf8EBTADAQH/MAsGA1UdDwQEAwIBRjAVBgNVHSAEDjAMMAoGCCqB +egF5AQEBMB0GA1UdDgQWBBSjBS8YYFDCiQrdKyFP/45OqDAxNjAfBgNVHSMEGDAWgBSjBS8YYFDC +iQrdKyFP/45OqDAxNjANBgkqhkiG9w0BAQUFAAOCAQEABdwm2Pp3FURo/C9mOnTgXeQp/wYHE4RK +q89toB9RlPhJy3Q2FLwV3duJL92PoF189RLrn544pEfMs5bZvpwlqwN+Mw+VgQ39FuCIvjfwbF3Q +MZsyK10XZZOYYLxuj7GoPB7ZHPOpJkL5ZB3C55L29B5aqhlSXa/oovdgoPaN8In1buAKBQGVyYsg +Crpa/JosPL3Dt8ldeCUFP1YUmwza+zpI/pdpXsoQhvdOlgQITeywvl3cO45Pwf2aNjSaTFR+FwNI +lQgRHAdvhQh+XU3Endv7rs6y0bO4g2wdsrN58dhwmX7wEwLOXt1R0982gaEbeC9xs/FZTEYYKKuF +0mBWWg== +-----END CERTIFICATE----- + +Security Communication EV RootCA1 +================================= +-----BEGIN CERTIFICATE----- +MIIDfTCCAmWgAwIBAgIBADANBgkqhkiG9w0BAQUFADBgMQswCQYDVQQGEwJKUDElMCMGA1UEChMc +U0VDT00gVHJ1c3QgU3lzdGVtcyBDTy4sTFRELjEqMCgGA1UECxMhU2VjdXJpdHkgQ29tbXVuaWNh +dGlvbiBFViBSb290Q0ExMB4XDTA3MDYwNjAyMTIzMloXDTM3MDYwNjAyMTIzMlowYDELMAkGA1UE +BhMCSlAxJTAjBgNVBAoTHFNFQ09NIFRydXN0IFN5c3RlbXMgQ08uLExURC4xKjAoBgNVBAsTIVNl +Y3VyaXR5IENvbW11bmljYXRpb24gRVYgUm9vdENBMTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCC +AQoCggEBALx/7FebJOD+nLpCeamIivqA4PUHKUPqjgo0No0c+qe1OXj/l3X3L+SqawSERMqm4miO +/VVQYg+kcQ7OBzgtQoVQrTyWb4vVog7P3kmJPdZkLjjlHmy1V4qe70gOzXppFodEtZDkBp2uoQSX +WHnvIEqCa4wiv+wfD+mEce3xDuS4GBPMVjZd0ZoeUWs5bmB2iDQL87PRsJ3KYeJkHcFGB7hj3R4z +ZbOOCVVSPbW9/wfrrWFVGCypaZhKqkDFMxRldAD5kd6vA0jFQFTcD4SQaCDFkpbcLuUCRarAX1T4 +bepJz11sS6/vmsJWXMY1VkJqMF/Cq/biPT+zyRGPMUzXn0kCAwEAAaNCMEAwHQYDVR0OBBYEFDVK +9U2vP9eCOKyrcWUXdYydVZPmMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMBAf8EBTADAQH/MA0GCSqG +SIb3DQEBBQUAA4IBAQCoh+ns+EBnXcPBZsdAS5f8hxOQWsTvoMpfi7ent/HWtWS3irO4G8za+6xm +iEHO6Pzk2x6Ipu0nUBsCMCRGef4Eh3CXQHPRwMFXGZpppSeZq51ihPZRwSzJIxXYKLerJRO1RuGG +Av8mjMSIkh1W/hln8lXkgKNrnKt34VFxDSDbEJrbvXZ5B3eZKK2aXtqxT0QsNY6llsf9g/BYxnnW +mHyojf6GPgcWkuF75x3sM3Z+Qi5KhfmRiWiEA4Glm5q+4zfFVKtWOxgtQaQM+ELbmaDgcm+7XeEW +T1MKZPlO9L9OVL14bIjqv5wTJMJwaaJ/D8g8rQjJsJhAoyrniIPtd490 +-----END CERTIFICATE----- + +OISTE WISeKey Global Root GA CA +=============================== +-----BEGIN CERTIFICATE----- +MIID8TCCAtmgAwIBAgIQQT1yx/RrH4FDffHSKFTfmjANBgkqhkiG9w0BAQUFADCBijELMAkGA1UE +BhMCQ0gxEDAOBgNVBAoTB1dJU2VLZXkxGzAZBgNVBAsTEkNvcHlyaWdodCAoYykgMjAwNTEiMCAG +A1UECxMZT0lTVEUgRm91bmRhdGlvbiBFbmRvcnNlZDEoMCYGA1UEAxMfT0lTVEUgV0lTZUtleSBH +bG9iYWwgUm9vdCBHQSBDQTAeFw0wNTEyMTExNjAzNDRaFw0zNzEyMTExNjA5NTFaMIGKMQswCQYD +VQQGEwJDSDEQMA4GA1UEChMHV0lTZUtleTEbMBkGA1UECxMSQ29weXJpZ2h0IChjKSAyMDA1MSIw +IAYDVQQLExlPSVNURSBGb3VuZGF0aW9uIEVuZG9yc2VkMSgwJgYDVQQDEx9PSVNURSBXSVNlS2V5 +IEdsb2JhbCBSb290IEdBIENBMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAy0+zAJs9 +Nt350UlqaxBJH+zYK7LG+DKBKUOVTJoZIyEVRd7jyBxRVVuuk+g3/ytr6dTqvirdqFEr12bDYVxg +Asj1znJ7O7jyTmUIms2kahnBAbtzptf2w93NvKSLtZlhuAGio9RN1AU9ka34tAhxZK9w8RxrfvbD +d50kc3vkDIzh2TbhmYsFmQvtRTEJysIA2/dyoJaqlYfQjse2YXMNdmaM3Bu0Y6Kff5MTMPGhJ9vZ +/yxViJGg4E8HsChWjBgbl0SOid3gF27nKu+POQoxhILYQBRJLnpB5Kf+42TMwVlxSywhp1t94B3R +LoGbw9ho972WG6xwsRYUC9tguSYBBQIDAQABo1EwTzALBgNVHQ8EBAMCAYYwDwYDVR0TAQH/BAUw +AwEB/zAdBgNVHQ4EFgQUswN+rja8sHnR3JQmthG+IbJphpQwEAYJKwYBBAGCNxUBBAMCAQAwDQYJ +KoZIhvcNAQEFBQADggEBAEuh/wuHbrP5wUOxSPMowB0uyQlB+pQAHKSkq0lPjz0e701vvbyk9vIm +MMkQyh2I+3QZH4VFvbBsUfk2ftv1TDI6QU9bR8/oCy22xBmddMVHxjtqD6wU2zz0c5ypBd8A3HR4 ++vg1YFkCExh8vPtNsCBtQ7tgMHpnM1zFmdH4LTlSc/uMqpclXHLZCB6rTjzjgTGfA6b7wP4piFXa +hNVQA7bihKOmNqoROgHhGEvWRGizPflTdISzRpFGlgC3gCy24eMQ4tui5yiPAZZiFj4A4xylNoEY +okxSdsARo27mHbrjWr42U8U+dY+GaSlYU7Wcu2+fXMUY7N0v4ZjJ/L7fCg0= +-----END CERTIFICATE----- + +Microsec e-Szigno Root CA +========================= +-----BEGIN CERTIFICATE----- +MIIHqDCCBpCgAwIBAgIRAMy4579OKRr9otxmpRwsDxEwDQYJKoZIhvcNAQEFBQAwcjELMAkGA1UE +BhMCSFUxETAPBgNVBAcTCEJ1ZGFwZXN0MRYwFAYDVQQKEw1NaWNyb3NlYyBMdGQuMRQwEgYDVQQL +EwtlLVN6aWdubyBDQTEiMCAGA1UEAxMZTWljcm9zZWMgZS1Temlnbm8gUm9vdCBDQTAeFw0wNTA0 +MDYxMjI4NDRaFw0xNzA0MDYxMjI4NDRaMHIxCzAJBgNVBAYTAkhVMREwDwYDVQQHEwhCdWRhcGVz +dDEWMBQGA1UEChMNTWljcm9zZWMgTHRkLjEUMBIGA1UECxMLZS1Temlnbm8gQ0ExIjAgBgNVBAMT +GU1pY3Jvc2VjIGUtU3ppZ25vIFJvb3QgQ0EwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB +AQDtyADVgXvNOABHzNuEwSFpLHSQDCHZU4ftPkNEU6+r+ICbPHiN1I2uuO/TEdyB5s87lozWbxXG +d36hL+BfkrYn13aaHUM86tnsL+4582pnS4uCzyL4ZVX+LMsvfUh6PXX5qqAnu3jCBspRwn5mS6/N +oqdNAoI/gqyFxuEPkEeZlApxcpMqyabAvjxWTHOSJ/FrtfX9/DAFYJLG65Z+AZHCabEeHXtTRbjc +QR/Ji3HWVBTji1R4P770Yjtb9aPs1ZJ04nQw7wHb4dSrmZsqa/i9phyGI0Jf7Enemotb9HI6QMVJ +PqW+jqpx62z69Rrkav17fVVA71hu5tnVvCSrwe+3AgMBAAGjggQ3MIIEMzBnBggrBgEFBQcBAQRb +MFkwKAYIKwYBBQUHMAGGHGh0dHBzOi8vcmNhLmUtc3ppZ25vLmh1L29jc3AwLQYIKwYBBQUHMAKG +IWh0dHA6Ly93d3cuZS1zemlnbm8uaHUvUm9vdENBLmNydDAPBgNVHRMBAf8EBTADAQH/MIIBcwYD +VR0gBIIBajCCAWYwggFiBgwrBgEEAYGoGAIBAQEwggFQMCgGCCsGAQUFBwIBFhxodHRwOi8vd3d3 +LmUtc3ppZ25vLmh1L1NaU1ovMIIBIgYIKwYBBQUHAgIwggEUHoIBEABBACAAdABhAG4A+gBzAO0A +dAB2AOEAbgB5ACAA6QByAHQAZQBsAG0AZQB6AOkAcwDpAGgAZQB6ACAA6QBzACAAZQBsAGYAbwBn +AGEAZADhAHMA4QBoAG8AegAgAGEAIABTAHoAbwBsAGcA4QBsAHQAYQB0APMAIABTAHoAbwBsAGcA +4QBsAHQAYQB0AOEAcwBpACAAUwB6AGEAYgDhAGwAeQB6AGEAdABhACAAcwB6AGUAcgBpAG4AdAAg +AGsAZQBsAGwAIABlAGwAagDhAHIAbgBpADoAIABoAHQAdABwADoALwAvAHcAdwB3AC4AZQAtAHMA +egBpAGcAbgBvAC4AaAB1AC8AUwBaAFMAWgAvMIHIBgNVHR8EgcAwgb0wgbqggbeggbSGIWh0dHA6 +Ly93d3cuZS1zemlnbm8uaHUvUm9vdENBLmNybIaBjmxkYXA6Ly9sZGFwLmUtc3ppZ25vLmh1L0NO +PU1pY3Jvc2VjJTIwZS1Temlnbm8lMjBSb290JTIwQ0EsT1U9ZS1Temlnbm8lMjBDQSxPPU1pY3Jv +c2VjJTIwTHRkLixMPUJ1ZGFwZXN0LEM9SFU/Y2VydGlmaWNhdGVSZXZvY2F0aW9uTGlzdDtiaW5h +cnkwDgYDVR0PAQH/BAQDAgEGMIGWBgNVHREEgY4wgYuBEGluZm9AZS1zemlnbm8uaHWkdzB1MSMw +IQYDVQQDDBpNaWNyb3NlYyBlLVN6aWduw7MgUm9vdCBDQTEWMBQGA1UECwwNZS1TemlnbsOzIEhT +WjEWMBQGA1UEChMNTWljcm9zZWMgS2Z0LjERMA8GA1UEBxMIQnVkYXBlc3QxCzAJBgNVBAYTAkhV +MIGsBgNVHSMEgaQwgaGAFMegSXUWYYTbMUuE0vE3QJDvTtz3oXakdDByMQswCQYDVQQGEwJIVTER +MA8GA1UEBxMIQnVkYXBlc3QxFjAUBgNVBAoTDU1pY3Jvc2VjIEx0ZC4xFDASBgNVBAsTC2UtU3pp +Z25vIENBMSIwIAYDVQQDExlNaWNyb3NlYyBlLVN6aWdubyBSb290IENBghEAzLjnv04pGv2i3Gal +HCwPETAdBgNVHQ4EFgQUx6BJdRZhhNsxS4TS8TdAkO9O3PcwDQYJKoZIhvcNAQEFBQADggEBANMT +nGZjWS7KXHAM/IO8VbH0jgdsZifOwTsgqRy7RlRw7lrMoHfqaEQn6/Ip3Xep1fvj1KcExJW4C+FE +aGAHQzAxQmHl7tnlJNUb3+FKG6qfx1/4ehHqE5MAyopYse7tDk2016g2JnzgOsHVV4Lxdbb9iV/a +86g4nzUGCM4ilb7N1fy+W955a9x6qWVmvrElWl/tftOsRm1M9DKHtCAE4Gx4sHfRhUZLphK3dehK +yVZs15KrnfVJONJPU+NVkBHbmJbGSfI+9J8b4PeI3CVimUTYc78/MPMMNz7UwiiAc7EBt51alhQB +S6kRnSlqLtBdgcDPsiBDxwPgN05dCtxZICU= +-----END CERTIFICATE----- + +Certigna +======== +-----BEGIN CERTIFICATE----- +MIIDqDCCApCgAwIBAgIJAP7c4wEPyUj/MA0GCSqGSIb3DQEBBQUAMDQxCzAJBgNVBAYTAkZSMRIw +EAYDVQQKDAlEaGlteW90aXMxETAPBgNVBAMMCENlcnRpZ25hMB4XDTA3MDYyOTE1MTMwNVoXDTI3 +MDYyOTE1MTMwNVowNDELMAkGA1UEBhMCRlIxEjAQBgNVBAoMCURoaW15b3RpczERMA8GA1UEAwwI +Q2VydGlnbmEwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDIaPHJ1tazNHUmgh7stL7q +XOEm7RFHYeGifBZ4QCHkYJ5ayGPhxLGWkv8YbWkj4Sti993iNi+RB7lIzw7sebYs5zRLcAglozyH +GxnygQcPOJAZ0xH+hrTy0V4eHpbNgGzOOzGTtvKg0KmVEn2lmsxryIRWijOp5yIVUxbwzBfsV1/p +ogqYCd7jX5xv3EjjhQsVWqa6n6xI4wmy9/Qy3l40vhx4XUJbzg4ij02Q130yGLMLLGq/jj8UEYkg +DncUtT2UCIf3JR7VsmAA7G8qKCVuKj4YYxclPz5EIBb2JsglrgVKtOdjLPOMFlN+XPsRGgjBRmKf +Irjxwo1p3Po6WAbfAgMBAAGjgbwwgbkwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUGu3+QTmQ +tCRZvgHyUtVF9lo53BEwZAYDVR0jBF0wW4AUGu3+QTmQtCRZvgHyUtVF9lo53BGhOKQ2MDQxCzAJ +BgNVBAYTAkZSMRIwEAYDVQQKDAlEaGlteW90aXMxETAPBgNVBAMMCENlcnRpZ25hggkA/tzjAQ/J +SP8wDgYDVR0PAQH/BAQDAgEGMBEGCWCGSAGG+EIBAQQEAwIABzANBgkqhkiG9w0BAQUFAAOCAQEA +hQMeknH2Qq/ho2Ge6/PAD/Kl1NqV5ta+aDY9fm4fTIrv0Q8hbV6lUmPOEvjvKtpv6zf+EwLHyzs+ +ImvaYS5/1HI93TDhHkxAGYwP15zRgzB7mFncfca5DClMoTOi62c6ZYTTluLtdkVwj7Ur3vkj1klu +PBS1xp81HlDQwY9qcEQCYsuuHWhBp6pX6FOqB9IG9tUUBguRA3UsbHK1YZWaDYu5Def131TN3ubY +1gkIl2PlwS6wt0QmwCbAr1UwnjvVNioZBPRcHv/PLLf/0P2HQBHVESO7SMAhqaQoLf0V+LBOK/Qw +WyH8EZE0vkHve52Xdf+XlcCWWC/qu0bXu+TZLg== +-----END CERTIFICATE----- + +AC Ra\xC3\xADz Certic\xC3\xA1mara S.A. +====================================== +-----BEGIN CERTIFICATE----- +MIIGZjCCBE6gAwIBAgIPB35Sk3vgFeNX8GmMy+wMMA0GCSqGSIb3DQEBBQUAMHsxCzAJBgNVBAYT +AkNPMUcwRQYDVQQKDD5Tb2NpZWRhZCBDYW1lcmFsIGRlIENlcnRpZmljYWNpw7NuIERpZ2l0YWwg +LSBDZXJ0aWPDoW1hcmEgUy5BLjEjMCEGA1UEAwwaQUMgUmHDrXogQ2VydGljw6FtYXJhIFMuQS4w +HhcNMDYxMTI3MjA0NjI5WhcNMzAwNDAyMjE0MjAyWjB7MQswCQYDVQQGEwJDTzFHMEUGA1UECgw+ +U29jaWVkYWQgQ2FtZXJhbCBkZSBDZXJ0aWZpY2FjacOzbiBEaWdpdGFsIC0gQ2VydGljw6FtYXJh +IFMuQS4xIzAhBgNVBAMMGkFDIFJhw616IENlcnRpY8OhbWFyYSBTLkEuMIICIjANBgkqhkiG9w0B +AQEFAAOCAg8AMIICCgKCAgEAq2uJo1PMSCMI+8PPUZYILrgIem08kBeGqentLhM0R7LQcNzJPNCN +yu5LF6vQhbCnIwTLqKL85XXbQMpiiY9QngE9JlsYhBzLfDe3fezTf3MZsGqy2IiKLUV0qPezuMDU +2s0iiXRNWhU5cxh0T7XrmafBHoi0wpOQY5fzp6cSsgkiBzPZkc0OnB8OIMfuuzONj8LSWKdf/WU3 +4ojC2I+GdV75LaeHM/J4Ny+LvB2GNzmxlPLYvEqcgxhaBvzz1NS6jBUJJfD5to0EfhcSM2tXSExP +2yYe68yQ54v5aHxwD6Mq0Do43zeX4lvegGHTgNiRg0JaTASJaBE8rF9ogEHMYELODVoqDA+bMMCm +8Ibbq0nXl21Ii/kDwFJnmxL3wvIumGVC2daa49AZMQyth9VXAnow6IYm+48jilSH5L887uvDdUhf +HjlvgWJsxS3EF1QZtzeNnDeRyPYL1epjb4OsOMLzP96a++EjYfDIJss2yKHzMI+ko6Kh3VOz3vCa +Mh+DkXkwwakfU5tTohVTP92dsxA7SH2JD/ztA/X7JWR1DhcZDY8AFmd5ekD8LVkH2ZD6mq093ICK +5lw1omdMEWux+IBkAC1vImHFrEsm5VoQgpukg3s0956JkSCXjrdCx2bD0Omk1vUgjcTDlaxECp1b +czwmPS9KvqfJpxAe+59QafMCAwEAAaOB5jCB4zAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQE +AwIBBjAdBgNVHQ4EFgQU0QnQ6dfOeXRU+Tows/RtLAMDG2gwgaAGA1UdIASBmDCBlTCBkgYEVR0g +ADCBiTArBggrBgEFBQcCARYfaHR0cDovL3d3dy5jZXJ0aWNhbWFyYS5jb20vZHBjLzBaBggrBgEF +BQcCAjBOGkxMaW1pdGFjaW9uZXMgZGUgZ2FyYW507WFzIGRlIGVzdGUgY2VydGlmaWNhZG8gc2Ug +cHVlZGVuIGVuY29udHJhciBlbiBsYSBEUEMuMA0GCSqGSIb3DQEBBQUAA4ICAQBclLW4RZFNjmEf +AygPU3zmpFmps4p6xbD/CHwso3EcIRNnoZUSQDWDg4902zNc8El2CoFS3UnUmjIz75uny3XlesuX +EpBcunvFm9+7OSPI/5jOCk0iAUgHforA1SBClETvv3eiiWdIG0ADBaGJ7M9i4z0ldma/Jre7Ir5v +/zlXdLp6yQGVwZVR6Kss+LGGIOk/yzVb0hfpKv6DExdA7ohiZVvVO2Dpezy4ydV/NgIlqmjCMRW3 +MGXrfx1IebHPOeJCgBbT9ZMj/EyXyVo3bHwi2ErN0o42gzmRkBDI8ck1fj+404HGIGQatlDCIaR4 +3NAvO2STdPCWkPHv+wlaNECW8DYSwaN0jJN+Qd53i+yG2dIPPy3RzECiiWZIHiCznCNZc6lEc7wk +eZBWN7PGKX6jD/EpOe9+XCgycDWs2rjIdWb8m0w5R44bb5tNAlQiM+9hup4phO9OSzNHdpdqy35f +/RWmnkJDW2ZaiogN9xa5P1FlK2Zqi9E4UqLWRhH6/JocdJ6PlwsCT2TG9WjTSy3/pDceiz+/RL5h +RqGEPQgnTIEgd4kI6mdAXmwIUV80WoyWaM3X94nCHNMyAK9Sy9NgWyo6R35rMDOhYil/SrnhLecU +Iw4OGEfhefwVVdCx/CVxY3UzHCMrr1zZ7Ud3YA47Dx7SwNxkBYn8eNZcLCZDqQ== +-----END CERTIFICATE----- + +TC TrustCenter Class 2 CA II +============================ +-----BEGIN CERTIFICATE----- +MIIEqjCCA5KgAwIBAgIOLmoAAQACH9dSISwRXDswDQYJKoZIhvcNAQEFBQAwdjELMAkGA1UEBhMC +REUxHDAaBgNVBAoTE1RDIFRydXN0Q2VudGVyIEdtYkgxIjAgBgNVBAsTGVRDIFRydXN0Q2VudGVy +IENsYXNzIDIgQ0ExJTAjBgNVBAMTHFRDIFRydXN0Q2VudGVyIENsYXNzIDIgQ0EgSUkwHhcNMDYw +MTEyMTQzODQzWhcNMjUxMjMxMjI1OTU5WjB2MQswCQYDVQQGEwJERTEcMBoGA1UEChMTVEMgVHJ1 +c3RDZW50ZXIgR21iSDEiMCAGA1UECxMZVEMgVHJ1c3RDZW50ZXIgQ2xhc3MgMiBDQTElMCMGA1UE +AxMcVEMgVHJ1c3RDZW50ZXIgQ2xhc3MgMiBDQSBJSTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCC +AQoCggEBAKuAh5uO8MN8h9foJIIRszzdQ2Lu+MNF2ujhoF/RKrLqk2jftMjWQ+nEdVl//OEd+DFw +IxuInie5e/060smp6RQvkL4DUsFJzfb95AhmC1eKokKguNV/aVyQMrKXDcpK3EY+AlWJU+MaWss2 +xgdW94zPEfRMuzBwBJWl9jmM/XOBCH2JXjIeIqkiRUuwZi4wzJ9l/fzLganx4Duvo4bRierERXlQ +Xa7pIXSSTYtZgo+U4+lK8edJsBTj9WLL1XK9H7nSn6DNqPoByNkN39r8R52zyFTfSUrxIan+GE7u +SNQZu+995OKdy1u2bv/jzVrndIIFuoAlOMvkaZ6vQaoahPUCAwEAAaOCATQwggEwMA8GA1UdEwEB +/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBTjq1RMgKHbVkO3kUrL84J6E1wIqzCB +7QYDVR0fBIHlMIHiMIHfoIHcoIHZhjVodHRwOi8vd3d3LnRydXN0Y2VudGVyLmRlL2NybC92Mi90 +Y19jbGFzc18yX2NhX0lJLmNybIaBn2xkYXA6Ly93d3cudHJ1c3RjZW50ZXIuZGUvQ049VEMlMjBU +cnVzdENlbnRlciUyMENsYXNzJTIwMiUyMENBJTIwSUksTz1UQyUyMFRydXN0Q2VudGVyJTIwR21i +SCxPVT1yb290Y2VydHMsREM9dHJ1c3RjZW50ZXIsREM9ZGU/Y2VydGlmaWNhdGVSZXZvY2F0aW9u +TGlzdD9iYXNlPzANBgkqhkiG9w0BAQUFAAOCAQEAjNfffu4bgBCzg/XbEeprS6iSGNn3Bzn1LL4G +dXpoUxUc6krtXvwjshOg0wn/9vYua0Fxec3ibf2uWWuFHbhOIprtZjluS5TmVfwLG4t3wVMTZonZ +KNaL80VKY7f9ewthXbhtvsPcW3nS7Yblok2+XnR8au0WOB9/WIFaGusyiC2y8zl3gK9etmF1Kdsj +TYjKUCjLhdLTEKJZbtOTVAB6okaVhgWcqRmY5TFyDADiZ9lA4CQze28suVyrZZ0srHbqNZn1l7kP +JOzHdiEoZa5X6AeIdUpWoNIFOqTmjZKILPPy4cHGYdtBxceb9w4aUUXCYWvcZCcXjFq32nQozZfk +vQ== +-----END CERTIFICATE----- + +TC TrustCenter Class 3 CA II +============================ +-----BEGIN CERTIFICATE----- +MIIEqjCCA5KgAwIBAgIOSkcAAQAC5aBd1j8AUb8wDQYJKoZIhvcNAQEFBQAwdjELMAkGA1UEBhMC +REUxHDAaBgNVBAoTE1RDIFRydXN0Q2VudGVyIEdtYkgxIjAgBgNVBAsTGVRDIFRydXN0Q2VudGVy +IENsYXNzIDMgQ0ExJTAjBgNVBAMTHFRDIFRydXN0Q2VudGVyIENsYXNzIDMgQ0EgSUkwHhcNMDYw +MTEyMTQ0MTU3WhcNMjUxMjMxMjI1OTU5WjB2MQswCQYDVQQGEwJERTEcMBoGA1UEChMTVEMgVHJ1 +c3RDZW50ZXIgR21iSDEiMCAGA1UECxMZVEMgVHJ1c3RDZW50ZXIgQ2xhc3MgMyBDQTElMCMGA1UE +AxMcVEMgVHJ1c3RDZW50ZXIgQ2xhc3MgMyBDQSBJSTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCC +AQoCggEBALTgu1G7OVyLBMVMeRwjhjEQY0NVJz/GRcekPewJDRoeIMJWHt4bNwcwIi9v8Qbxq63W +yKthoy9DxLCyLfzDlml7forkzMA5EpBCYMnMNWju2l+QVl/NHE1bWEnrDgFPZPosPIlY2C8u4rBo +6SI7dYnWRBpl8huXJh0obazovVkdKyT21oQDZogkAHhg8fir/gKya/si+zXmFtGt9i4S5Po1auUZ +uV3bOx4a+9P/FRQI2AlqukWdFHlgfa9Aigdzs5OW03Q0jTo3Kd5c7PXuLjHCINy+8U9/I1LZW+Jk +2ZyqBwi1Rb3R0DHBq1SfqdLDYmAD8bs5SpJKPQq5ncWg/jcCAwEAAaOCATQwggEwMA8GA1UdEwEB +/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBTUovyfs8PYA9NXXAek0CSnwPIA1DCB +7QYDVR0fBIHlMIHiMIHfoIHcoIHZhjVodHRwOi8vd3d3LnRydXN0Y2VudGVyLmRlL2NybC92Mi90 +Y19jbGFzc18zX2NhX0lJLmNybIaBn2xkYXA6Ly93d3cudHJ1c3RjZW50ZXIuZGUvQ049VEMlMjBU +cnVzdENlbnRlciUyMENsYXNzJTIwMyUyMENBJTIwSUksTz1UQyUyMFRydXN0Q2VudGVyJTIwR21i +SCxPVT1yb290Y2VydHMsREM9dHJ1c3RjZW50ZXIsREM9ZGU/Y2VydGlmaWNhdGVSZXZvY2F0aW9u +TGlzdD9iYXNlPzANBgkqhkiG9w0BAQUFAAOCAQEANmDkcPcGIEPZIxpC8vijsrlNirTzwppVMXzE +O2eatN9NDoqTSheLG43KieHPOh6sHfGcMrSOWXaiQYUlN6AT0PV8TtXqluJucsG7Kv5sbviRmEb8 +yRtXW+rIGjs/sFGYPAfaLFkB2otE6OF0/ado3VS6g0bsyEa1+K+XwDsJHI/OcpY9M1ZwvJbL2NV9 +IJqDnxrcOfHFcqMRA/07QlIp2+gB95tejNaNhk4Z+rwcvsUhpYeeeC422wlxo3I0+GzjBgnyXlal +092Y+tTmBvTwtiBjS+opvaqCZh77gaqnN60TGOaSw4HBM7uIHqHn4rS9MWwOUT1v+5ZWgOI2F9Hc +5A== +-----END CERTIFICATE----- + +TC TrustCenter Universal CA I +============================= +-----BEGIN CERTIFICATE----- +MIID3TCCAsWgAwIBAgIOHaIAAQAC7LdggHiNtgYwDQYJKoZIhvcNAQEFBQAweTELMAkGA1UEBhMC +REUxHDAaBgNVBAoTE1RDIFRydXN0Q2VudGVyIEdtYkgxJDAiBgNVBAsTG1RDIFRydXN0Q2VudGVy +IFVuaXZlcnNhbCBDQTEmMCQGA1UEAxMdVEMgVHJ1c3RDZW50ZXIgVW5pdmVyc2FsIENBIEkwHhcN +MDYwMzIyMTU1NDI4WhcNMjUxMjMxMjI1OTU5WjB5MQswCQYDVQQGEwJERTEcMBoGA1UEChMTVEMg +VHJ1c3RDZW50ZXIgR21iSDEkMCIGA1UECxMbVEMgVHJ1c3RDZW50ZXIgVW5pdmVyc2FsIENBMSYw +JAYDVQQDEx1UQyBUcnVzdENlbnRlciBVbml2ZXJzYWwgQ0EgSTCCASIwDQYJKoZIhvcNAQEBBQAD +ggEPADCCAQoCggEBAKR3I5ZEr5D0MacQ9CaHnPM42Q9e3s9B6DGtxnSRJJZ4Hgmgm5qVSkr1YnwC +qMqs+1oEdjneX/H5s7/zA1hV0qq34wQi0fiU2iIIAI3TfCZdzHd55yx4Oagmcw6iXSVphU9VDprv +xrlE4Vc93x9UIuVvZaozhDrzznq+VZeujRIPFDPiUHDDSYcTvFHe15gSWu86gzOSBnWLknwSaHtw +ag+1m7Z3W0hZneTvWq3zwZ7U10VOylY0Ibw+F1tvdwxIAUMpsN0/lm7mlaoMwCC2/T42J5zjXM9O +gdwZu5GQfezmlwQek8wiSdeXhrYTCjxDI3d+8NzmzSQfO4ObNDqDNOMCAwEAAaNjMGEwHwYDVR0j +BBgwFoAUkqR1LKSevoFE63n8isWVpesQdXMwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMC +AYYwHQYDVR0OBBYEFJKkdSyknr6BROt5/IrFlaXrEHVzMA0GCSqGSIb3DQEBBQUAA4IBAQAo0uCG +1eb4e/CX3CJrO5UUVg8RMKWaTzqwOuAGy2X17caXJ/4l8lfmXpWMPmRgFVp/Lw0BxbFg/UU1z/Cy +vwbZ71q+s2IhtNerNXxTPqYn8aEt2hojnczd7Dwtnic0XQ/CNnm8yUpiLe1r2X1BQ3y2qsrtYbE3 +ghUJGooWMNjsydZHcnhLEEYUjl8Or+zHL6sQ17bxbuyGssLoDZJz3KL0Dzq/YSMQiZxIQG5wALPT +ujdEWBF6AmqI8Dc08BnprNRlc/ZpjGSUOnmFKbAWKwyCPwacx/0QK54PLLae4xW/2TYcuiUaUj0a +7CIMHOCkoj3w6DnPgcB77V0fb8XQC9eY +-----END CERTIFICATE----- + +Deutsche Telekom Root CA 2 +========================== +-----BEGIN CERTIFICATE----- +MIIDnzCCAoegAwIBAgIBJjANBgkqhkiG9w0BAQUFADBxMQswCQYDVQQGEwJERTEcMBoGA1UEChMT +RGV1dHNjaGUgVGVsZWtvbSBBRzEfMB0GA1UECxMWVC1UZWxlU2VjIFRydXN0IENlbnRlcjEjMCEG +A1UEAxMaRGV1dHNjaGUgVGVsZWtvbSBSb290IENBIDIwHhcNOTkwNzA5MTIxMTAwWhcNMTkwNzA5 +MjM1OTAwWjBxMQswCQYDVQQGEwJERTEcMBoGA1UEChMTRGV1dHNjaGUgVGVsZWtvbSBBRzEfMB0G +A1UECxMWVC1UZWxlU2VjIFRydXN0IENlbnRlcjEjMCEGA1UEAxMaRGV1dHNjaGUgVGVsZWtvbSBS +b290IENBIDIwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCrC6M14IspFLEUha88EOQ5 +bzVdSq7d6mGNlUn0b2SjGmBmpKlAIoTZ1KXleJMOaAGtuU1cOs7TuKhCQN/Po7qCWWqSG6wcmtoI +KyUn+WkjR/Hg6yx6m/UTAtB+NHzCnjwAWav12gz1MjwrrFDa1sPeg5TKqAyZMg4ISFZbavva4VhY +AUlfckE8FQYBjl2tqriTtM2e66foai1SNNs671x1Udrb8zH57nGYMsRUFUQM+ZtV7a3fGAigo4aK +Se5TBY8ZTNXeWHmb0mocQqvF1afPaA+W5OFhmHZhyJF81j4A4pFQh+GdCuatl9Idxjp9y7zaAzTV +jlsB9WoHtxa2bkp/AgMBAAGjQjBAMB0GA1UdDgQWBBQxw3kbuvVT1xfgiXotF2wKsyudMzAPBgNV +HRMECDAGAQH/AgEFMA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQUFAAOCAQEAlGRZrTlk5ynr +E/5aw4sTV8gEJPB0d8Bg42f76Ymmg7+Wgnxu1MM9756AbrsptJh6sTtU6zkXR34ajgv8HzFZMQSy +zhfzLMdiNlXiItiJVbSYSKpk+tYcNthEeFpaIzpXl/V6ME+un2pMSyuOoAPjPuCp1NJ70rOo4nI8 +rZ7/gFnkm0W09juwzTkZmDLl6iFhkOQxIY40sfcvNUqFENrnijchvllj4PKFiDFT1FQUhXB59C4G +dyd1Lx+4ivn+xbrYNuSD7Odlt79jWvNGr4GUN9RBjNYj1h7P9WgbRGOiWrqnNVmh5XAFmw4jV5mU +Cm26OWMohpLzGITY+9HPBVZkVw== +-----END CERTIFICATE----- + +ComSign Secured CA +================== +-----BEGIN CERTIFICATE----- +MIIDqzCCApOgAwIBAgIRAMcoRwmzuGxFjB36JPU2TukwDQYJKoZIhvcNAQEFBQAwPDEbMBkGA1UE +AxMSQ29tU2lnbiBTZWN1cmVkIENBMRAwDgYDVQQKEwdDb21TaWduMQswCQYDVQQGEwJJTDAeFw0w +NDAzMjQxMTM3MjBaFw0yOTAzMTYxNTA0NTZaMDwxGzAZBgNVBAMTEkNvbVNpZ24gU2VjdXJlZCBD +QTEQMA4GA1UEChMHQ29tU2lnbjELMAkGA1UEBhMCSUwwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAw +ggEKAoIBAQDGtWhfHZQVw6QIVS3joFd67+l0Kru5fFdJGhFeTymHDEjWaueP1H5XJLkGieQcPOqs +49ohgHMhCu95mGwfCP+hUH3ymBvJVG8+pSjsIQQPRbsHPaHA+iqYHU4Gk/v1iDurX8sWv+bznkqH +7Rnqwp9D5PGBpX8QTz7RSmKtUxvLg/8HZaWSLWapW7ha9B20IZFKF3ueMv5WJDmyVIRD9YTC2LxB +kMyd1mja6YJQqTtoz7VdApRgFrFD2UNd3V2Hbuq7s8lr9gOUCXDeFhF6K+h2j0kQmHe5Y1yLM5d1 +9guMsqtb3nQgJT/j8xH5h2iGNXHDHYwt6+UarA9z1YJZQIDTAgMBAAGjgacwgaQwDAYDVR0TBAUw +AwEB/zBEBgNVHR8EPTA7MDmgN6A1hjNodHRwOi8vZmVkaXIuY29tc2lnbi5jby5pbC9jcmwvQ29t +U2lnblNlY3VyZWRDQS5jcmwwDgYDVR0PAQH/BAQDAgGGMB8GA1UdIwQYMBaAFMFL7XC29z58ADsA +j8c+DkWfHl3sMB0GA1UdDgQWBBTBS+1wtvc+fAA7AI/HPg5Fnx5d7DANBgkqhkiG9w0BAQUFAAOC +AQEAFs/ukhNQq3sUnjO2QiBq1BW9Cav8cujvR3qQrFHBZE7piL1DRYHjZiM/EoZNGeQFsOY3wo3a +BijJD4mkU6l1P7CW+6tMM1X5eCZGbxs2mPtCdsGCuY7e+0X5YxtiOzkGynd6qDwJz2w2PQ8KRUtp +FhpFfTMDZflScZAmlaxMDPWLkz/MdXSFmLr/YnpNH4n+rr2UAJm/EaXc4HnFFgt9AmEd6oX5AhVP +51qJThRv4zdLhfXBPGHg/QVBspJ/wx2g0K5SZGBrGMYmnNj1ZOQ2GmKfig8+/21OGVZOIJFsnzQz +OjRXUDpvgV4GxvU+fE6OK85lBi5d0ipTdF7Tbieejw== +-----END CERTIFICATE----- + +Cybertrust Global Root +====================== +-----BEGIN CERTIFICATE----- +MIIDoTCCAomgAwIBAgILBAAAAAABD4WqLUgwDQYJKoZIhvcNAQEFBQAwOzEYMBYGA1UEChMPQ3li +ZXJ0cnVzdCwgSW5jMR8wHQYDVQQDExZDeWJlcnRydXN0IEdsb2JhbCBSb290MB4XDTA2MTIxNTA4 +MDAwMFoXDTIxMTIxNTA4MDAwMFowOzEYMBYGA1UEChMPQ3liZXJ0cnVzdCwgSW5jMR8wHQYDVQQD +ExZDeWJlcnRydXN0IEdsb2JhbCBSb290MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA ++Mi8vRRQZhP/8NN57CPytxrHjoXxEnOmGaoQ25yiZXRadz5RfVb23CO21O1fWLE3TdVJDm71aofW +0ozSJ8bi/zafmGWgE07GKmSb1ZASzxQG9Dvj1Ci+6A74q05IlG2OlTEQXO2iLb3VOm2yHLtgwEZL +AfVJrn5GitB0jaEMAs7u/OePuGtm839EAL9mJRQr3RAwHQeWP032a7iPt3sMpTjr3kfb1V05/Iin +89cqdPHoWqI7n1C6poxFNcJQZZXcY4Lv3b93TZxiyWNzFtApD0mpSPCzqrdsxacwOUBdrsTiXSZT +8M4cIwhhqJQZugRiQOwfOHB3EgZxpzAYXSUnpQIDAQABo4GlMIGiMA4GA1UdDwEB/wQEAwIBBjAP +BgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBS2CHsNesysIEyGVjJez6tuhS1wVzA/BgNVHR8EODA2 +MDSgMqAwhi5odHRwOi8vd3d3Mi5wdWJsaWMtdHJ1c3QuY29tL2NybC9jdC9jdHJvb3QuY3JsMB8G +A1UdIwQYMBaAFLYIew16zKwgTIZWMl7Pq26FLXBXMA0GCSqGSIb3DQEBBQUAA4IBAQBW7wojoFRO +lZfJ+InaRcHUowAl9B8Tq7ejhVhpwjCt2BWKLePJzYFa+HMjWqd8BfP9IjsO0QbE2zZMcwSO5bAi +5MXzLqXZI+O4Tkogp24CJJ8iYGd7ix1yCcUxXOl5n4BHPa2hCwcUPUf/A2kaDAtE52Mlp3+yybh2 +hO0j9n0Hq0V+09+zv+mKts2oomcrUtW3ZfA5TGOgkXmTUg9U3YO7n9GPp1Nzw8v/MOx8BLjYRB+T +X3EJIrduPuocA06dGiBh+4E37F78CkWr1+cXVdCg6mCbpvbjjFspwgZgFJ0tl0ypkxWdYcQBX0jW +WL1WMRJOEcgh4LMRkWXbtKaIOM5V +-----END CERTIFICATE----- + +ePKI Root Certification Authority +================================= +-----BEGIN CERTIFICATE----- +MIIFsDCCA5igAwIBAgIQFci9ZUdcr7iXAF7kBtK8nTANBgkqhkiG9w0BAQUFADBeMQswCQYDVQQG +EwJUVzEjMCEGA1UECgwaQ2h1bmdod2EgVGVsZWNvbSBDby4sIEx0ZC4xKjAoBgNVBAsMIWVQS0kg +Um9vdCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTAeFw0wNDEyMjAwMjMxMjdaFw0zNDEyMjAwMjMx +MjdaMF4xCzAJBgNVBAYTAlRXMSMwIQYDVQQKDBpDaHVuZ2h3YSBUZWxlY29tIENvLiwgTHRkLjEq +MCgGA1UECwwhZVBLSSBSb290IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MIICIjANBgkqhkiG9w0B +AQEFAAOCAg8AMIICCgKCAgEA4SUP7o3biDN1Z82tH306Tm2d0y8U82N0ywEhajfqhFAHSyZbCUNs +IZ5qyNUD9WBpj8zwIuQf5/dqIjG3LBXy4P4AakP/h2XGtRrBp0xtInAhijHyl3SJCRImHJ7K2RKi +lTza6We/CKBk49ZCt0Xvl/T29de1ShUCWH2YWEtgvM3XDZoTM1PRYfl61dd4s5oz9wCGzh1NlDiv +qOx4UXCKXBCDUSH3ET00hl7lSM2XgYI1TBnsZfZrxQWh7kcT1rMhJ5QQCtkkO7q+RBNGMD+XPNjX +12ruOzjjK9SXDrkb5wdJfzcq+Xd4z1TtW0ado4AOkUPB1ltfFLqfpo0kR0BZv3I4sjZsN/+Z0V0O +WQqraffAsgRFelQArr5T9rXn4fg8ozHSqf4hUmTFpmfwdQcGlBSBVcYn5AGPF8Fqcde+S/uUWH1+ +ETOxQvdibBjWzwloPn9s9h6PYq2lY9sJpx8iQkEeb5mKPtf5P0B6ebClAZLSnT0IFaUQAS2zMnao +lQ2zepr7BxB4EW/hj8e6DyUadCrlHJhBmd8hh+iVBmoKs2pHdmX2Os+PYhcZewoozRrSgx4hxyy/ +vv9haLdnG7t4TY3OZ+XkwY63I2binZB1NJipNiuKmpS5nezMirH4JYlcWrYvjB9teSSnUmjDhDXi +Zo1jDiVN1Rmy5nk3pyKdVDECAwEAAaNqMGgwHQYDVR0OBBYEFB4M97Zn8uGSJglFwFU5Lnc/Qkqi +MAwGA1UdEwQFMAMBAf8wOQYEZyoHAAQxMC8wLQIBADAJBgUrDgMCGgUAMAcGBWcqAwAABBRFsMLH +ClZ87lt4DJX5GFPBphzYEDANBgkqhkiG9w0BAQUFAAOCAgEACbODU1kBPpVJufGBuvl2ICO1J2B0 +1GqZNF5sAFPZn/KmsSQHRGoqxqWOeBLoR9lYGxMqXnmbnwoqZ6YlPwZpVnPDimZI+ymBV3QGypzq +KOg4ZyYr8dW1P2WT+DZdjo2NQCCHGervJ8A9tDkPJXtoUHRVnAxZfVo9QZQlUgjgRywVMRnVvwdV +xrsStZf0X4OFunHB2WyBEXYKCrC/gpf36j36+uwtqSiUO1bd0lEursC9CBWMd1I0ltabrNMdjmEP +NXubrjlpC2JgQCA2j6/7Nu4tCEoduL+bXPjqpRugc6bY+G7gMwRfaKonh+3ZwZCc7b3jajWvY9+r +GNm65ulK6lCKD2GTHuItGeIwlDWSXQ62B68ZgI9HkFFLLk3dheLSClIKF5r8GrBQAuUBo2M3IUxE +xJtRmREOc5wGj1QupyheRDmHVi03vYVElOEMSyycw5KFNGHLD7ibSkNS/jQ6fbjpKdx2qcgw+BRx +gMYeNkh0IkFch4LoGHGLQYlE535YW6i4jRPpp2zDR+2zGp1iro2C6pSe3VkQw63d4k3jMdXH7Ojy +sP6SHhYKGvzZ8/gntsm+HbRsZJB/9OTEW9c3rkIO3aQab3yIVMUWbuF6aC74Or8NpDyJO3inTmOD +BCEIZ43ygknQW/2xzQ+DhNQ+IIX3Sj0rnP0qCglN6oH4EZw= +-----END CERTIFICATE----- + +T\xc3\x9c\x42\xC4\xB0TAK UEKAE K\xC3\xB6k Sertifika Hizmet Sa\xC4\x9Flay\xc4\xb1\x63\xc4\xb1s\xc4\xb1 - S\xC3\xBCr\xC3\xBCm 3 +============================================================================================================================= +-----BEGIN CERTIFICATE----- +MIIFFzCCA/+gAwIBAgIBETANBgkqhkiG9w0BAQUFADCCASsxCzAJBgNVBAYTAlRSMRgwFgYDVQQH +DA9HZWJ6ZSAtIEtvY2FlbGkxRzBFBgNVBAoMPlTDvHJraXllIEJpbGltc2VsIHZlIFRla25vbG9q +aWsgQXJhxZ90xLFybWEgS3VydW11IC0gVMOcQsSwVEFLMUgwRgYDVQQLDD9VbHVzYWwgRWxla3Ry +b25payB2ZSBLcmlwdG9sb2ppIEFyYcWfdMSxcm1hIEVuc3RpdMO8c8O8IC0gVUVLQUUxIzAhBgNV +BAsMGkthbXUgU2VydGlmaWthc3lvbiBNZXJrZXppMUowSAYDVQQDDEFUw5xCxLBUQUsgVUVLQUUg +S8O2ayBTZXJ0aWZpa2EgSGl6bWV0IFNhxJ9sYXnEsWPEsXPEsSAtIFPDvHLDvG0gMzAeFw0wNzA4 +MjQxMTM3MDdaFw0xNzA4MjExMTM3MDdaMIIBKzELMAkGA1UEBhMCVFIxGDAWBgNVBAcMD0dlYnpl +IC0gS29jYWVsaTFHMEUGA1UECgw+VMO8cmtpeWUgQmlsaW1zZWwgdmUgVGVrbm9sb2ppayBBcmHF +n3TEsXJtYSBLdXJ1bXUgLSBUw5xCxLBUQUsxSDBGBgNVBAsMP1VsdXNhbCBFbGVrdHJvbmlrIHZl +IEtyaXB0b2xvamkgQXJhxZ90xLFybWEgRW5zdGl0w7xzw7wgLSBVRUtBRTEjMCEGA1UECwwaS2Ft +dSBTZXJ0aWZpa2FzeW9uIE1lcmtlemkxSjBIBgNVBAMMQVTDnELEsFRBSyBVRUtBRSBLw7ZrIFNl +cnRpZmlrYSBIaXptZXQgU2HEn2xhecSxY8Sxc8SxIC0gU8O8csO8bSAzMIIBIjANBgkqhkiG9w0B +AQEFAAOCAQ8AMIIBCgKCAQEAim1L/xCIOsP2fpTo6iBkcK4hgb46ezzb8R1Sf1n68yJMlaCQvEhO +Eav7t7WNeoMojCZG2E6VQIdhn8WebYGHV2yKO7Rm6sxA/OOqbLLLAdsyv9Lrhc+hDVXDWzhXcLh1 +xnnRFDDtG1hba+818qEhTsXOfJlfbLm4IpNQp81McGq+agV/E5wrHur+R84EpW+sky58K5+eeROR +6Oqeyjh1jmKwlZMq5d/pXpduIF9fhHpEORlAHLpVK/swsoHvhOPc7Jg4OQOFCKlUAwUp8MmPi+oL +hmUZEdPpCSPeaJMDyTYcIW7OjGbxmTDY17PDHfiBLqi9ggtm/oLL4eAagsNAgQIDAQABo0IwQDAd +BgNVHQ4EFgQUvYiHyY/2pAoLquvF/pEjnatKijIwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQF +MAMBAf8wDQYJKoZIhvcNAQEFBQADggEBAB18+kmPNOm3JpIWmgV050vQbTlswyb2zrgxvMTfvCr4 +N5EY3ATIZJkrGG2AA1nJrvhY0D7twyOfaTyGOBye79oneNGEN3GKPEs5z35FBtYt2IpNeBLWrcLT +y9LQQfMmNkqblWwM7uXRQydmwYj3erMgbOqwaSvHIOgMA8RBBZniP+Rr+KCGgceExh/VS4ESshYh +LBOhgLJeDEoTniDYYkCrkOpkSi+sDQESeUWoL4cZaMjihccwsnX5OD+ywJO0a+IDRM5noN+J1q2M +dqMTw5RhK2vZbMEHCiIHhWyFJEapvj+LeISCfiQMnf2BN+MlqO02TpUsyZyQ2uypQjyttgI= +-----END CERTIFICATE----- + +Buypass Class 2 CA 1 +==================== +-----BEGIN CERTIFICATE----- +MIIDUzCCAjugAwIBAgIBATANBgkqhkiG9w0BAQUFADBLMQswCQYDVQQGEwJOTzEdMBsGA1UECgwU +QnV5cGFzcyBBUy05ODMxNjMzMjcxHTAbBgNVBAMMFEJ1eXBhc3MgQ2xhc3MgMiBDQSAxMB4XDTA2 +MTAxMzEwMjUwOVoXDTE2MTAxMzEwMjUwOVowSzELMAkGA1UEBhMCTk8xHTAbBgNVBAoMFEJ1eXBh +c3MgQVMtOTgzMTYzMzI3MR0wGwYDVQQDDBRCdXlwYXNzIENsYXNzIDIgQ0EgMTCCASIwDQYJKoZI +hvcNAQEBBQADggEPADCCAQoCggEBAIs8B0XY9t/mx8q6jUPFR42wWsE425KEHK8T1A9vNkYgxC7M +cXA0ojTTNy7Y3Tp3L8DrKehc0rWpkTSHIln+zNvnma+WwajHQN2lFYxuyHyXA8vmIPLXl18xoS83 +0r7uvqmtqEyeIWZDO6i88wmjONVZJMHCR3axiFyCO7srpgTXjAePzdVBHfCuuCkslFJgNJQ72uA4 +0Z0zPhX0kzLFANq1KWYOOngPIVJfAuWSeyXTkh4vFZ2B5J2O6O+JzhRMVB0cgRJNcKi+EAUXfh/R +uFdV7c27UsKwHnjCTTZoy1YmwVLBvXb3WNVyfh9EdrsAiR0WnVE1703CVu9r4Iw7DekCAwEAAaNC +MEAwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUP42aWYv8e3uco684sDntkHGA1sgwDgYDVR0P +AQH/BAQDAgEGMA0GCSqGSIb3DQEBBQUAA4IBAQAVGn4TirnoB6NLJzKyQJHyIdFkhb5jatLPgcIV +1Xp+DCmsNx4cfHZSldq1fyOhKXdlyTKdqC5Wq2B2zha0jX94wNWZUYN/Xtm+DKhQ7SLHrQVMdvvt +7h5HZPb3J31cKA9FxVxiXqaakZG3Uxcu3K1gnZZkOb1naLKuBctN518fV4bVIJwo+28TOPX2EZL2 +fZleHwzoq0QkKXJAPTZSr4xYkHPB7GEseaHsh7U/2k3ZIQAw3pDaDtMaSKk+hQsUi4y8QZ5q9w5w +wDX3OaJdZtB7WZ+oRxKaJyOkLY4ng5IgodcVf/EuGO70SH8vf/GhGLWhC5SgYiAynB321O+/TIho +-----END CERTIFICATE----- + +Buypass Class 3 CA 1 +==================== +-----BEGIN CERTIFICATE----- +MIIDUzCCAjugAwIBAgIBAjANBgkqhkiG9w0BAQUFADBLMQswCQYDVQQGEwJOTzEdMBsGA1UECgwU +QnV5cGFzcyBBUy05ODMxNjMzMjcxHTAbBgNVBAMMFEJ1eXBhc3MgQ2xhc3MgMyBDQSAxMB4XDTA1 +MDUwOTE0MTMwM1oXDTE1MDUwOTE0MTMwM1owSzELMAkGA1UEBhMCTk8xHTAbBgNVBAoMFEJ1eXBh +c3MgQVMtOTgzMTYzMzI3MR0wGwYDVQQDDBRCdXlwYXNzIENsYXNzIDMgQ0EgMTCCASIwDQYJKoZI +hvcNAQEBBQADggEPADCCAQoCggEBAKSO13TZKWTeXx+HgJHqTjnmGcZEC4DVC69TB4sSveZn8AKx +ifZgisRbsELRwCGoy+Gb72RRtqfPFfV0gGgEkKBYouZ0plNTVUhjP5JW3SROjvi6K//zNIqeKNc0 +n6wv1g/xpC+9UrJJhW05NfBEMJNGJPO251P7vGGvqaMU+8IXF4Rs4HyI+MkcVyzwPX6UvCWThOia +AJpFBUJXgPROztmuOfbIUxAMZTpHe2DC1vqRycZxbL2RhzyRhkmr8w+gbCZ2Xhysm3HljbybIR6c +1jh+JIAVMYKWsUnTYjdbiAwKYjT+p0h+mbEwi5A3lRyoH6UsjfRVyNvdWQrCrXig9IsCAwEAAaNC +MEAwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUOBTmyPCppAP0Tj4io1vy1uCtQHQwDgYDVR0P +AQH/BAQDAgEGMA0GCSqGSIb3DQEBBQUAA4IBAQABZ6OMySU9E2NdFm/soT4JXJEVKirZgCFPBdy7 +pYmrEzMqnji3jG8CcmPHc3ceCQa6Oyh7pEfJYWsICCD8igWKH7y6xsL+z27sEzNxZy5p+qksP2bA +EllNC1QCkoS72xLvg3BweMhT+t/Gxv/ciC8HwEmdMldg0/L2mSlf56oBzKwzqBwKu5HEA6BvtjT5 +htOzdlSY9EqBs1OdTUDs5XcTRa9bqh/YL0yCe/4qxFi7T/ye/QNlGioOw6UgFpRreaaiErS7GqQj +el/wroQk5PMr+4okoyeYZdowdXb8GZHo2+ubPzK/QJcHJrrM85SFSnonk8+QQtS4Wxam58tAA915 +-----END CERTIFICATE----- + +EBG Elektronik Sertifika Hizmet Sa\xC4\x9Flay\xc4\xb1\x63\xc4\xb1s\xc4\xb1 +========================================================================== +-----BEGIN CERTIFICATE----- +MIIF5zCCA8+gAwIBAgIITK9zQhyOdAIwDQYJKoZIhvcNAQEFBQAwgYAxODA2BgNVBAMML0VCRyBF +bGVrdHJvbmlrIFNlcnRpZmlrYSBIaXptZXQgU2HEn2xhecSxY8Sxc8SxMTcwNQYDVQQKDC5FQkcg +QmlsacWfaW0gVGVrbm9sb2ppbGVyaSB2ZSBIaXptZXRsZXJpIEEuxZ4uMQswCQYDVQQGEwJUUjAe +Fw0wNjA4MTcwMDIxMDlaFw0xNjA4MTQwMDMxMDlaMIGAMTgwNgYDVQQDDC9FQkcgRWxla3Ryb25p +ayBTZXJ0aWZpa2EgSGl6bWV0IFNhxJ9sYXnEsWPEsXPEsTE3MDUGA1UECgwuRUJHIEJpbGnFn2lt +IFRla25vbG9qaWxlcmkgdmUgSGl6bWV0bGVyaSBBLsWeLjELMAkGA1UEBhMCVFIwggIiMA0GCSqG +SIb3DQEBAQUAA4ICDwAwggIKAoICAQDuoIRh0DpqZhAy2DE4f6en5f2h4fuXd7hxlugTlkaDT7by +X3JWbhNgpQGR4lvFzVcfd2NR/y8927k/qqk153nQ9dAktiHq6yOU/im/+4mRDGSaBUorzAzu8T2b +gmmkTPiab+ci2hC6X5L8GCcKqKpE+i4stPtGmggDg3KriORqcsnlZR9uKg+ds+g75AxuetpX/dfr +eYteIAbTdgtsApWjluTLdlHRKJ2hGvxEok3MenaoDT2/F08iiFD9rrbskFBKW5+VQarKD7JK/oCZ +TqNGFav4c0JqwmZ2sQomFd2TkuzbqV9UIlKRcF0T6kjsbgNs2d1s/OsNA/+mgxKb8amTD8UmTDGy +Y5lhcucqZJnSuOl14nypqZoaqsNW2xCaPINStnuWt6yHd6i58mcLlEOzrz5z+kI2sSXFCjEmN1Zn +uqMLfdb3ic1nobc6HmZP9qBVFCVMLDMNpkGMvQQxahByCp0OLna9XvNRiYuoP1Vzv9s6xiQFlpJI +qkuNKgPlV5EQ9GooFW5Hd4RcUXSfGenmHmMWOeMRFeNYGkS9y8RsZteEBt8w9DeiQyJ50hBs37vm +ExH8nYQKE3vwO9D8owrXieqWfo1IhR5kX9tUoqzVegJ5a9KK8GfaZXINFHDk6Y54jzJ0fFfy1tb0 +Nokb+Clsi7n2l9GkLqq+CxnCRelwXQIDAJ3Zo2MwYTAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB +/wQEAwIBBjAdBgNVHQ4EFgQU587GT/wWZ5b6SqMHwQSny2re2kcwHwYDVR0jBBgwFoAU587GT/wW +Z5b6SqMHwQSny2re2kcwDQYJKoZIhvcNAQEFBQADggIBAJuYml2+8ygjdsZs93/mQJ7ANtyVDR2t +FcU22NU57/IeIl6zgrRdu0waypIN30ckHrMk2pGI6YNw3ZPX6bqz3xZaPt7gyPvT/Wwp+BVGoGgm +zJNSroIBk5DKd8pNSe/iWtkqvTDOTLKBtjDOWU/aWR1qeqRFsIImgYZ29fUQALjuswnoT4cCB64k +XPBfrAowzIpAoHMEwfuJJPaaHFy3PApnNgUIMbOv2AFoKuB4j3TeuFGkjGwgPaL7s9QJ/XvCgKqT +bCmYIai7FvOpEl90tYeY8pUm3zTvilORiF0alKM/fCL414i6poyWqD1SNGKfAB5UVUJnxk1Gj7sU +RT0KlhaOEKGXmdXTMIXM3rRyt7yKPBgpaP3ccQfuJDlq+u2lrDgv+R4QDgZxGhBM/nV+/x5XOULK +1+EVoVZVWRvRo68R2E7DpSvvkL/A7IITW43WciyTTo9qKd+FPNMN4KIYEsxVL0e3p5sC/kH2iExt +2qkBR4NkJ2IQgtYSe14DHzSpyZH+r11thie3I6p1GMog57AP14kOpmciY/SDQSsGS7tY1dHXt7kQ +Y9iJSrSq3RZj9W6+YKH47ejWkE8axsWgKdOnIaj1Wjz3x0miIZpKlVIglnKaZsv30oZDfCK+lvm9 +AahH3eU7QPl1K5srRmSGjR70j/sHd9DqSaIcjVIUpgqT +-----END CERTIFICATE----- + +certSIGN ROOT CA +================ +-----BEGIN CERTIFICATE----- +MIIDODCCAiCgAwIBAgIGIAYFFnACMA0GCSqGSIb3DQEBBQUAMDsxCzAJBgNVBAYTAlJPMREwDwYD +VQQKEwhjZXJ0U0lHTjEZMBcGA1UECxMQY2VydFNJR04gUk9PVCBDQTAeFw0wNjA3MDQxNzIwMDRa +Fw0zMTA3MDQxNzIwMDRaMDsxCzAJBgNVBAYTAlJPMREwDwYDVQQKEwhjZXJ0U0lHTjEZMBcGA1UE +CxMQY2VydFNJR04gUk9PVCBDQTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBALczuX7I +JUqOtdu0KBuqV5Do0SLTZLrTk+jUrIZhQGpgV2hUhE28alQCBf/fm5oqrl0Hj0rDKH/v+yv6efHH +rfAQUySQi2bJqIirr1qjAOm+ukbuW3N7LBeCgV5iLKECZbO9xSsAfsT8AzNXDe3i+s5dRdY4zTW2 +ssHQnIFKquSyAVwdj1+ZxLGt24gh65AIgoDzMKND5pCCrlUoSe1b16kQOA7+j0xbm0bqQfWwCHTD +0IgztnzXdN/chNFDDnU5oSVAKOp4yw4sLjmdjItuFhwvJoIQ4uNllAoEwF73XVv4EOLQunpL+943 +AAAaWyjj0pxzPjKHmKHJUS/X3qwzs08CAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8B +Af8EBAMCAcYwHQYDVR0OBBYEFOCMm9slSbPxfIbWskKHC9BroNnkMA0GCSqGSIb3DQEBBQUAA4IB +AQA+0hyJLjX8+HXd5n9liPRyTMks1zJO890ZeUe9jjtbkw9QSSQTaxQGcu8J06Gh40CEyecYMnQ8 +SG4Pn0vU9x7Tk4ZkVJdjclDVVc/6IJMCopvDI5NOFlV2oHB5bc0hH88vLbwZ44gx+FkagQnIl6Z0 +x2DEW8xXjrJ1/RsCCdtZb3KTafcxQdaIOL+Hsr0Wefmq5L6IJd1hJyMctTEHBDa0GpC9oHRxUIlt +vBTjD4au8as+x6AJzKNI0eDbZOeStc+vckNwi/nDhDwTqn6Sm1dTk/pwwpEOMfmbZ13pljheX7Nz +TogVZ96edhBiIL5VaZVDADlN9u6wWk5JRFRYX0KD +-----END CERTIFICATE----- + +CNNIC ROOT +========== +-----BEGIN CERTIFICATE----- +MIIDVTCCAj2gAwIBAgIESTMAATANBgkqhkiG9w0BAQUFADAyMQswCQYDVQQGEwJDTjEOMAwGA1UE +ChMFQ05OSUMxEzARBgNVBAMTCkNOTklDIFJPT1QwHhcNMDcwNDE2MDcwOTE0WhcNMjcwNDE2MDcw +OTE0WjAyMQswCQYDVQQGEwJDTjEOMAwGA1UEChMFQ05OSUMxEzARBgNVBAMTCkNOTklDIFJPT1Qw +ggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDTNfc/c3et6FtzF8LRb+1VvG7q6KR5smzD +o+/hn7E7SIX1mlwhIhAsxYLO2uOabjfhhyzcuQxauohV3/2q2x8x6gHx3zkBwRP9SFIhxFXf2tiz +VHa6dLG3fdfA6PZZxU3Iva0fFNrfWEQlMhkqx35+jq44sDB7R3IJMfAw28Mbdim7aXZOV/kbZKKT +VrdvmW7bCgScEeOAH8tjlBAKqeFkgjH5jCftppkA9nCTGPihNIaj3XrCGHn2emU1z5DrvTOTn1Or +czvmmzQgLx3vqR1jGqCA2wMv+SYahtKNu6m+UjqHZ0gNv7Sg2Ca+I19zN38m5pIEo3/PIKe38zrK +y5nLAgMBAAGjczBxMBEGCWCGSAGG+EIBAQQEAwIABzAfBgNVHSMEGDAWgBRl8jGtKvf33VKWCscC +wQ7vptU7ETAPBgNVHRMBAf8EBTADAQH/MAsGA1UdDwQEAwIB/jAdBgNVHQ4EFgQUZfIxrSr3991S +lgrHAsEO76bVOxEwDQYJKoZIhvcNAQEFBQADggEBAEs17szkrr/Dbq2flTtLP1se31cpolnKOOK5 +Gv+e5m4y3R6u6jW39ZORTtpC4cMXYFDy0VwmuYK36m3knITnA3kXr5g9lNvHugDnuL8BV8F3RTIM +O/G0HAiw/VGgod2aHRM2mm23xzy54cXZF/qD1T0VoDy7HgviyJA/qIYM/PmLXoXLT1tLYhFHxUV8 +BS9BsZ4QaRuZluBVeftOhpm4lNqGOGqTo+fLbuXf6iFViZx9fX+Y9QCJ7uOEwFyWtcVG6kbghVW2 +G8kS1sHNzYDzAgE8yGnLRUhj2JTQ7IUOO04RZfSCjKY9ri4ilAnIXOo8gV0WKgOXFlUJ24pBgp5m +mxE= +-----END CERTIFICATE----- + +ApplicationCA - Japanese Government +=================================== +-----BEGIN CERTIFICATE----- +MIIDoDCCAoigAwIBAgIBMTANBgkqhkiG9w0BAQUFADBDMQswCQYDVQQGEwJKUDEcMBoGA1UEChMT +SmFwYW5lc2UgR292ZXJubWVudDEWMBQGA1UECxMNQXBwbGljYXRpb25DQTAeFw0wNzEyMTIxNTAw +MDBaFw0xNzEyMTIxNTAwMDBaMEMxCzAJBgNVBAYTAkpQMRwwGgYDVQQKExNKYXBhbmVzZSBHb3Zl +cm5tZW50MRYwFAYDVQQLEw1BcHBsaWNhdGlvbkNBMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIB +CgKCAQEAp23gdE6Hj6UG3mii24aZS2QNcfAKBZuOquHMLtJqO8F6tJdhjYq+xpqcBrSGUeQ3DnR4 +fl+Kf5Sk10cI/VBaVuRorChzoHvpfxiSQE8tnfWuREhzNgaeZCw7NCPbXCbkcXmP1G55IrmTwcrN +wVbtiGrXoDkhBFcsovW8R0FPXjQilbUfKW1eSvNNcr5BViCH/OlQR9cwFO5cjFW6WY2H/CPek9AE +jP3vbb3QesmlOmpyM8ZKDQUXKi17safY1vC+9D/qDihtQWEjdnjDuGWk81quzMKq2edY3rZ+nYVu +nyoKb58DKTCXKB28t89UKU5RMfkntigm/qJj5kEW8DOYRwIDAQABo4GeMIGbMB0GA1UdDgQWBBRU +WssmP3HMlEYNllPqa0jQk/5CdTAOBgNVHQ8BAf8EBAMCAQYwWQYDVR0RBFIwUKROMEwxCzAJBgNV +BAYTAkpQMRgwFgYDVQQKDA/ml6XmnKzlm73mlL/lupwxIzAhBgNVBAsMGuOCouODl+ODquOCseOD +vOOCt+ODp+ODs0NBMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQEFBQADggEBADlqRHZ3ODrs +o2dGD/mLBqj7apAxzn7s2tGJfHrrLgy9mTLnsCTWw//1sogJhyzjVOGjprIIC8CFqMjSnHH2HZ9g +/DgzE+Ge3Atf2hZQKXsvcJEPmbo0NI2VdMV+eKlmXb3KIXdCEKxmJj3ekav9FfBv7WxfEPjzFvYD +io+nEhEMy/0/ecGc/WLuo89UDNErXxc+4z6/wCs+CZv+iKZ+tJIX/COUgb1up8WMwusRRdv4QcmW +dupwX3kSa+SjB1oF7ydJzyGfikwJcGapJsErEU4z0g781mzSDjJkaP+tBXhfAx2o45CsJOAPQKdL +rosot4LKGAfmt1t06SAZf7IbiVQ= +-----END CERTIFICATE----- + +GeoTrust Primary Certification Authority - G3 +============================================= +-----BEGIN CERTIFICATE----- +MIID/jCCAuagAwIBAgIQFaxulBmyeUtB9iepwxgPHzANBgkqhkiG9w0BAQsFADCBmDELMAkGA1UE +BhMCVVMxFjAUBgNVBAoTDUdlb1RydXN0IEluYy4xOTA3BgNVBAsTMChjKSAyMDA4IEdlb1RydXN0 +IEluYy4gLSBGb3IgYXV0aG9yaXplZCB1c2Ugb25seTE2MDQGA1UEAxMtR2VvVHJ1c3QgUHJpbWFy +eSBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eSAtIEczMB4XDTA4MDQwMjAwMDAwMFoXDTM3MTIwMTIz +NTk1OVowgZgxCzAJBgNVBAYTAlVTMRYwFAYDVQQKEw1HZW9UcnVzdCBJbmMuMTkwNwYDVQQLEzAo +YykgMjAwOCBHZW9UcnVzdCBJbmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxNjA0BgNVBAMT +LUdlb1RydXN0IFByaW1hcnkgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkgLSBHMzCCASIwDQYJKoZI +hvcNAQEBBQADggEPADCCAQoCggEBANziXmJYHTNXOTIz+uvLh4yn1ErdBojqZI4xmKU4kB6Yzy5j +K/BGvESyiaHAKAxJcCGVn2TAppMSAmUmhsalifD614SgcK9PGpc/BkTVyetyEH3kMSj7HGHmKAdE +c5IiaacDiGydY8hS2pgn5whMcD60yRLBxWeDXTPzAxHsatBT4tG6NmCUgLthY2xbF37fQJQeqw3C +IShwiP/WJmxsYAQlTlV+fe+/lEjetx3dcI0FX4ilm/LC7urRQEFtYjgdVgbFA0dRIBn8exALDmKu +dlW/X3e+PkkBUz2YJQN2JFodtNuJ6nnltrM7P7pMKEF/BqxqjsHQ9gUdfeZChuOl1UcCAwEAAaNC +MEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFMR5yo6hTgMdHNxr +2zFblD4/MH8tMA0GCSqGSIb3DQEBCwUAA4IBAQAtxRPPVoB7eni9n64smefv2t+UXglpp+duaIy9 +cr5HqQ6XErhK8WTTOd8lNNTBzU6B8A8ExCSzNJbGpqow32hhc9f5joWJ7w5elShKKiePEI4ufIbE +Ap7aDHdlDkQNkv39sxY2+hENHYwOB4lqKVb3cvTdFZx3NWZXqxNT2I7BQMXXExZacse3aQHEerGD +AWh9jUGhlBjBJVz88P6DAod8DQ3PLghcSkANPuyBYeYk28rgDi0Hsj5W3I31QYUHSJsMC8tJP33s +t/3LjWeJGqvtux6jAAgIFyqCXDFdRootD4abdNlF+9RAsXqqaC2Gspki4cErx5z481+oghLrGREt +-----END CERTIFICATE----- + +thawte Primary Root CA - G2 +=========================== +-----BEGIN CERTIFICATE----- +MIICiDCCAg2gAwIBAgIQNfwmXNmET8k9Jj1Xm67XVjAKBggqhkjOPQQDAzCBhDELMAkGA1UEBhMC +VVMxFTATBgNVBAoTDHRoYXd0ZSwgSW5jLjE4MDYGA1UECxMvKGMpIDIwMDcgdGhhd3RlLCBJbmMu +IC0gRm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxJDAiBgNVBAMTG3RoYXd0ZSBQcmltYXJ5IFJvb3Qg +Q0EgLSBHMjAeFw0wNzExMDUwMDAwMDBaFw0zODAxMTgyMzU5NTlaMIGEMQswCQYDVQQGEwJVUzEV +MBMGA1UEChMMdGhhd3RlLCBJbmMuMTgwNgYDVQQLEy8oYykgMjAwNyB0aGF3dGUsIEluYy4gLSBG +b3IgYXV0aG9yaXplZCB1c2Ugb25seTEkMCIGA1UEAxMbdGhhd3RlIFByaW1hcnkgUm9vdCBDQSAt +IEcyMHYwEAYHKoZIzj0CAQYFK4EEACIDYgAEotWcgnuVnfFSeIf+iha/BebfowJPDQfGAFG6DAJS +LSKkQjnE/o/qycG+1E3/n3qe4rF8mq2nhglzh9HnmuN6papu+7qzcMBniKI11KOasf2twu8x+qi5 +8/sIxpHR+ymVo0IwQDAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQU +mtgAMADna3+FGO6Lts6KDPgR4bswCgYIKoZIzj0EAwMDaQAwZgIxAN344FdHW6fmCsO99YCKlzUN +G4k8VIZ3KMqh9HneteY4sPBlcIx/AlTCv//YoT7ZzwIxAMSNlPzcU9LcnXgWHxUzI1NS41oxXZ3K +rr0TKUQNJ1uo52icEvdYPy5yAlejj6EULg== +-----END CERTIFICATE----- + +thawte Primary Root CA - G3 +=========================== +-----BEGIN CERTIFICATE----- +MIIEKjCCAxKgAwIBAgIQYAGXt0an6rS0mtZLL/eQ+zANBgkqhkiG9w0BAQsFADCBrjELMAkGA1UE +BhMCVVMxFTATBgNVBAoTDHRoYXd0ZSwgSW5jLjEoMCYGA1UECxMfQ2VydGlmaWNhdGlvbiBTZXJ2 +aWNlcyBEaXZpc2lvbjE4MDYGA1UECxMvKGMpIDIwMDggdGhhd3RlLCBJbmMuIC0gRm9yIGF1dGhv +cml6ZWQgdXNlIG9ubHkxJDAiBgNVBAMTG3RoYXd0ZSBQcmltYXJ5IFJvb3QgQ0EgLSBHMzAeFw0w +ODA0MDIwMDAwMDBaFw0zNzEyMDEyMzU5NTlaMIGuMQswCQYDVQQGEwJVUzEVMBMGA1UEChMMdGhh +d3RlLCBJbmMuMSgwJgYDVQQLEx9DZXJ0aWZpY2F0aW9uIFNlcnZpY2VzIERpdmlzaW9uMTgwNgYD +VQQLEy8oYykgMjAwOCB0aGF3dGUsIEluYy4gLSBGb3IgYXV0aG9yaXplZCB1c2Ugb25seTEkMCIG +A1UEAxMbdGhhd3RlIFByaW1hcnkgUm9vdCBDQSAtIEczMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8A +MIIBCgKCAQEAsr8nLPvb2FvdeHsbnndmgcs+vHyu86YnmjSjaDFxODNi5PNxZnmxqWWjpYvVj2At +P0LMqmsywCPLLEHd5N/8YZzic7IilRFDGF/Eth9XbAoFWCLINkw6fKXRz4aviKdEAhN0cXMKQlkC ++BsUa0Lfb1+6a4KinVvnSr0eAXLbS3ToO39/fR8EtCab4LRarEc9VbjXsCZSKAExQGbY2SS99irY +7CFJXJv2eul/VTV+lmuNk5Mny5K76qxAwJ/C+IDPXfRa3M50hqY+bAtTyr2SzhkGcuYMXDhpxwTW +vGzOW/b3aJzcJRVIiKHpqfiYnODz1TEoYRFsZ5aNOZnLwkUkOQIDAQABo0IwQDAPBgNVHRMBAf8E +BTADAQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUrWyqlGCc7eT/+j4KdCtjA/e2Wb8wDQYJ +KoZIhvcNAQELBQADggEBABpA2JVlrAmSicY59BDlqQ5mU1143vokkbvnRFHfxhY0Cu9qRFHqKweK +A3rD6z8KLFIWoCtDuSWQP3CpMyVtRRooOyfPqsMpQhvfO0zAMzRbQYi/aytlryjvsvXDqmbOe1bu +t8jLZ8HJnBoYuMTDSQPxYA5QzUbF83d597YV4Djbxy8ooAw/dyZ02SUS2jHaGh7cKUGRIjxpp7sC +8rZcJwOJ9Abqm+RyguOhCcHpABnTPtRwa7pxpqpYrvS76Wy274fMm7v/OeZWYdMKp8RcTGB7BXcm +er/YB1IsYvdwY9k5vG8cwnncdimvzsUsZAReiDZuMdRAGmI0Nj81Aa6sY6A= +-----END CERTIFICATE----- + +GeoTrust Primary Certification Authority - G2 +============================================= +-----BEGIN CERTIFICATE----- +MIICrjCCAjWgAwIBAgIQPLL0SAoA4v7rJDteYD7DazAKBggqhkjOPQQDAzCBmDELMAkGA1UEBhMC +VVMxFjAUBgNVBAoTDUdlb1RydXN0IEluYy4xOTA3BgNVBAsTMChjKSAyMDA3IEdlb1RydXN0IElu +Yy4gLSBGb3IgYXV0aG9yaXplZCB1c2Ugb25seTE2MDQGA1UEAxMtR2VvVHJ1c3QgUHJpbWFyeSBD +ZXJ0aWZpY2F0aW9uIEF1dGhvcml0eSAtIEcyMB4XDTA3MTEwNTAwMDAwMFoXDTM4MDExODIzNTk1 +OVowgZgxCzAJBgNVBAYTAlVTMRYwFAYDVQQKEw1HZW9UcnVzdCBJbmMuMTkwNwYDVQQLEzAoYykg +MjAwNyBHZW9UcnVzdCBJbmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNlIG9ubHkxNjA0BgNVBAMTLUdl +b1RydXN0IFByaW1hcnkgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkgLSBHMjB2MBAGByqGSM49AgEG +BSuBBAAiA2IABBWx6P0DFUPlrOuHNxFi79KDNlJ9RVcLSo17VDs6bl8VAsBQps8lL33KSLjHUGMc +KiEIfJo22Av+0SbFWDEwKCXzXV2juLaltJLtbCyf691DiaI8S0iRHVDsJt/WYC69IaNCMEAwDwYD +VR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFBVfNVdRVfslsq0DafwBo/q+ +EVXVMAoGCCqGSM49BAMDA2cAMGQCMGSWWaboCd6LuvpaiIjwH5HTRqjySkwCY/tsXzjbLkGTqQ7m +ndwxHLKgpxgceeHHNgIwOlavmnRs9vuD4DPTCF+hnMJbn0bWtsuRBmOiBuczrD6ogRLQy7rQkgu2 +npaqBA+K +-----END CERTIFICATE----- + +VeriSign Universal Root Certification Authority +=============================================== +-----BEGIN CERTIFICATE----- +MIIEuTCCA6GgAwIBAgIQQBrEZCGzEyEDDrvkEhrFHTANBgkqhkiG9w0BAQsFADCBvTELMAkGA1UE +BhMCVVMxFzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMR8wHQYDVQQLExZWZXJpU2lnbiBUcnVzdCBO +ZXR3b3JrMTowOAYDVQQLEzEoYykgMjAwOCBWZXJpU2lnbiwgSW5jLiAtIEZvciBhdXRob3JpemVk +IHVzZSBvbmx5MTgwNgYDVQQDEy9WZXJpU2lnbiBVbml2ZXJzYWwgUm9vdCBDZXJ0aWZpY2F0aW9u +IEF1dGhvcml0eTAeFw0wODA0MDIwMDAwMDBaFw0zNzEyMDEyMzU5NTlaMIG9MQswCQYDVQQGEwJV +UzEXMBUGA1UEChMOVmVyaVNpZ24sIEluYy4xHzAdBgNVBAsTFlZlcmlTaWduIFRydXN0IE5ldHdv +cmsxOjA4BgNVBAsTMShjKSAyMDA4IFZlcmlTaWduLCBJbmMuIC0gRm9yIGF1dGhvcml6ZWQgdXNl +IG9ubHkxODA2BgNVBAMTL1ZlcmlTaWduIFVuaXZlcnNhbCBSb290IENlcnRpZmljYXRpb24gQXV0 +aG9yaXR5MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAx2E3XrEBNNti1xWb/1hajCMj +1mCOkdeQmIN65lgZOIzF9uVkhbSicfvtvbnazU0AtMgtc6XHaXGVHzk8skQHnOgO+k1KxCHfKWGP +MiJhgsWHH26MfF8WIFFE0XBPV+rjHOPMee5Y2A7Cs0WTwCznmhcrewA3ekEzeOEz4vMQGn+HLL72 +9fdC4uW/h2KJXwBL38Xd5HVEMkE6HnFuacsLdUYI0crSK5XQz/u5QGtkjFdN/BMReYTtXlT2NJ8I +AfMQJQYXStrxHXpma5hgZqTZ79IugvHw7wnqRMkVauIDbjPTrJ9VAMf2CGqUuV/c4DPxhGD5WycR +tPwW8rtWaoAljQIDAQABo4GyMIGvMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMG0G +CCsGAQUFBwEMBGEwX6FdoFswWTBXMFUWCWltYWdlL2dpZjAhMB8wBwYFKw4DAhoEFI/l0xqGrI2O +a8PPgGrUSBgsexkuMCUWI2h0dHA6Ly9sb2dvLnZlcmlzaWduLmNvbS92c2xvZ28uZ2lmMB0GA1Ud +DgQWBBS2d/ppSEefUxLVwuoHMnYH0ZcHGTANBgkqhkiG9w0BAQsFAAOCAQEASvj4sAPmLGd75JR3 +Y8xuTPl9Dg3cyLk1uXBPY/ok+myDjEedO2Pzmvl2MpWRsXe8rJq+seQxIcaBlVZaDrHC1LGmWazx +Y8u4TB1ZkErvkBYoH1quEPuBUDgMbMzxPcP1Y+Oz4yHJJDnp/RVmRvQbEdBNc6N9Rvk97ahfYtTx +P/jgdFcrGJ2BtMQo2pSXpXDrrB2+BxHw1dvd5Yzw1TKwg+ZX4o+/vqGqvz0dtdQ46tewXDpPaj+P +wGZsY6rp2aQW9IHRlRQOfc2VNNnSj3BzgXucfr2YYdhFh5iQxeuGMMY1v/D/w1WIg0vvBZIGcfK4 +mJO37M2CYfE45k+XmCpajQ== +-----END CERTIFICATE----- + +VeriSign Class 3 Public Primary Certification Authority - G4 +============================================================ +-----BEGIN CERTIFICATE----- +MIIDhDCCAwqgAwIBAgIQL4D+I4wOIg9IZxIokYesszAKBggqhkjOPQQDAzCByjELMAkGA1UEBhMC +VVMxFzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMR8wHQYDVQQLExZWZXJpU2lnbiBUcnVzdCBOZXR3 +b3JrMTowOAYDVQQLEzEoYykgMjAwNyBWZXJpU2lnbiwgSW5jLiAtIEZvciBhdXRob3JpemVkIHVz +ZSBvbmx5MUUwQwYDVQQDEzxWZXJpU2lnbiBDbGFzcyAzIFB1YmxpYyBQcmltYXJ5IENlcnRpZmlj +YXRpb24gQXV0aG9yaXR5IC0gRzQwHhcNMDcxMTA1MDAwMDAwWhcNMzgwMTE4MjM1OTU5WjCByjEL +MAkGA1UEBhMCVVMxFzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMR8wHQYDVQQLExZWZXJpU2lnbiBU +cnVzdCBOZXR3b3JrMTowOAYDVQQLEzEoYykgMjAwNyBWZXJpU2lnbiwgSW5jLiAtIEZvciBhdXRo +b3JpemVkIHVzZSBvbmx5MUUwQwYDVQQDEzxWZXJpU2lnbiBDbGFzcyAzIFB1YmxpYyBQcmltYXJ5 +IENlcnRpZmljYXRpb24gQXV0aG9yaXR5IC0gRzQwdjAQBgcqhkjOPQIBBgUrgQQAIgNiAASnVnp8 +Utpkmw4tXNherJI9/gHmGUo9FANL+mAnINmDiWn6VMaaGF5VKmTeBvaNSjutEDxlPZCIBIngMGGz +rl0Bp3vefLK+ymVhAIau2o970ImtTR1ZmkGxvEeA3J5iw/mjgbIwga8wDwYDVR0TAQH/BAUwAwEB +/zAOBgNVHQ8BAf8EBAMCAQYwbQYIKwYBBQUHAQwEYTBfoV2gWzBZMFcwVRYJaW1hZ2UvZ2lmMCEw +HzAHBgUrDgMCGgQUj+XTGoasjY5rw8+AatRIGCx7GS4wJRYjaHR0cDovL2xvZ28udmVyaXNpZ24u +Y29tL3ZzbG9nby5naWYwHQYDVR0OBBYEFLMWkf3upm7ktS5Jj4d4gYDs5bG1MAoGCCqGSM49BAMD +A2gAMGUCMGYhDBgmYFo4e1ZC4Kf8NoRRkSAsdk1DPcQdhCPQrNZ8NQbOzWm9kA3bbEhCHQ6qQgIx +AJw9SDkjOVgaFRJZap7v1VmyHVIsmXHNxynfGyphe3HR3vPA5Q06Sqotp9iGKt0uEA== +-----END CERTIFICATE----- + +NetLock Arany (Class Gold) Főtanúsítvány +============================================ +-----BEGIN CERTIFICATE----- +MIIEFTCCAv2gAwIBAgIGSUEs5AAQMA0GCSqGSIb3DQEBCwUAMIGnMQswCQYDVQQGEwJIVTERMA8G +A1UEBwwIQnVkYXBlc3QxFTATBgNVBAoMDE5ldExvY2sgS2Z0LjE3MDUGA1UECwwuVGFuw7pzw610 +dsOhbnlraWFkw7NrIChDZXJ0aWZpY2F0aW9uIFNlcnZpY2VzKTE1MDMGA1UEAwwsTmV0TG9jayBB +cmFueSAoQ2xhc3MgR29sZCkgRsWRdGFuw7pzw610dsOhbnkwHhcNMDgxMjExMTUwODIxWhcNMjgx +MjA2MTUwODIxWjCBpzELMAkGA1UEBhMCSFUxETAPBgNVBAcMCEJ1ZGFwZXN0MRUwEwYDVQQKDAxO +ZXRMb2NrIEtmdC4xNzA1BgNVBAsMLlRhbsO6c8OtdHbDoW55a2lhZMOzayAoQ2VydGlmaWNhdGlv +biBTZXJ2aWNlcykxNTAzBgNVBAMMLE5ldExvY2sgQXJhbnkgKENsYXNzIEdvbGQpIEbFkXRhbsO6 +c8OtdHbDoW55MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAxCRec75LbRTDofTjl5Bu +0jBFHjzuZ9lk4BqKf8owyoPjIMHj9DrTlF8afFttvzBPhCf2nx9JvMaZCpDyD/V/Q4Q3Y1GLeqVw +/HpYzY6b7cNGbIRwXdrzAZAj/E4wqX7hJ2Pn7WQ8oLjJM2P+FpD/sLj916jAwJRDC7bVWaaeVtAk +H3B5r9s5VA1lddkVQZQBr17s9o3x/61k/iCa11zr/qYfCGSji3ZVrR47KGAuhyXoqq8fxmRGILdw +fzzeSNuWU7c5d+Qa4scWhHaXWy+7GRWF+GmF9ZmnqfI0p6m2pgP8b4Y9VHx2BJtr+UBdADTHLpl1 +neWIA6pN+APSQnbAGwIDAKiLo0UwQzASBgNVHRMBAf8ECDAGAQH/AgEEMA4GA1UdDwEB/wQEAwIB +BjAdBgNVHQ4EFgQUzPpnk/C2uNClwB7zU/2MU9+D15YwDQYJKoZIhvcNAQELBQADggEBAKt/7hwW +qZw8UQCgwBEIBaeZ5m8BiFRhbvG5GK1Krf6BQCOUL/t1fC8oS2IkgYIL9WHxHG64YTjrgfpioTta +YtOUZcTh5m2C+C8lcLIhJsFyUR+MLMOEkMNaj7rP9KdlpeuY0fsFskZ1FSNqb4VjMIDw1Z4fKRzC +bLBQWV2QWzuoDTDPv31/zvGdg73JRm4gpvlhUbohL3u+pRVjodSVh/GeufOJ8z2FuLjbvrW5Kfna +NwUASZQDhETnv0Mxz3WLJdH0pmT1kvarBes96aULNmLazAZfNou2XjG4Kvte9nHfRCaexOYNkbQu +dZWAUWpLMKawYqGT8ZvYzsRjdT9ZR7E= +-----END CERTIFICATE----- + +Staat der Nederlanden Root CA - G2 +================================== +-----BEGIN CERTIFICATE----- +MIIFyjCCA7KgAwIBAgIEAJiWjDANBgkqhkiG9w0BAQsFADBaMQswCQYDVQQGEwJOTDEeMBwGA1UE +CgwVU3RhYXQgZGVyIE5lZGVybGFuZGVuMSswKQYDVQQDDCJTdGFhdCBkZXIgTmVkZXJsYW5kZW4g +Um9vdCBDQSAtIEcyMB4XDTA4MDMyNjExMTgxN1oXDTIwMDMyNTExMDMxMFowWjELMAkGA1UEBhMC +TkwxHjAcBgNVBAoMFVN0YWF0IGRlciBOZWRlcmxhbmRlbjErMCkGA1UEAwwiU3RhYXQgZGVyIE5l +ZGVybGFuZGVuIFJvb3QgQ0EgLSBHMjCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAMVZ +5291qj5LnLW4rJ4L5PnZyqtdj7U5EILXr1HgO+EASGrP2uEGQxGZqhQlEq0i6ABtQ8SpuOUfiUtn +vWFI7/3S4GCI5bkYYCjDdyutsDeqN95kWSpGV+RLufg3fNU254DBtvPUZ5uW6M7XxgpT0GtJlvOj +CwV3SPcl5XCsMBQgJeN/dVrlSPhOewMHBPqCYYdu8DvEpMfQ9XQ+pV0aCPKbJdL2rAQmPlU6Yiil +e7Iwr/g3wtG61jj99O9JMDeZJiFIhQGp5Rbn3JBV3w/oOM2ZNyFPXfUib2rFEhZgF1XyZWampzCR +OME4HYYEhLoaJXhena/MUGDWE4dS7WMfbWV9whUYdMrhfmQpjHLYFhN9C0lK8SgbIHRrxT3dsKpI +CT0ugpTNGmXZK4iambwYfp/ufWZ8Pr2UuIHOzZgweMFvZ9C+X+Bo7d7iscksWXiSqt8rYGPy5V65 +48r6f1CGPqI0GAwJaCgRHOThuVw+R7oyPxjMW4T182t0xHJ04eOLoEq9jWYv6q012iDTiIJh8BIi +trzQ1aTsr1SIJSQ8p22xcik/Plemf1WvbibG/ufMQFxRRIEKeN5KzlW/HdXZt1bv8Hb/C3m1r737 +qWmRRpdogBQ2HbN/uymYNqUg+oJgYjOk7Na6B6duxc8UpufWkjTYgfX8HV2qXB72o007uPc5AgMB +AAGjgZcwgZQwDwYDVR0TAQH/BAUwAwEB/zBSBgNVHSAESzBJMEcGBFUdIAAwPzA9BggrBgEFBQcC +ARYxaHR0cDovL3d3dy5wa2lvdmVyaGVpZC5ubC9wb2xpY2llcy9yb290LXBvbGljeS1HMjAOBgNV +HQ8BAf8EBAMCAQYwHQYDVR0OBBYEFJFoMocVHYnitfGsNig0jQt8YojrMA0GCSqGSIb3DQEBCwUA +A4ICAQCoQUpnKpKBglBu4dfYszk78wIVCVBR7y29JHuIhjv5tLySCZa59sCrI2AGeYwRTlHSeYAz ++51IvuxBQ4EffkdAHOV6CMqqi3WtFMTC6GY8ggen5ieCWxjmD27ZUD6KQhgpxrRW/FYQoAUXvQwj +f/ST7ZwaUb7dRUG/kSS0H4zpX897IZmflZ85OkYcbPnNe5yQzSipx6lVu6xiNGI1E0sUOlWDuYaN +kqbG9AclVMwWVxJKgnjIFNkXgiYtXSAfea7+1HAWFpWD2DU5/1JddRwWxRNVz0fMdWVSSt7wsKfk +CpYL+63C4iWEst3kvX5ZbJvw8NjnyvLplzh+ib7M+zkXYT9y2zqR2GUBGR2tUKRXCnxLvJxxcypF +URmFzI79R6d0lR2o0a9OF7FpJsKqeFdbxU2n5Z4FF5TKsl+gSRiNNOkmbEgeqmiSBeGCc1qb3Adb +CG19ndeNIdn8FCCqwkXfP+cAslHkwvgFuXkajDTznlvkN1trSt8sV4pAWja63XVECDdCcAz+3F4h +oKOKwJCcaNpQ5kUQR3i2TtJlycM33+FCY7BXN0Ute4qcvwXqZVUz9zkQxSgqIXobisQk+T8VyJoV +IPVVYpbtbZNQvOSqeK3Zywplh6ZmwcSBo3c6WB4L7oOLnR7SUqTMHW+wmG2UMbX4cQrcufx9MmDm +66+KAQ== +-----END CERTIFICATE----- + +CA Disig +======== +-----BEGIN CERTIFICATE----- +MIIEDzCCAvegAwIBAgIBATANBgkqhkiG9w0BAQUFADBKMQswCQYDVQQGEwJTSzETMBEGA1UEBxMK +QnJhdGlzbGF2YTETMBEGA1UEChMKRGlzaWcgYS5zLjERMA8GA1UEAxMIQ0EgRGlzaWcwHhcNMDYw +MzIyMDEzOTM0WhcNMTYwMzIyMDEzOTM0WjBKMQswCQYDVQQGEwJTSzETMBEGA1UEBxMKQnJhdGlz +bGF2YTETMBEGA1UEChMKRGlzaWcgYS5zLjERMA8GA1UEAxMIQ0EgRGlzaWcwggEiMA0GCSqGSIb3 +DQEBAQUAA4IBDwAwggEKAoIBAQCS9jHBfYj9mQGp2HvycXXxMcbzdWb6UShGhJd4NLxs/LxFWYgm +GErENx+hSkS943EE9UQX4j/8SFhvXJ56CbpRNyIjZkMhsDxkovhqFQ4/61HhVKndBpnXmjxUizkD +Pw/Fzsbrg3ICqB9x8y34dQjbYkzo+s7552oftms1grrijxaSfQUMbEYDXcDtab86wYqg6I7ZuUUo +hwjstMoVvoLdtUSLLa2GDGhibYVW8qwUYzrG0ZmsNHhWS8+2rT+MitcE5eN4TPWGqvWP+j1scaMt +ymfraHtuM6kMgiioTGohQBUgDCZbg8KpFhXAJIJdKxatymP2dACw30PEEGBWZ2NFAgMBAAGjgf8w +gfwwDwYDVR0TAQH/BAUwAwEB/zAdBgNVHQ4EFgQUjbJJaJ1yCCW5wCf1UJNWSEZx+Y8wDgYDVR0P +AQH/BAQDAgEGMDYGA1UdEQQvMC2BE2Nhb3BlcmF0b3JAZGlzaWcuc2uGFmh0dHA6Ly93d3cuZGlz +aWcuc2svY2EwZgYDVR0fBF8wXTAtoCugKYYnaHR0cDovL3d3dy5kaXNpZy5zay9jYS9jcmwvY2Ff +ZGlzaWcuY3JsMCygKqAohiZodHRwOi8vY2EuZGlzaWcuc2svY2EvY3JsL2NhX2Rpc2lnLmNybDAa +BgNVHSAEEzARMA8GDSuBHpGT5goAAAABAQEwDQYJKoZIhvcNAQEFBQADggEBAF00dGFMrzvY/59t +WDYcPQuBDRIrRhCA/ec8J9B6yKm2fnQwM6M6int0wHl5QpNt/7EpFIKrIYwvF/k/Ji/1WcbvgAa3 +mkkp7M5+cTxqEEHA9tOasnxakZzArFvITV734VP/Q3f8nktnbNfzg9Gg4H8l37iYC5oyOGwwoPP/ +CBUz91BKez6jPiCp3C9WgArtQVCwyfTssuMmRAAOb54GvCKWU3BlxFAKRmukLyeBEicTXxChds6K +ezfqwzlhA5WYOudsiCUI/HloDYd9Yvi0X/vF2Ey9WLw/Q1vUHgFNPGO+I++MzVpQuGhU+QqZMxEA +4Z7CRneC9VkGjCFMhwnN5ag= +-----END CERTIFICATE----- + +Juur-SK +======= +-----BEGIN CERTIFICATE----- +MIIE5jCCA86gAwIBAgIEO45L/DANBgkqhkiG9w0BAQUFADBdMRgwFgYJKoZIhvcNAQkBFglwa2lA +c2suZWUxCzAJBgNVBAYTAkVFMSIwIAYDVQQKExlBUyBTZXJ0aWZpdHNlZXJpbWlza2Vza3VzMRAw +DgYDVQQDEwdKdXVyLVNLMB4XDTAxMDgzMDE0MjMwMVoXDTE2MDgyNjE0MjMwMVowXTEYMBYGCSqG +SIb3DQEJARYJcGtpQHNrLmVlMQswCQYDVQQGEwJFRTEiMCAGA1UEChMZQVMgU2VydGlmaXRzZWVy +aW1pc2tlc2t1czEQMA4GA1UEAxMHSnV1ci1TSzCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoC +ggEBAIFxNj4zB9bjMI0TfncyRsvPGbJgMUaXhvSYRqTCZUXP00B841oiqBB4M8yIsdOBSvZiF3tf +TQou0M+LI+5PAk676w7KvRhj6IAcjeEcjT3g/1tf6mTll+g/mX8MCgkzABpTpyHhOEvWgxutr2TC ++Rx6jGZITWYfGAriPrsfB2WThbkasLnE+w0R9vXW+RvHLCu3GFH+4Hv2qEivbDtPL+/40UceJlfw +UR0zlv/vWT3aTdEVNMfqPxZIe5EcgEMPPbgFPtGzlc3Yyg/CQ2fbt5PgIoIuvvVoKIO5wTtpeyDa +Tpxt4brNj3pssAki14sL2xzVWiZbDcDq5WDQn/413z8CAwEAAaOCAawwggGoMA8GA1UdEwEB/wQF +MAMBAf8wggEWBgNVHSAEggENMIIBCTCCAQUGCisGAQQBzh8BAQEwgfYwgdAGCCsGAQUFBwICMIHD +HoHAAFMAZQBlACAAcwBlAHIAdABpAGYAaQBrAGEAYQB0ACAAbwBuACAAdgDkAGwAagBhAHMAdABh +AHQAdQBkACAAQQBTAC0AaQBzACAAUwBlAHIAdABpAGYAaQB0AHMAZQBlAHIAaQBtAGkAcwBrAGUA +cwBrAHUAcwAgAGEAbABhAG0ALQBTAEsAIABzAGUAcgB0AGkAZgBpAGsAYQBhAHQAaQBkAGUAIABr +AGkAbgBuAGkAdABhAG0AaQBzAGUAawBzMCEGCCsGAQUFBwIBFhVodHRwOi8vd3d3LnNrLmVlL2Nw +cy8wKwYDVR0fBCQwIjAgoB6gHIYaaHR0cDovL3d3dy5zay5lZS9qdXVyL2NybC8wHQYDVR0OBBYE +FASqekej5ImvGs8KQKcYP2/v6X2+MB8GA1UdIwQYMBaAFASqekej5ImvGs8KQKcYP2/v6X2+MA4G +A1UdDwEB/wQEAwIB5jANBgkqhkiG9w0BAQUFAAOCAQEAe8EYlFOiCfP+JmeaUOTDBS8rNXiRTHyo +ERF5TElZrMj3hWVcRrs7EKACr81Ptcw2Kuxd/u+gkcm2k298gFTsxwhwDY77guwqYHhpNjbRxZyL +abVAyJRld/JXIWY7zoVAtjNjGr95HvxcHdMdkxuLDF2FvZkwMhgJkVLpfKG6/2SSmuz+Ne6ML678 +IIbsSt4beDI3poHSna9aEhbKmVv8b20OxaAehsmR0FyYgl9jDIpaq9iVpszLita/ZEuOyoqysOkh +Mp6qqIWYNIE5ITuoOlIyPfZrN4YGWhWY3PARZv40ILcD9EEQfTmEeZZyY7aWAuVrua0ZTbvGRNs2 +yyqcjg== +-----END CERTIFICATE----- + +Hongkong Post Root CA 1 +======================= +-----BEGIN CERTIFICATE----- +MIIDMDCCAhigAwIBAgICA+gwDQYJKoZIhvcNAQEFBQAwRzELMAkGA1UEBhMCSEsxFjAUBgNVBAoT +DUhvbmdrb25nIFBvc3QxIDAeBgNVBAMTF0hvbmdrb25nIFBvc3QgUm9vdCBDQSAxMB4XDTAzMDUx +NTA1MTMxNFoXDTIzMDUxNTA0NTIyOVowRzELMAkGA1UEBhMCSEsxFjAUBgNVBAoTDUhvbmdrb25n +IFBvc3QxIDAeBgNVBAMTF0hvbmdrb25nIFBvc3QgUm9vdCBDQSAxMIIBIjANBgkqhkiG9w0BAQEF +AAOCAQ8AMIIBCgKCAQEArP84tulmAknjorThkPlAj3n54r15/gK97iSSHSL22oVyaf7XPwnU3ZG1 +ApzQjVrhVcNQhrkpJsLj2aDxaQMoIIBFIi1WpztUlVYiWR8o3x8gPW2iNr4joLFutbEnPzlTCeqr +auh0ssJlXI6/fMN4hM2eFvz1Lk8gKgifd/PFHsSaUmYeSF7jEAaPIpjhZY4bXSNmO7ilMlHIhqqh +qZ5/dpTCpmy3QfDVyAY45tQM4vM7TG1QjMSDJ8EThFk9nnV0ttgCXjqQesBCNnLsak3c78QA3xMY +V18meMjWCnl3v/evt3a5pQuEF10Q6m/hq5URX208o1xNg1vysxmKgIsLhwIDAQABoyYwJDASBgNV +HRMBAf8ECDAGAQH/AgEDMA4GA1UdDwEB/wQEAwIBxjANBgkqhkiG9w0BAQUFAAOCAQEADkbVPK7i +h9legYsCmEEIjEy82tvuJxuC52pF7BaLT4Wg87JwvVqWuspube5Gi27nKi6Wsxkz67SfqLI37pio +l7Yutmcn1KZJ/RyTZXaeQi/cImyaT/JaFTmxcdcrUehtHJjA2Sr0oYJ71clBoiMBdDhViw+5Lmei +IAQ32pwL0xch4I+XeTRvhEgCIDMb5jREn5Fw9IBehEPCKdJsEhTkYY2sEJCehFC78JZvRZ+K88ps +T/oROhUVRsPNH4NbLUES7VBnQRM9IauUiqpOfMGx+6fWtScvl6tu4B3i0RwsH0Ti/L6RoZz71ilT +c4afU9hDDl3WY4JxHYB0yvbiAmvZWg== +-----END CERTIFICATE----- + +SecureSign RootCA11 +=================== +-----BEGIN CERTIFICATE----- +MIIDbTCCAlWgAwIBAgIBATANBgkqhkiG9w0BAQUFADBYMQswCQYDVQQGEwJKUDErMCkGA1UEChMi +SmFwYW4gQ2VydGlmaWNhdGlvbiBTZXJ2aWNlcywgSW5jLjEcMBoGA1UEAxMTU2VjdXJlU2lnbiBS +b290Q0ExMTAeFw0wOTA0MDgwNDU2NDdaFw0yOTA0MDgwNDU2NDdaMFgxCzAJBgNVBAYTAkpQMSsw +KQYDVQQKEyJKYXBhbiBDZXJ0aWZpY2F0aW9uIFNlcnZpY2VzLCBJbmMuMRwwGgYDVQQDExNTZWN1 +cmVTaWduIFJvb3RDQTExMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA/XeqpRyQBTvL +TJszi1oURaTnkBbR31fSIRCkF/3frNYfp+TbfPfs37gD2pRY/V1yfIw/XwFndBWW4wI8h9uuywGO +wvNmxoVF9ALGOrVisq/6nL+k5tSAMJjzDbaTj6nU2DbysPyKyiyhFTOVMdrAG/LuYpmGYz+/3ZMq +g6h2uRMft85OQoWPIucuGvKVCbIFtUROd6EgvanyTgp9UK31BQ1FT0Zx/Sg+U/sE2C3XZR1KG/rP +O7AxmjVuyIsG0wCR8pQIZUyxNAYAeoni8McDWc/V1uinMrPmmECGxc0nEovMe863ETxiYAcjPitA +bpSACW22s293bzUIUPsCh8U+iQIDAQABo0IwQDAdBgNVHQ4EFgQUW/hNT7KlhtQ60vFjmqC+CfZX +t94wDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wDQYJKoZIhvcNAQEFBQADggEBAKCh +OBZmLqdWHyGcBvod7bkixTgm2E5P7KN/ed5GIaGHd48HCJqypMWvDzKYC3xmKbabfSVSSUOrTC4r +bnpwrxYO4wJs+0LmGJ1F2FXI6Dvd5+H0LgscNFxsWEr7jIhQX5Ucv+2rIrVls4W6ng+4reV6G4pQ +Oh29Dbx7VFALuUKvVaAYga1lme++5Jy/xIWrQbJUb9wlze144o4MjQlJ3WN7WmmWAiGovVJZ6X01 +y8hSyn+B/tlr0/cR7SXf+Of5pPpyl4RTDaXQMhhRdlkUbA/r7F+AjHVDg8OFmP9Mni0N5HeDk061 +lgeLKBObjBmNQSdJQO7e5iNEOdyhIta6A/I= +-----END CERTIFICATE----- + +ACEDICOM Root +============= +-----BEGIN CERTIFICATE----- +MIIFtTCCA52gAwIBAgIIYY3HhjsBggUwDQYJKoZIhvcNAQEFBQAwRDEWMBQGA1UEAwwNQUNFRElD +T00gUm9vdDEMMAoGA1UECwwDUEtJMQ8wDQYDVQQKDAZFRElDT00xCzAJBgNVBAYTAkVTMB4XDTA4 +MDQxODE2MjQyMloXDTI4MDQxMzE2MjQyMlowRDEWMBQGA1UEAwwNQUNFRElDT00gUm9vdDEMMAoG +A1UECwwDUEtJMQ8wDQYDVQQKDAZFRElDT00xCzAJBgNVBAYTAkVTMIICIjANBgkqhkiG9w0BAQEF +AAOCAg8AMIICCgKCAgEA/5KV4WgGdrQsyFhIyv2AVClVYyT/kGWbEHV7w2rbYgIB8hiGtXxaOLHk +WLn709gtn70yN78sFW2+tfQh0hOR2QetAQXW8713zl9CgQr5auODAKgrLlUTY4HKRxx7XBZXehuD +YAQ6PmXDzQHe3qTWDLqO3tkE7hdWIpuPY/1NFgu3e3eM+SW10W2ZEi5PGrjm6gSSrj0RuVFCPYew +MYWveVqc/udOXpJPQ/yrOq2lEiZmueIM15jO1FillUAKt0SdE3QrwqXrIhWYENiLxQSfHY9g5QYb +m8+5eaA9oiM/Qj9r+hwDezCNzmzAv+YbX79nuIQZ1RXve8uQNjFiybwCq0Zfm/4aaJQ0PZCOrfbk +HQl/Sog4P75n/TSW9R28MHTLOO7VbKvU/PQAtwBbhTIWdjPp2KOZnQUAqhbm84F9b32qhm2tFXTT +xKJxqvQUfecyuB+81fFOvW8XAjnXDpVCOscAPukmYxHqC9FK/xidstd7LzrZlvvoHpKuE1XI2Sf2 +3EgbsCTBheN3nZqk8wwRHQ3ItBTutYJXCb8gWH8vIiPYcMt5bMlL8qkqyPyHK9caUPgn6C9D4zq9 +2Fdx/c6mUlv53U3t5fZvie27k5x2IXXwkkwp9y+cAS7+UEaeZAwUswdbxcJzbPEHXEUkFDWug/Fq +TYl6+rPYLWbwNof1K1MCAwEAAaOBqjCBpzAPBgNVHRMBAf8EBTADAQH/MB8GA1UdIwQYMBaAFKaz +4SsrSbbXc6GqlPUB53NlTKxQMA4GA1UdDwEB/wQEAwIBhjAdBgNVHQ4EFgQUprPhKytJttdzoaqU +9QHnc2VMrFAwRAYDVR0gBD0wOzA5BgRVHSAAMDEwLwYIKwYBBQUHAgEWI2h0dHA6Ly9hY2VkaWNv +bS5lZGljb21ncm91cC5jb20vZG9jMA0GCSqGSIb3DQEBBQUAA4ICAQDOLAtSUWImfQwng4/F9tqg +aHtPkl7qpHMyEVNEskTLnewPeUKzEKbHDZ3Ltvo/Onzqv4hTGzz3gvoFNTPhNahXwOf9jU8/kzJP +eGYDdwdY6ZXIfj7QeQCM8htRM5u8lOk6e25SLTKeI6RF+7YuE7CLGLHdztUdp0J/Vb77W7tH1Pwk +zQSulgUV1qzOMPPKC8W64iLgpq0i5ALudBF/TP94HTXa5gI06xgSYXcGCRZj6hitoocf8seACQl1 +ThCojz2GuHURwCRiipZ7SkXp7FnFvmuD5uHorLUwHv4FB4D54SMNUI8FmP8sX+g7tq3PgbUhh8oI +KiMnMCArz+2UW6yyetLHKKGKC5tNSixthT8Jcjxn4tncB7rrZXtaAWPWkFtPF2Y9fwsZo5NjEFIq +nxQWWOLcpfShFosOkYuByptZ+thrkQdlVV9SH686+5DdaaVbnG0OLLb6zqylfDJKZ0DcMDQj3dcE +I2bw/FWAp/tmGYI1Z2JwOV5vx+qQQEQIHriy1tvuWacNGHk0vFQYXlPKNFHtRQrmjseCNj6nOGOp +MCwXEGCSn1WHElkQwg9naRHMTh5+Spqtr0CodaxWkHS4oJyleW/c6RrIaQXpuvoDs3zk4E7Czp3o +tkYNbn5XOmeUwssfnHdKZ05phkOTOPu220+DkdRgfks+KzgHVZhepA== +-----END CERTIFICATE----- + +Verisign Class 3 Public Primary Certification Authority +======================================================= +-----BEGIN CERTIFICATE----- +MIICPDCCAaUCEDyRMcsf9tAbDpq40ES/Er4wDQYJKoZIhvcNAQEFBQAwXzELMAkGA1UEBhMCVVMx +FzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMTcwNQYDVQQLEy5DbGFzcyAzIFB1YmxpYyBQcmltYXJ5 +IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MB4XDTk2MDEyOTAwMDAwMFoXDTI4MDgwMjIzNTk1OVow +XzELMAkGA1UEBhMCVVMxFzAVBgNVBAoTDlZlcmlTaWduLCBJbmMuMTcwNQYDVQQLEy5DbGFzcyAz +IFB1YmxpYyBQcmltYXJ5IENlcnRpZmljYXRpb24gQXV0aG9yaXR5MIGfMA0GCSqGSIb3DQEBAQUA +A4GNADCBiQKBgQDJXFme8huKARS0EN8EQNvjV69qRUCPhAwL0TPZ2RHP7gJYHyX3KqhEBarsAx94 +f56TuZoAqiN91qyFomNFx3InzPRMxnVx0jnvT0Lwdd8KkMaOIG+YD/isI19wKTakyYbnsZogy1Ol +hec9vn2a/iRFM9x2Fe0PonFkTGUugWhFpwIDAQABMA0GCSqGSIb3DQEBBQUAA4GBABByUqkFFBky +CEHwxWsKzH4PIRnN5GfcX6kb5sroc50i2JhucwNhkcV8sEVAbkSdjbCxlnRhLQ2pRdKkkirWmnWX +bj9T/UWZYB2oK0z5XqcJ2HUw19JlYD1n1khVdWk/kfVIC0dpImmClr7JyDiGSnoscxlIaU5rfGW/ +D/xwzoiQ +-----END CERTIFICATE----- + +Microsec e-Szigno Root CA 2009 +============================== +-----BEGIN CERTIFICATE----- +MIIECjCCAvKgAwIBAgIJAMJ+QwRORz8ZMA0GCSqGSIb3DQEBCwUAMIGCMQswCQYDVQQGEwJIVTER +MA8GA1UEBwwIQnVkYXBlc3QxFjAUBgNVBAoMDU1pY3Jvc2VjIEx0ZC4xJzAlBgNVBAMMHk1pY3Jv +c2VjIGUtU3ppZ25vIFJvb3QgQ0EgMjAwOTEfMB0GCSqGSIb3DQEJARYQaW5mb0BlLXN6aWduby5o +dTAeFw0wOTA2MTYxMTMwMThaFw0yOTEyMzAxMTMwMThaMIGCMQswCQYDVQQGEwJIVTERMA8GA1UE +BwwIQnVkYXBlc3QxFjAUBgNVBAoMDU1pY3Jvc2VjIEx0ZC4xJzAlBgNVBAMMHk1pY3Jvc2VjIGUt +U3ppZ25vIFJvb3QgQ0EgMjAwOTEfMB0GCSqGSIb3DQEJARYQaW5mb0BlLXN6aWduby5odTCCASIw +DQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAOn4j/NjrdqG2KfgQvvPkd6mJviZpWNwrZuuyjNA +fW2WbqEORO7hE52UQlKavXWFdCyoDh2Tthi3jCyoz/tccbna7P7ofo/kLx2yqHWH2Leh5TvPmUpG +0IMZfcChEhyVbUr02MelTTMuhTlAdX4UfIASmFDHQWe4oIBhVKZsTh/gnQ4H6cm6M+f+wFUoLAKA +pxn1ntxVUwOXewdI/5n7N4okxFnMUBBjjqqpGrCEGob5X7uxUG6k0QrM1XF+H6cbfPVTbiJfyyvm +1HxdrtbCxkzlBQHZ7Vf8wSN5/PrIJIOV87VqUQHQd9bpEqH5GoP7ghu5sJf0dgYzQ0mg/wu1+rUC +AwEAAaOBgDB+MA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBTLD8bf +QkPMPcu1SCOhGnqmKrs0aDAfBgNVHSMEGDAWgBTLD8bfQkPMPcu1SCOhGnqmKrs0aDAbBgNVHREE +FDASgRBpbmZvQGUtc3ppZ25vLmh1MA0GCSqGSIb3DQEBCwUAA4IBAQDJ0Q5eLtXMs3w+y/w9/w0o +lZMEyL/azXm4Q5DwpL7v8u8hmLzU1F0G9u5C7DBsoKqpyvGvivo/C3NqPuouQH4frlRheesuCDfX +I/OMn74dseGkddug4lQUsbocKaQY9hK6ohQU4zE1yED/t+AFdlfBHFny+L/k7SViXITwfn4fs775 +tyERzAMBVnCnEJIeGzSBHq2cGsMEPO0CYdYeBvNfOofyK/FFh+U9rNHHV4S9a67c2Pm2G2JwCz02 +yULyMtd6YebS2z3PyKnJm9zbWETXbzivf3jTo60adbocwTZ8jx5tHMN1Rq41Bab2XD0h7lbwyYIi +LXpUq3DDfSJlgnCW +-----END CERTIFICATE----- + +E-Guven Kok Elektronik Sertifika Hizmet Saglayicisi +=================================================== +-----BEGIN CERTIFICATE----- +MIIDtjCCAp6gAwIBAgIQRJmNPMADJ72cdpW56tustTANBgkqhkiG9w0BAQUFADB1MQswCQYDVQQG +EwJUUjEoMCYGA1UEChMfRWxla3Ryb25payBCaWxnaSBHdXZlbmxpZ2kgQS5TLjE8MDoGA1UEAxMz +ZS1HdXZlbiBLb2sgRWxla3Ryb25payBTZXJ0aWZpa2EgSGl6bWV0IFNhZ2xheWljaXNpMB4XDTA3 +MDEwNDExMzI0OFoXDTE3MDEwNDExMzI0OFowdTELMAkGA1UEBhMCVFIxKDAmBgNVBAoTH0VsZWt0 +cm9uaWsgQmlsZ2kgR3V2ZW5saWdpIEEuUy4xPDA6BgNVBAMTM2UtR3V2ZW4gS29rIEVsZWt0cm9u +aWsgU2VydGlmaWthIEhpem1ldCBTYWdsYXlpY2lzaTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCC +AQoCggEBAMMSIJ6wXgBljU5Gu4Bc6SwGl9XzcslwuedLZYDBS75+PNdUMZTe1RK6UxYC6lhj71vY +8+0qGqpxSKPcEC1fX+tcS5yWCEIlKBHMilpiAVDV6wlTL/jDj/6z/P2douNffb7tC+Bg62nsM+3Y +jfsSSYMAyYuXjDtzKjKzEve5TfL0TW3H5tYmNwjy2f1rXKPlSFxYvEK+A1qBuhw1DADT9SN+cTAI +JjjcJRFHLfO6IxClv7wC90Nex/6wN1CZew+TzuZDLMN+DfIcQ2Zgy2ExR4ejT669VmxMvLz4Bcpk +9Ok0oSy1c+HCPujIyTQlCFzz7abHlJ+tiEMl1+E5YP6sOVkCAwEAAaNCMEAwDgYDVR0PAQH/BAQD +AgEGMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYEFJ/uRLOU1fqRTy7ZVZoEVtstxNulMA0GCSqG +SIb3DQEBBQUAA4IBAQB/X7lTW2M9dTLn+sR0GstG30ZpHFLPqk/CaOv/gKlR6D1id4k9CnU58W5d +F4dvaAXBlGzZXd/aslnLpRCKysw5zZ/rTt5S/wzw9JKp8mxTq5vSR6AfdPebmvEvFZ96ZDAYBzwq +D2fK/A+JYZ1lpTzlvBNbCNvj/+27BrtqBrF6T2XGgv0enIu1De5Iu7i9qgi0+6N8y5/NkHZchpZ4 +Vwpm+Vganf2XKWDeEaaQHBkc7gGWIjQ0LpH5t8Qn0Xvmv/uARFoW5evg1Ao4vOSR49XrXMGs3xtq +fJ7lddK2l4fbzIcrQzqECK+rPNv3PGYxhrCdU3nt+CPeQuMtgvEP5fqX +-----END CERTIFICATE----- + +GlobalSign Root CA - R3 +======================= +-----BEGIN CERTIFICATE----- +MIIDXzCCAkegAwIBAgILBAAAAAABIVhTCKIwDQYJKoZIhvcNAQELBQAwTDEgMB4GA1UECxMXR2xv +YmFsU2lnbiBSb290IENBIC0gUjMxEzARBgNVBAoTCkdsb2JhbFNpZ24xEzARBgNVBAMTCkdsb2Jh +bFNpZ24wHhcNMDkwMzE4MTAwMDAwWhcNMjkwMzE4MTAwMDAwWjBMMSAwHgYDVQQLExdHbG9iYWxT +aWduIFJvb3QgQ0EgLSBSMzETMBEGA1UEChMKR2xvYmFsU2lnbjETMBEGA1UEAxMKR2xvYmFsU2ln +bjCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAMwldpB5BngiFvXAg7aEyiie/QV2EcWt +iHL8RgJDx7KKnQRfJMsuS+FggkbhUqsMgUdwbN1k0ev1LKMPgj0MK66X17YUhhB5uzsTgHeMCOFJ +0mpiLx9e+pZo34knlTifBtc+ycsmWQ1z3rDI6SYOgxXG71uL0gRgykmmKPZpO/bLyCiR5Z2KYVc3 +rHQU3HTgOu5yLy6c+9C7v/U9AOEGM+iCK65TpjoWc4zdQQ4gOsC0p6Hpsk+QLjJg6VfLuQSSaGjl +OCZgdbKfd/+RFO+uIEn8rUAVSNECMWEZXriX7613t2Saer9fwRPvm2L7DWzgVGkWqQPabumDk3F2 +xmmFghcCAwEAAaNCMEAwDgYDVR0PAQH/BAQDAgEGMA8GA1UdEwEB/wQFMAMBAf8wHQYDVR0OBBYE +FI/wS3+oLkUkrk1Q+mOai97i3Ru8MA0GCSqGSIb3DQEBCwUAA4IBAQBLQNvAUKr+yAzv95ZURUm7 +lgAJQayzE4aGKAczymvmdLm6AC2upArT9fHxD4q/c2dKg8dEe3jgr25sbwMpjjM5RcOO5LlXbKr8 +EpbsU8Yt5CRsuZRj+9xTaGdWPoO4zzUhw8lo/s7awlOqzJCK6fBdRoyV3XpYKBovHd7NADdBj+1E +bddTKJd+82cEHhXXipa0095MJ6RMG3NzdvQXmcIfeg7jLQitChws/zyrVQ4PkX4268NXSb7hLi18 +YIvDQVETI53O9zJrlAGomecsMx86OyXShkDOOyyGeMlhLxS67ttVb9+E7gUJTb0o2HLO02JQZR7r +kpeDMdmztcpHWD9f +-----END CERTIFICATE----- + +Autoridad de Certificacion Firmaprofesional CIF A62634068 +========================================================= +-----BEGIN CERTIFICATE----- +MIIGFDCCA/ygAwIBAgIIU+w77vuySF8wDQYJKoZIhvcNAQEFBQAwUTELMAkGA1UEBhMCRVMxQjBA +BgNVBAMMOUF1dG9yaWRhZCBkZSBDZXJ0aWZpY2FjaW9uIEZpcm1hcHJvZmVzaW9uYWwgQ0lGIEE2 +MjYzNDA2ODAeFw0wOTA1MjAwODM4MTVaFw0zMDEyMzEwODM4MTVaMFExCzAJBgNVBAYTAkVTMUIw +QAYDVQQDDDlBdXRvcmlkYWQgZGUgQ2VydGlmaWNhY2lvbiBGaXJtYXByb2Zlc2lvbmFsIENJRiBB +NjI2MzQwNjgwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDKlmuO6vj78aI14H9M2uDD +Utd9thDIAl6zQyrET2qyyhxdKJp4ERppWVevtSBC5IsP5t9bpgOSL/UR5GLXMnE42QQMcas9UX4P +B99jBVzpv5RvwSmCwLTaUbDBPLutN0pcyvFLNg4kq7/DhHf9qFD0sefGL9ItWY16Ck6WaVICqjaY +7Pz6FIMMNx/Jkjd/14Et5cS54D40/mf0PmbR0/RAz15iNA9wBj4gGFrO93IbJWyTdBSTo3OxDqqH +ECNZXyAFGUftaI6SEspd/NYrspI8IM/hX68gvqB2f3bl7BqGYTM+53u0P6APjqK5am+5hyZvQWyI +plD9amML9ZMWGxmPsu2bm8mQ9QEM3xk9Dz44I8kvjwzRAv4bVdZO0I08r0+k8/6vKtMFnXkIoctX +MbScyJCyZ/QYFpM6/EfY0XiWMR+6KwxfXZmtY4laJCB22N/9q06mIqqdXuYnin1oKaPnirjaEbsX +LZmdEyRG98Xi2J+Of8ePdG1asuhy9azuJBCtLxTa/y2aRnFHvkLfuwHb9H/TKI8xWVvTyQKmtFLK +bpf7Q8UIJm+K9Lv9nyiqDdVF8xM6HdjAeI9BZzwelGSuewvF6NkBiDkal4ZkQdU7hwxu+g/GvUgU +vzlN1J5Bto+WHWOWk9mVBngxaJ43BjuAiUVhOSPHG0SjFeUc+JIwuwIDAQABo4HvMIHsMBIGA1Ud +EwEB/wQIMAYBAf8CAQEwDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBRlzeurNR4APn7VdMActHNH +DhpkLzCBpgYDVR0gBIGeMIGbMIGYBgRVHSAAMIGPMC8GCCsGAQUFBwIBFiNodHRwOi8vd3d3LmZp +cm1hcHJvZmVzaW9uYWwuY29tL2NwczBcBggrBgEFBQcCAjBQHk4AUABhAHMAZQBvACAAZABlACAA +bABhACAAQgBvAG4AYQBuAG8AdgBhACAANAA3ACAAQgBhAHIAYwBlAGwAbwBuAGEAIAAwADgAMAAx +ADcwDQYJKoZIhvcNAQEFBQADggIBABd9oPm03cXF661LJLWhAqvdpYhKsg9VSytXjDvlMd3+xDLx +51tkljYyGOylMnfX40S2wBEqgLk9am58m9Ot/MPWo+ZkKXzR4Tgegiv/J2Wv+xYVxC5xhOW1//qk +R71kMrv2JYSiJ0L1ILDCExARzRAVukKQKtJE4ZYm6zFIEv0q2skGz3QeqUvVhyj5eTSSPi5E6PaP +T481PyWzOdxjKpBrIF/EUhJOlywqrJ2X3kjyo2bbwtKDlaZmp54lD+kLM5FlClrD2VQS3a/DTg4f +Jl4N3LON7NWBcN7STyQF82xO9UxJZo3R/9ILJUFI/lGExkKvgATP0H5kSeTy36LssUzAKh3ntLFl +osS88Zj0qnAHY7S42jtM+kAiMFsRpvAFDsYCA0irhpuF3dvd6qJ2gHN99ZwExEWN57kci57q13XR +crHedUTnQn3iV2t93Jm8PYMo6oCTjcVMZcFwgbg4/EMxsvYDNEeyrPsiBsse3RdHHF9mudMaotoR +saS8I8nkvof/uZS2+F0gStRf571oe2XyFR7SOqkt6dhrJKyXWERHrVkY8SFlcN7ONGCoQPHzPKTD +KCOM/iczQ0CgFzzr6juwcqajuUpLXhZI9LK8yIySxZ2frHI2vDSANGupi5LAuBft7HZT9SQBjLMi +6Et8Vcad+qMUu2WFbm5PEn4KPJ2V +-----END CERTIFICATE----- + +Izenpe.com +========== +-----BEGIN CERTIFICATE----- +MIIF8TCCA9mgAwIBAgIQALC3WhZIX7/hy/WL1xnmfTANBgkqhkiG9w0BAQsFADA4MQswCQYDVQQG +EwJFUzEUMBIGA1UECgwLSVpFTlBFIFMuQS4xEzARBgNVBAMMCkl6ZW5wZS5jb20wHhcNMDcxMjEz +MTMwODI4WhcNMzcxMjEzMDgyNzI1WjA4MQswCQYDVQQGEwJFUzEUMBIGA1UECgwLSVpFTlBFIFMu +QS4xEzARBgNVBAMMCkl6ZW5wZS5jb20wggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQDJ +03rKDx6sp4boFmVqscIbRTJxldn+EFvMr+eleQGPicPK8lVx93e+d5TzcqQsRNiekpsUOqHnJJAK +ClaOxdgmlOHZSOEtPtoKct2jmRXagaKH9HtuJneJWK3W6wyyQXpzbm3benhB6QiIEn6HLmYRY2xU ++zydcsC8Lv/Ct90NduM61/e0aL6i9eOBbsFGb12N4E3GVFWJGjMxCrFXuaOKmMPsOzTFlUFpfnXC +PCDFYbpRR6AgkJOhkEvzTnyFRVSa0QUmQbC1TR0zvsQDyCV8wXDbO/QJLVQnSKwv4cSsPsjLkkxT +OTcj7NMB+eAJRE1NZMDhDVqHIrytG6P+JrUV86f8hBnp7KGItERphIPzidF0BqnMC9bC3ieFUCbK +F7jJeodWLBoBHmy+E60QrLUk9TiRodZL2vG70t5HtfG8gfZZa88ZU+mNFctKy6lvROUbQc/hhqfK +0GqfvEyNBjNaooXlkDWgYlwWTvDjovoDGrQscbNYLN57C9saD+veIR8GdwYDsMnvmfzAuU8Lhij+ +0rnq49qlw0dpEuDb8PYZi+17cNcC1u2HGCgsBCRMd+RIihrGO5rUD8r6ddIBQFqNeb+Lz0vPqhbB +leStTIo+F5HUsWLlguWABKQDfo2/2n+iD5dPDNMN+9fR5XJ+HMh3/1uaD7euBUbl8agW7EekFwID +AQABo4H2MIHzMIGwBgNVHREEgagwgaWBD2luZm9AaXplbnBlLmNvbaSBkTCBjjFHMEUGA1UECgw+ +SVpFTlBFIFMuQS4gLSBDSUYgQTAxMzM3MjYwLVJNZXJjLlZpdG9yaWEtR2FzdGVpeiBUMTA1NSBG +NjIgUzgxQzBBBgNVBAkMOkF2ZGEgZGVsIE1lZGl0ZXJyYW5lbyBFdG9yYmlkZWEgMTQgLSAwMTAx +MCBWaXRvcmlhLUdhc3RlaXowDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0O +BBYEFB0cZQ6o8iV7tJHP5LGx5r1VdGwFMA0GCSqGSIb3DQEBCwUAA4ICAQB4pgwWSp9MiDrAyw6l +Fn2fuUhfGI8NYjb2zRlrrKvV9pF9rnHzP7MOeIWblaQnIUdCSnxIOvVFfLMMjlF4rJUT3sb9fbga +kEyrkgPH7UIBzg/YsfqikuFgba56awmqxinuaElnMIAkejEWOVt+8Rwu3WwJrfIxwYJOubv5vr8q +hT/AQKM6WfxZSzwoJNu0FXWuDYi6LnPAvViH5ULy617uHjAimcs30cQhbIHsvm0m5hzkQiCeR7Cs +g1lwLDXWrzY0tM07+DKo7+N4ifuNRSzanLh+QBxh5z6ikixL8s36mLYp//Pye6kfLqCTVyvehQP5 +aTfLnnhqBbTFMXiJ7HqnheG5ezzevh55hM6fcA5ZwjUukCox2eRFekGkLhObNA5me0mrZJfQRsN5 +nXJQY6aYWwa9SG3YOYNw6DXwBdGqvOPbyALqfP2C2sJbUjWumDqtujWTI6cfSN01RpiyEGjkpTHC +ClguGYEQyVB1/OpaFs4R1+7vUIgtYf8/QnMFlEPVjjxOAToZpR9GTnfQXeWBIiGH/pR9hNiTrdZo +Q0iy2+tzJOeRf1SktoA+naM8THLCV8Sg1Mw4J87VBp6iSNnpn86CcDaTmjvfliHjWbcM2pE38P1Z +WrOZyGlsQyYBNWNgVYkDOnXYukrZVP/u3oDYLdE41V4tC5h9Pmzb/CaIxw== +-----END CERTIFICATE----- + +Chambers of Commerce Root - 2008 +================================ +-----BEGIN CERTIFICATE----- +MIIHTzCCBTegAwIBAgIJAKPaQn6ksa7aMA0GCSqGSIb3DQEBBQUAMIGuMQswCQYDVQQGEwJFVTFD +MEEGA1UEBxM6TWFkcmlkIChzZWUgY3VycmVudCBhZGRyZXNzIGF0IHd3dy5jYW1lcmZpcm1hLmNv +bS9hZGRyZXNzKTESMBAGA1UEBRMJQTgyNzQzMjg3MRswGQYDVQQKExJBQyBDYW1lcmZpcm1hIFMu +QS4xKTAnBgNVBAMTIENoYW1iZXJzIG9mIENvbW1lcmNlIFJvb3QgLSAyMDA4MB4XDTA4MDgwMTEy +Mjk1MFoXDTM4MDczMTEyMjk1MFowga4xCzAJBgNVBAYTAkVVMUMwQQYDVQQHEzpNYWRyaWQgKHNl +ZSBjdXJyZW50IGFkZHJlc3MgYXQgd3d3LmNhbWVyZmlybWEuY29tL2FkZHJlc3MpMRIwEAYDVQQF +EwlBODI3NDMyODcxGzAZBgNVBAoTEkFDIENhbWVyZmlybWEgUy5BLjEpMCcGA1UEAxMgQ2hhbWJl +cnMgb2YgQ29tbWVyY2UgUm9vdCAtIDIwMDgwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoIC +AQCvAMtwNyuAWko6bHiUfaN/Gh/2NdW928sNRHI+JrKQUrpjOyhYb6WzbZSm891kDFX29ufyIiKA +XuFixrYp4YFs8r/lfTJqVKAyGVn+H4vXPWCGhSRv4xGzdz4gljUha7MI2XAuZPeEklPWDrCQiorj +h40G072QDuKZoRuGDtqaCrsLYVAGUvGef3bsyw/QHg3PmTA9HMRFEFis1tPo1+XqxQEHd9ZR5gN/ +ikilTWh1uem8nk4ZcfUyS5xtYBkL+8ydddy/Js2Pk3g5eXNeJQ7KXOt3EgfLZEFHcpOrUMPrCXZk +NNI5t3YRCQ12RcSprj1qr7V9ZS+UWBDsXHyvfuK2GNnQm05aSd+pZgvMPMZ4fKecHePOjlO+Bd5g +D2vlGts/4+EhySnB8esHnFIbAURRPHsl18TlUlRdJQfKFiC4reRB7noI/plvg6aRArBsNlVq5331 +lubKgdaX8ZSD6e2wsWsSaR6s+12pxZjptFtYer49okQ6Y1nUCyXeG0+95QGezdIp1Z8XGQpvvwyQ +0wlf2eOKNcx5Wk0ZN5K3xMGtr/R5JJqyAQuxr1yW84Ay+1w9mPGgP0revq+ULtlVmhduYJ1jbLhj +ya6BXBg14JC7vjxPNyK5fuvPnnchpj04gftI2jE9K+OJ9dC1vX7gUMQSibMjmhAxhduub+84Mxh2 +EQIDAQABo4IBbDCCAWgwEgYDVR0TAQH/BAgwBgEB/wIBDDAdBgNVHQ4EFgQU+SSsD7K1+HnA+mCI +G8TZTQKeFxkwgeMGA1UdIwSB2zCB2IAU+SSsD7K1+HnA+mCIG8TZTQKeFxmhgbSkgbEwga4xCzAJ +BgNVBAYTAkVVMUMwQQYDVQQHEzpNYWRyaWQgKHNlZSBjdXJyZW50IGFkZHJlc3MgYXQgd3d3LmNh +bWVyZmlybWEuY29tL2FkZHJlc3MpMRIwEAYDVQQFEwlBODI3NDMyODcxGzAZBgNVBAoTEkFDIENh +bWVyZmlybWEgUy5BLjEpMCcGA1UEAxMgQ2hhbWJlcnMgb2YgQ29tbWVyY2UgUm9vdCAtIDIwMDiC +CQCj2kJ+pLGu2jAOBgNVHQ8BAf8EBAMCAQYwPQYDVR0gBDYwNDAyBgRVHSAAMCowKAYIKwYBBQUH +AgEWHGh0dHA6Ly9wb2xpY3kuY2FtZXJmaXJtYS5jb20wDQYJKoZIhvcNAQEFBQADggIBAJASryI1 +wqM58C7e6bXpeHxIvj99RZJe6dqxGfwWPJ+0W2aeaufDuV2I6A+tzyMP3iU6XsxPpcG1Lawk0lgH +3qLPaYRgM+gQDROpI9CF5Y57pp49chNyM/WqfcZjHwj0/gF/JM8rLFQJ3uIrbZLGOU8W6jx+ekbU +RWpGqOt1glanq6B8aBMz9p0w8G8nOSQjKpD9kCk18pPfNKXG9/jvjA9iSnyu0/VU+I22mlaHFoI6 +M6taIgj3grrqLuBHmrS1RaMFO9ncLkVAO+rcf+g769HsJtg1pDDFOqxXnrN2pSB7+R5KBWIBpih1 +YJeSDW4+TTdDDZIVnBgizVGZoCkaPF+KMjNbMMeJL0eYD6MDxvbxrN8y8NmBGuScvfaAFPDRLLmF +9dijscilIeUcE5fuDr3fKanvNFNb0+RqE4QGtjICxFKuItLcsiFCGtpA8CnJ7AoMXOLQusxI0zcK +zBIKinmwPQN/aUv0NCB9szTqjktk9T79syNnFQ0EuPAtwQlRPLJsFfClI9eDdOTlLsn+mCdCxqvG +nrDQWzilm1DefhiYtUU79nm06PcaewaD+9CL2rvHvRirCG88gGtAPxkZumWK5r7VXNM21+9AUiRg +OGcEMeyP84LG3rlV8zsxkVrctQgVrXYlCg17LofiDKYGvCYQbTed7N14jHyAxfDZd0jQ +-----END CERTIFICATE----- + +Global Chambersign Root - 2008 +============================== +-----BEGIN CERTIFICATE----- +MIIHSTCCBTGgAwIBAgIJAMnN0+nVfSPOMA0GCSqGSIb3DQEBBQUAMIGsMQswCQYDVQQGEwJFVTFD +MEEGA1UEBxM6TWFkcmlkIChzZWUgY3VycmVudCBhZGRyZXNzIGF0IHd3dy5jYW1lcmZpcm1hLmNv +bS9hZGRyZXNzKTESMBAGA1UEBRMJQTgyNzQzMjg3MRswGQYDVQQKExJBQyBDYW1lcmZpcm1hIFMu +QS4xJzAlBgNVBAMTHkdsb2JhbCBDaGFtYmVyc2lnbiBSb290IC0gMjAwODAeFw0wODA4MDExMjMx +NDBaFw0zODA3MzExMjMxNDBaMIGsMQswCQYDVQQGEwJFVTFDMEEGA1UEBxM6TWFkcmlkIChzZWUg +Y3VycmVudCBhZGRyZXNzIGF0IHd3dy5jYW1lcmZpcm1hLmNvbS9hZGRyZXNzKTESMBAGA1UEBRMJ +QTgyNzQzMjg3MRswGQYDVQQKExJBQyBDYW1lcmZpcm1hIFMuQS4xJzAlBgNVBAMTHkdsb2JhbCBD +aGFtYmVyc2lnbiBSb290IC0gMjAwODCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAMDf +VtPkOpt2RbQT2//BthmLN0EYlVJH6xedKYiONWwGMi5HYvNJBL99RDaxccy9Wglz1dmFRP+RVyXf +XjaOcNFccUMd2drvXNL7G706tcuto8xEpw2uIRU/uXpbknXYpBI4iRmKt4DS4jJvVpyR1ogQC7N0 +ZJJ0YPP2zxhPYLIj0Mc7zmFLmY/CDNBAspjcDahOo7kKrmCgrUVSY7pmvWjg+b4aqIG7HkF4ddPB +/gBVsIdU6CeQNR1MM62X/JcumIS/LMmjv9GYERTtY/jKmIhYF5ntRQOXfjyGHoiMvvKRhI9lNNgA +TH23MRdaKXoKGCQwoze1eqkBfSbW+Q6OWfH9GzO1KTsXO0G2Id3UwD2ln58fQ1DJu7xsepeY7s2M +H/ucUa6LcL0nn3HAa6x9kGbo1106DbDVwo3VyJ2dwW3Q0L9R5OP4wzg2rtandeavhENdk5IMagfe +Ox2YItaswTXbo6Al/3K1dh3ebeksZixShNBFks4c5eUzHdwHU1SjqoI7mjcv3N2gZOnm3b2u/GSF +HTynyQbehP9r6GsaPMWis0L7iwk+XwhSx2LE1AVxv8Rk5Pihg+g+EpuoHtQ2TS9x9o0o9oOpE9Jh +wZG7SMA0j0GMS0zbaRL/UJScIINZc+18ofLx/d33SdNDWKBWY8o9PeU1VlnpDsogzCtLkykPAgMB +AAGjggFqMIIBZjASBgNVHRMBAf8ECDAGAQH/AgEMMB0GA1UdDgQWBBS5CcqcHtvTbDprru1U8VuT +BjUuXjCB4QYDVR0jBIHZMIHWgBS5CcqcHtvTbDprru1U8VuTBjUuXqGBsqSBrzCBrDELMAkGA1UE +BhMCRVUxQzBBBgNVBAcTOk1hZHJpZCAoc2VlIGN1cnJlbnQgYWRkcmVzcyBhdCB3d3cuY2FtZXJm +aXJtYS5jb20vYWRkcmVzcykxEjAQBgNVBAUTCUE4Mjc0MzI4NzEbMBkGA1UEChMSQUMgQ2FtZXJm +aXJtYSBTLkEuMScwJQYDVQQDEx5HbG9iYWwgQ2hhbWJlcnNpZ24gUm9vdCAtIDIwMDiCCQDJzdPp +1X0jzjAOBgNVHQ8BAf8EBAMCAQYwPQYDVR0gBDYwNDAyBgRVHSAAMCowKAYIKwYBBQUHAgEWHGh0 +dHA6Ly9wb2xpY3kuY2FtZXJmaXJtYS5jb20wDQYJKoZIhvcNAQEFBQADggIBAICIf3DekijZBZRG +/5BXqfEv3xoNa/p8DhxJJHkn2EaqbylZUohwEurdPfWbU1Rv4WCiqAm57OtZfMY18dwY6fFn5a+6 +ReAJ3spED8IXDneRRXozX1+WLGiLwUePmJs9wOzL9dWCkoQ10b42OFZyMVtHLaoXpGNR6woBrX/s +dZ7LoR/xfxKxueRkf2fWIyr0uDldmOghp+G9PUIadJpwr2hsUF1Jz//7Dl3mLEfXgTpZALVza2Mg +9jFFCDkO9HB+QHBaP9BrQql0PSgvAm11cpUJjUhjxsYjV5KTXjXBjfkK9yydYhz2rXzdpjEetrHH +foUm+qRqtdpjMNHvkzeyZi99Bffnt0uYlDXA2TopwZ2yUDMdSqlapskD7+3056huirRXhOukP9Du +qqqHW2Pok+JrqNS4cnhrG+055F3Lm6qH1U9OAP7Zap88MQ8oAgF9mOinsKJknnn4SPIVqczmyETr +P3iZ8ntxPjzxmKfFGBI/5rsoM0LpRQp8bfKGeS/Fghl9CYl8slR2iK7ewfPM4W7bMdaTrpmg7yVq +c5iJWzouE4gev8CSlDQb4ye3ix5vQv/n6TebUB0tovkC7stYWDpxvGjjqsGvHCgfotwjZT+B6q6Z +09gwzxMNTxXJhLynSC34MCN32EZLeW32jO06f2ARePTpm67VVMB0gNELQp/B +-----END CERTIFICATE----- + +Go Daddy Root Certificate Authority - G2 +======================================== +-----BEGIN CERTIFICATE----- +MIIDxTCCAq2gAwIBAgIBADANBgkqhkiG9w0BAQsFADCBgzELMAkGA1UEBhMCVVMxEDAOBgNVBAgT +B0FyaXpvbmExEzARBgNVBAcTClNjb3R0c2RhbGUxGjAYBgNVBAoTEUdvRGFkZHkuY29tLCBJbmMu +MTEwLwYDVQQDEyhHbyBEYWRkeSBSb290IENlcnRpZmljYXRlIEF1dGhvcml0eSAtIEcyMB4XDTA5 +MDkwMTAwMDAwMFoXDTM3MTIzMTIzNTk1OVowgYMxCzAJBgNVBAYTAlVTMRAwDgYDVQQIEwdBcml6 +b25hMRMwEQYDVQQHEwpTY290dHNkYWxlMRowGAYDVQQKExFHb0RhZGR5LmNvbSwgSW5jLjExMC8G +A1UEAxMoR28gRGFkZHkgUm9vdCBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkgLSBHMjCCASIwDQYJKoZI +hvcNAQEBBQADggEPADCCAQoCggEBAL9xYgjx+lk09xvJGKP3gElY6SKDE6bFIEMBO4Tx5oVJnyfq +9oQbTqC023CYxzIBsQU+B07u9PpPL1kwIuerGVZr4oAH/PMWdYA5UXvl+TW2dE6pjYIT5LY/qQOD ++qK+ihVqf94Lw7YZFAXK6sOoBJQ7RnwyDfMAZiLIjWltNowRGLfTshxgtDj6AozO091GB94KPutd +fMh8+7ArU6SSYmlRJQVhGkSBjCypQ5Yj36w6gZoOKcUcqeldHraenjAKOc7xiID7S13MMuyFYkMl +NAJWJwGRtDtwKj9useiciAF9n9T521NtYJ2/LOdYq7hfRvzOxBsDPAnrSTFcaUaz4EcCAwEAAaNC +MEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFDqahQcQZyi27/a9 +BUFuIMGU2g/eMA0GCSqGSIb3DQEBCwUAA4IBAQCZ21151fmXWWcDYfF+OwYxdS2hII5PZYe096ac +vNjpL9DbWu7PdIxztDhC2gV7+AJ1uP2lsdeu9tfeE8tTEH6KRtGX+rcuKxGrkLAngPnon1rpN5+r +5N9ss4UXnT3ZJE95kTXWXwTrgIOrmgIttRD02JDHBHNA7XIloKmf7J6raBKZV8aPEjoJpL1E/QYV +N8Gb5DKj7Tjo2GTzLH4U/ALqn83/B2gX2yKQOC16jdFU8WnjXzPKej17CuPKf1855eJ1usV2GDPO +LPAvTK33sefOT6jEm0pUBsV/fdUID+Ic/n4XuKxe9tQWskMJDE32p2u0mYRlynqI4uJEvlz36hz1 +-----END CERTIFICATE----- + +Starfield Root Certificate Authority - G2 +========================================= +-----BEGIN CERTIFICATE----- +MIID3TCCAsWgAwIBAgIBADANBgkqhkiG9w0BAQsFADCBjzELMAkGA1UEBhMCVVMxEDAOBgNVBAgT +B0FyaXpvbmExEzARBgNVBAcTClNjb3R0c2RhbGUxJTAjBgNVBAoTHFN0YXJmaWVsZCBUZWNobm9s +b2dpZXMsIEluYy4xMjAwBgNVBAMTKVN0YXJmaWVsZCBSb290IENlcnRpZmljYXRlIEF1dGhvcml0 +eSAtIEcyMB4XDTA5MDkwMTAwMDAwMFoXDTM3MTIzMTIzNTk1OVowgY8xCzAJBgNVBAYTAlVTMRAw +DgYDVQQIEwdBcml6b25hMRMwEQYDVQQHEwpTY290dHNkYWxlMSUwIwYDVQQKExxTdGFyZmllbGQg +VGVjaG5vbG9naWVzLCBJbmMuMTIwMAYDVQQDEylTdGFyZmllbGQgUm9vdCBDZXJ0aWZpY2F0ZSBB +dXRob3JpdHkgLSBHMjCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEBAL3twQP89o/8ArFv +W59I2Z154qK3A2FWGMNHttfKPTUuiUP3oWmb3ooa/RMgnLRJdzIpVv257IzdIvpy3Cdhl+72WoTs +bhm5iSzchFvVdPtrX8WJpRBSiUZV9Lh1HOZ/5FSuS/hVclcCGfgXcVnrHigHdMWdSL5stPSksPNk +N3mSwOxGXn/hbVNMYq/NHwtjuzqd+/x5AJhhdM8mgkBj87JyahkNmcrUDnXMN/uLicFZ8WJ/X7Nf +ZTD4p7dNdloedl40wOiWVpmKs/B/pM293DIxfJHP4F8R+GuqSVzRmZTRouNjWwl2tVZi4Ut0HZbU +JtQIBFnQmA4O5t78w+wfkPECAwEAAaNCMEAwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMC +AQYwHQYDVR0OBBYEFHwMMh+n2TB/xH1oo2Kooc6rB1snMA0GCSqGSIb3DQEBCwUAA4IBAQARWfol +TwNvlJk7mh+ChTnUdgWUXuEok21iXQnCoKjUsHU48TRqneSfioYmUeYs0cYtbpUgSpIB7LiKZ3sx +4mcujJUDJi5DnUox9g61DLu34jd/IroAow57UvtruzvE03lRTs2Q9GcHGcg8RnoNAX3FWOdt5oUw +F5okxBDgBPfg8n/Uqgr/Qh037ZTlZFkSIHc40zI+OIF1lnP6aI+xy84fxez6nH7PfrHxBy22/L/K +pL/QlwVKvOoYKAKQvVR4CSFx09F9HdkWsKlhPdAKACL8x3vLCWRFCztAgfd9fDL1mMpYjn0q7pBZ +c2T5NnReJaH1ZgUufzkVqSr7UIuOhWn0 +-----END CERTIFICATE----- + +Starfield Services Root Certificate Authority - G2 +================================================== +-----BEGIN CERTIFICATE----- +MIID7zCCAtegAwIBAgIBADANBgkqhkiG9w0BAQsFADCBmDELMAkGA1UEBhMCVVMxEDAOBgNVBAgT +B0FyaXpvbmExEzARBgNVBAcTClNjb3R0c2RhbGUxJTAjBgNVBAoTHFN0YXJmaWVsZCBUZWNobm9s +b2dpZXMsIEluYy4xOzA5BgNVBAMTMlN0YXJmaWVsZCBTZXJ2aWNlcyBSb290IENlcnRpZmljYXRl +IEF1dGhvcml0eSAtIEcyMB4XDTA5MDkwMTAwMDAwMFoXDTM3MTIzMTIzNTk1OVowgZgxCzAJBgNV +BAYTAlVTMRAwDgYDVQQIEwdBcml6b25hMRMwEQYDVQQHEwpTY290dHNkYWxlMSUwIwYDVQQKExxT +dGFyZmllbGQgVGVjaG5vbG9naWVzLCBJbmMuMTswOQYDVQQDEzJTdGFyZmllbGQgU2VydmljZXMg +Um9vdCBDZXJ0aWZpY2F0ZSBBdXRob3JpdHkgLSBHMjCCASIwDQYJKoZIhvcNAQEBBQADggEPADCC +AQoCggEBANUMOsQq+U7i9b4Zl1+OiFOxHz/Lz58gE20pOsgPfTz3a3Y4Y9k2YKibXlwAgLIvWX/2 +h/klQ4bnaRtSmpDhcePYLQ1Ob/bISdm28xpWriu2dBTrz/sm4xq6HZYuajtYlIlHVv8loJNwU4Pa +hHQUw2eeBGg6345AWh1KTs9DkTvnVtYAcMtS7nt9rjrnvDH5RfbCYM8TWQIrgMw0R9+53pBlbQLP +LJGmpufehRhJfGZOozptqbXuNC66DQO4M99H67FrjSXZm86B0UVGMpZwh94CDklDhbZsc7tk6mFB +rMnUVN+HL8cisibMn1lUaJ/8viovxFUcdUBgF4UCVTmLfwUCAwEAAaNCMEAwDwYDVR0TAQH/BAUw +AwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFJxfAN+qAdcwKziIorhtSpzyEZGDMA0GCSqG +SIb3DQEBCwUAA4IBAQBLNqaEd2ndOxmfZyMIbw5hyf2E3F/YNoHN2BtBLZ9g3ccaaNnRbobhiCPP +E95Dz+I0swSdHynVv/heyNXBve6SbzJ08pGCL72CQnqtKrcgfU28elUSwhXqvfdqlS5sdJ/PHLTy +xQGjhdByPq1zqwubdQxtRbeOlKyWN7Wg0I8VRw7j6IPdj/3vQQF3zCepYoUz8jcI73HPdwbeyBkd +iEDPfUYd/x7H4c7/I9vG+o1VTqkC50cRRj70/b17KSa7qWFiNyi2LSr2EIZkyXCn0q23KXB56jza +YyWf/Wi3MOxw+3WKt21gZ7IeyLnp2KhvAotnDU0mV3HaIPzBSlCNsSi6 +-----END CERTIFICATE----- + +AffirmTrust Commercial +====================== +-----BEGIN CERTIFICATE----- +MIIDTDCCAjSgAwIBAgIId3cGJyapsXwwDQYJKoZIhvcNAQELBQAwRDELMAkGA1UEBhMCVVMxFDAS +BgNVBAoMC0FmZmlybVRydXN0MR8wHQYDVQQDDBZBZmZpcm1UcnVzdCBDb21tZXJjaWFsMB4XDTEw +MDEyOTE0MDYwNloXDTMwMTIzMTE0MDYwNlowRDELMAkGA1UEBhMCVVMxFDASBgNVBAoMC0FmZmly +bVRydXN0MR8wHQYDVQQDDBZBZmZpcm1UcnVzdCBDb21tZXJjaWFsMIIBIjANBgkqhkiG9w0BAQEF +AAOCAQ8AMIIBCgKCAQEA9htPZwcroRX1BiLLHwGy43NFBkRJLLtJJRTWzsO3qyxPxkEylFf6Eqdb +DuKPHx6GGaeqtS25Xw2Kwq+FNXkyLbscYjfysVtKPcrNcV/pQr6U6Mje+SJIZMblq8Yrba0F8PrV +C8+a5fBQpIs7R6UjW3p6+DM/uO+Zl+MgwdYoic+U+7lF7eNAFxHUdPALMeIrJmqbTFeurCA+ukV6 +BfO9m2kVrn1OIGPENXY6BwLJN/3HR+7o8XYdcxXyl6S1yHp52UKqK39c/s4mT6NmgTWvRLpUHhww +MmWd5jyTXlBOeuM61G7MGvv50jeuJCqrVwMiKA1JdX+3KNp1v47j3A55MQIDAQABo0IwQDAdBgNV +HQ4EFgQUnZPGU4teyq8/nx4P5ZmVvCT2lI8wDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMC +AQYwDQYJKoZIhvcNAQELBQADggEBAFis9AQOzcAN/wr91LoWXym9e2iZWEnStB03TX8nfUYGXUPG +hi4+c7ImfU+TqbbEKpqrIZcUsd6M06uJFdhrJNTxFq7YpFzUf1GO7RgBsZNjvbz4YYCanrHOQnDi +qX0GJX0nof5v7LMeJNrjS1UaADs1tDvZ110w/YETifLCBivtZ8SOyUOyXGsViQK8YvxO8rUzqrJv +0wqiUOP2O+guRMLbZjipM1ZI8W0bM40NjD9gN53Tym1+NH4Nn3J2ixufcv1SNUFFApYvHLKac0kh +sUlHRUe072o0EclNmsxZt9YCnlpOZbWUrhvfKbAW8b8Angc6F2S1BLUjIZkKlTuXfO8= +-----END CERTIFICATE----- + +AffirmTrust Networking +====================== +-----BEGIN CERTIFICATE----- +MIIDTDCCAjSgAwIBAgIIfE8EORzUmS0wDQYJKoZIhvcNAQEFBQAwRDELMAkGA1UEBhMCVVMxFDAS +BgNVBAoMC0FmZmlybVRydXN0MR8wHQYDVQQDDBZBZmZpcm1UcnVzdCBOZXR3b3JraW5nMB4XDTEw +MDEyOTE0MDgyNFoXDTMwMTIzMTE0MDgyNFowRDELMAkGA1UEBhMCVVMxFDASBgNVBAoMC0FmZmly +bVRydXN0MR8wHQYDVQQDDBZBZmZpcm1UcnVzdCBOZXR3b3JraW5nMIIBIjANBgkqhkiG9w0BAQEF +AAOCAQ8AMIIBCgKCAQEAtITMMxcua5Rsa2FSoOujz3mUTOWUgJnLVWREZY9nZOIG41w3SfYvm4SE +Hi3yYJ0wTsyEheIszx6e/jarM3c1RNg1lho9Nuh6DtjVR6FqaYvZ/Ls6rnla1fTWcbuakCNrmreI +dIcMHl+5ni36q1Mr3Lt2PpNMCAiMHqIjHNRqrSK6mQEubWXLviRmVSRLQESxG9fhwoXA3hA/Pe24 +/PHxI1Pcv2WXb9n5QHGNfb2V1M6+oF4nI979ptAmDgAp6zxG8D1gvz9Q0twmQVGeFDdCBKNwV6gb +h+0t+nvujArjqWaJGctB+d1ENmHP4ndGyH329JKBNv3bNPFyfvMMFr20FQIDAQABo0IwQDAdBgNV +HQ4EFgQUBx/S55zawm6iQLSwelAQUHTEyL0wDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMC +AQYwDQYJKoZIhvcNAQEFBQADggEBAIlXshZ6qML91tmbmzTCnLQyFE2npN/svqe++EPbkTfOtDIu +UFUaNU52Q3Eg75N3ThVwLofDwR1t3Mu1J9QsVtFSUzpE0nPIxBsFZVpikpzuQY0x2+c06lkh1QF6 +12S4ZDnNye2v7UsDSKegmQGA3GWjNq5lWUhPgkvIZfFXHeVZLgo/bNjR9eUJtGxUAArgFU2HdW23 +WJZa3W3SAKD0m0i+wzekujbgfIeFlxoVot4uolu9rxj5kFDNcFn4J2dHy8egBzp90SxdbBk6ZrV9 +/ZFvgrG+CJPbFEfxojfHRZ48x3evZKiT3/Zpg4Jg8klCNO1aAFSFHBY2kgxc+qatv9s= +-----END CERTIFICATE----- + +AffirmTrust Premium +=================== +-----BEGIN CERTIFICATE----- +MIIFRjCCAy6gAwIBAgIIbYwURrGmCu4wDQYJKoZIhvcNAQEMBQAwQTELMAkGA1UEBhMCVVMxFDAS +BgNVBAoMC0FmZmlybVRydXN0MRwwGgYDVQQDDBNBZmZpcm1UcnVzdCBQcmVtaXVtMB4XDTEwMDEy +OTE0MTAzNloXDTQwMTIzMTE0MTAzNlowQTELMAkGA1UEBhMCVVMxFDASBgNVBAoMC0FmZmlybVRy +dXN0MRwwGgYDVQQDDBNBZmZpcm1UcnVzdCBQcmVtaXVtMIICIjANBgkqhkiG9w0BAQEFAAOCAg8A +MIICCgKCAgEAxBLfqV/+Qd3d9Z+K4/as4Tx4mrzY8H96oDMq3I0gW64tb+eT2TZwamjPjlGjhVtn +BKAQJG9dKILBl1fYSCkTtuG+kU3fhQxTGJoeJKJPj/CihQvL9Cl/0qRY7iZNyaqoe5rZ+jjeRFcV +5fiMyNlI4g0WJx0eyIOFJbe6qlVBzAMiSy2RjYvmia9mx+n/K+k8rNrSs8PhaJyJ+HoAVt70VZVs ++7pk3WKL3wt3MutizCaam7uqYoNMtAZ6MMgpv+0GTZe5HMQxK9VfvFMSF5yZVylmd2EhMQcuJUmd +GPLu8ytxjLW6OQdJd/zvLpKQBY0tL3d770O/Nbua2Plzpyzy0FfuKE4mX4+QaAkvuPjcBukumj5R +p9EixAqnOEhss/n/fauGV+O61oV4d7pD6kh/9ti+I20ev9E2bFhc8e6kGVQa9QPSdubhjL08s9NI +S+LI+H+SqHZGnEJlPqQewQcDWkYtuJfzt9WyVSHvutxMAJf7FJUnM7/oQ0dG0giZFmA7mn7S5u04 +6uwBHjxIVkkJx0w3AJ6IDsBz4W9m6XJHMD4Q5QsDyZpCAGzFlH5hxIrff4IaC1nEWTJ3s7xgaVY5 +/bQGeyzWZDbZvUjthB9+pSKPKrhC9IK31FOQeE4tGv2Bb0TXOwF0lkLgAOIua+rF7nKsu7/+6qqo ++Nz2snmKtmcCAwEAAaNCMEAwHQYDVR0OBBYEFJ3AZ6YMItkm9UWrpmVSESfYRaxjMA8GA1UdEwEB +/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMA0GCSqGSIb3DQEBDAUAA4ICAQCzV00QYk465KzquByv +MiPIs0laUZx2KI15qldGF9X1Uva3ROgIRL8YhNILgM3FEv0AVQVhh0HctSSePMTYyPtwni94loMg +Nt58D2kTiKV1NpgIpsbfrM7jWNa3Pt668+s0QNiigfV4Py/VpfzZotReBA4Xrf5B8OWycvpEgjNC +6C1Y91aMYj+6QrCcDFx+LmUmXFNPALJ4fqENmS2NuB2OosSw/WDQMKSOyARiqcTtNd56l+0OOF6S +L5Nwpamcb6d9Ex1+xghIsV5n61EIJenmJWtSKZGc0jlzCFfemQa0W50QBuHCAKi4HEoCChTQwUHK ++4w1IX2COPKpVJEZNZOUbWo6xbLQu4mGk+ibyQ86p3q4ofB4Rvr8Ny/lioTz3/4E2aFooC8k4gmV +BtWVyuEklut89pMFu+1z6S3RdTnX5yTb2E5fQ4+e0BQ5v1VwSJlXMbSc7kqYA5YwH2AG7hsj/oFg +IxpHYoWlzBk0gG+zrBrjn/B7SK3VAdlntqlyk+otZrWyuOQ9PLLvTIzq6we/qzWaVYa8GKa1qF60 +g2xraUDTn9zxw2lrueFtCfTxqlB2Cnp9ehehVZZCmTEJ3WARjQUwfuaORtGdFNrHF+QFlozEJLUb +zxQHskD4o55BhrwE0GuWyCqANP2/7waj3VjFhT0+j/6eKeC2uAloGRwYQw== +-----END CERTIFICATE----- + +AffirmTrust Premium ECC +======================= +-----BEGIN CERTIFICATE----- +MIIB/jCCAYWgAwIBAgIIdJclisc/elQwCgYIKoZIzj0EAwMwRTELMAkGA1UEBhMCVVMxFDASBgNV +BAoMC0FmZmlybVRydXN0MSAwHgYDVQQDDBdBZmZpcm1UcnVzdCBQcmVtaXVtIEVDQzAeFw0xMDAx +MjkxNDIwMjRaFw00MDEyMzExNDIwMjRaMEUxCzAJBgNVBAYTAlVTMRQwEgYDVQQKDAtBZmZpcm1U +cnVzdDEgMB4GA1UEAwwXQWZmaXJtVHJ1c3QgUHJlbWl1bSBFQ0MwdjAQBgcqhkjOPQIBBgUrgQQA +IgNiAAQNMF4bFZ0D0KF5Nbc6PJJ6yhUczWLznCZcBz3lVPqj1swS6vQUX+iOGasvLkjmrBhDeKzQ +N8O9ss0s5kfiGuZjuD0uL3jET9v0D6RoTFVya5UdThhClXjMNzyR4ptlKymjQjBAMB0GA1UdDgQW +BBSaryl6wBE1NSZRMADDav5A1a7WPDAPBgNVHRMBAf8EBTADAQH/MA4GA1UdDwEB/wQEAwIBBjAK +BggqhkjOPQQDAwNnADBkAjAXCfOHiFBar8jAQr9HX/VsaobgxCd05DhT1wV/GzTjxi+zygk8N53X +57hG8f2h4nECMEJZh0PUUd+60wkyWs6Iflc9nF9Ca/UHLbXwgpP5WW+uZPpY5Yse42O+tYHNbwKM +eQ== +-----END CERTIFICATE----- + +Certum Trusted Network CA +========================= +-----BEGIN CERTIFICATE----- +MIIDuzCCAqOgAwIBAgIDBETAMA0GCSqGSIb3DQEBBQUAMH4xCzAJBgNVBAYTAlBMMSIwIAYDVQQK +ExlVbml6ZXRvIFRlY2hub2xvZ2llcyBTLkEuMScwJQYDVQQLEx5DZXJ0dW0gQ2VydGlmaWNhdGlv +biBBdXRob3JpdHkxIjAgBgNVBAMTGUNlcnR1bSBUcnVzdGVkIE5ldHdvcmsgQ0EwHhcNMDgxMDIy +MTIwNzM3WhcNMjkxMjMxMTIwNzM3WjB+MQswCQYDVQQGEwJQTDEiMCAGA1UEChMZVW5pemV0byBU +ZWNobm9sb2dpZXMgUy5BLjEnMCUGA1UECxMeQ2VydHVtIENlcnRpZmljYXRpb24gQXV0aG9yaXR5 +MSIwIAYDVQQDExlDZXJ0dW0gVHJ1c3RlZCBOZXR3b3JrIENBMIIBIjANBgkqhkiG9w0BAQEFAAOC +AQ8AMIIBCgKCAQEA4/t9o3K6wvDJFIf1awFO4W5AB7ptJ11/91sts1rHUV+rpDKmYYe2bg+G0jAC +l/jXaVehGDldamR5xgFZrDwxSjh80gTSSyjoIF87B6LMTXPb865Px1bVWqeWifrzq2jUI4ZZJ88J +J7ysbnKDHDBy3+Ci6dLhdHUZvSqeexVUBBvXQzmtVSjF4hq79MDkrjhJM8x2hZ85RdKknvISjFH4 +fOQtf/WsX+sWn7Et0brMkUJ3TCXJkDhv2/DM+44el1k+1WBO5gUo7Ul5E0u6SNsv+XLTOcr+H9g0 +cvW0QM8xAcPs3hEtF10fuFDRXhmnad4HMyjKUJX5p1TLVIZQRan5SQIDAQABo0IwQDAPBgNVHRMB +Af8EBTADAQH/MB0GA1UdDgQWBBQIds3LB/8k9sXN7buQvOKEN0Z19zAOBgNVHQ8BAf8EBAMCAQYw +DQYJKoZIhvcNAQEFBQADggEBAKaorSLOAT2mo/9i0Eidi15ysHhE49wcrwn9I0j6vSrEuVUEtRCj +jSfeC4Jj0O7eDDd5QVsisrCaQVymcODU0HfLI9MA4GxWL+FpDQ3Zqr8hgVDZBqWo/5U30Kr+4rP1 +mS1FhIrlQgnXdAIv94nYmem8J9RHjboNRhx3zxSkHLmkMcScKHQDNP8zGSal6Q10tz6XxnboJ5aj +Zt3hrvJBW8qYVoNzcOSGGtIxQbovvi0TWnZvTuhOgQ4/WwMioBK+ZlgRSssDxLQqKi2WF+A5VLxI +03YnnZotBqbJ7DnSq9ufmgsnAjUpsUCV5/nonFWIGUbWtzT1fs45mtk48VH3Tyw= +-----END CERTIFICATE----- + +Certinomis - Autorité Racine +============================= +-----BEGIN CERTIFICATE----- +MIIFnDCCA4SgAwIBAgIBATANBgkqhkiG9w0BAQUFADBjMQswCQYDVQQGEwJGUjETMBEGA1UEChMK +Q2VydGlub21pczEXMBUGA1UECxMOMDAwMiA0MzM5OTg5MDMxJjAkBgNVBAMMHUNlcnRpbm9taXMg +LSBBdXRvcml0w6kgUmFjaW5lMB4XDTA4MDkxNzA4Mjg1OVoXDTI4MDkxNzA4Mjg1OVowYzELMAkG +A1UEBhMCRlIxEzARBgNVBAoTCkNlcnRpbm9taXMxFzAVBgNVBAsTDjAwMDIgNDMzOTk4OTAzMSYw +JAYDVQQDDB1DZXJ0aW5vbWlzIC0gQXV0b3JpdMOpIFJhY2luZTCCAiIwDQYJKoZIhvcNAQEBBQAD +ggIPADCCAgoCggIBAJ2Fn4bT46/HsmtuM+Cet0I0VZ35gb5j2CN2DpdUzZlMGvE5x4jYF1AMnmHa +wE5V3udauHpOd4cN5bjr+p5eex7Ezyh0x5P1FMYiKAT5kcOrJ3NqDi5N8y4oH3DfVS9O7cdxbwly +Lu3VMpfQ8Vh30WC8Tl7bmoT2R2FFK/ZQpn9qcSdIhDWerP5pqZ56XjUl+rSnSTV3lqc2W+HN3yNw +2F1MpQiD8aYkOBOo7C+ooWfHpi2GR+6K/OybDnT0K0kCe5B1jPyZOQE51kqJ5Z52qz6WKDgmi92N +jMD2AR5vpTESOH2VwnHu7XSu5DaiQ3XV8QCb4uTXzEIDS3h65X27uK4uIJPT5GHfceF2Z5c/tt9q +c1pkIuVC28+BA5PY9OMQ4HL2AHCs8MF6DwV/zzRpRbWT5BnbUhYjBYkOjUjkJW+zeL9i9Qf6lSTC +lrLooyPCXQP8w9PlfMl1I9f09bze5N/NgL+RiH2nE7Q5uiy6vdFrzPOlKO1Enn1So2+WLhl+HPNb +xxaOu2B9d2ZHVIIAEWBsMsGoOBvrbpgT1u449fCfDu/+MYHB0iSVL1N6aaLwD4ZFjliCK0wi1F6g +530mJ0jfJUaNSih8hp75mxpZuWW/Bd22Ql095gBIgl4g9xGC3srYn+Y3RyYe63j3YcNBZFgCQfna +4NH4+ej9Uji29YnfAgMBAAGjWzBZMA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0G +A1UdDgQWBBQNjLZh2kS40RR9w759XkjwzspqsDAXBgNVHSAEEDAOMAwGCiqBegFWAgIAAQEwDQYJ +KoZIhvcNAQEFBQADggIBACQ+YAZ+He86PtvqrxyaLAEL9MW12Ukx9F1BjYkMTv9sov3/4gbIOZ/x +WqndIlgVqIrTseYyCYIDbNc/CMf4uboAbbnW/FIyXaR/pDGUu7ZMOH8oMDX/nyNTt7buFHAAQCva +R6s0fl6nVjBhK4tDrP22iCj1a7Y+YEq6QpA0Z43q619FVDsXrIvkxmUP7tCMXWY5zjKn2BCXwH40 +nJ+U8/aGH88bc62UeYdocMMzpXDn2NU4lG9jeeu/Cg4I58UvD0KgKxRA/yHgBcUn4YQRE7rWhh1B +CxMjidPJC+iKunqjo3M3NYB9Ergzd0A4wPpeMNLytqOx1qKVl4GbUu1pTP+A5FPbVFsDbVRfsbjv +JL1vnxHDx2TCDyhihWZeGnuyt++uNckZM6i4J9szVb9o4XVIRFb7zdNIu0eJOqxp9YDG5ERQL1TE +qkPFMTFYvZbF6nVsmnWxTfj3l/+WFvKXTej28xH5On2KOG4Ey+HTRRWqpdEdnV1j6CTmNhTih60b +WfVEm/vXd3wfAXBioSAaosUaKPQhA+4u2cGA6rnZgtZbdsLLO7XSAPCjDuGtbkD326C00EauFddE +wk01+dIL8hf2rGbVJLJP0RyZwG71fet0BLj5TXcJ17TPBzAJ8bgAVtkXFhYKK4bfjwEZGuW7gmP/ +vgt2Fl43N+bYdJeimUV5 +-----END CERTIFICATE----- + +Root CA Generalitat Valenciana +============================== +-----BEGIN CERTIFICATE----- +MIIGizCCBXOgAwIBAgIEO0XlaDANBgkqhkiG9w0BAQUFADBoMQswCQYDVQQGEwJFUzEfMB0GA1UE +ChMWR2VuZXJhbGl0YXQgVmFsZW5jaWFuYTEPMA0GA1UECxMGUEtJR1ZBMScwJQYDVQQDEx5Sb290 +IENBIEdlbmVyYWxpdGF0IFZhbGVuY2lhbmEwHhcNMDEwNzA2MTYyMjQ3WhcNMjEwNzAxMTUyMjQ3 +WjBoMQswCQYDVQQGEwJFUzEfMB0GA1UEChMWR2VuZXJhbGl0YXQgVmFsZW5jaWFuYTEPMA0GA1UE +CxMGUEtJR1ZBMScwJQYDVQQDEx5Sb290IENBIEdlbmVyYWxpdGF0IFZhbGVuY2lhbmEwggEiMA0G +CSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDGKqtXETcvIorKA3Qdyu0togu8M1JAJke+WmmmO3I2 +F0zo37i7L3bhQEZ0ZQKQUgi0/6iMweDHiVYQOTPvaLRfX9ptI6GJXiKjSgbwJ/BXufjpTjJ3Cj9B +ZPPrZe52/lSqfR0grvPXdMIKX/UIKFIIzFVd0g/bmoGlu6GzwZTNVOAydTGRGmKy3nXiz0+J2ZGQ +D0EbtFpKd71ng+CT516nDOeB0/RSrFOyA8dEJvt55cs0YFAQexvba9dHq198aMpunUEDEO5rmXte +JajCq+TA81yc477OMUxkHl6AovWDfgzWyoxVjr7gvkkHD6MkQXpYHYTqWBLI4bft75PelAgxAgMB +AAGjggM7MIIDNzAyBggrBgEFBQcBAQQmMCQwIgYIKwYBBQUHMAGGFmh0dHA6Ly9vY3NwLnBraS5n +dmEuZXMwEgYDVR0TAQH/BAgwBgEB/wIBAjCCAjQGA1UdIASCAiswggInMIICIwYKKwYBBAG/VQIB +ADCCAhMwggHoBggrBgEFBQcCAjCCAdoeggHWAEEAdQB0AG8AcgBpAGQAYQBkACAAZABlACAAQwBl +AHIAdABpAGYAaQBjAGEAYwBpAPMAbgAgAFIAYQDtAHoAIABkAGUAIABsAGEAIABHAGUAbgBlAHIA +YQBsAGkAdABhAHQAIABWAGEAbABlAG4AYwBpAGEAbgBhAC4ADQAKAEwAYQAgAEQAZQBjAGwAYQBy +AGEAYwBpAPMAbgAgAGQAZQAgAFAAcgDhAGMAdABpAGMAYQBzACAAZABlACAAQwBlAHIAdABpAGYA +aQBjAGEAYwBpAPMAbgAgAHEAdQBlACAAcgBpAGcAZQAgAGUAbAAgAGYAdQBuAGMAaQBvAG4AYQBt +AGkAZQBuAHQAbwAgAGQAZQAgAGwAYQAgAHAAcgBlAHMAZQBuAHQAZQAgAEEAdQB0AG8AcgBpAGQA +YQBkACAAZABlACAAQwBlAHIAdABpAGYAaQBjAGEAYwBpAPMAbgAgAHMAZQAgAGUAbgBjAHUAZQBu +AHQAcgBhACAAZQBuACAAbABhACAAZABpAHIAZQBjAGMAaQDzAG4AIAB3AGUAYgAgAGgAdAB0AHAA +OgAvAC8AdwB3AHcALgBwAGsAaQAuAGcAdgBhAC4AZQBzAC8AYwBwAHMwJQYIKwYBBQUHAgEWGWh0 +dHA6Ly93d3cucGtpLmd2YS5lcy9jcHMwHQYDVR0OBBYEFHs100DSHHgZZu90ECjcPk+yeAT8MIGV +BgNVHSMEgY0wgYqAFHs100DSHHgZZu90ECjcPk+yeAT8oWykajBoMQswCQYDVQQGEwJFUzEfMB0G +A1UEChMWR2VuZXJhbGl0YXQgVmFsZW5jaWFuYTEPMA0GA1UECxMGUEtJR1ZBMScwJQYDVQQDEx5S +b290IENBIEdlbmVyYWxpdGF0IFZhbGVuY2lhbmGCBDtF5WgwDQYJKoZIhvcNAQEFBQADggEBACRh +TvW1yEICKrNcda3FbcrnlD+laJWIwVTAEGmiEi8YPyVQqHxK6sYJ2fR1xkDar1CdPaUWu20xxsdz +Ckj+IHLtb8zog2EWRpABlUt9jppSCS/2bxzkoXHPjCpaF3ODR00PNvsETUlR4hTJZGH71BTg9J63 +NI8KJr2XXPR5OkowGcytT6CYirQxlyric21+eLj4iIlPsSKRZEv1UN4D2+XFducTZnV+ZfsBn5OH +iJ35Rld8TWCvmHMTI6QgkYH60GFmuH3Rr9ZvHmw96RH9qfmCIoaZM3Fa6hlXPZHNqcCjbgcTpsnt ++GijnsNacgmHKNHEc8RzGF9QdRYxn7fofMM= +-----END CERTIFICATE----- + +A-Trust-nQual-03 +================ +-----BEGIN CERTIFICATE----- +MIIDzzCCAregAwIBAgIDAWweMA0GCSqGSIb3DQEBBQUAMIGNMQswCQYDVQQGEwJBVDFIMEYGA1UE +Cgw/QS1UcnVzdCBHZXMuIGYuIFNpY2hlcmhlaXRzc3lzdGVtZSBpbSBlbGVrdHIuIERhdGVudmVy +a2VociBHbWJIMRkwFwYDVQQLDBBBLVRydXN0LW5RdWFsLTAzMRkwFwYDVQQDDBBBLVRydXN0LW5R +dWFsLTAzMB4XDTA1MDgxNzIyMDAwMFoXDTE1MDgxNzIyMDAwMFowgY0xCzAJBgNVBAYTAkFUMUgw +RgYDVQQKDD9BLVRydXN0IEdlcy4gZi4gU2ljaGVyaGVpdHNzeXN0ZW1lIGltIGVsZWt0ci4gRGF0 +ZW52ZXJrZWhyIEdtYkgxGTAXBgNVBAsMEEEtVHJ1c3QtblF1YWwtMDMxGTAXBgNVBAMMEEEtVHJ1 +c3QtblF1YWwtMDMwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQCtPWFuA/OQO8BBC4SA +zewqo51ru27CQoT3URThoKgtUaNR8t4j8DRE/5TrzAUjlUC5B3ilJfYKvUWG6Nm9wASOhURh73+n +yfrBJcyFLGM/BWBzSQXgYHiVEEvc+RFZznF/QJuKqiTfC0Li21a8StKlDJu3Qz7dg9MmEALP6iPE +SU7l0+m0iKsMrmKS1GWH2WrX9IWf5DMiJaXlyDO6w8dB3F/GaswADm0yqLaHNgBid5seHzTLkDx4 +iHQF63n1k3Flyp3HaxgtPVxO59X4PzF9j4fsCiIvI+n+u33J4PTs63zEsMMtYrWacdaxaujs2e3V +cuy+VwHOBVWf3tFgiBCzAgMBAAGjNjA0MA8GA1UdEwEB/wQFMAMBAf8wEQYDVR0OBAoECERqlWdV +eRFPMA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQUFAAOCAQEAVdRU0VlIXLOThaq/Yy/kgM40 +ozRiPvbY7meIMQQDbwvUB/tOdQ/TLtPAF8fGKOwGDREkDg6lXb+MshOWcdzUzg4NCmgybLlBMRmr +sQd7TZjTXLDR8KdCoLXEjq/+8T/0709GAHbrAvv5ndJAlseIOrifEXnzgGWovR/TeIGgUUw3tKZd +JXDRZslo+S4RFGjxVJgIrCaSD96JntT6s3kr0qN51OyLrIdTaEJMUVF0HhsnLuP1Hyl0Te2v9+GS +mYHovjrHF1D2t8b8m7CKa9aIA5GPBnc6hQLdmNVDeD/GMBWsm2vLV7eJUYs66MmEDNuxUCAKGkq6 +ahq97BvIxYSazQ== +-----END CERTIFICATE----- + +TWCA Root Certification Authority +================================= +-----BEGIN CERTIFICATE----- +MIIDezCCAmOgAwIBAgIBATANBgkqhkiG9w0BAQUFADBfMQswCQYDVQQGEwJUVzESMBAGA1UECgwJ +VEFJV0FOLUNBMRAwDgYDVQQLDAdSb290IENBMSowKAYDVQQDDCFUV0NBIFJvb3QgQ2VydGlmaWNh +dGlvbiBBdXRob3JpdHkwHhcNMDgwODI4MDcyNDMzWhcNMzAxMjMxMTU1OTU5WjBfMQswCQYDVQQG +EwJUVzESMBAGA1UECgwJVEFJV0FOLUNBMRAwDgYDVQQLDAdSb290IENBMSowKAYDVQQDDCFUV0NB +IFJvb3QgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEK +AoIBAQCwfnK4pAOU5qfeCTiRShFAh6d8WWQUe7UREN3+v9XAu1bihSX0NXIP+FPQQeFEAcK0HMMx +QhZHhTMidrIKbw/lJVBPhYa+v5guEGcevhEFhgWQxFnQfHgQsIBct+HHK3XLfJ+utdGdIzdjp9xC +oi2SBBtQwXu4PhvJVgSLL1KbralW6cH/ralYhzC2gfeXRfwZVzsrb+RH9JlF/h3x+JejiB03HFyP +4HYlmlD4oFT/RJB2I9IyxsOrBr/8+7/zrX2SYgJbKdM1o5OaQ2RgXbL6Mv87BK9NQGr5x+PvI/1r +y+UPizgN7gr8/g+YnzAx3WxSZfmLgb4i4RxYA7qRG4kHAgMBAAGjQjBAMA4GA1UdDwEB/wQEAwIB +BjAPBgNVHRMBAf8EBTADAQH/MB0GA1UdDgQWBBRqOFsmjd6LWvJPelSDGRjjCDWmujANBgkqhkiG +9w0BAQUFAAOCAQEAPNV3PdrfibqHDAhUaiBQkr6wQT25JmSDCi/oQMCXKCeCMErJk/9q56YAf4lC +mtYR5VPOL8zy2gXE/uJQxDqGfczafhAJO5I1KlOy/usrBdlsXebQ79NqZp4VKIV66IIArB6nCWlW +QtNoURi+VJq/REG6Sb4gumlc7rh3zc5sH62Dlhh9DrUUOYTxKOkto557HnpyWoOzeW/vtPzQCqVY +T0bf+215WfKEIlKuD8z7fDvnaspHYcN6+NOSBB+4IIThNlQWx0DeO4pz3N/GCUzf7Nr/1FNCocny +Yh0igzyXxfkZYiesZSLX0zzG5Y6yU8xJzrww/nsOM5D77dIUkR8Hrw== +-----END CERTIFICATE----- + +Security Communication RootCA2 +============================== +-----BEGIN CERTIFICATE----- +MIIDdzCCAl+gAwIBAgIBADANBgkqhkiG9w0BAQsFADBdMQswCQYDVQQGEwJKUDElMCMGA1UEChMc +U0VDT00gVHJ1c3QgU3lzdGVtcyBDTy4sTFRELjEnMCUGA1UECxMeU2VjdXJpdHkgQ29tbXVuaWNh +dGlvbiBSb290Q0EyMB4XDTA5MDUyOTA1MDAzOVoXDTI5MDUyOTA1MDAzOVowXTELMAkGA1UEBhMC +SlAxJTAjBgNVBAoTHFNFQ09NIFRydXN0IFN5c3RlbXMgQ08uLExURC4xJzAlBgNVBAsTHlNlY3Vy +aXR5IENvbW11bmljYXRpb24gUm9vdENBMjCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEB +ANAVOVKxUrO6xVmCxF1SrjpDZYBLx/KWvNs2l9amZIyoXvDjChz335c9S672XewhtUGrzbl+dp++ ++T42NKA7wfYxEUV0kz1XgMX5iZnK5atq1LXaQZAQwdbWQonCv/Q4EpVMVAX3NuRFg3sUZdbcDE3R +3n4MqzvEFb46VqZab3ZpUql6ucjrappdUtAtCms1FgkQhNBqyjoGADdH5H5XTz+L62e4iKrFvlNV +spHEfbmwhRkGeC7bYRr6hfVKkaHnFtWOojnflLhwHyg/i/xAXmODPIMqGplrz95Zajv8bxbXH/1K +EOtOghY6rCcMU/Gt1SSwawNQwS08Ft1ENCcadfsCAwEAAaNCMEAwHQYDVR0OBBYEFAqFqXdlBZh8 +QIH4D5csOPEK7DzPMA4GA1UdDwEB/wQEAwIBBjAPBgNVHRMBAf8EBTADAQH/MA0GCSqGSIb3DQEB +CwUAA4IBAQBMOqNErLlFsceTfsgLCkLfZOoc7llsCLqJX2rKSpWeeo8HxdpFcoJxDjrSzG+ntKEj +u/Ykn8sX/oymzsLS28yN/HH8AynBbF0zX2S2ZTuJbxh2ePXcokgfGT+Ok+vx+hfuzU7jBBJV1uXk +3fs+BXziHV7Gp7yXT2g69ekuCkO2r1dcYmh8t/2jioSgrGK+KwmHNPBqAbubKVY8/gA3zyNs8U6q +tnRGEmyR7jTV7JqR50S+kDFy1UkC9gLl9B/rfNmWVan/7Ir5mUf/NVoCqgTLiluHcSmRvaS0eg29 +mvVXIwAHIRc/SjnRBUkLp7Y3gaVdjKozXoEofKd9J+sAro03 +-----END CERTIFICATE----- + +EC-ACC +====== +-----BEGIN CERTIFICATE----- +MIIFVjCCBD6gAwIBAgIQ7is969Qh3hSoYqwE893EATANBgkqhkiG9w0BAQUFADCB8zELMAkGA1UE +BhMCRVMxOzA5BgNVBAoTMkFnZW5jaWEgQ2F0YWxhbmEgZGUgQ2VydGlmaWNhY2lvIChOSUYgUS0w +ODAxMTc2LUkpMSgwJgYDVQQLEx9TZXJ2ZWlzIFB1YmxpY3MgZGUgQ2VydGlmaWNhY2lvMTUwMwYD +VQQLEyxWZWdldSBodHRwczovL3d3dy5jYXRjZXJ0Lm5ldC92ZXJhcnJlbCAoYykwMzE1MDMGA1UE +CxMsSmVyYXJxdWlhIEVudGl0YXRzIGRlIENlcnRpZmljYWNpbyBDYXRhbGFuZXMxDzANBgNVBAMT +BkVDLUFDQzAeFw0wMzAxMDcyMzAwMDBaFw0zMTAxMDcyMjU5NTlaMIHzMQswCQYDVQQGEwJFUzE7 +MDkGA1UEChMyQWdlbmNpYSBDYXRhbGFuYSBkZSBDZXJ0aWZpY2FjaW8gKE5JRiBRLTA4MDExNzYt +SSkxKDAmBgNVBAsTH1NlcnZlaXMgUHVibGljcyBkZSBDZXJ0aWZpY2FjaW8xNTAzBgNVBAsTLFZl +Z2V1IGh0dHBzOi8vd3d3LmNhdGNlcnQubmV0L3ZlcmFycmVsIChjKTAzMTUwMwYDVQQLEyxKZXJh +cnF1aWEgRW50aXRhdHMgZGUgQ2VydGlmaWNhY2lvIENhdGFsYW5lczEPMA0GA1UEAxMGRUMtQUND +MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAsyLHT+KXQpWIR4NA9h0X84NzJB5R85iK +w5K4/0CQBXCHYMkAqbWUZRkiFRfCQ2xmRJoNBD45b6VLeqpjt4pEndljkYRm4CgPukLjbo73FCeT +ae6RDqNfDrHrZqJyTxIThmV6PttPB/SnCWDaOkKZx7J/sxaVHMf5NLWUhdWZXqBIoH7nF2W4onW4 +HvPlQn2v7fOKSGRdghST2MDk/7NQcvJ29rNdQlB50JQ+awwAvthrDk4q7D7SzIKiGGUzE3eeml0a +E9jD2z3Il3rucO2n5nzbcc8tlGLfbdb1OL4/pYUKGbio2Al1QnDE6u/LDsg0qBIimAy4E5S2S+zw +0JDnJwIDAQABo4HjMIHgMB0GA1UdEQQWMBSBEmVjX2FjY0BjYXRjZXJ0Lm5ldDAPBgNVHRMBAf8E +BTADAQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUoMOLRKo3pUW/l4Ba0fF4opvpXY0wfwYD +VR0gBHgwdjB0BgsrBgEEAfV4AQMBCjBlMCwGCCsGAQUFBwIBFiBodHRwczovL3d3dy5jYXRjZXJ0 +Lm5ldC92ZXJhcnJlbDA1BggrBgEFBQcCAjApGidWZWdldSBodHRwczovL3d3dy5jYXRjZXJ0Lm5l +dC92ZXJhcnJlbCAwDQYJKoZIhvcNAQEFBQADggEBAKBIW4IB9k1IuDlVNZyAelOZ1Vr/sXE7zDkJ +lF7W2u++AVtd0x7Y/X1PzaBB4DSTv8vihpw3kpBWHNzrKQXlxJ7HNd+KDM3FIUPpqojlNcAZQmNa +Al6kSBg6hW/cnbw/nZzBh7h6YQjpdwt/cKt63dmXLGQehb+8dJahw3oS7AwaboMMPOhyRp/7SNVe +l+axofjk70YllJyJ22k4vuxcDlbHZVHlUIiIv0LVKz3l+bqeLrPK9HOSAgu+TGbrIP65y7WZf+a2 +E/rKS03Z7lNGBjvGTq2TWoF+bCpLagVFjPIhpDGQh2xlnJ2lYJU6Un/10asIbvPuW/mIPX64b24D +5EI= +-----END CERTIFICATE----- + +Hellenic Academic and Research Institutions RootCA 2011 +======================================================= +-----BEGIN CERTIFICATE----- +MIIEMTCCAxmgAwIBAgIBADANBgkqhkiG9w0BAQUFADCBlTELMAkGA1UEBhMCR1IxRDBCBgNVBAoT +O0hlbGxlbmljIEFjYWRlbWljIGFuZCBSZXNlYXJjaCBJbnN0aXR1dGlvbnMgQ2VydC4gQXV0aG9y +aXR5MUAwPgYDVQQDEzdIZWxsZW5pYyBBY2FkZW1pYyBhbmQgUmVzZWFyY2ggSW5zdGl0dXRpb25z +IFJvb3RDQSAyMDExMB4XDTExMTIwNjEzNDk1MloXDTMxMTIwMTEzNDk1MlowgZUxCzAJBgNVBAYT +AkdSMUQwQgYDVQQKEztIZWxsZW5pYyBBY2FkZW1pYyBhbmQgUmVzZWFyY2ggSW5zdGl0dXRpb25z +IENlcnQuIEF1dGhvcml0eTFAMD4GA1UEAxM3SGVsbGVuaWMgQWNhZGVtaWMgYW5kIFJlc2VhcmNo +IEluc3RpdHV0aW9ucyBSb290Q0EgMjAxMTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoCggEB +AKlTAOMupvaO+mDYLZU++CwqVE7NuYRhlFhPjz2L5EPzdYmNUeTDN9KKiE15HrcS3UN4SoqS5tdI +1Q+kOilENbgH9mgdVc04UfCMJDGFr4PJfel3r+0ae50X+bOdOFAPplp5kYCvN66m0zH7tSYJnTxa +71HFK9+WXesyHgLacEnsbgzImjeN9/E2YEsmLIKe0HjzDQ9jpFEw4fkrJxIH2Oq9GGKYsFk3fb7u +8yBRQlqD75O6aRXxYp2fmTmCobd0LovUxQt7L/DICto9eQqakxylKHJzkUOap9FNhYS5qXSPFEDH +3N6sQWRstBmbAmNtJGSPRLIl6s5ddAxjMlyNh+UCAwEAAaOBiTCBhjAPBgNVHRMBAf8EBTADAQH/ +MAsGA1UdDwQEAwIBBjAdBgNVHQ4EFgQUppFC/RNhSiOeCKQp5dgTBCPuQSUwRwYDVR0eBEAwPqA8 +MAWCAy5ncjAFggMuZXUwBoIELmVkdTAGggQub3JnMAWBAy5ncjAFgQMuZXUwBoEELmVkdTAGgQQu +b3JnMA0GCSqGSIb3DQEBBQUAA4IBAQAf73lB4XtuP7KMhjdCSk4cNx6NZrokgclPEg8hwAOXhiVt +XdMiKahsog2p6z0GW5k6x8zDmjR/qw7IThzh+uTczQ2+vyT+bOdrwg3IBp5OjWEopmr95fZi6hg8 +TqBTnbI6nOulnJEWtk2C4AwFSKls9cz4y51JtPACpf1wA+2KIaWuE4ZJwzNzvoc7dIsXRSZMFpGD +/md9zU1jZ/rzAxKWeAaNsWftjj++n08C9bMJL/NMh98qy5V8AcysNnq/onN694/BtZqhFLKPM58N +7yLcZnuEvUUXBj08yrl3NI/K6s8/MT7jiOOASSXIl7WdmplNsDz4SgCbZN2fOUvRJ9e4 +-----END CERTIFICATE----- + +Actalis Authentication Root CA +============================== +-----BEGIN CERTIFICATE----- +MIIFuzCCA6OgAwIBAgIIVwoRl0LE48wwDQYJKoZIhvcNAQELBQAwazELMAkGA1UEBhMCSVQxDjAM +BgNVBAcMBU1pbGFuMSMwIQYDVQQKDBpBY3RhbGlzIFMucC5BLi8wMzM1ODUyMDk2NzEnMCUGA1UE +AwweQWN0YWxpcyBBdXRoZW50aWNhdGlvbiBSb290IENBMB4XDTExMDkyMjExMjIwMloXDTMwMDky +MjExMjIwMlowazELMAkGA1UEBhMCSVQxDjAMBgNVBAcMBU1pbGFuMSMwIQYDVQQKDBpBY3RhbGlz +IFMucC5BLi8wMzM1ODUyMDk2NzEnMCUGA1UEAwweQWN0YWxpcyBBdXRoZW50aWNhdGlvbiBSb290 +IENBMIICIjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAp8bEpSmkLO/lGMWwUKNvUTufClrJ +wkg4CsIcoBh/kbWHuUA/3R1oHwiD1S0eiKD4j1aPbZkCkpAW1V8IbInX4ay8IMKx4INRimlNAJZa +by/ARH6jDuSRzVju3PvHHkVH3Se5CAGfpiEd9UEtL0z9KK3giq0itFZljoZUj5NDKd45RnijMCO6 +zfB9E1fAXdKDa0hMxKufgFpbOr3JpyI/gCczWw63igxdBzcIy2zSekciRDXFzMwujt0q7bd9Zg1f +YVEiVRvjRuPjPdA1YprbrxTIW6HMiRvhMCb8oJsfgadHHwTrozmSBp+Z07/T6k9QnBn+locePGX2 +oxgkg4YQ51Q+qDp2JE+BIcXjDwL4k5RHILv+1A7TaLndxHqEguNTVHnd25zS8gebLra8Pu2Fbe8l +EfKXGkJh90qX6IuxEAf6ZYGyojnP9zz/GPvG8VqLWeICrHuS0E4UT1lF9gxeKF+w6D9Fz8+vm2/7 +hNN3WpVvrJSEnu68wEqPSpP4RCHiMUVhUE4Q2OM1fEwZtN4Fv6MGn8i1zeQf1xcGDXqVdFUNaBr8 +EBtiZJ1t4JWgw5QHVw0U5r0F+7if5t+L4sbnfpb2U8WANFAoWPASUHEXMLrmeGO89LKtmyuy/uE5 +jF66CyCU3nuDuP/jVo23Eek7jPKxwV2dpAtMK9myGPW1n0sCAwEAAaNjMGEwHQYDVR0OBBYEFFLY +iDrIn3hm7YnzezhwlMkCAjbQMA8GA1UdEwEB/wQFMAMBAf8wHwYDVR0jBBgwFoAUUtiIOsifeGbt +ifN7OHCUyQICNtAwDgYDVR0PAQH/BAQDAgEGMA0GCSqGSIb3DQEBCwUAA4ICAQALe3KHwGCmSUyI +WOYdiPcUZEim2FgKDk8TNd81HdTtBjHIgT5q1d07GjLukD0R0i70jsNjLiNmsGe+b7bAEzlgqqI0 +JZN1Ut6nna0Oh4lScWoWPBkdg/iaKWW+9D+a2fDzWochcYBNy+A4mz+7+uAwTc+G02UQGRjRlwKx +K3JCaKygvU5a2hi/a5iB0P2avl4VSM0RFbnAKVy06Ij3Pjaut2L9HmLecHgQHEhb2rykOLpn7VU+ +Xlff1ANATIGk0k9jpwlCCRT8AKnCgHNPLsBA2RF7SOp6AsDT6ygBJlh0wcBzIm2Tlf05fbsq4/aC +4yyXX04fkZT6/iyj2HYauE2yOE+b+h1IYHkm4vP9qdCa6HCPSXrW5b0KDtst842/6+OkfcvHlXHo +2qN8xcL4dJIEG4aspCJTQLas/kx2z/uUMsA1n3Y/buWQbqCmJqK4LL7RK4X9p2jIugErsWx0Hbhz +lefut8cl8ABMALJ+tguLHPPAUJ4lueAI3jZm/zel0btUZCzJJ7VLkn5l/9Mt4blOvH+kQSGQQXem +OR/qnuOf0GZvBeyqdn6/axag67XH/JJULysRJyU3eExRarDzzFhdFPFqSBX/wge2sY0PjlxQRrM9 +vwGYT7JZVEc+NHt4bVaTLnPqZih4zR0Uv6CPLy64Lo7yFIrM6bV8+2ydDKXhlg== +-----END CERTIFICATE----- + +Trustis FPS Root CA +=================== +-----BEGIN CERTIFICATE----- +MIIDZzCCAk+gAwIBAgIQGx+ttiD5JNM2a/fH8YygWTANBgkqhkiG9w0BAQUFADBFMQswCQYDVQQG +EwJHQjEYMBYGA1UEChMPVHJ1c3RpcyBMaW1pdGVkMRwwGgYDVQQLExNUcnVzdGlzIEZQUyBSb290 +IENBMB4XDTAzMTIyMzEyMTQwNloXDTI0MDEyMTExMzY1NFowRTELMAkGA1UEBhMCR0IxGDAWBgNV +BAoTD1RydXN0aXMgTGltaXRlZDEcMBoGA1UECxMTVHJ1c3RpcyBGUFMgUm9vdCBDQTCCASIwDQYJ +KoZIhvcNAQEBBQADggEPADCCAQoCggEBAMVQe547NdDfxIzNjpvto8A2mfRC6qc+gIMPpqdZh8mQ +RUN+AOqGeSoDvT03mYlmt+WKVoaTnGhLaASMk5MCPjDSNzoiYYkchU59j9WvezX2fihHiTHcDnlk +H5nSW7r+f2C/revnPDgpai/lkQtV/+xvWNUtyd5MZnGPDNcE2gfmHhjjvSkCqPoc4Vu5g6hBSLwa +cY3nYuUtsuvffM/bq1rKMfFMIvMFE/eC+XN5DL7XSxzA0RU8k0Fk0ea+IxciAIleH2ulrG6nS4zt +o3Lmr2NNL4XSFDWaLk6M6jKYKIahkQlBOrTh4/L68MkKokHdqeMDx4gVOxzUGpTXn2RZEm0CAwEA +AaNTMFEwDwYDVR0TAQH/BAUwAwEB/zAfBgNVHSMEGDAWgBS6+nEleYtXQSUhhgtx67JkDoshZzAd +BgNVHQ4EFgQUuvpxJXmLV0ElIYYLceuyZA6LIWcwDQYJKoZIhvcNAQEFBQADggEBAH5Y//01GX2c +GE+esCu8jowU/yyg2kdbw++BLa8F6nRIW/M+TgfHbcWzk88iNVy2P3UnXwmWzaD+vkAMXBJV+JOC +yinpXj9WV4s4NvdFGkwozZ5BuO1WTISkQMi4sKUraXAEasP41BIy+Q7DsdwyhEQsb8tGD+pmQQ9P +8Vilpg0ND2HepZ5dfWWhPBfnqFVO76DH7cZEf1T1o+CP8HxVIo8ptoGj4W1OLBuAZ+ytIJ8MYmHV +l/9D7S3B2l0pKoU/rGXuhg8FjZBf3+6f9L/uHfuY5H+QK4R4EA5sSVPvFVtlRkpdr7r7OnIdzfYl +iB6XzCGcKQENZetX2fNXlrtIzYE= +-----END CERTIFICATE----- + +StartCom Certification Authority +================================ +-----BEGIN CERTIFICATE----- +MIIHhzCCBW+gAwIBAgIBLTANBgkqhkiG9w0BAQsFADB9MQswCQYDVQQGEwJJTDEWMBQGA1UEChMN +U3RhcnRDb20gTHRkLjErMCkGA1UECxMiU2VjdXJlIERpZ2l0YWwgQ2VydGlmaWNhdGUgU2lnbmlu +ZzEpMCcGA1UEAxMgU3RhcnRDb20gQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMDYwOTE3MTk0 +NjM3WhcNMzYwOTE3MTk0NjM2WjB9MQswCQYDVQQGEwJJTDEWMBQGA1UEChMNU3RhcnRDb20gTHRk +LjErMCkGA1UECxMiU2VjdXJlIERpZ2l0YWwgQ2VydGlmaWNhdGUgU2lnbmluZzEpMCcGA1UEAxMg +U3RhcnRDb20gQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAw +ggIKAoICAQDBiNsJvGxGfHiflXu1M5DycmLWwTYgIiRezul38kMKogZkpMyONvg45iPwbm2xPN1y +o4UcodM9tDMr0y+v/uqwQVlntsQGfQqedIXWeUyAN3rfOQVSWff0G0ZDpNKFhdLDcfN1YjS6LIp/ +Ho/u7TTQEceWzVI9ujPW3U3eCztKS5/CJi/6tRYccjV3yjxd5srhJosaNnZcAdt0FCX+7bWgiA/d +eMotHweXMAEtcnn6RtYTKqi5pquDSR3l8u/d5AGOGAqPY1MWhWKpDhk6zLVmpsJrdAfkK+F2PrRt +2PZE4XNiHzvEvqBTViVsUQn3qqvKv3b9bZvzndu/PWa8DFaqr5hIlTpL36dYUNk4dalb6kMMAv+Z +6+hsTXBbKWWc3apdzK8BMewM69KN6Oqce+Zu9ydmDBpI125C4z/eIT574Q1w+2OqqGwaVLRcJXrJ +osmLFqa7LH4XXgVNWG4SHQHuEhANxjJ/GP/89PrNbpHoNkm+Gkhpi8KWTRoSsmkXwQqQ1vp5Iki/ +untp+HDH+no32NgN0nZPV/+Qt+OR0t3vwmC3Zzrd/qqc8NSLf3Iizsafl7b4r4qgEKjZ+xjGtrVc +UjyJthkqcwEKDwOzEmDyei+B26Nu/yYwl/WL3YlXtq09s68rxbd2AvCl1iuahhQqcvbjM4xdCUsT +37uMdBNSSwIDAQABo4ICEDCCAgwwDwYDVR0TAQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYD +VR0OBBYEFE4L7xqkQFulF2mHMMo0aEPQQa7yMB8GA1UdIwQYMBaAFE4L7xqkQFulF2mHMMo0aEPQ +Qa7yMIIBWgYDVR0gBIIBUTCCAU0wggFJBgsrBgEEAYG1NwEBATCCATgwLgYIKwYBBQUHAgEWImh0 +dHA6Ly93d3cuc3RhcnRzc2wuY29tL3BvbGljeS5wZGYwNAYIKwYBBQUHAgEWKGh0dHA6Ly93d3cu +c3RhcnRzc2wuY29tL2ludGVybWVkaWF0ZS5wZGYwgc8GCCsGAQUFBwICMIHCMCcWIFN0YXJ0IENv +bW1lcmNpYWwgKFN0YXJ0Q29tKSBMdGQuMAMCAQEagZZMaW1pdGVkIExpYWJpbGl0eSwgcmVhZCB0 +aGUgc2VjdGlvbiAqTGVnYWwgTGltaXRhdGlvbnMqIG9mIHRoZSBTdGFydENvbSBDZXJ0aWZpY2F0 +aW9uIEF1dGhvcml0eSBQb2xpY3kgYXZhaWxhYmxlIGF0IGh0dHA6Ly93d3cuc3RhcnRzc2wuY29t +L3BvbGljeS5wZGYwEQYJYIZIAYb4QgEBBAQDAgAHMDgGCWCGSAGG+EIBDQQrFilTdGFydENvbSBG +cmVlIFNTTCBDZXJ0aWZpY2F0aW9uIEF1dGhvcml0eTANBgkqhkiG9w0BAQsFAAOCAgEAjo/n3JR5 +fPGFf59Jb2vKXfuM/gTFwWLRfUKKvFO3lANmMD+x5wqnUCBVJX92ehQN6wQOQOY+2IirByeDqXWm +N3PH/UvSTa0XQMhGvjt/UfzDtgUx3M2FIk5xt/JxXrAaxrqTi3iSSoX4eA+D/i+tLPfkpLst0OcN +Org+zvZ49q5HJMqjNTbOx8aHmNrs++myziebiMMEofYLWWivydsQD032ZGNcpRJvkrKTlMeIFw6T +tn5ii5B/q06f/ON1FE8qMt9bDeD1e5MNq6HPh+GlBEXoPBKlCcWw0bdT82AUuoVpaiF8H3VhFyAX +e2w7QSlc4axa0c2Mm+tgHRns9+Ww2vl5GKVFP0lDV9LdJNUso/2RjSe15esUBppMeyG7Oq0wBhjA +2MFrLH9ZXF2RsXAiV+uKa0hK1Q8p7MZAwC+ITGgBF3f0JBlPvfrhsiAhS90a2Cl9qrjeVOwhVYBs +HvUwyKMQ5bLmKhQxw4UtjJixhlpPiVktucf3HMiKf8CdBUrmQk9io20ppB+Fq9vlgcitKj1MXVuE +JnHEhV5xJMqlG2zYYdMa4FTbzrqpMrUi9nNBCV24F10OD5mQ1kfabwo6YigUZ4LZ8dCAWZvLMdib +D4x3TrVoivJs9iQOLWxwxXPR3hTQcY+203sC9uO41Alua551hDnmfyWl8kgAwKQB2j8= +-----END CERTIFICATE----- + +StartCom Certification Authority G2 +=================================== +-----BEGIN CERTIFICATE----- +MIIFYzCCA0ugAwIBAgIBOzANBgkqhkiG9w0BAQsFADBTMQswCQYDVQQGEwJJTDEWMBQGA1UEChMN +U3RhcnRDb20gTHRkLjEsMCoGA1UEAxMjU3RhcnRDb20gQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkg +RzIwHhcNMTAwMTAxMDEwMDAxWhcNMzkxMjMxMjM1OTAxWjBTMQswCQYDVQQGEwJJTDEWMBQGA1UE +ChMNU3RhcnRDb20gTHRkLjEsMCoGA1UEAxMjU3RhcnRDb20gQ2VydGlmaWNhdGlvbiBBdXRob3Jp +dHkgRzIwggIiMA0GCSqGSIb3DQEBAQUAA4ICDwAwggIKAoICAQC2iTZbB7cgNr2Cu+EWIAOVeq8O +o1XJJZlKxdBWQYeQTSFgpBSHO839sj60ZwNq7eEPS8CRhXBF4EKe3ikj1AENoBB5uNsDvfOpL9HG +4A/LnooUCri99lZi8cVytjIl2bLzvWXFDSxu1ZJvGIsAQRSCb0AgJnooD/Uefyf3lLE3PbfHkffi +Aez9lInhzG7TNtYKGXmu1zSCZf98Qru23QumNK9LYP5/Q0kGi4xDuFby2X8hQxfqp0iVAXV16iul +Q5XqFYSdCI0mblWbq9zSOdIxHWDirMxWRST1HFSr7obdljKF+ExP6JV2tgXdNiNnvP8V4so75qbs +O+wmETRIjfaAKxojAuuKHDp2KntWFhxyKrOq42ClAJ8Em+JvHhRYW6Vsi1g8w7pOOlz34ZYrPu8H +vKTlXcxNnw3h3Kq74W4a7I/htkxNeXJdFzULHdfBR9qWJODQcqhaX2YtENwvKhOuJv4KHBnM0D4L +nMgJLvlblnpHnOl68wVQdJVznjAJ85eCXuaPOQgeWeU1FEIT/wCc976qUM/iUUjXuG+v+E5+M5iS +FGI6dWPPe/regjupuznixL0sAA7IF6wT700ljtizkC+p2il9Ha90OrInwMEePnWjFqmveiJdnxMa +z6eg6+OGCtP95paV1yPIN93EfKo2rJgaErHgTuixO/XWb/Ew1wIDAQABo0IwQDAPBgNVHRMBAf8E +BTADAQH/MA4GA1UdDwEB/wQEAwIBBjAdBgNVHQ4EFgQUS8W0QGutHLOlHGVuRjaJhwUMDrYwDQYJ +KoZIhvcNAQELBQADggIBAHNXPyzVlTJ+N9uWkusZXn5T50HsEbZH77Xe7XRcxfGOSeD8bpkTzZ+K +2s06Ctg6Wgk/XzTQLwPSZh0avZyQN8gMjgdalEVGKua+etqhqaRpEpKwfTbURIfXUfEpY9Z1zRbk +J4kd+MIySP3bmdCPX1R0zKxnNBFi2QwKN4fRoxdIjtIXHfbX/dtl6/2o1PXWT6RbdejF0mCy2wl+ +JYt7ulKSnj7oxXehPOBKc2thz4bcQ///If4jXSRK9dNtD2IEBVeC2m6kMyV5Sy5UGYvMLD0w6dEG +/+gyRr61M3Z3qAFdlsHB1b6uJcDJHgoJIIihDsnzb02CVAAgp9KP5DlUFy6NHrgbuxu9mk47EDTc +nIhT76IxW1hPkWLIwpqazRVdOKnWvvgTtZ8SafJQYqz7Fzf07rh1Z2AQ+4NQ+US1dZxAF7L+/Xld +blhYXzD8AK6vM8EOTmy6p6ahfzLbOOCxchcKK5HsamMm7YnUeMx0HgX4a/6ManY5Ka5lIxKVCCIc +l85bBu4M4ru8H0ST9tg4RQUh7eStqxK2A6RCLi3ECToDZ2mEmuFZkIoohdVddLHRDiBYmxOlsGOm +7XtH/UVVMKTumtTm4ofvmMkyghEpIrwACjFeLQ/Ajulrso8uBtjRkcfGEvRM/TAXw8HaOFvjqerm +obp573PYtlNXLfbQ4ddI +-----END CERTIFICATE----- + +Buypass Class 2 Root CA +======================= +-----BEGIN CERTIFICATE----- +MIIFWTCCA0GgAwIBAgIBAjANBgkqhkiG9w0BAQsFADBOMQswCQYDVQQGEwJOTzEdMBsGA1UECgwU +QnV5cGFzcyBBUy05ODMxNjMzMjcxIDAeBgNVBAMMF0J1eXBhc3MgQ2xhc3MgMiBSb290IENBMB4X +DTEwMTAyNjA4MzgwM1oXDTQwMTAyNjA4MzgwM1owTjELMAkGA1UEBhMCTk8xHTAbBgNVBAoMFEJ1 +eXBhc3MgQVMtOTgzMTYzMzI3MSAwHgYDVQQDDBdCdXlwYXNzIENsYXNzIDIgUm9vdCBDQTCCAiIw +DQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBANfHXvfBB9R3+0Mh9PT1aeTuMgHbo4Yf5FkNuud1 +g1Lr6hxhFUi7HQfKjK6w3Jad6sNgkoaCKHOcVgb/S2TwDCo3SbXlzwx87vFKu3MwZfPVL4O2fuPn +9Z6rYPnT8Z2SdIrkHJasW4DptfQxh6NR/Md+oW+OU3fUl8FVM5I+GC911K2GScuVr1QGbNgGE41b +/+EmGVnAJLqBcXmQRFBoJJRfuLMR8SlBYaNByyM21cHxMlAQTn/0hpPshNOOvEu/XAFOBz3cFIqU +CqTqc/sLUegTBxj6DvEr0VQVfTzh97QZQmdiXnfgolXsttlpF9U6r0TtSsWe5HonfOV116rLJeff +awrbD02TTqigzXsu8lkBarcNuAeBfos4GzjmCleZPe4h6KP1DBbdi+w0jpwqHAAVF41og9JwnxgI +zRFo1clrUs3ERo/ctfPYV3Me6ZQ5BL/T3jjetFPsaRyifsSP5BtwrfKi+fv3FmRmaZ9JUaLiFRhn +Bkp/1Wy1TbMz4GHrXb7pmA8y1x1LPC5aAVKRCfLf6o3YBkBjqhHk/sM3nhRSP/TizPJhk9H9Z2vX +Uq6/aKtAQ6BXNVN48FP4YUIHZMbXb5tMOA1jrGKvNouicwoN9SG9dKpN6nIDSdvHXx1iY8f93ZHs +M+71bbRuMGjeyNYmsHVee7QHIJihdjK4TWxPAgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wHQYD +VR0OBBYEFMmAd+BikoL1RpzzuvdMw964o605MA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQsF +AAOCAgEAU18h9bqwOlI5LJKwbADJ784g7wbylp7ppHR/ehb8t/W2+xUbP6umwHJdELFx7rxP462s +A20ucS6vxOOto70MEae0/0qyexAQH6dXQbLArvQsWdZHEIjzIVEpMMpghq9Gqx3tOluwlN5E40EI +osHsHdb9T7bWR9AUC8rmyrV7d35BH16Dx7aMOZawP5aBQW9gkOLo+fsicdl9sz1Gv7SEr5AcD48S +aq/v7h56rgJKihcrdv6sVIkkLE8/trKnToyokZf7KcZ7XC25y2a2t6hbElGFtQl+Ynhw/qlqYLYd +DnkM/crqJIByw5c/8nerQyIKx+u2DISCLIBrQYoIwOula9+ZEsuK1V6ADJHgJgg2SMX6OBE1/yWD +LfJ6v9r9jv6ly0UsH8SIU653DtmadsWOLB2jutXsMq7Aqqz30XpN69QH4kj3Io6wpJ9qzo6ysmD0 +oyLQI+uUWnpp3Q+/QFesa1lQ2aOZ4W7+jQF5JyMV3pKdewlNWudLSDBaGOYKbeaP4NK75t98biGC +wWg5TbSYWGZizEqQXsP6JwSxeRV0mcy+rSDeJmAc61ZRpqPq5KM/p/9h3PFaTWwyI0PurKju7koS +CTxdccK+efrCh2gdC/1cacwG0Jp9VJkqyTkaGa9LKkPzY11aWOIv4x3kqdbQCtCev9eBCfHJxyYN +rJgWVqA= +-----END CERTIFICATE----- + +Buypass Class 3 Root CA +======================= +-----BEGIN CERTIFICATE----- +MIIFWTCCA0GgAwIBAgIBAjANBgkqhkiG9w0BAQsFADBOMQswCQYDVQQGEwJOTzEdMBsGA1UECgwU +QnV5cGFzcyBBUy05ODMxNjMzMjcxIDAeBgNVBAMMF0J1eXBhc3MgQ2xhc3MgMyBSb290IENBMB4X +DTEwMTAyNjA4Mjg1OFoXDTQwMTAyNjA4Mjg1OFowTjELMAkGA1UEBhMCTk8xHTAbBgNVBAoMFEJ1 +eXBhc3MgQVMtOTgzMTYzMzI3MSAwHgYDVQQDDBdCdXlwYXNzIENsYXNzIDMgUm9vdCBDQTCCAiIw +DQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAKXaCpUWUOOV8l6ddjEGMnqb8RB2uACatVI2zSRH +sJ8YZLya9vrVediQYkwiL944PdbgqOkcLNt4EemOaFEVcsfzM4fkoF0LXOBXByow9c3EN3coTRiR +5r/VUv1xLXA+58bEiuPwKAv0dpihi4dVsjoT/Lc+JzeOIuOoTyrvYLs9tznDDgFHmV0ST9tD+leh +7fmdvhFHJlsTmKtdFoqwNxxXnUX/iJY2v7vKB3tvh2PX0DJq1l1sDPGzbjniazEuOQAnFN44wOwZ +ZoYS6J1yFhNkUsepNxz9gjDthBgd9K5c/3ATAOux9TN6S9ZV+AWNS2mw9bMoNlwUxFFzTWsL8TQH +2xc519woe2v1n/MuwU8XKhDzzMro6/1rqy6any2CbgTUUgGTLT2G/H783+9CHaZr77kgxve9oKeV +/afmiSTYzIw0bOIjL9kSGiG5VZFvC5F5GQytQIgLcOJ60g7YaEi7ghM5EFjp2CoHxhLbWNvSO1UQ +RwUVZ2J+GGOmRj8JDlQyXr8NYnon74Do29lLBlo3WiXQCBJ31G8JUJc9yB3D34xFMFbG02SrZvPA +Xpacw8Tvw3xrizp5f7NJzz3iiZ+gMEuFuZyUJHmPfWupRWgPK9Dx2hzLabjKSWJtyNBjYt1gD1iq +j6G8BaVmos8bdrKEZLFMOVLAMLrwjEsCsLa3AgMBAAGjQjBAMA8GA1UdEwEB/wQFMAMBAf8wHQYD +VR0OBBYEFEe4zf/lb+74suwvTg75JbCOPGvDMA4GA1UdDwEB/wQEAwIBBjANBgkqhkiG9w0BAQsF +AAOCAgEAACAjQTUEkMJAYmDv4jVM1z+s4jSQuKFvdvoWFqRINyzpkMLyPPgKn9iB5btb2iUspKdV +cSQy9sgL8rxq+JOssgfCX5/bzMiKqr5qb+FJEMwx14C7u8jYog5kV+qi9cKpMRXSIGrs/CIBKM+G +uIAeqcwRpTzyFrNHnfzSgCHEy9BHcEGhyoMZCCxt8l13nIoUE9Q2HJLw5QY33KbmkJs4j1xrG0aG +Q0JfPgEHU1RdZX33inOhmlRaHylDFCfChQ+1iHsaO5S3HWCntZznKWlXWpuTekMwGwPXYshApqr8 +ZORK15FTAaggiG6cX0S5y2CBNOxv033aSF/rtJC8LakcC6wc1aJoIIAE1vyxjy+7SjENSoYc6+I2 +KSb12tjE8nVhz36udmNKekBlk4f4HoCMhuWG1o8O/FMsYOgWYRqiPkN7zTlgVGr18okmAWiDSKIz +6MkEkbIRNBE+6tBDGR8Dk5AM/1E9V/RBbuHLoL7ryWPNbczk+DaqaJ3tvV2XcEQNtg413OEMXbug +UZTLfhbrES+jkkXITHHZvMmZUldGL1DPvTVp9D0VzgalLA8+9oG6lLvDu79leNKGef9JOxqDDPDe +eOzI8k1MGt6CKfjBWtrt7uYnXuhF0J0cUahoq0Tj0Itq4/g7u9xN12TyUb7mqqta6THuBrxzvxNi +Cp/HuZc= +-----END CERTIFICATE----- + +T-TeleSec GlobalRoot Class 3 +============================ +-----BEGIN CERTIFICATE----- +MIIDwzCCAqugAwIBAgIBATANBgkqhkiG9w0BAQsFADCBgjELMAkGA1UEBhMCREUxKzApBgNVBAoM +IlQtU3lzdGVtcyBFbnRlcnByaXNlIFNlcnZpY2VzIEdtYkgxHzAdBgNVBAsMFlQtU3lzdGVtcyBU +cnVzdCBDZW50ZXIxJTAjBgNVBAMMHFQtVGVsZVNlYyBHbG9iYWxSb290IENsYXNzIDMwHhcNMDgx +MDAxMTAyOTU2WhcNMzMxMDAxMjM1OTU5WjCBgjELMAkGA1UEBhMCREUxKzApBgNVBAoMIlQtU3lz +dGVtcyBFbnRlcnByaXNlIFNlcnZpY2VzIEdtYkgxHzAdBgNVBAsMFlQtU3lzdGVtcyBUcnVzdCBD +ZW50ZXIxJTAjBgNVBAMMHFQtVGVsZVNlYyBHbG9iYWxSb290IENsYXNzIDMwggEiMA0GCSqGSIb3 +DQEBAQUAA4IBDwAwggEKAoIBAQC9dZPwYiJvJK7genasfb3ZJNW4t/zN8ELg63iIVl6bmlQdTQyK +9tPPcPRStdiTBONGhnFBSivwKixVA9ZIw+A5OO3yXDw/RLyTPWGrTs0NvvAgJ1gORH8EGoel15YU +NpDQSXuhdfsaa3Ox+M6pCSzyU9XDFES4hqX2iys52qMzVNn6chr3IhUciJFrf2blw2qAsCTz34ZF +iP0Zf3WHHx+xGwpzJFu5ZeAsVMhg02YXP+HMVDNzkQI6pn97djmiH5a2OK61yJN0HZ65tOVgnS9W +0eDrXltMEnAMbEQgqxHY9Bn20pxSN+f6tsIxO0rUFJmtxxr1XV/6B7h8DR/Wgx6zAgMBAAGjQjBA +MA8GA1UdEwEB/wQFMAMBAf8wDgYDVR0PAQH/BAQDAgEGMB0GA1UdDgQWBBS1A/d2O2GCahKqGFPr +AyGUv/7OyjANBgkqhkiG9w0BAQsFAAOCAQEAVj3vlNW92nOyWL6ukK2YJ5f+AbGwUgC4TeQbIXQb +fsDuXmkqJa9c1h3a0nnJ85cp4IaH3gRZD/FZ1GSFS5mvJQQeyUapl96Cshtwn5z2r3Ex3XsFpSzT +ucpH9sry9uetuUg/vBa3wW306gmv7PO15wWeph6KU1HWk4HMdJP2udqmJQV0eVp+QD6CSyYRMG7h +P0HHRwA11fXT91Q+gT3aSWqas+8QPebrb9HIIkfLzM8BMZLZGOMivgkeGj5asuRrDFR6fUNOuIml +e9eiPZaGzPImNC1qkp2aGtAw4l1OBLBfiyB+d8E9lYLRRpo7PHi4b6HQDWSieB4pTpPDpFQUWw== +-----END CERTIFICATE----- + +EE Certification Centre Root CA +=============================== +-----BEGIN CERTIFICATE----- +MIIEAzCCAuugAwIBAgIQVID5oHPtPwBMyonY43HmSjANBgkqhkiG9w0BAQUFADB1MQswCQYDVQQG +EwJFRTEiMCAGA1UECgwZQVMgU2VydGlmaXRzZWVyaW1pc2tlc2t1czEoMCYGA1UEAwwfRUUgQ2Vy +dGlmaWNhdGlvbiBDZW50cmUgUm9vdCBDQTEYMBYGCSqGSIb3DQEJARYJcGtpQHNrLmVlMCIYDzIw +MTAxMDMwMTAxMDMwWhgPMjAzMDEyMTcyMzU5NTlaMHUxCzAJBgNVBAYTAkVFMSIwIAYDVQQKDBlB +UyBTZXJ0aWZpdHNlZXJpbWlza2Vza3VzMSgwJgYDVQQDDB9FRSBDZXJ0aWZpY2F0aW9uIENlbnRy +ZSBSb290IENBMRgwFgYJKoZIhvcNAQkBFglwa2lAc2suZWUwggEiMA0GCSqGSIb3DQEBAQUAA4IB +DwAwggEKAoIBAQDIIMDs4MVLqwd4lfNE7vsLDP90jmG7sWLqI9iroWUyeuuOF0+W2Ap7kaJjbMeM +TC55v6kF/GlclY1i+blw7cNRfdCT5mzrMEvhvH2/UpvObntl8jixwKIy72KyaOBhU8E2lf/slLo2 +rpwcpzIP5Xy0xm90/XsY6KxX7QYgSzIwWFv9zajmofxwvI6Sc9uXp3whrj3B9UiHbCe9nyV0gVWw +93X2PaRka9ZP585ArQ/dMtO8ihJTmMmJ+xAdTX7Nfh9WDSFwhfYggx/2uh8Ej+p3iDXE/+pOoYtN +P2MbRMNE1CV2yreN1x5KZmTNXMWcg+HCCIia7E6j8T4cLNlsHaFLAgMBAAGjgYowgYcwDwYDVR0T +AQH/BAUwAwEB/zAOBgNVHQ8BAf8EBAMCAQYwHQYDVR0OBBYEFBLyWj7qVhy/zQas8fElyalL1BSZ +MEUGA1UdJQQ+MDwGCCsGAQUFBwMCBggrBgEFBQcDAQYIKwYBBQUHAwMGCCsGAQUFBwMEBggrBgEF +BQcDCAYIKwYBBQUHAwkwDQYJKoZIhvcNAQEFBQADggEBAHv25MANqhlHt01Xo/6tu7Fq1Q+e2+Rj +xY6hUFaTlrg4wCQiZrxTFGGVv9DHKpY5P30osxBAIWrEr7BSdxjhlthWXePdNl4dp1BUoMUq5KqM +lIpPnTX/dqQGE5Gion0ARD9V04I8GtVbvFZMIi5GQ4okQC3zErg7cBqklrkar4dBGmoYDQZPxz5u +uSlNDUmJEYcyW+ZLBMjkXOZ0c5RdFpgTlf7727FE5TpwrDdr5rMzcijJs1eg9gIWiAYLtqZLICjU +3j2LrTcFU3T+bsy8QxdxXvnFzBqpYe73dgzzcvRyrc9yAjYHR8/vGVCJYMzpJJUPwssd8m92kMfM +dcGWxZ0= +-----END CERTIFICATE----- + +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----- +MIIF2TCCA8GgAwIBAgIQHp4o6Ejy5e/DfEoeWhhntjANBgkqhkiG9w0BAQsFADBkMQswCQYDVQQG +EwJjaDERMA8GA1UEChMIU3dpc3Njb20xJTAjBgNVBAsTHERpZ2l0YWwgQ2VydGlmaWNhdGUgU2Vy +dmljZXMxGzAZBgNVBAMTElN3aXNzY29tIFJvb3QgQ0EgMjAeFw0xMTA2MjQwODM4MTRaFw0zMTA2 +MjUwNzM4MTRaMGQxCzAJBgNVBAYTAmNoMREwDwYDVQQKEwhTd2lzc2NvbTElMCMGA1UECxMcRGln +aXRhbCBDZXJ0aWZpY2F0ZSBTZXJ2aWNlczEbMBkGA1UEAxMSU3dpc3Njb20gUm9vdCBDQSAyMIIC +IjANBgkqhkiG9w0BAQEFAAOCAg8AMIICCgKCAgEAlUJOhJ1R5tMJ6HJaI2nbeHCOFvErjw0DzpPM +LgAIe6szjPTpQOYXTKueuEcUMncy3SgM3hhLX3af+Dk7/E6J2HzFZ++r0rk0X2s682Q2zsKwzxNo +ysjL67XiPS4h3+os1OD5cJZM/2pYmLcX5BtS5X4HAB1f2uY+lQS3aYg5oUFgJWFLlTloYhyxCwWJ +wDaCFCE/rtuh/bxvHGCGtlOUSbkrRsVPACu/obvLP+DHVxxX6NZp+MEkUp2IVd3Chy50I9AU/SpH +Wrumnf2U5NGKpV+GY3aFy6//SSj8gO1MedK75MDvAe5QQQg1I3ArqRa0jG6F6bYRzzHdUyYb3y1a +SgJA/MTAtukxGggo5WDDH8SQjhBiYEQN7Aq+VRhxLKX0srwVYv8c474d2h5Xszx+zYIdkeNL6yxS +NLCK/RJOlrDrcH+eOfdmQrGrrFLadkBXeyq96G4DsguAhYidDMfCd7Camlf0uPoTXGiTOmekl9Ab +mbeGMktg2M7v0Ax/lZ9vh0+Hio5fCHyqW/xavqGRn1V9TrALacywlKinh/LTSlDcX3KwFnUey7QY +Ypqwpzmqm59m2I2mbJYV4+by+PGDYmy7Velhk6M99bFXi08jsJvllGov34zflVEpYKELKeRcVVi3 +qPyZ7iVNTA6z00yPhOgpD/0QVAKFyPnlw4vP5w8CAwEAAaOBhjCBgzAOBgNVHQ8BAf8EBAMCAYYw +HQYDVR0hBBYwFDASBgdghXQBUwIBBgdghXQBUwIBMBIGA1UdEwEB/wQIMAYBAf8CAQcwHQYDVR0O +BBYEFE0mICKJS9PVpAqhb97iEoHF8TwuMB8GA1UdIwQYMBaAFE0mICKJS9PVpAqhb97iEoHF8Twu +MA0GCSqGSIb3DQEBCwUAA4ICAQAyCrKkG8t9voJXiblqf/P0wS4RfbgZPnm3qKhyN2abGu2sEzsO +v2LwnN+ee6FTSA5BesogpxcbtnjsQJHzQq0Qw1zv/2BZf82Fo4s9SBwlAjxnffUy6S8w5X2lejjQ +82YqZh6NM4OKb3xuqFp1mrjX2lhIREeoTPpMSQpKwhI3qEAMw8jh0FcNlzKVxzqfl9NX+Ave5XLz +o9v/tdhZsnPdTSpxsrpJ9csc1fV5yJmz/MFMdOO0vSk3FQQoHt5FRnDsr7p4DooqzgB53MBfGWcs +a0vvaGgLQ+OswWIJ76bdZWGgr4RVSJFSHMYlkSrQwSIjYVmvRRGFHQEkNI/Ps/8XciATwoCqISxx +OQ7Qj1zB09GOInJGTB2Wrk9xseEFKZZZ9LuedT3PDTcNYtsmjGOpI99nBjx8Oto0QuFmtEYE3saW +mA9LSHokMnWRn6z3aOkquVVlzl1h0ydw2Df+n7mvoC5Wt6NlUe07qxS/TFED6F+KBZvuim6c779o ++sjaC+NCydAXFJy3SuCvkychVSa1ZC+N8f+mQAWFBVzKBxlcCxMoTFh/wqXvRdpg065lYZ1Tg3TC +rvJcwhbtkj6EPnNgiLx29CzP0H1907he0ZESEOnN3col49XtmS++dYFLJPlFRpTJKSFTnCZFqhMX +5OfNeOI5wSsSnqaeG8XmDtkx2Q== +-----END CERTIFICATE----- + +Swisscom Root EV CA 2 +===================== +-----BEGIN CERTIFICATE----- +MIIF4DCCA8igAwIBAgIRAPL6ZOJ0Y9ON/RAdBB92ylgwDQYJKoZIhvcNAQELBQAwZzELMAkGA1UE +BhMCY2gxETAPBgNVBAoTCFN3aXNzY29tMSUwIwYDVQQLExxEaWdpdGFsIENlcnRpZmljYXRlIFNl +cnZpY2VzMR4wHAYDVQQDExVTd2lzc2NvbSBSb290IEVWIENBIDIwHhcNMTEwNjI0MDk0NTA4WhcN +MzEwNjI1MDg0NTA4WjBnMQswCQYDVQQGEwJjaDERMA8GA1UEChMIU3dpc3Njb20xJTAjBgNVBAsT +HERpZ2l0YWwgQ2VydGlmaWNhdGUgU2VydmljZXMxHjAcBgNVBAMTFVN3aXNzY29tIFJvb3QgRVYg +Q0EgMjCCAiIwDQYJKoZIhvcNAQEBBQADggIPADCCAgoCggIBAMT3HS9X6lds93BdY7BxUglgRCgz +o3pOCvrY6myLURYaVa5UJsTMRQdBTxB5f3HSek4/OE6zAMaVylvNwSqD1ycfMQ4jFrclyxy0uYAy +Xhqdk/HoPGAsp15XGVhRXrwsVgu42O+LgrQ8uMIkqBPHoCE2G3pXKSinLr9xJZDzRINpUKTk4Rti +GZQJo/PDvO/0vezbE53PnUgJUmfANykRHvvSEaeFGHR55E+FFOtSN+KxRdjMDUN/rhPSays/p8Li +qG12W0OfvrSdsyaGOx9/5fLoZigWJdBLlzin5M8J0TbDC77aO0RYjb7xnglrPvMyxyuHxuxenPaH +Za0zKcQvidm5y8kDnftslFGXEBuGCxobP/YCfnvUxVFkKJ3106yDgYjTdLRZncHrYTNaRdHLOdAG +alNgHa/2+2m8atwBz735j9m9W8E6X47aD0upm50qKGsaCnw8qyIL5XctcfaCNYGu+HuB5ur+rPQa +m3Rc6I8k9l2dRsQs0h4rIWqDJ2dVSqTjyDKXZpBy2uPUZC5f46Fq9mDU5zXNysRojddxyNMkM3Ox +bPlq4SjbX8Y96L5V5jcb7STZDxmPX2MYWFCBUWVv8p9+agTnNCRxunZLWB4ZvRVgRaoMEkABnRDi +xzgHcgplwLa7JSnaFp6LNYth7eVxV4O1PHGf40+/fh6Bn0GXAgMBAAGjgYYwgYMwDgYDVR0PAQH/ +BAQDAgGGMB0GA1UdIQQWMBQwEgYHYIV0AVMCAgYHYIV0AVMCAjASBgNVHRMBAf8ECDAGAQH/AgED +MB0GA1UdDgQWBBRF2aWBbj2ITY1x0kbBbkUe88SAnTAfBgNVHSMEGDAWgBRF2aWBbj2ITY1x0kbB +bkUe88SAnTANBgkqhkiG9w0BAQsFAAOCAgEAlDpzBp9SSzBc1P6xXCX5145v9Ydkn+0UjrgEjihL +j6p7jjm02Vj2e6E1CqGdivdj5eu9OYLU43otb98TPLr+flaYC/NUn81ETm484T4VvwYmneTwkLbU +wp4wLh/vx3rEUMfqe9pQy3omywC0Wqu1kx+AiYQElY2NfwmTv9SoqORjbdlk5LgpWgi/UOGED1V7 +XwgiG/W9mR4U9s70WBCCswo9GcG/W6uqmdjyMb3lOGbcWAXH7WMaLgqXfIeTK7KK4/HsGOV1timH +59yLGn602MnTihdsfSlEvoqq9X46Lmgxk7lq2prg2+kupYTNHAq4Sgj5nPFhJpiTt3tm7JFe3VE/ +23MPrQRYCd0EApUKPtN236YQHoA96M2kZNEzx5LH4k5E4wnJTsJdhw4Snr8PyQUQ3nqjsTzyP6Wq +J3mtMX0f/fwZacXduT98zca0wjAefm6S139hdlqP65VNvBFuIXxZN5nQBrz5Bm0yFqXZaajh3DyA +HmBR3NdUIR7KYndP+tiPsys6DXhyyWhBWkdKwqPrGtcKqzwyVcgKEZzfdNbwQBUdyLmPtTbFr/gi +uMod89a2GQ+fYWVq6nTIfI/DT11lgh/ZDYnadXL77/FHZxOzyNEZiCcmmpl5fx7kLD977vHeTYuW +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----- diff --git a/vendor/guzzle/guzzle/src/Guzzle/Http/StaticClient.php b/vendor/guzzle/guzzle/src/Guzzle/Http/StaticClient.php new file mode 100644 index 0000000..dbd4c18 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Http/Url.php b/vendor/guzzle/guzzle/src/Guzzle/Http/Url.php new file mode 100644 index 0000000..6a4e772 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Http/composer.json b/vendor/guzzle/guzzle/src/Guzzle/Http/composer.json new file mode 100644 index 0000000..9384a5b --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Http/composer.json @@ -0,0 +1,32 @@ +{ + "name": "guzzle/http", + "description": "HTTP libraries used by Guzzle", + "homepage": "http://guzzlephp.org/", + "keywords": ["http client", "http", "client", "Guzzle", "curl"], + "license": "MIT", + "authors": [ + { + "name": "Michael Dowling", + "email": "mtdowling@gmail.com", + "homepage": "https://github.com/mtdowling" + } + ], + "require": { + "php": ">=5.3.2", + "guzzle/common": "self.version", + "guzzle/parser": "self.version", + "guzzle/stream": "self.version" + }, + "suggest": { + "ext-curl": "*" + }, + "autoload": { + "psr-0": { "Guzzle\\Http": "" } + }, + "target-dir": "Guzzle/Http", + "extra": { + "branch-alias": { + "dev-master": "3.7-dev" + } + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Inflection/Inflector.php b/vendor/guzzle/guzzle/src/Guzzle/Inflection/Inflector.php new file mode 100644 index 0000000..c699773 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Inflection/PreComputedInflector.php b/vendor/guzzle/guzzle/src/Guzzle/Inflection/PreComputedInflector.php new file mode 100644 index 0000000..db37e4f --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Inflection/composer.json b/vendor/guzzle/guzzle/src/Guzzle/Inflection/composer.json new file mode 100644 index 0000000..93f9e7b --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Inflection/composer.json @@ -0,0 +1,26 @@ +{ + "name": "guzzle/inflection", + "description": "Guzzle inflection component", + "homepage": "http://guzzlephp.org/", + "keywords": ["inflection", "guzzle"], + "license": "MIT", + "authors": [ + { + "name": "Michael Dowling", + "email": "mtdowling@gmail.com", + "homepage": "https://github.com/mtdowling" + } + ], + "require": { + "php": ">=5.3.2" + }, + "autoload": { + "psr-0": { "Guzzle\\Inflection": "" } + }, + "target-dir": "Guzzle/Inflection", + "extra": { + "branch-alias": { + "dev-master": "3.7-dev" + } + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Iterator/AppendIterator.php b/vendor/guzzle/guzzle/src/Guzzle/Iterator/AppendIterator.php new file mode 100644 index 0000000..1b6bd7e --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Iterator/AppendIterator.php @@ -0,0 +1,19 @@ +getArrayIterator()->append($iterator); + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Iterator/ChunkedIterator.php b/vendor/guzzle/guzzle/src/Guzzle/Iterator/ChunkedIterator.php new file mode 100644 index 0000000..d76cdd4 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Iterator/FilterIterator.php b/vendor/guzzle/guzzle/src/Guzzle/Iterator/FilterIterator.php new file mode 100644 index 0000000..b103367 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Iterator/MapIterator.php b/vendor/guzzle/guzzle/src/Guzzle/Iterator/MapIterator.php new file mode 100644 index 0000000..7e586bd --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Iterator/MethodProxyIterator.php b/vendor/guzzle/guzzle/src/Guzzle/Iterator/MethodProxyIterator.php new file mode 100644 index 0000000..de4ab03 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Iterator/README.md b/vendor/guzzle/guzzle/src/Guzzle/Iterator/README.md new file mode 100644 index 0000000..8bb7e08 --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Iterator/README.md @@ -0,0 +1,25 @@ +Guzzle Iterator +=============== + +Provides useful Iterators and Iterator decorators + +- ChunkedIterator: Pulls out chunks from an inner iterator and yields the chunks as arrays +- FilterIterator: Used when PHP 5.4's CallbackFilterIterator is not available +- MapIterator: Maps values before yielding +- MethodProxyIterator: Proxies missing method calls to the innermost iterator + +### Installing via Composer + +```bash +# Install Composer +curl -sS https://getcomposer.org/installer | php + +# Add Guzzle as a dependency +php composer.phar require guzzle/iterator:~3.0 +``` + +After installing, you need to require Composer's autoloader: + +```php +require 'vendor/autoload.php'; +``` diff --git a/vendor/guzzle/guzzle/src/Guzzle/Iterator/composer.json b/vendor/guzzle/guzzle/src/Guzzle/Iterator/composer.json new file mode 100644 index 0000000..ee17379 --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Iterator/composer.json @@ -0,0 +1,27 @@ +{ + "name": "guzzle/iterator", + "description": "Provides helpful iterators and iterator decorators", + "keywords": ["iterator", "guzzle"], + "homepage": "http://guzzlephp.org/", + "license": "MIT", + "authors": [ + { + "name": "Michael Dowling", + "email": "mtdowling@gmail.com", + "homepage": "https://github.com/mtdowling" + } + ], + "require": { + "php": ">=5.3.2", + "guzzle/common": ">=2.8.0" + }, + "autoload": { + "psr-0": { "Guzzle\\Iterator": "/" } + }, + "target-dir": "Guzzle/Iterator", + "extra": { + "branch-alias": { + "dev-master": "3.7-dev" + } + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Log/AbstractLogAdapter.php b/vendor/guzzle/guzzle/src/Guzzle/Log/AbstractLogAdapter.php new file mode 100644 index 0000000..7f6271b --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Log/AbstractLogAdapter.php @@ -0,0 +1,16 @@ +log; + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Log/ArrayLogAdapter.php b/vendor/guzzle/guzzle/src/Guzzle/Log/ArrayLogAdapter.php new file mode 100644 index 0000000..a70fc8d --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Log/ClosureLogAdapter.php b/vendor/guzzle/guzzle/src/Guzzle/Log/ClosureLogAdapter.php new file mode 100644 index 0000000..d4bb73f --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Log/LogAdapterInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Log/LogAdapterInterface.php new file mode 100644 index 0000000..d7ac4ea --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Log/MonologLogAdapter.php b/vendor/guzzle/guzzle/src/Guzzle/Log/MonologLogAdapter.php new file mode 100644 index 0000000..6afe7b6 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Log/PsrLogAdapter.php b/vendor/guzzle/guzzle/src/Guzzle/Log/PsrLogAdapter.php new file mode 100644 index 0000000..38a2b60 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Log/Zf1LogAdapter.php b/vendor/guzzle/guzzle/src/Guzzle/Log/Zf1LogAdapter.php new file mode 100644 index 0000000..0ea8e3b --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Log/Zf2LogAdapter.php b/vendor/guzzle/guzzle/src/Guzzle/Log/Zf2LogAdapter.php new file mode 100644 index 0000000..863f6a1 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Log/composer.json b/vendor/guzzle/guzzle/src/Guzzle/Log/composer.json new file mode 100644 index 0000000..a8213e8 --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Log/composer.json @@ -0,0 +1,29 @@ +{ + "name": "guzzle/log", + "description": "Guzzle log adapter component", + "homepage": "http://guzzlephp.org/", + "keywords": ["log", "adapter", "guzzle"], + "license": "MIT", + "authors": [ + { + "name": "Michael Dowling", + "email": "mtdowling@gmail.com", + "homepage": "https://github.com/mtdowling" + } + ], + "require": { + "php": ">=5.3.2" + }, + "autoload": { + "psr-0": { "Guzzle\\Log": "" } + }, + "suggest": { + "guzzle/http": "self.version" + }, + "target-dir": "Guzzle/Log", + "extra": { + "branch-alias": { + "dev-master": "3.7-dev" + } + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Parser/Cookie/CookieParser.php b/vendor/guzzle/guzzle/src/Guzzle/Parser/Cookie/CookieParser.php new file mode 100644 index 0000000..4349eeb --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Parser/Cookie/CookieParserInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Parser/Cookie/CookieParserInterface.php new file mode 100644 index 0000000..d21ffe2 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Parser/Message/MessageParser.php b/vendor/guzzle/guzzle/src/Guzzle/Parser/Message/MessageParser.php new file mode 100644 index 0000000..1047400 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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($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/guzzle/guzzle/src/Guzzle/Parser/Message/MessageParserInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Parser/Message/MessageParserInterface.php new file mode 100644 index 0000000..cc44808 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Parser/ParserRegistry.php b/vendor/guzzle/guzzle/src/Guzzle/Parser/ParserRegistry.php new file mode 100644 index 0000000..f838683 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Parser/UriTemplate/PeclUriTemplate.php b/vendor/guzzle/guzzle/src/Guzzle/Parser/UriTemplate/PeclUriTemplate.php new file mode 100644 index 0000000..b0764e8 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Parser/UriTemplate/UriTemplateInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Parser/UriTemplate/UriTemplateInterface.php new file mode 100644 index 0000000..c81d515 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Parser/Url/UrlParserInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Parser/Url/UrlParserInterface.php new file mode 100644 index 0000000..89ac4b3 --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Parser/Url/UrlParserInterface.php @@ -0,0 +1,19 @@ +=5.3.2" + }, + "autoload": { + "psr-0": { "Guzzle\\Parser": "" } + }, + "target-dir": "Guzzle/Parser", + "extra": { + "branch-alias": { + "dev-master": "3.7-dev" + } + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Plugin/Async/AsyncPlugin.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Async/AsyncPlugin.php new file mode 100644 index 0000000..ae59418 --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Async/AsyncPlugin.php @@ -0,0 +1,84 @@ + '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/guzzle/guzzle/src/Guzzle/Plugin/Async/composer.json b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Async/composer.json new file mode 100644 index 0000000..dc3fc5b --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Async/composer.json @@ -0,0 +1,27 @@ +{ + "name": "guzzle/plugin-async", + "description": "Guzzle async request plugin", + "homepage": "http://guzzlephp.org/", + "keywords": ["plugin", "guzzle"], + "license": "MIT", + "authors": [ + { + "name": "Michael Dowling", + "email": "mtdowling@gmail.com", + "homepage": "https://github.com/mtdowling" + } + ], + "require": { + "php": ">=5.3.2", + "guzzle/http": "self.version" + }, + "autoload": { + "psr-0": { "Guzzle\\Plugin\\Async": "" } + }, + "target-dir": "Guzzle/Plugin/Async", + "extra": { + "branch-alias": { + "dev-master": "3.7-dev" + } + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/AbstractBackoffStrategy.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/AbstractBackoffStrategy.php new file mode 100644 index 0000000..0a85983 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Plugin/Backoff/AbstractErrorCodeBackoffStrategy.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/AbstractErrorCodeBackoffStrategy.php new file mode 100644 index 0000000..6ebee6c --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Plugin/Backoff/BackoffLogger.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/BackoffLogger.php new file mode 100644 index 0000000..ec54c28 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Plugin/Backoff/BackoffPlugin.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/BackoffPlugin.php new file mode 100644 index 0000000..99ace05 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Plugin/Backoff/BackoffStrategyInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/BackoffStrategyInterface.php new file mode 100644 index 0000000..4e590db --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Plugin/Backoff/ConstantBackoffStrategy.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/ConstantBackoffStrategy.php new file mode 100644 index 0000000..061d2a4 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Plugin/Backoff/CurlBackoffStrategy.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/CurlBackoffStrategy.php new file mode 100644 index 0000000..a584ed4 --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/CurlBackoffStrategy.php @@ -0,0 +1,28 @@ +errorCodes[$e->getErrorNo()]) ? true : null; + } + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/ExponentialBackoffStrategy.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/ExponentialBackoffStrategy.php new file mode 100644 index 0000000..fb2912d --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Plugin/Backoff/LinearBackoffStrategy.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/LinearBackoffStrategy.php new file mode 100644 index 0000000..b35e8a4 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Plugin/Backoff/ReasonPhraseBackoffStrategy.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/ReasonPhraseBackoffStrategy.php new file mode 100644 index 0000000..4fd73fe --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/ReasonPhraseBackoffStrategy.php @@ -0,0 +1,25 @@ +errorCodes[$response->getReasonPhrase()]) ? true : null; + } + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/TruncatedBackoffStrategy.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/TruncatedBackoffStrategy.php new file mode 100644 index 0000000..3608f35 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Plugin/Backoff/composer.json b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/composer.json new file mode 100644 index 0000000..91c122c --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Backoff/composer.json @@ -0,0 +1,28 @@ +{ + "name": "guzzle/plugin-backoff", + "description": "Guzzle backoff retry plugins", + "homepage": "http://guzzlephp.org/", + "keywords": ["plugin", "guzzle"], + "license": "MIT", + "authors": [ + { + "name": "Michael Dowling", + "email": "mtdowling@gmail.com", + "homepage": "https://github.com/mtdowling" + } + ], + "require": { + "php": ">=5.3.2", + "guzzle/http": "self.version", + "guzzle/log": "self.version" + }, + "autoload": { + "psr-0": { "Guzzle\\Plugin\\Backoff": "" } + }, + "target-dir": "Guzzle/Plugin/Backoff", + "extra": { + "branch-alias": { + "dev-master": "3.7-dev" + } + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cache/CacheKeyProviderInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cache/CacheKeyProviderInterface.php new file mode 100644 index 0000000..7790f88 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Plugin/Cache/CacheStorageInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cache/CacheStorageInterface.php new file mode 100644 index 0000000..f3d9154 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Plugin/Cache/CanCacheStrategyInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cache/CanCacheStrategyInterface.php new file mode 100644 index 0000000..6e01a8e --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Plugin/Cache/DefaultCacheStorage.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cache/DefaultCacheStorage.php new file mode 100644 index 0000000..555c9b7 --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cache/DefaultCacheStorage.php @@ -0,0 +1,251 @@ +cache = CacheAdapterFactory::fromCache($cache); + $this->defaultTtl = $defaultTtl; + $this->keyPrefix = $keyPrefix; + } + + public function cache(RequestInterface $request, Response $response) + { + $currentTime = time(); + $ttl = $request->getParams()->get('cache.override_ttl') ?: $response->getMaxAge() ?: $this->defaultTtl; + + if ($cacheControl = $response->getHeader('Cache-Control')) { + $stale = $cacheControl->getDirective('stale-if-error'); + $ttl += $stale == true ? $ttl : $stale; + } + + // Determine which manifest key should be used + $key = $this->getCacheKey($request); + $persistedRequest = $this->persistHeaders($request); + $entries = array(); + + if ($manifest = $this->cache->fetch($key)) { + // Determine which cache entries should still be in the cache + $vary = $response->getVary(); + foreach (unserialize($manifest) as $entry) { + // Check if the entry is expired + if ($entry[4] < $currentTime) { + continue; + } + $entry[1]['vary'] = isset($entry[1]['vary']) ? $entry[1]['vary'] : ''; + if ($vary != $entry[1]['vary'] || !$this->requestsMatch($vary, $entry[0], $persistedRequest)) { + $entries[] = $entry; + } + } + } + + // Persist the response body if needed + $bodyDigest = null; + if ($response->getBody() && $response->getBody()->getContentLength() > 0) { + $bodyDigest = $this->getBodyKey($request->getUrl(), $response->getBody()); + $this->cache->save($bodyDigest, (string) $response->getBody(), $ttl); + } + + array_unshift($entries, array( + $persistedRequest, + $this->persistHeaders($response), + $response->getStatusCode(), + $bodyDigest, + $currentTime + $ttl + )); + + $this->cache->save($key, serialize($entries)); + } + + public function delete(RequestInterface $request) + { + $key = $this->getCacheKey($request); + if ($entries = $this->cache->fetch($key)) { + // Delete each cached body + foreach (unserialize($entries) as $entry) { + if ($entry[3]) { + $this->cache->delete($entry[3]); + } + } + $this->cache->delete($key); + } + } + + public function purge($url) + { + foreach (array('GET', 'HEAD', 'POST', 'PUT', 'DELETE') as $method) { + $this->delete(new Request($method, $url)); + } + } + + public function fetch(RequestInterface $request) + { + $key = $this->getCacheKey($request); + if (!($entries = $this->cache->fetch($key))) { + return null; + } + + $match = null; + $headers = $this->persistHeaders($request); + $entries = unserialize($entries); + foreach ($entries as $index => $entry) { + if ($this->requestsMatch(isset($entry[1]['vary']) ? $entry[1]['vary'] : '', $headers, $entry[0])) { + $match = $entry; + break; + } + } + + if (!$match) { + return null; + } + + // Ensure that the response is not expired + $response = null; + if ($match[4] < time()) { + $response = -1; + } else { + $response = new Response($match[2], $match[1]); + if ($match[3]) { + if ($body = $this->cache->fetch($match[3])) { + $response->setBody($body); + } else { + // The response is not valid because the body was somehow deleted + $response = -1; + } + } + } + + if ($response === -1) { + // Remove the entry from the metadata and update the cache + unset($entries[$index]); + if ($entries) { + $this->cache->save($key, serialize($entries)); + } else { + $this->cache->delete($key); + } + return null; + } + + return $response; + } + + /** + * Hash a request URL into a string that returns cache metadata + * + * @param RequestInterface $request + * + * @return string + */ + protected function getCacheKey(RequestInterface $request) + { + // Allow cache.key_filter to trim down the URL cache key by removing generate query string values (e.g. auth) + if ($filter = $request->getParams()->get('cache.key_filter')) { + $url = $request->getUrl(true); + foreach (explode(',', $filter) as $remove) { + $url->getQuery()->remove(trim($remove)); + } + } else { + $url = $request->getUrl(); + } + + return $this->keyPrefix . md5($request->getMethod() . ' ' . $url); + } + + /** + * Create a cache key for a response's body + * + * @param string $url URL of the entry + * @param EntityBodyInterface $body Response body + * + * @return string + */ + protected function getBodyKey($url, EntityBodyInterface $body) + { + return $this->keyPrefix . md5($url) . $body->getContentMd5(); + } + + /** + * Determines whether two Request HTTP header sets are non-varying + * + * @param string $vary Response vary header + * @param array $r1 HTTP header array + * @param array $r2 HTTP header array + * + * @return bool + */ + private function requestsMatch($vary, $r1, $r2) + { + if ($vary) { + foreach (explode(',', $vary) as $header) { + $key = trim(strtolower($header)); + $v1 = isset($r1[$key]) ? $r1[$key] : null; + $v2 = isset($r2[$key]) ? $r2[$key] : null; + if ($v1 !== $v2) { + return false; + } + } + } + + return true; + } + + /** + * Creates an array of cacheable and normalized message headers + * + * @param MessageInterface $message + * + * @return array + */ + private function persistHeaders(MessageInterface $message) + { + // Headers are excluded from the caching (see RFC 2616:13.5.1) + static $noCache = array( + 'age' => true, + 'connection' => true, + 'keep-alive' => true, + 'proxy-authenticate' => true, + 'proxy-authorization' => true, + 'te' => true, + 'trailers' => true, + 'transfer-encoding' => true, + 'upgrade' => true, + 'set-cookie' => true, + 'set-cookie2' => true + ); + + // Clone the response to not destroy any necessary headers when caching + $headers = $message->getHeaders()->getAll(); + $headers = array_diff_key($headers, $noCache); + // Cast the headers to a string + $headers = array_map(function ($h) { return (string) $h; }, $headers); + + return $headers; + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cache/DefaultCanCacheStrategy.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cache/DefaultCanCacheStrategy.php new file mode 100644 index 0000000..3ca1fbf --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Plugin/Cache/DefaultRevalidation.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cache/DefaultRevalidation.php new file mode 100644 index 0000000..af33234 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Plugin/Cache/DenyRevalidation.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cache/DenyRevalidation.php new file mode 100644 index 0000000..88b86f3 --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cache/DenyRevalidation.php @@ -0,0 +1,19 @@ +=5.3.2", + "guzzle/http": "self.version", + "guzzle/cache": "self.version" + }, + "autoload": { + "psr-0": { "Guzzle\\Plugin\\Cache": "" } + }, + "target-dir": "Guzzle/Plugin/Cache", + "extra": { + "branch-alias": { + "dev-master": "3.7-dev" + } + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cookie/Cookie.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cookie/Cookie.php new file mode 100644 index 0000000..5218e5f --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cookie/Cookie.php @@ -0,0 +1,538 @@ + '', + '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/guzzle/guzzle/src/Guzzle/Plugin/Cookie/CookieJar/ArrayCookieJar.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cookie/CookieJar/ArrayCookieJar.php new file mode 100644 index 0000000..6b67503 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Plugin/Cookie/CookieJar/CookieJarInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cookie/CookieJar/CookieJarInterface.php new file mode 100644 index 0000000..7faa7d2 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Plugin/Cookie/CookiePlugin.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cookie/CookiePlugin.php new file mode 100644 index 0000000..df3210e --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Plugin/Cookie/Exception/InvalidCookieException.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cookie/Exception/InvalidCookieException.php new file mode 100644 index 0000000..b1fa6fd --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Cookie/Exception/InvalidCookieException.php @@ -0,0 +1,7 @@ +=5.3.2", + "guzzle/http": "self.version" + }, + "autoload": { + "psr-0": { "Guzzle\\Plugin\\Cookie": "" } + }, + "target-dir": "Guzzle/Plugin/Cookie", + "extra": { + "branch-alias": { + "dev-master": "3.7-dev" + } + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Plugin/CurlAuth/CurlAuthPlugin.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/CurlAuth/CurlAuthPlugin.php new file mode 100644 index 0000000..610e60c --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Plugin/CurlAuth/CurlAuthPlugin.php @@ -0,0 +1,46 @@ +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/guzzle/guzzle/src/Guzzle/Plugin/CurlAuth/composer.json b/vendor/guzzle/guzzle/src/Guzzle/Plugin/CurlAuth/composer.json new file mode 100644 index 0000000..edc8b24 --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Plugin/CurlAuth/composer.json @@ -0,0 +1,27 @@ +{ + "name": "guzzle/plugin-curlauth", + "description": "Guzzle cURL authorization plugin", + "homepage": "http://guzzlephp.org/", + "keywords": ["plugin", "curl", "guzzle"], + "license": "MIT", + "authors": [ + { + "name": "Michael Dowling", + "email": "mtdowling@gmail.com", + "homepage": "https://github.com/mtdowling" + } + ], + "require": { + "php": ">=5.3.2", + "guzzle/http": "self.version" + }, + "autoload": { + "psr-0": { "Guzzle\\Plugin\\CurlAuth": "" } + }, + "target-dir": "Guzzle/Plugin/CurlAuth", + "extra": { + "branch-alias": { + "dev-master": "3.7-dev" + } + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Plugin/ErrorResponse/ErrorResponseExceptionInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/ErrorResponse/ErrorResponseExceptionInterface.php new file mode 100644 index 0000000..5dce8bd --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Plugin/ErrorResponse/Exception/ErrorResponseException.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/ErrorResponse/Exception/ErrorResponseException.php new file mode 100644 index 0000000..1d89e40 --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Plugin/ErrorResponse/Exception/ErrorResponseException.php @@ -0,0 +1,7 @@ +=5.3.2", + "guzzle/service": "self.version" + }, + "autoload": { + "psr-0": { "Guzzle\\Plugin\\ErrorResponse": "" } + }, + "target-dir": "Guzzle/Plugin/ErrorResponse", + "extra": { + "branch-alias": { + "dev-master": "3.7-dev" + } + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Plugin/History/HistoryPlugin.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/History/HistoryPlugin.php new file mode 100644 index 0000000..7375e89 --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Plugin/History/HistoryPlugin.php @@ -0,0 +1,163 @@ + 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/guzzle/guzzle/src/Guzzle/Plugin/History/composer.json b/vendor/guzzle/guzzle/src/Guzzle/Plugin/History/composer.json new file mode 100644 index 0000000..ba0bf2c --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Plugin/History/composer.json @@ -0,0 +1,27 @@ +{ + "name": "guzzle/plugin-history", + "description": "Guzzle history plugin", + "homepage": "http://guzzlephp.org/", + "keywords": ["plugin", "guzzle"], + "license": "MIT", + "authors": [ + { + "name": "Michael Dowling", + "email": "mtdowling@gmail.com", + "homepage": "https://github.com/mtdowling" + } + ], + "require": { + "php": ">=5.3.2", + "guzzle/http": "self.version" + }, + "autoload": { + "psr-0": { "Guzzle\\Plugin\\History": "" } + }, + "target-dir": "Guzzle/Plugin/History", + "extra": { + "branch-alias": { + "dev-master": "3.7-dev" + } + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Plugin/Log/LogPlugin.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Log/LogPlugin.php new file mode 100644 index 0000000..cabdea8 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Plugin/Log/composer.json b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Log/composer.json new file mode 100644 index 0000000..130e6da --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Log/composer.json @@ -0,0 +1,28 @@ +{ + "name": "guzzle/plugin-log", + "description": "Guzzle log plugin for over the wire logging", + "homepage": "http://guzzlephp.org/", + "keywords": ["plugin", "log", "guzzle"], + "license": "MIT", + "authors": [ + { + "name": "Michael Dowling", + "email": "mtdowling@gmail.com", + "homepage": "https://github.com/mtdowling" + } + ], + "require": { + "php": ">=5.3.2", + "guzzle/http": "self.version", + "guzzle/log": "self.version" + }, + "autoload": { + "psr-0": { "Guzzle\\Plugin\\Log": "" } + }, + "target-dir": "Guzzle/Plugin/Log", + "extra": { + "branch-alias": { + "dev-master": "3.7-dev" + } + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Plugin/Md5/CommandContentMd5Plugin.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Md5/CommandContentMd5Plugin.php new file mode 100644 index 0000000..8512424 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Plugin/Md5/Md5ValidatorPlugin.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Md5/Md5ValidatorPlugin.php new file mode 100644 index 0000000..5d7a378 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Plugin/Md5/composer.json b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Md5/composer.json new file mode 100644 index 0000000..0602d06 --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Md5/composer.json @@ -0,0 +1,27 @@ +{ + "name": "guzzle/plugin-md5", + "description": "Guzzle MD5 plugins", + "homepage": "http://guzzlephp.org/", + "keywords": ["plugin", "guzzle"], + "license": "MIT", + "authors": [ + { + "name": "Michael Dowling", + "email": "mtdowling@gmail.com", + "homepage": "https://github.com/mtdowling" + } + ], + "require": { + "php": ">=5.3.2", + "guzzle/http": "self.version" + }, + "autoload": { + "psr-0": { "Guzzle\\Plugin\\Md5": "" } + }, + "target-dir": "Guzzle/Plugin/Md5", + "extra": { + "branch-alias": { + "dev-master": "3.7-dev" + } + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Plugin/Mock/MockPlugin.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Mock/MockPlugin.php new file mode 100644 index 0000000..2440578 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Plugin/Mock/composer.json b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Mock/composer.json new file mode 100644 index 0000000..f8201e3 --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Mock/composer.json @@ -0,0 +1,27 @@ +{ + "name": "guzzle/plugin-mock", + "description": "Guzzle Mock plugin", + "homepage": "http://guzzlephp.org/", + "keywords": ["mock", "plugin", "guzzle"], + "license": "MIT", + "authors": [ + { + "name": "Michael Dowling", + "email": "mtdowling@gmail.com", + "homepage": "https://github.com/mtdowling" + } + ], + "require": { + "php": ">=5.3.2", + "guzzle/http": "self.version" + }, + "autoload": { + "psr-0": { "Guzzle\\Plugin\\Mock": "" } + }, + "target-dir": "Guzzle/Plugin/Mock", + "extra": { + "branch-alias": { + "dev-master": "3.7-dev" + } + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Plugin/Oauth/OauthPlugin.php b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Oauth/OauthPlugin.php new file mode 100644 index 0000000..95e0c3e --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Plugin/Oauth/composer.json b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Oauth/composer.json new file mode 100644 index 0000000..c9766ba --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Plugin/Oauth/composer.json @@ -0,0 +1,27 @@ +{ + "name": "guzzle/plugin-oauth", + "description": "Guzzle OAuth plugin", + "homepage": "http://guzzlephp.org/", + "keywords": ["oauth", "plugin", "guzzle"], + "license": "MIT", + "authors": [ + { + "name": "Michael Dowling", + "email": "mtdowling@gmail.com", + "homepage": "https://github.com/mtdowling" + } + ], + "require": { + "php": ">=5.3.2", + "guzzle/http": "self.version" + }, + "autoload": { + "psr-0": { "Guzzle\\Plugin\\Oauth": "" } + }, + "target-dir": "Guzzle/Plugin/Oauth", + "extra": { + "branch-alias": { + "dev-master": "3.7-dev" + } + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Plugin/composer.json b/vendor/guzzle/guzzle/src/Guzzle/Plugin/composer.json new file mode 100644 index 0000000..2bbe64c --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Plugin/composer.json @@ -0,0 +1,44 @@ +{ + "name": "guzzle/plugin", + "description": "Guzzle plugin component containing all Guzzle HTTP plugins", + "homepage": "http://guzzlephp.org/", + "keywords": ["http", "client", "plugin", "extension", "guzzle"], + "license": "MIT", + "authors": [ + { + "name": "Michael Dowling", + "email": "mtdowling@gmail.com", + "homepage": "https://github.com/mtdowling" + } + ], + "require": { + "php": ">=5.3.2", + "guzzle/http": "self.version" + }, + "suggest": { + "guzzle/cache": "self.version", + "guzzle/log": "self.version" + }, + "autoload": { + "psr-0": { "Guzzle\\Plugin": "" } + }, + "target-dir": "Guzzle/Plugin", + "replace": { + "guzzle/plugin-async": "self.version", + "guzzle/plugin-backoff": "self.version", + "guzzle/plugin-cache": "self.version", + "guzzle/plugin-cookie": "self.version", + "guzzle/plugin-curlauth": "self.version", + "guzzle/plugin-error-response": "self.version", + "guzzle/plugin-history": "self.version", + "guzzle/plugin-log": "self.version", + "guzzle/plugin-md5": "self.version", + "guzzle/plugin-mock": "self.version", + "guzzle/plugin-oauth": "self.version" + }, + "extra": { + "branch-alias": { + "dev-master": "3.7-dev" + } + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Service/AbstractConfigLoader.php b/vendor/guzzle/guzzle/src/Guzzle/Service/AbstractConfigLoader.php new file mode 100644 index 0000000..cd06f57 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Builder/ServiceBuilder.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Builder/ServiceBuilder.php new file mode 100644 index 0000000..38150db --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Builder/ServiceBuilderInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Builder/ServiceBuilderInterface.php new file mode 100644 index 0000000..4fc310a --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/CachingConfigLoader.php b/vendor/guzzle/guzzle/src/Guzzle/Service/CachingConfigLoader.php new file mode 100644 index 0000000..26f8360 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Client.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Client.php new file mode 100644 index 0000000..3e5f8e5 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/ClientInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Service/ClientInterface.php new file mode 100644 index 0000000..814154f --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Command/ClosureCommand.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/ClosureCommand.php new file mode 100644 index 0000000..cb6ac40 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Command/CommandInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/CommandInterface.php new file mode 100644 index 0000000..fbb61d2 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Command/DefaultRequestSerializer.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/DefaultRequestSerializer.php new file mode 100644 index 0000000..2dc4acd --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Command/DefaultResponseParser.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/DefaultResponseParser.php new file mode 100644 index 0000000..4fe3803 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Command/Factory/AliasFactory.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/Factory/AliasFactory.php new file mode 100644 index 0000000..1c5ce07 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Command/Factory/CompositeFactory.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/Factory/CompositeFactory.php new file mode 100644 index 0000000..8c46983 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Command/Factory/ConcreteClassFactory.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/Factory/ConcreteClassFactory.php new file mode 100644 index 0000000..0e93dea --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Command/Factory/FactoryInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/Factory/FactoryInterface.php new file mode 100644 index 0000000..35c299d --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Command/Factory/ServiceDescriptionFactory.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/Factory/ServiceDescriptionFactory.php new file mode 100644 index 0000000..b943a5b --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Request/AbstractRequestVisitor.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Request/AbstractRequestVisitor.php new file mode 100644 index 0000000..adcfca1 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Request/BodyVisitor.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Request/BodyVisitor.php new file mode 100644 index 0000000..168d780 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Request/HeaderVisitor.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Request/HeaderVisitor.php new file mode 100644 index 0000000..2a53754 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Request/JsonVisitor.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Request/JsonVisitor.php new file mode 100644 index 0000000..757e1c5 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Request/PostFieldVisitor.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Request/PostFieldVisitor.php new file mode 100644 index 0000000..975850b --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Request/PostFieldVisitor.php @@ -0,0 +1,18 @@ +setPostField($param->getWireName(), $this->prepareValue($value, $param)); + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Request/PostFileVisitor.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Request/PostFileVisitor.php new file mode 100644 index 0000000..0853ebe --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Request/QueryVisitor.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Request/QueryVisitor.php new file mode 100644 index 0000000..315877a --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Request/QueryVisitor.php @@ -0,0 +1,18 @@ +getQuery()->set($param->getWireName(), $this->prepareValue($value, $param)); + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Request/RequestVisitorInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Request/RequestVisitorInterface.php new file mode 100644 index 0000000..14e0b2d --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Request/RequestVisitorInterface.php @@ -0,0 +1,31 @@ +setResponseBody($value); + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Request/XmlVisitor.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Request/XmlVisitor.php new file mode 100644 index 0000000..5b71487 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Response/AbstractResponseVisitor.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Response/AbstractResponseVisitor.php new file mode 100644 index 0000000..d87eeb9 --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Response/AbstractResponseVisitor.php @@ -0,0 +1,26 @@ +getName()] = $param->filter($response->getBody()); + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Response/HeaderVisitor.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Response/HeaderVisitor.php new file mode 100644 index 0000000..0f8737c --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Response/JsonVisitor.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Response/JsonVisitor.php new file mode 100644 index 0000000..a609ebd --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Response/ReasonPhraseVisitor.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Response/ReasonPhraseVisitor.php new file mode 100644 index 0000000..1b10ebc --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Response/ReasonPhraseVisitor.php @@ -0,0 +1,23 @@ +getName()] = $response->getReasonPhrase(); + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Response/ResponseVisitorInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Response/ResponseVisitorInterface.php new file mode 100644 index 0000000..033f40c --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Response/ResponseVisitorInterface.php @@ -0,0 +1,46 @@ +getName()] = $response->getStatusCode(); + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Response/XmlVisitor.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/Response/XmlVisitor.php new file mode 100644 index 0000000..bb7124b --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/VisitorFlyweight.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/LocationVisitor/VisitorFlyweight.php new file mode 100644 index 0000000..74cb628 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Command/OperationCommand.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/OperationCommand.php new file mode 100644 index 0000000..0748b5a --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Command/OperationResponseParser.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/OperationResponseParser.php new file mode 100644 index 0000000..ca00bc0 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Command/RequestSerializerInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Command/RequestSerializerInterface.php new file mode 100644 index 0000000..60b9334 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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), 'phrase' (response reason phrase or description of the + * error), and 'class' (a custom exception class that would be thrown if the error is + * encountered). + * - data: (array) Any extra data that might be used to help build or serialize the operation + * - additionalParameters: (null|array) Parameter schema to use when an option is passed to the operation that is + * not in the schema + * + * @param array $config Array of configuration data + * @param ServiceDescriptionInterface $description Service description used to resolve models if $ref tags are found + */ + public function __construct(array $config = array(), ServiceDescriptionInterface $description = null) + { + $this->description = $description; + + // Get the intersection of the available properties and properties set on the operation + foreach (array_intersect_key($config, self::$properties) as $key => $value) { + $this->{$key} = $value; + } + + $this->class = $this->class ?: self::DEFAULT_COMMAND_CLASS; + $this->deprecated = (bool) $this->deprecated; + $this->errorResponses = $this->errorResponses ?: array(); + $this->data = $this->data ?: array(); + + if (!$this->responseClass) { + $this->responseClass = 'array'; + $this->responseType = 'primitive'; + } elseif ($this->responseType) { + // Set the response type to perform validation + $this->setResponseType($this->responseType); + } else { + // A response class was set and no response type was set, so guess what the type is + $this->inferResponseType(); + } + + // Parameters need special handling when adding + if ($this->parameters) { + foreach ($this->parameters as $name => $param) { + if ($param instanceof Parameter) { + $param->setName($name)->setParent($this); + } elseif (is_array($param)) { + $param['name'] = $name; + $this->addParam(new Parameter($param, $this->description)); + } + } + } + + if ($this->additionalParameters) { + if ($this->additionalParameters instanceof Parameter) { + $this->additionalParameters->setParent($this); + } elseif (is_array($this->additionalParameters)) { + $this->setadditionalParameters(new Parameter($this->additionalParameters, $this->description)); + } + } + } + + public function toArray() + { + $result = array(); + // Grab valid properties and filter out values that weren't set + foreach (array_keys(self::$properties) as $check) { + if ($value = $this->{$check}) { + $result[$check] = $value; + } + } + // Remove the name property + unset($result['name']); + // Parameters need to be converted to arrays + $result['parameters'] = array(); + foreach ($this->parameters as $key => $param) { + $result['parameters'][$key] = $param->toArray(); + } + // Additional parameters need to be cast to an array + if ($this->additionalParameters instanceof Parameter) { + $result['additionalParameters'] = $this->additionalParameters->toArray(); + } + + return $result; + } + + public function getServiceDescription() + { + return $this->description; + } + + public function setServiceDescription(ServiceDescriptionInterface $description) + { + $this->description = $description; + + return $this; + } + + public function getParams() + { + return $this->parameters; + } + + public function getParamNames() + { + return array_keys($this->parameters); + } + + public function hasParam($name) + { + return isset($this->parameters[$name]); + } + + public function getParam($param) + { + return isset($this->parameters[$param]) ? $this->parameters[$param] : null; + } + + /** + * Add a parameter to the command + * + * @param Parameter $param Parameter to add + * + * @return self + */ + public function addParam(Parameter $param) + { + $this->parameters[$param->getName()] = $param; + $param->setParent($this); + + return $this; + } + + /** + * Remove a parameter from the command + * + * @param string $name Name of the parameter to remove + * + * @return self + */ + public function removeParam($name) + { + unset($this->parameters[$name]); + + return $this; + } + + public function getHttpMethod() + { + return $this->httpMethod; + } + + /** + * Set the HTTP method of the command + * + * @param string $httpMethod Method to set + * + * @return self + */ + public function setHttpMethod($httpMethod) + { + $this->httpMethod = $httpMethod; + + return $this; + } + + public function getClass() + { + return $this->class; + } + + /** + * Set the concrete class of the command + * + * @param string $className Concrete class name + * + * @return self + */ + public function setClass($className) + { + $this->class = $className; + + return $this; + } + + public function getName() + { + return $this->name; + } + + /** + * Set the name of the command + * + * @param string $name Name of the command + * + * @return self + */ + public function setName($name) + { + $this->name = $name; + + return $this; + } + + public function getSummary() + { + return $this->summary; + } + + /** + * Set a short summary of what the operation does + * + * @param string $summary Short summary of the operation + * + * @return self + */ + public function setSummary($summary) + { + $this->summary = $summary; + + return $this; + } + + public function getNotes() + { + return $this->notes; + } + + /** + * Set a longer text field to explain the behavior of the operation. + * + * @param string $notes Notes on the operation + * + * @return self + */ + public function setNotes($notes) + { + $this->notes = $notes; + + return $this; + } + + public function getDocumentationUrl() + { + return $this->documentationUrl; + } + + /** + * Set the URL pointing to additional documentation on the command + * + * @param string $docUrl Documentation URL + * + * @return self + */ + public function setDocumentationUrl($docUrl) + { + $this->documentationUrl = $docUrl; + + return $this; + } + + public function getResponseClass() + { + return $this->responseClass; + } + + /** + * Set what is returned from the method. Can be a primitive, class name, or model. For example: 'array', + * 'Guzzle\\Foo\\Baz', or 'MyModelName' (to reference a model by ID). + * + * @param string $responseClass Type of response + * + * @return self + */ + public function setResponseClass($responseClass) + { + $this->responseClass = $responseClass; + $this->inferResponseType(); + + return $this; + } + + public function getResponseType() + { + return $this->responseType; + } + + /** + * Set qualifying information about the responseClass. One of 'primitive', 'class', 'model', or 'documentation' + * + * @param string $responseType Response type information + * + * @return self + * @throws InvalidArgumentException + */ + public function setResponseType($responseType) + { + static $types = array( + self::TYPE_PRIMITIVE => true, + self::TYPE_CLASS => true, + self::TYPE_MODEL => true, + self::TYPE_DOCUMENTATION => true + ); + if (!isset($types[$responseType])) { + throw new InvalidArgumentException('responseType must be one of ' . implode(', ', array_keys($types))); + } + + $this->responseType = $responseType; + + return $this; + } + + public function getResponseNotes() + { + return $this->responseNotes; + } + + /** + * Set notes about the response of the operation + * + * @param string $notes Response notes + * + * @return self + */ + public function setResponseNotes($notes) + { + $this->responseNotes = $notes; + + return $this; + } + + public function getDeprecated() + { + return $this->deprecated; + } + + /** + * Set whether or not the command is deprecated + * + * @param bool $isDeprecated Set to true to mark as deprecated + * + * @return self + */ + public function setDeprecated($isDeprecated) + { + $this->deprecated = $isDeprecated; + + return $this; + } + + public function getUri() + { + return $this->uri; + } + + /** + * Set the URI template of the command + * + * @param string $uri URI template to set + * + * @return self + */ + public function setUri($uri) + { + $this->uri = $uri; + + return $this; + } + + public function getErrorResponses() + { + return $this->errorResponses; + } + + /** + * Add an error to the command + * + * @param string $code HTTP response code + * @param string $reason HTTP response reason phrase or information about the error + * @param string $class Exception class associated with the error + * + * @return self + */ + public function addErrorResponse($code, $reason, $class) + { + $this->errorResponses[] = array('code' => $code, 'reason' => $reason, 'class' => $class); + + return $this; + } + + /** + * Set all of the error responses of the operation + * + * @param array $errorResponses Hash of error name to a hash containing a code, reason, class + * + * @return self + */ + public function setErrorResponses(array $errorResponses) + { + $this->errorResponses = $errorResponses; + + return $this; + } + + public function getData($name) + { + return isset($this->data[$name]) ? $this->data[$name] : null; + } + + /** + * Set a particular data point on the operation + * + * @param string $name Name of the data value + * @param mixed $value Value to set + * + * @return self + */ + public function setData($name, $value) + { + $this->data[$name] = $value; + + return $this; + } + + /** + * Get the additionalParameters of the operation + * + * @return Parameter|null + */ + public function getAdditionalParameters() + { + return $this->additionalParameters; + } + + /** + * Set the additionalParameters of the operation + * + * @param Parameter|null $parameter Parameter to set + * + * @return self + */ + public function setAdditionalParameters($parameter) + { + if ($this->additionalParameters = $parameter) { + $this->additionalParameters->setParent($this); + } + + return $this; + } + + /** + * Infer the response type from the responseClass value + */ + protected function inferResponseType() + { + static $primitives = array('array' => 1, 'boolean' => 1, 'string' => 1, 'integer' => 1, '' => 1); + if (isset($primitives[$this->responseClass])) { + $this->responseType = self::TYPE_PRIMITIVE; + } elseif ($this->description && $this->description->hasModel($this->responseClass)) { + $this->responseType = self::TYPE_MODEL; + } else { + $this->responseType = self::TYPE_CLASS; + } + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Service/Description/OperationInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Description/OperationInterface.php new file mode 100644 index 0000000..4de41bd --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Description/SchemaFormatter.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Description/SchemaFormatter.php new file mode 100644 index 0000000..7f47fc9 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Description/SchemaValidator.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Description/SchemaValidator.php new file mode 100644 index 0000000..b045422 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Description/ServiceDescription.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Description/ServiceDescription.php new file mode 100644 index 0000000..286e65e --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Description/ServiceDescriptionInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Description/ServiceDescriptionInterface.php new file mode 100644 index 0000000..5983e58 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Description/ValidatorInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Description/ValidatorInterface.php new file mode 100644 index 0000000..94ca77d --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Exception/DescriptionBuilderException.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Exception/DescriptionBuilderException.php new file mode 100644 index 0000000..1407e56 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Exception/ResponseClassException.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Exception/ResponseClassException.php new file mode 100644 index 0000000..d59ff21 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Resource/AbstractResourceIteratorFactory.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Resource/AbstractResourceIteratorFactory.php new file mode 100644 index 0000000..21140e7 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Resource/CompositeResourceIteratorFactory.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Resource/CompositeResourceIteratorFactory.php new file mode 100644 index 0000000..2efc133 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Resource/MapResourceIteratorFactory.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Resource/MapResourceIteratorFactory.php new file mode 100644 index 0000000..c71ca9d --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Resource/Model.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Resource/Model.php new file mode 100644 index 0000000..2322434 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Resource/ResourceIterator.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Resource/ResourceIterator.php new file mode 100644 index 0000000..e141524 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Resource/ResourceIteratorApplyBatched.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Resource/ResourceIteratorApplyBatched.php new file mode 100644 index 0000000..6aa3615 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Resource/ResourceIteratorClassFactory.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Resource/ResourceIteratorClassFactory.php new file mode 100644 index 0000000..2fd9980 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Service/Resource/ResourceIteratorFactoryInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Service/Resource/ResourceIteratorFactoryInterface.php new file mode 100644 index 0000000..8b4e8db --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Service/Resource/ResourceIteratorFactoryInterface.php @@ -0,0 +1,30 @@ +=5.3.2", + "guzzle/cache": "self.version", + "guzzle/http": "self.version", + "guzzle/inflection": "self.version" + }, + "autoload": { + "psr-0": { "Guzzle\\Service": "" } + }, + "target-dir": "Guzzle/Service", + "extra": { + "branch-alias": { + "dev-master": "3.7-dev" + } + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Stream/PhpStreamRequestFactory.php b/vendor/guzzle/guzzle/src/Guzzle/Stream/PhpStreamRequestFactory.php new file mode 100644 index 0000000..9949e45 --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Stream/PhpStreamRequestFactory.php @@ -0,0 +1,276 @@ +contextOptions = stream_context_get_options($context); + $this->context = $context; + } elseif (is_array($context) || !$context) { + $this->contextOptions = $context; + $this->createContext($params); + } elseif ($context) { + throw new InvalidArgumentException('$context must be an array or resource'); + } + + // Dispatch the before send event + $request->dispatch('request.before_send', array( + 'request' => $request, + 'context' => $this->context, + 'context_options' => $this->contextOptions + )); + + $this->setUrl($request); + $this->addDefaultContextOptions($request); + $this->addSslOptions($request); + $this->addBodyOptions($request); + $this->addProxyOptions($request); + + // Create the file handle but silence errors + return $this->createStream($params) + ->setCustomData('request', $request) + ->setCustomData('response_headers', $this->getLastResponseHeaders()); + } + + /** + * Set an option on the context and the internal options array + * + * @param string $wrapper Stream wrapper name of http + * @param string $name Context name + * @param mixed $value Context value + * @param bool $overwrite Set to true to overwrite an existing value + */ + protected function setContextValue($wrapper, $name, $value, $overwrite = false) + { + if (!isset($this->contextOptions[$wrapper])) { + $this->contextOptions[$wrapper] = array($name => $value); + } elseif (!$overwrite && isset($this->contextOptions[$wrapper][$name])) { + return; + } + $this->contextOptions[$wrapper][$name] = $value; + stream_context_set_option($this->context, $wrapper, $name, $value); + } + + /** + * Create a stream context + * + * @param array $params Parameter array + */ + protected function createContext(array $params) + { + $options = $this->contextOptions; + $this->context = $this->createResource(function () use ($params, $options) { + return stream_context_create($options, $params); + }); + } + + /** + * Get the last response headers received by the HTTP request + * + * @return array + */ + public function getLastResponseHeaders() + { + return $this->lastResponseHeaders; + } + + /** + * Adds the default context options to the stream context options + * + * @param RequestInterface $request Request + */ + protected function addDefaultContextOptions(RequestInterface $request) + { + $this->setContextValue('http', 'method', $request->getMethod()); + $headers = $request->getHeaderLines(); + + // "Connection: close" is required to get streams to work in HTTP 1.1 + if (!$request->hasHeader('Connection')) { + $headers[] = 'Connection: close'; + } + + $this->setContextValue('http', 'header', $headers); + $this->setContextValue('http', 'protocol_version', $request->getProtocolVersion()); + $this->setContextValue('http', 'ignore_errors', true); + } + + /** + * Set the URL to use with the factory + * + * @param RequestInterface $request Request that owns the URL + */ + protected function setUrl(RequestInterface $request) + { + $this->url = $request->getUrl(true); + + // Check for basic Auth username + if ($request->getUsername()) { + $this->url->setUsername($request->getUsername()); + } + + // Check for basic Auth password + if ($request->getPassword()) { + $this->url->setPassword($request->getPassword()); + } + } + + /** + * Add SSL options to the stream context + * + * @param RequestInterface $request Request + */ + protected function addSslOptions(RequestInterface $request) + { + if ($request->getCurlOptions()->get(CURLOPT_SSL_VERIFYPEER)) { + $this->setContextValue('ssl', 'verify_peer', true, true); + if ($cafile = $request->getCurlOptions()->get(CURLOPT_CAINFO)) { + $this->setContextValue('ssl', 'cafile', $cafile, true); + } + } else { + $this->setContextValue('ssl', 'verify_peer', false, true); + } + } + + /** + * Add body (content) specific options to the context options + * + * @param RequestInterface $request + */ + protected function addBodyOptions(RequestInterface $request) + { + // Add the content for the request if needed + if (!($request instanceof EntityEnclosingRequestInterface)) { + return; + } + + if (count($request->getPostFields())) { + $this->setContextValue('http', 'content', (string) $request->getPostFields(), true); + } elseif ($request->getBody()) { + $this->setContextValue('http', 'content', (string) $request->getBody(), true); + } + + // Always ensure a content-length header is sent + if (isset($this->contextOptions['http']['content'])) { + $headers = isset($this->contextOptions['http']['header']) ? $this->contextOptions['http']['header'] : array(); + $headers[] = 'Content-Length: ' . strlen($this->contextOptions['http']['content']); + $this->setContextValue('http', 'header', $headers, true); + } + } + + /** + * Add proxy parameters to the context if needed + * + * @param RequestInterface $request Request + */ + protected function addProxyOptions(RequestInterface $request) + { + if ($proxy = $request->getCurlOptions()->get(CURLOPT_PROXY)) { + $this->setContextValue('http', 'proxy', $proxy); + } + } + + /** + * Create the stream for the request with the context options + * + * @param array $params Parameters of the stream + * + * @return StreamInterface + */ + protected function createStream(array $params) + { + $http_response_header = null; + $url = $this->url; + $context = $this->context; + $fp = $this->createResource(function () use ($context, $url, &$http_response_header) { + return fopen((string) $url, 'r', false, $context); + }); + + // Determine the class to instantiate + $className = isset($params['stream_class']) ? $params['stream_class'] : __NAMESPACE__ . '\\Stream'; + + /** @var $stream StreamInterface */ + $stream = new $className($fp); + + // Track the response headers of the request + if (isset($http_response_header)) { + $this->lastResponseHeaders = $http_response_header; + $this->processResponseHeaders($stream); + } + + return $stream; + } + + /** + * Process response headers + * + * @param StreamInterface $stream + */ + protected function processResponseHeaders(StreamInterface $stream) + { + // Set the size on the stream if it was returned in the response + foreach ($this->lastResponseHeaders as $header) { + if ((stripos($header, 'Content-Length:')) === 0) { + $stream->setSize(trim(substr($header, 15))); + } + } + } + + /** + * Create a resource and check to ensure it was created successfully + * + * @param callable $callback Closure to invoke that must return a valid resource + * + * @return resource + * @throws RuntimeException on error + */ + protected function createResource($callback) + { + // Turn off error reporting while we try to initiate the request + $level = error_reporting(0); + $resource = call_user_func($callback); + error_reporting($level); + + // If the resource could not be created, then grab the last error and throw an exception + if (false === $resource) { + $message = 'Error creating resource. '; + foreach (error_get_last() as $key => $value) { + $message .= "[{$key}] {$value} "; + } + throw new RuntimeException(trim($message)); + } + + return $resource; + } +} diff --git a/vendor/guzzle/guzzle/src/Guzzle/Stream/Stream.php b/vendor/guzzle/guzzle/src/Guzzle/Stream/Stream.php new file mode 100644 index 0000000..12bed26 --- /dev/null +++ b/vendor/guzzle/guzzle/src/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/guzzle/guzzle/src/Guzzle/Stream/StreamInterface.php b/vendor/guzzle/guzzle/src/Guzzle/Stream/StreamInterface.php new file mode 100644 index 0000000..6d7dc37 --- /dev/null +++ b/vendor/guzzle/guzzle/src/Guzzle/Stream/StreamInterface.php @@ -0,0 +1,218 @@ +=5.3.2", + "guzzle/common": "self.version" + }, + "suggest": { + "guzzle/http": "To convert Guzzle request objects to PHP streams" + }, + "autoload": { + "psr-0": { "Guzzle\\Stream": "" } + }, + "target-dir": "Guzzle/Stream", + "extra": { + "branch-alias": { + "dev-master": "3.7-dev" + } + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/AbstractBatchDecoratorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/AbstractBatchDecoratorTest.php new file mode 100644 index 0000000..951738d --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/AbstractBatchDecoratorTest.php @@ -0,0 +1,33 @@ +getMock('Guzzle\Batch\BatchTransferInterface'), + $this->getMock('Guzzle\Batch\BatchDivisorInterface') + ); + + $decoratorA = $this->getMockBuilder('Guzzle\Batch\AbstractBatchDecorator') + ->setConstructorArgs(array($batch)) + ->getMockForAbstractClass(); + + $decoratorB = $this->getMockBuilder('Guzzle\Batch\AbstractBatchDecorator') + ->setConstructorArgs(array($decoratorA)) + ->getMockForAbstractClass(); + + $decoratorA->add('foo'); + $this->assertFalse($decoratorB->isEmpty()); + $this->assertFalse($batch->isEmpty()); + $this->assertEquals(array($decoratorB, $decoratorA), $decoratorB->getDecorators()); + $this->assertEquals(array(), $decoratorB->flush()); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/BatchBuilderTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/BatchBuilderTest.php new file mode 100644 index 0000000..4da09d3 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/BatchBuilderTest.php @@ -0,0 +1,86 @@ +getMock('Guzzle\Batch\BatchTransferInterface'); + } + + private function getMockDivisor() + { + return $this->getMock('Guzzle\Batch\BatchDivisorInterface'); + } + + private function getMockBatchBuilder() + { + return BatchBuilder::factory() + ->transferWith($this->getMockTransfer()) + ->createBatchesWith($this->getMockDivisor()); + } + + public function testFactoryCreatesInstance() + { + $builder = BatchBuilder::factory(); + $this->assertInstanceOf('Guzzle\Batch\BatchBuilder', $builder); + } + + public function testAddsAutoFlush() + { + $batch = $this->getMockBatchBuilder()->autoFlushAt(10)->build(); + $this->assertInstanceOf('Guzzle\Batch\FlushingBatch', $batch); + } + + public function testAddsExceptionBuffering() + { + $batch = $this->getMockBatchBuilder()->bufferExceptions()->build(); + $this->assertInstanceOf('Guzzle\Batch\ExceptionBufferingBatch', $batch); + } + + public function testAddHistory() + { + $batch = $this->getMockBatchBuilder()->keepHistory()->build(); + $this->assertInstanceOf('Guzzle\Batch\HistoryBatch', $batch); + } + + public function testAddsNotify() + { + $batch = $this->getMockBatchBuilder()->notify(function() {})->build(); + $this->assertInstanceOf('Guzzle\Batch\NotifyingBatch', $batch); + } + + /** + * @expectedException Guzzle\Common\Exception\RuntimeException + */ + public function testTransferStrategyMustBeSet() + { + $batch = BatchBuilder::factory()->createBatchesWith($this->getMockDivisor())->build(); + } + + /** + * @expectedException Guzzle\Common\Exception\RuntimeException + */ + public function testDivisorStrategyMustBeSet() + { + $batch = BatchBuilder::factory()->transferWith($this->getMockTransfer())->build(); + } + + public function testTransfersRequests() + { + $batch = BatchBuilder::factory()->transferRequests(10)->build(); + $this->assertInstanceOf('Guzzle\Batch\BatchRequestTransfer', $this->readAttribute($batch, 'transferStrategy')); + } + + public function testTransfersCommands() + { + $batch = BatchBuilder::factory()->transferCommands(10)->build(); + $this->assertInstanceOf('Guzzle\Batch\BatchCommandTransfer', $this->readAttribute($batch, 'transferStrategy')); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/BatchClosureDivisorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/BatchClosureDivisorTest.php new file mode 100644 index 0000000..753db7d --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/BatchClosureDivisorTest.php @@ -0,0 +1,36 @@ +createBatches($queue); + $this->assertEquals(array(array('foo'), array('baz')), $batches); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/BatchClosureTransferTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/BatchClosureTransferTest.php new file mode 100644 index 0000000..6ba7ae0 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/BatchClosureTransferTest.php @@ -0,0 +1,52 @@ +itemsTransferred = null; + $itemsTransferred =& $this->itemsTransferred; + + $this->transferStrategy = new BatchClosureTransfer(function (array $batch) use (&$itemsTransferred) { + $itemsTransferred = $batch; + return; + }); + } + + public function testTransfersBatch() + { + $batchedItems = array('foo', 'bar', 'baz'); + $this->transferStrategy->transfer($batchedItems); + + $this->assertEquals($batchedItems, $this->itemsTransferred); + } + + public function testTransferBailsOnEmptyBatch() + { + $batchedItems = array(); + $this->transferStrategy->transfer($batchedItems); + + $this->assertNull($this->itemsTransferred); + } + + /** + * @expectedException Guzzle\Common\Exception\InvalidArgumentException + */ + public function testEnsuresCallableIsCallable() + { + $foo = new BatchClosureTransfer('uh oh!'); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/BatchCommandTransferTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/BatchCommandTransferTest.php new file mode 100644 index 0000000..a04efab --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/BatchCommandTransferTest.php @@ -0,0 +1,83 @@ + $command) { + if ($i % 2) { + $command->setClient($client1); + } else { + $command->setClient($client2); + } + $queue[] = $command; + } + + $batch = new BatchCommandTransfer(2); + $this->assertEquals(array( + array($commands[0], $commands[2]), + array($commands[4]), + array($commands[1], $commands[3]) + ), $batch->createBatches($queue)); + } + + /** + * @expectedException Guzzle\Common\Exception\InvalidArgumentException + */ + public function testEnsuresAllItemsAreCommands() + { + $queue = new \SplQueue(); + $queue[] = 'foo'; + $batch = new BatchCommandTransfer(2); + $batch->createBatches($queue); + } + + public function testTransfersBatches() + { + $client = $this->getMockBuilder('Guzzle\Service\Client') + ->setMethods(array('send')) + ->getMock(); + $client->expects($this->once()) + ->method('send'); + $command = new Mc(); + $command->setClient($client); + $batch = new BatchCommandTransfer(2); + $batch->transfer(array($command)); + } + + public function testDoesNotTransfersEmptyBatches() + { + $batch = new BatchCommandTransfer(2); + $batch->transfer(array()); + } + + /** + * @expectedException Guzzle\Service\Exception\InconsistentClientTransferException + */ + public function testEnsuresAllCommandsUseTheSameClient() + { + $batch = new BatchCommandTransfer(2); + $client1 = new Client('http://www.example.com'); + $client2 = new Client('http://www.example.com'); + $command1 = new Mc(); + $command1->setClient($client1); + $command2 = new Mc(); + $command2->setClient($client2); + $batch->transfer(array($command1, $command2)); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/BatchRequestTransferTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/BatchRequestTransferTest.php new file mode 100644 index 0000000..d929ef0 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/BatchRequestTransferTest.php @@ -0,0 +1,80 @@ +setCurlMulti(new CurlMulti()); + + $client2 = new Client('http://www.example.com'); + $client2->setCurlMulti(new CurlMulti()); + + $request1 = $client1->get(); + $request2 = $client2->get(); + $request3 = $client1->get(); + $request4 = $client2->get(); + $request5 = $client1->get(); + + $queue = new \SplQueue(); + $queue[] = $request1; + $queue[] = $request2; + $queue[] = $request3; + $queue[] = $request4; + $queue[] = $request5; + + $batch = new BatchRequestTransfer(2); + $this->assertEquals(array( + array($request1, $request3), + array($request3), + array($request2, $request4) + ), $batch->createBatches($queue)); + } + + /** + * @expectedException \Guzzle\Common\Exception\InvalidArgumentException + */ + public function testEnsuresAllItemsAreRequests() + { + $queue = new \SplQueue(); + $queue[] = 'foo'; + $batch = new BatchRequestTransfer(2); + $batch->createBatches($queue); + } + + public function testTransfersBatches() + { + $client = new Client('http://localhost:123'); + $request = $client->get(); + // For some reason... PHP unit clones the request, which emits a request.clone event. This causes the + // 'sorted' property of the event dispatcher to contain an array in the cloned request that is not present in + // the original. + $request->dispatch('request.clone'); + + $multi = $this->getMock('Guzzle\Http\Curl\CurlMultiInterface'); + $client->setCurlMulti($multi); + $multi->expects($this->once()) + ->method('add') + ->with($request); + $multi->expects($this->once()) + ->method('send'); + + $batch = new BatchRequestTransfer(2); + $batch->transfer(array($request)); + } + + public function testDoesNotTransfersEmptyBatches() + { + $batch = new BatchRequestTransfer(2); + $batch->transfer(array()); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/BatchSizeDivisorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/BatchSizeDivisorTest.php new file mode 100644 index 0000000..5542228 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/BatchSizeDivisorTest.php @@ -0,0 +1,24 @@ +assertEquals(3, $d->getSize()); + $d->setSize(2); + $batches = $d->createBatches($queue); + $this->assertEquals(array(array('foo', 'baz'), array('bar')), $batches); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/BatchTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/BatchTest.php new file mode 100644 index 0000000..296f57a --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/BatchTest.php @@ -0,0 +1,91 @@ +getMock('Guzzle\Batch\BatchTransferInterface'); + } + + private function getMockDivisor() + { + return $this->getMock('Guzzle\Batch\BatchDivisorInterface'); + } + + public function testAddsItemsToQueue() + { + $batch = new Batch($this->getMockTransfer(), $this->getMockDivisor()); + $this->assertSame($batch, $batch->add('foo')); + $this->assertEquals(1, count($batch)); + } + + public function testFlushReturnsItems() + { + $transfer = $this->getMockTransfer(); + $transfer->expects($this->exactly(2)) + ->method('transfer'); + + $divisor = $this->getMockDivisor(); + $divisor->expects($this->once()) + ->method('createBatches') + ->will($this->returnValue(array(array('foo', 'baz'), array('bar')))); + + $batch = new Batch($transfer, $divisor); + + $batch->add('foo')->add('baz')->add('bar'); + $items = $batch->flush(); + + $this->assertEquals(array('foo', 'baz', 'bar'), $items); + } + + public function testThrowsExceptionContainingTheFailedBatch() + { + $called = 0; + $originalException = new \Exception('Foo!'); + + $transfer = $this->getMockTransfer(); + $transfer->expects($this->exactly(2)) + ->method('transfer') + ->will($this->returnCallback(function () use (&$called, $originalException) { + if (++$called == 2) { + throw $originalException; + } + })); + + $divisor = $this->getMockDivisor(); + $batch = new Batch($transfer, $divisor); + + // PHPunit clones objects before passing them to a callback. + // Horrible hack to get around this! + $queue = $this->readAttribute($batch, 'queue'); + + $divisor->expects($this->once()) + ->method('createBatches') + ->will($this->returnCallback(function ($batch) use ($queue) { + foreach ($queue as $item) { + $items[] = $item; + } + return array_chunk($items, 2); + })); + + $batch->add('foo')->add('baz')->add('bar')->add('bee')->add('boo'); + $this->assertFalse($batch->isEmpty()); + + try { + $items = $batch->flush(); + $this->fail('Expected exception'); + } catch (BatchTransferException $e) { + $this->assertEquals($originalException, $e->getPrevious()); + $this->assertEquals(array('bar', 'bee'), array_values($e->getBatch())); + $this->assertEquals(1, count($batch)); + } + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/ExceptionBufferingBatchTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/ExceptionBufferingBatchTest.php new file mode 100644 index 0000000..fd810b1 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/ExceptionBufferingBatchTest.php @@ -0,0 +1,45 @@ +getMockBuilder('Guzzle\Batch\BatchTransferInterface') + ->setMethods(array('transfer')) + ->getMock(); + + $d = new BatchSizeDivisor(1); + $batch = new Batch($t, $d); + + $called = 0; + $t->expects($this->exactly(3)) + ->method('transfer') + ->will($this->returnCallback(function ($batch) use (&$called) { + if (++$called === 2) { + throw new \Exception('Foo'); + } + })); + + $decorator = new ExceptionBufferingBatch($batch); + $decorator->add('foo')->add('baz')->add('bar'); + $result = $decorator->flush(); + + $e = $decorator->getExceptions(); + $this->assertEquals(1, count($e)); + $this->assertEquals(array('baz'), $e[0]->getBatch()); + + $decorator->clearExceptions(); + $this->assertEquals(0, count($decorator->getExceptions())); + + $this->assertEquals(array('foo', 'bar'), $result); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/FlushingBatchTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/FlushingBatchTest.php new file mode 100644 index 0000000..9b37a48 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/FlushingBatchTest.php @@ -0,0 +1,40 @@ +getMock('Guzzle\Batch\BatchTransferInterface', array('transfer')); + $d = $this->getMock('Guzzle\Batch\BatchDivisorInterface', array('createBatches')); + + $batch = new Batch($t, $d); + $queue = $this->readAttribute($batch, 'queue'); + + $d->expects($this->exactly(2)) + ->method('createBatches') + ->will($this->returnCallback(function () use ($queue) { + $items = array(); + foreach ($queue as $item) { + $items[] = $item; + } + return array($items); + })); + + $t->expects($this->exactly(2)) + ->method('transfer'); + + $flush = new FlushingBatch($batch, 3); + $this->assertEquals(3, $flush->getThreshold()); + $flush->setThreshold(2); + $flush->add('foo')->add('baz')->add('bar')->add('bee')->add('boo'); + $this->assertEquals(1, count($flush)); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/HistoryBatchTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/HistoryBatchTest.php new file mode 100644 index 0000000..60d6f95 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/HistoryBatchTest.php @@ -0,0 +1,26 @@ +getMock('Guzzle\Batch\BatchTransferInterface'), + $this->getMock('Guzzle\Batch\BatchDivisorInterface') + ); + + $history = new HistoryBatch($batch); + $history->add('foo')->add('baz'); + $this->assertEquals(array('foo', 'baz'), $history->getHistory()); + $history->clearHistory(); + $this->assertEquals(array(), $history->getHistory()); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/NotifyingBatchTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/NotifyingBatchTest.php new file mode 100644 index 0000000..69a8900 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Batch/NotifyingBatchTest.php @@ -0,0 +1,45 @@ +getMock('Guzzle\Batch\Batch', array('flush'), array( + $this->getMock('Guzzle\Batch\BatchTransferInterface'), + $this->getMock('Guzzle\Batch\BatchDivisorInterface') + )); + + $batch->expects($this->once()) + ->method('flush') + ->will($this->returnValue(array('foo', 'baz'))); + + $data = array(); + $decorator = new NotifyingBatch($batch, function ($batch) use (&$data) { + $data[] = $batch; + }); + + $decorator->add('foo')->add('baz'); + $decorator->flush(); + $this->assertEquals(array(array('foo', 'baz')), $data); + } + + /** + * @expectedException Guzzle\Common\Exception\InvalidArgumentException + */ + public function testEnsuresCallableIsValid() + { + $batch = new Batch( + $this->getMock('Guzzle\Batch\BatchTransferInterface'), + $this->getMock('Guzzle\Batch\BatchDivisorInterface') + ); + $decorator = new NotifyingBatch($batch, 'foo'); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Cache/CacheAdapterFactoryTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Cache/CacheAdapterFactoryTest.php new file mode 100644 index 0000000..c4140a9 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Cache/CacheAdapterFactoryTest.php @@ -0,0 +1,64 @@ +cache = new ArrayCache(); + $this->adapter = new DoctrineCacheAdapter($this->cache); + } + + /** + * @expectedException \InvalidArgumentException + */ + public function testEnsuresConfigIsObject() + { + CacheAdapterFactory::fromCache(array()); + } + + /** + * @expectedException \InvalidArgumentException + */ + public function testEnsuresKnownType() + { + CacheAdapterFactory::fromCache(new \stdClass()); + } + + public function cacheProvider() + { + return array( + array(new DoctrineCacheAdapter(new ArrayCache()), 'Guzzle\Cache\DoctrineCacheAdapter'), + array(new ArrayCache(), 'Guzzle\Cache\DoctrineCacheAdapter'), + array(StorageFactory::factory(array('adapter' => 'memory')), 'Guzzle\Cache\Zf2CacheAdapter'), + ); + } + + /** + * @dataProvider cacheProvider + */ + public function testCreatesNullCacheAdapterByDefault($cache, $type) + { + $adapter = CacheAdapterFactory::fromCache($cache); + $this->assertInstanceOf($type, $adapter); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Cache/CacheAdapterTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Cache/CacheAdapterTest.php new file mode 100644 index 0000000..3e30ddd --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Cache/CacheAdapterTest.php @@ -0,0 +1,68 @@ +cache = new ArrayCache(); + $this->adapter = new DoctrineCacheAdapter($this->cache); + } + + /** + * Cleans up the environment after running a test. + */ + protected function tearDown() + { + $this->adapter = null; + $this->cache = null; + parent::tearDown(); + } + + public function testGetCacheObject() + { + $this->assertEquals($this->cache, $this->adapter->getCacheObject()); + } + + public function testSave() + { + $this->assertTrue($this->adapter->save('test', 'data', 1000)); + } + + public function testFetch() + { + $this->assertTrue($this->adapter->save('test', 'data', 1000)); + $this->assertEquals('data', $this->adapter->fetch('test')); + } + + public function testContains() + { + $this->assertTrue($this->adapter->save('test', 'data', 1000)); + $this->assertTrue($this->adapter->contains('test')); + } + + public function testDelete() + { + $this->assertTrue($this->adapter->save('test', 'data', 1000)); + $this->assertTrue($this->adapter->delete('test')); + $this->assertFalse($this->adapter->contains('test')); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Cache/ClosureCacheAdapterTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Cache/ClosureCacheAdapterTest.php new file mode 100644 index 0000000..12de65b --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Cache/ClosureCacheAdapterTest.php @@ -0,0 +1,94 @@ +callables = array( + 'contains' => function($id, $options = array()) use ($that) { + return array_key_exists($id, $that->data); + }, + 'delete' => function($id, $options = array()) use ($that) { + unset($that->data[$id]); + return true; + }, + 'fetch' => function($id, $options = array()) use ($that) { + return array_key_exists($id, $that->data) ? $that->data[$id] : null; + }, + 'save' => function($id, $data, $lifeTime, $options = array()) use ($that) { + $that->data[$id] = $data; + return true; + } + ); + + $this->adapter = new ClosureCacheAdapter($this->callables); + } + + /** + * Cleans up the environment after running a test. + */ + protected function tearDown() + { + $this->cache = null; + $this->callables = null; + parent::tearDown(); + } + + /** + * @expectedException InvalidArgumentException + */ + public function testEnsuresCallablesArePresent() + { + $callables = $this->callables; + unset($callables['delete']); + $cache = new ClosureCacheAdapter($callables); + } + + public function testAllCallablesMustBePresent() + { + $cache = new ClosureCacheAdapter($this->callables); + } + + public function testCachesDataUsingCallables() + { + $this->assertTrue($this->adapter->save('test', 'data', 1000)); + $this->assertEquals('data', $this->adapter->fetch('test')); + } + + public function testChecksIfCacheContainsKeys() + { + $this->adapter->save('test', 'data', 1000); + $this->assertTrue($this->adapter->contains('test')); + $this->assertFalse($this->adapter->contains('foo')); + } + + public function testDeletesFromCacheByKey() + { + $this->adapter->save('test', 'data', 1000); + $this->assertTrue($this->adapter->contains('test')); + $this->adapter->delete('test'); + $this->assertFalse($this->adapter->contains('test')); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Cache/NullCacheAdapterTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Cache/NullCacheAdapterTest.php new file mode 100644 index 0000000..e05df3f --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Cache/NullCacheAdapterTest.php @@ -0,0 +1,20 @@ +assertEquals(false, $c->contains('foo')); + $this->assertEquals(true, $c->delete('foo')); + $this->assertEquals(false, $c->fetch('foo')); + $this->assertEquals(true, $c->save('foo', 'bar')); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Cache/Zf2CacheAdapterTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Cache/Zf2CacheAdapterTest.php new file mode 100644 index 0000000..9077c12 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Cache/Zf2CacheAdapterTest.php @@ -0,0 +1,58 @@ +cache = StorageFactory::factory(array( + 'adapter' => 'memory' + )); + $this->adapter = new Zf2CacheAdapter($this->cache); + } + + /** + * Cleans up the environment after running a test. + */ + protected function tearDown() + { + $this->adapter = null; + $this->cache = null; + parent::tearDown(); + } + + public function testCachesDataUsingCallables() + { + $this->assertTrue($this->adapter->save('test', 'data', 1000)); + $this->assertEquals('data', $this->adapter->fetch('test')); + } + + public function testChecksIfCacheContainsKeys() + { + $this->adapter->save('test', 'data', 1000); + $this->assertTrue($this->adapter->contains('test')); + $this->assertFalse($this->adapter->contains('foo')); + } + + public function testDeletesFromCacheByKey() + { + $this->adapter->save('test', 'data', 1000); + $this->assertTrue($this->adapter->contains('test')); + $this->adapter->delete('test'); + $this->assertFalse($this->adapter->contains('test')); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Common/AbstractHasDispatcherTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Common/AbstractHasDispatcherTest.php new file mode 100644 index 0000000..19d12e6 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Common/AbstractHasDispatcherTest.php @@ -0,0 +1,63 @@ +assertEquals(array(), AbstractHasDispatcher::getAllEvents()); + } + + public function testAllowsDispatcherToBeInjected() + { + $d = new EventDispatcher(); + $mock = $this->getMockForAbstractClass('Guzzle\Common\AbstractHasDispatcher'); + $this->assertSame($mock, $mock->setEventDispatcher($d)); + $this->assertSame($d, $mock->getEventDispatcher()); + } + + public function testCreatesDefaultEventDispatcherIfNeeded() + { + $mock = $this->getMockForAbstractClass('Guzzle\Common\AbstractHasDispatcher'); + $this->assertInstanceOf('Symfony\Component\EventDispatcher\EventDispatcher', $mock->getEventDispatcher()); + } + + public function testHelperDispatchesEvents() + { + $data = array(); + $mock = $this->getMockForAbstractClass('Guzzle\Common\AbstractHasDispatcher'); + $mock->getEventDispatcher()->addListener('test', function(Event $e) use (&$data) { + $data = $e->getIterator()->getArrayCopy(); + }); + $mock->dispatch('test', array( + 'param' => 'abc' + )); + $this->assertEquals(array( + 'param' => 'abc', + ), $data); + } + + public function testHelperAttachesSubscribers() + { + $mock = $this->getMockForAbstractClass('Guzzle\Common\AbstractHasDispatcher'); + $subscriber = $this->getMockForAbstractClass('Symfony\Component\EventDispatcher\EventSubscriberInterface'); + + $dispatcher = $this->getMockBuilder('Symfony\Component\EventDispatcher\EventDispatcher') + ->setMethods(array('addSubscriber')) + ->getMock(); + + $dispatcher->expects($this->once()) + ->method('addSubscriber'); + + $mock->setEventDispatcher($dispatcher); + $mock->addSubscriber($subscriber); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Common/CollectionTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Common/CollectionTest.php new file mode 100644 index 0000000..0648a02 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Common/CollectionTest.php @@ -0,0 +1,529 @@ +coll = new Collection(); + } + + public function testConstructorCanBeCalledWithNoParams() + { + $this->coll = new Collection(); + $p = $this->coll->getAll(); + $this->assertEmpty($p, '-> Collection must be empty when no data is passed'); + } + + public function testConstructorCanBeCalledWithParams() + { + $testData = array( + 'test' => 'value', + 'test_2' => 'value2' + ); + $this->coll = new Collection($testData); + $this->assertEquals($this->coll->getAll(), $testData, '-> getAll() must return the data passed in the constructor'); + $this->assertEquals($this->coll->getAll(), $this->coll->toArray()); + } + + public function testImplementsIteratorAggregate() + { + $this->coll->set('key', 'value'); + $this->assertInstanceOf('ArrayIterator', $this->coll->getIterator()); + $this->assertEquals(1, count($this->coll)); + $total = 0; + foreach ($this->coll as $key => $value) { + $this->assertEquals('key', $key); + $this->assertEquals('value', $value); + $total++; + } + $this->assertEquals(1, $total); + } + + public function testCanAddValuesToExistingKeysByUsingArray() + { + $this->coll->add('test', 'value1'); + $this->assertEquals($this->coll->getAll(), array('test' => 'value1')); + $this->coll->add('test', 'value2'); + $this->assertEquals($this->coll->getAll(), array('test' => array('value1', 'value2'))); + $this->coll->add('test', 'value3'); + $this->assertEquals($this->coll->getAll(), array('test' => array('value1', 'value2', 'value3'))); + } + + public function testHandlesMergingInDisparateDataSources() + { + $params = array( + 'test' => 'value1', + 'test2' => 'value2', + 'test3' => array('value3', 'value4') + ); + $this->coll->merge($params); + $this->assertEquals($this->coll->getAll(), $params); + + // Pass the same object to itself + $this->assertEquals($this->coll->merge($this->coll), $this->coll); + } + + public function testCanClearAllDataOrSpecificKeys() + { + $this->coll->merge(array( + 'test' => 'value1', + 'test2' => 'value2' + )); + + // Clear a specific parameter by name + $this->coll->remove('test'); + + $this->assertEquals($this->coll->getAll(), array( + 'test2' => 'value2' + )); + + // Clear all parameters + $this->coll->clear(); + + $this->assertEquals($this->coll->getAll(), array()); + } + + public function testGetsValuesByKey() + { + $this->assertNull($this->coll->get('test')); + $this->coll->add('test', 'value'); + $this->assertEquals('value', $this->coll->get('test')); + $this->coll->set('test2', 'v2'); + $this->coll->set('test3', 'v3'); + $this->assertEquals(array( + 'test' => 'value', + 'test2' => 'v2' + ), $this->coll->getAll(array('test', 'test2'))); + } + + public function testProvidesKeys() + { + $this->assertEquals(array(), $this->coll->getKeys()); + $this->coll->merge(array( + 'test1' => 'value1', + 'test2' => 'value2' + )); + $this->assertEquals(array('test1', 'test2'), $this->coll->getKeys()); + // Returns the cached array previously returned + $this->assertEquals(array('test1', 'test2'), $this->coll->getKeys()); + $this->coll->remove('test1'); + $this->assertEquals(array('test2'), $this->coll->getKeys()); + $this->coll->add('test3', 'value3'); + $this->assertEquals(array('test2', 'test3'), $this->coll->getKeys()); + } + + public function testChecksIfHasKey() + { + $this->assertFalse($this->coll->hasKey('test')); + $this->coll->add('test', 'value'); + $this->assertEquals(true, $this->coll->hasKey('test')); + $this->coll->add('test2', 'value2'); + $this->assertEquals(true, $this->coll->hasKey('test')); + $this->assertEquals(true, $this->coll->hasKey('test2')); + $this->assertFalse($this->coll->hasKey('testing')); + $this->assertEquals(false, $this->coll->hasKey('AB-C', 'junk')); + } + + public function testChecksIfHasValue() + { + $this->assertFalse($this->coll->hasValue('value')); + $this->coll->add('test', 'value'); + $this->assertEquals('test', $this->coll->hasValue('value')); + $this->coll->add('test2', 'value2'); + $this->assertEquals('test', $this->coll->hasValue('value')); + $this->assertEquals('test2', $this->coll->hasValue('value2')); + $this->assertFalse($this->coll->hasValue('val')); + } + + public function testCanGetAllValuesByArray() + { + $this->coll->add('foo', 'bar'); + $this->coll->add('tEsT', 'value'); + $this->coll->add('tesTing', 'v2'); + $this->coll->add('key', 'v3'); + $this->assertNull($this->coll->get('test')); + $this->assertEquals(array( + 'foo' => 'bar', + 'tEsT' => 'value', + 'tesTing' => 'v2' + ), $this->coll->getAll(array( + 'foo', 'tesTing', 'tEsT' + ))); + } + + public function testImplementsCount() + { + $data = new Collection(); + $this->assertEquals(0, $data->count()); + $data->add('key', 'value'); + $this->assertEquals(1, count($data)); + $data->add('key', 'value2'); + $this->assertEquals(1, count($data)); + $data->add('key_2', 'value3'); + $this->assertEquals(2, count($data)); + } + + public function testAddParamsByMerging() + { + $params = array( + 'test' => 'value1', + 'test2' => 'value2', + 'test3' => array('value3', 'value4') + ); + + // Add some parameters + $this->coll->merge($params); + + // Add more parameters by merging them in + $this->coll->merge(array( + 'test' => 'another', + 'different_key' => 'new value' + )); + + $this->assertEquals(array( + 'test' => array('value1', 'another'), + 'test2' => 'value2', + 'test3' => array('value3', 'value4'), + 'different_key' => 'new value' + ), $this->coll->getAll()); + } + + public function testAllowsFunctionalFilter() + { + $this->coll->merge(array( + 'fruit' => 'apple', + 'number' => 'ten', + 'prepositions' => array('about', 'above', 'across', 'after'), + 'same_number' => 'ten' + )); + + $filtered = $this->coll->filter(function($key, $value) { + return $value == 'ten'; + }); + + $this->assertNotEquals($filtered, $this->coll); + + $this->assertEquals(array( + 'number' => 'ten', + 'same_number' => 'ten' + ), $filtered->getAll()); + } + + public function testAllowsFunctionalMapping() + { + $this->coll->merge(array( + 'number_1' => 1, + 'number_2' => 2, + 'number_3' => 3 + )); + + $mapped = $this->coll->map(function($key, $value) { + return $value * $value; + }); + + $this->assertNotEquals($mapped, $this->coll); + + $this->assertEquals(array( + 'number_1' => 1, + 'number_2' => 4, + 'number_3' => 9 + ), $mapped->getAll()); + } + + public function testImplementsArrayAccess() + { + $this->coll->merge(array( + 'k1' => 'v1', + 'k2' => 'v2' + )); + + $this->assertTrue($this->coll->offsetExists('k1')); + $this->assertFalse($this->coll->offsetExists('Krull')); + + $this->coll->offsetSet('k3', 'v3'); + $this->assertEquals('v3', $this->coll->offsetGet('k3')); + $this->assertEquals('v3', $this->coll->get('k3')); + + $this->coll->offsetUnset('k1'); + $this->assertFalse($this->coll->offsetExists('k1')); + } + + public function testUsesStaticWhenCreatingNew() + { + $qs = new QueryString(array( + 'a' => 'b', + 'c' => 'd' + )); + + $this->assertInstanceOf('Guzzle\\Http\\QueryString', $qs->map(function($a, $b) {})); + $this->assertInstanceOf('Guzzle\\Common\\Collection', $qs->map(function($a, $b) {}, array(), false)); + + $this->assertInstanceOf('Guzzle\\Http\\QueryString', $qs->filter(function($a, $b) {})); + $this->assertInstanceOf('Guzzle\\Common\\Collection', $qs->filter(function($a, $b) {}, false)); + } + + public function testCanReplaceAllData() + { + $this->assertSame($this->coll, $this->coll->replace(array( + 'a' => '123' + ))); + + $this->assertEquals(array( + 'a' => '123' + ), $this->coll->getAll()); + } + + public function dataProvider() + { + return array( + array('this_is_a_test', '{a}_is_a_{b}', array( + 'a' => 'this', + 'b' => 'test' + )), + array('this_is_a_test', '{abc}_is_a_{0}', array( + 'abc' => 'this', + 0 => 'test' + )), + array('this_is_a_test', '{abc}_is_a_{0}', array( + 'abc' => 'this', + 0 => 'test' + )), + array('this_is_a_test', 'this_is_a_test', array( + 'abc' => 'this' + )), + array('{abc}_is_{not_found}a_{0}', '{abc}_is_{not_found}a_{0}', array()) + ); + } + + /** + * @dataProvider dataProvider + */ + public function testInjectsConfigData($output, $input, $config) + { + $collection = new Collection($config); + $this->assertEquals($output, $collection->inject($input)); + } + + public function testCanSearchByKey() + { + $collection = new Collection(array( + 'foo' => 'bar', + 'BaZ' => 'pho' + )); + + $this->assertEquals('foo', $collection->keySearch('FOO')); + $this->assertEquals('BaZ', $collection->keySearch('baz')); + $this->assertEquals(false, $collection->keySearch('Bar')); + } + + public function testPreparesFromConfig() + { + $c = Collection::fromConfig(array( + 'a' => '123', + 'base_url' => 'http://www.test.com/' + ), array( + 'a' => 'xyz', + 'b' => 'lol' + ), array('a')); + + $this->assertInstanceOf('Guzzle\Common\Collection', $c); + $this->assertEquals(array( + 'a' => '123', + 'b' => 'lol', + 'base_url' => 'http://www.test.com/' + ), $c->getAll()); + + try { + $c = Collection::fromConfig(array(), array(), array('a')); + $this->fail('Exception not throw when missing config'); + } catch (InvalidArgumentException $e) { + } + } + + function falseyDataProvider() + { + return array( + array(false, false), + array(null, null), + array('', ''), + array(array(), array()), + array(0, 0), + ); + } + + /** + * @dataProvider falseyDataProvider + */ + public function testReturnsCorrectData($a, $b) + { + $c = new Collection(array('value' => $a)); + $this->assertSame($b, $c->get('value')); + } + + public function testRetrievesNestedKeysUsingPath() + { + $data = array( + 'foo' => 'bar', + 'baz' => array( + 'mesa' => array( + 'jar' => 'jar' + ) + ) + ); + $collection = new Collection($data); + $this->assertEquals('bar', $collection->getPath('foo')); + $this->assertEquals('jar', $collection->getPath('baz/mesa/jar')); + $this->assertNull($collection->getPath('wewewf')); + $this->assertNull($collection->getPath('baz/mesa/jar/jar')); + } + + public function testFalseyKeysStillDescend() + { + $collection = new Collection(array( + '0' => array( + 'a' => 'jar' + ), + 1 => 'other' + )); + $this->assertEquals('jar', $collection->getPath('0/a')); + $this->assertEquals('other', $collection->getPath('1')); + } + + public function getPathProvider() + { + $data = array( + 'foo' => 'bar', + 'baz' => array( + 'mesa' => array( + 'jar' => 'jar', + 'array' => array('a', 'b', 'c') + ), + 'bar' => array( + 'baz' => 'bam', + 'array' => array('d', 'e', 'f') + ) + ), + 'bam' => array( + array('foo' => 1), + array('foo' => 2), + array('array' => array('h', 'i')) + ) + ); + $c = new Collection($data); + + return array( + // Simple path selectors + array($c, 'foo', 'bar'), + array($c, 'baz', $data['baz']), + array($c, 'bam', $data['bam']), + array($c, 'baz/mesa', $data['baz']['mesa']), + array($c, 'baz/mesa/jar', 'jar'), + // Merge everything two levels under baz + array($c, 'baz/*', array( + 'jar' => 'jar', + 'array' => array_merge($data['baz']['mesa']['array'], $data['baz']['bar']['array']), + 'baz' => 'bam' + )), + // Does not barf on missing keys + array($c, 'fefwfw', null), + // Does not barf when a wildcard does not resolve correctly + array($c, '*/*/*/*/*/wefwfe', array()), + // Allows custom separator + array($c, '*|mesa', $data['baz']['mesa'], '|'), + // Merge all 'array' keys two levels under baz (the trailing * does not hurt the results) + array($c, 'baz/*/array/*', array_merge($data['baz']['mesa']['array'], $data['baz']['bar']['array'])), + // Merge all 'array' keys two levels under baz + array($c, 'baz/*/array', array_merge($data['baz']['mesa']['array'], $data['baz']['bar']['array'])), + array($c, 'baz/mesa/array', $data['baz']['mesa']['array']), + // Having a trailing * does not hurt the results + array($c, 'baz/mesa/array/*', $data['baz']['mesa']['array']), + // Merge of anything one level deep + array($c, '*', array_merge(array('bar'), $data['baz'], $data['bam'])), + // Funky merge of anything two levels deep + array($c, '*/*', array( + 'jar' => 'jar', + 'array' => array('a', 'b', 'c', 'd', 'e', 'f', 'h', 'i'), + 'baz' => 'bam', + 'foo' => array(1, 2) + )), + // Funky merge of all 'array' keys that are two levels deep + array($c, '*/*/array', array('a', 'b', 'c', 'd', 'e', 'f', 'h', 'i')) + ); + } + + /** + * @dataProvider getPathProvider + */ + public function testGetPath(Collection $c, $path, $expected, $separator = '/') + { + $this->assertEquals($expected, $c->getPath($path, $separator)); + } + + public function testOverridesSettings() + { + $c = new Collection(array('foo' => 1, 'baz' => 2, 'bar' => 3)); + $c->overwriteWith(array('foo' => 10, 'bar' => 300)); + $this->assertEquals(array('foo' => 10, 'baz' => 2, 'bar' => 300), $c->getAll()); + } + + public function testOverwriteWithCollection() + { + $c = new Collection(array('foo' => 1, 'baz' => 2, 'bar' => 3)); + $b = new Collection(array('foo' => 10, 'bar' => 300)); + $c->overwriteWith($b); + $this->assertEquals(array('foo' => 10, 'baz' => 2, 'bar' => 300), $c->getAll()); + } + + public function testOverwriteWithTraversable() + { + $c = new Collection(array('foo' => 1, 'baz' => 2, 'bar' => 3)); + $b = new Collection(array('foo' => 10, 'bar' => 300)); + $c->overwriteWith($b->getIterator()); + $this->assertEquals(array('foo' => 10, 'baz' => 2, 'bar' => 300), $c->getAll()); + } + + public function testCanSetNestedPathValueThatDoesNotExist() + { + $c = new Collection(array()); + $c->setPath('foo/bar/baz/123', 'hi'); + $this->assertEquals('hi', $c['foo']['bar']['baz']['123']); + } + + public function testCanSetNestedPathValueThatExists() + { + $c = new Collection(array('foo' => array('bar' => 'test'))); + $c->setPath('foo/bar', 'hi'); + $this->assertEquals('hi', $c['foo']['bar']); + } + + /** + * @expectedException \Guzzle\Common\Exception\RuntimeException + */ + public function testVerifiesNestedPathIsValidAtExactLevel() + { + $c = new Collection(array('foo' => 'bar')); + $c->setPath('foo/bar', 'hi'); + $this->assertEquals('hi', $c['foo']['bar']); + } + + /** + * @expectedException \Guzzle\Common\Exception\RuntimeException + */ + public function testVerifiesThatNestedPathIsValidAtAnyLevel() + { + $c = new Collection(array('foo' => 'bar')); + $c->setPath('foo/bar/baz', 'test'); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Common/EventTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Common/EventTest.php new file mode 100644 index 0000000..5484e14 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Common/EventTest.php @@ -0,0 +1,62 @@ + '123', + 'other' => '456', + 'event' => 'test.notify' + )); + } + + public function testAllowsParameterInjection() + { + $event = new Event(array( + 'test' => '123' + )); + $this->assertEquals('123', $event['test']); + } + + public function testImplementsArrayAccess() + { + $event = $this->getEvent(); + $this->assertEquals('123', $event['test']); + $this->assertNull($event['foobar']); + + $this->assertTrue($event->offsetExists('test')); + $this->assertFalse($event->offsetExists('foobar')); + + unset($event['test']); + $this->assertFalse($event->offsetExists('test')); + + $event['test'] = 'new'; + $this->assertEquals('new', $event['test']); + } + + public function testImplementsIteratorAggregate() + { + $event = $this->getEvent(); + $this->assertInstanceOf('ArrayIterator', $event->getIterator()); + } + + public function testConvertsToArray() + { + $this->assertEquals(array( + 'test' => '123', + 'other' => '456', + 'event' => 'test.notify' + ), $this->getEvent()->toArray()); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Common/Exception/BatchTransferExceptionTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Common/Exception/BatchTransferExceptionTest.php new file mode 100644 index 0000000..c72a2a6 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Common/Exception/BatchTransferExceptionTest.php @@ -0,0 +1,21 @@ +getMock('Guzzle\Batch\BatchTransferInterface'); + $d = $this->getMock('Guzzle\Batch\BatchDivisorInterface'); + $transferException = new BatchTransferException(array('foo'), array(1, 2), $e, $t, $d); + $this->assertEquals(array('foo'), $transferException->getBatch()); + $this->assertSame($t, $transferException->getTransferStrategy()); + $this->assertSame($d, $transferException->getDivisorStrategy()); + $this->assertSame($e, $transferException->getPrevious()); + $this->assertEquals(array(1, 2), $transferException->getTransferredItems()); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Common/Exception/ExceptionCollectionTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Common/Exception/ExceptionCollectionTest.php new file mode 100644 index 0000000..2aecf2a --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Common/Exception/ExceptionCollectionTest.php @@ -0,0 +1,66 @@ +getExceptions(); + $e->add($exceptions[0]); + $e->add($exceptions[1]); + $this->assertContains("(Exception) ./tests/Guzzle/Tests/Common/Exception/ExceptionCollectionTest.php line ", $e->getMessage()); + $this->assertContains(" Test\n\n #0 ./", $e->getMessage()); + $this->assertSame($exceptions[0], $e->getFirst()); + } + + public function testCanSetExceptions() + { + $ex = new \Exception('foo'); + $e = new ExceptionCollection(); + $e->setExceptions(array($ex)); + $this->assertSame($ex, $e->getFirst()); + } + + public function testActsAsArray() + { + $e = new ExceptionCollection(); + $exceptions = $this->getExceptions(); + $e->add($exceptions[0]); + $e->add($exceptions[1]); + $this->assertEquals(2, count($e)); + $this->assertEquals($exceptions, $e->getIterator()->getArrayCopy()); + } + + public function testCanAddSelf() + { + $e1 = new ExceptionCollection(); + $e1->add(new \Exception("Test")); + $e2 = new ExceptionCollection('Meta description!'); + $e2->add(new \Exception("Test 2")); + $e3 = new ExceptionCollection(); + $e3->add(new \Exception('Baz')); + $e2->add($e3); + $e1->add($e2); + $message = $e1->getMessage(); + $this->assertContains("(Exception) ./tests/Guzzle/Tests/Common/Exception/ExceptionCollectionTest.php line ", $message); + $this->assertContains("\n Test\n\n #0 ", $message); + $this->assertContains("\n\n(Guzzle\\Common\\Exception\\ExceptionCollection) ./tests/Guzzle/Tests/Common/Exception/ExceptionCollectionTest.php line ", $message); + $this->assertContains("\n\n Meta description!\n\n", $message); + $this->assertContains(" (Exception) ./tests/Guzzle/Tests/Common/Exception/ExceptionCollectionTest.php line ", $message); + $this->assertContains("\n Test 2\n\n #0 ", $message); + $this->assertContains(" (Exception) ./tests/Guzzle/Tests/Common/Exception/ExceptionCollectionTest.php line ", $message); + $this->assertContains(" Baz\n\n #0", $message); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Common/VersionTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Common/VersionTest.php new file mode 100644 index 0000000..c3a81d1 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Common/VersionTest.php @@ -0,0 +1,27 @@ +isRunning()) { + self::$server->flush(); + } else { + self::$server->start(); + } + } + + return self::$server; + } + + /** + * Set the service builder to use for tests + * + * @param ServiceBuilderInterface $builder Service builder + */ + public static function setServiceBuilder(ServiceBuilderInterface $builder) + { + self::$serviceBuilder = $builder; + } + + /** + * Get a service builder object that can be used throughout the service tests + * + * @return ServiceBuilder + */ + public static function getServiceBuilder() + { + if (!self::$serviceBuilder) { + throw new RuntimeException('No service builder has been set via setServiceBuilder()'); + } + + return self::$serviceBuilder; + } + + /** + * Check if an event dispatcher has a subscriber + * + * @param HasDispatcherInterface $dispatcher + * @param EventSubscriberInterface $subscriber + * + * @return bool + */ + protected function hasSubscriber(HasDispatcherInterface $dispatcher, EventSubscriberInterface $subscriber) + { + $class = get_class($subscriber); + $all = array_keys(call_user_func(array($class, 'getSubscribedEvents'))); + + foreach ($all as $i => $event) { + foreach ($dispatcher->getEventDispatcher()->getListeners($event) as $e) { + if ($e[0] === $subscriber) { + unset($all[$i]); + break; + } + } + } + + return count($all) == 0; + } + + /** + * Get a wildcard observer for an event dispatcher + * + * @param HasDispatcherInterface $hasDispatcher + * + * @return MockObserver + */ + public function getWildcardObserver(HasDispatcherInterface $hasDispatcher) + { + $class = get_class($hasDispatcher); + $o = new MockObserver(); + $events = call_user_func(array($class, 'getAllEvents')); + foreach ($events as $event) { + $hasDispatcher->getEventDispatcher()->addListener($event, array($o, 'update')); + } + + return $o; + } + + /** + * Set the mock response base path + * + * @param string $path Path to mock response folder + * + * @return GuzzleTestCase + */ + public static function setMockBasePath($path) + { + self::$mockBasePath = $path; + } + + /** + * Mark a request as being mocked + * + * @param RequestInterface $request + * + * @return self + */ + public function addMockedRequest(RequestInterface $request) + { + $this->requests[] = $request; + + return $this; + } + + /** + * Get all of the mocked requests + * + * @return array + */ + public function getMockedRequests() + { + return $this->requests; + } + + /** + * Get a mock response for a client by mock file name + * + * @param string $path Relative path to the mock response file + * + * @return Response + */ + public function getMockResponse($path) + { + return $path instanceof Response + ? $path + : MockPlugin::getMockFile(self::$mockBasePath . DIRECTORY_SEPARATOR . $path); + } + + /** + * Set a mock response from a mock file on the next client request. + * + * This method assumes that mock response files are located under the + * Command/Mock/ directory of the Service being tested + * (e.g. Unfuddle/Command/Mock/). A mock response is added to the next + * request sent by the client. + * + * @param Client $client Client object to modify + * @param string $paths Path to files within the Mock folder of the service + * + * @return MockPlugin returns the created mock plugin + */ + public function setMockResponse(Client $client, $paths) + { + $this->requests = array(); + $that = $this; + $mock = new MockPlugin(null, true); + $client->getEventDispatcher()->removeSubscriber($mock); + $mock->getEventDispatcher()->addListener('mock.request', function(Event $event) use ($that) { + $that->addMockedRequest($event['request']); + }); + + if ($paths instanceof Response) { + // A single response instance has been specified, create an array with that instance + // as the only element for the following loop to work as expected + $paths = array($paths); + } + + foreach ((array) $paths as $path) { + $mock->addResponse($this->getMockResponse($path)); + } + + $client->getEventDispatcher()->addSubscriber($mock); + + return $mock; + } + + /** + * Compare HTTP headers and use special markup to filter values + * A header prefixed with '!' means it must not exist + * A header prefixed with '_' means it must be ignored + * A header value of '*' means anything after the * will be ignored + * + * @param array $filteredHeaders Array of special headers + * @param array $actualHeaders Array of headers to check against + * + * @return array|bool Returns an array of the differences or FALSE if none + */ + public function compareHeaders($filteredHeaders, $actualHeaders) + { + $comparison = new HeaderComparison(); + + return $comparison->compare($filteredHeaders, $actualHeaders); + } + + /** + * Case insensitive assertContains + * + * @param string $needle Search string + * @param string $haystack Search this + * @param string $message Optional failure message + */ + public function assertContainsIns($needle, $haystack, $message = null) + { + $this->assertContains(strtolower($needle), strtolower($haystack), $message); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/AbstractEntityBodyDecoratorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/AbstractEntityBodyDecoratorTest.php new file mode 100644 index 0000000..20feaa8 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/AbstractEntityBodyDecoratorTest.php @@ -0,0 +1,34 @@ +getMockForAbstractClass('Guzzle\Http\AbstractEntityBodyDecorator', array($e)); + + $this->assertSame($e->getStream(), $mock->getStream()); + $this->assertSame($e->getContentLength(), $mock->getContentLength()); + $this->assertSame($e->getSize(), $mock->getSize()); + $this->assertSame($e->getContentMd5(), $mock->getContentMd5()); + $this->assertSame($e->getContentType(), $mock->getContentType()); + $this->assertSame($e->__toString(), $mock->__toString()); + $this->assertSame($e->getUri(), $mock->getUri()); + $this->assertSame($e->getStreamType(), $mock->getStreamType()); + $this->assertSame($e->getWrapper(), $mock->getWrapper()); + $this->assertSame($e->getWrapperData(), $mock->getWrapperData()); + $this->assertSame($e->isReadable(), $mock->isReadable()); + $this->assertSame($e->isWritable(), $mock->isWritable()); + $this->assertSame($e->isConsumed(), $mock->isConsumed()); + $this->assertSame($e->isLocal(), $mock->isLocal()); + $this->assertSame($e->isSeekable(), $mock->isSeekable()); + $this->assertSame($e->getContentEncoding(), $mock->getContentEncoding()); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/CachingEntityBodyTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/CachingEntityBodyTest.php new file mode 100644 index 0000000..e6e6cdb --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/CachingEntityBodyTest.php @@ -0,0 +1,249 @@ +decorated = EntityBody::factory('testing'); + $this->body = new CachingEntityBody($this->decorated); + } + + public function testUsesRemoteSizeIfPossible() + { + $body = EntityBody::factory('test'); + $caching = new CachingEntityBody($body); + $this->assertEquals(4, $caching->getSize()); + $this->assertEquals(4, $caching->getContentLength()); + } + + /** + * @expectedException \Guzzle\Common\Exception\RuntimeException + * @expectedExceptionMessage does not support custom stream rewind + */ + public function testDoesNotAllowRewindFunction() + { + $this->body->setRewindFunction(true); + } + + /** + * @expectedException \Guzzle\Common\Exception\RuntimeException + * @expectedExceptionMessage Cannot seek to byte 10 + */ + public function testCannotSeekPastWhatHasBeenRead() + { + $this->body->seek(10); + } + + /** + * @expectedException \Guzzle\Common\Exception\RuntimeException + * @expectedExceptionMessage supports only SEEK_SET and SEEK_CUR + */ + public function testCannotUseSeekEnd() + { + $this->body->seek(2, SEEK_END); + } + + public function testChangingUnderlyingStreamUpdatesSizeAndStream() + { + $size = filesize(__FILE__); + $s = fopen(__FILE__, 'r'); + $this->body->setStream($s, $size); + $this->assertEquals($size, $this->body->getSize()); + $this->assertEquals($size, $this->decorated->getSize()); + $this->assertSame($s, $this->body->getStream()); + $this->assertSame($s, $this->decorated->getStream()); + } + + public function testRewindUsesSeek() + { + $a = EntityBody::factory('foo'); + $d = $this->getMockBuilder('Guzzle\Http\CachingEntityBody') + ->setMethods(array('seek')) + ->setConstructorArgs(array($a)) + ->getMock(); + $d->expects($this->once()) + ->method('seek') + ->with(0) + ->will($this->returnValue(true)); + $d->rewind(); + } + + public function testCanSeekToReadBytes() + { + $this->assertEquals('te', $this->body->read(2)); + $this->body->seek(0); + $this->assertEquals('test', $this->body->read(4)); + $this->assertEquals(4, $this->body->ftell()); + $this->body->seek(2); + $this->assertEquals(2, $this->body->ftell()); + $this->body->seek(2, SEEK_CUR); + $this->assertEquals(4, $this->body->ftell()); + $this->assertEquals('ing', $this->body->read(3)); + } + + public function testWritesToBufferStream() + { + $this->body->read(2); + $this->body->write('hi'); + $this->body->rewind(); + $this->assertEquals('tehiing', (string) $this->body); + } + + public function testReadLinesFromBothStreams() + { + $this->body->seek($this->body->ftell()); + $this->body->write("test\n123\nhello\n1234567890\n"); + $this->body->rewind(); + $this->assertEquals("test\n", $this->body->readLine(7)); + $this->assertEquals("123\n", $this->body->readLine(7)); + $this->assertEquals("hello\n", $this->body->readLine(7)); + $this->assertEquals("123456", $this->body->readLine(7)); + $this->assertEquals("7890\n", $this->body->readLine(7)); + // We overwrote the decorated stream, so no more data + $this->assertEquals('', $this->body->readLine(7)); + } + + public function testSkipsOverwrittenBytes() + { + $decorated = EntityBody::factory( + implode("\n", array_map(function ($n) { + return str_pad($n, 4, '0', STR_PAD_LEFT); + }, range(0, 25))) + ); + + $body = new CachingEntityBody($decorated); + + $this->assertEquals("0000\n", $body->readLine()); + $this->assertEquals("0001\n", $body->readLine()); + // Write over part of the body yet to be read, so skip some bytes + $this->assertEquals(5, $body->write("TEST\n")); + $this->assertEquals(5, $this->readAttribute($body, 'skipReadBytes')); + // Read, which skips bytes, then reads + $this->assertEquals("0003\n", $body->readLine()); + $this->assertEquals(0, $this->readAttribute($body, 'skipReadBytes')); + $this->assertEquals("0004\n", $body->readLine()); + $this->assertEquals("0005\n", $body->readLine()); + + // Overwrite part of the cached body (so don't skip any bytes) + $body->seek(5); + $this->assertEquals(5, $body->write("ABCD\n")); + $this->assertEquals(0, $this->readAttribute($body, 'skipReadBytes')); + $this->assertEquals("TEST\n", $body->readLine()); + $this->assertEquals("0003\n", $body->readLine()); + $this->assertEquals("0004\n", $body->readLine()); + $this->assertEquals("0005\n", $body->readLine()); + $this->assertEquals("0006\n", $body->readLine()); + $this->assertEquals(5, $body->write("1234\n")); + $this->assertEquals(5, $this->readAttribute($body, 'skipReadBytes')); + + // Seek to 0 and ensure the overwritten bit is replaced + $body->rewind(); + $this->assertEquals("0000\nABCD\nTEST\n0003\n0004\n0005\n0006\n1234\n0008\n0009\n", $body->read(50)); + + // Ensure that casting it to a string does not include the bit that was overwritten + $this->assertContains("0000\nABCD\nTEST\n0003\n0004\n0005\n0006\n1234\n0008\n0009\n", (string) $body); + } + + public function testWrapsContentType() + { + $a = $this->getMockBuilder('Guzzle\Http\EntityBody') + ->setMethods(array('getContentType')) + ->setConstructorArgs(array(fopen(__FILE__, 'r'))) + ->getMock(); + $a->expects($this->once()) + ->method('getContentType') + ->will($this->returnValue('foo')); + $d = new CachingEntityBody($a); + $this->assertEquals('foo', $d->getContentType()); + } + + public function testWrapsContentEncoding() + { + $a = $this->getMockBuilder('Guzzle\Http\EntityBody') + ->setMethods(array('getContentEncoding')) + ->setConstructorArgs(array(fopen(__FILE__, 'r'))) + ->getMock(); + $a->expects($this->once()) + ->method('getContentEncoding') + ->will($this->returnValue('foo')); + $d = new CachingEntityBody($a); + $this->assertEquals('foo', $d->getContentEncoding()); + } + + public function testWrapsMetadata() + { + $a = $this->getMockBuilder('Guzzle\Http\EntityBody') + ->setMethods(array('getMetadata', 'getWrapper', 'getWrapperData', 'getStreamType', 'getUri')) + ->setConstructorArgs(array(fopen(__FILE__, 'r'))) + ->getMock(); + + $a->expects($this->once()) + ->method('getMetadata') + ->will($this->returnValue(array())); + // Called twice for getWrapper and getWrapperData + $a->expects($this->exactly(1)) + ->method('getWrapper') + ->will($this->returnValue('wrapper')); + $a->expects($this->once()) + ->method('getWrapperData') + ->will($this->returnValue(array())); + $a->expects($this->once()) + ->method('getStreamType') + ->will($this->returnValue('baz')); + $a->expects($this->once()) + ->method('getUri') + ->will($this->returnValue('path/to/foo')); + + $d = new CachingEntityBody($a); + $this->assertEquals(array(), $d->getMetaData()); + $this->assertEquals('wrapper', $d->getWrapper()); + $this->assertEquals(array(), $d->getWrapperData()); + $this->assertEquals('baz', $d->getStreamType()); + $this->assertEquals('path/to/foo', $d->getUri()); + } + + public function testWrapsCustomData() + { + $a = $this->getMockBuilder('Guzzle\Http\EntityBody') + ->setMethods(array('getCustomData', 'setCustomData')) + ->setConstructorArgs(array(fopen(__FILE__, 'r'))) + ->getMock(); + + $a->expects($this->exactly(1)) + ->method('getCustomData') + ->with('foo') + ->will($this->returnValue('bar')); + + $a->expects($this->exactly(1)) + ->method('setCustomData') + ->with('foo', 'bar') + ->will($this->returnSelf()); + + $d = new CachingEntityBody($a); + $this->assertSame($d, $d->setCustomData('foo', 'bar')); + $this->assertEquals('bar', $d->getCustomData('foo')); + } + + public function testClosesBothStreams() + { + $s = fopen('php://temp', 'r'); + $a = EntityBody::factory($s); + $d = new CachingEntityBody($a); + $d->close(); + $this->assertFalse(is_resource($s)); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/ClientTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/ClientTest.php new file mode 100644 index 0000000..4a91a18 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/ClientTest.php @@ -0,0 +1,601 @@ +assertEquals('http://www.google.com/', $client->getBaseUrl()); + $this->assertSame($client, $client->setConfig(array( + 'test' => '123' + ))); + $this->assertEquals(array('test' => '123'), $client->getConfig()->getAll()); + $this->assertEquals('123', $client->getConfig('test')); + $this->assertSame($client, $client->setBaseUrl('http://www.test.com/{test}')); + $this->assertEquals('http://www.test.com/123', $client->getBaseUrl()); + $this->assertEquals('http://www.test.com/{test}', $client->getBaseUrl(false)); + + try { + $client->setConfig(false); + } catch (\InvalidArgumentException $e) { + } + } + + public function testDescribesEvents() + { + $this->assertEquals(array('client.create_request'), Client::getAllEvents()); + } + + public function testConstructorCanAcceptConfig() + { + $client = new Client('http://www.test.com/', array( + 'data' => '123' + )); + $this->assertEquals('123', $client->getConfig('data')); + } + + public function testCanUseCollectionAsConfig() + { + $client = new Client('http://www.google.com/'); + $client->setConfig(new Collection(array( + 'api' => 'v1', + 'key' => 'value', + 'base_url' => 'http://www.google.com/' + ))); + $this->assertEquals('v1', $client->getConfig('api')); + } + + public function testExpandsUriTemplatesUsingConfig() + { + $client = new Client('http://www.google.com/'); + $client->setConfig(array('api' => 'v1', 'key' => 'value', 'foo' => 'bar')); + $ref = new \ReflectionMethod($client, 'expandTemplate'); + $ref->setAccessible(true); + $this->assertEquals('Testing...api/v1/key/value', $ref->invoke($client, 'Testing...api/{api}/key/{key}')); + } + + public function testClientAttachersObserversToRequests() + { + $this->getServer()->flush(); + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n"); + + $client = new Client($this->getServer()->getUrl()); + $logPlugin = $this->getLogPlugin(); + $client->getEventDispatcher()->addSubscriber($logPlugin); + + // Get a request from the client and ensure the the observer was + // attached to the new request + $request = $client->createRequest(); + $this->assertTrue($this->hasSubscriber($request, $logPlugin)); + } + + public function testClientReturnsValidBaseUrls() + { + $client = new Client('http://www.{foo}.{data}/', array( + 'data' => '123', + 'foo' => 'bar' + )); + $this->assertEquals('http://www.bar.123/', $client->getBaseUrl()); + $client->setBaseUrl('http://www.google.com/'); + $this->assertEquals('http://www.google.com/', $client->getBaseUrl()); + } + + public function testClientAddsCurlOptionsToRequests() + { + $client = new Client('http://www.test.com/', array( + 'api' => 'v1', + // Adds the option using the curl values + 'curl.options' => array( + 'CURLOPT_HTTPAUTH' => 'CURLAUTH_DIGEST', + 'abc' => 'foo', + 'blacklist' => 'abc', + 'debug' => true + ) + )); + + $request = $client->createRequest(); + $options = $request->getCurlOptions(); + $this->assertEquals(CURLAUTH_DIGEST, $options->get(CURLOPT_HTTPAUTH)); + $this->assertEquals('foo', $options->get('abc')); + $this->assertEquals('abc', $options->get('blacklist')); + } + + public function testClientAllowsFineGrainedSslControlButIsSecureByDefault() + { + $client = new Client('https://www.secure.com/'); + + // secure by default + $request = $client->createRequest(); + $options = $request->getCurlOptions(); + $this->assertTrue($options->get(CURLOPT_SSL_VERIFYPEER)); + + // set a capath if you prefer + $client = new Client('https://www.secure.com/'); + $client->setSslVerification(__DIR__); + $request = $client->createRequest(); + $options = $request->getCurlOptions(); + $this->assertSame(__DIR__, $options->get(CURLOPT_CAPATH)); + } + + public function testConfigSettingsControlSslConfiguration() + { + // Use the default ca certs on the system + $client = new Client('https://www.secure.com/', array('ssl.certificate_authority' => 'system')); + $this->assertNull($client->getConfig('curl.options')); + // Can set the cacert value as well + $client = new Client('https://www.secure.com/', array('ssl.certificate_authority' => false)); + $options = $client->getConfig('curl.options'); + $this->assertArrayNotHasKey(CURLOPT_CAINFO, $options); + $this->assertSame(false, $options[CURLOPT_SSL_VERIFYPEER]); + $this->assertSame(0, $options[CURLOPT_SSL_VERIFYHOST]); + } + + public function testClientAllowsUnsafeOperationIfRequested() + { + // be really unsafe if you insist + $client = new Client('https://www.secure.com/', array( + 'api' => 'v1' + )); + + $client->setSslVerification(false); + $request = $client->createRequest(); + $options = $request->getCurlOptions(); + $this->assertFalse($options->get(CURLOPT_SSL_VERIFYPEER)); + $this->assertNull($options->get(CURLOPT_CAINFO)); + } + + /** + * @expectedException \Guzzle\Common\Exception\RuntimeException + */ + public function testThrowsExceptionForInvalidCertificate() + { + $client = new Client('https://www.secure.com/'); + $client->setSslVerification('/path/to/missing/file'); + } + + public function testClientAllowsSettingSpecificSslCaInfo() + { + // set a file other than the provided cacert.pem + $client = new Client('https://www.secure.com/', array( + 'api' => 'v1' + )); + + $client->setSslVerification(__FILE__); + $request = $client->createRequest(); + $options = $request->getCurlOptions(); + $this->assertSame(__FILE__, $options->get(CURLOPT_CAINFO)); + } + + /** + * @expectedException Guzzle\Common\Exception\InvalidArgumentException + */ + public function testClientPreventsInadvertentInsecureVerifyHostSetting() + { + // set a file other than the provided cacert.pem + $client = new Client('https://www.secure.com/', array( + 'api' => 'v1' + )); + $client->setSslVerification(__FILE__, true, true); + } + + /** + * @expectedException Guzzle\Common\Exception\InvalidArgumentException + */ + public function testClientPreventsInvalidVerifyPeerSetting() + { + // set a file other than the provided cacert.pem + $client = new Client('https://www.secure.com/', array( + 'api' => 'v1' + )); + $client->setSslVerification(__FILE__, 'yes'); + } + + public function testClientAddsParamsToRequests() + { + Version::$emitWarnings = false; + $client = new Client('http://www.example.com', array( + 'api' => 'v1', + 'request.params' => array( + 'foo' => 'bar', + 'baz' => 'jar' + ) + )); + $request = $client->createRequest(); + $this->assertEquals('bar', $request->getParams()->get('foo')); + $this->assertEquals('jar', $request->getParams()->get('baz')); + Version::$emitWarnings = true; + } + + public function urlProvider() + { + $u = $this->getServer()->getUrl() . 'base/'; + $u2 = $this->getServer()->getUrl() . 'base?z=1'; + return array( + array($u, '', $u), + array($u, 'relative/path/to/resource', $u . 'relative/path/to/resource'), + array($u, 'relative/path/to/resource?a=b&c=d', $u . 'relative/path/to/resource?a=b&c=d'), + array($u, '/absolute/path/to/resource', $this->getServer()->getUrl() . 'absolute/path/to/resource'), + array($u, '/absolute/path/to/resource?a=b&c=d', $this->getServer()->getUrl() . 'absolute/path/to/resource?a=b&c=d'), + array($u2, '/absolute/path/to/resource?a=b&c=d', $this->getServer()->getUrl() . 'absolute/path/to/resource?a=b&c=d&z=1'), + array($u2, 'relative/path/to/resource', $this->getServer()->getUrl() . 'base/relative/path/to/resource?z=1'), + array($u2, 'relative/path/to/resource?another=query', $this->getServer()->getUrl() . 'base/relative/path/to/resource?another=query&z=1') + ); + } + + /** + * @dataProvider urlProvider + */ + public function testBuildsRelativeUrls($baseUrl, $url, $result) + { + $client = new Client($baseUrl); + $this->assertEquals($result, $client->get($url)->getUrl()); + } + + public function testAllowsConfigsToBeChangedAndInjectedInBaseUrl() + { + $client = new Client('http://{a}/{b}'); + $this->assertEquals('http:///', $client->getBaseUrl()); + $this->assertEquals('http://{a}/{b}', $client->getBaseUrl(false)); + $client->setConfig(array( + 'a' => 'test.com', + 'b' => 'index.html' + )); + $this->assertEquals('http://test.com/index.html', $client->getBaseUrl()); + } + + public function testCreatesRequestsWithDefaultValues() + { + $client = new Client($this->getServer()->getUrl() . 'base'); + + // Create a GET request + $request = $client->createRequest(); + $this->assertEquals('GET', $request->getMethod()); + $this->assertEquals($client->getBaseUrl(), $request->getUrl()); + + // Create a DELETE request + $request = $client->createRequest('DELETE'); + $this->assertEquals('DELETE', $request->getMethod()); + $this->assertEquals($client->getBaseUrl(), $request->getUrl()); + + // Create a HEAD request with custom headers + $request = $client->createRequest('HEAD', 'http://www.test.com/'); + $this->assertEquals('HEAD', $request->getMethod()); + $this->assertEquals('http://www.test.com/', $request->getUrl()); + + // Create a PUT request + $request = $client->createRequest('PUT'); + $this->assertEquals('PUT', $request->getMethod()); + + // Create a PUT request with injected config + $client->getConfig()->set('a', 1)->set('b', 2); + $request = $client->createRequest('PUT', '/path/{a}?q={b}'); + $this->assertEquals($request->getUrl(), $this->getServer()->getUrl() . 'path/1?q=2'); + } + + public function testClientHasHelperMethodsForCreatingRequests() + { + $url = $this->getServer()->getUrl(); + $client = new Client($url . 'base'); + $this->assertEquals('GET', $client->get()->getMethod()); + $this->assertEquals('PUT', $client->put()->getMethod()); + $this->assertEquals('POST', $client->post()->getMethod()); + $this->assertEquals('HEAD', $client->head()->getMethod()); + $this->assertEquals('DELETE', $client->delete()->getMethod()); + $this->assertEquals('OPTIONS', $client->options()->getMethod()); + $this->assertEquals('PATCH', $client->patch()->getMethod()); + $this->assertEquals($url . 'base/abc', $client->get('abc')->getUrl()); + $this->assertEquals($url . 'zxy', $client->put('/zxy')->getUrl()); + $this->assertEquals($url . 'zxy?a=b', $client->post('/zxy?a=b')->getUrl()); + $this->assertEquals($url . 'base?a=b', $client->head('?a=b')->getUrl()); + $this->assertEquals($url . 'base?a=b', $client->delete('/base?a=b')->getUrl()); + } + + public function testClientInjectsConfigsIntoUrls() + { + $client = new Client('http://www.test.com/api/v1', array( + 'test' => '123' + )); + $request = $client->get('relative/{test}'); + $this->assertEquals('http://www.test.com/api/v1/relative/123', $request->getUrl()); + } + + public function testAllowsEmptyBaseUrl() + { + $client = new Client(); + $request = $client->get('http://www.google.com/'); + $this->assertEquals('http://www.google.com/', $request->getUrl()); + $request->setResponse(new Response(200), true); + $request->send(); + } + + public function testAllowsCustomCurlMultiObjects() + { + $mock = $this->getMock('Guzzle\\Http\\Curl\\CurlMulti', array('add', 'send')); + $mock->expects($this->once()) + ->method('add') + ->will($this->returnSelf()); + $mock->expects($this->once()) + ->method('send') + ->will($this->returnSelf()); + + $client = new Client(); + $client->setCurlMulti($mock); + + $request = $client->get(); + $request->setResponse(new Response(200), true); + $client->send($request); + } + + public function testClientSendsMultipleRequests() + { + $client = new Client($this->getServer()->getUrl()); + $mock = new MockPlugin(); + + $responses = array( + new Response(200), + new Response(201), + new Response(202) + ); + + $mock->addResponse($responses[0]); + $mock->addResponse($responses[1]); + $mock->addResponse($responses[2]); + + $client->getEventDispatcher()->addSubscriber($mock); + + $requests = array( + $client->get(), + $client->head(), + $client->put('/', null, 'test') + ); + + $this->assertEquals(array( + $responses[0], + $responses[1], + $responses[2] + ), $client->send($requests)); + } + + public function testClientSendsSingleRequest() + { + $client = new Client($this->getServer()->getUrl()); + $mock = new MockPlugin(); + $response = new Response(200); + $mock->addResponse($response); + $client->getEventDispatcher()->addSubscriber($mock); + $this->assertEquals($response, $client->send($client->get())); + } + + /** + * @expectedException \Guzzle\Http\Exception\BadResponseException + */ + public function testClientThrowsExceptionForSingleRequest() + { + $client = new Client($this->getServer()->getUrl()); + $mock = new MockPlugin(); + $response = new Response(404); + $mock->addResponse($response); + $client->getEventDispatcher()->addSubscriber($mock); + $client->send($client->get()); + } + + /** + * @expectedException \Guzzle\Common\Exception\ExceptionCollection + */ + public function testClientThrowsExceptionForMultipleRequests() + { + $client = new Client($this->getServer()->getUrl()); + $mock = new MockPlugin(); + $mock->addResponse(new Response(200)); + $mock->addResponse(new Response(404)); + $client->getEventDispatcher()->addSubscriber($mock); + $client->send(array($client->get(), $client->head())); + } + + public function testQueryStringsAreNotDoubleEncoded() + { + $client = new Client('http://test.com', array( + 'path' => array('foo', 'bar'), + 'query' => 'hi there', + 'data' => array( + 'test' => 'a&b' + ) + )); + + $request = $client->get('{/path*}{?query,data*}'); + $this->assertEquals('http://test.com/foo/bar?query=hi%20there&test=a%26b', $request->getUrl()); + $this->assertEquals('hi there', $request->getQuery()->get('query')); + $this->assertEquals('a&b', $request->getQuery()->get('test')); + } + + public function testQueryStringsAreNotDoubleEncodedUsingAbsolutePaths() + { + $client = new Client('http://test.com', array( + 'path' => array('foo', 'bar'), + 'query' => 'hi there', + )); + $request = $client->get('http://test.com{?query}'); + $this->assertEquals('http://test.com?query=hi%20there', $request->getUrl()); + $this->assertEquals('hi there', $request->getQuery()->get('query')); + } + + public function testAllowsUriTemplateInjection() + { + $client = new Client('http://test.com'); + $ref = new \ReflectionMethod($client, 'getUriTemplate'); + $ref->setAccessible(true); + $a = $ref->invoke($client); + $this->assertSame($a, $ref->invoke($client)); + $client->setUriTemplate(new UriTemplate()); + $this->assertNotSame($a, $ref->invoke($client)); + } + + public function testAllowsCustomVariablesWhenExpandingTemplates() + { + $client = new Client('http://test.com', array('test' => 'hi')); + $ref = new \ReflectionMethod($client, 'expandTemplate'); + $ref->setAccessible(true); + $uri = $ref->invoke($client, 'http://{test}{?query*}', array('query' => array('han' => 'solo'))); + $this->assertEquals('http://hi?han=solo', $uri); + } + + public function testUriArrayAllowsCustomTemplateVariables() + { + $client = new Client(); + $vars = array( + 'var' => 'hi' + ); + $this->assertEquals('/hi', (string) $client->createRequest('GET', array('/{var}', $vars))->getUrl()); + $this->assertEquals('/hi', (string) $client->get(array('/{var}', $vars))->getUrl()); + $this->assertEquals('/hi', (string) $client->put(array('/{var}', $vars))->getUrl()); + $this->assertEquals('/hi', (string) $client->post(array('/{var}', $vars))->getUrl()); + $this->assertEquals('/hi', (string) $client->head(array('/{var}', $vars))->getUrl()); + $this->assertEquals('/hi', (string) $client->options(array('/{var}', $vars))->getUrl()); + } + + public function testAllowsDefaultHeaders() + { + Version::$emitWarnings = false; + $default = array('X-Test' => 'Hi!'); + $other = array('X-Other' => 'Foo'); + + $client = new Client(); + $client->setDefaultHeaders($default); + $this->assertEquals($default, $client->getDefaultHeaders()->getAll()); + $client->setDefaultHeaders(new Collection($default)); + $this->assertEquals($default, $client->getDefaultHeaders()->getAll()); + + $request = $client->createRequest('GET', null, $other); + $this->assertEquals('Hi!', $request->getHeader('X-Test')); + $this->assertEquals('Foo', $request->getHeader('X-Other')); + + $request = $client->createRequest('GET', null, new Collection($other)); + $this->assertEquals('Hi!', $request->getHeader('X-Test')); + $this->assertEquals('Foo', $request->getHeader('X-Other')); + + $request = $client->createRequest('GET'); + $this->assertEquals('Hi!', $request->getHeader('X-Test')); + Version::$emitWarnings = true; + } + + public function testDontReuseCurlMulti() + { + $client1 = new Client(); + $client2 = new Client(); + $this->assertNotSame($client1->getCurlMulti(), $client2->getCurlMulti()); + } + + public function testGetDefaultUserAgent() + { + $client = new Client(); + $agent = $this->readAttribute($client, 'userAgent'); + $version = curl_version(); + $testAgent = sprintf('Guzzle/%s curl/%s PHP/%s', Version::VERSION, $version['version'], PHP_VERSION); + $this->assertEquals($agent, $testAgent); + + $client->setUserAgent('foo'); + $this->assertEquals('foo', $this->readAttribute($client, 'userAgent')); + } + + public function testOverwritesUserAgent() + { + $client = new Client(); + $request = $client->createRequest('GET', 'http://www.foo.com', array('User-agent' => 'foo')); + $this->assertEquals('foo', (string) $request->getHeader('User-Agent')); + } + + public function testUsesDefaultUserAgent() + { + $client = new Client(); + $request = $client->createRequest('GET', 'http://www.foo.com'); + $this->assertContains('Guzzle/', (string) $request->getHeader('User-Agent')); + } + + public function testCanSetDefaultRequestOptions() + { + $client = new Client(); + $client->getConfig()->set('request.options', array( + 'query' => array('test' => '123', 'other' => 'abc'), + 'headers' => array('Foo' => 'Bar', 'Baz' => 'Bam') + )); + $request = $client->createRequest('GET', 'http://www.foo.com?test=hello', array('Foo' => 'Test')); + // Explicit options on a request should overrule default options + $this->assertEquals('Test', (string) $request->getHeader('Foo')); + $this->assertEquals('hello', $request->getQuery()->get('test')); + // Default options should still be set + $this->assertEquals('abc', $request->getQuery()->get('other')); + $this->assertEquals('Bam', (string) $request->getHeader('Baz')); + } + + public function testCanSetSetOptionsOnRequests() + { + $client = new Client(); + $request = $client->createRequest('GET', 'http://www.foo.com?test=hello', array('Foo' => 'Test'), null, array( + 'cookies' => array('michael' => 'test') + )); + $this->assertEquals('test', $request->getCookie('michael')); + } + + public function testHasDefaultOptionsHelperMethods() + { + $client = new Client(); + // With path + $client->setDefaultOption('headers/foo', 'bar'); + $this->assertEquals('bar', $client->getDefaultOption('headers/foo')); + // With simple key + $client->setDefaultOption('allow_redirects', false); + $this->assertFalse($client->getDefaultOption('allow_redirects')); + + $this->assertEquals(array( + 'headers' => array('foo' => 'bar'), + 'allow_redirects' => false + ), $client->getConfig('request.options')); + + $request = $client->get('/'); + $this->assertEquals('bar', $request->getHeader('foo')); + } + + public function testHeadCanUseOptions() + { + $client = new Client(); + $head = $client->head('http://www.foo.com', array(), array('query' => array('foo' => 'bar'))); + $this->assertEquals('bar', $head->getQuery()->get('foo')); + } + + public function testCanSetRelativeUrlStartingWithHttp() + { + $client = new Client('http://www.foo.com'); + $this->assertEquals( + 'http://www.foo.com/httpfoo', + $client->createRequest('GET', 'httpfoo')->getUrl() + ); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Curl/CurlHandleTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Curl/CurlHandleTest.php new file mode 100644 index 0000000..bfa85bd --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Curl/CurlHandleTest.php @@ -0,0 +1,947 @@ +getEventDispatcher()->addListener('request.sent', function (Event $e) use ($that) { + $that->requestHandle = $e['handle']; + }); + + return $request; + } + + public function setUp() + { + $this->requestHandle = null; + } + + /** + * @expectedException \InvalidArgumentException + */ + public function testConstructorExpectsCurlResource() + { + $h = new CurlHandle(false, array()); + } + + public function testConstructorExpectsProperOptions() + { + $h = curl_init($this->getServer()->getUrl()); + try { + $ha = new CurlHandle($h, false); + $this->fail('Expected InvalidArgumentException'); + } catch (\InvalidArgumentException $e) { + } + + $ha = new CurlHandle($h, array( + CURLOPT_URL => $this->getServer()->getUrl() + )); + $this->assertEquals($this->getServer()->getUrl(), $ha->getOptions()->get(CURLOPT_URL)); + + $ha = new CurlHandle($h, new Collection(array( + CURLOPT_URL => $this->getServer()->getUrl() + ))); + $this->assertEquals($this->getServer()->getUrl(), $ha->getOptions()->get(CURLOPT_URL)); + } + + public function testConstructorInitializesObject() + { + $handle = curl_init($this->getServer()->getUrl()); + $h = new CurlHandle($handle, array( + CURLOPT_URL => $this->getServer()->getUrl() + )); + $this->assertSame($handle, $h->getHandle()); + $this->assertInstanceOf('Guzzle\\Http\\Url', $h->getUrl()); + $this->assertEquals($this->getServer()->getUrl(), (string) $h->getUrl()); + $this->assertEquals($this->getServer()->getUrl(), $h->getOptions()->get(CURLOPT_URL)); + } + + public function testStoresStdErr() + { + $request = RequestFactory::getInstance()->create('GET', 'http://test.com'); + $request->getCurlOptions()->set('debug', true); + $h = CurlHandle::factory($request); + $this->assertEquals($h->getStderr(true), $h->getOptions()->get(CURLOPT_STDERR)); + $this->assertInternalType('resource', $h->getStderr(true)); + $this->assertInternalType('string', $h->getStderr(false)); + $r = $h->getStderr(true); + fwrite($r, 'test'); + $this->assertEquals('test', $h->getStderr(false)); + } + + public function testStoresCurlErrorNumber() + { + $h = new CurlHandle(curl_init('http://test.com'), array(CURLOPT_URL => 'http://test.com')); + $this->assertEquals(CURLE_OK, $h->getErrorNo()); + $h->setErrorNo(CURLE_OPERATION_TIMEOUTED); + $this->assertEquals(CURLE_OPERATION_TIMEOUTED, $h->getErrorNo()); + } + + public function testAccountsForMissingStdErr() + { + $handle = curl_init('http://www.test.com/'); + $h = new CurlHandle($handle, array( + CURLOPT_URL => 'http://www.test.com/' + )); + $this->assertNull($h->getStderr(false)); + } + + public function testDeterminesIfResourceIsAvailable() + { + $handle = curl_init($this->getServer()->getUrl()); + $h = new CurlHandle($handle, array()); + $this->assertTrue($h->isAvailable()); + + // Mess it up by closing the handle + curl_close($handle); + $this->assertFalse($h->isAvailable()); + + // Mess it up by unsetting the handle + $handle = null; + $this->assertFalse($h->isAvailable()); + } + + public function testWrapsErrorsAndInfo() + { + if (!defined('CURLOPT_TIMEOUT_MS')) { + $this->markTestSkipped('Update curl'); + } + + $settings = array( + CURLOPT_PORT => 123, + CURLOPT_CONNECTTIMEOUT_MS => 1, + CURLOPT_TIMEOUT_MS => 1 + ); + + $handle = curl_init($this->getServer()->getUrl()); + curl_setopt_array($handle, $settings); + $h = new CurlHandle($handle, $settings); + @curl_exec($handle); + + $errors = array( + "couldn't connect to host", + 'timeout was reached', + 'connection time-out', + 'connect() timed out!', + 'failed connect to 127.0.0.1:123; connection refused', + 'failed to connect to 127.0.0.1 port 123: connection refused' + ); + $this->assertTrue(in_array(strtolower($h->getError()), $errors), $h->getError() . ' was not the error'); + + $this->assertTrue($h->getErrorNo() > 0); + + $this->assertEquals($this->getServer()->getUrl(), $h->getInfo(CURLINFO_EFFECTIVE_URL)); + $this->assertInternalType('array', $h->getInfo()); + + curl_close($handle); + $this->assertEquals(null, $h->getInfo('url')); + } + + public function testGetInfoWithoutDebugMode() + { + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n"); + $client = new Client($this->getServer()->getUrl()); + $request = $client->get($this->getServer()->getUrl()); + $response = $request->send(); + + $info = $response->getInfo(); + $this->assertFalse(empty($info)); + $this->assertEquals($this->getServer()->getUrl(), $info['url']); + } + + public function testWrapsCurlOptions() + { + $handle = curl_init($this->getServer()->getUrl()); + $h = new CurlHandle($handle, array( + CURLOPT_AUTOREFERER => true, + CURLOPT_BUFFERSIZE => 1024 + )); + + $this->assertEquals(true, $h->getOptions()->get(CURLOPT_AUTOREFERER)); + $this->assertEquals(1024, $h->getOptions()->get(CURLOPT_BUFFERSIZE)); + } + + /** + * Data provider for factory tests + * + * @return array + */ + public function dataProvider() + { + $testFile = __DIR__ . '/../../../../../phpunit.xml.dist'; + + $postBody = new QueryString(array('file' => '@' . $testFile)); + $qs = new QueryString(array( + 'x' => 'y', + 'z' => 'a' + )); + + $client = new Client(); + $userAgent = $client->getDefaultUserAgent(); + $auth = base64_encode('michael:123'); + $testFileSize = filesize($testFile); + + $tests = array( + // Send a regular GET + array('GET', 'http://www.google.com/', null, null, array( + CURLOPT_RETURNTRANSFER => 0, + CURLOPT_HEADER => 0, + CURLOPT_CONNECTTIMEOUT => 150, + CURLOPT_WRITEFUNCTION => 'callback', + CURLOPT_HEADERFUNCTION => 'callback', + CURLOPT_HTTPHEADER => array('Accept:', 'Host: www.google.com', 'User-Agent: ' . $userAgent), + )), + // Test that custom request methods can be used + array('TRACE', 'http://www.google.com/', null, null, array( + CURLOPT_CUSTOMREQUEST => 'TRACE' + )), + // Send a GET using a port + array('GET', 'http://127.0.0.1:8080', null, null, array( + CURLOPT_RETURNTRANSFER => 0, + CURLOPT_HEADER => 0, + CURLOPT_CONNECTTIMEOUT => 150, + CURLOPT_WRITEFUNCTION => 'callback', + CURLOPT_HEADERFUNCTION => 'callback', + CURLOPT_PORT => 8080, + CURLOPT_HTTPHEADER => array('Accept:', 'Host: 127.0.0.1:8080', 'User-Agent: ' . $userAgent), + )), + // Send a HEAD request + array('HEAD', 'http://www.google.com/', null, null, array( + CURLOPT_RETURNTRANSFER => 0, + CURLOPT_HEADER => 0, + CURLOPT_CONNECTTIMEOUT => 150, + CURLOPT_HEADERFUNCTION => 'callback', + CURLOPT_HTTPHEADER => array('Accept:', 'Host: www.google.com', 'User-Agent: ' . $userAgent), + CURLOPT_NOBODY => 1 + )), + // Send a GET using basic auth + array('GET', 'https://michael:123@localhost/index.html?q=2', null, null, array( + CURLOPT_RETURNTRANSFER => 0, + CURLOPT_HEADER => 0, + CURLOPT_CONNECTTIMEOUT => 150, + CURLOPT_WRITEFUNCTION => 'callback', + CURLOPT_HEADERFUNCTION => 'callback', + CURLOPT_HTTPHEADER => array( + 'Accept:', + 'Host: localhost', + 'Authorization: Basic ' . $auth, + 'User-Agent: ' . $userAgent + ), + CURLOPT_PORT => 443 + )), + // Send a GET request with custom headers + array('GET', 'http://localhost:8124/', array( + 'x-test-data' => 'Guzzle' + ), null, array( + CURLOPT_PORT => 8124, + CURLOPT_HTTPHEADER => array( + 'Accept:', + 'Host: localhost:8124', + 'x-test-data: Guzzle', + 'User-Agent: ' . $userAgent + ) + ), array( + 'Host' => '*', + 'User-Agent' => '*', + 'x-test-data' => 'Guzzle' + )), + // Send a POST using a query string + array('POST', 'http://localhost:8124/post.php', null, $qs, array( + CURLOPT_RETURNTRANSFER => 0, + CURLOPT_HEADER => 0, + CURLOPT_CONNECTTIMEOUT => 150, + CURLOPT_WRITEFUNCTION => 'callback', + CURLOPT_HEADERFUNCTION => 'callback', + CURLOPT_POSTFIELDS => 'x=y&z=a', + CURLOPT_HTTPHEADER => array ( + 'Expect:', + 'Accept:', + 'Host: localhost:8124', + 'Content-Type: application/x-www-form-urlencoded; charset=utf-8', + 'User-Agent: ' . $userAgent + ) + ), array( + 'Host' => '*', + 'User-Agent' => '*', + 'Content-Length' => '7', + '!Expect' => null, + 'Content-Type' => 'application/x-www-form-urlencoded; charset=utf-8', + '!Transfer-Encoding' => null + )), + // Send a PUT using raw data + array('PUT', 'http://localhost:8124/put.php', null, EntityBody::factory(fopen($testFile, 'r+')), array( + CURLOPT_RETURNTRANSFER => 0, + CURLOPT_HEADER => 0, + CURLOPT_CONNECTTIMEOUT => 150, + CURLOPT_WRITEFUNCTION => 'callback', + CURLOPT_HEADERFUNCTION => 'callback', + CURLOPT_READFUNCTION => 'callback', + CURLOPT_INFILESIZE => filesize($testFile), + CURLOPT_HTTPHEADER => array ( + 'Expect:', + 'Accept:', + 'Host: localhost:8124', + 'User-Agent: ' . $userAgent + ) + ), array( + 'Host' => '*', + 'User-Agent' => '*', + '!Expect' => null, + 'Content-Length' => $testFileSize, + '!Transfer-Encoding' => null + )), + // Send a POST request using an array of fields + array('POST', 'http://localhost:8124/post.php', null, array( + 'x' => 'y', + 'a' => 'b' + ), array( + CURLOPT_RETURNTRANSFER => 0, + CURLOPT_HEADER => 0, + CURLOPT_CONNECTTIMEOUT => 150, + CURLOPT_WRITEFUNCTION => 'callback', + CURLOPT_HEADERFUNCTION => 'callback', + CURLOPT_POST => 1, + CURLOPT_POSTFIELDS => 'x=y&a=b', + CURLOPT_HTTPHEADER => array ( + 'Expect:', + 'Accept:', + 'Host: localhost:8124', + 'Content-Type: application/x-www-form-urlencoded; charset=utf-8', + 'User-Agent: ' . $userAgent + ) + ), array( + 'Host' => '*', + 'User-Agent' => '*', + 'Content-Length' => '7', + '!Expect' => null, + 'Content-Type' => 'application/x-www-form-urlencoded; charset=utf-8', + '!Transfer-Encoding' => null + )), + // Send a POST request with raw POST data and a custom content-type + array('POST', 'http://localhost:8124/post.php', array( + 'Content-Type' => 'application/json' + ), '{"hi":"there"}', array( + CURLOPT_RETURNTRANSFER => 0, + CURLOPT_HEADER => 0, + CURLOPT_CONNECTTIMEOUT => 150, + CURLOPT_WRITEFUNCTION => 'callback', + CURLOPT_HEADERFUNCTION => 'callback', + CURLOPT_CUSTOMREQUEST => 'POST', + CURLOPT_UPLOAD => true, + CURLOPT_INFILESIZE => 14, + CURLOPT_HTTPHEADER => array ( + 'Expect:', + 'Accept:', + 'Host: localhost:8124', + 'Content-Type: application/json', + 'User-Agent: ' . $userAgent + ), + ), array( + 'Host' => '*', + 'User-Agent' => '*', + 'Content-Type' => 'application/json', + '!Expect' => null, + 'Content-Length' => '14', + '!Transfer-Encoding' => null + )), + // Send a POST request with raw POST data, a custom content-type, and use chunked encoding + array('POST', 'http://localhost:8124/post.php', array( + 'Content-Type' => 'application/json', + 'Transfer-Encoding' => 'chunked' + ), '{"hi":"there"}', array( + CURLOPT_RETURNTRANSFER => 0, + CURLOPT_HEADER => 0, + CURLOPT_CONNECTTIMEOUT => 150, + CURLOPT_WRITEFUNCTION => 'callback', + CURLOPT_HEADERFUNCTION => 'callback', + CURLOPT_CUSTOMREQUEST => 'POST', + CURLOPT_UPLOAD => true, + CURLOPT_HTTPHEADER => array ( + 'Expect:', + 'Accept:', + 'Host: localhost:8124', + 'Transfer-Encoding: chunked', + 'Content-Type: application/json', + 'User-Agent: ' . $userAgent + ), + ), array( + 'Host' => '*', + 'User-Agent' => '*', + 'Content-Type' => 'application/json', + '!Expect' => null, + 'Transfer-Encoding' => 'chunked', + '!Content-Length' => '' + )), + // Send a POST request with no body + array('POST', 'http://localhost:8124/post.php', null, '', array( + CURLOPT_CUSTOMREQUEST => 'POST', + CURLOPT_HTTPHEADER => array ( + 'Expect:', + 'Accept:', + 'Host: localhost:8124', + 'User-Agent: ' . $userAgent + ) + ), array( + 'Host' => '*', + 'User-Agent' => '*', + 'Content-Length' => '0', + '!Transfer-Encoding' => null + )), + // Send a POST request with empty post fields + array('POST', 'http://localhost:8124/post.php', null, array(), array( + CURLOPT_CUSTOMREQUEST => 'POST', + CURLOPT_HTTPHEADER => array ( + 'Expect:', + 'Accept:', + 'Host: localhost:8124', + 'User-Agent: ' . $userAgent + ) + ), array( + 'Host' => '*', + 'User-Agent' => '*', + 'Content-Length' => '0', + '!Transfer-Encoding' => null + )), + // Send a PATCH request + array('PATCH', 'http://localhost:8124/patch.php', null, 'body', array( + CURLOPT_INFILESIZE => 4, + CURLOPT_HTTPHEADER => array ( + 'Expect:', + 'Accept:', + 'Host: localhost:8124', + 'User-Agent: ' . $userAgent + ) + )), + // Send a DELETE request with a body + array('DELETE', 'http://localhost:8124/delete.php', null, 'body', array( + CURLOPT_CUSTOMREQUEST => 'DELETE', + CURLOPT_INFILESIZE => 4, + CURLOPT_HTTPHEADER => array ( + 'Expect:', + 'Accept:', + 'Host: localhost:8124', + 'User-Agent: ' . $userAgent + ) + ), array( + 'Host' => '*', + 'User-Agent' => '*', + 'Content-Length' => '4', + '!Expect' => null, + '!Transfer-Encoding' => null + )), + + /** + * Send a request with empty path and a fragment - the fragment must be + * stripped out before sending it to curl + * + * @issue 453 + * @link https://github.com/guzzle/guzzle/issues/453 + */ + array('GET', 'http://www.google.com#head', null, null, array( + CURLOPT_RETURNTRANSFER => 0, + CURLOPT_HEADER => 0, + CURLOPT_CONNECTTIMEOUT => 150, + CURLOPT_WRITEFUNCTION => 'callback', + CURLOPT_HEADERFUNCTION => 'callback', + CURLOPT_HTTPHEADER => array('Accept:', 'Host: www.google.com', 'User-Agent: ' . $userAgent), + )), + ); + + $postTest = array('POST', 'http://localhost:8124/post.php', null, $postBody, array( + CURLOPT_RETURNTRANSFER => 0, + CURLOPT_HEADER => 0, + CURLOPT_CONNECTTIMEOUT => 150, + CURLOPT_WRITEFUNCTION => 'callback', + CURLOPT_HEADERFUNCTION => 'callback', + CURLOPT_POST => 1, + CURLOPT_POSTFIELDS => array( + 'file' => '@' . $testFile . ';filename=phpunit.xml.dist;type=application/octet-stream' + ), + CURLOPT_HTTPHEADER => array ( + 'Accept:', + 'Host: localhost:8124', + 'Content-Type: multipart/form-data', + 'Expect: 100-Continue', + 'User-Agent: ' . $userAgent + ) + ), array( + 'Host' => '*', + 'User-Agent' => '*', + 'Content-Length' => '*', + 'Expect' => '100-Continue', + 'Content-Type' => 'multipart/form-data; boundary=*', + '!Transfer-Encoding' => null + )); + + if (version_compare(phpversion(), '5.5.0', '>=')) { + $postTest[4][CURLOPT_POSTFIELDS] = array( + 'file' => new \CurlFile($testFile, 'application/octet-stream', 'phpunit.xml.dist') + ); + } + + $tests[] = $postTest; + + return $tests; + } + + /** + * @dataProvider dataProvider + */ + public function testFactoryCreatesCurlBasedOnRequest($method, $url, $headers, $body, $options, $expectedHeaders = null) + { + $client = new Client(); + $request = $client->createRequest($method, $url, $headers, $body); + $request->getCurlOptions()->set('debug', true); + + $originalRequest = clone $request; + $curlTest = clone $request; + $handle = CurlHandle::factory($curlTest); + + $this->assertInstanceOf('Guzzle\\Http\\Curl\\CurlHandle', $handle); + $o = $handle->getOptions()->getAll(); + + // Headers are case-insensitive + if (isset($o[CURLOPT_HTTPHEADER])) { + $o[CURLOPT_HTTPHEADER] = array_map('strtolower', $o[CURLOPT_HTTPHEADER]); + } + if (isset($options[CURLOPT_HTTPHEADER])) { + $options[CURLOPT_HTTPHEADER] = array_map('strtolower', $options[CURLOPT_HTTPHEADER]); + } + + $check = 0; + foreach ($options as $key => $value) { + $check++; + $this->assertArrayHasKey($key, $o, '-> Check number ' . $check); + if ($key != CURLOPT_HTTPHEADER && $key != CURLOPT_POSTFIELDS && (is_array($o[$key])) || $o[$key] instanceof \Closure) { + $this->assertEquals('callback', $value, '-> Check number ' . $check); + } else { + $this->assertTrue($value == $o[$key], '-> Check number ' . $check . ' - ' . var_export($value, true) . ' != ' . var_export($o[$key], true)); + } + } + + // If we are testing the actual sent headers + if ($expectedHeaders) { + + // Send the request to the test server + $client = new Client($this->getServer()->getUrl()); + $request->setClient($client); + $this->getServer()->flush(); + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n"); + $request->send(); + + // Get the request that was sent and create a request that we expected + $requests = $this->getServer()->getReceivedRequests(true); + $this->assertEquals($method, $requests[0]->getMethod()); + + $test = $this->compareHeaders($expectedHeaders, $requests[0]->getHeaders()); + $this->assertFalse($test, $test . "\nSent: \n" . $request . "\n\n" . $requests[0]); + + // Ensure only one Content-Length header is sent + if ($request->getHeader('Content-Length')) { + $this->assertEquals((string) $request->getHeader('Content-Length'), (string) $requests[0]->getHeader('Content-Length')); + } + } + } + + public function testFactoryUsesSpecifiedProtocol() + { + $request = RequestFactory::getInstance()->create('GET', 'http://localhost:8124/'); + $request->setProtocolVersion('1.1'); + $handle = CurlHandle::factory($request); + $options = $handle->getOptions(); + $this->assertEquals(CURL_HTTP_VERSION_1_1, $options[CURLOPT_HTTP_VERSION]); + } + + public function testUploadsPutData() + { + $this->getServer()->flush(); + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 2\r\n\r\nhi"); + + $client = new Client($this->getServer()->getUrl()); + $request = $client->put('/'); + $request->getCurlOptions()->set('debug', true); + $request->setBody(EntityBody::factory('test'), 'text/plain', false); + $request->getCurlOptions()->set('progress', true); + + $o = $this->getWildcardObserver($request); + $request->send(); + + // Make sure that the events were dispatched + $this->assertTrue($o->has('curl.callback.progress')); + + // Ensure that the request was received exactly as intended + $r = $this->getServer()->getReceivedRequests(true); + $this->assertFalse($r[0]->hasHeader('Transfer-Encoding')); + $this->assertEquals(4, (string) $r[0]->getHeader('Content-Length')); + $sent = strtolower($r[0]); + $this->assertContains('put / http/1.1', $sent); + $this->assertContains('host: 127.0.0.1', $sent); + $this->assertContains('user-agent:', $sent); + $this->assertContains('content-type: text/plain', $sent); + } + + public function testUploadsPutDataUsingChunkedEncodingWhenLengthCannotBeDetermined() + { + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 200 OK\r\nContent-Length: 2\r\n\r\nhi" + )); + $client = new Client($this->getServer()->getUrl()); + $request = $client->put('/'); + $request->setBody(EntityBody::factory(fopen($this->getServer()->getUrl(), 'r')), 'text/plain'); + $request->send(); + + $r = $this->getServer()->getReceivedRequests(true); + $this->assertEquals('chunked', $r[1]->getHeader('Transfer-Encoding')); + $this->assertFalse($r[1]->hasHeader('Content-Length')); + } + + public function testUploadsPutDataUsingChunkedEncodingWhenForced() + { + $this->getServer()->flush(); + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 2\r\n\r\nhi"); + + $client = new Client($this->getServer()->getUrl()); + $request = $client->put('/', array('Transfer-Encoding' => 'chunked'), 'hi!'); + $request->send(); + + $r = $this->getServer()->getReceivedRequests(true); + $this->assertEquals('chunked', $r[0]->getHeader('Transfer-Encoding')); + $this->assertFalse($r[0]->hasHeader('Content-Length')); + $this->assertEquals('hi!', $r[0]->getBody(true)); + } + + public function testSendsPostRequestsWithFields() + { + $this->getServer()->flush(); + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 2\r\n\r\nhi"); + + $request = RequestFactory::getInstance()->create('POST', $this->getServer()->getUrl()); + $request->getCurlOptions()->set('debug', true); + $request->setClient(new Client()); + $request->addPostFields(array( + 'a' => 'b', + 'c' => 'ay! ~This is a test, isn\'t it?' + )); + $request->send(); + + // Make sure that the request was sent correctly + $r = $this->getServer()->getReceivedRequests(true); + $this->assertEquals('a=b&c=ay%21%20~This%20is%20a%20test%2C%20isn%27t%20it%3F', (string) $r[0]->getBody()); + $this->assertFalse($r[0]->hasHeader('Transfer-Encoding')); + $this->assertEquals(56, (string) $r[0]->getHeader('Content-Length')); + $sent = strtolower($r[0]); + $this->assertContains('post / http/1.1', $sent); + $this->assertContains('content-type: application/x-www-form-urlencoded; charset=utf-8', $sent); + } + + public function testSendsPostRequestsWithFiles() + { + $this->getServer()->flush(); + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 2\r\n\r\nhi"); + + $request = RequestFactory::getInstance()->create('POST', $this->getServer()->getUrl()); + $request->getCurlOptions()->set('debug', true); + $request->setClient(new Client()); + $request->addPostFiles(array( + 'foo' => __FILE__, + )); + $request->addPostFields(array( + 'bar' => 'baz', + 'arr' => array('a' => 1, 'b' => 2), + )); + $this->updateForHandle($request); + $request->send(); + + // Ensure the CURLOPT_POSTFIELDS option was set properly + $options = $this->requestHandle->getOptions()->getAll(); + if (version_compare(phpversion(), '5.5.0', '<')) { + $this->assertContains('@' . __FILE__ . ';filename=CurlHandleTest.php;type=text/x-', $options[CURLOPT_POSTFIELDS]['foo']); + } else{ + $this->assertInstanceOf('CURLFile', $options[CURLOPT_POSTFIELDS]['foo']); + } + $this->assertEquals('baz', $options[CURLOPT_POSTFIELDS]['bar']); + $this->assertEquals('1', $options[CURLOPT_POSTFIELDS]['arr[a]']); + $this->assertEquals('2', $options[CURLOPT_POSTFIELDS]['arr[b]']); + // Ensure that a Content-Length header was sent by cURL + $this->assertTrue($request->hasHeader('Content-Length')); + } + + public function testCurlConfigurationOptionsAreSet() + { + $request = RequestFactory::getInstance()->create('PUT', $this->getServer()->getUrl()); + $request->setClient(new Client('http://www.example.com')); + $request->getCurlOptions()->set(CURLOPT_CONNECTTIMEOUT, 99); + $request->getCurlOptions()->set('curl.fake_opt', 99); + $request->getCurlOptions()->set(CURLOPT_PORT, 8181); + $handle = CurlHandle::factory($request); + $this->assertEquals(99, $handle->getOptions()->get(CURLOPT_CONNECTTIMEOUT)); + $this->assertEquals(8181, $handle->getOptions()->get(CURLOPT_PORT)); + $this->assertNull($handle->getOptions()->get('curl.fake_opt')); + $this->assertNull($handle->getOptions()->get('fake_opt')); + } + + public function testEnsuresRequestsHaveResponsesWhenUpdatingFromTransfer() + { + $request = RequestFactory::getInstance()->create('PUT', $this->getServer()->getUrl()); + $handle = CurlHandle::factory($request); + $handle->updateRequestFromTransfer($request); + } + + public function testCanSendBodyAsString() + { + $this->getServer()->flush(); + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n"); + $client = new Client($this->getServer()->getUrl()); + $request = $client->put('/', null, 'foo'); + $request->getCurlOptions()->set('body_as_string', true); + $request->send(); + $requests = $this->getServer()->getReceivedRequests(false); + $this->assertContains('PUT /', $requests[0]); + $this->assertContains("\nfoo", $requests[0]); + $this->assertContains('content-length: 3', $requests[0]); + $this->assertNotContains('content-type', $requests[0]); + } + + public function testCanSendPostBodyAsString() + { + $this->getServer()->flush(); + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n"); + $client = new Client($this->getServer()->getUrl()); + $request = $client->post('/', null, 'foo'); + $request->getCurlOptions()->set('body_as_string', true); + $request->send(); + $requests = $this->getServer()->getReceivedRequests(false); + $this->assertContains('POST /', $requests[0]); + $this->assertContains("\nfoo", $requests[0]); + $this->assertContains('content-length: 3', $requests[0]); + $this->assertNotContains('content-type', $requests[0]); + } + + public function testAllowsWireTransferInfoToBeEnabled() + { + $request = RequestFactory::getInstance()->create('PUT', $this->getServer()->getUrl()); + $request->getCurlOptions()->set('debug', true); + $handle = CurlHandle::factory($request); + $this->assertNotNull($handle->getOptions()->get(CURLOPT_STDERR)); + $this->assertNotNull($handle->getOptions()->get(CURLOPT_VERBOSE)); + } + + public function testAddsCustomCurlOptions() + { + $request = RequestFactory::getInstance()->create('PUT', $this->getServer()->getUrl()); + $request->getCurlOptions()->set(CURLOPT_TIMEOUT, 200); + $handle = CurlHandle::factory($request); + $this->assertEquals(200, $handle->getOptions()->get(CURLOPT_TIMEOUT)); + } + + public function testSendsPostUploadsWithContentDispositionHeaders() + { + $this->getServer()->flush(); + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\n\r\nContent-Length: 0\r\n\r\n"); + + $fileToUpload = dirname(dirname(__DIR__)) . DIRECTORY_SEPARATOR . 'TestData' . DIRECTORY_SEPARATOR . 'test_service.json'; + + $client = new Client($this->getServer()->getUrl()); + $request = $client->post(); + $request->addPostFile('foo', $fileToUpload, 'application/json'); + $request->addPostFile('foo', __FILE__); + + $request->send(); + $requests = $this->getServer()->getReceivedRequests(true); + $body = (string) $requests[0]->getBody(); + + $this->assertContains('Content-Disposition: form-data; name="foo[0]"; filename="', $body); + $this->assertContains('Content-Type: application/json', $body); + $this->assertContains('Content-Type: text/x-', $body); + $this->assertContains('Content-Disposition: form-data; name="foo[1]"; filename="', $body); + } + + public function requestMethodProvider() + { + return array(array('POST'), array('PUT'), array('PATCH')); + } + + /** + * @dataProvider requestMethodProvider + */ + public function testSendsRequestsWithNoBodyUsingContentLengthZero($method) + { + $this->getServer()->flush(); + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n"); + $client = new Client($this->getServer()->getUrl()); + $client->createRequest($method)->send(); + $requests = $this->getServer()->getReceivedRequests(true); + $this->assertFalse($requests[0]->hasHeader('Transfer-Encoding')); + $this->assertTrue($requests[0]->hasHeader('Content-Length')); + $this->assertEquals('0', (string) $requests[0]->getHeader('Content-Length')); + } + + /** + * @dataProvider provideCurlConfig + */ + public function testParseCurlConfigConvertsStringKeysToConstantKeys($options, $expected) + { + $actual = CurlHandle::parseCurlConfig($options); + $this->assertEquals($expected, $actual); + } + + /** + * Data provider for curl configurations + * + * @return array + */ + public function provideCurlConfig() + { + return array( + // Conversion of option name to constant value + array( + array( + 'CURLOPT_PORT' => 10, + 'CURLOPT_TIMEOUT' => 99 + ), + array( + CURLOPT_PORT => 10, + CURLOPT_TIMEOUT => 99 + ) + ), + // Keeps non constant options + array( + array('debug' => true), + array('debug' => true) + ), + // Conversion of constant names to constant values + array( + array('debug' => 'CURLPROXY_HTTP'), + array('debug' => CURLPROXY_HTTP) + ) + ); + } + + public function testSeeksToBeginningOfStreamWhenSending() + { + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n" + )); + + $client = new Client($this->getServer()->getUrl()); + $request = $client->put('/', null, 'test'); + $request->send(); + $request->send(); + + $received = $this->getServer()->getReceivedRequests(true); + $this->assertEquals(2, count($received)); + $this->assertEquals('test', (string) $received[0]->getBody()); + $this->assertEquals('test', (string) $received[1]->getBody()); + } + + public function testAllowsCurloptEncodingToBeSet() + { + $this->getServer()->flush(); + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n"); + + $client = new Client($this->getServer()->getUrl()); + $request = $client->get('/', null); + $request->getCurlOptions()->set(CURLOPT_ENCODING, ''); + $this->updateForHandle($request); + $request->send(); + $options = $this->requestHandle->getOptions()->getAll(); + $this->assertSame('', $options[CURLOPT_ENCODING]); + $received = $this->getServer()->getReceivedRequests(false); + $this->assertContainsIns('accept: */*', $received[0]); + $this->assertContainsIns('accept-encoding: ', $received[0]); + } + + public function testSendsExpectHeaderWhenSizeIsGreaterThanCutoff() + { + $this->getServer()->flush(); + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n"); + $client = new Client($this->getServer()->getUrl()); + $request = $client->put('/', null, 'test'); + // Start sending the expect header to 2 bytes + $this->updateForHandle($request); + $request->setExpectHeaderCutoff(2)->send(); + $options = $this->requestHandle->getOptions()->getAll(); + $this->assertContains('Expect: 100-Continue', $options[CURLOPT_HTTPHEADER]); + $received = $this->getServer()->getReceivedRequests(false); + $this->assertContainsIns('expect: 100-continue', $received[0]); + } + + public function testSetsCurloptEncodingWhenAcceptEncodingHeaderIsSet() + { + $this->getServer()->flush(); + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 4\r\n\r\ndata"); + $client = new Client($this->getServer()->getUrl()); + $request = $client->get('/', array( + 'Accept' => 'application/json', + 'Accept-Encoding' => 'gzip, deflate', + )); + $this->updateForHandle($request); + $request->send(); + $options = $this->requestHandle->getOptions()->getAll(); + $this->assertSame('gzip, deflate', $options[CURLOPT_ENCODING]); + $received = $this->getServer()->getReceivedRequests(false); + $this->assertContainsIns('accept: application/json', $received[0]); + $this->assertContainsIns('accept-encoding: gzip, deflate', $received[0]); + } + + public function testSendsPostFieldsForNonPostRequests() + { + $this->getServer()->flush(); + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\n\r\nContent-Length: 0\r\n\r\n"); + + $client = new Client(); + $request = $client->put($this->getServer()->getUrl(), null, array( + 'foo' => 'baz', + 'baz' => 'bar' + )); + + $request->send(); + $requests = $this->getServer()->getReceivedRequests(true); + $this->assertEquals('PUT', $requests[0]->getMethod()); + $this->assertEquals( + 'application/x-www-form-urlencoded; charset=utf-8', + (string) $requests[0]->getHeader('Content-Type') + ); + $this->assertEquals(15, (string) $requests[0]->getHeader('Content-Length')); + $this->assertEquals('foo=baz&baz=bar', (string) $requests[0]->getBody()); + } + + public function testSendsPostFilesForNonPostRequests() + { + $this->getServer()->flush(); + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\n\r\nContent-Length: 0\r\n\r\n"); + + $client = new Client(); + $request = $client->put($this->getServer()->getUrl(), null, array( + 'foo' => '@' . __FILE__ + )); + + $request->send(); + $requests = $this->getServer()->getReceivedRequests(true); + $this->assertEquals('PUT', $requests[0]->getMethod()); + $this->assertContains('multipart/form-data', (string) $requests[0]->getHeader('Content-Type')); + $this->assertContains('testSendsPostFilesForNonPostRequests', (string) $requests[0]->getBody()); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Curl/CurlMultiProxyTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Curl/CurlMultiProxyTest.php new file mode 100644 index 0000000..e04141c --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Curl/CurlMultiProxyTest.php @@ -0,0 +1,110 @@ +multi = new CurlMultiProxy(self::MAX_HANDLES, self::SELECT_TIMEOUT); + } + + public function tearDown() + { + unset($this->multi); + } + + public function testConstructorSetsMaxHandles() + { + $m = new CurlMultiProxy(self::MAX_HANDLES, self::SELECT_TIMEOUT); + $this->assertEquals(self::MAX_HANDLES, $this->readAttribute($m, 'maxHandles')); + } + + public function testConstructorSetsSelectTimeout() + { + $m = new CurlMultiProxy(self::MAX_HANDLES, self::SELECT_TIMEOUT); + $this->assertEquals(self::SELECT_TIMEOUT, $this->readAttribute($m, 'selectTimeout')); + } + + public function testAddingRequestsAddsToQueue() + { + $r = new Request('GET', 'http://www.foo.com'); + $this->assertSame($this->multi, $this->multi->add($r)); + $this->assertEquals(1, count($this->multi)); + $this->assertEquals(array($r), $this->multi->all()); + + $this->assertTrue($this->multi->remove($r)); + $this->assertFalse($this->multi->remove($r)); + $this->assertEquals(0, count($this->multi)); + } + + public function testResetClearsState() + { + $r = new Request('GET', 'http://www.foo.com'); + $this->multi->add($r); + $this->multi->reset(); + $this->assertEquals(0, count($this->multi)); + } + + public function testSendWillSendQueuedRequestsFirst() + { + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n" + )); + $client = new Client($this->getServer()->getUrl()); + $events = array(); + $client->getCurlMulti()->getEventDispatcher()->addListener( + CurlMultiProxy::ADD_REQUEST, + function ($e) use (&$events) { + $events[] = $e; + } + ); + $request = $client->get(); + $request->getEventDispatcher()->addListener('request.complete', function () use ($client) { + $client->get('/foo')->send(); + }); + $request->send(); + $received = $this->getServer()->getReceivedRequests(true); + $this->assertEquals(2, count($received)); + $this->assertEquals($this->getServer()->getUrl(), $received[0]->getUrl()); + $this->assertEquals($this->getServer()->getUrl() . 'foo', $received[1]->getUrl()); + $this->assertEquals(2, count($events)); + } + + public function testTrimsDownMaxHandleCount() + { + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 307 OK\r\nLocation: /foo\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 307 OK\r\nLocation: /foo\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 307 OK\r\nLocation: /foo\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 307 OK\r\nLocation: /foo\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n" + )); + $client = new Client($this->getServer()->getUrl()); + $client->setCurlMulti(new CurlMultiProxy(self::MAX_HANDLES, self::SELECT_TIMEOUT)); + $request = $client->get(); + $request->send(); + $this->assertEquals(200, $request->getResponse()->getStatusCode()); + $handles = $this->readAttribute($client->getCurlMulti(), 'handles'); + $this->assertEquals(2, count($handles)); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Curl/CurlMultiTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Curl/CurlMultiTest.php new file mode 100644 index 0000000..a21f73b --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Curl/CurlMultiTest.php @@ -0,0 +1,455 @@ +multi = new MockMulti(); + } + + public function tearDown() + { + unset($this->multi); + } + + public function testConstructorCreateMultiHandle() + { + $this->assertInternalType('resource', $this->multi->getHandle()); + $this->assertEquals('curl_multi', get_resource_type($this->multi->getHandle())); + } + + public function testDestructorClosesMultiHandle() + { + $handle = $this->multi->getHandle(); + $this->multi->__destruct(); + $this->assertFalse(is_resource($handle)); + } + + public function testRequestsCanBeAddedAndCounted() + { + $multi = new CurlMulti(); + $request1 = new Request('GET', 'http://www.google.com/'); + $multi->add($request1); + $this->assertEquals(array($request1), $multi->all()); + $request2 = new Request('POST', 'http://www.google.com/'); + $multi->add($request2); + $this->assertEquals(array($request1, $request2), $multi->all()); + $this->assertEquals(2, count($multi)); + } + + public function testRequestsCanBeRemoved() + { + $request1 = new Request('GET', 'http://www.google.com/'); + $this->multi->add($request1); + $request2 = new Request('PUT', 'http://www.google.com/'); + $this->multi->add($request2); + $this->assertEquals(array($request1, $request2), $this->multi->all()); + $this->assertTrue($this->multi->remove($request1)); + $this->assertFalse($this->multi->remove($request1)); + $this->assertEquals(array($request2), $this->multi->all()); + } + + public function testsResetRemovesRequestsAndResetsState() + { + $this->multi->add(new Request('GET', 'http://www.google.com/')); + $this->multi->reset(); + $this->assertEquals(array(), $this->multi->all()); + } + + public function testSendsRequestsThroughCurl() + { + $this->getServer()->enqueue(array( + "HTTP/1.1 204 No content\r\n" . + "Content-Length: 0\r\n" . + "Server: Jetty(6.1.3)\r\n\r\n", + "HTTP/1.1 200 OK\r\n" . + "Content-Type: text/html; charset=utf-8\r\n" . + "Content-Length: 4\r\n" . + "Server: Jetty(6.1.3)\r\n\r\n" . + "data" + )); + + $request1 = new Request('GET', $this->getServer()->getUrl()); + $request2 = new Request('GET', $this->getServer()->getUrl()); + $this->multi->add($request1); + $this->multi->add($request2); + $this->multi->send(); + + $response1 = $request1->getResponse(); + $response2 = $request2->getResponse(); + $this->assertInstanceOf('Guzzle\\Http\\Message\\Response', $response1); + $this->assertInstanceOf('Guzzle\\Http\\Message\\Response', $response2); + + $this->assertTrue($response1->getBody(true) == 'data' || $response2->getBody(true) == 'data'); + $this->assertTrue($response1->getBody(true) == '' || $response2->getBody(true) == ''); + $this->assertTrue($response1->getStatusCode() == '204' || $response2->getStatusCode() == '204'); + $this->assertNotEquals((string) $response1, (string) $response2); + } + + public function testSendsThroughCurlAndAggregatesRequestExceptions() + { + $this->getServer()->enqueue(array( + "HTTP/1.1 200 OK\r\n" . + "Content-Type: text/html; charset=utf-8\r\n" . + "Content-Length: 4\r\n" . + "Server: Jetty(6.1.3)\r\n" . + "\r\n" . + "data", + "HTTP/1.1 204 No content\r\n" . + "Content-Length: 0\r\n" . + "Server: Jetty(6.1.3)\r\n" . + "\r\n", + "HTTP/1.1 404 Not Found\r\n" . + "Content-Length: 0\r\n" . + "\r\n" + )); + + $request1 = new Request('GET', $this->getServer()->getUrl()); + $request2 = new Request('HEAD', $this->getServer()->getUrl()); + $request3 = new Request('GET', $this->getServer()->getUrl()); + $this->multi->add($request1); + $this->multi->add($request2); + $this->multi->add($request3); + + try { + $this->multi->send(); + $this->fail('MultiTransferException not thrown when aggregating request exceptions'); + } catch (MultiTransferException $e) { + + $this->assertTrue($e->containsRequest($request1)); + $this->assertTrue($e->containsRequest($request2)); + $this->assertTrue($e->containsRequest($request3)); + $this->assertInstanceOf('ArrayIterator', $e->getIterator()); + $this->assertEquals(1, count($e)); + $exceptions = $e->getIterator(); + + $response1 = $request1->getResponse(); + $response2 = $request2->getResponse(); + $response3 = $request3->getResponse(); + + $this->assertNotEquals((string) $response1, (string) $response2); + $this->assertNotEquals((string) $response3, (string) $response1); + $this->assertInstanceOf('Guzzle\\Http\\Message\\Response', $response1); + $this->assertInstanceOf('Guzzle\\Http\\Message\\Response', $response2); + $this->assertInstanceOf('Guzzle\\Http\\Message\\Response', $response3); + + $failed = $exceptions[0]->getResponse(); + $this->assertEquals(404, $failed->getStatusCode()); + $this->assertEquals(1, count($e)); + + // Test the IteratorAggregate functionality + foreach ($e as $except) { + $this->assertEquals($failed, $except->getResponse()); + } + + $this->assertEquals(1, count($e->getFailedRequests())); + $this->assertEquals(2, count($e->getSuccessfulRequests())); + $this->assertEquals(3, count($e->getAllRequests())); + } + } + + public function testCurlErrorsAreCaught() + { + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n"); + try { + $request = RequestFactory::getInstance()->create('GET', 'http://127.0.0.1:9876/'); + $request->setClient(new Client()); + $request->getCurlOptions()->set(CURLOPT_FRESH_CONNECT, true); + $request->getCurlOptions()->set(CURLOPT_FORBID_REUSE, true); + $request->getCurlOptions()->set(CURLOPT_CONNECTTIMEOUT_MS, 5); + $request->send(); + $this->fail('CurlException not thrown'); + } catch (CurlException $e) { + $m = $e->getMessage(); + $this->assertContains('[curl] ', $m); + $this->assertContains('[url] http://127.0.0.1:9876/', $m); + $this->assertInternalType('array', $e->getCurlInfo()); + } + } + + public function testRemovesQueuedRequests() + { + $request = RequestFactory::getInstance()->create('GET', 'http://127.0.0.1:9876/'); + $r = new Response(200); + $request->setClient(new Client()); + $request->setResponse($r, true); + $this->multi->add($request); + $this->multi->send(); + $this->assertSame($r, $request->getResponse()); + } + + public function testRemovesQueuedRequestsAddedInTransit() + { + $this->getServer()->flush(); + $this->getServer()->enqueue(array("HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n")); + $client = new Client($this->getServer()->getUrl()); + $r = $client->get(); + $r->getEventDispatcher()->addListener('request.receive.status_line', function (Event $event) use ($client) { + // Create a request using a queued response + $request = $client->get()->setResponse(new Response(200), true); + $request->send(); + }); + $r->send(); + $this->assertEquals(1, count($this->getServer()->getReceivedRequests(false))); + } + + public function testCatchesExceptionsBeforeSendingSingleRequest() + { + $client = new Client($this->getServer()->getUrl()); + $multi = new CurlMulti(); + $client->setCurlMulti($multi); + $request = $client->get(); + $request->getEventDispatcher()->addListener('request.before_send', function() { + throw new \RuntimeException('Testing!'); + }); + try { + $request->send(); + $this->fail('Did not throw'); + } catch (\RuntimeException $e) { + // Ensure it was removed + $this->assertEquals(0, count($multi)); + } + } + + /** + * @expectedException \Guzzle\Common\Exception\ExceptionCollection + * @expectedExceptionMessage Thrown before sending! + */ + public function testCatchesExceptionsBeforeSendingMultipleRequests() + { + $client = new Client($this->getServer()->getUrl()); + $request = $client->get(); + $request->getEventDispatcher()->addListener('request.before_send', function() { + throw new \RuntimeException('Thrown before sending!'); + }); + $client->send(array($request)); + } + + public function testCatchesExceptionsWhenRemovingQueuedRequests() + { + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n"); + $client = new Client($this->getServer()->getUrl()); + $r = $client->get(); + $r->getEventDispatcher()->addListener('request.sent', function() use ($client) { + // Create a request using a queued response + $client->get()->setResponse(new Response(404), true)->send(); + }); + try { + $r->send(); + $this->fail('Did not throw'); + } catch (BadResponseException $e) { + $this->assertCount(0, $client->getCurlMulti()); + } + } + + public function testCatchesExceptionsWhenRemovingQueuedRequestsBeforeSending() + { + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n"); + $client = new Client($this->getServer()->getUrl()); + $r = $client->get(); + $r->getEventDispatcher()->addListener('request.before_send', function() use ($client) { + // Create a request using a queued response + $client->get()->setResponse(new Response(404), true)->send(); + }); + try { + $r->send(); + $this->fail('Did not throw'); + } catch (BadResponseException $e) { + $this->assertCount(0, $client->getCurlMulti()); + } + } + + /** + * @expectedException \RuntimeException + * @expectedExceptionMessage test + */ + public function testDoesNotCatchRandomExceptionsThrownDuringPerform() + { + $client = new Client($this->getServer()->getUrl()); + $multi = $this->getMock('Guzzle\\Http\\Curl\\CurlMulti', array('perform')); + $multi->expects($this->once()) + ->method('perform') + ->will($this->throwException(new \RuntimeException('test'))); + $multi->add($client->get()); + $multi->send(); + } + + public function testDoesNotSendRequestsDecliningToBeSent() + { + if (!defined('CURLOPT_TIMEOUT_MS')) { + $this->markTestSkipped('Update curl'); + } + + // Create a client that is bound to fail connecting + $client = new Client('http://localhost:123', array( + 'curl.CURLOPT_PORT' => 123, + 'curl.CURLOPT_CONNECTTIMEOUT_MS' => 1, + )); + + $request = $client->get(); + $multi = new CurlMulti(); + $multi->add($request); + + // Listen for request exceptions, and when they occur, first change the + // state of the request back to transferring, and then just allow it to + // exception out + $request->getEventDispatcher()->addListener('request.exception', function(Event $event) use ($multi) { + $retries = $event['request']->getParams()->get('retries'); + // Allow the first failure to retry + if ($retries == 0) { + $event['request']->setState('transfer'); + $event['request']->getParams()->set('retries', 1); + // Remove the request to try again + $multi->remove($event['request']); + $multi->add($event['request']); + } + }); + + try { + $multi->send(); + $this->fail('Did not throw an exception at all!?!'); + } catch (\Exception $e) { + $this->assertEquals(1, $request->getParams()->get('retries')); + } + } + + public function testDoesNotThrowExceptionsWhenRequestsRecoverWithRetry() + { + $this->getServer()->flush(); + $client = new Client($this->getServer()->getUrl()); + $request = $client->get(); + $request->getEventDispatcher()->addListener('request.before_send', function(Event $event) { + $event['request']->setResponse(new Response(200)); + }); + + $multi = new CurlMulti(); + $multi->add($request); + $multi->send(); + $this->assertEquals(0, count($this->getServer()->getReceivedRequests(false))); + } + + public function testDoesNotThrowExceptionsWhenRequestsRecoverWithSuccess() + { + // Attempt a port that 99.9% is not listening + $client = new Client('http://localhost:123'); + $request = $client->get(); + // Ensure it times out quickly if needed + $request->getCurlOptions()->set(CURLOPT_TIMEOUT_MS, 1)->set(CURLOPT_CONNECTTIMEOUT_MS, 1); + + $request->getEventDispatcher()->addListener('request.exception', function(Event $event) use (&$count) { + $event['request']->setResponse(new Response(200)); + }); + + $multi = new CurlMulti(); + $multi->add($request); + $multi->send(); + + // Ensure that the exception was caught, and the response was set manually + $this->assertEquals(200, $request->getResponse()->getStatusCode()); + } + + public function testHardResetReopensMultiHandle() + { + $this->getServer()->enqueue(array( + "HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n" + )); + + $stream = fopen('php://temp', 'w+'); + $client = new Client($this->getServer()->getUrl()); + $client->getConfig()->set('curl.CURLOPT_VERBOSE', true)->set('curl.CURLOPT_STDERR', $stream); + + $request = $client->get(); + $multi = new CurlMulti(); + $multi->add($request); + $multi->send(); + $multi->reset(true); + $multi->add($request); + $multi->send(); + + rewind($stream); + $this->assertNotContains('Re-using existing connection', stream_get_contents($stream)); + } + + public function testThrowsMeaningfulExceptionsForCurlMultiErrors() + { + $multi = new CurlMulti(); + + // Set the state of the multi object to sending to trigger the exception + $reflector = new \ReflectionMethod('Guzzle\Http\Curl\CurlMulti', 'checkCurlResult'); + $reflector->setAccessible(true); + + // Successful + $reflector->invoke($multi, 0); + + // Known error + try { + $reflector->invoke($multi, CURLM_BAD_HANDLE); + $this->fail('Expected an exception here'); + } catch (CurlException $e) { + $this->assertContains('The passed-in handle is not a valid CURLM handle.', $e->getMessage()); + $this->assertContains('CURLM_BAD_HANDLE', $e->getMessage()); + $this->assertContains(strval(CURLM_BAD_HANDLE), $e->getMessage()); + } + + // Unknown error + try { + $reflector->invoke($multi, 255); + $this->fail('Expected an exception here'); + } catch (CurlException $e) { + $this->assertEquals('Unexpected cURL error: 255', $e->getMessage()); + } + } + + public function testRequestBeforeSendIncludesContentLengthHeaderIfEmptyBody() + { + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n"); + $request = new Request('PUT', $this->getServer()->getUrl()); + $that = $this; + $request->getEventDispatcher()->addListener('request.before_send', function ($event) use ($that) { + $that->assertEquals(0, $event['request']->getHeader('Content-Length')); + }); + $this->multi->add($request); + $this->multi->send(); + } + + public function testRemovesConflictingTransferEncodingHeader() + { + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 200 OK\r\nContent-Length: 4\r\n\r\ntest", + "HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n" + )); + $client = new Client($this->getServer()->getUrl()); + $request = $client->put('/', null, fopen($this->getServer()->getUrl(), 'r')); + $request->setHeader('Content-Length', 4); + $request->send(); + $received = $this->getServer()->getReceivedRequests(true); + $this->assertFalse($received[1]->hasHeader('Transfer-Encoding')); + $this->assertEquals(4, (string) $received[1]->getHeader('Content-Length')); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Curl/CurlVersionTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Curl/CurlVersionTest.php new file mode 100644 index 0000000..c7b5ee6 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Curl/CurlVersionTest.php @@ -0,0 +1,39 @@ +getProperty('version'); + $refProperty->setAccessible(true); + $refProperty->setValue($instance, array()); + + $this->assertEquals($info, $instance->getAll()); + $this->assertEquals($info, $instance->getAll()); + + $this->assertEquals($info['version'], $instance->get('version')); + $this->assertFalse($instance->get('foo')); + } + + public function testIsSingleton() + { + $refObject = new \ReflectionClass('Guzzle\Http\Curl\CurlVersion'); + $refProperty = $refObject->getProperty('instance'); + $refProperty->setAccessible(true); + $refProperty->setValue(null, null); + + $this->assertInstanceOf('Guzzle\Http\Curl\CurlVersion', CurlVersion::getInstance()); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Curl/RequestMediatorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Curl/RequestMediatorTest.php new file mode 100644 index 0000000..c69e0c9 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Curl/RequestMediatorTest.php @@ -0,0 +1,67 @@ +events[] = $event; + } + + public function testEmitsEvents() + { + $request = new EntityEnclosingRequest('PUT', 'http://www.example.com'); + $request->setBody('foo'); + $request->setResponse(new Response(200)); + + // Ensure that IO events are emitted + $request->getCurlOptions()->set('emit_io', true); + + // Attach listeners for each event type + $request->getEventDispatcher()->addListener('curl.callback.progress', array($this, 'event')); + $request->getEventDispatcher()->addListener('curl.callback.read', array($this, 'event')); + $request->getEventDispatcher()->addListener('curl.callback.write', array($this, 'event')); + + $mediator = new RequestMediator($request, true); + + $mediator->progress('a', 'b', 'c', 'd'); + $this->assertEquals(1, count($this->events)); + $this->assertEquals('curl.callback.progress', $this->events[0]->getName()); + + $this->assertEquals(3, $mediator->writeResponseBody('foo', 'bar')); + $this->assertEquals(2, count($this->events)); + $this->assertEquals('curl.callback.write', $this->events[1]->getName()); + $this->assertEquals('bar', $this->events[1]['write']); + $this->assertSame($request, $this->events[1]['request']); + + $this->assertEquals('foo', $mediator->readRequestBody('a', 'b', 3)); + $this->assertEquals(3, count($this->events)); + $this->assertEquals('curl.callback.read', $this->events[2]->getName()); + $this->assertEquals('foo', $this->events[2]['read']); + $this->assertSame($request, $this->events[2]['request']); + } + + public function testDoesNotUseRequestResponseBodyWhenNotCustom() + { + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 307 Foo\r\nLocation: /foo\r\nContent-Length: 2\r\n\r\nHI", + "HTTP/1.1 301 Foo\r\nLocation: /foo\r\nContent-Length: 2\r\n\r\nFI", + "HTTP/1.1 200 OK\r\nContent-Length: 4\r\n\r\ntest", + )); + $client = new Client($this->getServer()->getUrl()); + $response = $client->get()->send(); + $this->assertEquals('test', $response->getBody(true)); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/EntityBodyTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/EntityBodyTest.php new file mode 100644 index 0000000..124a44d --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/EntityBodyTest.php @@ -0,0 +1,182 @@ +assertEquals('data', (string) $body); + $this->assertEquals(4, $body->getContentLength()); + $this->assertEquals('PHP', $body->getWrapper()); + $this->assertEquals('TEMP', $body->getStreamType()); + + $handle = fopen(__DIR__ . '/../../../../phpunit.xml.dist', 'r'); + if (!$handle) { + $this->fail('Could not open test file'); + } + $body = EntityBody::factory($handle); + $this->assertEquals(__DIR__ . '/../../../../phpunit.xml.dist', $body->getUri()); + $this->assertTrue($body->isLocal()); + $this->assertEquals(__DIR__ . '/../../../../phpunit.xml.dist', $body->getUri()); + $this->assertEquals(filesize(__DIR__ . '/../../../../phpunit.xml.dist'), $body->getContentLength()); + + // make sure that a body will return as the same object + $this->assertTrue($body === EntityBody::factory($body)); + } + + public function testFactoryCreatesTempStreamByDefault() + { + $body = EntityBody::factory(''); + $this->assertEquals('PHP', $body->getWrapper()); + $this->assertEquals('TEMP', $body->getStreamType()); + $body = EntityBody::factory(); + $this->assertEquals('PHP', $body->getWrapper()); + $this->assertEquals('TEMP', $body->getStreamType()); + } + + public function testFactoryCanCreateFromObject() + { + $body = EntityBody::factory(new QueryString(array('foo' => 'bar'))); + $this->assertEquals('foo=bar', (string) $body); + } + + /** + * @expectedException \Guzzle\Common\Exception\InvalidArgumentException + */ + public function testFactoryEnsuresObjectsHaveToStringMethod() + { + EntityBody::factory(new \stdClass('a')); + } + + public function testHandlesCompression() + { + $body = EntityBody::factory('testing 123...testing 123'); + $this->assertFalse($body->getContentEncoding(), '-> getContentEncoding() must initially return FALSE'); + $size = $body->getContentLength(); + $body->compress(); + $this->assertEquals('gzip', $body->getContentEncoding(), '-> getContentEncoding() must return the correct encoding after compressing'); + $this->assertEquals(gzdeflate('testing 123...testing 123'), (string) $body); + $this->assertTrue($body->getContentLength() < $size); + $this->assertTrue($body->uncompress()); + $this->assertEquals('testing 123...testing 123', (string) $body); + $this->assertFalse($body->getContentEncoding(), '-> getContentEncoding() must reset to FALSE'); + + if (in_array('bzip2.*', stream_get_filters())) { + $this->assertTrue($body->compress('bzip2.compress')); + $this->assertEquals('compress', $body->getContentEncoding(), '-> compress() must set \'compress\' as the Content-Encoding'); + } + + $this->assertFalse($body->compress('non-existent'), '-> compress() must return false when a non-existent stream filter is used'); + + // Release the body + unset($body); + + // Use gzip compression on the initial content. This will include a + // gzip header which will need to be stripped when deflating the stream + $body = EntityBody::factory(gzencode('test')); + $this->assertSame($body, $body->setStreamFilterContentEncoding('zlib.deflate')); + $this->assertTrue($body->uncompress('zlib.inflate')); + $this->assertEquals('test', (string) $body); + unset($body); + + // Test using a very long string + $largeString = ''; + for ($i = 0; $i < 25000; $i++) { + $largeString .= chr(rand(33, 126)); + } + $body = EntityBody::factory($largeString); + $this->assertEquals($largeString, (string) $body); + $this->assertTrue($body->compress()); + $this->assertNotEquals($largeString, (string) $body); + $compressed = (string) $body; + $this->assertTrue($body->uncompress()); + $this->assertEquals($largeString, (string) $body); + $this->assertEquals($compressed, gzdeflate($largeString)); + + $body = EntityBody::factory(fopen(__DIR__ . '/../TestData/compress_test', 'w')); + $this->assertFalse($body->compress()); + unset($body); + + unlink(__DIR__ . '/../TestData/compress_test'); + } + + public function testDeterminesContentType() + { + // Test using a string/temp stream + $body = EntityBody::factory('testing 123...testing 123'); + $this->assertNull($body->getContentType()); + + // Use a local file + $body = EntityBody::factory(fopen(__FILE__, 'r')); + $this->assertContains('text/x-', $body->getContentType()); + } + + public function testCreatesMd5Checksum() + { + $body = EntityBody::factory('testing 123...testing 123'); + $this->assertEquals(md5('testing 123...testing 123'), $body->getContentMd5()); + + $server = $this->getServer()->enqueue( + "HTTP/1.1 200 OK" . "\r\n" . + "Content-Length: 3" . "\r\n\r\n" . + "abc" + ); + + $body = EntityBody::factory(fopen($this->getServer()->getUrl(), 'r')); + $this->assertFalse($body->getContentMd5()); + } + + public function testSeeksToOriginalPosAfterMd5() + { + $body = EntityBody::factory('testing 123'); + $body->seek(4); + $this->assertEquals(md5('testing 123'), $body->getContentMd5()); + $this->assertEquals(4, $body->ftell()); + $this->assertEquals('ing 123', $body->read(1000)); + } + + public function testGetTypeFormBodyFactoring() + { + $body = EntityBody::factory(array('key1' => 'val1', 'key2' => 'val2')); + $this->assertEquals('key1=val1&key2=val2', (string) $body); + } + + public function testAllowsCustomRewind() + { + $body = EntityBody::factory('foo'); + $rewound = false; + $body->setRewindFunction(function ($body) use (&$rewound) { + $rewound = true; + return $body->seek(0); + }); + $body->seek(2); + $this->assertTrue($body->rewind()); + $this->assertTrue($rewound); + } + + /** + * @expectedException \Guzzle\Common\Exception\InvalidArgumentException + */ + public function testCustomRewindFunctionMustBeCallable() + { + $body = EntityBody::factory(); + $body->setRewindFunction('foo'); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Exception/CurlExceptionTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Exception/CurlExceptionTest.php new file mode 100644 index 0000000..df3e4b7 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Exception/CurlExceptionTest.php @@ -0,0 +1,27 @@ +assertNull($e->getError()); + $this->assertNull($e->getErrorNo()); + $this->assertSame($e, $e->setError('test', 12)); + $this->assertEquals('test', $e->getError()); + $this->assertEquals(12, $e->getErrorNo()); + + $handle = new CurlHandle(curl_init(), array()); + $e->setCurlHandle($handle); + $this->assertSame($handle, $e->getCurlHandle()); + $handle->close(); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Exception/ExceptionTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Exception/ExceptionTest.php new file mode 100644 index 0000000..12cfd36 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Exception/ExceptionTest.php @@ -0,0 +1,66 @@ +setRequest($request); + $this->assertEquals($request, $e->getRequest()); + } + + /** + * @covers Guzzle\Http\Exception\BadResponseException + */ + public function testBadResponseException() + { + $e = new BadResponseException('Message'); + $response = new Response(200); + $e->setResponse($response); + $this->assertEquals($response, $e->getResponse()); + } + + /** + * @covers Guzzle\Http\Exception\BadResponseException::factory + */ + public function testCreatesGenericErrorExceptionOnError() + { + $request = new Request('GET', 'http://www.example.com'); + $response = new Response(307); + $e = BadResponseException::factory($request, $response); + $this->assertInstanceOf('Guzzle\Http\Exception\BadResponseException', $e); + } + + /** + * @covers Guzzle\Http\Exception\BadResponseException::factory + */ + public function testCreatesClientErrorExceptionOnClientError() + { + $request = new Request('GET', 'http://www.example.com'); + $response = new Response(404); + $e = BadResponseException::factory($request, $response); + $this->assertInstanceOf('Guzzle\Http\Exception\ClientErrorResponseException', $e); + } + + /** + * @covers Guzzle\Http\Exception\BadResponseException::factory + */ + public function testCreatesServerErrorExceptionOnServerError() + { + $request = new Request('GET', 'http://www.example.com'); + $response = new Response(503); + $e = BadResponseException::factory($request, $response); + $this->assertInstanceOf('Guzzle\Http\Exception\ServerErrorResponseException', $e); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Exception/MultiTransferExceptionTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Exception/MultiTransferExceptionTest.php new file mode 100644 index 0000000..fa4ec26 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Exception/MultiTransferExceptionTest.php @@ -0,0 +1,51 @@ +addSuccessfulRequest($r1); + $e->addFailedRequest($r2); + $this->assertEquals(array($r1), $e->getSuccessfulRequests()); + $this->assertEquals(array($r2), $e->getSuccessfulRequests()); + $this->assertEquals(array($r1, $r2), $e->getAllRequests()); + $this->assertTrue($e->containsRequest($r1)); + $this->assertTrue($e->containsRequest($r2)); + $this->assertFalse($e->containsRequest(new Request('POST', '/foo'))); + } + + public function testCanSetRequests() + { + $s = array($r1 = new Request('GET', 'http://www.foo.com')); + $f = array($r2 = new Request('GET', 'http://www.foo.com')); + $e = new MultiTransferException(); + $e->setSuccessfulRequests($s); + $e->setFailedRequests($f); + $this->assertEquals(array($r1), $e->getSuccessfulRequests()); + $this->assertEquals(array($r2), $e->getSuccessfulRequests()); + } + + public function testAssociatesExceptionsWithRequests() + { + $r1 = new Request('GET', 'http://www.foo.com'); + $re1 = new \Exception('foo'); + $re2 = new \Exception('bar'); + $e = new MultiTransferException(); + $e->add($re2); + $e->addFailedRequestWithException($r1, $re1); + $this->assertSame($re1, $e->getExceptionForFailedRequest($r1)); + $this->assertNull($e->getExceptionForFailedRequest(new Request('POST', '/foo'))); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/IoEmittingEntityBodyTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/IoEmittingEntityBodyTest.php new file mode 100644 index 0000000..cd6355f --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/IoEmittingEntityBodyTest.php @@ -0,0 +1,47 @@ +decorated = EntityBody::factory('hello'); + $this->body = new IoEmittingEntityBody($this->decorated); + } + + public function testEmitsReadEvents() + { + $e = null; + $this->body->getEventDispatcher()->addListener('body.read', function ($event) use (&$e) { + $e = $event; + }); + $this->assertEquals('hel', $this->body->read(3)); + $this->assertEquals('hel', $e['read']); + $this->assertEquals(3, $e['length']); + $this->assertSame($this->body, $e['body']); + } + + public function testEmitsWriteEvents() + { + $e = null; + $this->body->getEventDispatcher()->addListener('body.write', function ($event) use (&$e) { + $e = $event; + }); + $this->body->seek(0, SEEK_END); + $this->assertEquals(5, $this->body->write('there')); + $this->assertEquals('there', $e['write']); + $this->assertEquals(5, $e['result']); + $this->assertSame($this->body, $e['body']); + $this->assertEquals('hellothere', (string) $this->body); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/AbstractMessageTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/AbstractMessageTest.php new file mode 100644 index 0000000..9447d8c --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/AbstractMessageTest.php @@ -0,0 +1,136 @@ +mock = $this->getMockForAbstractClass('Guzzle\Http\Message\AbstractMessage'); + } + + public function tearDown() + { + $this->mock = $this->request = null; + } + + public function testGetParams() + { + $request = new Request('GET', 'http://example.com'); + $this->assertInstanceOf('Guzzle\\Common\\Collection', $request->getParams()); + } + + public function testAddHeaders() + { + $this->mock->setHeader('A', 'B'); + + $this->assertEquals($this->mock, $this->mock->addHeaders(array( + 'X-Data' => '123' + ))); + + $this->assertTrue($this->mock->hasHeader('X-Data') !== false); + $this->assertTrue($this->mock->hasHeader('A') !== false); + } + + public function testAllowsHeaderToSetAsHeader() + { + $h = new Header('A', 'B'); + $this->mock->setHeader('A', $h); + $this->assertSame($h, $this->mock->getHeader('A')); + } + + public function testGetHeader() + { + $this->mock->setHeader('Test', '123'); + $this->assertEquals('123', $this->mock->getHeader('Test')); + } + + public function testGetHeaders() + { + $this->assertSame($this->mock, $this->mock->setHeaders(array('a' => 'b', 'c' => 'd'))); + $h = $this->mock->getHeaders(); + $this->assertArrayHasKey('a', $h->toArray()); + $this->assertArrayHasKey('c', $h->toArray()); + $this->assertInstanceOf('Guzzle\Http\Message\Header\HeaderInterface', $h->get('a')); + $this->assertInstanceOf('Guzzle\Http\Message\Header\HeaderInterface', $h->get('c')); + } + + public function testGetHeaderLinesUsesGlue() + { + $this->mock->setHeaders(array('a' => 'b', 'c' => 'd')); + $this->mock->addHeader('a', 'e'); + $this->mock->getHeader('a')->setGlue('!'); + $this->assertEquals(array( + 'a: b! e', + 'c: d' + ), $this->mock->getHeaderLines()); + } + + public function testHasHeader() + { + $this->assertFalse($this->mock->hasHeader('Foo')); + $this->mock->setHeader('Foo', 'Bar'); + $this->assertEquals(true, $this->mock->hasHeader('Foo')); + $this->mock->setHeader('foo', 'yoo'); + $this->assertEquals(true, $this->mock->hasHeader('Foo')); + $this->assertEquals(true, $this->mock->hasHeader('foo')); + $this->assertEquals(false, $this->mock->hasHeader('bar')); + } + + public function testRemoveHeader() + { + $this->mock->setHeader('Foo', 'Bar'); + $this->assertEquals(true, $this->mock->hasHeader('Foo')); + $this->mock->removeHeader('Foo'); + $this->assertFalse($this->mock->hasHeader('Foo')); + } + + public function testReturnsNullWhenHeaderIsNotFound() + { + $this->assertNull($this->mock->getHeader('foo')); + } + + public function testAddingHeadersPreservesOriginalHeaderCase() + { + $this->mock->addHeaders(array( + 'test' => '123', + 'Test' => 'abc' + )); + $this->mock->addHeader('test', '456'); + $this->mock->addHeader('test', '789'); + + $header = $this->mock->getHeader('test'); + $this->assertContains('123', $header->toArray()); + $this->assertContains('456', $header->toArray()); + $this->assertContains('789', $header->toArray()); + $this->assertContains('abc', $header->toArray()); + } + + public function testCanStoreEmptyHeaders() + { + $this->mock->setHeader('Content-Length', 0); + $this->assertTrue($this->mock->hasHeader('Content-Length')); + $this->assertEquals(0, (string) $this->mock->getHeader('Content-Length')); + } + + public function testCanSetCustomHeaderFactory() + { + $f = new Header\HeaderFactory(); + $this->mock->setHeaderFactory($f); + $this->assertSame($f, $this->readAttribute($this->mock, 'headerFactory')); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/EntityEnclosingRequestTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/EntityEnclosingRequestTest.php new file mode 100644 index 0000000..191b022 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/EntityEnclosingRequestTest.php @@ -0,0 +1,434 @@ +client = new Client(); + } + + public function tearDown() + { + $this->client = null; + } + + public function testConstructorConfiguresRequest() + { + $request = new EntityEnclosingRequest('PUT', 'http://test.com', array( + 'X-Test' => '123' + )); + $request->setBody('Test'); + $this->assertEquals('123', $request->getHeader('X-Test')); + $this->assertNull($request->getHeader('Expect')); + } + + public function testCanSetBodyWithoutOverridingContentType() + { + $request = new EntityEnclosingRequest('PUT', 'http://test.com', array('Content-Type' => 'foooooo')); + $request->setBody('{"a":"b"}'); + $this->assertEquals('foooooo', $request->getHeader('Content-Type')); + } + + public function testRequestIncludesBodyInMessage() + { + + $request = RequestFactory::getInstance()->create('PUT', 'http://www.guzzle-project.com/', null, 'data'); + $this->assertEquals("PUT / HTTP/1.1\r\n" + . "Host: www.guzzle-project.com\r\n" + . "Content-Length: 4\r\n\r\n" + . "data", (string) $request); + } + + public function testRequestIncludesPostBodyInMessageOnlyWhenNoPostFiles() + { + $request = RequestFactory::getInstance()->create('POST', 'http://www.guzzle-project.com/', null, array( + 'foo' => 'bar' + )); + $this->assertEquals("POST / HTTP/1.1\r\n" + . "Host: www.guzzle-project.com\r\n" + . "Content-Type: application/x-www-form-urlencoded; charset=utf-8\r\n\r\n" + . "foo=bar", (string) $request); + + $request = RequestFactory::getInstance()->create('POST', 'http://www.guzzle-project.com/', null, array( + 'foo' => '@' . __FILE__ + )); + $this->assertEquals("POST / HTTP/1.1\r\n" + . "Host: www.guzzle-project.com\r\n" + . "Content-Type: multipart/form-data\r\n" + . "Expect: 100-Continue\r\n\r\n", (string) $request); + } + + public function testAddsPostFieldsAndSetsContentLength() + { + $request = RequestFactory::getInstance()->create('POST', 'http://www.guzzle-project.com/', null, array( + 'data' => '123' + )); + $this->assertEquals("POST / HTTP/1.1\r\n" + . "Host: www.guzzle-project.com\r\n" + . "Content-Type: application/x-www-form-urlencoded; charset=utf-8\r\n\r\n" + . "data=123", (string) $request); + } + + public function testAddsPostFilesAndSetsContentType() + { + $request = RequestFactory::getInstance()->create('POST', 'http://www.test.com/') + ->addPostFiles(array( + 'file' => __FILE__ + ))->addPostFields(array( + 'a' => 'b' + )); + $message = (string) $request; + $this->assertEquals('multipart/form-data', $request->getHeader('Content-Type')); + $this->assertEquals('100-Continue', $request->getHeader('Expect')); + } + + public function testRequestBodyContainsPostFiles() + { + $request = RequestFactory::getInstance()->create('POST', 'http://www.test.com/'); + $request->addPostFields(array( + 'test' => '123' + )); + $this->assertContains("\r\n\r\ntest=123", (string) $request); + } + + public function testRequestBodyAddsContentLength() + { + $request = RequestFactory::getInstance()->create('PUT', 'http://www.test.com/'); + $request->setBody(EntityBody::factory('test')); + $this->assertEquals(4, (string) $request->getHeader('Content-Length')); + $this->assertFalse($request->hasHeader('Transfer-Encoding')); + } + + public function testRequestBodyDoesNotUseContentLengthWhenChunked() + { + $request = RequestFactory::getInstance()->create('PUT', 'http://www.test.com/', array( + 'Transfer-Encoding' => 'chunked' + ), 'test'); + $this->assertNull($request->getHeader('Content-Length')); + $this->assertTrue($request->hasHeader('Transfer-Encoding')); + } + + public function testRequestHasMutableBody() + { + $request = RequestFactory::getInstance()->create('PUT', 'http://www.guzzle-project.com/', null, 'data'); + $body = $request->getBody(); + $this->assertInstanceOf('Guzzle\\Http\\EntityBody', $body); + $this->assertSame($body, $request->getBody()); + + $newBody = EntityBody::factory('foobar'); + $request->setBody($newBody); + $this->assertEquals('foobar', (string) $request->getBody()); + $this->assertSame($newBody, $request->getBody()); + } + + public function testSetPostFields() + { + $request = RequestFactory::getInstance()->create('POST', 'http://www.guzzle-project.com/'); + $this->assertInstanceOf('Guzzle\\Http\\QueryString', $request->getPostFields()); + + $fields = new QueryString(array( + 'a' => 'b' + )); + $request->addPostFields($fields); + $this->assertEquals($fields->getAll(), $request->getPostFields()->getAll()); + $this->assertEquals(array(), $request->getPostFiles()); + } + + public function testSetPostFiles() + { + $request = RequestFactory::getInstance()->create('POST', $this->getServer()->getUrl()) + ->setClient(new Client()) + ->addPostFiles(array(__FILE__)) + ->addPostFields(array( + 'test' => 'abc' + )); + + $request->getCurlOptions()->set('debug', true); + + $this->assertEquals(array( + 'test' => 'abc' + ), $request->getPostFields()->getAll()); + + $files = $request->getPostFiles(); + $post = $files['file'][0]; + $this->assertEquals('file', $post->getFieldName()); + $this->assertContains('text/x-', $post->getContentType()); + $this->assertEquals(__FILE__, $post->getFilename()); + + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n"); + $request->send(); + + $this->assertNotNull($request->getHeader('Content-Length')); + $this->assertContains('multipart/form-data; boundary=', (string) $request->getHeader('Content-Type'), '-> cURL must add the boundary'); + } + + /** + * @expectedException Guzzle\Common\Exception\InvalidArgumentException + */ + public function testSetPostFilesThrowsExceptionWhenFileIsNotFound() + { + $request = RequestFactory::getInstance()->create('POST', 'http://www.guzzle-project.com/') + ->addPostFiles(array( + 'file' => 'filenotfound.ini' + )); + } + + /** + * @expectedException Guzzle\Http\Exception\RequestException + */ + public function testThrowsExceptionWhenNonStringsAreAddedToPost() + { + $request = RequestFactory::getInstance()->create('POST', 'http://www.guzzle-project.com/') + ->addPostFile('foo', new \stdClass()); + } + + public function testAllowsContentTypeInPostUploads() + { + $request = RequestFactory::getInstance()->create('POST', 'http://www.guzzle-project.com/') + ->addPostFile('foo', __FILE__, 'text/plain'); + + $this->assertEquals(array( + new PostFile('foo', __FILE__, 'text/plain') + ), $request->getPostFile('foo')); + } + + public function testGuessesContentTypeOfPostUpload() + { + $request = RequestFactory::getInstance()->create('POST', 'http://www.guzzle-project.com/') + ->addPostFile('foo', __FILE__); + $file = $request->getPostFile('foo'); + $this->assertContains('text/x-', $file[0]->getContentType()); + } + + public function testAllowsContentDispositionFieldsInPostUploadsWhenSettingInBulk() + { + $postFile = new PostFile('foo', __FILE__, 'text/x-php'); + $request = RequestFactory::getInstance()->create('POST', 'http://www.guzzle-project.com/') + ->addPostFiles(array('foo' => $postFile)); + + $this->assertEquals(array($postFile), $request->getPostFile('foo')); + } + + public function testPostRequestsUseApplicationXwwwForUrlEncodedForArrays() + { + $request = RequestFactory::getInstance()->create('POST', 'http://www.guzzle-project.com/'); + $request->setPostField('a', 'b'); + $this->assertContains("\r\n\r\na=b", (string) $request); + $this->assertEquals('application/x-www-form-urlencoded; charset=utf-8', $request->getHeader('Content-Type')); + } + + public function testProcessMethodAddsContentType() + { + $request = RequestFactory::getInstance()->create('POST', 'http://www.guzzle-project.com/'); + $request->setPostField('a', 'b'); + $this->assertEquals('application/x-www-form-urlencoded; charset=utf-8', $request->getHeader('Content-Type')); + } + + public function testPostRequestsUseMultipartFormDataWithFiles() + { + $request = RequestFactory::getInstance()->create('POST', 'http://www.guzzle-project.com/'); + $request->addPostFiles(array('file' => __FILE__)); + $this->assertEquals('multipart/form-data', $request->getHeader('Content-Type')); + } + + public function testCanSendMultipleRequestsUsingASingleRequestObject() + { + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 201 Created\r\nContent-Length: 0\r\n\r\n", + )); + + // Send the first request + $request = RequestFactory::getInstance()->create('PUT', $this->getServer()->getUrl()) + ->setBody('test') + ->setClient(new Client()); + $request->send(); + $this->assertEquals(200, $request->getResponse()->getStatusCode()); + + // Send the second request + $request->setBody('abcdefg', 'application/json', false); + $request->send(); + $this->assertEquals(201, $request->getResponse()->getStatusCode()); + + // Ensure that the same request was sent twice with different bodies + $requests = $this->getServer()->getReceivedRequests(true); + $this->assertEquals(2, count($requests)); + $this->assertEquals(4, (string) $requests[0]->getHeader('Content-Length')); + $this->assertEquals(7, (string) $requests[1]->getHeader('Content-Length')); + } + + public function testRemovingPostFieldRebuildsPostFields() + { + $request = new EntityEnclosingRequest('POST', 'http://test.com'); + $request->setPostField('test', 'value'); + $request->removePostField('test'); + $this->assertNull($request->getPostField('test')); + } + + public function testUsesChunkedTransferWhenBodyLengthCannotBeDetermined() + { + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n"); + $request = new EntityEnclosingRequest('PUT', 'http://test.com/'); + $request->setBody(fopen($this->getServer()->getUrl(), 'r')); + $this->assertEquals('chunked', $request->getHeader('Transfer-Encoding')); + $this->assertFalse($request->hasHeader('Content-Length')); + } + + /** + * @expectedException \Guzzle\Http\Exception\RequestException + */ + public function testThrowsExceptionWhenContentLengthCannotBeDeterminedAndUsingHttp1() + { + $request = new EntityEnclosingRequest('PUT', 'http://test.com/'); + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n"); + $request->setProtocolVersion('1.0'); + $request->setBody(fopen($this->getServer()->getUrl(), 'r')); + } + + public function testAllowsNestedPostData() + { + $request = new EntityEnclosingRequest('POST', 'http://test.com/'); + $request->addPostFields(array( + 'a' => array('b', 'c') + )); + $this->assertEquals(array( + 'a' => array('b', 'c') + ), $request->getPostFields()->getAll()); + } + + public function testAllowsEmptyFields() + { + $request = new EntityEnclosingRequest('POST', 'http://test.com/'); + $request->addPostFields(array( + 'a' => '' + )); + $this->assertEquals(array( + 'a' => '' + ), $request->getPostFields()->getAll()); + } + + /** + * @expectedException \Guzzle\Http\Exception\RequestException + */ + public function testFailsOnInvalidFiles() + { + $request = new EntityEnclosingRequest('POST', 'http://test.com/'); + $request->addPostFiles(array( + 'a' => new \stdClass() + )); + } + + public function testHandlesEmptyStrings() + { + $request = new EntityEnclosingRequest('POST', 'http://test.com/'); + $request->addPostFields(array( + 'a' => '', + 'b' => null, + 'c' => 'Foo' + )); + $this->assertEquals(array( + 'a' => '', + 'b' => null, + 'c' => 'Foo' + ), $request->getPostFields()->getAll()); + } + + public function testHoldsPostFiles() + { + $request = new EntityEnclosingRequest('POST', 'http://test.com/'); + $request->addPostFile('foo', __FILE__); + $request->addPostFile(new PostFile('foo', __FILE__)); + + $this->assertArrayHasKey('foo', $request->getPostFiles()); + $foo = $request->getPostFile('foo'); + $this->assertEquals(2, count($foo)); + $this->assertEquals(__FILE__, $foo[0]->getFilename()); + $this->assertEquals(__FILE__, $foo[1]->getFilename()); + + $request->removePostFile('foo'); + $this->assertEquals(array(), $request->getPostFiles()); + } + + public function testAllowsAtPrefixWhenAddingPostFiles() + { + $request = new EntityEnclosingRequest('POST', 'http://test.com/'); + $request->addPostFiles(array( + 'foo' => '@' . __FILE__ + )); + $foo = $request->getPostFile('foo'); + $this->assertEquals(__FILE__, $foo[0]->getFilename()); + } + + public function testSetStateToTransferWithEmptyBodySetsContentLengthToZero() + { + $request = new EntityEnclosingRequest('POST', 'http://test.com/'); + $request->setState($request::STATE_TRANSFER); + $this->assertEquals('0', (string) $request->getHeader('Content-Length')); + } + + public function testSettingExpectHeaderCutoffChangesRequest() + { + $request = new EntityEnclosingRequest('PUT', 'http://test.com/'); + $request->setHeader('Expect', '100-Continue'); + $request->setExpectHeaderCutoff(false); + $this->assertNull($request->getHeader('Expect')); + // There is not body, so remove the expect header + $request->setHeader('Expect', '100-Continue'); + $request->setExpectHeaderCutoff(10); + $this->assertNull($request->getHeader('Expect')); + // The size is less than the cutoff + $request->setBody('foo'); + $this->assertNull($request->getHeader('Expect')); + // The size is greater than the cutoff + $request->setBody('foobazbarbamboo'); + $this->assertNotNull($request->getHeader('Expect')); + } + + public function testStrictRedirectsCanBeSpecifiedOnEntityEnclosingRequests() + { + $request = new EntityEnclosingRequest('PUT', 'http://test.com/'); + $request->configureRedirects(true); + $this->assertTrue($request->getParams()->get(RedirectPlugin::STRICT_REDIRECTS)); + } + + public function testCanDisableRedirects() + { + $request = new EntityEnclosingRequest('PUT', 'http://test.com/'); + $request->configureRedirects(false, false); + $this->assertTrue($request->getParams()->get(RedirectPlugin::DISABLE)); + } + + public function testSetsContentTypeWhenSettingBodyByGuessingFromEntityBody() + { + $request = new EntityEnclosingRequest('PUT', 'http://test.com/foo'); + $request->setBody(EntityBody::factory(fopen(__FILE__, 'r'))); + $this->assertEquals('text/x-php', (string) $request->getHeader('Content-Type')); + } + + public function testDoesNotCloneBody() + { + $request = new EntityEnclosingRequest('PUT', 'http://test.com/foo'); + $request->setBody('test'); + $newRequest = clone $request; + $newRequest->setBody('foo'); + $this->assertInternalType('string', (string) $request->getBody()); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/Header/HeaderFactoryTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/Header/HeaderFactoryTest.php new file mode 100644 index 0000000..62ca555 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/Header/HeaderFactoryTest.php @@ -0,0 +1,29 @@ +createHeader('Foo', 'Bar'); + $this->assertInstanceOf('Guzzle\Http\Message\Header', $h); + $this->assertEquals('Foo', $h->getName()); + $this->assertEquals('Bar', (string) $h); + } + + public function testCreatesSpecificHeaders() + { + $f = new HeaderFactory(); + $h = $f->createHeader('Link', '; rel="test"'); + $this->assertInstanceOf('Guzzle\Http\Message\Header\Link', $h); + $this->assertEquals('Link', $h->getName()); + $this->assertEquals('; rel="test"', (string) $h); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/Header/LinkTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/Header/LinkTest.php new file mode 100644 index 0000000..c834d10 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/Header/LinkTest.php @@ -0,0 +1,63 @@ +; rel=front; type="image/jpeg", ; rel=back; type="image/jpeg", ; rel=side; type="image/jpeg"'); + $links = $link->getLinks(); + $this->assertEquals(array( + array( + 'rel' => 'front', + 'type' => 'image/jpeg', + 'url' => 'http:/.../front.jpeg', + ), + array( + 'rel' => 'back', + 'type' => 'image/jpeg', + 'url' => 'http://.../back.jpeg', + ), + array( + 'rel' => 'side', + 'type' => 'image/jpeg', + 'url' => 'http://.../side.jpeg?test=1' + ) + ), $links); + + $this->assertEquals(array( + 'rel' => 'back', + 'type' => 'image/jpeg', + 'url' => 'http://.../back.jpeg', + ), $link->getLink('back')); + + $this->assertTrue($link->hasLink('front')); + $this->assertFalse($link->hasLink('foo')); + } + + public function testCanAddLink() + { + $link = new Link('Link', '; rel=a; type="image/jpeg"'); + $link->addLink('http://test.com', 'test', array('foo' => 'bar')); + $this->assertEquals( + '; rel=a; type="image/jpeg", ; rel="test"; foo="bar"', + (string) $link + ); + } + + public function testCanParseLinksWithCommas() + { + $link = new Link('Link', '; rel="previous"; title="start, index"'); + $this->assertEquals(array( + array( + 'rel' => 'previous', + 'title' => 'start, index', + 'url' => 'http://example.com/TheBook/chapter1', + ) + ), $link->getLinks()); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/HeaderComparison.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/HeaderComparison.php new file mode 100644 index 0000000..a3f511b --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/HeaderComparison.php @@ -0,0 +1,135 @@ +toArray(); + } + + foreach ($filteredHeaders as $k => $v) { + if ($k[0] == '_') { + // This header should be ignored + $ignore[] = str_replace('_', '', $k); + } elseif ($k[0] == '!') { + // This header must not be present + $absent[] = str_replace('!', '', $k); + } else { + $expected[$k] = $v; + } + } + + return $this->compareArray($expected, $actualHeaders, $ignore, $absent); + } + + /** + * Check if an array of HTTP headers matches another array of HTTP headers while taking * into account as a wildcard + * + * @param array $expected Expected HTTP headers (allows wildcard values) + * @param array|Collection $actual Actual HTTP header array + * @param array $ignore Headers to ignore from the comparison + * @param array $absent Array of headers that must not be present + * + * @return array|bool Returns an array of the differences or FALSE if none + */ + public function compareArray(array $expected, $actual, array $ignore = array(), array $absent = array()) + { + $differences = array(); + + // Add information about headers that were present but weren't supposed to be + foreach ($absent as $header) { + if ($this->hasKey($header, $actual)) { + $differences["++ {$header}"] = $actual[$header]; + unset($actual[$header]); + } + } + + // Check if expected headers are missing + foreach ($expected as $header => $value) { + if (!$this->hasKey($header, $actual)) { + $differences["- {$header}"] = $value; + } + } + + // Flip the ignore array so it works with the case insensitive helper + $ignore = array_flip($ignore); + // Allow case-insensitive comparisons in wildcards + $expected = array_change_key_case($expected); + + // Compare the expected and actual HTTP headers in no particular order + foreach ($actual as $key => $value) { + + // If this is to be ignored, the skip it + if ($this->hasKey($key, $ignore)) { + continue; + } + + // If the header was not expected + if (!$this->hasKey($key, $expected)) { + $differences["+ {$key}"] = $value; + continue; + } + + // Check values and take wildcards into account + $lkey = strtolower($key); + $pos = is_string($expected[$lkey]) ? strpos($expected[$lkey], '*') : false; + + foreach ((array) $actual[$key] as $v) { + if (($pos === false && $v != $expected[$lkey]) || $pos > 0 && substr($v, 0, $pos) != substr($expected[$lkey], 0, $pos)) { + $differences[$key] = "{$value} != {$expected[$lkey]}"; + } + } + } + + return empty($differences) ? false : $differences; + } + + /** + * Case insensitive check if an array have a key + * + * @param string $key Key to check + * @param array $array Array to check + * + * @return bool + */ + protected function hasKey($key, $array) + { + if ($array instanceof Collection) { + $keys = $array->getKeys(); + } else { + $keys = array_keys($array); + } + + foreach ($keys as $k) { + if (!strcasecmp($k, $key)) { + return true; + } + } + + return false; + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/HeaderComparisonTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/HeaderComparisonTest.php new file mode 100644 index 0000000..86c4fe8 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/HeaderComparisonTest.php @@ -0,0 +1,115 @@ + 'Foo' + ), array( + 'Content-Length' => 'Foo' + ), false), + + // Missing header + array(array( + 'X-Foo' => 'Bar' + ), array(), array( + '- X-Foo' => 'Bar' + )), + + // Extra headers is present + array(array( + 'X-Foo' => 'Bar' + ), array( + 'X-Foo' => 'Bar', + 'X-Baz' => 'Jar' + ), array( + '+ X-Baz' => 'Jar' + )), + + // Header is present but must be absent + array(array( + '!X-Foo' => '*' + ), array( + 'X-Foo' => 'Bar' + ), array( + '++ X-Foo' => 'Bar' + )), + + // Different values + array(array( + 'X-Foo' => 'Bar' + ), array( + 'X-Foo' => 'Baz' + ), array( + 'X-Foo' => 'Baz != Bar' + )), + + // Wildcard search passes + array(array( + 'X-Foo' => '*' + ), array( + 'X-Foo' => 'Bar' + ), false), + + // Wildcard search fails + array(array( + 'X-Foo' => '*' + ), array(), array( + '- X-Foo' => '*' + )), + + // Ignore extra header if present + array(array( + 'X-Foo' => '*', + '_X-Bar' => '*', + ), array( + 'X-Foo' => 'Baz', + 'X-Bar' => 'Jar' + ), false), + + // Ignore extra header if present and is not + array(array( + 'X-Foo' => '*', + '_X-Bar' => '*', + ), array( + 'X-Foo' => 'Baz' + ), false), + + // Case insensitive + array(array( + 'X-Foo' => '*', + '_X-Bar' => '*', + ), array( + 'x-foo' => 'Baz', + 'x-BAR' => 'baz' + ), false), + + // Case insensitive with collection + array(array( + 'X-Foo' => '*', + '_X-Bar' => '*', + ), new Collection(array( + 'x-foo' => 'Baz', + 'x-BAR' => 'baz' + )), false), + ); + } + + /** + * @dataProvider filterProvider + */ + public function testComparesHeaders($filters, $headers, $result) + { + $compare = new HeaderComparison(); + $this->assertEquals($result, $compare->compare($filters, $headers)); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/HeaderTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/HeaderTest.php new file mode 100644 index 0000000..c750234 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/HeaderTest.php @@ -0,0 +1,162 @@ + array('foo', 'Foo'), + 'Zoo' => 'bar', + ); + + public function testStoresHeaderName() + { + $i = new Header('Zoo', $this->test); + $this->assertEquals('Zoo', $i->getName()); + } + + public function testConvertsToString() + { + $i = new Header('Zoo', $this->test); + $this->assertEquals('foo, Foo, bar', (string) $i); + $i->setGlue(';'); + $this->assertEquals('foo; Foo; bar', (string) $i); + } + + public function testNormalizesGluedHeaders() + { + $h = new Header('Zoo', array('foo, Faz', 'bar')); + $result = $h->normalize(true)->toArray(); + natsort($result); + $this->assertEquals(array('bar', 'foo', 'Faz'), $result); + } + + public function testCanSearchForValues() + { + $h = new Header('Zoo', $this->test); + $this->assertTrue($h->hasValue('foo')); + $this->assertTrue($h->hasValue('Foo')); + $this->assertTrue($h->hasValue('bar')); + $this->assertFalse($h->hasValue('moo')); + $this->assertFalse($h->hasValue('FoO')); + } + + public function testIsCountable() + { + $h = new Header('Zoo', $this->test); + $this->assertEquals(3, count($h)); + } + + public function testCanBeIterated() + { + $h = new Header('Zoo', $this->test); + $results = array(); + foreach ($h as $key => $value) { + $results[$key] = $value; + } + $this->assertEquals(array( + 'foo', 'Foo', 'bar' + ), $results); + } + + public function testAllowsFalseyValues() + { + // Allows 0 + $h = new Header('Foo', 0, ';'); + $this->assertEquals('0', (string) $h); + $this->assertEquals(1, count($h)); + $this->assertEquals(';', $h->getGlue()); + + // Does not add a null header by default + $h = new Header('Foo'); + $this->assertEquals('', (string) $h); + $this->assertEquals(0, count($h)); + + // Allows null array for a single null header + $h = new Header('Foo', array(null)); + $this->assertEquals('', (string) $h); + + // Allows empty string + $h = new Header('Foo', ''); + $this->assertEquals('', (string) $h); + $this->assertEquals(1, count($h)); + $this->assertEquals(1, count($h->normalize()->toArray())); + } + + public function testCanRemoveValues() + { + $h = new Header('Foo', array('Foo', 'baz', 'bar')); + $h->removeValue('bar'); + $this->assertTrue($h->hasValue('Foo')); + $this->assertFalse($h->hasValue('bar')); + $this->assertTrue($h->hasValue('baz')); + } + + public function testAllowsArrayInConstructor() + { + $h = new Header('Foo', array('Testing', '123', 'Foo=baz')); + $this->assertEquals(array('Testing', '123', 'Foo=baz'), $h->toArray()); + } + + public function parseParamsProvider() + { + $res1 = array( + array( + '' => '', + 'rel' => 'front', + 'type' => 'image/jpeg', + ), + array( + '' => '', + 'rel' => 'back', + 'type' => 'image/jpeg', + ), + ); + + return array( + array( + '; rel="front"; type="image/jpeg", ; rel=back; type="image/jpeg"', + $res1 + ), + array( + '; rel="front"; type="image/jpeg",; rel=back; type="image/jpeg"', + $res1 + ), + array( + 'foo="baz"; bar=123, boo, test="123", foobar="foo;bar"', + array( + array('foo' => 'baz', 'bar' => '123'), + array('boo' => ''), + array('test' => '123'), + array('foobar' => 'foo;bar') + ) + ), + array( + '; rel="side"; type="image/jpeg",; rel=side; type="image/jpeg"', + array( + array('' => '', 'rel' => 'side', 'type' => 'image/jpeg'), + array('' => '', 'rel' => 'side', 'type' => 'image/jpeg') + ) + ), + array( + '', + array() + ) + ); + } + + /** + * @dataProvider parseParamsProvider + */ + public function testParseParams($header, $result) + { + $response = new Response(200, array('Link' => $header)); + $this->assertEquals($result, $response->getHeader('Link')->parseParams()); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/PostFileTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/PostFileTest.php new file mode 100644 index 0000000..be048cb --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/PostFileTest.php @@ -0,0 +1,88 @@ +assertEquals('foo', $file->getFieldName()); + $this->assertEquals(__FILE__, $file->getFilename()); + $this->assertEquals('boo', $file->getPostName()); + $this->assertEquals('x-foo', $file->getContentType()); + } + + public function testRemovesLeadingAtSymbolFromPath() + { + $file = new PostFile('foo', '@' . __FILE__); + $this->assertEquals(__FILE__, $file->getFilename()); + } + + /** + * @expectedException Guzzle\Common\Exception\InvalidArgumentException + */ + public function testEnsuresFileIsReadable() + { + $file = new PostFile('foo', '/foo/baz/bar'); + } + + public function testCanChangeContentType() + { + $file = new PostFile('foo', '@' . __FILE__); + $file->setContentType('Boo'); + $this->assertEquals('Boo', $file->getContentType()); + } + + public function testCanChangeFieldName() + { + $file = new PostFile('foo', '@' . __FILE__); + $file->setFieldName('Boo'); + $this->assertEquals('Boo', $file->getFieldName()); + } + + public function testReturnsCurlValueString() + { + $file = new PostFile('foo', __FILE__); + if (version_compare(phpversion(), '5.5.0', '<')) { + $this->assertContains('@' . __FILE__ . ';filename=PostFileTest.php;type=text/x-', $file->getCurlValue()); + } else { + $c = $file->getCurlValue(); + $this->assertEquals(__FILE__, $c->getFilename()); + $this->assertEquals('PostFileTest.php', $c->getPostFilename()); + $this->assertContains('text/x-', $c->getMimeType()); + } + } + + public function testReturnsCurlValueStringAndPostname() + { + $file = new PostFile('foo', __FILE__, null, 'NewPostFileTest.php'); + if (version_compare(phpversion(), '5.5.0', '<')) { + $this->assertContains('@' . __FILE__ . ';filename=NewPostFileTest.php;type=text/x-', $file->getCurlValue()); + } else { + $c = $file->getCurlValue(); + $this->assertEquals(__FILE__, $c->getFilename()); + $this->assertEquals('NewPostFileTest.php', $c->getPostFilename()); + $this->assertContains('text/x-', $c->getMimeType()); + } + } + + public function testContentDispositionFilePathIsStripped() + { + $this->getServer()->flush(); + $client = new Client($this->getServer()->getUrl()); + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n"); + $request = $client->post()->addPostFile('file', __FILE__); + $request->send(); + $requests = $this->getServer()->getReceivedRequests(false); + $this->assertContains('POST / HTTP/1.1', $requests[0]); + $this->assertContains('Content-Disposition: form-data; name="file"; filename="PostFileTest.php"', $requests[0]); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/RequestFactoryTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/RequestFactoryTest.php new file mode 100644 index 0000000..f91bc84 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/RequestFactoryTest.php @@ -0,0 +1,616 @@ +assertSame($factory, RequestFactory::getInstance()); + } + + public function testCreatesNewGetRequests() + { + $request = RequestFactory::getInstance()->create('GET', 'http://www.google.com/'); + $this->assertInstanceOf('Guzzle\\Http\\Message\\MessageInterface', $request); + $this->assertInstanceOf('Guzzle\\Http\\Message\\RequestInterface', $request); + $this->assertInstanceOf('Guzzle\\Http\\Message\\Request', $request); + $this->assertEquals('GET', $request->getMethod()); + $this->assertEquals('http', $request->getScheme()); + $this->assertEquals('http://www.google.com/', $request->getUrl()); + $this->assertEquals('www.google.com', $request->getHost()); + $this->assertEquals('/', $request->getPath()); + $this->assertEquals('/', $request->getResource()); + + // Create a GET request with a custom receiving body + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n"); + $b = EntityBody::factory(); + $request = RequestFactory::getInstance()->create('GET', $this->getServer()->getUrl(), null, $b); + $request->setClient(new Client()); + $response = $request->send(); + $this->assertSame($b, $response->getBody()); + } + + public function testCreatesPutRequests() + { + // Test using a string + $request = RequestFactory::getInstance()->create('PUT', 'http://www.google.com/path?q=1&v=2', null, 'Data'); + $this->assertInstanceOf('Guzzle\\Http\\Message\\EntityEnclosingRequest', $request); + $this->assertEquals('PUT', $request->getMethod()); + $this->assertEquals('http', $request->getScheme()); + $this->assertEquals('http://www.google.com/path?q=1&v=2', $request->getUrl()); + $this->assertEquals('www.google.com', $request->getHost()); + $this->assertEquals('/path', $request->getPath()); + $this->assertEquals('/path?q=1&v=2', $request->getResource()); + $this->assertInstanceOf('Guzzle\\Http\\EntityBody', $request->getBody()); + $this->assertEquals('Data', (string) $request->getBody()); + unset($request); + + // Test using an EntityBody + $request = RequestFactory::getInstance()->create('PUT', 'http://www.google.com/path?q=1&v=2', null, EntityBody::factory('Data')); + $this->assertInstanceOf('Guzzle\\Http\\Message\\EntityEnclosingRequest', $request); + $this->assertEquals('Data', (string) $request->getBody()); + + // Test using a resource + $resource = fopen('php://temp', 'w+'); + fwrite($resource, 'Data'); + $request = RequestFactory::getInstance()->create('PUT', 'http://www.google.com/path?q=1&v=2', null, $resource); + $this->assertInstanceOf('Guzzle\\Http\\Message\\EntityEnclosingRequest', $request); + $this->assertEquals('Data', (string) $request->getBody()); + + // Test using an object that can be cast as a string + $request = RequestFactory::getInstance()->create('PUT', 'http://www.google.com/path?q=1&v=2', null, Url::factory('http://www.example.com/')); + $this->assertInstanceOf('Guzzle\\Http\\Message\\EntityEnclosingRequest', $request); + $this->assertEquals('http://www.example.com/', (string) $request->getBody()); + } + + public function testCreatesHeadAndDeleteRequests() + { + $request = RequestFactory::getInstance()->create('DELETE', 'http://www.test.com/'); + $this->assertEquals('DELETE', $request->getMethod()); + $request = RequestFactory::getInstance()->create('HEAD', 'http://www.test.com/'); + $this->assertEquals('HEAD', $request->getMethod()); + } + + public function testCreatesOptionsRequests() + { + $request = RequestFactory::getInstance()->create('OPTIONS', 'http://www.example.com/'); + $this->assertEquals('OPTIONS', $request->getMethod()); + $this->assertInstanceOf('Guzzle\\Http\\Message\\Request', $request); + } + + public function testCreatesNewPutRequestWithBody() + { + $request = RequestFactory::getInstance()->create('PUT', 'http://www.google.com/path?q=1&v=2', null, 'Data'); + $this->assertEquals('Data', (string) $request->getBody()); + } + + public function testCreatesNewPostRequestWithFields() + { + // Use an array + $request = RequestFactory::getInstance()->create('POST', 'http://www.google.com/path?q=1&v=2', null, array( + 'a' => 'b' + )); + $this->assertEquals(array('a' => 'b'), $request->getPostFields()->getAll()); + unset($request); + + // Use a collection + $request = RequestFactory::getInstance()->create('POST', 'http://www.google.com/path?q=1&v=2', null, new Collection(array( + 'a' => 'b' + ))); + $this->assertEquals(array('a' => 'b'), $request->getPostFields()->getAll()); + + // Use a QueryString + $request = RequestFactory::getInstance()->create('POST', 'http://www.google.com/path?q=1&v=2', null, new QueryString(array( + 'a' => 'b' + ))); + $this->assertEquals(array('a' => 'b'), $request->getPostFields()->getAll()); + + $request = RequestFactory::getInstance()->create('POST', 'http://www.test.com/', null, array( + 'a' => 'b', + 'file' => '@' . __FILE__ + )); + + $this->assertEquals(array( + 'a' => 'b' + ), $request->getPostFields()->getAll()); + + $files = $request->getPostFiles(); + $this->assertInstanceOf('Guzzle\Http\Message\PostFile', $files['file'][0]); + } + + public function testCreatesFromParts() + { + $parts = parse_url('http://michael:123@www.google.com:8080/path?q=1&v=2'); + + $request = RequestFactory::getInstance()->fromParts('PUT', $parts, null, 'Data'); + $this->assertInstanceOf('Guzzle\\Http\\Message\\EntityEnclosingRequest', $request); + $this->assertEquals('PUT', $request->getMethod()); + $this->assertEquals('http', $request->getScheme()); + $this->assertEquals('http://www.google.com:8080/path?q=1&v=2', $request->getUrl()); + $this->assertEquals('www.google.com', $request->getHost()); + $this->assertEquals('www.google.com:8080', $request->getHeader('Host')); + $this->assertEquals('/path', $request->getPath()); + $this->assertEquals('/path?q=1&v=2', $request->getResource()); + $this->assertInstanceOf('Guzzle\\Http\\EntityBody', $request->getBody()); + $this->assertEquals('Data', (string) $request->getBody()); + $this->assertEquals('michael', $request->getUsername()); + $this->assertEquals('123', $request->getPassword()); + $this->assertEquals('8080', $request->getPort()); + $this->assertEquals(array( + 'scheme' => 'http', + 'host' => 'www.google.com', + 'port' => 8080, + 'path' => '/path', + 'query' => 'q=1&v=2', + ), parse_url($request->getUrl())); + } + + public function testCreatesFromMessage() + { + $auth = base64_encode('michael:123'); + $message = "PUT /path?q=1&v=2 HTTP/1.1\r\nHost: www.google.com:8080\r\nContent-Length: 4\r\nAuthorization: Basic {$auth}\r\n\r\nData"; + $request = RequestFactory::getInstance()->fromMessage($message); + $this->assertInstanceOf('Guzzle\\Http\\Message\\EntityEnclosingRequest', $request); + $this->assertEquals('PUT', $request->getMethod()); + $this->assertEquals('http', $request->getScheme()); + $this->assertEquals('http://www.google.com:8080/path?q=1&v=2', $request->getUrl()); + $this->assertEquals('www.google.com', $request->getHost()); + $this->assertEquals('www.google.com:8080', $request->getHeader('Host')); + $this->assertEquals('/path', $request->getPath()); + $this->assertEquals('/path?q=1&v=2', $request->getResource()); + $this->assertInstanceOf('Guzzle\\Http\\EntityBody', $request->getBody()); + $this->assertEquals('Data', (string) $request->getBody()); + $this->assertEquals("Basic {$auth}", (string) $request->getHeader('Authorization')); + $this->assertEquals('8080', $request->getPort()); + + // Test passing a blank message returns false + $this->assertFalse($request = RequestFactory::getInstance()->fromMessage('')); + + // Test passing a url with no port + $message = "PUT /path?q=1&v=2 HTTP/1.1\r\nHost: www.google.com\r\nContent-Length: 4\r\nAuthorization: Basic {$auth}\r\n\r\nData"; + $request = RequestFactory::getInstance()->fromMessage($message); + $this->assertInstanceOf('Guzzle\\Http\\Message\\EntityEnclosingRequest', $request); + $this->assertEquals('PUT', $request->getMethod()); + $this->assertEquals('http', $request->getScheme()); + $this->assertEquals('http://www.google.com/path?q=1&v=2', $request->getUrl()); + $this->assertEquals('www.google.com', $request->getHost()); + $this->assertEquals('/path', $request->getPath()); + $this->assertEquals('/path?q=1&v=2', $request->getResource()); + $this->assertInstanceOf('Guzzle\\Http\\EntityBody', $request->getBody()); + $this->assertEquals('Data', (string) $request->getBody()); + $this->assertEquals("Basic {$auth}", (string) $request->getHeader('Authorization')); + $this->assertEquals(80, $request->getPort()); + } + + public function testCreatesNewTraceRequest() + { + $request = RequestFactory::getInstance()->create('TRACE', 'http://www.google.com/'); + $this->assertFalse($request instanceof \Guzzle\Http\Message\EntityEnclosingRequest); + $this->assertEquals('TRACE', $request->getMethod()); + } + + public function testCreatesProperTransferEncodingRequests() + { + $request = RequestFactory::getInstance()->create('PUT', 'http://www.google.com/', array( + 'Transfer-Encoding' => 'chunked' + ), 'hello'); + $this->assertEquals('chunked', $request->getHeader('Transfer-Encoding')); + $this->assertFalse($request->hasHeader('Content-Length')); + } + + public function testProperlyDealsWithDuplicateHeaders() + { + $parser = new MessageParser(); + + $message = "POST / http/1.1\r\n" + . "DATE:Mon, 09 Sep 2011 23:36:00 GMT\r\n" + . "host:host.foo.com\r\n" + . "ZOO:abc\r\n" + . "ZOO:123\r\n" + . "ZOO:HI\r\n" + . "zoo:456\r\n\r\n"; + + $parts = $parser->parseRequest($message); + $this->assertEquals(array ( + 'DATE' => 'Mon, 09 Sep 2011 23:36:00 GMT', + 'host' => 'host.foo.com', + 'ZOO' => array('abc', '123', 'HI'), + 'zoo' => '456', + ), $parts['headers']); + + $request = RequestFactory::getInstance()->fromMessage($message); + + $this->assertEquals(array( + 'abc', '123', 'HI', '456' + ), $request->getHeader('zoo')->toArray()); + } + + public function testCreatesHttpMessagesWithBodiesAndNormalizesLineEndings() + { + $message = "POST / http/1.1\r\n" + . "Content-Type:application/x-www-form-urlencoded; charset=utf8\r\n" + . "Date:Mon, 09 Sep 2011 23:36:00 GMT\r\n" + . "Host:host.foo.com\r\n\r\n" + . "foo=bar"; + + $request = RequestFactory::getInstance()->fromMessage($message); + $this->assertEquals('application/x-www-form-urlencoded; charset=utf8', (string) $request->getHeader('Content-Type')); + $this->assertEquals('foo=bar', (string) $request->getBody()); + + $message = "POST / http/1.1\n" + . "Content-Type:application/x-www-form-urlencoded; charset=utf8\n" + . "Date:Mon, 09 Sep 2011 23:36:00 GMT\n" + . "Host:host.foo.com\n\n" + . "foo=bar"; + $request = RequestFactory::getInstance()->fromMessage($message); + $this->assertEquals('foo=bar', (string) $request->getBody()); + + $message = "PUT / HTTP/1.1\r\nContent-Length: 0\r\n\r\n"; + $request = RequestFactory::getInstance()->fromMessage($message); + $this->assertTrue($request->hasHeader('Content-Length')); + $this->assertEquals(0, (string) $request->getHeader('Content-Length')); + } + + public function testBugPathIncorrectlyHandled() + { + $message = "POST /foo\r\n\r\nBODY"; + $request = RequestFactory::getInstance()->fromMessage($message); + $this->assertSame('POST', $request->getMethod()); + $this->assertSame('/foo', $request->getPath()); + $this->assertSame('BODY', (string) $request->getBody()); + } + + public function testHandlesChunkedTransferEncoding() + { + $request = RequestFactory::getInstance()->create('PUT', 'http://www.foo.com/', array( + 'Transfer-Encoding' => 'chunked' + ), 'Test'); + $this->assertFalse($request->hasHeader('Content-Length')); + $this->assertEquals('chunked', $request->getHeader('Transfer-Encoding')); + + $request = RequestFactory::getInstance()->create('POST', 'http://www.foo.com/', array( + 'transfer-encoding' => 'chunked' + ), array( + 'foo' => 'bar' + )); + + $this->assertFalse($request->hasHeader('Content-Length')); + $this->assertEquals('chunked', $request->getHeader('Transfer-Encoding')); + } + + public function testClonesRequestsWithMethodWithoutClient() + { + $f = RequestFactory::getInstance(); + $request = $f->create('GET', 'http://www.test.com', array('X-Foo' => 'Bar')); + $request->getParams()->replace(array('test' => '123')); + $request->getCurlOptions()->set('foo', 'bar'); + $cloned = $f->cloneRequestWithMethod($request, 'PUT'); + $this->assertEquals('PUT', $cloned->getMethod()); + $this->assertEquals('Bar', (string) $cloned->getHeader('X-Foo')); + $this->assertEquals('http://www.test.com', $cloned->getUrl()); + // Ensure params are cloned and cleaned up + $this->assertEquals(1, count($cloned->getParams()->getAll())); + $this->assertEquals('123', $cloned->getParams()->get('test')); + // Ensure curl options are cloned + $this->assertEquals('bar', $cloned->getCurlOptions()->get('foo')); + // Ensure event dispatcher is cloned + $this->assertNotSame($request->getEventDispatcher(), $cloned->getEventDispatcher()); + } + + public function testClonesRequestsWithMethodWithClient() + { + $f = RequestFactory::getInstance(); + $client = new Client(); + $request = $client->put('http://www.test.com', array('Content-Length' => 4), 'test'); + $cloned = $f->cloneRequestWithMethod($request, 'GET'); + $this->assertEquals('GET', $cloned->getMethod()); + $this->assertNull($cloned->getHeader('Content-Length')); + $this->assertEquals('http://www.test.com', $cloned->getUrl()); + $this->assertSame($request->getClient(), $cloned->getClient()); + } + + public function testClonesRequestsWithMethodWithClientWithEntityEnclosingChange() + { + $f = RequestFactory::getInstance(); + $client = new Client(); + $request = $client->put('http://www.test.com', array('Content-Length' => 4), 'test'); + $cloned = $f->cloneRequestWithMethod($request, 'POST'); + $this->assertEquals('POST', $cloned->getMethod()); + $this->assertEquals('test', (string) $cloned->getBody()); + } + + public function testCanDisableRedirects() + { + $this->getServer()->enqueue(array( + "HTTP/1.1 307\r\nLocation: " . $this->getServer()->getUrl() . "\r\nContent-Length: 0\r\n\r\n" + )); + $client = new Client($this->getServer()->getUrl()); + $response = $client->get('/', array(), array('allow_redirects' => false))->send(); + $this->assertEquals(307, $response->getStatusCode()); + } + + public function testCanAddCookies() + { + $client = new Client($this->getServer()->getUrl()); + $request = $client->get('/', array(), array('cookies' => array('Foo' => 'Bar'))); + $this->assertEquals('Bar', $request->getCookie('Foo')); + } + + public function testCanAddQueryString() + { + $request = RequestFactory::getInstance()->create('GET', 'http://foo.com', array(), null, array( + 'query' => array('Foo' => 'Bar') + )); + $this->assertEquals('Bar', $request->getQuery()->get('Foo')); + } + + public function testCanSetDefaultQueryString() + { + $request = new Request('GET', 'http://www.foo.com?test=abc'); + RequestFactory::getInstance()->applyOptions($request, array( + 'query' => array('test' => '123', 'other' => 't123') + ), RequestFactory::OPTIONS_AS_DEFAULTS); + $this->assertEquals('abc', $request->getQuery()->get('test')); + $this->assertEquals('t123', $request->getQuery()->get('other')); + } + + public function testCanAddBasicAuth() + { + $request = RequestFactory::getInstance()->create('GET', 'http://foo.com', array(), null, array( + 'auth' => array('michael', 'test') + )); + $this->assertEquals('michael', $request->getUsername()); + $this->assertEquals('test', $request->getPassword()); + } + + public function testCanAddDigestAuth() + { + $request = RequestFactory::getInstance()->create('GET', 'http://foo.com', array(), null, array( + 'auth' => array('michael', 'test', 'digest') + )); + $this->assertEquals(CURLAUTH_DIGEST, $request->getCurlOptions()->get(CURLOPT_HTTPAUTH)); + $this->assertEquals('michael', $request->getUsername()); + $this->assertEquals('test', $request->getPassword()); + } + + public function testCanAddEvents() + { + $foo = null; + $client = new Client(); + $client->addSubscriber(new MockPlugin(array(new Response(200)))); + $request = $client->get($this->getServer()->getUrl(), array(), array( + 'events' => array( + 'request.before_send' => function () use (&$foo) { $foo = true; } + ) + )); + $request->send(); + $this->assertTrue($foo); + } + + public function testCanAddEventsWithPriority() + { + $foo = null; + $client = new Client(); + $client->addSubscriber(new MockPlugin(array(new Response(200)))); + $request = $client->get($this->getServer()->getUrl(), array(), array( + 'events' => array( + 'request.before_send' => array(function () use (&$foo) { $foo = true; }, 100) + ) + )); + $request->send(); + $this->assertTrue($foo); + } + + public function testCanAddPlugins() + { + $mock = new MockPlugin(array( + new Response(200), + new Response(200) + )); + $client = new Client(); + $client->addSubscriber($mock); + $request = $client->get('/', array(), array( + 'plugins' => array($mock) + )); + $request->send(); + } + + public function testCanDisableExceptions() + { + $client = new Client(); + $request = $client->get('/', array(), array( + 'plugins' => array(new MockPlugin(array(new Response(500)))), + 'exceptions' => false + )); + $this->assertEquals(500, $request->send()->getStatusCode()); + } + + public function testCanDisableExceptionsWithErrorListener() + { + $client = new Client(); + $client->getEventDispatcher()->addListener('request.error', function () {}); + $request = $client->get('/', array(), array( + 'plugins' => array(new MockPlugin(array(new Response(500)))), + 'exceptions' => false + )); + $this->assertEquals(500, $request->send()->getStatusCode()); + } + + public function testCanChangeSaveToLocation() + { + $r = EntityBody::factory(); + $client = new Client(); + $request = $client->get('/', array(), array( + 'plugins' => array(new MockPlugin(array(new Response(200, array(), 'testing')))), + 'save_to' => $r + )); + $request->send(); + $this->assertEquals('testing', (string) $r); + } + + public function testCanSetProxy() + { + $client = new Client(); + $request = $client->get('/', array(), array('proxy' => '192.168.16.121')); + $this->assertEquals('192.168.16.121', $request->getCurlOptions()->get(CURLOPT_PROXY)); + } + + public function testCanSetHeadersOption() + { + $client = new Client(); + $request = $client->get('/', array(), array('headers' => array('Foo' => 'Bar'))); + $this->assertEquals('Bar', (string) $request->getHeader('Foo')); + } + + public function testCanSetDefaultHeadersOptions() + { + $request = new Request('GET', 'http://www.foo.com', array('Foo' => 'Bar')); + RequestFactory::getInstance()->applyOptions($request, array( + 'headers' => array('Foo' => 'Baz', 'Bam' => 't123') + ), RequestFactory::OPTIONS_AS_DEFAULTS); + $this->assertEquals('Bar', (string) $request->getHeader('Foo')); + $this->assertEquals('t123', (string) $request->getHeader('Bam')); + } + + public function testCanSetBodyOption() + { + $client = new Client(); + $request = $client->put('/', array(), null, array('body' => 'test')); + $this->assertEquals('test', (string) $request->getBody()); + } + + /** + * @expectedException \InvalidArgumentException + */ + public function testValidatesBodyOption() + { + $client = new Client(); + $client->get('/', array(), array('body' => 'test')); + } + + public function testCanSetTimeoutOption() + { + $client = new Client(); + $request = $client->get('/', array(), array('timeout' => 1.5)); + $this->assertEquals(1500, $request->getCurlOptions()->get(CURLOPT_TIMEOUT_MS)); + } + + public function testCanSetConnectTimeoutOption() + { + $client = new Client(); + $request = $client->get('/', array(), array('connect_timeout' => 1.5)); + $this->assertEquals(1500, $request->getCurlOptions()->get(CURLOPT_CONNECTTIMEOUT_MS)); + } + + public function testCanSetDebug() + { + $client = new Client(); + $request = $client->get('/', array(), array('debug' => true)); + $this->assertTrue($request->getCurlOptions()->get(CURLOPT_VERBOSE)); + } + + public function testCanSetVerifyToOff() + { + $client = new Client(); + $request = $client->get('/', array(), array('verify' => false)); + $this->assertNull($request->getCurlOptions()->get(CURLOPT_CAINFO)); + $this->assertSame(0, $request->getCurlOptions()->get(CURLOPT_SSL_VERIFYHOST)); + $this->assertFalse($request->getCurlOptions()->get(CURLOPT_SSL_VERIFYPEER)); + } + + public function testCanSetVerifyToOn() + { + $client = new Client(); + $request = $client->get('/', array(), array('verify' => true)); + $this->assertNotNull($request->getCurlOptions()->get(CURLOPT_CAINFO)); + $this->assertSame(2, $request->getCurlOptions()->get(CURLOPT_SSL_VERIFYHOST)); + $this->assertTrue($request->getCurlOptions()->get(CURLOPT_SSL_VERIFYPEER)); + } + + public function testCanSetVerifyToPath() + { + $client = new Client(); + $request = $client->get('/', array(), array('verify' => '/foo.pem')); + $this->assertEquals('/foo.pem', $request->getCurlOptions()->get(CURLOPT_CAINFO)); + $this->assertSame(2, $request->getCurlOptions()->get(CURLOPT_SSL_VERIFYHOST)); + $this->assertTrue($request->getCurlOptions()->get(CURLOPT_SSL_VERIFYPEER)); + } + + public function inputValidation() + { + return array_map(function ($option) { return array($option); }, array( + 'headers', 'query', 'cookies', 'auth', 'events', 'plugins', 'params' + )); + } + + /** + * @dataProvider inputValidation + * @expectedException \Guzzle\Common\Exception\InvalidArgumentException + */ + public function testValidatesInput($option) + { + $client = new Client(); + $client->get('/', array(), array($option => 'foo')); + } + + public function testCanAddRequestParams() + { + $client = new Client(); + $request = $client->put('/', array(), null, array('params' => array('foo' => 'test'))); + $this->assertEquals('test', $request->getParams()->get('foo')); + } + + public function testCanAddSslKey() + { + $client = new Client(); + $request = $client->get('/', array(), array('ssl_key' => '/foo.pem')); + $this->assertEquals('/foo.pem', $request->getCurlOptions()->get(CURLOPT_SSLKEY)); + } + + public function testCanAddSslKeyPassword() + { + $client = new Client(); + $request = $client->get('/', array(), array('ssl_key' => array('/foo.pem', 'bar'))); + $this->assertEquals('/foo.pem', $request->getCurlOptions()->get(CURLOPT_SSLKEY)); + $this->assertEquals('bar', $request->getCurlOptions()->get(CURLOPT_SSLKEYPASSWD)); + } + + public function testCanAddSslCert() + { + $client = new Client(); + $request = $client->get('/', array(), array('cert' => '/foo.pem')); + $this->assertEquals('/foo.pem', $request->getCurlOptions()->get(CURLOPT_SSLCERT)); + } + + public function testCanAddSslCertPassword() + { + $client = new Client(); + $request = $client->get('/', array(), array('cert' => array('/foo.pem', 'bar'))); + $this->assertEquals('/foo.pem', $request->getCurlOptions()->get(CURLOPT_SSLCERT)); + $this->assertEquals('bar', $request->getCurlOptions()->get(CURLOPT_SSLCERTPASSWD)); + } + + public function testCreatesBodyWithoutZeroString() + { + $request = RequestFactory::getInstance()->create('PUT', 'http://test.com', array(), '0'); + $this->assertSame('0', (string) $request->getBody()); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/RequestTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/RequestTest.php new file mode 100644 index 0000000..5bf6248 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/RequestTest.php @@ -0,0 +1,639 @@ +client = new Client($this->getServer()->getUrl()); + $this->request = $this->client->get(); + } + + public function tearDown() + { + unset($this->request); + unset($this->client); + } + + public function testConstructorBuildsRequestWithArrayHeaders() + { + // Test passing an array of headers + $request = new Request('GET', 'http://www.guzzle-project.com/', array( + 'foo' => 'bar' + )); + + $this->assertEquals('GET', $request->getMethod()); + $this->assertEquals('http://www.guzzle-project.com/', $request->getUrl()); + $this->assertEquals('bar', $request->getHeader('foo')); + } + + public function testDescribesEvents() + { + $this->assertInternalType('array', Request::getAllEvents()); + } + + public function testConstructorBuildsRequestWithCollectionHeaders() + { + $request = new Request('GET', 'http://www.guzzle-project.com/', new Collection(array( + 'foo' => 'bar' + ))); + $this->assertEquals('bar', $request->getHeader('foo')); + } + + public function testConstructorBuildsRequestWithNoHeaders() + { + $request = new Request('GET', 'http://www.guzzle-project.com/', null); + $this->assertFalse($request->hasHeader('foo')); + } + + public function testConstructorHandlesNonBasicAuth() + { + $request = new Request('GET', 'http://www.guzzle-project.com/', array( + 'Authorization' => 'Foo bar' + )); + $this->assertNull($request->getUserName()); + $this->assertNull($request->getPassword()); + $this->assertEquals('Foo bar', (string) $request->getHeader('Authorization')); + } + + public function testRequestsCanBeConvertedToRawMessageStrings() + { + $auth = base64_encode('michael:123'); + $message = "PUT /path?q=1&v=2 HTTP/1.1\r\n" + . "Host: www.google.com\r\n" + . "Authorization: Basic {$auth}\r\n" + . "Content-Length: 4\r\n\r\nData"; + + $request = RequestFactory::getInstance()->create('PUT', 'http://www.google.com/path?q=1&v=2', array( + 'Authorization' => 'Basic ' . $auth + ), 'Data'); + + $this->assertEquals($message, $request->__toString()); + } + + /** + * Add authorization after the fact and see that it was put in the message + */ + public function testRequestStringsIncludeAuth() + { + $auth = base64_encode('michael:123'); + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n"); + $request = RequestFactory::getInstance()->create('PUT', $this->getServer()->getUrl(), null, 'Data') + ->setClient($this->client) + ->setAuth('michael', '123', CURLAUTH_BASIC); + $request->send(); + + $this->assertContains('Authorization: Basic ' . $auth, (string) $request); + } + + public function testGetEventDispatcher() + { + $d = $this->request->getEventDispatcher(); + $this->assertInstanceOf('Symfony\\Component\\EventDispatcher\\EventDispatcherInterface', $d); + $this->assertEquals($d, $this->request->getEventDispatcher()); + } + + public function testRequestsManageClients() + { + $request = new Request('GET', 'http://test.com'); + $this->assertNull($request->getClient()); + $request->setClient($this->client); + $this->assertSame($this->client, $request->getClient()); + } + + /** + * @expectedException \RuntimeException + * @expectedExceptionMessage A client must be set on the request + */ + public function testRequestsRequireClients() + { + $request = new Request('GET', 'http://test.com'); + $request->send(); + } + + public function testSend() + { + $response = new Response(200, array( + 'Content-Length' => 3 + ), 'abc'); + $this->request->setResponse($response, true); + $r = $this->request->send(); + + $this->assertSame($response, $r); + $this->assertInstanceOf('Guzzle\\Http\\Message\\Response', $this->request->getResponse()); + $this->assertSame($r, $this->request->getResponse()); + $this->assertEquals('complete', $this->request->getState()); + } + + public function testGetResponse() + { + $this->assertNull($this->request->getResponse()); + $response = new Response(200, array('Content-Length' => 3), 'abc'); + + $this->request->setResponse($response); + $this->assertEquals($response, $this->request->getResponse()); + + $client = new Client('http://www.google.com'); + $request = $client->get('http://www.google.com/'); + $request->setResponse($response, true); + $request->send(); + $requestResponse = $request->getResponse(); + $this->assertSame($response, $requestResponse); + + // Try again, making sure it's still the same response + $this->assertSame($requestResponse, $request->getResponse()); + + $response = new Response(204); + $request = $client->get(); + $request->setResponse($response, true); + $request->send(); + $requestResponse = $request->getResponse(); + $this->assertSame($response, $requestResponse); + $this->assertInstanceOf('Guzzle\\Http\\EntityBody', $response->getBody()); + } + + public function testRequestThrowsExceptionOnBadResponse() + { + try { + $this->request->setResponse(new Response(404, array('Content-Length' => 3), 'abc'), true); + $this->request->send(); + $this->fail('Expected exception not thrown'); + } catch (BadResponseException $e) { + $this->assertInstanceOf('Guzzle\\Http\\Message\\RequestInterface', $e->getRequest()); + $this->assertInstanceOf('Guzzle\\Http\\Message\\Response', $e->getResponse()); + $this->assertContains('Client error response', $e->getMessage()); + } + } + + public function testManagesQuery() + { + $this->assertInstanceOf('Guzzle\\Http\\QueryString', $this->request->getQuery()); + $this->request->getQuery()->set('test', '123'); + $this->assertEquals('test=123', $this->request->getQuery(true)); + } + + public function testRequestHasMethod() + { + $this->assertEquals('GET', $this->request->getMethod()); + } + + public function testRequestHasScheme() + { + $this->assertEquals('http', $this->request->getScheme()); + $this->assertEquals($this->request, $this->request->setScheme('https')); + $this->assertEquals('https', $this->request->getScheme()); + } + + public function testRequestHasHost() + { + $this->assertEquals('127.0.0.1', $this->request->getHost()); + $this->assertEquals('127.0.0.1:8124', (string) $this->request->getHeader('Host')); + + $this->assertSame($this->request, $this->request->setHost('www2.google.com')); + $this->assertEquals('www2.google.com', $this->request->getHost()); + $this->assertEquals('www2.google.com:8124', (string) $this->request->getHeader('Host')); + + $this->assertSame($this->request, $this->request->setHost('www.test.com:8081')); + $this->assertEquals('www.test.com', $this->request->getHost()); + $this->assertEquals(8081, $this->request->getPort()); + } + + public function testRequestHasProtocol() + { + $this->assertEquals('1.1', $this->request->getProtocolVersion()); + $this->assertEquals($this->request, $this->request->setProtocolVersion('1.1')); + $this->assertEquals('1.1', $this->request->getProtocolVersion()); + $this->assertEquals($this->request, $this->request->setProtocolVersion('1.0')); + $this->assertEquals('1.0', $this->request->getProtocolVersion()); + } + + public function testRequestHasPath() + { + $this->assertEquals('/', $this->request->getPath()); + $this->assertEquals($this->request, $this->request->setPath('/index.html')); + $this->assertEquals('/index.html', $this->request->getPath()); + $this->assertEquals($this->request, $this->request->setPath('index.html')); + $this->assertEquals('/index.html', $this->request->getPath()); + } + + public function testPermitsFalsyComponents() + { + $request = new Request('GET', 'http://0/0?0'); + $this->assertSame('0', $request->getHost()); + $this->assertSame('/0', $request->getPath()); + $this->assertSame('0', $request->getQuery(true)); + + $request = new Request('GET', '0'); + $this->assertEquals('/0', $request->getPath()); + } + + public function testRequestHasPort() + { + $this->assertEquals(8124, $this->request->getPort()); + $this->assertEquals('127.0.0.1:8124', $this->request->getHeader('Host')); + + $this->assertEquals($this->request, $this->request->setPort('8080')); + $this->assertEquals('8080', $this->request->getPort()); + $this->assertEquals('127.0.0.1:8080', $this->request->getHeader('Host')); + + $this->request->setPort(80); + $this->assertEquals('127.0.0.1', $this->request->getHeader('Host')); + } + + public function testRequestHandlesAuthorization() + { + // Uninitialized auth + $this->assertEquals(null, $this->request->getUsername()); + $this->assertEquals(null, $this->request->getPassword()); + + // Set an auth + $this->assertSame($this->request, $this->request->setAuth('michael', '123')); + $this->assertEquals('michael', $this->request->getUsername()); + $this->assertEquals('123', $this->request->getPassword()); + + // Set an auth with blank password + $this->assertSame($this->request, $this->request->setAuth('michael', '')); + $this->assertEquals('michael', $this->request->getUsername()); + $this->assertEquals('', $this->request->getPassword()); + + // Remove the auth + $this->request->setAuth(false); + $this->assertEquals(null, $this->request->getUsername()); + $this->assertEquals(null, $this->request->getPassword()); + + // Make sure that the cURL based auth works too + $request = new Request('GET', $this->getServer()->getUrl()); + $request->setAuth('michael', 'password', CURLAUTH_DIGEST); + $this->assertEquals('michael:password', $request->getCurlOptions()->get(CURLOPT_USERPWD)); + $this->assertEquals(CURLAUTH_DIGEST, $request->getCurlOptions()->get(CURLOPT_HTTPAUTH)); + } + + /** + * @expectedException \Guzzle\Common\Exception\InvalidArgumentException + */ + public function testValidatesAuth() + { + $this->request->setAuth('foo', 'bar', 'bam'); + } + + public function testGetResourceUri() + { + $this->assertEquals('/', $this->request->getResource()); + $this->request->setPath('/index.html'); + $this->assertEquals('/index.html', $this->request->getResource()); + $this->request->getQuery()->add('v', '1'); + $this->assertEquals('/index.html?v=1', $this->request->getResource()); + } + + public function testRequestHasMutableUrl() + { + $url = 'http://www.test.com:8081/path?q=123#fragment'; + $u = Url::factory($url); + $this->assertSame($this->request, $this->request->setUrl($url)); + $this->assertEquals($url, $this->request->getUrl()); + + $this->assertSame($this->request, $this->request->setUrl($u)); + $this->assertEquals($url, $this->request->getUrl()); + } + + public function testRequestHasState() + { + $this->assertEquals(RequestInterface::STATE_NEW, $this->request->getState()); + $this->request->setState(RequestInterface::STATE_TRANSFER); + $this->assertEquals(RequestInterface::STATE_TRANSFER, $this->request->getState()); + } + + public function testSetManualResponse() + { + $response = new Response(200, array( + 'Date' => 'Sat, 16 Oct 2010 17:27:14 GMT', + 'Expires' => '-1', + 'Cache-Control' => 'private, max-age=0', + 'Content-Type' => 'text/html; charset=ISO-8859-1', + ), 'response body'); + + $this->assertSame($this->request, $this->request->setResponse($response), '-> setResponse() must use a fluent interface'); + $this->assertEquals('complete', $this->request->getState(), '-> setResponse() must change the state of the request to complete'); + $this->assertSame($response, $this->request->getResponse(), '-> setResponse() must set the exact same response that was passed in to it'); + } + + public function testRequestCanHaveManuallySetResponseBody() + { + $file = __DIR__ . '/../../TestData/temp.out'; + if (file_exists($file)) { + unlink($file); + } + + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 4\r\n\r\ndata"); + $request = RequestFactory::getInstance()->create('GET', $this->getServer()->getUrl()); + $request->setClient($this->client); + $entityBody = EntityBody::factory(fopen($file, 'w+')); + $request->setResponseBody($entityBody); + $response = $request->send(); + $this->assertSame($entityBody, $response->getBody()); + + $this->assertTrue(file_exists($file)); + $this->assertEquals('data', file_get_contents($file)); + unlink($file); + + $this->assertEquals('data', $response->getBody(true)); + } + + public function testHoldsCookies() + { + $this->assertNull($this->request->getCookie('test')); + + // Set a cookie + $this->assertSame($this->request, $this->request->addCookie('test', 'abc')); + $this->assertEquals('abc', $this->request->getCookie('test')); + + // Multiple cookies by setting the Cookie header + $this->request->setHeader('Cookie', '__utma=1.638370270.1344367610.1374365610.1944450276.2; __utmz=1.1346368610.1.1.utmcsr=(direct)|utmccn=(direct)|utmcmd=(none); hl=de; PHPSESSID=ak93pqashi5uubuoq8fjv60897'); + $this->assertEquals('1.638370270.1344367610.1374365610.1944450276.2', $this->request->getCookie('__utma')); + $this->assertEquals('1.1346368610.1.1.utmcsr=(direct)|utmccn=(direct)|utmcmd=(none)', $this->request->getCookie('__utmz')); + $this->assertEquals('de', $this->request->getCookie('hl')); + $this->assertEquals('ak93pqashi5uubuoq8fjv60897', $this->request->getCookie('PHPSESSID')); + + // Unset the cookies by setting the Cookie header to null + $this->request->setHeader('Cookie', null); + $this->assertNull($this->request->getCookie('test')); + $this->request->removeHeader('Cookie'); + + // Set and remove a cookie + $this->assertSame($this->request, $this->request->addCookie('test', 'abc')); + $this->assertEquals('abc', $this->request->getCookie('test')); + $this->assertSame($this->request, $this->request->removeCookie('test')); + $this->assertNull($this->request->getCookie('test')); + + // Remove the cookie header + $this->assertSame($this->request, $this->request->addCookie('test', 'abc')); + $this->request->removeHeader('Cookie'); + $this->assertEquals('', (string) $this->request->getHeader('Cookie')); + + // Remove a cookie value + $this->request->addCookie('foo', 'bar')->addCookie('baz', 'boo'); + $this->request->removeCookie('foo'); + $this->assertEquals(array( + 'baz' => 'boo' + ), $this->request->getCookies()); + + $this->request->addCookie('foo', 'bar'); + $this->assertEquals('baz=boo; foo=bar', (string) $this->request->getHeader('Cookie')); + } + + /** + * @expectedException \Guzzle\Http\Exception\RequestException + * @expectedExceptionMessage Error completing request + */ + public function testRequestThrowsExceptionWhenSetToCompleteWithNoResponse() + { + $this->request->setState(RequestInterface::STATE_COMPLETE); + } + + public function testClonedRequestsUseNewInternalState() + { + $p = new AsyncPlugin(); + $this->request->getEventDispatcher()->addSubscriber($p); + $h = $this->request->getHeader('Host'); + + $r = clone $this->request; + $this->assertEquals(RequestInterface::STATE_NEW, $r->getState()); + $this->assertNotSame($r->getQuery(), $this->request->getQuery()); + $this->assertNotSame($r->getCurlOptions(), $this->request->getCurlOptions()); + $this->assertNotSame($r->getEventDispatcher(), $this->request->getEventDispatcher()); + $this->assertEquals($r->getHeaders(), $this->request->getHeaders()); + $this->assertNotSame($h, $r->getHeader('Host')); + $this->assertNotSame($r->getParams(), $this->request->getParams()); + $this->assertTrue($this->request->getEventDispatcher()->hasListeners('request.sent')); + } + + public function testRecognizesBasicAuthCredentialsInUrls() + { + $this->request->setUrl('http://michael:test@test.com/'); + $this->assertEquals('michael', $this->request->getUsername()); + $this->assertEquals('test', $this->request->getPassword()); + } + + public function testRequestCanBeSentUsingCurl() + { + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 200 OK\r\nContent-Length: 4\r\nExpires: Thu, 01 Dec 1994 16:00:00 GMT\r\nConnection: close\r\n\r\ndata", + "HTTP/1.1 200 OK\r\nContent-Length: 4\r\nExpires: Thu, 01 Dec 1994 16:00:00 GMT\r\nConnection: close\r\n\r\ndata", + "HTTP/1.1 404 Not Found\r\nContent-Encoding: application/xml\r\nContent-Length: 48\r\n\r\nFile not found" + )); + + $request = RequestFactory::getInstance()->create('GET', $this->getServer()->getUrl()); + $request->setClient($this->client); + $response = $request->send(); + + $this->assertEquals('data', $response->getBody(true)); + $this->assertEquals(200, (int) $response->getStatusCode()); + $this->assertEquals('OK', $response->getReasonPhrase()); + $this->assertEquals(4, $response->getContentLength()); + $this->assertEquals('Thu, 01 Dec 1994 16:00:00 GMT', $response->getExpires()); + + // Test that the same handle can be sent twice without setting state to new + $response2 = $request->send(); + $this->assertNotSame($response, $response2); + + try { + $request = RequestFactory::getInstance()->create('GET', $this->getServer()->getUrl() . 'index.html'); + $request->setClient($this->client); + $response = $request->send(); + $this->fail('Request did not receive a 404 response'); + } catch (BadResponseException $e) { + } + + $requests = $this->getServer()->getReceivedRequests(true); + $messages = $this->getServer()->getReceivedRequests(false); + $port = $this->getServer()->getPort(); + + $userAgent = $this->client->getDefaultUserAgent(); + + $this->assertEquals('127.0.0.1:' . $port, $requests[0]->getHeader('Host')); + $this->assertEquals('127.0.0.1:' . $port, $requests[1]->getHeader('Host')); + $this->assertEquals('127.0.0.1:' . $port, $requests[2]->getHeader('Host')); + + $this->assertEquals('/', $requests[0]->getPath()); + $this->assertEquals('/', $requests[1]->getPath()); + $this->assertEquals('/index.html', $requests[2]->getPath()); + + $parts = explode("\r\n", $messages[0]); + $this->assertEquals('GET / HTTP/1.1', $parts[0]); + + $parts = explode("\r\n", $messages[1]); + $this->assertEquals('GET / HTTP/1.1', $parts[0]); + + $parts = explode("\r\n", $messages[2]); + $this->assertEquals('GET /index.html HTTP/1.1', $parts[0]); + } + + public function testThrowsExceptionsWhenUnsuccessfulResponseIsReceivedByDefault() + { + $this->getServer()->flush(); + $this->getServer()->enqueue("HTTP/1.1 404 Not found\r\nContent-Length: 0\r\n\r\n"); + + try { + $request = $this->client->get('/index.html'); + $response = $request->send(); + $this->fail('Request did not receive a 404 response'); + } catch (BadResponseException $e) { + $this->assertContains('Client error response', $e->getMessage()); + $this->assertContains('[status code] 404', $e->getMessage()); + $this->assertContains('[reason phrase] Not found', $e->getMessage()); + } + } + + public function testCanShortCircuitErrorHandling() + { + $request = $this->request; + $response = new Response(404); + $request->setResponse($response, true); + $out = ''; + $that = $this; + $request->getEventDispatcher()->addListener('request.error', function($event) use (&$out, $that) { + $out .= $event['request'] . "\n" . $event['response'] . "\n"; + $event->stopPropagation(); + }); + $request->send(); + $this->assertContains((string) $request, $out); + $this->assertContains((string) $request->getResponse(), $out); + $this->assertSame($response, $request->getResponse()); + } + + public function testCanOverrideUnsuccessfulResponses() + { + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 404 NOT FOUND\r\n" . + "Content-Length: 0\r\n" . + "\r\n", + "HTTP/1.1 200 OK\r\n" . + "Content-Length: 0\r\n" . + "\r\n" + )); + + $newResponse = null; + + $request = $this->request; + $request->getEventDispatcher()->addListener('request.error', function($event) use (&$newResponse) { + if ($event['response']->getStatusCode() == 404) { + $newRequest = clone $event['request']; + $newResponse = $newRequest->send(); + // Override the original response and bypass additional response processing + $event['response'] = $newResponse; + // Call $event['request']->setResponse($newResponse); to re-apply events + $event->stopPropagation(); + } + }); + + $request->send(); + + $this->assertEquals(200, $request->getResponse()->getStatusCode()); + $this->assertSame($newResponse, $request->getResponse()); + $this->assertEquals(2, count($this->getServer()->getReceivedRequests())); + } + + public function testCanRetrieveUrlObject() + { + $request = new Request('GET', 'http://www.example.com/foo?abc=d'); + $this->assertInstanceOf('Guzzle\Http\Url', $request->getUrl(true)); + $this->assertEquals('http://www.example.com/foo?abc=d', $request->getUrl()); + $this->assertEquals('http://www.example.com/foo?abc=d', (string) $request->getUrl(true)); + } + + public function testUnresolvedRedirectsReturnResponse() + { + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 303 SEE OTHER\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 301 Foo\r\nLocation: /foo\r\nContent-Length: 0\r\n\r\n" + )); + $request = $this->request; + $this->assertEquals(303, $request->send()->getStatusCode()); + $request->getParams()->set(RedirectPlugin::DISABLE, true); + $this->assertEquals(301, $request->send()->getStatusCode()); + } + + public function testCanSendCustomRequests() + { + $this->getServer()->flush(); + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n"); + $request = $this->client->createRequest('PROPFIND', $this->getServer()->getUrl(), array( + 'Content-Type' => 'text/plain' + ), 'foo'); + $response = $request->send(); + $requests = $this->getServer()->getReceivedRequests(true); + $this->assertEquals('PROPFIND', $requests[0]->getMethod()); + $this->assertEquals(3, (string) $requests[0]->getHeader('Content-Length')); + $this->assertEquals('foo', (string) $requests[0]->getBody()); + } + + /** + * @expectedException \PHPUnit_Framework_Error_Warning + */ + public function testEnsuresFileCanBeCreated() + { + $this->getServer()->flush(); + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 4\r\n\r\ntest"); + $this->client->get('/')->setResponseBody('/wefwefefefefwewefwe/wefwefwefefwe/wefwefewfw.txt')->send(); + } + + public function testAllowsFilenameForDownloadingContent() + { + $this->getServer()->flush(); + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 4\r\n\r\ntest"); + $name = sys_get_temp_dir() . '/foo.txt'; + $this->client->get('/')->setResponseBody($name)->send(); + $this->assertEquals('test', file_get_contents($name)); + unlink($name); + } + + public function testUsesCustomResponseBodyWhenItIsCustom() + { + $en = EntityBody::factory(); + $request = $this->client->get(); + $request->setResponseBody($en); + $request->setResponse(new Response(200, array(), 'foo')); + $this->assertEquals('foo', (string) $en); + } + + public function testCanChangePortThroughScheme() + { + $request = new Request('GET', 'http://foo.com'); + $request->setScheme('https'); + $this->assertEquals('https://foo.com', (string) $request->getUrl()); + $this->assertEquals('foo.com', $request->getHost()); + $request->setScheme('http'); + $this->assertEquals('http://foo.com', (string) $request->getUrl()); + $this->assertEquals('foo.com', $request->getHost()); + $request->setPort(null); + $this->assertEquals('http://foo.com', (string) $request->getUrl()); + $this->assertEquals('foo.com', $request->getHost()); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/ResponseTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/ResponseTest.php new file mode 100644 index 0000000..08b4df8 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Message/ResponseTest.php @@ -0,0 +1,677 @@ +response = new Response(200, new Collection(array( + 'Accept-Ranges' => 'bytes', + 'Age' => '12', + 'Allow' => 'GET, HEAD', + 'Cache-Control' => 'no-cache', + 'Content-Encoding' => 'gzip', + 'Content-Language' => 'da', + 'Content-Length' => '348', + 'Content-Location' => '/index.htm', + 'Content-Disposition' => 'attachment; filename=fname.ext', + 'Content-MD5' => 'Q2hlY2sgSW50ZWdyaXR5IQ==', + 'Content-Range' => 'bytes 21010-47021/47022', + 'Content-Type' => 'text/html; charset=utf-8', + 'Date' => 'Tue, 15 Nov 1994 08:12:31 GMT', + 'ETag' => '737060cd8c284d8af7ad3082f209582d', + 'Expires' => 'Thu, 01 Dec 1994 16:00:00 GMT', + 'Last-Modified' => 'Tue, 15 Nov 1994 12:45:26 GMT', + 'Location' => 'http://www.w3.org/pub/WWW/People.html', + 'Pragma' => 'no-cache', + 'Proxy-Authenticate' => 'Basic', + 'Retry-After' => '120', + 'Server' => 'Apache/1.3.27 (Unix) (Red-Hat/Linux)', + 'Set-Cookie' => 'UserID=JohnDoe; Max-Age=3600; Version=1', + 'Trailer' => 'Max-Forwards', + 'Transfer-Encoding' => 'chunked', + 'Vary' => '*', + 'Via' => '1.0 fred, 1.1 nowhere.com (Apache/1.1)', + 'Warning' => '199 Miscellaneous warning', + 'WWW-Authenticate' => 'Basic' + )), 'body'); + } + + public function tearDown() + { + unset($this->response); + } + + public function testConstructor() + { + $params = new Collection(); + $body = EntityBody::factory(''); + $response = new Response(200, $params, $body); + $this->assertEquals(200, $response->getStatusCode()); + $this->assertEquals($body, $response->getBody()); + $this->assertEquals('OK', $response->getReasonPhrase()); + $this->assertEquals("HTTP/1.1 200 OK\r\n\r\n", $response->getRawHeaders()); + + // Make sure Content-Length is set automatically + $response = new Response(200, $params); + $this->assertEquals("HTTP/1.1 200 OK\r\n\r\n", $response->getRawHeaders()); + + // Pass bodies to the response + $response = new Response(200, null, 'data'); + $this->assertInstanceOf('Guzzle\\Http\\EntityBody', $response->getBody()); + $response = new Response(200, null, EntityBody::factory('data')); + $this->assertInstanceOf('Guzzle\\Http\\EntityBody', $response->getBody()); + $this->assertEquals('data', $response->getBody(true)); + $response = new Response(200, null, '0'); + $this->assertSame('0', $response->getBody(true), 'getBody(true) should return "0" if response body is "0".'); + + // Make sure the proper exception is thrown + try { + //$response = new Response(200, null, array('foo' => 'bar')); + //$this->fail('Response did not throw exception when passing invalid body'); + } catch (HttpException $e) { + } + + // Ensure custom codes can be set + $response = new Response(2); + $this->assertEquals(2, $response->getStatusCode()); + $this->assertEquals('', $response->getReasonPhrase()); + + // Make sure the proper exception is thrown when sending invalid headers + try { + $response = new Response(200, 'adidas'); + $this->fail('Response did not throw exception when passing invalid $headers'); + } catch (BadResponseException $e) { + } + } + + public function test__toString() + { + $response = new Response(200); + $this->assertEquals("HTTP/1.1 200 OK\r\n\r\n", (string) $response); + + // Add another header + $response = new Response(200, array( + 'X-Test' => 'Guzzle' + )); + $this->assertEquals("HTTP/1.1 200 OK\r\nX-Test: Guzzle\r\n\r\n", (string) $response); + + $response = new Response(200, array( + 'Content-Length' => 4 + ), 'test'); + $this->assertEquals("HTTP/1.1 200 OK\r\nContent-Length: 4\r\n\r\ntest", (string) $response); + } + + public function testFactory() + { + $response = Response::fromMessage("HTTP/1.1 200 OK\r\nContent-Length: 4\r\n\r\ntest"); + $this->assertEquals(200, $response->getStatusCode()); + $this->assertEquals('OK', $response->getReasonPhrase()); + $this->assertEquals(4, (string) $response->getContentLength()); + $this->assertEquals('test', $response->getBody(true)); + + // Make sure that automatic Content-Length works + $response = Response::fromMessage("HTTP/1.1 200 OK\r\nContent-Length: 4\r\n\r\ntest"); + $this->assertEquals(4, (string) $response->getContentLength()); + $this->assertEquals('test', $response->getBody(true)); + } + + public function testFactoryCanCreateHeadResponses() + { + $response = Response::fromMessage("HTTP/1.1 200 OK\r\nContent-Length: 4\r\n\r\n"); + $this->assertEquals(200, $response->getStatusCode()); + $this->assertEquals('OK', $response->getReasonPhrase()); + $this->assertEquals(4, (string) $response->getContentLength()); + $this->assertEquals('', $response->getBody(true)); + } + + public function testFactoryRequiresMessage() + { + $this->assertFalse(Response::fromMessage('')); + } + + public function testGetBody() + { + $body = EntityBody::factory(''); + $response = new Response(403, new Collection(), $body); + $this->assertEquals($body, $response->getBody()); + $response->setBody('foo'); + $this->assertEquals('foo', $response->getBody(true)); + } + + public function testManagesStatusCode() + { + $response = new Response(403); + $this->assertEquals(403, $response->getStatusCode()); + } + + public function testGetMessage() + { + $response = new Response(200, new Collection(array( + 'Content-Length' => 4 + )), 'body'); + + $this->assertEquals("HTTP/1.1 200 OK\r\nContent-Length: 4\r\n\r\nbody", $response->getMessage()); + } + + public function testGetRawHeaders() + { + $response = new Response(200, new Collection(array( + 'Keep-Alive' => 155, + 'User-Agent' => 'Guzzle', + 'Content-Length' => 4 + )), 'body'); + + $this->assertEquals("HTTP/1.1 200 OK\r\nKeep-Alive: 155\r\nUser-Agent: Guzzle\r\nContent-Length: 4\r\n\r\n", $response->getRawHeaders()); + } + + public function testHandlesStatusAndStatusCodes() + { + $response = new Response(200, new Collection(), 'body'); + $this->assertEquals('OK', $response->getReasonPhrase()); + + $this->assertSame($response, $response->setStatus(204)); + $this->assertEquals('No Content', $response->getReasonPhrase()); + $this->assertEquals(204, $response->getStatusCode()); + + $this->assertSame($response, $response->setStatus(204, 'Testing!')); + $this->assertEquals('Testing!', $response->getReasonPhrase()); + $this->assertEquals(204, $response->getStatusCode()); + + $response->setStatus(2000); + $this->assertEquals(2000, $response->getStatusCode()); + $this->assertEquals('', $response->getReasonPhrase()); + + $response->setStatus(200, 'Foo'); + $this->assertEquals(200, $response->getStatusCode()); + $this->assertEquals('Foo', $response->getReasonPhrase()); + } + + public function testIsClientError() + { + $response = new Response(403); + $this->assertTrue($response->isClientError()); + $response = new Response(200); + $this->assertFalse($response->isClientError()); + } + + public function testIsError() + { + $response = new Response(403); + $this->assertTrue($response->isError()); + $response = new Response(200); + $this->assertFalse($response->isError()); + $response = new Response(500); + $this->assertTrue($response->isError()); + } + + public function testIsInformational() + { + $response = new Response(100); + $this->assertTrue($response->isInformational()); + $response = new Response(200); + $this->assertFalse($response->isInformational()); + } + + public function testIsRedirect() + { + $response = new Response(301); + $this->assertTrue($response->isRedirect()); + $response = new Response(200); + $this->assertFalse($response->isRedirect()); + } + + public function testIsServerError() + { + $response = new Response(500); + $this->assertTrue($response->isServerError()); + $response = new Response(400); + $this->assertFalse($response->isServerError()); + } + + public function testIsSuccessful() + { + $response = new Response(200); + $this->assertTrue($response->isSuccessful()); + $response = new Response(403); + $this->assertFalse($response->isSuccessful()); + } + + public function testGetAcceptRanges() + { + $this->assertEquals('bytes', $this->response->getAcceptRanges()); + } + + public function testCalculatesAge() + { + $this->assertEquals(12, $this->response->calculateAge()); + + $this->response->removeHeader('Age'); + $this->response->removeHeader('Date'); + $this->assertNull($this->response->calculateAge()); + + $this->response->setHeader('Date', gmdate(ClientInterface::HTTP_DATE, strtotime('-1 minute'))); + // If the test runs slowly, still pass with a +5 second allowance + $this->assertTrue($this->response->getAge() - 60 <= 5); + } + + public function testGetAllow() + { + $this->assertEquals('GET, HEAD', $this->response->getAllow()); + } + + public function testGetCacheControl() + { + $this->assertEquals('no-cache', $this->response->getCacheControl()); + } + + public function testGetContentEncoding() + { + $this->assertEquals('gzip', $this->response->getContentEncoding()); + } + + public function testGetContentLanguage() + { + $this->assertEquals('da', $this->response->getContentLanguage()); + } + + public function testGetContentLength() + { + $this->assertEquals('348', $this->response->getContentLength()); + } + + public function testGetContentLocation() + { + $this->assertEquals('/index.htm', $this->response->getContentLocation()); + } + + public function testGetContentDisposition() + { + $this->assertEquals('attachment; filename=fname.ext', $this->response->getContentDisposition()); + } + + public function testGetContentMd5() + { + $this->assertEquals('Q2hlY2sgSW50ZWdyaXR5IQ==', $this->response->getContentMd5()); + } + + public function testGetContentRange() + { + $this->assertEquals('bytes 21010-47021/47022', $this->response->getContentRange()); + } + + public function testGetContentType() + { + $this->assertEquals('text/html; charset=utf-8', $this->response->getContentType()); + } + + public function testGetDate() + { + $this->assertEquals('Tue, 15 Nov 1994 08:12:31 GMT', $this->response->getDate()); + } + + public function testGetEtag() + { + $this->assertEquals('737060cd8c284d8af7ad3082f209582d', $this->response->getEtag()); + } + + public function testGetExpires() + { + $this->assertEquals('Thu, 01 Dec 1994 16:00:00 GMT', $this->response->getExpires()); + } + + public function testGetLastModified() + { + $this->assertEquals('Tue, 15 Nov 1994 12:45:26 GMT', $this->response->getLastModified()); + } + + public function testGetLocation() + { + $this->assertEquals('http://www.w3.org/pub/WWW/People.html', $this->response->getLocation()); + } + + public function testGetPragma() + { + $this->assertEquals('no-cache', $this->response->getPragma()); + } + + public function testGetProxyAuthenticate() + { + $this->assertEquals('Basic', $this->response->getProxyAuthenticate()); + } + + public function testGetServer() + { + $this->assertEquals('Apache/1.3.27 (Unix) (Red-Hat/Linux)', $this->response->getServer()); + } + + public function testGetSetCookie() + { + $this->assertEquals('UserID=JohnDoe; Max-Age=3600; Version=1', $this->response->getSetCookie()); + } + + public function testGetMultipleSetCookie() + { + $this->response->addHeader('Set-Cookie', 'UserID=Mike; Max-Age=200'); + $this->assertEquals(array( + 'UserID=JohnDoe; Max-Age=3600; Version=1', + 'UserID=Mike; Max-Age=200', + ), $this->response->getHeader('Set-Cookie')->toArray()); + } + + public function testGetSetCookieNormalizesHeaders() + { + $this->response->addHeaders(array( + 'Set-Cooke' => 'boo', + 'set-cookie' => 'foo' + )); + + $this->assertEquals(array( + 'UserID=JohnDoe; Max-Age=3600; Version=1', + 'foo' + ), $this->response->getHeader('Set-Cookie')->toArray()); + + $this->response->addHeaders(array( + 'set-cookie' => 'fubu' + )); + $this->assertEquals( + array('UserID=JohnDoe; Max-Age=3600; Version=1', 'foo', 'fubu'), + $this->response->getHeader('Set-Cookie')->toArray() + ); + } + + public function testGetTrailer() + { + $this->assertEquals('Max-Forwards', $this->response->getTrailer()); + } + + public function testGetTransferEncoding() + { + $this->assertEquals('chunked', $this->response->getTransferEncoding()); + } + + public function testGetVary() + { + $this->assertEquals('*', $this->response->getVary()); + } + + public function testReturnsViaHeader() + { + $this->assertEquals('1.0 fred, 1.1 nowhere.com (Apache/1.1)', $this->response->getVia()); + } + public function testGetWarning() + { + $this->assertEquals('199 Miscellaneous warning', $this->response->getWarning()); + } + + public function testReturnsWwwAuthenticateHeader() + { + $this->assertEquals('Basic', $this->response->getWwwAuthenticate()); + } + + public function testReturnsConnectionHeader() + { + $this->assertEquals(null, $this->response->getConnection()); + $this->response->setHeader('Connection', 'close'); + $this->assertEquals('close', $this->response->getConnection()); + } + + public function testReturnsHeaders() + { + $this->assertEquals('Basic', $this->response->getHeader('WWW-Authenticate', null, true)); + $this->assertEquals('chunked', $this->response->getHeader('Transfer-Encoding', null, false)); + } + + public function testHasTransferInfo() + { + $stats = array ( + 'url' => 'http://www.google.com/', + 'content_type' => 'text/html; charset=ISO-8859-1', + 'http_code' => 200, + 'header_size' => 606, + 'request_size' => 53, + 'filetime' => -1, + 'ssl_verify_result' => 0, + 'redirect_count' => 0, + 'total_time' => 0.093284, + 'namelookup_time' => 0.001349, + 'connect_time' => 0.01635, + 'pretransfer_time' => 0.016358, + 'size_upload' => 0, + 'size_download' => 10330, + 'speed_download' => 110737, + 'speed_upload' => 0, + 'download_content_length' => -1, + 'upload_content_length' => 0, + 'starttransfer_time' => 0.07066, + 'redirect_time' => 0, + ); + + // Uninitialized state + $this->assertNull($this->response->getInfo('url')); + $this->assertEquals(array(), $this->response->getInfo()); + + // Set the stats + $this->response->setInfo($stats); + $this->assertEquals($stats, $this->response->getInfo()); + $this->assertEquals(606, $this->response->getInfo('header_size')); + $this->assertNull($this->response->getInfo('does_not_exist')); + } + + /** + * @return Response + */ + private function getResponse($code, array $headers = null, EntityBody $body = null) + { + return new Response($code, $headers, $body); + } + + public function testDeterminesIfItCanBeCached() + { + $this->assertTrue($this->getResponse(200)->canCache()); + $this->assertTrue($this->getResponse(410)->canCache()); + $this->assertFalse($this->getResponse(404)->canCache()); + $this->assertTrue($this->getResponse(200, array( + 'Cache-Control' => 'public' + ))->canCache()); + + // This has the no-store directive + $this->assertFalse($this->getResponse(200, array( + 'Cache-Control' => 'private, no-store' + ))->canCache()); + + // The body cannot be read, so it cannot be cached + $tmp = tempnam('/tmp', 'not-readable'); + $resource = fopen($tmp, 'w'); + $this->assertFalse($this->getResponse(200, array( + 'Transfer-Encoding' => 'chunked' + ), EntityBody::factory($resource, 10))->canCache()); + unlink($tmp); + + // The body is 0 length, cannot be read, so it can be cached + $tmp = tempnam('/tmp', 'not-readable'); + $resource = fopen($tmp, 'w'); + $this->assertTrue($this->getResponse(200, array(array( + 'Content-Length' => 0 + )), EntityBody::factory($resource, 0))->canCache()); + unlink($tmp); + } + + public function testDeterminesResponseMaxAge() + { + $this->assertEquals(null, $this->getResponse(200)->getMaxAge()); + + // Uses the response's s-maxage + $this->assertEquals(140, $this->getResponse(200, array( + 'Cache-Control' => 's-maxage=140' + ))->getMaxAge()); + + // Uses the response's max-age + $this->assertEquals(120, $this->getResponse(200, array( + 'Cache-Control' => 'max-age=120' + ))->getMaxAge()); + + // Uses the response's max-age + $this->assertEquals(120, $this->getResponse(200, array( + 'Cache-Control' => 'max-age=120', + 'Expires' => gmdate(ClientInterface::HTTP_DATE, strtotime('+1 day')) + ))->getMaxAge()); + + // Uses the Expires date + $this->assertGreaterThanOrEqual(82400, $this->getResponse(200, array( + 'Expires' => gmdate(ClientInterface::HTTP_DATE, strtotime('+1 day')) + ))->getMaxAge()); + + // Uses the Expires date + $this->assertGreaterThanOrEqual(82400, $this->getResponse(200, array( + 'Expires' => gmdate(ClientInterface::HTTP_DATE, strtotime('+1 day')) + ))->getMaxAge()); + } + + public function testDeterminesIfItCanValidate() + { + $response = new Response(200); + $this->assertFalse($response->canValidate()); + $response->setHeader('ETag', '123'); + $this->assertTrue($response->canValidate()); + $response->removeHeader('ETag'); + $this->assertFalse($response->canValidate()); + $response->setHeader('Last-Modified', '123'); + $this->assertTrue($response->canValidate()); + } + + public function testCalculatesFreshness() + { + $response = new Response(200); + $this->assertNull($response->isFresh()); + $this->assertNull($response->getFreshness()); + + $response->setHeader('Cache-Control', 'max-age=120'); + $response->setHeader('Age', 100); + $this->assertEquals(20, $response->getFreshness()); + $this->assertTrue($response->isFresh()); + + $response->setHeader('Age', 120); + $this->assertEquals(0, $response->getFreshness()); + $this->assertTrue($response->isFresh()); + + $response->setHeader('Age', 150); + $this->assertEquals(-30, $response->getFreshness()); + $this->assertFalse($response->isFresh()); + } + + public function testHandlesProtocols() + { + $this->assertSame($this->response, $this->response->setProtocol('HTTP', '1.0')); + $this->assertEquals('HTTP', $this->response->getProtocol()); + $this->assertEquals('1.0', $this->response->getProtocolVersion()); + } + + public function testComparesContentType() + { + $response = new Response(200, array( + 'Content-Type' => 'text/html; charset=ISO-8859-4' + )); + + $this->assertTrue($response->isContentType('text/html')); + $this->assertTrue($response->isContentType('TExT/html')); + $this->assertTrue($response->isContentType('charset=ISO-8859-4')); + $this->assertFalse($response->isContentType('application/xml')); + } + + public function testResponseDeterminesIfMethodIsAllowedBaseOnAllowHeader() + { + $response = new Response(200, array( + 'Allow' => 'OPTIONS, POST, deletE,GET' + )); + + $this->assertTrue($response->isMethodAllowed('get')); + $this->assertTrue($response->isMethodAllowed('GET')); + $this->assertTrue($response->isMethodAllowed('options')); + $this->assertTrue($response->isMethodAllowed('post')); + $this->assertTrue($response->isMethodAllowed('Delete')); + $this->assertFalse($response->isMethodAllowed('put')); + $this->assertFalse($response->isMethodAllowed('PUT')); + + $response = new Response(200); + $this->assertFalse($response->isMethodAllowed('get')); + } + + public function testParsesJsonResponses() + { + $response = new Response(200, array(), '{"foo": "bar"}'); + $this->assertEquals(array('foo' => 'bar'), $response->json()); + // Return array when null is a service response + $response = new Response(200); + $this->assertEquals(array(), $response->json()); + } + + /** + * @expectedException \Guzzle\Common\Exception\RuntimeException + * @expectedExceptionMessage Unable to parse response body into JSON: 4 + */ + public function testThrowsExceptionWhenFailsToParseJsonResponse() + { + $response = new Response(200, array(), '{"foo": "'); + $response->json(); + } + + public function testParsesXmlResponses() + { + $response = new Response(200, array(), 'bar'); + $this->assertEquals('bar', (string) $response->xml()->foo); + // Always return a SimpleXMLElement from the xml method + $response = new Response(200); + $this->assertEmpty((string) $response->xml()->foo); + } + + /** + * @expectedException \Guzzle\Common\Exception\RuntimeException + * @expectedExceptionMessage Unable to parse response body into XML: String could not be parsed as XML + */ + public function testThrowsExceptionWhenFailsToParseXmlResponse() + { + $response = new Response(200, array(), 'xml(); + } + + public function testResponseIsSerializable() + { + $response = new Response(200, array('Foo' => 'bar'), 'test'); + $r = unserialize(serialize($response)); + $this->assertEquals(200, $r->getStatusCode()); + $this->assertEquals('bar', (string) $r->getHeader('Foo')); + $this->assertEquals('test', (string) $r->getBody()); + } + + public function testPreventsComplexExternalEntities() + { + $xml = ']>&test;'; + $response = new Response(200, array(), $xml); + + $oldCwd = getcwd(); + chdir(__DIR__); + try { + $xml = $response->xml(); + chdir($oldCwd); + $this->markTestIncomplete('Did not throw the expected exception! XML resolved as: ' . $xml->asXML()); + } catch (\Exception $e) { + chdir($oldCwd); + } + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/MimetypesTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/MimetypesTest.php new file mode 100644 index 0000000..7228453 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/MimetypesTest.php @@ -0,0 +1,31 @@ +assertEquals('text/x-php', Mimetypes::getInstance()->fromExtension('php')); + } + + public function testGetsFromFilename() + { + $this->assertEquals('text/x-php', Mimetypes::getInstance()->fromFilename(__FILE__)); + } + + public function testGetsFromCaseInsensitiveFilename() + { + $this->assertEquals('text/x-php', Mimetypes::getInstance()->fromFilename(strtoupper(__FILE__))); + } + + public function testReturnsNullWhenNoMatchFound() + { + $this->assertNull(Mimetypes::getInstance()->fromExtension('foobar')); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/QueryAggregator/CommaAggregatorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/QueryAggregator/CommaAggregatorTest.php new file mode 100644 index 0000000..549d3ed --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/QueryAggregator/CommaAggregatorTest.php @@ -0,0 +1,30 @@ +aggregate($key, $value, $query); + $this->assertEquals(array('test%20123' => 'foo%20123,baz,bar'), $result); + } + + public function testEncodes() + { + $query = new QueryString(); + $query->useUrlEncoding(false); + $a = new Ag(); + $key = 'test 123'; + $value = array('foo 123', 'baz', 'bar'); + $result = $a->aggregate($key, $value, $query); + $this->assertEquals(array('test 123' => 'foo 123,baz,bar'), $result); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/QueryAggregator/DuplicateAggregatorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/QueryAggregator/DuplicateAggregatorTest.php new file mode 100644 index 0000000..6a4d9d9 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/QueryAggregator/DuplicateAggregatorTest.php @@ -0,0 +1,30 @@ +aggregate($key, $value, $query); + $this->assertEquals(array('facet%201' => array('size%20a', 'width%20b')), $result); + } + + public function testEncodes() + { + $query = new QueryString(); + $query->useUrlEncoding(false); + $a = new Ag(); + $key = 'facet 1'; + $value = array('size a', 'width b'); + $result = $a->aggregate($key, $value, $query); + $this->assertEquals(array('facet 1' => array('size a', 'width b')), $result); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/QueryAggregator/PhpAggregatorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/QueryAggregator/PhpAggregatorTest.php new file mode 100644 index 0000000..1e7f0c2 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/QueryAggregator/PhpAggregatorTest.php @@ -0,0 +1,32 @@ +useUrlEncoding(false); + $a = new Ag(); + $key = 't'; + $value = array( + 'v1' => 'a', + 'v2' => 'b', + 'v3' => array( + 'v4' => 'c', + 'v5' => 'd', + ) + ); + $result = $a->aggregate($key, $value, $query); + $this->assertEquals(array( + 't[v1]' => 'a', + 't[v2]' => 'b', + 't[v3][v4]' => 'c', + 't[v3][v5]' => 'd', + ), $result); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/QueryStringTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/QueryStringTest.php new file mode 100644 index 0000000..948db44 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/QueryStringTest.php @@ -0,0 +1,233 @@ +q = new QueryString(); + } + + public function testGetFieldSeparator() + { + $this->assertEquals('&', $this->q->getFieldSeparator()); + } + + public function testGetValueSeparator() + { + $this->assertEquals('=', $this->q->getValueSeparator()); + } + + public function testIsUrlEncoding() + { + $this->assertEquals('RFC 3986', $this->q->getUrlEncoding()); + $this->assertTrue($this->q->isUrlEncoding()); + $this->assertEquals('foo%20bar', $this->q->encodeValue('foo bar')); + + $this->q->useUrlEncoding(QueryString::FORM_URLENCODED); + $this->assertTrue($this->q->isUrlEncoding()); + $this->assertEquals(QueryString::FORM_URLENCODED, $this->q->getUrlEncoding()); + $this->assertEquals('foo+bar', $this->q->encodeValue('foo bar')); + + $this->assertSame($this->q, $this->q->useUrlEncoding(false)); + $this->assertFalse($this->q->isUrlEncoding()); + $this->assertFalse($this->q->isUrlEncoding()); + } + + public function testSetFieldSeparator() + { + $this->assertEquals($this->q, $this->q->setFieldSeparator('/')); + $this->assertEquals('/', $this->q->getFieldSeparator()); + } + + public function testSetValueSeparator() + { + $this->assertEquals($this->q, $this->q->setValueSeparator('/')); + $this->assertEquals('/', $this->q->getValueSeparator()); + } + + public function testUrlEncode() + { + $params = array( + 'test' => 'value', + 'test 2' => 'this is a test?', + 'test3' => array('v1', 'v2', 'v3'), + 'ሴ' => 'bar' + ); + $encoded = array( + 'test' => 'value', + 'test%202' => rawurlencode('this is a test?'), + 'test3%5B0%5D' => 'v1', + 'test3%5B1%5D' => 'v2', + 'test3%5B2%5D' => 'v3', + '%E1%88%B4' => 'bar' + ); + $this->q->replace($params); + $this->assertEquals($encoded, $this->q->urlEncode()); + + // Disable encoding + $testData = array('test 2' => 'this is a test'); + $this->q->replace($testData); + $this->q->useUrlEncoding(false); + $this->assertEquals($testData, $this->q->urlEncode()); + } + + public function testToString() + { + // Check with no parameters + $this->assertEquals('', $this->q->__toString()); + + $params = array( + 'test' => 'value', + 'test 2' => 'this is a test?', + 'test3' => array('v1', 'v2', 'v3'), + 'test4' => null, + ); + $this->q->replace($params); + $this->assertEquals('test=value&test%202=this%20is%20a%20test%3F&test3%5B0%5D=v1&test3%5B1%5D=v2&test3%5B2%5D=v3&test4', $this->q->__toString()); + $this->q->useUrlEncoding(false); + $this->assertEquals('test=value&test 2=this is a test?&test3[0]=v1&test3[1]=v2&test3[2]=v3&test4', $this->q->__toString()); + + // Use an alternative aggregator + $this->q->setAggregator(new CommaAggregator()); + $this->assertEquals('test=value&test 2=this is a test?&test3=v1,v2,v3&test4', $this->q->__toString()); + } + + public function testAllowsMultipleValuesPerKey() + { + $q = new QueryString(); + $q->add('facet', 'size'); + $q->add('facet', 'width'); + $q->add('facet.field', 'foo'); + // Use the duplicate aggregator + $q->setAggregator(new DuplicateAggregator()); + $this->assertEquals('facet=size&facet=width&facet.field=foo', $q->__toString()); + } + + public function testAllowsNestedQueryData() + { + $this->q->replace(array( + 'test' => 'value', + 't' => array( + 'v1' => 'a', + 'v2' => 'b', + 'v3' => array( + 'v4' => 'c', + 'v5' => 'd', + ) + ) + )); + + $this->q->useUrlEncoding(false); + $this->assertEquals('test=value&t[v1]=a&t[v2]=b&t[v3][v4]=c&t[v3][v5]=d', $this->q->__toString()); + } + + public function parseQueryProvider() + { + return array( + // Ensure that multiple query string values are allowed per value + array('q=a&q=b', array('q' => array('a', 'b'))), + // Ensure that PHP array style query string values are parsed + array('q[]=a&q[]=b', array('q' => array('a', 'b'))), + // Ensure that a single PHP array style query string value is parsed into an array + array('q[]=a', array('q' => array('a'))), + // Ensure that decimals are allowed in query strings + array('q.a=a&q.b=b', array( + 'q.a' => 'a', + 'q.b' => 'b' + )), + // Ensure that query string values are percent decoded + array('q%20a=a%20b', array('q a' => 'a b')), + // Ensure null values can be added + array('q&a', array('q' => false, 'a' => false)), + ); + } + + /** + * @dataProvider parseQueryProvider + */ + public function testParsesQueryStrings($query, $data) + { + $query = QueryString::fromString($query); + $this->assertEquals($data, $query->getAll()); + } + + public function testProperlyDealsWithDuplicateQueryStringValues() + { + $query = QueryString::fromString('foo=a&foo=b&?µ=c'); + $this->assertEquals(array('a', 'b'), $query->get('foo')); + $this->assertEquals('c', $query->get('?µ')); + } + + public function testAllowsBlankQueryStringValues() + { + $query = QueryString::fromString('foo'); + $this->assertEquals('foo', (string) $query); + $query->set('foo', QueryString::BLANK); + $this->assertEquals('foo', (string) $query); + } + + public function testAllowsFalsyQueryStringValues() + { + $query = QueryString::fromString('0'); + $this->assertEquals('0', (string) $query); + $query->set('0', QueryString::BLANK); + $this->assertSame('0', (string) $query); + } + + public function testFromStringIgnoresQuestionMark() + { + $query = QueryString::fromString('foo=baz&bar=boo'); + $this->assertEquals('foo=baz&bar=boo', (string) $query); + } + + public function testConvertsPlusSymbolsToSpaces() + { + $query = QueryString::fromString('var=foo+bar'); + $this->assertEquals('foo bar', $query->get('var')); + } + + public function testFromStringDoesntMangleZeroes() + { + $query = QueryString::fromString('var=0'); + $this->assertSame('0', $query->get('var')); + } + + public function testAllowsZeroValues() + { + $query = new QueryString(array( + 'foo' => 0, + 'baz' => '0', + 'bar' => null, + 'boo' => false, + 'bam' => '' + )); + $this->assertEquals('foo=0&baz=0&bar&boo&bam=', (string) $query); + } + + public function testFromStringDoesntStripTrailingEquals() + { + $query = QueryString::fromString('data=mF0b3IiLCJUZWFtIERldiJdfX0='); + $this->assertEquals('mF0b3IiLCJUZWFtIERldiJdfX0=', $query->get('data')); + } + + public function testGuessesIfDuplicateAggregatorShouldBeUsed() + { + $query = QueryString::fromString('test=a&test=b'); + $this->assertEquals('test=a&test=b', (string) $query); + } + + public function testGuessesIfDuplicateAggregatorShouldBeUsedAndChecksForPhpStyle() + { + $query = QueryString::fromString('test[]=a&test[]=b'); + $this->assertEquals('test%5B0%5D=a&test%5B1%5D=b', (string) $query); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/ReadLimitEntityBodyTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/ReadLimitEntityBodyTest.php new file mode 100644 index 0000000..6bb3fed --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/ReadLimitEntityBodyTest.php @@ -0,0 +1,81 @@ +decorated = EntityBody::factory(fopen(__FILE__, 'r')); + $this->body = new ReadLimitEntityBody($this->decorated, 10, 3); + } + + public function testReturnsSubsetWhenCastToString() + { + $body = EntityBody::factory('foo_baz_bar'); + $limited = new ReadLimitEntityBody($body, 3, 4); + $this->assertEquals('baz', (string) $limited); + } + + public function testReturnsSubsetOfEmptyBodyWhenCastToString() + { + $body = EntityBody::factory(''); + $limited = new ReadLimitEntityBody($body, 0, 10); + $this->assertEquals('', (string) $limited); + } + + public function testSeeksWhenConstructed() + { + $this->assertEquals(3, $this->body->ftell()); + } + + public function testAllowsBoundedSeek() + { + $this->body->seek(100); + $this->assertEquals(13, $this->body->ftell()); + $this->body->seek(0); + $this->assertEquals(3, $this->body->ftell()); + $this->assertEquals(false, $this->body->seek(1000, SEEK_END)); + } + + public function testReadsOnlySubsetOfData() + { + $data = $this->body->read(100); + $this->assertEquals(10, strlen($data)); + $this->assertFalse($this->body->read(1000)); + + $this->body->setOffset(10); + $newData = $this->body->read(100); + $this->assertEquals(10, strlen($newData)); + $this->assertNotSame($data, $newData); + } + + public function testClaimsConsumedWhenReadLimitIsReached() + { + $this->assertFalse($this->body->isConsumed()); + $this->body->read(1000); + $this->assertTrue($this->body->isConsumed()); + } + + public function testContentLengthIsBounded() + { + $this->assertEquals(10, $this->body->getContentLength()); + } + + public function testContentMd5IsBasedOnSubsection() + { + $this->assertNotSame($this->body->getContentMd5(), $this->decorated->getContentMd5()); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/RedirectPluginTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/RedirectPluginTest.php new file mode 100755 index 0000000..886236d --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/RedirectPluginTest.php @@ -0,0 +1,277 @@ +getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 301 Moved Permanently\r\nLocation: /redirect1\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 301 Moved Permanently\r\nLocation: /redirect2\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n", + )); + + // Create a client that uses the default redirect behavior + $client = new Client($this->getServer()->getUrl()); + $history = new HistoryPlugin(); + $client->addSubscriber($history); + + $request = $client->get('/foo'); + $response = $request->send(); + $this->assertEquals(200, $response->getStatusCode()); + $this->assertContains('/redirect2', $response->getEffectiveUrl()); + + // Ensure that two requests were sent + $requests = $this->getServer()->getReceivedRequests(true); + $this->assertEquals('/foo', $requests[0]->getResource()); + $this->assertEquals('GET', $requests[0]->getMethod()); + $this->assertEquals('/redirect1', $requests[1]->getResource()); + $this->assertEquals('GET', $requests[1]->getMethod()); + $this->assertEquals('/redirect2', $requests[2]->getResource()); + $this->assertEquals('GET', $requests[2]->getMethod()); + + // Ensure that the redirect count was incremented + $this->assertEquals(2, $request->getParams()->get(RedirectPlugin::REDIRECT_COUNT)); + $this->assertCount(3, $history); + $requestHistory = $history->getAll(); + + $this->assertEquals(301, $requestHistory[0]['response']->getStatusCode()); + $this->assertEquals('/redirect1', (string) $requestHistory[0]['response']->getHeader('Location')); + $this->assertEquals(301, $requestHistory[1]['response']->getStatusCode()); + $this->assertEquals('/redirect2', (string) $requestHistory[1]['response']->getHeader('Location')); + $this->assertEquals(200, $requestHistory[2]['response']->getStatusCode()); + } + + public function testCanLimitNumberOfRedirects() + { + // Flush the server and queue up a redirect followed by a successful response + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 301 Moved Permanently\r\nLocation: /redirect1\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 301 Moved Permanently\r\nLocation: /redirect2\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 301 Moved Permanently\r\nLocation: /redirect3\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 301 Moved Permanently\r\nLocation: /redirect4\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 301 Moved Permanently\r\nLocation: /redirect5\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 301 Moved Permanently\r\nLocation: /redirect6\r\nContent-Length: 0\r\n\r\n" + )); + + try { + $client = new Client($this->getServer()->getUrl()); + $client->get('/foo')->send(); + $this->fail('Did not throw expected exception'); + } catch (TooManyRedirectsException $e) { + $this->assertContains( + "5 redirects were issued for this request:\nGET /foo HTTP/1.1\r\n", + $e->getMessage() + ); + } + } + + public function testDefaultBehaviorIsToRedirectWithGetForEntityEnclosingRequests() + { + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 301 Moved Permanently\r\nLocation: /redirect\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 301 Moved Permanently\r\nLocation: /redirect\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n", + )); + + $client = new Client($this->getServer()->getUrl()); + $client->post('/foo', array('X-Baz' => 'bar'), 'testing')->send(); + + $requests = $this->getServer()->getReceivedRequests(true); + $this->assertEquals('POST', $requests[0]->getMethod()); + $this->assertEquals('GET', $requests[1]->getMethod()); + $this->assertEquals('bar', (string) $requests[1]->getHeader('X-Baz')); + $this->assertEquals('GET', $requests[2]->getMethod()); + } + + public function testCanRedirectWithStrictRfcCompliance() + { + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 301 Moved Permanently\r\nLocation: /redirect\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 301 Moved Permanently\r\nLocation: /redirect\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n", + )); + + $client = new Client($this->getServer()->getUrl()); + $request = $client->post('/foo', array('X-Baz' => 'bar'), 'testing'); + $request->getParams()->set(RedirectPlugin::STRICT_REDIRECTS, true); + $request->send(); + + $requests = $this->getServer()->getReceivedRequests(true); + $this->assertEquals('POST', $requests[0]->getMethod()); + $this->assertEquals('POST', $requests[1]->getMethod()); + $this->assertEquals('bar', (string) $requests[1]->getHeader('X-Baz')); + $this->assertEquals('POST', $requests[2]->getMethod()); + } + + public function testRedirect303WithGet() + { + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 303 Moved Permanently\r\nLocation: /redirect\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n", + )); + + $client = new Client($this->getServer()->getUrl()); + $request = $client->post('/foo'); + $request->send(); + + $requests = $this->getServer()->getReceivedRequests(true); + $this->assertEquals('POST', $requests[0]->getMethod()); + $this->assertEquals('GET', $requests[1]->getMethod()); + } + + public function testRedirect303WithGetWithStrictRfcCompliance() + { + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 303 Moved Permanently\r\nLocation: /redirect\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n", + )); + + $client = new Client($this->getServer()->getUrl()); + $request = $client->post('/foo'); + $request->getParams()->set(RedirectPlugin::STRICT_REDIRECTS, true); + $request->send(); + + $requests = $this->getServer()->getReceivedRequests(true); + $this->assertEquals('POST', $requests[0]->getMethod()); + $this->assertEquals('GET', $requests[1]->getMethod()); + } + + public function testRewindsStreamWhenRedirectingIfNeeded() + { + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 301 Moved Permanently\r\nLocation: /redirect\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n", + )); + + $client = new Client($this->getServer()->getUrl()); + $request = $client->put(); + $request->configureRedirects(true); + $body = EntityBody::factory('foo'); + $body->read(1); + $request->setBody($body); + $request->send(); + $requests = $this->getServer()->getReceivedRequests(true); + $this->assertEquals('foo', (string) $requests[0]->getBody()); + } + + /** + * @expectedException \Guzzle\Http\Exception\CouldNotRewindStreamException + */ + public function testThrowsExceptionWhenStreamCannotBeRewound() + { + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 200 OK\r\nContent-Length: 2\r\n\r\nhi", + "HTTP/1.1 301 Moved Permanently\r\nLocation: /redirect\r\nContent-Length: 0\r\n\r\n" + )); + + $client = new Client($this->getServer()->getUrl()); + $request = $client->put(); + $request->configureRedirects(true); + $body = EntityBody::factory(fopen($this->getServer()->getUrl(), 'r')); + $body->read(1); + $request->setBody($body)->send(); + } + + public function testRedirectsCanBeDisabledPerRequest() + { + $this->getServer()->flush(); + $this->getServer()->enqueue(array("HTTP/1.1 301 Foo\r\nLocation: /foo\r\nContent-Length: 0\r\n\r\n")); + $client = new Client($this->getServer()->getUrl()); + $request = $client->put(); + $request->configureRedirects(false, 0); + $this->assertEquals(301, $request->send()->getStatusCode()); + } + + public function testCanRedirectWithNoLeadingSlashAndQuery() + { + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 301 Moved Permanently\r\nLocation: redirect?foo=bar\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n", + )); + $client = new Client($this->getServer()->getUrl()); + $request = $client->get('?foo=bar'); + $request->send(); + $requests = $this->getServer()->getReceivedRequests(true); + $this->assertEquals($this->getServer()->getUrl() . '?foo=bar', $requests[0]->getUrl()); + $this->assertEquals($this->getServer()->getUrl() . 'redirect?foo=bar', $requests[1]->getUrl()); + // Ensure that the history on the actual request is correct + $this->assertEquals($this->getServer()->getUrl() . '?foo=bar', $request->getUrl()); + } + + public function testRedirectWithStrictRfc386Compliance() + { + // Flush the server and queue up a redirect followed by a successful response + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 301 Moved Permanently\r\nLocation: redirect\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n" + )); + $client = new Client($this->getServer()->getUrl()); + $request = $client->get('/foo'); + $request->send(); + $requests = $this->getServer()->getReceivedRequests(true); + $this->assertEquals('/redirect', $requests[1]->getResource()); + } + + public function testResetsHistoryEachSend() + { + // Flush the server and queue up a redirect followed by a successful response + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 301 Moved Permanently\r\nLocation: /redirect1\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 301 Moved Permanently\r\nLocation: /redirect2\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n" + )); + + // Create a client that uses the default redirect behavior + $client = new Client($this->getServer()->getUrl()); + $history = new HistoryPlugin(); + $client->addSubscriber($history); + + $request = $client->get('/foo'); + $response = $request->send(); + $this->assertEquals(3, count($history)); + $this->assertTrue($request->getParams()->hasKey('redirect.count')); + $this->assertContains('/redirect2', $response->getEffectiveUrl()); + + $request->send(); + $this->assertFalse($request->getParams()->hasKey('redirect.count')); + } + + public function testHandlesRedirectsWithSpacesProperly() + { + // Flush the server and queue up a redirect followed by a successful response + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 301 Moved Permanently\r\nLocation: /redirect 1\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n" + )); + $client = new Client($this->getServer()->getUrl()); + $request = $client->get('/foo'); + $request->send(); + $reqs = $this->getServer()->getReceivedRequests(true); + $this->assertEquals('/redirect%201', $reqs[1]->getResource()); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Server.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Server.php new file mode 100644 index 0000000..a61caee --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/Server.php @@ -0,0 +1,187 @@ +port = $port ?: self::DEFAULT_PORT; + $this->client = new Client($this->getUrl()); + register_shutdown_function(array($this, 'stop')); + } + + /** + * Flush the received requests from the server + * @throws RuntimeException + */ + public function flush() + { + $this->client->delete('guzzle-server/requests')->send(); + } + + /** + * Queue an array of responses or a single response on the server. + * + * Any currently queued responses will be overwritten. Subsequent requests + * on the server will return queued responses in FIFO order. + * + * @param array|Response $responses A single or array of Responses to queue + * @throws BadResponseException + */ + public function enqueue($responses) + { + $data = array(); + foreach ((array) $responses as $response) { + + // Create the response object from a string + if (is_string($response)) { + $response = Response::fromMessage($response); + } elseif (!($response instanceof Response)) { + throw new BadResponseException('Responses must be strings or implement Response'); + } + + $data[] = array( + 'statusCode' => $response->getStatusCode(), + 'reasonPhrase' => $response->getReasonPhrase(), + 'headers' => $response->getHeaders()->toArray(), + 'body' => $response->getBody(true) + ); + } + + $request = $this->client->put('guzzle-server/responses', null, json_encode($data)); + $request->send(); + } + + /** + * Check if the server is running + * + * @return bool + */ + public function isRunning() + { + if ($this->running) { + return true; + } + + try { + $this->client->get('guzzle-server/perf', array(), array('timeout' => 5))->send(); + return $this->running = true; + } catch (\Exception $e) { + return false; + } + } + + /** + * Get the URL to the server + * + * @return string + */ + public function getUrl() + { + return 'http://127.0.0.1:' . $this->getPort() . '/'; + } + + /** + * Get the port that the server is listening on + * + * @return int + */ + public function getPort() + { + return $this->port; + } + + /** + * Get all of the received requests + * + * @param bool $hydrate Set to TRUE to turn the messages into + * actual {@see RequestInterface} objects. If $hydrate is FALSE, + * requests will be returned as strings. + * + * @return array + * @throws RuntimeException + */ + public function getReceivedRequests($hydrate = false) + { + $response = $this->client->get('guzzle-server/requests')->send(); + $data = array_filter(explode(self::REQUEST_DELIMITER, $response->getBody(true))); + if ($hydrate) { + $data = array_map(function($message) { + return RequestFactory::getInstance()->fromMessage($message); + }, $data); + } + + return $data; + } + + /** + * Start running the node.js server in the background + */ + public function start() + { + if (!$this->isRunning()) { + exec('node ' . __DIR__ . \DIRECTORY_SEPARATOR . 'server.js ' . $this->port . ' >> /tmp/server.log 2>&1 &'); + // Wait at most 5 seconds for the server the setup before proceeding + $start = time(); + while (!$this->isRunning() && time() - $start < 5); + if (!$this->running) { + throw new RuntimeException( + 'Unable to contact server.js. Have you installed node.js v0.5.0+? node must be in your path.' + ); + } + } + } + + /** + * Stop running the node.js server + */ + public function stop() + { + if (!$this->isRunning()) { + return false; + } + + $this->running = false; + $this->client->delete('guzzle-server')->send(); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/StaticClientTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/StaticClientTest.php new file mode 100644 index 0000000..091314b --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/StaticClientTest.php @@ -0,0 +1,67 @@ +assertTrue(class_exists('FooBazBar')); + $this->assertSame($client, $this->readAttribute('Guzzle\Http\StaticClient', 'client')); + } + + public function requestProvider() + { + return array_map( + function ($m) { return array($m); }, + array('GET', 'POST', 'PUT', 'DELETE', 'PATCH', 'HEAD', 'OPTIONS') + ); + } + + /** + * @dataProvider requestProvider + */ + public function testSendsRequests($method) + { + $mock = new MockPlugin(array(new Response(200))); + call_user_func('Guzzle\Http\StaticClient::' . $method, 'http://foo.com', array( + 'plugins' => array($mock) + )); + $requests = $mock->getReceivedRequests(); + $this->assertCount(1, $requests); + $this->assertEquals($method, $requests[0]->getMethod()); + } + + public function testCanCreateStreamsUsingDefaultFactory() + { + $this->getServer()->enqueue(array("HTTP/1.1 200 OK\r\nContent-Length: 4\r\n\r\ntest")); + $stream = StaticClient::get($this->getServer()->getUrl(), array('stream' => true)); + $this->assertInstanceOf('Guzzle\Stream\StreamInterface', $stream); + $this->assertEquals('test', (string) $stream); + } + + public function testCanCreateStreamsUsingCustomFactory() + { + $stream = $this->getMockBuilder('Guzzle\Stream\StreamRequestFactoryInterface') + ->setMethods(array('fromRequest')) + ->getMockForAbstractClass(); + $resource = new Stream(fopen('php://temp', 'r+')); + $stream->expects($this->once()) + ->method('fromRequest') + ->will($this->returnValue($resource)); + $this->getServer()->enqueue(array("HTTP/1.1 200 OK\r\nContent-Length: 4\r\n\r\ntest")); + $result = StaticClient::get($this->getServer()->getUrl(), array('stream' => $stream)); + $this->assertSame($resource, $result); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/UrlTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/UrlTest.php new file mode 100644 index 0000000..28f2671 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/UrlTest.php @@ -0,0 +1,303 @@ +assertEquals('', (string) $url); + } + + public function testPortIsDeterminedFromScheme() + { + $this->assertEquals(80, Url::factory('http://www.test.com/')->getPort()); + $this->assertEquals(443, Url::factory('https://www.test.com/')->getPort()); + $this->assertEquals(null, Url::factory('ftp://www.test.com/')->getPort()); + $this->assertEquals(8192, Url::factory('http://www.test.com:8192/')->getPort()); + } + + public function testCloneCreatesNewInternalObjects() + { + $u1 = Url::factory('http://www.test.com/'); + $u2 = clone $u1; + $this->assertNotSame($u1->getQuery(), $u2->getQuery()); + } + + public function testValidatesUrlPartsInFactory() + { + $url = Url::factory('/index.php'); + $this->assertEquals('/index.php', (string) $url); + $this->assertFalse($url->isAbsolute()); + + $url = 'http://michael:test@test.com:80/path/123?q=abc#test'; + $u = Url::factory($url); + $this->assertEquals('http://michael:test@test.com/path/123?q=abc#test', (string) $u); + $this->assertTrue($u->isAbsolute()); + } + + public function testAllowsFalsyUrlParts() + { + $url = Url::factory('http://0:50/0?0#0'); + $this->assertSame('0', $url->getHost()); + $this->assertEquals(50, $url->getPort()); + $this->assertSame('/0', $url->getPath()); + $this->assertEquals('0', (string) $url->getQuery()); + $this->assertSame('0', $url->getFragment()); + $this->assertEquals('http://0:50/0?0#0', (string) $url); + + $url = Url::factory(''); + $this->assertSame('', (string) $url); + + $url = Url::factory('0'); + $this->assertSame('0', (string) $url); + } + + public function testBuildsRelativeUrlsWithFalsyParts() + { + $url = Url::buildUrl(array( + 'host' => '0', + 'path' => '0', + )); + + $this->assertSame('//0/0', $url); + + $url = Url::buildUrl(array( + 'path' => '0', + )); + $this->assertSame('0', $url); + } + + public function testUrlStoresParts() + { + $url = Url::factory('http://test:pass@www.test.com:8081/path/path2/?a=1&b=2#fragment'); + $this->assertEquals('http', $url->getScheme()); + $this->assertEquals('test', $url->getUsername()); + $this->assertEquals('pass', $url->getPassword()); + $this->assertEquals('www.test.com', $url->getHost()); + $this->assertEquals(8081, $url->getPort()); + $this->assertEquals('/path/path2/', $url->getPath()); + $this->assertEquals('fragment', $url->getFragment()); + $this->assertEquals('a=1&b=2', (string) $url->getQuery()); + + $this->assertEquals(array( + 'fragment' => 'fragment', + 'host' => 'www.test.com', + 'pass' => 'pass', + 'path' => '/path/path2/', + 'port' => 8081, + 'query' => 'a=1&b=2', + 'scheme' => 'http', + 'user' => 'test' + ), $url->getParts()); + } + + public function testHandlesPathsCorrectly() + { + $url = Url::factory('http://www.test.com'); + $this->assertEquals('', $url->getPath()); + $url->setPath('test'); + $this->assertEquals('test', $url->getPath()); + + $url->setPath('/test/123/abc'); + $this->assertEquals(array('test', '123', 'abc'), $url->getPathSegments()); + + $parts = parse_url('http://www.test.com/test'); + $parts['path'] = ''; + $this->assertEquals('http://www.test.com', Url::buildUrl($parts)); + $parts['path'] = 'test'; + $this->assertEquals('http://www.test.com/test', Url::buildUrl($parts)); + } + + public function testAddsQueryStringIfPresent() + { + $this->assertEquals('?foo=bar', Url::buildUrl(array( + 'query' => 'foo=bar' + ))); + } + + public function testAddsToPath() + { + // Does nothing here + $this->assertEquals('http://e.com/base?a=1', (string) Url::factory('http://e.com/base?a=1')->addPath(false)); + $this->assertEquals('http://e.com/base?a=1', (string) Url::factory('http://e.com/base?a=1')->addPath(null)); + $this->assertEquals('http://e.com/base?a=1', (string) Url::factory('http://e.com/base?a=1')->addPath(array())); + $this->assertEquals('http://e.com/base?a=1', (string) Url::factory('http://e.com/base?a=1')->addPath(new \stdClass())); + $this->assertEquals('http://e.com/base?a=1', (string) Url::factory('http://e.com/base?a=1')->addPath('')); + $this->assertEquals('http://e.com/base?a=1', (string) Url::factory('http://e.com/base?a=1')->addPath('/')); + $this->assertEquals('http://e.com/baz/foo', (string) Url::factory('http://e.com/baz/')->addPath('foo')); + $this->assertEquals('http://e.com/base/relative?a=1', (string) Url::factory('http://e.com/base?a=1')->addPath('relative')); + $this->assertEquals('http://e.com/base/relative?a=1', (string) Url::factory('http://e.com/base?a=1')->addPath('/relative')); + $this->assertEquals('http://e.com/base/0', (string) Url::factory('http://e.com/base')->addPath('0')); + $this->assertEquals('http://e.com/base/0/1', (string) Url::factory('http://e.com/base')->addPath('0')->addPath('1')); + } + + /** + * URL combination data provider + * + * @return array + */ + public function urlCombineDataProvider() + { + return array( + array('http://www.example.com/', 'http://www.example.com/', 'http://www.example.com/'), + array('http://www.example.com/path', '/absolute', 'http://www.example.com/absolute'), + array('http://www.example.com/path', '/absolute?q=2', 'http://www.example.com/absolute?q=2'), + array('http://www.example.com/path', 'more', 'http://www.example.com/path/more'), + array('http://www.example.com/path', 'more?q=1', 'http://www.example.com/path/more?q=1'), + array('http://www.example.com/', '?q=1', 'http://www.example.com/?q=1'), + array('http://www.example.com/path', 'http://test.com', 'http://test.com'), + array('http://www.example.com:8080/path', 'http://test.com', 'http://test.com'), + array('http://www.example.com:8080/path', '?q=2#abc', 'http://www.example.com:8080/path?q=2#abc'), + array('http://u:a@www.example.com/path', 'test', 'http://u:a@www.example.com/path/test'), + array('http://www.example.com/path', 'http://u:a@www.example.com/', 'http://u:a@www.example.com/'), + array('/path?q=2', 'http://www.test.com/', 'http://www.test.com/path?q=2'), + array('http://api.flickr.com/services/', 'http://www.flickr.com/services/oauth/access_token', 'http://www.flickr.com/services/oauth/access_token'), + array('http://www.example.com/?foo=bar', 'some/path', 'http://www.example.com/some/path?foo=bar'), + array('http://www.example.com/?foo=bar', 'some/path?boo=moo', 'http://www.example.com/some/path?boo=moo&foo=bar'), + array('http://www.example.com/some/', 'path?foo=bar&foo=baz', 'http://www.example.com/some/path?foo=bar&foo=baz'), + ); + } + + /** + * @dataProvider urlCombineDataProvider + */ + public function testCombinesUrls($a, $b, $c) + { + $this->assertEquals($c, (string) Url::factory($a)->combine($b)); + } + + public function testHasGettersAndSetters() + { + $url = Url::factory('http://www.test.com/'); + $this->assertEquals('example.com', $url->setHost('example.com')->getHost()); + $this->assertEquals('8080', $url->setPort(8080)->getPort()); + $this->assertEquals('/foo/bar', $url->setPath(array('foo', 'bar'))->getPath()); + $this->assertEquals('a', $url->setPassword('a')->getPassword()); + $this->assertEquals('b', $url->setUsername('b')->getUsername()); + $this->assertEquals('abc', $url->setFragment('abc')->getFragment()); + $this->assertEquals('https', $url->setScheme('https')->getScheme()); + $this->assertEquals('a=123', (string) $url->setQuery('a=123')->getQuery()); + $this->assertEquals('https://b:a@example.com:8080/foo/bar?a=123#abc', (string) $url); + $this->assertEquals('b=boo', (string) $url->setQuery(new QueryString(array( + 'b' => 'boo' + )))->getQuery()); + $this->assertEquals('https://b:a@example.com:8080/foo/bar?b=boo#abc', (string) $url); + } + + public function testSetQueryAcceptsArray() + { + $url = Url::factory('http://www.test.com'); + $url->setQuery(array('a' => 'b')); + $this->assertEquals('http://www.test.com?a=b', (string) $url); + } + + public function urlProvider() + { + return array( + array('/foo/..', '/'), + array('//foo//..', '/'), + array('/foo/../..', '/'), + array('/foo/../.', '/'), + array('/./foo/..', '/'), + array('/./foo', '/foo'), + array('/./foo/', '/foo/'), + array('/./foo/bar/baz/pho/../..', '/foo/bar'), + array('*', '*'), + array('/foo', '/foo'), + array('/abc/123/../foo/', '/abc/foo/'), + array('/a/b/c/./../../g', '/a/g'), + array('/b/c/./../../g', '/g'), + array('/b/c/./../../g', '/g'), + array('/c/./../../g', '/g'), + array('/./../../g', '/g'), + ); + } + + /** + * @dataProvider urlProvider + */ + public function testNormalizesPaths($path, $result) + { + $url = Url::factory('http://www.example.com/'); + $url->setPath($path)->normalizePath(); + $this->assertEquals($result, $url->getPath()); + } + + public function testSettingHostWithPortModifiesPort() + { + $url = Url::factory('http://www.example.com'); + $url->setHost('foo:8983'); + $this->assertEquals('foo', $url->getHost()); + $this->assertEquals(8983, $url->getPort()); + } + + /** + * @expectedException \Guzzle\Common\Exception\InvalidArgumentException + */ + public function testValidatesUrlCanBeParsed() + { + Url::factory('foo:////'); + } + + public function testConvertsSpecialCharsInPathWhenCastingToString() + { + $url = Url::factory('http://foo.com/baz bar?a=b'); + $url->addPath('?'); + $this->assertEquals('http://foo.com/baz%20bar/%3F?a=b', (string) $url); + } + + /** + * @link http://tools.ietf.org/html/rfc3986#section-5.4.1 + */ + public function rfc3986UrlProvider() + { + $result = array( + array('g', 'http://a/b/c/g'), + array('./g', 'http://a/b/c/g'), + array('g/', 'http://a/b/c/g/'), + array('/g', 'http://a/g'), + array('?y', 'http://a/b/c/d;p?y'), + array('g?y', 'http://a/b/c/g?y'), + array('#s', 'http://a/b/c/d;p?q#s'), + array('g#s', 'http://a/b/c/g#s'), + array('g?y#s', 'http://a/b/c/g?y#s'), + array(';x', 'http://a/b/c/;x'), + array('g;x', 'http://a/b/c/g;x'), + array('g;x?y#s', 'http://a/b/c/g;x?y#s'), + array('', 'http://a/b/c/d;p?q'), + array('.', 'http://a/b/c'), + array('./', 'http://a/b/c/'), + array('..', 'http://a/b'), + array('../', 'http://a/b/'), + array('../g', 'http://a/b/g'), + array('../..', 'http://a/'), + array('../../', 'http://a/'), + array('../../g', 'http://a/g') + ); + + // This support was added in PHP 5.4.7: https://bugs.php.net/bug.php?id=62844 + if (version_compare(PHP_VERSION, '5.4.7', '>=')) { + $result[] = array('//g', 'http://g'); + } + + return $result; + } + + /** + * @dataProvider rfc3986UrlProvider + */ + public function testCombinesUrlsUsingRfc3986($relative, $result) + { + $a = Url::factory('http://a/b/c/d;p?q'); + $b = Url::factory($relative); + $this->assertEquals($result, trim((string) $a->combine($b, true), '=')); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/server.js b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/server.js new file mode 100644 index 0000000..4156f1a --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Http/server.js @@ -0,0 +1,146 @@ +/** + * Guzzle node.js test server to return queued responses to HTTP requests and + * expose a RESTful API for enqueueing responses and retrieving the requests + * that have been received. + * + * - Delete all requests that have been received: + * DELETE /guzzle-server/requests + * Host: 127.0.0.1:8124 + * + * - Enqueue responses + * PUT /guzzle-server/responses + * Host: 127.0.0.1:8124 + * + * [{ "statusCode": 200, "reasonPhrase": "OK", "headers": {}, "body": "" }] + * + * - Get the received requests + * GET /guzzle-server/requests + * Host: 127.0.0.1:8124 + * + * - Shutdown the server + * DELETE /guzzle-server + * Host: 127.0.0.1:8124 + * + * @package Guzzle PHP + * @license See the LICENSE file that was distributed with this source code. + */ + +var http = require("http"); + +/** + * Guzzle node.js server + * @class + */ +var GuzzleServer = function(port, log) { + + this.port = port; + this.log = log; + this.responses = []; + this.requests = []; + var that = this; + + var controlRequest = function(request, req, res) { + if (req.url == '/guzzle-server/perf') { + res.writeHead(200, "OK", {"Content-Length": 16}); + res.end("Body of response"); + } else if (req.method == "DELETE") { + if (req.url == "/guzzle-server/requests") { + // Clear the received requests + that.requests = []; + res.writeHead(200, "OK", { "Content-Length": 0 }); + res.end(); + if (this.log) { + console.log("Flushing requests"); + } + } else if (req.url == "/guzzle-server") { + // Shutdown the server + res.writeHead(200, "OK", { "Content-Length": 0, "Connection": "close" }); + res.end(); + if (this.log) { + console.log("Shutting down"); + } + that.server.close(); + } + } else if (req.method == "GET") { + if (req.url === "/guzzle-server/requests") { + // Get received requests + var data = that.requests.join("\n----[request]\n"); + res.writeHead(200, "OK", { "Content-Length": data.length }); + res.end(data); + if (that.log) { + console.log("Sending receiving requests"); + } + } + } else if (req.method == "PUT") { + if (req.url == "/guzzle-server/responses") { + if (that.log) { + console.log("Adding responses..."); + } + // Received response to queue + var data = request.split("\r\n\r\n")[1]; + if (!data) { + if (that.log) { + console.log("No response data was provided"); + } + res.writeHead(400, "NO RESPONSES IN REQUEST", { "Content-Length": 0 }); + } else { + that.responses = eval("(" + data + ")"); + if (that.log) { + console.log(that.responses); + } + res.writeHead(200, "OK", { "Content-Length": 0 }); + } + res.end(); + } + } + }; + + var receivedRequest = function(request, req, res) { + if (req.url.indexOf("/guzzle-server") === 0) { + controlRequest(request, req, res); + } else if (req.url.indexOf("/guzzle-server") == -1 && !that.responses.length) { + res.writeHead(500); + res.end("No responses in queue"); + } else { + var response = that.responses.shift(); + res.writeHead(response.statusCode, response.reasonPhrase, response.headers); + res.end(response.body); + that.requests.push(request); + } + }; + + this.start = function() { + + that.server = http.createServer(function(req, res) { + + var request = req.method + " " + req.url + " HTTP/" + req.httpVersion + "\r\n"; + for (var i in req.headers) { + request += i + ": " + req.headers[i] + "\r\n"; + } + request += "\r\n"; + + // Receive each chunk of the request body + req.addListener("data", function(chunk) { + request += chunk; + }); + + // Called when the request completes + req.addListener("end", function() { + receivedRequest(request, req, res); + }); + }); + that.server.listen(port, "127.0.0.1"); + + if (this.log) { + console.log("Server running at http://127.0.0.1:8124/"); + } + }; +}; + +// Get the port from the arguments +port = process.argv.length >= 3 ? process.argv[2] : 8124; +log = process.argv.length >= 4 ? process.argv[3] : false; + +// Start the server +server = new GuzzleServer(port, log); +server.start(); diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Inflection/InflectorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Inflection/InflectorTest.php new file mode 100644 index 0000000..990c0af --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Inflection/InflectorTest.php @@ -0,0 +1,37 @@ +assertSame(Inflector::getDefault(), Inflector::getDefault()); + } + + public function testSnake() + { + $this->assertEquals('camel_case', Inflector::getDefault()->snake('camelCase')); + $this->assertEquals('camel_case', Inflector::getDefault()->snake('CamelCase')); + $this->assertEquals('camel_case_words', Inflector::getDefault()->snake('CamelCaseWords')); + $this->assertEquals('camel_case_words', Inflector::getDefault()->snake('CamelCase_words')); + $this->assertEquals('test', Inflector::getDefault()->snake('test')); + $this->assertEquals('test', Inflector::getDefault()->snake('test')); + $this->assertEquals('expect100_continue', Inflector::getDefault()->snake('Expect100Continue')); + } + + public function testCamel() + { + $this->assertEquals('CamelCase', Inflector::getDefault()->camel('camel_case')); + $this->assertEquals('CamelCaseWords', Inflector::getDefault()->camel('camel_case_words')); + $this->assertEquals('Test', Inflector::getDefault()->camel('test')); + $this->assertEquals('Expect100Continue', ucfirst(Inflector::getDefault()->camel('expect100_continue'))); + // Get from cache + $this->assertEquals('Test', Inflector::getDefault()->camel('test', false)); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Inflection/MemoizingInflectorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Inflection/MemoizingInflectorTest.php new file mode 100644 index 0000000..f00b7fa --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Inflection/MemoizingInflectorTest.php @@ -0,0 +1,46 @@ +getMock('Guzzle\Inflection\Inflector', array('snake', 'camel')); + $mock->expects($this->once())->method('snake')->will($this->returnValue('foo_bar')); + $mock->expects($this->once())->method('camel')->will($this->returnValue('FooBar')); + + $inflector = new MemoizingInflector($mock); + $this->assertEquals('foo_bar', $inflector->snake('FooBar')); + $this->assertEquals('foo_bar', $inflector->snake('FooBar')); + $this->assertEquals('FooBar', $inflector->camel('foo_bar')); + $this->assertEquals('FooBar', $inflector->camel('foo_bar')); + } + + public function testProtectsAgainstCacheOverflow() + { + $inflector = new MemoizingInflector(new Inflector(), 10); + for ($i = 1; $i < 11; $i++) { + $inflector->camel('foo_' . $i); + $inflector->snake('Foo' . $i); + } + + $cache = $this->readAttribute($inflector, 'cache'); + $this->assertEquals(10, count($cache['snake'])); + $this->assertEquals(10, count($cache['camel'])); + + $inflector->camel('baz!'); + $inflector->snake('baz!'); + + // Now ensure that 20% of the cache was removed (2), then the item was added + $cache = $this->readAttribute($inflector, 'cache'); + $this->assertEquals(9, count($cache['snake'])); + $this->assertEquals(9, count($cache['camel'])); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Inflection/PreComputedInflectorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Inflection/PreComputedInflectorTest.php new file mode 100644 index 0000000..ff2654c --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Inflection/PreComputedInflectorTest.php @@ -0,0 +1,45 @@ +getMock('Guzzle\Inflection\Inflector', array('snake', 'camel')); + $mock->expects($this->once())->method('snake')->with('Test')->will($this->returnValue('test')); + $mock->expects($this->once())->method('camel')->with('Test')->will($this->returnValue('Test')); + $inflector = new PreComputedInflector($mock, array('FooBar' => 'foo_bar'), array('foo_bar' => 'FooBar')); + $this->assertEquals('FooBar', $inflector->camel('foo_bar')); + $this->assertEquals('foo_bar', $inflector->snake('FooBar')); + $this->assertEquals('Test', $inflector->camel('Test')); + $this->assertEquals('test', $inflector->snake('Test')); + } + + public function testMirrorsPrecomputedValues() + { + $mock = $this->getMock('Guzzle\Inflection\Inflector', array('snake', 'camel')); + $mock->expects($this->never())->method('snake'); + $mock->expects($this->never())->method('camel'); + $inflector = new PreComputedInflector($mock, array('Zeep' => 'zeep'), array(), true); + $this->assertEquals('Zeep', $inflector->camel('zeep')); + $this->assertEquals('zeep', $inflector->snake('Zeep')); + } + + public function testMirrorsPrecomputedValuesByMerging() + { + $mock = $this->getMock('Guzzle\Inflection\Inflector', array('snake', 'camel')); + $mock->expects($this->never())->method('snake'); + $mock->expects($this->never())->method('camel'); + $inflector = new PreComputedInflector($mock, array('Zeep' => 'zeep'), array('foo' => 'Foo'), true); + $this->assertEquals('Zeep', $inflector->camel('zeep')); + $this->assertEquals('zeep', $inflector->snake('Zeep')); + $this->assertEquals('Foo', $inflector->camel('foo')); + $this->assertEquals('foo', $inflector->snake('Foo')); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Iterator/AppendIteratorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Iterator/AppendIteratorTest.php new file mode 100644 index 0000000..8d6ae84 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Iterator/AppendIteratorTest.php @@ -0,0 +1,29 @@ + 1, + 'b' => 2 + )); + $b = new \ArrayIterator(array()); + $c = new \ArrayIterator(array( + 'c' => 3, + 'd' => 4 + )); + $i = new AppendIterator(); + $i->append($a); + $i->append($b); + $i->append($c); + $this->assertEquals(array(1, 2, 3, 4), iterator_to_array($i, false)); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Iterator/ChunkedIteratorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Iterator/ChunkedIteratorTest.php new file mode 100644 index 0000000..5d474b5 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Iterator/ChunkedIteratorTest.php @@ -0,0 +1,60 @@ +assertEquals(11, count($chunks)); + foreach ($chunks as $j => $chunk) { + $this->assertEquals(range($j * 10, min(100, $j * 10 + 9)), $chunk); + } + } + + public function testChunksIteratorWithOddValues() + { + $chunked = new ChunkedIterator(new \ArrayIterator(array(1, 2, 3, 4, 5)), 2); + $chunks = iterator_to_array($chunked, false); + $this->assertEquals(3, count($chunks)); + $this->assertEquals(array(1, 2), $chunks[0]); + $this->assertEquals(array(3, 4), $chunks[1]); + $this->assertEquals(array(5), $chunks[2]); + } + + /** + * @test + * @runInSeparateProcess + */ + public function mustNotTerminateWithTraversable() + { + $traversable = simplexml_load_string('')->foo; + $chunked = new ChunkedIterator($traversable, 2); + $actual = iterator_to_array($chunked, false); + $this->assertCount(2, $actual); + } + + /** + * @test + */ + public function sizeOfZeroMakesIteratorInvalid() { + $chunked = new ChunkedIterator(new \ArrayIterator(range(1, 5)), 0); + $chunked->rewind(); + $this->assertFalse($chunked->valid()); + } + + /** + * @test + * @expectedException \InvalidArgumentException + */ + public function sizeLowerZeroThrowsException() { + $chunked = new ChunkedIterator(new \ArrayIterator(range(1, 5)), -1); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Iterator/FilterIteratorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Iterator/FilterIteratorTest.php new file mode 100644 index 0000000..73b4f69 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Iterator/FilterIteratorTest.php @@ -0,0 +1,28 @@ +assertEquals(range(1, 99, 2), iterator_to_array($i, false)); + } + + /** + * @expectedException \InvalidArgumentException + */ + public function testValidatesCallable() + { + $i = new FilterIterator(new \ArrayIterator(), new \stdClass()); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Iterator/MapIteratorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Iterator/MapIteratorTest.php new file mode 100644 index 0000000..4de4a6b --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Iterator/MapIteratorTest.php @@ -0,0 +1,28 @@ +assertEquals(range(0, 1000, 10), iterator_to_array($i, false)); + } + + /** + * @expectedException \InvalidArgumentException + */ + public function testValidatesCallable() + { + $i = new MapIterator(new \ArrayIterator(), new \stdClass()); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Iterator/MethodProxyIteratorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Iterator/MethodProxyIteratorTest.php new file mode 100644 index 0000000..5bcf06f --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Iterator/MethodProxyIteratorTest.php @@ -0,0 +1,28 @@ +append('a'); + $proxy->append('b'); + $this->assertEquals(array('a', 'b'), $i->getArrayCopy()); + $this->assertEquals(array('a', 'b'), $proxy->getArrayCopy()); + } + + public function testUsesInnerIterator() + { + $i = new MethodProxyIterator(new ChunkedIterator(new \ArrayIterator(array(1, 2, 3, 4, 5)), 2)); + $this->assertEquals(3, count(iterator_to_array($i, false))); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Log/ArrayLogAdapterTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Log/ArrayLogAdapterTest.php new file mode 100644 index 0000000..95033e0 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Log/ArrayLogAdapterTest.php @@ -0,0 +1,23 @@ +log('test', \LOG_NOTICE, 'localhost'); + $this->assertEquals(array(array('message' => 'test', 'priority' => \LOG_NOTICE, 'extras' => 'localhost')), $adapter->getLogs()); + } + + public function testClearLog() + { + $adapter = new ArrayLogAdapter(); + $adapter->log('test', \LOG_NOTICE, 'localhost'); + $adapter->clearLogs(); + $this->assertEquals(array(), $adapter->getLogs()); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Log/ClosureLogAdapterTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Log/ClosureLogAdapterTest.php new file mode 100644 index 0000000..7d1aa16 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Log/ClosureLogAdapterTest.php @@ -0,0 +1,30 @@ +adapter = new ClosureLogAdapter(function($message, $priority, $extras = null) use ($that, &$modified) { + $modified = array($message, $priority, $extras); + }); + $this->adapter->log('test', LOG_NOTICE, 'localhost'); + $this->assertEquals(array('test', LOG_NOTICE, 'localhost'), $modified); + } + + /** + * @expectedException InvalidArgumentException + */ + public function testThrowsExceptionWhenNotCallable() + { + $this->adapter = new ClosureLogAdapter(123); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Log/MessageFormatterTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Log/MessageFormatterTest.php new file mode 100644 index 0000000..3851724 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Log/MessageFormatterTest.php @@ -0,0 +1,143 @@ +request = new EntityEnclosingRequest('POST', 'http://foo.com?q=test', array( + 'X-Foo' => 'bar', + 'Authorization' => 'Baz' + )); + $this->request->setBody(EntityBody::factory('Hello')); + + $this->response = new Response(200, array( + 'X-Test' => 'Abc' + ), 'Foo'); + + $this->handle = $this->getMockBuilder('Guzzle\Http\Curl\CurlHandle') + ->disableOriginalConstructor() + ->setMethods(array('getError', 'getErrorNo', 'getStderr', 'getInfo')) + ->getMock(); + + $this->handle->expects($this->any()) + ->method('getError') + ->will($this->returnValue('e')); + + $this->handle->expects($this->any()) + ->method('getErrorNo') + ->will($this->returnValue('123')); + + $this->handle->expects($this->any()) + ->method('getStderr') + ->will($this->returnValue('testing')); + + $this->handle->expects($this->any()) + ->method('getInfo') + ->will($this->returnValueMap(array( + array(CURLINFO_CONNECT_TIME, '123'), + array(CURLINFO_TOTAL_TIME, '456') + ))); + } + + public function logProvider() + { + return array( + // Uses the cache for the second time + array('{method} - {method}', 'POST - POST'), + array('{url}', 'http://foo.com?q=test'), + array('{port}', '80'), + array('{resource}', '/?q=test'), + array('{host}', 'foo.com'), + array('{hostname}', gethostname()), + array('{protocol}/{version}', 'HTTP/1.1'), + array('{code} {phrase}', '200 OK'), + array('{req_header_Foo}', ''), + array('{req_header_X-Foo}', 'bar'), + array('{req_header_Authorization}', 'Baz'), + array('{res_header_foo}', ''), + array('{res_header_X-Test}', 'Abc'), + array('{req_body}', 'Hello'), + array('{res_body}', 'Foo'), + array('{curl_stderr}', 'testing'), + array('{curl_error}', 'e'), + array('{curl_code}', '123'), + array('{connect_time}', '123'), + array('{total_time}', '456') + ); + } + + /** + * @dataProvider logProvider + */ + public function testFormatsMessages($template, $output) + { + $formatter = new MessageFormatter($template); + $this->assertEquals($output, $formatter->format($this->request, $this->response, $this->handle)); + } + + public function testFormatsRequestsAndResponses() + { + $formatter = new MessageFormatter(); + $formatter->setTemplate('{request}{response}'); + $this->assertEquals($this->request . $this->response, $formatter->format($this->request, $this->response)); + } + + public function testAddsTimestamp() + { + $formatter = new MessageFormatter('{ts}'); + $this->assertNotEmpty($formatter->format($this->request, $this->response)); + } + + public function testUsesResponseWhenNoHandleAndGettingCurlInformation() + { + $formatter = new MessageFormatter('{connect_time}/{total_time}'); + $response = $this->getMockBuilder('Guzzle\Http\Message\Response') + ->disableOriginalConstructor() + ->setMethods(array('getInfo')) + ->getMock(); + $response->expects($this->exactly(2)) + ->method('getInfo') + ->will($this->returnValueMap(array( + array('connect_time', '1'), + array('total_time', '2'), + ))); + $this->assertEquals('1/2', $formatter->format($this->request, $response)); + } + + public function testUsesEmptyStringWhenNoHandleAndNoResponse() + { + $formatter = new MessageFormatter('{connect_time}/{total_time}'); + $this->assertEquals('/', $formatter->format($this->request)); + } + + public function testInjectsTotalTime() + { + $out = ''; + $formatter = new MessageFormatter('{connect_time}/{total_time}'); + $adapter = new ClosureLogAdapter(function ($m) use (&$out) { $out .= $m; }); + $log = new LogPlugin($adapter, $formatter); + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 2\r\n\r\nHI"); + $client = new Client($this->getServer()->getUrl()); + $client->addSubscriber($log); + $client->get('/')->send(); + $this->assertNotEquals('/', $out); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Log/PsrLogAdapterTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Log/PsrLogAdapterTest.php new file mode 100644 index 0000000..7b72dd6 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Log/PsrLogAdapterTest.php @@ -0,0 +1,25 @@ +pushHandler($handler); + $adapter = new PsrLogAdapter($log); + $adapter->log('test!', LOG_INFO); + $this->assertTrue($handler->hasInfoRecords()); + $this->assertSame($log, $adapter->getLogObject()); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Log/Zf2LogAdapterTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Log/Zf2LogAdapterTest.php new file mode 100644 index 0000000..1b61283 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Log/Zf2LogAdapterTest.php @@ -0,0 +1,51 @@ +stream = fopen('php://temp', 'r+'); + $this->log = new Logger(); + $this->log->addWriter(new Stream($this->stream)); + $this->adapter = new Zf2LogAdapter($this->log); + + } + + public function testLogsMessagesToAdaptedObject() + { + // Test without a priority + $this->adapter->log('Zend_Test!', \LOG_NOTICE); + rewind($this->stream); + $contents = stream_get_contents($this->stream); + $this->assertEquals(1, substr_count($contents, 'Zend_Test!')); + + // Test with a priority + $this->adapter->log('Zend_Test!', \LOG_ALERT); + rewind($this->stream); + $contents = stream_get_contents($this->stream); + $this->assertEquals(2, substr_count($contents, 'Zend_Test!')); + } + + public function testExposesAdaptedLogObject() + { + $this->assertEquals($this->log, $this->adapter->getLogObject()); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Mock/CustomResponseModel.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Mock/CustomResponseModel.php new file mode 100644 index 0000000..3fb6527 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Mock/CustomResponseModel.php @@ -0,0 +1,21 @@ +command = $command; + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Mock/ErrorResponseMock.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Mock/ErrorResponseMock.php new file mode 100644 index 0000000..aabb15f --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Mock/ErrorResponseMock.php @@ -0,0 +1,25 @@ +command = $command; + $this->response = $response; + $this->message = 'Error from ' . $response; + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Mock/ExceptionMock.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Mock/ExceptionMock.php new file mode 100644 index 0000000..97a1974 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Mock/ExceptionMock.php @@ -0,0 +1,11 @@ +multiHandle; + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Mock/MockObserver.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Mock/MockObserver.php new file mode 100644 index 0000000..11e22eb --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Mock/MockObserver.php @@ -0,0 +1,65 @@ +events as $event) { + if ($event->getName() == $eventName) { + return true; + } + } + + return false; + } + + public function getLastEvent() + { + return end($this->events); + } + + public function count() + { + return count($this->events); + } + + public function getGrouped() + { + $events = array(); + foreach ($this->events as $event) { + if (!isset($events[$event->getName()])) { + $events[$event->getName()] = array(); + } + $events[$event->getName()][] = $event; + } + + return $events; + } + + public function getData($event, $key, $occurrence = 0) + { + $grouped = $this->getGrouped(); + if (isset($grouped[$event])) { + return $grouped[$event][$occurrence][$key]; + } + + return null; + } + + public function update(Event $event) + { + $this->events[] = $event; + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Mock/MockSubject.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Mock/MockSubject.php new file mode 100644 index 0000000..e011959 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Mock/MockSubject.php @@ -0,0 +1,7 @@ + 'allseeing-i.com', + 'path' => '/', + 'data' => array( + 'PHPSESSID' => '6c951590e7a9359bcedde25cda73e43c' + ), + 'max_age' => NULL, + 'expires' => 'Sat, 26-Jul-2008 17:00:42 GMT', + 'version' => NULL, + 'secure' => NULL, + 'discard' => NULL, + 'port' => NULL, + 'cookies' => array( + 'ASIHTTPRequestTestCookie' => 'This+is+the+value' + ), + 'comment' => null, + 'comment_url' => null, + 'http_only' => false + ) + ), + array('', false), + array('foo', false), + // Test setting a blank value for a cookie + array(array( + 'foo=', 'foo =', 'foo =;', 'foo= ;', 'foo =', 'foo= '), + array( + 'cookies' => array( + 'foo' => '' + ), + 'data' => array(), + 'discard' => null, + 'domain' => null, + 'expires' => null, + 'max_age' => null, + 'path' => '/', + 'port' => null, + 'secure' => null, + 'version' => null, + 'comment' => null, + 'comment_url' => null, + 'http_only' => false + ) + ), + // Test setting a value and removing quotes + array(array( + 'foo=1', 'foo =1', 'foo =1;', 'foo=1 ;', 'foo =1', 'foo= 1', 'foo = 1 ;', 'foo="1"', 'foo="1";', 'foo= "1";'), + array( + 'cookies' => array( + 'foo' => '1' + ), + 'data' => array(), + 'discard' => null, + 'domain' => null, + 'expires' => null, + 'max_age' => null, + 'path' => '/', + 'port' => null, + 'secure' => null, + 'version' => null, + 'comment' => null, + 'comment_url' => null, + 'http_only' => false + ) + ), + // Test setting multiple values + array(array( + 'foo=1; bar=2;', 'foo =1; bar = "2"', 'foo=1; bar=2'), + array( + 'cookies' => array( + 'foo' => '1', + 'bar' => '2', + ), + 'data' => array(), + 'discard' => null, + 'domain' => null, + 'expires' => null, + 'max_age' => null, + 'path' => '/', + 'port' => null, + 'secure' => null, + 'version' => null, + 'comment' => null, + 'comment_url' => null, + 'http_only' => false + ) + ), + // Tests getting the domain and path from a reference request + array(array( + 'foo=1; port="80,8081"; httponly', 'foo=1; port="80,8081"; domain=www.test.com; HttpOnly;', 'foo=1; ; domain=www.test.com; path=/path; port="80,8081"; HttpOnly;'), + array( + 'cookies' => array( + 'foo' => 1 + ), + 'data' => array(), + 'discard' => null, + 'domain' => 'www.test.com', + 'expires' => null, + 'max_age' => null, + 'path' => '/path', + 'port' => array('80', '8081'), + 'secure' => null, + 'version' => null, + 'comment' => null, + 'comment_url' => null, + 'http_only' => true + ), + 'http://www.test.com/path/' + ), + // Some of the following tests are based on http://framework.zend.com/svn/framework/standard/trunk/tests/Zend/Http/CookieTest.php + array( + 'justacookie=foo; domain=example.com', + array( + 'cookies' => array( + 'justacookie' => 'foo' + ), + 'domain' => 'example.com', + 'data' => array(), + 'discard' => null, + 'expires' => null, + 'max_age' => null, + 'path' => '/', + 'port' => null, + 'secure' => null, + 'version' => null, + 'comment' => null, + 'comment_url' => null, + 'http_only' => false + ) + ), + array( + 'expires=tomorrow; secure; path=/Space Out/; expires=Tue, 21-Nov-2006 08:33:44 GMT; domain=.example.com', + array( + 'cookies' => array( + 'expires' => 'tomorrow' + ), + 'domain' => '.example.com', + 'path' => '/Space Out/', + 'expires' => 'Tue, 21-Nov-2006 08:33:44 GMT', + 'data' => array(), + 'discard' => null, + 'port' => null, + 'secure' => true, + 'version' => null, + 'max_age' => null, + 'comment' => null, + 'comment_url' => null, + 'http_only' => false + ) + ), + array( + 'domain=unittests; expires=Tue, 21-Nov-2006 08:33:44 GMT; domain=example.com; path=/some value/', + array( + 'cookies' => array( + 'domain' => 'unittests' + ), + 'domain' => 'example.com', + 'path' => '/some value/', + 'expires' => 'Tue, 21-Nov-2006 08:33:44 GMT', + 'secure' => false, + 'data' => array(), + 'discard' => null, + 'max_age' => null, + 'port' => null, + 'version' => null, + 'comment' => null, + 'comment_url' => null, + 'http_only' => false + ) + ), + array( + 'path=indexAction; path=/; domain=.foo.com; expires=Tue, 21-Nov-2006 08:33:44 GMT', + array( + 'cookies' => array( + 'path' => 'indexAction' + ), + 'domain' => '.foo.com', + 'path' => '/', + 'expires' => 'Tue, 21-Nov-2006 08:33:44 GMT', + 'secure' => false, + 'data' => array(), + 'discard' => null, + 'max_age' => null, + 'port' => null, + 'version' => null, + 'comment' => null, + 'comment_url' => null, + 'http_only' => false + ) + ), + array( + 'secure=sha1; secure; SECURE; domain=some.really.deep.domain.com; version=1; Max-Age=86400', + array( + 'cookies' => array( + 'secure' => 'sha1' + ), + 'domain' => 'some.really.deep.domain.com', + 'path' => '/', + 'secure' => true, + 'data' => array(), + 'discard' => null, + 'expires' => time() + 86400, + 'max_age' => 86400, + 'port' => null, + 'version' => 1, + 'comment' => null, + 'comment_url' => null, + 'http_only' => false + ) + ), + array( + 'PHPSESSID=123456789+abcd%2Cef; secure; discard; domain=.localdomain; path=/foo/baz; expires=Tue, 21-Nov-2006 08:33:44 GMT;', + array( + 'cookies' => array( + 'PHPSESSID' => '123456789+abcd%2Cef' + ), + 'domain' => '.localdomain', + 'path' => '/foo/baz', + 'expires' => 'Tue, 21-Nov-2006 08:33:44 GMT', + 'secure' => true, + 'data' => array(), + 'discard' => true, + 'max_age' => null, + 'port' => null, + 'version' => null, + 'comment' => null, + 'comment_url' => null, + 'http_only' => false + ) + ), + // rfc6265#section-5.1.4 + array( + 'cookie=value', + array( + 'cookies' => array( + 'cookie' => 'value' + ), + 'domain' => 'example.com', + 'data' => array(), + 'discard' => null, + 'expires' => null, + 'max_age' => null, + 'path' => '/some/path', + 'port' => null, + 'secure' => null, + 'version' => null, + 'comment' => null, + 'comment_url' => null, + 'http_only' => false + ), + 'http://example.com/some/path/test.html' + ), + array( + 'empty=path', + array( + 'cookies' => array( + 'empty' => 'path' + ), + 'domain' => 'example.com', + 'data' => array(), + 'discard' => null, + 'expires' => null, + 'max_age' => null, + 'path' => '/', + 'port' => null, + 'secure' => null, + 'version' => null, + 'comment' => null, + 'comment_url' => null, + 'http_only' => false + ), + 'http://example.com/test.html' + ), + array( + 'baz=qux', + array( + 'cookies' => array( + 'baz' => 'qux' + ), + 'domain' => 'example.com', + 'data' => array(), + 'discard' => null, + 'expires' => null, + 'max_age' => null, + 'path' => '/', + 'port' => null, + 'secure' => null, + 'version' => null, + 'comment' => null, + 'comment_url' => null, + 'http_only' => false + ), + 'http://example.com?query=here' + ), + array( + 'test=noSlashPath; path=someString', + array( + 'cookies' => array( + 'test' => 'noSlashPath' + ), + 'domain' => 'example.com', + 'data' => array(), + 'discard' => null, + 'expires' => null, + 'max_age' => null, + 'path' => '/real/path', + 'port' => null, + 'secure' => null, + 'version' => null, + 'comment' => null, + 'comment_url' => null, + 'http_only' => false + ), + 'http://example.com/real/path/' + ), + ); + } + + /** + * @dataProvider cookieParserDataProvider + */ + public function testParseCookie($cookie, $parsed, $url = null) + { + $c = $this->cookieParserClass; + $parser = new $c(); + + $request = null; + if ($url) { + $url = Url::factory($url); + $host = $url->getHost(); + $path = $url->getPath(); + } else { + $host = ''; + $path = ''; + } + + foreach ((array) $cookie as $c) { + $p = $parser->parseCookie($c, $host, $path); + + // Remove expires values from the assertion if they are relatively equal by allowing a 5 minute difference + if ($p['expires'] != $parsed['expires']) { + if (abs($p['expires'] - $parsed['expires']) < 300) { + unset($p['expires']); + unset($parsed['expires']); + } + } + + if (is_array($parsed)) { + foreach ($parsed as $key => $value) { + $this->assertEquals($parsed[$key], $p[$key], 'Comparing ' . $key . ' ' . var_export($value, true) . ' : ' . var_export($parsed, true) . ' | ' . var_export($p, true)); + } + + foreach ($p as $key => $value) { + $this->assertEquals($p[$key], $parsed[$key], 'Comparing ' . $key . ' ' . var_export($value, true) . ' : ' . var_export($parsed, true) . ' | ' . var_export($p, true)); + } + } else { + $this->assertEquals($parsed, $p); + } + } + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/Cookie/CookieParserTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/Cookie/CookieParserTest.php new file mode 100644 index 0000000..75d336f --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/Cookie/CookieParserTest.php @@ -0,0 +1,22 @@ +parseCookie('foo=baz+bar', null, null, true); + $this->assertEquals(array( + 'foo' => 'baz bar' + ), $result['cookies']); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/Message/MessageParserProvider.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/Message/MessageParserProvider.php new file mode 100644 index 0000000..da58bb4 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/Message/MessageParserProvider.php @@ -0,0 +1,225 @@ + 'GET', + 'protocol' => 'HTTP', + 'version' => '1.1', + 'request_url' => array( + 'scheme' => 'http', + 'host' => '', + 'port' => '', + 'path' => '/', + 'query' => '' + ), + 'headers' => array(), + 'body' => '' + )), + // Path and query string, multiple header values per header and case sensitive storage + array("HEAD /path?query=foo HTTP/1.0\r\nHost: example.com\r\nX-Foo: foo\r\nx-foo: Bar\r\nX-Foo: foo\r\nX-Foo: Baz\r\n\r\n", array( + 'method' => 'HEAD', + 'protocol' => 'HTTP', + 'version' => '1.0', + 'request_url' => array( + 'scheme' => 'http', + 'host' => 'example.com', + 'port' => '', + 'path' => '/path', + 'query' => 'query=foo' + ), + 'headers' => array( + 'Host' => 'example.com', + 'X-Foo' => array('foo', 'foo', 'Baz'), + 'x-foo' => 'Bar' + ), + 'body' => '' + )), + // Includes a body + array("PUT / HTTP/1.0\r\nhost: example.com:443\r\nContent-Length: 4\r\n\r\ntest", array( + 'method' => 'PUT', + 'protocol' => 'HTTP', + 'version' => '1.0', + 'request_url' => array( + 'scheme' => 'https', + 'host' => 'example.com', + 'port' => '443', + 'path' => '/', + 'query' => '' + ), + 'headers' => array( + 'host' => 'example.com:443', + 'Content-Length' => '4' + ), + 'body' => 'test' + )), + // Includes Authorization headers + array("GET / HTTP/1.1\r\nHost: example.com:8080\r\nAuthorization: Basic {$auth}\r\n\r\n", array( + 'method' => 'GET', + 'protocol' => 'HTTP', + 'version' => '1.1', + 'request_url' => array( + 'scheme' => 'http', + 'host' => 'example.com', + 'port' => '8080', + 'path' => '/', + 'query' => '' + ), + 'headers' => array( + 'Host' => 'example.com:8080', + 'Authorization' => "Basic {$auth}" + ), + 'body' => '' + )), + // Include authorization header + array("GET / HTTP/1.1\r\nHost: example.com:8080\r\nauthorization: Basic {$auth}\r\n\r\n", array( + 'method' => 'GET', + 'protocol' => 'HTTP', + 'version' => '1.1', + 'request_url' => array( + 'scheme' => 'http', + 'host' => 'example.com', + 'port' => '8080', + 'path' => '/', + 'query' => '' + ), + 'headers' => array( + 'Host' => 'example.com:8080', + 'authorization' => "Basic {$auth}" + ), + 'body' => '' + )), + ); + } + + public function responseProvider() + { + return array( + // Empty request + array('', false), + + array("HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n", array( + 'protocol' => 'HTTP', + 'version' => '1.1', + 'code' => '200', + 'reason_phrase' => 'OK', + 'headers' => array( + 'Content-Length' => 0 + ), + 'body' => '' + )), + array("HTTP/1.0 400 Bad Request\r\nContent-Length: 0\r\n\r\n", array( + 'protocol' => 'HTTP', + 'version' => '1.0', + 'code' => '400', + 'reason_phrase' => 'Bad Request', + 'headers' => array( + 'Content-Length' => 0 + ), + 'body' => '' + )), + array("HTTP/1.0 100 Continue\r\n\r\n", array( + 'protocol' => 'HTTP', + 'version' => '1.0', + 'code' => '100', + 'reason_phrase' => 'Continue', + 'headers' => array(), + 'body' => '' + )), + array("HTTP/1.1 204 No Content\r\nX-Foo: foo\r\nx-foo: Bar\r\nX-Foo: foo\r\n\r\n", array( + 'protocol' => 'HTTP', + 'version' => '1.1', + 'code' => '204', + 'reason_phrase' => 'No Content', + 'headers' => array( + 'X-Foo' => array('foo', 'foo'), + 'x-foo' => 'Bar' + ), + 'body' => '' + )), + array("HTTP/1.1 200 Ok that is great!\r\nContent-Length: 4\r\n\r\nTest", array( + 'protocol' => 'HTTP', + 'version' => '1.1', + 'code' => '200', + 'reason_phrase' => 'Ok that is great!', + 'headers' => array( + 'Content-Length' => 4 + ), + 'body' => 'Test' + )), + ); + } + + public function compareRequestResults($result, $expected) + { + if (!$result) { + $this->assertFalse($expected); + return; + } + + $this->assertEquals($result['method'], $expected['method']); + $this->assertEquals($result['protocol'], $expected['protocol']); + $this->assertEquals($result['version'], $expected['version']); + $this->assertEquals($result['request_url'], $expected['request_url']); + $this->assertEquals($result['body'], $expected['body']); + $this->compareHttpHeaders($result['headers'], $expected['headers']); + } + + public function compareResponseResults($result, $expected) + { + if (!$result) { + $this->assertFalse($expected); + return; + } + + $this->assertEquals($result['protocol'], $expected['protocol']); + $this->assertEquals($result['version'], $expected['version']); + $this->assertEquals($result['code'], $expected['code']); + $this->assertEquals($result['reason_phrase'], $expected['reason_phrase']); + $this->assertEquals($result['body'], $expected['body']); + $this->compareHttpHeaders($result['headers'], $expected['headers']); + } + + protected function normalizeHeaders($headers) + { + $normalized = array(); + foreach ($headers as $key => $value) { + $key = strtolower($key); + if (!isset($normalized[$key])) { + $normalized[$key] = $value; + } elseif (!is_array($normalized[$key])) { + $normalized[$key] = array($value); + } else { + $normalized[$key][] = $value; + } + } + + foreach ($normalized as $key => &$value) { + if (is_array($value)) { + sort($value); + } + } + + return $normalized; + } + + public function compareHttpHeaders($result, $expected) + { + // Aggregate all headers case-insensitively + $result = $this->normalizeHeaders($result); + $expected = $this->normalizeHeaders($expected); + $this->assertEquals($result, $expected); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/Message/MessageParserTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/Message/MessageParserTest.php new file mode 100644 index 0000000..2f52228 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/Message/MessageParserTest.php @@ -0,0 +1,58 @@ +compareRequestResults($parts, $parser->parseRequest($message)); + } + + /** + * @dataProvider responseProvider + */ + public function testParsesResponses($message, $parts) + { + $parser = new MessageParser(); + $this->compareResponseResults($parts, $parser->parseResponse($message)); + } + + public function testParsesRequestsWithMissingProtocol() + { + $parser = new MessageParser(); + $parts = $parser->parseRequest("GET /\r\nHost: Foo.com\r\n\r\n"); + $this->assertEquals('GET', $parts['method']); + $this->assertEquals('HTTP', $parts['protocol']); + $this->assertEquals('1.1', $parts['version']); + } + + public function testParsesRequestsWithMissingVersion() + { + $parser = new MessageParser(); + $parts = $parser->parseRequest("GET / HTTP\r\nHost: Foo.com\r\n\r\n"); + $this->assertEquals('GET', $parts['method']); + $this->assertEquals('HTTP', $parts['protocol']); + $this->assertEquals('1.1', $parts['version']); + } + + public function testParsesResponsesWithMissingReasonPhrase() + { + $parser = new MessageParser(); + $parts = $parser->parseResponse("HTTP/1.1 200\r\n\r\n"); + $this->assertEquals('200', $parts['code']); + $this->assertEquals('', $parts['reason_phrase']); + $this->assertEquals('HTTP', $parts['protocol']); + $this->assertEquals('1.1', $parts['version']); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/Message/PeclHttpMessageParserTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/Message/PeclHttpMessageParserTest.php new file mode 100644 index 0000000..6706e20 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/Message/PeclHttpMessageParserTest.php @@ -0,0 +1,36 @@ +markTestSkipped('pecl_http is not available.'); + } + } + + /** + * @dataProvider requestProvider + */ + public function testParsesRequests($message, $parts) + { + $parser = new PeclHttpMessageParser(); + $this->compareRequestResults($parts, $parser->parseRequest($message)); + } + + /** + * @dataProvider responseProvider + */ + public function testParsesResponses($message, $parts) + { + $parser = new PeclHttpMessageParser(); + $this->compareResponseResults($parts, $parser->parseResponse($message)); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/ParserRegistryTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/ParserRegistryTest.php new file mode 100644 index 0000000..7675efb --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/ParserRegistryTest.php @@ -0,0 +1,33 @@ +registerParser('foo', $c); + $this->assertSame($c, $r->getParser('foo')); + } + + public function testReturnsNullWhenNotFound() + { + $r = new ParserRegistry(); + $this->assertNull($r->getParser('FOO')); + } + + public function testReturnsLazyLoadedDefault() + { + $r = new ParserRegistry(); + $c = $r->getParser('cookie'); + $this->assertInstanceOf('Guzzle\Parser\Cookie\CookieParser', $c); + $this->assertSame($c, $r->getParser('cookie')); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/UriTemplate/AbstractUriTemplateTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/UriTemplate/AbstractUriTemplateTest.php new file mode 100644 index 0000000..a05fc2e --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/UriTemplate/AbstractUriTemplateTest.php @@ -0,0 +1,113 @@ + 'value', + 'hello' => 'Hello World!', + 'empty' => '', + 'path' => '/foo/bar', + 'x' => '1024', + 'y' => '768', + 'null' => null, + 'list' => array('red', 'green', 'blue'), + 'keys' => array( + "semi" => ';', + "dot" => '.', + "comma" => ',' + ), + 'empty_keys' => array(), + ); + + return array_map(function($t) use ($params) { + $t[] = $params; + return $t; + }, array( + array('foo', 'foo'), + array('{var}', 'value'), + array('{hello}', 'Hello%20World%21'), + array('{+var}', 'value'), + array('{+hello}', 'Hello%20World!'), + array('{+path}/here', '/foo/bar/here'), + array('here?ref={+path}', 'here?ref=/foo/bar'), + array('X{#var}', 'X#value'), + array('X{#hello}', 'X#Hello%20World!'), + array('map?{x,y}', 'map?1024,768'), + array('{x,hello,y}', '1024,Hello%20World%21,768'), + array('{+x,hello,y}', '1024,Hello%20World!,768'), + array('{+path,x}/here', '/foo/bar,1024/here'), + array('{#x,hello,y}', '#1024,Hello%20World!,768'), + array('{#path,x}/here', '#/foo/bar,1024/here'), + array('X{.var}', 'X.value'), + array('X{.x,y}', 'X.1024.768'), + array('{/var}', '/value'), + array('{/var,x}/here', '/value/1024/here'), + array('{;x,y}', ';x=1024;y=768'), + array('{;x,y,empty}', ';x=1024;y=768;empty'), + array('{?x,y}', '?x=1024&y=768'), + array('{?x,y,empty}', '?x=1024&y=768&empty='), + array('?fixed=yes{&x}', '?fixed=yes&x=1024'), + array('{&x,y,empty}', '&x=1024&y=768&empty='), + array('{var:3}', 'val'), + array('{var:30}', 'value'), + array('{list}', 'red,green,blue'), + array('{list*}', 'red,green,blue'), + array('{keys}', 'semi,%3B,dot,.,comma,%2C'), + array('{keys*}', 'semi=%3B,dot=.,comma=%2C'), + array('{+path:6}/here', '/foo/b/here'), + array('{+list}', 'red,green,blue'), + array('{+list*}', 'red,green,blue'), + array('{+keys}', 'semi,;,dot,.,comma,,'), + array('{+keys*}', 'semi=;,dot=.,comma=,'), + array('{#path:6}/here', '#/foo/b/here'), + array('{#list}', '#red,green,blue'), + array('{#list*}', '#red,green,blue'), + array('{#keys}', '#semi,;,dot,.,comma,,'), + array('{#keys*}', '#semi=;,dot=.,comma=,'), + array('X{.var:3}', 'X.val'), + array('X{.list}', 'X.red,green,blue'), + array('X{.list*}', 'X.red.green.blue'), + array('X{.keys}', 'X.semi,%3B,dot,.,comma,%2C'), + array('X{.keys*}', 'X.semi=%3B.dot=..comma=%2C'), + array('{/var:1,var}', '/v/value'), + array('{/list}', '/red,green,blue'), + array('{/list*}', '/red/green/blue'), + array('{/list*,path:4}', '/red/green/blue/%2Ffoo'), + array('{/keys}', '/semi,%3B,dot,.,comma,%2C'), + array('{/keys*}', '/semi=%3B/dot=./comma=%2C'), + array('{;hello:5}', ';hello=Hello'), + array('{;list}', ';list=red,green,blue'), + array('{;list*}', ';list=red;list=green;list=blue'), + array('{;keys}', ';keys=semi,%3B,dot,.,comma,%2C'), + array('{;keys*}', ';semi=%3B;dot=.;comma=%2C'), + array('{?var:3}', '?var=val'), + array('{?list}', '?list=red,green,blue'), + array('{?list*}', '?list=red&list=green&list=blue'), + array('{?keys}', '?keys=semi,%3B,dot,.,comma,%2C'), + array('{?keys*}', '?semi=%3B&dot=.&comma=%2C'), + array('{&var:3}', '&var=val'), + array('{&list}', '&list=red,green,blue'), + array('{&list*}', '&list=red&list=green&list=blue'), + array('{&keys}', '&keys=semi,%3B,dot,.,comma,%2C'), + array('{&keys*}', '&semi=%3B&dot=.&comma=%2C'), + array('{.null}', ''), + array('{.null,var}', '.value'), + array('X{.empty_keys*}', 'X'), + array('X{.empty_keys}', 'X'), + // Test that missing expansions are skipped + array('test{&missing*}', 'test'), + // Test that multiple expansions can be set + array('http://{var}/{var:2}{?keys*}', 'http://value/va?semi=%3B&dot=.&comma=%2C'), + // Test more complex query string stuff + array('http://www.test.com{+path}{?var,keys*}', 'http://www.test.com/foo/bar?var=value&semi=%3B&dot=.&comma=%2C') + )); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/UriTemplate/PeclUriTemplateTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/UriTemplate/PeclUriTemplateTest.php new file mode 100644 index 0000000..633c5d5 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/UriTemplate/PeclUriTemplateTest.php @@ -0,0 +1,27 @@ +markTestSkipped('uri_template PECL extension must be installed to test PeclUriTemplate'); + } + } + + /** + * @dataProvider templateProvider + */ + public function testExpandsUriTemplates($template, $expansion, $params) + { + $uri = new PeclUriTemplate($template); + $this->assertEquals($expansion, $uri->expand($template, $params)); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/UriTemplate/UriTemplateTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/UriTemplate/UriTemplateTest.php new file mode 100644 index 0000000..5130d6f --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Parser/UriTemplate/UriTemplateTest.php @@ -0,0 +1,106 @@ +assertEquals($expansion, $uri->expand($template, $params)); + } + + public function expressionProvider() + { + return array( + array( + '{+var*}', array( + 'operator' => '+', + 'values' => array( + array('value' => 'var', 'modifier' => '*') + ) + ), + ), + array( + '{?keys,var,val}', array( + 'operator' => '?', + 'values' => array( + array('value' => 'keys', 'modifier' => ''), + array('value' => 'var', 'modifier' => ''), + array('value' => 'val', 'modifier' => '') + ) + ), + ), + array( + '{+x,hello,y}', array( + 'operator' => '+', + 'values' => array( + array('value' => 'x', 'modifier' => ''), + array('value' => 'hello', 'modifier' => ''), + array('value' => 'y', 'modifier' => '') + ) + ) + ) + ); + } + + /** + * @dataProvider expressionProvider + */ + public function testParsesExpressions($exp, $data) + { + $template = new UriTemplate($exp); + + // Access the config object + $class = new \ReflectionClass($template); + $method = $class->getMethod('parseExpression'); + $method->setAccessible(true); + + $exp = substr($exp, 1, -1); + $this->assertEquals($data, $method->invokeArgs($template, array($exp))); + } + + /** + * @ticket https://github.com/guzzle/guzzle/issues/90 + */ + public function testAllowsNestedArrayExpansion() + { + $template = new UriTemplate(); + + $result = $template->expand('http://example.com{+path}{/segments}{?query,data*,foo*}', array( + 'path' => '/foo/bar', + 'segments' => array('one', 'two'), + 'query' => 'test', + 'data' => array( + 'more' => array('fun', 'ice cream') + ), + 'foo' => array( + 'baz' => array( + 'bar' => 'fizz', + 'test' => 'buzz' + ), + 'bam' => 'boo' + ) + )); + + $this->assertEquals('http://example.com/foo/bar/one,two?query=test&more%5B0%5D=fun&more%5B1%5D=ice%20cream&baz%5Bbar%5D=fizz&baz%5Btest%5D=buzz&bam=boo', $result); + } + + /** + * @ticket https://github.com/guzzle/guzzle/issues/426 + */ + public function testSetRegex() + { + $template = new UriTemplate(); + $template->setRegex('/\<\$(.+)\>/'); + $this->assertSame('/foo', $template->expand('/<$a>', array('a' => 'foo'))); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Async/AsyncPluginTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Async/AsyncPluginTest.php new file mode 100644 index 0000000..16990a5 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Async/AsyncPluginTest.php @@ -0,0 +1,93 @@ +assertArrayHasKey('request.before_send', $events); + $this->assertArrayHasKey('request.exception', $events); + $this->assertArrayHasKey('curl.callback.progress', $events); + } + + public function testEnablesProgressCallbacks() + { + $p = new AsyncPlugin(); + $request = RequestFactory::getInstance()->create('PUT', 'http://www.example.com'); + $event = new Event(array( + 'request' => $request + )); + $p->onBeforeSend($event); + $this->assertEquals(true, $request->getCurlOptions()->get('progress')); + } + + public function testAddsTimesOutAfterSending() + { + $p = new AsyncPlugin(); + $request = RequestFactory::getInstance()->create('PUT', 'http://www.example.com'); + $handle = CurlHandle::factory($request); + $event = new Event(array( + 'request' => $request, + 'handle' => $handle->getHandle(), + 'uploaded' => 10, + 'upload_size' => 10, + 'downloaded' => 0 + )); + $p->onCurlProgress($event); + } + + public function testEnsuresRequestIsSet() + { + $p = new AsyncPlugin(); + $event = new Event(array( + 'uploaded' => 10, + 'upload_size' => 10, + 'downloaded' => 0 + )); + $p->onCurlProgress($event); + } + + public function testMasksCurlExceptions() + { + $p = new AsyncPlugin(); + $request = RequestFactory::getInstance()->create('PUT', 'http://www.example.com'); + $e = new CurlException('Error'); + $event = new Event(array( + 'request' => $request, + 'exception' => $e + )); + $p->onRequestTimeout($event); + $this->assertEquals(RequestInterface::STATE_COMPLETE, $request->getState()); + $this->assertEquals(200, $request->getResponse()->getStatusCode()); + $this->assertTrue($request->getResponse()->hasHeader('X-Guzzle-Async')); + } + + public function testEnsuresIntegration() + { + $this->getServer()->flush(); + $this->getServer()->enqueue("HTTP/1.1 204 FOO\r\nContent-Length: 4\r\n\r\ntest"); + $client = new Client($this->getServer()->getUrl()); + $request = $client->post('/', null, array( + 'foo' => 'bar' + )); + $request->getEventDispatcher()->addSubscriber(new AsyncPlugin()); + $request->send(); + $this->assertEquals('', $request->getResponse()->getBody(true)); + $this->assertTrue($request->getResponse()->hasHeader('X-Guzzle-Async')); + $received = $this->getServer()->getReceivedRequests(true); + $this->assertEquals('POST', $received[0]->getMethod()); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/AbstractBackoffStrategyTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/AbstractBackoffStrategyTest.php new file mode 100644 index 0000000..72af263 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/AbstractBackoffStrategyTest.php @@ -0,0 +1,86 @@ +getMockBuilder('Guzzle\Plugin\Backoff\AbstractBackoffStrategy') + ->setMethods(array('getDelay', 'makesDecision')) + ->getMockForAbstractClass(); + } + + public function testReturnsZeroWhenNoNextAndGotNull() + { + $request = new Request('GET', 'http://www.foo.com'); + $mock = $this->getMockStrategy(); + $mock->expects($this->atLeastOnce())->method('getDelay')->will($this->returnValue(null)); + $this->assertEquals(0, $mock->getBackoffPeriod(0, $request)); + } + + public function testReturnsFalse() + { + $request = new Request('GET', 'http://www.foo.com'); + $mock = $this->getMockStrategy(); + $mock->expects($this->atLeastOnce())->method('getDelay')->will($this->returnValue(false)); + $this->assertEquals(false, $mock->getBackoffPeriod(0, $request)); + } + + public function testReturnsNextValueWhenNullOrTrue() + { + $request = new Request('GET', 'http://www.foo.com'); + $mock = $this->getMockStrategy(); + $mock->expects($this->atLeastOnce())->method('getDelay')->will($this->returnValue(null)); + $mock->expects($this->any())->method('makesDecision')->will($this->returnValue(false)); + + $mock2 = $this->getMockStrategy(); + $mock2->expects($this->atLeastOnce())->method('getDelay')->will($this->returnValue(10)); + $mock2->expects($this->atLeastOnce())->method('makesDecision')->will($this->returnValue(true)); + $mock->setNext($mock2); + + $this->assertEquals(10, $mock->getBackoffPeriod(0, $request)); + } + + public function testReturnsFalseWhenNullAndNoNext() + { + $request = new Request('GET', 'http://www.foo.com'); + $s = new TruncatedBackoffStrategy(2); + $this->assertFalse($s->getBackoffPeriod(0, $request)); + } + + public function testHasNext() + { + $a = new TruncatedBackoffStrategy(2); + $b = new TruncatedBackoffStrategy(2); + $a->setNext($b); + $this->assertSame($b, $a->getNext()); + } + + public function testSkipsOtherDecisionsInChainWhenOneReturnsTrue() + { + $a = new CallbackBackoffStrategy(function () { return null; }, true); + $b = new CallbackBackoffStrategy(function () { return true; }, true); + $c = new CallbackBackoffStrategy(function () { return null; }, true); + $d = new CallbackBackoffStrategy(function () { return 10; }, false); + $a->setNext($b); + $b->setNext($c); + $c->setNext($d); + $this->assertEquals(10, $a->getBackoffPeriod(2, new Request('GET', 'http://www.foo.com'))); + } + + public function testReturnsZeroWhenDecisionMakerReturnsTrueButNoFurtherStrategiesAreInTheChain() + { + $a = new CallbackBackoffStrategy(function () { return null; }, true); + $b = new CallbackBackoffStrategy(function () { return true; }, true); + $a->setNext($b); + $this->assertSame(0, $a->getBackoffPeriod(2, new Request('GET', 'http://www.foo.com'))); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/BackoffLoggerTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/BackoffLoggerTest.php new file mode 100644 index 0000000..a64dd82 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/BackoffLoggerTest.php @@ -0,0 +1,110 @@ +message = ''; + } + + public function testHasEventList() + { + $this->assertEquals(1, count(BackoffLogger::getSubscribedEvents())); + } + + public function testLogsEvents() + { + list($logPlugin, $request, $response) = $this->getMocks(); + + $response = $this->getMockBuilder('Guzzle\Http\Message\Response') + ->setConstructorArgs(array(503)) + ->setMethods(array('getInfo')) + ->getMock(); + + $response->expects($this->any()) + ->method('getInfo') + ->will($this->returnValue(2)); + + $handle = $this->getMockHandle(); + + $event = new Event(array( + 'request' => $request, + 'response' => $response, + 'retries' => 1, + 'delay' => 3, + 'handle' => $handle + )); + + $logPlugin->onRequestRetry($event); + $this->assertContains( + '] PUT http://www.example.com - 503 Service Unavailable - Retries: 1, Delay: 3, Time: 2, 2, cURL: 30 Foo', + $this->message + ); + } + + public function testCanSetTemplate() + { + $l = new BackoffLogger(new ClosureLogAdapter(function () {})); + $l->setTemplate('foo'); + $t = $this->readAttribute($l, 'formatter'); + $this->assertEquals('foo', $this->readAttribute($t, 'template')); + } + + /** + * @return array + */ + protected function getMocks() + { + $that = $this; + $logger = new ClosureLogAdapter(function ($message) use ($that) { + $that->message .= $message . "\n"; + }); + $logPlugin = new BackoffLogger($logger); + $response = new Response(503); + $request = RequestFactory::getInstance()->create('PUT', 'http://www.example.com', array( + 'Content-Length' => 3, + 'Foo' => 'Bar' + )); + + return array($logPlugin, $request, $response); + } + + /** + * @return CurlHandle + */ + protected function getMockHandle() + { + $handle = $this->getMockBuilder('Guzzle\Http\Curl\CurlHandle') + ->disableOriginalConstructor() + ->setMethods(array('getError', 'getErrorNo', 'getInfo')) + ->getMock(); + + $handle->expects($this->once()) + ->method('getError') + ->will($this->returnValue('Foo')); + + $handle->expects($this->once()) + ->method('getErrorNo') + ->will($this->returnValue(30)); + + $handle->expects($this->any()) + ->method('getInfo') + ->will($this->returnValue(2)); + + return $handle; + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/BackoffPluginTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/BackoffPluginTest.php new file mode 100644 index 0000000..496e49e --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/BackoffPluginTest.php @@ -0,0 +1,297 @@ +retried = false; + } + + public static function getSubscribedEvents() + { + return array(BackoffPlugin::RETRY_EVENT => 'onRequestRetry'); + } + + public function onRequestRetry(Event $event) + { + $this->retried = $event; + } + + public function testHasEventList() + { + $this->assertEquals(1, count(BackoffPlugin::getAllEvents())); + } + + public function testCreatesDefaultExponentialBackoffPlugin() + { + $plugin = BackoffPlugin::getExponentialBackoff(3, array(204), array(10)); + $this->assertInstanceOf('Guzzle\Plugin\Backoff\BackoffPlugin', $plugin); + $strategy = $this->readAttribute($plugin, 'strategy'); + $this->assertInstanceOf('Guzzle\Plugin\Backoff\TruncatedBackoffStrategy', $strategy); + $this->assertEquals(3, $this->readAttribute($strategy, 'max')); + $strategy = $this->readAttribute($strategy, 'next'); + $this->assertInstanceOf('Guzzle\Plugin\Backoff\HttpBackoffStrategy', $strategy); + $this->assertEquals(array(204 => true), $this->readAttribute($strategy, 'errorCodes')); + $strategy = $this->readAttribute($strategy, 'next'); + $this->assertInstanceOf('Guzzle\Plugin\Backoff\CurlBackoffStrategy', $strategy); + $this->assertEquals(array(10 => true), $this->readAttribute($strategy, 'errorCodes')); + $strategy = $this->readAttribute($strategy, 'next'); + $this->assertInstanceOf('Guzzle\Plugin\Backoff\ExponentialBackoffStrategy', $strategy); + } + + public function testDoesNotRetryUnlessStrategyReturnsNumber() + { + $request = new Request('GET', 'http://www.example.com'); + $request->setState('transfer'); + + $mock = $this->getMockBuilder('Guzzle\Plugin\Backoff\BackoffStrategyInterface') + ->setMethods(array('getBackoffPeriod')) + ->getMockForAbstractClass(); + + $mock->expects($this->once()) + ->method('getBackoffPeriod') + ->will($this->returnValue(false)); + + $plugin = new BackoffPlugin($mock); + $plugin->addSubscriber($this); + $plugin->onRequestSent(new Event(array('request' => $request))); + $this->assertFalse($this->retried); + } + + public function testUpdatesRequestForRetry() + { + $request = new Request('GET', 'http://www.example.com'); + $request->setState('transfer'); + $response = new Response(500); + $handle = $this->getMockBuilder('Guzzle\Http\Curl\CurlHandle')->disableOriginalConstructor()->getMock(); + $e = new CurlException(); + $e->setCurlHandle($handle); + + $plugin = new BackoffPlugin(new ConstantBackoffStrategy(10)); + $plugin->addSubscriber($this); + + $event = new Event(array( + 'request' => $request, + 'response' => $response, + 'exception' => $e + )); + + $plugin->onRequestSent($event); + $this->assertEquals(array( + 'request' => $request, + 'response' => $response, + 'handle' => $handle, + 'retries' => 1, + 'delay' => 10 + ), $this->readAttribute($this->retried, 'context')); + + $plugin->onRequestSent($event); + $this->assertEquals(array( + 'request' => $request, + 'response' => $response, + 'handle' => $handle, + 'retries' => 2, + 'delay' => 10 + ), $this->readAttribute($this->retried, 'context')); + } + + public function testDoesNothingWhenNotRetryingAndPollingRequest() + { + $request = new Request('GET', 'http://www.foo.com'); + $plugin = new BackoffPlugin(new ConstantBackoffStrategy(10)); + $plugin->onRequestPoll(new Event(array('request' => $request))); + } + + public function testRetriesRequests() + { + // Create a script to return several 500 and 503 response codes + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 500 Internal Server Error\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 500 Internal Server Error\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 200 OK\r\nContent-Length: 4\r\n\r\ndata" + )); + + $plugin = new BackoffPlugin( + new TruncatedBackoffStrategy(3, + new HttpBackoffStrategy(null, + new CurlBackoffStrategy(null, + new ConstantBackoffStrategy(0.05) + ) + ) + ) + ); + + $client = new Client($this->getServer()->getUrl()); + $client->getEventDispatcher()->addSubscriber($plugin); + $request = $client->get(); + $request->send(); + + // Make sure it eventually completed successfully + $this->assertEquals(200, $request->getResponse()->getStatusCode()); + $this->assertEquals('data', $request->getResponse()->getBody(true)); + + // Check that three requests were made to retry this request + $this->assertEquals(3, count($this->getServer()->getReceivedRequests(false))); + $this->assertEquals(2, $request->getParams()->get(BackoffPlugin::RETRY_PARAM)); + } + + /** + * @expectedException \Guzzle\Http\Exception\ServerErrorResponseException + */ + public function testFailsOnTruncation() + { + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 500 Internal Server Error\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 500 Internal Server Error\r\nContent-Length: 0\r\n\r\n" + )); + + $plugin = new BackoffPlugin( + new TruncatedBackoffStrategy(2, + new HttpBackoffStrategy(null, + new ConstantBackoffStrategy(0.05) + ) + ) + ); + + $client = new Client($this->getServer()->getUrl()); + $client->addSubscriber($plugin); + $client->get()->send(); + } + + public function testRetriesRequestsWhenInParallel() + { + // Create a script to return several 500 and 503 response codes + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 500 Internal Server Error\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 500 Internal Server Error\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 500 Internal Server Error\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 500 Internal Server Error\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 500 Internal Server Error\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 500 Internal Server Error\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 500 Internal Server Error\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 500 Internal Server Error\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 500 Internal Server Error\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 500 Internal Server Error\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 200 OK\r\nContent-Length: 4\r\n\r\ndata", + "HTTP/1.1 200 OK\r\nContent-Length: 4\r\n\r\ndata", + "HTTP/1.1 200 OK\r\nContent-Length: 4\r\n\r\ndata", + "HTTP/1.1 200 OK\r\nContent-Length: 4\r\n\r\ndata", + "HTTP/1.1 200 OK\r\nContent-Length: 4\r\n\r\ndata" + )); + + $plugin = new BackoffPlugin( + new HttpBackoffStrategy(null, + new TruncatedBackoffStrategy(3, + new CurlBackoffStrategy(null, + new ConstantBackoffStrategy(0.1) + ) + ) + ) + ); + $client = new Client($this->getServer()->getUrl()); + $client->getEventDispatcher()->addSubscriber($plugin); + $requests = array(); + for ($i = 0; $i < 5; $i++) { + $requests[] = $client->get(); + } + $client->send($requests); + + $this->assertEquals(15, count($this->getServer()->getReceivedRequests(false))); + } + + /** + * @covers Guzzle\Plugin\Backoff\BackoffPlugin + * @covers Guzzle\Http\Curl\CurlMulti + */ + public function testRetriesPooledRequestsUsingDelayAndPollingEvent() + { + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 500 Internal Server Error\r\nContent-Length: 0\r\n\r\n", + "HTTP/1.1 200 OK\r\nContent-Length: 4\r\n\r\ndata" + )); + // Need to sleep for some time ensure that the polling works correctly in the observer + $plugin = new BackoffPlugin(new HttpBackoffStrategy(null, + new TruncatedBackoffStrategy(1, + new ConstantBackoffStrategy(0.5)))); + + $client = new Client($this->getServer()->getUrl()); + $client->getEventDispatcher()->addSubscriber($plugin); + $request = $client->get(); + $request->send(); + // Make sure it eventually completed successfully + $this->assertEquals('data', $request->getResponse()->getBody(true)); + // Check that two requests were made to retry this request + $this->assertEquals(2, count($this->getServer()->getReceivedRequests(false))); + } + + public function testSeeksToBeginningOfRequestBodyWhenRetrying() + { + // Create a request with a body + $request = new EntityEnclosingRequest('PUT', 'http://www.example.com'); + $request->setBody('abc'); + // Set the retry time to be something that will be retried always + $request->getParams()->set(BackoffPlugin::DELAY_PARAM, 2); + // Seek to the end of the stream + $request->getBody()->seek(3); + $this->assertEquals('', $request->getBody()->read(1)); + // Create a plugin that does not delay when retrying + $plugin = new BackoffPlugin(new ConstantBackoffStrategy(0)); + $plugin->onRequestPoll($this->getMockEvent($request)); + // Ensure that the stream was seeked to 0 + $this->assertEquals('a', $request->getBody()->read(1)); + } + + public function testDoesNotSeekOnRequestsWithNoBodyWhenRetrying() + { + // Create a request with a body + $request = new EntityEnclosingRequest('PUT', 'http://www.example.com'); + $request->getParams()->set(BackoffPlugin::DELAY_PARAM, 2); + $plugin = new BackoffPlugin(new ConstantBackoffStrategy(0)); + $plugin->onRequestPoll($this->getMockEvent($request)); + } + + protected function getMockEvent(RequestInterface $request) + { + // Create a mock curl multi object + $multi = $this->getMockBuilder('Guzzle\Http\Curl\CurlMulti') + ->setMethods(array('remove', 'add')) + ->getMock(); + + // Create an event that is expected for the Poll event + $event = new Event(array( + 'request' => $request, + 'curl_multi' => $multi + )); + $event->setName(CurlMultiInterface::POLLING_REQUEST); + + return $event; + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/CallbackBackoffStrategyTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/CallbackBackoffStrategyTest.php new file mode 100644 index 0000000..c0ce10d --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/CallbackBackoffStrategyTest.php @@ -0,0 +1,31 @@ +getMock('Guzzle\Http\Message\Request', array(), array(), '', false); + $strategy = new CallbackBackoffStrategy(function () { return 10; }, true); + $this->assertTrue($strategy->makesDecision()); + $this->assertEquals(10, $strategy->getBackoffPeriod(0, $request)); + // Ensure it chains correctly when null is returned + $strategy = new CallbackBackoffStrategy(function () { return null; }, false); + $this->assertFalse($strategy->makesDecision()); + $this->assertFalse($strategy->getBackoffPeriod(0, $request)); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/ConstantBackoffStrategyTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/ConstantBackoffStrategyTest.php new file mode 100644 index 0000000..703eb4a --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/ConstantBackoffStrategyTest.php @@ -0,0 +1,20 @@ +assertFalse($strategy->makesDecision()); + $request = $this->getMock('Guzzle\Http\Message\Request', array(), array(), '', false); + $this->assertEquals(3.5, $strategy->getBackoffPeriod(0, $request)); + $this->assertEquals(3.5, $strategy->getBackoffPeriod(1, $request)); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/CurlBackoffStrategyTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/CurlBackoffStrategyTest.php new file mode 100644 index 0000000..0a5c3e2 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/CurlBackoffStrategyTest.php @@ -0,0 +1,36 @@ +assertNotEmpty(CurlBackoffStrategy::getDefaultFailureCodes()); + $strategy = new CurlBackoffStrategy(); + $this->assertTrue($strategy->makesDecision()); + $request = $this->getMock('Guzzle\Http\Message\Request', array(), array(), '', false); + $e = new CurlException(); + $e->setError('foo', CURLE_BAD_CALLING_ORDER); + $this->assertEquals(false, $strategy->getBackoffPeriod(0, $request, null, $e)); + + foreach (CurlBackoffStrategy::getDefaultFailureCodes() as $code) { + $this->assertEquals(0, $strategy->getBackoffPeriod(0, $request, null, $e->setError('foo', $code))); + } + } + + public function testIgnoresNonErrors() + { + $strategy = new CurlBackoffStrategy(); + $request = $this->getMock('Guzzle\Http\Message\Request', array(), array(), '', false); + $this->assertEquals(false, $strategy->getBackoffPeriod(0, $request, new Response(200))); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/ExponentialBackoffStrategyTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/ExponentialBackoffStrategyTest.php new file mode 100644 index 0000000..09965bc --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/ExponentialBackoffStrategyTest.php @@ -0,0 +1,23 @@ +assertFalse($strategy->makesDecision()); + $request = $this->getMock('Guzzle\Http\Message\Request', array(), array(), '', false); + $this->assertEquals(1, $strategy->getBackoffPeriod(0, $request)); + $this->assertEquals(2, $strategy->getBackoffPeriod(1, $request)); + $this->assertEquals(4, $strategy->getBackoffPeriod(2, $request)); + $this->assertEquals(8, $strategy->getBackoffPeriod(3, $request)); + $this->assertEquals(16, $strategy->getBackoffPeriod(4, $request)); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/HttpBackoffStrategyTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/HttpBackoffStrategyTest.php new file mode 100644 index 0000000..ae68a4e --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/HttpBackoffStrategyTest.php @@ -0,0 +1,47 @@ +assertNotEmpty(HttpBackoffStrategy::getDefaultFailureCodes()); + $strategy = new HttpBackoffStrategy(); + $this->assertTrue($strategy->makesDecision()); + $request = $this->getMock('Guzzle\Http\Message\Request', array(), array(), '', false); + + $response = new Response(200); + $this->assertEquals(false, $strategy->getBackoffPeriod(0, $request, $response)); + $response->setStatus(400); + $this->assertEquals(false, $strategy->getBackoffPeriod(0, $request, $response)); + + foreach (HttpBackoffStrategy::getDefaultFailureCodes() as $code) { + $this->assertEquals(0, $strategy->getBackoffPeriod(0, $request, $response->setStatus($code))); + } + } + + public function testAllowsCustomCodes() + { + $strategy = new HttpBackoffStrategy(array(204)); + $request = $this->getMock('Guzzle\Http\Message\Request', array(), array(), '', false); + $response = new Response(204); + $this->assertEquals(0, $strategy->getBackoffPeriod(0, $request, $response)); + $response->setStatus(500); + $this->assertEquals(false, $strategy->getBackoffPeriod(0, $request, $response)); + } + + public function testIgnoresNonErrors() + { + $strategy = new HttpBackoffStrategy(); + $request = $this->getMock('Guzzle\Http\Message\Request', array(), array(), '', false); + $this->assertEquals(false, $strategy->getBackoffPeriod(0, $request)); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/LinearBackoffStrategyTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/LinearBackoffStrategyTest.php new file mode 100644 index 0000000..b4ce8e4 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/LinearBackoffStrategyTest.php @@ -0,0 +1,21 @@ +assertFalse($strategy->makesDecision()); + $request = $this->getMock('Guzzle\Http\Message\Request', array(), array(), '', false); + $this->assertEquals(0, $strategy->getBackoffPeriod(0, $request)); + $this->assertEquals(5, $strategy->getBackoffPeriod(1, $request)); + $this->assertEquals(10, $strategy->getBackoffPeriod(2, $request)); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/ReasonPhraseBackoffStrategyTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/ReasonPhraseBackoffStrategyTest.php new file mode 100644 index 0000000..dea5a68 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/ReasonPhraseBackoffStrategyTest.php @@ -0,0 +1,32 @@ +assertEmpty(ReasonPhraseBackoffStrategy::getDefaultFailureCodes()); + $strategy = new ReasonPhraseBackoffStrategy(array('Foo', 'Internal Server Error')); + $this->assertTrue($strategy->makesDecision()); + $request = $this->getMock('Guzzle\Http\Message\Request', array(), array(), '', false); + $response = new Response(200); + $this->assertEquals(false, $strategy->getBackoffPeriod(0, $request, $response)); + $response->setStatus(200, 'Foo'); + $this->assertEquals(0, $strategy->getBackoffPeriod(0, $request, $response)); + } + + public function testIgnoresNonErrors() + { + $strategy = new ReasonPhraseBackoffStrategy(); + $request = $this->getMock('Guzzle\Http\Message\Request', array(), array(), '', false); + $this->assertEquals(false, $strategy->getBackoffPeriod(0, $request)); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/TruncatedBackoffStrategyTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/TruncatedBackoffStrategyTest.php new file mode 100644 index 0000000..5590dfb --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Backoff/TruncatedBackoffStrategyTest.php @@ -0,0 +1,30 @@ +assertTrue($strategy->makesDecision()); + $request = $this->getMock('Guzzle\Http\Message\Request', array(), array(), '', false); + $this->assertFalse($strategy->getBackoffPeriod(0, $request)); + $this->assertFalse($strategy->getBackoffPeriod(1, $request)); + $this->assertFalse($strategy->getBackoffPeriod(2, $request)); + + $response = new Response(500); + $strategy->setNext(new HttpBackoffStrategy(null, new ConstantBackoffStrategy(10))); + $this->assertEquals(10, $strategy->getBackoffPeriod(0, $request, $response)); + $this->assertEquals(10, $strategy->getBackoffPeriod(1, $request, $response)); + $this->assertFalse($strategy->getBackoffPeriod(2, $request, $response)); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cache/CachePluginTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cache/CachePluginTest.php new file mode 100644 index 0000000..69da60a --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cache/CachePluginTest.php @@ -0,0 +1,441 @@ +assertInstanceOf('Guzzle\Plugin\Cache\CacheStorageInterface', $this->readAttribute($plugin, 'storage')); + } + + public function testAddsDefaultCollaborators() + { + $this->assertNotEmpty(CachePlugin::getSubscribedEvents()); + $plugin = new CachePlugin(array( + 'storage' => $this->getMockBuilder('Guzzle\Plugin\Cache\CacheStorageInterface')->getMockForAbstractClass() + )); + $this->assertInstanceOf('Guzzle\Plugin\Cache\CacheStorageInterface', $this->readAttribute($plugin, 'storage')); + $this->assertInstanceOf( + 'Guzzle\Plugin\Cache\CanCacheStrategyInterface', + $this->readAttribute($plugin, 'canCache') + ); + $this->assertInstanceOf( + 'Guzzle\Plugin\Cache\RevalidationInterface', + $this->readAttribute($plugin, 'revalidation') + ); + } + + public function testAddsCallbackCollaborators() + { + $this->assertNotEmpty(CachePlugin::getSubscribedEvents()); + $plugin = new CachePlugin(array('can_cache' => function () {})); + $this->assertInstanceOf( + 'Guzzle\Plugin\Cache\CallbackCanCacheStrategy', + $this->readAttribute($plugin, 'canCache') + ); + } + + public function testCanPassCacheAsOnlyArgumentToConstructor() + { + $p = new CachePlugin(new DoctrineCacheAdapter(new ArrayCache())); + $p = new CachePlugin(new DefaultCacheStorage(new DoctrineCacheAdapter(new ArrayCache()))); + } + + public function testUsesCreatedCacheStorage() + { + $plugin = new CachePlugin(array( + 'adapter' => $this->getMockBuilder('Guzzle\Cache\CacheAdapterInterface')->getMockForAbstractClass() + )); + $this->assertInstanceOf('Guzzle\Plugin\Cache\CacheStorageInterface', $this->readAttribute($plugin, 'storage')); + } + + public function testUsesProvidedOptions() + { + $can = $this->getMockBuilder('Guzzle\Plugin\Cache\CanCacheStrategyInterface')->getMockForAbstractClass(); + $revalidate = $this->getMockBuilder('Guzzle\Plugin\Cache\RevalidationInterface')->getMockForAbstractClass(); + $plugin = new CachePlugin(array( + 'storage' => $this->getMockBuilder('Guzzle\Plugin\Cache\CacheStorageInterface')->getMockForAbstractClass(), + 'can_cache' => $can, + 'revalidation' => $revalidate + )); + $this->assertSame($can, $this->readAttribute($plugin, 'canCache')); + $this->assertSame($revalidate, $this->readAttribute($plugin, 'revalidation')); + } + + public function satisfyProvider() + { + $req1 = new Request('GET', 'http://foo.com', array('Cache-Control' => 'no-cache')); + + return array( + // The response is too old to satisfy the request + array(new Request('GET', 'http://foo.com', array('Cache-Control' => 'max-age=20')), new Response(200, array('Age' => 100)), false, false), + // The response cannot satisfy the request because it is stale + array(new Request('GET', 'http://foo.com'), new Response(200, array('Cache-Control' => 'max-age=10', 'Age' => 100)), false, false), + // Allows the expired response to satisfy the request because of the max-stale + array(new Request('GET', 'http://foo.com', array('Cache-Control' => 'max-stale=15')), new Response(200, array('Cache-Control' => 'max-age=90', 'Age' => 100)), true, false), + // Max stale is > than the allowed staleness + array(new Request('GET', 'http://foo.com', array('Cache-Control' => 'max-stale=5')), new Response(200, array('Cache-Control' => 'max-age=90', 'Age' => 100)), false, false), + // Performs cache revalidation + array($req1, new Response(200), true, true), + // Performs revalidation due to ETag on the response and no cache-control on the request + array(new Request('GET', 'http://foo.com'), new Response(200, array( + 'ETag' => 'ABC', + 'Expires' => date('c', strtotime('+1 year')) + )), true, true), + ); + } + + /** + * @dataProvider satisfyProvider + */ + public function testChecksIfResponseCanSatisfyRequest($request, $response, $can, $revalidates) + { + $didRevalidate = false; + $storage = $this->getMockBuilder('Guzzle\Plugin\Cache\CacheStorageInterface')->getMockForAbstractClass(); + $revalidate = $this->getMockBuilder('Guzzle\Plugin\Cache\DefaultRevalidation') + ->setMethods(array('revalidate')) + ->setConstructorArgs(array($storage)) + ->getMockForAbstractClass(); + + $revalidate->expects($this->any()) + ->method('revalidate') + ->will($this->returnCallback(function () use (&$didRevalidate) { + $didRevalidate = true; + return true; + })); + + $plugin = new CachePlugin(array( + 'storage' => $storage, + 'revalidation' => $revalidate + )); + + $this->assertEquals($can, $plugin->canResponseSatisfyRequest($request, $response)); + $this->assertEquals($didRevalidate, $revalidates); + } + + public function satisfyFailedProvider() + { + return array( + // Neither has stale-if-error + array(new Request('GET', 'http://foo.com', array()), new Response(200, array('Age' => 100)), false), + // Request has stale-if-error + array(new Request('GET', 'http://foo.com', array('Cache-Control' => 'stale-if-error')), new Response(200, array('Age' => 100, 'Cache-Control' => 'max-age=50')), true), + // Request has valid stale-if-error + array(new Request('GET', 'http://foo.com', array('Cache-Control' => 'stale-if-error=50')), new Response(200, array('Age' => 100, 'Cache-Control' => 'max-age=50')), true), + // Request has expired stale-if-error + array(new Request('GET', 'http://foo.com', array('Cache-Control' => 'stale-if-error=20')), new Response(200, array('Age' => 100, 'Cache-Control' => 'max-age=50')), false), + // Response has permanent stale-if-error + array(new Request('GET', 'http://foo.com', array()), new Response(200, array('Age' => 100, 'Cache-Control' => 'max-age=50, stale-if-error', )), true), + // Response has valid stale-if-error + array(new Request('GET', 'http://foo.com', array()), new Response(200, array('Age' => 100, 'Cache-Control' => 'max-age=50, stale-if-error=50')), true), + // Response has expired stale-if-error + array(new Request('GET', 'http://foo.com', array()), new Response(200, array('Age' => 100, 'Cache-Control' => 'max-age=50, stale-if-error=20')), false), + // Request has valid stale-if-error but response does not + array(new Request('GET', 'http://foo.com', array('Cache-Control' => 'stale-if-error=50')), new Response(200, array('Age' => 100, 'Cache-Control' => 'max-age=50, stale-if-error=20')), false), + // Response has valid stale-if-error but request does not + array(new Request('GET', 'http://foo.com', array('Cache-Control' => 'stale-if-error=20')), new Response(200, array('Age' => 100, 'Cache-Control' => 'max-age=50, stale-if-error=50')), false), + ); + } + + /** + * @dataProvider satisfyFailedProvider + */ + public function testChecksIfResponseCanSatisfyFailedRequest($request, $response, $can) + { + $plugin = new CachePlugin(); + + $this->assertEquals($can, $plugin->canResponseSatisfyFailedRequest($request, $response)); + } + + public function testDoesNothingWhenRequestIsNotCacheable() + { + $storage = $this->getMockBuilder('Guzzle\Plugin\Cache\CacheStorageInterface') + ->setMethods(array('fetch')) + ->getMockForAbstractClass(); + $storage->expects($this->never())->method('fetch'); + + $plugin = new CachePlugin(array( + 'storage' => $storage, + 'can_cache' => new CallbackCanCacheStrategy(function () { return false; }) + )); + + $plugin->onRequestBeforeSend(new Event(array( + 'request' => new Request('GET', 'http://foo.com') + ))); + } + + public function satisfiableProvider() + { + $date = new \DateTime('-10 seconds'); + + return array( + // Fresh response + array(new Response(200, array(), 'foo')), + // Stale response + array(new Response(200, array('Date' => $date->format('c'), 'Cache-Control' => 'max-age=5'), 'foo')) + ); + } + + /** + * @dataProvider satisfiableProvider + */ + public function testInjectsSatisfiableResponses($response) + { + $storage = $this->getMockBuilder('Guzzle\Plugin\Cache\CacheStorageInterface') + ->setMethods(array('fetch')) + ->getMockForAbstractClass(); + + $storage->expects($this->once())->method('fetch')->will($this->returnValue($response)); + $plugin = new CachePlugin(array('storage' => $storage)); + $request = new Request('GET', 'http://foo.com', array('Cache-Control' => 'max-stale')); + $plugin->onRequestBeforeSend(new Event(array('request' => $request))); + $plugin->onRequestSent(new Event(array('request' => $request, 'response' => $request->getResponse()))); + $this->assertEquals($response->getStatusCode(), $request->getResponse()->getStatusCode()); + $this->assertEquals((string) $response->getBody(), (string) $request->getResponse()->getBody()); + $this->assertTrue($request->getResponse()->hasHeader('Age')); + if ($request->getResponse()->isFresh() === false) { + $this->assertContains('110', (string) $request->getResponse()->getHeader('Warning')); + } + $this->assertSame( + sprintf('%s GuzzleCache/%s', $request->getProtocolVersion(), Version::VERSION), + (string) $request->getHeader('Via') + ); + $this->assertSame( + sprintf('%s GuzzleCache/%s',$request->getProtocolVersion(), Version::VERSION), + (string) $request->getResponse()->getHeader('Via') + ); + $this->assertTrue($request->getParams()->get('cache.lookup')); + $this->assertTrue($request->getParams()->get('cache.hit')); + $this->assertTrue($request->getResponse()->hasHeader('X-Cache-Lookup')); + $this->assertTrue($request->getResponse()->hasHeader('X-Cache')); + $this->assertEquals('HIT from GuzzleCache', (string) $request->getResponse()->getHeader('X-Cache')); + $this->assertEquals('HIT from GuzzleCache', (string) $request->getResponse()->getHeader('X-Cache-Lookup')); + } + + public function satisfiableOnErrorProvider() + { + $date = new \DateTime('-10 seconds'); + return array( + array( + new Response(200, array( + 'Date' => $date->format('c'), + 'Cache-Control' => 'max-age=5, stale-if-error' + ), 'foo'), + ) + ); + } + + /** + * @dataProvider satisfiableOnErrorProvider + */ + public function testInjectsSatisfiableResponsesOnError($cacheResponse) + { + $storage = $this->getMockBuilder('Guzzle\Plugin\Cache\CacheStorageInterface') + ->setMethods(array('fetch')) + ->getMockForAbstractClass(); + $storage->expects($this->exactly(2))->method('fetch')->will($this->returnValue($cacheResponse)); + $plugin = new CachePlugin(array('storage' => $storage)); + $request = new Request('GET', 'http://foo.com', array('Cache-Control' => 'max-stale')); + $plugin->onRequestBeforeSend(new Event(array('request' => $request))); + $plugin->onRequestError( + $event = new Event(array( + 'request' => $request, + 'response' => $request->getResponse(), + )) + ); + $response = $event['response']; + $this->assertEquals($cacheResponse->getStatusCode(), $response->getStatusCode()); + $this->assertEquals((string) $cacheResponse->getBody(), (string) $response->getBody()); + $this->assertTrue($response->hasHeader('Age')); + if ($response->isFresh() === false) { + $this->assertContains('110', (string) $response->getHeader('Warning')); + } + $this->assertSame(sprintf('%s GuzzleCache/%s', $request->getProtocolVersion(), Version::VERSION), (string) $request->getHeader('Via')); + $this->assertSame(sprintf('%s GuzzleCache/%s', $request->getProtocolVersion(), Version::VERSION), (string) $response->getHeader('Via')); + $this->assertTrue($request->getParams()->get('cache.lookup')); + $this->assertSame('error', $request->getParams()->get('cache.hit')); + $this->assertTrue($response->hasHeader('X-Cache-Lookup')); + $this->assertTrue($response->hasHeader('X-Cache')); + $this->assertEquals('HIT from GuzzleCache', (string) $response->getHeader('X-Cache-Lookup')); + $this->assertEquals('HIT_ERROR from GuzzleCache', (string) $response->getHeader('X-Cache')); + } + + /** + * @dataProvider satisfiableOnErrorProvider + */ + public function testInjectsSatisfiableResponsesOnException($cacheResponse) + { + $storage = $this->getMockBuilder('Guzzle\Plugin\Cache\CacheStorageInterface') + ->setMethods(array('fetch')) + ->getMockForAbstractClass(); + $storage->expects($this->exactly(2))->method('fetch')->will($this->returnValue($cacheResponse)); + $plugin = new CachePlugin(array('storage' => $storage)); + $request = new Request('GET', 'http://foo.com', array('Cache-Control' => 'max-stale')); + $plugin->onRequestBeforeSend(new Event(array( + 'request' => $request + ))); + $plugin->onRequestException( + new Event(array( + 'request' => $request, + 'response' => $request->getResponse(), + 'exception' => $this->getMock('Guzzle\Http\Exception\CurlException'), + )) + ); + $plugin->onRequestSent( + new Event(array( + 'request' => $request, + 'response' => $response = $request->getResponse(), + )) + ); + $this->assertEquals($cacheResponse->getStatusCode(), $response->getStatusCode()); + $this->assertEquals((string) $cacheResponse->getBody(), (string) $response->getBody()); + $this->assertTrue($response->hasHeader('Age')); + if ($response->isFresh() === false) { + $this->assertContains('110', (string) $response->getHeader('Warning')); + } + $this->assertSame(sprintf('%s GuzzleCache/%s', $request->getProtocolVersion(), Version::VERSION), (string) $request->getHeader('Via')); + $this->assertSame(sprintf('%s GuzzleCache/%s', $request->getProtocolVersion(), Version::VERSION), (string) $response->getHeader('Via')); + $this->assertTrue($request->getParams()->get('cache.lookup')); + $this->assertSame('error', $request->getParams()->get('cache.hit')); + $this->assertTrue($response->hasHeader('X-Cache-Lookup')); + $this->assertTrue($response->hasHeader('X-Cache')); + $this->assertEquals('HIT from GuzzleCache', (string) $response->getHeader('X-Cache-Lookup')); + $this->assertEquals('HIT_ERROR from GuzzleCache', (string) $response->getHeader('X-Cache')); + } + + public function unsatisfiableOnErrorProvider() + { + $date = new \DateTime('-10 seconds'); + + return array( + // no-store on request + array( + false, + array('Cache-Control' => 'no-store'), + new Response(200, array('Date' => $date->format('D, d M Y H:i:s T'), 'Cache-Control' => 'max-age=5, stale-if-error'), 'foo'), + ), + // request expired + array( + true, + array('Cache-Control' => 'stale-if-error=4'), + new Response(200, array('Date' => $date->format('D, d M Y H:i:s T'), 'Cache-Control' => 'max-age=5, stale-if-error'), 'foo'), + ), + // response expired + array( + true, + array('Cache-Control' => 'stale-if-error'), + new Response(200, array('Date' => $date->format('D, d M Y H:i:s T'), 'Cache-Control' => 'max-age=5, stale-if-error=4'), 'foo'), + ), + ); + } + + /** + * @dataProvider unsatisfiableOnErrorProvider + */ + public function testDoesNotInjectUnsatisfiableResponsesOnError($requestCanCache, $requestHeaders, $cacheResponse) + { + $storage = $this->getMockBuilder('Guzzle\Plugin\Cache\CacheStorageInterface') + ->setMethods(array('fetch')) + ->getMockForAbstractClass(); + $storage->expects($this->exactly($requestCanCache ? 2 : 0))->method('fetch')->will($this->returnValue($cacheResponse)); + $plugin = new CachePlugin(array('storage' => $storage)); + $request = new Request('GET', 'http://foo.com', $requestHeaders); + $plugin->onRequestBeforeSend(new Event(array( + 'request' => $request + ))); + $plugin->onRequestError( + $event = new Event(array( + 'request' => $request, + 'response' => $response = $request->getResponse(), + )) + ); + + $this->assertSame($response, $event['response']); + } + + /** + * @dataProvider unsatisfiableOnErrorProvider + */ + public function testDoesNotInjectUnsatisfiableResponsesOnException($requestCanCache, $requestHeaders, $responseParts) + { + $storage = $this->getMockBuilder('Guzzle\Plugin\Cache\CacheStorageInterface') + ->setMethods(array('fetch')) + ->getMockForAbstractClass(); + $storage->expects($this->exactly($requestCanCache ? 2 : 0))->method('fetch')->will($this->returnValue($responseParts)); + $plugin = new CachePlugin(array('storage' => $storage)); + $request = new Request('GET', 'http://foo.com', $requestHeaders); + $plugin->onRequestBeforeSend(new Event(array( + 'request' => $request + ))); + $plugin->onRequestException( + $event = new Event(array( + 'request' => $request, + 'response' => $response = $request->getResponse(), + 'exception' => $this->getMock('Guzzle\Http\Exception\CurlException'), + )) + ); + + $this->assertSame($response, $request->getResponse()); + } + + public function testCachesResponsesWhenCacheable() + { + $cache = new ArrayCache(); + $plugin = new CachePlugin($cache); + + $request = new Request('GET', 'http://foo.com'); + $response = new Response(200, array(), 'Foo'); + $plugin->onRequestBeforeSend(new Event(array( + 'request' => $request + ))); + $plugin->onRequestSent(new Event(array( + 'request' => $request, + 'response' => $response + ))); + $data = $this->readAttribute($cache, 'data'); + $this->assertNotEmpty($data); + } + + public function testPurgesRequests() + { + $storage = $this->getMockBuilder('Guzzle\Plugin\Cache\CacheStorageInterface') + ->setMethods(array('purge')) + ->getMockForAbstractClass(); + $storage->expects($this->atLeastOnce())->method('purge'); + $plugin = new CachePlugin(array('storage' => $storage)); + $request = new Request('GET', 'http://foo.com', array('X-Foo' => 'Bar')); + $plugin->purge($request); + } + + public function testAutoPurgesRequests() + { + $storage = $this->getMockBuilder('Guzzle\Plugin\Cache\CacheStorageInterface') + ->setMethods(array('purge')) + ->getMockForAbstractClass(); + $storage->expects($this->atLeastOnce())->method('purge'); + $plugin = new CachePlugin(array('storage' => $storage, 'auto_purge' => true)); + $client = new Client(); + $request = $client->put('http://foo.com', array('X-Foo' => 'Bar')); + $request->addSubscriber($plugin); + $request->setResponse(new Response(200), true); + $request->send(); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cache/CallbackCanCacheStrategyTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cache/CallbackCanCacheStrategyTest.php new file mode 100644 index 0000000..f3d9baf --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cache/CallbackCanCacheStrategyTest.php @@ -0,0 +1,72 @@ +assertTrue($c->canCacheRequest(new Request('DELETE', 'http://www.foo.com'))); + } + + /** + * The following is a bit of an integration test to ensure that the CachePlugin honors a + * custom can cache strategy. + */ + public function testIntegrationWithCachePlugin() + { + $c = new CallbackCanCacheStrategy( + function ($request) { return true; }, + function ($response) { return true; } + ); + + // Make a request and response that have no business being cached + $request = new Request('DELETE', 'http://www.foo.com'); + $response = Response::fromMessage( + "HTTP/1.1 200 OK\r\n" + . "Expires: Mon, 26 Jul 1997 05:00:00 GMT\r\n" + . "Last-Modified: Wed, 09 Jan 2013 08:48:53 GMT\r\n" + . "Content-Length: 2\r\n" + . "Cache-Control: no-store, no-cache, must-revalidate, post-check=0, pre-check=0\r\n\r\n" + . "hi" + ); + + $this->assertTrue($c->canCacheRequest($request)); + $this->assertTrue($c->canCacheResponse($response)); + + $s = $this->getMockBuilder('Guzzle\Plugin\Cache\DefaultCacheStorage') + ->setConstructorArgs(array(new DoctrineCacheAdapter(new ArrayCache()))) + ->setMethods(array('fetch')) + ->getMockForAbstractClass(); + + $s->expects($this->once()) + ->method('fetch') + ->will($this->returnValue($response)); + + $plugin = new CachePlugin(array('can_cache' => $c, 'storage' => $s)); + $plugin->onRequestBeforeSend(new Event(array('request' => $request))); + + $this->assertEquals(200, $request->getResponse()->getStatusCode()); + $this->assertEquals('hi', $request->getResponse()->getBody(true)); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cache/DefaultCacheStorageTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cache/DefaultCacheStorageTest.php new file mode 100644 index 0000000..701a015 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cache/DefaultCacheStorageTest.php @@ -0,0 +1,193 @@ + 'application/json')); + $response = new Response(200, array( + 'Content-Type' => 'application/json', + 'Connection' => 'close', + 'X-Foo' => 'Bar', + 'Vary' => 'Accept' + ), 'test'); + $s->cache($request, $response); + $data = $this->readAttribute($a, 'data'); + + return array( + 'cache' => $a, + 'adapter' => $c, + 'storage' => $s, + 'request' => $request, + 'response' => $response, + 'serialized' => end($data) + ); + } + + public function testReturnsNullForCacheMiss() + { + $cache = $this->getCache(); + $this->assertNull($cache['storage']->fetch(new Request('GET', 'http://test.com'))); + } + + public function testCachesRequests() + { + $cache = $this->getCache(); + $foundRequest = $foundBody = $bodyKey = false; + foreach ($this->readAttribute($cache['cache'], 'data') as $key => $v) { + if (strpos($v, 'foo.com')) { + $foundRequest = true; + $data = unserialize($v); + $bodyKey = $data[0][3]; + $this->assertInternalType('integer', $data[0][4]); + $this->assertFalse(isset($data[0][0]['connection'])); + $this->assertEquals('foo.com', $data[0][0]['host']); + } elseif ($v == 'test') { + $foundBody = $key; + } + } + $this->assertContains($bodyKey, $foundBody); + $this->assertTrue($foundRequest); + } + + public function testFetchesResponse() + { + $cache = $this->getCache(); + $response = $cache['storage']->fetch($cache['request']); + $this->assertEquals(200, $response->getStatusCode()); + $this->assertFalse($response->hasHeader('Connection')); + $this->assertEquals('Bar', (string) $response->getHeader('X-Foo')); + $this->assertEquals('test', (string) $response->getBody()); + $this->assertTrue(in_array($cache['serialized'], $this->readAttribute($cache['cache'], 'data'))); + } + + public function testDeletesRequestItemsAndBody() + { + $cache = $this->getCache(); + $cache['storage']->delete($cache['request']); + $this->assertFalse(in_array('test', $this->readAttribute($cache['cache'], 'data'))); + $this->assertFalse(in_array($cache['serialized'], $this->readAttribute($cache['cache'], 'data'))); + } + + public function testCachesMultipleRequestsWithVary() + { + $cache = $this->getCache(); + $cache['request']->setHeader('Accept', 'application/xml'); + $response = $cache['response']->setHeader('Content-Type', 'application/xml'); + $response->setBody('123'); + $cache['storage']->cache($cache['request'], $response); + $data = $this->readAttribute($cache['cache'], 'data'); + foreach ($data as $v) { + if (strpos($v, 'foo.com')) { + $u = unserialize($v); + $this->assertEquals(2, count($u)); + $this->assertEquals($u[0][0]['accept'], 'application/xml'); + $this->assertEquals($u[0][1]['content-type'], 'application/xml'); + $this->assertEquals($u[1][0]['accept'], 'application/json'); + $this->assertEquals($u[1][1]['content-type'], 'application/json'); + $this->assertNotSame($u[0][3], $u[1][3]); + break; + } + } + } + + public function testPurgeRemovesAllMethodCaches() + { + $cache = $this->getCache(); + foreach (array('HEAD', 'POST', 'PUT', 'DELETE') as $method) { + $request = RequestFactory::getInstance()->cloneRequestWithMethod($cache['request'], $method); + $cache['storage']->cache($request, $cache['response']); + } + $cache['storage']->purge('http://foo.com'); + $this->assertFalse(in_array('test', $this->readAttribute($cache['cache'], 'data'))); + $this->assertFalse(in_array($cache['serialized'], $this->readAttribute($cache['cache'], 'data'))); + $this->assertEquals( + array('DoctrineNamespaceCacheKey[]'), + array_keys($this->readAttribute($cache['cache'], 'data')) + ); + } + + public function testRemovesExpiredResponses() + { + $cache = $this->getCache(); + $request = new Request('GET', 'http://xyz.com'); + $response = new Response(200, array('Age' => 1000, 'Cache-Control' => 'max-age=-10000')); + $cache['storage']->cache($request, $response); + $this->assertNull($cache['storage']->fetch($request)); + $data = $this->readAttribute($cache['cache'], 'data'); + $this->assertFalse(in_array('xyz.com', $data)); + $this->assertTrue(in_array($cache['serialized'], $data)); + } + + public function testUsesVaryToDetermineResult() + { + $cache = $this->getCache(); + $this->assertInstanceOf('Guzzle\Http\Message\Response', $cache['storage']->fetch($cache['request'])); + $request = new Request('GET', 'http://foo.com', array('Accept' => 'application/xml')); + $this->assertNull($cache['storage']->fetch($request)); + } + + public function testEnsuresResponseIsStillPresent() + { + $cache = $this->getCache(); + $data = $this->readAttribute($cache['cache'], 'data'); + $key = array_search('test', $data); + $cache['cache']->delete(substr($key, 1, -4)); + $this->assertNull($cache['storage']->fetch($cache['request'])); + } + + public function staleProvider() + { + return array( + array( + new Request('GET', 'http://foo.com', array('Accept' => 'foo')), + new Response(200, array('Cache-Control' => 'stale-if-error=100', 'Vary' => 'Accept')) + ), + array( + new Request('GET', 'http://foo.com', array('Accept' => 'foo')), + new Response(200, array('Cache-Control' => 'stale-if-error', 'Vary' => 'Accept')) + ) + ); + } + + /** + * @dataProvider staleProvider + */ + public function testUsesStaleTimeDirectiveForTtd($request, $response) + { + $cache = $this->getCache(); + $cache['storage']->cache($request, $response); + $data = $this->readAttribute($cache['cache'], 'data'); + foreach ($data as $v) { + if (strpos($v, 'foo.com')) { + $u = unserialize($v); + $this->assertGreaterThan($u[1][4], $u[0][4]); + break; + } + } + } + + public function testCanFilterCacheKeys() + { + $cache = $this->getCache(); + $cache['request']->getQuery()->set('auth', 'foo'); + $this->assertNull($cache['storage']->fetch($cache['request'])); + $cache['request']->getParams()->set('cache.key_filter', 'auth'); + $this->assertNotNull($cache['storage']->fetch($cache['request'])); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cache/DefaultCanCacheStrategyTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cache/DefaultCanCacheStrategyTest.php new file mode 100644 index 0000000..de4d182 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cache/DefaultCanCacheStrategyTest.php @@ -0,0 +1,40 @@ +assertTrue($strategy->canCacheRequest($request)); + } + + public function testDoesNotCacheNoStore() + { + $strategy = new DefaultCanCacheStrategy(); + $request = new Request('GET', 'http://foo.com', array('cache-control' => 'no-store')); + $this->assertFalse($strategy->canCacheRequest($request)); + } + + public function testCanCacheResponse() + { + $response = $this->getMockBuilder('Guzzle\Http\Message\Response') + ->setMethods(array('canCache')) + ->setConstructorArgs(array(200)) + ->getMock(); + $response->expects($this->once()) + ->method('canCache') + ->will($this->returnValue(true)); + $strategy = new DefaultCanCacheStrategy(); + $this->assertTrue($strategy->canCacheResponse($response)); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cache/DefaultRevalidationTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cache/DefaultRevalidationTest.php new file mode 100644 index 0000000..0699cb2 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cache/DefaultRevalidationTest.php @@ -0,0 +1,248 @@ +getHttpDate('-100 hours') . "\r\nContent-Length: 4\r\n\r\nData", + "HTTP/1.1 304 NOT MODIFIED\r\nCache-Control: max-age=2000000\r\nContent-Length: 0\r\n\r\n", + ), + // Forces revalidation that overwrites what is in cache + array( + false, + "\r\n", + "HTTP/1.1 200 OK\r\nCache-Control: must-revalidate, no-cache\r\nDate: " . $this->getHttpDate('-10 hours') . "\r\nContent-Length: 4\r\n\r\nData", + "HTTP/1.1 200 OK\r\nContent-Length: 5\r\n\r\nDatas", + "HTTP/1.1 200 OK\r\nContent-Length: 5\r\nDate: " . $this->getHttpDate('now') . "\r\n\r\nDatas" + ), + // Throws an exception during revalidation + array( + false, + "\r\n", + "HTTP/1.1 200 OK\r\nCache-Control: no-cache\r\nDate: " . $this->getHttpDate('-3 hours') . "\r\n\r\nData", + "HTTP/1.1 500 INTERNAL SERVER ERROR\r\nContent-Length: 0\r\n\r\n" + ), + // ETag mismatch + array( + false, + "\r\n", + "HTTP/1.1 200 OK\r\nCache-Control: no-cache\r\nETag: \"123\"\r\nDate: " . $this->getHttpDate('-10 hours') . "\r\n\r\nData", + "HTTP/1.1 304 NOT MODIFIED\r\nETag: \"123456\"\r\n\r\n", + ), + ); + } + + /** + * @dataProvider cacheRevalidationDataProvider + */ + public function testRevalidatesResponsesAgainstOriginServer($can, $request, $response, $validate = null, $result = null) + { + // Send some responses to the test server for cache validation + $server = $this->getServer(); + $server->flush(); + + if ($validate) { + $server->enqueue($validate); + } + + $request = RequestFactory::getInstance()->fromMessage("GET / HTTP/1.1\r\nHost: 127.0.0.1:" . $server->getPort() . "\r\n" . $request); + $response = Response::fromMessage($response); + $request->setClient(new Client()); + + $plugin = new CachePlugin(new DoctrineCacheAdapter(new ArrayCache())); + $this->assertEquals( + $can, + $plugin->canResponseSatisfyRequest($request, $response), + '-> ' . $request . "\n" . $response + ); + + if ($result) { + $result = Response::fromMessage($result); + $result->removeHeader('Date'); + $request->getResponse()->removeHeader('Date'); + $request->getResponse()->removeHeader('Connection'); + // Get rid of dates + $this->assertEquals((string) $result, (string) $request->getResponse()); + } + + if ($validate) { + $this->assertEquals(1, count($server->getReceivedRequests())); + } + } + + public function testHandles404RevalidationResponses() + { + $request = new Request('GET', 'http://foo.com'); + $request->setClient(new Client()); + $badResponse = new Response(404, array(), 'Oh no!'); + $badRequest = clone $request; + $badRequest->setResponse($badResponse, true); + $response = new Response(200, array(), 'foo'); + + // Seed the cache + $s = new DefaultCacheStorage(new DoctrineCacheAdapter(new ArrayCache())); + $s->cache($request, $response); + $this->assertNotNull($s->fetch($request)); + + $rev = $this->getMockBuilder('Guzzle\Plugin\Cache\DefaultRevalidation') + ->setConstructorArgs(array($s)) + ->setMethods(array('createRevalidationRequest')) + ->getMock(); + + $rev->expects($this->once()) + ->method('createRevalidationRequest') + ->will($this->returnValue($badRequest)); + + try { + $rev->revalidate($request, $response); + $this->fail('Should have thrown an exception'); + } catch (BadResponseException $e) { + $this->assertSame($badResponse, $e->getResponse()); + $this->assertNull($s->fetch($request)); + } + } + + public function testCanRevalidateWithPlugin() + { + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 200 OK\r\n" . + "Date: Mon, 12 Nov 2012 03:06:37 GMT\r\n" . + "Cache-Control: private, s-maxage=0, max-age=0, must-revalidate\r\n" . + "Last-Modified: Mon, 12 Nov 2012 02:53:38 GMT\r\n" . + "Content-Length: 2\r\n\r\nhi", + "HTTP/1.0 304 Not Modified\r\n" . + "Date: Mon, 12 Nov 2012 03:06:38 GMT\r\n" . + "Content-Type: text/html; charset=UTF-8\r\n" . + "Last-Modified: Mon, 12 Nov 2012 02:53:38 GMT\r\n" . + "Age: 6302\r\n\r\n", + "HTTP/1.0 304 Not Modified\r\n" . + "Date: Mon, 12 Nov 2012 03:06:38 GMT\r\n" . + "Content-Type: text/html; charset=UTF-8\r\n" . + "Last-Modified: Mon, 12 Nov 2012 02:53:38 GMT\r\n" . + "Age: 6302\r\n\r\n", + )); + $client = new Client($this->getServer()->getUrl()); + $client->addSubscriber(new CachePlugin()); + $this->assertEquals(200, $client->get()->send()->getStatusCode()); + $this->assertEquals(200, $client->get()->send()->getStatusCode()); + $this->assertEquals(200, $client->get()->send()->getStatusCode()); + $this->assertEquals(3, count($this->getServer()->getReceivedRequests())); + } + + public function testCanHandleRevalidationFailures() + { + $client = new Client($this->getServer()->getUrl()); + $lm = gmdate('c', time() - 60); + $mock = new MockPlugin(array( + new Response(200, array( + 'Date' => $lm, + 'Cache-Control' => 'max-age=100, must-revalidate, stale-if-error=9999', + 'Last-Modified' => $lm, + 'Content-Length' => 2 + ), 'hi'), + new CurlException('Bleh'), + new CurlException('Bleh') + )); + $client->addSubscriber(new CachePlugin()); + $client->addSubscriber($mock); + $client->get()->send(); + $response = $client->get()->send(); + $this->assertEquals(200, $response->getStatusCode()); + $this->assertEquals('hi', $response->getBody(true)); + $this->assertEquals(3, count($mock->getReceivedRequests())); + $this->assertEquals(0, count($mock->getQueue())); + } + + public function testCanHandleStaleIfErrorWhenRevalidating() + { + $lm = gmdate('c', time() - 60); + $mock = new MockPlugin(array( + new Response(200, array( + 'Date' => $lm, + 'Cache-Control' => 'must-revalidate, max-age=0, stale-if-error=1200', + 'Last-Modified' => $lm, + 'Content-Length' => 2 + ), 'hi'), + new CurlException('Oh no!'), + new CurlException('Oh no!') + )); + $cache = new CachePlugin(); + $client = new Client('http://www.example.com'); + $client->addSubscriber($cache); + $client->addSubscriber($mock); + $this->assertEquals(200, $client->get()->send()->getStatusCode()); + $response = $client->get()->send(); + $this->assertEquals(200, $response->getStatusCode()); + $this->assertCount(0, $mock); + $this->assertEquals('HIT from GuzzleCache', (string) $response->getHeader('X-Cache-Lookup')); + $this->assertEquals('HIT_ERROR from GuzzleCache', (string) $response->getHeader('X-Cache')); + } + + /** + * @group issue-437 + */ + public function testDoesNotTouchClosureListeners() + { + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 200 OK\r\n" . + "Date: Mon, 12 Nov 2012 03:06:37 GMT\r\n" . + "Cache-Control: private, s-maxage=0, max-age=0, must-revalidate\r\n" . + "Last-Modified: Mon, 12 Nov 2012 02:53:38 GMT\r\n" . + "Content-Length: 2\r\n\r\nhi", + "HTTP/1.0 304 Not Modified\r\n" . + "Date: Mon, 12 Nov 2012 03:06:38 GMT\r\n" . + "Content-Type: text/html; charset=UTF-8\r\n" . + "Last-Modified: Mon, 12 Nov 2012 02:53:38 GMT\r\n" . + "Age: 6302\r\n\r\n", + "HTTP/1.0 304 Not Modified\r\n" . + "Date: Mon, 12 Nov 2012 03:06:38 GMT\r\n" . + "Content-Type: text/html; charset=UTF-8\r\n" . + "Last-Modified: Mon, 12 Nov 2012 02:53:38 GMT\r\n" . + "Age: 6302\r\n\r\n", + )); + $client = new Client($this->getServer()->getUrl()); + $client->addSubscriber(new CachePlugin()); + $client->getEventDispatcher()->addListener('command.after_send', function(){}); + $this->assertEquals(200, $client->get()->send()->getStatusCode()); + $this->assertEquals(200, $client->get()->send()->getStatusCode()); + $this->assertEquals(200, $client->get()->send()->getStatusCode()); + } + +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cache/DenyRevalidationTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cache/DenyRevalidationTest.php new file mode 100644 index 0000000..9af80f2 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cache/DenyRevalidationTest.php @@ -0,0 +1,19 @@ +assertFalse($deny->revalidate(new Request('GET', 'http://foo.com'), new Response(200))); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cache/SkipRevalidationTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cache/SkipRevalidationTest.php new file mode 100644 index 0000000..4bcc04b --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cache/SkipRevalidationTest.php @@ -0,0 +1,19 @@ +assertTrue($skip->revalidate(new Request('GET', 'http://foo.com'), new Response(200))); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cookie/CookieJar/ArrayCookieJarTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cookie/CookieJar/ArrayCookieJarTest.php new file mode 100644 index 0000000..5d0f668 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cookie/CookieJar/ArrayCookieJarTest.php @@ -0,0 +1,385 @@ +jar = new ArrayCookieJar(); + } + + protected function getTestCookies() + { + return array( + new Cookie(array('name' => 'foo', 'value' => 'bar', 'domain' => 'foo.com', 'path' => '/', 'discard' => true)), + new Cookie(array('name' => 'test', 'value' => '123', 'domain' => 'baz.com', 'path' => '/foo', 'expires' => 2)), + new Cookie(array('name' => 'you', 'value' => '123', 'domain' => 'bar.com', 'path' => '/boo', 'expires' => time() + 1000)) + ); + } + + /** + * Provides test data for cookie cookieJar retrieval + */ + public function getCookiesDataProvider() + { + return array( + array(array('foo', 'baz', 'test', 'muppet', 'googoo'), '', '', '', false), + array(array('foo', 'baz', 'muppet', 'googoo'), '', '', '', true), + array(array('googoo'), 'www.example.com', '', '', false), + array(array('muppet', 'googoo'), 'test.y.example.com', '', '', false), + array(array('foo', 'baz'), 'example.com', '', '', false), + array(array('muppet'), 'x.y.example.com', '/acme/', '', false), + array(array('muppet'), 'x.y.example.com', '/acme/test/', '', false), + array(array('googoo'), 'x.y.example.com', '/test/acme/test/', '', false), + array(array('foo', 'baz'), 'example.com', '', '', false), + array(array('baz'), 'example.com', '', 'baz', false), + ); + } + + public function testStoresAndRetrievesCookies() + { + $cookies = $this->getTestCookies(); + foreach ($cookies as $cookie) { + $this->assertTrue($this->jar->add($cookie)); + } + + $this->assertEquals(3, count($this->jar)); + $this->assertEquals(3, count($this->jar->getIterator())); + $this->assertEquals($cookies, $this->jar->all(null, null, null, false, false)); + } + + public function testRemovesExpiredCookies() + { + $cookies = $this->getTestCookies(); + foreach ($this->getTestCookies() as $cookie) { + $this->jar->add($cookie); + } + $this->jar->removeExpired(); + $this->assertEquals(array($cookies[0], $cookies[2]), $this->jar->all()); + } + + public function testRemovesTemporaryCookies() + { + $cookies = $this->getTestCookies(); + foreach ($this->getTestCookies() as $cookie) { + $this->jar->add($cookie); + } + $this->jar->removeTemporary(); + $this->assertEquals(array($cookies[2]), $this->jar->all()); + } + + public function testIsSerializable() + { + $this->assertEquals('[]', $this->jar->serialize()); + $this->jar->unserialize('[]'); + $this->assertEquals(array(), $this->jar->all()); + + $cookies = $this->getTestCookies(); + foreach ($this->getTestCookies() as $cookie) { + $this->jar->add($cookie); + } + + // Remove discard and expired cookies + $serialized = $this->jar->serialize(); + $data = json_decode($serialized, true); + $this->assertEquals(1, count($data)); + + $a = new ArrayCookieJar(); + $a->unserialize($serialized); + $this->assertEquals(1, count($a)); + } + + public function testRemovesSelectively() + { + $cookies = $this->getTestCookies(); + foreach ($this->getTestCookies() as $cookie) { + $this->jar->add($cookie); + } + + // Remove foo.com cookies + $this->jar->remove('foo.com'); + $this->assertEquals(2, count($this->jar)); + // Try again, removing no further cookies + $this->jar->remove('foo.com'); + $this->assertEquals(2, count($this->jar)); + + // Remove bar.com cookies with path of /boo + $this->jar->remove('bar.com', '/boo'); + $this->assertEquals(1, count($this->jar)); + + // Remove cookie by name + $this->jar->remove(null, null, 'test'); + $this->assertEquals(0, count($this->jar)); + } + + public function testDoesNotAddIncompleteCookies() + { + $this->assertEquals(false, $this->jar->add(new Cookie())); + $this->assertFalse($this->jar->add(new Cookie(array( + 'name' => 'foo' + )))); + $this->assertFalse($this->jar->add(new Cookie(array( + 'name' => false + )))); + $this->assertFalse($this->jar->add(new Cookie(array( + 'name' => true + )))); + $this->assertFalse($this->jar->add(new Cookie(array( + 'name' => 'foo', + 'domain' => 'foo.com' + )))); + } + + public function testDoesAddValidCookies() + { + $this->assertTrue($this->jar->add(new Cookie(array( + 'name' => 'foo', + 'domain' => 'foo.com', + 'value' => 0 + )))); + $this->assertTrue($this->jar->add(new Cookie(array( + 'name' => 'foo', + 'domain' => 'foo.com', + 'value' => 0.0 + )))); + $this->assertTrue($this->jar->add(new Cookie(array( + 'name' => 'foo', + 'domain' => 'foo.com', + 'value' => '0' + )))); + } + + public function testOverwritesCookiesThatAreOlderOrDiscardable() + { + $t = time() + 1000; + $data = array( + 'name' => 'foo', + 'value' => 'bar', + 'domain' => '.example.com', + 'path' => '/', + 'max_age' => '86400', + 'port' => array(80, 8080), + 'version' => '1', + 'secure' => true, + 'discard' => true, + 'expires' => $t + ); + + // Make sure that the discard cookie is overridden with the non-discard + $this->assertTrue($this->jar->add(new Cookie($data))); + + unset($data['discard']); + $this->assertTrue($this->jar->add(new Cookie($data))); + $this->assertEquals(1, count($this->jar)); + + $c = $this->jar->all(); + $this->assertEquals(false, $c[0]->getDiscard()); + + // Make sure it doesn't duplicate the cookie + $this->jar->add(new Cookie($data)); + $this->assertEquals(1, count($this->jar)); + + // Make sure the more future-ful expiration date supersede the other + $data['expires'] = time() + 2000; + $this->assertTrue($this->jar->add(new Cookie($data))); + $this->assertEquals(1, count($this->jar)); + $c = $this->jar->all(); + $this->assertNotEquals($t, $c[0]->getExpires()); + } + + public function testOverwritesCookiesThatHaveChanged() + { + $t = time() + 1000; + $data = array( + 'name' => 'foo', + 'value' => 'bar', + 'domain' => '.example.com', + 'path' => '/', + 'max_age' => '86400', + 'port' => array(80, 8080), + 'version' => '1', + 'secure' => true, + 'discard' => true, + 'expires' => $t + ); + + // Make sure that the discard cookie is overridden with the non-discard + $this->assertTrue($this->jar->add(new Cookie($data))); + + $data['value'] = 'boo'; + $this->assertTrue($this->jar->add(new Cookie($data))); + $this->assertEquals(1, count($this->jar)); + + // Changing the value plus a parameter also must overwrite the existing one + $data['value'] = 'zoo'; + $data['secure'] = false; + $this->assertTrue($this->jar->add(new Cookie($data))); + $this->assertEquals(1, count($this->jar)); + + $c = $this->jar->all(); + $this->assertEquals('zoo', $c[0]->getValue()); + } + + public function testAddsCookiesFromResponseWithNoRequest() + { + $response = new Response(200, array( + 'Set-Cookie' => array( + "fpc=d=.Hm.yh4.1XmJWjJfs4orLQzKzPImxklQoxXSHOZATHUSEFciRueW_7704iYUtsXNEXq0M92Px2glMdWypmJ7HIQl6XIUvrZimWjQ3vIdeuRbI.FNQMAfcxu_XN1zSx7l.AcPdKL6guHc2V7hIQFhnjRW0rxm2oHY1P4bGQxFNz7f.tHm12ZD3DbdMDiDy7TBXsuP4DM-&v=2; expires=Fri, 02-Mar-2019 02:17:40 GMT; path=/; domain=127.0.0.1", + "FPCK3=AgBNbvoQAGpGEABZLRAAbFsQAF1tEABkDhAAeO0=; expires=Sat, 02-Apr-2019 02:17:40 GMT; path=/; domain=127.0.0.1", + "CH=deleted; expires=Wed, 03-Mar-2010 02:17:39 GMT; path=/; domain=127.0.0.1", + "CH=AgBNbvoQAAEcEAApuhAAMJcQADQvEAAvGxAALe0QAD6uEAATwhAAC1AQAC8t; expires=Sat, 02-Apr-2019 02:17:40 GMT; path=/; domain=127.0.0.1" + ) + )); + + $this->jar->addCookiesFromResponse($response); + $this->assertEquals(3, count($this->jar)); + $this->assertEquals(1, count($this->jar->all(null, null, 'fpc'))); + $this->assertEquals(1, count($this->jar->all(null, null, 'FPCK3'))); + $this->assertEquals(1, count($this->jar->all(null, null, 'CH'))); + } + + public function testAddsCookiesFromResponseWithRequest() + { + $response = new Response(200, array( + 'Set-Cookie' => "fpc=d=.Hm.yh4.1XmJWjJfs4orLQzKzPImxklQoxXSHOZATHUSEFciRueW_7704iYUtsXNEXq0M92Px2glMdWypmJ7HIQl6XIUvrZimWjQ3vIdeuRbI.FNQMAfcxu_XN1zSx7l.AcPdKL6guHc2V7hIQFhnjRW0rxm2oHY1P4bGQxFNz7f.tHm12ZD3DbdMDiDy7TBXsuP4DM-&v=2; expires=Fri, 02-Mar-2019 02:17:40 GMT;" + )); + $request = new Request('GET', 'http://www.example.com'); + $this->jar->addCookiesFromResponse($response, $request); + $this->assertEquals(1, count($this->jar)); + } + + public function getMatchingCookiesDataProvider() + { + return array( + array('https://example.com', array(0)), + array('http://example.com', array()), + array('https://example.com:8912', array()), + array('https://foo.example.com', array(0)), + array('http://foo.example.com/test/acme/', array(4)) + ); + } + + /** + * @dataProvider getMatchingCookiesDataProvider + */ + public function testReturnsCookiesMatchingRequests($url, $cookies) + { + $bag = array( + new Cookie(array( + 'name' => 'foo', + 'value' => 'bar', + 'domain' => 'example.com', + 'path' => '/', + 'max_age' => '86400', + 'port' => array(443, 8080), + 'version' => '1', + 'secure' => true + )), + new Cookie(array( + 'name' => 'baz', + 'value' => 'foobar', + 'domain' => 'example.com', + 'path' => '/', + 'max_age' => '86400', + 'port' => array(80, 8080), + 'version' => '1', + 'secure' => true + )), + new Cookie(array( + 'name' => 'test', + 'value' => '123', + 'domain' => 'www.foobar.com', + 'path' => '/path/', + 'discard' => true + )), + new Cookie(array( + 'name' => 'muppet', + 'value' => 'cookie_monster', + 'domain' => '.y.example.com', + 'path' => '/acme/', + 'comment' => 'Comment goes here...', + 'expires' => time() + 86400 + )), + new Cookie(array( + 'name' => 'googoo', + 'value' => 'gaga', + 'domain' => '.example.com', + 'path' => '/test/acme/', + 'max_age' => 1500, + 'version' => 2 + )) + ); + + foreach ($bag as $cookie) { + $this->jar->add($cookie); + } + + $request = new Request('GET', $url); + $results = $this->jar->getMatchingCookies($request); + $this->assertEquals(count($cookies), count($results)); + foreach ($cookies as $i) { + $this->assertContains($bag[$i], $results); + } + } + + /** + * @expectedException \Guzzle\Plugin\Cookie\Exception\InvalidCookieException + * @expectedExceptionMessage The cookie name must not contain invalid characters: abc:@123 + */ + public function testThrowsExceptionWithStrictMode() + { + $a = new ArrayCookieJar(); + $a->setStrictMode(true); + $a->add(new Cookie(array( + 'name' => 'abc:@123', + 'value' => 'foo', + 'domain' => 'bar' + ))); + } + + public function testRemoveExistingCookieIfEmpty() + { + // Add a cookie that should not be affected + $a = new Cookie(array( + 'name' => 'foo', + 'value' => 'nope', + 'domain' => 'foo.com', + 'path' => '/abc' + )); + $this->jar->add($a); + + $data = array( + 'name' => 'foo', + 'value' => 'bar', + 'domain' => 'foo.com', + 'path' => '/' + ); + + $b = new Cookie($data); + $this->assertTrue($this->jar->add($b)); + $this->assertEquals(2, count($this->jar)); + + // Try to re-set the same cookie with no value: assert that cookie is not added + $data['value'] = null; + $this->assertFalse($this->jar->add(new Cookie($data))); + // assert that original cookie has been deleted + $cookies = $this->jar->all('foo.com'); + $this->assertTrue(in_array($a, $cookies, true)); + $this->assertFalse(in_array($b, $cookies, true)); + $this->assertEquals(1, count($this->jar)); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cookie/CookieJar/FileCookieJarTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cookie/CookieJar/FileCookieJarTest.php new file mode 100644 index 0000000..ac9471f --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cookie/CookieJar/FileCookieJarTest.php @@ -0,0 +1,63 @@ +file = tempnam('/tmp', 'file-cookies'); + } + + public function testLoadsFromFileFile() + { + $jar = new FileCookieJar($this->file); + $this->assertEquals(array(), $jar->all()); + unlink($this->file); + } + + public function testPersistsToFileFile() + { + $jar = new FileCookieJar($this->file); + $jar->add(new Cookie(array( + 'name' => 'foo', + 'value' => 'bar', + 'domain' => 'foo.com', + 'expires' => time() + 1000 + ))); + $jar->add(new Cookie(array( + 'name' => 'baz', + 'value' => 'bar', + 'domain' => 'foo.com', + 'expires' => time() + 1000 + ))); + $jar->add(new Cookie(array( + 'name' => 'boo', + 'value' => 'bar', + 'domain' => 'foo.com', + ))); + + $this->assertEquals(3, count($jar)); + unset($jar); + + // Make sure it wrote to the file + $contents = file_get_contents($this->file); + $this->assertNotEmpty($contents); + + // Load the cookieJar from the file + $jar = new FileCookieJar($this->file); + + // Weeds out temporary and session cookies + $this->assertEquals(2, count($jar)); + unset($jar); + unlink($this->file); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cookie/CookiePluginTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cookie/CookiePluginTest.php new file mode 100644 index 0000000..f8c175c --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cookie/CookiePluginTest.php @@ -0,0 +1,134 @@ +getMockBuilder('Guzzle\Plugin\Cookie\CookieJar\ArrayCookieJar') + ->setMethods(array('addCookiesFromResponse')) + ->getMock(); + + $mock->expects($this->exactly(1)) + ->method('addCookiesFromResponse') + ->with($response); + + $plugin = new CookiePlugin($mock); + $plugin->onRequestSent(new Event(array( + 'response' => $response + ))); + } + + public function testAddsCookiesToRequests() + { + $cookie = new Cookie(array( + 'name' => 'foo', + 'value' => 'bar' + )); + + $mock = $this->getMockBuilder('Guzzle\Plugin\Cookie\CookieJar\ArrayCookieJar') + ->setMethods(array('getMatchingCookies')) + ->getMock(); + + $mock->expects($this->once()) + ->method('getMatchingCookies') + ->will($this->returnValue(array($cookie))); + + $plugin = new CookiePlugin($mock); + + $client = new Client(); + $client->getEventDispatcher()->addSubscriber($plugin); + + $request = $client->get('http://www.example.com'); + $plugin->onRequestBeforeSend(new Event(array( + 'request' => $request + ))); + + $this->assertEquals('bar', $request->getCookie('foo')); + } + + public function testCookiesAreExtractedFromRedirectResponses() + { + $plugin = new CookiePlugin(new ArrayCookieJar()); + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 302 Moved Temporarily\r\n" . + "Set-Cookie: test=583551; expires=Wednesday, 23-Mar-2050 19:49:45 GMT; path=/\r\n" . + "Location: /redirect\r\n\r\n", + "HTTP/1.1 200 OK\r\n" . + "Content-Length: 0\r\n\r\n", + "HTTP/1.1 200 OK\r\n" . + "Content-Length: 0\r\n\r\n" + )); + + $client = new Client($this->getServer()->getUrl()); + $client->getEventDispatcher()->addSubscriber($plugin); + + $client->get()->send(); + $request = $client->get(); + $request->send(); + $this->assertEquals('test=583551', $request->getHeader('Cookie')); + + $requests = $this->getServer()->getReceivedRequests(true); + // Confirm subsequent requests have the cookie. + $this->assertEquals('test=583551', $requests[2]->getHeader('Cookie')); + // Confirm the redirected request has the cookie. + $this->assertEquals('test=583551', $requests[1]->getHeader('Cookie')); + } + + public function testCookiesAreNotAddedWhenParamIsSet() + { + $jar = new ArrayCookieJar(); + $plugin = new CookiePlugin($jar); + + $jar->add(new Cookie(array( + 'domain' => 'example.com', + 'path' => '/', + 'name' => 'test', + 'value' => 'hi', + 'expires' => time() + 3600 + ))); + + $client = new Client('http://example.com'); + $client->getEventDispatcher()->addSubscriber($plugin); + + // Ensure that it is normally added + $request = $client->get(); + $request->setResponse(new Response(200), true); + $request->send(); + $this->assertEquals('hi', $request->getCookie('test')); + + // Now ensure that it is not added + $request = $client->get(); + $request->getParams()->set('cookies.disable', true); + $request->setResponse(new Response(200), true); + $request->send(); + $this->assertNull($request->getCookie('test')); + } + + public function testProvidesCookieJar() + { + $jar = new ArrayCookieJar(); + $plugin = new CookiePlugin($jar); + $this->assertSame($jar, $plugin->getCookieJar()); + } + + public function testEscapesCookieDomains() + { + $cookie = new Cookie(array('domain' => '/foo/^$[A-Z]+/')); + $this->assertFalse($cookie->matchesDomain('foo')); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cookie/CookieTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cookie/CookieTest.php new file mode 100644 index 0000000..9fb0b43 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Cookie/CookieTest.php @@ -0,0 +1,223 @@ +assertEquals('/', $cookie->getPath()); + $this->assertEquals(array(), $cookie->getPorts()); + } + + public function testConvertsDateTimeMaxAgeToUnixTimestamp() + { + $cookie = new Cookie(array( + 'expires' => 'November 20, 1984' + )); + $this->assertTrue(is_numeric($cookie->getExpires())); + } + + public function testAddsExpiresBasedOnMaxAge() + { + $t = time(); + $cookie = new Cookie(array( + 'max_age' => 100 + )); + $this->assertEquals($t + 100, $cookie->getExpires()); + } + + public function testHoldsValues() + { + $t = time(); + $data = array( + 'name' => 'foo', + 'value' => 'baz', + 'path' => '/bar', + 'domain' => 'baz.com', + 'expires' => $t, + 'max_age' => 100, + 'comment' => 'Hi', + 'comment_url' => 'foo.com', + 'port' => array(1, 2), + 'version' => 2, + 'secure' => true, + 'discard' => true, + 'http_only' => true, + 'data' => array( + 'foo' => 'baz', + 'bar' => 'bam' + ) + ); + + $cookie = new Cookie($data); + $this->assertEquals($data, $cookie->toArray()); + + $this->assertEquals('foo', $cookie->getName()); + $this->assertEquals('baz', $cookie->getValue()); + $this->assertEquals('baz.com', $cookie->getDomain()); + $this->assertEquals('/bar', $cookie->getPath()); + $this->assertEquals($t, $cookie->getExpires()); + $this->assertEquals(100, $cookie->getMaxAge()); + $this->assertEquals('Hi', $cookie->getComment()); + $this->assertEquals('foo.com', $cookie->getCommentUrl()); + $this->assertEquals(array(1, 2), $cookie->getPorts()); + $this->assertEquals(2, $cookie->getVersion()); + $this->assertTrue($cookie->getSecure()); + $this->assertTrue($cookie->getDiscard()); + $this->assertTrue($cookie->getHttpOnly()); + $this->assertEquals('baz', $cookie->getAttribute('foo')); + $this->assertEquals('bam', $cookie->getAttribute('bar')); + $this->assertEquals(array( + 'foo' => 'baz', + 'bar' => 'bam' + ), $cookie->getAttributes()); + + $cookie->setName('a') + ->setValue('b') + ->setPath('c') + ->setDomain('bar.com') + ->setExpires(10) + ->setMaxAge(200) + ->setComment('e') + ->setCommentUrl('f') + ->setPorts(array(80)) + ->setVersion(3) + ->setSecure(false) + ->setHttpOnly(false) + ->setDiscard(false) + ->setAttribute('snoop', 'dog'); + + $this->assertEquals('a', $cookie->getName()); + $this->assertEquals('b', $cookie->getValue()); + $this->assertEquals('c', $cookie->getPath()); + $this->assertEquals('bar.com', $cookie->getDomain()); + $this->assertEquals(10, $cookie->getExpires()); + $this->assertEquals(200, $cookie->getMaxAge()); + $this->assertEquals('e', $cookie->getComment()); + $this->assertEquals('f', $cookie->getCommentUrl()); + $this->assertEquals(array(80), $cookie->getPorts()); + $this->assertEquals(3, $cookie->getVersion()); + $this->assertFalse($cookie->getSecure()); + $this->assertFalse($cookie->getDiscard()); + $this->assertFalse($cookie->getHttpOnly()); + $this->assertEquals('dog', $cookie->getAttribute('snoop')); + } + + public function testDeterminesIfExpired() + { + $c = new Cookie(); + $c->setExpires(10); + $this->assertTrue($c->isExpired()); + $c->setExpires(time() + 10000); + $this->assertFalse($c->isExpired()); + } + + public function testMatchesPorts() + { + $cookie = new Cookie(); + // Always matches when nothing is set + $this->assertTrue($cookie->matchesPort(2)); + + $cookie->setPorts(array(1, 2)); + $this->assertTrue($cookie->matchesPort(2)); + $this->assertFalse($cookie->matchesPort(100)); + } + + public function testMatchesDomain() + { + $cookie = new Cookie(); + $this->assertTrue($cookie->matchesDomain('baz.com')); + + $cookie->setDomain('baz.com'); + $this->assertTrue($cookie->matchesDomain('baz.com')); + $this->assertFalse($cookie->matchesDomain('bar.com')); + + $cookie->setDomain('.baz.com'); + $this->assertTrue($cookie->matchesDomain('.baz.com')); + $this->assertTrue($cookie->matchesDomain('foo.baz.com')); + $this->assertFalse($cookie->matchesDomain('baz.bar.com')); + $this->assertTrue($cookie->matchesDomain('baz.com')); + + $cookie->setDomain('.127.0.0.1'); + $this->assertTrue($cookie->matchesDomain('127.0.0.1')); + + $cookie->setDomain('127.0.0.1'); + $this->assertTrue($cookie->matchesDomain('127.0.0.1')); + + $cookie->setDomain('.com.'); + $this->assertFalse($cookie->matchesDomain('baz.com')); + + $cookie->setDomain('.local'); + $this->assertTrue($cookie->matchesDomain('example.local')); + } + + public function testMatchesPath() + { + $cookie = new Cookie(); + $this->assertTrue($cookie->matchesPath('/foo')); + + $cookie->setPath('/foo'); + + // o The cookie-path and the request-path are identical. + $this->assertTrue($cookie->matchesPath('/foo')); + $this->assertFalse($cookie->matchesPath('/bar')); + + // 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. + $this->assertTrue($cookie->matchesPath('/foo/bar')); + $this->assertFalse($cookie->matchesPath('/fooBar')); + + // o The cookie-path is a prefix of the request-path, and the last + // character of the cookie-path is %x2F ("/"). + $cookie->setPath('/foo/'); + $this->assertTrue($cookie->matchesPath('/foo/bar')); + $this->assertFalse($cookie->matchesPath('/fooBaz')); + $this->assertFalse($cookie->matchesPath('/foo')); + + } + + public function cookieValidateProvider() + { + return array( + array('foo', 'baz', 'bar', true), + array('0', '0', '0', true), + array('', 'baz', 'bar', 'The cookie name must not be empty'), + array('foo', '', 'bar', 'The cookie value must not be empty'), + array('foo', 'baz', '', 'The cookie domain must not be empty'), + array('foo\\', 'baz', '0', 'The cookie name must not contain invalid characters: foo\\'), + ); + } + + /** + * @dataProvider cookieValidateProvider + */ + public function testValidatesCookies($name, $value, $domain, $result) + { + $cookie = new Cookie(array( + 'name' => $name, + 'value' => $value, + 'domain' => $domain + )); + $this->assertSame($result, $cookie->validate()); + } + + public function testCreatesInvalidCharacterString() + { + $m = new \ReflectionMethod('Guzzle\Plugin\Cookie\Cookie', 'getInvalidCharacters'); + $m->setAccessible(true); + $p = new \ReflectionProperty('Guzzle\Plugin\Cookie\Cookie', 'invalidCharString'); + $p->setAccessible(true); + $p->setValue(''); + // Expects a string containing 51 invalid characters + $this->assertEquals(51, strlen($m->invoke($m))); + $this->assertContains('@', $m->invoke($m)); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/CurlAuth/CurlAuthPluginTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/CurlAuth/CurlAuthPluginTest.php new file mode 100644 index 0000000..2a4b49e --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/CurlAuth/CurlAuthPluginTest.php @@ -0,0 +1,39 @@ +getEventDispatcher()->addSubscriber($plugin); + $request = $client->get('/'); + $this->assertEquals('michael', $request->getUsername()); + $this->assertEquals('test', $request->getPassword()); + Version::$emitWarnings = true; + } + + public function testAddsDigestAuthentication() + { + Version::$emitWarnings = false; + $plugin = new CurlAuthPlugin('julian', 'test', CURLAUTH_DIGEST); + $client = new Client('http://www.test.com/'); + $client->getEventDispatcher()->addSubscriber($plugin); + $request = $client->get('/'); + $this->assertEquals('julian', $request->getUsername()); + $this->assertEquals('test', $request->getPassword()); + $this->assertEquals('julian:test', $request->getCurlOptions()->get(CURLOPT_USERPWD)); + $this->assertEquals(CURLAUTH_DIGEST, $request->getCurlOptions()->get(CURLOPT_HTTPAUTH)); + Version::$emitWarnings = true; + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/ErrorResponse/ErrorResponsePluginTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/ErrorResponse/ErrorResponsePluginTest.php new file mode 100644 index 0000000..6f94186 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/ErrorResponse/ErrorResponsePluginTest.php @@ -0,0 +1,137 @@ +flush(); + } + + public function setUp() + { + $mockError = 'Guzzle\Tests\Mock\ErrorResponseMock'; + $description = ServiceDescription::factory(array( + 'operations' => array( + 'works' => array( + 'httpMethod' => 'GET', + 'errorResponses' => array( + array('code' => 500, 'class' => $mockError), + array('code' => 503, 'reason' => 'foo', 'class' => $mockError), + array('code' => 200, 'reason' => 'Error!', 'class' => $mockError) + ) + ), + 'bad_class' => array( + 'httpMethod' => 'GET', + 'errorResponses' => array( + array('code' => 500, 'class' => 'Does\\Not\\Exist') + ) + ), + 'does_not_implement' => array( + 'httpMethod' => 'GET', + 'errorResponses' => array( + array('code' => 500, 'class' => __CLASS__) + ) + ), + 'no_errors' => array('httpMethod' => 'GET'), + 'no_class' => array( + 'httpMethod' => 'GET', + 'errorResponses' => array( + array('code' => 500) + ) + ), + ) + )); + $this->client = new Client($this->getServer()->getUrl()); + $this->client->setDescription($description); + } + + /** + * @expectedException \Guzzle\Http\Exception\ServerErrorResponseException + */ + public function testSkipsWhenErrorResponsesIsNotSet() + { + $this->getServer()->enqueue("HTTP/1.1 500 Foo\r\nContent-Length: 0\r\n\r\n"); + $this->client->addSubscriber(new ErrorResponsePlugin()); + $this->client->getCommand('no_errors')->execute(); + } + + public function testSkipsWhenErrorResponsesIsNotSetAndAllowsSuccess() + { + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n"); + $this->client->addSubscriber(new ErrorResponsePlugin()); + $this->client->getCommand('no_errors')->execute(); + } + + /** + * @expectedException \Guzzle\Plugin\ErrorResponse\Exception\ErrorResponseException + * @expectedExceptionMessage Does\Not\Exist does not exist + */ + public function testEnsuresErrorResponseExists() + { + $this->getServer()->enqueue("HTTP/1.1 500 Foo\r\nContent-Length: 0\r\n\r\n"); + $this->client->addSubscriber(new ErrorResponsePlugin()); + $this->client->getCommand('bad_class')->execute(); + } + + /** + * @expectedException \Guzzle\Plugin\ErrorResponse\Exception\ErrorResponseException + * @expectedExceptionMessage must implement Guzzle\Plugin\ErrorResponse\ErrorResponseExceptionInterface + */ + public function testEnsuresErrorResponseImplementsInterface() + { + $this->getServer()->enqueue("HTTP/1.1 500 Foo\r\nContent-Length: 0\r\n\r\n"); + $this->client->addSubscriber(new ErrorResponsePlugin()); + $this->client->getCommand('does_not_implement')->execute(); + } + + public function testThrowsSpecificErrorResponseOnMatch() + { + try { + $this->getServer()->enqueue("HTTP/1.1 500 Foo\r\nContent-Length: 0\r\n\r\n"); + $this->client->addSubscriber(new ErrorResponsePlugin()); + $command = $this->client->getCommand('works'); + $command->execute(); + $this->fail('Exception not thrown'); + } catch (ErrorResponseMock $e) { + $this->assertSame($command, $e->command); + $this->assertEquals(500, $e->response->getStatusCode()); + } + } + + /** + * @expectedException \Guzzle\Tests\Mock\ErrorResponseMock + */ + public function testThrowsWhenCodeAndPhraseMatch() + { + $this->getServer()->enqueue("HTTP/1.1 200 Error!\r\nContent-Length: 0\r\n\r\n"); + $this->client->addSubscriber(new ErrorResponsePlugin()); + $this->client->getCommand('works')->execute(); + } + + public function testSkipsWhenReasonDoesNotMatch() + { + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n"); + $this->client->addSubscriber(new ErrorResponsePlugin()); + $this->client->getCommand('works')->execute(); + } + + public function testSkipsWhenNoClassIsSet() + { + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n"); + $this->client->addSubscriber(new ErrorResponsePlugin()); + $this->client->getCommand('no_class')->execute(); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/History/HistoryPluginTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/History/HistoryPluginTest.php new file mode 100644 index 0000000..84dc90d --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/History/HistoryPluginTest.php @@ -0,0 +1,140 @@ +get(); + $requests[$i]->setResponse(new Response(200), true); + $requests[$i]->send(); + $h->add($requests[$i]); + } + + return $requests; + } + + public function testDescribesSubscribedEvents() + { + $this->assertInternalType('array', HistoryPlugin::getSubscribedEvents()); + } + + public function testMaintainsLimitValue() + { + $h = new HistoryPlugin(); + $this->assertSame($h, $h->setLimit(10)); + $this->assertEquals(10, $h->getLimit()); + } + + public function testAddsRequests() + { + $h = new HistoryPlugin(); + $requests = $this->addRequests($h, 1); + $this->assertEquals(1, count($h)); + $i = $h->getIterator(); + $this->assertEquals(1, count($i)); + $this->assertEquals($requests[0], $i[0]); + } + + /** + * @depends testAddsRequests + */ + public function testMaintainsLimit() + { + $h = new HistoryPlugin(); + $h->setLimit(2); + $requests = $this->addRequests($h, 3); + $this->assertEquals(2, count($h)); + $i = 0; + foreach ($h as $request) { + if ($i > 0) { + $this->assertSame($requests[$i], $request); + } + } + } + + public function testReturnsLastRequest() + { + $h = new HistoryPlugin(); + $requests = $this->addRequests($h, 5); + $this->assertSame(end($requests), $h->getLastRequest()); + } + + public function testReturnsLastResponse() + { + $h = new HistoryPlugin(); + $requests = $this->addRequests($h, 5); + $this->assertSame(end($requests)->getResponse(), $h->getLastResponse()); + } + + public function testClearsHistory() + { + $h = new HistoryPlugin(); + $requests = $this->addRequests($h, 5); + $this->assertEquals(5, count($h)); + $h->clear(); + $this->assertEquals(0, count($h)); + } + + /** + * @depends testAddsRequests + */ + public function testUpdatesAddRequests() + { + $h = new HistoryPlugin(); + $client = new Client('http://localhost/'); + $client->getEventDispatcher()->addSubscriber($h); + + $request = $client->get(); + $request->setResponse(new Response(200), true); + $request->send(); + + $this->assertSame($request, $h->getLastRequest()); + } + + public function testCanCastToString() + { + $client = new Client('http://localhost/'); + $h = new HistoryPlugin(); + $client->getEventDispatcher()->addSubscriber($h); + + $mock = new MockPlugin(array( + new Response(301, array('Location' => '/redirect1', 'Content-Length' => 0)), + new Response(307, array('Location' => '/redirect2', 'Content-Length' => 0)), + new Response(200, array('Content-Length' => '2'), 'HI') + )); + + $client->getEventDispatcher()->addSubscriber($mock); + $request = $client->get(); + $request->send(); + $this->assertEquals(3, count($h)); + $this->assertEquals(3, count($mock->getReceivedRequests())); + + $h = str_replace("\r", '', $h); + $this->assertContains("> GET / HTTP/1.1\nHost: localhost\nUser-Agent:", $h); + $this->assertContains("< HTTP/1.1 301 Moved Permanently\nLocation: /redirect1", $h); + $this->assertContains("< HTTP/1.1 307 Temporary Redirect\nLocation: /redirect2", $h); + $this->assertContains("< HTTP/1.1 200 OK\nContent-Length: 2\n\nHI", $h); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Log/LogPluginTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Log/LogPluginTest.php new file mode 100644 index 0000000..ad663a5 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Log/LogPluginTest.php @@ -0,0 +1,95 @@ +adapter = new ClosureLogAdapter(function ($message) { + echo $message; + }); + } + + public function testIgnoresCurlEventsWhenNotWiringBodies() + { + $p = new LogPlugin($this->adapter); + $this->assertNotEmpty($p->getSubscribedEvents()); + $event = new Event(array('request' => new Request('GET', 'http://foo.com'))); + $p->onCurlRead($event); + $p->onCurlWrite($event); + $p->onRequestBeforeSend($event); + } + + public function testLogsWhenComplete() + { + $output = ''; + $p = new LogPlugin(new ClosureLogAdapter(function ($message) use (&$output) { + $output = $message; + }), '{method} {resource} | {code} {res_body}'); + + $p->onRequestSent(new Event(array( + 'request' => new Request('GET', 'http://foo.com'), + 'response' => new Response(200, array(), 'Foo') + ))); + + $this->assertEquals('GET / | 200 Foo', $output); + } + + public function testWiresBodiesWhenNeeded() + { + $client = new Client($this->getServer()->getUrl()); + $plugin = new LogPlugin($this->adapter, '{req_body} | {res_body}', true); + $client->getEventDispatcher()->addSubscriber($plugin); + $request = $client->put(); + + // Send the response from the dummy server as the request body + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 4\r\n\r\nsend"); + $stream = fopen($this->getServer()->getUrl(), 'r'); + $request->setBody(EntityBody::factory($stream, 4)); + + $tmpFile = tempnam(sys_get_temp_dir(), 'non_repeatable'); + $request->setResponseBody(EntityBody::factory(fopen($tmpFile, 'w'))); + + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 8\r\n\r\nresponse"); + + ob_start(); + $request->send(); + $message = ob_get_clean(); + + unlink($tmpFile); + $this->assertContains("send", $message); + $this->assertContains("response", $message); + } + + public function testHasHelpfulStaticFactoryMethod() + { + $s = fopen('php://temp', 'r+'); + $client = new Client(); + $client->addSubscriber(LogPlugin::getDebugPlugin(true, $s)); + $request = $client->put('http://foo.com', array('Content-Type' => 'Foo'), 'Bar'); + $request->setresponse(new Response(200), true); + $request->send(); + rewind($s); + $contents = stream_get_contents($s); + $this->assertContains('# Request:', $contents); + $this->assertContainsIns('PUT / HTTP/1.1', $contents); + $this->assertContains('# Response:', $contents); + $this->assertContainsIns('HTTP/1.1 200 OK', $contents); + $this->assertContains('# Errors:', $contents); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Md5/CommandContentMd5PluginTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Md5/CommandContentMd5PluginTest.php new file mode 100644 index 0000000..4bd4111 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Md5/CommandContentMd5PluginTest.php @@ -0,0 +1,97 @@ + array( + 'test' => array( + 'httpMethod' => 'PUT', + 'parameters' => array( + 'ContentMD5' => array(), + 'Body' => array( + 'location' => 'body' + ) + ) + ) + ) + )); + + $client = new Client(); + $client->setDescription($description); + + return $client; + } + + public function testHasEvents() + { + $this->assertNotEmpty(CommandContentMd5Plugin::getSubscribedEvents()); + } + + public function testValidatesMd5WhenParamExists() + { + $client = $this->getClient(); + $command = $client->getCommand('test', array( + 'Body' => 'Foo', + 'ContentMD5' => true + )); + $event = new Event(array('command' => $command)); + $request = $command->prepare(); + $plugin = new CommandContentMd5Plugin(); + $plugin->onCommandBeforeSend($event); + $this->assertEquals('E1bGfXrRY42Ba/uCLdLCXQ==', (string) $request->getHeader('Content-MD5')); + } + + public function testDoesNothingWhenNoPayloadExists() + { + $client = $this->getClient(); + $client->getDescription()->getOperation('test')->setHttpMethod('GET'); + $command = $client->getCommand('test'); + $event = new Event(array('command' => $command)); + $request = $command->prepare(); + $plugin = new CommandContentMd5Plugin(); + $plugin->onCommandBeforeSend($event); + $this->assertNull($request->getHeader('Content-MD5')); + } + + public function testAddsValidationToResponsesOfContentMd5() + { + $client = $this->getClient(); + $client->getDescription()->getOperation('test')->setHttpMethod('GET'); + $command = $client->getCommand('test', array( + 'ValidateMD5' => true + )); + $event = new Event(array('command' => $command)); + $request = $command->prepare(); + $plugin = new CommandContentMd5Plugin(); + $plugin->onCommandBeforeSend($event); + $listeners = $request->getEventDispatcher()->getListeners('request.complete'); + $this->assertNotEmpty($listeners); + } + + public function testIgnoresValidationWhenDisabled() + { + $client = $this->getClient(); + $client->getDescription()->getOperation('test')->setHttpMethod('GET'); + $command = $client->getCommand('test', array( + 'ValidateMD5' => false + )); + $event = new Event(array('command' => $command)); + $request = $command->prepare(); + $plugin = new CommandContentMd5Plugin(); + $plugin->onCommandBeforeSend($event); + $listeners = $request->getEventDispatcher()->getListeners('request.complete'); + $this->assertEmpty($listeners); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Md5/Md5ValidatorPluginTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Md5/Md5ValidatorPluginTest.php new file mode 100644 index 0000000..482e92b --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Md5/Md5ValidatorPluginTest.php @@ -0,0 +1,120 @@ +create('GET', 'http://www.test.com/'); + $request->getEventDispatcher()->addSubscriber($plugin); + + $body = 'abc'; + $hash = md5($body); + $response = new Response(200, array( + 'Content-MD5' => $hash, + 'Content-Length' => 3 + ), 'abc'); + + $request->dispatch('request.complete', array( + 'response' => $response + )); + + // Try again with no Content-MD5 + $response->removeHeader('Content-MD5'); + $request->dispatch('request.complete', array( + 'response' => $response + )); + } + + /** + * @expectedException UnexpectedValueException + */ + public function testThrowsExceptionOnInvalidMd5() + { + $plugin = new Md5ValidatorPlugin(); + $request = RequestFactory::getInstance()->create('GET', 'http://www.test.com/'); + $request->getEventDispatcher()->addSubscriber($plugin); + + $request->dispatch('request.complete', array( + 'response' => new Response(200, array( + 'Content-MD5' => 'foobar', + 'Content-Length' => 3 + ), 'abc') + )); + } + + public function testSkipsWhenContentLengthIsTooLarge() + { + $plugin = new Md5ValidatorPlugin(false, 1); + $request = RequestFactory::getInstance()->create('GET', 'http://www.test.com/'); + $request->getEventDispatcher()->addSubscriber($plugin); + + $request->dispatch('request.complete', array( + 'response' => new Response(200, array( + 'Content-MD5' => 'foobar', + 'Content-Length' => 3 + ), 'abc') + )); + } + + public function testProperlyValidatesWhenUsingContentEncoding() + { + $plugin = new Md5ValidatorPlugin(true); + $request = RequestFactory::getInstance()->create('GET', 'http://www.test.com/'); + $request->getEventDispatcher()->addSubscriber($plugin); + + // Content-MD5 is the MD5 hash of the canonical content after all + // content-encoding has been applied. Because cURL will automatically + // decompress entity bodies, we need to re-compress it to calculate. + $body = EntityBody::factory('abc'); + $body->compress(); + $hash = $body->getContentMd5(); + $body->uncompress(); + + $response = new Response(200, array( + 'Content-MD5' => $hash, + 'Content-Encoding' => 'gzip' + ), 'abc'); + $request->dispatch('request.complete', array( + 'response' => $response + )); + $this->assertEquals('abc', $response->getBody(true)); + + // Try again with an unknown encoding + $response = new Response(200, array( + 'Content-MD5' => $hash, + 'Content-Encoding' => 'foobar' + ), 'abc'); + $request->dispatch('request.complete', array( + 'response' => $response + )); + + // Try again with compress + $body->compress('bzip2.compress'); + $response = new Response(200, array( + 'Content-MD5' => $body->getContentMd5(), + 'Content-Encoding' => 'compress' + ), 'abc'); + $request->dispatch('request.complete', array( + 'response' => $response + )); + + // Try again with encoding and disabled content-encoding checks + $request->getEventDispatcher()->removeSubscriber($plugin); + $plugin = new Md5ValidatorPlugin(false); + $request->getEventDispatcher()->addSubscriber($plugin); + $request->dispatch('request.complete', array( + 'response' => $response + )); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Mock/MockPluginTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Mock/MockPluginTest.php new file mode 100644 index 0000000..3760abd --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Mock/MockPluginTest.php @@ -0,0 +1,199 @@ +assertInternalType('array', MockPlugin::getSubscribedEvents()); + } + + public function testDescribesEvents() + { + $this->assertInternalType('array', MockPlugin::getAllEvents()); + } + + public function testCanBeTemporary() + { + $plugin = new MockPlugin(); + $this->assertFalse($plugin->isTemporary()); + $plugin = new MockPlugin(null, true); + $this->assertTrue($plugin->isTemporary()); + } + + public function testIsCountable() + { + $plugin = new MockPlugin(); + $plugin->addResponse(Response::fromMessage("HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n")); + $this->assertEquals(1, count($plugin)); + } + + /** + * @depends testIsCountable + */ + public function testCanClearQueue() + { + $plugin = new MockPlugin(); + $plugin->addResponse(Response::fromMessage("HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n")); + $plugin->clearQueue(); + $this->assertEquals(0, count($plugin)); + } + + public function testCanInspectQueue() + { + $plugin = new MockPlugin(); + $this->assertInternalType('array', $plugin->getQueue()); + $plugin->addResponse(Response::fromMessage("HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n")); + $queue = $plugin->getQueue(); + $this->assertInternalType('array', $queue); + $this->assertEquals(1, count($queue)); + } + + public function testRetrievesResponsesFromFiles() + { + $response = MockPlugin::getMockFile(__DIR__ . '/../../TestData/mock_response'); + $this->assertInstanceOf('Guzzle\\Http\\Message\\Response', $response); + $this->assertEquals(200, $response->getStatusCode()); + } + + /** + * @expectedException InvalidArgumentException + */ + public function testThrowsExceptionWhenResponseFileIsNotFound() + { + MockPlugin::getMockFile('missing/filename'); + } + + /** + * @expectedException InvalidArgumentException + */ + public function testInvalidResponsesThrowAnException() + { + $p = new MockPlugin(); + $p->addResponse($this); + } + + public function testAddsResponseObjectsToQueue() + { + $p = new MockPlugin(); + $response = Response::fromMessage("HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n"); + $p->addResponse($response); + $this->assertEquals(array($response), $p->getQueue()); + } + + public function testAddsResponseFilesToQueue() + { + $p = new MockPlugin(); + $p->addResponse(__DIR__ . '/../../TestData/mock_response'); + $this->assertEquals(1, count($p)); + } + + /** + * @depends testAddsResponseFilesToQueue + */ + public function testAddsMockResponseToRequestFromClient() + { + $p = new MockPlugin(); + $response = MockPlugin::getMockFile(__DIR__ . '/../../TestData/mock_response'); + $p->addResponse($response); + + $client = new Client('http://localhost:123/'); + $client->getEventDispatcher()->addSubscriber($p, 9999); + $request = $client->get(); + $request->send(); + + $this->assertSame($response, $request->getResponse()); + $this->assertEquals(0, count($p)); + } + + /** + * @depends testAddsResponseFilesToQueue + * @expectedException \OutOfBoundsException + */ + public function testUpdateThrowsExceptionWhenEmpty() + { + $p = new MockPlugin(); + $p->onRequestBeforeSend(new Event()); + } + + /** + * @depends testAddsMockResponseToRequestFromClient + */ + public function testDetachesTemporaryWhenEmpty() + { + $p = new MockPlugin(null, true); + $p->addResponse(MockPlugin::getMockFile(__DIR__ . '/../../TestData/mock_response')); + $client = new Client('http://localhost:123/'); + $client->getEventDispatcher()->addSubscriber($p, 9999); + $request = $client->get(); + $request->send(); + + $this->assertFalse($this->hasSubscriber($client, $p)); + } + + public function testLoadsResponsesFromConstructor() + { + $p = new MockPlugin(array(new Response(200))); + $this->assertEquals(1, $p->count()); + } + + public function testStoresMockedRequests() + { + $p = new MockPlugin(array(new Response(200), new Response(200))); + $client = new Client('http://localhost:123/'); + $client->getEventDispatcher()->addSubscriber($p, 9999); + + $request1 = $client->get(); + $request1->send(); + $this->assertEquals(array($request1), $p->getReceivedRequests()); + + $request2 = $client->get(); + $request2->send(); + $this->assertEquals(array($request1, $request2), $p->getReceivedRequests()); + + $p->flush(); + $this->assertEquals(array(), $p->getReceivedRequests()); + } + + public function testReadsBodiesFromMockedRequests() + { + $p = new MockPlugin(array(new Response(200))); + $p->readBodies(true); + $client = new Client('http://localhost:123/'); + $client->getEventDispatcher()->addSubscriber($p, 9999); + + $body = EntityBody::factory('foo'); + $request = $client->put(); + $request->setBody($body); + $request->send(); + $this->assertEquals(3, $body->ftell()); + } + + public function testCanMockBadRequestExceptions() + { + $client = new Client('http://localhost:123/'); + $ex = new CurlException('Foo'); + $mock = new MockPlugin(array($ex)); + $client->addSubscriber($mock); + $request = $client->get('foo'); + + try { + $request->send(); + $this->fail('Did not dequeue an exception'); + } catch (CurlException $e) { + $this->assertSame($e, $ex); + $this->assertSame($request, $ex->getRequest()); + } + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Oauth/OauthPluginTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Oauth/OauthPluginTest.php new file mode 100644 index 0000000..3892fb6 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Plugin/Oauth/OauthPluginTest.php @@ -0,0 +1,345 @@ + 'foo', + 'consumer_secret' => 'bar', + 'token' => 'count', + 'token_secret' => 'dracula' + ); + + protected function getRequest() + { + return RequestFactory::getInstance()->create('POST', 'http://www.test.com/path?a=b&c=d', null, array( + 'e' => 'f' + )); + } + + public function testSubscribesToEvents() + { + $events = OauthPlugin::getSubscribedEvents(); + $this->assertArrayHasKey('request.before_send', $events); + } + + public function testAcceptsConfigurationData() + { + $p = new OauthPlugin($this->config); + + // Access the config object + $class = new \ReflectionClass($p); + $property = $class->getProperty('config'); + $property->setAccessible(true); + $config = $property->getValue($p); + + $this->assertEquals('foo', $config['consumer_key']); + $this->assertEquals('bar', $config['consumer_secret']); + $this->assertEquals('count', $config['token']); + $this->assertEquals('dracula', $config['token_secret']); + $this->assertEquals('1.0', $config['version']); + $this->assertEquals('HMAC-SHA1', $config['signature_method']); + $this->assertEquals('header', $config['request_method']); + } + + public function testCreatesStringToSignFromPostRequest() + { + $p = new OauthPlugin($this->config); + $request = $this->getRequest(); + $signString = $p->getStringToSign($request, self::TIMESTAMP, self::NONCE); + + $this->assertContains('&e=f', rawurldecode($signString)); + + $expectedSignString = + // Method and URL + 'POST&http%3A%2F%2Fwww.test.com%2Fpath' . + // Sorted parameters from query string and body + '&a%3Db%26c%3Dd%26e%3Df%26oauth_consumer_key%3Dfoo' . + '%26oauth_nonce%3De7aa11195ca58349bec8b5ebe351d3497eb9e603%26' . + 'oauth_signature_method%3DHMAC-SHA1' . + '%26oauth_timestamp%3D' . self::TIMESTAMP . '%26oauth_token%3Dcount%26oauth_version%3D1.0'; + + $this->assertEquals($expectedSignString, $signString); + } + + public function testCreatesStringToSignIgnoringPostFields() + { + $config = $this->config; + $config['disable_post_params'] = true; + $p = new OauthPlugin($config); + $request = $this->getRequest(); + $sts = rawurldecode($p->getStringToSign($request, self::TIMESTAMP, self::NONCE)); + $this->assertNotContains('&e=f', $sts); + } + + public function testCreatesStringToSignFromPostRequestWithCustomContentType() + { + $p = new OauthPlugin($this->config); + $request = $this->getRequest(); + $request->setHeader('Content-Type', 'Foo'); + $this->assertEquals( + // Method and URL + 'POST&http%3A%2F%2Fwww.test.com%2Fpath' . + // Sorted parameters from query string and body + '&a%3Db%26c%3Dd%26oauth_consumer_key%3Dfoo' . + '%26oauth_nonce%3D'. self::NONCE .'%26' . + 'oauth_signature_method%3DHMAC-SHA1' . + '%26oauth_timestamp%3D' . self::TIMESTAMP . '%26oauth_token%3Dcount%26oauth_version%3D1.0', + $p->getStringToSign($request, self::TIMESTAMP, self::NONCE) + ); + } + + /** + * @depends testCreatesStringToSignFromPostRequest + */ + public function testConvertsBooleansToStrings() + { + $p = new OauthPlugin($this->config); + $request = $this->getRequest(); + $request->getQuery()->set('a', true); + $request->getQuery()->set('c', false); + $this->assertContains('&a%3Dtrue%26c%3Dfalse', $p->getStringToSign($request, self::TIMESTAMP, self::NONCE)); + } + + public function testCreatesStringToSignFromPostRequestWithNullValues() + { + $config = array( + 'consumer_key' => 'foo', + 'consumer_secret' => 'bar', + 'token' => null, + 'token_secret' => 'dracula' + ); + + $p = new OauthPlugin($config); + $request = $this->getRequest(); + $signString = $p->getStringToSign($request, self::TIMESTAMP, self::NONCE); + + $this->assertContains('&e=f', rawurldecode($signString)); + + $expectedSignString = // Method and URL + 'POST&http%3A%2F%2Fwww.test.com%2Fpath' . + // Sorted parameters from query string and body + '&a%3Db%26c%3Dd%26e%3Df%26oauth_consumer_key%3Dfoo' . + '%26oauth_nonce%3De7aa11195ca58349bec8b5ebe351d3497eb9e603%26' . + 'oauth_signature_method%3DHMAC-SHA1' . + '%26oauth_timestamp%3D' . self::TIMESTAMP . '%26oauth_version%3D1.0'; + + $this->assertEquals($expectedSignString, $signString); + } + + /** + * @depends testCreatesStringToSignFromPostRequest + */ + public function testMultiDimensionalArray() + { + $p = new OauthPlugin($this->config); + $request = $this->getRequest(); + $request->getQuery()->set('a', array('b' => array('e' => 'f', 'c' => 'd'))); + $this->assertContains('a%255Bb%255D%255Bc%255D%3Dd%26a%255Bb%255D%255Be%255D%3Df%26c%3Dd%26e%3Df%26', $p->getStringToSign($request, self::TIMESTAMP, self::NONCE)); + } + + /** + * @depends testMultiDimensionalArray + */ + public function testMultiDimensionalArrayWithNonDefaultQueryAggregator() + { + $p = new OauthPlugin($this->config); + $request = $this->getRequest(); + $aggregator = new CommaAggregator(); + $query = $request->getQuery()->setAggregator($aggregator) + ->set('g', array('h', 'i', 'j')) + ->set('k', array('l')) + ->set('m', array('n', 'o')); + $this->assertContains('a%3Db%26c%3Dd%26e%3Df%26g%3Dh%2Ci%2Cj%26k%3Dl%26m%3Dn%2Co', $p->getStringToSign($request, self::TIMESTAMP, self::NONCE)); + } + + /** + * @depends testCreatesStringToSignFromPostRequest + */ + public function testSignsStrings() + { + $p = new OauthPlugin(array_merge($this->config, array( + 'signature_callback' => function($string, $key) { + return "_{$string}|{$key}_"; + } + ))); + $request = $this->getRequest(); + $sig = $p->getSignature($request, self::TIMESTAMP, self::NONCE); + $this->assertEquals( + '_POST&http%3A%2F%2Fwww.test.com%2Fpath&a%3Db%26c%3Dd%26e%3Df%26oauth_consumer_key%3Dfoo' . + '%26oauth_nonce%3D'. self::NONCE .'%26oauth_signature_method%3DHMAC-SHA1' . + '%26oauth_timestamp%3D' . self::TIMESTAMP . '%26oauth_token%3Dcount%26oauth_version%3D1.0|' . + 'bar&dracula_', + base64_decode($sig) + ); + } + + /** + * Test that the Oauth is signed correctly and that extra strings haven't been added + * to the authorization header. + */ + public function testSignsOauthRequests() + { + $p = new OauthPlugin($this->config); + $event = new Event(array( + 'request' => $this->getRequest(), + 'timestamp' => self::TIMESTAMP + )); + $params = $p->onRequestBeforeSend($event); + + $this->assertTrue($event['request']->hasHeader('Authorization')); + + $authorizationHeader = (string)$event['request']->getHeader('Authorization'); + + $this->assertStringStartsWith('OAuth ', $authorizationHeader); + + $stringsToCheck = array( + 'oauth_consumer_key="foo"', + 'oauth_nonce="'.urlencode($params['oauth_nonce']).'"', + 'oauth_signature="'.urlencode($params['oauth_signature']).'"', + 'oauth_signature_method="HMAC-SHA1"', + 'oauth_timestamp="' . self::TIMESTAMP . '"', + 'oauth_token="count"', + 'oauth_version="1.0"', + ); + + $totalLength = strlen('OAuth '); + + //Separator is not used before first parameter. + $separator = ''; + + foreach ($stringsToCheck as $stringToCheck) { + $this->assertContains($stringToCheck, $authorizationHeader); + $totalLength += strlen($separator); + $totalLength += strlen($stringToCheck); + $separator = ', '; + } + + // Technically this test is not universally valid. It would be allowable to have extra \n characters + // in the Authorization header. However Guzzle does not do this, so we just perform a simple check + // on length to validate the Authorization header is composed of only the strings above. + $this->assertEquals($totalLength, strlen($authorizationHeader), 'Authorization has extra characters i.e. contains extra elements compared to stringsToCheck.'); + } + + public function testSignsOauthQueryStringRequest() + { + $config = array_merge( + $this->config, + array('request_method' => OauthPlugin::REQUEST_METHOD_QUERY) + ); + + $p = new OauthPlugin($config); + $event = new Event(array( + 'request' => $this->getRequest(), + 'timestamp' => self::TIMESTAMP + )); + $params = $p->onRequestBeforeSend($event); + + $this->assertFalse($event['request']->hasHeader('Authorization')); + + $stringsToCheck = array( + 'a=b', + 'c=d', + 'oauth_consumer_key=foo', + 'oauth_nonce='.urlencode($params['oauth_nonce']), + 'oauth_signature='.urlencode($params['oauth_signature']), + 'oauth_signature_method=HMAC-SHA1', + 'oauth_timestamp='.self::TIMESTAMP, + 'oauth_token=count', + 'oauth_version=1.0', + ); + + $queryString = (string) $event['request']->getQuery(); + + $totalLength = strlen('?'); + + //Separator is not used before first parameter. + $separator = ''; + + foreach ($stringsToCheck as $stringToCheck) { + $this->assertContains($stringToCheck, $queryString); + $totalLength += strlen($separator); + $totalLength += strlen($stringToCheck); + $separator = '&'; + } + + // Removes the last query string separator '&' + $totalLength -= 1; + + $this->assertEquals($totalLength, strlen($queryString), 'Query string has extra characters i.e. contains extra elements compared to stringsToCheck.'); + } + + /** + * @expectedException \InvalidArgumentException + */ + public function testInvalidArgumentExceptionOnMethodError() + { + $config = array_merge( + $this->config, + array('request_method' => 'FakeMethod') + ); + + $p = new OauthPlugin($config); + $event = new Event(array( + 'request' => $this->getRequest(), + 'timestamp' => self::TIMESTAMP + )); + + $p->onRequestBeforeSend($event); + } + + public function testDoesNotAddFalseyValuesToAuthorization() + { + unset($this->config['token']); + $p = new OauthPlugin($this->config); + $event = new Event(array('request' => $this->getRequest(), 'timestamp' => self::TIMESTAMP)); + $p->onRequestBeforeSend($event); + $this->assertTrue($event['request']->hasHeader('Authorization')); + $this->assertNotContains('oauth_token=', (string) $event['request']->getHeader('Authorization')); + } + + public function testOptionalOauthParametersAreNotAutomaticallyAdded() + { + // The only required Oauth parameters are the consumer key and secret. That is enough credentials + // for signing oauth requests. + $config = array( + 'consumer_key' => 'foo', + 'consumer_secret' => 'bar', + ); + + $plugin = new OauthPlugin($config); + $event = new Event(array( + 'request' => $this->getRequest(), + 'timestamp' => self::TIMESTAMP + )); + + $timestamp = $plugin->getTimestamp($event); + $request = $event['request']; + $nonce = $plugin->generateNonce($request); + + $paramsToSign = $plugin->getParamsToSign($request, $timestamp, $nonce); + + $optionalParams = array( + 'callback' => 'oauth_callback', + 'token' => 'oauth_token', + 'verifier' => 'oauth_verifier', + 'token_secret' => 'token_secret' + ); + + foreach ($optionalParams as $optionName => $oauthName) { + $this->assertArrayNotHasKey($oauthName, $paramsToSign, "Optional Oauth param '$oauthName' was not set via config variable '$optionName', but it is listed in getParamsToSign()."); + } + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/AbstractConfigLoaderTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/AbstractConfigLoaderTest.php new file mode 100644 index 0000000..8b42fb8 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/AbstractConfigLoaderTest.php @@ -0,0 +1,149 @@ +loader = $this->getMockBuilder('Guzzle\Service\AbstractConfigLoader') + ->setMethods(array('build')) + ->getMockForAbstractClass(); + } + + public function tearDown() + { + foreach ($this->cleanup as $file) { + unlink($file); + } + } + + /** + * @expectedException \Guzzle\Common\Exception\InvalidArgumentException + */ + public function testOnlyLoadsSupportedTypes() + { + $this->loader->load(new \stdClass()); + } + + /** + * @expectedException \Guzzle\Common\Exception\InvalidArgumentException + * @expectedExceptionMessage Unable to open fooooooo.json + */ + public function testFileMustBeReadable() + { + $this->loader->load('fooooooo.json'); + } + + /** + * @expectedException \Guzzle\Common\Exception\InvalidArgumentException + * @expectedExceptionMessage Unknown file extension + */ + public function testMustBeSupportedExtension() + { + $this->loader->load(dirname(__DIR__) . '/TestData/FileBody.txt'); + } + + /** + * @expectedException \Guzzle\Common\Exception\RuntimeException + * @expectedExceptionMessage Error loading JSON data from + */ + public function testJsonMustBeValue() + { + $filename = tempnam(sys_get_temp_dir(), 'json') . '.json'; + file_put_contents($filename, '{/{./{}foo'); + $this->cleanup[] = $filename; + $this->loader->load($filename); + } + + /** + * @expectedException \Guzzle\Common\Exception\InvalidArgumentException + * @expectedExceptionMessage PHP files must return an array + */ + public function testPhpFilesMustReturnAnArray() + { + $filename = tempnam(sys_get_temp_dir(), 'php') . '.php'; + file_put_contents($filename, 'cleanup[] = $filename; + $this->loader->load($filename); + } + + public function testLoadsPhpFileIncludes() + { + $filename = tempnam(sys_get_temp_dir(), 'php') . '.php'; + file_put_contents($filename, ' "bar");'); + $this->cleanup[] = $filename; + $this->loader->expects($this->exactly(1))->method('build')->will($this->returnArgument(0)); + $config = $this->loader->load($filename); + $this->assertEquals(array('foo' => 'bar'), $config); + } + + public function testCanCreateFromJson() + { + $file = dirname(__DIR__) . '/TestData/services/json1.json'; + // The build method will just return the config data + $this->loader->expects($this->exactly(1))->method('build')->will($this->returnArgument(0)); + $data = $this->loader->load($file); + // Ensure that the config files were merged using the includes directives + $this->assertArrayHasKey('includes', $data); + $this->assertArrayHasKey('services', $data); + $this->assertInternalType('array', $data['services']['foo']); + $this->assertInternalType('array', $data['services']['abstract']); + $this->assertInternalType('array', $data['services']['mock']); + $this->assertEquals('bar', $data['services']['foo']['params']['baz']); + } + + public function testUsesAliases() + { + $file = dirname(__DIR__) . '/TestData/services/json1.json'; + $this->loader->addAlias('foo', $file); + // The build method will just return the config data + $this->loader->expects($this->exactly(1))->method('build')->will($this->returnArgument(0)); + $data = $this->loader->load('foo'); + $this->assertEquals('bar', $data['services']['foo']['params']['baz']); + } + + /** + * @expectedException \Guzzle\Common\Exception\InvalidArgumentException + * @expectedExceptionMessage Unable to open foo.json + */ + public function testCanRemoveAliases() + { + $file = dirname(__DIR__) . '/TestData/services/json1.json'; + $this->loader->addAlias('foo.json', $file); + $this->loader->removeAlias('foo.json'); + $this->loader->load('foo.json'); + } + + public function testCanLoadArraysWithIncludes() + { + $file = dirname(__DIR__) . '/TestData/services/json1.json'; + $config = array('includes' => array($file)); + // The build method will just return the config data + $this->loader->expects($this->exactly(1))->method('build')->will($this->returnArgument(0)); + $data = $this->loader->load($config); + $this->assertEquals('bar', $data['services']['foo']['params']['baz']); + } + + public function testDoesNotEnterInfiniteLoop() + { + $prefix = $file = dirname(__DIR__) . '/TestData/description'; + $this->loader->load("{$prefix}/baz.json"); + $this->assertCount(4, $this->readAttribute($this->loader, 'loadedFiles')); + // Ensure that the internal list of loaded files is reset + $this->loader->load("{$prefix}/../test_service2.json"); + $this->assertCount(1, $this->readAttribute($this->loader, 'loadedFiles')); + // Ensure that previously loaded files will be reloaded when starting fresh + $this->loader->load("{$prefix}/baz.json"); + $this->assertCount(4, $this->readAttribute($this->loader, 'loadedFiles')); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Builder/ServiceBuilderLoaderTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Builder/ServiceBuilderLoaderTest.php new file mode 100644 index 0000000..f63070e --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Builder/ServiceBuilderLoaderTest.php @@ -0,0 +1,177 @@ + array( + 'abstract' => array( + 'params' => array( + 'access_key' => 'xyz', + 'secret' => 'abc', + ), + ), + 'foo' => array( + 'extends' => 'abstract', + 'params' => array( + 'baz' => 'bar', + ), + ), + 'mock' => array( + 'extends' => 'abstract', + 'params' => array( + 'username' => 'foo', + 'password' => 'baz', + 'subdomain' => 'bar', + ) + ) + ) + ); + + $builder = $arrayFactory->load($data); + + // Ensure that services were parsed + $this->assertTrue(isset($builder['mock'])); + $this->assertTrue(isset($builder['abstract'])); + $this->assertTrue(isset($builder['foo'])); + $this->assertFalse(isset($builder['jimmy'])); + } + + /** + * @expectedException Guzzle\Service\Exception\ServiceNotFoundException + * @expectedExceptionMessage foo is trying to extend a non-existent service: abstract + */ + public function testThrowsExceptionWhenExtendingNonExistentService() + { + $arrayFactory = new ServiceBuilderLoader(); + + $data = array( + 'services' => array( + 'foo' => array( + 'extends' => 'abstract' + ) + ) + ); + + $builder = $arrayFactory->load($data); + } + + public function testAllowsGlobalParameterOverrides() + { + $arrayFactory = new ServiceBuilderLoader(); + + $data = array( + 'services' => array( + 'foo' => array( + 'params' => array( + 'foo' => 'baz', + 'bar' => 'boo' + ) + ) + ) + ); + + $builder = $arrayFactory->load($data, array( + 'bar' => 'jar', + 'far' => 'car' + )); + + $compiled = json_decode($builder->serialize(), true); + $this->assertEquals(array( + 'foo' => 'baz', + 'bar' => 'jar', + 'far' => 'car' + ), $compiled['foo']['params']); + } + + public function tstDoesNotErrorOnCircularReferences() + { + $arrayFactory = new ServiceBuilderLoader(); + $arrayFactory->load(array( + 'services' => array( + 'too' => array('extends' => 'ball'), + 'ball' => array('extends' => 'too'), + ) + )); + } + + public function configProvider() + { + $foo = array( + 'extends' => 'bar', + 'class' => 'stdClass', + 'params' => array('a' => 'test', 'b' => '456') + ); + + return array( + array( + // Does not extend the existing `foo` service but overwrites it + array( + 'services' => array( + 'foo' => $foo, + 'bar' => array('params' => array('baz' => '123')) + ) + ), + array( + 'services' => array( + 'foo' => array('class' => 'Baz') + ) + ), + array( + 'services' => array( + 'foo' => array('class' => 'Baz'), + 'bar' => array('params' => array('baz' => '123')) + ) + ) + ), + array( + // Extends the existing `foo` service + array( + 'services' => array( + 'foo' => $foo, + 'bar' => array('params' => array('baz' => '123')) + ) + ), + array( + 'services' => array( + 'foo' => array( + 'extends' => 'foo', + 'params' => array('b' => '123', 'c' => 'def') + ) + ) + ), + array( + 'services' => array( + 'foo' => array( + 'extends' => 'bar', + 'class' => 'stdClass', + 'params' => array('a' => 'test', 'b' => '123', 'c' => 'def') + ), + 'bar' => array('params' => array('baz' => '123')) + ) + ) + ) + ); + } + + /** + * @dataProvider configProvider + */ + public function testCombinesConfigs($a, $b, $c) + { + $l = new ServiceBuilderLoader(); + $m = new \ReflectionMethod($l, 'mergeData'); + $m->setAccessible(true); + $this->assertEquals($c, $m->invoke($l, $a, $b)); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Builder/ServiceBuilderTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Builder/ServiceBuilderTest.php new file mode 100644 index 0000000..e1b3a1d --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Builder/ServiceBuilderTest.php @@ -0,0 +1,317 @@ + array( + 'class' => 'Guzzle\Tests\Service\Mock\MockClient', + 'params' => array( + 'username' => 'michael', + 'password' => 'testing123', + 'subdomain' => 'michael', + ), + ), + 'billy.mock' => array( + 'alias' => 'Hello!', + 'class' => 'Guzzle\Tests\Service\Mock\MockClient', + 'params' => array( + 'username' => 'billy', + 'password' => 'passw0rd', + 'subdomain' => 'billy', + ), + ), + 'billy.testing' => array( + 'extends' => 'billy.mock', + 'params' => array( + 'subdomain' => 'test.billy', + ), + ), + 'missing_params' => array( + 'extends' => 'billy.mock' + ) + ); + + public function testAllowsSerialization() + { + $builder = ServiceBuilder::factory($this->arrayData); + $cached = unserialize(serialize($builder)); + $this->assertEquals($cached, $builder); + } + + public function testDelegatesFactoryMethodToAbstractFactory() + { + $builder = ServiceBuilder::factory($this->arrayData); + $c = $builder->get('michael.mock'); + $this->assertInstanceOf('Guzzle\Tests\Service\Mock\MockClient', $c); + } + + /** + * @expectedException Guzzle\Service\Exception\ServiceNotFoundException + * @expectedExceptionMessage No service is registered as foobar + */ + public function testThrowsExceptionWhenGettingInvalidClient() + { + ServiceBuilder::factory($this->arrayData)->get('foobar'); + } + + public function testStoresClientCopy() + { + $builder = ServiceBuilder::factory($this->arrayData); + $client = $builder->get('michael.mock'); + $this->assertInstanceOf('Guzzle\Tests\Service\Mock\MockClient', $client); + $this->assertEquals('http://127.0.0.1:8124/v1/michael', $client->getBaseUrl()); + $this->assertEquals($client, $builder->get('michael.mock')); + + // Get another client but throw this one away + $client2 = $builder->get('billy.mock', true); + $this->assertInstanceOf('Guzzle\Tests\Service\Mock\MockClient', $client2); + $this->assertEquals('http://127.0.0.1:8124/v1/billy', $client2->getBaseUrl()); + + // Make sure the original client is still there and set + $this->assertTrue($client === $builder->get('michael.mock')); + + // Create a new billy.mock client that is stored + $client3 = $builder->get('billy.mock'); + + // Make sure that the stored billy.mock client is equal to the other stored client + $this->assertTrue($client3 === $builder->get('billy.mock')); + + // Make sure that this client is not equal to the previous throwaway client + $this->assertFalse($client2 === $builder->get('billy.mock')); + } + + public function testBuildersPassOptionsThroughToClients() + { + $s = new ServiceBuilder(array( + 'michael.mock' => array( + 'class' => 'Guzzle\Tests\Service\Mock\MockClient', + 'params' => array( + 'base_url' => 'http://www.test.com/', + 'subdomain' => 'michael', + 'password' => 'test', + 'username' => 'michael', + 'curl.curlopt_proxyport' => 8080 + ) + ) + )); + + $c = $s->get('michael.mock'); + $this->assertEquals(8080, $c->getConfig('curl.curlopt_proxyport')); + } + + public function testUsesTheDefaultBuilderWhenNoBuilderIsSpecified() + { + $s = new ServiceBuilder(array( + 'michael.mock' => array( + 'class' => 'Guzzle\Tests\Service\Mock\MockClient', + 'params' => array( + 'base_url' => 'http://www.test.com/', + 'subdomain' => 'michael', + 'password' => 'test', + 'username' => 'michael', + 'curl.curlopt_proxyport' => 8080 + ) + ) + )); + + $c = $s->get('michael.mock'); + $this->assertInstanceOf('Guzzle\Tests\Service\Mock\MockClient', $c); + } + + public function testUsedAsArray() + { + $b = ServiceBuilder::factory($this->arrayData); + $this->assertTrue($b->offsetExists('michael.mock')); + $this->assertFalse($b->offsetExists('not_there')); + $this->assertInstanceOf('Guzzle\Service\Client', $b['michael.mock']); + + unset($b['michael.mock']); + $this->assertFalse($b->offsetExists('michael.mock')); + + $b['michael.mock'] = new Client('http://www.test.com/'); + $this->assertInstanceOf('Guzzle\Service\Client', $b['michael.mock']); + } + + public function testFactoryCanCreateFromJson() + { + $tmp = sys_get_temp_dir() . '/test.js'; + file_put_contents($tmp, json_encode($this->arrayData)); + $b = ServiceBuilder::factory($tmp); + unlink($tmp); + $s = $b->get('billy.testing'); + $this->assertEquals('test.billy', $s->getConfig('subdomain')); + $this->assertEquals('billy', $s->getConfig('username')); + } + + public function testFactoryCanCreateFromArray() + { + $b = ServiceBuilder::factory($this->arrayData); + $s = $b->get('billy.testing'); + $this->assertEquals('test.billy', $s->getConfig('subdomain')); + $this->assertEquals('billy', $s->getConfig('username')); + } + + public function testFactoryDoesNotRequireParams() + { + $b = ServiceBuilder::factory($this->arrayData); + $s = $b->get('missing_params'); + $this->assertEquals('billy', $s->getConfig('username')); + } + + public function testBuilderAllowsReferencesBetweenClients() + { + $builder = ServiceBuilder::factory(array( + 'a' => array( + 'class' => 'Guzzle\Tests\Service\Mock\MockClient', + 'params' => array( + 'other_client' => '{b}', + 'username' => 'x', + 'password' => 'y', + 'subdomain' => 'z' + ) + ), + 'b' => array( + 'class' => 'Guzzle\Tests\Service\Mock\MockClient', + 'params' => array( + 'username' => '1', + 'password' => '2', + 'subdomain' => '3' + ) + ) + )); + + $client = $builder['a']; + $this->assertEquals('x', $client->getConfig('username')); + $this->assertSame($builder['b'], $client->getConfig('other_client')); + $this->assertEquals('1', $builder['b']->getConfig('username')); + } + + public function testEmitsEventsWhenClientsAreCreated() + { + // Ensure that the client signals that it emits an event + $this->assertEquals(array('service_builder.create_client'), ServiceBuilder::getAllEvents()); + + // Create a test service builder + $builder = ServiceBuilder::factory(array( + 'a' => array( + 'class' => 'Guzzle\Tests\Service\Mock\MockClient', + 'params' => array( + 'username' => 'test', + 'password' => '123', + 'subdomain' => 'z' + ) + ) + )); + + // Add an event listener to pick up client creation events + $emits = 0; + $builder->getEventDispatcher()->addListener('service_builder.create_client', function($event) use (&$emits) { + $emits++; + }); + + // Get the 'a' client by name + $client = $builder->get('a'); + + // Ensure that the event was emitted once, and that the client was present + $this->assertEquals(1, $emits); + $this->assertInstanceOf('Guzzle\Tests\Service\Mock\MockClient', $client); + } + + public function testCanAddGlobalParametersToServicesOnLoad() + { + $builder = ServiceBuilder::factory($this->arrayData, array( + 'username' => 'fred', + 'new_value' => 'test' + )); + + $data = json_decode($builder->serialize(), true); + + foreach ($data as $service) { + $this->assertEquals('fred', $service['params']['username']); + $this->assertEquals('test', $service['params']['new_value']); + } + } + + public function testAddsGlobalPlugins() + { + $b = new ServiceBuilder($this->arrayData); + $b->addGlobalPlugin(new HistoryPlugin()); + $s = $b->get('michael.mock'); + $this->assertTrue($s->getEventDispatcher()->hasListeners('request.sent')); + } + + public function testCanGetData() + { + $b = new ServiceBuilder($this->arrayData); + $this->assertEquals($this->arrayData['michael.mock'], $b->getData('michael.mock')); + $this->assertNull($b->getData('ewofweoweofe')); + } + + public function testCanGetByAlias() + { + $b = new ServiceBuilder($this->arrayData); + $this->assertSame($b->get('billy.mock'), $b->get('Hello!')); + } + + public function testCanOverwriteParametersForThrowawayClients() + { + $b = new ServiceBuilder($this->arrayData); + + $c1 = $b->get('michael.mock'); + $this->assertEquals('michael', $c1->getConfig('username')); + + $c2 = $b->get('michael.mock', array('username' => 'jeremy')); + $this->assertEquals('jeremy', $c2->getConfig('username')); + } + + public function testGettingAThrowawayClientWithParametersDoesNotAffectGettingOtherClients() + { + $b = new ServiceBuilder($this->arrayData); + + $c1 = $b->get('michael.mock', array('username' => 'jeremy')); + $this->assertEquals('jeremy', $c1->getConfig('username')); + + $c2 = $b->get('michael.mock'); + $this->assertEquals('michael', $c2->getConfig('username')); + } + + public function testCanUseArbitraryData() + { + $b = new ServiceBuilder(); + $b['a'] = 'foo'; + $this->assertTrue(isset($b['a'])); + $this->assertEquals('foo', $b['a']); + unset($b['a']); + $this->assertFalse(isset($b['a'])); + } + + public function testCanRegisterServiceData() + { + $b = new ServiceBuilder(); + $b['a'] = array( + 'class' => 'Guzzle\Tests\Service\Mock\MockClient', + 'params' => array( + 'username' => 'billy', + 'password' => 'passw0rd', + 'subdomain' => 'billy', + ) + ); + $this->assertTrue(isset($b['a'])); + $this->assertInstanceOf('Guzzle\Tests\Service\Mock\MockClient', $b['a']); + $client = $b['a']; + unset($b['a']); + $this->assertFalse(isset($b['a'])); + // Ensure that instantiated clients can be registered + $b['mock'] = $client; + $this->assertSame($client, $b['mock']); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/CachingConfigLoaderTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/CachingConfigLoaderTest.php new file mode 100644 index 0000000..b8245ad --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/CachingConfigLoaderTest.php @@ -0,0 +1,43 @@ +getMockBuilder('Guzzle\Service\ConfigLoaderInterface') + ->setMethods(array('load')) + ->getMockForAbstractClass(); + $data = array('foo' => 'bar'); + $loader->expects($this->once()) + ->method('load') + ->will($this->returnValue($data)); + $cache = new CachingConfigLoader($loader, $cache); + $this->assertEquals($data, $cache->load('foo')); + $this->assertEquals($data, $cache->load('foo')); + } + + public function testDoesNotCacheArrays() + { + $cache = new DoctrineCacheAdapter(new ArrayCache()); + $loader = $this->getMockBuilder('Guzzle\Service\ConfigLoaderInterface') + ->setMethods(array('load')) + ->getMockForAbstractClass(); + $data = array('foo' => 'bar'); + $loader->expects($this->exactly(2)) + ->method('load') + ->will($this->returnValue($data)); + $cache = new CachingConfigLoader($loader, $cache); + $this->assertEquals($data, $cache->load(array())); + $this->assertEquals($data, $cache->load(array())); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/ClientTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/ClientTest.php new file mode 100644 index 0000000..aee29ed --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/ClientTest.php @@ -0,0 +1,320 @@ +serviceTest = new ServiceDescription(array( + 'test_command' => new Operation(array( + 'doc' => 'documentationForCommand', + 'method' => 'DELETE', + 'class' => 'Guzzle\\Tests\\Service\\Mock\\Command\\MockCommand', + 'args' => array( + 'bucket' => array( + 'required' => true + ), + 'key' => array( + 'required' => true + ) + ) + )) + )); + + $this->service = ServiceDescription::factory(__DIR__ . '/../TestData/test_service.json'); + } + + public function testAllowsCustomClientParameters() + { + $client = new Mock\MockClient(null, array( + Client::COMMAND_PARAMS => array(AbstractCommand::RESPONSE_PROCESSING => 'foo') + )); + $command = $client->getCommand('mock_command'); + $this->assertEquals('foo', $command->get(AbstractCommand::RESPONSE_PROCESSING)); + } + + public function testFactoryCreatesClient() + { + $client = Client::factory(array( + 'base_url' => 'http://www.test.com/', + 'test' => '123' + )); + + $this->assertEquals('http://www.test.com/', $client->getBaseUrl()); + $this->assertEquals('123', $client->getConfig('test')); + } + + public function testFactoryDoesNotRequireBaseUrl() + { + $client = Client::factory(); + } + + public function testDescribesEvents() + { + $this->assertInternalType('array', Client::getAllEvents()); + } + + public function testExecutesCommands() + { + $this->getServer()->flush(); + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n"); + + $client = new Client($this->getServer()->getUrl()); + $cmd = new MockCommand(); + $client->execute($cmd); + + $this->assertInstanceOf('Guzzle\\Http\\Message\\Response', $cmd->getResponse()); + $this->assertInstanceOf('Guzzle\\Http\\Message\\Response', $cmd->getResult()); + $this->assertEquals(1, count($this->getServer()->getReceivedRequests(false))); + } + + public function testExecutesCommandsWithArray() + { + $client = new Client('http://www.test.com/'); + $client->getEventDispatcher()->addSubscriber(new MockPlugin(array( + new Response(200), + new Response(200) + ))); + + // Create a command set and a command + $set = array(new MockCommand(), new MockCommand()); + $client->execute($set); + + // Make sure it sent + $this->assertTrue($set[0]->isExecuted()); + $this->assertTrue($set[1]->isExecuted()); + } + + /** + * @expectedException Guzzle\Common\Exception\InvalidArgumentException + */ + public function testThrowsExceptionWhenInvalidCommandIsExecuted() + { + $client = new Client(); + $client->execute(new \stdClass()); + } + + /** + * @expectedException InvalidArgumentException + */ + public function testThrowsExceptionWhenMissingCommand() + { + $client = new Client(); + + $mock = $this->getMock('Guzzle\\Service\\Command\\Factory\\FactoryInterface'); + $mock->expects($this->any()) + ->method('factory') + ->with($this->equalTo('test')) + ->will($this->returnValue(null)); + + $client->setCommandFactory($mock); + $client->getCommand('test'); + } + + public function testCreatesCommandsUsingCommandFactory() + { + $mockCommand = new MockCommand(); + + $client = new Mock\MockClient(); + $mock = $this->getMock('Guzzle\\Service\\Command\\Factory\\FactoryInterface'); + $mock->expects($this->any()) + ->method('factory') + ->with($this->equalTo('foo')) + ->will($this->returnValue($mockCommand)); + + $client->setCommandFactory($mock); + + $command = $client->getCommand('foo', array('acl' => '123')); + $this->assertSame($mockCommand, $command); + $command = $client->getCommand('foo', array('acl' => '123')); + $this->assertSame($mockCommand, $command); + $this->assertSame($client, $command->getClient()); + } + + public function testOwnsServiceDescription() + { + $client = new Mock\MockClient(); + $this->assertNull($client->getDescription()); + + $description = $this->getMock('Guzzle\\Service\\Description\\ServiceDescription'); + $this->assertSame($client, $client->setDescription($description)); + $this->assertSame($description, $client->getDescription()); + } + + public function testOwnsResourceIteratorFactory() + { + $client = new Mock\MockClient(); + + $method = new \ReflectionMethod($client, 'getResourceIteratorFactory'); + $method->setAccessible(TRUE); + $rf1 = $method->invoke($client); + + $rf = $this->readAttribute($client, 'resourceIteratorFactory'); + $this->assertInstanceOf('Guzzle\\Service\\Resource\\ResourceIteratorClassFactory', $rf); + $this->assertSame($rf1, $rf); + + $rf = new ResourceIteratorClassFactory('Guzzle\Tests\Service\Mock'); + $client->setResourceIteratorFactory($rf); + $this->assertNotSame($rf1, $rf); + } + + public function testClientResetsRequestsBeforeExecutingCommands() + { + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 200 OK\r\nContent-Length: 2\r\n\r\nHi", + "HTTP/1.1 200 OK\r\nContent-Length: 1\r\n\r\nI" + )); + + $client = new Mock\MockClient($this->getServer()->getUrl()); + + $command = $client->getCommand('mock_command'); + $client->execute($command); + $client->execute($command); + $this->assertEquals('I', $command->getResponse()->getBody(true)); + } + + public function testClientCreatesIterators() + { + $client = new Mock\MockClient(); + + $iterator = $client->getIterator('mock_command', array( + 'foo' => 'bar' + ), array( + 'limit' => 10 + )); + + $this->assertInstanceOf('Guzzle\Tests\Service\Mock\Model\MockCommandIterator', $iterator); + $this->assertEquals(10, $this->readAttribute($iterator, 'limit')); + + $command = $this->readAttribute($iterator, 'originalCommand'); + $this->assertEquals('bar', $command->get('foo')); + } + + public function testClientCreatesIteratorsWithNoOptions() + { + $client = new Mock\MockClient(); + $iterator = $client->getIterator('mock_command'); + $this->assertInstanceOf('Guzzle\Tests\Service\Mock\Model\MockCommandIterator', $iterator); + } + + public function testClientCreatesIteratorsWithCommands() + { + $client = new Mock\MockClient(); + $command = new MockCommand(); + $iterator = $client->getIterator($command); + $this->assertInstanceOf('Guzzle\Tests\Service\Mock\Model\MockCommandIterator', $iterator); + $iteratorCommand = $this->readAttribute($iterator, 'originalCommand'); + $this->assertSame($command, $iteratorCommand); + } + + public function testClientHoldsInflector() + { + $client = new Mock\MockClient(); + $this->assertInstanceOf('Guzzle\Inflection\MemoizingInflector', $client->getInflector()); + + $inflector = new Inflector(); + $client->setInflector($inflector); + $this->assertSame($inflector, $client->getInflector()); + } + + public function testClientAddsGlobalCommandOptions() + { + $client = new Mock\MockClient('http://www.foo.com', array( + Client::COMMAND_PARAMS => array( + 'mesa' => 'bar' + ) + )); + $command = $client->getCommand('mock_command'); + $this->assertEquals('bar', $command->get('mesa')); + } + + public function testSupportsServiceDescriptionBaseUrls() + { + $description = new ServiceDescription(array('baseUrl' => 'http://foo.com')); + $client = new Client(); + $client->setDescription($description); + $this->assertEquals('http://foo.com', $client->getBaseUrl()); + } + + public function testMergesDefaultCommandParamsCorrectly() + { + $client = new Mock\MockClient('http://www.foo.com', array( + Client::COMMAND_PARAMS => array( + 'mesa' => 'bar', + 'jar' => 'jar' + ) + )); + $command = $client->getCommand('mock_command', array('jar' => 'test')); + $this->assertEquals('bar', $command->get('mesa')); + $this->assertEquals('test', $command->get('jar')); + } + + /** + * @expectedException \Guzzle\Http\Exception\BadResponseException + */ + public function testWrapsSingleCommandExceptions() + { + $client = new Mock\MockClient('http://foobaz.com'); + $mock = new MockPlugin(array(new Response(401))); + $client->addSubscriber($mock); + $client->execute(new MockCommand()); + } + + public function testWrapsMultipleCommandExceptions() + { + $client = new Mock\MockClient('http://foobaz.com'); + $mock = new MockPlugin(array(new Response(200), new Response(200), new Response(404), new Response(500))); + $client->addSubscriber($mock); + + $cmds = array(new MockCommand(), new MockCommand(), new MockCommand(), new MockCommand()); + try { + $client->execute($cmds); + } catch (CommandTransferException $e) { + $this->assertEquals(2, count($e->getFailedRequests())); + $this->assertEquals(2, count($e->getSuccessfulRequests())); + $this->assertEquals(2, count($e->getFailedCommands())); + $this->assertEquals(2, count($e->getSuccessfulCommands())); + + foreach ($e->getSuccessfulCommands() as $c) { + $this->assertTrue($c->getResponse()->isSuccessful()); + } + + foreach ($e->getFailedCommands() as $c) { + $this->assertFalse($c->getRequest()->getResponse()->isSuccessful()); + } + } + } + + public function testGetCommandAfterTwoSetDescriptions() + { + $service1 = ServiceDescription::factory(__DIR__ . '/../TestData/test_service.json'); + $service2 = ServiceDescription::factory(__DIR__ . '/../TestData/test_service_3.json'); + + $client = new Mock\MockClient(); + + $client->setDescription($service1); + $client->getCommand('foo_bar'); + $client->setDescription($service2); + $client->getCommand('baz_qux'); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/AbstractCommandTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/AbstractCommandTest.php new file mode 100644 index 0000000..1004fae --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/AbstractCommandTest.php @@ -0,0 +1,16 @@ +setDescription(ServiceDescription::factory(__DIR__ . '/../../TestData/test_service.json')); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/ClosureCommandTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/ClosureCommandTest.php new file mode 100644 index 0000000..d762246 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/ClosureCommandTest.php @@ -0,0 +1,54 @@ + function($command, $api) { + $command->set('testing', '123'); + $request = RequestFactory::getInstance()->create('GET', 'http://www.test.com/'); + return $request; + } + )); + + $client = $this->getServiceBuilder()->get('mock'); + $c->setClient($client)->prepare(); + $this->assertEquals('123', $c->get('testing')); + $this->assertEquals('http://www.test.com/', $c->getRequest()->getUrl()); + } + + /** + * @expectedException UnexpectedValueException + * @expectedExceptionMessage Closure command did not return a RequestInterface object + */ + public function testMustReturnRequest() + { + $c = new ClosureCommand(array( + 'closure' => function($command, $api) { + return false; + } + )); + + $client = $this->getServiceBuilder()->get('mock'); + $c->setClient($client)->prepare(); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/CommandTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/CommandTest.php new file mode 100644 index 0000000..b7173d4 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/CommandTest.php @@ -0,0 +1,445 @@ +assertEquals('123', $command->get('test')); + $this->assertFalse($command->isPrepared()); + $this->assertFalse($command->isExecuted()); + } + + public function testDeterminesShortName() + { + $api = new Operation(array('name' => 'foobar')); + $command = new MockCommand(array(), $api); + $this->assertEquals('foobar', $command->getName()); + + $command = new MockCommand(); + $this->assertEquals('mock_command', $command->getName()); + + $command = new Sub(); + $this->assertEquals('sub.sub', $command->getName()); + } + + /** + * @expectedException RuntimeException + */ + public function testGetRequestThrowsExceptionBeforePreparation() + { + $command = new MockCommand(); + $command->getRequest(); + } + + public function testGetResponseExecutesCommandsWhenNeeded() + { + $response = new Response(200); + $client = $this->getClient(); + $this->setMockResponse($client, array($response)); + $command = new MockCommand(); + $command->setClient($client); + $this->assertSame($response, $command->getResponse()); + $this->assertSame($response, $command->getResponse()); + } + + public function testGetResultExecutesCommandsWhenNeeded() + { + $response = new Response(200); + $client = $this->getClient(); + $this->setMockResponse($client, array($response)); + $command = new MockCommand(); + $command->setClient($client); + $this->assertSame($response, $command->getResult()); + $this->assertSame($response, $command->getResult()); + } + + public function testSetClient() + { + $command = new MockCommand(); + $client = $this->getClient(); + + $command->setClient($client); + $this->assertEquals($client, $command->getClient()); + + unset($client); + unset($command); + + $command = new MockCommand(); + $client = $this->getClient(); + + $command->setClient($client)->prepare(); + $this->assertEquals($client, $command->getClient()); + $this->assertTrue($command->isPrepared()); + } + + public function testExecute() + { + $client = $this->getClient(); + $response = new Response(200, array( + 'Content-Type' => 'application/xml' + ), '123'); + $this->setMockResponse($client, array($response)); + $command = new MockCommand(); + $this->assertSame($command, $command->setClient($client)); + + // Returns the result of the command + $this->assertInstanceOf('SimpleXMLElement', $command->execute()); + + $this->assertTrue($command->isPrepared()); + $this->assertTrue($command->isExecuted()); + $this->assertSame($response, $command->getResponse()); + $this->assertInstanceOf('Guzzle\\Http\\Message\\Request', $command->getRequest()); + // Make sure that the result was automatically set to a SimpleXMLElement + $this->assertInstanceOf('SimpleXMLElement', $command->getResult()); + $this->assertEquals('123', (string) $command->getResult()->data); + } + + public function testConvertsJsonResponsesToArray() + { + $client = $this->getClient(); + $this->setMockResponse($client, array( + new \Guzzle\Http\Message\Response(200, array( + 'Content-Type' => 'application/json' + ), '{ "key": "Hi!" }' + ) + )); + $command = new MockCommand(); + $command->setClient($client); + $command->execute(); + $this->assertEquals(array( + 'key' => 'Hi!' + ), $command->getResult()); + } + + /** + * @expectedException \Guzzle\Common\Exception\RuntimeException + */ + public function testConvertsInvalidJsonResponsesToArray() + { + $json = '{ "key": "Hi!" }invalid'; + // Some implementations of php-json extension are not strict enough + // and allow to parse invalid json ignoring invalid parts + // See https://github.com/remicollet/pecl-json-c/issues/5 + if (json_decode($json) && JSON_ERROR_NONE === json_last_error()) { + $this->markTestSkipped('php-pecl-json library regression issues'); + } + + $client = $this->getClient(); + $this->setMockResponse($client, array( + new \Guzzle\Http\Message\Response(200, array( + 'Content-Type' => 'application/json' + ), $json + ) + )); + $command = new MockCommand(); + $command->setClient($client); + $command->execute(); + } + + public function testProcessResponseIsNotXml() + { + $client = $this->getClient(); + $this->setMockResponse($client, array( + new Response(200, array( + 'Content-Type' => 'application/octet-stream' + ), 'abc,def,ghi') + )); + $command = new MockCommand(); + $client->execute($command); + + // Make sure that the result was not converted to XML + $this->assertFalse($command->getResult() instanceof \SimpleXMLElement); + } + + /** + * @expectedException RuntimeException + */ + public function testExecuteThrowsExceptionWhenNoClientIsSet() + { + $command = new MockCommand(); + $command->execute(); + } + + /** + * @expectedException RuntimeException + */ + public function testPrepareThrowsExceptionWhenNoClientIsSet() + { + $command = new MockCommand(); + $command->prepare(); + } + + public function testCommandsAllowsCustomRequestHeaders() + { + $command = new MockCommand(); + $command->getRequestHeaders()->set('test', '123'); + $this->assertInstanceOf('Guzzle\Common\Collection', $command->getRequestHeaders()); + $this->assertEquals('123', $command->getRequestHeaders()->get('test')); + + $command->setClient($this->getClient())->prepare(); + $this->assertEquals('123', (string) $command->getRequest()->getHeader('test')); + } + + public function testCommandsAllowsCustomRequestHeadersAsArray() + { + $command = new MockCommand(array(AbstractCommand::HEADERS_OPTION => array('Foo' => 'Bar'))); + $this->assertInstanceOf('Guzzle\Common\Collection', $command->getRequestHeaders()); + $this->assertEquals('Bar', $command->getRequestHeaders()->get('Foo')); + } + + private function getOperation() + { + return new Operation(array( + 'name' => 'foobar', + 'httpMethod' => 'POST', + 'class' => 'Guzzle\\Tests\\Service\\Mock\\Command\\MockCommand', + 'parameters' => array( + 'test' => array( + 'default' => '123', + 'type' => 'string' + ) + ))); + } + + public function testCommandsUsesOperation() + { + $api = $this->getOperation(); + $command = new MockCommand(array(), $api); + $this->assertSame($api, $command->getOperation()); + $command->setClient($this->getClient())->prepare(); + $this->assertEquals('123', $command->get('test')); + $this->assertSame($api, $command->getOperation($api)); + } + + public function testCloneMakesNewRequest() + { + $client = $this->getClient(); + $command = new MockCommand(array(), $this->getOperation()); + $command->setClient($client); + + $command->prepare(); + $this->assertTrue($command->isPrepared()); + + $command2 = clone $command; + $this->assertFalse($command2->isPrepared()); + } + + public function testHasOnCompleteMethod() + { + $that = $this; + $called = 0; + + $testFunction = function($command) use (&$called, $that) { + $called++; + $that->assertInstanceOf('Guzzle\Service\Command\CommandInterface', $command); + }; + + $client = $this->getClient(); + $command = new MockCommand(array( + 'command.on_complete' => $testFunction + ), $this->getOperation()); + $command->setClient($client); + + $command->prepare()->setResponse(new Response(200), true); + $command->execute(); + $this->assertEquals(1, $called); + } + + /** + * @expectedException \Guzzle\Common\Exception\InvalidArgumentException + */ + public function testOnCompleteMustBeCallable() + { + $client = $this->getClient(); + $command = new MockCommand(); + $command->setOnComplete('foo'); + } + + public function testCanSetResultManually() + { + $client = $this->getClient(); + $client->getEventDispatcher()->addSubscriber(new MockPlugin(array( + new Response(200) + ))); + $command = new MockCommand(); + $client->execute($command); + $command->setResult('foo!'); + $this->assertEquals('foo!', $command->getResult()); + } + + public function testCanInitConfig() + { + $command = $this->getMockBuilder('Guzzle\\Service\\Command\\AbstractCommand') + ->setConstructorArgs(array(array( + 'foo' => 'bar' + ), new Operation(array( + 'parameters' => array( + 'baz' => new Parameter(array( + 'default' => 'baaar' + )) + ) + )))) + ->getMockForAbstractClass(); + + $this->assertEquals('bar', $command['foo']); + $this->assertEquals('baaar', $command['baz']); + } + + public function testAddsCurlOptionsToRequestsWhenPreparing() + { + $command = new MockCommand(array( + 'foo' => 'bar', + 'curl.options' => array('CURLOPT_PROXYPORT' => 8080) + )); + $client = new Client(); + $command->setClient($client); + $request = $command->prepare(); + $this->assertEquals(8080, $request->getCurlOptions()->get(CURLOPT_PROXYPORT)); + } + + public function testIsInvokable() + { + $client = $this->getClient(); + $response = new Response(200); + $this->setMockResponse($client, array($response)); + $command = new MockCommand(); + $command->setClient($client); + // Returns the result of the command + $this->assertSame($response, $command()); + } + + public function testCreatesDefaultOperation() + { + $command = $this->getMockBuilder('Guzzle\Service\Command\AbstractCommand')->getMockForAbstractClass(); + $this->assertInstanceOf('Guzzle\Service\Description\Operation', $command->getOperation()); + } + + public function testAllowsValidatorToBeInjected() + { + $command = $this->getMockBuilder('Guzzle\Service\Command\AbstractCommand')->getMockForAbstractClass(); + $v = new SchemaValidator(); + $command->setValidator($v); + $this->assertSame($v, $this->readAttribute($command, 'validator')); + } + + public function testCanDisableValidation() + { + $command = new MockCommand(); + $command->setClient(new \Guzzle\Service\Client()); + $v = $this->getMockBuilder('Guzzle\Service\Description\SchemaValidator') + ->setMethods(array('validate')) + ->getMock(); + $v->expects($this->never())->method('validate'); + $command->setValidator($v); + $command->set(AbstractCommand::DISABLE_VALIDATION, true); + $command->prepare(); + } + + public function testValidatorDoesNotUpdateNonDefaultValues() + { + $command = new MockCommand(array('test' => 123, 'foo' => 'bar')); + $command->setClient(new \Guzzle\Service\Client()); + $command->prepare(); + $this->assertEquals(123, $command->get('test')); + $this->assertEquals('bar', $command->get('foo')); + } + + public function testValidatorUpdatesDefaultValues() + { + $command = new MockCommand(); + $command->setClient(new \Guzzle\Service\Client()); + $command->prepare(); + $this->assertEquals(123, $command->get('test')); + $this->assertEquals('abc', $command->get('_internal')); + } + + /** + * @expectedException \Guzzle\Service\Exception\ValidationException + * @expectedExceptionMessage [Foo] Baz + */ + public function testValidatesCommandBeforeSending() + { + $command = new MockCommand(); + $command->setClient(new \Guzzle\Service\Client()); + $v = $this->getMockBuilder('Guzzle\Service\Description\SchemaValidator') + ->setMethods(array('validate', 'getErrors')) + ->getMock(); + $v->expects($this->any())->method('validate')->will($this->returnValue(false)); + $v->expects($this->any())->method('getErrors')->will($this->returnValue(array('[Foo] Baz', '[Bar] Boo'))); + $command->setValidator($v); + $command->prepare(); + } + + /** + * @expectedException \Guzzle\Service\Exception\ValidationException + * @expectedExceptionMessage Validation errors: [abc] must be of type string + */ + public function testValidatesAdditionalParameters() + { + $description = ServiceDescription::factory(array( + 'operations' => array( + 'foo' => array( + 'parameters' => array( + 'baz' => array('type' => 'integer') + ), + 'additionalParameters' => array( + 'type' => 'string' + ) + ) + ) + )); + + $client = new Client(); + $client->setDescription($description); + $command = $client->getCommand('foo', array( + 'abc' => false, + 'command.headers' => array('foo' => 'bar') + )); + $command->prepare(); + } + + public function testCanAccessValidationErrorsFromCommand() + { + $validationErrors = array('[Foo] Baz', '[Bar] Boo'); + $command = new MockCommand(); + $command->setClient(new \Guzzle\Service\Client()); + + $this->assertFalse($command->getValidationErrors()); + + $v = $this->getMockBuilder('Guzzle\Service\Description\SchemaValidator') + ->setMethods(array('validate', 'getErrors')) + ->getMock(); + $v->expects($this->any())->method('getErrors')->will($this->returnValue($validationErrors)); + $command->setValidator($v); + + $this->assertEquals($validationErrors, $command->getValidationErrors()); + } + + public function testCanChangeResponseBody() + { + $body = EntityBody::factory(); + $command = new MockCommand(); + $command->setClient(new \Guzzle\Service\Client()); + $command->set(AbstractCommand::RESPONSE_BODY, $body); + $request = $command->prepare(); + $this->assertSame($body, $this->readAttribute($request, 'responseBody')); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/DefaultRequestSerializerTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/DefaultRequestSerializerTest.php new file mode 100644 index 0000000..b7a4682 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/DefaultRequestSerializerTest.php @@ -0,0 +1,122 @@ +serializer = DefaultRequestSerializer::getInstance(); + $this->client = new Client('http://foo.com/baz'); + $this->operation = new Operation(array('httpMethod' => 'POST')); + $this->command = $this->getMockBuilder('Guzzle\Service\Command\AbstractCommand') + ->setConstructorArgs(array(array(), $this->operation)) + ->getMockForAbstractClass(); + $this->command->setClient($this->client); + } + + public function testAllowsCustomVisitor() + { + $this->serializer->addVisitor('custom', new HeaderVisitor()); + $this->command['test'] = '123'; + $this->operation->addParam(new Parameter(array('name' => 'test', 'location' => 'custom'))); + $request = $this->serializer->prepare($this->command); + $this->assertEquals('123', (string) $request->getHeader('test')); + } + + public function testUsesRelativePath() + { + $this->operation->setUri('bar'); + $request = $this->serializer->prepare($this->command); + $this->assertEquals('http://foo.com/baz/bar', (string) $request->getUrl()); + } + + public function testUsesRelativePathWithUriLocations() + { + $this->command['test'] = '123'; + $this->operation->setUri('bar/{test}'); + $this->operation->addParam(new Parameter(array('name' => 'test', 'location' => 'uri'))); + $request = $this->serializer->prepare($this->command); + $this->assertEquals('http://foo.com/baz/bar/123', (string) $request->getUrl()); + } + + public function testAllowsCustomFactory() + { + $f = new VisitorFlyweight(); + $serializer = new DefaultRequestSerializer($f); + $this->assertSame($f, $this->readAttribute($serializer, 'factory')); + } + + public function testMixedParams() + { + $this->operation->setUri('bar{?limit,fields}'); + $this->operation->addParam(new Parameter(array( + 'name' => 'limit', + 'location' => 'uri', + 'required' => false, + ))); + $this->operation->addParam(new Parameter(array( + 'name' => 'fields', + 'location' => 'uri', + 'required' => true, + ))); + + $this->command['fields'] = array('id', 'name'); + + $request = $this->serializer->prepare($this->command); + $this->assertEquals('http://foo.com/baz/bar?fields='.urlencode('id,name'), (string) $request->getUrl()); + } + + public function testValidatesAdditionalParameters() + { + $description = ServiceDescription::factory(array( + 'operations' => array( + 'foo' => array( + 'httpMethod' => 'PUT', + 'parameters' => array( + 'bar' => array('location' => 'header') + ), + 'additionalParameters' => array( + 'location' => 'json' + ) + ) + ) + )); + + $client = new Client(); + $client->setDescription($description); + $command = $client->getCommand('foo'); + $command['bar'] = 'test'; + $command['hello'] = 'abc'; + $request = $command->prepare(); + $this->assertEquals('test', (string) $request->getHeader('bar')); + $this->assertEquals('{"hello":"abc"}', (string) $request->getBody()); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/DefaultResponseParserTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/DefaultResponseParserTest.php new file mode 100644 index 0000000..a6a02f9 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/DefaultResponseParserTest.php @@ -0,0 +1,59 @@ +setClient(new Client()); + $request = $op->prepare(); + $request->setResponse(new Response(200, array( + 'Content-Type' => 'application/xml' + ), 'Bar'), true); + $this->assertInstanceOf('SimpleXMLElement', $op->execute()); + } + + public function testParsesJsonResponses() + { + $op = new OperationCommand(array(), new Operation()); + $op->setClient(new Client()); + $request = $op->prepare(); + $request->setResponse(new Response(200, array( + 'Content-Type' => 'application/json' + ), '{"Baz":"Bar"}'), true); + $this->assertEquals(array('Baz' => 'Bar'), $op->execute()); + } + + /** + * @expectedException \Guzzle\Common\Exception\RuntimeException + */ + public function testThrowsExceptionWhenParsingJsonFails() + { + $op = new OperationCommand(array(), new Operation()); + $op->setClient(new Client()); + $request = $op->prepare(); + $request->setResponse(new Response(200, array('Content-Type' => 'application/json'), '{"Baz":ddw}'), true); + $op->execute(); + } + + public function testAddsContentTypeWhenExpectsIsSetOnCommand() + { + $op = new OperationCommand(array(), new Operation()); + $op['command.expects'] = 'application/json'; + $op->setClient(new Client()); + $request = $op->prepare(); + $request->setResponse(new Response(200, null, '{"Baz":"Bar"}'), true); + $this->assertEquals(array('Baz' => 'Bar'), $op->execute()); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/Factory/AliasFactoryTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/Factory/AliasFactoryTest.php new file mode 100644 index 0000000..ab1041a --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/Factory/AliasFactoryTest.php @@ -0,0 +1,76 @@ +client = new Client(); + + $map = new MapFactory(array( + 'test' => 'Guzzle\Tests\Service\Mock\Command\MockCommand', + 'test1' => 'Guzzle\Tests\Service\Mock\Command\OtherCommand' + )); + + $this->factory = new AliasFactory($this->client, array( + 'foo' => 'test', + 'bar' => 'sub', + 'sub' => 'test1', + 'krull' => 'test3', + 'krull_2' => 'krull', + 'sub_2' => 'bar', + 'bad_link' => 'jarjar' + )); + + $map2 = new MapFactory(array( + 'test3' => 'Guzzle\Tests\Service\Mock\Command\Sub\Sub' + )); + + $this->client->setCommandFactory(new CompositeFactory(array($map, $this->factory, $map2))); + } + + public function aliasProvider() + { + return array( + array('foo', 'Guzzle\Tests\Service\Mock\Command\MockCommand', false), + array('bar', 'Guzzle\Tests\Service\Mock\Command\OtherCommand', false), + array('sub', 'Guzzle\Tests\Service\Mock\Command\OtherCommand', false), + array('sub_2', 'Guzzle\Tests\Service\Mock\Command\OtherCommand', false), + array('krull', 'Guzzle\Tests\Service\Mock\Command\Sub\Sub', false), + array('krull_2', 'Guzzle\Tests\Service\Mock\Command\Sub\Sub', false), + array('missing', null, true), + array('bad_link', null, true) + ); + } + + /** + * @dataProvider aliasProvider + */ + public function testAliasesCommands($key, $result, $exception) + { + try { + $command = $this->client->getCommand($key); + if (is_null($result)) { + $this->assertNull($command); + } else { + $this->assertInstanceof($result, $command); + } + } catch (\Exception $e) { + if (!$exception) { + $this->fail('Got exception when it was not expected'); + } + } + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/Factory/CompositeFactoryTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/Factory/CompositeFactoryTest.php new file mode 100644 index 0000000..b896dcf --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/Factory/CompositeFactoryTest.php @@ -0,0 +1,124 @@ +getMockBuilder($class) + ->disableOriginalConstructor() + ->getMock(); + } + + public function testIsIterable() + { + $factory = new CompositeFactory(array($this->getFactory(), $this->getFactory())); + $this->assertEquals(2, count($factory)); + $this->assertEquals(2, count(iterator_to_array($factory->getIterator()))); + } + + public function testFindsFactories() + { + $f1 = $this->getFactory(); + $f2 = $this->getFactory('Guzzle\\Service\\Command\\Factory\\CompositeFactory'); + $factory = new CompositeFactory(array($f1, $f2)); + $this->assertNull($factory->find('foo')); + $this->assertNull($factory->find($this->getFactory())); + $this->assertSame($f1, $factory->find('Guzzle\\Service\\Command\\Factory\\MapFactory')); + $this->assertSame($f2, $factory->find('Guzzle\\Service\\Command\\Factory\\CompositeFactory')); + $this->assertSame($f1, $factory->find($f1)); + $this->assertSame($f2, $factory->find($f2)); + + $this->assertFalse($factory->has('foo')); + $this->assertTrue($factory->has('Guzzle\\Service\\Command\\Factory\\MapFactory')); + $this->assertTrue($factory->has('Guzzle\\Service\\Command\\Factory\\CompositeFactory')); + } + + public function testCreatesCommands() + { + $factory = new CompositeFactory(); + $this->assertNull($factory->factory('foo')); + + $f1 = $this->getFactory(); + $mockCommand1 = $this->getMockForAbstractClass('Guzzle\\Service\\Command\\AbstractCommand'); + + $f1->expects($this->once()) + ->method('factory') + ->with($this->equalTo('foo')) + ->will($this->returnValue($mockCommand1)); + + $factory = new CompositeFactory(array($f1)); + $this->assertSame($mockCommand1, $factory->factory('foo')); + } + + public function testAllowsRemovalOfFactories() + { + $f1 = $this->getFactory(); + $f2 = $this->getFactory(); + $f3 = $this->getFactory('Guzzle\\Service\\Command\\Factory\\CompositeFactory'); + $factories = array($f1, $f2, $f3); + $factory = new CompositeFactory($factories); + + $factory->remove('foo'); + $this->assertEquals($factories, $factory->getIterator()->getArrayCopy()); + + $factory->remove($f1); + $this->assertEquals(array($f2, $f3), $factory->getIterator()->getArrayCopy()); + + $factory->remove('Guzzle\\Service\\Command\\Factory\\MapFactory'); + $this->assertEquals(array($f3), $factory->getIterator()->getArrayCopy()); + + $factory->remove('Guzzle\\Service\\Command\\Factory\\CompositeFactory'); + $this->assertEquals(array(), $factory->getIterator()->getArrayCopy()); + + $factory->remove('foo'); + $this->assertEquals(array(), $factory->getIterator()->getArrayCopy()); + } + + public function testAddsFactoriesBeforeAndAtEnd() + { + $f1 = $this->getFactory(); + $f2 = $this->getFactory(); + $f3 = $this->getFactory('Guzzle\\Service\\Command\\Factory\\CompositeFactory'); + $f4 = $this->getFactory(); + + $factory = new CompositeFactory(); + + $factory->add($f1); + $this->assertEquals(array($f1), $factory->getIterator()->getArrayCopy()); + + $factory->add($f2); + $this->assertEquals(array($f1, $f2), $factory->getIterator()->getArrayCopy()); + + $factory->add($f3, $f2); + $this->assertEquals(array($f1, $f3, $f2), $factory->getIterator()->getArrayCopy()); + + $factory->add($f4, 'Guzzle\\Service\\Command\\Factory\\CompositeFactory'); + $this->assertEquals(array($f1, $f4, $f3, $f2), $factory->getIterator()->getArrayCopy()); + } + + public function testProvidesDefaultChainForClients() + { + $client = $this->getMock('Guzzle\\Service\\Client'); + $chain = CompositeFactory::getDefaultChain($client); + $a = $chain->getIterator()->getArrayCopy(); + $this->assertEquals(1, count($a)); + $this->assertInstanceOf('Guzzle\\Service\\Command\\Factory\\ConcreteClassFactory', $a[0]); + + $description = $this->getMock('Guzzle\\Service\\Description\\ServiceDescription'); + $client->expects($this->once()) + ->method('getDescription') + ->will($this->returnValue($description)); + $chain = CompositeFactory::getDefaultChain($client); + $a = $chain->getIterator()->getArrayCopy(); + $this->assertEquals(2, count($a)); + $this->assertInstanceOf('Guzzle\\Service\\Command\\Factory\\ServiceDescriptionFactory', $a[0]); + $this->assertInstanceOf('Guzzle\\Service\\Command\\Factory\\ConcreteClassFactory', $a[1]); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/Factory/ConcreteClassFactoryTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/Factory/ConcreteClassFactoryTest.php new file mode 100644 index 0000000..7664718 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/Factory/ConcreteClassFactoryTest.php @@ -0,0 +1,49 @@ + $prefix + )); + } + + $factory = new ConcreteClassFactory($client); + + if (is_null($result)) { + $this->assertNull($factory->factory($key)); + } else { + $this->assertInstanceof($result, $factory->factory($key)); + } + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/Factory/MapFactoryTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/Factory/MapFactoryTest.php new file mode 100644 index 0000000..ee720d1 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/Factory/MapFactoryTest.php @@ -0,0 +1,37 @@ + 'Guzzle\Tests\Service\Mock\Command\MockCommand', + 'test1' => 'Guzzle\Tests\Service\Mock\Command\OtherCommand' + )); + + if (is_null($result)) { + $this->assertNull($factory->factory($key)); + } else { + $this->assertInstanceof($result, $factory->factory($key)); + } + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/Factory/ServiceDescriptionFactoryTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/Factory/ServiceDescriptionFactoryTest.php new file mode 100644 index 0000000..3372634 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/Factory/ServiceDescriptionFactoryTest.php @@ -0,0 +1,68 @@ +getDescription(); + + $factory = new ServiceDescriptionFactory($d); + $this->assertSame($d, $factory->getServiceDescription()); + + if (is_null($result)) { + $this->assertNull($factory->factory($key)); + } else { + $this->assertInstanceof($result, $factory->factory($key)); + } + } + + public function testUsesUcFirstIfNoExactMatch() + { + $d = $this->getDescription(); + $factory = new ServiceDescriptionFactory($d, new Inflector()); + $this->assertInstanceof('Guzzle\Tests\Service\Mock\Command\OtherCommand', $factory->factory('Test')); + $this->assertInstanceof('Guzzle\Tests\Service\Mock\Command\OtherCommand', $factory->factory('test')); + } + + public function testUsesInflectionIfNoExactMatch() + { + $d = $this->getDescription(); + $factory = new ServiceDescriptionFactory($d, new Inflector()); + $this->assertInstanceof('Guzzle\Tests\Service\Mock\Command\OtherCommand', $factory->factory('Binks')); + $this->assertInstanceof('Guzzle\Tests\Service\Mock\Command\OtherCommand', $factory->factory('binks')); + $this->assertInstanceof('Guzzle\Tests\Service\Mock\Command\MockCommand', $factory->factory('JarJar')); + $this->assertInstanceof('Guzzle\Tests\Service\Mock\Command\MockCommand', $factory->factory('jar_jar')); + } + + protected function getDescription() + { + return ServiceDescription::factory(array( + 'operations' => array( + 'jar_jar' => array('class' => 'Guzzle\Tests\Service\Mock\Command\MockCommand'), + 'binks' => array('class' => 'Guzzle\Tests\Service\Mock\Command\OtherCommand'), + 'Test' => array('class' => 'Guzzle\Tests\Service\Mock\Command\OtherCommand') + ) + )); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/AbstractVisitorTestCase.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/AbstractVisitorTestCase.php new file mode 100644 index 0000000..46b472e --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/AbstractVisitorTestCase.php @@ -0,0 +1,110 @@ +command = new MockCommand(); + $this->request = new EntityEnclosingRequest('POST', 'http://www.test.com/some/path.php'); + $this->validator = new SchemaValidator(); + } + + protected function getCommand($location) + { + $command = new OperationCommand(array(), $this->getNestedCommand($location)); + $command->setClient(new MockClient()); + + return $command; + } + + protected function getNestedCommand($location) + { + return new Operation(array( + 'httpMethod' => 'POST', + 'parameters' => array( + 'foo' => new Parameter(array( + 'type' => 'object', + 'location' => $location, + 'sentAs' => 'Foo', + 'required' => true, + 'properties' => array( + 'test' => array( + 'type' => 'object', + 'required' => true, + 'properties' => array( + 'baz' => array( + 'type' => 'boolean', + 'default' => true + ), + 'jenga' => array( + 'type' => 'string', + 'default' => 'hello', + 'sentAs' => 'Jenga_Yall!', + 'filters' => array('strtoupper') + ) + ) + ), + 'bar' => array('default' => 123) + ), + 'additionalProperties' => array( + 'type' => 'string', + 'filters' => array('strtoupper'), + 'location' => $location + ) + )), + 'arr' => new Parameter(array( + 'type' => 'array', + 'location' => $location, + 'items' => array( + 'type' => 'string', + 'filters' => array('strtoupper') + ) + )), + ) + )); + } + + protected function getCommandWithArrayParamAndFilters() + { + $operation = new Operation(array( + 'httpMethod' => 'POST', + 'parameters' => array( + 'foo' => new Parameter(array( + 'type' => 'string', + 'location' => 'query', + 'sentAs' => 'Foo', + 'required' => true, + 'default' => 'bar', + 'filters' => array('strtoupper') + )), + 'arr' => new Parameter(array( + 'type' => 'array', + 'location' => 'query', + 'sentAs' => 'Arr', + 'required' => true, + 'default' => array(123, 456, 789), + 'filters' => array(array('method' => 'implode', 'args' => array(',', '@value'))) + )) + ) + )); + $command = new OperationCommand(array(), $operation); + $command->setClient(new MockClient()); + + return $command; + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/BodyVisitorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/BodyVisitorTest.php new file mode 100644 index 0000000..2a95c45 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/BodyVisitorTest.php @@ -0,0 +1,63 @@ +getNestedCommand('body')->getParam('foo')->setSentAs('Foo'); + $visitor->visit($this->command, $this->request, $param, '123'); + $this->assertEquals('123', (string) $this->request->getBody()); + $this->assertNull($this->request->getHeader('Expect')); + } + + public function testAddsExpectHeaderWhenSetToTrue() + { + $visitor = new Visitor(); + $param = $this->getNestedCommand('body')->getParam('foo')->setSentAs('Foo'); + $param->setData('expect_header', true); + $visitor->visit($this->command, $this->request, $param, '123'); + $this->assertEquals('123', (string) $this->request->getBody()); + } + + public function testCanDisableExpectHeader() + { + $visitor = new Visitor(); + $param = $this->getNestedCommand('body')->getParam('foo')->setSentAs('Foo'); + $param->setData('expect_header', false); + $visitor->visit($this->command, $this->request, $param, '123'); + $this->assertNull($this->request->getHeader('Expect')); + } + + public function testCanSetExpectHeaderBasedOnSize() + { + $visitor = new Visitor(); + $param = $this->getNestedCommand('body')->getParam('foo')->setSentAs('Foo'); + // The body is less than the cutoff + $param->setData('expect_header', 5); + $visitor->visit($this->command, $this->request, $param, '123'); + $this->assertNull($this->request->getHeader('Expect')); + // Now check when the body is greater than the cutoff + $param->setData('expect_header', 2); + $visitor->visit($this->command, $this->request, $param, '123'); + $this->assertEquals('100-Continue', (string) $this->request->getHeader('Expect')); + } + + public function testAddsContentEncodingWhenSetOnBody() + { + $visitor = new Visitor(); + $param = $this->getNestedCommand('body')->getParam('foo')->setSentAs('Foo'); + $body = EntityBody::factory('foo'); + $body->compress(); + $visitor->visit($this->command, $this->request, $param, $body); + $this->assertEquals('gzip', (string) $this->request->getHeader('Content-Encoding')); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/HeaderVisitorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/HeaderVisitorTest.php new file mode 100644 index 0000000..7ea1ae9 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/HeaderVisitorTest.php @@ -0,0 +1,48 @@ +getNestedCommand('header')->getParam('foo')->setSentAs('test'); + $param->setAdditionalProperties(new Parameter(array())); + $visitor->visit($this->command, $this->request, $param, 'test'); + } + + public function testVisitsLocation() + { + $visitor = new Visitor(); + $param = $this->getNestedCommand('header')->getParam('foo')->setSentAs('test'); + $param->setAdditionalProperties(false); + $visitor->visit($this->command, $this->request, $param, '123'); + $this->assertEquals('123', (string) $this->request->getHeader('test')); + } + + public function testVisitsMappedPrefixHeaders() + { + $visitor = new Visitor(); + $param = $this->getNestedCommand('header')->getParam('foo')->setSentAs('test'); + $param->setSentAs('x-foo-'); + $param->setAdditionalProperties(new Parameter(array( + 'type' => 'string' + ))); + $visitor->visit($this->command, $this->request, $param, array( + 'bar' => 'test', + 'baz' => '123' + )); + $this->assertEquals('test', (string) $this->request->getHeader('x-foo-bar')); + $this->assertEquals('123', (string) $this->request->getHeader('x-foo-baz')); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/JsonVisitorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/JsonVisitorTest.php new file mode 100644 index 0000000..ea6782f --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/JsonVisitorTest.php @@ -0,0 +1,60 @@ +after($this->command, $this->request); + + $param = $this->getNestedCommand('json')->getParam('foo'); + $visitor->visit($this->command, $this->request, $param->setSentAs('test'), '123'); + $visitor->visit($this->command, $this->request, $param->setSentAs('test2'), 'abc'); + $visitor->after($this->command, $this->request); + $this->assertEquals('{"test":"123","test2":"abc"}', (string) $this->request->getBody()); + } + + public function testAddsJsonHeader() + { + $visitor = new Visitor(); + $visitor->setContentTypeHeader('application/json-foo'); + $param = $this->getNestedCommand('json')->getParam('foo'); + $visitor->visit($this->command, $this->request, $param->setSentAs('test'), '123'); + $visitor->after($this->command, $this->request); + $this->assertEquals('application/json-foo', (string) $this->request->getHeader('Content-Type')); + } + + public function testRecursivelyBuildsJsonBodies() + { + $command = $this->getCommand('json'); + $request = $command->prepare(); + $this->assertEquals('{"Foo":{"test":{"baz":true,"Jenga_Yall!":"HELLO"},"bar":123}}', (string) $request->getBody()); + } + + public function testAppliesFiltersToAdditionalProperties() + { + $command = $this->getCommand('json'); + $command->set('foo', array('not_set' => 'abc')); + $request = $command->prepare(); + $result = json_decode($request->getBody(), true); + $this->assertEquals('ABC', $result['Foo']['not_set']); + } + + public function testAppliesFiltersToArrayItemValues() + { + $command = $this->getCommand('json'); + $command->set('arr', array('a', 'b')); + $request = $command->prepare(); + $result = json_decode($request->getBody(), true); + $this->assertEquals(array('A', 'B'), $result['arr']); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/PostFieldVisitorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/PostFieldVisitorTest.php new file mode 100644 index 0000000..540b410 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/PostFieldVisitorTest.php @@ -0,0 +1,33 @@ +getNestedCommand('postField')->getParam('foo'); + $visitor->visit($this->command, $this->request, $param->setSentAs('test'), '123'); + $this->assertEquals('123', (string) $this->request->getPostField('test')); + } + + public function testRecursivelyBuildsPostFields() + { + $command = $this->getCommand('postField'); + $request = $command->prepare(); + $visitor = new Visitor(); + $param = $command->getOperation()->getParam('foo'); + $visitor->visit($command, $request, $param, $command['foo']); + $visitor->after($command, $request); + $this->assertEquals( + 'Foo[test][baz]=1&Foo[test][Jenga_Yall!]=HELLO&Foo[bar]=123', + rawurldecode((string) $request->getPostFields()) + ); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/PostFileVisitorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/PostFileVisitorTest.php new file mode 100644 index 0000000..21e3cec --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/PostFileVisitorTest.php @@ -0,0 +1,54 @@ +getNestedCommand('postFile')->getParam('foo'); + + // Test using a path to a file + $visitor->visit($this->command, $this->request, $param->setSentAs('test_3'), __FILE__); + $this->assertInternalType('array', $this->request->getPostFile('test_3')); + + // Test with a PostFile + $visitor->visit($this->command, $this->request, $param->setSentAs(null), new PostFile('baz', __FILE__)); + $this->assertInternalType('array', $this->request->getPostFile('baz')); + } + + public function testVisitsLocationWithMultipleFiles() + { + $description = ServiceDescription::factory(array( + 'operations' => array( + 'DoPost' => array( + 'httpMethod' => 'POST', + 'parameters' => array( + 'foo' => array( + 'location' => 'postFile', + 'type' => array('string', 'array') + ) + ) + ) + ) + )); + $this->getServer()->flush(); + $this->getServer()->enqueue(array("HTTP/1.1 200 OK\r\nContent-Length:0\r\n\r\n")); + $client = new Client($this->getServer()->getUrl()); + $client->setDescription($description); + $command = $client->getCommand('DoPost', array('foo' => array(__FILE__, __FILE__))); + $command->execute(); + $received = $this->getServer()->getReceivedRequests(); + $this->assertContains('name="foo[0]";', $received[0]); + $this->assertContains('name="foo[1]";', $received[0]); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/QueryVisitorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/QueryVisitorTest.php new file mode 100644 index 0000000..607af76 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/QueryVisitorTest.php @@ -0,0 +1,48 @@ +getNestedCommand('query')->getParam('foo')->setSentAs('test'); + $visitor->visit($this->command, $this->request, $param, '123'); + $this->assertEquals('123', $this->request->getQuery()->get('test')); + } + + /** + * @covers Guzzle\Service\Command\LocationVisitor\Request\QueryVisitor + * @covers Guzzle\Service\Command\LocationVisitor\Request\AbstractRequestVisitor::resolveRecursively + */ + public function testRecursivelyBuildsQueryStrings() + { + $command = $this->getCommand('query'); + $command->getOperation()->getParam('foo')->setSentAs('Foo'); + $request = $command->prepare(); + $this->assertEquals( + 'Foo[test][baz]=1&Foo[test][Jenga_Yall!]=HELLO&Foo[bar]=123', + rawurldecode($request->getQuery()) + ); + } + + /** + * @covers Guzzle\Service\Command\LocationVisitor\Request\AbstractRequestVisitor::resolveRecursively + */ + public function testFiltersAreAppliedToArrayParamType() + { + $command = $this->getCommandWithArrayParamAndFilters(); + $request = $command->prepare(); + $query = $request->getQuery(); + // param type 'string' + $this->assertEquals('BAR', $query->get('Foo')); + // param type 'array' + $this->assertEquals('123,456,789', $query->get('Arr')); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/ResponseBodyVisitorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/ResponseBodyVisitorTest.php new file mode 100644 index 0000000..ff8cec5 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/ResponseBodyVisitorTest.php @@ -0,0 +1,20 @@ +getNestedCommand('response_body')->getParam('foo'); + $visitor->visit($this->command, $this->request, $param, sys_get_temp_dir() . '/foo.txt'); + $body = $this->readAttribute($this->request, 'responseBody'); + $this->assertContains('/foo.txt', $body->getUri()); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/XmlVisitorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/XmlVisitorTest.php new file mode 100644 index 0000000..beb58b0 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Request/XmlVisitorTest.php @@ -0,0 +1,558 @@ + array( + 'xmlRoot' => array( + 'name' => 'test', + 'namespaces' => 'http://foo.com' + ) + ), + 'parameters' => array( + 'Foo' => array('location' => 'xml', 'type' => 'string'), + 'Baz' => array('location' => 'xml', 'type' => 'string') + ) + ), + array('Foo' => 'test', 'Baz' => 'bar'), + 'testbar' + ), + // Ensure that the content-type is not added + array(array('parameters' => array('Foo' => array('location' => 'xml', 'type' => 'string'))), array(), ''), + // Test with adding attributes and no namespace + array( + array( + 'data' => array( + 'xmlRoot' => array( + 'name' => 'test' + ) + ), + 'parameters' => array( + 'Foo' => array('location' => 'xml', 'type' => 'string', 'data' => array('xmlAttribute' => true)) + ) + ), + array('Foo' => 'test', 'Baz' => 'bar'), + '' + ), + // Test adding with an array + array( + array( + 'parameters' => array( + 'Foo' => array('location' => 'xml', 'type' => 'string'), + 'Baz' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'type' => 'numeric', + 'sentAs' => 'Bar' + ) + ) + ) + ), + array('Foo' => 'test', 'Baz' => array(1, 2)), + 'test12' + ), + // Test adding an object + array( + array( + 'parameters' => array( + 'Foo' => array('location' => 'xml', 'type' => 'string'), + 'Baz' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Bar' => array('type' => 'string'), + 'Bam' => array() + ) + ) + ) + ), + array('Foo' => 'test', 'Baz' => array('Bar' => 'abc', 'Bam' => 'foo')), + 'testabcfoo' + ), + // Add an array that contains an object + array( + array( + 'parameters' => array( + 'Baz' => array( + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'type' => 'object', + 'sentAs' => 'Bar', + 'properties' => array('A' => array(), 'B' => array()) + ) + ) + ) + ), + array('Baz' => array( + array('A' => '1', 'B' => '2'), + array('A' => '3', 'B' => '4') + )), + '1234' + ), + // Add an object of attributes + array( + array( + 'parameters' => array( + 'Foo' => array('location' => 'xml', 'type' => 'string'), + 'Baz' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Bar' => array('type' => 'string', 'data' => array('xmlAttribute' => true)), + 'Bam' => array() + ) + ) + ) + ), + array('Foo' => 'test', 'Baz' => array('Bar' => 'abc', 'Bam' => 'foo')), + 'testfoo' + ), + // Check order doesn't matter + array( + array( + 'parameters' => array( + 'Foo' => array('location' => 'xml', 'type' => 'string'), + 'Baz' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Bar' => array('type' => 'string', 'data' => array('xmlAttribute' => true)), + 'Bam' => array() + ) + ) + ) + ), + array('Foo' => 'test', 'Baz' => array('Bam' => 'foo', 'Bar' => 'abc')), + 'testfoo' + ), + // Add values with custom namespaces + array( + array( + 'parameters' => array( + 'Foo' => array( + 'location' => 'xml', + 'type' => 'string', + 'data' => array( + 'xmlNamespace' => 'http://foo.com' + ) + ) + ) + ), + array('Foo' => 'test'), + 'test' + ), + // Add attributes with custom namespace prefix + array( + array( + 'parameters' => array( + 'Wrap' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Foo' => array( + 'type' => 'string', + 'sentAs' => 'xsi:baz', + 'data' => array( + 'xmlNamespace' => 'http://foo.com', + 'xmlAttribute' => true + ) + ) + ) + ), + ) + ), + array('Wrap' => array( + 'Foo' => 'test' + )), + '' + ), + // Add nodes with custom namespace prefix + array( + array( + 'parameters' => array( + 'Wrap' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Foo' => array( + 'type' => 'string', + 'sentAs' => 'xsi:Foo', + 'data' => array( + 'xmlNamespace' => 'http://foobar.com' + ) + ) + ) + ), + ) + ), + array('Wrap' => array( + 'Foo' => 'test' + )), + 'test' + ), + array( + array( + 'parameters' => array( + 'Foo' => array( + 'location' => 'xml', + 'type' => 'string', + 'data' => array( + 'xmlNamespace' => 'http://foo.com' + ) + ) + ) + ), + array('Foo' => '

    This is a title

    '), + 'This is a title]]>' + ), + // Flat array at top level + array( + array( + 'parameters' => array( + 'Bars' => array( + 'type' => 'array', + 'data' => array('xmlFlattened' => true), + 'location' => 'xml', + 'items' => array( + 'type' => 'object', + 'sentAs' => 'Bar', + 'properties' => array( + 'A' => array(), + 'B' => array() + ) + ) + ), + 'Boos' => array( + 'type' => 'array', + 'data' => array('xmlFlattened' => true), + 'location' => 'xml', + 'items' => array( + 'sentAs' => 'Boo', + 'type' => 'string' + ) + ) + ) + ), + array( + 'Bars' => array( + array('A' => '1', 'B' => '2'), + array('A' => '3', 'B' => '4') + ), + 'Boos' => array('test', '123') + ), + '1234test123' + ), + // Nested flat arrays + array( + array( + 'parameters' => array( + 'Delete' => array( + 'type' => 'object', + 'location' => 'xml', + 'properties' => array( + 'Items' => array( + 'type' => 'array', + 'data' => array('xmlFlattened' => true), + 'items' => array( + 'type' => 'object', + 'sentAs' => 'Item', + 'properties' => array( + 'A' => array(), + 'B' => array() + ) + ) + ) + ) + ) + ) + ), + array( + 'Delete' => array( + 'Items' => array( + array('A' => '1', 'B' => '2'), + array('A' => '3', 'B' => '4') + ) + ) + ), + '1234' + ) + ); + } + + /** + * @dataProvider xmlProvider + */ + public function testSerializesXml(array $operation, array $input, $xml) + { + $operation = new Operation($operation); + $command = $this->getMockBuilder('Guzzle\Service\Command\OperationCommand') + ->setConstructorArgs(array($input, $operation)) + ->getMockForAbstractClass(); + $command->setClient(new Client('http://www.test.com/some/path.php')); + $request = $command->prepare(); + if (!empty($input)) { + $this->assertEquals('application/xml', (string) $request->getHeader('Content-Type')); + } else { + $this->assertNull($request->getHeader('Content-Type')); + } + $body = str_replace(array("\n", ""), '', (string) $request->getBody()); + $this->assertEquals($xml, $body); + } + + public function testAddsContentTypeAndTopLevelValues() + { + $operation = new Operation(array( + 'data' => array( + 'xmlRoot' => array( + 'name' => 'test', + 'namespaces' => array( + 'xsi' => 'http://foo.com' + ) + ) + ), + 'parameters' => array( + 'Foo' => array('location' => 'xml', 'type' => 'string'), + 'Baz' => array('location' => 'xml', 'type' => 'string') + ) + )); + + $command = $this->getMockBuilder('Guzzle\Service\Command\OperationCommand') + ->setConstructorArgs(array(array( + 'Foo' => 'test', + 'Baz' => 'bar' + ), $operation)) + ->getMockForAbstractClass(); + + $command->setClient(new Client()); + $request = $command->prepare(); + $this->assertEquals('application/xml', (string) $request->getHeader('Content-Type')); + $this->assertEquals( + '' . "\n" + . 'testbar' . "\n", + (string) $request->getBody() + ); + } + + public function testCanChangeContentType() + { + $visitor = new XmlVisitor(); + $visitor->setContentTypeHeader('application/foo'); + $this->assertEquals('application/foo', $this->readAttribute($visitor, 'contentType')); + } + + public function testCanAddArrayOfSimpleTypes() + { + $request = new EntityEnclosingRequest('POST', 'http://foo.com'); + $visitor = new XmlVisitor(); + $param = new Parameter(array( + 'type' => 'object', + 'location' => 'xml', + 'name' => 'Out', + 'properties' => array( + 'Nodes' => array( + 'required' => true, + 'type' => 'array', + 'min' => 1, + 'items' => array('type' => 'string', 'sentAs' => 'Node') + ) + ) + )); + + $param->setParent(new Operation(array( + 'data' => array( + 'xmlRoot' => array( + 'name' => 'Test', + 'namespaces' => array( + 'https://foo/' + ) + ) + ) + ))); + + $value = array('Nodes' => array('foo', 'baz')); + $this->assertTrue($this->validator->validate($param, $value)); + $visitor->visit($this->command, $request, $param, $value); + $visitor->after($this->command, $request); + + $this->assertEquals( + "\n" + . "foobaz\n", + (string) $request->getBody() + ); + } + + public function testCanAddMultipleNamespacesToRoot() + { + $operation = new Operation(array( + 'data' => array( + 'xmlRoot' => array( + 'name' => 'Hi', + 'namespaces' => array( + 'xsi' => 'http://foo.com', + 'foo' => 'http://foobar.com' + ) + ) + ), + 'parameters' => array( + 'Foo' => array('location' => 'xml', 'type' => 'string') + ) + )); + + $command = $this->getMockBuilder('Guzzle\Service\Command\OperationCommand') + ->setConstructorArgs(array(array( + 'Foo' => 'test' + ), $operation)) + ->getMockForAbstractClass(); + + $command->setClient(new Client()); + $request = $command->prepare(); + $this->assertEquals('application/xml', (string) $request->getHeader('Content-Type')); + $this->assertEquals( + '' . "\n" + . 'test' . "\n", + (string) $request->getBody() + ); + } + + public function testValuesAreFiltered() + { + $operation = new Operation(array( + 'parameters' => array( + 'Foo' => array( + 'location' => 'xml', + 'type' => 'string', + 'filters' => array('strtoupper') + ), + 'Bar' => array( + 'location' => 'xml', + 'type' => 'object', + 'properties' => array( + 'Baz' => array( + 'filters' => array('strtoupper') + ) + ) + ) + ) + )); + + $command = $this->getMockBuilder('Guzzle\Service\Command\OperationCommand') + ->setConstructorArgs(array(array( + 'Foo' => 'test', + 'Bar' => array( + 'Baz' => 'abc' + ) + ), $operation)) + ->getMockForAbstractClass(); + + $command->setClient(new Client()); + $request = $command->prepare(); + $this->assertEquals( + '' . "\n" + . 'TESTABC' . "\n", + (string) $request->getBody() + ); + } + + public function testSkipsNullValues() + { + $operation = new Operation(array( + 'parameters' => array( + 'Foo' => array( + 'location' => 'xml', + 'type' => 'string' + ), + 'Bar' => array( + 'location' => 'xml', + 'type' => 'object', + 'properties' => array( + 'Baz' => array(), + 'Bam' => array(), + ) + ), + 'Arr' => array( + 'type' => 'array', + 'items' => array( + 'type' => 'string' + ) + ) + ) + )); + + $command = $this->getMockBuilder('Guzzle\Service\Command\OperationCommand') + ->setConstructorArgs(array(array( + 'Foo' => null, + 'Bar' => array( + 'Bar' => null, + 'Bam' => 'test' + ), + 'Arr' => array(null) + ), $operation)) + ->getMockForAbstractClass(); + + $command->setClient(new Client()); + $request = $command->prepare(); + $this->assertEquals( + '' . "\n" + . 'test' . "\n", + (string) $request->getBody() + ); + } + + public function testAllowsXmlEncoding() + { + $operation = new Operation(array( + 'data' => array( + 'xmlEncoding' => 'UTF-8' + ), + 'parameters' => array( + 'Foo' => array('location' => 'xml') + ) + )); + $command = $this->getMockBuilder('Guzzle\Service\Command\OperationCommand') + ->setConstructorArgs(array(array('Foo' => 'test'), $operation)) + ->getMockForAbstractClass(); + $command->setClient(new Client()); + $request = $command->prepare(); + $this->assertEquals( + '' . "\n" + . 'test' . "\n", + (string) $request->getBody() + ); + } + + public function testAllowsSendingXmlPayloadIfNoXmlParamsWereSet() + { + $operation = new Operation(array( + 'httpMethod' => 'POST', + 'data' => array('xmlAllowEmpty' => true), + 'parameters' => array('Foo' => array('location' => 'xml')) + )); + $command = $this->getMockBuilder('Guzzle\Service\Command\OperationCommand') + ->setConstructorArgs(array(array(), $operation)) + ->getMockForAbstractClass(); + $command->setClient(new Client('http://foo.com')); + $request = $command->prepare(); + $this->assertEquals( + '' . "\n" + . '' . "\n", + (string) $request->getBody() + ); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Response/AbstractResponseVisitorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Response/AbstractResponseVisitorTest.php new file mode 100644 index 0000000..7b86003 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Response/AbstractResponseVisitorTest.php @@ -0,0 +1,29 @@ +value = array(); + $this->command = new MockCommand(); + $this->response = new Response(200, array( + 'X-Foo' => 'bar', + 'Content-Length' => 3, + 'Content-Type' => 'text/plain' + ), 'Foo'); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Response/BodyVisitorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Response/BodyVisitorTest.php new file mode 100644 index 0000000..932e39b --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Response/BodyVisitorTest.php @@ -0,0 +1,21 @@ + 'body', 'name' => 'foo')); + $visitor->visit($this->command, $this->response, $param, $this->value); + $this->assertEquals('Foo', (string) $this->value['foo']); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Response/HeaderVisitorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Response/HeaderVisitorTest.php new file mode 100644 index 0000000..db54b1a --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Response/HeaderVisitorTest.php @@ -0,0 +1,98 @@ + 'header', + 'name' => 'ContentType', + 'sentAs' => 'Content-Type' + )); + $visitor->visit($this->command, $this->response, $param, $this->value); + $this->assertEquals('text/plain', $this->value['ContentType']); + } + + public function testVisitsLocationWithFilters() + { + $visitor = new Visitor(); + $param = new Parameter(array( + 'location' => 'header', + 'name' => 'Content-Type', + 'filters' => array('strtoupper') + )); + $visitor->visit($this->command, $this->response, $param, $this->value); + $this->assertEquals('TEXT/PLAIN', $this->value['Content-Type']); + } + + public function testVisitsMappedPrefixHeaders() + { + $visitor = new Visitor(); + $param = new Parameter(array( + 'location' => 'header', + 'name' => 'Metadata', + 'sentAs' => 'X-Baz-', + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'string' + ) + )); + $response = new Response(200, array( + 'X-Baz-Test' => 'ABC', + 'X-Baz-Bar' => array('123', '456'), + 'Content-Length' => 3 + ), 'Foo'); + $visitor->visit($this->command, $response, $param, $this->value); + $this->assertEquals(array( + 'Metadata' => array( + 'Test' => 'ABC', + 'Bar' => array('123', '456') + ) + ), $this->value); + } + + /** + * @group issue-399 + * @link https://github.com/guzzle/guzzle/issues/399 + */ + public function testDiscardingUnknownHeaders() + { + $visitor = new Visitor(); + $param = new Parameter(array( + 'location' => 'header', + 'name' => 'Content-Type', + 'additionalParameters' => false + )); + $visitor->visit($this->command, $this->response, $param, $this->value); + $this->assertEquals('text/plain', $this->value['Content-Type']); + $this->assertArrayNotHasKey('X-Foo', $this->value); + } + + /** + * @group issue-399 + * @link https://github.com/guzzle/guzzle/issues/399 + */ + public function testDiscardingUnknownPropertiesWithAliasing() + { + $visitor = new Visitor(); + $param = new Parameter(array( + 'location' => 'header', + 'name' => 'ContentType', + 'sentAs' => 'Content-Type', + 'additionalParameters' => false + )); + $visitor->visit($this->command, $this->response, $param, $this->value); + $this->assertEquals('text/plain', $this->value['ContentType']); + $this->assertArrayNotHasKey('X-Foo', $this->value); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Response/JsonVisitorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Response/JsonVisitorTest.php new file mode 100644 index 0000000..4f8d30b --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Response/JsonVisitorTest.php @@ -0,0 +1,157 @@ +getMockBuilder('Guzzle\Service\Command\AbstractCommand') + ->setMethods(array('getResponse')) + ->getMockForAbstractClass(); + $command->expects($this->once()) + ->method('getResponse') + ->will($this->returnValue(new Response(200, null, '{"foo":"bar"}'))); + $result = array(); + $visitor->before($command, $result); + $this->assertEquals(array('foo' => 'bar'), $result); + } + + public function testVisitsLocation() + { + $visitor = new Visitor(); + $param = new Parameter(array( + 'name' => 'foo', + 'type' => 'array', + 'items' => array( + 'filters' => 'strtoupper', + 'type' => 'string' + ) + )); + $this->value = array('foo' => array('a', 'b', 'c')); + $visitor->visit($this->command, $this->response, $param, $this->value); + $this->assertEquals(array('A', 'B', 'C'), $this->value['foo']); + } + + public function testRenamesTopLevelValues() + { + $visitor = new Visitor(); + $param = new Parameter(array( + 'name' => 'foo', + 'sentAs' => 'Baz', + 'type' => 'string', + )); + $this->value = array('Baz' => 'test'); + $visitor->visit($this->command, $this->response, $param, $this->value); + $this->assertEquals(array('foo' => 'test'), $this->value); + } + + public function testRenamesDoesNotFailForNonExistentKey() + { + $visitor = new Visitor(); + $param = new Parameter(array( + 'name' => 'foo', + 'type' => 'object', + 'properties' => array( + 'bar' => array( + 'name' => 'bar', + 'sentAs' => 'baz', + ), + ), + )); + $this->value = array('foo' => array('unknown' => 'Unknown')); + $visitor->visit($this->command, $this->response, $param, $this->value); + $this->assertEquals(array('foo' => array('unknown' => 'Unknown')), $this->value); + } + + public function testTraversesObjectsAndAppliesFilters() + { + $visitor = new Visitor(); + $param = new Parameter(array( + 'name' => 'foo', + 'type' => 'object', + 'properties' => array( + 'foo' => array('filters' => 'strtoupper'), + 'bar' => array('filters' => 'strtolower') + ) + )); + $this->value = array('foo' => array('foo' => 'hello', 'bar' => 'THERE')); + $visitor->visit($this->command, $this->response, $param, $this->value); + $this->assertEquals(array('foo' => 'HELLO', 'bar' => 'there'), $this->value['foo']); + } + + /** + * @group issue-399 + * @link https://github.com/guzzle/guzzle/issues/399 + */ + public function testDiscardingUnknownProperties() + { + $visitor = new Visitor(); + $param = new Parameter(array( + 'name' => 'foo', + 'type' => 'object', + 'additionalProperties' => false, + 'properties' => array( + 'bar' => array( + 'type' => 'string', + 'name' => 'bar', + ), + ), + )); + $this->value = array('foo' => array('bar' => 15, 'unknown' => 'Unknown')); + $visitor->visit($this->command, $this->response, $param, $this->value); + $this->assertEquals(array('foo' => array('bar' => 15)), $this->value); + } + + /** + * @group issue-399 + * @link https://github.com/guzzle/guzzle/issues/399 + */ + public function testDiscardingUnknownPropertiesWithAliasing() + { + $visitor = new Visitor(); + $param = new Parameter(array( + 'name' => 'foo', + 'type' => 'object', + 'additionalProperties' => false, + 'properties' => array( + 'bar' => array( + 'name' => 'bar', + 'sentAs' => 'baz', + ), + ), + )); + $this->value = array('foo' => array('baz' => 15, 'unknown' => 'Unknown')); + $visitor->visit($this->command, $this->response, $param, $this->value); + $this->assertEquals(array('foo' => array('bar' => 15)), $this->value); + } + + public function testWalksAdditionalProperties() + { + $visitor = new Visitor(); + $param = new Parameter(array( + 'name' => 'foo', + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'object', + 'properties' => array( + 'bar' => array( + 'type' => 'string', + 'filters' => array('base64_decode') + ) + ), + ), + )); + $this->value = array('foo' => array('baz' => array('bar' => 'Zm9v'))); + $visitor->visit($this->command, $this->response, $param, $this->value); + $this->assertEquals('foo', $this->value['foo']['baz']['bar']); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Response/ReasonPhraseVisitorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Response/ReasonPhraseVisitorTest.php new file mode 100644 index 0000000..23cd40f --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Response/ReasonPhraseVisitorTest.php @@ -0,0 +1,21 @@ + 'reasonPhrase', 'name' => 'phrase')); + $visitor->visit($this->command, $this->response, $param, $this->value); + $this->assertEquals('OK', $this->value['phrase']); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Response/StatusCodeVisitorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Response/StatusCodeVisitorTest.php new file mode 100644 index 0000000..7211a58 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Response/StatusCodeVisitorTest.php @@ -0,0 +1,21 @@ + 'statusCode', 'name' => 'code')); + $visitor->visit($this->command, $this->response, $param, $this->value); + $this->assertEquals(200, $this->value['code']); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Response/XmlVisitorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Response/XmlVisitorTest.php new file mode 100644 index 0000000..f87cec7 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/Response/XmlVisitorTest.php @@ -0,0 +1,431 @@ +getMockBuilder('Guzzle\Service\Command\AbstractCommand') + ->setMethods(array('getResponse')) + ->getMockForAbstractClass(); + $command->expects($this->once()) + ->method('getResponse') + ->will($this->returnValue(new Response(200, null, 'test'))); + $result = array(); + $visitor->before($command, $result); + $this->assertEquals(array('Bar' => 'test'), $result); + } + + public function testBeforeMethodParsesXmlWithNamespace() + { + $this->markTestSkipped("Response/XmlVisitor cannot accept 'xmlns' in response, see #368 (http://git.io/USa1mA)."); + + $visitor = new Visitor(); + $command = $this->getMockBuilder('Guzzle\Service\Command\AbstractCommand') + ->setMethods(array('getResponse')) + ->getMockForAbstractClass(); + $command->expects($this->once()) + ->method('getResponse') + ->will($this->returnValue(new Response(200, null, 'test'))); + $result = array(); + $visitor->before($command, $result); + $this->assertEquals(array('Bar' => 'test'), $result); + } + + public function testBeforeMethodParsesNestedXml() + { + $visitor = new Visitor(); + $command = $this->getMockBuilder('Guzzle\Service\Command\AbstractCommand') + ->setMethods(array('getResponse')) + ->getMockForAbstractClass(); + $command->expects($this->once()) + ->method('getResponse') + ->will($this->returnValue(new Response(200, null, 'test'))); + $result = array(); + $visitor->before($command, $result); + $this->assertEquals(array('Items' => array('Bar' => 'test')), $result); + } + + public function testCanExtractAndRenameTopLevelXmlValues() + { + $visitor = new Visitor(); + $param = new Parameter(array( + 'location' => 'xml', + 'name' => 'foo', + 'sentAs' => 'Bar' + )); + $value = array('Bar' => 'test'); + $visitor->visit($this->command, $this->response, $param, $value); + $this->assertArrayHasKey('foo', $value); + $this->assertEquals('test', $value['foo']); + } + + public function testEnsuresRepeatedArraysAreInCorrectLocations() + { + $visitor = new Visitor(); + $param = new Parameter(array( + 'location' => 'xml', + 'name' => 'foo', + 'sentAs' => 'Foo', + 'type' => 'array', + 'items' => array( + 'type' => 'object', + 'properties' => array( + 'Bar' => array('type' => 'string'), + 'Baz' => array('type' => 'string'), + 'Bam' => array('type' => 'string') + ) + ) + )); + + $xml = new \SimpleXMLElement('12'); + $value = json_decode(json_encode($xml), true); + $visitor->visit($this->command, $this->response, $param, $value); + $this->assertEquals(array( + 'foo' => array( + array ( + 'Bar' => '1', + 'Baz' => '2' + ) + ) + ), $value); + } + + public function testEnsuresFlatArraysAreFlat() + { + $visitor = new Visitor(); + $param = new Parameter(array( + 'location' => 'xml', + 'name' => 'foo', + 'type' => 'array', + 'items' => array('type' => 'string') + )); + + $value = array('foo' => array('bar', 'baz')); + $visitor->visit($this->command, $this->response, $param, $value); + $this->assertEquals(array('foo' => array('bar', 'baz')), $value); + + $value = array('foo' => 'bar'); + $visitor->visit($this->command, $this->response, $param, $value); + $this->assertEquals(array('foo' => array('bar')), $value); + } + + public function xmlDataProvider() + { + $param = new Parameter(array( + 'location' => 'xml', + 'name' => 'Items', + 'type' => 'array', + 'items' => array( + 'type' => 'object', + 'name' => 'Item', + 'properties' => array( + 'Bar' => array('type' => 'string'), + 'Baz' => array('type' => 'string') + ) + ) + )); + + return array( + array($param, '12', array( + 'Items' => array( + array('Bar' => 1), + array('Bar' => 2) + ) + )), + array($param, '1', array( + 'Items' => array( + array('Bar' => 1) + ) + )), + array($param, '', array( + 'Items' => array() + )) + ); + } + + /** + * @dataProvider xmlDataProvider + */ + public function testEnsuresWrappedArraysAreInCorrectLocations($param, $xml, $result) + { + $visitor = new Visitor(); + $xml = new \SimpleXMLElement($xml); + $value = json_decode(json_encode($xml), true); + $visitor->visit($this->command, $this->response, $param, $value); + $this->assertEquals($result, $value); + } + + public function testCanRenameValues() + { + $visitor = new Visitor(); + $param = new Parameter(array( + 'name' => 'TerminatingInstances', + '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', + ), + ), + ), + ), + ) + )); + + $value = array( + 'instancesSet' => array ( + 'item' => array ( + 'instanceId' => 'i-3ea74257', + 'currentState' => array( + 'code' => '32', + 'name' => 'shutting-down', + ), + 'previousState' => array( + 'code' => '16', + 'name' => 'running', + ), + ), + ) + ); + + $visitor->visit($this->command, $this->response, $param, $value); + + $this->assertEquals(array( + 'TerminatingInstances' => array( + array( + 'InstanceId' => 'i-3ea74257', + 'CurrentState' => array( + 'Code' => '32', + 'Name' => 'shutting-down', + ), + 'PreviousState' => array( + 'Code' => '16', + 'Name' => 'running', + ) + ) + ) + ), $value); + } + + public function testCanRenameAttributes() + { + $visitor = new Visitor(); + $param = new Parameter(array( + 'name' => 'RunningQueues', + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'type' => 'object', + 'sentAs' => 'item', + 'properties' => array( + 'QueueId' => array( + 'type' => 'string', + 'sentAs' => 'queue_id', + 'data' => array( + 'xmlAttribute' => true, + ), + ), + 'CurrentState' => array( + 'type' => 'object', + 'properties' => array( + 'Code' => array( + 'type' => 'numeric', + 'sentAs' => 'code', + 'data' => array( + 'xmlAttribute' => true, + ), + ), + 'Name' => array( + 'sentAs' => 'name', + 'data' => array( + 'xmlAttribute' => true, + ), + ), + ), + ), + 'PreviousState' => array( + 'type' => 'object', + 'properties' => array( + 'Code' => array( + 'type' => 'numeric', + 'sentAs' => 'code', + 'data' => array( + 'xmlAttribute' => true, + ), + ), + 'Name' => array( + 'sentAs' => 'name', + 'data' => array( + 'xmlAttribute' => true, + ), + ), + ), + ), + ), + ) + )); + + $xml = ''; + $value = json_decode(json_encode(new \SimpleXMLElement($xml)), true); + $visitor->visit($this->command, $this->response, $param, $value); + + $this->assertEquals(array( + 'RunningQueues' => array( + array( + 'QueueId' => 'q-3ea74257', + 'CurrentState' => array( + 'Code' => '32', + 'Name' => 'processing', + ), + 'PreviousState' => array( + 'Code' => '16', + 'Name' => 'wait', + ), + ), + ) + ), $value); + } + + public function testAddsEmptyArraysWhenValueIsMissing() + { + $visitor = new Visitor(); + $param = new Parameter(array( + 'name' => 'Foo', + 'type' => 'array', + 'location' => 'xml', + 'items' => array( + 'type' => 'object', + 'properties' => array( + 'Baz' => array('type' => 'array'), + 'Bar' => array( + 'type' => 'object', + 'properties' => array( + 'Baz' => array('type' => 'array'), + ) + ) + ) + ) + )); + + $value = array(); + $visitor->visit($this->command, $this->response, $param, $value); + + $value = array( + 'Foo' => array( + 'Bar' => array() + ) + ); + $visitor->visit($this->command, $this->response, $param, $value); + $this->assertEquals(array( + 'Foo' => array( + array( + 'Bar' => array() + ) + ) + ), $value); + } + + /** + * @group issue-399 + * @link https://github.com/guzzle/guzzle/issues/399 + */ + public function testDiscardingUnknownProperties() + { + $visitor = new Visitor(); + $param = new Parameter(array( + 'name' => 'foo', + 'type' => 'object', + 'additionalProperties' => false, + 'properties' => array( + 'bar' => array( + 'type' => 'string', + 'name' => 'bar', + ), + ), + )); + $this->value = array('foo' => array('bar' => 15, 'unknown' => 'Unknown')); + $visitor->visit($this->command, $this->response, $param, $this->value); + $this->assertEquals(array('foo' => array('bar' => 15)), $this->value); + } + + /** + * @group issue-399 + * @link https://github.com/guzzle/guzzle/issues/399 + */ + public function testDiscardingUnknownPropertiesWithAliasing() + { + $visitor = new Visitor(); + $param = new Parameter(array( + 'name' => 'foo', + 'type' => 'object', + 'additionalProperties' => false, + 'properties' => array( + 'bar' => array( + 'name' => 'bar', + 'sentAs' => 'baz', + ), + ), + )); + $this->value = array('foo' => array('baz' => 15, 'unknown' => 'Unknown')); + $visitor->visit($this->command, $this->response, $param, $this->value); + $this->assertEquals(array('foo' => array('bar' => 15)), $this->value); + } + + public function testProperlyHandlesEmptyStringValues() + { + $visitor = new Visitor(); + $param = new Parameter(array( + 'name' => 'foo', + 'type' => 'object', + 'properties' => array( + 'bar' => array('type' => 'string') + ), + )); + $xml = ''; + $value = json_decode(json_encode(new \SimpleXMLElement($xml)), true); + $visitor->visit($this->command, $this->response, $param, $value); + $this->assertEquals(array('foo' => array('bar' => '')), $value); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/VisitorFlyweightTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/VisitorFlyweightTest.php new file mode 100644 index 0000000..a252ffe --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/LocationVisitor/VisitorFlyweightTest.php @@ -0,0 +1,53 @@ +assertInstanceOf('Guzzle\Service\Command\LocationVisitor\Request\JsonVisitor', $f->getRequestVisitor('json')); + $this->assertInstanceOf('Guzzle\Service\Command\LocationVisitor\Response\JsonVisitor', $f->getResponseVisitor('json')); + } + + public function testCanUseCustomMappings() + { + $f = new VisitorFlyweight(array()); + $this->assertEquals(array(), $this->readAttribute($f, 'mappings')); + } + + /** + * @expectedException \InvalidArgumentException + * @expectedExceptionMessage No request visitor has been mapped for foo + */ + public function testThrowsExceptionWhenRetrievingUnknownVisitor() + { + VisitorFlyweight::getInstance()->getRequestVisitor('foo'); + } + + public function testCachesVisitors() + { + $f = new VisitorFlyweight(); + $v1 = $f->getRequestVisitor('json'); + $this->assertSame($v1, $f->getRequestVisitor('json')); + } + + public function testAllowsAddingVisitors() + { + $f = new VisitorFlyweight(); + $j1 = new JsonRequestVisitor(); + $j2 = new JsonResponseVisitor(); + $f->addRequestVisitor('json', $j1); + $f->addResponseVisitor('json', $j2); + $this->assertSame($j1, $f->getRequestVisitor('json')); + $this->assertSame($j2, $f->getResponseVisitor('json')); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/OperationCommandTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/OperationCommandTest.php new file mode 100644 index 0000000..95fb533 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/OperationCommandTest.php @@ -0,0 +1,102 @@ +getRequestSerializer(); + $b = new DefaultRequestSerializer(VisitorFlyweight::getInstance()); + $operation->setRequestSerializer($b); + $this->assertNotSame($a, $operation->getRequestSerializer()); + } + + public function testPreparesRequestUsingSerializer() + { + $op = new OperationCommand(array(), new Operation()); + $op->setClient(new Client()); + $s = $this->getMockBuilder('Guzzle\Service\Command\RequestSerializerInterface') + ->setMethods(array('prepare')) + ->getMockForAbstractClass(); + $s->expects($this->once()) + ->method('prepare') + ->will($this->returnValue(new EntityEnclosingRequest('POST', 'http://foo.com'))); + $op->setRequestSerializer($s); + $op->prepare(); + } + + public function testParsesResponsesWithResponseParser() + { + $op = new OperationCommand(array(), new Operation()); + $p = $this->getMockBuilder('Guzzle\Service\Command\ResponseParserInterface') + ->setMethods(array('parse')) + ->getMockForAbstractClass(); + $p->expects($this->once()) + ->method('parse') + ->will($this->returnValue(array('foo' => 'bar'))); + $op->setResponseParser($p); + $op->setClient(new Client()); + $request = $op->prepare(); + $request->setResponse(new Response(200), true); + $this->assertEquals(array('foo' => 'bar'), $op->execute()); + } + + public function testParsesResponsesUsingModelParserWhenMatchingModelIsFound() + { + $description = ServiceDescription::factory(array( + 'operations' => array( + 'foo' => array('responseClass' => 'bar', 'responseType' => 'model') + ), + 'models' => array( + 'bar' => array( + 'type' => 'object', + 'properties' => array( + 'Baz' => array('type' => 'string', 'location' => 'xml') + ) + ) + ) + )); + + $op = new OperationCommand(array(), $description->getOperation('foo')); + $op->setClient(new Client()); + $request = $op->prepare(); + $request->setResponse(new Response(200, array( + 'Content-Type' => 'application/xml' + ), 'Bar'), true); + $result = $op->execute(); + $this->assertEquals(new Model(array('Baz' => 'Bar')), $result); + } + + public function testAllowsRawResponses() + { + $description = new ServiceDescription(array( + 'operations' => array('foo' => array('responseClass' => 'bar', 'responseType' => 'model')), + 'models' => array('bar' => array()) + )); + $op = new OperationCommand(array( + OperationCommand::RESPONSE_PROCESSING => OperationCommand::TYPE_RAW + ), $description->getOperation('foo')); + $op->setClient(new Client()); + $request = $op->prepare(); + $response = new Response(200, array( + 'Content-Type' => 'application/xml' + ), 'Bar'); + $request->setResponse($response, true); + $this->assertSame($response, $op->execute()); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/OperationResponseParserTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/OperationResponseParserTest.php new file mode 100644 index 0000000..69ba1fc --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Command/OperationResponseParserTest.php @@ -0,0 +1,335 @@ +addVisitor('foo', $visitor); + $this->assertSame($visitor, $this->readAttribute($p, 'factory')->getResponseVisitor('foo')); + } + + public function testUsesParentParser() + { + $p = new OperationResponseParser(new VisitorFlyweight()); + $operation = new Operation(); + $operation->setServiceDescription(new ServiceDescription()); + $op = new OperationCommand(array(), $operation); + $op->setResponseParser($p)->setClient(new Client()); + $op->prepare()->setResponse(new Response(200, array('Content-Type' => 'application/xml'), 'C'), true); + $this->assertInstanceOf('SimpleXMLElement', $op->execute()); + } + + public function testVisitsLocations() + { + $parser = new OperationResponseParser(new VisitorFlyweight(array())); + $parser->addVisitor('statusCode', new StatusCodeVisitor()); + $parser->addVisitor('reasonPhrase', new ReasonPhraseVisitor()); + $parser->addVisitor('json', new JsonVisitor()); + $op = new OperationCommand(array(), $this->getDescription()->getOperation('test')); + $op->setResponseParser($parser)->setClient(new Client()); + $op->prepare()->setResponse(new Response(201), true); + $result = $op->execute(); + $this->assertEquals(201, $result['code']); + $this->assertEquals('Created', $result['phrase']); + } + + public function testVisitsLocationsForJsonResponse() + { + $parser = OperationResponseParser::getInstance(); + $operation = $this->getDescription()->getOperation('test'); + $op = new OperationCommand(array(), $operation); + $op->setResponseParser($parser)->setClient(new Client()); + $op->prepare()->setResponse(new Response(200, array( + 'Content-Type' => 'application/json' + ), '{"baz":"bar","enigma":"123"}'), true); + $result = $op->execute(); + $this->assertEquals(array( + 'baz' => 'bar', + 'enigma' => '123', + 'code' => 200, + 'phrase' => 'OK' + ), $result->toArray()); + } + + public function testSkipsUnkownModels() + { + $parser = OperationResponseParser::getInstance(); + $operation = $this->getDescription()->getOperation('test'); + $operation->setResponseClass('Baz')->setResponseType('model'); + $op = new OperationCommand(array(), $operation); + $op->setResponseParser($parser)->setClient(new Client()); + $op->prepare()->setResponse(new Response(201), true); + $this->assertInstanceOf('Guzzle\Http\Message\Response', $op->execute()); + } + + public function testAllowsModelProcessingToBeDisabled() + { + $parser = OperationResponseParser::getInstance(); + $operation = $this->getDescription()->getOperation('test'); + $op = new OperationCommand(array('command.response_processing' => 'native'), $operation); + $op->setResponseParser($parser)->setClient(new Client()); + $op->prepare()->setResponse(new Response(200, array( + 'Content-Type' => 'application/json' + ), '{"baz":"bar","enigma":"123"}'), true); + $result = $op->execute(); + $this->assertInstanceOf('Guzzle\Service\Resource\Model', $result); + $this->assertEquals(array( + 'baz' => 'bar', + 'enigma' => '123' + ), $result->toArray()); + } + + public function testCanInjectModelSchemaIntoModels() + { + $parser = new OperationResponseParser(VisitorFlyweight::getInstance(), true); + $desc = $this->getDescription(); + $operation = $desc->getOperation('test'); + $op = new OperationCommand(array(), $operation); + $op->setResponseParser($parser)->setClient(new Client()); + $op->prepare()->setResponse(new Response(200, array( + 'Content-Type' => 'application/json' + ), '{"baz":"bar","enigma":"123"}'), true); + $result = $op->execute(); + $this->assertSame($result->getStructure(), $desc->getModel('Foo')); + } + + public function testDoesNotParseXmlWhenNotUsingXmlVisitor() + { + $parser = OperationResponseParser::getInstance(); + $description = ServiceDescription::factory(array( + 'operations' => array('test' => array('responseClass' => 'Foo')), + 'models' => array( + 'Foo' => array( + 'type' => 'object', + 'properties' => array('baz' => array('location' => 'body')) + ) + ) + )); + $operation = $description->getOperation('test'); + $op = new OperationCommand(array(), $operation); + $op->setResponseParser($parser)->setClient(new Client()); + $brokenXml = '<><><>>>>'; + $op->prepare()->setResponse(new Response(200, array( + 'Content-Type' => 'application/xml' + ), $brokenXml), true); + $result = $op->execute(); + $this->assertEquals(array('baz'), $result->getKeys()); + $this->assertEquals($brokenXml, (string) $result['baz']); + } + + public function testVisitsAdditionalProperties() + { + $parser = OperationResponseParser::getInstance(); + $description = ServiceDescription::factory(array( + 'operations' => array('test' => array('responseClass' => 'Foo')), + 'models' => array( + 'Foo' => array( + 'type' => 'object', + 'properties' => array( + 'code' => array('location' => 'statusCode') + ), + 'additionalProperties' => array( + 'location' => 'json', + 'type' => 'object', + 'properties' => array( + 'a' => array( + 'type' => 'string', + 'filters' => 'strtoupper' + ) + ) + ) + ) + ) + )); + + $operation = $description->getOperation('test'); + $op = new OperationCommand(array(), $operation); + $op->setResponseParser($parser)->setClient(new Client()); + $json = '[{"a":"test"},{"a":"baz"}]'; + $op->prepare()->setResponse(new Response(200, array('Content-Type' => 'application/json'), $json), true); + $result = $op->execute()->toArray(); + $this->assertEquals(array( + 'code' => 200, + array('a' => 'TEST'), + array('a' => 'BAZ') + ), $result); + } + + /** + * @group issue-399 + * @link https://github.com/guzzle/guzzle/issues/399 + */ + public function testAdditionalPropertiesDisabledDiscardsData() + { + $parser = OperationResponseParser::getInstance(); + $description = ServiceDescription::factory(array( + 'operations' => array('test' => array('responseClass' => 'Foo')), + 'models' => array( + 'Foo' => array( + 'type' => 'object', + 'additionalProperties' => false, + 'properties' => array( + 'name' => array( + 'location' => 'json', + 'type' => 'string', + ), + 'nested' => array( + 'location' => 'json', + 'type' => 'object', + 'additionalProperties' => false, + 'properties' => array( + 'width' => array( + 'type' => 'integer' + ) + ), + ), + 'code' => array('location' => 'statusCode') + ), + + ) + ) + )); + + $operation = $description->getOperation('test'); + $op = new OperationCommand(array(), $operation); + $op->setResponseParser($parser)->setClient(new Client()); + $json = '{"name":"test", "volume":2.0, "nested":{"width":10,"bogus":1}}'; + $op->prepare()->setResponse(new Response(200, array('Content-Type' => 'application/json'), $json), true); + $result = $op->execute()->toArray(); + $this->assertEquals(array( + 'name' => 'test', + 'nested' => array( + 'width' => 10, + ), + 'code' => 200 + ), $result); + } + + public function testCreatesCustomResponseClassInterface() + { + $parser = OperationResponseParser::getInstance(); + $description = ServiceDescription::factory(array( + 'operations' => array('test' => array('responseClass' => 'Guzzle\Tests\Mock\CustomResponseModel')) + )); + $operation = $description->getOperation('test'); + $op = new OperationCommand(array(), $operation); + $op->setResponseParser($parser)->setClient(new Client()); + $op->prepare()->setResponse(new Response(200, array('Content-Type' => 'application/json'), 'hi!'), true); + $result = $op->execute(); + $this->assertInstanceOf('Guzzle\Tests\Mock\CustomResponseModel', $result); + $this->assertSame($op, $result->command); + } + + /** + * @expectedException \Guzzle\Service\Exception\ResponseClassException + * @expectedExceptionMessage must exist + */ + public function testEnsuresResponseClassExists() + { + $parser = OperationResponseParser::getInstance(); + $description = ServiceDescription::factory(array( + 'operations' => array('test' => array('responseClass' => 'Foo\Baz\Bar')) + )); + $operation = $description->getOperation('test'); + $op = new OperationCommand(array(), $operation); + $op->setResponseParser($parser)->setClient(new Client()); + $op->prepare()->setResponse(new Response(200, array('Content-Type' => 'application/json'), 'hi!'), true); + $op->execute(); + } + + /** + * @expectedException \Guzzle\Service\Exception\ResponseClassException + * @expectedExceptionMessage and implement + */ + public function testEnsuresResponseClassImplementsResponseClassInterface() + { + $parser = OperationResponseParser::getInstance(); + $description = ServiceDescription::factory(array( + 'operations' => array('test' => array('responseClass' => __CLASS__)) + )); + $operation = $description->getOperation('test'); + $op = new OperationCommand(array(), $operation); + $op->setResponseParser($parser)->setClient(new Client()); + $op->prepare()->setResponse(new Response(200, array('Content-Type' => 'application/json'), 'hi!'), true); + $op->execute(); + } + + protected function getDescription() + { + return ServiceDescription::factory(array( + 'operations' => array('test' => array('responseClass' => 'Foo')), + 'models' => array( + 'Foo' => array( + 'type' => 'object', + 'properties' => array( + 'baz' => array('type' => 'string', 'location' => 'json'), + 'code' => array('location' => 'statusCode'), + 'phrase' => array('location' => 'reasonPhrase'), + ) + ) + ) + )); + } + + public function testCanAddListenerToParseDomainObjects() + { + $client = new Client(); + $client->setDescription(ServiceDescription::factory(array( + 'operations' => array('test' => array('responseClass' => 'FooBazBar')) + ))); + $foo = new \stdClass(); + $client->getEventDispatcher()->addListener('command.parse_response', function ($e) use ($foo) { + $e['result'] = $foo; + }); + $command = $client->getCommand('test'); + $command->prepare()->setResponse(new Response(200), true); + $result = $command->execute(); + $this->assertSame($result, $foo); + } + + /** + * @group issue-399 + * @link https://github.com/guzzle/guzzle/issues/501 + */ + public function testAdditionalPropertiesWithRefAreResolved() + { + $parser = OperationResponseParser::getInstance(); + $description = ServiceDescription::factory(array( + 'operations' => array('test' => array('responseClass' => 'Foo')), + 'models' => array( + 'Baz' => array('type' => 'string'), + 'Foo' => array( + 'type' => 'object', + 'additionalProperties' => array('$ref' => 'Baz', 'location' => 'json') + ) + ) + )); + $operation = $description->getOperation('test'); + $op = new OperationCommand(array(), $operation); + $op->setResponseParser($parser)->setClient(new Client()); + $json = '{"a":"a","b":"b","c":"c"}'; + $op->prepare()->setResponse(new Response(200, array('Content-Type' => 'application/json'), $json), true); + $result = $op->execute()->toArray(); + $this->assertEquals(array('a' => 'a', 'b' => 'b', 'c' => 'c'), $result); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Description/OperationTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Description/OperationTest.php new file mode 100644 index 0000000..ae33b69 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Description/OperationTest.php @@ -0,0 +1,308 @@ + 'test', + 'summary' => 'doc', + 'notes' => 'notes', + 'documentationUrl' => 'http://www.example.com', + 'httpMethod' => 'POST', + 'uri' => '/api/v1', + 'responseClass' => 'array', + 'responseNotes' => 'returns the json_decoded response', + 'deprecated' => true, + 'parameters' => array( + 'key' => array( + 'required' => true, + 'type' => 'string', + 'maxLength' => 10 + ), + 'key_2' => array( + 'required' => true, + 'type' => 'integer', + 'default' => 10 + ) + ) + )); + + $this->assertEquals('test', $c->getName()); + $this->assertEquals('doc', $c->getSummary()); + $this->assertEquals('http://www.example.com', $c->getDocumentationUrl()); + $this->assertEquals('POST', $c->getHttpMethod()); + $this->assertEquals('/api/v1', $c->getUri()); + $this->assertEquals('array', $c->getResponseClass()); + $this->assertEquals('returns the json_decoded response', $c->getResponseNotes()); + $this->assertTrue($c->getDeprecated()); + $this->assertEquals('Guzzle\\Service\\Command\\OperationCommand', $c->getClass()); + $this->assertEquals(array( + 'key' => new Parameter(array( + 'name' => 'key', + 'required' => true, + 'type' => 'string', + 'maxLength' => 10, + 'parent' => $c + )), + 'key_2' => new Parameter(array( + 'name' => 'key_2', + 'required' => true, + 'type' => 'integer', + 'default' => 10, + 'parent' => $c + )) + ), $c->getParams()); + + $this->assertEquals(new Parameter(array( + 'name' => 'key_2', + 'required' => true, + 'type' => 'integer', + 'default' => 10, + 'parent' => $c + )), $c->getParam('key_2')); + + $this->assertNull($c->getParam('afefwef')); + $this->assertArrayNotHasKey('parent', $c->getParam('key_2')->toArray()); + } + + public function testAllowsConcreteCommands() + { + $c = new Operation(array( + 'name' => 'test', + 'class' => 'Guzzle\\Service\\Command\ClosureCommand', + 'parameters' => array( + 'p' => new Parameter(array( + 'name' => 'foo' + )) + ) + )); + $this->assertEquals('Guzzle\\Service\\Command\ClosureCommand', $c->getClass()); + } + + public function testConvertsToArray() + { + $data = array( + 'name' => 'test', + 'class' => 'Guzzle\\Service\\Command\ClosureCommand', + 'summary' => 'test', + 'documentationUrl' => 'http://www.example.com', + 'httpMethod' => 'PUT', + 'uri' => '/', + 'parameters' => array('p' => array('name' => 'foo')) + ); + $c = new Operation($data); + $toArray = $c->toArray(); + unset($data['name']); + $this->assertArrayHasKey('parameters', $toArray); + $this->assertInternalType('array', $toArray['parameters']); + + // Normalize the array + unset($data['parameters']); + unset($toArray['parameters']); + + $data['responseType'] = 'primitive'; + $data['responseClass'] = 'array'; + $this->assertEquals($data, $toArray); + } + + public function testDeterminesIfHasParam() + { + $command = $this->getTestCommand(); + $this->assertTrue($command->hasParam('data')); + $this->assertFalse($command->hasParam('baz')); + } + + public function testReturnsParamNames() + { + $command = $this->getTestCommand(); + $this->assertEquals(array('data'), $command->getParamNames()); + } + + protected function getTestCommand() + { + return new Operation(array( + 'parameters' => array( + 'data' => new Parameter(array( + 'type' => 'string' + )) + ) + )); + } + + public function testCanBuildUpCommands() + { + $c = new Operation(array()); + $c->setName('foo') + ->setClass('Baz') + ->setDeprecated(false) + ->setSummary('summary') + ->setDocumentationUrl('http://www.foo.com') + ->setHttpMethod('PUT') + ->setResponseNotes('oh') + ->setResponseClass('string') + ->setUri('/foo/bar') + ->addParam(new Parameter(array( + 'name' => 'test' + ))); + + $this->assertEquals('foo', $c->getName()); + $this->assertEquals('Baz', $c->getClass()); + $this->assertEquals(false, $c->getDeprecated()); + $this->assertEquals('summary', $c->getSummary()); + $this->assertEquals('http://www.foo.com', $c->getDocumentationUrl()); + $this->assertEquals('PUT', $c->getHttpMethod()); + $this->assertEquals('oh', $c->getResponseNotes()); + $this->assertEquals('string', $c->getResponseClass()); + $this->assertEquals('/foo/bar', $c->getUri()); + $this->assertEquals(array('test'), $c->getParamNames()); + } + + public function testCanRemoveParams() + { + $c = new Operation(array()); + $c->addParam(new Parameter(array('name' => 'foo'))); + $this->assertTrue($c->hasParam('foo')); + $c->removeParam('foo'); + $this->assertFalse($c->hasParam('foo')); + } + + public function testAddsNameToParametersIfNeeded() + { + $command = new Operation(array('parameters' => array('foo' => new Parameter(array())))); + $this->assertEquals('foo', $command->getParam('foo')->getName()); + } + + public function testContainsApiErrorInformation() + { + $command = $this->getOperation(); + $this->assertEquals(1, count($command->getErrorResponses())); + $arr = $command->toArray(); + $this->assertEquals(1, count($arr['errorResponses'])); + $command->addErrorResponse(400, 'Foo', 'Baz\\Bar'); + $this->assertEquals(2, count($command->getErrorResponses())); + $command->setErrorResponses(array()); + $this->assertEquals(0, count($command->getErrorResponses())); + } + + public function testHasNotes() + { + $o = new Operation(array('notes' => 'foo')); + $this->assertEquals('foo', $o->getNotes()); + $o->setNotes('bar'); + $this->assertEquals('bar', $o->getNotes()); + } + + public function testHasData() + { + $o = new Operation(array('data' => array('foo' => 'baz', 'bar' => 123))); + $o->setData('test', false); + $this->assertEquals('baz', $o->getData('foo')); + $this->assertEquals(123, $o->getData('bar')); + $this->assertNull($o->getData('wfefwe')); + $this->assertEquals(array( + 'parameters' => array(), + 'class' => 'Guzzle\Service\Command\OperationCommand', + 'data' => array('foo' => 'baz', 'bar' => 123, 'test' => false), + 'responseClass' => 'array', + 'responseType' => 'primitive' + ), $o->toArray()); + } + + public function testHasServiceDescription() + { + $s = new ServiceDescription(); + $o = new Operation(array(), $s); + $this->assertSame($s, $o->getServiceDescription()); + } + + /** + * @expectedException Guzzle\Common\Exception\InvalidArgumentException + */ + public function testValidatesResponseType() + { + $o = new Operation(array('responseClass' => 'array', 'responseType' => 'foo')); + } + + public function testInfersResponseType() + { + $o = $this->getOperation(); + $o->setServiceDescription(new ServiceDescription(array('models' => array('Foo' => array())))); + $this->assertEquals('primitive', $o->getResponseType()); + $this->assertEquals('primitive', $o->setResponseClass('boolean')->getResponseType()); + $this->assertEquals('primitive', $o->setResponseClass('array')->getResponseType()); + $this->assertEquals('primitive', $o->setResponseClass('integer')->getResponseType()); + $this->assertEquals('primitive', $o->setResponseClass('string')->getResponseType()); + $this->assertEquals('class', $o->setResponseClass('foo')->getResponseType()); + $this->assertEquals('class', $o->setResponseClass(__CLASS__)->getResponseType()); + $this->assertEquals('model', $o->setResponseClass('Foo')->getResponseType()); + } + + public function testHasResponseType() + { + // infers in the constructor + $o = new Operation(array('responseClass' => 'array')); + $this->assertEquals('primitive', $o->getResponseType()); + // Infers when set + $o = new Operation(); + $this->assertEquals('primitive', $o->getResponseType()); + $this->assertEquals('model', $o->setResponseType('model')->getResponseType()); + } + + public function testHasAdditionalParameters() + { + $o = new Operation(array( + 'additionalParameters' => array( + 'type' => 'string', 'name' => 'binks' + ), + 'parameters' => array( + 'foo' => array('type' => 'integer') + ) + )); + $this->assertEquals('string', $o->getAdditionalParameters()->getType()); + $arr = $o->toArray(); + $this->assertEquals(array( + 'type' => 'string' + ), $arr['additionalParameters']); + } + + /** + * @return Operation + */ + protected function getOperation() + { + return new Operation(array( + 'name' => 'OperationTest', + 'class' => get_class($this), + 'parameters' => array( + 'test' => array('type' => 'object'), + 'bool_1' => array('default' => true, 'type' => 'boolean'), + 'bool_2' => array('default' => false), + 'float' => array('type' => 'numeric'), + 'int' => array('type' => 'integer'), + 'date' => array('type' => 'string'), + 'timestamp' => array('type' => 'string'), + 'string' => array('type' => 'string'), + 'username' => array('type' => 'string', 'required' => true, 'filters' => 'strtolower'), + 'test_function' => array('type' => 'string', 'filters' => __CLASS__ . '::strtoupper') + ), + 'errorResponses' => array( + array('code' => 503, 'reason' => 'InsufficientCapacity', 'class' => 'Guzzle\\Exception\\RuntimeException') + ) + )); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Description/ParameterTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Description/ParameterTest.php new file mode 100644 index 0000000..b9c162a --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Description/ParameterTest.php @@ -0,0 +1,411 @@ + 'foo', + 'type' => 'bar', + 'required' => true, + 'default' => '123', + 'description' => '456', + 'minLength' => 2, + 'maxLength' => 5, + 'location' => 'body', + 'static' => 'static!', + 'filters' => array('trim', 'json_encode') + ); + + public function testCreatesParamFromArray() + { + $p = new Parameter($this->data); + $this->assertEquals('foo', $p->getName()); + $this->assertEquals('bar', $p->getType()); + $this->assertEquals(true, $p->getRequired()); + $this->assertEquals('123', $p->getDefault()); + $this->assertEquals('456', $p->getDescription()); + $this->assertEquals(2, $p->getMinLength()); + $this->assertEquals(5, $p->getMaxLength()); + $this->assertEquals('body', $p->getLocation()); + $this->assertEquals('static!', $p->getStatic()); + $this->assertEquals(array('trim', 'json_encode'), $p->getFilters()); + } + + public function testCanConvertToArray() + { + $p = new Parameter($this->data); + unset($this->data['name']); + $this->assertEquals($this->data, $p->toArray()); + } + + public function testUsesStatic() + { + $d = $this->data; + $d['default'] = 'booboo'; + $d['static'] = true; + $p = new Parameter($d); + $this->assertEquals('booboo', $p->getValue('bar')); + } + + public function testUsesDefault() + { + $d = $this->data; + $d['default'] = 'foo'; + $d['static'] = null; + $p = new Parameter($d); + $this->assertEquals('foo', $p->getValue(null)); + } + + public function testReturnsYourValue() + { + $d = $this->data; + $d['static'] = null; + $p = new Parameter($d); + $this->assertEquals('foo', $p->getValue('foo')); + } + + public function testZeroValueDoesNotCauseDefaultToBeReturned() + { + $d = $this->data; + $d['default'] = '1'; + $d['static'] = null; + $p = new Parameter($d); + $this->assertEquals('0', $p->getValue('0')); + } + + public function testFiltersValues() + { + $d = $this->data; + $d['static'] = null; + $d['filters'] = 'strtoupper'; + $p = new Parameter($d); + $this->assertEquals('FOO', $p->filter('foo')); + } + + public function testConvertsBooleans() + { + $p = new Parameter(array('type' => 'boolean')); + $this->assertEquals(true, $p->filter('true')); + $this->assertEquals(false, $p->filter('false')); + } + + public function testUsesArrayByDefaultForFilters() + { + $d = $this->data; + $d['filters'] = null; + $p = new Parameter($d); + $this->assertEquals(array(), $p->getFilters()); + } + + public function testAllowsSimpleLocationValue() + { + $p = new Parameter(array('name' => 'myname', 'location' => 'foo', 'sentAs' => 'Hello')); + $this->assertEquals('foo', $p->getLocation()); + $this->assertEquals('Hello', $p->getSentAs()); + } + + public function testParsesTypeValues() + { + $p = new Parameter(array('type' => 'foo')); + $this->assertEquals('foo', $p->getType()); + } + + /** + * @expectedException InvalidArgumentException + * @expectedExceptionMessage A [method] value must be specified for each complex filter + */ + public function testValidatesComplexFilters() + { + $p = new Parameter(array('filters' => array(array('args' => 'foo')))); + } + + public function testCanBuildUpParams() + { + $p = new Parameter(array()); + $p->setName('foo') + ->setDescription('c') + ->setFilters(array('d')) + ->setLocation('e') + ->setSentAs('f') + ->setMaxLength(1) + ->setMinLength(1) + ->setMinimum(2) + ->setMaximum(2) + ->setMinItems(3) + ->setMaxItems(3) + ->setRequired(true) + ->setStatic(true) + ->setDefault('h') + ->setType('i'); + + $p->addFilter('foo'); + + $this->assertEquals('foo', $p->getName()); + $this->assertEquals('h', $p->getDefault()); + $this->assertEquals('c', $p->getDescription()); + $this->assertEquals(array('d', 'foo'), $p->getFilters()); + $this->assertEquals('e', $p->getLocation()); + $this->assertEquals('f', $p->getSentAs()); + $this->assertEquals(1, $p->getMaxLength()); + $this->assertEquals(1, $p->getMinLength()); + $this->assertEquals(2, $p->getMaximum()); + $this->assertEquals(2, $p->getMinimum()); + $this->assertEquals(3, $p->getMaxItems()); + $this->assertEquals(3, $p->getMinItems()); + $this->assertEquals(true, $p->getRequired()); + $this->assertEquals(true, $p->getStatic()); + $this->assertEquals('i', $p->getType()); + } + + public function testAllowsNestedShape() + { + $command = $this->getServiceBuilder()->get('mock')->getCommand('mock_command')->getOperation(); + $param = new Parameter(array( + 'parent' => $command, + 'name' => 'foo', + 'type' => 'object', + 'location' => 'query', + 'properties' => array( + 'foo' => array( + 'type' => 'object', + 'required' => true, + 'properties' => array( + 'baz' => array( + 'name' => 'baz', + 'type' => 'bool', + ) + ) + ), + 'bar' => array( + 'name' => 'bar', + 'default' => '123' + ) + ) + )); + + $this->assertSame($command, $param->getParent()); + $this->assertNotEmpty($param->getProperties()); + $this->assertInstanceOf('Guzzle\Service\Description\Parameter', $param->getProperty('foo')); + $this->assertSame($param, $param->getProperty('foo')->getParent()); + $this->assertSame($param->getProperty('foo'), $param->getProperty('foo')->getProperty('baz')->getParent()); + $this->assertInstanceOf('Guzzle\Service\Description\Parameter', $param->getProperty('bar')); + $this->assertSame($param, $param->getProperty('bar')->getParent()); + + $array = $param->toArray(); + $this->assertInternalType('array', $array['properties']); + $this->assertArrayHasKey('foo', $array['properties']); + $this->assertArrayHasKey('bar', $array['properties']); + } + + public function testAllowsComplexFilters() + { + $that = $this; + $param = new Parameter(array()); + $param->setFilters(array(array('method' => function ($a, $b, $c, $d) use ($that, $param) { + $that->assertEquals('test', $a); + $that->assertEquals('my_value!', $b); + $that->assertEquals('bar', $c); + $that->assertSame($param, $d); + return 'abc' . $b; + }, 'args' => array('test', '@value', 'bar', '@api')))); + $this->assertEquals('abcmy_value!', $param->filter('my_value!')); + } + + public function testCanChangeParentOfNestedParameter() + { + $param1 = new Parameter(array('name' => 'parent')); + $param2 = new Parameter(array('name' => 'child')); + $param2->setParent($param1); + $this->assertSame($param1, $param2->getParent()); + } + + public function testCanRemoveFromNestedStructure() + { + $param1 = new Parameter(array('name' => 'parent')); + $param2 = new Parameter(array('name' => 'child')); + $param1->addProperty($param2); + $this->assertSame($param1, $param2->getParent()); + $this->assertSame($param2, $param1->getProperty('child')); + + // Remove a single child from the structure + $param1->removeProperty('child'); + $this->assertNull($param1->getProperty('child')); + // Remove the entire structure + $param1->addProperty($param2); + $param1->removeProperty('child'); + $this->assertNull($param1->getProperty('child')); + } + + public function testAddsAdditionalProperties() + { + $p = new Parameter(array( + 'type' => 'object', + 'additionalProperties' => array('type' => 'string') + )); + $this->assertInstanceOf('Guzzle\Service\Description\Parameter', $p->getAdditionalProperties()); + $this->assertNull($p->getAdditionalProperties()->getAdditionalProperties()); + $p = new Parameter(array('type' => 'object')); + $this->assertTrue($p->getAdditionalProperties()); + } + + public function testAddsItems() + { + $p = new Parameter(array( + 'type' => 'array', + 'items' => array('type' => 'string') + )); + $this->assertInstanceOf('Guzzle\Service\Description\Parameter', $p->getItems()); + $out = $p->toArray(); + $this->assertEquals('array', $out['type']); + $this->assertInternalType('array', $out['items']); + } + + public function testHasExtraProperties() + { + $p = new Parameter(); + $this->assertEquals(array(), $p->getData()); + $p->setData(array('foo' => 'bar')); + $this->assertEquals('bar', $p->getData('foo')); + $p->setData('baz', 'boo'); + $this->assertEquals(array('foo' => 'bar', 'baz' => 'boo'), $p->getData()); + } + + public function testCanRetrieveKnownPropertiesUsingDataMethod() + { + $p = new Parameter(); + $this->assertEquals(null, $p->getData('foo')); + $p->setName('test'); + $this->assertEquals('test', $p->getData('name')); + } + + public function testHasInstanceOf() + { + $p = new Parameter(); + $this->assertNull($p->getInstanceOf()); + $p->setInstanceOf('Foo'); + $this->assertEquals('Foo', $p->getInstanceOf()); + } + + public function testHasPattern() + { + $p = new Parameter(); + $this->assertNull($p->getPattern()); + $p->setPattern('/[0-9]+/'); + $this->assertEquals('/[0-9]+/', $p->getPattern()); + } + + public function testHasEnum() + { + $p = new Parameter(); + $this->assertNull($p->getEnum()); + $p->setEnum(array('foo', 'bar')); + $this->assertEquals(array('foo', 'bar'), $p->getEnum()); + } + + public function testSerializesItems() + { + $p = new Parameter(array( + 'type' => 'object', + 'additionalProperties' => array('type' => 'string') + )); + $this->assertEquals(array( + 'type' => 'object', + 'additionalProperties' => array('type' => 'string') + ), $p->toArray()); + } + + public function testResolvesRefKeysRecursively() + { + $description = new ServiceDescription(array( + 'models' => array( + 'JarJar' => array('type' => 'string', 'default' => 'Mesa address tha senate!'), + 'Anakin' => array('type' => 'array', 'items' => array('$ref' => 'JarJar')) + ) + )); + $p = new Parameter(array('$ref' => 'Anakin', 'description' => 'added'), $description); + $this->assertEquals(array( + 'type' => 'array', + 'items' => array('type' => 'string', 'default' => 'Mesa address tha senate!'), + 'description' => 'added' + ), $p->toArray()); + } + + public function testResolvesExtendsRecursively() + { + $jarJar = array('type' => 'string', 'default' => 'Mesa address tha senate!', 'description' => 'a'); + $anakin = array('type' => 'array', 'items' => array('extends' => 'JarJar', 'description' => 'b')); + $description = new ServiceDescription(array( + 'models' => array('JarJar' => $jarJar, 'Anakin' => $anakin) + )); + // Description attribute will be updated, and format added + $p = new Parameter(array('extends' => 'Anakin', 'format' => 'date'), $description); + $this->assertEquals(array( + 'type' => 'array', + 'format' => 'date', + 'items' => array( + 'type' => 'string', + 'default' => 'Mesa address tha senate!', + 'description' => 'b' + ) + ), $p->toArray()); + } + + public function testHasKeyMethod() + { + $p = new Parameter(array('name' => 'foo', 'sentAs' => 'bar')); + $this->assertEquals('bar', $p->getWireName()); + $p->setSentAs(null); + $this->assertEquals('foo', $p->getWireName()); + } + + public function testIncludesNameInToArrayWhenItemsAttributeHasName() + { + $p = new Parameter(array( + 'type' => 'array', + 'name' => 'Abc', + 'items' => array( + 'name' => 'Foo', + 'type' => 'object' + ) + )); + $result = $p->toArray(); + $this->assertEquals(array( + 'type' => 'array', + 'items' => array( + 'name' => 'Foo', + 'type' => 'object', + 'additionalProperties' => true + ) + ), $result); + } + + public function dateTimeProvider() + { + $d = 'October 13, 2012 16:15:46 UTC'; + + return array( + array($d, 'date-time', '2012-10-13T16:15:46Z'), + array($d, 'date', '2012-10-13'), + array($d, 'timestamp', strtotime($d)), + array(new \DateTime($d), 'timestamp', strtotime($d)) + ); + } + + /** + * @dataProvider dateTimeProvider + */ + public function testAppliesFormat($d, $format, $result) + { + $p = new Parameter(); + $p->setFormat($format); + $this->assertEquals($format, $p->getFormat()); + $this->assertEquals($result, $p->filter($d)); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Description/SchemaFormatterTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Description/SchemaFormatterTest.php new file mode 100644 index 0000000..eb3619b --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Description/SchemaFormatterTest.php @@ -0,0 +1,61 @@ +assertEquals($result, SchemaFormatter::format($format, $value)); + } + + /** + * @expectedException \Guzzle\Common\Exception\InvalidArgumentException + */ + public function testValidatesDateTimeInput() + { + SchemaFormatter::format('date-time', false); + } + + public function testEnsuresTimestampsAreIntegers() + { + $t = time(); + $result = SchemaFormatter::format('timestamp', $t); + $this->assertSame($t, $result); + $this->assertInternalType('int', $result); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Description/SchemaValidatorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Description/SchemaValidatorTest.php new file mode 100644 index 0000000..4d6cc87 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Description/SchemaValidatorTest.php @@ -0,0 +1,326 @@ +validator = new SchemaValidator(); + } + + public function testValidatesArrayListsAreNumericallyIndexed() + { + $value = array(array(1)); + $this->assertFalse($this->validator->validate($this->getComplexParam(), $value)); + $this->assertEquals( + array('[Foo][0] must be an array of properties. Got a numerically indexed array.'), + $this->validator->getErrors() + ); + } + + public function testValidatesArrayListsContainProperItems() + { + $value = array(true); + $this->assertFalse($this->validator->validate($this->getComplexParam(), $value)); + $this->assertEquals( + array('[Foo][0] must be of type object'), + $this->validator->getErrors() + ); + } + + public function testAddsDefaultValuesInLists() + { + $value = array(array()); + $this->assertTrue($this->validator->validate($this->getComplexParam(), $value)); + $this->assertEquals(array(array('Bar' => true)), $value); + } + + public function testMergesDefaultValuesInLists() + { + $value = array( + array('Baz' => 'hello!'), + array('Bar' => false) + ); + $this->assertTrue($this->validator->validate($this->getComplexParam(), $value)); + $this->assertEquals(array( + array( + 'Baz' => 'hello!', + 'Bar' => true + ), + array('Bar' => false) + ), $value); + } + + public function testCorrectlyConvertsParametersToArrayWhenArraysArePresent() + { + $param = $this->getComplexParam(); + $result = $param->toArray(); + $this->assertInternalType('array', $result['items']); + $this->assertEquals('array', $result['type']); + $this->assertInstanceOf('Guzzle\Service\Description\Parameter', $param->getItems()); + } + + public function testAllowsInstanceOf() + { + $p = new Parameter(array( + 'name' => 'foo', + 'type' => 'object', + 'instanceOf' => get_class($this) + )); + $this->assertTrue($this->validator->validate($p, $this)); + $this->assertFalse($this->validator->validate($p, $p)); + $this->assertEquals(array('[foo] must be an instance of ' . __CLASS__), $this->validator->getErrors()); + } + + public function testEnforcesInstanceOfOnlyWhenObject() + { + $p = new Parameter(array( + 'name' => 'foo', + 'type' => array('object', 'string'), + 'instanceOf' => get_class($this) + )); + $this->assertTrue($this->validator->validate($p, $this)); + $s = 'test'; + $this->assertTrue($this->validator->validate($p, $s)); + } + + public function testConvertsObjectsToArraysWhenToArrayInterface() + { + $o = $this->getMockBuilder('Guzzle\Common\ToArrayInterface') + ->setMethods(array('toArray')) + ->getMockForAbstractClass(); + $o->expects($this->once()) + ->method('toArray') + ->will($this->returnValue(array( + 'foo' => 'bar' + ))); + $p = new Parameter(array( + 'name' => 'test', + 'type' => 'object', + 'properties' => array( + 'foo' => array('required' => 'true') + ) + )); + $this->assertTrue($this->validator->validate($p, $o)); + } + + public function testMergesValidationErrorsInPropertiesWithParent() + { + $p = new Parameter(array( + 'name' => 'foo', + 'type' => 'object', + 'properties' => array( + 'bar' => array('type' => 'string', 'required' => true, 'description' => 'This is what it does'), + 'test' => array('type' => 'string', 'minLength' => 2, 'maxLength' => 5), + 'test2' => array('type' => 'string', 'minLength' => 2, 'maxLength' => 2), + 'test3' => array('type' => 'integer', 'minimum' => 100), + 'test4' => array('type' => 'integer', 'maximum' => 10), + 'test5' => array('type' => 'array', 'maxItems' => 2), + 'test6' => array('type' => 'string', 'enum' => array('a', 'bc')), + 'test7' => array('type' => 'string', 'pattern' => '/[0-9]+/'), + 'test8' => array('type' => 'number'), + 'baz' => array( + 'type' => 'array', + 'minItems' => 2, + 'required' => true, + "items" => array("type" => "string") + ) + ) + )); + + $value = array( + 'test' => 'a', + 'test2' => 'abc', + 'baz' => array(false), + 'test3' => 10, + 'test4' => 100, + 'test5' => array(1, 3, 4), + 'test6' => 'Foo', + 'test7' => 'abc', + 'test8' => 'abc' + ); + + $this->assertFalse($this->validator->validate($p, $value)); + $this->assertEquals(array ( + '[foo][bar] is a required string: This is what it does', + '[foo][baz] must contain 2 or more elements', + '[foo][baz][0] must be of type string', + '[foo][test2] length must be less than or equal to 2', + '[foo][test3] must be greater than or equal to 100', + '[foo][test4] must be less than or equal to 10', + '[foo][test5] must contain 2 or fewer elements', + '[foo][test6] must be one of "a" or "bc"', + '[foo][test7] must match the following regular expression: /[0-9]+/', + '[foo][test8] must be of type number', + '[foo][test] length must be greater than or equal to 2', + ), $this->validator->getErrors()); + } + + public function testHandlesNullValuesInArraysWithDefaults() + { + $p = new Parameter(array( + 'name' => 'foo', + 'type' => 'object', + 'required' => true, + 'properties' => array( + 'bar' => array( + 'type' => 'object', + 'required' => true, + 'properties' => array( + 'foo' => array('default' => 'hi') + ) + ) + ) + )); + $value = array(); + $this->assertTrue($this->validator->validate($p, $value)); + $this->assertEquals(array('bar' => array('foo' => 'hi')), $value); + } + + public function testFailsWhenNullValuesInArraysWithNoDefaults() + { + $p = new Parameter(array( + 'name' => 'foo', + 'type' => 'object', + 'required' => true, + 'properties' => array( + 'bar' => array( + 'type' => 'object', + 'required' => true, + 'properties' => array('foo' => array('type' => 'string')) + ) + ) + )); + $value = array(); + $this->assertFalse($this->validator->validate($p, $value)); + $this->assertEquals(array('[foo][bar] is a required object'), $this->validator->getErrors()); + } + + public function testChecksTypes() + { + $p = new SchemaValidator(); + $r = new \ReflectionMethod($p, 'determineType'); + $r->setAccessible(true); + $this->assertEquals('any', $r->invoke($p, 'any', 'hello')); + $this->assertEquals(false, $r->invoke($p, 'foo', 'foo')); + $this->assertEquals('string', $r->invoke($p, 'string', 'hello')); + $this->assertEquals(false, $r->invoke($p, 'string', false)); + $this->assertEquals('integer', $r->invoke($p, 'integer', 1)); + $this->assertEquals(false, $r->invoke($p, 'integer', 'abc')); + $this->assertEquals('numeric', $r->invoke($p, 'numeric', 1)); + $this->assertEquals('numeric', $r->invoke($p, 'numeric', '1')); + $this->assertEquals('number', $r->invoke($p, 'number', 1)); + $this->assertEquals('number', $r->invoke($p, 'number', '1')); + $this->assertEquals(false, $r->invoke($p, 'numeric', 'a')); + $this->assertEquals('boolean', $r->invoke($p, 'boolean', true)); + $this->assertEquals('boolean', $r->invoke($p, 'boolean', false)); + $this->assertEquals(false, $r->invoke($p, 'boolean', 'false')); + $this->assertEquals('null', $r->invoke($p, 'null', null)); + $this->assertEquals(false, $r->invoke($p, 'null', 'abc')); + $this->assertEquals('array', $r->invoke($p, 'array', array())); + $this->assertEquals(false, $r->invoke($p, 'array', 'foo')); + } + + public function testValidatesFalseAdditionalProperties() + { + $param = new Parameter(array( + 'name' => 'foo', + 'type' => 'object', + 'properties' => array('bar' => array('type' => 'string')), + 'additionalProperties' => false + )); + $value = array('test' => '123'); + $this->assertFalse($this->validator->validate($param, $value)); + $this->assertEquals(array('[foo][test] is not an allowed property'), $this->validator->getErrors()); + $value = array('bar' => '123'); + $this->assertTrue($this->validator->validate($param, $value)); + } + + public function testAllowsUndefinedAdditionalProperties() + { + $param = new Parameter(array( + 'name' => 'foo', + 'type' => 'object', + 'properties' => array('bar' => array('type' => 'string')) + )); + $value = array('test' => '123'); + $this->assertTrue($this->validator->validate($param, $value)); + } + + public function testValidatesAdditionalProperties() + { + $param = new Parameter(array( + 'name' => 'foo', + 'type' => 'object', + 'properties' => array('bar' => array('type' => 'string')), + 'additionalProperties' => array('type' => 'integer') + )); + $value = array('test' => 'foo'); + $this->assertFalse($this->validator->validate($param, $value)); + $this->assertEquals(array('[foo][test] must be of type integer'), $this->validator->getErrors()); + } + + public function testValidatesAdditionalPropertiesThatArrayArrays() + { + $param = new Parameter(array( + 'name' => 'foo', + 'type' => 'object', + 'additionalProperties' => array( + 'type' => 'array', + 'items' => array('type' => 'string') + ) + )); + $value = array('test' => array(true)); + $this->assertFalse($this->validator->validate($param, $value)); + $this->assertEquals(array('[foo][test][0] must be of type string'), $this->validator->getErrors()); + } + + public function testIntegersCastToStringWhenTypeMismatch() + { + $param = new Parameter(array('name' => 'test', 'type' => 'string')); + $value = 12; + $this->assertTrue($this->validator->validate($param, $value)); + $this->assertEquals('12', $value); + } + + public function testRequiredMessageIncludesType() + { + $param = new Parameter(array('name' => 'test', 'type' => array('string', 'boolean'), 'required' => true)); + $value = null; + $this->assertFalse($this->validator->validate($param, $value)); + $this->assertEquals(array('[test] is a required string or boolean'), $this->validator->getErrors()); + } + + protected function getComplexParam() + { + return new Parameter(array( + 'name' => 'Foo', + 'type' => 'array', + 'required' => true, + 'min' => 1, + 'items' => array( + 'type' => 'object', + 'properties' => array( + 'Baz' => array( + 'type' => 'string', + ), + 'Bar' => array( + 'required' => true, + 'type' => 'boolean', + 'default' => true + ) + ) + ) + )); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Description/ServiceDescriptionLoaderTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Description/ServiceDescriptionLoaderTest.php new file mode 100644 index 0000000..bbfd1d6 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Description/ServiceDescriptionLoaderTest.php @@ -0,0 +1,177 @@ + true, + 'baz' => array('bar'), + 'apiVersion' => '123', + 'operations' => array() + )); + + $this->assertEquals(true, $d->getData('foo')); + $this->assertEquals(array('bar'), $d->getData('baz')); + $this->assertEquals('123', $d->getApiVersion()); + } + + public function testAllowsDeepNestedInheritance() + { + $d = ServiceDescription::factory(array( + 'operations' => array( + 'abstract' => array( + 'httpMethod' => 'HEAD', + 'parameters' => array( + 'test' => array('type' => 'string', 'required' => true) + ) + ), + 'abstract2' => array('uri' => '/test', 'extends' => 'abstract'), + 'concrete' => array('extends' => 'abstract2'), + 'override' => array('extends' => 'abstract', 'httpMethod' => 'PUT'), + 'override2' => array('extends' => 'override', 'httpMethod' => 'POST', 'uri' => '/') + ) + )); + + $c = $d->getOperation('concrete'); + $this->assertEquals('/test', $c->getUri()); + $this->assertEquals('HEAD', $c->getHttpMethod()); + $params = $c->getParams(); + $param = $params['test']; + $this->assertEquals('string', $param->getType()); + $this->assertTrue($param->getRequired()); + + // Ensure that merging HTTP method does not make an array + $this->assertEquals('PUT', $d->getOperation('override')->getHttpMethod()); + $this->assertEquals('POST', $d->getOperation('override2')->getHttpMethod()); + $this->assertEquals('/', $d->getOperation('override2')->getUri()); + } + + /** + * @expectedException RuntimeException + */ + public function testThrowsExceptionWhenExtendingMissingCommand() + { + ServiceDescription::factory(array( + 'operations' => array( + 'concrete' => array( + 'extends' => 'missing' + ) + ) + )); + } + + public function testAllowsMultipleInheritance() + { + $description = ServiceDescription::factory(array( + 'operations' => array( + 'a' => array( + 'httpMethod' => 'GET', + 'parameters' => array( + 'a1' => array( + 'default' => 'foo', + 'required' => true, + 'prepend' => 'hi' + ) + ) + ), + 'b' => array( + 'extends' => 'a', + 'parameters' => array( + 'b2' => array() + ) + ), + 'c' => array( + 'parameters' => array( + 'a1' => array( + 'default' => 'bar', + 'required' => true, + 'description' => 'test' + ), + 'c3' => array() + ) + ), + 'd' => array( + 'httpMethod' => 'DELETE', + 'extends' => array('b', 'c'), + 'parameters' => array( + 'test' => array() + ) + ) + ) + )); + + $command = $description->getOperation('d'); + $this->assertEquals('DELETE', $command->getHttpMethod()); + $this->assertContains('a1', $command->getParamNames()); + $this->assertContains('b2', $command->getParamNames()); + $this->assertContains('c3', $command->getParamNames()); + $this->assertContains('test', $command->getParamNames()); + + $this->assertTrue($command->getParam('a1')->getRequired()); + $this->assertEquals('bar', $command->getParam('a1')->getDefault()); + $this->assertEquals('test', $command->getParam('a1')->getDescription()); + } + + public function testAddsOtherFields() + { + $description = ServiceDescription::factory(array( + 'operations' => array(), + 'description' => 'Foo', + 'apiVersion' => 'bar' + )); + $this->assertEquals('Foo', $description->getDescription()); + $this->assertEquals('bar', $description->getApiVersion()); + } + + public function testCanLoadNestedExtends() + { + $description = ServiceDescription::factory(array( + 'operations' => array( + 'root' => array( + 'class' => 'foo' + ), + 'foo' => array( + 'extends' => 'root', + 'parameters' => array( + 'baz' => array('type' => 'string') + ) + ), + 'foo_2' => array( + 'extends' => 'foo', + 'parameters' => array( + 'bar' => array('type' => 'string') + ) + ), + 'foo_3' => array( + 'class' => 'bar', + 'parameters' => array( + 'bar2' => array('type' => 'string') + ) + ), + 'foo_4' => array( + 'extends' => array('foo_2', 'foo_3'), + 'parameters' => array( + 'bar3' => array('type' => 'string') + ) + ) + ) + )); + + $this->assertTrue($description->hasOperation('foo_4')); + $foo4 = $description->getOperation('foo_4'); + $this->assertTrue($foo4->hasParam('baz')); + $this->assertTrue($foo4->hasParam('bar')); + $this->assertTrue($foo4->hasParam('bar2')); + $this->assertTrue($foo4->hasParam('bar3')); + $this->assertEquals('bar', $foo4->getClass()); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Description/ServiceDescriptionTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Description/ServiceDescriptionTest.php new file mode 100644 index 0000000..ff25452 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Description/ServiceDescriptionTest.php @@ -0,0 +1,240 @@ +serviceData = array( + 'test_command' => new Operation(array( + 'name' => 'test_command', + 'description' => 'documentationForCommand', + 'httpMethod' => 'DELETE', + 'class' => 'Guzzle\\Tests\\Service\\Mock\\Command\\MockCommand', + 'parameters' => array( + 'bucket' => array('required' => true), + 'key' => array('required' => true) + ) + )) + ); + } + + /** + * @covers Guzzle\Service\Description\ServiceDescription::factory + * @covers Guzzle\Service\Description\ServiceDescriptionLoader::build + */ + public function testFactoryDelegatesToConcreteFactories() + { + $jsonFile = __DIR__ . '/../../TestData/test_service.json'; + $this->assertInstanceOf('Guzzle\Service\Description\ServiceDescription', ServiceDescription::factory($jsonFile)); + } + + public function testConstructor() + { + $service = new ServiceDescription(array('operations' => $this->serviceData)); + $this->assertEquals(1, count($service->getOperations())); + $this->assertFalse($service->hasOperation('foobar')); + $this->assertTrue($service->hasOperation('test_command')); + } + + public function testIsSerializable() + { + $service = new ServiceDescription(array('operations' => $this->serviceData)); + $data = serialize($service); + $d2 = unserialize($data); + $this->assertEquals(serialize($service), serialize($d2)); + } + + public function testSerializesParameters() + { + $service = new ServiceDescription(array( + 'operations' => array( + 'foo' => new Operation(array('parameters' => array('foo' => array('type' => 'string')))) + ) + )); + $serialized = serialize($service); + $this->assertContains('"parameters":{"foo":', $serialized); + $service = unserialize($serialized); + $this->assertTrue($service->getOperation('foo')->hasParam('foo')); + } + + public function testAllowsForJsonBasedArrayParamsFunctionalTest() + { + $description = new ServiceDescription(array( + 'operations' => array( + 'test' => new Operation(array( + 'httpMethod' => 'PUT', + 'parameters' => array( + 'data' => array( + 'required' => true, + 'filters' => 'json_encode', + 'location' => 'body' + ) + ) + )) + ) + )); + $client = new Client(); + $client->setDescription($description); + $command = $client->getCommand('test', array( + 'data' => array( + 'foo' => 'bar' + ) + )); + + $request = $command->prepare(); + $this->assertEquals('{"foo":"bar"}', (string) $request->getBody()); + } + + public function testContainsModels() + { + $d = new ServiceDescription(array( + 'operations' => array('foo' => array()), + 'models' => array( + 'Tag' => array('type' => 'object'), + 'Person' => array('type' => 'object') + ) + )); + $this->assertTrue($d->hasModel('Tag')); + $this->assertTrue($d->hasModel('Person')); + $this->assertFalse($d->hasModel('Foo')); + $this->assertInstanceOf('Guzzle\Service\Description\Parameter', $d->getModel('Tag')); + $this->assertNull($d->getModel('Foo')); + $this->assertContains('"models":{', serialize($d)); + $this->assertEquals(array('Tag', 'Person'), array_keys($d->getModels())); + } + + public function testCanAddModels() + { + $d = new ServiceDescription(array()); + $this->assertFalse($d->hasModel('Foo')); + $d->addModel(new Parameter(array('name' => 'Foo'))); + $this->assertTrue($d->hasModel('Foo')); + } + + public function testHasAttributes() + { + $d = new ServiceDescription(array( + 'operations' => array(), + 'name' => 'Name', + 'description' => 'Description', + 'apiVersion' => '1.24' + )); + + $this->assertEquals('Name', $d->getName()); + $this->assertEquals('Description', $d->getDescription()); + $this->assertEquals('1.24', $d->getApiVersion()); + + $s = serialize($d); + $this->assertContains('"name":"Name"', $s); + $this->assertContains('"description":"Description"', $s); + $this->assertContains('"apiVersion":"1.24"', $s); + + $d = unserialize($s); + $this->assertEquals('Name', $d->getName()); + $this->assertEquals('Description', $d->getDescription()); + $this->assertEquals('1.24', $d->getApiVersion()); + } + + public function testPersistsCustomAttributes() + { + $data = array( + 'operations' => array('foo' => array('class' => 'foo', 'parameters' => array())), + 'name' => 'Name', + 'description' => 'Test', + 'apiVersion' => '1.24', + 'auth' => 'foo', + 'keyParam' => 'bar' + ); + $d = new ServiceDescription($data); + $d->setData('hello', 'baz'); + $this->assertEquals('foo', $d->getData('auth')); + $this->assertEquals('baz', $d->getData('hello')); + $this->assertEquals('bar', $d->getData('keyParam')); + // responseClass and responseType are added by default + $data['operations']['foo']['responseClass'] = 'array'; + $data['operations']['foo']['responseType'] = 'primitive'; + $this->assertEquals($data + array('hello' => 'baz'), json_decode($d->serialize(), true)); + } + + public function testHasToArray() + { + $data = array( + 'operations' => array(), + 'name' => 'Name', + 'description' => 'Test' + ); + $d = new ServiceDescription($data); + $arr = $d->toArray(); + $this->assertEquals('Name', $arr['name']); + $this->assertEquals('Test', $arr['description']); + } + + public function testReturnsNullWhenRetrievingMissingOperation() + { + $s = new ServiceDescription(array()); + $this->assertNull($s->getOperation('foo')); + } + + public function testCanAddOperations() + { + $s = new ServiceDescription(array()); + $this->assertFalse($s->hasOperation('Foo')); + $s->addOperation(new Operation(array('name' => 'Foo'))); + $this->assertTrue($s->hasOperation('Foo')); + } + + /** + * @expectedException Guzzle\Common\Exception\InvalidArgumentException + */ + public function testValidatesOperationTypes() + { + $s = new ServiceDescription(array( + 'operations' => array('foo' => new \stdClass()) + )); + } + + public function testHasBaseUrl() + { + $description = new ServiceDescription(array('baseUrl' => 'http://foo.com')); + $this->assertEquals('http://foo.com', $description->getBaseUrl()); + $description->setBaseUrl('http://foobar.com'); + $this->assertEquals('http://foobar.com', $description->getBaseUrl()); + } + + public function testCanUseBasePath() + { + $description = new ServiceDescription(array('basePath' => 'http://foo.com')); + $this->assertEquals('http://foo.com', $description->getBaseUrl()); + } + + public function testModelsHaveNames() + { + $desc = array( + 'models' => array( + 'date' => array('type' => 'string'), + 'user'=> array( + 'type' => 'object', + 'properties' => array( + 'dob' => array('$ref' => 'date') + ) + ) + ) + ); + + $s = ServiceDescription::factory($desc); + $this->assertEquals('date', $s->getModel('date')->getName()); + $this->assertEquals('dob', $s->getModel('user')->getProperty('dob')->getName()); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Exception/CommandTransferExceptionTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Exception/CommandTransferExceptionTest.php new file mode 100644 index 0000000..be0d4ac --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Exception/CommandTransferExceptionTest.php @@ -0,0 +1,66 @@ +addSuccessfulCommand($c1)->addFailedCommand($c2); + $this->assertSame(array($c1), $e->getSuccessfulCommands()); + $this->assertSame(array($c2), $e->getFailedCommands()); + $this->assertSame(array($c1, $c2), $e->getAllCommands()); + } + + public function testConvertsMultiExceptionIntoCommandTransfer() + { + $r1 = new Request('GET', 'http://foo.com'); + $r2 = new Request('GET', 'http://foobaz.com'); + $e = new MultiTransferException('Test', 123); + $e->addSuccessfulRequest($r1)->addFailedRequest($r2); + $ce = CommandTransferException::fromMultiTransferException($e); + + $this->assertInstanceOf('Guzzle\Service\Exception\CommandTransferException', $ce); + $this->assertEquals('Test', $ce->getMessage()); + $this->assertEquals(123, $ce->getCode()); + $this->assertSame(array($r1), $ce->getSuccessfulRequests()); + $this->assertSame(array($r2), $ce->getFailedRequests()); + } + + public function testCanRetrieveExceptionForCommand() + { + $r1 = new Request('GET', 'http://foo.com'); + $e1 = new \Exception('foo'); + $c1 = $this->getMockBuilder('Guzzle\Tests\Service\Mock\Command\MockCommand') + ->setMethods(array('getRequest')) + ->getMock(); + $c1->expects($this->once())->method('getRequest')->will($this->returnValue($r1)); + + $e = new MultiTransferException('Test', 123); + $e->addFailedRequestWithException($r1, $e1); + $ce = CommandTransferException::fromMultiTransferException($e); + $ce->addFailedCommand($c1); + + $this->assertSame($e1, $ce->getExceptionForFailedCommand($c1)); + } + + public function testAddsNonRequestExceptions() + { + $e = new MultiTransferException(); + $e->add(new \Exception('bar')); + $e->addFailedRequestWithException(new Request('GET', 'http://www.foo.com'), new \Exception('foo')); + $ce = CommandTransferException::fromMultiTransferException($e); + $this->assertEquals(2, count($ce)); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Exception/InconsistentClientTransferExceptionTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Exception/InconsistentClientTransferExceptionTest.php new file mode 100644 index 0000000..6455295 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Exception/InconsistentClientTransferExceptionTest.php @@ -0,0 +1,15 @@ +assertEquals($items, $e->getCommands()); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Exception/ValidationExceptionTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Exception/ValidationExceptionTest.php new file mode 100644 index 0000000..ef789d8 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Exception/ValidationExceptionTest.php @@ -0,0 +1,17 @@ +setErrors($errors); + $this->assertEquals($errors, $e->getErrors()); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Mock/Command/IterableCommand.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Mock/Command/IterableCommand.php new file mode 100644 index 0000000..4ab423e --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Mock/Command/IterableCommand.php @@ -0,0 +1,31 @@ + 'iterable_command', + 'parameters' => array( + 'page_size' => array('type' => 'integer'), + 'next_token' => array('type' => 'string') + ) + )); + } + + protected function build() + { + $this->request = $this->client->createRequest('GET'); + + // Add the next token and page size query string values + $this->request->getQuery()->set('next_token', $this->get('next_token')); + + if ($this->get('page_size')) { + $this->request->getQuery()->set('page_size', $this->get('page_size')); + } + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Mock/Command/MockCommand.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Mock/Command/MockCommand.php new file mode 100644 index 0000000..831a7e7 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Mock/Command/MockCommand.php @@ -0,0 +1,32 @@ + get_called_class() == __CLASS__ ? 'mock_command' : 'sub.sub', + 'httpMethod' => 'POST', + 'parameters' => array( + 'test' => array( + 'default' => 123, + 'required' => true, + 'doc' => 'Test argument' + ), + '_internal' => array( + 'default' => 'abc' + ), + 'foo' => array('filters' => array('strtoupper')) + ) + )); + } + + protected function build() + { + $this->request = $this->client->createRequest(); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Mock/Command/OtherCommand.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Mock/Command/OtherCommand.php new file mode 100644 index 0000000..72ae1f6 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Mock/Command/OtherCommand.php @@ -0,0 +1,30 @@ + 'other_command', + 'parameters' => array( + 'test' => array( + 'default' => '123', + 'required' => true, + 'doc' => 'Test argument' + ), + 'other' => array(), + 'arg' => array('type' => 'string'), + 'static' => array('static' => true, 'default' => 'this is static') + ) + )); + } + + protected function build() + { + $this->request = $this->client->getRequest('HEAD'); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Mock/Command/Sub/Sub.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Mock/Command/Sub/Sub.php new file mode 100644 index 0000000..d348480 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Mock/Command/Sub/Sub.php @@ -0,0 +1,7 @@ + '{scheme}://127.0.0.1:8124/{api_version}/{subdomain}', + 'scheme' => 'http', + 'api_version' => 'v1' + ), array('username', 'password', 'subdomain')); + + return new self($config->get('base_url'), $config); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Mock/Model/MockCommandIterator.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Mock/Model/MockCommandIterator.php new file mode 100644 index 0000000..8faf412 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Mock/Model/MockCommandIterator.php @@ -0,0 +1,42 @@ +nextToken) { + $this->command->set('next_token', $this->nextToken); + } + + $this->command->set('page_size', (int) $this->calculatePageSize()); + $this->command->execute(); + + $data = json_decode($this->command->getResponse()->getBody(true), true); + + $this->nextToken = $data['next_token']; + + return $data['resources']; + } + + public function next() + { + $this->calledNext++; + parent::next(); + } + + public function getResources() + { + return $this->resources; + } + + public function getIteratedCount() + { + return $this->iteratedCount; + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Resource/CompositeResourceIteratorFactoryTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Resource/CompositeResourceIteratorFactoryTest.php new file mode 100644 index 0000000..41c2073 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Resource/CompositeResourceIteratorFactoryTest.php @@ -0,0 +1,37 @@ +assertFalse($factory->canBuild($cmd)); + $factory->build($cmd); + } + + public function testBuildsResourceIterators() + { + $f1 = new ResourceIteratorClassFactory('Guzzle\Tests\Service\Mock\Model'); + $factory = new CompositeResourceIteratorFactory(array()); + $factory->addFactory($f1); + $command = new MockCommand(); + $iterator = $factory->build($command, array('client.namespace' => 'Guzzle\Tests\Service\Mock')); + $this->assertInstanceOf('Guzzle\Tests\Service\Mock\Model\MockCommandIterator', $iterator); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Resource/MapResourceIteratorFactoryTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Resource/MapResourceIteratorFactoryTest.php new file mode 100644 index 0000000..d166e92 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Resource/MapResourceIteratorFactoryTest.php @@ -0,0 +1,40 @@ +build(new MockCommand()); + } + + public function testBuildsResourceIterators() + { + $factory = new MapResourceIteratorFactory(array( + 'mock_command' => 'Guzzle\Tests\Service\Mock\Model\MockCommandIterator' + )); + $iterator = $factory->build(new MockCommand()); + $this->assertInstanceOf('Guzzle\Tests\Service\Mock\Model\MockCommandIterator', $iterator); + } + + public function testUsesWildcardMappings() + { + $factory = new MapResourceIteratorFactory(array( + '*' => 'Guzzle\Tests\Service\Mock\Model\MockCommandIterator' + )); + $iterator = $factory->build(new MockCommand()); + $this->assertInstanceOf('Guzzle\Tests\Service\Mock\Model\MockCommandIterator', $iterator); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Resource/ModelTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Resource/ModelTest.php new file mode 100644 index 0000000..7214133 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Resource/ModelTest.php @@ -0,0 +1,65 @@ + 'object')); + $model = new Model(array('foo' => 'bar'), $param); + $this->assertSame($param, $model->getStructure()); + $this->assertEquals('bar', $model->get('foo')); + $this->assertEquals('bar', $model['foo']); + } + + public function testCanBeUsedWithoutStructure() + { + $model = new Model(array( + 'Foo' => 'baz', + 'Bar' => array( + 'Boo' => 'Bam' + ) + )); + $transform = function ($key, $value) { + return ($value && is_array($value)) ? new Collection($value) : $value; + }; + $model = $model->map($transform); + $this->assertInstanceOf('Guzzle\Common\Collection', $model->getPath('Bar')); + } + + public function testAllowsFiltering() + { + $model = new Model(array( + 'Foo' => 'baz', + 'Bar' => 'a' + )); + $model = $model->filter(function ($i, $v) { + return $v[0] == 'a'; + }); + $this->assertEquals(array('Bar' => 'a'), $model->toArray()); + } + + public function testDoesNotIncludeEmptyStructureInString() + { + $model = new Model(array('Foo' => 'baz')); + $str = (string) $model; + $this->assertContains('Debug output of model', $str); + $this->assertNotContains('Model structure', $str); + } + + public function testDoesIncludeModelStructureInString() + { + $model = new Model(array('Foo' => 'baz'), new Parameter(array('name' => 'Foo'))); + $str = (string) $model; + $this->assertContains('Debug output of Foo model', $str); + $this->assertContains('Model structure', $str); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Resource/ResourceIteratorClassFactoryTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Resource/ResourceIteratorClassFactoryTest.php new file mode 100644 index 0000000..7b061b5 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Resource/ResourceIteratorClassFactoryTest.php @@ -0,0 +1,41 @@ +registerNamespace('Baz'); + $command = new MockCommand(); + $factory->build($command); + } + + public function testBuildsResourceIterators() + { + $factory = new ResourceIteratorClassFactory('Guzzle\Tests\Service\Mock\Model'); + $command = new MockCommand(); + $iterator = $factory->build($command, array('client.namespace' => 'Guzzle\Tests\Service\Mock')); + $this->assertInstanceOf('Guzzle\Tests\Service\Mock\Model\MockCommandIterator', $iterator); + } + + public function testChecksIfCanBuild() + { + $factory = new ResourceIteratorClassFactory('Guzzle\Tests\Service'); + $this->assertFalse($factory->canBuild(new MockCommand())); + $factory = new ResourceIteratorClassFactory('Guzzle\Tests\Service\Mock\Model'); + $this->assertTrue($factory->canBuild(new MockCommand())); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Resource/ResourceIteratorTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Resource/ResourceIteratorTest.php new file mode 100644 index 0000000..573fb6d --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Service/Resource/ResourceIteratorTest.php @@ -0,0 +1,184 @@ +assertInternalType('array', ResourceIterator::getAllEvents()); + } + + public function testConstructorConfiguresDefaults() + { + $ri = $this->getMockForAbstractClass('Guzzle\\Service\\Resource\\ResourceIterator', array( + $this->getServiceBuilder()->get('mock')->getCommand('iterable_command'), + array( + 'limit' => 10, + 'page_size' => 3 + ) + ), 'MockIterator'); + + $this->assertEquals(false, $ri->getNextToken()); + $this->assertEquals(false, $ri->current()); + } + + public function testSendsRequestsForNextSetOfResources() + { + // Queue up an array of responses for iterating + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 200 OK\r\nContent-Length: 52\r\n\r\n{ \"next_token\": \"g\", \"resources\": [\"d\", \"e\", \"f\"] }", + "HTTP/1.1 200 OK\r\nContent-Length: 52\r\n\r\n{ \"next_token\": \"j\", \"resources\": [\"g\", \"h\", \"i\"] }", + "HTTP/1.1 200 OK\r\nContent-Length: 41\r\n\r\n{ \"next_token\": \"\", \"resources\": [\"j\"] }" + )); + + // Create a new resource iterator using the IterableCommand mock + $ri = new MockCommandIterator($this->getServiceBuilder()->get('mock')->getCommand('iterable_command'), array( + 'page_size' => 3 + )); + + // Ensure that no requests have been sent yet + $this->assertEquals(0, count($this->getServer()->getReceivedRequests(false))); + + //$this->assertEquals(array('d', 'e', 'f', 'g', 'h', 'i', 'j'), $ri->toArray()); + $ri->toArray(); + $requests = $this->getServer()->getReceivedRequests(true); + $this->assertEquals(3, count($requests)); + + $this->assertEquals(3, $requests[0]->getQuery()->get('page_size')); + $this->assertEquals(3, $requests[1]->getQuery()->get('page_size')); + $this->assertEquals(3, $requests[2]->getQuery()->get('page_size')); + + // Reset and resend + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 200 OK\r\nContent-Length: 52\r\n\r\n{ \"next_token\": \"g\", \"resources\": [\"d\", \"e\", \"f\"] }", + "HTTP/1.1 200 OK\r\nContent-Length: 52\r\n\r\n{ \"next_token\": \"j\", \"resources\": [\"g\", \"h\", \"i\"] }", + "HTTP/1.1 200 OK\r\nContent-Length: 41\r\n\r\n{ \"next_token\": \"\", \"resources\": [\"j\"] }", + )); + + $d = array(); + foreach ($ri as $data) { + $d[] = $data; + } + $this->assertEquals(array('d', 'e', 'f', 'g', 'h', 'i', 'j'), $d); + } + + public function testCalculatesPageSize() + { + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 200 OK\r\nContent-Length: 52\r\n\r\n{ \"next_token\": \"g\", \"resources\": [\"d\", \"e\", \"f\"] }", + "HTTP/1.1 200 OK\r\nContent-Length: 52\r\n\r\n{ \"next_token\": \"j\", \"resources\": [\"g\", \"h\", \"i\"] }", + "HTTP/1.1 200 OK\r\nContent-Length: 52\r\n\r\n{ \"next_token\": \"j\", \"resources\": [\"j\", \"k\"] }" + )); + + $ri = new MockCommandIterator($this->getServiceBuilder()->get('mock')->getCommand('iterable_command'), array( + 'page_size' => 3, + 'limit' => 7 + )); + + $this->assertEquals(array('d', 'e', 'f', 'g', 'h', 'i', 'j'), $ri->toArray()); + $requests = $this->getServer()->getReceivedRequests(true); + $this->assertEquals(3, count($requests)); + $this->assertEquals(3, $requests[0]->getQuery()->get('page_size')); + $this->assertEquals(3, $requests[1]->getQuery()->get('page_size')); + $this->assertEquals(1, $requests[2]->getQuery()->get('page_size')); + } + + public function testUseAsArray() + { + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 200 OK\r\nContent-Length: 52\r\n\r\n{ \"next_token\": \"g\", \"resources\": [\"d\", \"e\", \"f\"] }", + "HTTP/1.1 200 OK\r\nContent-Length: 52\r\n\r\n{ \"next_token\": \"\", \"resources\": [\"g\", \"h\", \"i\"] }" + )); + + $ri = new MockCommandIterator($this->getServiceBuilder()->get('mock')->getCommand('iterable_command')); + + // Ensure that the key is never < 0 + $this->assertEquals(0, $ri->key()); + $this->assertEquals(0, count($ri)); + + // Ensure that the iterator can be used as KVP array + $data = array(); + foreach ($ri as $key => $value) { + $data[$key] = $value; + } + + // Ensure that the iterate is countable + $this->assertEquals(6, count($ri)); + $this->assertEquals(array('d', 'e', 'f', 'g', 'h', 'i'), $data); + } + + public function testBailsWhenSendReturnsNoResults() + { + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 200 OK\r\n\r\n{ \"next_token\": \"g\", \"resources\": [\"d\", \"e\", \"f\"] }", + "HTTP/1.1 200 OK\r\n\r\n{ \"next_token\": \"\", \"resources\": [] }" + )); + + $ri = new MockCommandIterator($this->getServiceBuilder()->get('mock')->getCommand('iterable_command')); + + // Ensure that the iterator can be used as KVP array + $data = $ri->toArray(); + + // Ensure that the iterate is countable + $this->assertEquals(3, count($ri)); + $this->assertEquals(array('d', 'e', 'f'), $data); + + $this->assertEquals(2, $ri->getRequestCount()); + } + + public function testHoldsDataOptions() + { + $ri = new MockCommandIterator($this->getServiceBuilder()->get('mock')->getCommand('iterable_command')); + $this->assertNull($ri->get('foo')); + $this->assertSame($ri, $ri->set('foo', 'bar')); + $this->assertEquals('bar', $ri->get('foo')); + } + + public function testSettingLimitOrPageSizeClearsData() + { + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 200 OK\r\n\r\n{ \"next_token\": \"\", \"resources\": [\"d\", \"e\", \"f\"] }", + "HTTP/1.1 200 OK\r\n\r\n{ \"next_token\": \"\", \"resources\": [\"d\", \"e\", \"f\"] }", + "HTTP/1.1 200 OK\r\n\r\n{ \"next_token\": \"\", \"resources\": [\"d\", \"e\", \"f\"] }" + )); + + $ri = new MockCommandIterator($this->getServiceBuilder()->get('mock')->getCommand('iterable_command')); + $ri->toArray(); + $this->assertNotEmpty($this->readAttribute($ri, 'resources')); + + $ri->setLimit(10); + $this->assertEmpty($this->readAttribute($ri, 'resources')); + + $ri->toArray(); + $this->assertNotEmpty($this->readAttribute($ri, 'resources')); + $ri->setPageSize(10); + $this->assertEmpty($this->readAttribute($ri, 'resources')); + } + + public function testWorksWithCustomAppendIterator() + { + $this->getServer()->flush(); + $this->getServer()->enqueue(array( + "HTTP/1.1 200 OK\r\n\r\n{ \"next_token\": \"\", \"resources\": [\"d\", \"e\", \"f\"] }" + )); + $ri = new MockCommandIterator($this->getServiceBuilder()->get('mock')->getCommand('iterable_command')); + $a = new \Guzzle\Iterator\AppendIterator(); + $a->append($ri); + $results = iterator_to_array($a, false); + $this->assertEquals(4, $ri->calledNext); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Stream/PhpStreamRequestFactoryTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Stream/PhpStreamRequestFactoryTest.php new file mode 100644 index 0000000..083aaa0 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Stream/PhpStreamRequestFactoryTest.php @@ -0,0 +1,172 @@ +client = new Client($this->getServer()->getUrl()); + $this->factory = new PhpStreamRequestFactory(); + } + + public function testOpensValidStreamByCreatingContext() + { + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 2\r\n\r\nhi"); + $request = $this->client->get('/'); + $stream = $this->factory->fromRequest($request); + $this->assertEquals('hi', (string) $stream); + $headers = $this->factory->getLastResponseHeaders(); + $this->assertContains('HTTP/1.1 200 OK', $headers); + $this->assertContains('Content-Length: 2', $headers); + $this->assertSame($headers, $stream->getCustomData('response_headers')); + $this->assertEquals(2, $stream->getSize()); + } + + public function testOpensValidStreamByPassingContextAndMerging() + { + $request = $this->client->get('/'); + $this->factory = $this->getMockBuilder('Guzzle\Stream\PhpStreamRequestFactory') + ->setMethods(array('createContext', 'createStream')) + ->getMock(); + $this->factory->expects($this->never()) + ->method('createContext'); + $this->factory->expects($this->once()) + ->method('createStream') + ->will($this->returnValue(new Stream(fopen('php://temp', 'r')))); + + $context = array('http' => array('method' => 'HEAD', 'ignore_errors' => false)); + $this->factory->fromRequest($request, stream_context_create($context)); + $options = stream_context_get_options($this->readAttribute($this->factory, 'context')); + $this->assertEquals('HEAD', $options['http']['method']); + $this->assertFalse($options['http']['ignore_errors']); + $this->assertEquals('1.1', $options['http']['protocol_version']); + } + + public function testAppliesProxySettings() + { + $request = $this->client->get('/'); + $request->getCurlOptions()->set(CURLOPT_PROXY, 'tcp://foo.com'); + $this->factory = $this->getMockBuilder('Guzzle\Stream\PhpStreamRequestFactory') + ->setMethods(array('createStream')) + ->getMock(); + $this->factory->expects($this->once()) + ->method('createStream') + ->will($this->returnValue(new Stream(fopen('php://temp', 'r')))); + $this->factory->fromRequest($request); + $options = stream_context_get_options($this->readAttribute($this->factory, 'context')); + $this->assertEquals('tcp://foo.com', $options['http']['proxy']); + } + + public function testAddsPostFields() + { + $this->getServer()->flush(); + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 2\r\n\r\nhi"); + $request = $this->client->post('/', array('Foo' => 'Bar'), array('foo' => 'baz bar')); + $stream = $this->factory->fromRequest($request); + $this->assertEquals('hi', (string) $stream); + + $headers = $this->factory->getLastResponseHeaders(); + $this->assertContains('HTTP/1.1 200 OK', $headers); + $this->assertContains('Content-Length: 2', $headers); + $this->assertSame($headers, $stream->getCustomData('response_headers')); + + $received = $this->getServer()->getReceivedRequests(); + $this->assertEquals(1, count($received)); + $this->assertContains('POST / HTTP/1.1', $received[0]); + $this->assertContains('host: ', $received[0]); + $this->assertContains('user-agent: Guzzle/', $received[0]); + $this->assertContains('foo: Bar', $received[0]); + $this->assertContains('content-length: 13', $received[0]); + $this->assertContains('foo=baz%20bar', $received[0]); + } + + public function testAddsBody() + { + $this->getServer()->flush(); + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 2\r\n\r\nhi"); + $request = $this->client->put('/', array('Foo' => 'Bar'), 'Testing...123'); + $stream = $this->factory->fromRequest($request); + $this->assertEquals('hi', (string) $stream); + + $headers = $this->factory->getLastResponseHeaders(); + $this->assertContains('HTTP/1.1 200 OK', $headers); + $this->assertContains('Content-Length: 2', $headers); + $this->assertSame($headers, $stream->getCustomData('response_headers')); + + $received = $this->getServer()->getReceivedRequests(); + $this->assertEquals(1, count($received)); + $this->assertContains('PUT / HTTP/1.1', $received[0]); + $this->assertContains('host: ', $received[0]); + $this->assertContains('user-agent: Guzzle/', $received[0]); + $this->assertContains('foo: Bar', $received[0]); + $this->assertContains('content-length: 13', $received[0]); + $this->assertContains('Testing...123', $received[0]); + } + + public function testCanDisableSslValidation() + { + $request = $this->client->get('/'); + $request->getCurlOptions()->set(CURLOPT_SSL_VERIFYPEER, false); + $this->factory = $this->getMockBuilder('Guzzle\Stream\PhpStreamRequestFactory') + ->setMethods(array('createStream')) + ->getMock(); + $this->factory->expects($this->once()) + ->method('createStream') + ->will($this->returnValue(new Stream(fopen('php://temp', 'r')))); + $this->factory->fromRequest($request); + $options = stream_context_get_options($this->readAttribute($this->factory, 'context')); + $this->assertFalse($options['ssl']['verify_peer']); + } + + public function testUsesSslValidationByDefault() + { + $request = $this->client->get('/'); + $this->factory = $this->getMockBuilder('Guzzle\Stream\PhpStreamRequestFactory') + ->setMethods(array('createStream')) + ->getMock(); + $this->factory->expects($this->once()) + ->method('createStream') + ->will($this->returnValue(new Stream(fopen('php://temp', 'r')))); + $this->factory->fromRequest($request); + $options = stream_context_get_options($this->readAttribute($this->factory, 'context')); + $this->assertTrue($options['ssl']['verify_peer']); + $this->assertSame($request->getCurlOptions()->get(CURLOPT_CAINFO), $options['ssl']['cafile']); + } + + public function testBasicAuthAddsUserAndPassToUrl() + { + $request = $this->client->get('/'); + $request->setAuth('Foo', 'Bar'); + $this->factory = $this->getMockBuilder('Guzzle\Stream\PhpStreamRequestFactory') + ->setMethods(array('createStream')) + ->getMock(); + $this->factory->expects($this->once()) + ->method('createStream') + ->will($this->returnValue(new Stream(fopen('php://temp', 'r')))); + $this->factory->fromRequest($request); + $this->assertContains('Foo:Bar@', (string) $this->readAttribute($this->factory, 'url')); + } + + public function testCanCreateCustomStreamClass() + { + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 2\r\n\r\nhi"); + $request = $this->client->get('/'); + $stream = $this->factory->fromRequest($request, array(), array('stream_class' => 'Guzzle\Http\EntityBody')); + $this->assertInstanceOf('Guzzle\Http\EntityBody', $stream); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/Stream/StreamTest.php b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Stream/StreamTest.php new file mode 100644 index 0000000..4858acc --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/Stream/StreamTest.php @@ -0,0 +1,189 @@ +assertEquals($handle, $stream->getStream()); + $this->assertTrue($stream->isReadable()); + $this->assertTrue($stream->isWritable()); + $this->assertTrue($stream->isLocal()); + $this->assertTrue($stream->isSeekable()); + $this->assertEquals('PHP', $stream->getWrapper()); + $this->assertEquals('TEMP', $stream->getStreamType()); + $this->assertEquals(4, $stream->getSize()); + $this->assertEquals('php://temp', $stream->getUri()); + $this->assertEquals(array(), $stream->getWrapperData()); + $this->assertFalse($stream->isConsumed()); + unset($stream); + } + + public function testCanModifyStream() + { + $handle1 = fopen('php://temp', 'r+'); + $handle2 = fopen('php://temp', 'r+'); + $stream = new Stream($handle1); + $this->assertSame($handle1, $stream->getStream()); + $stream->setStream($handle2, 10); + $this->assertEquals(10, $stream->getSize()); + $this->assertSame($handle2, $stream->getStream()); + } + + public function testStreamClosesHandleOnDestruct() + { + $handle = fopen('php://temp', 'r'); + $stream = new Stream($handle); + unset($stream); + $this->assertFalse(is_resource($handle)); + } + + public function testConvertsToString() + { + $handle = fopen('php://temp', 'w+'); + fwrite($handle, 'data'); + $stream = new Stream($handle); + $this->assertEquals('data', (string) $stream); + unset($stream); + + $handle = fopen(__DIR__ . '/../TestData/FileBody.txt', 'r'); + $stream = new Stream($handle); + $this->assertEquals('', (string) $stream); + unset($stream); + } + + public function testConvertsToStringAndRestoresCursorPos() + { + $handle = fopen('php://temp', 'w+'); + $stream = new Stream($handle); + $stream->write('foobazbar'); + $stream->seek(3); + $this->assertEquals('foobazbar', (string) $stream); + $this->assertEquals(3, $stream->ftell()); + } + + public function testIsConsumed() + { + $handle = fopen('php://temp', 'w+'); + fwrite($handle, 'data'); + $stream = new Stream($handle); + $this->assertFalse($stream->isConsumed()); + $stream->read(4); + $this->assertTrue($stream->isConsumed()); + } + + public function testAllowsSettingManualSize() + { + $handle = fopen('php://temp', 'w+'); + fwrite($handle, 'data'); + $stream = new Stream($handle); + $stream->setSize(10); + $this->assertEquals(10, $stream->getSize()); + unset($stream); + } + + public function testWrapsStream() + { + $handle = fopen('php://temp', 'w+'); + fwrite($handle, 'data'); + $stream = new Stream($handle); + $this->assertTrue($stream->isSeekable()); + $this->assertTrue($stream->isReadable()); + $this->assertTrue($stream->seek(0)); + $this->assertEquals('da', $stream->read(2)); + $this->assertEquals('ta', $stream->read(2)); + $this->assertTrue($stream->seek(0)); + $this->assertEquals('data', $stream->read(4)); + $stream->write('_appended'); + $stream->seek(0); + $this->assertEquals('data_appended', $stream->read(13)); + } + + public function testGetSize() + { + $size = filesize(__DIR__ . '/../../../bootstrap.php'); + $handle = fopen(__DIR__ . '/../../../bootstrap.php', 'r'); + $stream = new Stream($handle); + $this->assertEquals($handle, $stream->getStream()); + $this->assertEquals($size, $stream->getSize()); + $this->assertEquals($size, $stream->getSize()); + unset($stream); + + // Make sure that false is returned when the size cannot be determined + $this->getServer()->enqueue("HTTP/1.1 200 OK\r\nContent-Length: 0\r\n\r\n"); + $handle = fopen('http://localhost:' . $this->getServer()->getPort(), 'r'); + $stream = new Stream($handle); + $this->assertEquals(false, $stream->getSize()); + unset($stream); + } + + public function testEnsuresSizeIsConsistent() + { + $h = fopen('php://temp', 'r+'); + fwrite($h, 'foo'); + $stream = new Stream($h); + $this->assertEquals(3, $stream->getSize()); + $stream->write('test'); + $this->assertEquals(7, $stream->getSize()); + fclose($h); + } + + public function testAbstractsMetaData() + { + $handle = fopen(__DIR__ . '/../../../bootstrap.php', 'r'); + $stream = new Stream($handle); + $this->assertEquals('plainfile', $stream->getMetaData('wrapper_type')); + $this->assertEquals(null, $stream->getMetaData('wrapper_data')); + $this->assertInternalType('array', $stream->getMetaData()); + } + + public function testDoesNotAttemptToWriteToReadonlyStream() + { + $handle = fopen(__DIR__ . '/../../../bootstrap.php', 'r'); + $stream = new Stream($handle); + $this->assertEquals(0, $stream->write('foo')); + } + + public function testProvidesStreamPosition() + { + $handle = fopen(__DIR__ . '/../../../bootstrap.php', 'r'); + $stream = new Stream($handle); + $stream->read(2); + $this->assertSame(ftell($handle), $stream->ftell()); + $this->assertEquals(2, $stream->ftell()); + } + + public function testRewindIsSeekZero() + { + $stream = new Stream(fopen('php://temp', 'w+')); + $stream->write('foobazbar'); + $this->assertTrue($stream->rewind()); + $this->assertEquals('foobazbar', $stream->read(9)); + } + + public function testCanDetachStream() + { + $r = fopen('php://temp', 'w+'); + $stream = new Stream($r); + $stream->detachStream(); + $this->assertNull($stream->getStream()); + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/FileBody.txt b/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/FileBody.txt new file mode 100644 index 0000000..e69de29 diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/description/bar.json b/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/description/bar.json new file mode 100644 index 0000000..c354ed7 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/description/bar.json @@ -0,0 +1,3 @@ +{ + "includes": ["foo.json"] +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/description/baz.json b/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/description/baz.json new file mode 100644 index 0000000..765237b --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/description/baz.json @@ -0,0 +1,3 @@ +{ + "includes": ["foo.json", "bar.json"] +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/description/foo.json b/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/description/foo.json new file mode 100644 index 0000000..cee5005 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/description/foo.json @@ -0,0 +1,8 @@ +{ + "includes": ["recursive.json"], + "operations": { + "abstract": { + "httpMethod": "POST" + } + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/description/recursive.json b/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/description/recursive.json new file mode 100644 index 0000000..c354ed7 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/description/recursive.json @@ -0,0 +1,3 @@ +{ + "includes": ["foo.json"] +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/mock_response b/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/mock_response new file mode 100644 index 0000000..b6938a2 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/mock_response @@ -0,0 +1,3 @@ +HTTP/1.1 200 OK +Content-Length: 0 + diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/services/json1.json b/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/services/json1.json new file mode 100644 index 0000000..7b2a9da --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/services/json1.json @@ -0,0 +1,18 @@ +{ + "includes": [ "json2.json" ], + "services": { + "abstract": { + "access_key": "xyz", + "secret": "abc" + }, + "mock": { + "class": "Guzzle\\Tests\\Service\\Mock\\MockClient", + "extends": "abstract", + "params": { + "username": "foo", + "password": "baz", + "subdomain": "bar" + } + } + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/services/json2.json b/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/services/json2.json new file mode 100644 index 0000000..08e5566 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/services/json2.json @@ -0,0 +1,11 @@ +{ + "services": { + "foo": { + "class": "Guzzle\\Tests\\Service\\Mock\\MockClient", + "extends": "abstract", + "params": { + "baz": "bar" + } + } + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/services/services.json b/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/services/services.json new file mode 100644 index 0000000..25452e4 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/services/services.json @@ -0,0 +1,71 @@ +{ + "abstract": { + "access_key": "xyz", + "secret": "abc" + }, + "mock": { + "class": "Guzzle\\Tests\\Service\\Mock\\MockClient", + "extends": "abstract", + "params": { + "username": "foo", + "password": "baz", + "subdomain": "bar" + } + }, + + "test.abstract.aws": { + "params": { + "access_key": "12345", + "secret_key": "abcd" + } + }, + + "test.s3": { + "class": "Guzzle\\Service\\Aws\\S3Client", + "extends": "test.abstract.aws", + "params": { + "devpay_product_token": "", + "devpay_user_token": "" + } + }, + + "test.simple_db": { + "class": "Guzzle\\Service\\Aws\\SimpleDb\\SimpleDbClient", + "extends": "test.abstract.aws" + }, + + "test.sqs": { + "class": "Guzzle\\Service\\Aws\\Sqs\\SqsClient", + "extends": "test.abstract.aws" + }, + + "test.centinel": { + "class": "Guzzle\\Service\\CardinalCommerce\\Centinel.CentinelClient", + "params": { + "password": "test", + "processor_id": "123", + "merchant_id": "456" + } + }, + + "test.mws": { + "class": "Guzzle\\Service\\Mws\\MwsClient", + "extends": "test.abstract.aws", + "params": { + "merchant_id": "ABCDE", + "marketplace_id": "FGHIJ", + "application_name": "GuzzleTest", + "application_version": "0.1", + "base_url": "https://mws.amazonservices.com" + } + }, + + "mock": { + "class": "Guzzle\\Tests\\Service\\Mock\\MockClient", + "params": { + "username": "test_user", + "password": "****", + "subdomain": "test" + } + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/test_service.json b/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/test_service.json new file mode 100644 index 0000000..01557ca --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/test_service.json @@ -0,0 +1,40 @@ +{ + "includes": [ "test_service2.json" ], + "operations": { + "test": { + "uri": "/path" + }, + "concrete": { + "extends": "abstract" + }, + "foo_bar": { + "uri": "/testing", + "parameters": { + "other": { + "location": "json", + "location_key": "Other" + }, + "test": { + "type": "object", + "location": "json", + "properties": { + "baz": { + "type": "boolean", + "default": true + }, + "bar": { + "type": "string", + "filters": [ + { + "method": "strtolower", + "args": ["test", "@value"] + }, + "strtoupper" + ] + } + } + } + } + } + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/test_service2.json b/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/test_service2.json new file mode 100644 index 0000000..66dd9ef --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/test_service2.json @@ -0,0 +1,7 @@ +{ + "operations": { + "abstract": { + "uri": "/abstract" + } + } +} diff --git a/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/test_service_3.json b/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/test_service_3.json new file mode 100644 index 0000000..ae2ae0b --- /dev/null +++ b/vendor/guzzle/guzzle/tests/Guzzle/Tests/TestData/test_service_3.json @@ -0,0 +1,40 @@ +{ + "includes": [ "test_service2.json" ], + "operations": { + "test": { + "uri": "/path" + }, + "concrete": { + "extends": "abstract" + }, + "baz_qux": { + "uri": "/testing", + "parameters": { + "other": { + "location": "json", + "location_key": "Other" + }, + "test": { + "type": "object", + "location": "json", + "properties": { + "baz": { + "type": "boolean", + "default": true + }, + "bar": { + "type": "string", + "filters": [ + { + "method": "strtolower", + "args": ["test", "@value"] + }, + "strtoupper" + ] + } + } + } + } + } + } +} diff --git a/vendor/guzzle/guzzle/tests/bootstrap.php b/vendor/guzzle/guzzle/tests/bootstrap.php new file mode 100644 index 0000000..d5f8cb6 --- /dev/null +++ b/vendor/guzzle/guzzle/tests/bootstrap.php @@ -0,0 +1,10 @@ + + * + * 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->listeners[$eventName])) { + foreach ($this->listeners[$eventName] as $key => $l) { + foreach ($this->listenerIds[$eventName] as $i => $args) { + list($serviceId, $method, $priority) = $args; + if ($key === $serviceId.'.'.$method) { + if ($listener === array($l, $method)) { + unset($this->listeners[$eventName][$key]); + if (empty($this->listeners[$eventName])) { + unset($this->listeners[$eventName]); + } + unset($this->listenerIds[$eventName][$i]); + if (empty($this->listenerIds[$eventName])) { + unset($this->listenerIds[$eventName]); + } + } + } + } + } + } + + parent::removeListener($eventName, $listener); + } + + /** + * @see EventDispatcherInterface::hasListeners + */ + public function hasListeners($eventName = null) + { + if (null === $eventName) { + return (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/symfony/event-dispatcher/Symfony/Component/EventDispatcher/Debug/TraceableEventDispatcher.php b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/Debug/TraceableEventDispatcher.php new file mode 100644 index 0000000..410226b --- /dev/null +++ b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/Debug/TraceableEventDispatcher.php @@ -0,0 +1,317 @@ + + * + * 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)); + } + } + + private function postProcess($eventName) + { + $skipped = false; + foreach ($this->dispatcher->getListeners($eventName) as $listener) { + // 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/symfony/event-dispatcher/Symfony/Component/EventDispatcher/Debug/TraceableEventDispatcherInterface.php b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/Debug/TraceableEventDispatcherInterface.php new file mode 100644 index 0000000..5483e81 --- /dev/null +++ b/vendor/symfony/event-dispatcher/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/symfony/event-dispatcher/Symfony/Component/EventDispatcher/Debug/WrappedListener.php b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/Debug/WrappedListener.php new file mode 100644 index 0000000..c501662 --- /dev/null +++ b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/Debug/WrappedListener.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 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; + + public function __construct($listener, $name, Stopwatch $stopwatch) + { + $this->listener = $listener; + $this->name = $name; + $this->stopwatch = $stopwatch; + $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, $dispatcher); + + if ($e->isStarted()) { + $e->stop(); + } + + if ($event->isPropagationStopped()) { + $this->stoppedPropagation = true; + } + } +} diff --git a/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/DependencyInjection/RegisterListenersPass.php b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/DependencyInjection/RegisterListenersPass.php new file mode 100644 index 0000000..afe3ecd --- /dev/null +++ b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/DependencyInjection/RegisterListenersPass.php @@ -0,0 +1,106 @@ + + * + * 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)); + } + + // We must assume that the class value has been correctly filled, even if the service is created by a factory + $class = $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/symfony/event-dispatcher/Symfony/Component/EventDispatcher/Event.php b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/Event.php new file mode 100644 index 0000000..bf792a2 --- /dev/null +++ b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/Event.php @@ -0,0 +1,129 @@ + + * + * 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/symfony/event-dispatcher/Symfony/Component/EventDispatcher/EventDispatcher.php b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/EventDispatcher.php new file mode 100644 index 0000000..ab140a6 --- /dev/null +++ b/vendor/symfony/event-dispatcher/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 $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/symfony/event-dispatcher/Symfony/Component/EventDispatcher/EventDispatcherInterface.php b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/EventDispatcherInterface.php new file mode 100644 index 0000000..3fdbfd8 --- /dev/null +++ b/vendor/symfony/event-dispatcher/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|array $eventName The event(s) to remove a listener from + * @param callable $listener The listener to remove + */ + public function removeListener($eventName, $listener); + + /** + * Removes an event subscriber. + * + * @param EventSubscriberInterface $subscriber The subscriber + */ + public function removeSubscriber(EventSubscriberInterface $subscriber); + + /** + * Gets the listeners of a specific event or all listeners. + * + * @param string $eventName The name of the event + * + * @return array The event listeners for the specified event, or all event listeners by event name + */ + public function getListeners($eventName = null); + + /** + * Checks whether an event has any registered listeners. + * + * @param string $eventName The name of the event + * + * @return bool true if the specified event has any listeners, false otherwise + */ + public function hasListeners($eventName = null); +} diff --git a/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/EventSubscriberInterface.php b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/EventSubscriberInterface.php new file mode 100644 index 0000000..080f892 --- /dev/null +++ b/vendor/symfony/event-dispatcher/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/symfony/event-dispatcher/Symfony/Component/EventDispatcher/GenericEvent.php b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/GenericEvent.php new file mode 100644 index 0000000..1e8c44a --- /dev/null +++ b/vendor/symfony/event-dispatcher/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/symfony/event-dispatcher/Symfony/Component/EventDispatcher/ImmutableEventDispatcher.php b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/ImmutableEventDispatcher.php new file mode 100644 index 0000000..b70b81a --- /dev/null +++ b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/ImmutableEventDispatcher.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 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/symfony/event-dispatcher/Symfony/Component/EventDispatcher/LICENSE b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/LICENSE new file mode 100644 index 0000000..0b3292c --- /dev/null +++ b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/LICENSE @@ -0,0 +1,19 @@ +Copyright (c) 2004-2014 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/symfony/event-dispatcher/Symfony/Component/EventDispatcher/README.md b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/README.md new file mode 100644 index 0000000..22bf74f --- /dev/null +++ b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/README.md @@ -0,0 +1,25 @@ +EventDispatcher Component +========================= + +The Symfony2 EventDispatcher component implements the Mediator pattern in a +simple and effective way to make your projects truly extensible. + + use Symfony\Component\EventDispatcher\EventDispatcher; + use Symfony\Component\EventDispatcher\Event; + + $dispatcher = new EventDispatcher(); + + $dispatcher->addListener('event_name', function (Event $event) { + // ... + }); + + $dispatcher->dispatch('event_name'); + +Resources +--------- + +You can run the unit tests with the following command: + + $ cd path/to/Symfony/Component/EventDispatcher/ + $ composer.phar install + $ phpunit diff --git a/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/Tests/ContainerAwareEventDispatcherTest.php b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/Tests/ContainerAwareEventDispatcherTest.php new file mode 100644 index 0000000..fb3b4ca --- /dev/null +++ b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/Tests/ContainerAwareEventDispatcherTest.php @@ -0,0 +1,244 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Symfony\Component\EventDispatcher\Tests; + +use Symfony\Component\DependencyInjection\Container; +use Symfony\Component\DependencyInjection\Scope; +use Symfony\Component\EventDispatcher\ContainerAwareEventDispatcher; +use Symfony\Component\EventDispatcher\Event; +use Symfony\Component\EventDispatcher\EventSubscriberInterface; + +class ContainerAwareEventDispatcherTest extends \PHPUnit_Framework_TestCase +{ + public function testAddAListenerService() + { + $event = new Event(); + + $service = $this->getMock('Symfony\Component\EventDispatcher\Tests\Service'); + + $service + ->expects($this->once()) + ->method('onEvent') + ->with($event) + ; + + $container = new Container(); + $container->set('service.listener', $service); + + $dispatcher = new ContainerAwareEventDispatcher($container); + $dispatcher->addListenerService('onEvent', array('service.listener', 'onEvent')); + + $dispatcher->dispatch('onEvent', $event); + } + + public function testAddASubscriberService() + { + $event = new Event(); + + $service = $this->getMock('Symfony\Component\EventDispatcher\Tests\SubscriberService'); + + $service + ->expects($this->once()) + ->method('onEvent') + ->with($event) + ; + + $container = new Container(); + $container->set('service.subscriber', $service); + + $dispatcher = new ContainerAwareEventDispatcher($container); + $dispatcher->addSubscriberService('service.subscriber', 'Symfony\Component\EventDispatcher\Tests\SubscriberService'); + + $dispatcher->dispatch('onEvent', $event); + } + + public function testPreventDuplicateListenerService() + { + $event = new Event(); + + $service = $this->getMock('Symfony\Component\EventDispatcher\Tests\Service'); + + $service + ->expects($this->once()) + ->method('onEvent') + ->with($event) + ; + + $container = new Container(); + $container->set('service.listener', $service); + + $dispatcher = new ContainerAwareEventDispatcher($container); + $dispatcher->addListenerService('onEvent', array('service.listener', 'onEvent'), 5); + $dispatcher->addListenerService('onEvent', array('service.listener', 'onEvent'), 10); + + $dispatcher->dispatch('onEvent', $event); + } + + /** + * @expectedException \InvalidArgumentException + */ + public function testTriggerAListenerServiceOutOfScope() + { + $service = $this->getMock('Symfony\Component\EventDispatcher\Tests\Service'); + + $scope = new Scope('scope'); + $container = new Container(); + $container->addScope($scope); + $container->enterScope('scope'); + + $container->set('service.listener', $service, 'scope'); + + $dispatcher = new ContainerAwareEventDispatcher($container); + $dispatcher->addListenerService('onEvent', array('service.listener', 'onEvent')); + + $container->leaveScope('scope'); + $dispatcher->dispatch('onEvent'); + } + + public function testReEnteringAScope() + { + $event = new Event(); + + $service1 = $this->getMock('Symfony\Component\EventDispatcher\Tests\Service'); + + $service1 + ->expects($this->exactly(2)) + ->method('onEvent') + ->with($event) + ; + + $scope = new Scope('scope'); + $container = new Container(); + $container->addScope($scope); + $container->enterScope('scope'); + + $container->set('service.listener', $service1, 'scope'); + + $dispatcher = new ContainerAwareEventDispatcher($container); + $dispatcher->addListenerService('onEvent', array('service.listener', 'onEvent')); + $dispatcher->dispatch('onEvent', $event); + + $service2 = $this->getMock('Symfony\Component\EventDispatcher\Tests\Service'); + + $service2 + ->expects($this->once()) + ->method('onEvent') + ->with($event) + ; + + $container->enterScope('scope'); + $container->set('service.listener', $service2, 'scope'); + + $dispatcher->dispatch('onEvent', $event); + + $container->leaveScope('scope'); + + $dispatcher->dispatch('onEvent'); + } + + public function testHasListenersOnLazyLoad() + { + $event = new Event(); + + $service = $this->getMock('Symfony\Component\EventDispatcher\Tests\Service'); + + $container = new Container(); + $container->set('service.listener', $service); + + $dispatcher = new ContainerAwareEventDispatcher($container); + $dispatcher->addListenerService('onEvent', array('service.listener', 'onEvent')); + + $event->setDispatcher($dispatcher); + $event->setName('onEvent'); + + $service + ->expects($this->once()) + ->method('onEvent') + ->with($event) + ; + + $this->assertTrue($dispatcher->hasListeners()); + + if ($dispatcher->hasListeners('onEvent')) { + $dispatcher->dispatch('onEvent'); + } + } + + public function testGetListenersOnLazyLoad() + { + $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' => 'onEvent', + 'onEvent' => array('onEvent', 10), + 'onEvent' => array('onEvent'), + ); + } + + public function onEvent(Event $e) + { + } +} diff --git a/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/Tests/Debug/TraceableEventDispatcherTest.php b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/Tests/Debug/TraceableEventDispatcherTest.php new file mode 100644 index 0000000..8ccfabb --- /dev/null +++ b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/Tests/Debug/TraceableEventDispatcherTest.php @@ -0,0 +1,171 @@ + + * + * 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 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/symfony/event-dispatcher/Symfony/Component/EventDispatcher/Tests/DependencyInjection/RegisterListenersPassTest.php b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/Tests/DependencyInjection/RegisterListenersPassTest.php new file mode 100644 index 0000000..5959db0 --- /dev/null +++ b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/Tests/DependencyInjection/RegisterListenersPassTest.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 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'); + $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'); + $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); + } +} + +class SubscriberService implements \Symfony\Component\EventDispatcher\EventSubscriberInterface +{ + public static function getSubscribedEvents() {} +} diff --git a/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/Tests/EventDispatcherTest.php b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/Tests/EventDispatcherTest.php new file mode 100644 index 0000000..1e3282f --- /dev/null +++ b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/Tests/EventDispatcherTest.php @@ -0,0 +1,346 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Symfony\Component\EventDispatcher\Tests; + +use Symfony\Component\EventDispatcher\Event; +use Symfony\Component\EventDispatcher\EventDispatcher; +use Symfony\Component\EventDispatcher\EventSubscriberInterface; + +class EventDispatcherTest extends \PHPUnit_Framework_TestCase +{ + /* Some pseudo events */ + const preFoo = 'pre.foo'; + const postFoo = 'post.foo'; + const preBar = 'pre.bar'; + const postBar = 'post.bar'; + + /** + * @var EventDispatcher + */ + private $dispatcher; + + private $listener; + + protected function setUp() + { + $this->dispatcher = new EventDispatcher(); + $this->listener = new TestEventListener(); + } + + protected function tearDown() + { + $this->dispatcher = null; + $this->listener = null; + } + + public function testInitialState() + { + $this->assertEquals(array(), $this->dispatcher->getListeners()); + $this->assertFalse($this->dispatcher->hasListeners(self::preFoo)); + $this->assertFalse($this->dispatcher->hasListeners(self::postFoo)); + } + + public function testAddListener() + { + $this->dispatcher->addListener('pre.foo', array($this->listener, 'preFoo')); + $this->dispatcher->addListener('post.foo', array($this->listener, 'postFoo')); + $this->assertTrue($this->dispatcher->hasListeners(self::preFoo)); + $this->assertTrue($this->dispatcher->hasListeners(self::postFoo)); + $this->assertCount(1, $this->dispatcher->getListeners(self::preFoo)); + $this->assertCount(1, $this->dispatcher->getListeners(self::postFoo)); + $this->assertCount(2, $this->dispatcher->getListeners()); + } + + public function testGetListenersSortsByPriority() + { + $listener1 = new TestEventListener(); + $listener2 = new TestEventListener(); + $listener3 = new TestEventListener(); + $listener1->name = '1'; + $listener2->name = '2'; + $listener3->name = '3'; + + $this->dispatcher->addListener('pre.foo', array($listener1, 'preFoo'), -10); + $this->dispatcher->addListener('pre.foo', array($listener2, 'preFoo'), 10); + $this->dispatcher->addListener('pre.foo', array($listener3, 'preFoo')); + + $expected = array( + array($listener2, 'preFoo'), + array($listener3, 'preFoo'), + array($listener1, 'preFoo'), + ); + + $this->assertSame($expected, $this->dispatcher->getListeners('pre.foo')); + } + + public function testGetAllListenersSortsByPriority() + { + $listener1 = new TestEventListener(); + $listener2 = new TestEventListener(); + $listener3 = new TestEventListener(); + $listener4 = new TestEventListener(); + $listener5 = new TestEventListener(); + $listener6 = new TestEventListener(); + + $this->dispatcher->addListener('pre.foo', $listener1, -10); + $this->dispatcher->addListener('pre.foo', $listener2); + $this->dispatcher->addListener('pre.foo', $listener3, 10); + $this->dispatcher->addListener('post.foo', $listener4, -10); + $this->dispatcher->addListener('post.foo', $listener5); + $this->dispatcher->addListener('post.foo', $listener6, 10); + + $expected = array( + 'pre.foo' => array($listener3, $listener2, $listener1), + 'post.foo' => array($listener6, $listener5, $listener4), + ); + + $this->assertSame($expected, $this->dispatcher->getListeners()); + } + + public function testDispatch() + { + $this->dispatcher->addListener('pre.foo', array($this->listener, 'preFoo')); + $this->dispatcher->addListener('post.foo', array($this->listener, 'postFoo')); + $this->dispatcher->dispatch(self::preFoo); + $this->assertTrue($this->listener->preFooInvoked); + $this->assertFalse($this->listener->postFooInvoked); + $this->assertInstanceOf('Symfony\Component\EventDispatcher\Event', $this->dispatcher->dispatch('noevent')); + $this->assertInstanceOf('Symfony\Component\EventDispatcher\Event', $this->dispatcher->dispatch(self::preFoo)); + $event = new Event(); + $return = $this->dispatcher->dispatch(self::preFoo, $event); + $this->assertEquals('pre.foo', $event->getName()); + $this->assertSame($event, $return); + } + + public function testDispatchForClosure() + { + $invoked = 0; + $listener = function () use (&$invoked) { + $invoked++; + }; + $this->dispatcher->addListener('pre.foo', $listener); + $this->dispatcher->addListener('post.foo', $listener); + $this->dispatcher->dispatch(self::preFoo); + $this->assertEquals(1, $invoked); + } + + public function testStopEventPropagation() + { + $otherListener = new TestEventListener(); + + // postFoo() stops the propagation, so only one listener should + // be executed + // Manually set priority to enforce $this->listener to be called first + $this->dispatcher->addListener('post.foo', array($this->listener, 'postFoo'), 10); + $this->dispatcher->addListener('post.foo', array($otherListener, 'preFoo')); + $this->dispatcher->dispatch(self::postFoo); + $this->assertTrue($this->listener->postFooInvoked); + $this->assertFalse($otherListener->postFooInvoked); + } + + public function testDispatchByPriority() + { + $invoked = array(); + $listener1 = function () use (&$invoked) { + $invoked[] = '1'; + }; + $listener2 = function () use (&$invoked) { + $invoked[] = '2'; + }; + $listener3 = function () use (&$invoked) { + $invoked[] = '3'; + }; + $this->dispatcher->addListener('pre.foo', $listener1, -10); + $this->dispatcher->addListener('pre.foo', $listener2); + $this->dispatcher->addListener('pre.foo', $listener3, 10); + $this->dispatcher->dispatch(self::preFoo); + $this->assertEquals(array('3', '2', '1'), $invoked); + } + + public function testRemoveListener() + { + $this->dispatcher->addListener('pre.bar', $this->listener); + $this->assertTrue($this->dispatcher->hasListeners(self::preBar)); + $this->dispatcher->removeListener('pre.bar', $this->listener); + $this->assertFalse($this->dispatcher->hasListeners(self::preBar)); + $this->dispatcher->removeListener('notExists', $this->listener); + } + + public function testAddSubscriber() + { + $eventSubscriber = new TestEventSubscriber(); + $this->dispatcher->addSubscriber($eventSubscriber); + $this->assertTrue($this->dispatcher->hasListeners(self::preFoo)); + $this->assertTrue($this->dispatcher->hasListeners(self::postFoo)); + } + + public function testAddSubscriberWithPriorities() + { + $eventSubscriber = new TestEventSubscriber(); + $this->dispatcher->addSubscriber($eventSubscriber); + + $eventSubscriber = new TestEventSubscriberWithPriorities(); + $this->dispatcher->addSubscriber($eventSubscriber); + + $listeners = $this->dispatcher->getListeners('pre.foo'); + $this->assertTrue($this->dispatcher->hasListeners(self::preFoo)); + $this->assertCount(2, $listeners); + $this->assertInstanceOf('Symfony\Component\EventDispatcher\Tests\TestEventSubscriberWithPriorities', $listeners[0][0]); + } + + public function testAddSubscriberWithMultipleListeners() + { + $eventSubscriber = new TestEventSubscriberWithMultipleListeners(); + $this->dispatcher->addSubscriber($eventSubscriber); + + $listeners = $this->dispatcher->getListeners('pre.foo'); + $this->assertTrue($this->dispatcher->hasListeners(self::preFoo)); + $this->assertCount(2, $listeners); + $this->assertEquals('preFoo2', $listeners[0][1]); + } + + public function testRemoveSubscriber() + { + $eventSubscriber = new TestEventSubscriber(); + $this->dispatcher->addSubscriber($eventSubscriber); + $this->assertTrue($this->dispatcher->hasListeners(self::preFoo)); + $this->assertTrue($this->dispatcher->hasListeners(self::postFoo)); + $this->dispatcher->removeSubscriber($eventSubscriber); + $this->assertFalse($this->dispatcher->hasListeners(self::preFoo)); + $this->assertFalse($this->dispatcher->hasListeners(self::postFoo)); + } + + public function testRemoveSubscriberWithPriorities() + { + $eventSubscriber = new TestEventSubscriberWithPriorities(); + $this->dispatcher->addSubscriber($eventSubscriber); + $this->assertTrue($this->dispatcher->hasListeners(self::preFoo)); + $this->dispatcher->removeSubscriber($eventSubscriber); + $this->assertFalse($this->dispatcher->hasListeners(self::preFoo)); + } + + public function testRemoveSubscriberWithMultipleListeners() + { + $eventSubscriber = new TestEventSubscriberWithMultipleListeners(); + $this->dispatcher->addSubscriber($eventSubscriber); + $this->assertTrue($this->dispatcher->hasListeners(self::preFoo)); + $this->assertCount(2, $this->dispatcher->getListeners(self::preFoo)); + $this->dispatcher->removeSubscriber($eventSubscriber); + $this->assertFalse($this->dispatcher->hasListeners(self::preFoo)); + } + + public function testEventReceivesTheDispatcherInstance() + { + $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 = new EventDispatcher(); + $dispatcher->addListener('bug.62976', new CallableClass()); + $dispatcher->removeListener('bug.62976', function () {}); + $this->assertTrue($dispatcher->hasListeners('bug.62976')); + } +} + +class CallableClass +{ + public function __invoke() + { + } +} + +class TestEventListener +{ + public $preFooInvoked = false; + public $postFooInvoked = false; + + /* Listener methods */ + + public function preFoo(Event $e) + { + $this->preFooInvoked = true; + } + + public function postFoo(Event $e) + { + $this->postFooInvoked = true; + + $e->stopPropagation(); + } +} + +class TestWithDispatcher +{ + public $name; + public $dispatcher; + + public function foo(Event $e, $name, $dispatcher) + { + $this->name = $name; + $this->dispatcher = $dispatcher; + } +} + +class TestEventSubscriber implements EventSubscriberInterface +{ + public static function getSubscribedEvents() + { + return array('pre.foo' => 'preFoo', 'post.foo' => 'postFoo'); + } +} + +class TestEventSubscriberWithPriorities implements EventSubscriberInterface +{ + public static function getSubscribedEvents() + { + return array( + 'pre.foo' => array('preFoo', 10), + 'post.foo' => array('postFoo'), + ); + } +} + +class TestEventSubscriberWithMultipleListeners implements EventSubscriberInterface +{ + public static function getSubscribedEvents() + { + return array('pre.foo' => array( + array('preFoo1'), + array('preFoo2', 10) + )); + } +} diff --git a/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/Tests/EventTest.php b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/Tests/EventTest.php new file mode 100644 index 0000000..7a20fe6 --- /dev/null +++ b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/Tests/EventTest.php @@ -0,0 +1,84 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Symfony\Component\EventDispatcher\Tests; + +use Symfony\Component\EventDispatcher\Event; +use Symfony\Component\EventDispatcher\EventDispatcher; + +/** + * Test class for Event. + */ +class EventTest extends \PHPUnit_Framework_TestCase +{ + /** + * @var \Symfony\Component\EventDispatcher\Event + */ + protected $event; + + /** + * @var \Symfony\Component\EventDispatcher\EventDispatcher + */ + protected $dispatcher; + + /** + * Sets up the fixture, for example, opens a network connection. + * This method is called before a test is executed. + */ + protected function setUp() + { + $this->event = new Event(); + $this->dispatcher = new EventDispatcher(); + } + + /** + * Tears down the fixture, for example, closes a network connection. + * This method is called after a test is executed. + */ + protected function tearDown() + { + $this->event = null; + $this->dispatcher = null; + } + + public function testIsPropagationStopped() + { + $this->assertFalse($this->event->isPropagationStopped()); + } + + public function testStopPropagationAndIsPropagationStopped() + { + $this->event->stopPropagation(); + $this->assertTrue($this->event->isPropagationStopped()); + } + + public function testSetDispatcher() + { + $this->event->setDispatcher($this->dispatcher); + $this->assertSame($this->dispatcher, $this->event->getDispatcher()); + } + + public function testGetDispatcher() + { + $this->assertNull($this->event->getDispatcher()); + } + + public function testGetName() + { + $this->assertNull($this->event->getName()); + } + + public function testSetName() + { + $this->event->setName('foo'); + $this->assertEquals('foo', $this->event->getName()); + } +} diff --git a/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/Tests/GenericEventTest.php b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/Tests/GenericEventTest.php new file mode 100644 index 0000000..5dfda92 --- /dev/null +++ b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/Tests/GenericEventTest.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 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/symfony/event-dispatcher/Symfony/Component/EventDispatcher/Tests/ImmutableEventDispatcherTest.php b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/Tests/ImmutableEventDispatcherTest.php new file mode 100644 index 0000000..80a7e43 --- /dev/null +++ b/vendor/symfony/event-dispatcher/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/symfony/event-dispatcher/Symfony/Component/EventDispatcher/composer.json b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/composer.json new file mode 100644 index 0000000..3715ece --- /dev/null +++ b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/composer.json @@ -0,0 +1,41 @@ +{ + "name": "symfony/event-dispatcher", + "type": "library", + "description": "Symfony EventDispatcher Component", + "keywords": [], + "homepage": "http://symfony.com", + "license": "MIT", + "authors": [ + { + "name": "Fabien Potencier", + "email": "fabien@symfony.com" + }, + { + "name": "Symfony Community", + "homepage": "http://symfony.com/contributors" + } + ], + "require": { + "php": ">=5.3.3" + }, + "require-dev": { + "symfony/dependency-injection": "~2.0", + "symfony/config": "~2.0", + "symfony/stopwatch": "~2.2", + "psr/log": "~1.0" + }, + "suggest": { + "symfony/dependency-injection": "", + "symfony/http-kernel": "" + }, + "autoload": { + "psr-0": { "Symfony\\Component\\EventDispatcher\\": "" } + }, + "target-dir": "Symfony/Component/EventDispatcher", + "minimum-stability": "dev", + "extra": { + "branch-alias": { + "dev-master": "2.5-dev" + } + } +} diff --git a/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/phpunit.xml.dist b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/phpunit.xml.dist new file mode 100644 index 0000000..0c3de4f --- /dev/null +++ b/vendor/symfony/event-dispatcher/Symfony/Component/EventDispatcher/phpunit.xml.dist @@ -0,0 +1,30 @@ + + + + + + ./Tests/ + + + + + + ./ + + ./Resources + ./Tests + ./vendor + + + +