@nlabs/reaktor 0.1.17 → 0.2.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/posts.js CHANGED
@@ -71,7 +71,9 @@ function _templateObject4() {
71
71
  return data;
72
72
  }
73
73
 
74
- 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; }
74
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
75
+
76
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
75
77
 
76
78
  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; }
77
79
 
@@ -107,6 +109,10 @@ function _templateObject() {
107
109
 
108
110
  function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
109
111
 
112
+ /**
113
+ * Copyright (c) 2019-Present, Nitrogen Labs, Inc.
114
+ * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
115
+ */
110
116
  // const eventCategory: string = 'posts';
111
117
  var MAX_CONTENT_LENGTH = 100000;
112
118
 
@@ -359,7 +365,7 @@ var getPostListByTags = function getPostListByTags(context, tagNames, options) {
359
365
 
360
366
  sortBy.push('p.added');
361
367
  return Promise.all(tagNames.map(function (tagName) {
362
- var aqlQry = "FOR targetTag IN tags\n FILTER targetTag.name == \"".concat(tagName, "\"\n FOR p, e IN OUTBOUND targetTag._id isTagged\n ").concat(selectQueries.join('\n'), "\n FILTER p.type = \"").concat(type, "\" && p.privacy == \"public\" && e.type == 'posts'\n ").concat(limit.aql, "\n SORT ").concat(sortBy.join(', '), "\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
368
+ var aqlQry = "FOR targetTag IN tags\n FILTER targetTag.name == \"".concat(tagName, "\"\n FOR p, e IN OUTBOUND targetTag._id isTagged\n ").concat(selectQueries.join('\n'), "\n FILTER p.type == \"").concat(type, "\" && p.privacy == \"public\" && e.type == 'posts'\n ").concat(limit.aql, "\n SORT ").concat(sortBy.join(', '), "\n RETURN DISTINCT MERGE(p, {").concat(selectObjects.join(', '), "})");
363
369
  return (0, _utils2.useDb)(database).query(aqlQry).then(function (cursor) {
364
370
  return cursor.all();
365
371
  })["catch"](function () {
@@ -634,4 +640,4 @@ var createPostEdge = function createPostEdge(db, file, postId) {
634
640
  };
635
641
 
636
642
  exports.createPostEdge = createPostEdge;
637
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/posts.ts"],"names":["MAX_CONTENT_LENGTH","parsePostOptions","options","from","latitude","longitude","to","type","limit","getPostOptional","fields","reduce","selects","field","queries","push","objects","getPost","context","itemId","database","sessionId","userId","formatItemId","db","selectObjects","selectQueries","aqlQry","aql","query","then","cursor","next","post","_key","groupId","privacy","privacyAqlQry","join","filteredPost","error","getPostList","all","getPostListByArea","formatLatitude","formatLongitude","getPostListByGroup","formatGroupId","groups","length","postAqlQry","getPostListByLatest","getPostListByTags","tagNames","sortBy","undefined","Promise","map","tagName","results","getPostListByUser","formatUserId","getPostComments","addPost","item","content","location","name","parentId","now","Date","insert","added","modified","postKey","tagList","tags","updatePost","postId","update","formatId","updatedPost","updatedPostKey","files","fileList","deletePost","edgeAqlQry","fileAqlQry","cleanPosts","createPostEdge","file","edgeCollection","fileId","formatFileId","edgeId","formatPostId","fileType","edge","save"],"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, parseId, parseNum, parseString, parseVarChar} from '@nlabs/utils';\nimport {aql, Database} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport flatten from 'lodash/flatten';\nimport uniqBy from 'lodash/uniqBy';\n\nimport {ApiContext, FileType, GroupType, PostOptions, PostType, TagType} from '../types';\nimport {getLimit, useDb} from '../utils';\nimport {updateFiles} from './files';\nimport {extractTags} from './tags';\n\n// const eventCategory: string = 'posts';\nconst MAX_CONTENT_LENGTH: number = 100000;\n\nexport const parsePostOptions = (options: PostOptions = {}) => {\n  const {\n    from = 0,\n    latitude = 0,\n    longitude = 0,\n    to = 30,\n    type = 'default'\n  } = options;\n\n\n  return {\n    latitude: parseNum(latitude, 32),\n    limit: getLimit(from, to),\n    longitude: parseNum(longitude, 32),\n    type: parseChar(type, 32)\n  };\n};\n\nexport const getPostOptional = (fields: string[]) =>\n  fields.reduce((selects: any, field: string) => {\n    switch(field) {\n      case 'reactions': {\n        selects.queries.push(`LET reactions = (\n          FOR post, r IN INBOUND p._id reactions\n          COLLECT reactionName = r.value INTO reactionItems\n          RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n        )`);\n        selects.objects.push('reactions:reactions');\n        return selects;\n      }\n      case 'tags': {\n        selects.queries.push(`LET tags = (\n          FOR t, pl IN INBOUND p._id isTagged\n          RETURN t\n        )`);\n        selects.objects.push('tags:tags');\n        return selects;\n      }\n      case 'user': {\n        selects.queries.push(`LET user = FIRST(\n          FOR u IN users\n          FILTER p.userId == u._key\n          LIMIT 1\n          RETURN u\n        )`);\n        selects.objects.push('user:user');\n        return selects;\n      }\n      default: {\n        return selects;\n      }\n    }\n  }, {objects: [], queries: []});\n\nexport const getPost = (context: ApiContext, itemId: string): Promise<PostType> => {\n  // const action: string = 'getItem';\n  const {database, fields, userId: sessionId} = context;\n  const formatItemId: string = parseId(itemId);\n  const db = useDb(database);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: AqlQuery = aql`FOR p IN posts\n    FILTER p._key == ${formatItemId}\n    LIMIT 1\n    RETURN p`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      const {\n        _key,\n        groupId,\n        privacy = 'default'\n      }: PostType = post;\n\n      // Query based on privacy level\n      let privacyAqlQry: string;\n\n      if(groupId && privacy === 'group') {\n        privacyAqlQry = `FOR p IN posts\n          FILTER p._key == \"${_key}\"\n          ${selectQueries.join('\\n')}\n          FOR group IN groups\n          FILTER group._key == p.groupId\n          FOR u, e IN OUTBOUND group._id isGrouped\n          FILTER u._key == ${sessionId}\n          LIMIT 1\n          RETURN MERGE(p, {${selectObjects.join(', ')}})`;\n      } else if(privacy === 'public') {\n        privacyAqlQry = `FOR p IN posts\n          FILTER p._key == \"${_key}\"\n          ${selectQueries.join('\\n')}\n          LIMIT 1\n          RETURN MERGE(p, {${selectObjects.join(', ')}})`;\n      }\n\n      if(privacyAqlQry) {\n        return db.query(privacyAqlQry)\n          .then((cursor: ArrayCursor) => cursor.next())\n          .then((filteredPost: PostType = {}) => filteredPost)\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n\n      return {};\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostList = (context: ApiContext, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getListByApp';\n  const {database, fields} = context;\n  const {limit, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: string = `FOR p IN posts\n    FILTER p.type == \"${type}\" && p.privacy == \"public\" && p.parent == null\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByArea = (\n  context: ApiContext,\n  latitude: number,\n  longitude: number,\n  options?: PostOptions\n): Promise<PostType[]> => {\n  // const action: string = 'getListByUser';\n  const {database, fields} = context;\n  const {limit, type} = parsePostOptions(options);\n  const formatLatitude: number = parseNum(latitude);\n  const formatLongitude: number = parseNum(longitude);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  selectQueries.push(`LET distance = DISTANCE(\n    ${formatLatitude},\n    ${formatLongitude},\n    NOT_NULL(p.latitude, 0),\n    NOT_NULL(p.longitude, 0))\n  `);\n  selectObjects.push('distance:distance');\n\n  const aqlQry: string = `FOR p IN posts\n    ${selectQueries.join('\\n')}\n    FILTER p.type == \"${type}\" && p.privacy == \"public\" && p.parentId == null\n    ${limit.aql}\n    SORT distance, p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByGroup = (\n  context: ApiContext,\n  groupId: string,\n  options?: PostOptions\n): Promise<PostType[]> => {\n  // const action: string = 'getListByGroup';\n  const {database, fields, userId: sessionId} = context;\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n\n  // Group id\n  const formatGroupId: string = parseId(groupId);\n  const db = useDb(database);\n  const aqlQry: string = `FOR u, g IN INBOUND ${formatGroupId} hasGroup\n      FILTER u._key == ${sessionId}\n      RETURN g`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((groups: GroupType[] = []) => {\n      if(groups.length) {\n        const {limit, type} = parsePostOptions(options);\n        const postAqlQry: string = `FOR p IN posts\n          FILTER p.type == \"${type}\" && p.groupId == \"${formatGroupId}\" && p.parent == null\n          ${selectQueries.join('\\n')}\n          ${limit.aql}\n          SORT p.added\n          RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n        return db.query(postAqlQry)\n          .then((cursor: ArrayCursor) => cursor.all())\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n\n      return [];\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByLatest = (context: ApiContext, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getListByLatest';\n  const {database, fields} = context;\n  const {limit, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: string = `FOR p IN posts\n    FILTER p.type == \"${type}\" && p.privacy == \"public\" && p.parent == null\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByTags = (\n  context: ApiContext,\n  tagNames: string[],\n  options?: PostOptions\n): Promise<PostType[]> => {\n  // const action: string = 'getListByTags';\n  const {database, fields} = context;\n  const {latitude, longitude, limit, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const sortBy: string[] = [];\n\n  if(latitude !== undefined && longitude !== undefined) {\n    const formatLatitude: number = parseNum(latitude);\n    const formatLongitude: number = parseNum(longitude);\n    selectQueries.push(`LET distance = DISTANCE(\n      ${formatLatitude},\n      ${formatLongitude},\n      NOT_NULL(p.latitude, 0),\n      NOT_NULL(p.longitude, 0))\n    `);\n    selectObjects.push('distance:distance');\n    sortBy.push('distance');\n  }\n\n  sortBy.push('p.added');\n\n  return Promise.all(\n    tagNames.map((tagName: string) => {\n      const aqlQry: string = `FOR targetTag IN tags\n        FILTER targetTag.name == \"${tagName}\"\n        FOR p, e IN OUTBOUND targetTag._id isTagged\n        ${selectQueries.join('\\n')}\n        FILTER p.type = \"${type}\" && p.privacy == \"public\" && e.type == 'posts'\n        ${limit.aql}\n        SORT ${sortBy.join(', ')}\n        RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.all())\n        .catch(() => []);\n    }))\n    .then((results) => uniqBy(flatten(results), '_key'))\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByUser = (context: ApiContext, userId: string, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getListByUser';\n  const {database, fields} = context;\n  const {limit, type} = parsePostOptions(options);\n  const formatUserId: string = parseId(userId);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: string = `FOR p IN posts\n    FILTER p.userId == \"${formatUserId}\" && p.type == \"${type}\" && p.privacy == \"public\" && p.parent == null\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostComments = (context: ApiContext, itemId: string, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getComments';\n  const {database, userId: sessionId} = context;\n  const {limit, type} = parsePostOptions(options);\n  const formatItemId: string = parseId(itemId);\n\n  // Get the parent post to get restrictions\n  const db = useDb(database);\n  const aqlQry: AqlQuery = aql`FOR p IN posts\n    FILTER p.type == ${type} && p._key == ${formatItemId}\n    LIMIT 1\n    RETURN p`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      const {\n        _key,\n        groupId,\n        privacy = 'public'\n      }: PostType = post;\n\n      // Query based on privacy level\n      let privacyAqlQry: string;\n\n      if(groupId && privacy === 'group') {\n        privacyAqlQry = `FOR p IN posts\n          FOR user IN users\n          FILTER p.parent == \"${_key}\" && user._key == p.userId\n          LET reactions = (\n            FOR post, r IN INBOUND p._id reactions\n            COLLECT reactionName = r.value INTO reactionItems\n            RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n          )\n          FOR group IN groups\n          FILTER group._key == p.groupId\n          FOR u, e IN OUTBOUND group._id isGrouped\n          FILTER u._key == \"${sessionId}\"\n          SORT p.added\n          ${limit.aql}\n          RETURN MERGE(p, {user: user, reactions: reactions})`;\n      } else if(privacy === 'public') {\n        privacyAqlQry = `FOR p IN posts\n          FOR user IN users\n          FILTER p.parent == \"${_key}\" && user._key == p.userId\n          LET reactions = (\n            FOR post, r IN INBOUND p._id reactions\n            COLLECT reactionName = r.value INTO reactionItems\n            RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n          )\n          SORT p.added\n          ${limit.aql}\n          RETURN MERGE(p, {user: user, reactions: reactions})`;\n      }\n\n      if(privacyAqlQry) {\n        return db.query(privacyAqlQry)\n          .then((cursor: ArrayCursor) => cursor.all())\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n\n      return [];\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const addPost = (context: ApiContext, item: PostType): Promise<PostType> => {\n  // const action: string = 'add';\n  const {database, userId: sessionId} = context;\n\n  const {\n    content = '',\n    groupId = '',\n    location,\n    latitude,\n    longitude,\n    name = '',\n    parentId = null,\n    privacy = 'public',\n    type = 'default'\n  }: PostType = item;\n\n  const now: number = Date.now();\n\n  const insert: PostType = {\n    _key: createHash(`post-${sessionId}`),\n    added: now,\n    content: parseString(content, MAX_CONTENT_LENGTH),\n    groupId: groupId ? parseId(groupId) : undefined,\n    latitude: latitude !== undefined ? parseNum(latitude) : undefined,\n    location: location ? parseString(location, 160) : undefined,\n    longitude: longitude !== undefined ? parseNum(longitude) : undefined,\n    modified: now,\n    name: parseString(name, 160),\n    parentId: parentId ? parseId(parentId) : undefined,\n    privacy: privacy ? parseVarChar(privacy, 16) : undefined,\n    type: parseChar(type, 32),\n    userId: sessionId\n  };\n\n  const db: Database = useDb(database);\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN posts RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      const {_key: postKey} = post;\n\n      // Update linked tags within posts\n      return extractTags(db, 'posts', postKey, insert.content)\n        .then((tagList: TagType[]) => {\n          post.tags = tagList;\n          return post;\n        });\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const updatePost = (context: ApiContext, item: PostType): Promise<PostType> => {\n  // const action: string = 'update';\n  const {database, userId: sessionId} = context;\n  const now: number = Date.now();\n  const {\n    content,\n    groupId,\n    name,\n    parentId,\n    postId,\n    privacy,\n    type\n  }: PostType = item;\n\n  const update: PostType = {\n    content: content ? parseString(content, MAX_CONTENT_LENGTH) : undefined,\n    modified: now,\n    name: name ? parseString(name, 160) : undefined,\n    parentId: parentId ? parseString(parentId, 160) : undefined,\n    privacy: privacy ? parseVarChar(privacy, 16) : undefined,\n    type: type !== undefined ? parseChar(type, 16) : undefined\n  };\n\n  let formatId: string = parseId(postId);\n  formatId = formatId === '' ? createHash(`post-${sessionId}`) : formatId;\n  const formatGroupId: string = parseId(groupId);\n  const insert: any = {\n    ...update,\n    _key: formatId,\n    added: now,\n    groupId: formatGroupId,\n    privacy,\n    userId: sessionId\n  };\n  const db: Database = useDb(database);\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${formatId}, userId: ${sessionId}}\n    INSERT ${insert}\n    UPDATE ${update}\n    IN posts RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((updatedPost: PostType = {}) => {\n      const {_key: updatedPostKey} = updatedPost;\n\n      // Update linked tags\n      return extractTags(db, 'posts', updatedPostKey, update.content || '')\n        .then((tagList = []) => {\n          updatedPost.tags = tagList;\n\n          // Update linked files\n          const files: FileType[] = updatedPost.files || [];\n\n          if(files.length) {\n            return updateFiles(db, formatId, files)\n              .then((fileList = []) => {\n                updatedPost.files = fileList;\n                return updatedPost;\n              });\n          }\n\n          updatedPost.files = [];\n          return updatedPost;\n        });\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const deletePost = (context: ApiContext, itemId: string): Promise<PostType> => {\n  // const action: string = 'delete';\n  const {database, userId: sessionId} = context;\n  const formatItemId: string = parseId(itemId);\n  const db: Database = useDb(database);\n  const aqlQry = aql`FOR p IN posts\n      FILTER p._key == ${formatItemId} && p.userId == ${sessionId}\n      LIMIT 1\n      REMOVE p IN posts\n      RETURN OLD`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      if(post) {\n        // Remove tag links\n        const edgeAqlQry: AqlQuery = aql`FOR t IN isTagged\n            FILTER t._to == ${formatItemId}\n            REMOVE t IN isTagged`;\n\n        return db.query(edgeAqlQry)\n          .then(() => {\n            // Remove attached files\n            const fileAqlQry: AqlQuery = aql`FOR f IN hasFile\n                FILTER f._to == ${formatItemId}\n                REMOVE f IN hasFile`;\n\n            return db.query(fileAqlQry)\n              .then(() => post)\n              .catch((error: Error) => {\n                throw error;\n              });\n          })\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n      return {};\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const cleanPosts = (database: string): Promise<number> => {\n  // Remove all messages that are over 60 days and not saved\n  const aqlQry: AqlQuery = aql`FOR p IN posts\n      FILTER p.added < DATE_TIMESTAMP(DATE_SUBTRACT(DATE_NOW(), 60, 'day')) && p.type == \"default\"\n      REMOVE p IN posts\n      RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((results: PostType[] = []) => results.length)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const createPostEdge = (db: Database, file: FileType, postId: string): Promise<FileType> => {\n  const edgeCollection = db.edgeCollection('isPosted');\n  const {fileId} = file;\n  const formatFileId: string = parseId(fileId);\n  const edgeId: string = createHash(`file-${postId}-${formatFileId}`);\n  const formatPostId: string = parseId(postId);\n  const fileType: string = parseChar(file.fileType, 16);\n\n  const edge: any = {\n    _key: edgeId,\n    added: Date.now(),\n    type: fileType\n  };\n\n  return edgeCollection.save(edge, `posts/${formatPostId}`, `files/${formatFileId}`)\n    .then(() => file)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n"]}
643
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/data/posts.ts"],"names":["MAX_CONTENT_LENGTH","parsePostOptions","options","from","latitude","longitude","to","type","limit","getPostOptional","fields","reduce","selects","field","queries","push","objects","getPost","context","itemId","database","sessionId","userId","formatItemId","db","selectObjects","selectQueries","aqlQry","aql","query","then","cursor","next","post","_key","groupId","privacy","privacyAqlQry","join","filteredPost","error","getPostList","all","getPostListByArea","formatLatitude","formatLongitude","getPostListByGroup","formatGroupId","groups","length","postAqlQry","getPostListByLatest","getPostListByTags","tagNames","sortBy","undefined","Promise","map","tagName","results","getPostListByUser","formatUserId","getPostComments","addPost","item","content","location","name","parentId","now","Date","insert","added","modified","postKey","tagList","tags","updatePost","postId","update","formatId","updatedPost","updatedPostKey","files","fileList","deletePost","edgeAqlQry","fileAqlQry","cleanPosts","createPostEdge","file","edgeCollection","fileId","formatFileId","edgeId","formatPostId","fileType","edge","save"],"mappings":"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","sourcesContent":["import {createHash, parseChar, parseId, parseNum, parseString, parseVarChar} from '@nlabs/utils';\nimport {aql, Database} from 'arangojs';\nimport {AqlQuery} from 'arangojs/lib/cjs/aql-query';\nimport {ArrayCursor} from 'arangojs/lib/cjs/cursor';\nimport flatten from 'lodash/flatten';\nimport uniqBy from 'lodash/uniqBy';\n\nimport {ApiContext, FileType, GroupType, PostOptions, PostType, TagType} from '../types';\nimport {getLimit, useDb} from '../utils';\nimport {updateFiles} from './files';\nimport {extractTags} from './tags';\n\n/**\n * Copyright (c) 2019-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\n// const eventCategory: string = 'posts';\nconst MAX_CONTENT_LENGTH: number = 100000;\n\nexport const parsePostOptions = (options: PostOptions = {}) => {\n  const {\n    from = 0,\n    latitude = 0,\n    longitude = 0,\n    to = 30,\n    type = 'default'\n  } = options;\n\n  return {\n    latitude: parseNum(latitude, 32),\n    limit: getLimit(from, to),\n    longitude: parseNum(longitude, 32),\n    type: parseChar(type, 32)\n  };\n};\n\nexport const getPostOptional = (fields: string[]) =>\n  fields.reduce((selects: any, field: string) => {\n    switch(field) {\n      case 'reactions': {\n        selects.queries.push(`LET reactions = (\n          FOR post, r IN INBOUND p._id reactions\n          COLLECT reactionName = r.value INTO reactionItems\n          RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n        )`);\n        selects.objects.push('reactions:reactions');\n        return selects;\n      }\n      case 'tags': {\n        selects.queries.push(`LET tags = (\n          FOR t, pl IN INBOUND p._id isTagged\n          RETURN t\n        )`);\n        selects.objects.push('tags:tags');\n        return selects;\n      }\n      case 'user': {\n        selects.queries.push(`LET user = FIRST(\n          FOR u IN users\n          FILTER p.userId == u._key\n          LIMIT 1\n          RETURN u\n        )`);\n        selects.objects.push('user:user');\n        return selects;\n      }\n      default: {\n        return selects;\n      }\n    }\n  }, {objects: [], queries: []});\n\nexport const getPost = (context: ApiContext, itemId: string): Promise<PostType> => {\n  // const action: string = 'getItem';\n  const {database, fields, userId: sessionId} = context;\n  const formatItemId: string = parseId(itemId);\n  const db = useDb(database);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: AqlQuery = aql`FOR p IN posts\n    FILTER p._key == ${formatItemId}\n    LIMIT 1\n    RETURN p`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      const {\n        _key,\n        groupId,\n        privacy = 'default'\n      }: PostType = post;\n\n      // Query based on privacy level\n      let privacyAqlQry: string;\n\n      if(groupId && privacy === 'group') {\n        privacyAqlQry = `FOR p IN posts\n          FILTER p._key == \"${_key}\"\n          ${selectQueries.join('\\n')}\n          FOR group IN groups\n          FILTER group._key == p.groupId\n          FOR u, e IN OUTBOUND group._id isGrouped\n          FILTER u._key == ${sessionId}\n          LIMIT 1\n          RETURN MERGE(p, {${selectObjects.join(', ')}})`;\n      } else if(privacy === 'public') {\n        privacyAqlQry = `FOR p IN posts\n          FILTER p._key == \"${_key}\"\n          ${selectQueries.join('\\n')}\n          LIMIT 1\n          RETURN MERGE(p, {${selectObjects.join(', ')}})`;\n      }\n\n      if(privacyAqlQry) {\n        return db.query(privacyAqlQry)\n          .then((cursor: ArrayCursor) => cursor.next())\n          .then((filteredPost: PostType = {}) => filteredPost)\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n\n      return {};\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostList = (context: ApiContext, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getListByApp';\n  const {database, fields} = context;\n  const {limit, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: string = `FOR p IN posts\n    FILTER p.type == \"${type}\" && p.privacy == \"public\" && p.parent == null\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByArea = (\n  context: ApiContext,\n  latitude: number,\n  longitude: number,\n  options?: PostOptions\n): Promise<PostType[]> => {\n  // const action: string = 'getListByUser';\n  const {database, fields} = context;\n  const {limit, type} = parsePostOptions(options);\n  const formatLatitude: number = parseNum(latitude);\n  const formatLongitude: number = parseNum(longitude);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  selectQueries.push(`LET distance = DISTANCE(\n    ${formatLatitude},\n    ${formatLongitude},\n    NOT_NULL(p.latitude, 0),\n    NOT_NULL(p.longitude, 0))\n  `);\n  selectObjects.push('distance:distance');\n\n  const aqlQry: string = `FOR p IN posts\n    ${selectQueries.join('\\n')}\n    FILTER p.type == \"${type}\" && p.privacy == \"public\" && p.parentId == null\n    ${limit.aql}\n    SORT distance, p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByGroup = (\n  context: ApiContext,\n  groupId: string,\n  options?: PostOptions\n): Promise<PostType[]> => {\n  // const action: string = 'getListByGroup';\n  const {database, fields, userId: sessionId} = context;\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n\n  // Group id\n  const formatGroupId: string = parseId(groupId);\n  const db = useDb(database);\n  const aqlQry: string = `FOR u, g IN INBOUND ${formatGroupId} hasGroup\n      FILTER u._key == ${sessionId}\n      RETURN g`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((groups: GroupType[] = []) => {\n      if(groups.length) {\n        const {limit, type} = parsePostOptions(options);\n        const postAqlQry: string = `FOR p IN posts\n          FILTER p.type == \"${type}\" && p.groupId == \"${formatGroupId}\" && p.parent == null\n          ${selectQueries.join('\\n')}\n          ${limit.aql}\n          SORT p.added\n          RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n        return db.query(postAqlQry)\n          .then((cursor: ArrayCursor) => cursor.all())\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n\n      return [];\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByLatest = (context: ApiContext, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getListByLatest';\n  const {database, fields} = context;\n  const {limit, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: string = `FOR p IN posts\n    FILTER p.type == \"${type}\" && p.privacy == \"public\" && p.parent == null\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByTags = (\n  context: ApiContext,\n  tagNames: string[],\n  options?: PostOptions\n): Promise<PostType[]> => {\n  // const action: string = 'getListByTags';\n  const {database, fields} = context;\n  const {latitude, longitude, limit, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const sortBy: string[] = [];\n\n  if(latitude !== undefined && longitude !== undefined) {\n    const formatLatitude: number = parseNum(latitude);\n    const formatLongitude: number = parseNum(longitude);\n    selectQueries.push(`LET distance = DISTANCE(\n      ${formatLatitude},\n      ${formatLongitude},\n      NOT_NULL(p.latitude, 0),\n      NOT_NULL(p.longitude, 0))\n    `);\n    selectObjects.push('distance:distance');\n    sortBy.push('distance');\n  }\n\n  sortBy.push('p.added');\n\n  return Promise.all(\n    tagNames.map((tagName: string) => {\n      const aqlQry: string = `FOR targetTag IN tags\n        FILTER targetTag.name == \"${tagName}\"\n        FOR p, e IN OUTBOUND targetTag._id isTagged\n        ${selectQueries.join('\\n')}\n        FILTER p.type == \"${type}\" && p.privacy == \"public\" && e.type == 'posts'\n        ${limit.aql}\n        SORT ${sortBy.join(', ')}\n        RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n      return useDb(database).query(aqlQry)\n        .then((cursor: ArrayCursor) => cursor.all())\n        .catch(() => []);\n    }))\n    .then((results) => uniqBy(flatten(results), '_key'))\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostListByUser = (context: ApiContext, userId: string, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getListByUser';\n  const {database, fields} = context;\n  const {limit, type} = parsePostOptions(options);\n  const formatUserId: string = parseId(userId);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields);\n  const aqlQry: string = `FOR p IN posts\n    FILTER p.userId == \"${formatUserId}\" && p.type == \"${type}\" && p.privacy == \"public\" && p.parent == null\n    ${selectQueries.join('\\n')}\n    ${limit.aql}\n    SORT p.added\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostComments = (context: ApiContext, itemId: string, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getComments';\n  const {database, userId: sessionId} = context;\n  const {limit, type} = parsePostOptions(options);\n  const formatItemId: string = parseId(itemId);\n\n  // Get the parent post to get restrictions\n  const db = useDb(database);\n  const aqlQry: AqlQuery = aql`FOR p IN posts\n    FILTER p.type == ${type} && p._key == ${formatItemId}\n    LIMIT 1\n    RETURN p`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      const {\n        _key,\n        groupId,\n        privacy = 'public'\n      }: PostType = post;\n\n      // Query based on privacy level\n      let privacyAqlQry: string;\n\n      if(groupId && privacy === 'group') {\n        privacyAqlQry = `FOR p IN posts\n          FOR user IN users\n          FILTER p.parent == \"${_key}\" && user._key == p.userId\n          LET reactions = (\n            FOR post, r IN INBOUND p._id reactions\n            COLLECT reactionName = r.value INTO reactionItems\n            RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n          )\n          FOR group IN groups\n          FILTER group._key == p.groupId\n          FOR u, e IN OUTBOUND group._id isGrouped\n          FILTER u._key == \"${sessionId}\"\n          SORT p.added\n          ${limit.aql}\n          RETURN MERGE(p, {user: user, reactions: reactions})`;\n      } else if(privacy === 'public') {\n        privacyAqlQry = `FOR p IN posts\n          FOR user IN users\n          FILTER p.parent == \"${_key}\" && user._key == p.userId\n          LET reactions = (\n            FOR post, r IN INBOUND p._id reactions\n            COLLECT reactionName = r.value INTO reactionItems\n            RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}\n          )\n          SORT p.added\n          ${limit.aql}\n          RETURN MERGE(p, {user: user, reactions: reactions})`;\n      }\n\n      if(privacyAqlQry) {\n        return db.query(privacyAqlQry)\n          .then((cursor: ArrayCursor) => cursor.all())\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n\n      return [];\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const addPost = (context: ApiContext, item: PostType): Promise<PostType> => {\n  // const action: string = 'add';\n  const {database, userId: sessionId} = context;\n\n  const {\n    content = '',\n    groupId = '',\n    location,\n    latitude,\n    longitude,\n    name = '',\n    parentId = null,\n    privacy = 'public',\n    type = 'default'\n  }: PostType = item;\n\n  const now: number = Date.now();\n\n  const insert: PostType = {\n    _key: createHash(`post-${sessionId}`),\n    added: now,\n    content: parseString(content, MAX_CONTENT_LENGTH),\n    groupId: groupId ? parseId(groupId) : undefined,\n    latitude: latitude !== undefined ? parseNum(latitude) : undefined,\n    location: location ? parseString(location, 160) : undefined,\n    longitude: longitude !== undefined ? parseNum(longitude) : undefined,\n    modified: now,\n    name: parseString(name, 160),\n    parentId: parentId ? parseId(parentId) : undefined,\n    privacy: privacy ? parseVarChar(privacy, 16) : undefined,\n    type: parseChar(type, 32),\n    userId: sessionId\n  };\n\n  const db: Database = useDb(database);\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN posts RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      const {_key: postKey} = post;\n\n      // Update linked tags within posts\n      return extractTags(db, 'posts', postKey, insert.content)\n        .then((tagList: TagType[]) => {\n          post.tags = tagList;\n          return post;\n        });\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const updatePost = (context: ApiContext, item: PostType): Promise<PostType> => {\n  // const action: string = 'update';\n  const {database, userId: sessionId} = context;\n  const now: number = Date.now();\n  const {\n    content,\n    groupId,\n    name,\n    parentId,\n    postId,\n    privacy,\n    type\n  }: PostType = item;\n\n  const update: PostType = {\n    content: content ? parseString(content, MAX_CONTENT_LENGTH) : undefined,\n    modified: now,\n    name: name ? parseString(name, 160) : undefined,\n    parentId: parentId ? parseString(parentId, 160) : undefined,\n    privacy: privacy ? parseVarChar(privacy, 16) : undefined,\n    type: type !== undefined ? parseChar(type, 16) : undefined\n  };\n\n  let formatId: string = parseId(postId);\n  formatId = formatId === '' ? createHash(`post-${sessionId}`) : formatId;\n  const formatGroupId: string = parseId(groupId);\n  const insert: any = {\n    ...update,\n    _key: formatId,\n    added: now,\n    groupId: formatGroupId,\n    privacy,\n    userId: sessionId\n  };\n  const db: Database = useDb(database);\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${formatId}, userId: ${sessionId}}\n    INSERT ${insert}\n    UPDATE ${update}\n    IN posts RETURN NEW`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((updatedPost: PostType = {}) => {\n      const {_key: updatedPostKey} = updatedPost;\n\n      // Update linked tags\n      return extractTags(db, 'posts', updatedPostKey, update.content || '')\n        .then((tagList = []) => {\n          updatedPost.tags = tagList;\n\n          // Update linked files\n          const files: FileType[] = updatedPost.files || [];\n\n          if(files.length) {\n            return updateFiles(db, formatId, files)\n              .then((fileList = []) => {\n                updatedPost.files = fileList;\n                return updatedPost;\n              });\n          }\n\n          updatedPost.files = [];\n          return updatedPost;\n        });\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const deletePost = (context: ApiContext, itemId: string): Promise<PostType> => {\n  // const action: string = 'delete';\n  const {database, userId: sessionId} = context;\n  const formatItemId: string = parseId(itemId);\n  const db: Database = useDb(database);\n  const aqlQry = aql`FOR p IN posts\n      FILTER p._key == ${formatItemId} && p.userId == ${sessionId}\n      LIMIT 1\n      REMOVE p IN posts\n      RETURN OLD`;\n\n  return db.query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.next())\n    .then((post: PostType = {}) => {\n      if(post) {\n        // Remove tag links\n        const edgeAqlQry: AqlQuery = aql`FOR t IN isTagged\n            FILTER t._to == ${formatItemId}\n            REMOVE t IN isTagged`;\n\n        return db.query(edgeAqlQry)\n          .then(() => {\n            // Remove attached files\n            const fileAqlQry: AqlQuery = aql`FOR f IN hasFile\n                FILTER f._to == ${formatItemId}\n                REMOVE f IN hasFile`;\n\n            return db.query(fileAqlQry)\n              .then(() => post)\n              .catch((error: Error) => {\n                throw error;\n              });\n          })\n          .catch((error: Error) => {\n            throw error;\n          });\n      }\n      return {};\n    })\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const cleanPosts = (database: string): Promise<number> => {\n  // Remove all messages that are over 60 days and not saved\n  const aqlQry: AqlQuery = aql`FOR p IN posts\n      FILTER p.added < DATE_TIMESTAMP(DATE_SUBTRACT(DATE_NOW(), 60, 'day')) && p.type == \"default\"\n      REMOVE p IN posts\n      RETURN OLD`;\n\n  return useDb(database).query(aqlQry)\n    .then((cursor: ArrayCursor) => cursor.all())\n    .then((results: PostType[] = []) => results.length)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const createPostEdge = (db: Database, file: FileType, postId: string): Promise<FileType> => {\n  const edgeCollection = db.edgeCollection('isPosted');\n  const {fileId} = file;\n  const formatFileId: string = parseId(fileId);\n  const edgeId: string = createHash(`file-${postId}-${formatFileId}`);\n  const formatPostId: string = parseId(postId);\n  const fileType: string = parseChar(file.fileType, 16);\n\n  const edge: any = {\n    _key: edgeId,\n    added: Date.now(),\n    type: fileType\n  };\n\n  return edgeCollection.save(edge, `posts/${formatPostId}`, `files/${formatFileId}`)\n    .then(() => file)\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n"]}
@@ -1,6 +1,14 @@
1
- import { ApiContext, ReactionType, UserReactionQuery, UserReactionType, UserType } from '../types';
2
- export declare const addGroupReaction: (context: ApiContext, params?: UserReactionType) => Promise<boolean>;
3
- export declare const getGroupReactions: (context: ApiContext, params?: UserReactionType) => Promise<UserReactionType>;
4
- export declare const getReactionsByUser: (context: ApiContext, groupId: string) => Promise<UserReactionType[]>;
5
- export declare const getUsersByReaction: (context: ApiContext, params?: UserReactionQuery) => Promise<UserType[]>;
6
- export declare const postReaction: (context: ApiContext, postId: string, type?: string) => Promise<ReactionType>;
1
+ import { ApiContext, ReactionDirection, ReactionOptions, ReactionType, UserReactionQuery, UserType } from '../types';
2
+ export declare const parseReactionOptions: (options?: ReactionOptions) => {
3
+ limit: import("../types").ArangoDBLimit;
4
+ };
5
+ export declare const addReaction: (context: ApiContext, itemId: string, itemType?: string, reaction?: ReactionType, allowDuplicate?: boolean) => Promise<ReactionType>;
6
+ export declare const removeReaction: (context: ApiContext, reactionId: string) => Promise<ReactionType>;
7
+ export declare const removeReactionByItem: (context: ApiContext, itemId: string, itemType: string, reactionName: string) => Promise<ReactionType>;
8
+ export declare const updateReaction: (context: ApiContext, reaction?: ReactionType) => Promise<ReactionType>;
9
+ export declare const getReactionCount: (context: ApiContext, itemId: string, itemType: string, reactionName: string) => Promise<ReactionType>;
10
+ export declare const getReactionCountByUser: (context: ApiContext, itemId: string, itemType: string, reactionName: string) => Promise<ReactionType[]>;
11
+ export declare const getGroupUsersByReaction: (context: ApiContext, params?: UserReactionQuery) => Promise<UserType[]>;
12
+ export declare const getReactionsByItem: (context: ApiContext, itemId: string, itemType: string, reactionName: string, options: ReactionOptions) => Promise<UserType[]>;
13
+ export declare const getItemsByReaction: (context: ApiContext, itemId: string, itemType: string, reactionName: string, options: ReactionOptions) => Promise<ReactionType[]>;
14
+ export declare const hasReaction: (context: ApiContext, itemId: string, itemType: string, reactionName: string, direction?: ReactionDirection) => Promise<ReactionType[]>;