@nlabs/reaktor 0.10.2 → 0.10.6

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 (472) hide show
  1. package/coverage/block-navigation.js +1 -1
  2. package/coverage/index.html +23 -23
  3. package/coverage/sorter.js +21 -7
  4. package/lib/actions/apps.d.ts +1 -0
  5. package/lib/actions/apps.d.ts.map +1 -0
  6. package/lib/actions/apps.js +218 -17
  7. package/lib/actions/connections.d.ts +1 -0
  8. package/lib/actions/connections.d.ts.map +1 -0
  9. package/lib/actions/connections.js +61 -6
  10. package/lib/actions/content.d.ts +1 -0
  11. package/lib/actions/content.d.ts.map +1 -0
  12. package/lib/actions/content.js +232 -9
  13. package/lib/actions/conversations.d.ts +1 -0
  14. package/lib/actions/conversations.d.ts.map +1 -0
  15. package/lib/actions/conversations.js +321 -19
  16. package/lib/actions/dynamodb.d.ts +1 -0
  17. package/lib/actions/dynamodb.d.ts.map +1 -0
  18. package/lib/actions/dynamodb.js +119 -2
  19. package/lib/actions/email.d.ts +1 -0
  20. package/lib/actions/email.d.ts.map +1 -0
  21. package/lib/actions/email.js +56 -2
  22. package/lib/actions/files.d.ts +1 -0
  23. package/lib/actions/files.d.ts.map +1 -0
  24. package/lib/actions/files.js +226 -5
  25. package/lib/actions/groups.d.ts +1 -0
  26. package/lib/actions/groups.d.ts.map +1 -0
  27. package/lib/actions/groups.js +234 -19
  28. package/lib/actions/images.d.ts +1 -0
  29. package/lib/actions/images.d.ts.map +1 -0
  30. package/lib/actions/images.js +688 -31
  31. package/lib/actions/index.d.ts +2 -0
  32. package/lib/actions/index.d.ts.map +1 -0
  33. package/lib/actions/index.js +29 -2
  34. package/lib/actions/ios.d.ts +1 -0
  35. package/lib/actions/ios.d.ts.map +1 -0
  36. package/lib/actions/ios.js +228 -9
  37. package/lib/actions/locations.d.ts +1 -0
  38. package/lib/actions/locations.d.ts.map +1 -0
  39. package/lib/actions/locations.js +111 -7
  40. package/lib/actions/messages.d.ts +1 -0
  41. package/lib/actions/messages.d.ts.map +1 -0
  42. package/lib/actions/messages.js +155 -21
  43. package/lib/actions/notifications.d.ts +1 -0
  44. package/lib/actions/notifications.d.ts.map +1 -0
  45. package/lib/actions/notifications.js +37 -2
  46. package/lib/actions/payments.d.ts +1 -0
  47. package/lib/actions/payments.d.ts.map +1 -0
  48. package/lib/actions/payments.js +428 -11
  49. package/lib/actions/posts.d.ts +1 -0
  50. package/lib/actions/posts.d.ts.map +1 -0
  51. package/lib/actions/posts.js +540 -75
  52. package/lib/actions/profiles.d.ts +1 -0
  53. package/lib/actions/profiles.d.ts.map +1 -0
  54. package/lib/actions/profiles.js +58 -8
  55. package/lib/actions/reactions.d.ts +1 -0
  56. package/lib/actions/reactions.d.ts.map +1 -0
  57. package/lib/actions/reactions.js +276 -25
  58. package/lib/actions/s3.d.ts +1 -0
  59. package/lib/actions/s3.d.ts.map +1 -0
  60. package/lib/actions/s3.js +102 -2
  61. package/lib/actions/search.d.ts +1 -0
  62. package/lib/actions/search.d.ts.map +1 -0
  63. package/lib/actions/search.js +81 -5
  64. package/lib/actions/sms.d.ts +1 -0
  65. package/lib/actions/sms.d.ts.map +1 -0
  66. package/lib/actions/sms.js +52 -2
  67. package/lib/actions/statistics.d.ts +1 -0
  68. package/lib/actions/statistics.d.ts.map +1 -0
  69. package/lib/actions/statistics.js +41 -6
  70. package/lib/actions/subscriptions.d.ts +1 -0
  71. package/lib/actions/subscriptions.d.ts.map +1 -0
  72. package/lib/actions/subscriptions.js +196 -6
  73. package/lib/actions/tags.d.ts +1 -0
  74. package/lib/actions/tags.d.ts.map +1 -0
  75. package/lib/actions/tags.js +258 -19
  76. package/lib/actions/users.d.ts +1 -0
  77. package/lib/actions/users.d.ts.map +1 -0
  78. package/lib/actions/users.js +781 -66
  79. package/lib/actions/videos.d.ts +26 -0
  80. package/lib/actions/videos.d.ts.map +1 -0
  81. package/lib/actions/videos.js +423 -0
  82. package/lib/actions/websockets.d.ts +1 -0
  83. package/lib/actions/websockets.d.ts.map +1 -0
  84. package/lib/actions/websockets.js +148 -14
  85. package/lib/adapters/arangoAdapter.d.ts +1 -0
  86. package/lib/adapters/arangoAdapter.d.ts.map +1 -0
  87. package/lib/adapters/arangoAdapter.js +70 -2
  88. package/lib/adapters/contentAdapter.d.ts +1 -0
  89. package/lib/adapters/contentAdapter.d.ts.map +1 -0
  90. package/lib/adapters/contentAdapter.js +108 -2
  91. package/lib/adapters/fileAdapter.d.ts +1 -0
  92. package/lib/adapters/fileAdapter.d.ts.map +1 -0
  93. package/lib/adapters/fileAdapter.js +119 -2
  94. package/lib/adapters/imageAdapter.d.ts +1 -0
  95. package/lib/adapters/imageAdapter.d.ts.map +1 -0
  96. package/lib/adapters/imageAdapter.js +112 -2
  97. package/lib/adapters/index.d.ts +1 -0
  98. package/lib/adapters/index.d.ts.map +1 -0
  99. package/lib/adapters/index.js +11 -2
  100. package/lib/adapters/messageAdapter.d.ts +1 -0
  101. package/lib/adapters/messageAdapter.d.ts.map +1 -0
  102. package/lib/adapters/messageAdapter.js +82 -2
  103. package/lib/adapters/postAdapter.d.ts +1 -0
  104. package/lib/adapters/postAdapter.d.ts.map +1 -0
  105. package/lib/adapters/postAdapter.js +117 -2
  106. package/lib/adapters/reaktorAdapter.d.ts +1 -0
  107. package/lib/adapters/reaktorAdapter.d.ts.map +1 -0
  108. package/lib/adapters/reaktorAdapter.js +59 -2
  109. package/lib/adapters/tagAdapter.d.ts +1 -0
  110. package/lib/adapters/tagAdapter.d.ts.map +1 -0
  111. package/lib/adapters/tagAdapter.js +99 -2
  112. package/lib/adapters/userAdapter.d.ts +1 -0
  113. package/lib/adapters/userAdapter.d.ts.map +1 -0
  114. package/lib/adapters/userAdapter.js +264 -2
  115. package/lib/config.d.ts +1 -0
  116. package/lib/config.d.ts.map +1 -0
  117. package/lib/config.js +161 -2
  118. package/lib/handlers/graphqlHandler.d.ts +1 -0
  119. package/lib/handlers/graphqlHandler.d.ts.map +1 -0
  120. package/lib/handlers/graphqlHandler.js +118 -2
  121. package/lib/index.d.ts +1 -0
  122. package/lib/index.d.ts.map +1 -0
  123. package/lib/index.js +18 -2
  124. package/lib/lambdas/actions/websockets.d.ts +1 -0
  125. package/lib/lambdas/actions/websockets.d.ts.map +1 -0
  126. package/lib/lambdas/actions/websockets.js +89 -14
  127. package/lib/lambdas/authorizer.d.ts +1 -0
  128. package/lib/lambdas/authorizer.d.ts.map +1 -0
  129. package/lib/lambdas/authorizer.js +41 -2
  130. package/lib/lambdas/connection.d.ts +1 -0
  131. package/lib/lambdas/connection.d.ts.map +1 -0
  132. package/lib/lambdas/connection.js +85 -2
  133. package/lib/lambdas/utils/message.d.ts +1 -0
  134. package/lib/lambdas/utils/message.d.ts.map +1 -0
  135. package/lib/lambdas/utils/message.js +20 -2
  136. package/lib/lambdas/utils/websocket.d.ts +1 -0
  137. package/lib/lambdas/utils/websocket.d.ts.map +1 -0
  138. package/lib/lambdas/utils/websocket.js +78 -2
  139. package/lib/mocks/conversation.d.ts +1 -0
  140. package/lib/mocks/conversation.d.ts.map +1 -0
  141. package/lib/mocks/conversation.js +10 -2
  142. package/lib/mocks/file.d.ts +1 -0
  143. package/lib/mocks/file.d.ts.map +1 -0
  144. package/lib/mocks/file.js +13 -2
  145. package/lib/mocks/group.d.ts +1 -0
  146. package/lib/mocks/group.d.ts.map +1 -0
  147. package/lib/mocks/group.js +20 -2
  148. package/lib/mocks/image.d.ts +1 -0
  149. package/lib/mocks/image.d.ts.map +1 -0
  150. package/lib/mocks/image.js +17 -2
  151. package/lib/mocks/post.d.ts +1 -0
  152. package/lib/mocks/post.d.ts.map +1 -0
  153. package/lib/mocks/post.js +28 -2
  154. package/lib/mocks/tag.d.ts +1 -0
  155. package/lib/mocks/tag.d.ts.map +1 -0
  156. package/lib/mocks/tag.js +12 -2
  157. package/lib/mocks/user.d.ts +1 -0
  158. package/lib/mocks/user.d.ts.map +1 -0
  159. package/lib/mocks/user.js +61 -2
  160. package/lib/mocks/video.d.ts +4 -0
  161. package/lib/mocks/video.d.ts.map +1 -0
  162. package/lib/mocks/video.js +17 -0
  163. package/lib/mutations/content.d.ts +1 -0
  164. package/lib/mutations/content.d.ts.map +1 -0
  165. package/lib/mutations/content.js +27 -2
  166. package/lib/mutations/index.d.ts +1 -0
  167. package/lib/mutations/index.d.ts.map +1 -0
  168. package/lib/mutations/index.js +29 -2
  169. package/lib/mutations/locations.d.ts +1 -0
  170. package/lib/mutations/locations.d.ts.map +1 -0
  171. package/lib/mutations/locations.js +22 -2
  172. package/lib/mutations/messages.d.ts +1 -0
  173. package/lib/mutations/messages.d.ts.map +1 -0
  174. package/lib/mutations/messages.js +75 -2
  175. package/lib/mutations/posts.d.ts +1 -0
  176. package/lib/mutations/posts.d.ts.map +1 -0
  177. package/lib/mutations/posts.js +31 -2
  178. package/lib/mutations/profiles.d.ts +1 -0
  179. package/lib/mutations/profiles.d.ts.map +1 -0
  180. package/lib/mutations/profiles.js +78 -2
  181. package/lib/mutations/reactions.d.ts +1 -0
  182. package/lib/mutations/reactions.d.ts.map +1 -0
  183. package/lib/mutations/reactions.js +29 -2
  184. package/lib/mutations/statistics.d.ts +1 -0
  185. package/lib/mutations/statistics.d.ts.map +1 -0
  186. package/lib/mutations/statistics.js +17 -2
  187. package/lib/mutations/subscriptions.d.ts +1 -0
  188. package/lib/mutations/subscriptions.d.ts.map +1 -0
  189. package/lib/mutations/subscriptions.js +38 -2
  190. package/lib/mutations/tags.d.ts +1 -0
  191. package/lib/mutations/tags.d.ts.map +1 -0
  192. package/lib/mutations/tags.js +109 -2
  193. package/lib/mutations/users.d.ts +1 -0
  194. package/lib/mutations/users.d.ts.map +1 -0
  195. package/lib/mutations/users.js +129 -2
  196. package/lib/objectTypes/app.d.ts +1 -0
  197. package/lib/objectTypes/app.d.ts.map +1 -0
  198. package/lib/objectTypes/app.js +147 -2
  199. package/lib/objectTypes/bankAccount.d.ts +1 -0
  200. package/lib/objectTypes/bankAccount.d.ts.map +1 -0
  201. package/lib/objectTypes/bankAccount.js +54 -2
  202. package/lib/objectTypes/connection.d.ts +1 -0
  203. package/lib/objectTypes/connection.d.ts.map +1 -0
  204. package/lib/objectTypes/connection.js +26 -2
  205. package/lib/objectTypes/content.d.ts +1 -0
  206. package/lib/objectTypes/content.d.ts.map +1 -0
  207. package/lib/objectTypes/content.js +79 -2
  208. package/lib/objectTypes/conversation.d.ts +1 -0
  209. package/lib/objectTypes/conversation.d.ts.map +1 -0
  210. package/lib/objectTypes/conversation.js +53 -2
  211. package/lib/objectTypes/creditCard.d.ts +1 -0
  212. package/lib/objectTypes/creditCard.d.ts.map +1 -0
  213. package/lib/objectTypes/creditCard.js +64 -2
  214. package/lib/objectTypes/document.d.ts +1 -0
  215. package/lib/objectTypes/document.d.ts.map +1 -0
  216. package/lib/objectTypes/document.js +21 -2
  217. package/lib/objectTypes/error.d.ts +1 -0
  218. package/lib/objectTypes/error.d.ts.map +1 -0
  219. package/lib/objectTypes/error.js +24 -2
  220. package/lib/objectTypes/external.d.ts +1 -0
  221. package/lib/objectTypes/external.d.ts.map +1 -0
  222. package/lib/objectTypes/external.js +52 -2
  223. package/lib/objectTypes/file.d.ts +1 -0
  224. package/lib/objectTypes/file.d.ts.map +1 -0
  225. package/lib/objectTypes/file.js +76 -2
  226. package/lib/objectTypes/filter.d.ts +1 -0
  227. package/lib/objectTypes/filter.d.ts.map +1 -0
  228. package/lib/objectTypes/filter.js +21 -2
  229. package/lib/objectTypes/group.d.ts +1 -0
  230. package/lib/objectTypes/group.d.ts.map +1 -0
  231. package/lib/objectTypes/group.js +97 -2
  232. package/lib/objectTypes/iapSubscription.d.ts +1 -0
  233. package/lib/objectTypes/iapSubscription.d.ts.map +1 -0
  234. package/lib/objectTypes/iapSubscription.js +18 -2
  235. package/lib/objectTypes/image.d.ts +1 -0
  236. package/lib/objectTypes/image.d.ts.map +1 -0
  237. package/lib/objectTypes/image.js +105 -2
  238. package/lib/objectTypes/index.d.ts +1 -0
  239. package/lib/objectTypes/index.d.ts.map +1 -0
  240. package/lib/objectTypes/index.js +28 -2
  241. package/lib/objectTypes/location.d.ts +1 -0
  242. package/lib/objectTypes/location.d.ts.map +1 -0
  243. package/lib/objectTypes/location.js +85 -2
  244. package/lib/objectTypes/message.d.ts +1 -0
  245. package/lib/objectTypes/message.d.ts.map +1 -0
  246. package/lib/objectTypes/message.js +72 -2
  247. package/lib/objectTypes/passcode.d.ts +1 -0
  248. package/lib/objectTypes/passcode.d.ts.map +1 -0
  249. package/lib/objectTypes/passcode.js +20 -2
  250. package/lib/objectTypes/plan.d.ts +1 -0
  251. package/lib/objectTypes/plan.d.ts.map +1 -0
  252. package/lib/objectTypes/plan.js +71 -2
  253. package/lib/objectTypes/post.d.ts +1 -0
  254. package/lib/objectTypes/post.d.ts.map +1 -0
  255. package/lib/objectTypes/post.js +101 -2
  256. package/lib/objectTypes/profile.d.ts +1 -0
  257. package/lib/objectTypes/profile.d.ts.map +1 -0
  258. package/lib/objectTypes/profile.js +68 -2
  259. package/lib/objectTypes/reaction.d.ts +1 -0
  260. package/lib/objectTypes/reaction.d.ts.map +1 -0
  261. package/lib/objectTypes/reaction.js +37 -2
  262. package/lib/objectTypes/relation.d.ts +1 -0
  263. package/lib/objectTypes/relation.d.ts.map +1 -0
  264. package/lib/objectTypes/relation.js +27 -2
  265. package/lib/objectTypes/search.d.ts +1 -0
  266. package/lib/objectTypes/search.d.ts.map +1 -0
  267. package/lib/objectTypes/search.js +50 -2
  268. package/lib/objectTypes/statistics.d.ts +1 -0
  269. package/lib/objectTypes/statistics.d.ts.map +1 -0
  270. package/lib/objectTypes/statistics.js +17 -2
  271. package/lib/objectTypes/subscription.d.ts +1 -0
  272. package/lib/objectTypes/subscription.d.ts.map +1 -0
  273. package/lib/objectTypes/subscription.js +102 -2
  274. package/lib/objectTypes/tag.d.ts +1 -0
  275. package/lib/objectTypes/tag.d.ts.map +1 -0
  276. package/lib/objectTypes/tag.js +41 -2
  277. package/lib/objectTypes/user.d.ts +1 -0
  278. package/lib/objectTypes/user.d.ts.map +1 -0
  279. package/lib/objectTypes/user.js +111 -2
  280. package/lib/queries/content.d.ts +1 -0
  281. package/lib/queries/content.d.ts.map +1 -0
  282. package/lib/queries/content.js +50 -2
  283. package/lib/queries/index.d.ts +1 -0
  284. package/lib/queries/index.d.ts.map +1 -0
  285. package/lib/queries/index.js +27 -2
  286. package/lib/queries/locations.d.ts +1 -0
  287. package/lib/queries/locations.d.ts.map +1 -0
  288. package/lib/queries/locations.js +23 -2
  289. package/lib/queries/messages.d.ts +1 -0
  290. package/lib/queries/messages.d.ts.map +1 -0
  291. package/lib/queries/messages.js +35 -2
  292. package/lib/queries/posts.d.ts +1 -0
  293. package/lib/queries/posts.d.ts.map +1 -0
  294. package/lib/queries/posts.js +154 -2
  295. package/lib/queries/reactions.d.ts +1 -0
  296. package/lib/queries/reactions.d.ts.map +1 -0
  297. package/lib/queries/reactions.js +34 -2
  298. package/lib/queries/statistics.d.ts +1 -0
  299. package/lib/queries/statistics.d.ts.map +1 -0
  300. package/lib/queries/statistics.js +17 -2
  301. package/lib/queries/subscriptions.d.ts +1 -0
  302. package/lib/queries/subscriptions.d.ts.map +1 -0
  303. package/lib/queries/subscriptions.js +21 -2
  304. package/lib/queries/tags.d.ts +1 -0
  305. package/lib/queries/tags.d.ts.map +1 -0
  306. package/lib/queries/tags.js +56 -2
  307. package/lib/queries/users.d.ts +1 -0
  308. package/lib/queries/users.d.ts.map +1 -0
  309. package/lib/queries/users.js +39 -2
  310. package/lib/templates/email/layout.d.ts +1 -0
  311. package/lib/templates/email/layout.d.ts.map +1 -0
  312. package/lib/templates/email/layout.js +4 -3
  313. package/lib/templates/email/passwordForgot.d.ts +1 -0
  314. package/lib/templates/email/passwordForgot.d.ts.map +1 -0
  315. package/lib/templates/email/passwordForgot.js +4 -3
  316. package/lib/templates/email/passwordRecovery.d.ts +1 -0
  317. package/lib/templates/email/passwordRecovery.d.ts.map +1 -0
  318. package/lib/templates/email/passwordRecovery.js +4 -3
  319. package/lib/templates/email/verifyEmail.d.ts +1 -0
  320. package/lib/templates/email/verifyEmail.d.ts.map +1 -0
  321. package/lib/templates/email/verifyEmail.js +4 -3
  322. package/lib/templates/email/welcome.d.ts +1 -0
  323. package/lib/templates/email/welcome.d.ts.map +1 -0
  324. package/lib/templates/email/welcome.js +4 -3
  325. package/lib/templates/sms/passwordForgot.d.ts +1 -0
  326. package/lib/templates/sms/passwordForgot.d.ts.map +1 -0
  327. package/lib/templates/sms/passwordForgot.js +3 -2
  328. package/lib/templates/sms/passwordRecovery.d.ts +1 -0
  329. package/lib/templates/sms/passwordRecovery.d.ts.map +1 -0
  330. package/lib/templates/sms/passwordRecovery.js +3 -2
  331. package/lib/templates/sms/verifyEmail.d.ts +1 -0
  332. package/lib/templates/sms/verifyEmail.d.ts.map +1 -0
  333. package/lib/templates/sms/verifyEmail.js +3 -2
  334. package/lib/templates/sms/verifyPhone.d.ts +1 -0
  335. package/lib/templates/sms/verifyPhone.d.ts.map +1 -0
  336. package/lib/templates/sms/verifyPhone.js +3 -2
  337. package/lib/templates/sms/welcome.d.ts +1 -0
  338. package/lib/templates/sms/welcome.d.ts.map +1 -0
  339. package/lib/templates/sms/welcome.js +3 -2
  340. package/lib/types/apps.types.d.ts +1 -0
  341. package/lib/types/apps.types.d.ts.map +1 -0
  342. package/lib/types/apps.types.js +10 -2
  343. package/lib/types/arangodb.types.d.ts +2 -1
  344. package/lib/types/arangodb.types.d.ts.map +1 -0
  345. package/lib/types/arangodb.types.js +6 -1
  346. package/lib/types/auth.types.d.ts +1 -0
  347. package/lib/types/auth.types.d.ts.map +1 -0
  348. package/lib/types/auth.types.js +6 -1
  349. package/lib/types/connections.types.d.ts +1 -0
  350. package/lib/types/connections.types.d.ts.map +1 -0
  351. package/lib/types/connections.types.js +6 -1
  352. package/lib/types/content.types.d.ts +1 -0
  353. package/lib/types/content.types.d.ts.map +1 -0
  354. package/lib/types/content.types.js +6 -1
  355. package/lib/types/conversations.types.d.ts +1 -0
  356. package/lib/types/conversations.types.d.ts.map +1 -0
  357. package/lib/types/conversations.types.js +6 -1
  358. package/lib/types/email.types.d.ts +1 -0
  359. package/lib/types/email.types.d.ts.map +1 -0
  360. package/lib/types/email.types.js +6 -1
  361. package/lib/types/error.types.d.ts +1 -0
  362. package/lib/types/error.types.d.ts.map +1 -0
  363. package/lib/types/error.types.js +20 -2
  364. package/lib/types/files.types.d.ts +1 -0
  365. package/lib/types/files.types.d.ts.map +1 -0
  366. package/lib/types/files.types.js +6 -1
  367. package/lib/types/google.types.d.ts +1 -0
  368. package/lib/types/google.types.d.ts.map +1 -0
  369. package/lib/types/google.types.js +6 -1
  370. package/lib/types/groups.types.d.ts +1 -0
  371. package/lib/types/groups.types.d.ts.map +1 -0
  372. package/lib/types/groups.types.js +6 -1
  373. package/lib/types/images.types.d.ts +1 -0
  374. package/lib/types/images.types.d.ts.map +1 -0
  375. package/lib/types/images.types.js +6 -1
  376. package/lib/types/index.d.ts +2 -0
  377. package/lib/types/index.d.ts.map +1 -0
  378. package/lib/types/index.js +28 -2
  379. package/lib/types/locations.types.d.ts +1 -0
  380. package/lib/types/locations.types.d.ts.map +1 -0
  381. package/lib/types/locations.types.js +6 -1
  382. package/lib/types/messages.types.d.ts +1 -0
  383. package/lib/types/messages.types.d.ts.map +1 -0
  384. package/lib/types/messages.types.js +6 -1
  385. package/lib/types/notifications.types.d.ts +1 -0
  386. package/lib/types/notifications.types.d.ts.map +1 -0
  387. package/lib/types/notifications.types.js +6 -1
  388. package/lib/types/payments.types.d.ts +1 -0
  389. package/lib/types/payments.types.d.ts.map +1 -0
  390. package/lib/types/payments.types.js +6 -1
  391. package/lib/types/posts.types.d.ts +1 -0
  392. package/lib/types/posts.types.d.ts.map +1 -0
  393. package/lib/types/posts.types.js +6 -1
  394. package/lib/types/profiles.types.d.ts +1 -0
  395. package/lib/types/profiles.types.d.ts.map +1 -0
  396. package/lib/types/profiles.types.js +3 -1
  397. package/lib/types/statistics.types.d.ts +1 -0
  398. package/lib/types/statistics.types.d.ts.map +1 -0
  399. package/lib/types/statistics.types.js +3 -1
  400. package/lib/types/tags.types.d.ts +1 -0
  401. package/lib/types/tags.types.d.ts.map +1 -0
  402. package/lib/types/tags.types.js +6 -1
  403. package/lib/types/users.types.d.ts +1 -0
  404. package/lib/types/users.types.d.ts.map +1 -0
  405. package/lib/types/users.types.js +6 -1
  406. package/lib/types/videos.types.d.ts +47 -0
  407. package/lib/types/videos.types.d.ts.map +1 -0
  408. package/lib/types/videos.types.js +6 -0
  409. package/lib/types/websockets.types.d.ts +1 -0
  410. package/lib/types/websockets.types.d.ts.map +1 -0
  411. package/lib/types/websockets.types.js +6 -1
  412. package/lib/utils/adapterUtils.d.ts +1 -0
  413. package/lib/utils/adapterUtils.d.ts.map +1 -0
  414. package/lib/utils/adapterUtils.js +23 -2
  415. package/lib/utils/analyticsUtils.d.ts +1 -0
  416. package/lib/utils/analyticsUtils.d.ts.map +1 -0
  417. package/lib/utils/analyticsUtils.js +45 -2
  418. package/lib/utils/arangodbUtils.d.ts +1 -0
  419. package/lib/utils/arangodbUtils.d.ts.map +1 -0
  420. package/lib/utils/arangodbUtils.js +128 -5
  421. package/lib/utils/authUtils.d.ts +1 -0
  422. package/lib/utils/authUtils.d.ts.map +1 -0
  423. package/lib/utils/authUtils.js +54 -2
  424. package/lib/utils/contextUtils.d.ts +1 -0
  425. package/lib/utils/contextUtils.d.ts.map +1 -0
  426. package/lib/utils/contextUtils.js +10 -2
  427. package/lib/utils/dbI18n.d.ts +1 -0
  428. package/lib/utils/dbI18n.d.ts.map +1 -0
  429. package/lib/utils/dbI18n.example.d.ts +1 -0
  430. package/lib/utils/dbI18n.example.d.ts.map +1 -0
  431. package/lib/utils/dbI18n.example.js +92 -5
  432. package/lib/utils/dbI18n.js +28 -2
  433. package/lib/utils/googleTranslate.d.ts +1 -0
  434. package/lib/utils/googleTranslate.d.ts.map +1 -0
  435. package/lib/utils/googleTranslate.js +70 -2
  436. package/lib/utils/graphqlUtils.d.ts +1 -0
  437. package/lib/utils/graphqlUtils.d.ts.map +1 -0
  438. package/lib/utils/graphqlUtils.js +11 -2
  439. package/lib/utils/index.d.ts +1 -0
  440. package/lib/utils/index.d.ts.map +1 -0
  441. package/lib/utils/index.js +19 -2
  442. package/lib/utils/languageDetection.d.ts +1 -0
  443. package/lib/utils/languageDetection.d.ts.map +1 -0
  444. package/lib/utils/languageDetection.js +120 -2
  445. package/lib/utils/localeUtils.d.ts +1 -0
  446. package/lib/utils/localeUtils.d.ts.map +1 -0
  447. package/lib/utils/localeUtils.example.d.ts +1 -0
  448. package/lib/utils/localeUtils.example.d.ts.map +1 -0
  449. package/lib/utils/localeUtils.example.js +124 -2
  450. package/lib/utils/localeUtils.js +71 -2
  451. package/lib/utils/middlewareUtils.d.ts +1 -0
  452. package/lib/utils/middlewareUtils.d.ts.map +1 -0
  453. package/lib/utils/middlewareUtils.js +10 -2
  454. package/lib/utils/sessionUtils.d.ts +1 -0
  455. package/lib/utils/sessionUtils.d.ts.map +1 -0
  456. package/lib/utils/sessionUtils.js +26 -2
  457. package/lib/utils/stripeUtils.d.ts +2 -1
  458. package/lib/utils/stripeUtils.d.ts.map +1 -0
  459. package/lib/utils/stripeUtils.js +12 -2
  460. package/lib/utils/templateUtils.d.ts +1 -0
  461. package/lib/utils/templateUtils.d.ts.map +1 -0
  462. package/lib/utils/templateUtils.js +11 -2
  463. package/lib/utils/testUtils.d.ts +1 -0
  464. package/lib/utils/testUtils.d.ts.map +1 -0
  465. package/lib/utils/testUtils.js +292 -2
  466. package/lib/utils/translationQueue.d.ts +1 -0
  467. package/lib/utils/translationQueue.d.ts.map +1 -0
  468. package/lib/utils/translationQueue.example.d.ts +1 -0
  469. package/lib/utils/translationQueue.example.d.ts.map +1 -0
  470. package/lib/utils/translationQueue.example.js +340 -2
  471. package/lib/utils/translationQueue.js +113 -2
  472. package/package.json +47 -29
@@ -1,112 +1,386 @@
1
- import{parseNum as L}from"@nlabs/utils/parsers/numbers";import{createHash as v,parseArangoId as S,parseChar as _,parseId as D,parseString as q,parseVarChar as x}from"@nlabs/utils/parsers/strings";import{aql as A}from"arangojs";import{parsePost as H}from"../adapters/postAdapter.js";import{ErrorTypes as m}from"../types/error.types.js";import{logError as f,logException as w}from"../utils/analyticsUtils.js";import{getLimit as V,useDb as E}from"../utils/arangodbUtils.js";import{extractTags as B,getTagsByName as U,updateTagsInItem as Q}from"./tags.js";const W=1e5,O="posts",$=(t={})=>{const{from:r=0,latitude:e=0,longitude:o=0,to:i=30,type:n="post"}=t;return{latitude:L(e,32),limit:V(r,i),longitude:L(o,32),type:_(n,32)}},C=(t=[],r="")=>(t||[]).reduce((e,o)=>{switch(o){case"hasRsvp":return e.queries.push(`LET hasRsvp = TO_BOOL(FIRST(
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(
2
28
  FOR post, r IN INBOUND p._id hasReaction
3
- FILTER r.name == "rsvp" && r.type == "posts" && r._from == "users/${r}"
29
+ FILTER r.name == "rsvp" && r.type == "posts" && r._from == "users/${sessionId}"
4
30
  COLLECT WITH COUNT INTO count
5
31
  RETURN count
6
- ))`),e.objects.push("hasRsvp:hasRsvp"),e;case"isSaved":return e.queries.push(`LET isSaved = TO_BOOL(FIRST(
32
+ ))`);
33
+ selects.objects.push('hasRsvp:hasRsvp');
34
+ return selects;
35
+ }
36
+ case 'isSaved':
37
+ {
38
+ selects.queries.push(`LET isSaved = TO_BOOL(FIRST(
7
39
  FOR post, r IN INBOUND p._id hasReaction
8
- FILTER r.name == "pin" && r.type == "posts" && r._from == "users/${r}"
40
+ FILTER r.name == "pin" && r.type == "posts" && r._from == "users/${sessionId}"
9
41
  COLLECT WITH COUNT INTO count
10
42
  RETURN count
11
- ))`),e.objects.push("isSaved:isSaved"),e;case"reactions":return e.queries.push(`LET reactions = (
43
+ ))`);
44
+ selects.objects.push('isSaved:isSaved');
45
+ return selects;
46
+ }
47
+ case 'reactions':
48
+ {
49
+ selects.queries.push(`LET reactions = (
12
50
  FOR post, r IN INBOUND p._id hasReaction
13
51
  COLLECT reactionName = r.value INTO reactionItems
14
52
  RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}
15
- )`),e.objects.push("reactions:reactions"),e;case"rsvpCount":return e.queries.push(`LET rsvpCount = FIRST(
53
+ )`);
54
+ selects.objects.push('reactions:reactions');
55
+ return selects;
56
+ }
57
+ case 'rsvpCount':
58
+ {
59
+ selects.queries.push(`LET rsvpCount = FIRST(
16
60
  FOR post, r IN INBOUND p._id hasReaction
17
61
  FILTER r.name == "rsvp" && r.type == "posts"
18
62
  COLLECT WITH COUNT INTO count
19
63
  RETURN count
20
- )`),e.objects.push("rsvpCount:rsvpCount"),e;case"viewCount":return e.queries.push(`LET viewCount = FIRST(
64
+ )`);
65
+ selects.objects.push('rsvpCount:rsvpCount');
66
+ return selects;
67
+ }
68
+ case 'viewCount':
69
+ {
70
+ selects.queries.push(`LET viewCount = FIRST(
21
71
  FOR post, r IN INBOUND p._id hasReaction
22
72
  FILTER r.name == "view" && r.type == "posts"
23
73
  COLLECT WITH COUNT INTO count
24
74
  RETURN count
25
- )`),e.objects.push("viewCount:viewCount"),e;default:return e}},{objects:[],queries:[]}),st=async(t,r,e)=>{const o="getPost",{databaseName:i,fields:n,session:{userId:p}={}}=t,R=D(r),{type:c}=$(e),s=E(i),{objects:a,queries:u}=C(n,p),d=A`FOR p IN posts
26
- FILTER p._key == ${R} && p.type == ${c}
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}
27
97
  LIMIT 1
28
- RETURN p`;return s.query(d).then(I=>I.next()).then(I=>{const{_id:g,userId:T,groupId:h,privacy:N="default"}=I;let y;return T===p?I:(h&&N==="group"?y=`LET p = DOCUMENT("${g}")
29
- ${u.join(`
30
- `)}
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')}
31
108
  FOR group IN groups
32
109
  FILTER group._key == p.groupId
33
110
  FOR u, e IN OUTBOUND group._id hasConnection
34
- FILTER u._key == "${p}"
111
+ FILTER u._key == "${sessionId}"
35
112
  LIMIT 1
36
- RETURN MERGE(p, {${a.join(", ")}})`:N==="public"&&(y=`LET p = DOCUMENT("${g}")
37
- ${u.join(`
38
- `)}
113
+ RETURN MERGE(p, {${selectObjects.join(', ')}})`;
114
+ } else if (privacy === 'public') {
115
+ privacyAqlQry = `LET p = DOCUMENT("${postDocId}")
116
+ ${selectQueries.join('\n')}
39
117
  LIMIT 1
40
- RETURN MERGE(p, {${a.join(", ")}})`),y?s.query(y).then(l=>l.next()).catch(l=>f({action:o,category:O,label:m.DATABASE_ERROR},l,t)):{})}).catch(I=>f({action:o,category:O,label:m.DATABASE_ERROR},I,t))},ot=(t,r,e,o)=>{const i="getPostsByArea",{databaseName:n,fields:p,session:{userId:R}={}}=t,{limit:c,type:s}=$(o),a=L(r),u=L(e),{objects:d,queries:I}=C(p,R);I.push(`LET distance = DISTANCE(
41
- ${a},
42
- ${u},
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},
43
161
  NOT_NULL(p.latitude, 0),
44
162
  NOT_NULL(p.longitude, 0))
45
- `),d.push("distance:distance");const g=`FOR p IN posts
46
- ${I.join(`
47
- `)}
48
- FILTER p.type == "${s}" && p.privacy == "public" && p.parentId == null
49
- ${c.aql}
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}
50
169
  SORT distance, p.added
51
- RETURN DISTINCT MERGE(p, {${d.join(", ")}})`;return E(n).query(g).then(T=>T.all()).catch(T=>(f({action:i,category:O,label:m.DATABASE_ERROR},T,t),[]))},rt=(t,r)=>{const{databaseName:e,fields:o,session:{userId:i}={}}=t,{limit:n,type:p}=$(r),{objects:R,queries:c}=C(o,i),s=`FOR p IN posts
52
- FILTER p.type == "${p}" && p.privacy == "public" && p.parent == null
53
- ${c.join(`
54
- `)}
55
- ${n.aql}
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}
56
226
  SORT p.added DESC
57
- RETURN DISTINCT MERGE(p, {${R.join(", ")}})`;return E(e).query(s).then(a=>a.all()).catch(a=>{throw a})},nt=(t,r=[],e)=>{const o="getPostsByReactions",{databaseName:i,fields:n,session:{userId:p}={}}=t,{latitude:R,limit:c,longitude:s,type:a}=$(e),{objects:u,queries:d}=C(n,p),I=`users/${p}`,g=JSON.stringify(r.map(P=>_(P,32).toLowerCase())),T=[],h=[`p.type == "${a}"`,'p.privacy == "public"'],N=L(R),y=L(s);N&&y&&(d.push(`LET distance = DISTANCE(
58
- ${N},
59
- ${y},
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},
60
250
  NOT_NULL(p.latitude, 0),
61
251
  NOT_NULL(p.longitude, 0))
62
- `),u.push("distance:distance"),T.push("distance")),r.length&&(T.push("matchedTags DESC"),d.push(`LET matchedReactions = LENGTH(
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(
63
259
  FOR mr IN reactions
64
260
  FILTER mr.matched == true
65
261
  RETURN mr
66
- )`),u.push("matchedReactions:matchedReactions"),h.push("matchedReactions > 0")),T.push("p.added DESC"),u.push("reactions:reactions");const l=`FOR p, r IN OUTBOUND "${I}" hasReaction
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
67
270
  LET reactions = (
68
271
  FOR reaction, hr IN 1..1 INBOUND p isTagged
69
- LET matched = LENGTH(${g}) > 0 && POSITION(${g}, reaction.name)
272
+ LET matched = LENGTH(${formatReactions}) > 0 && POSITION(${formatReactions}, reaction.name)
70
273
  SORT reaction.name
71
274
  RETURN MERGE(reaction, {matched:matched})
72
275
  )
73
- ${d.join(`
74
- `)}
75
- FILTER ${h.join(" && ")}
76
- ${c.aql}
77
- RETURN DISTINCT MERGE(p, {${u.join(", ")}})`;return E(i).query(l).then(P=>P.all()).catch(P=>(f({action:o,category:O,label:m.DATABASE_ERROR},P,t),[]))},at=(t,r=[],e)=>{const o="getPostsByTags",{databaseName:i,fields:n,session:{userId:p}={}}=t,{latitude:R,limit:c,longitude:s,type:a}=$(e),{objects:u,queries:d}=C(n,p),I=JSON.stringify(r.map(l=>_(l,32).toLowerCase())),g=[],T=[`p.type == "${a}"`,'p.privacy == "public"'],h=L(R),N=L(s);h&&N&&(d.push(`LET distance = DISTANCE(
78
- ${h},
79
- ${N},
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},
80
306
  NOT_NULL(p.latitude, 0),
81
307
  NOT_NULL(p.longitude, 0))
82
- `),u.push("distance:distance"),g.push("distance")),r.length&&(g.push("matchedTags DESC"),d.push(`LET matchedTags = LENGTH(
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(
83
315
  FOR t IN tags
84
316
  FILTER t.matched == true
85
317
  RETURN t
86
- )`),u.push("matchedTags:matchedTags"),T.push("matchedTags > 0")),g.push("p.added DESC"),u.push("tags:tags");const y=`FOR p IN posts
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
87
325
  LET tags = (
88
326
  FOR tag, it IN 1..1 INBOUND p isTagged
89
- LET matched = LENGTH(${I}) > 0 && POSITION(${I}, tag.name)
327
+ LET matched = LENGTH(${formatTagNames}) > 0 && POSITION(${formatTagNames}, tag.name)
90
328
  SORT tag.name
91
329
  RETURN MERGE(tag, {matched:matched})
92
330
  )
93
- ${d.join(`
94
- `)}
95
- FILTER ${T.join(" && ")}
96
- ${c.aql}
97
- SORT ${g.join(", ")}
98
- RETURN DISTINCT MERGE(p, {${u.join(", ")}})`;return E(i).query(y).then(l=>l.all()).catch(l=>(f({action:o,category:O,label:m.DATABASE_ERROR},l,t),[]))},it=(t,r,e)=>{const o="getPostsByUser",{databaseName:i,fields:n,session:{userId:p}={}}=t,{limit:R,type:c}=$(e),s=D(r),{objects:a,queries:u}=C(n,p),d=`FOR p IN posts
99
- FILTER p.userId == "${s}" && p.type == "${c}" && p.privacy == "public" && p.parent == null
100
- ${u.join(`
101
- `)}
102
- ${R.aql}
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}
103
355
  SORT p.added
104
- RETURN DISTINCT MERGE(p, {${a.join(", ")}})`;return E(i).query(d).then(I=>I.all()).catch(I=>(f({action:o,category:O,label:m.DATABASE_ERROR},I,t),[]))},pt=(t,r,e)=>{const o="getPostComments",{databaseName:i,session:{userId:n}={}}=t,{limit:p,type:R}=$(e),c=D(r),s=A`FOR p IN posts
105
- FILTER p.type == ${R} && p._key == ${c}
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}
106
374
  LIMIT 1
107
- RETURN p`;return E(i).query(s).then(a=>a.next()).then(a=>{const{_key:u,groupId:d,privacy:I="default"}=a;let g;return d&&I==="group"?g=`FOR p IN posts
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
108
382
  FOR user IN users
109
- FILTER p.parent == "${u}" && user._key == p.userId
383
+ FILTER p.parent == "${_key}" && user._key == p.userId
110
384
  LET reactions = (
111
385
  FOR post, r IN INBOUND p._id reactions
112
386
  COLLECT reactionName = r.value INTO reactionItems
@@ -115,29 +389,220 @@ import{parseNum as L}from"@nlabs/utils/parsers/numbers";import{createHash as v,p
115
389
  FOR group IN groups
116
390
  FILTER group._key == p.groupId
117
391
  FOR u, e IN OUTBOUND group._id hasConnection
118
- FILTER u._key == "${n}"
392
+ FILTER u._key == "${sessionId}"
119
393
  SORT p.added
120
- ${p.aql}
121
- RETURN MERGE(p, {user: user, reactions: reactions})`:I==="public"&&(g=`FOR p IN posts
394
+ ${limit.aql}
395
+ RETURN MERGE(p, {user: user, reactions: reactions})`;
396
+ } else if (privacy === 'public') {
397
+ privacyAqlQry = `FOR p IN posts
122
398
  FOR user IN users
123
- FILTER p.parent == "${u}" && user._key == p.userId
399
+ FILTER p.parent == "${_key}" && user._key == p.userId
124
400
  LET reactions = (
125
401
  FOR post, r IN INBOUND p._id reactions
126
402
  COLLECT reactionName = r.value INTO reactionItems
127
403
  RETURN {name: reactionName, count: LENGTH(reactionItems[*].r.value)}
128
404
  )
129
405
  SORT p.added
130
- ${p.aql}
131
- RETURN MERGE(p, {user: user, reactions: reactions})`),g?E(i).query(g).then(T=>T.all()).catch(T=>(f({action:o,category:O,label:m.DATABASE_ERROR},T,t),[])):[]}).catch(a=>(f({action:o,category:O,label:m.DATABASE_ERROR},a,t),[]))},ct=async(t,{content:r="",endDate:e,groupId:o="",location:i,latitude:n,longitude:p,name:R="",parentId:c="",privacy:s="public",tags:a=[],startDate:u,type:d="default"})=>{const I="addPost",{databaseName:g,session:{userId:T}={}}=t,h=Date.now(),N=v(`post-${T}`),y={_id:`posts/${N}`,_key:N,added:h,content:q(r,W)||"",endDate:e?L(e,13):void 0,groupId:o?D(o):void 0,latitude:n!==void 0?L(n):void 0,location:i?q(i,160):void 0,longitude:p!==void 0?L(p):void 0,modified:h,name:q(R,160),parentId:c?D(c):void 0,privacy:x(s,16),startDate:u?L(u,13):void 0,type:_(d,32),userId:T},l=A`INSERT ${y} IN posts RETURN NEW`;try{const P=await E(g).query(l).then(b=>b.next()).catch(b=>f({action:I,category:O,label:m.DATABASE_ERROR},b,t)),{_id:M}=P,j=await B(y.content||"");if(a.length||j.length){const b=(await U(t,a.map(({name:F})=>F||""))).map(F=>({...F,tagBy:T})),G=(await U(t,j||[])).map(F=>({...F,tagBy:"extract"})),k=await Q(t,{itemDocId:M,tags:[...G,...b]});return{...P,tags:k}}return P}catch(P){throw P}},ut=async(t,r)=>{const e="updatePost",{databaseName:o,session:{userId:i}={}}=t,n=Date.now(),p=H(r),{postId:R,tags:c=[]}=p,s={...p,modified:n};if(!R)throw w({action:e,category:O,value:m.INVALID_ID},t);const a={...s,_key:R,added:n,userId:i},u=A`UPSERT {_key: ${R}, userId: ${i}}
132
- INSERT ${a}
133
- UPDATE ${s}
134
- IN posts RETURN NEW`;try{const d=await E(o).query(u).then(T=>T.next()).catch(T=>f({action:e,category:O,value:m.DATABASE_ERROR},T,{})),{_id:I}=d,g=await B(a.content||"");if(c?.length||g?.length){const T=c?.length?(await U(t,c.map(({name:y})=>y||""))).map(y=>({...y,tagBy:i})):[],h=g?.length?(await U(t,g||[])).map(y=>({...y,tagBy:"extract"})):[],N=await Q(t,{itemDocId:I,tags:[...h,...T]});return{...d,tags:N}}return d}catch(d){throw d}},dt=async(t,r)=>{const e="deletePost",{databaseName:o,session:{userId:i}={}}=t,n=S(r);if(!n)throw w({action:e,category:O,value:m.INVALID_ID},t);const p=A`FOR t IN isTagged
135
- FILTER t._to == ${n}
136
- REMOVE t IN isTagged`;await E(o).query(p).catch(s=>{throw s});const R=A`FOR f IN hasFile
137
- FILTER f._to == ${n}
138
- REMOVE f IN hasFile`;await E(o).query(R).catch(s=>{throw s});const c=A`FOR p IN posts
139
- FILTER p._id == ${n} && p.userId == ${i}
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}
140
573
  LIMIT 1
141
574
  REMOVE p IN posts
142
- RETURN OLD`;return E(o).query(c).then(s=>s.next()).catch(s=>{throw s})},Tt=(t,r,e,o="isPosted",i={})=>{const n="createPostEdge",{databaseName:p}=t,R=E(p).collection(o),c=S(r),s=S(e);if(!s||!c)throw new Error(m.INVALID_ID);const a=v(`postEdge-${c}-${s}`),u={_from:c,_key:a,_to:s,added:Date.now(),...i};return R.save(u,{returnNew:!0}).catch(d=>{throw f({action:n,category:O,value:m.DATABASE_ERROR},d,t)})};export{ct as addPost,Tt as createPostEdge,dt as deletePost,st as getPost,pt as getPostComments,C as getPostOptional,ot as getPostsByArea,rt as getPostsByLatest,nt as getPostsByReactions,at as getPostsByTags,it as getPostsByUser,$ as parsePostOptions,ut as updatePost};
143
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../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"],
  "mappings": "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",
  "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", "getPostOptional", "fields", "sessionId", "selects", "field", "getPost", "context", "postId", "action", "databaseName", "formatItemId", "database", "selectObjects", "selectQueries", "aqlQry", "cursor", "post", "postDocId", "userId", "groupId", "privacy", "privacyAqlQry", "error", "getPostsByArea", "limit", "formatLatitude", "formatLongitude", "getPostsByLatest", "getPostsByReactions", "reactions", "formatSessionId", "formatReactions", "reaction", "sortBy", "filters", "getPostsByTags", "tags", "formatTagNames", "tag", "getPostsByUser", "formatUserId", "getPostComments", "_key", "addPost", "content", "endDate", "location", "name", "parentId", "startDate", "now", "insert", "savedPost", "contentTagNames", "userTags", "contentTags", "updatedTags", "updatePost", "parsedPost", "update", "updatedPost", "updatedPostId", "deletePost", "formatPostId", "edgeAqlQry", "fileAqlQry", "createPostEdge", "itemDocId", "edgeType", "props", "edgeCollection", "formatDocId", "edgeId", "edge"]
}

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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"}