@nlabs/reaktor 0.1.5 → 0.1.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/config.js +20 -11
- package/lib/data/conversations.js +69 -39
- package/lib/data/dynamodb.js +60 -27
- package/lib/data/email.js +50 -19
- package/lib/data/files.js +103 -46
- package/lib/data/groups.js +114 -67
- package/lib/data/images.js +169 -102
- package/lib/data/index.js +234 -24
- package/lib/data/ios.js +48 -23
- package/lib/data/locations.js +45 -29
- package/lib/data/messages.d.ts +2 -2
- package/lib/data/messages.js +105 -72
- package/lib/data/notifications.js +31 -14
- package/lib/data/payments.js +164 -114
- package/lib/data/posts.js +144 -87
- package/lib/data/reactions.js +58 -33
- package/lib/data/s3.js +54 -24
- package/lib/data/search.js +32 -19
- package/lib/data/sms.js +35 -15
- package/lib/data/subscription.js +78 -51
- package/lib/data/tags.js +90 -51
- package/lib/data/users.js +119 -72
- package/lib/index.js +42 -8
- package/lib/types/apps.js +1 -1
- package/lib/types/arangodb.js +1 -1
- package/lib/types/auth.js +1 -1
- package/lib/types/conversations.js +1 -1
- package/lib/types/email.js +1 -1
- package/lib/types/files.js +1 -1
- package/lib/types/google.js +1 -1
- package/lib/types/groups.js +1 -1
- package/lib/types/images.js +1 -1
- package/lib/types/index.js +210 -22
- package/lib/types/locations.js +1 -1
- package/lib/types/messages.d.ts +12 -7
- package/lib/types/messages.js +1 -1
- package/lib/types/notifications.js +1 -1
- package/lib/types/payments.js +1 -1
- package/lib/types/posts.js +1 -1
- package/lib/types/reactions.js +1 -1
- package/lib/types/tags.js +1 -1
- package/lib/types/users.d.ts +0 -1
- package/lib/types/users.js +1 -1
- package/lib/utils/analytics.js +23 -11
- package/lib/utils/arangodb.js +48 -19
- package/lib/utils/auth.js +31 -15
- package/lib/utils/graphql.js +16 -4
- package/lib/utils/index.js +78 -11
- package/lib/utils/objects.js +30 -10
- package/lib/utils/redis.js +21 -8
- package/package.json +5 -5
- package/index.d.ts +0 -1
package/lib/config.js
CHANGED
|
@@ -1,3 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.Config = void 0;
|
|
7
|
+
|
|
8
|
+
var _get2 = _interopRequireDefault(require("lodash/get"));
|
|
9
|
+
|
|
10
|
+
var _merge = _interopRequireDefault(require("lodash/merge"));
|
|
11
|
+
|
|
12
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
13
|
+
|
|
1
14
|
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|
2
15
|
|
|
3
16
|
function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
|
|
@@ -6,13 +19,6 @@ function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _d
|
|
|
6
19
|
|
|
7
20
|
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
8
21
|
|
|
9
|
-
/**
|
|
10
|
-
* Copyright (c) 2019-Present, Nitrogen Labs, Inc.
|
|
11
|
-
* Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
|
|
12
|
-
*/
|
|
13
|
-
import _get from 'lodash/get';
|
|
14
|
-
import merge from 'lodash/merge';
|
|
15
|
-
|
|
16
22
|
var appPackage = require('../package.json');
|
|
17
23
|
|
|
18
24
|
var _process$env = process.env,
|
|
@@ -25,7 +31,8 @@ var _process$env = process.env,
|
|
|
25
31
|
arangodbUrl = _process$env$arangodb3 === void 0 ? 'db.reaktor.io' : _process$env$arangodb3,
|
|
26
32
|
_process$env$arangodb4 = _process$env.arangodbUsername,
|
|
27
33
|
arangodbUsername = _process$env$arangodb4 === void 0 ? 'reaktor' : _process$env$arangodb4;
|
|
28
|
-
|
|
34
|
+
|
|
35
|
+
var Config =
|
|
29
36
|
/*#__PURE__*/
|
|
30
37
|
function () {
|
|
31
38
|
function Config() {
|
|
@@ -36,16 +43,18 @@ function () {
|
|
|
36
43
|
key: "get",
|
|
37
44
|
value: function get(path) {
|
|
38
45
|
var environment = process.env.stage || 'development';
|
|
39
|
-
var configValues =
|
|
46
|
+
var configValues = (0, _merge.default)(this.values.default, this.values[environment], {
|
|
40
47
|
environment: environment
|
|
41
48
|
});
|
|
42
|
-
return
|
|
49
|
+
return (0, _get2.default)(configValues, path);
|
|
43
50
|
}
|
|
44
51
|
}]);
|
|
45
52
|
|
|
46
53
|
return Config;
|
|
47
54
|
}();
|
|
48
55
|
|
|
56
|
+
exports.Config = Config;
|
|
57
|
+
|
|
49
58
|
_defineProperty(Config, "values", {
|
|
50
59
|
default: {
|
|
51
60
|
app: {
|
|
@@ -127,4 +136,4 @@ _defineProperty(Config, "values", {
|
|
|
127
136
|
},
|
|
128
137
|
test: {}
|
|
129
138
|
});
|
|
130
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
139
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/config.ts"],"names":["appPackage","require","process","env","arangodbDatabase","arangodbPassword","arangodbPort","arangodbUrl","arangodbUsername","Config","path","environment","stage","configValues","values","default","app","name","url","version","arangodb","apiUrl","database","dump","password","port","restore","username","aws","Bucket","accessKeyId","maxRetries","region","secretAccessKey","signatureVersion","giphy","key","google","analytics","accountId","trackingId","geocode","image","imgQuality","imgSize","thmQuality","thmSize","redis","host","stripe","token","twilio","number","sid","development","production","test"],"mappings":"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","sourcesContent":["/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport get from 'lodash/get';\nimport merge from 'lodash/merge';\n\nexport interface AppConfig {\n  readonly app?: object;\n  readonly arangodb?: object;\n  readonly aws?: object;\n  readonly giphy?: object;\n  readonly google?: object;\n  readonly image?: object;\n  readonly redis?: object;\n  readonly stripe?: object;\n  readonly twilio?: object;\n}\n\nexport interface EnvConfig {\n  readonly default: AppConfig;\n  readonly development: AppConfig;\n  readonly production: AppConfig;\n  readonly test: AppConfig;\n}\n\nconst appPackage: any = require('../package.json');\n\nconst {\n  arangodbDatabase = 'reaktor',\n  arangodbPassword,\n  arangodbPort = '8529',\n  arangodbUrl = 'db.reaktor.io',\n  arangodbUsername = 'reaktor'\n} = process.env;\n\nexport class Config {\n  static values: EnvConfig = {\n    default: {\n      app: {\n        name: 'reaktor',\n        url: 'reaktor.io',\n        version: appPackage.version\n      },\n      arangodb: {\n        apiUrl: `http://${arangodbUrl}:${arangodbPort}`,\n        database: arangodbDatabase,\n        dump: '/Applications/ArangoDB-CLI.app/Contents/MacOS/arangodump',\n        password: arangodbPassword,\n        port: arangodbPort,\n        restore: '/Applications/ArangoDB-CLI.app/Contents/MacOS/arangorestore',\n        url: arangodbUrl,\n        username: arangodbUsername\n      },\n      aws: {\n        Bucket: 'dev.reaktor.io',\n        accessKeyId: 'AKIAJIYDT3EA2ZFMTJNA',\n        maxRetries: 3,\n        region: 'us-east-1',\n        secretAccessKey: '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',\n        signatureVersion: 'v4'\n      },\n      giphy: {\n        key: 'dc6zaTOxFJmzC'\n      },\n      google: {\n        analytics: {\n          accountId: '78158717',\n          trackingId: 'UA-78158717-1'\n        },\n        geocode: {\n          key: 'AIzaSyBwjmpBjWhiJoBCZiYzRurM9m4WnCxslv0',\n          url: 'https://maps.googleapis.com/maps/api/geocode/json'\n        },\n        key: 'AIzaSyC3_f2Us3y0qjbyMJ-4t5ObtCzfq_FHIgQ'\n      },\n      image: {\n        imgQuality: 90,\n        imgSize: 1500,\n        thmQuality: 80,\n        thmSize: 150\n      },\n      redis: {\n        host: '127.0.0.1',\n        port: 6379\n      },\n      stripe: {\n        token: 'sk_test_LS956be57YUXTB5a4sLGb5BQ'\n      },\n      twilio: {\n        number: '+15005550006',\n        sid: 'AC6bd7f513cbed2e5134c650be06cc732e',\n        token: '520ae739e761bab759b147f1ad28278f'\n      }\n    },\n    development: {\n    },\n    production: {\n      arangodb: {\n        dump: '/usr/bin/arangodump',\n        restore: '/usr/bin/arangorestore',\n      },\n      aws: {\n        Bucket: 'box.reaktor.io'\n      },\n      redis: {\n        host: 'reaktor-redis.ehcvnt.0001.use1.cache.amazonaws.com'\n      },\n      stripe: {\n        token: 'sk_live_bElZl8RLhMCJy33KG4lyLD4o'\n      },\n      twilio: {\n        number: '+18554165227',\n        sid: 'AC90b0528a911e652d643329a4d7b4d2c7',\n        token: 'a7941d173bd4846d0966a186e9865b72'\n      }\n    },\n    test: {\n    }\n  };\n\n  static get(path: string | string[]): any {\n    const environment: string = process.env.stage || 'development';\n    const configValues: object = merge(this.values.default, this.values[environment], {environment});\n    return get(configValues, path);\n  }\n}\n"]}
|
|
@@ -1,3 +1,32 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.updateConversation = exports.getConversation = exports.getDirectConversation = exports.getConversationList = void 0;
|
|
7
|
+
|
|
8
|
+
var _utils = require("@nlabs/utils");
|
|
9
|
+
|
|
10
|
+
var _arangojs = require("arangojs");
|
|
11
|
+
|
|
12
|
+
var _cloneDeep = _interopRequireDefault(require("lodash/cloneDeep"));
|
|
13
|
+
|
|
14
|
+
var _identity = _interopRequireDefault(require("lodash/identity"));
|
|
15
|
+
|
|
16
|
+
var _isEmpty = _interopRequireDefault(require("lodash/isEmpty"));
|
|
17
|
+
|
|
18
|
+
var _pick2 = _interopRequireDefault(require("lodash/pick"));
|
|
19
|
+
|
|
20
|
+
var _utils2 = require("../utils");
|
|
21
|
+
|
|
22
|
+
var _analytics = require("../utils/analytics");
|
|
23
|
+
|
|
24
|
+
var _images = require("./images");
|
|
25
|
+
|
|
26
|
+
var _users = require("./users");
|
|
27
|
+
|
|
28
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
29
|
+
|
|
1
30
|
function _templateObject3() {
|
|
2
31
|
var data = _taggedTemplateLiteral(["UPSERT {_key: ", "}\n INSERT ", "\n UPDATE ", "\n IN conversations RETURN NEW"]);
|
|
3
32
|
|
|
@@ -9,7 +38,7 @@ function _templateObject3() {
|
|
|
9
38
|
}
|
|
10
39
|
|
|
11
40
|
function _templateObject2() {
|
|
12
|
-
var data = _taggedTemplateLiteral(["FOR c IN conversations\n FILTER ", "
|
|
41
|
+
var data = _taggedTemplateLiteral(["FOR c IN conversations\n FILTER c._key == ", " && IS_LIST(c.users) && POSITION(c.users, ", ", false)\n LET u = (\n FOR g IN c.users\n FOR u IN users\n FILTER g == u._key\n RETURN {_key:u._key, first:u.first, last:u.last, name:u.name, email:u.email, username:u.username, photo:u.photo }\n )\n FILTER LENGTH(u) > 1\n LIMIT 1\n RETURN MERGE(c, {users: u})"]);
|
|
13
42
|
|
|
14
43
|
_templateObject2 = function _templateObject2() {
|
|
15
44
|
return data;
|
|
@@ -34,32 +63,22 @@ function _templateObject() {
|
|
|
34
63
|
|
|
35
64
|
function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
|
|
36
65
|
|
|
37
|
-
import { createHash, parseId } from '@nlabs/utils';
|
|
38
|
-
import { aql } from 'arangojs';
|
|
39
|
-
import cloneDeep from 'lodash/cloneDeep';
|
|
40
|
-
import identity from 'lodash/identity';
|
|
41
|
-
import isEmpty from 'lodash/isEmpty';
|
|
42
|
-
import pick from 'lodash/pick';
|
|
43
|
-
import { getLimit, useDb } from '../utils';
|
|
44
|
-
import { logError } from '../utils/analytics';
|
|
45
|
-
import { getUrlImages } from './images';
|
|
46
|
-
import { getDisplayName } from './users';
|
|
47
66
|
/**
|
|
48
67
|
* Copyright (c) 2019-Present, Nitrogen Labs, Inc.
|
|
49
68
|
* Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
|
|
50
69
|
*/
|
|
51
|
-
|
|
52
70
|
var eventCategory = 'conversations';
|
|
53
|
-
|
|
71
|
+
|
|
72
|
+
var getConversationList = function getConversationList(context, from, to) {
|
|
54
73
|
var action = 'getList';
|
|
55
74
|
var database = context.database,
|
|
56
75
|
sessionId = context.userId;
|
|
57
|
-
var limit = getLimit(from, to);
|
|
76
|
+
var limit = (0, _utils2.getLimit)(from, to);
|
|
58
77
|
var aqlQry = "FOR c IN conversations\n FILTER POSITION(c.users, \"".concat(sessionId, "\", false)\n LET u = (\n FOR g IN c.users\n FOR u IN users\n FILTER g == u._key\n RETURN {_key:u._key, first:u.first, last:u.last, name:u.name, email:u.email, username:u.username, photo:u.photo }\n )\n FILTER LENGTH(u) > 1\n ").concat(limit.aql, "\n RETURN {_key:c._key, name: c.name, direct: c.direct, users: u}");
|
|
59
|
-
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
78
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
60
79
|
return cursor.all();
|
|
61
80
|
}).catch(function (error) {
|
|
62
|
-
return logError({
|
|
81
|
+
return (0, _analytics.logError)({
|
|
63
82
|
action: action,
|
|
64
83
|
category: eventCategory,
|
|
65
84
|
label: 'db_error'
|
|
@@ -68,13 +87,16 @@ export var getConversationList = function getConversationList(context, from, to)
|
|
|
68
87
|
});
|
|
69
88
|
});
|
|
70
89
|
};
|
|
71
|
-
|
|
90
|
+
|
|
91
|
+
exports.getConversationList = getConversationList;
|
|
92
|
+
|
|
93
|
+
var getDirectConversation = function getDirectConversation(context, userId) {
|
|
72
94
|
var action = 'getDirect';
|
|
73
95
|
var database = context.database,
|
|
74
96
|
sessionId = context.userId;
|
|
75
|
-
var formatUserId = parseId(userId);
|
|
76
|
-
var aqlQry = aql(_templateObject(), sessionId, formatUserId);
|
|
77
|
-
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
97
|
+
var formatUserId = (0, _utils.parseId)(userId);
|
|
98
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject(), sessionId, formatUserId);
|
|
99
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
78
100
|
return cursor.next();
|
|
79
101
|
}).then(function () {
|
|
80
102
|
var conversation = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
@@ -93,15 +115,15 @@ export var getDirectConversation = function getDirectConversation(context, userI
|
|
|
93
115
|
typeId: userKey
|
|
94
116
|
};
|
|
95
117
|
return _objectSpread({}, user, {
|
|
96
|
-
name: getDisplayName(user),
|
|
97
|
-
thumb: getUrlImages(thumbUrlData)
|
|
118
|
+
name: (0, _users.getDisplayName)(user),
|
|
119
|
+
thumb: (0, _images.getUrlImages)(thumbUrlData)
|
|
98
120
|
});
|
|
99
121
|
});
|
|
100
122
|
}
|
|
101
123
|
|
|
102
124
|
return conversation;
|
|
103
125
|
}).catch(function (error) {
|
|
104
|
-
return logError({
|
|
126
|
+
return (0, _analytics.logError)({
|
|
105
127
|
action: action,
|
|
106
128
|
category: eventCategory,
|
|
107
129
|
label: 'db_error'
|
|
@@ -110,18 +132,21 @@ export var getDirectConversation = function getDirectConversation(context, userI
|
|
|
110
132
|
});
|
|
111
133
|
});
|
|
112
134
|
};
|
|
113
|
-
|
|
135
|
+
|
|
136
|
+
exports.getDirectConversation = getDirectConversation;
|
|
137
|
+
|
|
138
|
+
var getConversation = function getConversation(context, convoId) {
|
|
114
139
|
var action = 'getItem';
|
|
115
140
|
var database = context.database,
|
|
116
141
|
sessionId = context.userId;
|
|
117
|
-
var formatConvoId = parseId(convoId);
|
|
118
|
-
var aqlQry = aql(_templateObject2(), formatConvoId, sessionId);
|
|
119
|
-
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
142
|
+
var formatConvoId = (0, _utils.parseId)(convoId);
|
|
143
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject2(), formatConvoId, sessionId);
|
|
144
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
120
145
|
return cursor.next();
|
|
121
146
|
}).then(function () {
|
|
122
147
|
var conversation = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
123
148
|
|
|
124
|
-
if (!
|
|
149
|
+
if (!(0, _isEmpty.default)(conversation)) {
|
|
125
150
|
conversation.users = conversation.users.map(function (user) {
|
|
126
151
|
var userKey = user._key,
|
|
127
152
|
imgId = user.imgId;
|
|
@@ -133,8 +158,8 @@ export var getConversation = function getConversation(context, convoId) {
|
|
|
133
158
|
typeId: userKey
|
|
134
159
|
};
|
|
135
160
|
return _objectSpread({}, user, {
|
|
136
|
-
name: getDisplayName(user),
|
|
137
|
-
thumb: getUrlImages(thumbUrlData)
|
|
161
|
+
name: (0, _users.getDisplayName)(user),
|
|
162
|
+
thumb: (0, _images.getUrlImages)(thumbUrlData)
|
|
138
163
|
});
|
|
139
164
|
});
|
|
140
165
|
return conversation;
|
|
@@ -142,7 +167,7 @@ export var getConversation = function getConversation(context, convoId) {
|
|
|
142
167
|
|
|
143
168
|
return {};
|
|
144
169
|
}).catch(function (error) {
|
|
145
|
-
return logError({
|
|
170
|
+
return (0, _analytics.logError)({
|
|
146
171
|
action: action,
|
|
147
172
|
category: eventCategory,
|
|
148
173
|
label: 'db_error'
|
|
@@ -151,19 +176,22 @@ export var getConversation = function getConversation(context, convoId) {
|
|
|
151
176
|
});
|
|
152
177
|
});
|
|
153
178
|
};
|
|
154
|
-
|
|
179
|
+
|
|
180
|
+
exports.getConversation = getConversation;
|
|
181
|
+
|
|
182
|
+
var updateConversation = function updateConversation(context, item) {
|
|
155
183
|
var action = 'update';
|
|
156
184
|
var database = context.database,
|
|
157
185
|
sessionId = context.userId;
|
|
158
186
|
|
|
159
|
-
var _pick =
|
|
187
|
+
var _pick = (0, _pick2.default)(item, _identity.default),
|
|
160
188
|
direct = _pick.direct,
|
|
161
189
|
id = _pick.id,
|
|
162
190
|
name = _pick.name,
|
|
163
191
|
users = _pick.users;
|
|
164
192
|
|
|
165
193
|
var rcpt = users || [];
|
|
166
|
-
var formatId = item.id || createHash("convo-".concat(sessionId, "-").concat(rcpt.join('')));
|
|
194
|
+
var formatId = item.id || (0, _utils.createHash)("convo-".concat(sessionId, "-").concat(rcpt.join('')));
|
|
167
195
|
var now = Date.now();
|
|
168
196
|
var update = {
|
|
169
197
|
// Direct message
|
|
@@ -174,19 +202,19 @@ export var updateConversation = function updateConversation(context, item) {
|
|
|
174
202
|
users: !!users ? users : undefined
|
|
175
203
|
};
|
|
176
204
|
|
|
177
|
-
var insert = _objectSpread({},
|
|
205
|
+
var insert = _objectSpread({}, (0, _cloneDeep.default)(update), {
|
|
178
206
|
_key: formatId,
|
|
179
207
|
added: now
|
|
180
208
|
});
|
|
181
209
|
|
|
182
|
-
var aqlQry = aql(_templateObject3(), id, insert, update);
|
|
183
|
-
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
210
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject3(), id, insert, update);
|
|
211
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
184
212
|
return cursor.next();
|
|
185
213
|
}).then(function () {
|
|
186
214
|
var conversation = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
187
215
|
return conversation;
|
|
188
216
|
}).catch(function (error) {
|
|
189
|
-
return logError({
|
|
217
|
+
return (0, _analytics.logError)({
|
|
190
218
|
action: action,
|
|
191
219
|
category: eventCategory,
|
|
192
220
|
label: 'db_error'
|
|
@@ -195,4 +223,6 @@ export var updateConversation = function updateConversation(context, item) {
|
|
|
195
223
|
});
|
|
196
224
|
});
|
|
197
225
|
};
|
|
198
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/conversations.ts"],"names":["createHash","parseId","aql","cloneDeep","identity","isEmpty","pick","getLimit","useDb","logError","getUrlImages","getDisplayName","eventCategory","getConversationList","context","from","to","action","database","sessionId","userId","limit","aqlQry","query","then","cursor","all","catch","error","category","label","getDirectConversation","formatUserId","next","conversation","users","length","map","user","userKey","_key","imgId","thumbUrlData","directory","isThumb","type","typeId","name","thumb","getConversation","convoId","formatConvoId","updateConversation","item","direct","id","rcpt","formatId","join","now","Date","update","undefined","modified","insert","added"],"mappings":"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","sourcesContent":["import {createHash, parseId} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport cloneDeep from 'lodash/cloneDeep';\nimport identity from 'lodash/identity';\nimport isEmpty from 'lodash/isEmpty';\nimport pick from 'lodash/pick';\nimport {ApiContext} from 'types/auth';\n\nimport {ArangoDBLimit, ConversationType, ImageUrlData, UserType} from '../types';\nimport {getLimit, useDb} from '../utils';\nimport {logError} from '../utils/analytics';\nimport {getUrlImages} from './images';\nimport {getDisplayName} from './users';\n\n/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nconst eventCategory: string = 'conversations';\n\nexport const getConversationList = (context: ApiContext, from: number, to: number): Promise<ConversationType[]> => {\n  const action: string = 'getList';\n  const {database, userId: sessionId} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `FOR c IN conversations\n    FILTER POSITION(c.users, \"${sessionId}\", false)\n    LET u = (\n      FOR g IN c.users\n      FOR u IN users\n      FILTER g == u._key\n      RETURN {_key:u._key, first:u.first, last:u.last, name:u.name, email:u.email, username:u.username, photo:u.photo }\n    )\n    FILTER LENGTH(u) > 1\n    ${limit.aql}\n    RETURN {_key:c._key, name: c.name, direct: c.direct, users: u}`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getDirectConversation = (context: ApiContext, userId: string): Promise<ConversationType> => {\n  const action: string = 'getDirect';\n  const {database, userId: sessionId} = context;\n  const formatUserId: string = parseId(userId);\n\n  const aqlQry: AqlQuery = aql`FOR c IN conversations\n    FILTER LENGTH(c.users) == 2 &&\n    POSITION(c.users, ${sessionId}, false) &&\n    POSITION(c.users, ${formatUserId}, false)\n    LET u = (\n      FOR g IN c.users\n      FOR user IN users\n      FILTER user._key == g\n      RETURN user\n    )\n    LIMIT 1\n    RETURN MERGE(c, {users: u})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversation: ConversationType = {}) => {\n      const {users = []} = conversation;\n\n      if(users.length) {\n        conversation.users = users.map((user: UserType) => {\n          const {_key: userKey, imgId} = user;\n          const thumbUrlData: ImageUrlData = {\n            directory: 'images',\n            imgId,\n            isThumb: true,\n            type: 'users',\n            typeId: userKey\n          };\n          return {\n            ...user,\n            name: getDisplayName(user),\n            thumb: getUrlImages(thumbUrlData)\n          };\n        });\n      }\n\n      return conversation;\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getConversation = (context: ApiContext, convoId: string): Promise<ConversationType> => {\n  const action: string = 'getItem';\n  const {database, userId: sessionId} = context;\n  const formatConvoId: string = parseId(convoId);\n\n  const aqlQry: AqlQuery = aql`FOR c IN conversations\n    FILTER ${formatConvoId} == c._key && IS_LIST(c.users) && POSITION(c.users, ${sessionId}, false)\n    LET u = (\n      FOR g IN c.users\n      FOR u IN users\n      FILTER g == u._key\n      RETURN {_key:u._key, first:u.first, last:u.last, name:u.name, email:u.email, username:u.username, photo:u.photo }\n    )\n    FILTER LENGTH(u) > 1\n    LIMIT 1\n    RETURN MERGE(c, {users: u})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversation: ConversationType = {}) => {\n      if(!isEmpty(conversation)) {\n        conversation.users = conversation.users.map((user: UserType) => {\n          const {_key: userKey, imgId} = user;\n          const thumbUrlData: ImageUrlData = {\n            directory: 'images',\n            imgId,\n            isThumb: true,\n            type: 'users',\n            typeId: userKey\n          };\n          return {\n            ...user,\n            name: getDisplayName(user),\n            thumb: getUrlImages(thumbUrlData)\n          };\n        });\n\n        return conversation;\n      }\n      return {};\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const updateConversation = (context: ApiContext, item): Promise<ConversationType> => {\n  const action: string = 'update';\n  const {database, userId: sessionId} = context;\n  const {direct, id, name, users} = pick(item, identity);\n  const rcpt: UserType[] = users || [];\n  const formatId: string = item.id || createHash(`convo-${sessionId}-${rcpt.join('')}`);\n  const now: number = Date.now();\n  const update: any = {\n    // Direct message\n    direct: !!direct ? direct : undefined,\n    modified: now,\n    name: !!name ? name : undefined,\n    // Users\n    users: !!users ? users : undefined\n  };\n\n  const insert: any = {\n    ...cloneDeep(update),\n    _key: formatId,\n    added: now\n  };\n\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${id}}\n    INSERT ${insert}\n    UPDATE ${update}\n    IN conversations RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversation: ConversationType = {}) => conversation)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n"]}
|
|
226
|
+
|
|
227
|
+
exports.updateConversation = updateConversation;
|
|
228
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/conversations.ts"],"names":["eventCategory","getConversationList","context","from","to","action","database","sessionId","userId","limit","aqlQry","aql","query","then","cursor","all","catch","error","category","label","getDirectConversation","formatUserId","next","conversation","users","length","map","user","userKey","_key","imgId","thumbUrlData","directory","isThumb","type","typeId","name","thumb","getConversation","convoId","formatConvoId","updateConversation","item","identity","direct","id","rcpt","formatId","join","now","Date","update","undefined","modified","insert","added"],"mappings":"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","sourcesContent":["import {createHash, parseId} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport cloneDeep from 'lodash/cloneDeep';\nimport identity from 'lodash/identity';\nimport isEmpty from 'lodash/isEmpty';\nimport pick from 'lodash/pick';\nimport {ApiContext} from 'types/auth';\n\nimport {ArangoDBLimit, ConversationType, ImageUrlData, UserType} from '../types';\nimport {getLimit, useDb} from '../utils';\nimport {logError} from '../utils/analytics';\nimport {getUrlImages} from './images';\nimport {getDisplayName} from './users';\n\n/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nconst eventCategory: string = 'conversations';\n\nexport const getConversationList = (context: ApiContext, from: number, to: number): Promise<ConversationType[]> => {\n  const action: string = 'getList';\n  const {database, userId: sessionId} = context;\n  const limit: ArangoDBLimit = getLimit(from, to);\n  const aqlQry: string = `FOR c IN conversations\n    FILTER POSITION(c.users, \"${sessionId}\", false)\n    LET u = (\n      FOR g IN c.users\n      FOR u IN users\n      FILTER g == u._key\n      RETURN {_key:u._key, first:u.first, last:u.last, name:u.name, email:u.email, username:u.username, photo:u.photo }\n    )\n    FILTER LENGTH(u) > 1\n    ${limit.aql}\n    RETURN {_key:c._key, name: c.name, direct: c.direct, users: u}`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getDirectConversation = (context: ApiContext, userId: string): Promise<ConversationType> => {\n  const action: string = 'getDirect';\n  const {database, userId: sessionId} = context;\n  const formatUserId: string = parseId(userId);\n\n  const aqlQry: AqlQuery = aql`FOR c IN conversations\n    FILTER LENGTH(c.users) == 2 &&\n    POSITION(c.users, ${sessionId}, false) &&\n    POSITION(c.users, ${formatUserId}, false)\n    LET u = (\n      FOR g IN c.users\n      FOR user IN users\n      FILTER user._key == g\n      RETURN user\n    )\n    LIMIT 1\n    RETURN MERGE(c, {users: u})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversation: ConversationType = {}) => {\n      const {users = []} = conversation;\n\n      if(users.length) {\n        conversation.users = users.map((user: UserType) => {\n          const {_key: userKey, imgId} = user;\n          const thumbUrlData: ImageUrlData = {\n            directory: 'images',\n            imgId,\n            isThumb: true,\n            type: 'users',\n            typeId: userKey\n          };\n          return {\n            ...user,\n            name: getDisplayName(user),\n            thumb: getUrlImages(thumbUrlData)\n          };\n        });\n      }\n\n      return conversation;\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getConversation = (context: ApiContext, convoId: string): Promise<ConversationType> => {\n  const action: string = 'getItem';\n  const {database, userId: sessionId} = context;\n  const formatConvoId: string = parseId(convoId);\n\n  const aqlQry: AqlQuery = aql`FOR c IN conversations\n    FILTER c._key == ${formatConvoId} && IS_LIST(c.users) && POSITION(c.users, ${sessionId}, false)\n    LET u = (\n      FOR g IN c.users\n      FOR u IN users\n      FILTER g == u._key\n      RETURN {_key:u._key, first:u.first, last:u.last, name:u.name, email:u.email, username:u.username, photo:u.photo }\n    )\n    FILTER LENGTH(u) > 1\n    LIMIT 1\n    RETURN MERGE(c, {users: u})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversation: ConversationType = {}) => {\n      if(!isEmpty(conversation)) {\n        conversation.users = conversation.users.map((user: UserType) => {\n          const {_key: userKey, imgId} = user;\n          const thumbUrlData: ImageUrlData = {\n            directory: 'images',\n            imgId,\n            isThumb: true,\n            type: 'users',\n            typeId: userKey\n          };\n          return {\n            ...user,\n            name: getDisplayName(user),\n            thumb: getUrlImages(thumbUrlData)\n          };\n        });\n\n        return conversation;\n      }\n      return {};\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const updateConversation = (context: ApiContext, item): Promise<ConversationType> => {\n  const action: string = 'update';\n  const {database, userId: sessionId} = context;\n  const {direct, id, name, users} = pick(item, identity);\n  const rcpt: UserType[] = users || [];\n  const formatId: string = item.id || createHash(`convo-${sessionId}-${rcpt.join('')}`);\n  const now: number = Date.now();\n  const update: any = {\n    // Direct message\n    direct: !!direct ? direct : undefined,\n    modified: now,\n    name: !!name ? name : undefined,\n    // Users\n    users: !!users ? users : undefined\n  };\n\n  const insert: any = {\n    ...cloneDeep(update),\n    _key: formatId,\n    added: now\n  };\n\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${id}}\n    INSERT ${insert}\n    UPDATE ${update}\n    IN conversations RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversation: ConversationType = {}) => conversation)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n"]}
|
package/lib/data/dynamodb.js
CHANGED
|
@@ -1,18 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.parseDynamo = exports.dynamoDel = exports.dynamoPutList = exports.dynamoUpdate = exports.dynamoPut = exports.dynamoGetList = exports.dynamoGet = void 0;
|
|
7
|
+
|
|
8
|
+
var _awsSdk = _interopRequireWildcard(require("aws-sdk"));
|
|
9
|
+
|
|
10
|
+
var _config = require("../config");
|
|
11
|
+
|
|
12
|
+
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj.default = obj; return newObj; } }
|
|
13
|
+
|
|
1
14
|
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === 'function') { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _defineProperty(target, key, source[key]); }); } return target; }
|
|
2
15
|
|
|
3
16
|
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
4
17
|
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
* Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
|
|
8
|
-
*/
|
|
9
|
-
import aws, { DynamoDB } from 'aws-sdk';
|
|
10
|
-
import { Config } from '../config'; // const eventCategory: string = 'dynamodb';
|
|
11
|
-
|
|
12
|
-
export var dynamoGet = function dynamoGet(params) {
|
|
18
|
+
// const eventCategory: string = 'dynamodb';
|
|
19
|
+
var dynamoGet = function dynamoGet(params) {
|
|
13
20
|
return new Promise(function (resolve, reject) {
|
|
14
|
-
|
|
15
|
-
|
|
21
|
+
_awsSdk.default.config.update(_config.Config.get('aws'));
|
|
22
|
+
|
|
23
|
+
var dynamodb = new _awsSdk.DynamoDB();
|
|
16
24
|
params.ConsistentRead = false;
|
|
17
25
|
dynamodb.getItem(params, function (error, results) {
|
|
18
26
|
if (error) {
|
|
@@ -23,10 +31,14 @@ export var dynamoGet = function dynamoGet(params) {
|
|
|
23
31
|
});
|
|
24
32
|
});
|
|
25
33
|
};
|
|
26
|
-
|
|
34
|
+
|
|
35
|
+
exports.dynamoGet = dynamoGet;
|
|
36
|
+
|
|
37
|
+
var dynamoGetList = function dynamoGetList(params, index) {
|
|
27
38
|
return new Promise(function (resolve, reject) {
|
|
28
|
-
|
|
29
|
-
|
|
39
|
+
_awsSdk.default.config.update(_config.Config.get('aws'));
|
|
40
|
+
|
|
41
|
+
var dynamodb = new _awsSdk.DynamoDB();
|
|
30
42
|
var consistentRead = params.ConsistentRead;
|
|
31
43
|
|
|
32
44
|
var updatedParams = _objectSpread({}, params);
|
|
@@ -58,10 +70,14 @@ export var dynamoGetList = function dynamoGetList(params, index) {
|
|
|
58
70
|
});
|
|
59
71
|
});
|
|
60
72
|
};
|
|
61
|
-
|
|
73
|
+
|
|
74
|
+
exports.dynamoGetList = dynamoGetList;
|
|
75
|
+
|
|
76
|
+
var dynamoPut = function dynamoPut(params) {
|
|
62
77
|
return new Promise(function (resolve, reject) {
|
|
63
|
-
|
|
64
|
-
|
|
78
|
+
_awsSdk.default.config.update(_config.Config.get('aws'));
|
|
79
|
+
|
|
80
|
+
var dynamodb = new _awsSdk.DynamoDB();
|
|
65
81
|
dynamodb.putItem(params, function (error, output) {
|
|
66
82
|
if (error) {
|
|
67
83
|
return reject(error);
|
|
@@ -71,10 +87,14 @@ export var dynamoPut = function dynamoPut(params) {
|
|
|
71
87
|
});
|
|
72
88
|
});
|
|
73
89
|
};
|
|
74
|
-
|
|
90
|
+
|
|
91
|
+
exports.dynamoPut = dynamoPut;
|
|
92
|
+
|
|
93
|
+
var dynamoUpdate = function dynamoUpdate(params) {
|
|
75
94
|
return new Promise(function (resolve, reject) {
|
|
76
|
-
|
|
77
|
-
|
|
95
|
+
_awsSdk.default.config.update(_config.Config.get('aws'));
|
|
96
|
+
|
|
97
|
+
var dynamodb = new _awsSdk.DynamoDB();
|
|
78
98
|
dynamodb.updateItem(params, function (error, output) {
|
|
79
99
|
if (error) {
|
|
80
100
|
return reject(error);
|
|
@@ -84,10 +104,14 @@ export var dynamoUpdate = function dynamoUpdate(params) {
|
|
|
84
104
|
});
|
|
85
105
|
});
|
|
86
106
|
};
|
|
87
|
-
|
|
107
|
+
|
|
108
|
+
exports.dynamoUpdate = dynamoUpdate;
|
|
109
|
+
|
|
110
|
+
var dynamoPutList = function dynamoPutList(params) {
|
|
88
111
|
return new Promise(function (resolve, reject) {
|
|
89
|
-
|
|
90
|
-
|
|
112
|
+
_awsSdk.default.config.update(_config.Config.get('aws'));
|
|
113
|
+
|
|
114
|
+
var dynamodb = new _awsSdk.DynamoDB();
|
|
91
115
|
dynamodb.batchWriteItem(params, function (error, output) {
|
|
92
116
|
if (error) {
|
|
93
117
|
return reject(error);
|
|
@@ -97,10 +121,14 @@ export var dynamoPutList = function dynamoPutList(params) {
|
|
|
97
121
|
});
|
|
98
122
|
});
|
|
99
123
|
};
|
|
100
|
-
|
|
124
|
+
|
|
125
|
+
exports.dynamoPutList = dynamoPutList;
|
|
126
|
+
|
|
127
|
+
var dynamoDel = function dynamoDel(params) {
|
|
101
128
|
return new Promise(function (resolve, reject) {
|
|
102
|
-
|
|
103
|
-
|
|
129
|
+
_awsSdk.default.config.update(_config.Config.get('aws'));
|
|
130
|
+
|
|
131
|
+
var dynamodb = new _awsSdk.DynamoDB();
|
|
104
132
|
dynamodb.deleteItem(params, function (error, output) {
|
|
105
133
|
if (error) {
|
|
106
134
|
return reject(error);
|
|
@@ -110,7 +138,10 @@ export var dynamoDel = function dynamoDel(params) {
|
|
|
110
138
|
});
|
|
111
139
|
});
|
|
112
140
|
};
|
|
113
|
-
|
|
141
|
+
|
|
142
|
+
exports.dynamoDel = dynamoDel;
|
|
143
|
+
|
|
144
|
+
var parseDynamo = function parseDynamo(results) {
|
|
114
145
|
var items = results.Items;
|
|
115
146
|
var data = [];
|
|
116
147
|
|
|
@@ -136,4 +167,6 @@ export var parseDynamo = function parseDynamo(results) {
|
|
|
136
167
|
|
|
137
168
|
return data;
|
|
138
169
|
};
|
|
139
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/dynamodb.ts"],"names":["aws","DynamoDB","Config","dynamoGet","params","Promise","resolve","reject","config","update","get","dynamodb","ConsistentRead","getItem","error","results","dynamoGetList","index","consistentRead","updatedParams","ExclusiveStartKey","query","output","list","parseDynamo","lastKey","LastEvaluatedKey","undefined","dynamoPut","putItem","dynamoUpdate","updateItem","dynamoPutList","batchWriteItem","dynamoDel","deleteItem","items","Items","data","idx","len","length","tmp","obj","key","hasOwnProperty","S","toString","N","parseFloat","B","push"],"mappings":"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","sourcesContent":["/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport aws, {DynamoDB} from 'aws-sdk';\nimport {\n  BatchWriteItemInput,\n  BatchWriteItemOutput,\n  DeleteItemInput,\n  DeleteItemOutput,\n  GetItemInput,\n  GetItemOutput,\n  PutItemInput,\n  PutItemOutput,\n  QueryInput,\n  QueryOutput,\n  UpdateItemInput,\n  UpdateItemOutput\n} from 'aws-sdk/clients/dynamodb';\n\nimport {Config} from '../config';\n\n// const eventCategory: string = 'dynamodb';\n\nexport const dynamoGet = (params: GetItemInput): Promise<GetItemOutput> => {\n  return new Promise((resolve, reject) => {\n    aws.config.update(Config.get('aws'));\n    const dynamodb: DynamoDB = new DynamoDB();\n    params.ConsistentRead = false;\n\n    dynamodb.getItem(params, (error: Error, results: GetItemOutput) => {\n      if(error) {\n        return reject(error);\n      }\n\n      return resolve(results);\n    });\n  });\n};\n\nexport const dynamoGetList = (params: QueryInput, index): Promise<GetItemOutput[]> => {\n  return new Promise((resolve, reject) => {\n    aws.config.update(Config.get('aws'));\n    const dynamodb: DynamoDB = new DynamoDB();\n    const {ConsistentRead: consistentRead} = params;\n    const updatedParams = {...params};\n\n    if(index) {\n      updatedParams.ExclusiveStartKey = index;\n    }\n\n    if(!consistentRead) {\n      updatedParams.ConsistentRead = false;\n    }\n\n    dynamodb.query(updatedParams, (error: Error, output: QueryOutput) => {\n      if(error) {\n        return reject(error);\n      }\n      // Save list of items\n      const list: any[] = parseDynamo(output);\n      const {LastEvaluatedKey: lastKey} = output;\n\n      if(lastKey !== undefined) {\n        // Save last index before looping\n        return dynamoGetList(params, lastKey);\n      }\n\n      // Query complete, return final list\n      return resolve(list);\n    });\n  });\n};\n\nexport const dynamoPut = (params: PutItemInput): Promise<PutItemOutput> => {\n  return new Promise((resolve, reject) => {\n    aws.config.update(Config.get('aws'));\n    const dynamodb: DynamoDB = new DynamoDB();\n\n    dynamodb.putItem(params, (error, output: PutItemOutput) => {\n      if(error) {\n        return reject(error);\n      }\n      return resolve(output);\n    });\n  });\n};\n\nexport const dynamoUpdate = (params: UpdateItemInput): Promise<UpdateItemOutput> => {\n  return new Promise((resolve, reject) => {\n    aws.config.update(Config.get('aws'));\n    const dynamodb: DynamoDB = new DynamoDB();\n\n    dynamodb.updateItem(params, (error: Error, output: UpdateItemOutput) => {\n      if(error) {\n        return reject(error);\n      }\n      return resolve(output);\n    });\n  });\n};\n\nexport const dynamoPutList = (params: BatchWriteItemInput): Promise<BatchWriteItemOutput> => {\n  return new Promise((resolve, reject) => {\n    aws.config.update(Config.get('aws'));\n    const dynamodb: DynamoDB = new DynamoDB();\n\n    dynamodb.batchWriteItem(params, (error: Error, output: BatchWriteItemOutput) => {\n      if(error) {\n        return reject(error);\n      }\n      return resolve(output);\n    });\n  });\n};\n\nexport const dynamoDel = (params: DeleteItemInput): Promise<DeleteItemOutput> => {\n  return new Promise((resolve, reject) => {\n    aws.config.update(Config.get('aws'));\n    const dynamodb: DynamoDB = new DynamoDB();\n\n    dynamodb.deleteItem(params, (error, output: DeleteItemOutput) => {\n      if(error) {\n        return reject(error);\n      }\n      return resolve(output);\n    });\n  });\n};\n\nexport const parseDynamo = (results: QueryOutput): any[] => {\n  const {Items: items} = results;\n  const data: any[] = [];\n\n  for(let idx: number = 0, len = items.length; idx < len; idx++) {\n    const tmp = items[idx];\n    const obj = {};\n    let key;\n\n    for(key in tmp) {\n      if(tmp.hasOwnProperty(key)) {\n        if(tmp[key].S) {\n          obj[key] = tmp[key].S.toString();\n        } else if(tmp[key].N) {\n          obj[key] = parseFloat(tmp[key].N);\n        } else {\n          obj[key] = tmp[key].B;\n        }\n      }\n    }\n\n    data.push(obj);\n  }\n\n  return data;\n};\n\n"]}
|
|
170
|
+
|
|
171
|
+
exports.parseDynamo = parseDynamo;
|
|
172
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/dynamodb.ts"],"names":["dynamoGet","params","Promise","resolve","reject","aws","config","update","Config","get","dynamodb","DynamoDB","ConsistentRead","getItem","error","results","dynamoGetList","index","consistentRead","updatedParams","ExclusiveStartKey","query","output","list","parseDynamo","lastKey","LastEvaluatedKey","undefined","dynamoPut","putItem","dynamoUpdate","updateItem","dynamoPutList","batchWriteItem","dynamoDel","deleteItem","items","Items","data","idx","len","length","tmp","obj","key","hasOwnProperty","S","toString","N","parseFloat","B","push"],"mappings":"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","sourcesContent":["/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport aws, {DynamoDB} from 'aws-sdk';\nimport {\n  BatchWriteItemInput,\n  BatchWriteItemOutput,\n  DeleteItemInput,\n  DeleteItemOutput,\n  GetItemInput,\n  GetItemOutput,\n  PutItemInput,\n  PutItemOutput,\n  QueryInput,\n  QueryOutput,\n  UpdateItemInput,\n  UpdateItemOutput\n} from 'aws-sdk/clients/dynamodb';\n\nimport {Config} from '../config';\n\n// const eventCategory: string = 'dynamodb';\n\nexport const dynamoGet = (params: GetItemInput): Promise<GetItemOutput> => {\n  return new Promise((resolve, reject) => {\n    aws.config.update(Config.get('aws'));\n    const dynamodb: DynamoDB = new DynamoDB();\n    params.ConsistentRead = false;\n\n    dynamodb.getItem(params, (error: Error, results: GetItemOutput) => {\n      if(error) {\n        return reject(error);\n      }\n\n      return resolve(results);\n    });\n  });\n};\n\nexport const dynamoGetList = (params: QueryInput, index): Promise<GetItemOutput[]> => {\n  return new Promise((resolve, reject) => {\n    aws.config.update(Config.get('aws'));\n    const dynamodb: DynamoDB = new DynamoDB();\n    const {ConsistentRead: consistentRead} = params;\n    const updatedParams = {...params};\n\n    if(index) {\n      updatedParams.ExclusiveStartKey = index;\n    }\n\n    if(!consistentRead) {\n      updatedParams.ConsistentRead = false;\n    }\n\n    dynamodb.query(updatedParams, (error: Error, output: QueryOutput) => {\n      if(error) {\n        return reject(error);\n      }\n      // Save list of items\n      const list: any[] = parseDynamo(output);\n      const {LastEvaluatedKey: lastKey} = output;\n\n      if(lastKey !== undefined) {\n        // Save last index before looping\n        return dynamoGetList(params, lastKey);\n      }\n\n      // Query complete, return final list\n      return resolve(list);\n    });\n  });\n};\n\nexport const dynamoPut = (params: PutItemInput): Promise<PutItemOutput> => {\n  return new Promise((resolve, reject) => {\n    aws.config.update(Config.get('aws'));\n    const dynamodb: DynamoDB = new DynamoDB();\n\n    dynamodb.putItem(params, (error, output: PutItemOutput) => {\n      if(error) {\n        return reject(error);\n      }\n      return resolve(output);\n    });\n  });\n};\n\nexport const dynamoUpdate = (params: UpdateItemInput): Promise<UpdateItemOutput> => {\n  return new Promise((resolve, reject) => {\n    aws.config.update(Config.get('aws'));\n    const dynamodb: DynamoDB = new DynamoDB();\n\n    dynamodb.updateItem(params, (error: Error, output: UpdateItemOutput) => {\n      if(error) {\n        return reject(error);\n      }\n      return resolve(output);\n    });\n  });\n};\n\nexport const dynamoPutList = (params: BatchWriteItemInput): Promise<BatchWriteItemOutput> => {\n  return new Promise((resolve, reject) => {\n    aws.config.update(Config.get('aws'));\n    const dynamodb: DynamoDB = new DynamoDB();\n\n    dynamodb.batchWriteItem(params, (error: Error, output: BatchWriteItemOutput) => {\n      if(error) {\n        return reject(error);\n      }\n      return resolve(output);\n    });\n  });\n};\n\nexport const dynamoDel = (params: DeleteItemInput): Promise<DeleteItemOutput> => {\n  return new Promise((resolve, reject) => {\n    aws.config.update(Config.get('aws'));\n    const dynamodb: DynamoDB = new DynamoDB();\n\n    dynamodb.deleteItem(params, (error, output: DeleteItemOutput) => {\n      if(error) {\n        return reject(error);\n      }\n      return resolve(output);\n    });\n  });\n};\n\nexport const parseDynamo = (results: QueryOutput): any[] => {\n  const {Items: items} = results;\n  const data: any[] = [];\n\n  for(let idx: number = 0, len = items.length; idx < len; idx++) {\n    const tmp = items[idx];\n    const obj = {};\n    let key;\n\n    for(key in tmp) {\n      if(tmp.hasOwnProperty(key)) {\n        if(tmp[key].S) {\n          obj[key] = tmp[key].S.toString();\n        } else if(tmp[key].N) {\n          obj[key] = parseFloat(tmp[key].N);\n        } else {\n          obj[key] = tmp[key].B;\n        }\n      }\n    }\n\n    data.push(obj);\n  }\n\n  return data;\n};\n\n"]}
|