@nlabs/reaktor 0.3.0 → 0.4.0
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 +153 -0
- package/lib/data/conversations.js +311 -0
- package/lib/data/dynamodb.js +206 -0
- package/lib/data/email.js +222 -0
- package/lib/data/files.js +525 -0
- package/lib/data/groups.js +435 -0
- package/lib/data/images.d.ts +3 -2
- package/lib/data/images.js +1051 -0
- package/lib/data/index.js +266 -0
- package/lib/data/ios.js +355 -0
- package/lib/data/locations.js +172 -0
- package/lib/data/messages.js +299 -0
- package/lib/data/notifications.d.ts +2 -2
- package/lib/data/notifications.js +59 -0
- package/lib/data/payments.js +771 -0
- package/lib/data/posts.d.ts +1 -1
- package/lib/data/posts.js +766 -0
- package/lib/data/reactions.js +529 -0
- package/lib/data/s3.js +155 -0
- package/lib/data/search.js +155 -0
- package/lib/data/sms.js +83 -0
- package/lib/data/subscription.js +337 -0
- package/lib/data/tags.js +397 -0
- package/lib/data/users.d.ts +7 -4
- package/lib/data/users.js +470 -0
- package/lib/data/websockets.js +250 -0
- package/lib/index.js +45 -0
- package/lib/types/apps.js +2 -0
- package/lib/types/arangodb.js +2 -0
- package/lib/types/auth.js +2 -0
- package/lib/types/conversations.d.ts +2 -0
- package/lib/types/conversations.js +2 -0
- package/lib/types/email.js +2 -0
- package/lib/types/files.js +2 -0
- package/lib/types/google.js +2 -0
- package/lib/types/groups.js +2 -0
- package/lib/types/images.js +2 -0
- package/lib/types/index.js +227 -0
- package/lib/types/locations.js +2 -0
- package/lib/types/messages.js +2 -0
- package/lib/types/notifications.js +2 -0
- package/lib/types/payments.js +2 -0
- package/lib/types/posts.js +2 -0
- package/lib/types/reactions.d.ts +2 -0
- package/lib/types/reactions.js +2 -0
- package/lib/types/tags.js +2 -0
- package/lib/types/users.d.ts +1 -0
- package/lib/types/users.js +2 -0
- package/lib/utils/analytics.js +83 -0
- package/lib/utils/arangodb.js +143 -0
- package/lib/utils/auth.js +75 -0
- package/lib/utils/graphql.js +21 -0
- package/lib/utils/index.js +84 -0
- package/lib/utils/objects.js +62 -0
- package/lib/utils/redis.js +36 -0
- package/package.json +30 -30
package/lib/config.js
ADDED
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
require("core-js/modules/es.array.concat");
|
|
4
|
+
|
|
5
|
+
require("core-js/modules/es.array.iterator");
|
|
6
|
+
|
|
7
|
+
require("core-js/modules/es.object.define-property");
|
|
8
|
+
|
|
9
|
+
require("core-js/modules/es.object.to-string");
|
|
10
|
+
|
|
11
|
+
require("core-js/modules/web.dom-collections.iterator");
|
|
12
|
+
|
|
13
|
+
Object.defineProperty(exports, "__esModule", {
|
|
14
|
+
value: true
|
|
15
|
+
});
|
|
16
|
+
exports.Config = void 0;
|
|
17
|
+
|
|
18
|
+
var _get2 = _interopRequireDefault(require("lodash/get"));
|
|
19
|
+
|
|
20
|
+
var _merge = _interopRequireDefault(require("lodash/merge"));
|
|
21
|
+
|
|
22
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
23
|
+
|
|
24
|
+
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|
25
|
+
|
|
26
|
+
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); } }
|
|
27
|
+
|
|
28
|
+
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
|
|
29
|
+
|
|
30
|
+
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; }
|
|
31
|
+
|
|
32
|
+
var appPackage = require('../package.json');
|
|
33
|
+
|
|
34
|
+
var _process$env = process.env,
|
|
35
|
+
_process$env$arangodb = _process$env.arangodbDatabase,
|
|
36
|
+
arangodbDatabase = _process$env$arangodb === void 0 ? 'reaktor' : _process$env$arangodb,
|
|
37
|
+
arangodbPassword = _process$env.arangodbPassword,
|
|
38
|
+
_process$env$arangodb2 = _process$env.arangodbPort,
|
|
39
|
+
arangodbPort = _process$env$arangodb2 === void 0 ? '8529' : _process$env$arangodb2,
|
|
40
|
+
_process$env$arangodb3 = _process$env.arangodbUrl,
|
|
41
|
+
arangodbUrl = _process$env$arangodb3 === void 0 ? 'db.reaktor.io' : _process$env$arangodb3,
|
|
42
|
+
_process$env$arangodb4 = _process$env.arangodbUsername,
|
|
43
|
+
arangodbUsername = _process$env$arangodb4 === void 0 ? 'reaktor' : _process$env$arangodb4;
|
|
44
|
+
|
|
45
|
+
var Config = /*#__PURE__*/function () {
|
|
46
|
+
function Config() {
|
|
47
|
+
_classCallCheck(this, Config);
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
_createClass(Config, null, [{
|
|
51
|
+
key: "get",
|
|
52
|
+
value: function get(path) {
|
|
53
|
+
var environment = process.env.stage || 'dev';
|
|
54
|
+
var configValues = (0, _merge["default"])(this.values["default"], this.values[environment], {
|
|
55
|
+
environment: environment
|
|
56
|
+
});
|
|
57
|
+
return (0, _get2["default"])(configValues, path);
|
|
58
|
+
}
|
|
59
|
+
}]);
|
|
60
|
+
|
|
61
|
+
return Config;
|
|
62
|
+
}();
|
|
63
|
+
|
|
64
|
+
exports.Config = Config;
|
|
65
|
+
|
|
66
|
+
_defineProperty(Config, "values", {
|
|
67
|
+
"default": {
|
|
68
|
+
app: {
|
|
69
|
+
name: 'reaktor',
|
|
70
|
+
url: 'reaktor.io',
|
|
71
|
+
version: appPackage.version
|
|
72
|
+
},
|
|
73
|
+
arangodb: {
|
|
74
|
+
database: arangodbDatabase,
|
|
75
|
+
dump: '/Applications/ArangoDB-CLI.app/Contents/MacOS/arangodump',
|
|
76
|
+
password: arangodbPassword,
|
|
77
|
+
port: arangodbPort,
|
|
78
|
+
restore: '/Applications/ArangoDB-CLI.app/Contents/MacOS/arangorestore',
|
|
79
|
+
url: "".concat(arangodbUrl, ":").concat(arangodbPort),
|
|
80
|
+
username: arangodbUsername
|
|
81
|
+
},
|
|
82
|
+
aws: {
|
|
83
|
+
Bucket: 'dev.reaktor.io',
|
|
84
|
+
accessKeyId: 'AKIAJIYDT3EA2ZFMTJNA',
|
|
85
|
+
maxRetries: 3,
|
|
86
|
+
region: 'us-east-1',
|
|
87
|
+
secretAccessKey: 'bUssQRtJTZC7geF9RDH5KCn8CalVnf2VT34yqS+9',
|
|
88
|
+
signatureVersion: 'v4'
|
|
89
|
+
},
|
|
90
|
+
giphy: {
|
|
91
|
+
key: 'dc6zaTOxFJmzC'
|
|
92
|
+
},
|
|
93
|
+
google: {
|
|
94
|
+
analytics: {
|
|
95
|
+
accountId: '78158717',
|
|
96
|
+
trackingId: 'UA-78158717-1'
|
|
97
|
+
},
|
|
98
|
+
geocode: {
|
|
99
|
+
key: 'AIzaSyBwjmpBjWhiJoBCZiYzRurM9m4WnCxslv0',
|
|
100
|
+
url: 'https://maps.googleapis.com/maps/api/geocode/json'
|
|
101
|
+
},
|
|
102
|
+
key: 'AIzaSyC3_f2Us3y0qjbyMJ-4t5ObtCzfq_FHIgQ'
|
|
103
|
+
},
|
|
104
|
+
image: {
|
|
105
|
+
imgQuality: 90,
|
|
106
|
+
imgSize: 1500,
|
|
107
|
+
thmQuality: 80,
|
|
108
|
+
thmSize: 150
|
|
109
|
+
},
|
|
110
|
+
redis: {
|
|
111
|
+
host: '127.0.0.1',
|
|
112
|
+
port: 6379
|
|
113
|
+
},
|
|
114
|
+
stripe: {
|
|
115
|
+
token: 'sk_test_LS956be57YUXTB5a4sLGb5BQ'
|
|
116
|
+
},
|
|
117
|
+
twilio: {
|
|
118
|
+
number: '+15005550006',
|
|
119
|
+
sid: 'AC6bd7f513cbed2e5134c650be06cc732e',
|
|
120
|
+
token: '520ae739e761bab759b147f1ad28278f'
|
|
121
|
+
}
|
|
122
|
+
},
|
|
123
|
+
dev: {
|
|
124
|
+
aws: {
|
|
125
|
+
Bucket: 'dev.reaktor.io'
|
|
126
|
+
},
|
|
127
|
+
redis: {
|
|
128
|
+
host: 'nl-redis.ehcvnt.ng.0001.use1.cache.amazonaws.com'
|
|
129
|
+
}
|
|
130
|
+
},
|
|
131
|
+
prod: {
|
|
132
|
+
arangodb: {
|
|
133
|
+
dump: '/usr/bin/arangodump',
|
|
134
|
+
restore: '/usr/bin/arangorestore'
|
|
135
|
+
},
|
|
136
|
+
aws: {
|
|
137
|
+
Bucket: 'box.reaktor.io'
|
|
138
|
+
},
|
|
139
|
+
redis: {
|
|
140
|
+
host: 'nl-redis.ehcvnt.ng.0001.use1.cache.amazonaws.com'
|
|
141
|
+
},
|
|
142
|
+
stripe: {
|
|
143
|
+
token: 'sk_live_bElZl8RLhMCJy33KG4lyLD4o'
|
|
144
|
+
},
|
|
145
|
+
twilio: {
|
|
146
|
+
number: '+18554165227',
|
|
147
|
+
sid: 'AC90b0528a911e652d643329a4d7b4d2c7',
|
|
148
|
+
token: 'a7941d173bd4846d0966a186e9865b72'
|
|
149
|
+
}
|
|
150
|
+
},
|
|
151
|
+
test: {}
|
|
152
|
+
});
|
|
153
|
+
//# 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","app","name","url","version","arangodb","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","dev","prod","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 dev: AppConfig;\n  readonly prod: 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        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}:${arangodbPort}`,\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    dev: {\n      aws: {\n        Bucket: 'dev.reaktor.io'\n      },\n      redis: {\n        host: 'nl-redis.ehcvnt.ng.0001.use1.cache.amazonaws.com'\n      }\n    },\n    prod: {\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: 'nl-redis.ehcvnt.ng.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 || 'dev';\n    const configValues: object = merge(this.values.default, this.values[environment], {environment});\n    return get(configValues, path);\n  }\n}\n"]}
|
|
@@ -0,0 +1,311 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
require("core-js/modules/es.symbol");
|
|
4
|
+
|
|
5
|
+
require("core-js/modules/es.array.concat");
|
|
6
|
+
|
|
7
|
+
require("core-js/modules/es.array.filter");
|
|
8
|
+
|
|
9
|
+
require("core-js/modules/es.array.for-each");
|
|
10
|
+
|
|
11
|
+
require("core-js/modules/es.array.map");
|
|
12
|
+
|
|
13
|
+
require("core-js/modules/es.array.slice");
|
|
14
|
+
|
|
15
|
+
require("core-js/modules/es.date.now");
|
|
16
|
+
|
|
17
|
+
require("core-js/modules/es.date.to-string");
|
|
18
|
+
|
|
19
|
+
require("core-js/modules/es.function.name");
|
|
20
|
+
|
|
21
|
+
require("core-js/modules/es.object.define-properties");
|
|
22
|
+
|
|
23
|
+
require("core-js/modules/es.object.define-property");
|
|
24
|
+
|
|
25
|
+
require("core-js/modules/es.object.freeze");
|
|
26
|
+
|
|
27
|
+
require("core-js/modules/es.object.get-own-property-descriptor");
|
|
28
|
+
|
|
29
|
+
require("core-js/modules/es.object.get-own-property-descriptors");
|
|
30
|
+
|
|
31
|
+
require("core-js/modules/es.object.keys");
|
|
32
|
+
|
|
33
|
+
require("core-js/modules/es.string.sub");
|
|
34
|
+
|
|
35
|
+
require("core-js/modules/web.dom-collections.for-each");
|
|
36
|
+
|
|
37
|
+
Object.defineProperty(exports, "__esModule", {
|
|
38
|
+
value: true
|
|
39
|
+
});
|
|
40
|
+
exports.removeUserToConversation = exports.addUserToConversation = exports.updateConversation = exports.getConversation = exports.getDirectConversation = exports.getConversationList = void 0;
|
|
41
|
+
|
|
42
|
+
var _utils = require("@nlabs/utils");
|
|
43
|
+
|
|
44
|
+
var _arangojs = require("arangojs");
|
|
45
|
+
|
|
46
|
+
var _cloneDeep = _interopRequireDefault(require("lodash/cloneDeep"));
|
|
47
|
+
|
|
48
|
+
var _isEmpty = _interopRequireDefault(require("lodash/isEmpty"));
|
|
49
|
+
|
|
50
|
+
var _utils2 = require("../utils");
|
|
51
|
+
|
|
52
|
+
var _analytics = require("../utils/analytics");
|
|
53
|
+
|
|
54
|
+
var _images = require("./images");
|
|
55
|
+
|
|
56
|
+
var _users = require("./users");
|
|
57
|
+
|
|
58
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
59
|
+
|
|
60
|
+
function _templateObject5() {
|
|
61
|
+
var data = _taggedTemplateLiteral(["FOR c IN hasConversations\n FILTER c._from == ", " && c._to == ", "\n LIMIT 1\n REMOVE c IN hasConversations\n RETURN OLD"]);
|
|
62
|
+
|
|
63
|
+
_templateObject5 = function _templateObject5() {
|
|
64
|
+
return data;
|
|
65
|
+
};
|
|
66
|
+
|
|
67
|
+
return data;
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
function _templateObject4() {
|
|
71
|
+
var data = _taggedTemplateLiteral(["FOR c IN hasConversations\n FILTER c._from == ", " && c._to == ", "\n LIMIT 1\n RETURN c"]);
|
|
72
|
+
|
|
73
|
+
_templateObject4 = function _templateObject4() {
|
|
74
|
+
return data;
|
|
75
|
+
};
|
|
76
|
+
|
|
77
|
+
return data;
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
function _templateObject3() {
|
|
81
|
+
var data = _taggedTemplateLiteral(["UPSERT {_key: ", " }\n INSERT ", "\n UPDATE ", "\n IN conversations RETURN NEW"]);
|
|
82
|
+
|
|
83
|
+
_templateObject3 = function _templateObject3() {
|
|
84
|
+
return data;
|
|
85
|
+
};
|
|
86
|
+
|
|
87
|
+
return data;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
|
|
91
|
+
|
|
92
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
93
|
+
|
|
94
|
+
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; }
|
|
95
|
+
|
|
96
|
+
function _templateObject2() {
|
|
97
|
+
var data = _taggedTemplateLiteral(["FOR c, e IN 1..1 OUTBOUND ", " hasConversations\n FILTER c._id == ", "\n LET u = (\n FOR inUser, inEdge IN 1..1 INBOUND ", " hasConversations\n RETURN inUser\n )\n LIMIT 1\n RETURN MERGE(c, {users: u})"]);
|
|
98
|
+
|
|
99
|
+
_templateObject2 = function _templateObject2() {
|
|
100
|
+
return data;
|
|
101
|
+
};
|
|
102
|
+
|
|
103
|
+
return data;
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
function _templateObject() {
|
|
107
|
+
var data = _taggedTemplateLiteral(["LET from = (\n FOR c, e IN 1..1 OUTBOUND ", " hasConversations\n FILTER c.direct == true\n RETURN c\n )\n LET to = (\n FOR c, e IN 1..1 OUTBOUND ", " hasConversations\n FILTER c.direct == true\n RETURN c\n )\n LET conversation = FIRST(INTERSECTION(from, to))\n LET users = !IS_NULL(conversation) && (\n FOR g IN[", ", ", "]\n FOR u IN users\n FILTER g == u._id\n RETURN u\n )\n RETURN IS_NULL(conversation) ? null : MERGE(conversation, {users: users})"]);
|
|
108
|
+
|
|
109
|
+
_templateObject = function _templateObject() {
|
|
110
|
+
return data;
|
|
111
|
+
};
|
|
112
|
+
|
|
113
|
+
return data;
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
|
|
117
|
+
|
|
118
|
+
var eventCategory = 'conversations';
|
|
119
|
+
|
|
120
|
+
var getConversationList = function getConversationList(context, from, to) {
|
|
121
|
+
var action = 'getList';
|
|
122
|
+
var database = context.database,
|
|
123
|
+
sessionId = context.userId;
|
|
124
|
+
var limit = (0, _utils2.getLimit)(from, to);
|
|
125
|
+
var sessionDocId = "users/".concat(sessionId);
|
|
126
|
+
var aqlQry = "FOR c, e IN 1..1 OUTBOUND \"".concat(sessionDocId, "\" hasConversations\n ").concat(limit.aql, "\n LET users = (\n FOR u, uc IN 1..1 INBOUND c._id hasConversations\n FILTER u._id != \"").concat(sessionDocId, "\"\n RETURN u\n )\n RETURN MERGE(c, {users: users})");
|
|
127
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
128
|
+
return cursor.all();
|
|
129
|
+
})["catch"](function (error) {
|
|
130
|
+
return (0, _analytics.logError)({
|
|
131
|
+
action: action,
|
|
132
|
+
category: eventCategory,
|
|
133
|
+
label: 'db_error'
|
|
134
|
+
}, error, context).then(function () {
|
|
135
|
+
return null;
|
|
136
|
+
});
|
|
137
|
+
});
|
|
138
|
+
};
|
|
139
|
+
|
|
140
|
+
exports.getConversationList = getConversationList;
|
|
141
|
+
|
|
142
|
+
var getDirectConversation = function getDirectConversation(context, userId) {
|
|
143
|
+
var action = 'getDirectConversation';
|
|
144
|
+
var database = context.database,
|
|
145
|
+
sessionId = context.userId;
|
|
146
|
+
var sessionDocId = "users/".concat(sessionId);
|
|
147
|
+
var userDocId = "users/".concat((0, _utils.parseId)(userId));
|
|
148
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject(), sessionDocId, userDocId, sessionDocId, userDocId);
|
|
149
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
150
|
+
return cursor.next();
|
|
151
|
+
})["catch"](function (error) {
|
|
152
|
+
return (0, _analytics.logError)({
|
|
153
|
+
action: action,
|
|
154
|
+
category: eventCategory,
|
|
155
|
+
label: 'db_error'
|
|
156
|
+
}, error, context).then(function () {
|
|
157
|
+
return null;
|
|
158
|
+
});
|
|
159
|
+
});
|
|
160
|
+
};
|
|
161
|
+
|
|
162
|
+
exports.getDirectConversation = getDirectConversation;
|
|
163
|
+
|
|
164
|
+
var getConversation = function getConversation(context, convoId) {
|
|
165
|
+
var action = 'getItem';
|
|
166
|
+
var database = context.database,
|
|
167
|
+
sessionId = context.userId;
|
|
168
|
+
var sessionDocId = "users/".concat(sessionId);
|
|
169
|
+
var convoDocId = "conversations/".concat((0, _utils.parseId)(convoId));
|
|
170
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject2(), sessionDocId, convoDocId, convoDocId);
|
|
171
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
172
|
+
return cursor.next();
|
|
173
|
+
}).then(function () {
|
|
174
|
+
var conversation = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
175
|
+
|
|
176
|
+
if (!(0, _isEmpty["default"])(conversation)) {
|
|
177
|
+
conversation.users = conversation.users.map(function (user) {
|
|
178
|
+
var imgId = user.imgId,
|
|
179
|
+
sub = user.sub;
|
|
180
|
+
var thumbUrlData = {
|
|
181
|
+
imgId: imgId,
|
|
182
|
+
isThumb: true,
|
|
183
|
+
sub: sub
|
|
184
|
+
};
|
|
185
|
+
return _objectSpread(_objectSpread({}, user), {}, {
|
|
186
|
+
name: (0, _users.getDisplayName)(user),
|
|
187
|
+
thumb: (0, _images.getUserImageUrl)(thumbUrlData)
|
|
188
|
+
});
|
|
189
|
+
});
|
|
190
|
+
return conversation;
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
return {};
|
|
194
|
+
})["catch"](function (error) {
|
|
195
|
+
return (0, _analytics.logError)({
|
|
196
|
+
action: action,
|
|
197
|
+
category: eventCategory,
|
|
198
|
+
label: 'db_error'
|
|
199
|
+
}, error, context).then(function () {
|
|
200
|
+
return null;
|
|
201
|
+
});
|
|
202
|
+
});
|
|
203
|
+
};
|
|
204
|
+
|
|
205
|
+
exports.getConversation = getConversation;
|
|
206
|
+
|
|
207
|
+
var updateConversation = function updateConversation(context, conversation) {
|
|
208
|
+
var action = 'updateConversation';
|
|
209
|
+
var database = context.database,
|
|
210
|
+
sessionId = context.userId;
|
|
211
|
+
var direct = conversation.direct,
|
|
212
|
+
_conversation$convoId = conversation.convoId,
|
|
213
|
+
convoId = _conversation$convoId === void 0 ? (0, _utils.createHash)("convo - ".concat(sessionId, " ")) : _conversation$convoId,
|
|
214
|
+
name = conversation.name;
|
|
215
|
+
var formatConvoId = (0, _utils.parseId)(convoId);
|
|
216
|
+
var now = Date.now();
|
|
217
|
+
var update = {
|
|
218
|
+
// Direct message
|
|
219
|
+
direct: direct,
|
|
220
|
+
modified: now,
|
|
221
|
+
name: name
|
|
222
|
+
};
|
|
223
|
+
|
|
224
|
+
var insert = _objectSpread(_objectSpread({}, (0, _cloneDeep["default"])(update)), {}, {
|
|
225
|
+
_key: formatConvoId,
|
|
226
|
+
added: now
|
|
227
|
+
});
|
|
228
|
+
|
|
229
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject3(), formatConvoId, insert, update);
|
|
230
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
231
|
+
return cursor.next();
|
|
232
|
+
}).then(function () {
|
|
233
|
+
var conversation = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
234
|
+
return conversation;
|
|
235
|
+
})["catch"](function (error) {
|
|
236
|
+
return (0, _analytics.logError)({
|
|
237
|
+
action: action,
|
|
238
|
+
category: eventCategory,
|
|
239
|
+
label: 'db_error'
|
|
240
|
+
}, error, context).then(function () {
|
|
241
|
+
return null;
|
|
242
|
+
});
|
|
243
|
+
});
|
|
244
|
+
};
|
|
245
|
+
|
|
246
|
+
exports.updateConversation = updateConversation;
|
|
247
|
+
|
|
248
|
+
var addUserToConversation = function addUserToConversation(context, convoId, userId) {
|
|
249
|
+
var action = 'addUserToConversation';
|
|
250
|
+
var database = context.database;
|
|
251
|
+
var formatConvoId = (0, _utils.parseId)(convoId);
|
|
252
|
+
var formatUserId = (0, _utils.parseId)(userId);
|
|
253
|
+
var convoDocId = "conversations/".concat(formatConvoId, " ");
|
|
254
|
+
var userDocId = "users/".concat(formatUserId, " ");
|
|
255
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject4(), userDocId, convoDocId);
|
|
256
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
257
|
+
return cursor.next();
|
|
258
|
+
}).then(function (conversationEdge) {
|
|
259
|
+
if (!!conversationEdge) {
|
|
260
|
+
return conversationEdge;
|
|
261
|
+
}
|
|
262
|
+
|
|
263
|
+
var edgeCollection = (0, _utils2.useDb)(database).collection('hasConversations');
|
|
264
|
+
var edgeId = (0, _utils.createHash)("convo - ".concat(formatConvoId, " -").concat(formatUserId, " "));
|
|
265
|
+
var edge = {
|
|
266
|
+
_from: userDocId,
|
|
267
|
+
_key: edgeId,
|
|
268
|
+
_to: convoDocId,
|
|
269
|
+
added: Date.now()
|
|
270
|
+
};
|
|
271
|
+
return edgeCollection.save(edge, {
|
|
272
|
+
returnNew: true
|
|
273
|
+
}).then(function () {
|
|
274
|
+
return edge;
|
|
275
|
+
});
|
|
276
|
+
})["catch"](function (error) {
|
|
277
|
+
return (0, _analytics.logError)({
|
|
278
|
+
action: action,
|
|
279
|
+
category: eventCategory,
|
|
280
|
+
label: 'db_error'
|
|
281
|
+
}, error, context).then(function () {
|
|
282
|
+
return null;
|
|
283
|
+
});
|
|
284
|
+
});
|
|
285
|
+
};
|
|
286
|
+
|
|
287
|
+
exports.addUserToConversation = addUserToConversation;
|
|
288
|
+
|
|
289
|
+
var removeUserToConversation = function removeUserToConversation(context, convoId, userId) {
|
|
290
|
+
var action = 'addUserToConversation';
|
|
291
|
+
var database = context.database;
|
|
292
|
+
var formatConvoId = (0, _utils.parseId)(convoId);
|
|
293
|
+
var formatUserId = (0, _utils.parseId)(userId);
|
|
294
|
+
var convoDocId = "conversations / ".concat(formatConvoId, " ");
|
|
295
|
+
var userDocId = "users/".concat(formatUserId, " ");
|
|
296
|
+
var aqlQry = (0, _arangojs.aql)(_templateObject5(), userDocId, convoDocId);
|
|
297
|
+
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
298
|
+
return cursor.next();
|
|
299
|
+
})["catch"](function (error) {
|
|
300
|
+
return (0, _analytics.logError)({
|
|
301
|
+
action: action,
|
|
302
|
+
category: eventCategory,
|
|
303
|
+
label: 'db_error'
|
|
304
|
+
}, error, context).then(function () {
|
|
305
|
+
return null;
|
|
306
|
+
});
|
|
307
|
+
});
|
|
308
|
+
};
|
|
309
|
+
|
|
310
|
+
exports.removeUserToConversation = removeUserToConversation;
|
|
311
|
+
//# 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","sessionDocId","aqlQry","aql","query","then","cursor","all","error","category","label","getDirectConversation","userDocId","next","getConversation","convoId","convoDocId","conversation","users","map","user","imgId","sub","thumbUrlData","isThumb","name","thumb","updateConversation","direct","formatConvoId","now","Date","update","modified","insert","_key","added","addUserToConversation","formatUserId","conversationEdge","edgeCollection","collection","edgeId","edge","_from","_to","save","returnNew","removeUserToConversation"],"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} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/aql';\nimport {EdgeCollection} from 'arangojs/collection';\nimport {ArrayCursor} from 'arangojs/cursor';\nimport cloneDeep from 'lodash/cloneDeep';\nimport isEmpty from 'lodash/isEmpty';\nimport {ApiContext} from 'types/auth';\n\nimport {ArangoDBLimit, ConversationType, ImageUrlData, UserType} from '../types';\nimport {getLimit, useDb} from '../utils';\nimport {logError} from '../utils/analytics';\nimport {getUserImageUrl} from './images';\nimport {getDisplayName} from './users';\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 sessionDocId: string = `users/${sessionId}`;\n  const aqlQry: string = `FOR c, e IN 1..1 OUTBOUND \"${sessionDocId}\" hasConversations\n    ${limit.aql}\n    LET users = (\n      FOR u, uc IN 1..1 INBOUND c._id hasConversations\n      FILTER u._id != \"${sessionDocId}\"\n      RETURN u\n    )\n    RETURN MERGE(c, {users: users})`;\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 = 'getDirectConversation';\n  const {database, userId: sessionId} = context;\n  const sessionDocId: string = `users/${sessionId}`;\n  const userDocId: string = `users/${parseId(userId)}`;\n\n  const aqlQry: AqlQuery = aql`LET from = (\n      FOR c, e IN 1..1 OUTBOUND ${sessionDocId} hasConversations\n      FILTER c.direct == true\n      RETURN c\n    )\n    LET to = (\n      FOR c, e IN 1..1 OUTBOUND ${userDocId} hasConversations\n      FILTER c.direct == true\n      RETURN c\n    )\n    LET conversation = FIRST(INTERSECTION(from, to))\n    LET users = !IS_NULL(conversation) && (\n      FOR g IN[${sessionDocId}, ${userDocId}]\n      FOR u IN users\n      FILTER g == u._id\n      RETURN u\n    )\n    RETURN IS_NULL(conversation) ? null : MERGE(conversation, {users: users})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\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 sessionDocId: string = `users/${sessionId}`;\n  const convoDocId: string = `conversations/${parseId(convoId)}`;\n\n  const aqlQry: AqlQuery = aql`FOR c, e IN 1..1 OUTBOUND ${sessionDocId} hasConversations\n    FILTER c._id == ${convoDocId}\n    LET u = (\n      FOR inUser, inEdge IN 1..1 INBOUND ${convoDocId} hasConversations\n      RETURN inUser\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      if(!isEmpty(conversation)) {\n        conversation.users = conversation.users.map((user: UserType) => {\n          const {imgId, sub} = user;\n          const thumbUrlData: ImageUrlData = {\n            imgId,\n            isThumb: true,\n            sub\n          };\n          return {\n            ...user,\n            name: getDisplayName(user),\n            thumb: getUserImageUrl(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, conversation): Promise<ConversationType> => {\n  const action: string = 'updateConversation';\n  const {database, userId: sessionId} = context;\n  const {\n    direct,\n    convoId = createHash(`convo - ${sessionId} `),\n    name\n  } = conversation;\n  const formatConvoId: string = parseId(convoId);\n  const now: number = Date.now();\n  const update: any = {\n    // Direct message\n    direct,\n    modified: now,\n    name\n  };\n\n  const insert: any = {\n    ...cloneDeep(update),\n    _key: formatConvoId,\n    added: now\n  };\n\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${formatConvoId} }\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\nexport const addUserToConversation = (context: ApiContext, convoId: string, userId: string) => {\n  const action: string = 'addUserToConversation';\n  const {database} = context;\n  const formatConvoId: string = parseId(convoId);\n  const formatUserId: string = parseId(userId);\n  const convoDocId: string = `conversations/${formatConvoId} `;\n  const userDocId: string = `users/${formatUserId} `;\n\n  const aqlQry: AqlQuery = aql`FOR c IN hasConversations\n    FILTER c._from == ${userDocId} && c._to == ${convoDocId}\n    LIMIT 1\n    RETURN c`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((conversationEdge) => {\n      if(!!conversationEdge) {\n        return conversationEdge;\n      }\n\n      const edgeCollection: EdgeCollection = useDb(database).collection('hasConversations');\n      const edgeId: string = createHash(`convo - ${formatConvoId} -${formatUserId} `);\n\n      const edge: ConversationType = {\n        _from: userDocId,\n        _key: edgeId,\n        _to: convoDocId,\n        added: Date.now()\n      };\n\n      return edgeCollection.save(edge, {returnNew: true}).then(() => edge);\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const removeUserToConversation = (context: ApiContext, convoId: string, userId: string) => {\n  const action: string = 'addUserToConversation';\n  const {database} = context;\n  const formatConvoId: string = parseId(convoId);\n  const formatUserId: string = parseId(userId);\n  const convoDocId: string = `conversations / ${formatConvoId} `;\n  const userDocId: string = `users/${formatUserId} `;\n\n  const aqlQry: AqlQuery = aql`FOR c IN hasConversations\n    FILTER c._from == ${userDocId} && c._to == ${convoDocId}\n    LIMIT 1\n    REMOVE c IN hasConversations\n    RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n"]}
|