@nlabs/reaktor 0.1.2 → 0.1.4
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/.DS_Store +0 -0
- package/.eslintrc +18 -0
- package/lib/config.d.ts +21 -0
- package/lib/config.js +130 -0
- package/lib/data/conversations.d.ts +6 -0
- package/lib/data/conversations.js +197 -0
- package/lib/data/dynamodb.d.ts +8 -0
- package/lib/data/dynamodb.js +139 -0
- package/lib/data/email.d.ts +7 -0
- package/lib/data/email.js +163 -0
- package/lib/data/files.d.ts +16 -0
- package/lib/data/files.js +406 -0
- package/lib/data/groups.d.ts +13 -0
- package/lib/data/groups.js +354 -0
- package/lib/data/images.d.ts +12 -0
- package/lib/data/images.js +667 -0
- package/{src/data/index.ts → lib/data/index.d.ts} +1 -5
- package/lib/data/index.js +24 -0
- package/lib/data/ios.d.ts +6 -0
- package/lib/data/ios.js +302 -0
- package/lib/data/locations.d.ts +3 -0
- package/lib/data/locations.js +132 -0
- package/lib/data/messages.d.ts +9 -0
- package/lib/data/messages.js +248 -0
- package/lib/data/notifications.d.ts +5 -0
- package/lib/data/notifications.js +42 -0
- package/lib/data/payments.d.ts +11 -0
- package/lib/data/payments.js +748 -0
- package/lib/data/posts.d.ts +22 -0
- package/lib/data/posts.js +579 -0
- package/lib/data/reactions.d.ts +6 -0
- package/lib/data/reactions.js +218 -0
- package/lib/data/s3.d.ts +6 -0
- package/lib/data/s3.js +103 -0
- package/lib/data/search.d.ts +3 -0
- package/lib/data/search.js +98 -0
- package/lib/data/sms.d.ts +3 -0
- package/lib/data/sms.js +59 -0
- package/lib/data/subscription.d.ts +7 -0
- package/lib/data/subscription.js +284 -0
- package/lib/data/tags.d.ts +14 -0
- package/lib/data/tags.js +304 -0
- package/lib/data/users.d.ts +12 -0
- package/lib/data/users.js +310 -0
- package/lib/index.d.ts +3 -0
- package/lib/index.js +8 -0
- package/lib/types/apps.d.ts +43 -0
- package/lib/types/apps.js +2 -0
- package/lib/types/arangodb.d.ts +17 -0
- package/lib/types/arangodb.js +2 -0
- package/lib/types/auth.d.ts +10 -0
- package/lib/types/auth.js +2 -0
- package/lib/types/conversations.d.ts +6 -0
- package/lib/types/conversations.js +2 -0
- package/lib/types/email.d.ts +12 -0
- package/lib/types/email.js +2 -0
- package/lib/types/files.d.ts +26 -0
- package/lib/types/files.js +2 -0
- package/lib/types/google.d.ts +27 -0
- package/lib/types/google.js +2 -0
- package/lib/types/groups.d.ts +21 -0
- package/lib/types/groups.js +2 -0
- package/lib/types/images.d.ts +24 -0
- package/lib/types/images.js +2 -0
- package/{src/types/index.ts → lib/types/index.d.ts} +0 -4
- package/lib/types/index.js +22 -0
- package/lib/types/locations.d.ts +20 -0
- package/lib/types/locations.js +2 -0
- package/lib/types/messages.d.ts +12 -0
- package/lib/types/messages.js +2 -0
- package/lib/types/notifications.d.ts +19 -0
- package/lib/types/notifications.js +2 -0
- package/lib/types/payments.d.ts +114 -0
- package/lib/types/payments.js +2 -0
- package/lib/types/posts.d.ts +28 -0
- package/lib/types/posts.js +2 -0
- package/lib/types/reactions.d.ts +4 -0
- package/lib/types/reactions.js +2 -0
- package/lib/types/tags.d.ts +9 -0
- package/lib/types/tags.js +2 -0
- package/lib/types/users.d.ts +78 -0
- package/lib/types/users.js +2 -0
- package/lib/utils/analytics.d.ts +3 -0
- package/lib/utils/analytics.js +47 -0
- package/lib/utils/arangodb.d.ts +9 -0
- package/lib/utils/arangodb.js +98 -0
- package/lib/utils/auth.d.ts +7 -0
- package/lib/utils/auth.js +80 -0
- package/lib/utils/graphql.d.ts +1 -0
- package/lib/utils/graphql.js +7 -0
- package/{src/utils/index.ts → lib/utils/index.d.ts} +0 -4
- package/lib/utils/index.js +11 -0
- package/lib/utils/objects.d.ts +3 -0
- package/lib/utils/objects.js +34 -0
- package/lib/utils/redis.d.ts +1 -0
- package/lib/utils/redis.js +15 -0
- package/package.json +8 -7
- package/.vscode/extensions.json +0 -15
- package/.vscode/settings.json +0 -82
- package/lex.config.js +0 -4
- package/src/config.ts +0 -127
- package/src/data/conversations.ts +0 -181
- package/src/data/dynamodb.ts +0 -157
- package/src/data/email.ts +0 -163
- package/src/data/files.ts +0 -352
- package/src/data/groups.ts +0 -308
- package/src/data/images.ts +0 -606
- package/src/data/ios.ts +0 -249
- package/src/data/locations.ts +0 -114
- package/src/data/messages.ts +0 -237
- package/src/data/notifications.ts +0 -48
- package/src/data/payments.ts +0 -675
- package/src/data/posts.ts +0 -580
- package/src/data/reactions.ts +0 -186
- package/src/data/s3.ts +0 -117
- package/src/data/search.ts +0 -74
- package/src/data/sms.ts +0 -60
- package/src/data/subscription.ts +0 -228
- package/src/data/tags.ts +0 -230
- package/src/data/users.ts +0 -254
- package/src/index.ts +0 -7
- package/src/types/apps.ts +0 -56
- package/src/types/arangodb.ts +0 -23
- package/src/types/auth.ts +0 -20
- package/src/types/conversations.ts +0 -11
- package/src/types/email.ts +0 -17
- package/src/types/files.ts +0 -31
- package/src/types/google.ts +0 -37
- package/src/types/groups.ts +0 -27
- package/src/types/images.ts +0 -32
- package/src/types/locations.ts +0 -24
- package/src/types/messages.ts +0 -16
- package/src/types/notifications.ts +0 -26
- package/src/types/payments.ts +0 -129
- package/src/types/posts.ts +0 -34
- package/src/types/reactions.ts +0 -8
- package/src/types/tags.ts +0 -13
- package/src/types/users.ts +0 -89
- package/src/utils/analytics.ts +0 -41
- package/src/utils/arangodb.ts +0 -100
- package/src/utils/auth.ts +0 -61
- package/src/utils/graphql.ts +0 -7
- package/src/utils/objects.ts +0 -34
- package/src/utils/redis.ts +0 -17
- package/tsconfig.json +0 -45
|
@@ -0,0 +1,248 @@
|
|
|
1
|
+
function _templateObject5() {
|
|
2
|
+
var data = _taggedTemplateLiteral(["FOR m IN messages\n FILTER m.added < DATE_TIMESTAMP(DATE_SUBTRACT(DATE_NOW(), 60, 'day')) && LENGTH(m.saved) > 0\n REMOVE m IN messages\n RETURN OLD"]);
|
|
3
|
+
|
|
4
|
+
_templateObject5 = function _templateObject5() {
|
|
5
|
+
return data;
|
|
6
|
+
};
|
|
7
|
+
|
|
8
|
+
return data;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
function _templateObject4() {
|
|
12
|
+
var data = _taggedTemplateLiteral(["FOR m IN messages\n FILTER m._key == ", " && m.to == ", " && m.from == ", "\n REMOVE m IN messages\n RETURN OLD"]);
|
|
13
|
+
|
|
14
|
+
_templateObject4 = function _templateObject4() {
|
|
15
|
+
return data;
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
return data;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
function _templateObject3() {
|
|
22
|
+
var data = _taggedTemplateLiteral(["FOR m IN messages\n FILTER m._key == ", " && m.to == ", "\n UPDATE m WITH {saved: REMOVE_VALUE(m.saved, ", ")} IN messages\n RETURN NEW"]);
|
|
23
|
+
|
|
24
|
+
_templateObject3 = function _templateObject3() {
|
|
25
|
+
return data;
|
|
26
|
+
};
|
|
27
|
+
|
|
28
|
+
return data;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
function _templateObject2() {
|
|
32
|
+
var data = _taggedTemplateLiteral(["FOR m IN messages\n FILTER m._key == ", " && m.to == ", "\n UPDATE m WITH {saved: APPEND(m.saved, ", ", true)} IN messages\n RETURN NEW"]);
|
|
33
|
+
|
|
34
|
+
_templateObject2 = function _templateObject2() {
|
|
35
|
+
return data;
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
return data;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
function _templateObject() {
|
|
42
|
+
var data = _taggedTemplateLiteral(["UPSERT {_key: ", ", to: ", "}\n INSERT ", "\n UPDATE ", "\n IN messages RETURN NEW"]);
|
|
43
|
+
|
|
44
|
+
_templateObject = function _templateObject() {
|
|
45
|
+
return data;
|
|
46
|
+
};
|
|
47
|
+
|
|
48
|
+
return data;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
|
|
52
|
+
|
|
53
|
+
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; }
|
|
54
|
+
|
|
55
|
+
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; }
|
|
56
|
+
|
|
57
|
+
/**
|
|
58
|
+
* Copyright (c) 2019-Present, Nitrogen Labs, Inc.
|
|
59
|
+
* Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
|
|
60
|
+
*/
|
|
61
|
+
import { createHash, parseId, parseVarChar } from '@nlabs/utils';
|
|
62
|
+
import { aql } from 'arangojs';
|
|
63
|
+
import cloneDeep from 'lodash/cloneDeep';
|
|
64
|
+
import isEmpty from 'lodash/isEmpty';
|
|
65
|
+
import { getLimit, useDb } from '../utils';
|
|
66
|
+
import { getConversation } from './conversations'; // const eventCategory: string = 'messages';
|
|
67
|
+
|
|
68
|
+
export var getMessageList = function getMessageList(context, convoId, from, to) {
|
|
69
|
+
var database = context.database;
|
|
70
|
+
var formatConvoId = parseId(convoId);
|
|
71
|
+
return getConversation(context, formatConvoId).then(function (conversation) {
|
|
72
|
+
var conversationKey = conversation._key;
|
|
73
|
+
var limit = getLimit(from, to);
|
|
74
|
+
var aqlQry = "FOR m IN messages\n FILTER m.to == \"".concat(conversationKey, "\"\n ").concat(limit.aql, "\n SORT m.added\n RETURN m");
|
|
75
|
+
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
76
|
+
return cursor.all();
|
|
77
|
+
}).catch(function (error) {
|
|
78
|
+
throw error;
|
|
79
|
+
});
|
|
80
|
+
});
|
|
81
|
+
};
|
|
82
|
+
export var updateMessage = function updateMessage(context, message) {
|
|
83
|
+
var database = context.database,
|
|
84
|
+
sessionId = context.userId;
|
|
85
|
+
var files = message.files,
|
|
86
|
+
messageId = message.id,
|
|
87
|
+
toId = message.toId;
|
|
88
|
+
var formatToId = parseId(toId);
|
|
89
|
+
|
|
90
|
+
if (formatToId === '') {
|
|
91
|
+
throw new Error('required_to');
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
return getConversation(context, formatToId).then(function (conversation) {
|
|
95
|
+
var conversationKey = conversation._key;
|
|
96
|
+
var now = new Date().getTime();
|
|
97
|
+
var update = {
|
|
98
|
+
content: parseVarChar(message.content, 640),
|
|
99
|
+
files: files || [],
|
|
100
|
+
fromId: sessionId,
|
|
101
|
+
modified: now,
|
|
102
|
+
toId: formatToId
|
|
103
|
+
};
|
|
104
|
+
var formatId = parseId(messageId);
|
|
105
|
+
var updatedId = formatId === '' ? createHash("message-".concat(sessionId)) : formatId;
|
|
106
|
+
|
|
107
|
+
var insert = _objectSpread({}, cloneDeep(update), {
|
|
108
|
+
_key: updatedId,
|
|
109
|
+
added: now
|
|
110
|
+
});
|
|
111
|
+
|
|
112
|
+
var aqlQry = aql(_templateObject(), updatedId, conversationKey, insert, update);
|
|
113
|
+
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
114
|
+
return cursor.next();
|
|
115
|
+
}).then(function () {
|
|
116
|
+
var updatedMessage = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
117
|
+
return (// const {
|
|
118
|
+
// _key: msgId,
|
|
119
|
+
// added: msgAdded,
|
|
120
|
+
// content: msgContent,
|
|
121
|
+
// files: msgFiles,
|
|
122
|
+
// fromId: msgFromId,
|
|
123
|
+
// read: msgRead,
|
|
124
|
+
// saved: msgSaved,
|
|
125
|
+
// toId: msgToId
|
|
126
|
+
// } = updatedMessage;
|
|
127
|
+
// Broadcast to message box
|
|
128
|
+
// if(io) {
|
|
129
|
+
// const msg: MessageType = {
|
|
130
|
+
// added: msgAdded,
|
|
131
|
+
// content: msgContent,
|
|
132
|
+
// files: msgFiles,
|
|
133
|
+
// fromId: msgFromId,
|
|
134
|
+
// id: msgId,
|
|
135
|
+
// read: msgRead,
|
|
136
|
+
// saved: msgSaved,
|
|
137
|
+
// toId: msgToId
|
|
138
|
+
// };
|
|
139
|
+
// io.to(msgToId).emit('message_update', msg);
|
|
140
|
+
// }
|
|
141
|
+
updatedMessage
|
|
142
|
+
);
|
|
143
|
+
}).catch(function (error) {
|
|
144
|
+
throw error;
|
|
145
|
+
});
|
|
146
|
+
});
|
|
147
|
+
};
|
|
148
|
+
export var saveMessage = function saveMessage(context, msgId, convoId) {
|
|
149
|
+
var database = context.database,
|
|
150
|
+
sessionId = context.userId;
|
|
151
|
+
var formatId = parseId(msgId);
|
|
152
|
+
return getConversation(context, convoId).then(function (conversation) {
|
|
153
|
+
var conversationKey = conversation._key;
|
|
154
|
+
var aqlQry = aql(_templateObject2(), formatId, conversationKey, sessionId);
|
|
155
|
+
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
156
|
+
return cursor.next();
|
|
157
|
+
}).then(function () {
|
|
158
|
+
var message = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
159
|
+
|
|
160
|
+
if (!isEmpty(message)) {// Broadcast to message box
|
|
161
|
+
// const msg: MessageType = Messages.getMessageObject(message);
|
|
162
|
+
// io.to(message.toId).emit('message_save', msg);
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
return message;
|
|
166
|
+
}).catch(function (error) {
|
|
167
|
+
throw error;
|
|
168
|
+
});
|
|
169
|
+
});
|
|
170
|
+
};
|
|
171
|
+
export var unsaveMessage = function unsaveMessage(context, msgId, convoId) {
|
|
172
|
+
var database = context.database,
|
|
173
|
+
sessionId = context.userId;
|
|
174
|
+
var formatId = parseId(msgId);
|
|
175
|
+
return getConversation(context, convoId).then(function (conversation) {
|
|
176
|
+
var conversationKey = conversation._key;
|
|
177
|
+
var aqlQry = aql(_templateObject3(), formatId, conversationKey, sessionId);
|
|
178
|
+
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
179
|
+
return cursor.next();
|
|
180
|
+
}).then(function () {
|
|
181
|
+
var message = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
182
|
+
|
|
183
|
+
if (!isEmpty(message)) {// Broadcast to message box
|
|
184
|
+
// const msg: MessageType = Messages.getMessageObject(message);
|
|
185
|
+
// io.to(message.id).emit('message_unsave', msg);
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
return message;
|
|
189
|
+
}).catch(function (error) {
|
|
190
|
+
throw error;
|
|
191
|
+
});
|
|
192
|
+
});
|
|
193
|
+
};
|
|
194
|
+
export var deleteMessage = function deleteMessage(context, msgId, convoId) {
|
|
195
|
+
var database = context.database,
|
|
196
|
+
sessionId = context.userId;
|
|
197
|
+
var formatId = parseId(msgId);
|
|
198
|
+
return getConversation(context, convoId).then(function (conversation) {
|
|
199
|
+
var conversationKey = conversation._key;
|
|
200
|
+
var aqlQry = aql(_templateObject4(), formatId, conversationKey, sessionId);
|
|
201
|
+
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
202
|
+
return cursor.next();
|
|
203
|
+
}).then(function () {
|
|
204
|
+
var message = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
205
|
+
|
|
206
|
+
if (!isEmpty(message)) {// Broadcast to message box
|
|
207
|
+
// const msg: MessageType = Messages.getMessageObject(message);
|
|
208
|
+
// io.to(message.toId).emit('message_delete', msg);
|
|
209
|
+
}
|
|
210
|
+
|
|
211
|
+
return message;
|
|
212
|
+
}).catch(function (error) {
|
|
213
|
+
throw error;
|
|
214
|
+
});
|
|
215
|
+
});
|
|
216
|
+
};
|
|
217
|
+
export var getMessage = function getMessage(data) {
|
|
218
|
+
var msgAdded = data.added,
|
|
219
|
+
msgContent = data.content,
|
|
220
|
+
msgFiles = data.files,
|
|
221
|
+
msgFromId = data.fromId,
|
|
222
|
+
msgId = data._key,
|
|
223
|
+
msgRead = data.read,
|
|
224
|
+
msgSaved = data.saved,
|
|
225
|
+
msgToId = data.toId;
|
|
226
|
+
return {
|
|
227
|
+
added: msgAdded,
|
|
228
|
+
content: msgContent,
|
|
229
|
+
files: msgFiles,
|
|
230
|
+
fromId: msgFromId,
|
|
231
|
+
id: msgId,
|
|
232
|
+
read: msgRead,
|
|
233
|
+
saved: msgSaved,
|
|
234
|
+
toId: msgToId
|
|
235
|
+
};
|
|
236
|
+
};
|
|
237
|
+
export var cleanMessages = function cleanMessages(database) {
|
|
238
|
+
// Remove all messages that are over 60 days and not saved
|
|
239
|
+
var aqlQry = aql(_templateObject5());
|
|
240
|
+
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
241
|
+
return cursor.all();
|
|
242
|
+
}).then(function (list) {
|
|
243
|
+
return list.length;
|
|
244
|
+
}).catch(function (error) {
|
|
245
|
+
throw error;
|
|
246
|
+
});
|
|
247
|
+
};
|
|
248
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/messages.ts"],"names":["createHash","parseId","parseVarChar","aql","cloneDeep","isEmpty","getLimit","useDb","getConversation","getMessageList","context","convoId","from","to","database","formatConvoId","then","conversation","conversationKey","_key","limit","aqlQry","query","cursor","all","catch","error","updateMessage","message","sessionId","userId","files","messageId","id","toId","formatToId","Error","now","Date","getTime","update","content","fromId","modified","formatId","updatedId","insert","added","next","updatedMessage","saveMessage","msgId","unsaveMessage","deleteMessage","getMessage","data","msgAdded","msgContent","msgFiles","msgFromId","msgRead","read","msgSaved","saved","msgToId","cleanMessages","list","length"],"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 {createHash, parseId, parseVarChar} 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 isEmpty from 'lodash/isEmpty';\n\nimport {ArangoDBLimit} from '../types/arangodb';\nimport {ApiContext} from '../types/auth';\nimport {ConversationType} from '../types/conversations';\nimport {MessageType} from '../types/messages';\nimport {getLimit, useDb} from '../utils';\nimport {getConversation} from './conversations';\n\n// const eventCategory: string = 'messages';\n\nexport const getMessageList = (context: ApiContext, convoId: string, from: number, to: number): Promise<MessageType[]> => {\n  const {database} = context;\n  const formatConvoId: string = parseId(convoId);\n\n  return getConversation(context, formatConvoId)\n    .then((conversation: ConversationType) => {\n      const {_key: conversationKey} = conversation;\n      const limit: ArangoDBLimit = getLimit(from, to);\n      const aqlQry: string = `FOR m IN messages\n          FILTER m.to == \"${conversationKey}\"\n          ${limit.aql}\n          SORT m.added\n          RETURN m`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.all())\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n}\n\nexport const updateMessage = (context: ApiContext, message: MessageType): Promise<MessageType> => {\n  const {database, userId: sessionId} = context;\n  const {files, id: messageId, toId} = message;\n  const formatToId: string = parseId(toId);\n\n  if(formatToId === '') {\n    throw new Error('required_to');\n  }\n\n  return getConversation(context, formatToId)\n    .then((conversation: ConversationType) => {\n      const {_key: conversationKey} = conversation;\n      const now: number = (new Date()).getTime();\n      const update: MessageType = {\n        content: parseVarChar(message.content, 640),\n        files: files || [],\n        fromId: sessionId,\n        modified: now,\n        toId: formatToId\n      };\n      const formatId: string = parseId(messageId);\n      const updatedId: string = formatId === '' ? createHash(`message-${sessionId}`) : formatId;\n      const insert: MessageType = {\n        ...cloneDeep(update),\n        _key: updatedId,\n        added: now\n      };\n      const aqlQry: AqlQuery = aql`UPSERT {_key: ${updatedId}, to: ${conversationKey}}\n          INSERT ${insert}\n          UPDATE ${update}\n          IN messages RETURN NEW`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((updatedMessage: MessageType = {}) =>\n          // const {\n          //   _key: msgId,\n          //   added: msgAdded,\n          //   content: msgContent,\n          //   files: msgFiles,\n          //   fromId: msgFromId,\n          //   read: msgRead,\n          //   saved: msgSaved,\n          //   toId: msgToId\n          // } = updatedMessage;\n\n          // Broadcast to message box\n          // if(io) {\n          //   const msg: MessageType = {\n          //     added: msgAdded,\n          //     content: msgContent,\n          //     files: msgFiles,\n          //     fromId: msgFromId,\n          //     id: msgId,\n          //     read: msgRead,\n          //     saved: msgSaved,\n          //     toId: msgToId\n          //   };\n\n          //   io.to(msgToId).emit('message_update', msg);\n          // }\n\n          updatedMessage\n        )\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n}\n\nexport const saveMessage = (context: ApiContext, msgId: string, convoId: string): Promise<MessageType> => {\n  const {database, userId: sessionId} = context;\n  const formatId: string = parseId(msgId);\n\n  return getConversation(context, convoId)\n    .then((conversation: ConversationType) => {\n      const {_key: conversationKey} = conversation;\n      const aqlQry = aql`FOR m IN messages\n        FILTER m._key == ${formatId} && m.to == ${conversationKey}\n        UPDATE m WITH {saved: APPEND(m.saved, ${sessionId}, true)} IN messages\n        RETURN NEW`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((message: MessageType = {}) => {\n          if(!isEmpty(message)) {\n            // Broadcast to message box\n            // const msg: MessageType = Messages.getMessageObject(message);\n            // io.to(message.toId).emit('message_save', msg);\n          }\n\n          return message;\n        })\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n}\n\nexport const unsaveMessage = (context: ApiContext, msgId: string, convoId: string): Promise<MessageType> => {\n  const {database, userId: sessionId} = context;\n  const formatId: string = parseId(msgId);\n\n  return getConversation(context, convoId)\n    .then((conversation: ConversationType) => {\n      const {_key: conversationKey} = conversation;\n      const aqlQry: AqlQuery = aql`FOR m IN messages\n          FILTER m._key == ${formatId} && m.to == ${conversationKey}\n          UPDATE m WITH {saved: REMOVE_VALUE(m.saved, ${sessionId})} IN messages\n          RETURN NEW`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((message: MessageType = {}) => {\n          if(!isEmpty(message)) {\n            // Broadcast to message box\n            // const msg: MessageType = Messages.getMessageObject(message);\n            // io.to(message.id).emit('message_unsave', msg);\n          }\n\n          return message;\n        })\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n};\n\nexport const deleteMessage = (context: ApiContext, msgId: string, convoId: string): Promise<MessageType> => {\n  const {database, userId: sessionId} = context;\n  const formatId: string = parseId(msgId);\n\n  return getConversation(context, convoId)\n    .then((conversation: ConversationType) => {\n      const {_key: conversationKey} = conversation;\n      const aqlQry = aql`FOR m IN messages\n        FILTER m._key == ${formatId} && m.to == ${conversationKey} && m.from == ${sessionId}\n        REMOVE m IN messages\n        RETURN OLD`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.next())\n        .then((message: MessageType = {}) => {\n          if(!isEmpty(message)) {\n            // Broadcast to message box\n            // const msg: MessageType = Messages.getMessageObject(message);\n            // io.to(message.toId).emit('message_delete', msg);\n          }\n\n          return message;\n        })\n        .catch((error: Error) => {\n          throw error;\n        });\n    });\n};\n\nexport const getMessage = (data: MessageType): MessageType => {\n  const {\n    added: msgAdded,\n    content: msgContent,\n    files: msgFiles,\n    fromId: msgFromId,\n    _key: msgId,\n    read: msgRead,\n    saved: msgSaved,\n    toId: msgToId\n  } = data;\n\n  return {\n    added: msgAdded,\n    content: msgContent,\n    files: msgFiles,\n    fromId: msgFromId,\n    id: msgId,\n    read: msgRead,\n    saved: msgSaved,\n    toId: msgToId\n  };\n};\n\nexport const cleanMessages = (database: string): Promise<number> => {\n  // Remove all messages that are over 60 days and not saved\n  const aqlQry = aql`FOR m IN messages\n      FILTER m.added < DATE_TIMESTAMP(DATE_SUBTRACT(DATE_NOW(), 60, 'day')) && LENGTH(m.saved) > 0\n      REMOVE m IN messages\n      RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((list: MessageType[]) => list.length)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n"]}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { Provider, Responses } from 'apn';
|
|
2
|
+
import { NotificationType } from '../types/notifications';
|
|
3
|
+
export declare const getAPNProvider: () => Provider;
|
|
4
|
+
export declare const pushNotification: (deviceTokens: string[], note: NotificationType) => Promise<Responses>;
|
|
5
|
+
export declare const clearBadges: (deviceTokens: string[]) => Promise<Responses>;
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright (c) 2019-Present, Nitrogen Labs, Inc.
|
|
3
|
+
* Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
|
|
4
|
+
*/
|
|
5
|
+
import { Notification as APNNotification, Provider } from 'apn';
|
|
6
|
+
import { Config } from '../config';
|
|
7
|
+
// const eventCategory: string = 'notifications';
|
|
8
|
+
// Push Notifications
|
|
9
|
+
export var getAPNProvider = function getAPNProvider() {
|
|
10
|
+
return new Provider({
|
|
11
|
+
ca: Config.get('app.apn.ca'),
|
|
12
|
+
cert: Config.get('app.apn.cert'),
|
|
13
|
+
key: Config.get('app.apn.key'),
|
|
14
|
+
production: Config.get('environment') === 'production'
|
|
15
|
+
});
|
|
16
|
+
};
|
|
17
|
+
export var pushNotification = function pushNotification(deviceTokens, note) {
|
|
18
|
+
// Push notification to device
|
|
19
|
+
var provider = getAPNProvider();
|
|
20
|
+
var notification = new APNNotification();
|
|
21
|
+
notification.topic = Config.get('app.apn.id');
|
|
22
|
+
notification.alert = note.message;
|
|
23
|
+
|
|
24
|
+
if (note.data) {
|
|
25
|
+
notification.mutableContent = true;
|
|
26
|
+
notification.payload = note.data;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
if (note.badge !== undefined) {
|
|
30
|
+
notification.badge = note.badge;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
return provider.send(notification, deviceTokens);
|
|
34
|
+
};
|
|
35
|
+
export var clearBadges = function clearBadges(deviceTokens) {
|
|
36
|
+
// Push notification to device
|
|
37
|
+
var provider = getAPNProvider();
|
|
38
|
+
var notification = new APNNotification();
|
|
39
|
+
notification.badge = 0;
|
|
40
|
+
return provider.send(notification, deviceTokens);
|
|
41
|
+
};
|
|
42
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9kYXRhL25vdGlmaWNhdGlvbnMudHMiXSwibmFtZXMiOlsiTm90aWZpY2F0aW9uIiwiQVBOTm90aWZpY2F0aW9uIiwiUHJvdmlkZXIiLCJDb25maWciLCJnZXRBUE5Qcm92aWRlciIsImNhIiwiZ2V0IiwiY2VydCIsImtleSIsInByb2R1Y3Rpb24iLCJwdXNoTm90aWZpY2F0aW9uIiwiZGV2aWNlVG9rZW5zIiwibm90ZSIsInByb3ZpZGVyIiwibm90aWZpY2F0aW9uIiwidG9waWMiLCJhbGVydCIsIm1lc3NhZ2UiLCJkYXRhIiwibXV0YWJsZUNvbnRlbnQiLCJwYXlsb2FkIiwiYmFkZ2UiLCJ1bmRlZmluZWQiLCJzZW5kIiwiY2xlYXJCYWRnZXMiXSwibWFwcGluZ3MiOiJBQUFBOzs7O0FBSUEsU0FBUUEsWUFBWSxJQUFJQyxlQUF4QixFQUF5Q0MsUUFBekMsUUFBbUUsS0FBbkU7QUFFQSxTQUFRQyxNQUFSLFFBQXFCLFdBQXJCO0FBR0E7QUFFQTtBQUNBLE9BQU8sSUFBTUMsY0FBYyxHQUFHLFNBQWpCQSxjQUFpQixHQUFnQjtBQUM1QyxTQUFPLElBQUlGLFFBQUosQ0FBYTtBQUNsQkcsSUFBQUEsRUFBRSxFQUFFRixNQUFNLENBQUNHLEdBQVAsQ0FBVyxZQUFYLENBRGM7QUFFbEJDLElBQUFBLElBQUksRUFBRUosTUFBTSxDQUFDRyxHQUFQLENBQVcsY0FBWCxDQUZZO0FBR2xCRSxJQUFBQSxHQUFHLEVBQUVMLE1BQU0sQ0FBQ0csR0FBUCxDQUFXLGFBQVgsQ0FIYTtBQUlsQkcsSUFBQUEsVUFBVSxFQUFFTixNQUFNLENBQUNHLEdBQVAsQ0FBVyxhQUFYLE1BQThCO0FBSnhCLEdBQWIsQ0FBUDtBQU1ELENBUE07QUFTUCxPQUFPLElBQU1JLGdCQUFnQixHQUFHLFNBQW5CQSxnQkFBbUIsQ0FBQ0MsWUFBRCxFQUF5QkMsSUFBekIsRUFBd0U7QUFDdEc7QUFDQSxNQUFNQyxRQUFrQixHQUFHVCxjQUFjLEVBQXpDO0FBQ0EsTUFBTVUsWUFBNkIsR0FBRyxJQUFJYixlQUFKLEVBQXRDO0FBQ0FhLEVBQUFBLFlBQVksQ0FBQ0MsS0FBYixHQUFxQlosTUFBTSxDQUFDRyxHQUFQLENBQVcsWUFBWCxDQUFyQjtBQUNBUSxFQUFBQSxZQUFZLENBQUNFLEtBQWIsR0FBcUJKLElBQUksQ0FBQ0ssT0FBMUI7O0FBRUEsTUFBR0wsSUFBSSxDQUFDTSxJQUFSLEVBQWM7QUFDWkosSUFBQUEsWUFBWSxDQUFDSyxjQUFiLEdBQThCLElBQTlCO0FBQ0FMLElBQUFBLFlBQVksQ0FBQ00sT0FBYixHQUF1QlIsSUFBSSxDQUFDTSxJQUE1QjtBQUNEOztBQUVELE1BQUdOLElBQUksQ0FBQ1MsS0FBTCxLQUFlQyxTQUFsQixFQUE2QjtBQUMzQlIsSUFBQUEsWUFBWSxDQUFDTyxLQUFiLEdBQXFCVCxJQUFJLENBQUNTLEtBQTFCO0FBQ0Q7O0FBRUQsU0FBT1IsUUFBUSxDQUFDVSxJQUFULENBQWNULFlBQWQsRUFBNEJILFlBQTVCLENBQVA7QUFDRCxDQWpCTTtBQW1CUCxPQUFPLElBQU1hLFdBQVcsR0FBRyxTQUFkQSxXQUFjLENBQUNiLFlBQUQsRUFBZ0Q7QUFDekU7QUFDQSxNQUFNRSxRQUFRLEdBQUdULGNBQWMsRUFBL0I7QUFDQSxNQUFNVSxZQUFZLEdBQUcsSUFBSWIsZUFBSixFQUFyQjtBQUNBYSxFQUFBQSxZQUFZLENBQUNPLEtBQWIsR0FBcUIsQ0FBckI7QUFFQSxTQUFPUixRQUFRLENBQUNVLElBQVQsQ0FBY1QsWUFBZCxFQUE0QkgsWUFBNUIsQ0FBUDtBQUNELENBUE0iLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOS1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IHtOb3RpZmljYXRpb24gYXMgQVBOTm90aWZpY2F0aW9uLCBQcm92aWRlciwgUmVzcG9uc2VzfSBmcm9tICdhcG4nO1xuXG5pbXBvcnQge0NvbmZpZ30gZnJvbSAnLi4vY29uZmlnJztcbmltcG9ydCB7Tm90aWZpY2F0aW9uVHlwZX0gZnJvbSAnLi4vdHlwZXMvbm90aWZpY2F0aW9ucyc7XG5cbi8vIGNvbnN0IGV2ZW50Q2F0ZWdvcnk6IHN0cmluZyA9ICdub3RpZmljYXRpb25zJztcblxuLy8gUHVzaCBOb3RpZmljYXRpb25zXG5leHBvcnQgY29uc3QgZ2V0QVBOUHJvdmlkZXIgPSAoKTogUHJvdmlkZXIgPT4ge1xuICByZXR1cm4gbmV3IFByb3ZpZGVyKHtcbiAgICBjYTogQ29uZmlnLmdldCgnYXBwLmFwbi5jYScpLFxuICAgIGNlcnQ6IENvbmZpZy5nZXQoJ2FwcC5hcG4uY2VydCcpLFxuICAgIGtleTogQ29uZmlnLmdldCgnYXBwLmFwbi5rZXknKSxcbiAgICBwcm9kdWN0aW9uOiBDb25maWcuZ2V0KCdlbnZpcm9ubWVudCcpID09PSAncHJvZHVjdGlvbidcbiAgfSk7XG59O1xuXG5leHBvcnQgY29uc3QgcHVzaE5vdGlmaWNhdGlvbiA9IChkZXZpY2VUb2tlbnM6IHN0cmluZ1tdLCBub3RlOiBOb3RpZmljYXRpb25UeXBlKTogUHJvbWlzZTxSZXNwb25zZXM+ID0+IHtcbiAgLy8gUHVzaCBub3RpZmljYXRpb24gdG8gZGV2aWNlXG4gIGNvbnN0IHByb3ZpZGVyOiBQcm92aWRlciA9IGdldEFQTlByb3ZpZGVyKCk7XG4gIGNvbnN0IG5vdGlmaWNhdGlvbjogQVBOTm90aWZpY2F0aW9uID0gbmV3IEFQTk5vdGlmaWNhdGlvbigpO1xuICBub3RpZmljYXRpb24udG9waWMgPSBDb25maWcuZ2V0KCdhcHAuYXBuLmlkJyk7XG4gIG5vdGlmaWNhdGlvbi5hbGVydCA9IG5vdGUubWVzc2FnZTtcblxuICBpZihub3RlLmRhdGEpIHtcbiAgICBub3RpZmljYXRpb24ubXV0YWJsZUNvbnRlbnQgPSB0cnVlO1xuICAgIG5vdGlmaWNhdGlvbi5wYXlsb2FkID0gbm90ZS5kYXRhO1xuICB9XG5cbiAgaWYobm90ZS5iYWRnZSAhPT0gdW5kZWZpbmVkKSB7XG4gICAgbm90aWZpY2F0aW9uLmJhZGdlID0gbm90ZS5iYWRnZTtcbiAgfVxuXG4gIHJldHVybiBwcm92aWRlci5zZW5kKG5vdGlmaWNhdGlvbiwgZGV2aWNlVG9rZW5zKTtcbn07XG5cbmV4cG9ydCBjb25zdCBjbGVhckJhZGdlcyA9IChkZXZpY2VUb2tlbnM6IHN0cmluZ1tdKTogUHJvbWlzZTxSZXNwb25zZXM+ID0+IHtcbiAgLy8gUHVzaCBub3RpZmljYXRpb24gdG8gZGV2aWNlXG4gIGNvbnN0IHByb3ZpZGVyID0gZ2V0QVBOUHJvdmlkZXIoKTtcbiAgY29uc3Qgbm90aWZpY2F0aW9uID0gbmV3IEFQTk5vdGlmaWNhdGlvbigpO1xuICBub3RpZmljYXRpb24uYmFkZ2UgPSAwO1xuXG4gIHJldHVybiBwcm92aWRlci5zZW5kKG5vdGlmaWNhdGlvbiwgZGV2aWNlVG9rZW5zKTtcbn07XG4iXX0=
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { ApiContext, PaymentBankAccount, PaymentCardType, PaymentCharge, PaymentTransfer, UserType } from '../types';
|
|
2
|
+
export declare const addCustomerAccount: (context: ApiContext) => Promise<boolean>;
|
|
3
|
+
export declare const addPaymentAccountBank: (context: ApiContext, bankAccount: PaymentBankAccount) => Promise<boolean>;
|
|
4
|
+
export declare const addPaymentAccountCard: (context: ApiContext, card: PaymentCardType, requestData: any) => Promise<UserType>;
|
|
5
|
+
export declare const addCreditCard: (context: ApiContext, card: PaymentCardType) => Promise<PaymentCardType>;
|
|
6
|
+
export declare const updateCreditCard: (context: ApiContext, card: PaymentCardType) => Promise<PaymentCardType>;
|
|
7
|
+
export declare const getCreditCards: (context: ApiContext) => Promise<PaymentCardType[]>;
|
|
8
|
+
export declare const deleteCreditCard: (context: ApiContext, cardId: string) => Promise<boolean>;
|
|
9
|
+
export declare const deletePaymentAccountBank: (context: ApiContext, bankId: string) => Promise<boolean>;
|
|
10
|
+
export declare const createPaymentTransfer: (context: ApiContext, transfer: PaymentTransfer) => Promise<PaymentTransfer>;
|
|
11
|
+
export declare const createPaymentHold: (context: ApiContext, payment: PaymentCharge) => Promise<PaymentCharge>;
|