forked from kayomarz/dynamodb-data-types
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path02-binary-image.js
91 lines (76 loc) · 2.62 KB
/
02-binary-image.js
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
/* This example demonstrates putting an image (binary data) into a dynamoDb
* table and retreiving it. To run this exmple you need to create the necessary
* table and key. For this example, you may use Amazon's configuration via
* environment variables `AWS_SECRET_ACCESS_KEY' and `AWS_ACCESS_KEY_ID'.
* Run this example on the command line as follows:
* $ node 02-binary-image.js put
* $ node 02-binary-image.js get
* Observe the output dump shows the data structures as required by DynamoDb.
* When running this example, you may choose to use a live DynamoDb instance
* (optinal) by setting `USE_LIVE_DB'. If you choose to use a live DynamoDb
* instance, you will to setup a DynamoDb table with name and key mentioned
* below. */
var attr = require('dynamodb-data-types').AttributeValue;
var attrUpdate = require('dynamodb-data-types').AttributeValueUpdate;
var TABLE_NAME = 'TestTableForDynamoDbDataTypes'; // Hash key: `id' (Number).
var dynamo = dynamoDb();
var fs = require('fs');
function dynamoDb(useLiveDb) {
var AWS = require('aws-sdk');
AWS.config.update({region: 'us-east-1'});
var dynamo = new AWS.DynamoDB({apiVersion: '2013-10-16'});
return dynamo;
}
function putItemBinary(path, id) {
console.log('file read: ', path);
fs.readFile(path, function(err, data) {
if (err)
return console.log('file read error:', err.message);
console.log('file read ok; instance of Buffer: ', data instanceof Buffer);
var opts = {
TableName: TABLE_NAME,
Item: attr.wrap({
id: id,
img: data
})
};
console.log('putItem:\n', opts);
dynamo.putItem(opts, function(err){
console.error('putItem', err ? 'error\n' + err : 'ok');
});
});
}
function getItemAndSave(id, filename) {
var opts = {
TableName: TABLE_NAME,
Key: attr.wrap({
id: id
})
};
dynamo.getItem(opts, function(err, _data) {
if (err)
return console.error('getItem error:', err);
if (!_data.Item)
return console.error('No Item for requested options', opts);
console.log(_data);
var data = attr.unwrap(_data.Item);
console.log(data);
fs.writeFile(filename, data.img);
});
}
var action = process.argv[2];
if (!(action === 'get' || action === 'put')) {
console.log(
'no action specified\n' +
'usage: node 02-binary-image.js <action>\n' +
'<action> should be either \'put\' or \'get\'.'
);
process.exit(1);
}
var inPath = 'images/img.jpg';
var outPath = 'images/out-img.jpg';
var dbId = 2; // arbitrary ID
switch(action) {
case 'put': putItemBinary(inPath, dbId); break;
case 'get': getItemAndSave(dbId, outPath); break;
}