/usr/share/php/Aws/DynamoDb/DynamoDbClient.php is in php-aws-sdk 2.5.2-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 | <?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
*
* http://aws.amazon.com/apache2.0
*
* 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.
*/
namespace Aws\DynamoDb;
use Aws\Common\Client\AbstractClient;
use Aws\Common\Client\ClientBuilder;
use Aws\Common\Client\ExpiredCredentialsChecker;
use Aws\Common\Client\ThrottlingErrorChecker;
use Aws\Common\Enum\ClientOptions as Options;
use Aws\Common\Exception\Parser\JsonQueryExceptionParser;
use Aws\DynamoDb\Model\Attribute;
use Aws\DynamoDb\Session\SessionHandler;
use Guzzle\Common\Collection;
use Guzzle\Plugin\Backoff\BackoffPlugin;
use Guzzle\Plugin\Backoff\CallbackBackoffStrategy;
use Guzzle\Plugin\Backoff\CurlBackoffStrategy;
use Guzzle\Plugin\Backoff\HttpBackoffStrategy;
use Guzzle\Plugin\Backoff\TruncatedBackoffStrategy;
use Guzzle\Service\Command\AbstractCommand as Cmd;
use Guzzle\Service\Resource\Model;
use Guzzle\Service\Resource\ResourceIteratorInterface;
/**
* Client to interact with Amazon DynamoDB
*
* @method Model batchGetItem(array $args = array()) {@command DynamoDb BatchGetItem}
* @method Model batchWriteItem(array $args = array()) {@command DynamoDb BatchWriteItem}
* @method Model createTable(array $args = array()) {@command DynamoDb CreateTable}
* @method Model deleteItem(array $args = array()) {@command DynamoDb DeleteItem}
* @method Model deleteTable(array $args = array()) {@command DynamoDb DeleteTable}
* @method Model describeTable(array $args = array()) {@command DynamoDb DescribeTable}
* @method Model getItem(array $args = array()) {@command DynamoDb GetItem}
* @method Model listTables(array $args = array()) {@command DynamoDb ListTables}
* @method Model putItem(array $args = array()) {@command DynamoDb PutItem}
* @method Model query(array $args = array()) {@command DynamoDb Query}
* @method Model scan(array $args = array()) {@command DynamoDb Scan}
* @method Model updateItem(array $args = array()) {@command DynamoDb UpdateItem}
* @method Model updateTable(array $args = array()) {@command DynamoDb UpdateTable}
* @method waitUntilTableExists(array $input) Wait until a table exists and can be accessed The input array uses the parameters of the DescribeTable operation and waiter specific settings
* @method waitUntilTableNotExists(array $input) Wait until a table is deleted The input array uses the parameters of the DescribeTable operation and waiter specific settings
* @method ResourceIteratorInterface getBatchGetItemIterator(array $args = array()) The input array uses the parameters of the BatchGetItem operation
* @method ResourceIteratorInterface getListTablesIterator(array $args = array()) The input array uses the parameters of the ListTables operation
* @method ResourceIteratorInterface getQueryIterator(array $args = array()) The input array uses the parameters of the Query operation
* @method ResourceIteratorInterface getScanIterator(array $args = array()) The input array uses the parameters of the Scan operation
*
* @link http://docs.aws.amazon.com/aws-sdk-php/guide/latest/service-dynamodb.html User guide
* @link http://docs.aws.amazon.com/aws-sdk-php/latest/class-Aws.DynamoDb.DynamoDbClient.html API docs
*/
class DynamoDbClient extends AbstractClient
{
const LATEST_API_VERSION = '2012-08-10';
/**
* Factory method to create a new Amazon DynamoDB client using an array of configuration options.
*
* @param array|Collection $config Client configuration data
*
* @return self
* @see \Aws\Common\Client\DefaultClient for a list of available configuration options
*/
public static function factory($config = array())
{
// Configure the custom exponential backoff plugin for DynamoDB throttling
$exceptionParser = new JsonQueryExceptionParser();
if (!isset($config[Options::BACKOFF])) {
$config[Options::BACKOFF] = 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)
)
)
)
)
)
)
);
}
// Construct the DynamoDB client with the client builder
return ClientBuilder::factory(__NAMESPACE__)
->setConfig($config)
->setConfigDefaults(array(
// DynamoDB does not use redirects
self::DISABLE_REDIRECTS => true,
Options::VERSION => self::LATEST_API_VERSION,
Options::SERVICE_DESCRIPTION => __DIR__ . '/Resources/dynamodb-%s.php',
// DynamoDB does not require response processing other than turning JSON into an array
self::COMMAND_PARAMS => array(Cmd::RESPONSE_PROCESSING => Cmd::TYPE_NO_TRANSLATION)
))
->setExceptionParser($exceptionParser)
->setIteratorsConfig(array(
'result_key' => 'Items',
'token_param' => 'ExclusiveStartKey',
'token_key' => 'LastEvaluatedKey',
'operations' => array(
'BatchGetItem' => array(
'token_param' => 'RequestItems',
'token_key' => 'UnprocessedKeys',
'result_key' => 'Responses/*',
),
'ListTables' => array(
'result_key' => 'TableNames',
'token_param' => 'ExclusiveStartTableName',
'token_key' => 'LastEvaluatedTableName',
),
'Query',
'Scan',
)
))
->build();
}
/**
* Formats a value as a DynamoDB attribute.
*
* @param mixed $value The value to format for DynamoDB.
* @param string $format The type of format (e.g. put, update).
*
* @return array The formatted value.
*/
public function formatValue($value, $format = Attribute::FORMAT_PUT)
{
return Attribute::factory($value)->getFormatted($format);
}
/**
* Formats an array of values as DynamoDB attributes.
*
* @param array $values The values to format for DynamoDB.
* @param string $format The type of format (e.g. put, update).
*
* @return array The formatted values.
*/
public function formatAttributes(array $values, $format = Attribute::FORMAT_PUT)
{
$formatted = array();
foreach ($values as $key => $value) {
$formatted[$key] = $this->formatValue($value, $format);
}
return $formatted;
}
/**
* Calculate the amount of time needed for an exponential backoff to wait
* before retrying a request
*
* @param int $retries Number of retries
*
* @return float Returns the amount of time to wait in seconds
*/
public static function calculateRetryDelay($retries)
{
return $retries == 0 ? 0 : (50 * (int) pow(2, $retries - 1)) / 1000;
}
/**
* Convenience method for instantiating and registering the DynamoDB
* Session handler with this DynamoDB client object.
*
* @param array $config Array of options for the session handler factory
*
* @return SessionHandler
*/
public function registerSessionHandler(array $config = array())
{
$config = array_replace(array('dynamodb_client' => $this), $config);
$handler = SessionHandler::factory($config);
$handler->register();
return $handler;
}
}
|