@nlabs/reaktor 0.1.0 → 0.1.1
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/conversations.js +3 -7
- package/lib/data/email.js +4 -5
- package/lib/data/files.js +3 -4
- package/lib/data/images.js +6 -7
- package/lib/data/posts.d.ts +5 -3
- package/lib/data/posts.js +179 -97
- package/lib/data/users.js +1 -3
- package/lib/types/apps.d.ts +0 -1
- package/lib/types/auth.d.ts +1 -0
- package/lib/types/files.d.ts +0 -2
- package/lib/types/groups.d.ts +0 -1
- package/lib/types/images.d.ts +0 -1
- package/lib/types/locations.d.ts +0 -1
- package/lib/types/payments.d.ts +0 -5
- package/lib/types/posts.d.ts +11 -4
- package/lib/types/tags.d.ts +0 -1
- package/lib/utils/auth.d.ts +6 -1
- package/lib/utils/auth.js +41 -4
- package/lib/utils/graphql.d.ts +1 -0
- package/lib/utils/graphql.js +7 -0
- package/lib/utils/index.d.ts +1 -0
- package/lib/utils/index.js +2 -1
- package/package.json +12 -12
- package/src/data/conversations.ts +2 -4
- package/src/data/email.ts +3 -4
- package/src/data/files.ts +2 -2
- package/src/data/images.ts +5 -5
- package/src/data/posts.ts +178 -125
- package/src/data/users.ts +0 -2
- package/src/types/apps.ts +0 -1
- package/src/types/auth.ts +1 -0
- package/src/types/files.ts +0 -2
- package/src/types/groups.ts +0 -1
- package/src/types/images.ts +0 -1
- package/src/types/locations.ts +0 -1
- package/src/types/payments.ts +0 -5
- package/src/types/posts.ts +12 -4
- package/src/types/tags.ts +0 -1
- package/src/utils/auth.ts +35 -2
- package/src/utils/graphql.ts +7 -0
- package/src/utils/index.ts +1 -0
package/lib/data/users.js
CHANGED
|
@@ -256,9 +256,7 @@ export var getUsersByRelations = function getUsersByRelations(context, userId, t
|
|
|
256
256
|
var formatUserId = parseId(userId);
|
|
257
257
|
var formatType = parseChar(type, 32);
|
|
258
258
|
var limit = getLimit(from, to);
|
|
259
|
-
console.log('context', context);
|
|
260
259
|
var aqlQry = "FOR u, r IN INBOUND \"".concat("users/".concat(formatUserId), "\" hasRelation\n FILTER r.type == \"", formatType, "\"\n ").concat(limit.aql, "\n RETURN u");
|
|
261
|
-
console.log('getUsersByRelations::aqlQry', aqlQry);
|
|
262
260
|
return useDb(database).query(aqlQry).then(function (cursor) {
|
|
263
261
|
return cursor.all();
|
|
264
262
|
}).catch(function (error) {
|
|
@@ -309,4 +307,4 @@ export var getDisplayName = function getDisplayName() {
|
|
|
309
307
|
|
|
310
308
|
return 'Unknown';
|
|
311
309
|
};
|
|
312
|
-
//# 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","console","log","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  console.log('context', context);\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  console.log('getUsersByRelations::aqlQry', aqlQry);\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"]}
|
|
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"]}
|
package/lib/types/apps.d.ts
CHANGED
package/lib/types/auth.d.ts
CHANGED
package/lib/types/files.d.ts
CHANGED
|
@@ -2,7 +2,6 @@
|
|
|
2
2
|
export interface FileType {
|
|
3
3
|
readonly _key?: string;
|
|
4
4
|
readonly added?: number;
|
|
5
|
-
readonly appId?: string;
|
|
6
5
|
readonly base64?: string;
|
|
7
6
|
readonly buffer?: Buffer;
|
|
8
7
|
readonly description?: string;
|
|
@@ -21,7 +20,6 @@ export interface FileDecodedType {
|
|
|
21
20
|
type?: string;
|
|
22
21
|
}
|
|
23
22
|
export interface FileEdgeType {
|
|
24
|
-
readonly appId?: string;
|
|
25
23
|
readonly imgId?: string;
|
|
26
24
|
readonly itemId?: string;
|
|
27
25
|
readonly itemType?: string;
|
package/lib/types/groups.d.ts
CHANGED
package/lib/types/images.d.ts
CHANGED
|
@@ -15,7 +15,6 @@ export interface ImageIdentifyType {
|
|
|
15
15
|
}
|
|
16
16
|
export declare type ImageUrlTypes = 'app' | 'events' | 'groups' | 'users';
|
|
17
17
|
export interface ImageUrlData {
|
|
18
|
-
readonly appId?: string;
|
|
19
18
|
readonly directory?: string;
|
|
20
19
|
readonly imgId?: string;
|
|
21
20
|
readonly imgType?: string;
|
package/lib/types/locations.d.ts
CHANGED
package/lib/types/payments.d.ts
CHANGED
|
@@ -4,7 +4,6 @@ export interface PaymentCardType {
|
|
|
4
4
|
readonly acceptedTerms?: boolean;
|
|
5
5
|
readonly accountNumber?: string;
|
|
6
6
|
readonly added?: number;
|
|
7
|
-
readonly appId?: string;
|
|
8
7
|
readonly brand?: string;
|
|
9
8
|
city?: string;
|
|
10
9
|
country?: string;
|
|
@@ -28,7 +27,6 @@ export interface PaymentBankAccount {
|
|
|
28
27
|
export interface PaymentCharge {
|
|
29
28
|
readonly added?: number;
|
|
30
29
|
readonly amount?: number;
|
|
31
|
-
readonly appId?: string;
|
|
32
30
|
readonly capture?: boolean;
|
|
33
31
|
readonly cardId?: string;
|
|
34
32
|
readonly chargeFailCode?: string;
|
|
@@ -43,7 +41,6 @@ export interface PaymentCharge {
|
|
|
43
41
|
export interface PaymentTransfer {
|
|
44
42
|
readonly added?: number;
|
|
45
43
|
readonly amount?: number;
|
|
46
|
-
readonly appId?: string;
|
|
47
44
|
readonly currency?: string;
|
|
48
45
|
readonly description?: string;
|
|
49
46
|
readonly modified?: number;
|
|
@@ -54,7 +51,6 @@ export interface PaymentPlan {
|
|
|
54
51
|
readonly _key?: string;
|
|
55
52
|
readonly added?: number;
|
|
56
53
|
readonly amount?: number;
|
|
57
|
-
readonly appId?: string;
|
|
58
54
|
readonly currency?: string;
|
|
59
55
|
readonly description?: string;
|
|
60
56
|
readonly id?: string;
|
|
@@ -66,7 +62,6 @@ export interface PaymentPlan {
|
|
|
66
62
|
export interface PaymentSubscription {
|
|
67
63
|
readonly _key?: string;
|
|
68
64
|
readonly added?: number;
|
|
69
|
-
readonly appId?: string;
|
|
70
65
|
readonly cancelDate?: number;
|
|
71
66
|
readonly expires?: number;
|
|
72
67
|
readonly id?: string;
|
package/lib/types/posts.d.ts
CHANGED
|
@@ -4,17 +4,24 @@ export interface PostType {
|
|
|
4
4
|
readonly _id?: string;
|
|
5
5
|
readonly _key?: string;
|
|
6
6
|
readonly added?: number;
|
|
7
|
-
|
|
7
|
+
content?: string;
|
|
8
8
|
files?: FileType[];
|
|
9
9
|
readonly groupId?: string;
|
|
10
|
-
readonly
|
|
10
|
+
readonly postId?: string;
|
|
11
|
+
readonly latitude?: number;
|
|
12
|
+
readonly location?: string;
|
|
13
|
+
readonly longitude?: number;
|
|
11
14
|
readonly modified?: number;
|
|
12
15
|
name?: string;
|
|
13
16
|
parentId?: string;
|
|
14
17
|
privacy?: string;
|
|
15
18
|
tags?: TagType[];
|
|
16
|
-
text?: string;
|
|
17
|
-
title?: string;
|
|
18
19
|
type?: string;
|
|
19
20
|
readonly userId?: string;
|
|
20
21
|
}
|
|
22
|
+
export interface PostOptions {
|
|
23
|
+
readonly latitude?: number;
|
|
24
|
+
readonly longitude?: number;
|
|
25
|
+
readonly from?: number;
|
|
26
|
+
readonly to?: number;
|
|
27
|
+
}
|
package/lib/types/tags.d.ts
CHANGED
package/lib/utils/auth.d.ts
CHANGED
|
@@ -1,2 +1,7 @@
|
|
|
1
1
|
import { ApiContext } from '../types/auth';
|
|
2
|
-
export declare const
|
|
2
|
+
export declare const parseJsonData: (data: any) => any;
|
|
3
|
+
export declare const getLambdaData: (data: any) => {
|
|
4
|
+
body: any;
|
|
5
|
+
context: any;
|
|
6
|
+
};
|
|
7
|
+
export declare const parseContext: (appId: string, data: any) => ApiContext;
|
package/lib/utils/auth.js
CHANGED
|
@@ -1,10 +1,47 @@
|
|
|
1
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; var ownKeys = Object.keys(source); if (typeof Object.getOwnPropertySymbols === 'function') { ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) { return Object.getOwnPropertyDescriptor(source, sym).enumerable; })); } ownKeys.forEach(function (key) { _defineProperty(target, key, source[key]); }); } return target; }
|
|
2
|
+
|
|
3
|
+
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
4
|
+
|
|
1
5
|
/**
|
|
2
6
|
* Copyright (c) 2019-Present, Nitrogen Labs, Inc.
|
|
3
7
|
* Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
|
|
4
8
|
*/
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
9
|
+
import isPlainObject from 'lodash/isPlainObject';
|
|
10
|
+
import isString from 'lodash/isString';
|
|
11
|
+
export var parseJsonData = function parseJsonData(data) {
|
|
12
|
+
try {
|
|
13
|
+
return JSON.parse(data);
|
|
14
|
+
} catch (error) {
|
|
15
|
+
return data;
|
|
16
|
+
}
|
|
17
|
+
};
|
|
18
|
+
export var getLambdaData = function getLambdaData(data) {
|
|
19
|
+
if (isPlainObject(data)) {
|
|
20
|
+
var queryData = data.body || data['body-json'];
|
|
21
|
+
var requestContext = data.requestContext,
|
|
22
|
+
isOffline = data.isOffline;
|
|
23
|
+
return {
|
|
24
|
+
body: queryData ? parseJsonData(queryData) : data,
|
|
25
|
+
context: requestContext ? _objectSpread({}, requestContext, {
|
|
26
|
+
isOffline: isOffline
|
|
27
|
+
}) : {
|
|
28
|
+
isOffline: isOffline
|
|
29
|
+
}
|
|
30
|
+
};
|
|
31
|
+
} else if (isString(data)) {
|
|
32
|
+
return {
|
|
33
|
+
body: parseJsonData(data),
|
|
34
|
+
context: {}
|
|
35
|
+
};
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
return {
|
|
39
|
+
body: {},
|
|
40
|
+
context: {}
|
|
41
|
+
};
|
|
42
|
+
};
|
|
43
|
+
export var parseContext = function parseContext(appId, data) {
|
|
44
|
+
var _data$authorizer = data.authorizer,
|
|
8
45
|
authorizer = _data$authorizer === void 0 ? {} : _data$authorizer,
|
|
9
46
|
identity = data.identity,
|
|
10
47
|
isOffline = data.isOffline;
|
|
@@ -40,4 +77,4 @@ export var parseContext = function parseContext(data) {
|
|
|
40
77
|
|
|
41
78
|
return null;
|
|
42
79
|
};
|
|
43
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
80
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9hdXRoLnRzIl0sIm5hbWVzIjpbImlzUGxhaW5PYmplY3QiLCJpc1N0cmluZyIsInBhcnNlSnNvbkRhdGEiLCJkYXRhIiwiSlNPTiIsInBhcnNlIiwiZXJyb3IiLCJnZXRMYW1iZGFEYXRhIiwicXVlcnlEYXRhIiwiYm9keSIsInJlcXVlc3RDb250ZXh0IiwiaXNPZmZsaW5lIiwiY29udGV4dCIsInBhcnNlQ29udGV4dCIsImFwcElkIiwiYXV0aG9yaXplciIsImlkZW50aXR5IiwiY2xhaW1zIiwidXNlcm5hbWUiLCJlbWFpbCIsInVzZXJJZCIsInN1YiIsInVzZXJUeXBlIiwiaXBBZGRyZXNzIiwic291cmNlSXAiLCJkYXRhYmFzZSJdLCJtYXBwaW5ncyI6Ijs7OztBQUFBOzs7O0FBSUEsT0FBT0EsYUFBUCxNQUEwQixzQkFBMUI7QUFDQSxPQUFPQyxRQUFQLE1BQXFCLGlCQUFyQjtBQUlBLE9BQU8sSUFBTUMsYUFBYSxHQUFHLFNBQWhCQSxhQUFnQixDQUFDQyxJQUFELEVBQWU7QUFDMUMsTUFBSTtBQUNGLFdBQU9DLElBQUksQ0FBQ0MsS0FBTCxDQUFXRixJQUFYLENBQVA7QUFDRCxHQUZELENBRUUsT0FBTUcsS0FBTixFQUFhO0FBQ2IsV0FBT0gsSUFBUDtBQUNEO0FBQ0YsQ0FOTTtBQVFQLE9BQU8sSUFBTUksYUFBYSxHQUFHLFNBQWhCQSxhQUFnQixDQUFDSixJQUFELEVBQWU7QUFDMUMsTUFBR0gsYUFBYSxDQUFDRyxJQUFELENBQWhCLEVBQXdCO0FBQ3RCLFFBQU1LLFNBQVMsR0FBR0wsSUFBSSxDQUFDTSxJQUFMLElBQWFOLElBQUksQ0FBQyxXQUFELENBQW5DO0FBRHNCLFFBRWZPLGNBRmUsR0FFY1AsSUFGZCxDQUVmTyxjQUZlO0FBQUEsUUFFQ0MsU0FGRCxHQUVjUixJQUZkLENBRUNRLFNBRkQ7QUFJdEIsV0FBTztBQUNMRixNQUFBQSxJQUFJLEVBQUVELFNBQVMsR0FBR04sYUFBYSxDQUFDTSxTQUFELENBQWhCLEdBQThCTCxJQUR4QztBQUVMUyxNQUFBQSxPQUFPLEVBQUVGLGNBQWMscUJBQU9BLGNBQVA7QUFBdUJDLFFBQUFBLFNBQVMsRUFBVEE7QUFBdkIsV0FBb0M7QUFBQ0EsUUFBQUEsU0FBUyxFQUFUQTtBQUFEO0FBRnRELEtBQVA7QUFJRCxHQVJELE1BUU8sSUFBR1YsUUFBUSxDQUFDRSxJQUFELENBQVgsRUFBbUI7QUFDeEIsV0FBTztBQUNMTSxNQUFBQSxJQUFJLEVBQUVQLGFBQWEsQ0FBQ0MsSUFBRCxDQURkO0FBRUxTLE1BQUFBLE9BQU8sRUFBRTtBQUZKLEtBQVA7QUFJRDs7QUFFRCxTQUFPO0FBQ0xILElBQUFBLElBQUksRUFBRSxFQUREO0FBRUxHLElBQUFBLE9BQU8sRUFBRTtBQUZKLEdBQVA7QUFJRCxDQXBCTTtBQXNCUCxPQUFPLElBQU1DLFlBQVksR0FBRyxTQUFmQSxZQUFlLENBQUNDLEtBQUQsRUFBZ0JYLElBQWhCLEVBQTBDO0FBQUEseUJBQ3JCQSxJQURxQixDQUM3RFksVUFENkQ7QUFBQSxNQUM3REEsVUFENkQsaUNBQ2hELEVBRGdEO0FBQUEsTUFDNUNDLFFBRDRDLEdBQ3JCYixJQURxQixDQUM1Q2EsUUFENEM7QUFBQSxNQUNsQ0wsU0FEa0MsR0FDckJSLElBRHFCLENBQ2xDUSxTQURrQztBQUFBLE1BRTdETSxNQUY2RCxHQUVuREYsVUFGbUQsQ0FFN0RFLE1BRjZEOztBQUlwRSxNQUFHQSxNQUFILEVBQVc7QUFBQSxRQUNvQkMsUUFEcEIsR0FDMEVELE1BRDFFLENBQ0Qsa0JBREM7QUFBQSxRQUM4QkUsS0FEOUIsR0FDMEVGLE1BRDFFLENBQzhCRSxLQUQ5QjtBQUFBLFFBQzBDQyxNQUQxQyxHQUMwRUgsTUFEMUUsQ0FDcUNJLEdBRHJDO0FBQUEsMkJBQzBFSixNQUQxRSxDQUNrREssUUFEbEQ7QUFBQSxRQUNrREEsUUFEbEQsaUNBQzZELFNBRDdEO0FBQUEsUUFFUUMsU0FGUixHQUVxQlAsUUFGckIsQ0FFRlEsUUFGRTtBQUdULFdBQU87QUFBQ1YsTUFBQUEsS0FBSyxFQUFMQSxLQUFEO0FBQVFXLE1BQUFBLFFBQVEsRUFBRVgsS0FBbEI7QUFBeUJLLE1BQUFBLEtBQUssRUFBTEEsS0FBekI7QUFBZ0NJLE1BQUFBLFNBQVMsRUFBVEEsU0FBaEM7QUFBMkNILE1BQUFBLE1BQU0sRUFBTkEsTUFBM0M7QUFBbURFLE1BQUFBLFFBQVEsRUFBUkEsUUFBbkQ7QUFBNkRKLE1BQUFBLFFBQVEsRUFBUkE7QUFBN0QsS0FBUDtBQUNELEdBSkQsTUFJTyxJQUFHUCxTQUFILEVBQWM7QUFDbkIsV0FBTztBQUNMRyxNQUFBQSxLQUFLLEVBQUxBLEtBREs7QUFFTFcsTUFBQUEsUUFBUSxFQUFFWCxLQUZMO0FBR0xLLE1BQUFBLEtBQUssRUFBRSx1QkFIRjtBQUlMSSxNQUFBQSxTQUFTLEVBQUUsU0FKTjtBQUtMSCxNQUFBQSxNQUFNLEVBQUUsYUFMSDtBQU1MRSxNQUFBQSxRQUFRLEVBQUUsQ0FOTDtBQU9MSixNQUFBQSxRQUFRLEVBQUU7QUFQTCxLQUFQO0FBU0Q7O0FBRUQsU0FBTyxJQUFQO0FBQ0QsQ0FyQk0iLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOS1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuaW1wb3J0IGlzUGxhaW5PYmplY3QgZnJvbSAnbG9kYXNoL2lzUGxhaW5PYmplY3QnO1xuaW1wb3J0IGlzU3RyaW5nIGZyb20gJ2xvZGFzaC9pc1N0cmluZyc7XG5cbmltcG9ydCB7QXBpQ29udGV4dH0gZnJvbSAnLi4vdHlwZXMvYXV0aCc7XG5cbmV4cG9ydCBjb25zdCBwYXJzZUpzb25EYXRhID0gKGRhdGEpOiBhbnkgPT4ge1xuICB0cnkge1xuICAgIHJldHVybiBKU09OLnBhcnNlKGRhdGEpO1xuICB9IGNhdGNoKGVycm9yKSB7XG4gICAgcmV0dXJuIGRhdGE7XG4gIH1cbn07XG5cbmV4cG9ydCBjb25zdCBnZXRMYW1iZGFEYXRhID0gKGRhdGE6IGFueSkgPT4ge1xuICBpZihpc1BsYWluT2JqZWN0KGRhdGEpKSB7XG4gICAgY29uc3QgcXVlcnlEYXRhID0gZGF0YS5ib2R5IHx8IGRhdGFbJ2JvZHktanNvbiddO1xuICAgIGNvbnN0IHtyZXF1ZXN0Q29udGV4dCwgaXNPZmZsaW5lfSA9IGRhdGE7XG5cbiAgICByZXR1cm4ge1xuICAgICAgYm9keTogcXVlcnlEYXRhID8gcGFyc2VKc29uRGF0YShxdWVyeURhdGEpIDogZGF0YSxcbiAgICAgIGNvbnRleHQ6IHJlcXVlc3RDb250ZXh0ID8gey4uLnJlcXVlc3RDb250ZXh0LCBpc09mZmxpbmV9IDoge2lzT2ZmbGluZX1cbiAgICB9O1xuICB9IGVsc2UgaWYoaXNTdHJpbmcoZGF0YSkpIHtcbiAgICByZXR1cm4ge1xuICAgICAgYm9keTogcGFyc2VKc29uRGF0YShkYXRhKSxcbiAgICAgIGNvbnRleHQ6IHt9XG4gICAgfTtcbiAgfVxuXG4gIHJldHVybiB7XG4gICAgYm9keToge30sXG4gICAgY29udGV4dDoge31cbiAgfTtcbn07XG5cbmV4cG9ydCBjb25zdCBwYXJzZUNvbnRleHQgPSAoYXBwSWQ6IHN0cmluZywgZGF0YTogYW55KTogQXBpQ29udGV4dCA9PiB7XG4gIGNvbnN0IHthdXRob3JpemVyID0ge30sIGlkZW50aXR5LCBpc09mZmxpbmV9ID0gZGF0YTtcbiAgY29uc3Qge2NsYWltc30gPSBhdXRob3JpemVyO1xuXG4gIGlmKGNsYWltcykge1xuICAgIGNvbnN0IHtbJ2NvZ25pdG86dXNlcm5hbWUnXTogdXNlcm5hbWUsIGVtYWlsLCBzdWI6IHVzZXJJZCwgdXNlclR5cGUgPSAnZGVmYXVsdCd9ID0gY2xhaW1zO1xuICAgIGNvbnN0IHtzb3VyY2VJcDogaXBBZGRyZXNzfSA9IGlkZW50aXR5O1xuICAgIHJldHVybiB7YXBwSWQsIGRhdGFiYXNlOiBhcHBJZCwgZW1haWwsIGlwQWRkcmVzcywgdXNlcklkLCB1c2VyVHlwZSwgdXNlcm5hbWV9O1xuICB9IGVsc2UgaWYoaXNPZmZsaW5lKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGFwcElkLFxuICAgICAgZGF0YWJhc2U6IGFwcElkLFxuICAgICAgZW1haWw6ICd0ZXN0QG5pdHJvZ2VubGFicy5jb20nLFxuICAgICAgaXBBZGRyZXNzOiAnMS4xLjEuMScsXG4gICAgICB1c2VySWQ6ICd0ZXN0ZXJJZDEyMycsXG4gICAgICB1c2VyVHlwZTogMSxcbiAgICAgIHVzZXJuYW1lOiAndGVzdGVyJ1xuICAgIH07XG4gIH1cblxuICByZXR1cm4gbnVsbDtcbn07XG4iXX0=
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const getGqlFields: (info: any) => string[];
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import graphqlFields from 'graphql-fields';
|
|
2
|
+
export var getGqlFields = function getGqlFields(info) {
|
|
3
|
+
var fields = graphqlFields(info);
|
|
4
|
+
var methodName = Object.keys(fields)[0];
|
|
5
|
+
return Object.keys(fields[methodName]);
|
|
6
|
+
};
|
|
7
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9ncmFwaHFsLnRzIl0sIm5hbWVzIjpbImdyYXBocWxGaWVsZHMiLCJnZXRHcWxGaWVsZHMiLCJpbmZvIiwiZmllbGRzIiwibWV0aG9kTmFtZSIsIk9iamVjdCIsImtleXMiXSwibWFwcGluZ3MiOiJBQUFBLE9BQU9BLGFBQVAsTUFBMEIsZ0JBQTFCO0FBRUEsT0FBTyxJQUFNQyxZQUFZLEdBQUcsU0FBZkEsWUFBZSxDQUFDQyxJQUFELEVBQVU7QUFDcEMsTUFBTUMsTUFBTSxHQUFHSCxhQUFhLENBQUNFLElBQUQsQ0FBNUI7QUFDQSxNQUFNRSxVQUFrQixHQUFHQyxNQUFNLENBQUNDLElBQVAsQ0FBWUgsTUFBWixFQUFvQixDQUFwQixDQUEzQjtBQUNBLFNBQU9FLE1BQU0sQ0FBQ0MsSUFBUCxDQUFZSCxNQUFNLENBQUNDLFVBQUQsQ0FBbEIsQ0FBUDtBQUNELENBSk0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgZ3JhcGhxbEZpZWxkcyBmcm9tICdncmFwaHFsLWZpZWxkcyc7XG5cbmV4cG9ydCBjb25zdCBnZXRHcWxGaWVsZHMgPSAoaW5mbykgPT4ge1xuICBjb25zdCBmaWVsZHMgPSBncmFwaHFsRmllbGRzKGluZm8pO1xuICBjb25zdCBtZXRob2ROYW1lOiBzdHJpbmcgPSBPYmplY3Qua2V5cyhmaWVsZHMpWzBdO1xuICByZXR1cm4gT2JqZWN0LmtleXMoZmllbGRzW21ldGhvZE5hbWVdKTtcbn07Il19
|
package/lib/utils/index.d.ts
CHANGED
package/lib/utils/index.js
CHANGED
|
@@ -5,6 +5,7 @@
|
|
|
5
5
|
export * from './analytics';
|
|
6
6
|
export * from './auth';
|
|
7
7
|
export * from './arangodb';
|
|
8
|
+
export * from './graphql';
|
|
8
9
|
export * from './objects';
|
|
9
10
|
export * from './redis';
|
|
10
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
11
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlscy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7OztBQUlBLGNBQWMsYUFBZDtBQUNBLGNBQWMsUUFBZDtBQUNBLGNBQWMsWUFBZDtBQUNBLGNBQWMsV0FBZDtBQUNBLGNBQWMsV0FBZDtBQUNBLGNBQWMsU0FBZCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE5LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5leHBvcnQgKiBmcm9tICcuL2FuYWx5dGljcyc7XG5leHBvcnQgKiBmcm9tICcuL2F1dGgnO1xuZXhwb3J0ICogZnJvbSAnLi9hcmFuZ29kYic7XG5leHBvcnQgKiBmcm9tICcuL2dyYXBocWwnO1xuZXhwb3J0ICogZnJvbSAnLi9vYmplY3RzJztcbmV4cG9ydCAqIGZyb20gJy4vcmVkaXMnO1xuIl19
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@nlabs/reaktor",
|
|
3
|
-
"version": "0.1.
|
|
3
|
+
"version": "0.1.1",
|
|
4
4
|
"description": "Reaktor",
|
|
5
5
|
"main": "./index.js",
|
|
6
6
|
"types": "./lib/index.d.js",
|
|
@@ -34,27 +34,27 @@
|
|
|
34
34
|
},
|
|
35
35
|
"dependencies": {
|
|
36
36
|
"@nlabs/arkhamjs": "^3.11.11",
|
|
37
|
-
"@nlabs/rip-hunter": "^2.0.
|
|
38
|
-
"@nlabs/utils": "^1.2.
|
|
37
|
+
"@nlabs/rip-hunter": "^2.0.1",
|
|
38
|
+
"@nlabs/utils": "^1.2.1",
|
|
39
39
|
"apn": "^2.2.0",
|
|
40
40
|
"arangojs": "^6.0.0",
|
|
41
|
-
"aws-sdk": "^2.
|
|
41
|
+
"aws-sdk": "^2.420.0",
|
|
42
42
|
"gm": "^1.23.1",
|
|
43
43
|
"google-libphonenumber": "^3.0.10",
|
|
44
44
|
"googleapis": "^37.2.0",
|
|
45
45
|
"graphql": "^14.0.2",
|
|
46
46
|
"graphql-errors": "^2.1.0",
|
|
47
|
-
"graphql-fields": "^2.0.
|
|
47
|
+
"graphql-fields": "^2.0.3",
|
|
48
48
|
"hiredis": "^0.5.0",
|
|
49
49
|
"lodash": "^4.17.4",
|
|
50
|
-
"luxon": "^1.
|
|
50
|
+
"luxon": "^1.11.4",
|
|
51
51
|
"node-yelp": "0.0.3",
|
|
52
52
|
"numeral": "^2.0.6",
|
|
53
53
|
"redis": "^2.8.0",
|
|
54
54
|
"request-promise": "^4.2.2",
|
|
55
|
-
"stripe": "^6.
|
|
55
|
+
"stripe": "^6.26.0",
|
|
56
56
|
"to": "^0.2.9",
|
|
57
|
-
"twilio": "^3.
|
|
57
|
+
"twilio": "^3.29.1",
|
|
58
58
|
"typed-promisify": "^0.4.0",
|
|
59
59
|
"universal-analytics": "^0.4.16",
|
|
60
60
|
"update": "^0.7.4"
|
|
@@ -62,12 +62,12 @@
|
|
|
62
62
|
"devDependencies": {
|
|
63
63
|
"@types/graphql": "^14.0.1",
|
|
64
64
|
"@types/history": "^4.6.2",
|
|
65
|
-
"@types/jest": "^24.0.
|
|
65
|
+
"@types/jest": "^24.0.11",
|
|
66
66
|
"@types/luxon": "^1.11.0",
|
|
67
|
-
"@types/node": "^11.
|
|
67
|
+
"@types/node": "^11.11.2",
|
|
68
68
|
"@types/twilio": "^0.0.10",
|
|
69
|
-
"eslint": "^5.
|
|
70
|
-
"eslint-config-styleguidejs": "^1.0.
|
|
69
|
+
"eslint": "^5.15.1",
|
|
70
|
+
"eslint-config-styleguidejs": "^1.0.8",
|
|
71
71
|
"graphql-tools": "^4.0.0",
|
|
72
72
|
"source-map-loader": "^0.2.4",
|
|
73
73
|
"typescript": "^3.0.3"
|
|
@@ -47,7 +47,7 @@ export const getConversationList = (context: ApiContext, from: number, to: numbe
|
|
|
47
47
|
|
|
48
48
|
export const getDirectConversation = (context: ApiContext, userId: string): Promise<ConversationType> => {
|
|
49
49
|
const action: string = 'getDirect';
|
|
50
|
-
const {
|
|
50
|
+
const {database, userId: sessionId} = context;
|
|
51
51
|
const formatUserId: string = parseId(userId);
|
|
52
52
|
|
|
53
53
|
const aqlQry: AqlQuery = aql`FOR c IN conversations
|
|
@@ -72,7 +72,6 @@ export const getDirectConversation = (context: ApiContext, userId: string): Prom
|
|
|
72
72
|
conversation.users = users.map((user: UserType) => {
|
|
73
73
|
const {_key: userKey, imgId} = user;
|
|
74
74
|
const thumbUrlData: ImageUrlData = {
|
|
75
|
-
appId: sessionApp,
|
|
76
75
|
directory: 'images',
|
|
77
76
|
imgId,
|
|
78
77
|
isThumb: true,
|
|
@@ -98,7 +97,7 @@ export const getDirectConversation = (context: ApiContext, userId: string): Prom
|
|
|
98
97
|
|
|
99
98
|
export const getConversation = (context: ApiContext, convoId: string): Promise<ConversationType> => {
|
|
100
99
|
const action: string = 'getItem';
|
|
101
|
-
const {
|
|
100
|
+
const {database, userId: sessionId} = context;
|
|
102
101
|
const formatConvoId: string = parseId(convoId);
|
|
103
102
|
|
|
104
103
|
const aqlQry: AqlQuery = aql`FOR c IN conversations
|
|
@@ -120,7 +119,6 @@ export const getConversation = (context: ApiContext, convoId: string): Promise<C
|
|
|
120
119
|
conversation.users = conversation.users.map((user: UserType) => {
|
|
121
120
|
const {_key: userKey, imgId} = user;
|
|
122
121
|
const thumbUrlData: ImageUrlData = {
|
|
123
|
-
appId: sessionApp,
|
|
124
122
|
directory: 'images',
|
|
125
123
|
imgId,
|
|
126
124
|
isThumb: true,
|
package/src/data/email.ts
CHANGED
|
@@ -21,8 +21,7 @@ export const appTemplate = (app: AppType, message: string = '', vars = {}): stri
|
|
|
21
21
|
if(!isEmpty(app)) {
|
|
22
22
|
updatedMessage = message.replace(/\[appName\]/g, app.name)
|
|
23
23
|
.replace(/\[appUrl\]/g, app.url)
|
|
24
|
-
.replace(/\[appEmail\]/g, app.email)
|
|
25
|
-
.replace(/\[appId\]/g, app.id);
|
|
24
|
+
.replace(/\[appEmail\]/g, app.email);
|
|
26
25
|
}
|
|
27
26
|
|
|
28
27
|
Object.keys(vars).forEach((key: string) => {
|
|
@@ -53,7 +52,7 @@ export const sendEmail = (params: EmailType): Promise<boolean> => {
|
|
|
53
52
|
const formatTitle: string = appTemplate(app, title);
|
|
54
53
|
const formatText: string = appTemplate(app, text);
|
|
55
54
|
const formatHtml: string = appTemplate(app, html);
|
|
56
|
-
const {_key:
|
|
55
|
+
const {_key: hasCustomEmail, urlFacebook, urlTwitter} = app;
|
|
57
56
|
|
|
58
57
|
const parseTemplate = (body: string) => {
|
|
59
58
|
const templateBody: string = appTemplate(app, body || '');
|
|
@@ -89,7 +88,7 @@ export const sendEmail = (params: EmailType): Promise<boolean> => {
|
|
|
89
88
|
};
|
|
90
89
|
|
|
91
90
|
if(hasCustomEmail) {
|
|
92
|
-
const s3Params: GetObjectRequest = {Bucket: null, Key: `apps
|
|
91
|
+
const s3Params: GetObjectRequest = {Bucket: null, Key: `apps/templates/email.html`};
|
|
93
92
|
promise = s3Get(s3Params).then((results) => parseTemplate(results.Body.toString()));
|
|
94
93
|
} else {
|
|
95
94
|
promise = new Promise((resolve, reject) => {
|
package/src/data/files.ts
CHANGED
|
@@ -25,7 +25,7 @@ request.defaults({encoding: null});
|
|
|
25
25
|
|
|
26
26
|
// Upload file
|
|
27
27
|
export const addFile = (context: ApiContext, item: FileType = {}): Promise<FileType> => {
|
|
28
|
-
const {
|
|
28
|
+
const {database, userId: sessionId, userType} = context;
|
|
29
29
|
const {
|
|
30
30
|
description = '',
|
|
31
31
|
fileType = '',
|
|
@@ -35,7 +35,7 @@ export const addFile = (context: ApiContext, item: FileType = {}): Promise<FileT
|
|
|
35
35
|
} = item;
|
|
36
36
|
|
|
37
37
|
// Id
|
|
38
|
-
const fileId: string = id ? parseId(id) : createHash(`file-${sessionId}
|
|
38
|
+
const fileId: string = id ? parseId(id) : createHash(`file-${sessionId}`);
|
|
39
39
|
|
|
40
40
|
// Name
|
|
41
41
|
const isUrl: boolean = url !== '';
|
package/src/data/images.ts
CHANGED
|
@@ -407,7 +407,7 @@ export const getPathUserImages = (userID: string, photoId: string, type: string,
|
|
|
407
407
|
};
|
|
408
408
|
|
|
409
409
|
export const getUrlImages = (data: ImageUrlData): string => {
|
|
410
|
-
const {
|
|
410
|
+
const {imgId, directory = 'images', imgType = 'profile', isThumb, type, typeId} = data;
|
|
411
411
|
const host: string = Config.get('environment') === 'production'
|
|
412
412
|
? `https://box.${Config.get('app.url')}`
|
|
413
413
|
: `https://s3.amazonaws.com/dev.${Config.get('app.url')}`;
|
|
@@ -417,17 +417,17 @@ export const getUrlImages = (data: ImageUrlData): string => {
|
|
|
417
417
|
switch(type) {
|
|
418
418
|
case 'app':
|
|
419
419
|
// https://box.reaktor.io/myApp/app/images/123.jpg
|
|
420
|
-
return `${host}/${
|
|
420
|
+
return `${host}/${type}/${directory}/${imgId}${suffix}.jpg`;
|
|
421
421
|
case 'users':
|
|
422
422
|
// https://box.reaktor.io/myApp/users/demoUser/images/123.jpg
|
|
423
|
-
return `${host}/${
|
|
423
|
+
return `${host}/${type}/${typeId}/${directory}/${imgId}${suffix}.jpg`;
|
|
424
424
|
}
|
|
425
425
|
|
|
426
426
|
if(imgType === 'profile') {
|
|
427
|
-
return `${host}
|
|
427
|
+
return `${host}/defaults/${type}_bk${suffix}.jpg`;
|
|
428
428
|
}
|
|
429
429
|
|
|
430
|
-
return `${host}
|
|
430
|
+
return `${host}/defaults/${type}_wh${suffix}.jpg`;
|
|
431
431
|
}
|
|
432
432
|
|
|
433
433
|
return '';
|