@nlabs/reaktor 0.10.5 → 0.10.7

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.
Files changed (535) hide show
  1. package/lib/actions/apps.d.ts +1 -0
  2. package/lib/actions/apps.d.ts.map +1 -0
  3. package/lib/actions/apps.js +221 -0
  4. package/lib/actions/connections.d.ts +1 -0
  5. package/lib/actions/connections.d.ts.map +1 -0
  6. package/lib/actions/connections.js +62 -0
  7. package/lib/actions/content.d.ts +1 -0
  8. package/lib/actions/content.d.ts.map +1 -0
  9. package/lib/actions/content.js +240 -0
  10. package/lib/actions/conversations.d.ts +1 -0
  11. package/lib/actions/conversations.d.ts.map +1 -0
  12. package/lib/actions/conversations.js +335 -0
  13. package/lib/actions/dynamodb.d.ts +1 -0
  14. package/lib/actions/dynamodb.d.ts.map +1 -0
  15. package/lib/actions/dynamodb.js +119 -0
  16. package/lib/actions/email.d.ts +1 -0
  17. package/lib/actions/email.d.ts.map +1 -0
  18. package/lib/actions/email.js +56 -0
  19. package/lib/actions/files.d.ts +1 -0
  20. package/lib/actions/files.d.ts.map +1 -0
  21. package/lib/actions/files.js +226 -0
  22. package/lib/actions/groups.d.ts +1 -0
  23. package/lib/actions/groups.d.ts.map +1 -0
  24. package/lib/actions/groups.js +267 -0
  25. package/lib/actions/images.d.ts +1 -0
  26. package/lib/actions/images.d.ts.map +1 -0
  27. package/lib/actions/images.js +723 -0
  28. package/lib/actions/index.d.ts +1 -0
  29. package/lib/actions/index.d.ts.map +1 -0
  30. package/lib/actions/index.js +29 -0
  31. package/lib/actions/ios.d.ts +1 -0
  32. package/lib/actions/ios.d.ts.map +1 -0
  33. package/lib/actions/ios.js +230 -0
  34. package/lib/actions/locations.d.ts +1 -0
  35. package/lib/actions/locations.d.ts.map +1 -0
  36. package/lib/actions/locations.js +111 -0
  37. package/lib/actions/messages.d.ts +1 -0
  38. package/lib/actions/messages.d.ts.map +1 -0
  39. package/lib/actions/messages.js +167 -0
  40. package/lib/actions/notifications.d.ts +3 -2
  41. package/lib/actions/notifications.d.ts.map +1 -0
  42. package/lib/actions/notifications.js +37 -0
  43. package/lib/actions/payments.d.ts +1 -0
  44. package/lib/actions/payments.d.ts.map +1 -0
  45. package/lib/actions/payments.js +449 -0
  46. package/lib/actions/posts.d.ts +1 -0
  47. package/lib/actions/posts.d.ts.map +1 -0
  48. package/lib/actions/posts.js +608 -0
  49. package/lib/actions/profiles.d.ts +1 -0
  50. package/lib/actions/profiles.d.ts.map +1 -0
  51. package/lib/actions/profiles.js +58 -0
  52. package/lib/actions/reactions.d.ts +1 -0
  53. package/lib/actions/reactions.d.ts.map +1 -0
  54. package/lib/actions/reactions.js +286 -0
  55. package/lib/actions/s3.d.ts +1 -0
  56. package/lib/actions/s3.d.ts.map +1 -0
  57. package/lib/actions/s3.js +102 -0
  58. package/lib/actions/search.d.ts +1 -0
  59. package/lib/actions/search.d.ts.map +1 -0
  60. package/lib/actions/search.js +81 -0
  61. package/lib/actions/sms.d.ts +1 -0
  62. package/lib/actions/sms.d.ts.map +1 -0
  63. package/lib/actions/sms.js +52 -0
  64. package/lib/actions/statistics.d.ts +1 -0
  65. package/lib/actions/statistics.d.ts.map +1 -0
  66. package/lib/actions/statistics.js +43 -0
  67. package/lib/actions/subscriptions.d.ts +1 -0
  68. package/lib/actions/subscriptions.d.ts.map +1 -0
  69. package/lib/actions/subscriptions.js +202 -0
  70. package/lib/actions/tags.d.ts +1 -0
  71. package/lib/actions/tags.d.ts.map +1 -0
  72. package/lib/actions/tags.js +263 -0
  73. package/lib/actions/users.d.ts +1 -0
  74. package/lib/actions/users.d.ts.map +1 -0
  75. package/lib/actions/users.js +802 -0
  76. package/lib/actions/videos.d.ts +1 -0
  77. package/lib/actions/videos.d.ts.map +1 -0
  78. package/lib/actions/videos.js +423 -0
  79. package/lib/actions/websockets.d.ts +1 -0
  80. package/lib/actions/websockets.d.ts.map +1 -0
  81. package/lib/actions/websockets.js +164 -0
  82. package/lib/adapters/arangoAdapter.d.ts +1 -0
  83. package/lib/adapters/arangoAdapter.d.ts.map +1 -0
  84. package/lib/adapters/arangoAdapter.js +70 -0
  85. package/lib/adapters/contentAdapter.d.ts +1 -0
  86. package/lib/adapters/contentAdapter.d.ts.map +1 -0
  87. package/lib/adapters/contentAdapter.js +108 -0
  88. package/lib/adapters/fileAdapter.d.ts +1 -0
  89. package/lib/adapters/fileAdapter.d.ts.map +1 -0
  90. package/lib/adapters/fileAdapter.js +119 -0
  91. package/lib/adapters/imageAdapter.d.ts +1 -0
  92. package/lib/adapters/imageAdapter.d.ts.map +1 -0
  93. package/lib/adapters/imageAdapter.js +112 -0
  94. package/lib/adapters/index.d.ts +1 -0
  95. package/lib/adapters/index.d.ts.map +1 -0
  96. package/lib/adapters/index.js +11 -0
  97. package/lib/adapters/messageAdapter.d.ts +1 -0
  98. package/lib/adapters/messageAdapter.d.ts.map +1 -0
  99. package/lib/adapters/messageAdapter.js +82 -0
  100. package/lib/adapters/postAdapter.d.ts +1 -0
  101. package/lib/adapters/postAdapter.d.ts.map +1 -0
  102. package/lib/adapters/postAdapter.js +117 -0
  103. package/lib/adapters/reaktorAdapter.d.ts +1 -0
  104. package/lib/adapters/reaktorAdapter.d.ts.map +1 -0
  105. package/lib/adapters/reaktorAdapter.js +59 -0
  106. package/lib/adapters/tagAdapter.d.ts +1 -0
  107. package/lib/adapters/tagAdapter.d.ts.map +1 -0
  108. package/lib/adapters/tagAdapter.js +99 -0
  109. package/lib/adapters/userAdapter.d.ts +1 -0
  110. package/lib/adapters/userAdapter.d.ts.map +1 -0
  111. package/lib/adapters/userAdapter.js +264 -0
  112. package/lib/config.d.ts +1 -0
  113. package/lib/config.d.ts.map +1 -0
  114. package/lib/config.js +161 -0
  115. package/lib/handlers/graphqlHandler.d.ts +1 -0
  116. package/lib/handlers/graphqlHandler.d.ts.map +1 -0
  117. package/lib/handlers/graphqlHandler.js +118 -0
  118. package/lib/index.d.ts +1 -0
  119. package/lib/index.d.ts.map +1 -0
  120. package/lib/index.js +18 -0
  121. package/lib/lambdas/actions/websockets.d.ts +1 -0
  122. package/lib/lambdas/actions/websockets.d.ts.map +1 -0
  123. package/lib/lambdas/actions/websockets.js +105 -0
  124. package/lib/lambdas/authorizer.d.ts +1 -0
  125. package/lib/lambdas/authorizer.d.ts.map +1 -0
  126. package/lib/lambdas/authorizer.js +41 -0
  127. package/lib/lambdas/connection.d.ts +1 -0
  128. package/lib/lambdas/connection.d.ts.map +1 -0
  129. package/lib/lambdas/connection.js +85 -0
  130. package/lib/lambdas/utils/message.d.ts +1 -0
  131. package/lib/lambdas/utils/message.d.ts.map +1 -0
  132. package/lib/lambdas/utils/message.js +20 -0
  133. package/lib/lambdas/utils/websocket.d.ts +1 -0
  134. package/lib/lambdas/utils/websocket.d.ts.map +1 -0
  135. package/lib/lambdas/utils/websocket.js +78 -0
  136. package/lib/mocks/conversation.d.ts +1 -0
  137. package/lib/mocks/conversation.d.ts.map +1 -0
  138. package/lib/mocks/conversation.js +10 -0
  139. package/lib/mocks/file.d.ts +1 -0
  140. package/lib/mocks/file.d.ts.map +1 -0
  141. package/lib/mocks/file.js +13 -0
  142. package/lib/mocks/group.d.ts +1 -0
  143. package/lib/mocks/group.d.ts.map +1 -0
  144. package/lib/mocks/group.js +20 -0
  145. package/lib/mocks/image.d.ts +1 -0
  146. package/lib/mocks/image.d.ts.map +1 -0
  147. package/lib/mocks/image.js +17 -0
  148. package/lib/mocks/post.d.ts +1 -0
  149. package/lib/mocks/post.d.ts.map +1 -0
  150. package/lib/mocks/post.js +28 -0
  151. package/lib/mocks/tag.d.ts +1 -0
  152. package/lib/mocks/tag.d.ts.map +1 -0
  153. package/lib/mocks/tag.js +12 -0
  154. package/lib/mocks/user.d.ts +1 -0
  155. package/lib/mocks/user.d.ts.map +1 -0
  156. package/lib/mocks/user.js +61 -0
  157. package/lib/mocks/video.d.ts +1 -0
  158. package/lib/mocks/video.d.ts.map +1 -0
  159. package/lib/mocks/video.js +17 -0
  160. package/lib/mutations/content.d.ts +1 -0
  161. package/lib/mutations/content.d.ts.map +1 -0
  162. package/lib/mutations/content.js +27 -0
  163. package/lib/mutations/index.d.ts +1 -0
  164. package/lib/mutations/index.d.ts.map +1 -0
  165. package/lib/mutations/index.js +29 -0
  166. package/lib/mutations/locations.d.ts +1 -0
  167. package/lib/mutations/locations.d.ts.map +1 -0
  168. package/lib/mutations/locations.js +22 -0
  169. package/lib/mutations/messages.d.ts +1 -0
  170. package/lib/mutations/messages.d.ts.map +1 -0
  171. package/lib/mutations/messages.js +75 -0
  172. package/lib/mutations/posts.d.ts +1 -0
  173. package/lib/mutations/posts.d.ts.map +1 -0
  174. package/lib/mutations/posts.js +31 -0
  175. package/lib/mutations/profiles.d.ts +1 -0
  176. package/lib/mutations/profiles.d.ts.map +1 -0
  177. package/lib/mutations/profiles.js +78 -0
  178. package/lib/mutations/reactions.d.ts +1 -0
  179. package/lib/mutations/reactions.d.ts.map +1 -0
  180. package/lib/mutations/reactions.js +29 -0
  181. package/lib/mutations/statistics.d.ts +1 -0
  182. package/lib/mutations/statistics.d.ts.map +1 -0
  183. package/lib/mutations/statistics.js +17 -0
  184. package/lib/mutations/subscriptions.d.ts +1 -0
  185. package/lib/mutations/subscriptions.d.ts.map +1 -0
  186. package/lib/mutations/subscriptions.js +38 -0
  187. package/lib/mutations/tags.d.ts +1 -0
  188. package/lib/mutations/tags.d.ts.map +1 -0
  189. package/lib/mutations/tags.js +109 -0
  190. package/lib/mutations/users.d.ts +1 -0
  191. package/lib/mutations/users.d.ts.map +1 -0
  192. package/lib/mutations/users.js +129 -0
  193. package/lib/objectTypes/app.d.ts +1 -0
  194. package/lib/objectTypes/app.d.ts.map +1 -0
  195. package/lib/objectTypes/app.js +147 -0
  196. package/lib/objectTypes/bankAccount.d.ts +1 -0
  197. package/lib/objectTypes/bankAccount.d.ts.map +1 -0
  198. package/lib/objectTypes/bankAccount.js +54 -0
  199. package/lib/objectTypes/connection.d.ts +1 -0
  200. package/lib/objectTypes/connection.d.ts.map +1 -0
  201. package/lib/objectTypes/connection.js +26 -0
  202. package/lib/objectTypes/content.d.ts +1 -0
  203. package/lib/objectTypes/content.d.ts.map +1 -0
  204. package/lib/objectTypes/content.js +79 -0
  205. package/lib/objectTypes/conversation.d.ts +1 -0
  206. package/lib/objectTypes/conversation.d.ts.map +1 -0
  207. package/lib/objectTypes/conversation.js +53 -0
  208. package/lib/objectTypes/creditCard.d.ts +1 -0
  209. package/lib/objectTypes/creditCard.d.ts.map +1 -0
  210. package/lib/objectTypes/creditCard.js +64 -0
  211. package/lib/objectTypes/document.d.ts +1 -0
  212. package/lib/objectTypes/document.d.ts.map +1 -0
  213. package/lib/objectTypes/document.js +21 -0
  214. package/lib/objectTypes/error.d.ts +1 -0
  215. package/lib/objectTypes/error.d.ts.map +1 -0
  216. package/lib/objectTypes/error.js +24 -0
  217. package/lib/objectTypes/external.d.ts +1 -0
  218. package/lib/objectTypes/external.d.ts.map +1 -0
  219. package/lib/objectTypes/external.js +52 -0
  220. package/lib/objectTypes/file.d.ts +1 -0
  221. package/lib/objectTypes/file.d.ts.map +1 -0
  222. package/lib/objectTypes/file.js +76 -0
  223. package/lib/objectTypes/filter.d.ts +1 -0
  224. package/lib/objectTypes/filter.d.ts.map +1 -0
  225. package/lib/objectTypes/filter.js +21 -0
  226. package/lib/objectTypes/group.d.ts +1 -0
  227. package/lib/objectTypes/group.d.ts.map +1 -0
  228. package/lib/objectTypes/group.js +97 -0
  229. package/lib/objectTypes/iapSubscription.d.ts +1 -0
  230. package/lib/objectTypes/iapSubscription.d.ts.map +1 -0
  231. package/lib/objectTypes/iapSubscription.js +18 -0
  232. package/lib/objectTypes/image.d.ts +1 -0
  233. package/lib/objectTypes/image.d.ts.map +1 -0
  234. package/lib/objectTypes/image.js +105 -0
  235. package/lib/objectTypes/index.d.ts +1 -0
  236. package/lib/objectTypes/index.d.ts.map +1 -0
  237. package/lib/objectTypes/index.js +28 -0
  238. package/lib/objectTypes/location.d.ts +1 -0
  239. package/lib/objectTypes/location.d.ts.map +1 -0
  240. package/lib/objectTypes/location.js +85 -0
  241. package/lib/objectTypes/message.d.ts +1 -0
  242. package/lib/objectTypes/message.d.ts.map +1 -0
  243. package/lib/objectTypes/message.js +72 -0
  244. package/lib/objectTypes/passcode.d.ts +1 -0
  245. package/lib/objectTypes/passcode.d.ts.map +1 -0
  246. package/lib/objectTypes/passcode.js +20 -0
  247. package/lib/objectTypes/plan.d.ts +1 -0
  248. package/lib/objectTypes/plan.d.ts.map +1 -0
  249. package/lib/objectTypes/plan.js +71 -0
  250. package/lib/objectTypes/post.d.ts +1 -0
  251. package/lib/objectTypes/post.d.ts.map +1 -0
  252. package/lib/objectTypes/post.js +101 -0
  253. package/lib/objectTypes/profile.d.ts +1 -0
  254. package/lib/objectTypes/profile.d.ts.map +1 -0
  255. package/lib/objectTypes/profile.js +68 -0
  256. package/lib/objectTypes/reaction.d.ts +1 -0
  257. package/lib/objectTypes/reaction.d.ts.map +1 -0
  258. package/lib/objectTypes/reaction.js +37 -0
  259. package/lib/objectTypes/relation.d.ts +1 -0
  260. package/lib/objectTypes/relation.d.ts.map +1 -0
  261. package/lib/objectTypes/relation.js +27 -0
  262. package/lib/objectTypes/search.d.ts +1 -0
  263. package/lib/objectTypes/search.d.ts.map +1 -0
  264. package/lib/objectTypes/search.js +50 -0
  265. package/lib/objectTypes/statistics.d.ts +1 -0
  266. package/lib/objectTypes/statistics.d.ts.map +1 -0
  267. package/lib/objectTypes/statistics.js +17 -0
  268. package/lib/objectTypes/subscription.d.ts +1 -0
  269. package/lib/objectTypes/subscription.d.ts.map +1 -0
  270. package/lib/objectTypes/subscription.js +102 -0
  271. package/lib/objectTypes/tag.d.ts +1 -0
  272. package/lib/objectTypes/tag.d.ts.map +1 -0
  273. package/lib/objectTypes/tag.js +41 -0
  274. package/lib/objectTypes/user.d.ts +1 -0
  275. package/lib/objectTypes/user.d.ts.map +1 -0
  276. package/lib/objectTypes/user.js +111 -0
  277. package/lib/queries/content.d.ts +1 -0
  278. package/lib/queries/content.d.ts.map +1 -0
  279. package/lib/queries/content.js +50 -0
  280. package/lib/queries/index.d.ts +1 -0
  281. package/lib/queries/index.d.ts.map +1 -0
  282. package/lib/queries/index.js +27 -0
  283. package/lib/queries/locations.d.ts +1 -0
  284. package/lib/queries/locations.d.ts.map +1 -0
  285. package/lib/queries/locations.js +23 -0
  286. package/lib/queries/messages.d.ts +1 -0
  287. package/lib/queries/messages.d.ts.map +1 -0
  288. package/lib/queries/messages.js +35 -0
  289. package/lib/queries/posts.d.ts +1 -0
  290. package/lib/queries/posts.d.ts.map +1 -0
  291. package/lib/queries/posts.js +154 -0
  292. package/lib/queries/reactions.d.ts +1 -0
  293. package/lib/queries/reactions.d.ts.map +1 -0
  294. package/lib/queries/reactions.js +34 -0
  295. package/lib/queries/statistics.d.ts +1 -0
  296. package/lib/queries/statistics.d.ts.map +1 -0
  297. package/lib/queries/statistics.js +17 -0
  298. package/lib/queries/subscriptions.d.ts +1 -0
  299. package/lib/queries/subscriptions.d.ts.map +1 -0
  300. package/lib/queries/subscriptions.js +21 -0
  301. package/lib/queries/tags.d.ts +1 -0
  302. package/lib/queries/tags.d.ts.map +1 -0
  303. package/lib/queries/tags.js +56 -0
  304. package/lib/queries/users.d.ts +1 -0
  305. package/lib/queries/users.d.ts.map +1 -0
  306. package/lib/queries/users.js +39 -0
  307. package/lib/templates/email/layout.d.ts +1 -0
  308. package/lib/templates/email/layout.d.ts.map +1 -0
  309. package/lib/templates/email/layout.js +281 -0
  310. package/lib/templates/email/passwordForgot.d.ts +1 -0
  311. package/lib/templates/email/passwordForgot.d.ts.map +1 -0
  312. package/lib/templates/email/passwordForgot.js +17 -0
  313. package/lib/templates/email/passwordRecovery.d.ts +1 -0
  314. package/lib/templates/email/passwordRecovery.d.ts.map +1 -0
  315. package/lib/templates/email/passwordRecovery.js +14 -0
  316. package/lib/templates/email/verifyEmail.d.ts +1 -0
  317. package/lib/templates/email/verifyEmail.d.ts.map +1 -0
  318. package/lib/templates/email/verifyEmail.js +17 -0
  319. package/lib/templates/email/welcome.d.ts +1 -0
  320. package/lib/templates/email/welcome.d.ts.map +1 -0
  321. package/lib/templates/email/welcome.js +17 -0
  322. package/lib/templates/sms/passwordForgot.d.ts +1 -0
  323. package/lib/templates/sms/passwordForgot.d.ts.map +1 -0
  324. package/lib/templates/sms/passwordForgot.js +3 -0
  325. package/lib/templates/sms/passwordRecovery.d.ts +1 -0
  326. package/lib/templates/sms/passwordRecovery.d.ts.map +1 -0
  327. package/lib/templates/sms/passwordRecovery.js +3 -0
  328. package/lib/templates/sms/verifyEmail.d.ts +1 -0
  329. package/lib/templates/sms/verifyEmail.d.ts.map +1 -0
  330. package/lib/templates/sms/verifyEmail.js +3 -0
  331. package/lib/templates/sms/verifyPhone.d.ts +1 -0
  332. package/lib/templates/sms/verifyPhone.d.ts.map +1 -0
  333. package/lib/templates/sms/verifyPhone.js +3 -0
  334. package/lib/templates/sms/welcome.d.ts +1 -0
  335. package/lib/templates/sms/welcome.d.ts.map +1 -0
  336. package/lib/templates/sms/welcome.js +3 -0
  337. package/lib/types/apps.types.d.ts +1 -0
  338. package/lib/types/apps.types.d.ts.map +1 -0
  339. package/lib/types/apps.types.js +10 -0
  340. package/lib/types/arangodb.types.d.ts +1 -0
  341. package/lib/types/arangodb.types.d.ts.map +1 -0
  342. package/lib/types/arangodb.types.js +6 -0
  343. package/lib/types/auth.types.d.ts +1 -0
  344. package/lib/types/auth.types.d.ts.map +1 -0
  345. package/lib/types/auth.types.js +6 -0
  346. package/lib/types/connections.types.d.ts +1 -0
  347. package/lib/types/connections.types.d.ts.map +1 -0
  348. package/lib/types/connections.types.js +6 -0
  349. package/lib/types/content.types.d.ts +1 -0
  350. package/lib/types/content.types.d.ts.map +1 -0
  351. package/lib/types/content.types.js +6 -0
  352. package/lib/types/conversations.types.d.ts +1 -0
  353. package/lib/types/conversations.types.d.ts.map +1 -0
  354. package/lib/types/conversations.types.js +6 -0
  355. package/lib/types/email.types.d.ts +1 -0
  356. package/lib/types/email.types.d.ts.map +1 -0
  357. package/lib/types/email.types.js +6 -0
  358. package/lib/types/error.types.d.ts +1 -0
  359. package/lib/types/error.types.d.ts.map +1 -0
  360. package/lib/types/error.types.js +20 -0
  361. package/lib/types/files.types.d.ts +1 -0
  362. package/lib/types/files.types.d.ts.map +1 -0
  363. package/lib/types/files.types.js +6 -0
  364. package/lib/types/google.types.d.ts +1 -0
  365. package/lib/types/google.types.d.ts.map +1 -0
  366. package/lib/types/google.types.js +6 -0
  367. package/lib/types/groups.types.d.ts +1 -0
  368. package/lib/types/groups.types.d.ts.map +1 -0
  369. package/lib/types/groups.types.js +6 -0
  370. package/lib/types/images.types.d.ts +1 -0
  371. package/lib/types/images.types.d.ts.map +1 -0
  372. package/lib/types/images.types.js +6 -0
  373. package/lib/types/index.d.ts +1 -0
  374. package/lib/types/index.d.ts.map +1 -0
  375. package/lib/types/index.js +28 -0
  376. package/lib/types/locations.types.d.ts +1 -0
  377. package/lib/types/locations.types.d.ts.map +1 -0
  378. package/lib/types/locations.types.js +6 -0
  379. package/lib/types/messages.types.d.ts +1 -0
  380. package/lib/types/messages.types.d.ts.map +1 -0
  381. package/lib/types/messages.types.js +6 -0
  382. package/lib/types/notifications.types.d.ts +1 -0
  383. package/lib/types/notifications.types.d.ts.map +1 -0
  384. package/lib/types/notifications.types.js +6 -0
  385. package/lib/types/payments.types.d.ts +1 -0
  386. package/lib/types/payments.types.d.ts.map +1 -0
  387. package/lib/types/payments.types.js +6 -0
  388. package/lib/types/posts.types.d.ts +1 -0
  389. package/lib/types/posts.types.d.ts.map +1 -0
  390. package/lib/types/posts.types.js +6 -0
  391. package/lib/types/profiles.types.d.ts +1 -0
  392. package/lib/types/profiles.types.d.ts.map +1 -0
  393. package/lib/types/profiles.types.js +3 -0
  394. package/lib/types/statistics.types.d.ts +1 -0
  395. package/lib/types/statistics.types.d.ts.map +1 -0
  396. package/lib/types/statistics.types.js +3 -0
  397. package/lib/types/tags.types.d.ts +1 -0
  398. package/lib/types/tags.types.d.ts.map +1 -0
  399. package/lib/types/tags.types.js +6 -0
  400. package/lib/types/users.types.d.ts +1 -0
  401. package/lib/types/users.types.d.ts.map +1 -0
  402. package/lib/types/users.types.js +6 -0
  403. package/lib/types/videos.types.d.ts +1 -0
  404. package/lib/types/videos.types.d.ts.map +1 -0
  405. package/lib/types/videos.types.js +6 -0
  406. package/lib/types/websockets.types.d.ts +1 -0
  407. package/lib/types/websockets.types.d.ts.map +1 -0
  408. package/lib/types/websockets.types.js +6 -0
  409. package/lib/utils/adapterUtils.d.ts +1 -0
  410. package/lib/utils/adapterUtils.d.ts.map +1 -0
  411. package/lib/utils/adapterUtils.js +23 -0
  412. package/lib/utils/analyticsUtils.d.ts +1 -0
  413. package/lib/utils/analyticsUtils.d.ts.map +1 -0
  414. package/lib/utils/analyticsUtils.js +45 -0
  415. package/lib/utils/arangodbUtils.d.ts +1 -0
  416. package/lib/utils/arangodbUtils.d.ts.map +1 -0
  417. package/lib/utils/arangodbUtils.js +130 -0
  418. package/lib/utils/authUtils.d.ts +1 -0
  419. package/lib/utils/authUtils.d.ts.map +1 -0
  420. package/lib/utils/authUtils.js +54 -0
  421. package/lib/utils/contextUtils.d.ts +1 -0
  422. package/lib/utils/contextUtils.d.ts.map +1 -0
  423. package/lib/utils/contextUtils.js +10 -0
  424. package/lib/utils/dbI18n.d.ts +1 -0
  425. package/lib/utils/dbI18n.d.ts.map +1 -0
  426. package/lib/utils/dbI18n.example.d.ts +1 -0
  427. package/lib/utils/dbI18n.example.d.ts.map +1 -0
  428. package/lib/utils/dbI18n.example.js +93 -0
  429. package/lib/utils/dbI18n.js +28 -0
  430. package/lib/utils/googleTranslate.d.ts +1 -0
  431. package/lib/utils/googleTranslate.d.ts.map +1 -0
  432. package/lib/utils/googleTranslate.js +70 -0
  433. package/lib/utils/graphqlUtils.d.ts +1 -0
  434. package/lib/utils/graphqlUtils.d.ts.map +1 -0
  435. package/lib/utils/graphqlUtils.js +11 -0
  436. package/lib/utils/index.d.ts +1 -0
  437. package/lib/utils/index.d.ts.map +1 -0
  438. package/lib/utils/index.js +19 -0
  439. package/lib/utils/languageDetection.d.ts +1 -0
  440. package/lib/utils/languageDetection.d.ts.map +1 -0
  441. package/lib/utils/languageDetection.js +120 -0
  442. package/lib/utils/localeUtils.d.ts +1 -0
  443. package/lib/utils/localeUtils.d.ts.map +1 -0
  444. package/lib/utils/localeUtils.example.d.ts +1 -0
  445. package/lib/utils/localeUtils.example.d.ts.map +1 -0
  446. package/lib/utils/localeUtils.example.js +124 -0
  447. package/lib/utils/localeUtils.js +71 -0
  448. package/lib/utils/middlewareUtils.d.ts +1 -0
  449. package/lib/utils/middlewareUtils.d.ts.map +1 -0
  450. package/lib/utils/middlewareUtils.js +10 -0
  451. package/lib/utils/sessionUtils.d.ts +1 -0
  452. package/lib/utils/sessionUtils.d.ts.map +1 -0
  453. package/lib/utils/sessionUtils.js +26 -0
  454. package/lib/utils/stripeUtils.d.ts +2 -1
  455. package/lib/utils/stripeUtils.d.ts.map +1 -0
  456. package/lib/utils/stripeUtils.js +12 -0
  457. package/lib/utils/templateUtils.d.ts +1 -0
  458. package/lib/utils/templateUtils.d.ts.map +1 -0
  459. package/lib/utils/templateUtils.js +11 -0
  460. package/lib/utils/testUtils.d.ts +1 -0
  461. package/lib/utils/testUtils.d.ts.map +1 -0
  462. package/lib/utils/testUtils.js +292 -0
  463. package/lib/utils/translationQueue.d.ts +1 -0
  464. package/lib/utils/translationQueue.d.ts.map +1 -0
  465. package/lib/utils/translationQueue.example.d.ts +1 -0
  466. package/lib/utils/translationQueue.example.d.ts.map +1 -0
  467. package/lib/utils/translationQueue.example.js +340 -0
  468. package/lib/utils/translationQueue.js +113 -0
  469. package/package.json +54 -24
  470. package/.env +0 -1
  471. package/.env.example +0 -1
  472. package/DATABASE_I18N_GUIDE.md +0 -434
  473. package/TEST_UTILITIES_GUIDE.md +0 -360
  474. package/coverage/actions/groups.ts.html +0 -1039
  475. package/coverage/actions/images.ts.html +0 -2500
  476. package/coverage/actions/index.html +0 -116
  477. package/coverage/actions/notifications.ts.html +0 -223
  478. package/coverage/actions/posts.ts.html +0 -2356
  479. package/coverage/actions/tags.ts.html +0 -1000
  480. package/coverage/adapters/arangoAdapter.ts.html +0 -301
  481. package/coverage/adapters/fileAdapter.ts.html +0 -445
  482. package/coverage/adapters/index.html +0 -176
  483. package/coverage/adapters/postAdapter.ts.html +0 -436
  484. package/coverage/adapters/reaktorAdapter.ts.html +0 -310
  485. package/coverage/adapters/tagAdapter.ts.html +0 -409
  486. package/coverage/adapters/userAdapter.ts.html +0 -829
  487. package/coverage/analyticsUtils.ts.html +0 -286
  488. package/coverage/base.css +0 -224
  489. package/coverage/block-navigation.js +0 -87
  490. package/coverage/clover.xml +0 -6
  491. package/coverage/config.ts.html +0 -766
  492. package/coverage/coverage-final.json +0 -1
  493. package/coverage/favicon.png +0 -0
  494. package/coverage/index.html +0 -221
  495. package/coverage/lcov-report/base.css +0 -224
  496. package/coverage/lcov-report/block-navigation.js +0 -87
  497. package/coverage/lcov-report/favicon.png +0 -0
  498. package/coverage/lcov-report/index.html +0 -101
  499. package/coverage/lcov-report/prettify.css +0 -1
  500. package/coverage/lcov-report/prettify.js +0 -2
  501. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  502. package/coverage/lcov-report/sorter.js +0 -196
  503. package/coverage/lcov.info +0 -0
  504. package/coverage/mocks/file.ts.html +0 -118
  505. package/coverage/mocks/group.ts.html +0 -145
  506. package/coverage/mocks/image.ts.html +0 -142
  507. package/coverage/mocks/index.html +0 -176
  508. package/coverage/mocks/post.ts.html +0 -169
  509. package/coverage/mocks/tag.ts.html +0 -121
  510. package/coverage/mocks/user.ts.html +0 -271
  511. package/coverage/prettify.css +0 -1
  512. package/coverage/prettify.js +0 -2
  513. package/coverage/sort-arrow-sprite.png +0 -0
  514. package/coverage/sorter.js +0 -210
  515. package/coverage/testUtils.ts.html +0 -1309
  516. package/coverage/translationQueue.ts.html +0 -592
  517. package/coverage/types/error.ts.html +0 -145
  518. package/coverage/types/error.types.ts.html +0 -148
  519. package/coverage/types/index.html +0 -116
  520. package/coverage/utils/adapterUtils.ts.html +0 -163
  521. package/coverage/utils/analyticsUtils.ts.html +0 -286
  522. package/coverage/utils/arangodbUtils.ts.html +0 -463
  523. package/coverage/utils/authUtils.ts.html +0 -328
  524. package/coverage/utils/dbI18n.ts.html +0 -280
  525. package/coverage/utils/googleTranslate.ts.html +0 -385
  526. package/coverage/utils/index.html +0 -131
  527. package/coverage/utils/localeUtils.ts.html +0 -193
  528. package/coverage/utils/sessionUtils.ts.html +0 -211
  529. package/coverage/utils/testUtils.ts.html +0 -1309
  530. package/index.js +0 -5
  531. package/jpg:- +0 -0
  532. package/lex.config.mjs +0 -34
  533. package/tsconfig.build.json +0 -21
  534. package/tsconfig.lint.json +0 -33
  535. package/tsconfig.test.json +0 -31
@@ -0,0 +1,608 @@
1
+ /**
2
+ * Copyright (c) 2019-Present, Nitrogen Labs, Inc.
3
+ * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
4
+ */ import { parseNum } from '@nlabs/utils/parsers/numbers';
5
+ import { createHash, parseArangoId, parseChar, parseId, parseString, parseVarChar } from '@nlabs/utils/parsers/strings';
6
+ import { aql } from 'arangojs';
7
+ import { parsePost } from '../adapters/postAdapter.js';
8
+ import { ErrorTypes } from '../types/error.types.js';
9
+ import { logError, logException } from '../utils/analyticsUtils.js';
10
+ import { getLimit, useDb } from '../utils/arangodbUtils.js';
11
+ import { extractTags, getTagsByName, updateTagsInItem } from './tags.js';
12
+ const MAX_CONTENT_LENGTH = 100000;
13
+ const eventCategory = 'posts';
14
+ export const parsePostOptions = (options = {})=>{
15
+ const { from = 0, latitude = 0, longitude = 0, to = 30, type = 'post' } = options;
16
+ return {
17
+ latitude: parseNum(latitude, 32),
18
+ limit: getLimit(from, to),
19
+ longitude: parseNum(longitude, 32),
20
+ type: parseChar(type, 32)
21
+ };
22
+ };
23
+ export const getPostOptional = (fields = [], sessionId = '')=>(fields || []).reduce((selects, field)=>{
24
+ switch(field){
25
+ case 'hasRsvp':
26
+ {
27
+ selects.queries.push(`LET hasRsvp = TO_BOOL(FIRST(
28
+ FOR post, r IN INBOUND p._id hasReaction
29
+ FILTER r.name == "rsvp" && r.type == "posts" && r._from == "users/${sessionId}"
30
+ COLLECT WITH COUNT INTO count
31
+ RETURN count
32
+ ))`);
33
+ selects.objects.push('hasRsvp:hasRsvp');
34
+ return selects;
35
+ }
36
+ case 'isSaved':
37
+ {
38
+ selects.queries.push(`LET isSaved = TO_BOOL(FIRST(
39
+ FOR post, r IN INBOUND p._id hasReaction
40
+ FILTER r.name == "pin" && r.type == "posts" && r._from == "users/${sessionId}"
41
+ COLLECT WITH COUNT INTO count
42
+ RETURN count
43
+ ))`);
44
+ selects.objects.push('isSaved:isSaved');
45
+ return selects;
46
+ }
47
+ case 'reactions':
48
+ {
49
+ selects.queries.push(`LET reactions = (
50
+ FOR post, r IN INBOUND p._id hasReaction
51
+ COLLECT reactionName = r.value INTO reactionItems
52
+ RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}
53
+ )`);
54
+ selects.objects.push('reactions:reactions');
55
+ return selects;
56
+ }
57
+ case 'rsvpCount':
58
+ {
59
+ selects.queries.push(`LET rsvpCount = FIRST(
60
+ FOR post, r IN INBOUND p._id hasReaction
61
+ FILTER r.name == "rsvp" && r.type == "posts"
62
+ COLLECT WITH COUNT INTO count
63
+ RETURN count
64
+ )`);
65
+ selects.objects.push('rsvpCount:rsvpCount');
66
+ return selects;
67
+ }
68
+ case 'viewCount':
69
+ {
70
+ selects.queries.push(`LET viewCount = FIRST(
71
+ FOR post, r IN INBOUND p._id hasReaction
72
+ FILTER r.name == "view" && r.type == "posts"
73
+ COLLECT WITH COUNT INTO count
74
+ RETURN count
75
+ )`);
76
+ selects.objects.push('viewCount:viewCount');
77
+ return selects;
78
+ }
79
+ default:
80
+ {
81
+ return selects;
82
+ }
83
+ }
84
+ }, {
85
+ objects: [],
86
+ queries: []
87
+ });
88
+ export const getPost = async (context, postId, options)=>{
89
+ const action = 'getPost';
90
+ const { databaseName, fields, session: { userId: sessionId } = {} } = context;
91
+ const formatItemId = parseId(postId);
92
+ const { type } = parsePostOptions(options);
93
+ const database = useDb(databaseName);
94
+ const { objects: selectObjects, queries: selectQueries } = getPostOptional(fields, sessionId);
95
+ const aqlQry = aql`FOR p IN posts
96
+ FILTER p._key == ${formatItemId} && p.type == ${type}
97
+ LIMIT 1
98
+ RETURN p`;
99
+ return database.query(aqlQry).then((cursor)=>cursor.next()).then((post)=>{
100
+ const { _id: postDocId, userId, groupId, privacy = 'default' } = post;
101
+ let privacyAqlQry;
102
+ if (userId === sessionId) {
103
+ return post;
104
+ }
105
+ if (groupId && privacy === 'group') {
106
+ privacyAqlQry = `LET p = DOCUMENT("${postDocId}")
107
+ ${selectQueries.join('\n')}
108
+ FOR group IN groups
109
+ FILTER group._key == p.groupId
110
+ FOR u, e IN OUTBOUND group._id hasConnection
111
+ FILTER u._key == "${sessionId}"
112
+ LIMIT 1
113
+ RETURN MERGE(p, {${selectObjects.join(', ')}})`;
114
+ } else if (privacy === 'public') {
115
+ privacyAqlQry = `LET p = DOCUMENT("${postDocId}")
116
+ ${selectQueries.join('\n')}
117
+ LIMIT 1
118
+ RETURN MERGE(p, {${selectObjects.join(', ')}})`;
119
+ }
120
+ if (privacyAqlQry) {
121
+ return database.query(privacyAqlQry).then((cursor)=>cursor.next()).catch((error)=>logError({
122
+ action,
123
+ category: eventCategory,
124
+ label: ErrorTypes.DATABASE_ERROR
125
+ }, error, context));
126
+ }
127
+ return {};
128
+ }).catch((error)=>logError({
129
+ action,
130
+ category: eventCategory,
131
+ label: ErrorTypes.DATABASE_ERROR
132
+ }, error, context));
133
+ };
134
+ // export const getPostList = (context: ApiContext, options?: PostOptions): Promise<PostType[]> => {
135
+ // // const action: string = 'getListByApp';
136
+ // const {database, fields, session: {userId: sessionId}} = context;
137
+ // const {limit, type} = parsePostOptions(options);
138
+ // const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields, sessionId);
139
+ // const aqlQry: string = `FOR p IN posts
140
+ // FILTER p.type == "${type}" && p.privacy == "public" && p.parent == null
141
+ // ${selectQueries.join('\n')}
142
+ // ${limit.aql}
143
+ // SORT p.added
144
+ // RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;
145
+ // return database.query(aqlQry)
146
+ // .then((cursor) => cursor.all())
147
+ // .catch((error: Error) => {
148
+ // throw error;
149
+ // });
150
+ // };
151
+ export const getPostsByArea = (context, latitude, longitude, options)=>{
152
+ const action = 'getPostsByArea';
153
+ const { databaseName, fields, session: { userId: sessionId } = {} } = context;
154
+ const { limit, type } = parsePostOptions(options);
155
+ const formatLatitude = parseNum(latitude);
156
+ const formatLongitude = parseNum(longitude);
157
+ const { objects: selectObjects, queries: selectQueries } = getPostOptional(fields, sessionId);
158
+ selectQueries.push(`LET distance = DISTANCE(
159
+ ${formatLatitude},
160
+ ${formatLongitude},
161
+ NOT_NULL(p.latitude, 0),
162
+ NOT_NULL(p.longitude, 0))
163
+ `);
164
+ selectObjects.push('distance:distance');
165
+ const aqlQry = `FOR p IN posts
166
+ ${selectQueries.join('\n')}
167
+ FILTER p.type == "${type}" && p.privacy == "public" && p.parentId == null
168
+ ${limit.aql}
169
+ SORT distance, p.added
170
+ RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;
171
+ return useDb(databaseName).query(aqlQry).then((cursor)=>cursor.all()).catch((error)=>{
172
+ logError({
173
+ action,
174
+ category: eventCategory,
175
+ label: ErrorTypes.DATABASE_ERROR
176
+ }, error, context);
177
+ return [];
178
+ });
179
+ };
180
+ // export const getPostsByGroup = (
181
+ // context: ApiContext,
182
+ // groupId: string,
183
+ // options?: PostOptions
184
+ // ): Promise<PostType[]> => {
185
+ // // const action: string = 'getListByGroup';
186
+ // const {database, fields, session: {userId: sessionId}} = context;
187
+ // const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields, sessionId);
188
+ // // Group id
189
+ // const formatGroupId: string = parseId(groupId);
190
+ // const db = database;
191
+ // const aqlQry: string = `FOR u, g IN INBOUND ${formatGroupId} hasGroup
192
+ // FILTER u._key == ${sessionId}
193
+ // RETURN g`;
194
+ // return db.query(aqlQry)
195
+ // .then((cursor) => cursor.all())
196
+ // .then((groups: GroupType[] = []) => {
197
+ // if(groups.length) {
198
+ // const {limit, type} = parsePostOptions(options);
199
+ // const postAqlQry: string = `FOR p IN posts
200
+ // FILTER p.type == "${type}" && p.groupId == "${formatGroupId}" && p.parent == null
201
+ // ${selectQueries.join('\n')}
202
+ // ${limit.aql}
203
+ // SORT p.added
204
+ // RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;
205
+ // return db.query(postAqlQry)
206
+ // .then((cursor) => cursor.all())
207
+ // .catch((error: Error) => {
208
+ // throw error;
209
+ // });
210
+ // }
211
+ // return [];
212
+ // })
213
+ // .catch((error: Error) => {
214
+ // throw error;
215
+ // });
216
+ // };
217
+ export const getPostsByLatest = (context, options)=>{
218
+ // const action: string = 'getListByLatest';
219
+ const { databaseName, fields, session: { userId: sessionId } = {} } = context;
220
+ const { limit, type } = parsePostOptions(options);
221
+ const { objects: selectObjects, queries: selectQueries } = getPostOptional(fields, sessionId);
222
+ const aqlQry = `FOR p IN posts
223
+ FILTER p.type == "${type}" && p.privacy == "public" && p.parent == null
224
+ ${selectQueries.join('\n')}
225
+ ${limit.aql}
226
+ SORT p.added DESC
227
+ RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;
228
+ return useDb(databaseName).query(aqlQry).then((cursor)=>cursor.all()).catch((error)=>{
229
+ throw error;
230
+ });
231
+ };
232
+ export const getPostsByReactions = (context, reactions = [], options)=>{
233
+ const action = 'getPostsByReactions';
234
+ const { databaseName, fields, session: { userId: sessionId } = {} } = context;
235
+ const { latitude, limit, longitude, type } = parsePostOptions(options);
236
+ const { objects: selectObjects, queries: selectQueries } = getPostOptional(fields, sessionId);
237
+ const formatSessionId = `users/${sessionId}`;
238
+ const formatReactions = JSON.stringify(reactions.map((reaction)=>parseChar(reaction, 32).toLowerCase()));
239
+ const sortBy = [];
240
+ const filters = [
241
+ `p.type == "${type}"`,
242
+ 'p.privacy == "public"'
243
+ ];
244
+ const formatLatitude = parseNum(latitude);
245
+ const formatLongitude = parseNum(longitude);
246
+ if (formatLatitude && formatLongitude) {
247
+ selectQueries.push(`LET distance = DISTANCE(
248
+ ${formatLatitude},
249
+ ${formatLongitude},
250
+ NOT_NULL(p.latitude, 0),
251
+ NOT_NULL(p.longitude, 0))
252
+ `);
253
+ selectObjects.push('distance:distance');
254
+ sortBy.push('distance');
255
+ }
256
+ if (reactions.length) {
257
+ sortBy.push('matchedTags DESC');
258
+ selectQueries.push(`LET matchedReactions = LENGTH(
259
+ FOR mr IN reactions
260
+ FILTER mr.matched == true
261
+ RETURN mr
262
+ )`);
263
+ selectObjects.push('matchedReactions:matchedReactions');
264
+ filters.push('matchedReactions > 0');
265
+ }
266
+ sortBy.push('p.added DESC');
267
+ selectObjects.push('reactions:reactions');
268
+ // Get data from database
269
+ const aqlQry = `FOR p, r IN OUTBOUND "${formatSessionId}" hasReaction
270
+ LET reactions = (
271
+ FOR reaction, hr IN 1..1 INBOUND p isTagged
272
+ LET matched = LENGTH(${formatReactions}) > 0 && POSITION(${formatReactions}, reaction.name)
273
+ SORT reaction.name
274
+ RETURN MERGE(reaction, {matched:matched})
275
+ )
276
+ ${selectQueries.join('\n')}
277
+ FILTER ${filters.join(' && ')}
278
+ ${limit.aql}
279
+ RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;
280
+ return useDb(databaseName).query(aqlQry).then((cursor)=>cursor.all()).catch((error)=>{
281
+ logError({
282
+ action,
283
+ category: eventCategory,
284
+ label: ErrorTypes.DATABASE_ERROR
285
+ }, error, context);
286
+ return [];
287
+ });
288
+ };
289
+ export const getPostsByTags = (context, tags = [], options)=>{
290
+ const action = 'getPostsByTags';
291
+ const { databaseName, fields, session: { userId: sessionId } = {} } = context;
292
+ const { latitude, limit, longitude, type } = parsePostOptions(options);
293
+ const { objects: selectObjects, queries: selectQueries } = getPostOptional(fields, sessionId);
294
+ const formatTagNames = JSON.stringify(tags.map((tag)=>parseChar(tag, 32).toLowerCase()));
295
+ const sortBy = [];
296
+ const filters = [
297
+ `p.type == "${type}"`,
298
+ 'p.privacy == "public"'
299
+ ];
300
+ const formatLatitude = parseNum(latitude);
301
+ const formatLongitude = parseNum(longitude);
302
+ if (formatLatitude && formatLongitude) {
303
+ selectQueries.push(`LET distance = DISTANCE(
304
+ ${formatLatitude},
305
+ ${formatLongitude},
306
+ NOT_NULL(p.latitude, 0),
307
+ NOT_NULL(p.longitude, 0))
308
+ `);
309
+ selectObjects.push('distance:distance');
310
+ sortBy.push('distance');
311
+ }
312
+ if (tags.length) {
313
+ sortBy.push('matchedTags DESC');
314
+ selectQueries.push(`LET matchedTags = LENGTH(
315
+ FOR t IN tags
316
+ FILTER t.matched == true
317
+ RETURN t
318
+ )`);
319
+ selectObjects.push('matchedTags:matchedTags');
320
+ filters.push('matchedTags > 0');
321
+ }
322
+ sortBy.push('p.added DESC');
323
+ selectObjects.push('tags:tags');
324
+ const aqlQry = `FOR p IN posts
325
+ LET tags = (
326
+ FOR tag, it IN 1..1 INBOUND p isTagged
327
+ LET matched = LENGTH(${formatTagNames}) > 0 && POSITION(${formatTagNames}, tag.name)
328
+ SORT tag.name
329
+ RETURN MERGE(tag, {matched:matched})
330
+ )
331
+ ${selectQueries.join('\n')}
332
+ FILTER ${filters.join(' && ')}
333
+ ${limit.aql}
334
+ SORT ${sortBy.join(', ')}
335
+ RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;
336
+ return useDb(databaseName).query(aqlQry).then((cursor)=>cursor.all()).catch((error)=>{
337
+ logError({
338
+ action,
339
+ category: eventCategory,
340
+ label: ErrorTypes.DATABASE_ERROR
341
+ }, error, context);
342
+ return [];
343
+ });
344
+ };
345
+ export const getPostsByUser = (context, userId, options)=>{
346
+ const action = 'getPostsByUser';
347
+ const { databaseName, fields, session: { userId: sessionId } = {} } = context;
348
+ const { limit, type } = parsePostOptions(options);
349
+ const formatUserId = parseId(userId);
350
+ const { objects: selectObjects, queries: selectQueries } = getPostOptional(fields, sessionId);
351
+ const aqlQry = `FOR p IN posts
352
+ FILTER p.userId == "${formatUserId}" && p.type == "${type}" && p.privacy == "public" && p.parent == null
353
+ ${selectQueries.join('\n')}
354
+ ${limit.aql}
355
+ SORT p.added
356
+ RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;
357
+ return useDb(databaseName).query(aqlQry).then((cursor)=>cursor.all()).catch((error)=>{
358
+ logError({
359
+ action,
360
+ category: eventCategory,
361
+ label: ErrorTypes.DATABASE_ERROR
362
+ }, error, context);
363
+ return [];
364
+ });
365
+ };
366
+ export const getPostComments = (context, postId, options)=>{
367
+ const action = 'getPostComments';
368
+ const { databaseName, session: { userId: sessionId } = {} } = context;
369
+ const { limit, type } = parsePostOptions(options);
370
+ const formatItemId = parseId(postId);
371
+ // Get the parent post to get restrictions
372
+ const aqlQry = aql`FOR p IN posts
373
+ FILTER p.type == ${type} && p._key == ${formatItemId}
374
+ LIMIT 1
375
+ RETURN p`;
376
+ return useDb(databaseName).query(aqlQry).then((cursor)=>cursor.next()).then((post)=>{
377
+ const { _key, groupId, privacy = 'default' } = post;
378
+ // Query based on privacy level
379
+ let privacyAqlQry;
380
+ if (groupId && privacy === 'group') {
381
+ privacyAqlQry = `FOR p IN posts
382
+ FOR user IN users
383
+ FILTER p.parent == "${_key}" && user._key == p.userId
384
+ LET reactions = (
385
+ FOR post, r IN INBOUND p._id reactions
386
+ COLLECT reactionName = r.value INTO reactionItems
387
+ RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}
388
+ )
389
+ FOR group IN groups
390
+ FILTER group._key == p.groupId
391
+ FOR u, e IN OUTBOUND group._id hasConnection
392
+ FILTER u._key == "${sessionId}"
393
+ SORT p.added
394
+ ${limit.aql}
395
+ RETURN MERGE(p, {user: user, reactions: reactions})`;
396
+ } else if (privacy === 'public') {
397
+ privacyAqlQry = `FOR p IN posts
398
+ FOR user IN users
399
+ FILTER p.parent == "${_key}" && user._key == p.userId
400
+ LET reactions = (
401
+ FOR post, r IN INBOUND p._id reactions
402
+ COLLECT reactionName = r.value INTO reactionItems
403
+ RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}
404
+ )
405
+ SORT p.added
406
+ ${limit.aql}
407
+ RETURN MERGE(p, {user: user, reactions: reactions})`;
408
+ }
409
+ if (privacyAqlQry) {
410
+ return useDb(databaseName).query(privacyAqlQry).then((cursor)=>cursor.all()).catch((error)=>{
411
+ logError({
412
+ action,
413
+ category: eventCategory,
414
+ label: ErrorTypes.DATABASE_ERROR
415
+ }, error, context);
416
+ return [];
417
+ });
418
+ }
419
+ return [];
420
+ }).catch((error)=>{
421
+ logError({
422
+ action,
423
+ category: eventCategory,
424
+ label: ErrorTypes.DATABASE_ERROR
425
+ }, error, context);
426
+ return [];
427
+ });
428
+ };
429
+ export const addPost = async (context, { content = '', endDate, groupId = '', location, latitude, longitude, name = '', parentId = '', privacy = 'public', tags = [], startDate, type = 'default' })=>{
430
+ const action = 'addPost';
431
+ const { databaseName, session: { userId: sessionId } = {} } = context;
432
+ const now = Date.now();
433
+ const postId = createHash(`post-${sessionId}`);
434
+ const insert = {
435
+ _id: `posts/${postId}`,
436
+ _key: postId,
437
+ added: now,
438
+ content: parseString(content, MAX_CONTENT_LENGTH) || '',
439
+ endDate: endDate ? parseNum(endDate, 13) : undefined,
440
+ groupId: groupId ? parseId(groupId) : undefined,
441
+ latitude: latitude !== undefined ? parseNum(latitude) : undefined,
442
+ location: location ? parseString(location, 160) : undefined,
443
+ longitude: longitude !== undefined ? parseNum(longitude) : undefined,
444
+ modified: now,
445
+ name: parseString(name, 160),
446
+ parentId: parentId ? parseId(parentId) : undefined,
447
+ privacy: parseVarChar(privacy, 16),
448
+ startDate: startDate ? parseNum(startDate, 13) : undefined,
449
+ type: parseChar(type, 32),
450
+ userId: sessionId
451
+ };
452
+ const aqlQry = aql`INSERT ${insert} IN posts RETURN NEW`;
453
+ try {
454
+ const savedPost = await useDb(databaseName).query(aqlQry).then((cursor)=>cursor.next()).catch((error)=>logError({
455
+ action,
456
+ category: eventCategory,
457
+ label: ErrorTypes.DATABASE_ERROR
458
+ }, error, context));
459
+ const { _id: postDocId } = savedPost;
460
+ const contentTagNames = await extractTags(insert.content || '');
461
+ if (tags.length || contentTagNames.length) {
462
+ const userTags = (await getTagsByName(context, tags.map(({ name })=>name || ''))).map((tag)=>({
463
+ ...tag,
464
+ tagBy: sessionId
465
+ }));
466
+ const contentTags = (await getTagsByName(context, contentTagNames || [])).map((tag)=>({
467
+ ...tag,
468
+ tagBy: 'extract'
469
+ }));
470
+ const updatedTags = await updateTagsInItem(context, {
471
+ itemDocId: postDocId,
472
+ tags: [
473
+ ...contentTags,
474
+ ...userTags
475
+ ]
476
+ });
477
+ return {
478
+ ...savedPost,
479
+ tags: updatedTags
480
+ };
481
+ }
482
+ return savedPost;
483
+ } catch (error) {
484
+ throw error;
485
+ }
486
+ };
487
+ export const updatePost = async (context, post)=>{
488
+ const action = 'updatePost';
489
+ const { databaseName, session: { userId: sessionId } = {} } = context;
490
+ const now = Date.now();
491
+ const parsedPost = parsePost(post);
492
+ const { postId, tags = [] } = parsedPost;
493
+ const update = {
494
+ ...parsedPost,
495
+ modified: now
496
+ };
497
+ if (!postId) {
498
+ throw logException({
499
+ action,
500
+ category: eventCategory,
501
+ value: ErrorTypes.INVALID_ID
502
+ }, context);
503
+ }
504
+ const insert = {
505
+ ...update,
506
+ _key: postId,
507
+ added: now,
508
+ userId: sessionId
509
+ };
510
+ const aqlQry = aql`UPSERT {_key: ${postId}, userId: ${sessionId}}
511
+ INSERT ${insert}
512
+ UPDATE ${update}
513
+ IN posts RETURN NEW`;
514
+ try {
515
+ const updatedPost = await useDb(databaseName).query(aqlQry).then((cursor)=>cursor.next()).catch((error)=>logError({
516
+ action,
517
+ category: eventCategory,
518
+ value: ErrorTypes.DATABASE_ERROR
519
+ }, error, {}));
520
+ const { _id: updatedPostId } = updatedPost;
521
+ const contentTagNames = await extractTags(insert.content || '');
522
+ if (tags?.length || contentTagNames?.length) {
523
+ const userTags = tags?.length ? (await getTagsByName(context, tags.map(({ name })=>name || ''))).map((tag)=>({
524
+ ...tag,
525
+ tagBy: sessionId
526
+ })) : [];
527
+ const contentTags = contentTagNames?.length ? (await getTagsByName(context, contentTagNames || [])).map((tag)=>({
528
+ ...tag,
529
+ tagBy: 'extract'
530
+ })) : [];
531
+ const updatedTags = await updateTagsInItem(context, {
532
+ itemDocId: updatedPostId,
533
+ tags: [
534
+ ...contentTags,
535
+ ...userTags
536
+ ]
537
+ });
538
+ return {
539
+ ...updatedPost,
540
+ tags: updatedTags
541
+ };
542
+ }
543
+ return updatedPost;
544
+ } catch (error) {
545
+ throw error;
546
+ }
547
+ };
548
+ export const deletePost = async (context, postDocId)=>{
549
+ const action = 'deletePost';
550
+ const { databaseName, session: { userId: sessionId } = {} } = context;
551
+ const formatPostId = parseArangoId(postDocId);
552
+ if (!formatPostId) {
553
+ throw logException({
554
+ action,
555
+ category: eventCategory,
556
+ value: ErrorTypes.INVALID_ID
557
+ }, context);
558
+ }
559
+ const edgeAqlQry = aql`FOR t IN isTagged
560
+ FILTER t._to == ${formatPostId}
561
+ REMOVE t IN isTagged`;
562
+ await useDb(databaseName).query(edgeAqlQry).catch((error)=>{
563
+ throw error;
564
+ });
565
+ const fileAqlQry = aql`FOR f IN hasFile
566
+ FILTER f._to == ${formatPostId}
567
+ REMOVE f IN hasFile`;
568
+ await useDb(databaseName).query(fileAqlQry).catch((error)=>{
569
+ throw error;
570
+ });
571
+ const aqlQry = aql`FOR p IN posts
572
+ FILTER p._id == ${formatPostId} && p.userId == ${sessionId}
573
+ LIMIT 1
574
+ REMOVE p IN posts
575
+ RETURN OLD`;
576
+ return useDb(databaseName).query(aqlQry).then((cursor)=>cursor.next()).catch((error)=>{
577
+ throw error;
578
+ });
579
+ };
580
+ export const createPostEdge = (context, postDocId, itemDocId, edgeType = 'isPosted', props = {})=>{
581
+ const action = 'createPostEdge';
582
+ const { databaseName } = context;
583
+ const edgeCollection = useDb(databaseName).collection(edgeType);
584
+ const formatPostId = parseArangoId(postDocId);
585
+ const formatDocId = parseArangoId(itemDocId);
586
+ if (!formatDocId || !formatPostId) {
587
+ throw new Error(ErrorTypes.INVALID_ID);
588
+ }
589
+ const edgeId = createHash(`postEdge-${formatPostId}-${formatDocId}`);
590
+ const edge = {
591
+ _from: formatPostId,
592
+ _key: edgeId,
593
+ _to: formatDocId,
594
+ added: Date.now(),
595
+ ...props
596
+ };
597
+ return edgeCollection.save(edge, {
598
+ returnNew: true
599
+ }).catch((error)=>{
600
+ throw logError({
601
+ action,
602
+ category: eventCategory,
603
+ value: ErrorTypes.DATABASE_ERROR
604
+ }, error, context);
605
+ });
606
+ };
607
+
608
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["/Users/nitrog7/Development/reaktor/src/actions/posts.ts"],"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 { parseNum } from '@nlabs/utils/parsers/numbers';\nimport {\n    createHash, parseArangoId, parseChar, parseId, parseString, parseVarChar\n} from '@nlabs/utils/parsers/strings';\nimport { aql } from 'arangojs';\nimport { AqlQuery } from 'arangojs/aql';\n\nimport { parsePost } from '../adapters/postAdapter.js';\nimport { ErrorTypes } from '../types/error.types.js';\nimport { logError, logException } from '../utils/analyticsUtils.js';\nimport { getLimit, useDb } from '../utils/arangodbUtils.js';\nimport { extractTags, getTagsByName, updateTagsInItem } from './tags.js';\n\nimport type { EdgeCollection } from 'arangojs/collections';\nimport type { ArangoDbLimit } from '../types/arangodb.types.js';\nimport type { ApiContext } from '../types/auth.types.js';\nimport type { FileType } from '../types/files.types.js';\nimport type { PostInputType, PostOptions, PostType } from '../types/posts.types.js';\nimport type { TagType } from '../types/tags.types.js';\n\nconst MAX_CONTENT_LENGTH: number = 100000;\nconst eventCategory: string = 'posts';\n\nexport const parsePostOptions = (options: PostOptions = {}) => {\n  const {\n    from = 0,\n    latitude = 0,\n    longitude = 0,\n    to = 30,\n    type = 'post'\n  } = options;\n\n  return {\n    latitude: parseNum(latitude, 32),\n    limit: getLimit(from, to) as ArangoDbLimit,\n    longitude: parseNum(longitude, 32),\n    type: parseChar(type, 32)\n  };\n};\n\nexport const getPostOptional = (fields: string[] = [], sessionId: string = '') =>\n  (fields || []).reduce((selects: {objects: string[], queries: string[]}, field: string) => {\n    switch(field) {\n      case 'hasRsvp': {\n        selects.queries.push(`LET hasRsvp = TO_BOOL(FIRST(\n          FOR post, r IN INBOUND p._id hasReaction\n          FILTER r.name == \"rsvp\" && r.type == \"posts\" && r._from == \"users/${sessionId}\"\n          COLLECT WITH COUNT INTO count\n          RETURN count\n        ))`);\n        selects.objects.push('hasRsvp:hasRsvp');\n        return selects;\n      }\n      case 'isSaved': {\n        selects.queries.push(`LET isSaved = TO_BOOL(FIRST(\n          FOR post, r IN INBOUND p._id hasReaction\n          FILTER r.name == \"pin\" && r.type == \"posts\" && r._from == \"users/${sessionId}\"\n          COLLECT WITH COUNT INTO count\n          RETURN count\n        ))`);\n        selects.objects.push('isSaved:isSaved');\n        return selects;\n      }\n      case 'reactions': {\n        selects.queries.push(`LET reactions = (\n          FOR post, r IN INBOUND p._id hasReaction\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 'rsvpCount': {\n        selects.queries.push(`LET rsvpCount = FIRST(\n          FOR post, r IN INBOUND p._id hasReaction\n          FILTER r.name == \"rsvp\" && r.type == \"posts\"\n          COLLECT WITH COUNT INTO count\n          RETURN count\n        )`);\n        selects.objects.push('rsvpCount:rsvpCount');\n        return selects;\n      }\n      case 'viewCount': {\n        selects.queries.push(`LET viewCount = FIRST(\n          FOR post, r IN INBOUND p._id hasReaction\n          FILTER r.name == \"view\" && r.type == \"posts\"\n          COLLECT WITH COUNT INTO count\n          RETURN count\n        )`);\n        selects.objects.push('viewCount:viewCount');\n        return selects;\n      }\n      default: {\n        return selects;\n      }\n    }\n  }, {objects: [], queries: []});\n\nexport const getPost = async (\n  context: ApiContext,\n  postId: string,\n  options?: PostOptions\n): Promise<PostType> => {\n  const action: string = 'getPost';\n  const {databaseName, fields, session: {userId: sessionId} = {}} = context;\n  const formatItemId: string = parseId(postId);\n  const {type} = parsePostOptions(options);\n  const database = useDb(databaseName);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields, sessionId);\n  const aqlQry: AqlQuery = aql`FOR p IN posts\n    FILTER p._key == ${formatItemId} && p.type == ${type}\n    LIMIT 1\n    RETURN p`;\n\n  return database.query(aqlQry)\n    .then((cursor) => cursor.next())\n    .then((post: PostType) => {\n      const {\n        _id: postDocId,\n        userId,\n        groupId,\n        privacy = 'default'\n      }: PostType = post;\n\n      let privacyAqlQry: string | undefined;\n\n      if(userId === sessionId) {\n        return post;\n      }\n\n      if(groupId && privacy === 'group') {\n        privacyAqlQry = `LET p = DOCUMENT(\"${postDocId}\")\n          ${selectQueries.join('\\n')}\n          FOR group IN groups\n          FILTER group._key == p.groupId\n          FOR u, e IN OUTBOUND group._id hasConnection\n          FILTER u._key == \"${sessionId}\"\n          LIMIT 1\n          RETURN MERGE(p, {${selectObjects.join(', ')}})`;\n      } else if(privacy === 'public') {\n        privacyAqlQry = `LET p = DOCUMENT(\"${postDocId}\")\n          ${selectQueries.join('\\n')}\n          LIMIT 1\n          RETURN MERGE(p, {${selectObjects.join(', ')}})`;\n      }\n\n      if(privacyAqlQry) {\n        return database.query(privacyAqlQry)\n          .then((cursor) => cursor.next())\n          .catch((error: Error) => logError({\n            action,\n            category: eventCategory,\n            label: ErrorTypes.DATABASE_ERROR\n          }, error, context));\n      }\n\n      return {};\n    })\n    .catch((error: Error) => logError({\n      action,\n      category: eventCategory,\n      label: ErrorTypes.DATABASE_ERROR\n    }, error, context));\n};\n\n\n// export const getPostList = (context: ApiContext, options?: PostOptions): Promise<PostType[]> => {\n//   // const action: string = 'getListByApp';\n//   const {database, fields, session: {userId: sessionId}} = context;\n//   const {limit, type} = parsePostOptions(options);\n//   const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields, sessionId);\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 database.query(aqlQry)\n//     .then((cursor) => cursor.all())\n//     .catch((error: Error) => {\n//       throw error;\n//     });\n// };\n\nexport const getPostsByArea = (\n  context: ApiContext,\n  latitude: number,\n  longitude: number,\n  options?: PostOptions\n): Promise<PostType[]> => {\n  const action: string = 'getPostsByArea';\n  const {databaseName, fields, session: {userId: sessionId} = {}} = 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, sessionId);\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(databaseName).query(aqlQry)\n    .then((cursor) => cursor.all() as unknown as PostType[])\n    .catch((error: Error) => {\n      logError({\n        action,\n        category: eventCategory,\n        label: ErrorTypes.DATABASE_ERROR\n      }, error, context);\n\n      return [] as PostType[];\n    });\n};\n\n// export const getPostsByGroup = (\n//   context: ApiContext,\n//   groupId: string,\n//   options?: PostOptions\n// ): Promise<PostType[]> => {\n//   // const action: string = 'getListByGroup';\n//   const {database, fields, session: {userId: sessionId}} = context;\n//   const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields, sessionId);\n\n//   // Group id\n//   const formatGroupId: string = parseId(groupId);\n//   const db = 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) => 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) => 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 getPostsByLatest = (context: ApiContext, options?: PostOptions): Promise<PostType[]> => {\n  // const action: string = 'getListByLatest';\n  const {databaseName, fields, session: {userId: sessionId} = {}} = context;\n  const {limit, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields, sessionId);\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 DESC\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n  return useDb(databaseName).query(aqlQry)\n    .then((cursor) => cursor.all())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const getPostsByReactions = (\n  context: ApiContext,\n  reactions: string[] = [],\n  options?: PostOptions\n): Promise<PostType[]> => {\n  const action: string = 'getPostsByReactions';\n  const {databaseName, fields, session: {userId: sessionId} = {}} = context;\n  const {latitude, limit, longitude, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields, sessionId);\n  const formatSessionId: string = `users/${sessionId}`;\n  const formatReactions: string = JSON.stringify(reactions.map((reaction) => parseChar(reaction, 32).toLowerCase()));\n  const sortBy: string[] = [];\n  const filters: string[] = [`p.type == \"${type}\"`, 'p.privacy == \"public\"'];\n  const formatLatitude: number = parseNum(latitude);\n  const formatLongitude: number = parseNum(longitude);\n\n  if(formatLatitude && formatLongitude) {\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  if(reactions.length) {\n    sortBy.push('matchedTags DESC');\n    selectQueries.push(`LET matchedReactions = LENGTH(\n      FOR mr IN reactions\n      FILTER mr.matched == true\n      RETURN mr\n    )`);\n    selectObjects.push('matchedReactions:matchedReactions');\n    filters.push('matchedReactions > 0');\n  }\n\n  sortBy.push('p.added DESC');\n  selectObjects.push('reactions:reactions');\n\n  // Get data from database\n  const aqlQry: string = `FOR p, r IN OUTBOUND \"${formatSessionId}\" hasReaction\n    LET reactions = (\n      FOR reaction, hr IN 1..1 INBOUND p isTagged\n      LET matched = LENGTH(${formatReactions}) > 0 && POSITION(${formatReactions}, reaction.name)\n      SORT reaction.name\n      RETURN MERGE(reaction, {matched:matched})\n    )\n    ${selectQueries.join('\\n')}\n    FILTER ${filters.join(' && ')}\n    ${limit.aql}\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n  return useDb(databaseName).query(aqlQry)\n    .then((cursor) => cursor.all() as unknown as PostType[])\n    .catch((error: Error) => {\n      logError({\n        action,\n        category: eventCategory,\n        label: ErrorTypes.DATABASE_ERROR\n      }, error, context);\n\n      return [] as PostType[];\n    });\n};\n\nexport const getPostsByTags = (\n  context: ApiContext,\n  tags: string[] = [],\n  options?: PostOptions\n): Promise<PostType[]> => {\n  const action: string = 'getPostsByTags';\n  const {databaseName, fields, session: {userId: sessionId} = {}} = context;\n  const {latitude, limit, longitude, type} = parsePostOptions(options);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields, sessionId);\n  const formatTagNames: string = JSON.stringify(tags.map((tag) => parseChar(tag, 32).toLowerCase()));\n  const sortBy: string[] = [];\n  const filters: string[] = [`p.type == \"${type}\"`, 'p.privacy == \"public\"'];\n  const formatLatitude: number = parseNum(latitude);\n  const formatLongitude: number = parseNum(longitude);\n\n  if(formatLatitude && formatLongitude) {\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  if(tags.length) {\n    sortBy.push('matchedTags DESC');\n    selectQueries.push(`LET matchedTags = LENGTH(\n      FOR t IN tags\n      FILTER t.matched == true\n      RETURN t\n    )`);\n    selectObjects.push('matchedTags:matchedTags');\n    filters.push('matchedTags > 0');\n  }\n\n  sortBy.push('p.added DESC');\n  selectObjects.push('tags:tags');\n\n  const aqlQry: string = `FOR p IN posts\n    LET tags = (\n      FOR tag, it IN 1..1 INBOUND p isTagged\n      LET matched = LENGTH(${formatTagNames}) > 0 && POSITION(${formatTagNames}, tag.name)\n      SORT tag.name\n      RETURN MERGE(tag, {matched:matched})\n    )\n    ${selectQueries.join('\\n')}\n    FILTER ${filters.join(' && ')}\n    ${limit.aql}\n    SORT ${sortBy.join(', ')}\n    RETURN DISTINCT MERGE(p, {${selectObjects.join(', ')}})`;\n\n  return useDb(databaseName).query(aqlQry)\n    .then((cursor) => cursor.all() as unknown as PostType[])\n    .catch((error: Error) => {\n      logError({\n        action,\n        category: eventCategory,\n        label: ErrorTypes.DATABASE_ERROR\n      }, error, context);\n\n      return [] as PostType[];\n    });\n};\n\nexport const getPostsByUser = (context: ApiContext, userId: string, options?: PostOptions): Promise<PostType[]> => {\n  const action: string = 'getPostsByUser';\n  const {databaseName, fields, session: {userId: sessionId} = {}} = context;\n  const {limit, type} = parsePostOptions(options);\n  const formatUserId: string = parseId(userId);\n  const {objects: selectObjects, queries: selectQueries} = getPostOptional(fields, sessionId);\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(databaseName).query(aqlQry)\n    .then((cursor) => cursor.all() as unknown as PostType[])\n    .catch((error: Error) => {\n      logError({\n        action,\n        category: eventCategory,\n        label: ErrorTypes.DATABASE_ERROR\n      }, error, context);\n\n      return [] as PostType[];\n    });\n};\n\nexport const getPostComments = (context: ApiContext, postId: string, options?: PostOptions): Promise<PostType[]> => {\n  const action: string = 'getPostComments';\n  const {databaseName, session: {userId: sessionId} = {}} = context;\n  const {limit, type} = parsePostOptions(options);\n  const formatItemId: string = parseId(postId);\n\n  // Get the parent post to get restrictions\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 useDb(databaseName).query(aqlQry)\n    .then((cursor) => 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 | undefined;\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 hasConnection\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 useDb(databaseName).query(privacyAqlQry)\n          .then((cursor) => cursor.all() as unknown as PostType[])\n          .catch((error: Error) => {\n            logError({\n              action,\n              category: eventCategory,\n              label: ErrorTypes.DATABASE_ERROR\n            }, error, context);\n\n            return [] as PostType[];\n          });\n      }\n\n      return [] as PostType[];\n    })\n    .catch((error: Error) => {\n      logError({\n        action,\n        category: eventCategory,\n        label: ErrorTypes.DATABASE_ERROR\n      }, error, context);\n\n      return [] as PostType[];\n    });\n};\n\nexport const addPost = async (\n  context: ApiContext,\n  {\n    content = '',\n    endDate,\n    groupId = '',\n    location,\n    latitude,\n    longitude,\n    name = '',\n    parentId = '',\n    privacy = 'public',\n    tags = [],\n    startDate,\n    type = 'default'\n  }: PostInputType\n): Promise<PostType> => {\n  const action: string = 'addPost';\n  const {databaseName, session: {userId: sessionId} = {}} = context;\n  const now = Date.now();\n  const postId = createHash(`post-${sessionId}`);\n  const insert: PostType = {\n    _id: `posts/${postId}`,\n    _key: postId,\n    added: now,\n    content: parseString(content, MAX_CONTENT_LENGTH) || '',\n    endDate: endDate ? parseNum(endDate, 13) : undefined,\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: parseVarChar(privacy, 16),\n    startDate: startDate ? parseNum(startDate, 13) : undefined,\n    type: parseChar(type, 32),\n    userId: sessionId\n  };\n  const aqlQry: AqlQuery = aql`INSERT ${insert} IN posts RETURN NEW`;\n\n  try {\n    const savedPost: PostType = await useDb(databaseName).query(aqlQry)\n      .then((cursor) => cursor.next())\n      .catch((error: Error) => logError({\n        action,\n        category: eventCategory,\n        label: ErrorTypes.DATABASE_ERROR\n      }, error, context));\n    const {_id: postDocId} = savedPost;\n    const contentTagNames = await extractTags(insert.content || '');\n\n    if(tags.length || contentTagNames.length) {\n      const userTags = (await getTagsByName(context, tags.map(({name}) => name || '')))\n        .map((tag) => ({...tag, tagBy: sessionId}));\n      const contentTags = (await getTagsByName(context, contentTagNames || []))\n        .map((tag) => ({...tag, tagBy: 'extract'}));\n      const updatedTags: TagType[] = await updateTagsInItem(\n        context,\n        {\n          itemDocId: postDocId,\n          tags: [...contentTags, ...userTags]\n        }\n      );\n\n      return {\n        ...savedPost,\n        tags: updatedTags\n      };\n    }\n\n    return savedPost;\n  } catch(error) {\n    throw error;\n  }\n};\n\nexport const updatePost = async (context: ApiContext, post: PostInputType): Promise<PostType> => {\n  const action: string = 'updatePost';\n  const {databaseName, session: {userId: sessionId} = {}} = context;\n  const now: number = Date.now();\n  const parsedPost = parsePost(post);\n  const {\n    postId,\n    tags = []\n  } = parsedPost;\n\n  const update: PostType = {\n    ...parsedPost,\n    modified: now\n  };\n\n  if(!postId) {\n    throw logException({\n      action,\n      category: eventCategory,\n      value: ErrorTypes.INVALID_ID\n    }, context);\n  }\n\n  const insert = {\n    ...update,\n    _key: postId,\n    added: now,\n    userId: sessionId\n  };\n  const aqlQry: AqlQuery = aql`UPSERT {_key: ${postId}, userId: ${sessionId}}\n    INSERT ${insert}\n    UPDATE ${update}\n    IN posts RETURN NEW`;\n\n  try {\n    const updatedPost: PostType = await useDb(databaseName)\n      .query(aqlQry)\n      .then((cursor) => cursor.next())\n      .catch((error: Error) => logError({\n        action,\n        category: eventCategory,\n        value: ErrorTypes.DATABASE_ERROR\n      }, error, {}));\n    const {_id: updatedPostId} = updatedPost;\n    const contentTagNames = await extractTags(insert.content || '');\n\n    if(tags?.length || contentTagNames?.length) {\n      const userTags = tags?.length ? (await getTagsByName(context, tags.map(({name}) => name || '')))\n        .map((tag) => ({...tag, tagBy: sessionId})) : [];\n      const contentTags = contentTagNames?.length ? (await getTagsByName(context, contentTagNames || []))\n        .map((tag) => ({...tag, tagBy: 'extract'})) : [];\n      const updatedTags: TagType[] = await updateTagsInItem(\n        context,\n        {\n          itemDocId: updatedPostId,\n          tags: [...contentTags, ...userTags]\n        }\n      );\n\n      return {\n        ...updatedPost,\n        tags: updatedTags\n      };\n    }\n\n    return updatedPost;\n  } catch(error) {\n    throw error;\n  }\n};\n\nexport const deletePost = async (context: ApiContext, postDocId: string): Promise<PostType> => {\n  const action: string = 'deletePost';\n  const {databaseName, session: {userId: sessionId} = {}} = context;\n  const formatPostId: string = parseArangoId(postDocId);\n\n  if(!formatPostId) {\n    throw logException({\n      action,\n      category: eventCategory,\n      value: ErrorTypes.INVALID_ID\n    }, context);\n  }\n\n  const edgeAqlQry: AqlQuery = aql`FOR t IN isTagged\n  FILTER t._to == ${formatPostId}\n  REMOVE t IN isTagged`;\n\n  await useDb(databaseName).query(edgeAqlQry)\n    .catch((error: Error) => {\n      throw error;\n    });\n\n  const fileAqlQry: AqlQuery = aql`FOR f IN hasFile\n    FILTER f._to == ${formatPostId}\n    REMOVE f IN hasFile`;\n\n  await useDb(databaseName).query(fileAqlQry)\n    .catch((error: Error) => {\n      throw error;\n    });\n\n  const aqlQry = aql`FOR p IN posts\n      FILTER p._id == ${formatPostId} && p.userId == ${sessionId}\n      LIMIT 1\n      REMOVE p IN posts\n      RETURN OLD`;\n\n  return useDb(databaseName).query(aqlQry)\n    .then((cursor) => cursor.next())\n    .catch((error: Error) => {\n      throw error;\n    });\n};\n\nexport const createPostEdge = (\n  context: ApiContext,\n  postDocId: string,\n  itemDocId: string,\n  edgeType: string = 'isPosted',\n  props = {}\n): Promise<FileType> => {\n  const action = 'createPostEdge';\n  const {databaseName} = context;\n  const edgeCollection: EdgeCollection = useDb(databaseName).collection(edgeType);\n  const formatPostId: string = parseArangoId(postDocId);\n  const formatDocId: string = parseArangoId(itemDocId);\n\n  if(!formatDocId || !formatPostId) {\n    throw new Error(ErrorTypes.INVALID_ID);\n  }\n\n  const edgeId: string = createHash(`postEdge-${formatPostId}-${formatDocId}`);\n  const edge = {\n    _from: formatPostId,\n    _key: edgeId,\n    _to: formatDocId,\n    added: Date.now(),\n    ...props\n  };\n\n  return edgeCollection.save(edge, {returnNew: true})\n    .catch((error: Error) => {\n      throw logError({\n        action,\n        category: eventCategory,\n        value: ErrorTypes.DATABASE_ERROR\n      }, error, context);\n    });\n};\n"],"names":["parseNum","createHash","parseArangoId","parseChar","parseId","parseString","parseVarChar","aql","parsePost","ErrorTypes","logError","logException","getLimit","useDb","extractTags","getTagsByName","updateTagsInItem","MAX_CONTENT_LENGTH","eventCategory","parsePostOptions","options","from","latitude","longitude","to","type","limit","getPostOptional","fields","sessionId","reduce","selects","field","queries","push","objects","getPost","context","postId","action","databaseName","session","userId","formatItemId","database","selectObjects","selectQueries","aqlQry","query","then","cursor","next","post","_id","postDocId","groupId","privacy","privacyAqlQry","join","catch","error","category","label","DATABASE_ERROR","getPostsByArea","formatLatitude","formatLongitude","all","getPostsByLatest","getPostsByReactions","reactions","formatSessionId","formatReactions","JSON","stringify","map","reaction","toLowerCase","sortBy","filters","length","getPostsByTags","tags","formatTagNames","tag","getPostsByUser","formatUserId","getPostComments","_key","addPost","content","endDate","location","name","parentId","startDate","now","Date","insert","added","undefined","modified","savedPost","contentTagNames","userTags","tagBy","contentTags","updatedTags","itemDocId","updatePost","parsedPost","update","value","INVALID_ID","updatedPost","updatedPostId","deletePost","formatPostId","edgeAqlQry","fileAqlQry","createPostEdge","edgeType","props","edgeCollection","collection","formatDocId","Error","edgeId","edge","_from","_to","save","returnNew"],"mappings":"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"}