-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathdatabaseManager.js
98 lines (81 loc) · 1.72 KB
/
databaseManager.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
92
93
94
95
96
97
98
'use strict';
const AWS = require('aws-sdk');
let dynamo = new AWS.DynamoDB.DocumentClient();
const TABLE_NAME = 'inkProductsTable';
module.exports.initializateDynamoClient = newDynamo => {
dynamo = newDynamo;
};
module.exports.saveItem = item => {
const params = {
TableName: TABLE_NAME,
Item: item
};
return dynamo
.put(params)
.promise()
.then((result) => {
return item;
}, (error) => {
return error;
});
};
module.exports.getItem = itemId => {
const params = {
Key: {
productId: itemId
},
TableName: TABLE_NAME
};
return dynamo
.get(params)
.promise()
.then((result) => {
return result.Item;
}, (error) => {
return error;
});
};
module.exports.deleteItem = itemId => {
const params = {
Key: {
productId: itemId
},
TableName: TABLE_NAME
};
return dynamo.delete(params).promise();
};
module.exports.updateItem = (itemId, item) => {
let vbl = "x";
let adder = "y";
let updateexp = 'set ';
let itemKeys = Object.keys(item);
let expattvalues = {};
for (let i = 0; i < itemKeys.length; i++) {
vbl = vbl+adder;
if((itemKeys.length-1)==i)
updateexp += itemKeys[i] + ' = :'+ vbl;
else
updateexp += itemKeys[i] + ' = :'+ vbl + ", ";
expattvalues[":"+vbl] = item[itemKeys[i]];
}
console.log("update expression and expressionAttributeValues");
console.log(updateexp, expattvalues);
const params = {
TableName: TABLE_NAME,
Key: {
productId: itemId
},
ConditionExpression: 'attribute_exists(productId)',
UpdateExpression: updateexp,
ExpressionAttributeValues: expattvalues,
ReturnValues: 'ALL_NEW'
};
return dynamo
.update(params)
.promise()
.then(response => {
return response.Attributes;
}, (error) => {
return error;
});
};