@nlabs/reaktor 0.1.3 → 0.1.5

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/data/users.js CHANGED
@@ -1,6 +1,26 @@
1
- function _templateObject6() {
1
+ function _templateObject8() {
2
+ var data = _taggedTemplateLiteral(["FOR u, r IN INBOUND ", " hasRelation\n FILTER r._from == ", "\n LIMIT 1\n RETURN r"]);
3
+
4
+ _templateObject8 = function _templateObject8() {
5
+ return data;
6
+ };
7
+
8
+ return data;
9
+ }
10
+
11
+ function _templateObject7() {
2
12
  var data = _taggedTemplateLiteral(["FOR u, r IN INBOUND ", " hasRelation\n FILTER r._from == ", "\n RETURN r"]);
3
13
 
14
+ _templateObject7 = function _templateObject7() {
15
+ return data;
16
+ };
17
+
18
+ return data;
19
+ }
20
+
21
+ function _templateObject6() {
22
+ var data = _taggedTemplateLiteral(["FOR r IN hasRelation\n FILTER r.value == ", " && r._from == ", " && r._to == ", "\n LIMIT 1\n RETURN r"]);
23
+
4
24
  _templateObject6 = function _templateObject6() {
5
25
  return data;
6
26
  };
@@ -9,7 +29,7 @@ function _templateObject6() {
9
29
  }
10
30
 
11
31
  function _templateObject5() {
12
- var data = _taggedTemplateLiteral(["FOR r IN hasRelation\n FILTER r.value == ", " && r._from == ", " && r._to == ", "\n LIMIT 1\n RETURN r"]);
32
+ var data = _taggedTemplateLiteral(["FOR u IN users\n FILTER u._key == ", "\n LIMIT 1\n RETURN u"]);
13
33
 
14
34
  _templateObject5 = function _templateObject5() {
15
35
  return data;
@@ -150,12 +170,32 @@ export var deactivateUser = function deactivateUser(context, userId) {
150
170
  throw error;
151
171
  });
152
172
  };
173
+ export var getSessionUser = function getSessionUser(context) {
174
+ var action = 'getSessionUser';
175
+ var database = context.database,
176
+ sessionId = context.userId;
177
+ console.log('getSessionUser::sessionId', sessionId); // Get data from database
178
+
179
+ var aqlQry = aql(_templateObject4(), sessionId);
180
+ return useDb(database).query(aqlQry).then(function (cursor) {
181
+ return cursor.next();
182
+ }).then(function () {
183
+ var user = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
184
+ return user;
185
+ }).catch(function (error) {
186
+ return logError({
187
+ action: action,
188
+ category: eventCategory,
189
+ label: 'db_error'
190
+ }, error, context).then(function () {});
191
+ });
192
+ };
153
193
  export var getUser = function getUser(context, userId) {
154
194
  var action = 'getItem';
155
195
  var formatUserId = parseId(userId);
156
196
  var database = context.database; // Get data from database
157
197
 
158
- var aqlQry = aql(_templateObject4(), formatUserId);
198
+ var aqlQry = aql(_templateObject5(), formatUserId);
159
199
  return useDb(database).query(aqlQry).then(function (cursor) {
160
200
  return cursor.next();
161
201
  }).then(function () {
@@ -196,7 +236,7 @@ export var addUserRelation = function addUserRelation(context, userId, value) {
196
236
  var formatUserId = parseId(userId);
197
237
  var formatValue = parseChar(value, 32);
198
238
  var db = useDb(database);
199
- var aqlQry = aql(_templateObject5(), formatValue, sessionId, formatUserId);
239
+ var aqlQry = aql(_templateObject6(), formatValue, sessionId, formatUserId);
200
240
  return db.query(aqlQry).then(function (cursor) {
201
241
  return cursor.next();
202
242
  }).then(function (relation) {
@@ -274,7 +314,7 @@ export var getRelationsByUser = function getRelationsByUser(context, userId) {
274
314
  var database = context.database,
275
315
  sessionId = context.userId;
276
316
  var formatUserId = parseId(userId);
277
- var aqlQry = aql(_templateObject6(), "users/".concat(formatUserId), "users/".concat(sessionId));
317
+ var aqlQry = aql(_templateObject7(), "users/".concat(formatUserId), "users/".concat(sessionId));
278
318
  return useDb(database).query(aqlQry).then(function (cursor) {
279
319
  return cursor.all();
280
320
  }).catch(function (error) {
@@ -287,6 +327,24 @@ export var getRelationsByUser = function getRelationsByUser(context, userId) {
287
327
  });
288
328
  });
289
329
  };
330
+ export var getRelationship = function getRelationship(context, userId) {
331
+ var action = 'getRelationship';
332
+ var database = context.database,
333
+ sessionId = context.userId;
334
+ var formatUserId = parseId(userId);
335
+ var aqlQry = aql(_templateObject8(), "users/".concat(formatUserId), "users/".concat(sessionId));
336
+ return useDb(database).query(aqlQry).then(function (cursor) {
337
+ return cursor.next();
338
+ }).catch(function (error) {
339
+ return logError({
340
+ action: action,
341
+ category: eventCategory,
342
+ label: 'db_error'
343
+ }, error, context).then(function () {
344
+ return null;
345
+ });
346
+ });
347
+ };
290
348
  export var getDisplayName = function getDisplayName() {
291
349
  var user = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
292
350
  var first = user.first,
@@ -307,4 +365,4 @@ export var getDisplayName = function getDisplayName() {
307
365
 
308
366
  return 'Unknown';
309
367
  };
310
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/users.ts"],"names":["createHash","parseChar","parseEmail","parseId","parseUsername","parseVarChar","aql","isEmpty","stripe","getLimit","logError","logException","useDb","eventCategory","addUser","context","user","database","email","phone","sub","username","insert","_key","added","Date","now","undefined","modified","aqlQry","query","then","cursor","next","deleteUser","userId","action","sessionId","sessionType","userType","isAdmin","category","label","value","customers","del","stripeCustomerId","accounts","stripeAccountId","catch","error","deactivateUser","updated","getUser","formatUserId","getUserList","from","to","limit","all","addUserRelation","formatValue","db","relation","edgeId","edge","edgeCollection","save","deleteUserRelation","getUsersByRelations","type","formatType","getRelationsByUser","getDisplayName","first","last","name","fullname","join","trim"],"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, parseChar, parseEmail, parseId, parseUsername, parseVarChar} from '@nlabs/utils';\nimport {aql, Database, EdgeCollection} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport isEmpty from 'lodash/isEmpty';\nimport * as stripe from 'stripe';\n\nimport {ApiContext} from '../types/auth';\nimport {UserRelationType, UserType} from '../types/users';\nimport {getLimit, logError, logException, useDb} from '../utils';\n\nconst eventCategory: string = 'users';\n\nexport const addUser = (context: ApiContext, user: UserType): Promise<UserType> => {\n  const {database} = context;\n  const {email, phone, sub, username} = user;\n\n  // Add new user properties\n  const insert: UserType = {\n    _key: createHash(sub, null),\n    added: Date.now(),\n    email: email !== undefined ? parseEmail(email) : undefined,\n    modified: Date.now(),\n    phone: phone !== undefined ? parseVarChar(phone, 15) : undefined,\n    sub: parseVarChar(sub, 32),\n    username: parseUsername(username)\n  };\n\n  // Add new user in ArangoDB\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN users RETURN NEW`;\n  return useDb(database).query(aqlQry).then((cursor: ArrayCursor) => cursor.next());\n};\n\nexport const deleteUser = (context: ApiContext, userId: string): Promise<UserType> => {\n  const action: string = 'delete';\n  const {database, userId: sessionId, userType: sessionType} = context;\n  const isAdmin: boolean = sessionType > 2;\n\n  if(!isAdmin && (sessionId !== userId)) {\n    logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context);\n    return null;\n  }\n\n  const aqlQry: AqlQuery = aql`FOR u IN users\n      FILTER u._key == ${userId}\n      LIMIT 1\n      REMOVE u IN users\n      RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((user: UserType = {}) => stripe.customers.del(user.stripeCustomerId)\n      .then(() => stripe.accounts.del(user.stripeAccountId))\n      .then(() => user))\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const deactivateUser = (context: ApiContext, userId: string): Promise<UserType> => {\n  const action: string = 'delete';\n  const {database, userId: sessionId, userType: sessionType} = context;\n  const isAdmin: boolean = sessionType > 2;\n\n  if(!isAdmin && (sessionId !== userId)) {\n    logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context);\n    return null;\n  }\n\n  const updated: UserType = {\n    userType: 0\n  };\n  const aqlQry: AqlQuery = aql`UPDATE ${userId} WITH ${updated} IN users LIMIT 1 RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getUser = (context: ApiContext, userId): Promise<UserType> => {\n  const action: string = 'getItem';\n  const formatUserId: string = parseId(userId);\n  const {database} = context;\n\n  // Get data from database\n  const aqlQry = aql`FOR u IN users\n    FILTER u._key == ${formatUserId}\n    LIMIT 1\n    RETURN u`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((user = {}) => user)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => {}));\n};\n\nexport const getUserList = (context: ApiContext, from: number = 0, to: number = 15): Promise<UserType> => {\n  const action: string = 'getItem';\n  const {database} = context;\n  const limit = getLimit(from, to);\n\n  // Get data from database\n  const aqlQry: string = `FOR u IN users\n    ${limit.aql}\n    SORT u.username\n    RETURN 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(() => []));\n};\n\nexport const addUserRelation = (context: ApiContext, userId, value): Promise<UserRelationType> => {\n  const action: string = 'addRelation';\n  const {database, userId: sessionId} = context;\n  const formatUserId: string = parseId(userId);\n  const formatValue: string = parseChar(value, 32);\n  const db: Database = useDb(database);\n  const aqlQry = aql`FOR r IN hasRelation\n    FILTER r.value == ${formatValue} && r._from == ${sessionId} && r._to == ${formatUserId}\n    LIMIT 1\n    RETURN r`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((relation: UserRelationType) => {\n      // If a relationship between two users with the value exists, just return\n      if(relation) {\n        return relation;\n      }\n\n      // Otherwise, create the new relationship\n      const edgeId = createHash(`relation-${sessionId}-${formatUserId}-${formatValue}`);\n      const edge = {\n        _key: edgeId,\n        added: Date.now(),\n        value: formatValue\n      };\n      const edgeCollection: EdgeCollection = db.edgeCollection('hasRelation') as any;\n\n      return edgeCollection.save(edge, `users/${sessionId}`, `users/${formatUserId}`)\n        .then(() => edgeCollection.edge(edgeId))\n        .catch((error: Error) => {\n          throw error;\n        });\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const deleteUserRelation = (context: ApiContext, userId: string, value: string): Promise<UserRelationType> => {\n  const action: string = 'getRelationsByUser';\n  const {database, userId: sessionId} = context;\n  const formatUserId: string = parseId(userId);\n  const formatValue: string = parseChar(value, 32);\n  const aqlQry = `FOR u, r IN INBOUND \"${`users/${formatUserId}`}\" hasRelation\n    FILTER r._from == \"${`users/${sessionId}`}\" && r.value == \"${formatValue}\"\n    REMOVE r IN hasRelation\n    RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((relation = {}) => relation)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getUsersByRelations = (\n  context: ApiContext,\n  userId: string,\n  type: string,\n  from: number,\n  to: number\n): Promise<UserType[]> => {\n  const action: string = 'getUsersByRelations';\n  const {database} = context;\n  const formatUserId: string = parseId(userId);\n  const formatType: string = parseChar(type, 32);\n  const limit = getLimit(from, to);\n  const aqlQry: string = `FOR u, r IN INBOUND \"${`users/${formatUserId}`}\" hasRelation\n    FILTER r.type == \"${formatType}\"\n    ${limit.aql}\n    RETURN 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 getRelationsByUser = (context: ApiContext, userId: string): Promise<UserRelationType[]> => {\n  const action: string = 'getRelationsByUser';\n  const {database, userId: sessionId} = context;\n  const formatUserId: string = parseId(userId);\n  const aqlQry: AqlQuery = aql`FOR u, r IN INBOUND ${`users/${formatUserId}`} hasRelation\n      FILTER r._from == ${`users/${sessionId}`}\n      RETURN r`;\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 getDisplayName = (user: UserType = {}): string => {\n  const {first, last, name = '', username = ''} = user;\n  const fullname: string = ([first, last]).join(' ').trim();\n\n  if(!isEmpty(name)) {\n    return name;\n  } else if(fullname !== '') {\n    return fullname;\n  } else if(!isEmpty(username)) {\n    return username;\n  }\n\n  return 'Unknown';\n};\n"]}
368
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/users.ts"],"names":["createHash","parseChar","parseEmail","parseId","parseUsername","parseVarChar","aql","isEmpty","stripe","getLimit","logError","logException","useDb","eventCategory","addUser","context","user","database","email","phone","sub","username","insert","_key","added","Date","now","undefined","modified","aqlQry","query","then","cursor","next","deleteUser","userId","action","sessionId","sessionType","userType","isAdmin","category","label","value","customers","del","stripeCustomerId","accounts","stripeAccountId","catch","error","deactivateUser","updated","getSessionUser","console","log","getUser","formatUserId","getUserList","from","to","limit","all","addUserRelation","formatValue","db","relation","edgeId","edge","edgeCollection","save","deleteUserRelation","getUsersByRelations","type","formatType","getRelationsByUser","getRelationship","getDisplayName","first","last","name","fullname","join","trim"],"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, parseChar, parseEmail, parseId, parseUsername, parseVarChar} from '@nlabs/utils';\nimport {aql, Database, EdgeCollection} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport isEmpty from 'lodash/isEmpty';\nimport * as stripe from 'stripe';\n\nimport {ApiContext} from '../types/auth';\nimport {UserRelationType, UserType} from '../types/users';\nimport {getLimit, logError, logException, useDb} from '../utils';\n\nconst eventCategory: string = 'users';\n\nexport const addUser = (context: ApiContext, user: UserType): Promise<UserType> => {\n  const {database} = context;\n  const {email, phone, sub, username} = user;\n\n  // Add new user properties\n  const insert: UserType = {\n    _key: createHash(sub, null),\n    added: Date.now(),\n    email: email !== undefined ? parseEmail(email) : undefined,\n    modified: Date.now(),\n    phone: phone !== undefined ? parseVarChar(phone, 15) : undefined,\n    sub: parseVarChar(sub, 32),\n    username: parseUsername(username)\n  };\n\n  // Add new user in ArangoDB\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN users RETURN NEW`;\n  return useDb(database).query(aqlQry).then((cursor: ArrayCursor) => cursor.next());\n};\n\nexport const deleteUser = (context: ApiContext, userId: string): Promise<UserType> => {\n  const action: string = 'delete';\n  const {database, userId: sessionId, userType: sessionType} = context;\n  const isAdmin: boolean = sessionType > 2;\n\n  if(!isAdmin && (sessionId !== userId)) {\n    logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context);\n    return null;\n  }\n\n  const aqlQry: AqlQuery = aql`FOR u IN users\n      FILTER u._key == ${userId}\n      LIMIT 1\n      REMOVE u IN users\n      RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((user: UserType = {}) => stripe.customers.del(user.stripeCustomerId)\n      .then(() => stripe.accounts.del(user.stripeAccountId))\n      .then(() => user))\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const deactivateUser = (context: ApiContext, userId: string): Promise<UserType> => {\n  const action: string = 'delete';\n  const {database, userId: sessionId, userType: sessionType} = context;\n  const isAdmin: boolean = sessionType > 2;\n\n  if(!isAdmin && (sessionId !== userId)) {\n    logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context);\n    return null;\n  }\n\n  const updated: UserType = {\n    userType: 0\n  };\n  const aqlQry: AqlQuery = aql`UPDATE ${userId} WITH ${updated} IN users LIMIT 1 RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getSessionUser = (context: ApiContext): Promise<UserType> => {\n  const action: string = 'getSessionUser';\n  const {database, userId: sessionId} = context;\n\n  console.log('getSessionUser::sessionId', sessionId);\n  // Get data from database\n  const aqlQry = aql`FOR u IN users\n    FILTER u._key == ${sessionId}\n    LIMIT 1\n    RETURN u`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((user = {}) => user)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => {}));\n};\n\nexport const getUser = (context: ApiContext, userId): Promise<UserType> => {\n  const action: string = 'getItem';\n  const formatUserId: string = parseId(userId);\n  const {database} = context;\n\n  // Get data from database\n  const aqlQry = aql`FOR u IN users\n    FILTER u._key == ${formatUserId}\n    LIMIT 1\n    RETURN u`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((user = {}) => user)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => {}));\n};\n\nexport const getUserList = (context: ApiContext, from: number = 0, to: number = 15): Promise<UserType> => {\n  const action: string = 'getItem';\n  const {database} = context;\n  const limit = getLimit(from, to);\n\n  // Get data from database\n  const aqlQry: string = `FOR u IN users\n    ${limit.aql}\n    SORT u.username\n    RETURN 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(() => []));\n};\n\nexport const addUserRelation = (context: ApiContext, userId, value): Promise<UserRelationType> => {\n  const action: string = 'addRelation';\n  const {database, userId: sessionId} = context;\n  const formatUserId: string = parseId(userId);\n  const formatValue: string = parseChar(value, 32);\n  const db: Database = useDb(database);\n  const aqlQry = aql`FOR r IN hasRelation\n    FILTER r.value == ${formatValue} && r._from == ${sessionId} && r._to == ${formatUserId}\n    LIMIT 1\n    RETURN r`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((relation: UserRelationType) => {\n      // If a relationship between two users with the value exists, just return\n      if(relation) {\n        return relation;\n      }\n\n      // Otherwise, create the new relationship\n      const edgeId = createHash(`relation-${sessionId}-${formatUserId}-${formatValue}`);\n      const edge = {\n        _key: edgeId,\n        added: Date.now(),\n        value: formatValue\n      };\n      const edgeCollection: EdgeCollection = db.edgeCollection('hasRelation') as any;\n\n      return edgeCollection.save(edge, `users/${sessionId}`, `users/${formatUserId}`)\n        .then(() => edgeCollection.edge(edgeId))\n        .catch((error: Error) => {\n          throw error;\n        });\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const deleteUserRelation = (context: ApiContext, userId: string, value: string): Promise<UserRelationType> => {\n  const action: string = 'getRelationsByUser';\n  const {database, userId: sessionId} = context;\n  const formatUserId: string = parseId(userId);\n  const formatValue: string = parseChar(value, 32);\n  const aqlQry = `FOR u, r IN INBOUND \"${`users/${formatUserId}`}\" hasRelation\n    FILTER r._from == \"${`users/${sessionId}`}\" && r.value == \"${formatValue}\"\n    REMOVE r IN hasRelation\n    RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((relation = {}) => relation)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n\nexport const getUsersByRelations = (\n  context: ApiContext,\n  userId: string,\n  type: string,\n  from: number,\n  to: number\n): Promise<UserType[]> => {\n  const action: string = 'getUsersByRelations';\n  const {database} = context;\n  const formatUserId: string = parseId(userId);\n  const formatType: string = parseChar(type, 32);\n  const limit = getLimit(from, to);\n  const aqlQry: string = `FOR u, r IN INBOUND \"${`users/${formatUserId}`}\" hasRelation\n    FILTER r.type == \"${formatType}\"\n    ${limit.aql}\n    RETURN 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 getRelationsByUser = (context: ApiContext, userId: string): Promise<UserRelationType[]> => {\n  const action: string = 'getRelationsByUser';\n  const {database, userId: sessionId} = context;\n  const formatUserId: string = parseId(userId);\n  const aqlQry: AqlQuery = aql`FOR u, r IN INBOUND ${`users/${formatUserId}`} hasRelation\n      FILTER r._from == ${`users/${sessionId}`}\n      RETURN r`;\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 getRelationship = (context: ApiContext, userId: string): Promise<UserRelationType> => {\n  const action: string = 'getRelationship';\n  const {database, userId: sessionId} = context;\n  const formatUserId: string = parseId(userId);\n  const aqlQry: AqlQuery = aql`FOR u, r IN INBOUND ${`users/${formatUserId}`} hasRelation\n      FILTER r._from == ${`users/${sessionId}`}\n      LIMIT 1\n      RETURN r`;\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 getDisplayName = (user: UserType = {}): string => {\n  const {first, last, name = '', username = ''} = user;\n  const fullname: string = ([first, last]).join(' ').trim();\n\n  if(!isEmpty(name)) {\n    return name;\n  } else if(fullname !== '') {\n    return fullname;\n  } else if(!isEmpty(username)) {\n    return username;\n  }\n\n  return 'Unknown';\n};\n"]}
@@ -4,6 +4,7 @@ export interface ApiContext {
4
4
  readonly email: string;
5
5
  readonly fields?: string[];
6
6
  readonly ipAddress: string;
7
+ readonly sub: string;
7
8
  readonly userId: string;
8
9
  readonly username: string;
9
10
  readonly userType: number;
@@ -7,7 +7,7 @@ export interface FileType {
7
7
  readonly description?: string;
8
8
  fileSize?: number;
9
9
  readonly fileType?: string;
10
- readonly id?: string;
10
+ readonly fileId?: string;
11
11
  readonly itemId?: string;
12
12
  readonly itemType?: string;
13
13
  readonly modified?: number;
@@ -20,7 +20,7 @@ export interface FileDecodedType {
20
20
  type?: string;
21
21
  }
22
22
  export interface FileEdgeType {
23
- readonly imgId?: string;
23
+ readonly fileId?: string;
24
24
  readonly itemId?: string;
25
25
  readonly itemType?: string;
26
26
  }
@@ -1,10 +1,15 @@
1
+ import { PutObjectRequest } from 'aws-sdk/clients/s3';
1
2
  import { FileType } from './files';
3
+ export declare type ImageUrlTypes = 'app' | 'events' | 'groups' | 'users';
4
+ export declare type ImageLinkType = 'profile' | 'post';
2
5
  export interface ImageType extends FileType {
6
+ readonly bucket?: string;
3
7
  color?: string;
8
+ readonly imgId?: string;
4
9
  readonly height?: number;
5
- readonly id?: string;
6
10
  readonly model?: string;
7
11
  readonly make?: string;
12
+ readonly s3Options?: PutObjectRequest;
8
13
  readonly taken?: number;
9
14
  readonly width?: number;
10
15
  }
@@ -13,7 +18,6 @@ export interface ImageIdentifyType {
13
18
  readonly model?: string;
14
19
  readonly make?: string;
15
20
  }
16
- export declare type ImageUrlTypes = 'app' | 'events' | 'groups' | 'users';
17
21
  export interface ImageUrlData {
18
22
  readonly directory?: string;
19
23
  readonly imgId?: string;
@@ -22,3 +26,13 @@ export interface ImageUrlData {
22
26
  readonly type?: ImageUrlTypes;
23
27
  readonly typeId?: string;
24
28
  }
29
+ export interface ImageEdgeType {
30
+ readonly imgId?: string;
31
+ readonly itemId?: string;
32
+ readonly itemType?: string;
33
+ }
34
+ export interface ImageOptions {
35
+ readonly from?: number;
36
+ readonly to?: number;
37
+ readonly type?: string;
38
+ }
package/lib/utils/auth.js CHANGED
@@ -6,6 +6,7 @@ function _defineProperty(obj, key, value) { if (key in obj) { Object.definePrope
6
6
  * Copyright (c) 2019-Present, Nitrogen Labs, Inc.
7
7
  * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
8
8
  */
9
+ import { createHash } from '@nlabs/utils';
9
10
  import isPlainObject from 'lodash/isPlainObject';
10
11
  import isString from 'lodash/isString';
11
12
  export var parseJsonData = function parseJsonData(data) {
@@ -50,26 +51,33 @@ export var parseContext = function parseContext(appId, data) {
50
51
  if (claims) {
51
52
  var username = claims['cognito:username'],
52
53
  email = claims.email,
53
- userId = claims.sub,
54
+ sub = claims.sub,
54
55
  _claims$userType = claims.userType,
55
56
  userType = _claims$userType === void 0 ? 'default' : _claims$userType;
56
57
  var ipAddress = identity.sourceIp;
58
+ var userId = createHash(sub, null);
57
59
  return {
58
60
  appId: appId,
59
61
  database: appId,
60
62
  email: email,
61
63
  ipAddress: ipAddress,
64
+ sub: sub,
62
65
  userId: userId,
63
66
  userType: userType,
64
67
  username: username
65
68
  };
66
69
  } else if (isOffline) {
70
+ var _sub = 'a54224df-b74e-4398-a4ad-8be991c1f1ed';
71
+
72
+ var _userId = createHash(_sub, null);
73
+
67
74
  return {
68
75
  appId: appId,
69
76
  database: appId,
70
77
  email: 'test@nitrogenlabs.com',
71
78
  ipAddress: '1.1.1.1',
72
- userId: 'testerId123',
79
+ sub: _sub,
80
+ userId: _userId,
73
81
  userType: 1,
74
82
  username: 'tester'
75
83
  };
@@ -77,4 +85,4 @@ export var parseContext = function parseContext(appId, data) {
77
85
 
78
86
  return null;
79
87
  };
80
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9hdXRoLnRzIl0sIm5hbWVzIjpbImlzUGxhaW5PYmplY3QiLCJpc1N0cmluZyIsInBhcnNlSnNvbkRhdGEiLCJkYXRhIiwiSlNPTiIsInBhcnNlIiwiZXJyb3IiLCJnZXRMYW1iZGFEYXRhIiwicXVlcnlEYXRhIiwiYm9keSIsInJlcXVlc3RDb250ZXh0IiwiaXNPZmZsaW5lIiwiY29udGV4dCIsInBhcnNlQ29udGV4dCIsImFwcElkIiwiYXV0aG9yaXplciIsImlkZW50aXR5IiwiY2xhaW1zIiwidXNlcm5hbWUiLCJlbWFpbCIsInVzZXJJZCIsInN1YiIsInVzZXJUeXBlIiwiaXBBZGRyZXNzIiwic291cmNlSXAiLCJkYXRhYmFzZSJdLCJtYXBwaW5ncyI6Ijs7OztBQUFBOzs7O0FBSUEsT0FBT0EsYUFBUCxNQUEwQixzQkFBMUI7QUFDQSxPQUFPQyxRQUFQLE1BQXFCLGlCQUFyQjtBQUlBLE9BQU8sSUFBTUMsYUFBYSxHQUFHLFNBQWhCQSxhQUFnQixDQUFDQyxJQUFELEVBQWU7QUFDMUMsTUFBSTtBQUNGLFdBQU9DLElBQUksQ0FBQ0MsS0FBTCxDQUFXRixJQUFYLENBQVA7QUFDRCxHQUZELENBRUUsT0FBTUcsS0FBTixFQUFhO0FBQ2IsV0FBT0gsSUFBUDtBQUNEO0FBQ0YsQ0FOTTtBQVFQLE9BQU8sSUFBTUksYUFBYSxHQUFHLFNBQWhCQSxhQUFnQixDQUFDSixJQUFELEVBQWU7QUFDMUMsTUFBR0gsYUFBYSxDQUFDRyxJQUFELENBQWhCLEVBQXdCO0FBQ3RCLFFBQU1LLFNBQVMsR0FBR0wsSUFBSSxDQUFDTSxJQUFMLElBQWFOLElBQUksQ0FBQyxXQUFELENBQW5DO0FBRHNCLFFBRWZPLGNBRmUsR0FFY1AsSUFGZCxDQUVmTyxjQUZlO0FBQUEsUUFFQ0MsU0FGRCxHQUVjUixJQUZkLENBRUNRLFNBRkQ7QUFJdEIsV0FBTztBQUNMRixNQUFBQSxJQUFJLEVBQUVELFNBQVMsR0FBR04sYUFBYSxDQUFDTSxTQUFELENBQWhCLEdBQThCTCxJQUR4QztBQUVMUyxNQUFBQSxPQUFPLEVBQUVGLGNBQWMscUJBQU9BLGNBQVA7QUFBdUJDLFFBQUFBLFNBQVMsRUFBVEE7QUFBdkIsV0FBb0M7QUFBQ0EsUUFBQUEsU0FBUyxFQUFUQTtBQUFEO0FBRnRELEtBQVA7QUFJRCxHQVJELE1BUU8sSUFBR1YsUUFBUSxDQUFDRSxJQUFELENBQVgsRUFBbUI7QUFDeEIsV0FBTztBQUNMTSxNQUFBQSxJQUFJLEVBQUVQLGFBQWEsQ0FBQ0MsSUFBRCxDQURkO0FBRUxTLE1BQUFBLE9BQU8sRUFBRTtBQUZKLEtBQVA7QUFJRDs7QUFFRCxTQUFPO0FBQ0xILElBQUFBLElBQUksRUFBRSxFQUREO0FBRUxHLElBQUFBLE9BQU8sRUFBRTtBQUZKLEdBQVA7QUFJRCxDQXBCTTtBQXNCUCxPQUFPLElBQU1DLFlBQVksR0FBRyxTQUFmQSxZQUFlLENBQUNDLEtBQUQsRUFBZ0JYLElBQWhCLEVBQTBDO0FBQUEseUJBQ3JCQSxJQURxQixDQUM3RFksVUFENkQ7QUFBQSxNQUM3REEsVUFENkQsaUNBQ2hELEVBRGdEO0FBQUEsTUFDNUNDLFFBRDRDLEdBQ3JCYixJQURxQixDQUM1Q2EsUUFENEM7QUFBQSxNQUNsQ0wsU0FEa0MsR0FDckJSLElBRHFCLENBQ2xDUSxTQURrQztBQUFBLE1BRTdETSxNQUY2RCxHQUVuREYsVUFGbUQsQ0FFN0RFLE1BRjZEOztBQUlwRSxNQUFHQSxNQUFILEVBQVc7QUFBQSxRQUNvQkMsUUFEcEIsR0FDMEVELE1BRDFFLENBQ0Qsa0JBREM7QUFBQSxRQUM4QkUsS0FEOUIsR0FDMEVGLE1BRDFFLENBQzhCRSxLQUQ5QjtBQUFBLFFBQzBDQyxNQUQxQyxHQUMwRUgsTUFEMUUsQ0FDcUNJLEdBRHJDO0FBQUEsMkJBQzBFSixNQUQxRSxDQUNrREssUUFEbEQ7QUFBQSxRQUNrREEsUUFEbEQsaUNBQzZELFNBRDdEO0FBQUEsUUFFUUMsU0FGUixHQUVxQlAsUUFGckIsQ0FFRlEsUUFGRTtBQUdULFdBQU87QUFBQ1YsTUFBQUEsS0FBSyxFQUFMQSxLQUFEO0FBQVFXLE1BQUFBLFFBQVEsRUFBRVgsS0FBbEI7QUFBeUJLLE1BQUFBLEtBQUssRUFBTEEsS0FBekI7QUFBZ0NJLE1BQUFBLFNBQVMsRUFBVEEsU0FBaEM7QUFBMkNILE1BQUFBLE1BQU0sRUFBTkEsTUFBM0M7QUFBbURFLE1BQUFBLFFBQVEsRUFBUkEsUUFBbkQ7QUFBNkRKLE1BQUFBLFFBQVEsRUFBUkE7QUFBN0QsS0FBUDtBQUNELEdBSkQsTUFJTyxJQUFHUCxTQUFILEVBQWM7QUFDbkIsV0FBTztBQUNMRyxNQUFBQSxLQUFLLEVBQUxBLEtBREs7QUFFTFcsTUFBQUEsUUFBUSxFQUFFWCxLQUZMO0FBR0xLLE1BQUFBLEtBQUssRUFBRSx1QkFIRjtBQUlMSSxNQUFBQSxTQUFTLEVBQUUsU0FKTjtBQUtMSCxNQUFBQSxNQUFNLEVBQUUsYUFMSDtBQU1MRSxNQUFBQSxRQUFRLEVBQUUsQ0FOTDtBQU9MSixNQUFBQSxRQUFRLEVBQUU7QUFQTCxLQUFQO0FBU0Q7O0FBRUQsU0FBTyxJQUFQO0FBQ0QsQ0FyQk0iLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOS1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IGlzUGxhaW5PYmplY3QgZnJvbSAnbG9kYXNoL2lzUGxhaW5PYmplY3QnO1xuaW1wb3J0IGlzU3RyaW5nIGZyb20gJ2xvZGFzaC9pc1N0cmluZyc7XG5cbmltcG9ydCB7QXBpQ29udGV4dH0gZnJvbSAnLi4vdHlwZXMvYXV0aCc7XG5cbmV4cG9ydCBjb25zdCBwYXJzZUpzb25EYXRhID0gKGRhdGEpOiBhbnkgPT4ge1xuICB0cnkge1xuICAgIHJldHVybiBKU09OLnBhcnNlKGRhdGEpO1xuICB9IGNhdGNoKGVycm9yKSB7XG4gICAgcmV0dXJuIGRhdGE7XG4gIH1cbn07XG5cbmV4cG9ydCBjb25zdCBnZXRMYW1iZGFEYXRhID0gKGRhdGE6IGFueSkgPT4ge1xuICBpZihpc1BsYWluT2JqZWN0KGRhdGEpKSB7XG4gICAgY29uc3QgcXVlcnlEYXRhID0gZGF0YS5ib2R5IHx8IGRhdGFbJ2JvZHktanNvbiddO1xuICAgIGNvbnN0IHtyZXF1ZXN0Q29udGV4dCwgaXNPZmZsaW5lfSA9IGRhdGE7XG5cbiAgICByZXR1cm4ge1xuICAgICAgYm9keTogcXVlcnlEYXRhID8gcGFyc2VKc29uRGF0YShxdWVyeURhdGEpIDogZGF0YSxcbiAgICAgIGNvbnRleHQ6IHJlcXVlc3RDb250ZXh0ID8gey4uLnJlcXVlc3RDb250ZXh0LCBpc09mZmxpbmV9IDoge2lzT2ZmbGluZX1cbiAgICB9O1xuICB9IGVsc2UgaWYoaXNTdHJpbmcoZGF0YSkpIHtcbiAgICByZXR1cm4ge1xuICAgICAgYm9keTogcGFyc2VKc29uRGF0YShkYXRhKSxcbiAgICAgIGNvbnRleHQ6IHt9XG4gICAgfTtcbiAgfVxuXG4gIHJldHVybiB7XG4gICAgYm9keToge30sXG4gICAgY29udGV4dDoge31cbiAgfTtcbn07XG5cbmV4cG9ydCBjb25zdCBwYXJzZUNvbnRleHQgPSAoYXBwSWQ6IHN0cmluZywgZGF0YTogYW55KTogQXBpQ29udGV4dCA9PiB7XG4gIGNvbnN0IHthdXRob3JpemVyID0ge30sIGlkZW50aXR5LCBpc09mZmxpbmV9ID0gZGF0YTtcbiAgY29uc3Qge2NsYWltc30gPSBhdXRob3JpemVyO1xuXG4gIGlmKGNsYWltcykge1xuICAgIGNvbnN0IHtbJ2NvZ25pdG86dXNlcm5hbWUnXTogdXNlcm5hbWUsIGVtYWlsLCBzdWI6IHVzZXJJZCwgdXNlclR5cGUgPSAnZGVmYXVsdCd9ID0gY2xhaW1zO1xuICAgIGNvbnN0IHtzb3VyY2VJcDogaXBBZGRyZXNzfSA9IGlkZW50aXR5O1xuICAgIHJldHVybiB7YXBwSWQsIGRhdGFiYXNlOiBhcHBJZCwgZW1haWwsIGlwQWRkcmVzcywgdXNlcklkLCB1c2VyVHlwZSwgdXNlcm5hbWV9O1xuICB9IGVsc2UgaWYoaXNPZmZsaW5lKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGFwcElkLFxuICAgICAgZGF0YWJhc2U6IGFwcElkLFxuICAgICAgZW1haWw6ICd0ZXN0QG5pdHJvZ2VubGFicy5jb20nLFxuICAgICAgaXBBZGRyZXNzOiAnMS4xLjEuMScsXG4gICAgICB1c2VySWQ6ICd0ZXN0ZXJJZDEyMycsXG4gICAgICB1c2VyVHlwZTogMSxcbiAgICAgIHVzZXJuYW1lOiAndGVzdGVyJ1xuICAgIH07XG4gIH1cblxuICByZXR1cm4gbnVsbDtcbn07XG4iXX0=
88
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9hdXRoLnRzIl0sIm5hbWVzIjpbImNyZWF0ZUhhc2giLCJpc1BsYWluT2JqZWN0IiwiaXNTdHJpbmciLCJwYXJzZUpzb25EYXRhIiwiZGF0YSIsIkpTT04iLCJwYXJzZSIsImVycm9yIiwiZ2V0TGFtYmRhRGF0YSIsInF1ZXJ5RGF0YSIsImJvZHkiLCJyZXF1ZXN0Q29udGV4dCIsImlzT2ZmbGluZSIsImNvbnRleHQiLCJwYXJzZUNvbnRleHQiLCJhcHBJZCIsImF1dGhvcml6ZXIiLCJpZGVudGl0eSIsImNsYWltcyIsInVzZXJuYW1lIiwiZW1haWwiLCJzdWIiLCJ1c2VyVHlwZSIsImlwQWRkcmVzcyIsInNvdXJjZUlwIiwidXNlcklkIiwiZGF0YWJhc2UiXSwibWFwcGluZ3MiOiI7Ozs7QUFBQTs7OztBQUlBLFNBQVFBLFVBQVIsUUFBeUIsY0FBekI7QUFDQSxPQUFPQyxhQUFQLE1BQTBCLHNCQUExQjtBQUNBLE9BQU9DLFFBQVAsTUFBcUIsaUJBQXJCO0FBSUEsT0FBTyxJQUFNQyxhQUFhLEdBQUcsU0FBaEJBLGFBQWdCLENBQUNDLElBQUQsRUFBZTtBQUMxQyxNQUFJO0FBQ0YsV0FBT0MsSUFBSSxDQUFDQyxLQUFMLENBQVdGLElBQVgsQ0FBUDtBQUNELEdBRkQsQ0FFRSxPQUFNRyxLQUFOLEVBQWE7QUFDYixXQUFPSCxJQUFQO0FBQ0Q7QUFDRixDQU5NO0FBUVAsT0FBTyxJQUFNSSxhQUFhLEdBQUcsU0FBaEJBLGFBQWdCLENBQUNKLElBQUQsRUFBZTtBQUMxQyxNQUFHSCxhQUFhLENBQUNHLElBQUQsQ0FBaEIsRUFBd0I7QUFDdEIsUUFBTUssU0FBUyxHQUFHTCxJQUFJLENBQUNNLElBQUwsSUFBYU4sSUFBSSxDQUFDLFdBQUQsQ0FBbkM7QUFEc0IsUUFFZk8sY0FGZSxHQUVjUCxJQUZkLENBRWZPLGNBRmU7QUFBQSxRQUVDQyxTQUZELEdBRWNSLElBRmQsQ0FFQ1EsU0FGRDtBQUl0QixXQUFPO0FBQ0xGLE1BQUFBLElBQUksRUFBRUQsU0FBUyxHQUFHTixhQUFhLENBQUNNLFNBQUQsQ0FBaEIsR0FBOEJMLElBRHhDO0FBRUxTLE1BQUFBLE9BQU8sRUFBRUYsY0FBYyxxQkFBT0EsY0FBUDtBQUF1QkMsUUFBQUEsU0FBUyxFQUFUQTtBQUF2QixXQUFvQztBQUFDQSxRQUFBQSxTQUFTLEVBQVRBO0FBQUQ7QUFGdEQsS0FBUDtBQUlELEdBUkQsTUFRTyxJQUFHVixRQUFRLENBQUNFLElBQUQsQ0FBWCxFQUFtQjtBQUN4QixXQUFPO0FBQ0xNLE1BQUFBLElBQUksRUFBRVAsYUFBYSxDQUFDQyxJQUFELENBRGQ7QUFFTFMsTUFBQUEsT0FBTyxFQUFFO0FBRkosS0FBUDtBQUlEOztBQUVELFNBQU87QUFDTEgsSUFBQUEsSUFBSSxFQUFFLEVBREQ7QUFFTEcsSUFBQUEsT0FBTyxFQUFFO0FBRkosR0FBUDtBQUlELENBcEJNO0FBc0JQLE9BQU8sSUFBTUMsWUFBWSxHQUFHLFNBQWZBLFlBQWUsQ0FBQ0MsS0FBRCxFQUFnQlgsSUFBaEIsRUFBMEM7QUFBQSx5QkFDckJBLElBRHFCLENBQzdEWSxVQUQ2RDtBQUFBLE1BQzdEQSxVQUQ2RCxpQ0FDaEQsRUFEZ0Q7QUFBQSxNQUM1Q0MsUUFENEMsR0FDckJiLElBRHFCLENBQzVDYSxRQUQ0QztBQUFBLE1BQ2xDTCxTQURrQyxHQUNyQlIsSUFEcUIsQ0FDbENRLFNBRGtDO0FBQUEsTUFFN0RNLE1BRjZELEdBRW5ERixVQUZtRCxDQUU3REUsTUFGNkQ7O0FBSXBFLE1BQUdBLE1BQUgsRUFBVztBQUFBLFFBQ29CQyxRQURwQixHQUNrRUQsTUFEbEUsQ0FDRCxrQkFEQztBQUFBLFFBQzhCRSxLQUQ5QixHQUNrRUYsTUFEbEUsQ0FDOEJFLEtBRDlCO0FBQUEsUUFDcUNDLEdBRHJDLEdBQ2tFSCxNQURsRSxDQUNxQ0csR0FEckM7QUFBQSwyQkFDa0VILE1BRGxFLENBQzBDSSxRQUQxQztBQUFBLFFBQzBDQSxRQUQxQyxpQ0FDcUQsU0FEckQ7QUFBQSxRQUVRQyxTQUZSLEdBRXFCTixRQUZyQixDQUVGTyxRQUZFO0FBR1QsUUFBTUMsTUFBYyxHQUFHekIsVUFBVSxDQUFDcUIsR0FBRCxFQUFNLElBQU4sQ0FBakM7QUFDQSxXQUFPO0FBQUNOLE1BQUFBLEtBQUssRUFBTEEsS0FBRDtBQUFRVyxNQUFBQSxRQUFRLEVBQUVYLEtBQWxCO0FBQXlCSyxNQUFBQSxLQUFLLEVBQUxBLEtBQXpCO0FBQWdDRyxNQUFBQSxTQUFTLEVBQVRBLFNBQWhDO0FBQTJDRixNQUFBQSxHQUFHLEVBQUhBLEdBQTNDO0FBQWdESSxNQUFBQSxNQUFNLEVBQU5BLE1BQWhEO0FBQXdESCxNQUFBQSxRQUFRLEVBQVJBLFFBQXhEO0FBQWtFSCxNQUFBQSxRQUFRLEVBQVJBO0FBQWxFLEtBQVA7QUFDRCxHQUxELE1BS08sSUFBR1AsU0FBSCxFQUFjO0FBQ25CLFFBQU1TLElBQVcsR0FBRyxzQ0FBcEI7O0FBQ0EsUUFBTUksT0FBYyxHQUFHekIsVUFBVSxDQUFDcUIsSUFBRCxFQUFNLElBQU4sQ0FBakM7O0FBRUEsV0FBTztBQUNMTixNQUFBQSxLQUFLLEVBQUxBLEtBREs7QUFFTFcsTUFBQUEsUUFBUSxFQUFFWCxLQUZMO0FBR0xLLE1BQUFBLEtBQUssRUFBRSx1QkFIRjtBQUlMRyxNQUFBQSxTQUFTLEVBQUUsU0FKTjtBQUtMRixNQUFBQSxHQUFHLEVBQUhBLElBTEs7QUFNTEksTUFBQUEsTUFBTSxFQUFOQSxPQU5LO0FBT0xILE1BQUFBLFFBQVEsRUFBRSxDQVBMO0FBUUxILE1BQUFBLFFBQVEsRUFBRTtBQVJMLEtBQVA7QUFVRDs7QUFFRCxTQUFPLElBQVA7QUFDRCxDQTFCTSIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQge2NyZWF0ZUhhc2h9IGZyb20gJ0BubGFicy91dGlscyc7XG5pbXBvcnQgaXNQbGFpbk9iamVjdCBmcm9tICdsb2Rhc2gvaXNQbGFpbk9iamVjdCc7XG5pbXBvcnQgaXNTdHJpbmcgZnJvbSAnbG9kYXNoL2lzU3RyaW5nJztcblxuaW1wb3J0IHtBcGlDb250ZXh0fSBmcm9tICcuLi90eXBlcy9hdXRoJztcblxuZXhwb3J0IGNvbnN0IHBhcnNlSnNvbkRhdGEgPSAoZGF0YSk6IGFueSA9PiB7XG4gIHRyeSB7XG4gICAgcmV0dXJuIEpTT04ucGFyc2UoZGF0YSk7XG4gIH0gY2F0Y2goZXJyb3IpIHtcbiAgICByZXR1cm4gZGF0YTtcbiAgfVxufTtcblxuZXhwb3J0IGNvbnN0IGdldExhbWJkYURhdGEgPSAoZGF0YTogYW55KSA9PiB7XG4gIGlmKGlzUGxhaW5PYmplY3QoZGF0YSkpIHtcbiAgICBjb25zdCBxdWVyeURhdGEgPSBkYXRhLmJvZHkgfHwgZGF0YVsnYm9keS1qc29uJ107XG4gICAgY29uc3Qge3JlcXVlc3RDb250ZXh0LCBpc09mZmxpbmV9ID0gZGF0YTtcblxuICAgIHJldHVybiB7XG4gICAgICBib2R5OiBxdWVyeURhdGEgPyBwYXJzZUpzb25EYXRhKHF1ZXJ5RGF0YSkgOiBkYXRhLFxuICAgICAgY29udGV4dDogcmVxdWVzdENvbnRleHQgPyB7Li4ucmVxdWVzdENvbnRleHQsIGlzT2ZmbGluZX0gOiB7aXNPZmZsaW5lfVxuICAgIH07XG4gIH0gZWxzZSBpZihpc1N0cmluZyhkYXRhKSkge1xuICAgIHJldHVybiB7XG4gICAgICBib2R5OiBwYXJzZUpzb25EYXRhKGRhdGEpLFxuICAgICAgY29udGV4dDoge31cbiAgICB9O1xuICB9XG5cbiAgcmV0dXJuIHtcbiAgICBib2R5OiB7fSxcbiAgICBjb250ZXh0OiB7fVxuICB9O1xufTtcblxuZXhwb3J0IGNvbnN0IHBhcnNlQ29udGV4dCA9IChhcHBJZDogc3RyaW5nLCBkYXRhOiBhbnkpOiBBcGlDb250ZXh0ID0+IHtcbiAgY29uc3Qge2F1dGhvcml6ZXIgPSB7fSwgaWRlbnRpdHksIGlzT2ZmbGluZX0gPSBkYXRhO1xuICBjb25zdCB7Y2xhaW1zfSA9IGF1dGhvcml6ZXI7XG5cbiAgaWYoY2xhaW1zKSB7XG4gICAgY29uc3Qge1snY29nbml0bzp1c2VybmFtZSddOiB1c2VybmFtZSwgZW1haWwsIHN1YiwgdXNlclR5cGUgPSAnZGVmYXVsdCd9ID0gY2xhaW1zO1xuICAgIGNvbnN0IHtzb3VyY2VJcDogaXBBZGRyZXNzfSA9IGlkZW50aXR5O1xuICAgIGNvbnN0IHVzZXJJZDogc3RyaW5nID0gY3JlYXRlSGFzaChzdWIsIG51bGwpO1xuICAgIHJldHVybiB7YXBwSWQsIGRhdGFiYXNlOiBhcHBJZCwgZW1haWwsIGlwQWRkcmVzcywgc3ViLCB1c2VySWQsIHVzZXJUeXBlLCB1c2VybmFtZX07XG4gIH0gZWxzZSBpZihpc09mZmxpbmUpIHtcbiAgICBjb25zdCBzdWI6IHN0cmluZyA9ICdhNTQyMjRkZi1iNzRlLTQzOTgtYTRhZC04YmU5OTFjMWYxZWQnO1xuICAgIGNvbnN0IHVzZXJJZDogc3RyaW5nID0gY3JlYXRlSGFzaChzdWIsIG51bGwpO1xuXG4gICAgcmV0dXJuIHtcbiAgICAgIGFwcElkLFxuICAgICAgZGF0YWJhc2U6IGFwcElkLFxuICAgICAgZW1haWw6ICd0ZXN0QG5pdHJvZ2VubGFicy5jb20nLFxuICAgICAgaXBBZGRyZXNzOiAnMS4xLjEuMScsXG4gICAgICBzdWIsXG4gICAgICB1c2VySWQsXG4gICAgICB1c2VyVHlwZTogMSxcbiAgICAgIHVzZXJuYW1lOiAndGVzdGVyJ1xuICAgIH07XG4gIH1cblxuICByZXR1cm4gbnVsbDtcbn07XG4iXX0=
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nlabs/reaktor",
3
- "version": "0.1.3",
3
+ "version": "0.1.5",
4
4
  "description": "Reaktor",
5
5
  "main": "./index.js",
6
6
  "types": "./lib/index.d.js",
@@ -28,6 +28,7 @@
28
28
  "build": "lex compile -r",
29
29
  "clean": "lex clean",
30
30
  "lint": "eslint ./src --ext .ts,.tsx",
31
+ "prepublishOnly": "npm run build",
31
32
  "pretest": "stage=test npm run lint",
32
33
  "test": "stage=test jest",
33
34
  "update": "lex update -i"
@@ -38,7 +39,8 @@
38
39
  "@nlabs/utils": "^1.2.2",
39
40
  "apn": "^2.2.0",
40
41
  "arangojs": "^6.0.0",
41
- "aws-sdk": "^2.423.0",
42
+ "aws-sdk": "^2.428.0",
43
+ "file-type": "^10.9.0",
42
44
  "gm": "^1.23.1",
43
45
  "google-libphonenumber": "^3.0.10",
44
46
  "googleapis": "^38.0.0",
@@ -47,7 +49,7 @@
47
49
  "graphql-fields": "^2.0.3",
48
50
  "hiredis": "^0.5.0",
49
51
  "lodash": "^4.17.4",
50
- "luxon": "^1.11.4",
52
+ "luxon": "^1.12.0",
51
53
  "node-yelp": "0.0.3",
52
54
  "numeral": "^2.0.6",
53
55
  "redis": "^2.8.0",
@@ -64,12 +66,12 @@
64
66
  "@types/history": "^4.6.2",
65
67
  "@types/jest": "^24.0.11",
66
68
  "@types/luxon": "^1.11.0",
67
- "@types/node": "^11.11.3",
69
+ "@types/node": "^11.11.7",
68
70
  "@types/twilio": "^0.0.10",
69
71
  "eslint": "^5.15.3",
70
72
  "eslint-config-styleguidejs": "^1.0.8",
71
73
  "graphql-tools": "^4.0.0",
72
74
  "source-map-loader": "^0.2.4",
73
- "typescript": "^3.0.3"
75
+ "typescript": "^3.3.4000"
74
76
  }
75
77
  }