NAME
Amazon::DynamoDB::20120810 - interact with DynamoDB using API version 20120810
VERSION
version 0.002
DESCRIPTION
new
Instantiates the API object.
Expects the following named parameters:
implementation - the object which provides a Future-returning
request
method, see Amazon::DynamoDB::NaHTTP for example.host - the host (IP or hostname) to communicate with
port - the port to use for HTTP(S) requests
ssl - true for HTTPS, false for HTTP
algorithm - which signing algorithm to use, default AWS4-HMAC-SHA256
scope - the scope for requests, typically
region/host/aws4_request
access_key - the access key for signing requests
secret_key - the secret key for signing requests
debug_failures - print errors if they occur
max_retries - maximum number of retries for a request
create_table
Creates a new table. It may take some time before the table is marked as active - use "wait_for_table_status" to poll until the status changes.
Amazon Documentation:
http://docs.aws.amazon.com/amazondynamodb/latest/APIReference/API_CreateTable.html
$ddb->create_table(
TableName => $table_name,
ReadCapacityUnits => 2,
WriteCapacityUnits => 2,
AttributeDefinitions => {
user_id => 'N',
date => 'N',
},
KeySchema => ['user_id', 'date'],
LocalSecondaryIndexes => [
{
IndexName => 'UserDateIndex',
KeySchema => ['user_id', 'date'],
Projection => {
ProjectionType => 'KEYS_ONLY',
},
ProvisionedThroughput => {
ReadCapacityUnits => 2,
WriteCapacityUnits => 2,
}
}
]
);
describe_table
Describes the given table.
Amazon Documentation:
http://docs.aws.amazon.com/amazondynamodb/latest/APIReference/API_DescribeTable.html
$ddb->describe_table(TableName => $table_name);
delete_table
Delete a table entirely.
Amazon Documentation:
http://docs.aws.amazon.com/amazondynamodb/latest/APIReference/API_DeleteTable.html
$ddb->delete_table(TableName => $table_name)
wait_for_table_status
Waits for the given table to be marked as active.
TableName - the table name
WaitInterval - default wait interval in seconds.
DesiredStatus - status to expect before completing. Defaults to ACTIVE
$ddb->wait_for_table_status(TableName => $table_name);
each_table
Run code for all current tables.
Takes a coderef as the first parameter, will call this for each table found.
Amazon Documentation:
http://docs.aws.amazon.com/amazondynamodb/latest/APIReference/API_ListTables.html
my @all_tables;
$ddb->each_table(
sub {
my $table_name =shift;
push @all_tables, $table_name;
});
put_item
Writes a single item to the table.
Amazon Documentation:
http://docs.aws.amazon.com/amazondynamodb/latest/APIReference/API_PutItem.html
$ddb->put_item(
TableName => $table_name,
Item => {
name => 'Test Name'
},
ReturnValues => 'ALL_OLD');
update_item
Updates a single item in the table.
Amazon Documentation:
http://docs.aws.amazon.com/amazondynamodb/latest/APIReference/API_UpdateItem.html
$ddb->update_item(
TableName => $table_name,
Key => {
user_id => 2
},
AttributeUpdates => {
name => {
Action => 'PUT',
Value => "Rusty Conover-3",
},
favorite_color => {
Action => 'DELETE'
},
test_numbers => {
Action => 'DELETE',
Value => [500]
},
added_number => {
Action => 'ADD',
Value => 5,
},
subtracted_number => {
Action => 'ADD',
Value => -5,
},
});
delete_item
Deletes a single item from the table.
Amazon Documentation:
http://docs.aws.amazon.com/amazondynamodb/latest/APIReference/API_DeleteItem.html
$ddb->delete_item(
TableName => $table_name,
Key => {
user_id => 5
});
get_item
Retrieve an items from one tables.
Amazon Documentation:
http://docs.aws.amazon.com/amazondynamodb/latest/APIReference/API_GetItem.html
my $found_item;
my $get = $ddb->get_item(
sub {
$found_item = shift;
},
TableName => $table_name,
Key => {
user_id => 6
});
batch_write_item
Put or delete a collection of items.
Has no restriction on the number of items able to be processed at one time.
Amazon Documentation:
http://docs.aws.amazon.com/amazondynamodb/latest/APIReference/API_BatchWriteItem.html
$ddb->batch_write_item(
RequestItems => {
books => [
{
DeleteRequest => {
book_id => 3000,
}
},
],
users => [
{
PutRequest => {
user_id => 3000,
name => "Test batch write",
}
},
{
PutRequest => {
user_id => 3001,
name => "Test batch write",
}
}
]
});
batch_get_item
Retrieve a batch of items from one or more tables.
Takes a coderef which will be called for each found item, followed by these named parameters:
Amazon Documentation:
http://docs.aws.amazon.com/amazondynamodb/latest/APIReference/API_BatchGetItem.html
$ddb->batch_get_item(
sub {
my ($table, $item) = @_;
},
RequestItems => {
$table_name => {
ConsistentRead => 'true',
AttributesToGet => ['user_id', 'name'],
Keys => [
{
user_id => 1,
},
],
}
})
query
Query a table or an index.
Amazon Documentation:
http://docs.aws.amazon.com/amazondynamodb/latest/APIReference/API_Query.html
$ddb->query(
sub {
my $item = shift;
},
KeyConditions => {
user_id => {
ComparisonOperator => "EQ"
AttributeValueList => 1,
},
},
AttributesToGet => ["user_id"],
TableName => $table_name
);
scan
Scan a table for values with an optional filter expression.
Amazon Documentation:
http://docs.aws.amazon.com/amazondynamodb/latest/APIReference/API_Scan.html
$ddb->scan(
sub {
my $item = shift;
push @found_items, $item;
},
TableName => $table_name,
ScanFilter => {
user_id => {
ComparisonOperator => 'NOT_NULL',
}
});
METHODS - Internal
The following methods are intended for internal use and are documented purely for completeness - for normal operations see "METHODS" instead.
make_request
Generates an HTTP::Request.
FUNCTIONS - Internal
_encode_type_and_value
Returns an appropriate type (N, S, SS etc.) and stringified/encoded value for the given value.
DynamoDB only uses strings even if there is a Numeric value specified, so while the type will be expressed as a Number the value will be stringified.
http://docs.aws.amazon.com/amazondynamodb/latest/developerguide/DataFormat.html
AUTHOR
Rusty Conover <rusty@luckydinosaur.com>
Based on code by:
Tom Molesworth <cpan@entitymodel.com>
LICENSE
Copyright Tom Molesworth 2013. Licensed under the same terms as Perl itself. Copyright 2014 Rusty Conover, Lucky Dinosaur, LLC. Licensed under the same terms as Perl itself.
2 POD Errors
The following errors were encountered while parsing the POD:
- Around line 118:
=back without =over
- Around line 293:
You forgot a '=back' before '=head2'