@yrpri/api 9.0.101 → 9.0.103

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 (638) hide show
  1. package/active-citizen/engine/allOurIdeas/explainAnswersAssistant.js +11 -1
  2. package/active-citizen/llms/baseChatBot.js +8 -75
  3. package/active-citizen/llms/imageGeneration/chatGptImageGenerator.js +56 -0
  4. package/active-citizen/llms/imageGeneration/collectionImageGenerator.js +6 -0
  5. package/agents/assistants/agentAssistant.js +3 -2
  6. package/agents/assistants/baseAssistant.js +7 -30
  7. package/agents/assistants/baseAssistantWithVoice.js +3 -3
  8. package/agents/assistants/voiceAssistant.js +2 -2
  9. package/agents/controllers/agentProductController.js +2 -1
  10. package/agents/controllers/agentSubscriptionController.js +20 -11
  11. package/agents/controllers/assistantsController.js +171 -127
  12. package/agents/controllers/policySynthAgents.js +33 -12
  13. package/agents/managers/newAiModelSetup.js +96 -0
  14. package/agents/managers/subscriptionManager.js +2 -2
  15. package/app.js +12 -12
  16. package/authorization.cjs +4 -0
  17. package/controllers/allOurIdeas.js +2 -1
  18. package/controllers/communities.cjs +47 -1
  19. package/controllers/groups.cjs +67 -4
  20. package/controllers/index.cjs +7 -7
  21. package/controllers/nonSpa.cjs +1 -1
  22. package/dist/active-citizen/controllers/activities.cjs +174 -0
  23. package/dist/active-citizen/controllers/news_feeds.cjs +96 -0
  24. package/dist/active-citizen/controllers/notifications.cjs +243 -0
  25. package/dist/active-citizen/controllers/recommendations.cjs +280 -0
  26. package/dist/active-citizen/engine/allOurIdeas/aiHelper.js +204 -0
  27. package/dist/active-citizen/engine/allOurIdeas/explainAnswersAssistant.js +66 -0
  28. package/dist/active-citizen/engine/allOurIdeas/iconGenerator.js +38 -0
  29. package/dist/active-citizen/engine/analytics/export_anon_community_activities.js +334 -0
  30. package/dist/active-citizen/engine/analytics/importer.js +308 -0
  31. package/dist/active-citizen/engine/analytics/manager.cjs +377 -0
  32. package/dist/active-citizen/engine/analytics/plausible/manager.cjs +500 -0
  33. package/dist/active-citizen/engine/analytics/statsCalc.cjs +194 -0
  34. package/dist/active-citizen/engine/analytics/utils.cjs +369 -0
  35. package/dist/active-citizen/engine/marketing/campaign.cjs +90 -0
  36. package/dist/active-citizen/engine/moderation/fraud/CreateFraudAuditReport.cjs +313 -0
  37. package/dist/active-citizen/engine/moderation/fraud/FraudBase.cjs +239 -0
  38. package/dist/active-citizen/engine/moderation/fraud/FraudDeleteBase.cjs +211 -0
  39. package/dist/active-citizen/engine/moderation/fraud/FraudDeleteEndorsements.cjs +120 -0
  40. package/dist/active-citizen/engine/moderation/fraud/FraudDeletePointQualities.cjs +114 -0
  41. package/dist/active-citizen/engine/moderation/fraud/FraudDeletePoints.cjs +101 -0
  42. package/dist/active-citizen/engine/moderation/fraud/FraudDeletePosts.cjs +84 -0
  43. package/dist/active-citizen/engine/moderation/fraud/FraudDeleteRatings.cjs +15 -0
  44. package/dist/active-citizen/engine/moderation/fraud/FraudGetBase.cjs +133 -0
  45. package/dist/active-citizen/engine/moderation/fraud/FraudGetEndorsements.cjs +185 -0
  46. package/dist/active-citizen/engine/moderation/fraud/FraudGetPointQualities.cjs +184 -0
  47. package/dist/active-citizen/engine/moderation/fraud/FraudGetPoints.cjs +170 -0
  48. package/dist/active-citizen/engine/moderation/fraud/FraudGetPosts.cjs +109 -0
  49. package/dist/active-citizen/engine/moderation/fraud/FraudGetRatings.cjs +140 -0
  50. package/dist/active-citizen/engine/moderation/fraud/FraudScannerNotifier.cjs +279 -0
  51. package/dist/active-citizen/engine/moderation/get_moderation_items.cjs +386 -0
  52. package/dist/active-citizen/engine/moderation/image_labeling/CommunityLabeling.cjs +49 -0
  53. package/dist/active-citizen/engine/moderation/image_labeling/GroupLabeling.cjs +68 -0
  54. package/dist/active-citizen/engine/moderation/image_labeling/ImageLabelingBase.cjs +288 -0
  55. package/dist/active-citizen/engine/moderation/image_labeling/PointLabeling.cjs +33 -0
  56. package/dist/active-citizen/engine/moderation/image_labeling/PostLabeling.cjs +56 -0
  57. package/dist/active-citizen/engine/moderation/perspective_api_client.cjs +106 -0
  58. package/dist/active-citizen/engine/moderation/process_moderation_items.cjs +344 -0
  59. package/dist/active-citizen/engine/moderation/toxicity_analysis.cjs +810 -0
  60. package/dist/active-citizen/engine/news_feeds/activity_and_item_index_definitions.cjs +15 -0
  61. package/dist/active-citizen/engine/news_feeds/generate_dynamically.cjs +362 -0
  62. package/dist/active-citizen/engine/news_feeds/generate_from_notifications.cjs +268 -0
  63. package/dist/active-citizen/engine/news_feeds/news_feeds_utils.cjs +439 -0
  64. package/dist/active-citizen/engine/notifications/emails_utils.cjs +569 -0
  65. package/dist/active-citizen/engine/notifications/generate_point_notifications.cjs +233 -0
  66. package/dist/active-citizen/engine/notifications/generate_post_notifications.cjs +118 -0
  67. package/dist/active-citizen/engine/notifications/generate_post_status_change_notifications.cjs +41 -0
  68. package/dist/active-citizen/engine/notifications/notifications_utils.cjs +148 -0
  69. package/dist/active-citizen/engine/notifications/point_delivery.cjs +54 -0
  70. package/dist/active-citizen/engine/notifications/post_delivery.cjs +31 -0
  71. package/dist/active-citizen/engine/notifications/process_delayed_notifications.cjs +471 -0
  72. package/dist/active-citizen/engine/notifications/process_general_notifications.cjs +212 -0
  73. package/dist/active-citizen/engine/old/exporters/categories_dataset.js +153 -0
  74. package/dist/active-citizen/engine/old/exporters/dataset_tools.js +80 -0
  75. package/dist/active-citizen/engine/old/exporters/sentiment_dataset.js +157 -0
  76. package/dist/active-citizen/engine/recommendations/events_importer.cjs +139 -0
  77. package/dist/active-citizen/engine/recommendations/events_manager.cjs +212 -0
  78. package/dist/active-citizen/engine/reports/add_points_to_sheet.cjs +83 -0
  79. package/dist/active-citizen/engine/reports/commonUtils.js +75 -0
  80. package/dist/active-citizen/engine/reports/common_utils.cjs +740 -0
  81. package/dist/active-citizen/engine/reports/docx_group_report.cjs +596 -0
  82. package/dist/active-citizen/engine/reports/xlsAllOurIdeasExport.js +232 -0
  83. package/dist/active-citizen/engine/reports/xls_community_users_report.cjs +277 -0
  84. package/dist/active-citizen/engine/reports/xls_group_report.cjs +718 -0
  85. package/dist/active-citizen/llms/baseChatBot.js +183 -0
  86. package/dist/active-citizen/llms/imageGeneration/chatGptImageGenerator.js +56 -0
  87. package/dist/active-citizen/llms/imageGeneration/collectionImageGenerator.js +109 -0
  88. package/dist/active-citizen/llms/imageGeneration/dalleImageGenerator.js +84 -0
  89. package/dist/active-citizen/llms/imageGeneration/fluxImageGenerator.js +49 -0
  90. package/dist/active-citizen/llms/imageGeneration/imageProcessorService.js +64 -0
  91. package/dist/active-citizen/llms/imageGeneration/imagenImageGenerator.js +107 -0
  92. package/dist/active-citizen/llms/imageGeneration/s3Service.js +110 -0
  93. package/dist/active-citizen/llms/llmTranslation.js +472 -0
  94. package/dist/active-citizen/models/ac_activity.cjs +216 -0
  95. package/dist/active-citizen/models/ac_background_job.cjs +109 -0
  96. package/dist/active-citizen/models/ac_campaign.cjs +97 -0
  97. package/dist/active-citizen/models/ac_client_activity.cjs +23 -0
  98. package/dist/active-citizen/models/ac_delayed_notification.cjs +43 -0
  99. package/dist/active-citizen/models/ac_following.cjs +43 -0
  100. package/dist/active-citizen/models/ac_list.cjs +68 -0
  101. package/dist/active-citizen/models/ac_list_users.cjs +19 -0
  102. package/dist/active-citizen/models/ac_mute.cjs +27 -0
  103. package/dist/active-citizen/models/ac_news_feed_item.cjs +57 -0
  104. package/dist/active-citizen/models/ac_news_feed_processed_range.cjs +59 -0
  105. package/dist/active-citizen/models/ac_notification.cjs +292 -0
  106. package/dist/active-citizen/models/ac_translation_cache.cjs +750 -0
  107. package/dist/active-citizen/models/ac_watching.cjs +31 -0
  108. package/dist/active-citizen/scripts/analytics/setup_all_plausible_goals.cjs +13 -0
  109. package/dist/active-citizen/scripts/fix_old_delayed_notifications.js +63 -0
  110. package/dist/active-citizen/scripts/kue_status.js +31 -0
  111. package/dist/active-citizen/scripts/kue_watch_stuck_jobs.js +24 -0
  112. package/dist/active-citizen/scripts/translation_clear_language.js +117 -0
  113. package/dist/active-citizen/scripts/translation_delete.js +27 -0
  114. package/dist/active-citizen/scripts/translation_replace_text_from_url.js +180 -0
  115. package/dist/active-citizen/scripts/translation_update.js +28 -0
  116. package/dist/active-citizen/scripts/translations_list.js +27 -0
  117. package/{active-citizen/utils/airbrake.js → dist/active-citizen/utils/airbrake.cjs} +1 -1
  118. package/dist/active-citizen/utils/get_anonymous_system_user.cjs +21 -0
  119. package/dist/active-citizen/utils/i18n.cjs +3 -0
  120. package/dist/active-citizen/utils/logger.cjs +25 -0
  121. package/dist/active-citizen/utils/redisConnection.cjs +29 -0
  122. package/dist/active-citizen/utils/to_json.cjs +9 -0
  123. package/dist/active-citizen/utils/translation_cloning.cjs +171 -0
  124. package/dist/active-citizen/utils/translation_helpers.cjs +534 -0
  125. package/dist/active-citizen/utils/truncate_text.cjs +21 -0
  126. package/dist/active-citizen/utils/updateAllLocalesFromEn.js +253 -0
  127. package/dist/active-citizen/utils/updateLocaleFolders.js +34 -0
  128. package/dist/active-citizen/workers/activity.cjs +189 -0
  129. package/dist/active-citizen/workers/anonymizations.cjs +734 -0
  130. package/dist/active-citizen/workers/bulk_status_update.cjs +458 -0
  131. package/dist/active-citizen/workers/delayed_jobs.cjs +244 -0
  132. package/dist/active-citizen/workers/deletions.cjs +1911 -0
  133. package/dist/active-citizen/workers/email.cjs +9 -0
  134. package/dist/active-citizen/workers/fraud_management.cjs +109 -0
  135. package/dist/active-citizen/workers/generativeAi.js +56 -0
  136. package/dist/active-citizen/workers/main.cjs +89 -0
  137. package/dist/active-citizen/workers/marketing.cjs +25 -0
  138. package/dist/active-citizen/workers/moderation.cjs +73 -0
  139. package/dist/active-citizen/workers/notification_delivery.cjs +368 -0
  140. package/dist/active-citizen/workers/notification_news_feed.cjs +142 -0
  141. package/dist/active-citizen/workers/queue.cjs +99 -0
  142. package/dist/active-citizen/workers/recount.cjs +74 -0
  143. package/dist/active-citizen/workers/reports.cjs +42 -0
  144. package/dist/active-citizen/workers/similarities.cjs +21 -0
  145. package/dist/active-citizen/workers/speech_to_text.cjs +482 -0
  146. package/dist/agents/assistants/agentAssistant.js +88 -0
  147. package/dist/agents/assistants/baseAssistant.js +888 -0
  148. package/dist/agents/assistants/baseAssistantWithVoice.js +150 -0
  149. package/dist/agents/assistants/modes/agentDirectConnection.js +84 -0
  150. package/dist/agents/assistants/modes/agentSelectionMode.js +44 -0
  151. package/dist/agents/assistants/modes/baseAssistantMode.js +54 -0
  152. package/dist/agents/assistants/modes/tools/agentTools.js +447 -0
  153. package/dist/agents/assistants/modes/tools/baseTools.js +58 -0
  154. package/dist/agents/assistants/modes/tools/loginTools.js +156 -0
  155. package/dist/agents/assistants/modes/tools/models/agents.js +146 -0
  156. package/dist/agents/assistants/modes/tools/models/subscriptions.js +332 -0
  157. package/dist/agents/assistants/modes/tools/models/users.js +11 -0
  158. package/dist/agents/assistants/modes/tools/navigationTools.js +166 -0
  159. package/{agents/assistants/modes/tools/workflowConversationTools.js → dist/agents/assistants/modes/tools/subscriptionTools.js} +1 -4
  160. package/{agents/assistants/modes/tools/workflowTools.js → dist/agents/assistants/modes/tools/workflowConverstationTools.js} +1 -1
  161. package/dist/agents/assistants/voiceAssistant.js +619 -0
  162. package/dist/agents/controllers/agentProductController.js +103 -0
  163. package/dist/agents/controllers/agentSubscriptionController.js +261 -0
  164. package/dist/agents/controllers/assistantsController.js +511 -0
  165. package/dist/agents/controllers/policySynthAgents.js +395 -0
  166. package/{agents → dist/agents/managers}/agentProductManager.js +2 -2
  167. package/dist/agents/managers/emailInvitesManager.js +55 -0
  168. package/dist/agents/managers/emailTemplateRenderer.js +362 -0
  169. package/dist/agents/managers/newAiModelSetup.js +650 -0
  170. package/dist/agents/managers/notificationAgentQueueManager.js +510 -0
  171. package/dist/agents/managers/subscriptionManager.js +535 -0
  172. package/dist/agents/managers/workflowConversationManager.js +79 -0
  173. package/dist/agents/models/agentProduct.js +116 -0
  174. package/dist/agents/models/agentProductBoosterPurchase.js +58 -0
  175. package/dist/agents/models/agentProductBundle.js +68 -0
  176. package/dist/agents/models/agentProductRun.js +52 -0
  177. package/dist/agents/models/discount.js +88 -0
  178. package/dist/agents/models/subscription.js +79 -0
  179. package/dist/agents/models/subscriptionPlan.js +46 -0
  180. package/dist/agents/models/subscriptionUser.js +27 -0
  181. package/dist/agents/models/testData/createEvolyAgentProduct.js +477 -0
  182. package/dist/agents/models/testData/old/updateAgentWorkflowConfiguration.js +230 -0
  183. package/dist/agents/models/testData/setupEvolyAgentProductConfig.js +233 -0
  184. package/dist/agents/models/testData/updateAgentWorkflowConfiguration.js +230 -0
  185. package/{agents/models/workflowConverstation.js → dist/agents/models/workflowConversation.js} +1 -1
  186. package/{agents/tools/updateTemplateWorkflow.js → dist/agents/tools/setTemplateWorkflowCommunityId.js} +1 -0
  187. package/dist/app.js +943 -0
  188. package/dist/authorization.cjs +1860 -0
  189. package/dist/bot_control.js +1930 -0
  190. package/dist/config/config.cjs +14 -0
  191. package/dist/config/config.js +14 -0
  192. package/dist/controllers/allOurIdeas.js +696 -0
  193. package/dist/controllers/audios.cjs +100 -0
  194. package/dist/controllers/bulkStatusUpdates.cjs +202 -0
  195. package/dist/controllers/categories.cjs +199 -0
  196. package/dist/controllers/communities.cjs +2996 -0
  197. package/dist/controllers/domains.cjs +1341 -0
  198. package/dist/controllers/externalIds.cjs +223 -0
  199. package/dist/controllers/groups.cjs +4309 -0
  200. package/dist/controllers/images.cjs +499 -0
  201. package/dist/controllers/index.cjs +449 -0
  202. package/dist/controllers/legacyPages.cjs +35 -0
  203. package/dist/controllers/legacyPosts.cjs +56 -0
  204. package/dist/controllers/legacyUsers.cjs +36 -0
  205. package/dist/controllers/nonSpa.cjs +574 -0
  206. package/dist/controllers/organizations.cjs +250 -0
  207. package/dist/controllers/points.cjs +1137 -0
  208. package/dist/controllers/posts.cjs +2036 -0
  209. package/dist/controllers/ratings.cjs +234 -0
  210. package/dist/controllers/users.cjs +2255 -0
  211. package/dist/controllers/videos.cjs +226 -0
  212. package/dist/deleteUnwantedDeclerations.cjs +55 -0
  213. package/dist/migrations/agentAuditLogs.cjs +46 -0
  214. package/dist/migrations/agentClasses.cjs +60 -0
  215. package/dist/migrations/agentConnectorClasses.cjs +61 -0
  216. package/dist/migrations/agentConnectors.cjs +50 -0
  217. package/dist/migrations/agentEvals.cjs +45 -0
  218. package/dist/migrations/agentRegistries.cjs +40 -0
  219. package/dist/migrations/agents.cjs +54 -0
  220. package/dist/migrations/aiModels.cjs +49 -0
  221. package/dist/migrations/apiUsage.cjs +47 -0
  222. package/dist/migrations/apis.cjs +49 -0
  223. package/dist/migrations/groupPrivateData.cjs +30 -0
  224. package/dist/migrations/modelUsage.cjs +60 -0
  225. package/dist/migrations/oldMigrations/2019/20181030020612-AddActivitiesIndex.js +23 -0
  226. package/dist/migrations/oldMigrations/2019/20181102210612-AddFirstVideoFeatures.js +360 -0
  227. package/dist/migrations/oldMigrations/2019/20181212210612-ModerationFeatures.js +29 -0
  228. package/dist/migrations/oldMigrations/2019/2019010610612-CommunityFolders.js +43 -0
  229. package/dist/migrations/oldMigrations/2019/20190117020612-AddMissingIndexes.js +24 -0
  230. package/dist/migrations/oldMigrations/2019/20190117020612-RemoveUnusedIndexes.js +29 -0
  231. package/dist/migrations/oldMigrations/2019/20190127020612-RemoveUnusedIndexesPartThree.js +22 -0
  232. package/dist/migrations/oldMigrations/2019/20190127020612-RemoveUnusedIndexesPartTwo.js +23 -0
  233. package/{migrations/200824_create_embeddings_and_org_update.cjs → dist/migrations/oldMigrations/2019/20190223020612-AddPrivateProfileDataToUsers.js} +6 -3
  234. package/dist/migrations/oldMigrations/2019/20190706210612-AddCustomRatings.js +43 -0
  235. package/dist/migrations/oldMigrations/2019/20190829210612-AddGeneralStore.js +36 -0
  236. package/dist/migrations/oldMigrations/2019/20192811210612-AddAcClientActivities.js +41 -0
  237. package/dist/migrations/oldMigrations/2020/20190527020612-WorkOnIndexes.js +88 -0
  238. package/dist/migrations/oldMigrations/2020/20200409020612-AddBackgroundJob.js +33 -0
  239. package/dist/migrations/oldMigrations/2020/20200716210612-AddDataToCollections.js +38 -0
  240. package/dist/migrations/oldMigrations/2022/20220215100612-AddDataToEndorsements.js +19 -0
  241. package/dist/migrations/oldMigrations/2022/20220220100612-AddDataForFraudDetection.js +19 -0
  242. package/dist/migrations/oldMigrations/2022/20220903100612-AddPromotionFeatures.js +127 -0
  243. package/dist/migrations/oldMigrations/2022/onHold/20200527020612-AddCampaigns.js +68 -0
  244. package/dist/migrations/oldMigrations/2024/20241304175112-AddMediaSupportForHtmlGroups.cjs +63 -0
  245. package/dist/migrations/oldMigrations/older/20160511172514-AddNotificationFeatures.js +14 -0
  246. package/dist/migrations/oldMigrations/older/20161030020612-AddBulkStatusUpdate.js +71 -0
  247. package/dist/migrations/oldMigrations/older/20170514035258-add-metadata-to-invites.js +12 -0
  248. package/dist/migrations/oldMigrations/older/20180216020612-AddTranslationCaches.js +46 -0
  249. package/dist/migrations/oldMigrations/older/20180218210612-AddTranslationAndLanguages.js +46 -0
  250. package/dist/migrations/privateAccessStore.cjs +55 -0
  251. package/dist/migrations/zzz_associations.cjs +154 -0
  252. package/dist/migrations/zzzzz_create_agent_runs.cjs +606 -0
  253. package/dist/migrations/zzzzzz_create_agent_runs_fix.cjs +11 -0
  254. package/dist/migrations/zzzzzzz_create_trees.cjs +81 -0
  255. package/dist/models/audio.cjs +430 -0
  256. package/dist/models/bulk_status_update.cjs +58 -0
  257. package/dist/models/campaign.cjs +78 -0
  258. package/dist/models/category.cjs +94 -0
  259. package/dist/models/community.cjs +337 -0
  260. package/dist/models/domain.cjs +486 -0
  261. package/dist/models/endorsement.cjs +39 -0
  262. package/dist/models/general_data_store.cjs +20 -0
  263. package/dist/models/group.cjs +728 -0
  264. package/dist/models/image.cjs +579 -0
  265. package/dist/models/index.cjs +186 -0
  266. package/dist/models/invite.cjs +48 -0
  267. package/dist/models/iso_country.cjs +16 -0
  268. package/dist/models/organization.cjs +122 -0
  269. package/dist/models/page.cjs +273 -0
  270. package/dist/models/point.cjs +622 -0
  271. package/dist/models/point_quality.cjs +39 -0
  272. package/dist/models/point_revision.cjs +47 -0
  273. package/dist/models/post.cjs +680 -0
  274. package/dist/models/post_revision.cjs +38 -0
  275. package/dist/models/post_status_change.cjs +35 -0
  276. package/dist/models/promotion.cjs +34 -0
  277. package/dist/models/rating.cjs +51 -0
  278. package/dist/models/relationship.cjs +19 -0
  279. package/dist/models/request_to_join.cjs +20 -0
  280. package/dist/models/user.cjs +604 -0
  281. package/dist/models/user_legacy_password.cjs +13 -0
  282. package/dist/models/video.cjs +1137 -0
  283. package/dist/publish.js +40 -0
  284. package/dist/repack.js +53 -0
  285. package/dist/scripts/addRatingUsersToGroup.js +51 -0
  286. package/dist/scripts/addUserToOrganization.js +71 -0
  287. package/dist/scripts/analyseRatingsForCommunity.js +150 -0
  288. package/dist/scripts/analyzeAndFixBrokenPointUsers.js +28 -0
  289. package/dist/scripts/analyzeEndorsementsByCountry.js +70 -0
  290. package/dist/scripts/analyzePostsForCommunity.js +185 -0
  291. package/dist/scripts/bulkStatusUpdates/listUpdates.js +14 -0
  292. package/dist/scripts/bulkStatusUpdates/mergeLatestPostsToUpdate.js +110 -0
  293. package/dist/scripts/bulkStatusUpdates/performUpdate.js +116 -0
  294. package/{scripts/bulkStatusUpdates/performUpdateForGroup.js → dist/scripts/bulkStatusUpdates/performUpdateForGroup.cjs} +1 -2
  295. package/dist/scripts/bulkStatusUpdates/performUpdateForStatus.js +141 -0
  296. package/dist/scripts/change/changeVideoAspectTo.js +34 -0
  297. package/dist/scripts/change/setUseNewVersion.cjs +22 -0
  298. package/dist/scripts/changeCommunityGroupcount.js +30 -0
  299. package/dist/scripts/changeCommunityPostCount.js +30 -0
  300. package/dist/scripts/changeGroupPostCount.js +30 -0
  301. package/dist/scripts/changeLanguage.js +50 -0
  302. package/dist/scripts/changeOfficalStatus.js +30 -0
  303. package/{scripts/cleanups/deleteAnonNotifications.js → dist/scripts/cleanups/deleteAnonNotifications.cjs} +1 -1
  304. package/dist/scripts/cleanups/deleteLinkGroupsWithDeletedCommunities.js +62 -0
  305. package/dist/scripts/cleanups/deleteYearOldNotifications.cjs +72 -0
  306. package/dist/scripts/cleanups/removeAllUsersFromHiddenPublicGroup.js +43 -0
  307. package/dist/scripts/clearAllEndorsementInGroup.js +50 -0
  308. package/dist/scripts/cloning/clearUsersForCommunitiesFromUrl.js +129 -0
  309. package/dist/scripts/cloning/cloneFromUrlScript.js +65 -0
  310. package/dist/scripts/cloning/cloneWBFromUrlScriptAndCreateLinks.js +140 -0
  311. package/dist/scripts/cloning/cloneWBFromUrlScriptNoUsersOrPoints.js +140 -0
  312. package/dist/scripts/cloning/cloneWBSerbianFromUrlScriptAndCreateLinks.js +131 -0
  313. package/dist/scripts/cloning/copyCommunityConfigAndTranslationsFromURL.js +173 -0
  314. package/dist/scripts/cloning/copyCommunityOneGroupToDomainNoUsersNoEndorsements.js +18 -0
  315. package/dist/scripts/cloning/copyCommunityToDomainNoUsersNoEndorsements.js +17 -0
  316. package/dist/scripts/cloning/copyCommunityToDomainWithEverything.js +17 -0
  317. package/dist/scripts/cloning/copyCommunityToDomainWithOnlyGroups.js +26 -0
  318. package/dist/scripts/cloning/copyGroupConfigAndTranslationsFromURL.js +205 -0
  319. package/dist/scripts/cloning/copyPostToGroupOld.js +397 -0
  320. package/dist/scripts/cloning/copyPostVideosFromURL.js +236 -0
  321. package/dist/scripts/cloning/copyPostWithOutAnyVotingOrActivities.js +17 -0
  322. package/dist/scripts/cloning/deepCloneSerbianWBFromUrlScriptAndCreateLinks.js +131 -0
  323. package/dist/scripts/cloning/deepCloneWBFromUrlScriptAndCreateLinks.js +139 -0
  324. package/dist/scripts/cloning/setAdminsFromURL.js +161 -0
  325. package/dist/scripts/cloning/setExternalIdsFromURL.js +129 -0
  326. package/dist/scripts/countCommunity.js +291 -0
  327. package/dist/scripts/countCommunityUsers.js +152 -0
  328. package/dist/scripts/countDelayedNotifications.js +18 -0
  329. package/dist/scripts/countGroup.js +246 -0
  330. package/dist/scripts/countStuff.js +67 -0
  331. package/dist/scripts/countUniqueVotersInAGroup.js +48 -0
  332. package/dist/scripts/createInvitesAndShow.js +75 -0
  333. package/dist/scripts/database/sync_database.js +14 -0
  334. package/dist/scripts/database/sync_dev_database.js +17 -0
  335. package/dist/scripts/debugNotifications.js +58 -0
  336. package/dist/scripts/deleteAllNewsFeeds.js +10 -0
  337. package/dist/scripts/deleteCategory.js +13 -0
  338. package/dist/scripts/deleteOldAppActivities.js +40 -0
  339. package/dist/scripts/deletePostContactDataForCommunity.js +53 -0
  340. package/dist/scripts/destroy/destroy_all_but_one_domain.js +1026 -0
  341. package/dist/scripts/displayAuthorForPost.js +16 -0
  342. package/dist/scripts/endorsementFraudDetection/analyseEndorsementsForCommunity.js +183 -0
  343. package/dist/scripts/endorsementFraudDetection/bulkDeleteDuplicateEndorsmentsFromUrl.js +208 -0
  344. package/dist/scripts/exportAllStatusChanges.js +36 -0
  345. package/dist/scripts/exportClientAcitivity.js +36 -0
  346. package/dist/scripts/exportEndorsementsForCommunity.js +79 -0
  347. package/dist/scripts/exportPointQualitiesForCommunity.js +84 -0
  348. package/dist/scripts/exportPostsAndPointsForCommunity.js +147 -0
  349. package/dist/scripts/exportPostsDataSetForDomain.js +244 -0
  350. package/dist/scripts/exportPostsForGroup.js +173 -0
  351. package/dist/scripts/exportRatingsForPost.js +15 -0
  352. package/dist/scripts/exportUserEndorsementsWithUserAnalysis.js +123 -0
  353. package/dist/scripts/exportUsersForCommunity.js +24 -0
  354. package/dist/scripts/exportUsersForDomain.js +24 -0
  355. package/dist/scripts/exportUsersForGroup.js +24 -0
  356. package/dist/scripts/exports/ratingDistribution.js +71 -0
  357. package/dist/scripts/exports/whoEndorsedWhatByCommunity.js +56 -0
  358. package/dist/scripts/findUnusedClientImports.js +56 -0
  359. package/dist/scripts/fixAllPostPointCounts.js +22 -0
  360. package/dist/scripts/fixAnonNotificationsSettings.js +48 -0
  361. package/dist/scripts/fixCountKopavogur.js +9 -0
  362. package/dist/scripts/fixEndorsementsAfterCopyPostToGroup.js +190 -0
  363. package/dist/scripts/fixExternalUserId.js +24 -0
  364. package/dist/scripts/fixGroupAccess.js +16 -0
  365. package/dist/scripts/fixGroupIdeasAndPointsCount.js +49 -0
  366. package/dist/scripts/fixNotificationSettings.js +39 -0
  367. package/dist/scripts/fixSurveyRadioBakedInSubCodes.js +64 -0
  368. package/dist/scripts/fixWrongUserIdForStatusUpdates.js +49 -0
  369. package/dist/scripts/gallery/exportGalleryData.js +40 -0
  370. package/dist/scripts/gallery/importGalleryForCommunity.js +168 -0
  371. package/dist/scripts/gallery/readJsonAndDownloadImagesVersion2.js +55 -0
  372. package/dist/scripts/gallery/refreshAcApiPostIdsForCommunity.js +58 -0
  373. package/dist/scripts/genderAnalysis.js +63 -0
  374. package/dist/scripts/genderAnalysisByStatus.js +62 -0
  375. package/dist/scripts/importAllLocalesFromLocalFolders.js +55 -0
  376. package/dist/scripts/importDomain.js +1652 -0
  377. package/dist/scripts/keys/addOidcToDomain.cjs +61 -0
  378. package/dist/scripts/landUseGame/export3Ddata.js +162 -0
  379. package/dist/scripts/listLanguagesForGroup.js +54 -0
  380. package/dist/scripts/loadTestCreateDummyContentForGroup.js +27 -0
  381. package/dist/scripts/makeRecursiveMapData.js +103 -0
  382. package/dist/scripts/mapping/community_map_csv.js +145 -0
  383. package/dist/scripts/moveCommunityToDomain.js +22 -0
  384. package/dist/scripts/moveGroupToCommunity.js +23 -0
  385. package/dist/scripts/movePostToGroup.js +101 -0
  386. package/dist/scripts/movePostsToGroupsRecountGroupFromUrl.js +297 -0
  387. package/dist/scripts/oldMovePostToGroup.js +153 -0
  388. package/dist/scripts/processCsvForPdfUrls.js +37 -0
  389. package/dist/scripts/processCsvForTranslationAndToxicity.js +125 -0
  390. package/dist/scripts/recount/recount_recursive_communities.js +125 -0
  391. package/dist/scripts/recountALLCommunityGroupCounts.js +37 -0
  392. package/dist/scripts/recountAll.js +97 -0
  393. package/dist/scripts/recountCommunitesFromUrl.js +58 -0
  394. package/dist/scripts/recountCommunity.js +19 -0
  395. package/dist/scripts/recountGroup.js +218 -0
  396. package/dist/scripts/recountGroupNoUserChange.js +219 -0
  397. package/dist/scripts/resetAllEndorsementsForGroup.js +57 -0
  398. package/dist/scripts/resetEnTranslationForGroup.js +45 -0
  399. package/dist/scripts/setAdminOnAll.cjs +107 -0
  400. package/{scripts/change → dist/scripts}/setDomainAdmin.cjs +0 -2
  401. package/dist/scripts/setDomainLocales.js +33 -0
  402. package/dist/scripts/setEarlQuestionIdOnGroup.cjs +29 -0
  403. package/dist/scripts/setLanguageOnGroupCommunitesFromUrl.js +86 -0
  404. package/dist/scripts/setMemberOfAll.js +101 -0
  405. package/dist/scripts/setNewUserForContentOfCommunity.js +189 -0
  406. package/dist/scripts/setOfficialStatusOnAllPostsForCommunity.js +35 -0
  407. package/dist/scripts/setUserOnAll.js +101 -0
  408. package/dist/scripts/showCategoryForGroup.js +18 -0
  409. package/dist/scripts/showOldActivityTypes.js +14 -0
  410. package/dist/scripts/showPostsMissingCategoryForGroup.js +17 -0
  411. package/dist/scripts/showStatuses.js +17 -0
  412. package/dist/scripts/showUniqueVotersInCommunity.js +61 -0
  413. package/dist/scripts/showUserAgentsAndIpsForEmails.js +66 -0
  414. package/dist/scripts/simpleExportForGroupsForCommunity.js +46 -0
  415. package/dist/scripts/simpleExportForPointsForCommunity.js +82 -0
  416. package/dist/scripts/simpleExportForPostsForCommunity.js +61 -0
  417. package/dist/scripts/testForEndorsments.js +21 -0
  418. package/dist/scripts/undeleteGroupAndAllContent.js +151 -0
  419. package/dist/scripts/undeletePost.js +135 -0
  420. package/dist/scripts/unlinkSsn.js +23 -0
  421. package/dist/scripts/updateFromAlthingi.js +303 -0
  422. package/dist/server.js +3 -0
  423. package/dist/utils/airbrake.cjs +17 -0
  424. package/dist/utils/cjsCodeReview.js +99 -0
  425. package/dist/utils/community_mapping_tools.cjs +124 -0
  426. package/dist/utils/copy_utils.cjs +1399 -0
  427. package/dist/utils/docx_utils.cjs +464 -0
  428. package/dist/utils/export_utils.cjs +491 -0
  429. package/dist/utils/i18n.cjs +17 -0
  430. package/dist/utils/is_valid_db_id.cjs +28 -0
  431. package/dist/utils/logger.cjs +25 -0
  432. package/dist/utils/loggerTs.js +26 -0
  433. package/dist/utils/manifest_generator.cjs +104 -0
  434. package/dist/utils/parse_domain.cjs +16 -0
  435. package/dist/utils/recount_utils.cjs +415 -0
  436. package/dist/utils/sharing_parameters.cjs +111 -0
  437. package/dist/utils/sitemap_generator.cjs +286 -0
  438. package/dist/utils/to_json.cjs +14 -0
  439. package/dist/utils/ypLanguages.js +747 -0
  440. package/dist/webSockets.js +77 -0
  441. package/package.json +46 -44
  442. package/server.d.ts +104 -2
  443. package/utils/copy_utils.cjs +7 -1
  444. package/active-citizen/engine/allOurIdeas/aiHelper.d.ts +0 -21
  445. package/active-citizen/engine/allOurIdeas/aiHelper.d.ts.map +0 -1
  446. package/active-citizen/engine/allOurIdeas/explainAnswersAssistant.d.ts.map +0 -1
  447. package/active-citizen/engine/allOurIdeas/iconGenerator.d.ts +0 -12
  448. package/active-citizen/engine/allOurIdeas/iconGenerator.d.ts.map +0 -1
  449. package/active-citizen/engine/analytics/export_anon_community_activities.d.ts.map +0 -1
  450. package/active-citizen/engine/analytics/importer.d.ts.map +0 -1
  451. package/active-citizen/engine/old/exporters/categories_dataset.d.ts.map +0 -1
  452. package/active-citizen/engine/old/exporters/dataset_tools.d.ts.map +0 -1
  453. package/active-citizen/engine/old/exporters/sentiment_dataset.d.ts.map +0 -1
  454. package/active-citizen/engine/reports/xls_all_our_ideas_export.js +0 -141
  455. package/active-citizen/llms/baseChatBot.d.ts +0 -51
  456. package/active-citizen/llms/baseChatBot.d.ts.map +0 -1
  457. package/active-citizen/llms/collectionImageGenerator.js +0 -357
  458. package/active-citizen/llms/llmTranslation.d.ts +0 -24
  459. package/active-citizen/llms/llmTranslation.d.ts.map +0 -1
  460. package/active-citizen/scripts/fix_old_delayed_notifications.d.ts.map +0 -1
  461. package/active-citizen/scripts/kue_status.d.ts.map +0 -1
  462. package/active-citizen/scripts/kue_watch_stuck_jobs.d.ts.map +0 -1
  463. package/active-citizen/scripts/translation_clear_language.d.ts.map +0 -1
  464. package/active-citizen/scripts/translation_delete.d.ts.map +0 -1
  465. package/active-citizen/scripts/translation_replace_text_from_url.d.ts.map +0 -1
  466. package/active-citizen/scripts/translation_update.d.ts.map +0 -1
  467. package/active-citizen/scripts/translations_list.d.ts.map +0 -1
  468. package/active-citizen/utils/airbrake.d.ts.map +0 -1
  469. package/active-citizen/utils/updateAllLocalesFromEn.d.ts +0 -21
  470. package/active-citizen/utils/updateAllLocalesFromEn.d.ts.map +0 -1
  471. package/active-citizen/utils/updateLocaleFolders.d.ts +0 -2
  472. package/active-citizen/utils/updateLocaleFolders.d.ts.map +0 -1
  473. package/active-citizen/workers/cloudflare/voiceSession/worker.js +0 -213
  474. package/active-citizen/workers/generativeAi.d.ts.map +0 -1
  475. package/agents/assistants/agentAssistantOld.js +0 -863
  476. package/agents/assistants/modes/agentConfigurationMode.js +0 -63
  477. package/agents/assistants/modes/agentOperationsMode.js +0 -195
  478. package/agents/assistants/modes/commonTools.js +0 -58
  479. package/agents/assistants/modes/directConversationMode.js +0 -14
  480. package/agents/assistants/modes/toolHandlers/accountHandlers.js +0 -46
  481. package/agents/assistants/modes/toolHandlers/commonHandlers.js +0 -57
  482. package/agents/assistants/modes/toolHandlers/commonTools.js +0 -58
  483. package/agents/assistants/modes/toolHandlers/loginHandlers.js +0 -46
  484. package/agents/assistants/modes/toolHandlers/subscriptionHandlers.js +0 -469
  485. package/agents/assistants/modes/tools/agentConnectionTools.js +0 -326
  486. package/agents/assistants/modes/tools/commonHandlers.js +0 -57
  487. package/agents/assistants/modes/tools/loginHandlers.js +0 -46
  488. package/agents/assistants/modes/tools/subscriptionHandlers.js +0 -469
  489. package/agents/controllers/assistantController.js +0 -243
  490. package/agents/managers/workflowManager.js +0 -76
  491. package/agents/models/testData/setupConfig.js +0 -140
  492. package/agents/models/workflow.js +0 -53
  493. package/agents/subscriptionManager.js +0 -218
  494. package/app.d.ts +0 -40
  495. package/app.d.ts.map +0 -1
  496. package/bot_control.d.ts.map +0 -1
  497. package/publish.d.ts.map +0 -1
  498. package/repack.d.ts.map +0 -1
  499. package/scripts/addRatingUsersToGroup.d.ts.map +0 -1
  500. package/scripts/addUserToOrganization.d.ts.map +0 -1
  501. package/scripts/analyseRatingsForCommunity.d.ts.map +0 -1
  502. package/scripts/analyzeAndFixBrokenPointUsers.d.ts.map +0 -1
  503. package/scripts/analyzeEndorsementsByCountry.d.ts.map +0 -1
  504. package/scripts/analyzePostsForCommunity.d.ts.map +0 -1
  505. package/scripts/bulkStatusUpdates/listUpdates.d.ts.map +0 -1
  506. package/scripts/bulkStatusUpdates/mergeLatestPostsToUpdate.d.ts.map +0 -1
  507. package/scripts/bulkStatusUpdates/performUpdate.d.ts.map +0 -1
  508. package/scripts/bulkStatusUpdates/performUpdateForGroup.d.ts.map +0 -1
  509. package/scripts/bulkStatusUpdates/performUpdateForStatus.d.ts.map +0 -1
  510. package/scripts/change/changeVideoAspectTo.d.ts.map +0 -1
  511. package/scripts/changeCommunityGroupcount.d.ts.map +0 -1
  512. package/scripts/changeCommunityPostCount.d.ts.map +0 -1
  513. package/scripts/changeGroupPostCount.d.ts.map +0 -1
  514. package/scripts/changeLanguage.d.ts.map +0 -1
  515. package/scripts/changeOfficalStatus.d.ts.map +0 -1
  516. package/scripts/cleanups/deleteAnonNotifications.d.ts.map +0 -1
  517. package/scripts/cleanups/deleteLinkGroupsWithDeletedCommunities.d.ts.map +0 -1
  518. package/scripts/cleanups/removeAllUsersFromHiddenPublicGroup.d.ts.map +0 -1
  519. package/scripts/clearAllEndorsementInGroup.d.ts.map +0 -1
  520. package/scripts/cloning/clearUsersForCommunitiesFromUrl.d.ts.map +0 -1
  521. package/scripts/cloning/cloneFromUrlScript.d.ts.map +0 -1
  522. package/scripts/cloning/cloneWBFromUrlScriptAndCreateLinks.d.ts.map +0 -1
  523. package/scripts/cloning/cloneWBFromUrlScriptNoUsersOrPoints.d.ts.map +0 -1
  524. package/scripts/cloning/cloneWBSerbianFromUrlScriptAndCreateLinks.d.ts.map +0 -1
  525. package/scripts/cloning/copyCommunityConfigAndTranslationsFromURL.d.ts.map +0 -1
  526. package/scripts/cloning/copyCommunityOneGroupToDomainNoUsersNoEndorsements.d.ts.map +0 -1
  527. package/scripts/cloning/copyCommunityToDomainNoUsersNoEndorsements.d.ts.map +0 -1
  528. package/scripts/cloning/copyCommunityToDomainWithEverything.d.ts.map +0 -1
  529. package/scripts/cloning/copyCommunityToDomainWithOnlyGroups.d.ts.map +0 -1
  530. package/scripts/cloning/copyGroupConfigAndTranslationsFromURL.d.ts.map +0 -1
  531. package/scripts/cloning/copyPostToGroupOld.d.ts.map +0 -1
  532. package/scripts/cloning/copyPostVideosFromURL.d.ts.map +0 -1
  533. package/scripts/cloning/copyPostWithOutAnyVotingOrActivities.d.ts.map +0 -1
  534. package/scripts/cloning/deepCloneSerbianWBFromUrlScriptAndCreateLinks.d.ts.map +0 -1
  535. package/scripts/cloning/deepCloneWBFromUrlScriptAndCreateLinks.d.ts.map +0 -1
  536. package/scripts/cloning/setAdminsFromURL.d.ts.map +0 -1
  537. package/scripts/cloning/setExternalIdsFromURL.d.ts.map +0 -1
  538. package/scripts/countCommunity.d.ts.map +0 -1
  539. package/scripts/countCommunityUsers.d.ts.map +0 -1
  540. package/scripts/countDelayedNotifications.d.ts.map +0 -1
  541. package/scripts/countGroup.d.ts.map +0 -1
  542. package/scripts/countStuff.d.ts.map +0 -1
  543. package/scripts/countUniqueVotersInAGroup.d.ts.map +0 -1
  544. package/scripts/createInvitesAndShow.d.ts.map +0 -1
  545. package/scripts/database/seedTestAiModels.js +0 -64
  546. package/scripts/database/sync_database.d.ts.map +0 -1
  547. package/scripts/database/sync_dev_database.d.ts.map +0 -1
  548. package/scripts/debugNotifications.d.ts.map +0 -1
  549. package/scripts/deleteAllNewsFeeds.d.ts.map +0 -1
  550. package/scripts/deleteCategory.d.ts.map +0 -1
  551. package/scripts/deleteOldAppActivities.d.ts.map +0 -1
  552. package/scripts/deletePostContactDataForCommunity.d.ts.map +0 -1
  553. package/scripts/destroy/destroy_all_but_one_domain.d.ts.map +0 -1
  554. package/scripts/displayAuthorForPost.d.ts.map +0 -1
  555. package/scripts/endorsementFraudDetection/analyseEndorsementsForCommunity.d.ts.map +0 -1
  556. package/scripts/endorsementFraudDetection/bulkDeleteDuplicateEndorsmentsFromUrl.d.ts.map +0 -1
  557. package/scripts/exportAllStatusChanges.d.ts.map +0 -1
  558. package/scripts/exportClientAcitivity.d.ts.map +0 -1
  559. package/scripts/exportEndorsementsForCommunity.d.ts.map +0 -1
  560. package/scripts/exportPointQualitiesForCommunity.d.ts.map +0 -1
  561. package/scripts/exportPostsAndPointsForCommunity.d.ts.map +0 -1
  562. package/scripts/exportPostsDataSetForDomain.d.ts.map +0 -1
  563. package/scripts/exportPostsForGroup.d.ts.map +0 -1
  564. package/scripts/exportRatingsForPost.d.ts.map +0 -1
  565. package/scripts/exportUserEndorsementsWithUserAnalysis.d.ts.map +0 -1
  566. package/scripts/exportUsersForCommunity.d.ts.map +0 -1
  567. package/scripts/exportUsersForDomain.d.ts.map +0 -1
  568. package/scripts/exportUsersForGroup.d.ts.map +0 -1
  569. package/scripts/exports/ratingDistribution.d.ts.map +0 -1
  570. package/scripts/exports/whoEndorsedWhatByCommunity.d.ts.map +0 -1
  571. package/scripts/findUnusedClientImports.d.ts.map +0 -1
  572. package/scripts/fixAllPostPointCounts.d.ts.map +0 -1
  573. package/scripts/fixAnonNotificationsSettings.d.ts.map +0 -1
  574. package/scripts/fixCountKopavogur.d.ts.map +0 -1
  575. package/scripts/fixEndorsementsAfterCopyPostToGroup.d.ts.map +0 -1
  576. package/scripts/fixExternalUserId.d.ts.map +0 -1
  577. package/scripts/fixGroupAccess.d.ts.map +0 -1
  578. package/scripts/fixGroupIdeasAndPointsCount.d.ts.map +0 -1
  579. package/scripts/fixNotificationSettings.d.ts.map +0 -1
  580. package/scripts/fixSurveyRadioBakedInSubCodes.d.ts.map +0 -1
  581. package/scripts/fixWrongUserIdForStatusUpdates.d.ts.map +0 -1
  582. package/scripts/gallery/exportGalleryData.d.ts.map +0 -1
  583. package/scripts/gallery/importGalleryForCommunity.d.ts.map +0 -1
  584. package/scripts/gallery/readJsonAndDownloadImagesVersion2.d.ts.map +0 -1
  585. package/scripts/gallery/refreshAcApiPostIdsForCommunity.d.ts.map +0 -1
  586. package/scripts/genderAnalysis.d.ts.map +0 -1
  587. package/scripts/genderAnalysisByStatus.d.ts.map +0 -1
  588. package/scripts/importAllLocalesFromLocalFolders.d.ts.map +0 -1
  589. package/scripts/importDomain.d.ts.map +0 -1
  590. package/scripts/landUseGame/export3Ddata.d.ts.map +0 -1
  591. package/scripts/listLanguagesForGroup.d.ts.map +0 -1
  592. package/scripts/loadTestCreateDummyContentForGroup.d.ts.map +0 -1
  593. package/scripts/makeRecursiveMapData.d.ts.map +0 -1
  594. package/scripts/mapping/community_map_csv.d.ts.map +0 -1
  595. package/scripts/moveCommunityToDomain.d.ts.map +0 -1
  596. package/scripts/moveGroupToCommunity.d.ts.map +0 -1
  597. package/scripts/movePostToGroup.d.ts.map +0 -1
  598. package/scripts/movePostsToGroupsRecountGroupFromUrl.d.ts.map +0 -1
  599. package/scripts/oldMovePostToGroup.d.ts.map +0 -1
  600. package/scripts/processCsvForPdfUrls.d.ts.map +0 -1
  601. package/scripts/processCsvForTranslationAndToxicity.d.ts.map +0 -1
  602. package/scripts/recount/recount_recursive_communities.d.ts.map +0 -1
  603. package/scripts/recountALLCommunityGroupCounts.d.ts.map +0 -1
  604. package/scripts/recountAll.d.ts.map +0 -1
  605. package/scripts/recountCommunitesFromUrl.d.ts.map +0 -1
  606. package/scripts/recountCommunity.d.ts.map +0 -1
  607. package/scripts/recountGroup.d.ts.map +0 -1
  608. package/scripts/recountGroupNoUserChange.d.ts.map +0 -1
  609. package/scripts/resetAllEndorsementsForGroup.d.ts.map +0 -1
  610. package/scripts/resetEnTranslationForGroup.d.ts.map +0 -1
  611. package/scripts/setDomainLocales.d.ts.map +0 -1
  612. package/scripts/setLanguageOnGroupCommunitesFromUrl.d.ts.map +0 -1
  613. package/scripts/setMemberOfAll.d.ts.map +0 -1
  614. package/scripts/setNewUserForContentOfCommunity.d.ts.map +0 -1
  615. package/scripts/setOfficialStatusOnAllPostsForCommunity.d.ts.map +0 -1
  616. package/scripts/setUserOnAll.d.ts.map +0 -1
  617. package/scripts/showCategoryForGroup.d.ts.map +0 -1
  618. package/scripts/showOldActivityTypes.d.ts.map +0 -1
  619. package/scripts/showPostsMissingCategoryForGroup.d.ts.map +0 -1
  620. package/scripts/showStatuses.d.ts.map +0 -1
  621. package/scripts/showUniqueVotersInCommunity.d.ts.map +0 -1
  622. package/scripts/showUserAgentsAndIpsForEmails.d.ts.map +0 -1
  623. package/scripts/simpleExportForGroupsForCommunity.d.ts.map +0 -1
  624. package/scripts/simpleExportForPointsForCommunity.d.ts.map +0 -1
  625. package/scripts/simpleExportForPostsForCommunity.d.ts.map +0 -1
  626. package/scripts/testForEndorsments.d.ts.map +0 -1
  627. package/scripts/undeleteGroupAndAllContent.d.ts.map +0 -1
  628. package/scripts/undeletePost.d.ts.map +0 -1
  629. package/scripts/unlinkSsn.d.ts.map +0 -1
  630. package/scripts/updateFromAlthingi.d.ts.map +0 -1
  631. package/server.d.ts.map +0 -1
  632. package/utils/copyGroup.js +0 -246
  633. package/utils/loggerTs.d.ts +0 -4
  634. package/utils/loggerTs.d.ts.map +0 -1
  635. package/utils/ypLanguages.d.ts +0 -18
  636. package/utils/ypLanguages.d.ts.map +0 -1
  637. /package/{agents/tools/updateCommunityWorkflow.js → dist/active-citizen/llms/imageGeneration/iImageGenerator.js} +0 -0
  638. /package/{migrations/270724_createUsersAndAdminsForClasses.cjs → dist/migrations/zzzz_createUsersAndAdminsForClasses.cjs} +0 -0
@@ -0,0 +1,2255 @@
1
+ "use strict";
2
+ var async = require("async");
3
+ var crypto = require("crypto");
4
+ var express = require('express');
5
+ var router = express.Router();
6
+ var models = require("../models/index.cjs");
7
+ var passport = require('passport');
8
+ var auth = require('../authorization.cjs');
9
+ var log = require('../utils/logger.cjs');
10
+ var toJson = require('../utils/to_json.cjs');
11
+ var _ = require('lodash');
12
+ var queue = require('../active-citizen/workers/queue.cjs');
13
+ const url = require('url');
14
+ const randomstring = require('randomstring');
15
+ const { sendPlausibleFavicon } = require("../active-citizen/engine/analytics/plausible/manager.cjs");
16
+ var getAllModeratedItemsByUser = require('../active-citizen/engine/moderation/get_moderation_items.cjs').getAllModeratedItemsByUser;
17
+ const performSingleModerationAction = require('../active-citizen/engine/moderation/process_moderation_items.cjs').performSingleModerationAction;
18
+ const logoutFromSession = (req, res, statusCode = 200) => {
19
+ if (req.session) {
20
+ req.session.destroy((err) => {
21
+ if (err) {
22
+ log.error("Error on destroying session", { err });
23
+ return res.sendStatus(500);
24
+ }
25
+ res.clearCookie('yrpri.sid', { path: '/' });
26
+ log.info("Session destroyed successfully");
27
+ res.sendStatus(statusCode);
28
+ });
29
+ }
30
+ else {
31
+ res.sendStatus(statusCode);
32
+ }
33
+ };
34
+ var sendUserOrError = function (res, user, context, error, errorStatus) {
35
+ if (error || !user) {
36
+ if (errorStatus == 404) {
37
+ log.warn("User Not Found", { context: context, err: error, user: user,
38
+ errorStatus: 404 });
39
+ }
40
+ else {
41
+ log.error("User Error", { context: context, user: user, err: error,
42
+ errorStatus: errorStatus ? errorStatus : 500 });
43
+ }
44
+ if (errorStatus) {
45
+ res.status(errorStatus).send({ message: error ? error.name : "Unknown" });
46
+ }
47
+ else {
48
+ res.status(500).send({ message: error.name });
49
+ }
50
+ }
51
+ else {
52
+ delete user.dataValues.encrypted_password;
53
+ res.send(user);
54
+ }
55
+ };
56
+ var getUserWithAll = function (userId, getPrivateProfileData, callback) {
57
+ var user, endorsements, ratings, pointQualities;
58
+ //TODO: Optimize this and get those items above more on demand
59
+ let attributes = _.concat(models.User.defaultAttributesWithSocialMediaPublic, ['notifications_settings', 'profile_data', 'email', 'ssn', 'default_locale']);
60
+ if (getPrivateProfileData) {
61
+ attributes = _.concat(attributes, ['private_profile_data']);
62
+ }
63
+ async.parallel([
64
+ function (seriesCallback) {
65
+ models.User.findOne({
66
+ where: { id: userId },
67
+ attributes,
68
+ order: [
69
+ [{ model: models.Image, as: 'UserProfileImages' }, 'created_at', 'asc'],
70
+ [{ model: models.Image, as: 'UserHeaderImages' }, 'created_at', 'asc']
71
+ ],
72
+ include: [
73
+ {
74
+ model: models.Image, as: 'UserProfileImages',
75
+ attributes: ['id', 'created_at', 'formats'],
76
+ required: false
77
+ },
78
+ {
79
+ model: models.Image, as: 'UserHeaderImages',
80
+ attributes: ['id', 'created_at', 'formats'],
81
+ required: false
82
+ }
83
+ ]
84
+ }).then(function (userIn) {
85
+ user = userIn;
86
+ seriesCallback();
87
+ }).catch(function (error) {
88
+ seriesCallback(error);
89
+ });
90
+ },
91
+ function (seriesCallback) {
92
+ models.Endorsement.findAll({
93
+ where: { user_id: userId },
94
+ attributes: ['id', 'value', 'post_id'],
95
+ include: [
96
+ {
97
+ model: models.Post,
98
+ attributes: ['group_id']
99
+ }
100
+ ]
101
+ }).then(function (endorsementsIn) {
102
+ endorsements = endorsementsIn;
103
+ seriesCallback();
104
+ }).catch(function (error) {
105
+ seriesCallback(error);
106
+ });
107
+ },
108
+ function (seriesCallback) {
109
+ models.Rating.findAll({
110
+ where: {
111
+ user_id: userId
112
+ },
113
+ attributes: ['id', 'value', 'post_id', 'type_index']
114
+ }).then(function (ratingsIn) {
115
+ ratings = ratingsIn;
116
+ seriesCallback();
117
+ }).catch(function (error) {
118
+ seriesCallback(error);
119
+ });
120
+ },
121
+ function (seriesCallback) {
122
+ models.PointQuality.findAll({
123
+ where: { user_id: userId },
124
+ attributes: ['id', 'value', 'point_id']
125
+ }).then(function (pointQualitiesIn) {
126
+ pointQualities = pointQualitiesIn;
127
+ seriesCallback();
128
+ }).catch(function (error) {
129
+ seriesCallback(error);
130
+ });
131
+ }
132
+ ], function (error) {
133
+ if (user) {
134
+ user.dataValues.Endorsements = endorsements;
135
+ user.dataValues.PointQualities = pointQualities;
136
+ user.dataValues.Ratings = ratings;
137
+ }
138
+ callback(error, user);
139
+ });
140
+ };
141
+ // Login
142
+ router.post('/login', function (req, res) {
143
+ const startTime = new Date();
144
+ log.info('User Login start', { elapsedTime: (new Date() - startTime), userId: req.user ? req.user.id : null });
145
+ req.sso.authenticate('local-strategy', {}, req, res, function (err, user) {
146
+ log.info(`User Login before get ${req.user ? "HASUSER" : "NOUSER"}`, { elapsedTime: (new Date() - startTime), userId: req.user ? req.user.id : null });
147
+ getUserWithAll(req.user.id, true, async function (error, user) {
148
+ log.info('User Login completed', { elapsedTime: (new Date() - startTime), userId: req.user ? req.user.id : null });
149
+ if (error || !user) {
150
+ log.error("User Login Error", { context: 'login', user: user ? user.id : null, err: error, errorStatus: 500 });
151
+ res.sendStatus(500);
152
+ }
153
+ else {
154
+ if (user.email) {
155
+ delete user.email;
156
+ }
157
+ else {
158
+ user.missingEmail = true;
159
+ }
160
+ if (user.private_profile_data && user.private_profile_data.registration_answers) {
161
+ user.dataValues.hasRegistrationAnswers = true;
162
+ }
163
+ else {
164
+ user.dataValues.hasRegistrationAnswers = false;
165
+ }
166
+ delete user.private_profile_data;
167
+ //TODO: Without this hack there is a small chance the session is recreated each time due to some new Redis timing issue
168
+ await new Promise(resolve => setTimeout(resolve, 50));
169
+ res.send(user);
170
+ }
171
+ });
172
+ });
173
+ });
174
+ router.put('/setRegistrationAnswers', (req, res) => {
175
+ if (req.user) {
176
+ getUserWithAll(req.user.id, true, function (error, user) {
177
+ if (error) {
178
+ log.error("Error in setRegistrationAnswers", { error });
179
+ res.sendStatus(500);
180
+ }
181
+ else {
182
+ setUserProfileData(user, req.body.registration_answers);
183
+ user.save().then(() => {
184
+ log.info("Have set registration questions");
185
+ res.sendStatus(200);
186
+ }).catch(error => {
187
+ log.error("Error in setRegistrationAnswers", { error });
188
+ res.sendStatus(500);
189
+ });
190
+ }
191
+ });
192
+ }
193
+ else {
194
+ res.sendStatus(401);
195
+ }
196
+ });
197
+ const setUserProfileData = (user, profileData) => {
198
+ if (!user.private_profile_data) {
199
+ user.set('private_profile_data', {});
200
+ }
201
+ user.set('private_profile_data.registration_answers', profileData);
202
+ };
203
+ // Register
204
+ router.post('/register', function (req, res) {
205
+ var user = models.User.build({
206
+ email: req.body.email.toLowerCase(),
207
+ name: req.body.name,
208
+ notifications_settings: models.AcNotification.defaultNotificationSettings,
209
+ status: 'active'
210
+ });
211
+ user.createPasswordHash(req.body.password);
212
+ if (req.body.registration_answers) {
213
+ setUserProfileData(user, req.body.registration_answers);
214
+ user.dataValues.hasRegistrationAnswers = true;
215
+ }
216
+ else {
217
+ user.dataValues.hasRegistrationAnswers = false;
218
+ }
219
+ user.save().then(function () {
220
+ log.info('User Created', { user: toJson(user), context: 'create', loggedInUser: toJson(req.user) });
221
+ req.logIn(user, async function (error, detail) {
222
+ //TODO: Without this hack there is a small chance the session is recreated each time due to some new Redis timing issue
223
+ await new Promise(resolve => setTimeout(resolve, 50));
224
+ sendUserOrError(res, user, 'registerUser', error, 401);
225
+ });
226
+ }).catch(function (error) {
227
+ if (error && error.name == 'SequelizeUniqueConstraintError') {
228
+ log.error("User Error", { context: 'SequelizeUniqueConstraintError', user: user, err: error.name,
229
+ errorStatus: 401 });
230
+ res.status(401).send({ status: 401, message: error.name, type: 'internal' });
231
+ }
232
+ else {
233
+ sendUserOrError(res, null, 'create', error);
234
+ }
235
+ });
236
+ });
237
+ // Register anonymous
238
+ router.post('/register_anonymously', async function (req, res) {
239
+ try {
240
+ log.info("Anon debug in register_anonymously");
241
+ const groupId = req.body.groupId;
242
+ const oneTimeLoginName = req.body.oneTimeLoginName;
243
+ const group = await models.Group.findOne({
244
+ where: { id: groupId }
245
+ });
246
+ if (!group || !group.configuration ||
247
+ !(group.configuration.allowAnonymousUsers ||
248
+ group.configuration.allowOneTimeLoginWithName)) {
249
+ log.error("Tried to register to a group anonymously", {
250
+ context: 'register_anonymous',
251
+ err: "Group not found or anonymous users not allowed",
252
+ errorStatus: 401
253
+ });
254
+ return res.sendStatus(401);
255
+ }
256
+ const anonEmail = req.sessionID + "_anonymous@citizens.is";
257
+ let user = await models.User.findOne({
258
+ where: { email: anonEmail }
259
+ });
260
+ if (user && user.profile_data && user.profile_data.isAnonymousUser) {
261
+ log.info('Found Already Registered Anonymous', {
262
+ user: toJson(user),
263
+ context: 'register_anonymous'
264
+ });
265
+ }
266
+ else {
267
+ user = models.User.build({
268
+ email: anonEmail,
269
+ name: oneTimeLoginName ? oneTimeLoginName : "Anonymous User",
270
+ notifications_settings: models.AcNotification.anonymousNotificationSettings,
271
+ status: 'active'
272
+ });
273
+ // Match original profile_data setting pattern
274
+ user.set('profile_data', {});
275
+ user.set('profile_data.isAnonymousUser', true);
276
+ user.set('profile_data.trackingParameters', req.body.trackingParameters);
277
+ if (req.body.registration_answers) {
278
+ setUserProfileData(user, req.body.registration_answers);
279
+ user.dataValues.hasRegistrationAnswers = true;
280
+ }
281
+ else {
282
+ user.dataValues.hasRegistrationAnswers = false;
283
+ }
284
+ await user.save();
285
+ log.info('User Created Anonymous', {
286
+ user: toJson(user),
287
+ context: 'register_anonymous'
288
+ });
289
+ }
290
+ // Handle login with proper session management
291
+ await new Promise((resolve, reject) => {
292
+ req.logIn(user, function (error) {
293
+ if (error) {
294
+ reject(error);
295
+ }
296
+ else {
297
+ resolve();
298
+ }
299
+ });
300
+ });
301
+ //TODO: Without this hack the user session is recreated each time due to some new Redis timing issue
302
+ await new Promise(resolve => setTimeout(resolve, 100));
303
+ log.info("Successfully logged in anonymous user", {
304
+ sessionID: req.sessionID,
305
+ user: toJson(user)
306
+ });
307
+ sendUserOrError(res, user, 'registerUser', null, 401);
308
+ }
309
+ catch (error) {
310
+ log.error("Error in anonymous registration", {
311
+ context: 'register_anonymous',
312
+ err: error,
313
+ errorStatus: error.name == 'SequelizeUniqueConstraintError' ? 401 : 500
314
+ });
315
+ if (error.name == 'SequelizeUniqueConstraintError') {
316
+ res.status(401).send({
317
+ status: 401,
318
+ message: error.name,
319
+ type: 'internal'
320
+ });
321
+ }
322
+ else {
323
+ sendUserOrError(res, null, 'register_anonymous', error);
324
+ }
325
+ }
326
+ });
327
+ // Moderation
328
+ router.delete('/:userId/:itemId/:itemType/:actionType/process_one_moderation_item', auth.can('edit user'), (req, res) => {
329
+ performSingleModerationAction(req, res, {
330
+ userId: req.params.userId,
331
+ itemId: req.params.itemId,
332
+ itemType: req.params.itemType,
333
+ actionType: req.params.actionType
334
+ });
335
+ });
336
+ router.delete('/:userId/:actionType/process_many_moderation_item', auth.can('edit user'), (req, res) => {
337
+ queue.add('process-moderation', {
338
+ type: 'perform-many-moderation-actions',
339
+ items: req.body.items,
340
+ actionType: req.params.actionType,
341
+ userId: req.params.userId
342
+ }, 'critical');
343
+ res.send({});
344
+ });
345
+ router.get('/:userId/moderate_all_content', auth.can('edit user'), (req, res) => {
346
+ getAllModeratedItemsByUser({ userId: req.params.userId, allContent: true }, (error, items) => {
347
+ if (error) {
348
+ log.error("Error getting items for moderation", { error });
349
+ res.sendStatus(500);
350
+ }
351
+ else {
352
+ res.send(items);
353
+ }
354
+ });
355
+ });
356
+ // Edit User
357
+ router.put('/:id', auth.can('edit user'), function (req, res) {
358
+ models.User.findOne({
359
+ where: { id: req.params.id },
360
+ attributes: _.concat(models.User.defaultAttributesWithSocialMediaPublic, ['created_at', 'profile_data', 'notifications_settings'])
361
+ }).then(function (user) {
362
+ if (user) {
363
+ user.name = req.body.name;
364
+ user.email = req.body.email;
365
+ user.description = req.body.description;
366
+ user.notifications_settings = JSON.parse(req.body.notifications_settings);
367
+ if (user.profile_data && user.profile_data.isAnonymousUser) {
368
+ user.set('profile_data.isAnonymousUser', false);
369
+ }
370
+ user.save().then(function () {
371
+ log.info('User Updated', { user: toJson(user.simple()), context: 'update', loggedInUser: toJson(req.user.simple()) });
372
+ user.setupImages(req.body, function (error) {
373
+ sendUserOrError(res, user, 'setupImages', error);
374
+ });
375
+ }).catch((error) => {
376
+ log.error("User Error", { context: 'user_edit', err: error, errorStatus: 500 });
377
+ if (error.name === "SequelizeUniqueConstraintError") {
378
+ res.send({ duplicateEmail: true, isError: true });
379
+ }
380
+ else {
381
+ res.sendStatus(500);
382
+ }
383
+ });
384
+ }
385
+ else {
386
+ sendUserOrError(res, req.params.id, 'update', 'Not found', 404);
387
+ }
388
+ }).catch((error) => {
389
+ log.error("User Error", { context: 'user_edit', err: error, errorStatus: 500 });
390
+ res.sendStatus(500);
391
+ });
392
+ });
393
+ router.get('/:id', auth.can('edit user'), function (req, res) {
394
+ if (true) {
395
+ log.error("In Get User - Should not be called error", { context: 'user_get' });
396
+ res.sendStatus(401);
397
+ }
398
+ else {
399
+ var groupsInclude, communitiesInclude;
400
+ var where = {
401
+ id: req.params.id
402
+ };
403
+ groupsInclude = {
404
+ model: models.Group,
405
+ as: 'GroupUsers',
406
+ attributes: ['id', 'name', 'objectives'],
407
+ include: [
408
+ {
409
+ model: models.Image, as: 'GroupLogoImages',
410
+ attributes: ['id', 'formats'],
411
+ required: false
412
+ }
413
+ ]
414
+ };
415
+ communitiesInclude = {
416
+ model: models.Community,
417
+ as: 'CommunityUsers',
418
+ attributes: ['id', 'name', 'description'],
419
+ include: [
420
+ {
421
+ model: models.Image, as: 'CommunityLogoImages',
422
+ attributes: ['id', 'formats'],
423
+ required: false
424
+ }
425
+ ]
426
+ };
427
+ var attributes = ['id', 'name', 'description'];
428
+ if (req.user && req.user.id == req.params.id) {
429
+ attributes = _.concat(attributes, ['email']);
430
+ }
431
+ if (req.user && req.user.id == parseInt(req.params.id)) {
432
+ }
433
+ else {
434
+ _.merge(communitiesInclude, {
435
+ where: {
436
+ access: models.Community.ACCESS_PUBLIC
437
+ }
438
+ });
439
+ _.merge(groupsInclude, {
440
+ where: {
441
+ access: models.Group.ACCESS_PUBLIC
442
+ }
443
+ });
444
+ }
445
+ models.User.findOne({
446
+ where: where,
447
+ order: [
448
+ [{ model: models.Community, as: "CommunityUsers" }, 'counter_users', 'desc'],
449
+ [{ model: models.Community, as: "CommunityUsers" }, { model: models.Image, as: 'CommunityLogoImages' }, 'created_at', 'asc'],
450
+ [{ model: models.Group, as: "GroupUsers" }, { model: models.Image, as: 'GroupLogoImages' }, 'created_at', 'asc'],
451
+ [{ model: models.Group, as: "GroupUsers" }, 'counter_users', 'desc'],
452
+ [{ model: models.Image, as: 'UserProfileImages' }, 'created_at', 'asc'],
453
+ [{ model: models.Image, as: 'UserHeaderImages' }, 'created_at', 'asc']
454
+ ],
455
+ attributes: attributes,
456
+ include: [
457
+ communitiesInclude,
458
+ groupsInclude,
459
+ {
460
+ model: models.Image, as: 'UserProfileImages',
461
+ attributes: ['id', 'created_at', 'formats'],
462
+ required: false
463
+ },
464
+ {
465
+ model: models.Image, as: 'UserHeaderImages',
466
+ attributes: ['id', 'created_at', 'formats'],
467
+ required: false
468
+ }
469
+ ]
470
+ }).then(function (user) {
471
+ res.send(user);
472
+ }).catch(function (error) {
473
+ log.error("User Get Error", { context: 'user_get', err: error, errorStatus: 500 });
474
+ res.sendStatus(500);
475
+ });
476
+ }
477
+ });
478
+ const getDomainAdminAndUserIncludes = (req) => {
479
+ let groupAdminsOrUsersInclude, communityAdminsOrUsersInclude, domainAdminsOrUsersWhere;
480
+ domainAdminsOrUsersWhere = (req.clientIp.includes("::1") ||
481
+ req.clientIp.includes("127.0.0.1")) ? {} : {};
482
+ communityAdminsOrUsersInclude = [{
483
+ model: models.Domain,
484
+ attributes: [],
485
+ required: true,
486
+ where: domainAdminsOrUsersWhere
487
+ }];
488
+ groupAdminsOrUsersInclude = [
489
+ {
490
+ model: models.Community,
491
+ attributes: [],
492
+ required: true,
493
+ include: communityAdminsOrUsersInclude
494
+ }
495
+ ];
496
+ return { groupAdminsOrUsersInclude, communityAdminsOrUsersInclude, domainAdminsOrUsersWhere };
497
+ };
498
+ router.get('/loggedInUser/promoterRights', function (req, res) {
499
+ const { groupAdminsOrUsersInclude, communityAdminsOrUsersInclude } = getDomainAdminAndUserIncludes(req);
500
+ if (req.isAuthenticated() && req.user) {
501
+ var promoterAccess = {};
502
+ async.parallel([
503
+ function (seriesCallback) {
504
+ models.User.findOne({
505
+ where: { id: req.user.id },
506
+ attributes: ['id'],
507
+ include: [
508
+ {
509
+ model: models.Community,
510
+ as: 'CommunityPromoters',
511
+ attributes: ['id'],
512
+ through: {
513
+ attributes: []
514
+ },
515
+ required: false,
516
+ include: communityAdminsOrUsersInclude
517
+ }
518
+ ]
519
+ }).then(function (user) {
520
+ promoterAccess.CommunityPromoters = user.CommunityPromoters;
521
+ seriesCallback();
522
+ }).catch(function (error) {
523
+ seriesCallback(error);
524
+ });
525
+ },
526
+ function (seriesCallback) {
527
+ models.User.findOne({
528
+ where: { id: req.user.id },
529
+ attributes: ['id'],
530
+ include: [
531
+ {
532
+ model: models.Group,
533
+ as: 'GroupPromoters',
534
+ attributes: ['id'],
535
+ required: false,
536
+ through: {
537
+ attributes: []
538
+ },
539
+ include: groupAdminsOrUsersInclude
540
+ }
541
+ ]
542
+ }).then(function (user) {
543
+ promoterAccess.GroupPromoters = user.GroupPromoters;
544
+ seriesCallback();
545
+ }).catch(function (error) {
546
+ seriesCallback(error);
547
+ });
548
+ },
549
+ ], function (error) {
550
+ if (!error) {
551
+ log.info('User Sent Promoter Rights', { userId: req.user ? req.user.id : -1, context: 'promoterRights' });
552
+ if (promoterAccess.GroupPromoters.length === 0 &&
553
+ promoterAccess.CommunityPromoters.length === 0) {
554
+ res.send('0');
555
+ }
556
+ else {
557
+ res.send(promoterAccess);
558
+ }
559
+ }
560
+ else {
561
+ log.error("User promoterRights Error", { context: 'promoterRights', err: error, errorStatus: 500 });
562
+ res.sendStatus(500);
563
+ }
564
+ });
565
+ }
566
+ else {
567
+ log.info('Not Logged in', { context: 'promoterRights' });
568
+ res.send('0');
569
+ }
570
+ });
571
+ router.get('/loggedInUser/adminRights', function (req, res) {
572
+ const { groupAdminsOrUsersInclude, communityAdminsOrUsersInclude, domainAdminsOrUsersWhere } = getDomainAdminAndUserIncludes(req);
573
+ if (req.isAuthenticated() && req.user) {
574
+ var adminAccess = {};
575
+ async.parallel([
576
+ function (seriesCallback) {
577
+ models.User.findOne({
578
+ where: { id: req.user.id },
579
+ attributes: ['id'],
580
+ include: [
581
+ {
582
+ model: models.Domain,
583
+ as: 'DomainAdmins',
584
+ attributes: ['id'],
585
+ through: {
586
+ attributes: []
587
+ },
588
+ required: false,
589
+ where: domainAdminsOrUsersWhere
590
+ }
591
+ ]
592
+ }).then(function (user) {
593
+ adminAccess.DomainAdmins = user.DomainAdmins;
594
+ seriesCallback();
595
+ }).catch(function (error) {
596
+ seriesCallback(error);
597
+ });
598
+ },
599
+ function (seriesCallback) {
600
+ models.User.findOne({
601
+ where: { id: req.user.id },
602
+ attributes: ['id'],
603
+ include: [
604
+ {
605
+ model: models.Community,
606
+ as: 'CommunityAdmins',
607
+ attributes: ['id'],
608
+ through: {
609
+ attributes: []
610
+ },
611
+ required: false,
612
+ include: communityAdminsOrUsersInclude
613
+ }
614
+ ]
615
+ }).then(function (user) {
616
+ adminAccess.CommunityAdmins = user.CommunityAdmins;
617
+ seriesCallback();
618
+ }).catch(function (error) {
619
+ seriesCallback(error);
620
+ });
621
+ },
622
+ function (seriesCallback) {
623
+ models.User.findOne({
624
+ where: { id: req.user.id },
625
+ attributes: ['id'],
626
+ include: [
627
+ {
628
+ model: models.Group,
629
+ as: 'GroupAdmins',
630
+ attributes: ['id'],
631
+ required: false,
632
+ through: {
633
+ attributes: []
634
+ },
635
+ include: groupAdminsOrUsersInclude
636
+ }
637
+ ]
638
+ }).then(function (user) {
639
+ adminAccess.GroupAdmins = user.GroupAdmins;
640
+ seriesCallback();
641
+ }).catch(function (error) {
642
+ seriesCallback(error);
643
+ });
644
+ },
645
+ function (seriesCallback) {
646
+ models.User.findOne({
647
+ where: { id: req.user.id },
648
+ attributes: ['id'],
649
+ include: [
650
+ {
651
+ model: models.Organization,
652
+ as: 'OrganizationAdmins',
653
+ through: {
654
+ attributes: []
655
+ },
656
+ attributes: ['id', 'name'],
657
+ required: false
658
+ }
659
+ ]
660
+ }).then(function (user) {
661
+ adminAccess.OrganizationAdmins = user.OrganizationAdmins;
662
+ seriesCallback();
663
+ }).catch(function (error) {
664
+ seriesCallback(error);
665
+ });
666
+ }
667
+ ], function (error) {
668
+ if (!error) {
669
+ log.info('User Sent Admin Rights', { userId: req.user ? req.user.id : -1, context: 'adminRights' });
670
+ if (adminAccess.OrganizationAdmins.length === 0 &&
671
+ adminAccess.GroupAdmins.length === 0 &&
672
+ adminAccess.CommunityAdmins.length === 0 &&
673
+ adminAccess.DomainAdmins.length === 0) {
674
+ res.send('0');
675
+ }
676
+ else {
677
+ res.send(adminAccess);
678
+ }
679
+ }
680
+ else {
681
+ log.error("User AdminRights Error", { context: 'adminRights', err: error, errorStatus: 500 });
682
+ res.sendStatus(500);
683
+ }
684
+ });
685
+ }
686
+ else {
687
+ log.info('Not Logged in', { context: 'adminRights' });
688
+ res.send('0');
689
+ }
690
+ });
691
+ router.get('/loggedInUser/adminRightsWithNames', function (req, res) {
692
+ const { communityAdminsOrUsersInclude, domainAdminsOrUsersWhere } = getDomainAdminAndUserIncludes(req);
693
+ if (req.isAuthenticated() && req.user) {
694
+ var adminAccess = {};
695
+ async.parallel([
696
+ function (seriesCallback) {
697
+ models.User.findOne({
698
+ where: { id: req.user.id },
699
+ attributes: ['id'],
700
+ order: [
701
+ [{ model: models.Domain, as: 'DomainAdmins' }, 'updated_at', 'desc']
702
+ ],
703
+ include: [
704
+ {
705
+ model: models.Domain,
706
+ as: 'DomainAdmins',
707
+ attributes: ['id', 'name', 'updated_at'],
708
+ through: {
709
+ attributes: []
710
+ },
711
+ required: false,
712
+ where: domainAdminsOrUsersWhere
713
+ }
714
+ ]
715
+ }).then(function (user) {
716
+ adminAccess.DomainAdmins = user.DomainAdmins;
717
+ seriesCallback();
718
+ }).catch(function (error) {
719
+ seriesCallback(error);
720
+ });
721
+ },
722
+ function (seriesCallback) {
723
+ models.User.findOne({
724
+ where: { id: req.user.id },
725
+ attributes: ['id'],
726
+ order: [
727
+ [{ model: models.Community, as: 'CommunityAdmins' }, 'updated_at', 'desc']
728
+ ],
729
+ include: [
730
+ {
731
+ model: models.Community,
732
+ as: 'CommunityAdmins',
733
+ attributes: ['id', 'name', 'updated_at'],
734
+ through: {
735
+ attributes: []
736
+ },
737
+ required: false,
738
+ include: communityAdminsOrUsersInclude
739
+ }
740
+ ]
741
+ }).then(function (user) {
742
+ adminAccess.CommunityAdmins = _.take(user.CommunityAdmins, req.query.getAll ? 1000000 : 500);
743
+ seriesCallback();
744
+ }).catch(function (error) {
745
+ seriesCallback(error);
746
+ });
747
+ },
748
+ function (seriesCallback) {
749
+ models.User.findOne({
750
+ where: { id: req.user.id },
751
+ attributes: ['id'],
752
+ order: [
753
+ [{ model: models.Group, as: 'GroupAdmins' }, 'updated_at', 'desc']
754
+ ],
755
+ include: [
756
+ {
757
+ model: models.Group,
758
+ as: 'GroupAdmins',
759
+ attributes: ['id', 'name', 'configuration', 'updated_at'],
760
+ through: {
761
+ attributes: []
762
+ },
763
+ required: false,
764
+ where: {
765
+ configuration: {
766
+ actAsLinkToCommunityId: null
767
+ }
768
+ },
769
+ include: [
770
+ {
771
+ model: models.Community,
772
+ attributes: ['id', 'name', 'domain_id', 'updated_at'],
773
+ required: true,
774
+ include: communityAdminsOrUsersInclude
775
+ }
776
+ ]
777
+ }
778
+ ]
779
+ }).then(function (user) {
780
+ adminAccess.GroupAdmins = _.take(user.GroupAdmins, req.query.getAll ? 1000000 : 500);
781
+ seriesCallback();
782
+ }).catch(function (error) {
783
+ seriesCallback(error);
784
+ });
785
+ },
786
+ function (seriesCallback) {
787
+ models.User.findOne({
788
+ where: { id: req.user.id },
789
+ attributes: ['id'],
790
+ order: [
791
+ [{ model: models.Organization, as: 'OrganizationAdmins' }, 'updated_at', 'desc']
792
+ ],
793
+ include: [
794
+ {
795
+ model: models.Organization,
796
+ as: 'OrganizationAdmins',
797
+ attributes: ['id', 'name', 'description', 'website', 'access', 'updated_at'],
798
+ required: false
799
+ }
800
+ ]
801
+ }).then(function (user) {
802
+ adminAccess.OrganizationAdmins = user.OrganizationAdmins;
803
+ seriesCallback();
804
+ }).catch(function (error) {
805
+ seriesCallback(error);
806
+ });
807
+ }
808
+ ], function (error) {
809
+ if (!error) {
810
+ log.info('User Sent Admin Rights', { userId: req.user ? req.user.id : -1, context: 'adminRights' });
811
+ if (adminAccess.OrganizationAdmins.length === 0 &&
812
+ adminAccess.GroupAdmins.length === 0 &&
813
+ adminAccess.CommunityAdmins.length === 0 &&
814
+ adminAccess.DomainAdmins.length === 0) {
815
+ res.send('0');
816
+ }
817
+ else {
818
+ res.send(adminAccess);
819
+ }
820
+ }
821
+ else {
822
+ log.error("User AdminRights Error", { context: 'adminRights', err: error, errorStatus: 500 });
823
+ res.sendStatus(500);
824
+ }
825
+ });
826
+ }
827
+ else {
828
+ log.info('Not Logged in', { context: 'adminRights' });
829
+ res.send('0');
830
+ }
831
+ });
832
+ router.get('/loggedInUser/memberships', function (req, res) {
833
+ const { groupAdminsOrUsersInclude, communityAdminsOrUsersInclude, domainAdminsOrUsersWhere } = getDomainAdminAndUserIncludes(req);
834
+ if (req.isAuthenticated() && req.user) {
835
+ var memberships = {};
836
+ async.parallel([
837
+ function (seriesCallback) {
838
+ models.User.findOne({
839
+ where: { id: req.user.id },
840
+ attributes: ['id'],
841
+ include: [
842
+ {
843
+ model: models.Domain,
844
+ as: 'DomainUsers',
845
+ through: {
846
+ attributes: []
847
+ },
848
+ attributes: ['id'],
849
+ required: false,
850
+ where: domainAdminsOrUsersWhere
851
+ }
852
+ ]
853
+ }).then(function (user) {
854
+ memberships.DomainUsers = user.DomainUsers;
855
+ seriesCallback();
856
+ }).catch(function (error) {
857
+ seriesCallback(error);
858
+ });
859
+ },
860
+ function (seriesCallback) {
861
+ models.User.findOne({
862
+ where: { id: req.user.id },
863
+ attributes: ['id'],
864
+ include: [
865
+ {
866
+ model: models.Community,
867
+ as: 'CommunityUsers',
868
+ through: {
869
+ attributes: []
870
+ },
871
+ attributes: ['id'],
872
+ required: false,
873
+ include: communityAdminsOrUsersInclude
874
+ }
875
+ ]
876
+ }).then(function (user) {
877
+ memberships.CommunityUsers = user.CommunityUsers;
878
+ seriesCallback();
879
+ }).catch(function (error) {
880
+ seriesCallback(error);
881
+ });
882
+ },
883
+ function (seriesCallback) {
884
+ models.User.findOne({
885
+ where: { id: req.user.id },
886
+ attributes: ['id'],
887
+ include: [
888
+ {
889
+ model: models.Group,
890
+ as: 'GroupUsers',
891
+ through: {
892
+ attributes: []
893
+ },
894
+ attributes: ['id'],
895
+ required: false,
896
+ include: groupAdminsOrUsersInclude
897
+ }
898
+ ]
899
+ }).then(function (user) {
900
+ memberships.GroupUsers = user.GroupUsers;
901
+ seriesCallback();
902
+ }).catch(function (error) {
903
+ seriesCallback(error);
904
+ });
905
+ },
906
+ function (seriesCallback) {
907
+ models.User.findOne({
908
+ where: { id: req.user.id },
909
+ attributes: ['id'],
910
+ include: [
911
+ {
912
+ model: models.Organization,
913
+ as: 'OrganizationUsers',
914
+ through: {
915
+ attributes: []
916
+ },
917
+ attributes: ['id'],
918
+ required: false
919
+ }
920
+ ]
921
+ }).then(function (user) {
922
+ memberships.OrganizationUsers = user.OrganizationUsers;
923
+ seriesCallback();
924
+ }).catch(function (error) {
925
+ seriesCallback(error);
926
+ });
927
+ }
928
+ ], function (error) {
929
+ if (!error) {
930
+ log.info('User Sent Memberships', { userId: req.user ? req.user.id : -1, context: 'memberships' });
931
+ res.send(memberships);
932
+ }
933
+ else {
934
+ log.error("User Memberships Error", { context: 'memberships', err: error, errorStatus: 500 });
935
+ res.sendStatus(500);
936
+ }
937
+ });
938
+ }
939
+ else {
940
+ log.info('Not Logged in', { context: 'memberships' });
941
+ res.send('0');
942
+ }
943
+ });
944
+ router.get('/loggedInUser/membershipsWithNames', function (req, res) {
945
+ const { communityAdminsOrUsersInclude, domainAdminsOrUsersWhere } = getDomainAdminAndUserIncludes(req);
946
+ if (req.isAuthenticated() && req.user) {
947
+ var memberships = {};
948
+ async.parallel([
949
+ function (seriesCallback) {
950
+ models.User.findOne({
951
+ where: { id: req.user.id },
952
+ attributes: ['id'],
953
+ order: [
954
+ [{ model: models.Domain, as: 'DomainUsers' }, 'updated_at', 'desc']
955
+ ],
956
+ include: [
957
+ {
958
+ model: models.Domain,
959
+ as: 'DomainUsers',
960
+ through: {
961
+ attributes: []
962
+ },
963
+ attributes: ['id', 'name', 'counter_users', 'updated_at'],
964
+ required: false,
965
+ where: domainAdminsOrUsersWhere
966
+ }
967
+ ]
968
+ }).then(function (user) {
969
+ memberships.DomainUsers = user.DomainUsers;
970
+ seriesCallback();
971
+ }).catch(function (error) {
972
+ seriesCallback(error);
973
+ });
974
+ },
975
+ function (seriesCallback) {
976
+ models.User.findOne({
977
+ where: { id: req.user.id },
978
+ attributes: ['id'],
979
+ order: [
980
+ [{ model: models.Community, as: 'CommunityUsers' }, 'updated_at', 'desc']
981
+ ],
982
+ include: [
983
+ {
984
+ model: models.Community,
985
+ as: 'CommunityUsers',
986
+ attributes: ['id', 'name', 'counter_users', 'updated_at'],
987
+ required: false,
988
+ include: communityAdminsOrUsersInclude
989
+ }
990
+ ]
991
+ }).then(function (user) {
992
+ memberships.CommunityUsers = user.CommunityUsers;
993
+ seriesCallback();
994
+ }).catch(function (error) {
995
+ seriesCallback(error);
996
+ });
997
+ },
998
+ function (seriesCallback) {
999
+ models.User.findOne({
1000
+ where: { id: req.user.id },
1001
+ attributes: ['id'],
1002
+ order: [
1003
+ [{ model: models.Group, as: 'GroupUsers' }, 'updated_at', 'desc']
1004
+ ],
1005
+ include: [
1006
+ {
1007
+ model: models.Group,
1008
+ as: 'GroupUsers',
1009
+ attributes: ['id', 'name', 'counter_users', 'configuration', 'updated_at'],
1010
+ through: {
1011
+ attributes: []
1012
+ },
1013
+ required: false,
1014
+ where: {
1015
+ configuration: {
1016
+ actAsLinkToCommunityId: null
1017
+ }
1018
+ },
1019
+ include: [
1020
+ {
1021
+ model: models.Community,
1022
+ attributes: ['id', 'name', 'domain_id', 'updated_at'],
1023
+ required: true,
1024
+ include: communityAdminsOrUsersInclude
1025
+ }
1026
+ ]
1027
+ }
1028
+ ]
1029
+ }).then(function (user) {
1030
+ memberships.GroupUsers = user.GroupUsers;
1031
+ seriesCallback();
1032
+ }).catch(function (error) {
1033
+ seriesCallback(error);
1034
+ });
1035
+ },
1036
+ function (seriesCallback) {
1037
+ models.User.findOne({
1038
+ where: { id: req.user.id },
1039
+ attributes: ['id'],
1040
+ include: [
1041
+ {
1042
+ model: models.Organization,
1043
+ as: 'OrganizationUsers',
1044
+ through: {
1045
+ attributes: []
1046
+ },
1047
+ attributes: ['id', 'name'],
1048
+ required: false
1049
+ }
1050
+ ]
1051
+ }).then(function (user) {
1052
+ memberships.OrganizationUsers = user.OrganizationUsers;
1053
+ seriesCallback();
1054
+ }).catch(function (error) {
1055
+ seriesCallback(error);
1056
+ });
1057
+ }
1058
+ ], function (error) {
1059
+ if (!error) {
1060
+ log.info('User Sent Memberships', { userId: req.user ? req.user.id : -1, context: 'memberships' });
1061
+ res.send(memberships);
1062
+ }
1063
+ else {
1064
+ log.error("User Memberships Error", { context: 'memberships', err: error, errorStatus: 500 });
1065
+ res.sendStatus(500);
1066
+ }
1067
+ });
1068
+ }
1069
+ else {
1070
+ log.info('Not Logged in', { context: 'memberships' });
1071
+ res.send('0');
1072
+ }
1073
+ });
1074
+ router.put('/loggedInUser/setLocale', function (req, res) {
1075
+ if (req.isAuthenticated() && req.user) {
1076
+ getUserWithAll(req.user.id, false, function (error, user) {
1077
+ if (error || !user) {
1078
+ log.error("User setLocale Error", { context: 'setLocale', user: req.user.id, err: error, errorStatus: 500 });
1079
+ res.sendStatus(500);
1080
+ }
1081
+ else {
1082
+ user.set('default_locale', req.body.locale);
1083
+ user.save().then(function (user) {
1084
+ log.info("User setLocale", { context: 'setLocale', user: req.user.id });
1085
+ res.sendStatus(200);
1086
+ }).catch(function (error) {
1087
+ log.error("User setLocale Error", { context: 'setLocale', user: req.user.id, err: error, errorStatus: 500 });
1088
+ res.sendStatus(500);
1089
+ });
1090
+ }
1091
+ });
1092
+ }
1093
+ else {
1094
+ res.send('0');
1095
+ }
1096
+ });
1097
+ const setSAMLSettingsOnUser = (req, user, done) => {
1098
+ let forceSecureSamlLogin = null;
1099
+ let customSamlLoginMessage = null;
1100
+ let customSamlDeniedMessage = null;
1101
+ const referrer = req.get('Referrer');
1102
+ let id = null;
1103
+ let urlComponents;
1104
+ if (referrer) {
1105
+ urlComponents = url.parse(referrer);
1106
+ }
1107
+ else {
1108
+ log.warn("Can't find referrer for URL when setting up SAML");
1109
+ }
1110
+ if (urlComponents && urlComponents.pathname && urlComponents.pathname.split("/").length > 1) {
1111
+ if (urlComponents.pathname.split("/").length > 3)
1112
+ id = urlComponents.pathname.split("/")[3];
1113
+ else
1114
+ id = urlComponents.pathname.split("/")[2];
1115
+ }
1116
+ let community, group, isGroupAdmin, isCommunityAdmin;
1117
+ if (isNaN(id)) {
1118
+ id = undefined;
1119
+ }
1120
+ async.parallel([
1121
+ (parallelCallback) => {
1122
+ if (id && referrer.indexOf("/community/") > -1) {
1123
+ models.Community.findOne({
1124
+ where: {
1125
+ id: id
1126
+ },
1127
+ attributes: ['id', 'configuration']
1128
+ }).then((communityIn) => {
1129
+ community = communityIn;
1130
+ parallelCallback();
1131
+ }).catch((error) => {
1132
+ parallelCallback(error);
1133
+ });
1134
+ }
1135
+ else {
1136
+ parallelCallback();
1137
+ }
1138
+ },
1139
+ (parallelCallback) => {
1140
+ if (id && referrer.indexOf("/group/") > -1) {
1141
+ models.Group.findOne({
1142
+ where: {
1143
+ id: id
1144
+ },
1145
+ attributes: ['id', 'configuration'],
1146
+ include: [
1147
+ {
1148
+ model: models.Community,
1149
+ attributes: ['id', 'configuration'],
1150
+ }
1151
+ ]
1152
+ }).then((groupIn) => {
1153
+ if (groupIn) {
1154
+ group = groupIn;
1155
+ community = groupIn.Community;
1156
+ }
1157
+ parallelCallback();
1158
+ }).catch((error) => {
1159
+ parallelCallback(error);
1160
+ });
1161
+ }
1162
+ else {
1163
+ parallelCallback();
1164
+ }
1165
+ },
1166
+ (parallelCallback) => {
1167
+ if (id && referrer.indexOf("/post/") > -1) {
1168
+ models.Post.findOne({
1169
+ where: {
1170
+ id: id
1171
+ },
1172
+ attributes: ['id'],
1173
+ include: [
1174
+ {
1175
+ model: models.Group,
1176
+ attributes: ['id', 'configuration'],
1177
+ include: [
1178
+ {
1179
+ model: models.Community,
1180
+ attributes: ['id', 'configuration'],
1181
+ }
1182
+ ]
1183
+ }
1184
+ ]
1185
+ }).then((postIn) => {
1186
+ if (postIn) {
1187
+ group = postIn.Group;
1188
+ community = postIn.Group.Community;
1189
+ }
1190
+ else {
1191
+ log.error("Can't find post for SAML setup");
1192
+ }
1193
+ parallelCallback();
1194
+ }).catch((error) => {
1195
+ parallelCallback(error);
1196
+ });
1197
+ }
1198
+ else {
1199
+ parallelCallback();
1200
+ }
1201
+ },
1202
+ (parallelCallback) => {
1203
+ if (group && req.user) {
1204
+ group.hasGroupAdmins(req.user).then((results) => {
1205
+ isGroupAdmin = results;
1206
+ parallelCallback();
1207
+ }).catch((error) => {
1208
+ parallelCallback(error);
1209
+ });
1210
+ }
1211
+ else {
1212
+ parallelCallback();
1213
+ }
1214
+ },
1215
+ (parallelCallback) => {
1216
+ if (community && req.user) {
1217
+ community.hasCommunityAdmins(req.user).then((results) => {
1218
+ isCommunityAdmin = results;
1219
+ parallelCallback();
1220
+ }).catch((error) => {
1221
+ parallelCallback(error);
1222
+ });
1223
+ }
1224
+ else {
1225
+ parallelCallback();
1226
+ }
1227
+ }
1228
+ ], (error) => {
1229
+ if (error) {
1230
+ done(error);
1231
+ }
1232
+ else {
1233
+ if (group && group.configuration && !isGroupAdmin) {
1234
+ if (group.configuration.forceSecureSamlLogin) {
1235
+ forceSecureSamlLogin = true;
1236
+ }
1237
+ }
1238
+ if (community && community.configuration && !isCommunityAdmin) {
1239
+ if (community.configuration.forceSecureSamlLogin) {
1240
+ forceSecureSamlLogin = true;
1241
+ }
1242
+ if (community.configuration.customSamlDeniedMessage) {
1243
+ customSamlDeniedMessage = community.configuration.customSamlDeniedMessage;
1244
+ }
1245
+ if (community.configuration.customSamlLoginMessage) {
1246
+ customSamlLoginMessage = community.configuration.customSamlLoginMessage;
1247
+ }
1248
+ }
1249
+ if (user.dataValues) {
1250
+ user.dataValues.forceSecureSamlLogin = forceSecureSamlLogin;
1251
+ user.dataValues.customSamlDeniedMessage = customSamlDeniedMessage;
1252
+ user.dataValues.customSamlLoginMessage = customSamlLoginMessage;
1253
+ }
1254
+ else {
1255
+ user.forceSecureSamlLogin = forceSecureSamlLogin;
1256
+ user.customSamlDeniedMessage = customSamlDeniedMessage;
1257
+ user.customSamlLoginMessage = customSamlLoginMessage;
1258
+ }
1259
+ done();
1260
+ }
1261
+ });
1262
+ };
1263
+ router.get('/loggedInUser/isloggedin', function (req, res) {
1264
+ if (req.isAuthenticated()) {
1265
+ log.info('Logged in', { userId: req.user ? req.user.id : -1, context: 'isLoggedIn' });
1266
+ }
1267
+ else {
1268
+ log.info('Not Logged in');
1269
+ }
1270
+ if (req.isAuthenticated() && req.user) {
1271
+ getUserWithAll(req.user.id, true, function (error, user) {
1272
+ if (error || !user) {
1273
+ log.error("User IsLoggedIn Error 1", { context: 'isloggedin', user: req.user.id, err: error, errorStatus: 500 });
1274
+ res.sendStatus(500);
1275
+ }
1276
+ else {
1277
+ if (user.email && user.email != "") {
1278
+ delete user.email;
1279
+ }
1280
+ else {
1281
+ user.dataValues.missingEmail = true;
1282
+ }
1283
+ if (user.private_profile_data && user.private_profile_data.registration_answers) {
1284
+ user.dataValues.hasRegistrationAnswers = true;
1285
+ }
1286
+ else {
1287
+ user.dataValues.hasRegistrationAnswers = false;
1288
+ }
1289
+ delete user.private_profile_data;
1290
+ if (req.user.loginProvider)
1291
+ user.dataValues.loginProvider = req.user.loginProvider;
1292
+ if (req.user.isSamlEmployee)
1293
+ user.dataValues.isSamlEmployee = req.user.isSamlEmployee;
1294
+ delete user.dataValues.private_profile_data;
1295
+ setSAMLSettingsOnUser(req, user, (error) => {
1296
+ if (error) {
1297
+ log.error("User IsLoggedIn Error 2", { context: 'isloggedin', user: req.user.id, err: error, errorStatus: 500 });
1298
+ res.sendStatus(500);
1299
+ }
1300
+ else {
1301
+ res.send(user);
1302
+ }
1303
+ });
1304
+ }
1305
+ });
1306
+ }
1307
+ else {
1308
+ const user = { notLoggedIn: true };
1309
+ setSAMLSettingsOnUser(req, user, (error) => {
1310
+ if (error) {
1311
+ log.error("User IsLoggedIn Error 3", { context: 'isloggedin', user: req.user ? req.user.id : -1, err: error, errorStatus: 500 });
1312
+ res.sendStatus(500);
1313
+ }
1314
+ else {
1315
+ res.send(user);
1316
+ }
1317
+ });
1318
+ }
1319
+ });
1320
+ router.delete('/delete_current_user', function (req, res) {
1321
+ if (req.isAuthenticated() && req.user) {
1322
+ log.info('Deleting user', { user: toJson(req.user), context: 'delete_current_user' });
1323
+ var userId = req.user.id;
1324
+ models.User.findOne({
1325
+ where: {
1326
+ id: userId
1327
+ }
1328
+ }).then(function (user) {
1329
+ if (user) {
1330
+ user.deleted = true;
1331
+ user.email = user.email + "_deleted_" + Math.floor(Math.random() * 9000);
1332
+ user.save().then(function () {
1333
+ log.info('User deleted', { context: 'delete', user: toJson(req.user) });
1334
+ queue.add('process-deletion', { type: 'delete-user-content', userId: userId }, 'critical');
1335
+ logoutFromSession(req, res);
1336
+ }).catch((error) => {
1337
+ log.error('User delete error', { error: error, user: toJson(req.user), context: 'delete_current_user' });
1338
+ res.sendStatus(500);
1339
+ });
1340
+ }
1341
+ else {
1342
+ log.error('User delete user not found', { error: error, user: toJson(req.user), context: 'delete_current_user' });
1343
+ res.sendStatus(404);
1344
+ }
1345
+ }).catch(function (error) {
1346
+ log.error('User delete error', { error: error, user: toJson(req.user), context: 'delete_current_user' });
1347
+ res.sendStatus(500);
1348
+ });
1349
+ }
1350
+ else {
1351
+ log.error('Trying to delete user but not logged in', { user: toJson(req.user), context: 'delete_current_user' });
1352
+ res.sendStatus(401);
1353
+ }
1354
+ });
1355
+ router.delete('/anonymize_current_user', function (req, res) {
1356
+ if (req.isAuthenticated()) {
1357
+ log.info('Anonymizing user', { user: toJson(req.user), context: 'delete_current_user' });
1358
+ var userId = req.user.id;
1359
+ models.User.findOne({
1360
+ where: {
1361
+ id: userId
1362
+ }
1363
+ }).then(function (user) {
1364
+ if (user) {
1365
+ user.email = user.email + "_anonymous_anonymized_" + Math.floor(Math.random() * 90000);
1366
+ user.name = "Anonymous";
1367
+ user.ssn = null;
1368
+ user.age_group = null;
1369
+ user.post_code = null;
1370
+ user.my_gender = null;
1371
+ user.description = null;
1372
+ user.facebook_id = null;
1373
+ user.facebook_profile = null;
1374
+ user.twitter_id = null;
1375
+ user.twitter_profile = null;
1376
+ user.google_id = null;
1377
+ user.google_profile = null;
1378
+ user.github_id = null;
1379
+ user.github_profile = null;
1380
+ user.counter_login = 0;
1381
+ user.buddy_icon_file_name = null;
1382
+ user.twitter_profile_image_url = null;
1383
+ user.interaction_profile = null;
1384
+ user.social_points = null;
1385
+ user.legacy_user_id = null;
1386
+ user.ignore_list = null;
1387
+ if (!user.profile_data)
1388
+ user.set('profile_data', {});
1389
+ user.set('profile_data.isAnonymousUser', true);
1390
+ user.setUserProfileImages([]).then(() => {
1391
+ user.save().then(function () {
1392
+ log.info('User anonymized', { context: 'delete', user: toJson(req.user) });
1393
+ queue.add('process-anonymization', { type: 'anonymize-user-content', userId: userId }, 'high');
1394
+ logoutFromSession(req, res);
1395
+ }).catch((error) => {
1396
+ log.error('User delete error', { error: error, user: toJson(req.user), context: 'delete_current_user' });
1397
+ logoutFromSession(req, res, 500);
1398
+ });
1399
+ }).catch((error) => {
1400
+ log.error('User delete error', { error: error, user: toJson(req.user), context: 'delete_current_user' });
1401
+ logoutFromSession(req, res, 500);
1402
+ });
1403
+ }
1404
+ else {
1405
+ log.error('User anonymize user not found', { error: error, user: toJson(req.user), context: 'delete_current_user' });
1406
+ res.sendStatus(404);
1407
+ }
1408
+ }).catch(function (error) {
1409
+ log.error('User anonymization error', { error: error, user: toJson(req.user), context: 'delete_current_user' });
1410
+ res.sendStatus(500);
1411
+ });
1412
+ }
1413
+ else {
1414
+ log.error('Trying to anonymize user but not logged in', { user: toJson(req.user), context: 'delete_current_user' });
1415
+ res.sendStatus(401);
1416
+ }
1417
+ });
1418
+ router.post('/logout', function (req, res) {
1419
+ log.info("Anon debug logout");
1420
+ if (req.isAuthenticated()) {
1421
+ log.info('User Logging out', { userId: req.user.id, context: 'logout' });
1422
+ }
1423
+ else {
1424
+ log.warn('User Logging out but not logged in', { context: 'logout' });
1425
+ }
1426
+ logoutFromSession(req, res);
1427
+ });
1428
+ // Reset password
1429
+ router.post('/forgot_password', function (req, res) {
1430
+ async.waterfall([
1431
+ function (done) {
1432
+ crypto.randomBytes(20, function (error, buf) {
1433
+ var token = buf.toString('hex');
1434
+ done(error, token);
1435
+ });
1436
+ },
1437
+ function (token, done) {
1438
+ models.User.findOne({
1439
+ where: { email: req.body.email.toLowerCase() },
1440
+ attributes: ['id', 'email', 'reset_password_token', 'reset_password_expires', 'legacy_passwords_disabled']
1441
+ }).then(function (user) {
1442
+ if (user) {
1443
+ user.reset_password_token = token;
1444
+ user.reset_password_expires = Date.now() + (3600000 * 240); // 10 days
1445
+ user.save().then(function () {
1446
+ log.info('User Reset Password Token Created', { user: toJson(user), context: 'forgotPassword', loggedInUser: toJson(req.user) });
1447
+ done(null, token, user);
1448
+ });
1449
+ }
1450
+ else {
1451
+ log.info('User Reset Password Token Not Found', { user: toJson(user), context: 'forgotPassword',
1452
+ loggedInUser: toJson(req.user), error: 'Token not found', errorStatus: 404 });
1453
+ res.sendStatus(404);
1454
+ return;
1455
+ }
1456
+ }).catch(function (error) {
1457
+ log.error('User Reset Password Token Error', { user: null, context: 'forgotPassword', loggedInUser: toJson(req.user), err: error, errorStatus: 500 });
1458
+ res.sendStatus(500);
1459
+ });
1460
+ },
1461
+ function (token, user, done) {
1462
+ models.AcActivity.createPasswordRecovery(user, req.ypDomain, req.ypCommunity, token, function (error) {
1463
+ done(error, token, user);
1464
+ });
1465
+ }
1466
+ ], function (error, token, user) {
1467
+ if (error) {
1468
+ log.error('User Reset Password Token Error', { user: toJson(user), context: 'forgotPassword', loggedInUser: toJson(req.user), err: error, errorStatus: 500 });
1469
+ res.sendStatus(500);
1470
+ }
1471
+ else {
1472
+ log.info('User Reset Password Token Activity Created', { user: toJson(user), context: 'forgotPassword', loggedInUser: toJson(req.user) });
1473
+ res.sendStatus(200);
1474
+ }
1475
+ });
1476
+ });
1477
+ router.get('/reset/:token', function (req, res) {
1478
+ if (req.params.token) {
1479
+ models.User.findOne({
1480
+ attributes: ['id', 'email', 'reset_password_token', 'reset_password_expires', 'legacy_passwords_disabled'],
1481
+ where: {
1482
+ reset_password_token: req.params.token,
1483
+ reset_password_expires: {
1484
+ $gt: Date.now()
1485
+ }
1486
+ }
1487
+ }).then(function (user) {
1488
+ if (user) {
1489
+ log.info('Get User For Reset Password Token', { user: toJson(user), context: 'getUserToken', loggedInUser: toJson(req.user), errorStatus: 401 });
1490
+ getUserWithAll(user.id, false, function (error, user) {
1491
+ if (error || !user) {
1492
+ log.error("User Error", { context: 'reset_password_expires', user: req.user.id, err: error, errorStatus: 500 });
1493
+ res.sendStatus(500);
1494
+ }
1495
+ else {
1496
+ res.send(user);
1497
+ }
1498
+ });
1499
+ }
1500
+ else {
1501
+ log.error('Get User For Reset Password Token Not found', { user: null, context: 'getUserToken', err: 'Token not found', loggedInUser: toJson(req.user), errorStatus: 401 });
1502
+ res.send({ error: 'not_found' });
1503
+ }
1504
+ }).catch(function (error) {
1505
+ log.error('Get User For Reset Password Token Error', { user: null, context: 'getUserToken', loggedInUser: toJson(req.user), err: error, errorStatus: 500 });
1506
+ res.sendStatus(500);
1507
+ });
1508
+ }
1509
+ else {
1510
+ log.error('No token with request', { user: null, context: 'getUserToken', loggedInUser: req.user ? toJson(req.user) : null, errorStatus: 404 });
1511
+ res.sendStatus(404);
1512
+ }
1513
+ });
1514
+ router.post('/createActivityFromApp', function (req, res) {
1515
+ const workData = {
1516
+ body: {
1517
+ actor: req.body.actor,
1518
+ type: req.body.type,
1519
+ object: req.body.object,
1520
+ target: req.body.target,
1521
+ path_name: req.body.path_name,
1522
+ context: req.body.context,
1523
+ event_time: req.body.event_time,
1524
+ sessionId: req.body.sessionId,
1525
+ user_agent: req.body.user_agent,
1526
+ userLocale: req.body.userLocale,
1527
+ userAutoTranslate: req.body.userAutoTranslate,
1528
+ screen_width: req.body.screen_width,
1529
+ originalQueryString: req.body.originalQueryString,
1530
+ referrer: req.body.referrer,
1531
+ url: req.body.url,
1532
+ ipAddress: req.clientIp,
1533
+ server_timestamp: Date.now()
1534
+ },
1535
+ userId: req.user ? req.user.id : null,
1536
+ domainId: req.body.domainId ? req.body.domainId : req.ypDomain ? req.ypDomain.id : null,
1537
+ communityId: req.body.communityId ? req.body.communityId : req.ypCommunity ? req.ypCommunity.id : null,
1538
+ groupId: req.body.groupId ? req.body.groupId : null,
1539
+ postId: req.body.postId ? req.body.postId :
1540
+ (req.body.object && req.body.object.postId) ? req.body.object.postId.split('/post/')[1] : null,
1541
+ pointId: req.body.pointId ? req.body.pointId : null,
1542
+ };
1543
+ queue.add('delayed-job', { type: 'create-activity-from-app', workData }, 'medium');
1544
+ res.sendStatus(200);
1545
+ });
1546
+ router.post('/reset/:token', function (req, res) {
1547
+ async.waterfall([
1548
+ function (done) {
1549
+ models.User.findOne({
1550
+ attributes: ['id', 'email', 'reset_password_token', 'reset_password_expires', 'legacy_passwords_disabled'],
1551
+ where: {
1552
+ reset_password_token: req.params.token,
1553
+ reset_password_expires: {
1554
+ $gt: Date.now()
1555
+ }
1556
+ }
1557
+ }).then(function (user) {
1558
+ if (user) {
1559
+ user.createPasswordHash(req.body.password);
1560
+ user.reset_password_token = null;
1561
+ user.reset_password_expires = null;
1562
+ user.legacy_passwords_disabled = true;
1563
+ user.save().then(function () {
1564
+ req.logIn(user, function (error) {
1565
+ if (error) {
1566
+ log.error('User Reset Password Cant login', { user: toJson(user), context: 'useResetToken', loggedInUser: toJson(req.user), err: error, errorStatus: 500 });
1567
+ done(error);
1568
+ }
1569
+ else {
1570
+ log.info('User Reset Password User logged in', { user: toJson(user), context: 'useResetToken', loggedInUser: toJson(req.user) });
1571
+ done();
1572
+ }
1573
+ });
1574
+ });
1575
+ }
1576
+ else {
1577
+ log.info('User Reset Password Token Not found', { user: toJson(user), context: 'useResetToken' });
1578
+ done('Not found');
1579
+ }
1580
+ });
1581
+ },
1582
+ function (done) {
1583
+ if (req.user) {
1584
+ models.AcActivity.createActivity({
1585
+ type: 'activity.password.changed',
1586
+ userId: req.user.id,
1587
+ domainId: req.ypDomain.id,
1588
+ groupId: req.params.groupId
1589
+ // communityId: req.ypCommunity ? req.ypCommunity.id : null
1590
+ }, function (error) {
1591
+ done(error);
1592
+ });
1593
+ }
1594
+ else {
1595
+ done('Not found');
1596
+ }
1597
+ }
1598
+ ], function (error) {
1599
+ if (error) {
1600
+ log.error('User Reset Password Token Error', { user: null, context: 'useResetToken', loggedInUser: toJson(req.user), err: error, errorStatus: 500 });
1601
+ if (error == 'Not found') {
1602
+ res.send({ error: 'not_found' });
1603
+ }
1604
+ else {
1605
+ res.sendStatus(500);
1606
+ }
1607
+ }
1608
+ else {
1609
+ log.info('User Reset Password Completed', { user: req.user, context: 'useResetToken', loggedInUser: toJson(req.user) });
1610
+ getUserWithAll(req.user.id, false, function (error, user) {
1611
+ if (error || !user) {
1612
+ log.error("User Error", { context: 'useResetToken', user: req.user.id, err: error, errorStatus: 500 });
1613
+ res.sendStatus(500);
1614
+ }
1615
+ else {
1616
+ res.send(user);
1617
+ }
1618
+ });
1619
+ }
1620
+ });
1621
+ });
1622
+ router.get('/get_invite_info/:token', function (req, res) {
1623
+ models.Invite.findOne({
1624
+ where: {
1625
+ token: req.params.token,
1626
+ joined_at: null
1627
+ },
1628
+ include: [
1629
+ {
1630
+ model: models.User,
1631
+ as: 'FromUser',
1632
+ attributes: ['id', 'name', 'email'],
1633
+ required: true
1634
+ },
1635
+ {
1636
+ model: models.Group,
1637
+ required: false
1638
+ },
1639
+ {
1640
+ model: models.Community,
1641
+ required: false
1642
+ }
1643
+ ]
1644
+ }).then(function (invite) {
1645
+ if (invite) {
1646
+ var targetName, configuration;
1647
+ if (invite.Group) {
1648
+ targetName = invite.Group.name;
1649
+ configuration = invite.Group.configuration;
1650
+ }
1651
+ else if (invite.Community) {
1652
+ targetName = invite.Community.name;
1653
+ configuration = invite.Community.configuration;
1654
+ }
1655
+ res.send({
1656
+ configuration: configuration,
1657
+ targetName: targetName,
1658
+ inviteName: invite.FromUser.name,
1659
+ targetEmail: invite.metadata ? invite.metadata.toEmail : null
1660
+ });
1661
+ }
1662
+ else {
1663
+ log.info('User Invite Token Not found', { context: 'get_invite_info' });
1664
+ res.sendStatus(404);
1665
+ }
1666
+ });
1667
+ });
1668
+ router.post('/accept_invite/:token', auth.isLoggedIn, function (req, res) {
1669
+ models.Invite.findOne({
1670
+ where: {
1671
+ token: req.params.token,
1672
+ joined_at: null
1673
+ },
1674
+ include: [
1675
+ {
1676
+ model: models.User,
1677
+ as: 'FromUser',
1678
+ attributes: ['id', 'name', 'email'],
1679
+ required: true
1680
+ },
1681
+ {
1682
+ model: models.Group,
1683
+ required: false
1684
+ },
1685
+ {
1686
+ model: models.Community,
1687
+ required: false
1688
+ }
1689
+ ]
1690
+ }).then(function (invite) {
1691
+ if (invite) {
1692
+ invite.joined_at = Date.now();
1693
+ invite.save().then(function (results) {
1694
+ if (invite.Group) {
1695
+ models.Group.addUserToGroupIfNeeded(invite.Group.id, req, function () {
1696
+ res.send({ name: invite.Group.name, redirectTo: "/group/" + invite.Group.id });
1697
+ });
1698
+ }
1699
+ else if (invite.Community) {
1700
+ invite.Community.addCommunityUsers(req.user).then(function (error) {
1701
+ invite.Community.increment('counter_users');
1702
+ res.send({ name: invite.Community.name, redirectTo: "/community/" + invite.Community.id });
1703
+ });
1704
+ }
1705
+ });
1706
+ }
1707
+ else {
1708
+ res.sendStatus(404);
1709
+ log.warn('User Invite Token Not found', { context: 'get_invite_info' });
1710
+ }
1711
+ });
1712
+ });
1713
+ router.put('/missingEmail/setEmail', auth.isLoggedInNoAnonymousCheck, function (req, res, next) {
1714
+ models.User.findOne({
1715
+ where: {
1716
+ email: req.body.email
1717
+ }
1718
+ }).then(function (user) {
1719
+ if (user) {
1720
+ res.send({
1721
+ alreadyRegistered: true
1722
+ });
1723
+ }
1724
+ else {
1725
+ models.User.findOne({
1726
+ where: {
1727
+ id: req.user.id
1728
+ }
1729
+ }).then(function (user) {
1730
+ user.email = req.body.email;
1731
+ user.save().then(function (results) {
1732
+ res.send({ email: user.email });
1733
+ });
1734
+ });
1735
+ }
1736
+ }).catch(function (error) {
1737
+ log.error("Error from setEmail", { err: error });
1738
+ res.sendStatus(500);
1739
+ });
1740
+ });
1741
+ router.put('/missingEmail/emailConfirmationShown', auth.isLoggedIn, function (req, res, next) {
1742
+ log.info("email_confirmation_shown 1");
1743
+ models.User.findOne({
1744
+ attributes: ['id', 'profile_data'],
1745
+ where: {
1746
+ id: req.user.id
1747
+ }
1748
+ }).then(function (user) {
1749
+ log.info("email_confirmation_shown 2");
1750
+ if (user) {
1751
+ log.info("email_confirmation_shown 3");
1752
+ if (user.profile_data && user.profile_data.saml_show_confirm_email_completed === false) {
1753
+ log.info("email_confirmation_shown 4");
1754
+ user.set('profile_data.saml_show_confirm_email_completed', true);
1755
+ user.save().then(function () {
1756
+ res.sendStatus(200);
1757
+ }).catch(function (error) {
1758
+ log.error("Error in saving user", { error });
1759
+ res.sendStatus(500);
1760
+ });
1761
+ }
1762
+ else {
1763
+ res.sendStatus(200);
1764
+ }
1765
+ }
1766
+ else {
1767
+ res.sendStatus(404);
1768
+ }
1769
+ }).catch(function (error) {
1770
+ log.error("Error from setEmail", { err: error });
1771
+ res.sendStatus(500);
1772
+ });
1773
+ });
1774
+ router.delete('/disconnectFacebookLogin', auth.isLoggedIn, function (req, res, next) {
1775
+ models.User.findOne({
1776
+ where: {
1777
+ id: req.user.id
1778
+ }
1779
+ }).then(function (user) {
1780
+ if (user) {
1781
+ user.facebook_id = null;
1782
+ user.save().then(function (results) {
1783
+ log.info("Disconnected from Facebook", { userId: user.id });
1784
+ res.sendStatus(200);
1785
+ });
1786
+ }
1787
+ else {
1788
+ res.sendStatus(404);
1789
+ }
1790
+ }).catch(function (error) {
1791
+ log.error("Error in disconnect from Facebook", { err: error });
1792
+ res.sendStatus(500);
1793
+ });
1794
+ });
1795
+ router.delete('/disconnectSamlLogin', auth.isLoggedIn, function (req, res, next) {
1796
+ models.User.findOne({
1797
+ where: {
1798
+ id: req.user.id
1799
+ }
1800
+ }).then(function (user) {
1801
+ if (user) {
1802
+ user.ssn = null;
1803
+ user.save().then(function (results) {
1804
+ log.info("Disconnected from Saml", { userId: user.id });
1805
+ res.sendStatus(200);
1806
+ });
1807
+ }
1808
+ else {
1809
+ res.sendStatus(404);
1810
+ }
1811
+ }).catch(function (error) {
1812
+ log.error("Error in disconnect from Saml", { err: error });
1813
+ res.sendStatus(500);
1814
+ });
1815
+ });
1816
+ const completeCreationOfApiKey = (user, apiKey, res) => {
1817
+ user.set('private_profile_data.apiKey', apiKey);
1818
+ user.save().then(() => {
1819
+ log.info("ApiKey created for user", { userId: user.id });
1820
+ res.send({ apiKey: user.private_profile_data.apiKey });
1821
+ }).catch(error => {
1822
+ log.error("Error in createApiKey", { err: error });
1823
+ res.sendStatus(500);
1824
+ });
1825
+ };
1826
+ router.post('/createApiKey', auth.isLoggedIn, function (req, res, next) {
1827
+ models.User.findOne({
1828
+ where: {
1829
+ id: req.user.id
1830
+ }
1831
+ }).then(function (user) {
1832
+ if (user) {
1833
+ if (!user.private_profile_data) {
1834
+ user.set('private_profile_data', {});
1835
+ }
1836
+ if (!user.profile_data) {
1837
+ user.set('profile_data', {});
1838
+ }
1839
+ user.set('profile_data.hasApiKey', true);
1840
+ let apiKey = randomstring.generate(48);
1841
+ models.User.findOne({
1842
+ where: {
1843
+ private_profile_data: {
1844
+ apiKey: apiKey
1845
+ }
1846
+ },
1847
+ attributes: ['id']
1848
+ }).then(findUser => {
1849
+ if (!findUser) {
1850
+ completeCreationOfApiKey(user, apiKey, res);
1851
+ }
1852
+ else {
1853
+ apiKey = randomstring.generate(48);
1854
+ models.User.findOne({
1855
+ where: {
1856
+ private_profile_data: {
1857
+ apiKey: apiKey
1858
+ }
1859
+ },
1860
+ attributes: ['id']
1861
+ }).then(findUserTwo => {
1862
+ if (!findUserTwo) {
1863
+ completeCreationOfApiKey(user, apiKey, res);
1864
+ }
1865
+ else {
1866
+ log.error("Can't create unique createApiKey", {});
1867
+ res.sendStatus(500);
1868
+ }
1869
+ }).catch(error => {
1870
+ log.error("Error in createApiKey", { err: error });
1871
+ res.sendStatus(500);
1872
+ });
1873
+ }
1874
+ }).catch(error => {
1875
+ log.error("Error in createApiKey", { err: error });
1876
+ res.sendStatus(500);
1877
+ });
1878
+ }
1879
+ else {
1880
+ res.sendStatus(404);
1881
+ }
1882
+ }).catch(function (error) {
1883
+ log.error("Error in disconnect from Saml", { err: error });
1884
+ res.sendStatus(500);
1885
+ });
1886
+ });
1887
+ router.put('/missingEmail/linkAccounts', auth.isLoggedIn, function (req, res, next) {
1888
+ log.info("User Serialized Link 1", { loginProvider: req.user.loginProvider });
1889
+ models.User.findOne({
1890
+ where: {
1891
+ email: req.body.email
1892
+ }
1893
+ }).then(function (user) {
1894
+ if (user) {
1895
+ user.validatePassword(req.body.password, function (hmm, userWithPassword, message) {
1896
+ if (!userWithPassword) {
1897
+ res.send({
1898
+ error: 'wrong password'
1899
+ });
1900
+ }
1901
+ else {
1902
+ var foundLoginProvider = true;
1903
+ log.info("User Serialized Link 2", { loginProvider: req.user.loginProvider });
1904
+ if (req.user.loginProvider == 'facebook') {
1905
+ user.facebook_id = req.user.facebook_id;
1906
+ req.user.facebook_id = null;
1907
+ user.provider = "facebook";
1908
+ }
1909
+ else if (req.user.loginProvider == 'google') {
1910
+ user.google_id = req.user.google_id;
1911
+ req.user.google_id = null;
1912
+ }
1913
+ else if (req.user.loginProvider == 'twitter') {
1914
+ user.twitter_id = req.user.twitter_id;
1915
+ req.user.twitter_id = null;
1916
+ }
1917
+ else if (req.user.loginProvider == 'github') {
1918
+ user.github_id = req.user.github_id;
1919
+ req.user.github_id = null;
1920
+ }
1921
+ else if (req.user.loginProvider == 'saml' || req.user.loginProvider == 'oidc') {
1922
+ user.set('ssn', req.user.ssn);
1923
+ var profileData = req.user.profile_data;
1924
+ if (profileData && user.profile_data)
1925
+ profileData = _.merge(req.user.profile_data, user.profile_data);
1926
+ if (!profileData && user.profile_data)
1927
+ profileData = user.profile_data;
1928
+ var privateProfileData = req.user.private_profile_data;
1929
+ if (privateProfileData && user.private_profile_data)
1930
+ privateProfileData = _.merge(req.user.private_profile_data, user.private_profile_data);
1931
+ if (!privateProfileData && user.private_profile_data)
1932
+ privateProfileData = user.private_profile_data;
1933
+ user.set('private_profile_data', privateProfileData);
1934
+ user.set('profile_data', profileData);
1935
+ user.UserSSN = user.ssn;
1936
+ user.provider = "saml";
1937
+ req.user.set('ssn', null);
1938
+ log.info("User Serialized Linked Accounts SAML", { userFrom: req.user, toUser: user, toUserSsn: user.ssn, fromUserSsn: req.user.ssn });
1939
+ }
1940
+ else {
1941
+ foundLoginProvider = false;
1942
+ }
1943
+ user.loginProvider = req.user.loginProvider;
1944
+ if (foundLoginProvider) {
1945
+ models.sequelize.transaction(function (t) {
1946
+ return user.save({ transaction: t }).then(function (user) {
1947
+ return req.user.save({ transaction: t });
1948
+ });
1949
+ }).then(function (result) {
1950
+ log.info("User Serialized Linked Accounts", { toUserSsn: user.ssn, fromUserSsn: req.user.ssn, userFrom: req.user, toUser: user });
1951
+ queue.add('process-deletion', { type: 'move-user-endorsements', toUserId: user.id, fromUserId: req.user.id }, 'high');
1952
+ req.logIn(user, function (error, detail) {
1953
+ if (error) {
1954
+ sendUserOrError(res, null, 'linkAccounts', error, 401);
1955
+ }
1956
+ else {
1957
+ res.send({ email: user.email, accountLinked: true });
1958
+ }
1959
+ });
1960
+ }).catch(function (err) {
1961
+ log.error("User Serialized Linked Accounts Error", { userFrom: req.user, toUser: user, err: err });
1962
+ res.send({
1963
+ error: 'Unexpected error'
1964
+ });
1965
+ });
1966
+ }
1967
+ else {
1968
+ res.send({
1969
+ error: 'no login provider to move from'
1970
+ });
1971
+ }
1972
+ }
1973
+ });
1974
+ }
1975
+ else {
1976
+ log.error("Email not found for linkAccounts", {});
1977
+ res.sendStatus(404);
1978
+ }
1979
+ }).catch(function (error) {
1980
+ log.error("Error from linkAccounts", { err: error });
1981
+ res.sendStatus(500);
1982
+ });
1983
+ });
1984
+ router.get('/available/groups', function (req, res, next) {
1985
+ models.Group.findAll({
1986
+ attributes: ['id', 'name', 'access', 'configuration'],
1987
+ include: [
1988
+ {
1989
+ model: models.Community,
1990
+ required: true,
1991
+ attributes: [
1992
+ 'id', 'domain_id'
1993
+ ],
1994
+ where: {
1995
+ domain_id: req.ypDomain.id
1996
+ }
1997
+ }
1998
+ ],
1999
+ where: {
2000
+ access: models.Group.ACCESS_PUBLIC
2001
+ }
2002
+ }).then(function (groups) {
2003
+ res.send({ groups: groups, domainId: req.ypDomain.id });
2004
+ }).catch(function (error) {
2005
+ log.error("Error from get available groups", { err: error });
2006
+ res.sendStatus(500);
2007
+ });
2008
+ });
2009
+ router.get('/has/AutoTranslation', function (req, res) {
2010
+ const hasAutoTranslation = process.env.GOOGLE_APPLICATION_CREDENTIALS_JSON ? true : false;
2011
+ if (typeof hasAutoTranslation === "boolean") {
2012
+ res.send({ hasAutoTranslation: hasAutoTranslation });
2013
+ }
2014
+ else {
2015
+ res.sendStatus(500);
2016
+ }
2017
+ });
2018
+ router.get('/has/PlausibleSiteName', function (req, res) {
2019
+ if (process.env.PLAUSIBLE_SITE_NAME) {
2020
+ res.send({ plausibleSiteName: process.env.PLAUSIBLE_SITE_NAME });
2021
+ }
2022
+ else {
2023
+ res.sendStatus(404);
2024
+ }
2025
+ });
2026
+ router.get('/PlausibleFavIcon/:sourceName', async (req, res) => {
2027
+ try {
2028
+ const iconFile = await sendPlausibleFavicon(req.params.sourceName);
2029
+ if (iconFile) {
2030
+ res.send(iconFile);
2031
+ }
2032
+ else {
2033
+ res.sendStatus(404);
2034
+ }
2035
+ }
2036
+ catch (error) {
2037
+ if (error == 404) {
2038
+ res.sendStatus(404);
2039
+ }
2040
+ else {
2041
+ log.error(`PlausibleFavIcon Error ${error}`);
2042
+ res.sendStatus(500);
2043
+ }
2044
+ }
2045
+ });
2046
+ router.get('/:id/status_update/:bulkStatusUpdateId', function (req, res, next) {
2047
+ if (false) {
2048
+ log.error("In status_update status_update - Should not be called error", { context: 'user_get' });
2049
+ res.sendStatus(500);
2050
+ }
2051
+ else {
2052
+ var statusUpdate;
2053
+ var allUserEndorsementsPostId = [];
2054
+ var config;
2055
+ async.series([
2056
+ function (seriesCallback) {
2057
+ models.BulkStatusUpdate.findOne({
2058
+ where: { id: req.params.bulkStatusUpdateId },
2059
+ order: [
2060
+ [models.Community, { model: models.Image, as: 'CommunityLogoImages' }, 'created_at', 'asc'],
2061
+ [models.Community, { model: models.Image, as: 'CommunityHeaderImages' }, 'created_at', 'asc']
2062
+ ],
2063
+ include: [
2064
+ {
2065
+ model: models.Community,
2066
+ required: true,
2067
+ attributes: models.Community.defaultAttributesPublic,
2068
+ include: [
2069
+ {
2070
+ model: models.Image, as: 'CommunityLogoImages',
2071
+ attributes: ['id', 'formats'],
2072
+ required: false
2073
+ },
2074
+ {
2075
+ model: models.Image, as: 'CommunityHeaderImages',
2076
+ attributes: ['id', 'formats'],
2077
+ required: false
2078
+ }
2079
+ ]
2080
+ },
2081
+ {
2082
+ model: models.User,
2083
+ required: true,
2084
+ attributes: ['id']
2085
+ }
2086
+ ]
2087
+ }).then(function (statusUpdateIn) {
2088
+ if (statusUpdateIn) {
2089
+ statusUpdate = statusUpdateIn;
2090
+ seriesCallback();
2091
+ }
2092
+ else {
2093
+ seriesCallback("Bulk status update not found");
2094
+ }
2095
+ }).catch(function (error) {
2096
+ seriesCallback(error);
2097
+ });
2098
+ },
2099
+ function (seriesCallback) {
2100
+ models.Endorsement.findAll({
2101
+ where: {
2102
+ user_id: req.params.id
2103
+ },
2104
+ attributes: ['id', 'post_id']
2105
+ }).then(function (endorsements) {
2106
+ _.each(endorsements, function (endorsement) {
2107
+ allUserEndorsementsPostId.push(endorsement.post_id);
2108
+ });
2109
+ seriesCallback();
2110
+ }).catch(function (error) {
2111
+ seriesCallback(error);
2112
+ });
2113
+ },
2114
+ function (seriesCallback) {
2115
+ config = JSON.parse(JSON.stringify(statusUpdate.config));
2116
+ _.each(config.groups, function (group, groupsIndex) {
2117
+ log.info("Before posts reject count " + config.groups[groupsIndex].posts.length);
2118
+ /*config.groups[groupsIndex].posts = _.reject(config.groups[groupsIndex].posts, function (post) {
2119
+ return !_.includes(allUserEndorsementsPostId, post.id)
2120
+ });*/
2121
+ log.info("After posts reject count " + config.groups[groupsIndex].posts.length);
2122
+ config.groups[groupsIndex]["statuses"] = [];
2123
+ var gotStatus = {};
2124
+ _.each(config.groups[groupsIndex].posts, function (post) {
2125
+ if (!post.newOfficialStatus)
2126
+ post.newOfficialStatus = 0;
2127
+ if (!gotStatus[post.newOfficialStatus]) {
2128
+ gotStatus[post.newOfficialStatus] = true;
2129
+ if (post.newOfficialStatus) {
2130
+ config.groups[groupsIndex]["statuses"].push({ official_status: post.newOfficialStatus, posts: [] });
2131
+ }
2132
+ }
2133
+ _.each(config.groups[groupsIndex]["statuses"], function (status, index) {
2134
+ if (status.official_status == post.newOfficialStatus) {
2135
+ config.groups[groupsIndex]["statuses"][index].posts.push(post);
2136
+ }
2137
+ });
2138
+ config.groups[groupsIndex].posts = null;
2139
+ });
2140
+ });
2141
+ config.groups = _.reject(config.groups, function (group) {
2142
+ var totalCount = 0;
2143
+ _.each(group.statuses, function (status) {
2144
+ totalCount += status.posts.length;
2145
+ });
2146
+ return totalCount == 0;
2147
+ });
2148
+ seriesCallback();
2149
+ }
2150
+ ], function (error) {
2151
+ if (error) {
2152
+ log.error("Error from status_update", { err: error });
2153
+ res.sendStatus(500);
2154
+ }
2155
+ else {
2156
+ res.send({ config: config, templates: statusUpdate.templates, community: statusUpdate.Community });
2157
+ }
2158
+ });
2159
+ }
2160
+ });
2161
+ // Facebook Authentication
2162
+ router.get('/auth/facebook', function (req, res) {
2163
+ req.sso.authenticate('facebook-strategy-' + req.ypDomain.id, {}, req, res, function (error, user) {
2164
+ if (error) {
2165
+ log.error("Error from Facebook login init", { err: error });
2166
+ throw error;
2167
+ }
2168
+ });
2169
+ });
2170
+ router.get('/auth/audkenni', function (req, res) {
2171
+ req.sso.authenticate('oidc-strategy-' + req.ypDomain.id, {}, req, res, function (error, user) {
2172
+ if (error) {
2173
+ log.error("Error from OIDC login init", { err: error });
2174
+ throw error;
2175
+ }
2176
+ });
2177
+ });
2178
+ router.get('/auth/oidc', function (req, res) {
2179
+ req.sso.authenticate('oidc-strategy-' + req.ypDomain.id, {}, req, res, function (error, user) {
2180
+ if (error) {
2181
+ log.error("Error from OIDC login init", { err: error });
2182
+ throw error;
2183
+ }
2184
+ });
2185
+ });
2186
+ // SAML Authentication
2187
+ router.get('/auth/saml', function (req, res, next) {
2188
+ req.sso.authenticate('saml-strategy-' + req.ypDomain.id, {}, req, res, function (error, user) {
2189
+ if (error) {
2190
+ log.error("Error from SAML login", { err: error });
2191
+ res.sendStatus(500);
2192
+ }
2193
+ });
2194
+ });
2195
+ router.get('/auth/facebook/callback', function (req, res) {
2196
+ req.sso.authenticate('facebook-strategy-' + req.ypDomain.id, {}, req, res, function (error, user) {
2197
+ if (error) {
2198
+ log.error("Error from Facebook login", { err: error });
2199
+ res.sendStatus(500);
2200
+ }
2201
+ else {
2202
+ res.render('facebookLoginComplete', {});
2203
+ }
2204
+ });
2205
+ });
2206
+ router.get('/auth/oidc/callback', function (req, res) {
2207
+ req.sso.authenticate('oidc-strategy-' + req.ypDomain.id, {}, req, res, function (error, user) {
2208
+ if (error) {
2209
+ log.error("Error from OIDC login", { err: error });
2210
+ res.sendStatus(500);
2211
+ }
2212
+ else {
2213
+ res.render('samlLoginComplete', {});
2214
+ }
2215
+ });
2216
+ });
2217
+ router.get('/auth/audkenni/callback', async function (req, res) {
2218
+ await new Promise(resolve => setTimeout(resolve, 100));
2219
+ req.sso.authenticate('oidc-strategy-' + req.ypDomain.id, {}, req, res, function (error, user) {
2220
+ if (error) {
2221
+ log.error("Error from Audkenni login", { err: error });
2222
+ res.sendStatus(500);
2223
+ }
2224
+ else {
2225
+ res.render('samlLoginComplete', {});
2226
+ }
2227
+ });
2228
+ });
2229
+ router.get('/auth/twitter/callback', passport.authenticate('twitter', { failureRedirect: '/' }), function (req, res) {
2230
+ log.info('User Logged in from Twitter', { user: toJson(req.user), context: 'twitterCallback' });
2231
+ res.sendStatus(200);
2232
+ });
2233
+ // Google Authentication
2234
+ router.get('/auth/google', passport.authenticate('google', { scope: 'https://www.google.com/m8/feeds' }));
2235
+ router.get('/auth/google/callback', passport.authenticate('google', { failureRedirect: '/' }), function (req, res) {
2236
+ log.info('User Logged in from Google', { user: toJson(req.user), context: 'googleCallback' });
2237
+ res.sendStatus(200);
2238
+ });
2239
+ // GitHub Authentication
2240
+ router.get('/auth/github', passport.authenticate('github'));
2241
+ router.get('/auth/github/callback', passport.authenticate('github', { failureRedirect: '/' }), function (req, res) {
2242
+ log.info('User Logged in from GitHub', { user: toJson(req.user), context: 'githubCallback' });
2243
+ res.sendStatus(200);
2244
+ });
2245
+ /*
2246
+ router.get('/:id/endorsements', auth.can('view user'), function (req, res) {
2247
+ models.Endorsement.findAll({
2248
+ where: {user_id: req.params.id, status: 'active'},
2249
+ order: [['created_at','DESC']],
2250
+ }).then(function (endorsements) {
2251
+ res.send(endorsements);
2252
+ });
2253
+ });
2254
+ */
2255
+ module.exports = router;