@yrpri/api 9.0.103 → 9.0.104

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 (422) hide show
  1. package/package.json +1 -1
  2. package/dist/active-citizen/controllers/activities.cjs +0 -174
  3. package/dist/active-citizen/controllers/news_feeds.cjs +0 -96
  4. package/dist/active-citizen/controllers/notifications.cjs +0 -243
  5. package/dist/active-citizen/controllers/recommendations.cjs +0 -280
  6. package/dist/active-citizen/engine/allOurIdeas/aiHelper.js +0 -204
  7. package/dist/active-citizen/engine/allOurIdeas/explainAnswersAssistant.js +0 -66
  8. package/dist/active-citizen/engine/allOurIdeas/iconGenerator.js +0 -38
  9. package/dist/active-citizen/engine/analytics/export_anon_community_activities.js +0 -334
  10. package/dist/active-citizen/engine/analytics/importer.js +0 -308
  11. package/dist/active-citizen/engine/analytics/manager.cjs +0 -377
  12. package/dist/active-citizen/engine/analytics/plausible/manager.cjs +0 -500
  13. package/dist/active-citizen/engine/analytics/statsCalc.cjs +0 -194
  14. package/dist/active-citizen/engine/analytics/utils.cjs +0 -369
  15. package/dist/active-citizen/engine/marketing/campaign.cjs +0 -90
  16. package/dist/active-citizen/engine/moderation/fraud/CreateFraudAuditReport.cjs +0 -313
  17. package/dist/active-citizen/engine/moderation/fraud/FraudBase.cjs +0 -239
  18. package/dist/active-citizen/engine/moderation/fraud/FraudDeleteBase.cjs +0 -211
  19. package/dist/active-citizen/engine/moderation/fraud/FraudDeleteEndorsements.cjs +0 -120
  20. package/dist/active-citizen/engine/moderation/fraud/FraudDeletePointQualities.cjs +0 -114
  21. package/dist/active-citizen/engine/moderation/fraud/FraudDeletePoints.cjs +0 -101
  22. package/dist/active-citizen/engine/moderation/fraud/FraudDeletePosts.cjs +0 -84
  23. package/dist/active-citizen/engine/moderation/fraud/FraudDeleteRatings.cjs +0 -15
  24. package/dist/active-citizen/engine/moderation/fraud/FraudGetBase.cjs +0 -133
  25. package/dist/active-citizen/engine/moderation/fraud/FraudGetEndorsements.cjs +0 -185
  26. package/dist/active-citizen/engine/moderation/fraud/FraudGetPointQualities.cjs +0 -184
  27. package/dist/active-citizen/engine/moderation/fraud/FraudGetPoints.cjs +0 -170
  28. package/dist/active-citizen/engine/moderation/fraud/FraudGetPosts.cjs +0 -109
  29. package/dist/active-citizen/engine/moderation/fraud/FraudGetRatings.cjs +0 -140
  30. package/dist/active-citizen/engine/moderation/fraud/FraudScannerNotifier.cjs +0 -279
  31. package/dist/active-citizen/engine/moderation/get_moderation_items.cjs +0 -386
  32. package/dist/active-citizen/engine/moderation/image_labeling/CommunityLabeling.cjs +0 -49
  33. package/dist/active-citizen/engine/moderation/image_labeling/GroupLabeling.cjs +0 -68
  34. package/dist/active-citizen/engine/moderation/image_labeling/ImageLabelingBase.cjs +0 -288
  35. package/dist/active-citizen/engine/moderation/image_labeling/PointLabeling.cjs +0 -33
  36. package/dist/active-citizen/engine/moderation/image_labeling/PostLabeling.cjs +0 -56
  37. package/dist/active-citizen/engine/moderation/perspective_api_client.cjs +0 -106
  38. package/dist/active-citizen/engine/moderation/process_moderation_items.cjs +0 -344
  39. package/dist/active-citizen/engine/moderation/toxicity_analysis.cjs +0 -810
  40. package/dist/active-citizen/engine/news_feeds/activity_and_item_index_definitions.cjs +0 -15
  41. package/dist/active-citizen/engine/news_feeds/generate_dynamically.cjs +0 -362
  42. package/dist/active-citizen/engine/news_feeds/generate_from_notifications.cjs +0 -268
  43. package/dist/active-citizen/engine/news_feeds/news_feeds_utils.cjs +0 -439
  44. package/dist/active-citizen/engine/notifications/emails_utils.cjs +0 -569
  45. package/dist/active-citizen/engine/notifications/generate_point_notifications.cjs +0 -233
  46. package/dist/active-citizen/engine/notifications/generate_post_notifications.cjs +0 -118
  47. package/dist/active-citizen/engine/notifications/generate_post_status_change_notifications.cjs +0 -41
  48. package/dist/active-citizen/engine/notifications/notifications_utils.cjs +0 -148
  49. package/dist/active-citizen/engine/notifications/point_delivery.cjs +0 -54
  50. package/dist/active-citizen/engine/notifications/post_delivery.cjs +0 -31
  51. package/dist/active-citizen/engine/notifications/process_delayed_notifications.cjs +0 -471
  52. package/dist/active-citizen/engine/notifications/process_general_notifications.cjs +0 -212
  53. package/dist/active-citizen/engine/old/exporters/categories_dataset.js +0 -153
  54. package/dist/active-citizen/engine/old/exporters/dataset_tools.js +0 -80
  55. package/dist/active-citizen/engine/old/exporters/sentiment_dataset.js +0 -157
  56. package/dist/active-citizen/engine/recommendations/events_importer.cjs +0 -139
  57. package/dist/active-citizen/engine/recommendations/events_manager.cjs +0 -212
  58. package/dist/active-citizen/engine/reports/add_points_to_sheet.cjs +0 -83
  59. package/dist/active-citizen/engine/reports/commonUtils.js +0 -75
  60. package/dist/active-citizen/engine/reports/common_utils.cjs +0 -740
  61. package/dist/active-citizen/engine/reports/docx_group_report.cjs +0 -596
  62. package/dist/active-citizen/engine/reports/xlsAllOurIdeasExport.js +0 -232
  63. package/dist/active-citizen/engine/reports/xls_community_users_report.cjs +0 -277
  64. package/dist/active-citizen/engine/reports/xls_group_report.cjs +0 -718
  65. package/dist/active-citizen/llms/baseChatBot.js +0 -183
  66. package/dist/active-citizen/llms/imageGeneration/chatGptImageGenerator.js +0 -56
  67. package/dist/active-citizen/llms/imageGeneration/collectionImageGenerator.js +0 -109
  68. package/dist/active-citizen/llms/imageGeneration/dalleImageGenerator.js +0 -84
  69. package/dist/active-citizen/llms/imageGeneration/fluxImageGenerator.js +0 -49
  70. package/dist/active-citizen/llms/imageGeneration/iImageGenerator.js +0 -1
  71. package/dist/active-citizen/llms/imageGeneration/imageProcessorService.js +0 -64
  72. package/dist/active-citizen/llms/imageGeneration/imagenImageGenerator.js +0 -107
  73. package/dist/active-citizen/llms/imageGeneration/s3Service.js +0 -110
  74. package/dist/active-citizen/llms/llmTranslation.js +0 -472
  75. package/dist/active-citizen/models/ac_activity.cjs +0 -216
  76. package/dist/active-citizen/models/ac_background_job.cjs +0 -109
  77. package/dist/active-citizen/models/ac_campaign.cjs +0 -97
  78. package/dist/active-citizen/models/ac_client_activity.cjs +0 -23
  79. package/dist/active-citizen/models/ac_delayed_notification.cjs +0 -43
  80. package/dist/active-citizen/models/ac_following.cjs +0 -43
  81. package/dist/active-citizen/models/ac_list.cjs +0 -68
  82. package/dist/active-citizen/models/ac_list_users.cjs +0 -19
  83. package/dist/active-citizen/models/ac_mute.cjs +0 -27
  84. package/dist/active-citizen/models/ac_news_feed_item.cjs +0 -57
  85. package/dist/active-citizen/models/ac_news_feed_processed_range.cjs +0 -59
  86. package/dist/active-citizen/models/ac_notification.cjs +0 -292
  87. package/dist/active-citizen/models/ac_translation_cache.cjs +0 -750
  88. package/dist/active-citizen/models/ac_watching.cjs +0 -31
  89. package/dist/active-citizen/scripts/analytics/setup_all_plausible_goals.cjs +0 -13
  90. package/dist/active-citizen/scripts/fix_old_delayed_notifications.js +0 -63
  91. package/dist/active-citizen/scripts/kue_status.js +0 -31
  92. package/dist/active-citizen/scripts/kue_watch_stuck_jobs.js +0 -24
  93. package/dist/active-citizen/scripts/translation_clear_language.js +0 -117
  94. package/dist/active-citizen/scripts/translation_delete.js +0 -27
  95. package/dist/active-citizen/scripts/translation_replace_text_from_url.js +0 -180
  96. package/dist/active-citizen/scripts/translation_update.js +0 -28
  97. package/dist/active-citizen/scripts/translations_list.js +0 -27
  98. package/dist/active-citizen/utils/airbrake.cjs +0 -17
  99. package/dist/active-citizen/utils/get_anonymous_system_user.cjs +0 -21
  100. package/dist/active-citizen/utils/i18n.cjs +0 -3
  101. package/dist/active-citizen/utils/logger.cjs +0 -25
  102. package/dist/active-citizen/utils/redisConnection.cjs +0 -29
  103. package/dist/active-citizen/utils/to_json.cjs +0 -9
  104. package/dist/active-citizen/utils/translation_cloning.cjs +0 -171
  105. package/dist/active-citizen/utils/translation_helpers.cjs +0 -534
  106. package/dist/active-citizen/utils/truncate_text.cjs +0 -21
  107. package/dist/active-citizen/utils/updateAllLocalesFromEn.js +0 -253
  108. package/dist/active-citizen/utils/updateLocaleFolders.js +0 -34
  109. package/dist/active-citizen/workers/activity.cjs +0 -189
  110. package/dist/active-citizen/workers/anonymizations.cjs +0 -734
  111. package/dist/active-citizen/workers/bulk_status_update.cjs +0 -458
  112. package/dist/active-citizen/workers/delayed_jobs.cjs +0 -244
  113. package/dist/active-citizen/workers/deletions.cjs +0 -1911
  114. package/dist/active-citizen/workers/email.cjs +0 -9
  115. package/dist/active-citizen/workers/fraud_management.cjs +0 -109
  116. package/dist/active-citizen/workers/generativeAi.js +0 -56
  117. package/dist/active-citizen/workers/main.cjs +0 -89
  118. package/dist/active-citizen/workers/marketing.cjs +0 -25
  119. package/dist/active-citizen/workers/moderation.cjs +0 -73
  120. package/dist/active-citizen/workers/notification_delivery.cjs +0 -368
  121. package/dist/active-citizen/workers/notification_news_feed.cjs +0 -142
  122. package/dist/active-citizen/workers/queue.cjs +0 -99
  123. package/dist/active-citizen/workers/recount.cjs +0 -74
  124. package/dist/active-citizen/workers/reports.cjs +0 -42
  125. package/dist/active-citizen/workers/similarities.cjs +0 -21
  126. package/dist/active-citizen/workers/speech_to_text.cjs +0 -482
  127. package/dist/agents/assistants/agentAssistant.js +0 -88
  128. package/dist/agents/assistants/baseAssistant.js +0 -888
  129. package/dist/agents/assistants/baseAssistantWithVoice.js +0 -150
  130. package/dist/agents/assistants/modes/agentDirectConnection.js +0 -84
  131. package/dist/agents/assistants/modes/agentSelectionMode.js +0 -44
  132. package/dist/agents/assistants/modes/baseAssistantMode.js +0 -54
  133. package/dist/agents/assistants/modes/tools/agentTools.js +0 -447
  134. package/dist/agents/assistants/modes/tools/baseTools.js +0 -58
  135. package/dist/agents/assistants/modes/tools/loginTools.js +0 -156
  136. package/dist/agents/assistants/modes/tools/models/agents.js +0 -146
  137. package/dist/agents/assistants/modes/tools/models/subscriptions.js +0 -332
  138. package/dist/agents/assistants/modes/tools/models/users.js +0 -11
  139. package/dist/agents/assistants/modes/tools/navigationTools.js +0 -166
  140. package/dist/agents/assistants/modes/tools/subscriptionTools.js +0 -323
  141. package/dist/agents/assistants/modes/tools/workflowConverstationTools.js +0 -112
  142. package/dist/agents/assistants/voiceAssistant.js +0 -619
  143. package/dist/agents/controllers/agentProductController.js +0 -103
  144. package/dist/agents/controllers/agentSubscriptionController.js +0 -261
  145. package/dist/agents/controllers/assistantsController.js +0 -511
  146. package/dist/agents/controllers/policySynthAgents.js +0 -395
  147. package/dist/agents/managers/agentProductManager.js +0 -91
  148. package/dist/agents/managers/emailInvitesManager.js +0 -55
  149. package/dist/agents/managers/emailTemplateRenderer.js +0 -362
  150. package/dist/agents/managers/newAiModelSetup.js +0 -650
  151. package/dist/agents/managers/notificationAgentQueueManager.js +0 -510
  152. package/dist/agents/managers/subscriptionManager.js +0 -535
  153. package/dist/agents/managers/workflowConversationManager.js +0 -79
  154. package/dist/agents/models/agentProduct.js +0 -116
  155. package/dist/agents/models/agentProductBoosterPurchase.js +0 -58
  156. package/dist/agents/models/agentProductBundle.js +0 -68
  157. package/dist/agents/models/agentProductRun.js +0 -52
  158. package/dist/agents/models/discount.js +0 -88
  159. package/dist/agents/models/subscription.js +0 -79
  160. package/dist/agents/models/subscriptionPlan.js +0 -46
  161. package/dist/agents/models/subscriptionUser.js +0 -27
  162. package/dist/agents/models/testData/createEvolyAgentProduct.js +0 -477
  163. package/dist/agents/models/testData/old/updateAgentWorkflowConfiguration.js +0 -230
  164. package/dist/agents/models/testData/setupEvolyAgentProductConfig.js +0 -233
  165. package/dist/agents/models/testData/updateAgentWorkflowConfiguration.js +0 -230
  166. package/dist/agents/models/workflowConversation.js +0 -53
  167. package/dist/agents/tools/setTemplateWorkflowCommunityId.js +0 -46
  168. package/dist/app.js +0 -943
  169. package/dist/authorization.cjs +0 -1860
  170. package/dist/bot_control.js +0 -1930
  171. package/dist/config/config.cjs +0 -14
  172. package/dist/config/config.js +0 -14
  173. package/dist/controllers/allOurIdeas.js +0 -696
  174. package/dist/controllers/audios.cjs +0 -100
  175. package/dist/controllers/bulkStatusUpdates.cjs +0 -202
  176. package/dist/controllers/categories.cjs +0 -199
  177. package/dist/controllers/communities.cjs +0 -2996
  178. package/dist/controllers/domains.cjs +0 -1341
  179. package/dist/controllers/externalIds.cjs +0 -223
  180. package/dist/controllers/groups.cjs +0 -4309
  181. package/dist/controllers/images.cjs +0 -499
  182. package/dist/controllers/index.cjs +0 -449
  183. package/dist/controllers/legacyPages.cjs +0 -35
  184. package/dist/controllers/legacyPosts.cjs +0 -56
  185. package/dist/controllers/legacyUsers.cjs +0 -36
  186. package/dist/controllers/nonSpa.cjs +0 -574
  187. package/dist/controllers/organizations.cjs +0 -250
  188. package/dist/controllers/points.cjs +0 -1137
  189. package/dist/controllers/posts.cjs +0 -2036
  190. package/dist/controllers/ratings.cjs +0 -234
  191. package/dist/controllers/users.cjs +0 -2255
  192. package/dist/controllers/videos.cjs +0 -226
  193. package/dist/deleteUnwantedDeclerations.cjs +0 -55
  194. package/dist/migrations/agentAuditLogs.cjs +0 -46
  195. package/dist/migrations/agentClasses.cjs +0 -60
  196. package/dist/migrations/agentConnectorClasses.cjs +0 -61
  197. package/dist/migrations/agentConnectors.cjs +0 -50
  198. package/dist/migrations/agentEvals.cjs +0 -45
  199. package/dist/migrations/agentRegistries.cjs +0 -40
  200. package/dist/migrations/agents.cjs +0 -54
  201. package/dist/migrations/aiModels.cjs +0 -49
  202. package/dist/migrations/apiUsage.cjs +0 -47
  203. package/dist/migrations/apis.cjs +0 -49
  204. package/dist/migrations/groupPrivateData.cjs +0 -30
  205. package/dist/migrations/modelUsage.cjs +0 -60
  206. package/dist/migrations/oldMigrations/2019/20181030020612-AddActivitiesIndex.js +0 -23
  207. package/dist/migrations/oldMigrations/2019/20181102210612-AddFirstVideoFeatures.js +0 -360
  208. package/dist/migrations/oldMigrations/2019/20181212210612-ModerationFeatures.js +0 -29
  209. package/dist/migrations/oldMigrations/2019/2019010610612-CommunityFolders.js +0 -43
  210. package/dist/migrations/oldMigrations/2019/20190117020612-AddMissingIndexes.js +0 -24
  211. package/dist/migrations/oldMigrations/2019/20190117020612-RemoveUnusedIndexes.js +0 -29
  212. package/dist/migrations/oldMigrations/2019/20190127020612-RemoveUnusedIndexesPartThree.js +0 -22
  213. package/dist/migrations/oldMigrations/2019/20190127020612-RemoveUnusedIndexesPartTwo.js +0 -23
  214. package/dist/migrations/oldMigrations/2019/20190223020612-AddPrivateProfileDataToUsers.js +0 -18
  215. package/dist/migrations/oldMigrations/2019/20190706210612-AddCustomRatings.js +0 -43
  216. package/dist/migrations/oldMigrations/2019/20190829210612-AddGeneralStore.js +0 -36
  217. package/dist/migrations/oldMigrations/2019/20192811210612-AddAcClientActivities.js +0 -41
  218. package/dist/migrations/oldMigrations/2020/20190527020612-WorkOnIndexes.js +0 -88
  219. package/dist/migrations/oldMigrations/2020/20200409020612-AddBackgroundJob.js +0 -33
  220. package/dist/migrations/oldMigrations/2020/20200716210612-AddDataToCollections.js +0 -38
  221. package/dist/migrations/oldMigrations/2022/20220215100612-AddDataToEndorsements.js +0 -19
  222. package/dist/migrations/oldMigrations/2022/20220220100612-AddDataForFraudDetection.js +0 -19
  223. package/dist/migrations/oldMigrations/2022/20220903100612-AddPromotionFeatures.js +0 -127
  224. package/dist/migrations/oldMigrations/2022/onHold/20200527020612-AddCampaigns.js +0 -68
  225. package/dist/migrations/oldMigrations/2024/20241304175112-AddMediaSupportForHtmlGroups.cjs +0 -63
  226. package/dist/migrations/oldMigrations/older/20160511172514-AddNotificationFeatures.js +0 -14
  227. package/dist/migrations/oldMigrations/older/20161030020612-AddBulkStatusUpdate.js +0 -71
  228. package/dist/migrations/oldMigrations/older/20170514035258-add-metadata-to-invites.js +0 -12
  229. package/dist/migrations/oldMigrations/older/20180216020612-AddTranslationCaches.js +0 -46
  230. package/dist/migrations/oldMigrations/older/20180218210612-AddTranslationAndLanguages.js +0 -46
  231. package/dist/migrations/privateAccessStore.cjs +0 -55
  232. package/dist/migrations/zzz_associations.cjs +0 -154
  233. package/dist/migrations/zzzz_createUsersAndAdminsForClasses.cjs +0 -100
  234. package/dist/migrations/zzzzz_create_agent_runs.cjs +0 -606
  235. package/dist/migrations/zzzzzz_create_agent_runs_fix.cjs +0 -11
  236. package/dist/migrations/zzzzzzz_create_trees.cjs +0 -81
  237. package/dist/models/audio.cjs +0 -430
  238. package/dist/models/bulk_status_update.cjs +0 -58
  239. package/dist/models/campaign.cjs +0 -78
  240. package/dist/models/category.cjs +0 -94
  241. package/dist/models/community.cjs +0 -337
  242. package/dist/models/domain.cjs +0 -486
  243. package/dist/models/endorsement.cjs +0 -39
  244. package/dist/models/general_data_store.cjs +0 -20
  245. package/dist/models/group.cjs +0 -728
  246. package/dist/models/image.cjs +0 -579
  247. package/dist/models/index.cjs +0 -186
  248. package/dist/models/invite.cjs +0 -48
  249. package/dist/models/iso_country.cjs +0 -16
  250. package/dist/models/organization.cjs +0 -122
  251. package/dist/models/page.cjs +0 -273
  252. package/dist/models/point.cjs +0 -622
  253. package/dist/models/point_quality.cjs +0 -39
  254. package/dist/models/point_revision.cjs +0 -47
  255. package/dist/models/post.cjs +0 -680
  256. package/dist/models/post_revision.cjs +0 -38
  257. package/dist/models/post_status_change.cjs +0 -35
  258. package/dist/models/promotion.cjs +0 -34
  259. package/dist/models/rating.cjs +0 -51
  260. package/dist/models/relationship.cjs +0 -19
  261. package/dist/models/request_to_join.cjs +0 -20
  262. package/dist/models/user.cjs +0 -604
  263. package/dist/models/user_legacy_password.cjs +0 -13
  264. package/dist/models/video.cjs +0 -1137
  265. package/dist/publish.js +0 -40
  266. package/dist/repack.js +0 -53
  267. package/dist/scripts/addRatingUsersToGroup.js +0 -51
  268. package/dist/scripts/addUserToOrganization.js +0 -71
  269. package/dist/scripts/analyseRatingsForCommunity.js +0 -150
  270. package/dist/scripts/analyzeAndFixBrokenPointUsers.js +0 -28
  271. package/dist/scripts/analyzeEndorsementsByCountry.js +0 -70
  272. package/dist/scripts/analyzePostsForCommunity.js +0 -185
  273. package/dist/scripts/bulkStatusUpdates/listUpdates.js +0 -14
  274. package/dist/scripts/bulkStatusUpdates/mergeLatestPostsToUpdate.js +0 -110
  275. package/dist/scripts/bulkStatusUpdates/performUpdate.js +0 -116
  276. package/dist/scripts/bulkStatusUpdates/performUpdateForGroup.cjs +0 -124
  277. package/dist/scripts/bulkStatusUpdates/performUpdateForStatus.js +0 -141
  278. package/dist/scripts/change/changeVideoAspectTo.js +0 -34
  279. package/dist/scripts/change/setUseNewVersion.cjs +0 -22
  280. package/dist/scripts/changeCommunityGroupcount.js +0 -30
  281. package/dist/scripts/changeCommunityPostCount.js +0 -30
  282. package/dist/scripts/changeGroupPostCount.js +0 -30
  283. package/dist/scripts/changeLanguage.js +0 -50
  284. package/dist/scripts/changeOfficalStatus.js +0 -30
  285. package/dist/scripts/cleanups/deleteAnonNotifications.cjs +0 -91
  286. package/dist/scripts/cleanups/deleteLinkGroupsWithDeletedCommunities.js +0 -62
  287. package/dist/scripts/cleanups/deleteYearOldNotifications.cjs +0 -72
  288. package/dist/scripts/cleanups/removeAllUsersFromHiddenPublicGroup.js +0 -43
  289. package/dist/scripts/clearAllEndorsementInGroup.js +0 -50
  290. package/dist/scripts/cloning/clearUsersForCommunitiesFromUrl.js +0 -129
  291. package/dist/scripts/cloning/cloneFromUrlScript.js +0 -65
  292. package/dist/scripts/cloning/cloneWBFromUrlScriptAndCreateLinks.js +0 -140
  293. package/dist/scripts/cloning/cloneWBFromUrlScriptNoUsersOrPoints.js +0 -140
  294. package/dist/scripts/cloning/cloneWBSerbianFromUrlScriptAndCreateLinks.js +0 -131
  295. package/dist/scripts/cloning/copyCommunityConfigAndTranslationsFromURL.js +0 -173
  296. package/dist/scripts/cloning/copyCommunityOneGroupToDomainNoUsersNoEndorsements.js +0 -18
  297. package/dist/scripts/cloning/copyCommunityToDomainNoUsersNoEndorsements.js +0 -17
  298. package/dist/scripts/cloning/copyCommunityToDomainWithEverything.js +0 -17
  299. package/dist/scripts/cloning/copyCommunityToDomainWithOnlyGroups.js +0 -26
  300. package/dist/scripts/cloning/copyGroupConfigAndTranslationsFromURL.js +0 -205
  301. package/dist/scripts/cloning/copyPostToGroupOld.js +0 -397
  302. package/dist/scripts/cloning/copyPostVideosFromURL.js +0 -236
  303. package/dist/scripts/cloning/copyPostWithOutAnyVotingOrActivities.js +0 -17
  304. package/dist/scripts/cloning/deepCloneSerbianWBFromUrlScriptAndCreateLinks.js +0 -131
  305. package/dist/scripts/cloning/deepCloneWBFromUrlScriptAndCreateLinks.js +0 -139
  306. package/dist/scripts/cloning/setAdminsFromURL.js +0 -161
  307. package/dist/scripts/cloning/setExternalIdsFromURL.js +0 -129
  308. package/dist/scripts/countCommunity.js +0 -291
  309. package/dist/scripts/countCommunityUsers.js +0 -152
  310. package/dist/scripts/countDelayedNotifications.js +0 -18
  311. package/dist/scripts/countGroup.js +0 -246
  312. package/dist/scripts/countStuff.js +0 -67
  313. package/dist/scripts/countUniqueVotersInAGroup.js +0 -48
  314. package/dist/scripts/createInvitesAndShow.js +0 -75
  315. package/dist/scripts/database/sync_database.js +0 -14
  316. package/dist/scripts/database/sync_dev_database.js +0 -17
  317. package/dist/scripts/debugNotifications.js +0 -58
  318. package/dist/scripts/deleteAllNewsFeeds.js +0 -10
  319. package/dist/scripts/deleteCategory.js +0 -13
  320. package/dist/scripts/deleteOldAppActivities.js +0 -40
  321. package/dist/scripts/deletePostContactDataForCommunity.js +0 -53
  322. package/dist/scripts/destroy/destroy_all_but_one_domain.js +0 -1026
  323. package/dist/scripts/displayAuthorForPost.js +0 -16
  324. package/dist/scripts/endorsementFraudDetection/analyseEndorsementsForCommunity.js +0 -183
  325. package/dist/scripts/endorsementFraudDetection/bulkDeleteDuplicateEndorsmentsFromUrl.js +0 -208
  326. package/dist/scripts/exportAllStatusChanges.js +0 -36
  327. package/dist/scripts/exportClientAcitivity.js +0 -36
  328. package/dist/scripts/exportEndorsementsForCommunity.js +0 -79
  329. package/dist/scripts/exportPointQualitiesForCommunity.js +0 -84
  330. package/dist/scripts/exportPostsAndPointsForCommunity.js +0 -147
  331. package/dist/scripts/exportPostsDataSetForDomain.js +0 -244
  332. package/dist/scripts/exportPostsForGroup.js +0 -173
  333. package/dist/scripts/exportRatingsForPost.js +0 -15
  334. package/dist/scripts/exportUserEndorsementsWithUserAnalysis.js +0 -123
  335. package/dist/scripts/exportUsersForCommunity.js +0 -24
  336. package/dist/scripts/exportUsersForDomain.js +0 -24
  337. package/dist/scripts/exportUsersForGroup.js +0 -24
  338. package/dist/scripts/exports/ratingDistribution.js +0 -71
  339. package/dist/scripts/exports/whoEndorsedWhatByCommunity.js +0 -56
  340. package/dist/scripts/findUnusedClientImports.js +0 -56
  341. package/dist/scripts/fixAllPostPointCounts.js +0 -22
  342. package/dist/scripts/fixAnonNotificationsSettings.js +0 -48
  343. package/dist/scripts/fixCountKopavogur.js +0 -9
  344. package/dist/scripts/fixEndorsementsAfterCopyPostToGroup.js +0 -190
  345. package/dist/scripts/fixExternalUserId.js +0 -24
  346. package/dist/scripts/fixGroupAccess.js +0 -16
  347. package/dist/scripts/fixGroupIdeasAndPointsCount.js +0 -49
  348. package/dist/scripts/fixNotificationSettings.js +0 -39
  349. package/dist/scripts/fixSurveyRadioBakedInSubCodes.js +0 -64
  350. package/dist/scripts/fixWrongUserIdForStatusUpdates.js +0 -49
  351. package/dist/scripts/gallery/exportGalleryData.js +0 -40
  352. package/dist/scripts/gallery/importGalleryForCommunity.js +0 -168
  353. package/dist/scripts/gallery/readJsonAndDownloadImagesVersion2.js +0 -55
  354. package/dist/scripts/gallery/refreshAcApiPostIdsForCommunity.js +0 -58
  355. package/dist/scripts/genderAnalysis.js +0 -63
  356. package/dist/scripts/genderAnalysisByStatus.js +0 -62
  357. package/dist/scripts/importAllLocalesFromLocalFolders.js +0 -55
  358. package/dist/scripts/importDomain.js +0 -1652
  359. package/dist/scripts/keys/addOidcToDomain.cjs +0 -61
  360. package/dist/scripts/landUseGame/export3Ddata.js +0 -162
  361. package/dist/scripts/listLanguagesForGroup.js +0 -54
  362. package/dist/scripts/loadTestCreateDummyContentForGroup.js +0 -27
  363. package/dist/scripts/makeRecursiveMapData.js +0 -103
  364. package/dist/scripts/mapping/community_map_csv.js +0 -145
  365. package/dist/scripts/moveCommunityToDomain.js +0 -22
  366. package/dist/scripts/moveGroupToCommunity.js +0 -23
  367. package/dist/scripts/movePostToGroup.js +0 -101
  368. package/dist/scripts/movePostsToGroupsRecountGroupFromUrl.js +0 -297
  369. package/dist/scripts/oldMovePostToGroup.js +0 -153
  370. package/dist/scripts/processCsvForPdfUrls.js +0 -37
  371. package/dist/scripts/processCsvForTranslationAndToxicity.js +0 -125
  372. package/dist/scripts/recount/recount_recursive_communities.js +0 -125
  373. package/dist/scripts/recountALLCommunityGroupCounts.js +0 -37
  374. package/dist/scripts/recountAll.js +0 -97
  375. package/dist/scripts/recountCommunitesFromUrl.js +0 -58
  376. package/dist/scripts/recountCommunity.js +0 -19
  377. package/dist/scripts/recountGroup.js +0 -218
  378. package/dist/scripts/recountGroupNoUserChange.js +0 -219
  379. package/dist/scripts/resetAllEndorsementsForGroup.js +0 -57
  380. package/dist/scripts/resetEnTranslationForGroup.js +0 -45
  381. package/dist/scripts/setAdminOnAll.cjs +0 -107
  382. package/dist/scripts/setDomainAdmin.cjs +0 -43
  383. package/dist/scripts/setDomainLocales.js +0 -33
  384. package/dist/scripts/setEarlQuestionIdOnGroup.cjs +0 -29
  385. package/dist/scripts/setLanguageOnGroupCommunitesFromUrl.js +0 -86
  386. package/dist/scripts/setMemberOfAll.js +0 -101
  387. package/dist/scripts/setNewUserForContentOfCommunity.js +0 -189
  388. package/dist/scripts/setOfficialStatusOnAllPostsForCommunity.js +0 -35
  389. package/dist/scripts/setUserOnAll.js +0 -101
  390. package/dist/scripts/showCategoryForGroup.js +0 -18
  391. package/dist/scripts/showOldActivityTypes.js +0 -14
  392. package/dist/scripts/showPostsMissingCategoryForGroup.js +0 -17
  393. package/dist/scripts/showStatuses.js +0 -17
  394. package/dist/scripts/showUniqueVotersInCommunity.js +0 -61
  395. package/dist/scripts/showUserAgentsAndIpsForEmails.js +0 -66
  396. package/dist/scripts/simpleExportForGroupsForCommunity.js +0 -46
  397. package/dist/scripts/simpleExportForPointsForCommunity.js +0 -82
  398. package/dist/scripts/simpleExportForPostsForCommunity.js +0 -61
  399. package/dist/scripts/testForEndorsments.js +0 -21
  400. package/dist/scripts/undeleteGroupAndAllContent.js +0 -151
  401. package/dist/scripts/undeletePost.js +0 -135
  402. package/dist/scripts/unlinkSsn.js +0 -23
  403. package/dist/scripts/updateFromAlthingi.js +0 -303
  404. package/dist/server.js +0 -3
  405. package/dist/utils/airbrake.cjs +0 -17
  406. package/dist/utils/cjsCodeReview.js +0 -99
  407. package/dist/utils/community_mapping_tools.cjs +0 -124
  408. package/dist/utils/copy_utils.cjs +0 -1399
  409. package/dist/utils/docx_utils.cjs +0 -464
  410. package/dist/utils/export_utils.cjs +0 -491
  411. package/dist/utils/i18n.cjs +0 -17
  412. package/dist/utils/is_valid_db_id.cjs +0 -28
  413. package/dist/utils/logger.cjs +0 -25
  414. package/dist/utils/loggerTs.js +0 -26
  415. package/dist/utils/manifest_generator.cjs +0 -104
  416. package/dist/utils/parse_domain.cjs +0 -16
  417. package/dist/utils/recount_utils.cjs +0 -415
  418. package/dist/utils/sharing_parameters.cjs +0 -111
  419. package/dist/utils/sitemap_generator.cjs +0 -286
  420. package/dist/utils/to_json.cjs +0 -14
  421. package/dist/utils/ypLanguages.js +0 -747
  422. package/dist/webSockets.js +0 -77
@@ -1,15 +0,0 @@
1
- "use strict";
2
- var commonIndexForActivitiesAndNewsFeeds = function (createdAtField) {
3
- return [
4
- {
5
- fields: ['post_id', 'user_id', createdAtField, 'id'],
6
- where: {
7
- status: 'active',
8
- deleted: false
9
- }
10
- }
11
- ];
12
- };
13
- module.exports = {
14
- commonIndexForActivitiesAndNewsFeeds: commonIndexForActivitiesAndNewsFeeds
15
- };
@@ -1,362 +0,0 @@
1
- "use strict";
2
- var models = require("../../../models/index.cjs");
3
- var async = require('async');
4
- var log = require('../../utils/logger.cjs');
5
- var _ = require('lodash');
6
- var getRecommendationFor = require('../recommendations/events_manager.cjs').getRecommendationFor;
7
- var getProcessedRange = require('./news_feeds_utils.cjs').getProcessedRange;
8
- var activitiesDefaultIncludes = require('./news_feeds_utils.cjs').activitiesDefaultIncludes;
9
- var getCommonWhereOptions = require('./news_feeds_utils.cjs').getCommonWhereOptions;
10
- var defaultKeyActivities = require('./news_feeds_utils.cjs').defaultKeyActivities;
11
- var getActivityDate = require('./news_feeds_utils.cjs').getActivityDate;
12
- var airbrake = null;
13
- if (process.env.AIRBRAKE_PROJECT_ID) {
14
- airbrake = require('../../utils/airbrake.cjs');
15
- }
16
- // Load current news feed generated from notifications by modified_at
17
- // Get recommendations and insert into the news with the modified_at timestamps
18
- // Get promotions to add to the news feed
19
- // Create critical priority job to insert recommendation and promotions to postgres
20
- // Send data back to user
21
- var GENERAL_NEWS_FEED_LIMIT = 20;
22
- var RECOMMENDATION_FILTER_THRESHOLD = 14;
23
- var getNewsFeedItems = function (options, callback) {
24
- var where = getCommonWhereOptions(options);
25
- models.AcNewsFeedItem.findAll({
26
- where: where,
27
- order: [
28
- ["latest_activity_at", "desc"],
29
- [models.AcActivity, models.User, { model: models.Image, as: 'UserProfileImages' }, 'created_at', 'asc'],
30
- [models.AcActivity, models.User, { model: models.Organization, as: 'OrganizationUsers' }, { model: models.Image, as: 'OrgLogoImgs' }, 'created_at', 'asc']
31
- ],
32
- limit: options.limit || GENERAL_NEWS_FEED_LIMIT,
33
- include: [
34
- {
35
- model: models.AcActivity,
36
- required: true,
37
- include: activitiesDefaultIncludes(options)
38
- }
39
- ]
40
- }).then(function (items) {
41
- log.info("Generate News Feed Dynamically Got news feed", { itemsLength: items.length });
42
- callback(null, items);
43
- }).catch(function (error) {
44
- callback(error);
45
- });
46
- };
47
- var getAllActivities = function (options, callback) {
48
- var where = getCommonWhereOptions(_.merge(options, { dateColumn: 'created_at' }));
49
- where = _.merge(where, {
50
- type: {
51
- $in: defaultKeyActivities
52
- }
53
- });
54
- delete where.user_id;
55
- models.AcActivity.findAll({
56
- where: where,
57
- limit: GENERAL_NEWS_FEED_LIMIT,
58
- order: [
59
- ["created_at", "desc"],
60
- [models.User, { model: models.Image, as: 'UserProfileImages' }, 'created_at', 'asc'],
61
- [models.User, { model: models.Organization, as: 'OrganizationUsers' }, { model: models.Image, as: 'OrgLogoImgs' }, 'created_at', 'asc']
62
- ],
63
- include: activitiesDefaultIncludes(options)
64
- }).then(function (activities) {
65
- log.info("Generate News Feed Dynamically Got defaultKeyActivities", { activitiesLength: activities.length });
66
- callback(null, activities);
67
- }).catch(function (error) {
68
- callback(error);
69
- });
70
- };
71
- var filterRecommendations = function (allActivities, options, callback) {
72
- log.info("Generate News Feed Dynamically Breached Recommendation Filter Threshold", {
73
- allActivitiesLength: allActivities.length, threshold: RECOMMENDATION_FILTER_THRESHOLD
74
- });
75
- // Add my own activities
76
- var myActivities = _.filter(allActivities, function (activity) { return activity.user_id == options.user_id; });
77
- allActivities = _.filter(allActivities, function (activity) { return activity.user_id != options.user_id; });
78
- // Add non post activities
79
- var noPostActivities = _.filter(allActivities, function (activity) { return !activity.post_id; });
80
- allActivities = _.filter(allActivities, function (activity) { return activity.post_id; });
81
- var currentPostIds = _.map(allActivities, function (item) { return item.post_id ? item.post_id.toString() : null; });
82
- // There can be more than one instance of a post_id from a group of activities
83
- // Get all status updates and make sure they are not removed due to lack of recommendations
84
- currentPostIds = _.uniq(currentPostIds);
85
- currentPostIds = _.without(currentPostIds, null);
86
- var dateRange = {};
87
- if (options.afterDate && options.beforeDate) {
88
- dateRange = { name: 'date', after: options.afterDate, before: options.beforeDate };
89
- }
90
- else if (options.afterDate) {
91
- dateRange = { name: 'date', after: options.afterDate };
92
- }
93
- else if (options.beforeDate) {
94
- dateRange = { name: 'date', before: options.beforeDate };
95
- }
96
- getRecommendationFor({}, options.user_id, dateRange, options, function (error, recommendedItemIds) {
97
- if (error) {
98
- recommendedItemIds = [];
99
- if (airbrake) {
100
- airbrake.notify(error).then((airbrakeErr) => {
101
- if (airbrakeErr.error) {
102
- log.error("AirBrake Error", { context: 'airbrake', err: airbrakeErr.error, errorStatus: 500 });
103
- }
104
- });
105
- }
106
- }
107
- var recommendedPostIds = _.filter(currentPostIds, function (activity) { return _.includes(recommendedItemIds, activity); });
108
- var notRecommendedPostIds = _.filter(currentPostIds, function (activity) { return !_.includes(recommendedItemIds, activity); });
109
- log.info("Generate News Feed Dynamically Recommendation status", {
110
- recommendedPostIdsLength: recommendedPostIds.length, notRecommendedPostIdsLength: notRecommendedPostIds.length
111
- });
112
- var finalPostIds;
113
- if (recommendedPostIds.length < RECOMMENDATION_FILTER_THRESHOLD) {
114
- // Randomize the remaining not recommended activities
115
- notRecommendedPostIds = _.shuffle(notRecommendedPostIds);
116
- // Merge the recommended activities using the not recommended ones and drop the rest
117
- finalPostIds = _.concat(recommendedPostIds, _.dropRight(notRecommendedPostIds, notRecommendedPostIds.length - (RECOMMENDATION_FILTER_THRESHOLD - recommendedPostIds.length)));
118
- }
119
- else {
120
- finalPostIds = recommendedPostIds;
121
- }
122
- allActivities = _.filter(allActivities, function (activity) { return (activity.post_id && _.includes(finalPostIds, activity.post_id.toString())); });
123
- allActivities = _.concat(allActivities, myActivities);
124
- allActivities = _.concat(allActivities, noPostActivities);
125
- callback(null, allActivities);
126
- });
127
- };
128
- var removeDuplicates = function (allActivities, options, callback) {
129
- allActivities = _.uniq(allActivities);
130
- var currentActivityIds = _.map(allActivities, function (item) { return item.id; });
131
- var where = _.merge(getCommonWhereOptions(options), {
132
- ac_activity_id: {
133
- $in: currentActivityIds
134
- }
135
- });
136
- models.AcNewsFeedItem.findAll({
137
- where: where
138
- }).then(function (alreadySavedActivities) {
139
- log.info("Generate News Feed Dynamically Found already saved", {
140
- alreadySavedActivitiesLength: alreadySavedActivities.length
141
- });
142
- var alreadySavedActivitiesIds = _.map(alreadySavedActivities, function (item) { return item.id; });
143
- // Filter out activities already in this newsfeed
144
- allActivities = _.filter(allActivities, function (activity) { return !_.includes(alreadySavedActivities, activity.id); });
145
- callback(null, allActivities);
146
- }).catch(function (error) {
147
- callback(error);
148
- });
149
- };
150
- var createNewsFeedItemsFromActivities = function (allActivities, options, callback) {
151
- log.info("Generate News Feed Dynamically Saving new news items", { allActivitiesLength: allActivities.length });
152
- models.sequelize.transaction(function (t1) {
153
- allInserts = [];
154
- _.forEach(allActivities, function (activity) {
155
- allInserts.push(models.AcNewsFeedItem.create({ ac_activity_id: activity.id, latest_activity_at: activity.created_at,
156
- type: 'newsFeed.dynamic.recommendation', user_id: options.user_id,
157
- domain_id: options.domain_id, community_id: options.community_id,
158
- group_id: options.group_id, post_id: options.post_id }, { transaction: t1 }));
159
- });
160
- return Promise.all(allInserts);
161
- }).then(function (result) {
162
- log.info("Generate News Feed Dynamically Saved", { result: result });
163
- callback(null, result);
164
- }).catch(function (error) {
165
- callback(error);
166
- });
167
- };
168
- var loadOtherNewsItemsInRange = function (latestActivity, oldestActivity, options, callback) {
169
- getNewsFeedItems(_.merge(options, {
170
- afterOrEqualFilter: oldestActivity.created_at,
171
- beforeOrEqualFilter: latestActivity.created_at,
172
- type: 'newsFeed.from.notification.recommendation',
173
- dateColumn: 'latest_activity_at'
174
- }), callback);
175
- };
176
- var createProcessedRange = function (latestActivity, oldestActivity, options, callback) {
177
- models.AcNewsFeedProcessedRange.create({
178
- latest_activity_at: latestActivity.created_at,
179
- oldest_activity_at: oldestActivity.created_at,
180
- user_id: options.user_id, domain_id: options.domain_id, community_id: options.community_id,
181
- group_id: options.group_id, post_id: options.post_id
182
- }).then(function (results) {
183
- callback(null, results);
184
- }).catch(function (error) {
185
- callback(error);
186
- });
187
- };
188
- var generateNewsFeedFromActivities = function (options, callback) {
189
- var allActivities, finalActivities, latestActivity, oldestActivity, otherNewsItems, processedRange;
190
- async.series([
191
- // Get all activities
192
- function (seriesCallback) {
193
- getAllActivities(options, function (error, activities) {
194
- if (error) {
195
- seriesCallback(error);
196
- }
197
- else {
198
- allActivities = activities;
199
- latestActivity = _.first(allActivities);
200
- oldestActivity = _.last(allActivities);
201
- seriesCallback();
202
- }
203
- });
204
- },
205
- // Filter out activities if needed based on recommendations
206
- function (seriesCallback) {
207
- if (allActivities.length > RECOMMENDATION_FILTER_THRESHOLD) {
208
- filterRecommendations(allActivities, options, function (error, activities) {
209
- if (error) {
210
- seriesCallback(error);
211
- }
212
- else {
213
- allActivities = activities;
214
- seriesCallback();
215
- }
216
- });
217
- }
218
- else {
219
- log.info("Generate News Feed Dynamically Not being filtered", {
220
- allActivitiesLength: allActivities.length, threshold: RECOMMENDATION_FILTER_THRESHOLD
221
- });
222
- seriesCallback();
223
- }
224
- },
225
- // Make sure there are no duplicated activities in news feed
226
- function (seriesCallback) {
227
- removeDuplicates(allActivities, options, function (error, activities) {
228
- if (error) {
229
- seriesCallback(error);
230
- }
231
- else {
232
- // Save all new news feed items
233
- createNewsFeedItemsFromActivities(activities, options, function (error, results) {
234
- if (error) {
235
- seriesCallback(error);
236
- }
237
- else {
238
- seriesCallback();
239
- }
240
- });
241
- }
242
- });
243
- },
244
- // Load other news items created from notifications
245
- function (seriesCallback) {
246
- if (oldestActivity) {
247
- loadOtherNewsItemsInRange(latestActivity, oldestActivity, options, function (error, newsItems) {
248
- if (error) {
249
- seriesCallback(error);
250
- }
251
- else {
252
- otherNewsItems = newsItems;
253
- seriesCallback();
254
- }
255
- });
256
- }
257
- else {
258
- seriesCallback();
259
- }
260
- },
261
- // Combine older and new dynamically recommended activities
262
- function (seriesCallback) {
263
- var olderActivities = _.map(otherNewsItems, function (item) { return item.AcActivity; });
264
- finalActivities = _.concat(allActivities, olderActivities);
265
- // Sort the combined activities
266
- finalActivities = _.orderBy(finalActivities, ['created_at'], ['desc']);
267
- log.info("Generate News Feed Dynamically Have created the final activities to deliver", { finalActivitiesLength: finalActivities.length });
268
- seriesCallback();
269
- },
270
- // Create the News Feed Processed Range
271
- function (seriesCallback) {
272
- if (latestActivity && oldestActivity) {
273
- createProcessedRange(latestActivity, oldestActivity, options, function (error, processedRangeIn) {
274
- if (error) {
275
- seriesCallback(error);
276
- }
277
- else {
278
- processedRange = processedRangeIn;
279
- seriesCallback();
280
- }
281
- });
282
- }
283
- else {
284
- seriesCallback();
285
- }
286
- }
287
- ], function (error) {
288
- // Return all
289
- callback(error, finalActivities, processedRange ? processedRange.oldest_activity_at : null);
290
- });
291
- };
292
- var getNewsFeedItemsFromProcessedRange = function (processedRange, options, callback) {
293
- getNewsFeedItems(_.merge(options, {
294
- afterOrEqualFilter: processedRange.oldest_activity_at,
295
- beforeOrEqualFilter: processedRange.latest_activity_at,
296
- dateColumn: 'latest_activity_at'
297
- }), function (error, newsitems) {
298
- if (error) {
299
- callback(error, false);
300
- }
301
- else if (newsitems.length == 0) {
302
- // We delete the processed range as the activities in it have been deleted
303
- processedRange.deleted = true;
304
- processedRange.save().then(function () {
305
- callback(null, true);
306
- }).catch(function (error) {
307
- callback(error, false);
308
- });
309
- }
310
- else {
311
- var activities = _.map(newsitems, function (item) { return item.AcActivity; });
312
- callback(null, false, activities, processedRange.oldest_activity_at);
313
- }
314
- });
315
- };
316
- var getCuratedNewsItems = function (options, callback) {
317
- var latestActivityTime, latestProcessedRange;
318
- var possibleEmptyRanges = true;
319
- var originalOptions = JSON.parse(JSON.stringify(options));
320
- async.whilst(function () { return possibleEmptyRanges; }, function (whilstCallback) {
321
- options = JSON.parse(JSON.stringify(originalOptions));
322
- async.parallel([
323
- function (seriesCallback) {
324
- getActivityDate(options, function (error, latestActivityTimeIn) {
325
- latestActivityTime = latestActivityTimeIn;
326
- seriesCallback(error);
327
- });
328
- },
329
- function (seriesCallback) {
330
- getProcessedRange(options, function (error, latestProcessedRangeIn) {
331
- latestProcessedRange = latestProcessedRangeIn;
332
- seriesCallback(error);
333
- });
334
- }
335
- ], function (error) {
336
- if (error) {
337
- whilstCallback(error);
338
- }
339
- else {
340
- if (!latestProcessedRange || latestActivityTime > latestProcessedRange.latest_activity_at) {
341
- possibleEmptyRanges = false;
342
- if (latestProcessedRange) {
343
- options.afterFilter = latestProcessedRange.latest_activity_at;
344
- }
345
- generateNewsFeedFromActivities(options, whilstCallback);
346
- }
347
- else {
348
- getNewsFeedItemsFromProcessedRange(latestProcessedRange, options, function (error, possibleEmptyRangesIn, activities, oldestActivityAt) {
349
- possibleEmptyRanges = possibleEmptyRangesIn;
350
- whilstCallback(error, activities, oldestActivityAt);
351
- });
352
- }
353
- }
354
- });
355
- }, function (error, activities, oldestActivityAt) {
356
- callback(error, activities, oldestActivityAt);
357
- });
358
- };
359
- module.exports = {
360
- getNewsFeedItems: getNewsFeedItems,
361
- getCuratedNewsItems: getCuratedNewsItems
362
- };
@@ -1,268 +0,0 @@
1
- "use strict";
2
- var models = require("../../../models/index.cjs");
3
- var async = require('async');
4
- var log = require('../../utils/logger.cjs');
5
- var _ = require('lodash');
6
- var toJson = require('../../utils/to_json.cjs');
7
- var airbrake = null;
8
- if (process.env.AIRBRAKE_PROJECT_ID) {
9
- airbrake = require('../../utils/airbrake.cjs');
10
- }
11
- var isItemRecommended = require('../recommendations/events_manager.cjs').isItemRecommended;
12
- var getNewsFeedDate = require('./news_feeds_utils.cjs').getNewsFeedDate;
13
- var createItemFromNotification = function (notification, options, callback) {
14
- var detail = {};
15
- detail.ac_notification_id = notification.id;
16
- detail.ac_activity_id = _.last(notification.AcActivities).id;
17
- detail.user_id = notification.user_id;
18
- detail.latest_activity_at = _.last(notification.AcActivities).created_at;
19
- models.AcNewsFeedItem.findOne({ where: { ac_activity_id: detail.ac_activity_id } }).then(function (results) {
20
- if (!results) {
21
- models.AcNewsFeedItem.create(_.merge(detail, options)).then(function (item) {
22
- if (item) {
23
- log.info("Generate News Feed Notifications Created item", { item: toJson(item) });
24
- callback();
25
- }
26
- else {
27
- callback('Could not created item');
28
- }
29
- }).catch(function (error) {
30
- callback(error);
31
- });
32
- }
33
- else {
34
- log.warn("Not creating news feed item for activitity that is already there", { acActivityId: detail.ac_activity_id, userId: detail.user_id });
35
- callback();
36
- }
37
- });
38
- };
39
- var buildNewsFeedItems = function (notification, callback) {
40
- var shouldInclude = false;
41
- var activity = _.last(notification.AcActivities);
42
- var lastNewsItem;
43
- async.series([
44
- // If my activity, new post, my post or some of my followings mark it as should include
45
- function (seriesCallback) {
46
- if (notification.user_id == activity.user_id ||
47
- activity.type == 'activity.post.new' ||
48
- (activity.Post && activity.Post.user_id == notification.user_id)) {
49
- shouldInclude = true;
50
- seriesCallback();
51
- }
52
- else {
53
- models.AcFollowing.findOne({
54
- where: {
55
- user_id: notification.user_id,
56
- other_user_id: activity.user_id
57
- }
58
- }).then(function (following) {
59
- if (following) {
60
- shouldInclude = true;
61
- }
62
- seriesCallback();
63
- }).catch(function (error) {
64
- seriesCallback(error);
65
- });
66
- }
67
- },
68
- function (seriesCallback) {
69
- if (shouldInclude || !activity.Post) {
70
- seriesCallback();
71
- }
72
- else {
73
- models.Endorsement.findOne({
74
- where: {
75
- user_id: notification.user_id,
76
- post_id: activity.Post.id
77
- }
78
- }).then(function (endorsement) {
79
- if (endorsement) {
80
- shouldInclude = true;
81
- }
82
- seriesCallback();
83
- }).catch(function (error) {
84
- seriesCallback(error);
85
- });
86
- }
87
- },
88
- function (seriesCallback) {
89
- // Create newsFeed item if needed
90
- if (shouldInclude) {
91
- createItemFromNotification(notification, {
92
- type: 'newsFeed.from.notification.should',
93
- domain_id: activity.domain_id,
94
- group_id: activity.group_id,
95
- post_id: activity.post_id,
96
- community_id: activity.community_id,
97
- latest_activity_at: activity.created_at
98
- }, seriesCallback);
99
- }
100
- else {
101
- var lastNewsItemUpdatedAt;
102
- async.series([
103
- // Domain news feed from recommendations
104
- function (innerSeriesCallback) {
105
- lastNewsItemUpdatedAt = null;
106
- getNewsFeedDate({ domain_id: activity.domain_id }, 'newsFeed.from.notification.recommendation', function (error, itemUpdatedAt) {
107
- lastNewsItemUpdatedAt = itemUpdatedAt;
108
- innerSeriesCallback(error);
109
- });
110
- },
111
- function (innerSeriesCallback) {
112
- isItemRecommended({}, activity.post_id, notification.User.id, {
113
- limit: 15,
114
- after: lastNewsItemUpdatedAt ? lastNewsItemUpdatedAt.toISOString() : null
115
- }, {
116
- domain_id: activity.domain_id
117
- }, function (isRecommended) {
118
- if (isRecommended) {
119
- createItemFromNotification(notification, {
120
- type: 'newsFeed.from.notification.recommendation',
121
- domain_id: activity.domain_id
122
- }, function (error) {
123
- innerSeriesCallback(error);
124
- });
125
- }
126
- else {
127
- innerSeriesCallback();
128
- }
129
- });
130
- },
131
- // Community news feed from recommendations
132
- function (innerSeriesCallback) {
133
- lastNewsItemUpdatedAt = null;
134
- getNewsFeedDate({ community_id: activity.community_id }, 'newsFeed.from.notification.recommendation', function (error, itemUpdatedAt) {
135
- lastNewsItemUpdatedAt = itemUpdatedAt;
136
- innerSeriesCallback(error);
137
- });
138
- },
139
- function (innerSeriesCallback) {
140
- isItemRecommended({}, activity.post_id, notification.User.id, {
141
- after: lastNewsItemUpdatedAt ? lastNewsItemUpdatedAt.toISOString() : null
142
- }, {
143
- community_id: activity.community_id
144
- }, function (isRecommended) {
145
- if (isRecommended) {
146
- createItemFromNotification(notification, {
147
- type: 'newsFeed.from.notification.recommendation',
148
- community_id: activity.community_id
149
- }, function (error) {
150
- innerSeriesCallback(error);
151
- });
152
- }
153
- else {
154
- innerSeriesCallback();
155
- }
156
- });
157
- },
158
- // Group news feed from recommendations
159
- function (innerSeriesCallback) {
160
- lastNewsItemUpdatedAt = null;
161
- getNewsFeedDate({ group_id: activity.group_id }, 'newsFeed.from.notification.recommendation', function (error, itemUpdatedAt) {
162
- lastNewsItemUpdatedAt = itemUpdatedAt;
163
- innerSeriesCallback(error);
164
- });
165
- },
166
- function (innerSeriesCallback) {
167
- isItemRecommended({}, activity.post_id, notification.User.id, {
168
- after: lastNewsItemUpdatedAt ? lastNewsItemUpdatedAt.toISOString() : null
169
- }, {
170
- group_id: activity.group_id
171
- }, function (isRecommended) {
172
- if (isRecommended) {
173
- createItemFromNotification(notification, {
174
- type: 'newsFeed.from.notification.recommendation',
175
- group_id: activity.group_id
176
- }, function (error) {
177
- innerSeriesCallback(error);
178
- });
179
- }
180
- else {
181
- innerSeriesCallback();
182
- }
183
- });
184
- },
185
- // Post news feed from recommendations
186
- function (innerSeriesCallback) {
187
- lastNewsItemUpdatedAt = null;
188
- getNewsFeedDate({ post_id: activity.post_id }, 'newsFeed.from.notification.recommendation', function (error, itemUpdatedAt) {
189
- lastNewsItemUpdatedAt = itemUpdatedAt;
190
- innerSeriesCallback(error);
191
- });
192
- },
193
- // Create item if recommended
194
- function (innerSeriesCallback) {
195
- isItemRecommended({}, activity.post_id, notification.User.id, {
196
- after: lastNewsItemUpdatedAt ? lastNewsItemUpdatedAt.toISOString() : null
197
- }, {
198
- post_id: activity.post_id
199
- }, function (isRecommended) {
200
- if (isRecommended) {
201
- createItemFromNotification(notification, {
202
- type: 'newsFeed.from.notification.recommendation',
203
- post_id: activity.post_id
204
- }, function (error) {
205
- innerSeriesCallback(error);
206
- });
207
- }
208
- else {
209
- innerSeriesCallback();
210
- }
211
- });
212
- }
213
- ], seriesCallback);
214
- }
215
- }
216
- ], callback);
217
- };
218
- module.exports = function (notification, user, callback) {
219
- var news_feed_item;
220
- var activity = _.last(notification.AcActivities);
221
- async.series([
222
- // See if news item for same notification exists and set updated time if needed
223
- function (seriesCallback) {
224
- models.AcNewsFeedItem.findOne({
225
- where: {
226
- ac_notification_id: notification.id
227
- }
228
- }).then(function (oldNewsFeedItem) {
229
- if (oldNewsFeedItem) {
230
- log.info("Generate News Feed Notifications found old item and updating timestamp", { oldNewsFeedItemId: oldNewsFeedItem.id });
231
- news_feed_item = oldNewsFeedItem;
232
- news_feed_item.latest_activity_at = activity.created_at;
233
- news_feed_item.save().then(function (updateResults) {
234
- if (!updateResults) {
235
- log.error("Filtering News Feed Notifications Error", { err: "Could not update timestamp" });
236
- }
237
- seriesCallback();
238
- });
239
- }
240
- else {
241
- seriesCallback();
242
- }
243
- }).catch(function (error) {
244
- seriesCallback(error);
245
- });
246
- },
247
- function (seriesCallback) {
248
- if (news_feed_item) {
249
- seriesCallback();
250
- }
251
- else {
252
- buildNewsFeedItems(notification, seriesCallback);
253
- }
254
- }
255
- ], function (error) {
256
- if (error) {
257
- log.error("Generate News Feed Notifications Error", { err: error });
258
- if (airbrake) {
259
- airbrake.notify(error).then((airbrakeErr) => {
260
- if (airbrakeErr.error) {
261
- log.error("AirBrake Error", { context: 'airbrake', user: toJson(req.user), err: airbrakeErr.error, errorStatus: 500 });
262
- }
263
- });
264
- }
265
- }
266
- callback(error);
267
- });
268
- };