@nlabs/reaktor 0.2.0 → 0.2.2
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/images.js +3 -3
- package/lib/data/posts.d.ts +7 -6
- package/lib/data/posts.js +92 -45
- package/lib/data/reactions.js +2 -2
- package/lib/data/users.js +2 -12
- package/package.json +5 -5
package/lib/data/reactions.js
CHANGED
|
@@ -129,7 +129,7 @@ var addReaction = function addReaction(context, itemId) {
|
|
|
129
129
|
added: Date.now(),
|
|
130
130
|
name: formatReactionName,
|
|
131
131
|
type: formatItemType,
|
|
132
|
-
value: formatValue
|
|
132
|
+
value: itemValue !== undefined ? formatValue : undefined
|
|
133
133
|
}; // Check for duplicates if not allowed
|
|
134
134
|
|
|
135
135
|
if (!allowDuplicate) {
|
|
@@ -484,4 +484,4 @@ var hasReaction = function hasReaction(context, itemId, itemType, reactionName)
|
|
|
484
484
|
};
|
|
485
485
|
|
|
486
486
|
exports.hasReaction = hasReaction;
|
|
487
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/reactions.ts"],"names":["eventCategory","parseReactionOptions","options","from","to","limit","addReaction","context","itemId","itemType","reaction","allowDuplicate","action","database","sessionId","userId","category","label","value","then","name","itemName","itemValue","formatItemId","formatItemType","formatReactionName","formatValue","edgeCollection","typeDocId","sessionDocId","edgeId","edge","_key","added","Date","now","type","aqlQry","aql","query","cursor","next","save","error","removeReaction","reactionId","formatSessionnId","formatReactionId","removeReactionByItem","reactionName","formatSessionId","formatItemDocId","updateReaction","id","formatId","formatName","formatType","update","insert","getReactionCount","itemDocId","getReactionCountByUser","all","getGroupUsersByReaction","params","filters","groupId","groupDocId","filterStr","map","filter","conditional","queryValue","filterCond","concat","join","getReactionsByItem","getItemsByReaction","hasReaction","direction","formatDirection","itemDirection","reactions","length"],"mappings":"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","sourcesContent":["import {createHash, parseChar, parseId, parseNum, parseString} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\n\nimport {\n  ApiContext,\n  QueryFilter,\n  ReactionDirection,\n  ReactionOptions,\n  ReactionType,\n  UserReactionQuery,\n  UserType\n} from '../types';\nimport {getLimit, logError, logException, useDb} from '../utils';\n\nconst eventCategory: string = 'reactions';\n\nexport const parseReactionOptions = (options: ReactionOptions = {}) => {\n  const {\n    from = 0,\n    to = 30\n  } = options;\n\n  return {\n    limit: getLimit(from, to)\n  };\n};\n\nexport const addReaction = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string = 'users',\n  reaction: ReactionType = {},\n  allowDuplicate: boolean = false\n): Promise<ReactionType> => {\n  const action: string = 'addReaction';\n  const {database, userId: sessionId} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const {\n    name: itemName = 'like',\n    value: itemValue\n  } = reaction;\n  const formatItemId: string = parseId(itemId);\n  const formatItemType: any = parseChar(itemType, 32);\n  const formatReactionName: string = parseChar(itemName, 32);\n  const formatValue: string = parseString(itemValue, 32);\n  const edgeCollection = useDb(database).edgeCollection('hasReactions');\n  const typeDocId: string = `${formatItemType}/${formatItemId}`;\n  const sessionDocId: string = `users/${sessionId}`;\n  const edgeId: string = createHash(`reaction-${formatItemId}-${sessionId}`);\n  const edge: ReactionType = {\n    _key: edgeId,\n    added: Date.now(),\n    name: formatReactionName,\n    type: formatItemType,\n    value: formatValue\n  };\n\n  // Check for duplicates if not allowed\n  if(!allowDuplicate) {\n    // Query\n    const aqlQry: AqlQuery = aql`FOR r IN hasReactions\n      FILTER r._from == ${sessionDocId} && r._to == ${typeDocId} && r.name == ${formatReactionName}\n      LIMIT 1\n      RETURN r`;\n\n    return useDb(database).query(aqlQry)\n      .then((cursor: ArrayCursor) => cursor.next())\n      .then((reaction) => {\n        if(!!reaction) {\n          return reaction;\n        }\n\n        return edgeCollection.save(edge, sessionDocId, typeDocId).then(() => edge);\n      })\n      .catch((error: Error) => logError({\n        action,\n        category: eventCategory,\n        label: 'db_error'\n      }, error, context).then(() => null));\n  }\n\n  return edgeCollection.save(edge, sessionDocId, typeDocId).then(() => edge);\n};\n\nexport const removeReaction = (context: ApiContext, reactionId: string): Promise<ReactionType> => {\n  const action: string = 'removeReaction';\n  const {database, userId: sessionId} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const formatSessionnId: string = `users/${parseId(sessionId)}`;\n  const formatReactionId: string = `hasReactions/${parseId(reactionId)}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`LET r = DOCUMENT(${formatReactionId})\n    FILTER r._from == ${formatSessionnId}\n    LIMIT 1\n    REMOVE r IN hasReactions\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\nexport const removeReactionByItem = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string\n): Promise<ReactionType> => {\n  const action: string = 'removeReaction';\n  const {database, userId: sessionId} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const formatSessionId: string = `users/${parseId(sessionId)}`;\n  const formatItemType: string = parseChar(itemType, 32);\n  const formatItemDocId: string = `${formatItemType}/${parseId(itemId)}`;\n  const formatReactionName: string = parseChar(reactionName, 32);\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR r IN hasReactions\n    FILTER r._from == ${formatSessionId}\n      && r._to == ${formatItemDocId}\n      && r.type == ${formatItemType}\n      && r.name == ${formatReactionName}\n    LIMIT 1\n    REMOVE r IN hasReactions\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\nexport const updateReaction = (context: ApiContext, reaction: ReactionType = {}): Promise<ReactionType> => {\n  const action: string = 'updateReaction';\n  const {database, userId: sessionId} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const {\n    id: itemId,\n    name: itemName,\n    type: itemType,\n    value: itemValue\n  } = reaction;\n  const formatId: string = parseId(itemId);\n  const formatName: string = parseChar(itemName, 32);\n  const formatType: any = parseChar(itemType, 32);\n  const formatValue: string = parseString(itemValue, 32);\n  const edgeId: string = createHash(`reaction-${formatId}-${sessionId}`);\n  const update: ReactionType = {\n    name: formatName,\n    type: formatType,\n    value: formatValue\n  };\n  const insert: ReactionType = {\n    ...update,\n    _key: edgeId,\n    added: Date.now()\n  };\n\n  // Query\n  const aqlQry: AqlQuery = aql`UPSERT ${{_key: formatId}}\n    INSERT ${insert}\n    UPDATE ${update}\n    LIMIT 1\n    RETURN NEW`;\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 getReactionCount = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string\n): Promise<ReactionType> => {\n  const action: string = 'getReactionCount';\n  const {database} = context;\n  const formatItemId: string = parseId(itemId);\n  const formatReactionName: any = parseChar(reactionName, 32);\n  const formatItemType: any = parseChar(itemType, 32);\n  const itemDocId: string = `${formatItemType}/${formatItemId}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR i, r IN INBOUND ${itemDocId} hasReactions\n    FILTER r.name == ${formatReactionName} && r.type == ${formatItemType}\n    COLLECT WITH COUNT INTO count\n    RETURN count`;\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 getReactionCountByUser = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string\n): Promise<ReactionType[]> => {\n  const action: string = 'getReactionsByUser';\n  const {database, userId: sessionId} = context;\n  const formatItemId: string = parseId(itemId);\n  const formatReactionName: any = parseChar(reactionName, 32);\n  const formatItemType: any = parseChar(itemType, 32);\n  const sessionDocId: string = `users/${sessionId}`;\n  const itemDocId: string = `${formatItemType}/${formatItemId}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR i, r IN INBOUND ${itemDocId} hasReactions\n      FILTER r.name == ${formatReactionName} && r._from == ${sessionDocId}\n      COLLECT reactionValue = r.value INTO reactionItems\n      RETURN MERGE(r, {count: LENGTH(reactionItems[*].r.value)})`;\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 getGroupUsersByReaction = (context: ApiContext, params: UserReactionQuery = {}): Promise<UserType[]> => {\n  const action: string = 'getUsersByReaction';\n  const {database, userId: sessionId} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const {filters = [], id: groupId, value}: UserReactionQuery = params;\n  const reaction = parseChar(value, 32);\n  const groupDocId = `groups/${parseId(groupId)}`;\n  const filterStr: string = filters\n    .map((filter: QueryFilter) => {\n      const {conditional, name, value: queryValue}: QueryFilter = filter;\n      let filterCond: string = conditional;\n\n      if(conditional !== '>=' && conditional !== '<=' && conditional !== '>' && conditional !== '<') {\n        filterCond = '==';\n      }\n\n      switch(name) {\n        case 'added':\n          return `r.added ${filterCond} ${parseNum(queryValue)}`;\n        default:\n          return '';\n      }\n    })\n    .concat([\n      `r.value == \"${reaction}\"`,\n      'u._id == r._from'\n    ])\n    .join(' && ');\n\n  // Query\n  const aqlQry: string = `FOR g, r IN INBOUND \"${groupDocId}\" hasReactions\n      FOR u IN users\n      FILTER  ${filterStr}\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 getReactionsByItem = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string,\n  options: ReactionOptions\n): Promise<UserType[]> => {\n  const action: string = 'getUsersByReactions';\n  const {database} = context;\n  const formatItemId: string = parseId(itemId);\n  const formatItemType: string = parseChar(itemType, 32);\n  const formatReactionName: string = parseChar(reactionName, 32);\n  const itemDocId = `${formatItemType}/${formatItemId}`;\n  const {limit} = parseReactionOptions(options);\n  const aqlQry: string = `FOR i, r IN INBOUND \"${itemDocId}\" hasReactions\n    FILTER r.name == \"${formatReactionName}\"\n    ${limit.aql}\n    RETURN MERGE(i, {reaction: 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 getItemsByReaction = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string,\n  options: ReactionOptions\n): Promise<ReactionType[]> => {\n  const action: string = 'getUserReactionsByReaction';\n  const {database} = context;\n  const formatItemId: string = parseId(itemId);\n  const formatItemType: string = parseChar(itemType, 32);\n  const formatReactionName: string = parseChar(reactionName, 32);\n  const itemDocId = `${formatItemType}/${formatItemId}`;\n  const {limit} = parseReactionOptions(options);\n\n  // Query\n  const aqlQry: string = `FOR u, r IN OUTBOUND \"${itemDocId}\" hasReactions\n    FILTER r.name == ${formatReactionName}\n    ${limit.aql}\n    RETURN MERGE(u, {reaction: 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 hasReaction = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string,\n  direction: ReactionDirection = 'OUTBOUND'\n): Promise<ReactionType[]> => {\n  const action: string = 'getReactionsByUser';\n  const {database, userId: sessionId} = context;\n  const sessionDocId: string = `users/${sessionId}`;\n  const formatItemId: string = parseId(itemId);\n  const formatItemType: string = parseChar(itemType, 32);\n  const formatDirection = direction === 'OUTBOUND' ? 'OUTBOUND' : 'INBOUND';\n  const itemDirection: string = direction === 'OUTBOUND' ? 'r._to' : 'r._from';\n  const itemDocId: string = `${formatItemType}/${formatItemId}`;\n\n  // Query\n  const aqlQry: string = `FOR i, r IN ${formatDirection} \"${sessionDocId}\" hasReactions\n    FILTER r.name == \"${reactionName}\" && ${itemDirection} == \"${itemDocId}\"\n    RETURN MERGE(i, {reaction: r})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((reactions = []) => !!reactions.length)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n"]}
|
|
487
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/reactions.ts"],"names":["eventCategory","parseReactionOptions","options","from","to","limit","addReaction","context","itemId","itemType","reaction","allowDuplicate","action","database","sessionId","userId","category","label","value","then","name","itemName","itemValue","formatItemId","formatItemType","formatReactionName","formatValue","edgeCollection","typeDocId","sessionDocId","edgeId","edge","_key","added","Date","now","type","undefined","aqlQry","aql","query","cursor","next","save","error","removeReaction","reactionId","formatSessionnId","formatReactionId","removeReactionByItem","reactionName","formatSessionId","formatItemDocId","updateReaction","id","formatId","formatName","formatType","update","insert","getReactionCount","itemDocId","getReactionCountByUser","all","getGroupUsersByReaction","params","filters","groupId","groupDocId","filterStr","map","filter","conditional","queryValue","filterCond","concat","join","getReactionsByItem","getItemsByReaction","hasReaction","direction","formatDirection","itemDirection","reactions","length"],"mappings":"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","sourcesContent":["import {createHash, parseChar, parseId, parseNum, parseString} from '@nlabs/utils';\nimport {aql} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\n\nimport {\n  ApiContext,\n  QueryFilter,\n  ReactionDirection,\n  ReactionOptions,\n  ReactionType,\n  UserReactionQuery,\n  UserType\n} from '../types';\nimport {getLimit, logError, logException, useDb} from '../utils';\n\nconst eventCategory: string = 'reactions';\n\nexport const parseReactionOptions = (options: ReactionOptions = {}) => {\n  const {\n    from = 0,\n    to = 30\n  } = options;\n\n  return {\n    limit: getLimit(from, to)\n  };\n};\n\nexport const addReaction = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string = 'users',\n  reaction: ReactionType = {},\n  allowDuplicate: boolean = false\n): Promise<ReactionType> => {\n  const action: string = 'addReaction';\n  const {database, userId: sessionId} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const {\n    name: itemName = 'like',\n    value: itemValue\n  } = reaction;\n  const formatItemId: string = parseId(itemId);\n  const formatItemType: any = parseChar(itemType, 32);\n  const formatReactionName: string = parseChar(itemName, 32);\n  const formatValue: string = parseString(itemValue, 32);\n  const edgeCollection = useDb(database).edgeCollection('hasReactions');\n  const typeDocId: string = `${formatItemType}/${formatItemId}`;\n  const sessionDocId: string = `users/${sessionId}`;\n  const edgeId: string = createHash(`reaction-${formatItemId}-${sessionId}`);\n  const edge: ReactionType = {\n    _key: edgeId,\n    added: Date.now(),\n    name: formatReactionName,\n    type: formatItemType,\n    value: itemValue !== undefined ? formatValue : undefined\n  };\n\n  // Check for duplicates if not allowed\n  if(!allowDuplicate) {\n    // Query\n    const aqlQry: AqlQuery = aql`FOR r IN hasReactions\n      FILTER r._from == ${sessionDocId} && r._to == ${typeDocId} && r.name == ${formatReactionName}\n      LIMIT 1\n      RETURN r`;\n\n    return useDb(database).query(aqlQry)\n      .then((cursor: ArrayCursor) => cursor.next())\n      .then((reaction) => {\n        if(!!reaction) {\n          return reaction;\n        }\n\n        return edgeCollection.save(edge, sessionDocId, typeDocId).then(() => edge);\n      })\n      .catch((error: Error) => logError({\n        action,\n        category: eventCategory,\n        label: 'db_error'\n      }, error, context).then(() => null));\n  }\n\n  return edgeCollection.save(edge, sessionDocId, typeDocId).then(() => edge);\n};\n\nexport const removeReaction = (context: ApiContext, reactionId: string): Promise<ReactionType> => {\n  const action: string = 'removeReaction';\n  const {database, userId: sessionId} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const formatSessionnId: string = `users/${parseId(sessionId)}`;\n  const formatReactionId: string = `hasReactions/${parseId(reactionId)}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`LET r = DOCUMENT(${formatReactionId})\n    FILTER r._from == ${formatSessionnId}\n    LIMIT 1\n    REMOVE r IN hasReactions\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\nexport const removeReactionByItem = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string\n): Promise<ReactionType> => {\n  const action: string = 'removeReaction';\n  const {database, userId: sessionId} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const formatSessionId: string = `users/${parseId(sessionId)}`;\n  const formatItemType: string = parseChar(itemType, 32);\n  const formatItemDocId: string = `${formatItemType}/${parseId(itemId)}`;\n  const formatReactionName: string = parseChar(reactionName, 32);\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR r IN hasReactions\n    FILTER r._from == ${formatSessionId}\n      && r._to == ${formatItemDocId}\n      && r.type == ${formatItemType}\n      && r.name == ${formatReactionName}\n    LIMIT 1\n    REMOVE r IN hasReactions\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\nexport const updateReaction = (context: ApiContext, reaction: ReactionType = {}): Promise<ReactionType> => {\n  const action: string = 'updateReaction';\n  const {database, userId: sessionId} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const {\n    id: itemId,\n    name: itemName,\n    type: itemType,\n    value: itemValue\n  } = reaction;\n  const formatId: string = parseId(itemId);\n  const formatName: string = parseChar(itemName, 32);\n  const formatType: any = parseChar(itemType, 32);\n  const formatValue: string = parseString(itemValue, 32);\n  const edgeId: string = createHash(`reaction-${formatId}-${sessionId}`);\n  const update: ReactionType = {\n    name: formatName,\n    type: formatType,\n    value: formatValue\n  };\n  const insert: ReactionType = {\n    ...update,\n    _key: edgeId,\n    added: Date.now()\n  };\n\n  // Query\n  const aqlQry: AqlQuery = aql`UPSERT ${{_key: formatId}}\n    INSERT ${insert}\n    UPDATE ${update}\n    LIMIT 1\n    RETURN NEW`;\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 getReactionCount = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string\n): Promise<ReactionType> => {\n  const action: string = 'getReactionCount';\n  const {database} = context;\n  const formatItemId: string = parseId(itemId);\n  const formatReactionName: any = parseChar(reactionName, 32);\n  const formatItemType: any = parseChar(itemType, 32);\n  const itemDocId: string = `${formatItemType}/${formatItemId}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR i, r IN INBOUND ${itemDocId} hasReactions\n    FILTER r.name == ${formatReactionName} && r.type == ${formatItemType}\n    COLLECT WITH COUNT INTO count\n    RETURN count`;\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 getReactionCountByUser = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string\n): Promise<ReactionType[]> => {\n  const action: string = 'getReactionsByUser';\n  const {database, userId: sessionId} = context;\n  const formatItemId: string = parseId(itemId);\n  const formatReactionName: any = parseChar(reactionName, 32);\n  const formatItemType: any = parseChar(itemType, 32);\n  const sessionDocId: string = `users/${sessionId}`;\n  const itemDocId: string = `${formatItemType}/${formatItemId}`;\n\n  // Query\n  const aqlQry: AqlQuery = aql`FOR i, r IN INBOUND ${itemDocId} hasReactions\n      FILTER r.name == ${formatReactionName} && r._from == ${sessionDocId}\n      COLLECT reactionValue = r.value INTO reactionItems\n      RETURN MERGE(r, {count: LENGTH(reactionItems[*].r.value)})`;\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 getGroupUsersByReaction = (context: ApiContext, params: UserReactionQuery = {}): Promise<UserType[]> => {\n  const action: string = 'getUsersByReaction';\n  const {database, userId: sessionId} = context;\n\n  if(!sessionId) {\n    return logException({\n      action,\n      category: eventCategory,\n      label: 'unauthorized',\n      value: 'invalid_session'\n    }, context).then(() => null);\n  }\n\n  const {filters = [], id: groupId, value}: UserReactionQuery = params;\n  const reaction = parseChar(value, 32);\n  const groupDocId = `groups/${parseId(groupId)}`;\n  const filterStr: string = filters\n    .map((filter: QueryFilter) => {\n      const {conditional, name, value: queryValue}: QueryFilter = filter;\n      let filterCond: string = conditional;\n\n      if(conditional !== '>=' && conditional !== '<=' && conditional !== '>' && conditional !== '<') {\n        filterCond = '==';\n      }\n\n      switch(name) {\n        case 'added':\n          return `r.added ${filterCond} ${parseNum(queryValue)}`;\n        default:\n          return '';\n      }\n    })\n    .concat([\n      `r.value == \"${reaction}\"`,\n      'u._id == r._from'\n    ])\n    .join(' && ');\n\n  // Query\n  const aqlQry: string = `FOR g, r IN INBOUND \"${groupDocId}\" hasReactions\n      FOR u IN users\n      FILTER  ${filterStr}\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 getReactionsByItem = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string,\n  options: ReactionOptions\n): Promise<UserType[]> => {\n  const action: string = 'getUsersByReactions';\n  const {database} = context;\n  const formatItemId: string = parseId(itemId);\n  const formatItemType: string = parseChar(itemType, 32);\n  const formatReactionName: string = parseChar(reactionName, 32);\n  const itemDocId = `${formatItemType}/${formatItemId}`;\n  const {limit} = parseReactionOptions(options);\n  const aqlQry: string = `FOR i, r IN INBOUND \"${itemDocId}\" hasReactions\n    FILTER r.name == \"${formatReactionName}\"\n    ${limit.aql}\n    RETURN MERGE(i, {reaction: 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 getItemsByReaction = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string,\n  options: ReactionOptions\n): Promise<ReactionType[]> => {\n  const action: string = 'getUserReactionsByReaction';\n  const {database} = context;\n  const formatItemId: string = parseId(itemId);\n  const formatItemType: string = parseChar(itemType, 32);\n  const formatReactionName: string = parseChar(reactionName, 32);\n  const itemDocId = `${formatItemType}/${formatItemId}`;\n  const {limit} = parseReactionOptions(options);\n\n  // Query\n  const aqlQry: string = `FOR u, r IN OUTBOUND \"${itemDocId}\" hasReactions\n    FILTER r.name == ${formatReactionName}\n    ${limit.aql}\n    RETURN MERGE(u, {reaction: 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 hasReaction = (\n  context: ApiContext,\n  itemId: string,\n  itemType: string,\n  reactionName: string,\n  direction: ReactionDirection = 'OUTBOUND'\n): Promise<ReactionType[]> => {\n  const action: string = 'getReactionsByUser';\n  const {database, userId: sessionId} = context;\n  const sessionDocId: string = `users/${sessionId}`;\n  const formatItemId: string = parseId(itemId);\n  const formatItemType: string = parseChar(itemType, 32);\n  const formatDirection = direction === 'OUTBOUND' ? 'OUTBOUND' : 'INBOUND';\n  const itemDirection: string = direction === 'OUTBOUND' ? 'r._to' : 'r._from';\n  const itemDocId: string = `${formatItemType}/${formatItemId}`;\n\n  // Query\n  const aqlQry: string = `FOR i, r IN ${formatDirection} \"${sessionDocId}\" hasReactions\n    FILTER r.name == \"${reactionName}\" && ${itemDirection} == \"${itemDocId}\"\n    RETURN MERGE(i, {reaction: r})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((reactions = []) => !!reactions.length)\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: 'db_error'\n    }, error, context).then(() => null));\n};\n"]}
|
package/lib/data/users.js
CHANGED
|
@@ -19,16 +19,6 @@ function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj;
|
|
|
19
19
|
|
|
20
20
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
21
21
|
|
|
22
|
-
function _templateObject5() {
|
|
23
|
-
var data = _taggedTemplateLiteral(["FOR u IN users\n FILTER u._key == ", "\n ", "\n LIMIT 1\n RETURN MERGE(u, {", "})"]);
|
|
24
|
-
|
|
25
|
-
_templateObject5 = function _templateObject5() {
|
|
26
|
-
return data;
|
|
27
|
-
};
|
|
28
|
-
|
|
29
|
-
return data;
|
|
30
|
-
}
|
|
31
|
-
|
|
32
22
|
function _templateObject4() {
|
|
33
23
|
var data = _taggedTemplateLiteral(["UPDATE ", " WITH ", " IN users LIMIT 1 RETURN NEW"]);
|
|
34
24
|
|
|
@@ -238,7 +228,7 @@ var getSessionUser = function getSessionUser(context) {
|
|
|
238
228
|
selectQueries = _getUserOptional.queries; // Get data from database
|
|
239
229
|
|
|
240
230
|
|
|
241
|
-
var aqlQry =
|
|
231
|
+
var aqlQry = "FOR u IN users\n FILTER u._key == \"".concat(sessionId, "\"\n ").concat(selectQueries.join('\n'), "\n LIMIT 1\n RETURN MERGE(u, {").concat(selectObjects.join(', '), "})");
|
|
242
232
|
return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
|
|
243
233
|
return cursor.next();
|
|
244
234
|
}).then(function () {
|
|
@@ -426,4 +416,4 @@ var getDisplayName = function getDisplayName() {
|
|
|
426
416
|
};
|
|
427
417
|
|
|
428
418
|
exports.getDisplayName = getDisplayName;
|
|
429
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/users.ts"],"names":["eventCategory","getUserOptional","fields","reduce","selects","field","queries","push","objects","parseUserOptions","options","from","to","limit","addUser","context","user","database","email","phone","sub","username","insert","_key","added","Date","now","undefined","modified","aqlQry","aql","query","then","cursor","next","updateUser","userId","updated","userDocId","error","console","log","deleteUser","action","sessionId","sessionAccess","userAccess","isAdmin","category","label","value","stripe","customers","del","stripeCustomerId","accounts","stripeAccountId","deactivateUser","getSessionUser","selectObjects","selectQueries","join","getUser","formatUserId","getUserList","all","getUsersByReaction","reactionName","formatSessionId","formatReactionName","getUsersByRecent","getUsersByUsername","formatQuery","getDisplayName","first","last","name","fullname","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} 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 {UserOptions, UserType} from '../types/users';\nimport {getLimit, logError, logException, useDb} from '../utils';\n\nconst eventCategory: string = 'users';\nexport const getUserOptional = (fields: string[]) =>\n  fields.reduce((selects: any, field: string) => {\n    switch(field) {\n      case 'likes': {\n        selects.queries.push(`LET likes = FIRST(\n          FOR usr, r IN INBOUND u._id hasReactions\n          FILTER r.name == \"like\" && r.type == \"users\"\n          COLLECT WITH COUNT INTO count\n          RETURN count\n        )`);\n        selects.objects.push('likes:likes');\n        return selects;\n      }\n      case 'views': {\n        selects.queries.push(`LET views = FIRST(\n          FOR usr, r IN INBOUND u._id hasReactions\n          FILTER r.name == \"view\" && r.type == \"users\"\n          COLLECT WITH COUNT INTO count\n          RETURN count\n        )`);\n        selects.objects.push('views:views');\n        return selects;\n      }\n      default: {\n        return selects;\n      }\n    }\n  }, {objects: [], queries: []});\n\nexport const parseUserOptions = (options: UserOptions = {}) => {\n  const {\n    from = 0,\n    to = 30\n  } = options;\n\n  return {\n    limit: getLimit(from, to)\n  };\n};\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 updateUser = (context: ApiContext, user: UserType): Promise<UserType> => {\n  const {database} = context;\n  const {userId, ...updated} = user;\n  const userDocId: string = `users/${userId}`;\n  const aqlQry: AqlQuery = aql`LET doc = DOCUMENT(${userDocId})\n    UPDATE doc WITH ${updated} IN users RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor) => cursor.next())\n    .catch((error: Error) => {\n      console.log(error);\n      throw error;\n    });\n};\n\nexport const deleteUser = (context: ApiContext, userId: string): Promise<UserType> => {\n  const action: string = 'delete';\n  const {database, userId: sessionId, userAccess: sessionAccess} = context;\n  const isAdmin: boolean = sessionAccess > 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, userAccess: sessionAccess} = context;\n  const isAdmin: boolean = sessionAccess > 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    userAccess: 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, fields, userId: sessionId} = context;\n  const {objects: selectObjects, queries: selectQueries} = getUserOptional(fields);\n\n  // Get data from database\n  const aqlQry = aql`FOR u IN users\n  FILTER u._key == ${sessionId}\n  ${selectQueries.join('\\n')}\n  LIMIT 1\n  RETURN MERGE(u, {${selectObjects.join(', ')}})`;\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: string): Promise<UserType> => {\n  const action: string = 'getItem';\n  const formatUserId: string = parseId(userId);\n  const {database, fields} = context;\n  const {objects: selectObjects, queries: selectQueries} = getUserOptional(fields);\n\n  // Get data from database\n  const aqlQry: string = `FOR u IN users\n    ${selectQueries.join('\\n')}\n    FILTER u._key == \"${formatUserId}\"\n    LIMIT 1\n    RETURN MERGE(u, {${selectObjects.join(', ')}})`;\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, options?: UserOptions): Promise<UserType> => {\n  const action: string = 'getUserList';\n  const {database, fields} = context;\n  const {limit} = parseUserOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getUserOptional(fields);\n\n  // Get data from database\n  const aqlQry: string = `FOR u IN users\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT u.username\n    RETURN MERGE(u, {${selectObjects.join(', ')}})`;\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 getUsersByReaction = (\n  context: ApiContext,\n  reactionName: string,\n  options?: UserOptions\n): Promise<UserType> => {\n  const action: string = 'getUsersByReaction';\n  const {database, fields, userId: sessionId} = context;\n  const {limit} = parseUserOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getUserOptional(fields);\n\n  const formatSessionId: string = `users/${sessionId}`;\n  const formatReactionName: string = parseChar(reactionName, 32);\n\n  // Get data from database\n  const aqlQry: string = `FOR u, r IN OUTBOUND \"${formatSessionId}\" hasReactions\n    ${selectQueries.join('\\n')}\n    FILTER r.type == \"users\" && r.name == \"${formatReactionName}\"\n    ${limit.aql}\n    RETURN MERGE(u, {${selectObjects.join(', ')}})`;\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 getUsersByRecent = (context: ApiContext, options?: UserOptions): Promise<UserType> => {\n  const action: string = 'getUsersByUsername';\n  const {database, fields} = context;\n  const {limit} = parseUserOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getUserOptional(fields);\n\n  // Get data from database\n  const aqlQry: string = `FOR u IN users\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT u.added DESC\n    RETURN MERGE(u, {${selectObjects.join(', ')}})`;\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 getUsersByUsername = (context: ApiContext, query: string, options?: UserOptions): Promise<UserType> => {\n  const action: string = 'getUsersByUsername';\n  const {database, fields} = context;\n  const {limit} = parseUserOptions(options);\n  const formatQuery: string = parseVarChar(query, 32);\n  const {objects: selectObjects, queries: selectQueries} = getUserOptional(fields);\n\n  // Get data from database\n  const aqlQry: string = `FOR u IN users\n    FILTER CONTAINS(u.username, \"${formatQuery}\")\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT u.username\n    RETURN MERGE(u, {${selectObjects.join(', ')}})`;\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 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"]}
|
|
419
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/users.ts"],"names":["eventCategory","getUserOptional","fields","reduce","selects","field","queries","push","objects","parseUserOptions","options","from","to","limit","addUser","context","user","database","email","phone","sub","username","insert","_key","added","Date","now","undefined","modified","aqlQry","aql","query","then","cursor","next","updateUser","userId","updated","userDocId","error","console","log","deleteUser","action","sessionId","sessionAccess","userAccess","isAdmin","category","label","value","stripe","customers","del","stripeCustomerId","accounts","stripeAccountId","deactivateUser","getSessionUser","selectObjects","selectQueries","join","getUser","formatUserId","getUserList","all","getUsersByReaction","reactionName","formatSessionId","formatReactionName","getUsersByRecent","getUsersByUsername","formatQuery","getDisplayName","first","last","name","fullname","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} 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 {UserOptions, UserType} from '../types/users';\nimport {getLimit, logError, logException, useDb} from '../utils';\n\nconst eventCategory: string = 'users';\nexport const getUserOptional = (fields: string[]) =>\n  fields.reduce((selects: any, field: string) => {\n    switch(field) {\n      case 'likes': {\n        selects.queries.push(`LET likes = FIRST(\n          FOR usr, r IN INBOUND u._id hasReactions\n          FILTER r.name == \"like\" && r.type == \"users\"\n          COLLECT WITH COUNT INTO count\n          RETURN count\n        )`);\n        selects.objects.push('likes:likes');\n        return selects;\n      }\n      case 'views': {\n        selects.queries.push(`LET views = FIRST(\n          FOR usr, r IN INBOUND u._id hasReactions\n          FILTER r.name == \"view\" && r.type == \"users\"\n          COLLECT WITH COUNT INTO count\n          RETURN count\n        )`);\n        selects.objects.push('views:views');\n        return selects;\n      }\n      default: {\n        return selects;\n      }\n    }\n  }, {objects: [], queries: []});\n\nexport const parseUserOptions = (options: UserOptions = {}) => {\n  const {\n    from = 0,\n    to = 30\n  } = options;\n\n  return {\n    limit: getLimit(from, to)\n  };\n};\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 updateUser = (context: ApiContext, user: UserType): Promise<UserType> => {\n  const {database} = context;\n  const {userId, ...updated} = user;\n  const userDocId: string = `users/${userId}`;\n  const aqlQry: AqlQuery = aql`LET doc = DOCUMENT(${userDocId})\n    UPDATE doc WITH ${updated} IN users RETURN NEW`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor) => cursor.next())\n    .catch((error: Error) => {\n      console.log(error);\n      throw error;\n    });\n};\n\nexport const deleteUser = (context: ApiContext, userId: string): Promise<UserType> => {\n  const action: string = 'delete';\n  const {database, userId: sessionId, userAccess: sessionAccess} = context;\n  const isAdmin: boolean = sessionAccess > 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, userAccess: sessionAccess} = context;\n  const isAdmin: boolean = sessionAccess > 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    userAccess: 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, fields, userId: sessionId} = context;\n  const {objects: selectObjects, queries: selectQueries} = getUserOptional(fields);\n\n  // Get data from database\n  const aqlQry: string = `FOR u IN users\n  FILTER u._key == \"${sessionId}\"\n  ${selectQueries.join('\\n')}\n  LIMIT 1\n  RETURN MERGE(u, {${selectObjects.join(', ')}})`;\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: string): Promise<UserType> => {\n  const action: string = 'getItem';\n  const formatUserId: string = parseId(userId);\n  const {database, fields} = context;\n  const {objects: selectObjects, queries: selectQueries} = getUserOptional(fields);\n\n  // Get data from database\n  const aqlQry: string = `FOR u IN users\n    ${selectQueries.join('\\n')}\n    FILTER u._key == \"${formatUserId}\"\n    LIMIT 1\n    RETURN MERGE(u, {${selectObjects.join(', ')}})`;\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, options?: UserOptions): Promise<UserType> => {\n  const action: string = 'getUserList';\n  const {database, fields} = context;\n  const {limit} = parseUserOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getUserOptional(fields);\n\n  // Get data from database\n  const aqlQry: string = `FOR u IN users\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT u.username\n    RETURN MERGE(u, {${selectObjects.join(', ')}})`;\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 getUsersByReaction = (\n  context: ApiContext,\n  reactionName: string,\n  options?: UserOptions\n): Promise<UserType> => {\n  const action: string = 'getUsersByReaction';\n  const {database, fields, userId: sessionId} = context;\n  const {limit} = parseUserOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getUserOptional(fields);\n\n  const formatSessionId: string = `users/${sessionId}`;\n  const formatReactionName: string = parseChar(reactionName, 32);\n\n  // Get data from database\n  const aqlQry: string = `FOR u, r IN OUTBOUND \"${formatSessionId}\" hasReactions\n    ${selectQueries.join('\\n')}\n    FILTER r.type == \"users\" && r.name == \"${formatReactionName}\"\n    ${limit.aql}\n    RETURN MERGE(u, {${selectObjects.join(', ')}})`;\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 getUsersByRecent = (context: ApiContext, options?: UserOptions): Promise<UserType> => {\n  const action: string = 'getUsersByUsername';\n  const {database, fields} = context;\n  const {limit} = parseUserOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getUserOptional(fields);\n\n  // Get data from database\n  const aqlQry: string = `FOR u IN users\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT u.added DESC\n    RETURN MERGE(u, {${selectObjects.join(', ')}})`;\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 getUsersByUsername = (context: ApiContext, query: string, options?: UserOptions): Promise<UserType> => {\n  const action: string = 'getUsersByUsername';\n  const {database, fields} = context;\n  const {limit} = parseUserOptions(options);\n  const formatQuery: string = parseVarChar(query, 32);\n  const {objects: selectObjects, queries: selectQueries} = getUserOptional(fields);\n\n  // Get data from database\n  const aqlQry: string = `FOR u IN users\n    FILTER CONTAINS(u.username, \"${formatQuery}\")\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT u.username\n    RETURN MERGE(u, {${selectObjects.join(', ')}})`;\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 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/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@nlabs/reaktor",
|
|
3
|
-
"version": "0.2.
|
|
3
|
+
"version": "0.2.2",
|
|
4
4
|
"description": "Reaktor",
|
|
5
5
|
"main": "./index.js",
|
|
6
6
|
"types": "./lib/index.d.js",
|
|
@@ -27,13 +27,13 @@
|
|
|
27
27
|
"scripts": {
|
|
28
28
|
"build": "lex compile -r",
|
|
29
29
|
"clean": "lex clean",
|
|
30
|
-
"git:tags": "git push --tags && git push",
|
|
31
30
|
"lint": "eslint ./src --ext .ts,.tsx",
|
|
32
31
|
"prepublishOnly": "npm run build",
|
|
33
32
|
"pretest": "stage=test npm run lint",
|
|
34
|
-
"publish:major": "npm version major && npm run
|
|
35
|
-
"publish:minor": "npm version minor && npm run
|
|
36
|
-
"publish:patch": "npm version patch && npm run
|
|
33
|
+
"publish:major": "npm version major && npm run publish:tags && npm publish",
|
|
34
|
+
"publish:minor": "npm version minor && npm run publish:tags && npm publish",
|
|
35
|
+
"publish:patch": "npm version patch && npm run publish:tags && npm publish",
|
|
36
|
+
"publish:tags": "git push --tags && git push origin HEAD",
|
|
37
37
|
"test": "stage=test jest",
|
|
38
38
|
"update": "lex update -i"
|
|
39
39
|
},
|