@yrpri/api 9.0.139 → 9.0.141

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 (322) hide show
  1. package/agents/assistants/agentAssistant.js +4 -3
  2. package/agents/assistants/baseAssistant.js +72 -71
  3. package/agents/assistants/baseAssistantWithVoice.js +6 -5
  4. package/agents/assistants/modes/agentDirectConnection.js +8 -7
  5. package/agents/assistants/modes/agentSelectionMode.js +2 -1
  6. package/agents/assistants/modes/baseAssistantMode.js +3 -2
  7. package/agents/assistants/modes/tools/agentTools.js +11 -10
  8. package/agents/assistants/modes/tools/loginTools.js +7 -6
  9. package/agents/assistants/modes/tools/models/agents.js +6 -5
  10. package/agents/assistants/modes/tools/models/subscriptions.js +7 -6
  11. package/agents/assistants/modes/tools/navigationTools.js +7 -6
  12. package/agents/assistants/modes/tools/subscriptionTools.js +12 -11
  13. package/agents/assistants/modes/tools/workflowConverstationTools.js +7 -6
  14. package/agents/assistants/voiceAssistant.js +45 -44
  15. package/agents/controllers/agentProductController.js +8 -7
  16. package/agents/controllers/agentSubscriptionController.js +13 -12
  17. package/agents/controllers/assistantsController.js +45 -44
  18. package/agents/controllers/policySynthAgents.js +33 -32
  19. package/agents/managers/emailInvitesManager.js +4 -3
  20. package/agents/managers/newAiModelSetup.js +46 -45
  21. package/agents/managers/notificationAgentQueueManager.js +55 -54
  22. package/agents/managers/subscriptionManager.js +24 -23
  23. package/agents/models/agentProduct.js +2 -1
  24. package/agents/models/agentProductBoosterPurchase.js +2 -1
  25. package/agents/models/testData/createEvolyAgentProduct.js +7 -6
  26. package/agents/models/testData/old/updateAgentWorkflowConfiguration.js +5 -4
  27. package/agents/models/testData/updateAgentWorkflowConfiguration.js +5 -4
  28. package/agents/tools/setTemplateWorkflowCommunityId.js +6 -5
  29. package/app.d.ts +2 -1
  30. package/app.js +60 -34
  31. package/authorization.cjs +4 -4
  32. package/controllers/allOurIdeas.js +45 -44
  33. package/controllers/groups.cjs +4 -9
  34. package/controllers/images.cjs +8 -8
  35. package/controllers/index.cjs +1 -1
  36. package/controllers/points.cjs +1 -1
  37. package/controllers/posts.cjs +3 -3
  38. package/deleteUnwantedDeclerations.cjs +6 -5
  39. package/models/community.cjs +1 -1
  40. package/models/domain.cjs +7 -7
  41. package/models/image.cjs +2 -2
  42. package/models/index.cjs +8 -4
  43. package/models/post.cjs +10 -10
  44. package/models/user.cjs +1 -1
  45. package/models/video.cjs +4 -4
  46. package/package.json +5 -5
  47. package/scripts/addRatingUsersToGroup.js +1 -1
  48. package/scripts/addUserToOrganization.js +8 -8
  49. package/scripts/agents/changeModelForWorkflowGroupTemplate.js +13 -12
  50. package/scripts/agents/generateAgentWorkflowTemplateFromAgentClass.js +5 -4
  51. package/scripts/analyseRatingsForCommunity.js +2 -2
  52. package/scripts/analyzeAndFixBrokenPointUsers.js +3 -3
  53. package/scripts/analyzeEndorsementsByCountry.js +7 -7
  54. package/scripts/analyzePostsForCommunity.js +1 -1
  55. package/scripts/bulkStatusUpdates/listUpdates.js +2 -2
  56. package/scripts/bulkStatusUpdates/mergeLatestPostsToUpdate.js +5 -5
  57. package/scripts/bulkStatusUpdates/performUpdate.js +9 -9
  58. package/scripts/bulkStatusUpdates/performUpdateForGroup.cjs +12 -11
  59. package/scripts/bulkStatusUpdates/performUpdateForStatus.js +15 -15
  60. package/scripts/change/changeVideoAspectTo.js +3 -3
  61. package/scripts/change/setUseNewVersion.cjs +5 -4
  62. package/scripts/changeCommunityGroupcount.js +3 -3
  63. package/scripts/changeCommunityPostCount.js +3 -3
  64. package/scripts/changeGroupPostCount.js +3 -3
  65. package/scripts/changeLanguage.js +4 -4
  66. package/scripts/changeOfficalStatus.js +3 -3
  67. package/scripts/cleanups/deleteAnonNotifications.cjs +8 -7
  68. package/scripts/cleanups/deleteLinkGroupsWithDeletedCommunities.js +8 -8
  69. package/scripts/cleanups/deleteYearOldNotifications.cjs +6 -5
  70. package/scripts/cleanups/removeAllUsersFromHiddenPublicGroup.js +5 -5
  71. package/scripts/clearAllEndorsementInGroup.js +5 -5
  72. package/scripts/cloning/clearUsersForCommunitiesFromUrl.js +3 -3
  73. package/scripts/cloning/cloneFromUrlScript.js +4 -4
  74. package/scripts/cloning/cloneWBFromUrlScriptAndCreateLinks.js +6 -6
  75. package/scripts/cloning/cloneWBFromUrlScriptNoUsersOrPoints.js +6 -6
  76. package/scripts/cloning/cloneWBSerbianFromUrlScriptAndCreateLinks.js +6 -6
  77. package/scripts/cloning/copyCommunityConfigAndTranslationsFromURL.js +3 -3
  78. package/scripts/cloning/copyCommunityOneGroupToDomainNoUsersNoEndorsements.js +2 -2
  79. package/scripts/cloning/copyCommunityToDomainNoUsersNoEndorsements.js +2 -2
  80. package/scripts/cloning/copyCommunityToDomainWithEverything.js +2 -2
  81. package/scripts/cloning/copyCommunityToDomainWithOnlyGroups.js +3 -3
  82. package/scripts/cloning/copyGroupConfigAndTranslationsFromURL.js +3 -3
  83. package/scripts/cloning/copyPostToGroupOld.js +12 -12
  84. package/scripts/cloning/copyPostVideosFromURL.js +3 -3
  85. package/scripts/cloning/copyPostWithOutAnyVotingOrActivities.js +2 -2
  86. package/scripts/cloning/deepCloneSerbianWBFromUrlScriptAndCreateLinks.js +7 -7
  87. package/scripts/cloning/deepCloneWBFromUrlScriptAndCreateLinks.js +6 -6
  88. package/scripts/cloning/setAdminsFromURL.js +5 -5
  89. package/scripts/cloning/setExternalIdsFromURL.js +3 -3
  90. package/scripts/countCommunity.js +11 -11
  91. package/scripts/countCommunityUsers.js +4 -4
  92. package/scripts/countDelayedNotifications.js +3 -3
  93. package/scripts/countGroup.js +11 -11
  94. package/scripts/countStuff.js +3 -3
  95. package/scripts/countUniqueVotersInAGroup.js +3 -3
  96. package/scripts/createInvitesAndShow.js +2 -2
  97. package/scripts/database/sync_database.js +2 -2
  98. package/scripts/database/sync_dev_database.js +3 -3
  99. package/scripts/debugNotifications.js +5 -5
  100. package/scripts/deleteAllNewsFeeds.js +2 -2
  101. package/scripts/deleteCategory.js +1 -1
  102. package/scripts/deleteOldAppActivities.js +5 -4
  103. package/scripts/deletePostContactDataForCommunity.js +5 -4
  104. package/scripts/destroy/destroy_all_but_one_domain.js +59 -59
  105. package/scripts/displayAuthorForPost.js +1 -1
  106. package/scripts/domains/createDomain.js +5 -4
  107. package/scripts/domains/importDomainsFromXls.js +7 -6
  108. package/scripts/endorsementFraudDetection/analyseEndorsementsForCommunity.js +2 -2
  109. package/scripts/endorsementFraudDetection/bulkDeleteDuplicateEndorsmentsFromUrl.js +9 -9
  110. package/scripts/exportAllStatusChanges.js +5 -5
  111. package/scripts/exportEndorsementsForCommunity.js +5 -5
  112. package/scripts/exportPointQualitiesForCommunity.js +5 -5
  113. package/scripts/exportPostsAndPointsForCommunity.js +9 -9
  114. package/scripts/exportPostsDataSetForDomain.js +12 -12
  115. package/scripts/exportPostsForGroup.js +7 -7
  116. package/scripts/exportRatingsForPost.js +2 -2
  117. package/scripts/exportUserEndorsementsWithUserAnalysis.js +6 -6
  118. package/scripts/exportUsersForCommunity.js +3 -3
  119. package/scripts/exportUsersForDomain.js +3 -3
  120. package/scripts/exportUsersForGroup.js +3 -3
  121. package/scripts/exports/ratingDistribution.js +6 -6
  122. package/scripts/exports/whoEndorsedWhatByCommunity.js +2 -2
  123. package/scripts/findUnusedClientImports.js +2 -2
  124. package/scripts/fixAllPostPointCounts.js +1 -1
  125. package/scripts/fixAnonNotificationsSettings.js +5 -5
  126. package/scripts/fixCountKopavogur.js +1 -1
  127. package/scripts/fixEndorsementsAfterCopyPostToGroup.js +10 -10
  128. package/scripts/fixExternalUserId.js +2 -2
  129. package/scripts/fixGroupAccess.js +3 -3
  130. package/scripts/fixGroupIdeasAndPointsCount.js +2 -2
  131. package/scripts/fixNotificationSettings.js +4 -4
  132. package/scripts/fixSurveyRadioBakedInSubCodes.js +6 -6
  133. package/scripts/fixWrongUserIdForStatusUpdates.js +6 -5
  134. package/scripts/gallery/exportGalleryData.js +2 -2
  135. package/scripts/gallery/importGalleryForCommunity.js +14 -14
  136. package/scripts/gallery/readJsonAndDownloadImagesVersion2.js +6 -6
  137. package/scripts/gallery/refreshAcApiPostIdsForCommunity.js +5 -5
  138. package/scripts/genderAnalysis.js +10 -10
  139. package/scripts/genderAnalysisByStatus.js +4 -4
  140. package/scripts/importAllLocalesFromLocalFolders.js +7 -7
  141. package/scripts/importDomain.js +131 -131
  142. package/scripts/keys/addOidcToDomain.cjs +10 -9
  143. package/scripts/landUseGame/export3Ddata.js +15 -15
  144. package/scripts/listLanguagesForGroup.js +6 -6
  145. package/scripts/loadTestCreateDummyContentForGroup.js +2 -2
  146. package/scripts/makeRecursiveMapData.js +4 -4
  147. package/scripts/mapping/community_map_csv.js +5 -5
  148. package/scripts/moveCommunityToDomain.js +3 -3
  149. package/scripts/moveGroupToCommunity.js +3 -3
  150. package/scripts/movePostToGroup.js +5 -5
  151. package/scripts/movePostsToGroupsRecountGroupFromUrl.js +6 -6
  152. package/scripts/oldMovePostToGroup.js +9 -9
  153. package/scripts/processCsvForPdfUrls.js +2 -2
  154. package/scripts/processCsvForTranslationAndToxicity.js +10 -10
  155. package/scripts/recount/recount_recursive_communities.js +6 -6
  156. package/scripts/recountALLCommunityGroupCounts.js +4 -4
  157. package/scripts/recountAll.js +3 -3
  158. package/scripts/recountCommunitesFromUrl.js +3 -3
  159. package/scripts/recountCommunity.js +2 -2
  160. package/scripts/recountGroup.js +5 -5
  161. package/scripts/recountGroupNoUserChange.js +5 -5
  162. package/scripts/resetAllEndorsementsForGroup.js +3 -3
  163. package/scripts/resetEnTranslationForGroup.js +5 -5
  164. package/scripts/setAdminOnAll.cjs +15 -14
  165. package/scripts/setDomainAdmin.cjs +7 -6
  166. package/scripts/setDomainLocales.js +2 -2
  167. package/scripts/setEarlQuestionIdOnGroup.cjs +5 -4
  168. package/scripts/setLanguageOnGroupCommunitesFromUrl.js +3 -3
  169. package/scripts/setMemberOfAll.js +14 -14
  170. package/scripts/setNewUserForContentOfCommunity.js +9 -9
  171. package/scripts/setOfficialStatusOnAllPostsForCommunity.js +1 -1
  172. package/scripts/setUserOnAll.js +14 -14
  173. package/scripts/showCategoryForGroup.js +1 -1
  174. package/scripts/showOldActivityTypes.js +3 -3
  175. package/scripts/showPostsMissingCategoryForGroup.js +2 -2
  176. package/scripts/showStatuses.js +4 -4
  177. package/scripts/showUniqueVotersInCommunity.js +4 -4
  178. package/scripts/showUserAgentsAndIpsForEmails.js +4 -4
  179. package/scripts/simpleExportForGroupsForCommunity.js +5 -5
  180. package/scripts/simpleExportForPointsForCommunity.js +5 -5
  181. package/scripts/simpleExportForPostsForCommunity.js +5 -5
  182. package/scripts/testForEndorsments.js +4 -4
  183. package/scripts/undeleteGroupAndAllContent.js +8 -8
  184. package/scripts/undeletePost.js +7 -7
  185. package/scripts/unlinkSsn.js +4 -4
  186. package/scripts/updateFromAlthingi.js +8 -8
  187. package/scripts/users/createUserAddDomain.js +6 -5
  188. package/scripts/users/importUsersForDomainsFromXls.js +4 -3
  189. package/scripts/users/listDomainUsersWithSsn.js +6 -5
  190. package/scripts/users/removeUserFromDomain.js +6 -5
  191. package/scripts/users/updatePasswordFromSsn.js +5 -4
  192. package/scripts/users/updateUserSsnFromEmail.js +5 -4
  193. package/services/controllers/activities.cjs +1 -1
  194. package/services/controllers/news_feeds.cjs +1 -1
  195. package/services/controllers/notifications.cjs +1 -1
  196. package/services/controllers/recommendations.cjs +1 -1
  197. package/services/engine/allOurIdeas/aiHelper.js +10 -9
  198. package/services/engine/analytics/export_anon_community_activities.js +3 -3
  199. package/services/engine/analytics/importer.js +10 -10
  200. package/services/engine/analytics/plausible/manager.cjs +4 -4
  201. package/services/engine/analytics/statsCalc.cjs +1 -1
  202. package/services/engine/analytics/utils.cjs +11 -10
  203. package/services/engine/marketing/campaign.cjs +1 -0
  204. package/services/engine/moderation/fraud/CreateFraudAuditReport.cjs +2 -1
  205. package/services/engine/moderation/fraud/FraudBase.cjs +3 -2
  206. package/services/engine/moderation/fraud/FraudDeleteBase.cjs +5 -4
  207. package/services/engine/moderation/fraud/FraudGetBase.cjs +2 -1
  208. package/services/engine/moderation/fraud/FraudGetEndorsements.cjs +2 -1
  209. package/services/engine/moderation/fraud/FraudGetPointQualities.cjs +2 -1
  210. package/services/engine/moderation/fraud/FraudGetPoints.cjs +2 -1
  211. package/services/engine/moderation/fraud/FraudGetPosts.cjs +2 -1
  212. package/services/engine/moderation/fraud/FraudGetRatings.cjs +2 -1
  213. package/services/engine/moderation/fraud/FraudScannerNotifier.cjs +10 -9
  214. package/services/engine/moderation/get_moderation_items.cjs +1 -1
  215. package/services/engine/moderation/image_labeling/ImageLabelingBase.cjs +1 -1
  216. package/services/engine/moderation/process_moderation_items.cjs +1 -1
  217. package/services/engine/moderation/toxicity_analysis.cjs +1 -1
  218. package/services/engine/news_feeds/generate_dynamically.cjs +1 -1
  219. package/services/engine/news_feeds/generate_from_notifications.cjs +1 -1
  220. package/services/engine/notifications/emails_utils.cjs +2 -2
  221. package/services/engine/notifications/generate_point_notifications.cjs +1 -1
  222. package/services/engine/notifications/generate_post_notifications.cjs +1 -1
  223. package/services/engine/notifications/process_delayed_notifications.cjs +38 -38
  224. package/services/engine/notifications/process_general_notifications.cjs +1 -0
  225. package/services/engine/old/exporters/categories_dataset.js +11 -11
  226. package/services/engine/old/exporters/sentiment_dataset.js +12 -12
  227. package/services/engine/recommendations/events_importer.cjs +5 -5
  228. package/services/engine/recommendations/events_manager.cjs +1 -1
  229. package/services/engine/reports/add_points_to_sheet.cjs +3 -2
  230. package/services/engine/reports/commonUtils.js +3 -2
  231. package/services/engine/reports/common_utils.cjs +8 -8
  232. package/services/engine/reports/docx_group_report.cjs +1 -1
  233. package/services/engine/reports/xlsAllOurIdeasExport.js +16 -15
  234. package/services/engine/reports/xls_community_users_report.cjs +2 -2
  235. package/services/engine/reports/xls_group_report.cjs +1 -1
  236. package/services/llms/baseChatBot.js +12 -11
  237. package/services/llms/imageGeneration/chatGptImageGenerator.js +3 -2
  238. package/services/llms/imageGeneration/collectionImageGenerator.js +7 -6
  239. package/services/llms/imageGeneration/dalleImageGenerator.js +6 -5
  240. package/services/llms/imageGeneration/fluxImageGenerator.js +5 -4
  241. package/services/llms/imageGeneration/imageProcessorService.js +2 -1
  242. package/services/llms/imageGeneration/imagenImageGenerator.js +8 -7
  243. package/services/llms/imageGeneration/s3Service.js +12 -11
  244. package/services/llms/llmTranslation.js +30 -29
  245. package/services/models/ac_activity.cjs +1 -1
  246. package/services/models/ac_notification.cjs +1 -1
  247. package/services/models/ac_translation_cache.cjs +11 -11
  248. package/services/scripts/analytics/setup_all_plausible_goals.cjs +3 -2
  249. package/services/scripts/fix_old_delayed_notifications.js +3 -3
  250. package/services/scripts/kue_status.js +11 -11
  251. package/services/scripts/kue_watch_stuck_jobs.js +6 -6
  252. package/services/scripts/translation_clear_language.js +21 -21
  253. package/services/scripts/translation_delete.js +4 -4
  254. package/services/scripts/translation_replace_text_from_url.js +4 -4
  255. package/services/scripts/translation_update.js +4 -4
  256. package/services/scripts/translations_list.js +5 -5
  257. package/services/utils/airbrake.cjs +2 -1
  258. package/services/utils/redisConnection.cjs +6 -5
  259. package/services/utils/translation_helpers.cjs +3 -2
  260. package/services/utils/updateAllLocalesFromEn.js +20 -19
  261. package/services/utils/updateLocaleFolders.js +7 -6
  262. package/services/workers/activity.cjs +1 -1
  263. package/services/workers/anonymizations.cjs +1 -1
  264. package/services/workers/bulk_status_update.cjs +2 -2
  265. package/services/workers/delayed_jobs.cjs +1 -1
  266. package/services/workers/deletions.cjs +1 -1
  267. package/services/workers/email.cjs +1 -1
  268. package/services/workers/fraud_management.cjs +3 -3
  269. package/services/workers/generativeAi.js +6 -5
  270. package/services/workers/main.cjs +1 -1
  271. package/services/workers/marketing.cjs +1 -1
  272. package/services/workers/moderation.cjs +1 -1
  273. package/services/workers/notification_delivery.cjs +1 -1
  274. package/services/workers/notification_news_feed.cjs +1 -1
  275. package/services/workers/queue.cjs +2 -2
  276. package/services/workers/recount.cjs +1 -1
  277. package/services/workers/reports.cjs +1 -1
  278. package/services/workers/similarities.cjs +4 -2
  279. package/services/workers/speech_to_text.cjs +1 -1
  280. package/utils/airbrake.cjs +2 -1
  281. package/utils/cjsCodeReview.js +7 -6
  282. package/utils/community_mapping_tools.cjs +3 -2
  283. package/utils/copy_utils.cjs +32 -31
  284. package/utils/export_utils.cjs +7 -7
  285. package/utils/generateDocumentation.js +10 -9
  286. package/utils/logger.cjs +2 -23
  287. package/utils/logger.d.cts +1 -1
  288. package/utils/loggerAirbrakeTransport.cjs +52 -0
  289. package/utils/loggerAirbrakeTransport.d.cts +15 -0
  290. package/utils/loggerAirbrakeTransportTs.d.ts +15 -0
  291. package/utils/loggerAirbrakeTransportTs.js +45 -0
  292. package/utils/loggerCore.cjs +29 -0
  293. package/utils/loggerCore.d.cts +2 -0
  294. package/utils/loggerCoreTs.d.ts +2 -0
  295. package/utils/loggerCoreTs.js +23 -0
  296. package/utils/loggerTs.d.ts +1 -2
  297. package/utils/loggerTs.js +2 -25
  298. package/utils/manifest_generator.cjs +1 -0
  299. package/utils/recount_utils.cjs +6 -5
  300. package/utils/seedModels.js +50 -49
  301. package/utils/sitemap_generator.cjs +4 -4
  302. package/utils/ypLanguages.js +2 -2
  303. package/webSockets.js +8 -7
  304. package/services/utils/logger.cjs +0 -25
  305. package/services/utils/logger.d.cts +0 -2
  306. package/src/agents/assistants/assistant.d.ts +0 -156
  307. package/src/controllers/audios.d.ts +0 -5
  308. package/src/controllers/categories.d.ts +0 -5
  309. package/src/controllers/communities.d.ts +0 -5
  310. package/src/controllers/domains.d.ts +0 -5
  311. package/src/controllers/groups.d.ts +0 -5
  312. package/src/controllers/images.d.ts +0 -5
  313. package/src/controllers/points.d.ts +0 -5
  314. package/src/controllers/posts.d.ts +0 -5
  315. package/src/controllers/ratings.d.ts +0 -5
  316. package/src/controllers/users.d.ts +0 -5
  317. package/src/controllers/videos.d.ts +0 -5
  318. package/src/models/index.d.ts +0 -84
  319. package/src/services/controllers/activities.d.ts +0 -5
  320. package/src/services/controllers/notifications.d.ts +0 -5
  321. package/src/utils/copy_utils.d.ts +0 -4
  322. package/src/utils/manifest_generator.d.ts +0 -18
@@ -5,10 +5,10 @@ var fs = require('fs');
5
5
  var communityId = process.argv[2];
6
6
  var outFile = process.argv[3];
7
7
  var clean = function (text) {
8
- //console.log("Before: "+ text);
8
+ //log.info("Before: "+ text);
9
9
  if (text) {
10
10
  var newText = text.replace('"', "'").replace('\n', '').replace('\r', '').replace(/(\r\n|\n|\r)/gm, "").replace(/"/gm, "'").replace(',', ';').trim();
11
- //console.log("After:" + newText);
11
+ //log.info("After:" + newText);
12
12
  return newText.replace(/´/g, '');
13
13
  }
14
14
  else {
@@ -56,7 +56,7 @@ models.PointQuality.findAll({
56
56
  ]
57
57
  }).then(function (endorsements) {
58
58
  var outFileContent = "";
59
- console.log(endorsements.length);
59
+ log.info(endorsements.length);
60
60
  outFileContent += "Point qualities for Community Id: " + communityId + "\n";
61
61
  outFileContent += "User Id, External User Id, State, Group Id, Post Id, Point Id, Vote Value\n";
62
62
  async.eachSeries(endorsements, function (endorsement, seriesCallback) {
@@ -74,9 +74,9 @@ models.PointQuality.findAll({
74
74
  }, function (error) {
75
75
  fs.writeFile(outFile, outFileContent, function (err) {
76
76
  if (err) {
77
- console.log(err);
77
+ log.info(err);
78
78
  }
79
- console.log("The file was saved!");
79
+ log.info("The file was saved!");
80
80
  process.exit();
81
81
  });
82
82
  });
@@ -6,9 +6,9 @@ var communityId = 1017; // process.argv[2];
6
6
  var outFile = process.argv[3];
7
7
  let outFileContent = "";
8
8
  const clean = (text) => {
9
- //console.log("Before: "+ text);
9
+ //log.info("Before: "+ text);
10
10
  var newText = text.replace('"', "'").replace('\n', '').replace('\r', '').replace(/(\r\n|\n|\r)/gm, "").replace(/"/gm, "'").replace(/,/, ';').trim();
11
- //console.log("After:" + newText);
11
+ //log.info("After:" + newText);
12
12
  return newText.replace(/´/g, '');
13
13
  };
14
14
  const getPoints = (points) => {
@@ -18,7 +18,7 @@ const getPoints = (points) => {
18
18
  if (content.startsWith(",")) {
19
19
  content = content.substr(1);
20
20
  }
21
- console.log("content: " + content);
21
+ log.info("content: " + content);
22
22
  totalContent += content;
23
23
  });
24
24
  return totalContent;
@@ -37,7 +37,7 @@ const getPointsUpOrDown = (post, value) => {
37
37
  if (pointsText.startsWith(",")) {
38
38
  pointsText = pointsText.substr(1);
39
39
  }
40
- console.log("PointText: " + pointsText);
40
+ log.info("PointText: " + pointsText);
41
41
  return pointsText;
42
42
  };
43
43
  const getToxicityScore = (model) => {
@@ -91,7 +91,7 @@ models.Post.findAll({
91
91
  englishTranslation = translation.content;
92
92
  }
93
93
  else {
94
- console.error(error);
94
+ log.error(error);
95
95
  }
96
96
  addCrowdsourcingRow('post', post.Group.name, post.name, post.description, 0, post.counter_endorsements_up, post.counter_endorsements_down, post.id, getToxicityScore(post), englishTranslation);
97
97
  models.Point.findAll({
@@ -113,7 +113,7 @@ models.Post.findAll({
113
113
  else {
114
114
  pointTextContent = point.content;
115
115
  }
116
- console.log(pointTextContent);
116
+ log.info(pointTextContent);
117
117
  let req = {
118
118
  query: {
119
119
  textType: 'pointContent',
@@ -126,7 +126,7 @@ models.Post.findAll({
126
126
  englishTranslation = translation.content;
127
127
  }
128
128
  else {
129
- console.error(error);
129
+ log.error(error);
130
130
  }
131
131
  addCrowdsourcingRow('point', post.Group.name, post.name, pointTextContent, point.value, point.counter_quality_up, point.counter_quality_down, point.id, getToxicityScore(point), englishTranslation);
132
132
  pointsCallback();
@@ -137,9 +137,9 @@ models.Post.findAll({
137
137
  }, function (error) {
138
138
  fs.writeFile(outFile, outFileContent, function (err) {
139
139
  if (err) {
140
- console.log(err);
140
+ log.info(err);
141
141
  }
142
- console.log("The file was saved!");
142
+ log.info("The file was saved!");
143
143
  process.exit();
144
144
  });
145
145
  });
@@ -23,9 +23,9 @@ var getUserEmail = function (post) {
23
23
  };
24
24
  var clean = function (text) {
25
25
  if (text) {
26
- //console.log("Before: "+ text);
26
+ //log.info("Before: "+ text);
27
27
  var newText = text.replace('"', "'").replace('\n', '').replace('\r', '').replace(/(\r\n|\n|\r)/gm, "").replace(/"/gm, "'").replace(/,/, ';').trim();
28
- //console.log("After:" + newText);
28
+ //log.info("After:" + newText);
29
29
  return newText.replace(/´/g, '');
30
30
  }
31
31
  else {
@@ -48,7 +48,7 @@ var getPoints = function (points) {
48
48
  if (content.startsWith(",")) {
49
49
  content = content.substr(1);
50
50
  }
51
- console.log("content: " + content);
51
+ log.info("content: " + content);
52
52
  totalContent += content;
53
53
  });
54
54
  return totalContent;
@@ -67,7 +67,7 @@ var getPointsUpOrDown = function (post, value) {
67
67
  if (pointsText.startsWith(",")) {
68
68
  pointsText = pointsText.substr(1);
69
69
  }
70
- console.log("PointText: " + pointsText);
70
+ log.info("PointText: " + pointsText);
71
71
  return pointsText;
72
72
  };
73
73
  var getPointsUp = function (post) {
@@ -169,7 +169,7 @@ models.Post.unscoped().findAll({
169
169
  var outFilePostContent = "";
170
170
  var outFilePointForContent = "";
171
171
  var outFilePointAgainstContent = "";
172
- console.log(posts.length);
172
+ log.info(posts.length);
173
173
  var postCounter = 0;
174
174
  async.eachSeries(posts, function (post, seriesCallback) {
175
175
  if (!post.deleted) {
@@ -181,7 +181,7 @@ models.Post.unscoped().findAll({
181
181
  var outFileName = outFolderPath + "/posts/" + post.id + "_post_" + (post.language ? post.language : "??") + ".txt";
182
182
  fs.writeFile(outFileName, "Name: " + clean(post.name) + "\n\n" + clean(post.description), function (err) {
183
183
  if (err) {
184
- console.log(err);
184
+ log.info(err);
185
185
  }
186
186
  innerSeriesCallback();
187
187
  });
@@ -189,7 +189,7 @@ models.Post.unscoped().findAll({
189
189
  (innerSeriesCallback) => {
190
190
  fs.writeFile(outFolderPath + "/points_for/" + post.id + "_post_points_for_" + (post.language ? post.language : "??") + ".txt", getPointsUp(post), function (err) {
191
191
  if (err) {
192
- console.log(err);
192
+ log.info(err);
193
193
  }
194
194
  innerSeriesCallback();
195
195
  });
@@ -197,7 +197,7 @@ models.Post.unscoped().findAll({
197
197
  (innerSeriesCallback) => {
198
198
  fs.writeFile(outFolderPath + "/points_against/" + post.id + "_post_points_against_" + (post.language ? post.language : "??") + ".txt", getPointsDown(post), function (err) {
199
199
  if (err) {
200
- console.log(err);
200
+ log.info(err);
201
201
  }
202
202
  innerSeriesCallback();
203
203
  });
@@ -214,7 +214,7 @@ models.Post.unscoped().findAll({
214
214
  (innerSeriesCallback) => {
215
215
  fs.writeFile(outFolderPath + "/all/all_posts.txt", outFilePostContent, function (err) {
216
216
  if (err) {
217
- console.log(err);
217
+ log.info(err);
218
218
  }
219
219
  innerSeriesCallback();
220
220
  });
@@ -222,7 +222,7 @@ models.Post.unscoped().findAll({
222
222
  (innerSeriesCallback) => {
223
223
  fs.writeFile(outFolderPath + "/all/all_post_points_for.txt", outFilePointForContent, function (err) {
224
224
  if (err) {
225
- console.log(err);
225
+ log.info(err);
226
226
  }
227
227
  innerSeriesCallback();
228
228
  });
@@ -230,13 +230,13 @@ models.Post.unscoped().findAll({
230
230
  (innerSeriesCallback) => {
231
231
  fs.writeFile(outFolderPath + "/all/all_post_points_against.txt", outFilePointAgainstContent, function (err) {
232
232
  if (err) {
233
- console.log(err);
233
+ log.info(err);
234
234
  }
235
235
  innerSeriesCallback();
236
236
  });
237
237
  }
238
238
  ], () => {
239
- console.log("Done");
239
+ log.info("Done");
240
240
  process.exit();
241
241
  });
242
242
  });
@@ -23,9 +23,9 @@ var getUserEmail = function (post) {
23
23
  }
24
24
  };
25
25
  var clean = function (text) {
26
- //console.log("Before: "+ text);
26
+ //log.info("Before: "+ text);
27
27
  var newText = text.replace('"', "'").replace('\n', '').replace('\r', '').replace(/(\r\n|\n|\r)/gm, "").replace(/"/gm, "'").replace(/,/, ';').trim();
28
- //console.log("After:" + newText);
28
+ //log.info("After:" + newText);
29
29
  return newText.replace(/´/g, '');
30
30
  };
31
31
  var getLocation = function (post) {
@@ -44,7 +44,7 @@ var getPoints = function (points) {
44
44
  if (content.startsWith(",")) {
45
45
  content = content.substr(1);
46
46
  }
47
- console.log("content: " + content);
47
+ log.info("content: " + content);
48
48
  totalContent += content;
49
49
  });
50
50
  return totalContent;
@@ -63,7 +63,7 @@ var getPointsUpOrDown = function (post, value) {
63
63
  if (pointsText.startsWith(",")) {
64
64
  pointsText = pointsText.substr(1);
65
65
  }
66
- console.log("PointText: " + pointsText);
66
+ log.info("PointText: " + pointsText);
67
67
  return pointsText;
68
68
  };
69
69
  var getPointsUp = function (post) {
@@ -144,7 +144,7 @@ models.Post.unscoped().findAll({
144
144
  ]
145
145
  }).then(function (posts) {
146
146
  var outFileContent = "";
147
- console.log(posts.length);
147
+ log.info(posts.length);
148
148
  outFileContent += "Id, Post id,email,User Name,Post Name,Description,Url,Category,Latitude,Longitude,Up Votes,Down Votes,Points Count,Points For,Points Against,Images\n";
149
149
  postCounter = 0;
150
150
  async.eachSeries(posts, function (post, seriesCallback) {
@@ -163,9 +163,9 @@ models.Post.unscoped().findAll({
163
163
  }, function (error) {
164
164
  fs.writeFile(outFile, outFileContent, function (err) {
165
165
  if (err) {
166
- console.log(err);
166
+ log.info(err);
167
167
  }
168
- console.log("The file was saved!");
168
+ log.info("The file was saved!");
169
169
  process.exit();
170
170
  });
171
171
  });
@@ -1,6 +1,6 @@
1
1
  const models = require('../models/index.cjs');
2
2
  var postId = process.argv[2];
3
- console.log(`Id,PostId,TypeIndex,Value`);
3
+ log.info(`Id,PostId,TypeIndex,Value`);
4
4
  models.Rating.findAll({
5
5
  where: {
6
6
  post_id: postId
@@ -8,7 +8,7 @@ models.Rating.findAll({
8
8
  attributes: ['id', 'post_id', 'value', 'type_index']
9
9
  }).then(ratings => {
10
10
  ratings.forEach(rating => {
11
- console.log(`${rating.id},${rating.post_id},${rating.type_index},${rating.value}`);
11
+ log.info(`${rating.id},${rating.post_id},${rating.type_index},${rating.value}`);
12
12
  });
13
13
  process.exit();
14
14
  });
@@ -51,7 +51,7 @@ models.Group.findOne({
51
51
  ]
52
52
  }).then(function (endorsements) {
53
53
  var outFileContent = "";
54
- console.log(endorsements.length);
54
+ log.info(endorsements.length);
55
55
  outFileContent += "Post endorsements for Group Id: " + groupId + "\n";
56
56
  outFileContent += "Post Id,Post Name,Value,Category Id,Category Name,User Id";
57
57
  if (registrationQuestions) {
@@ -107,17 +107,17 @@ models.Group.findOne({
107
107
  }, function (error) {
108
108
  fs.writeFile(outFile, outFileContent, function (err) {
109
109
  if (err) {
110
- console.log(err);
110
+ log.info(err);
111
111
  }
112
- console.log("The file was saved!");
113
- console.log(`${notValidCounter} not valid entries ${notValidUserCounter} not valid users ${nullValueCounter} 0 values`);
114
- console.log(`${validUsersCount} valid users`);
112
+ log.info("The file was saved!");
113
+ log.info(`${notValidCounter} not valid entries ${notValidUserCounter} not valid users ${nullValueCounter} 0 values`);
114
+ log.info(`${validUsersCount} valid users`);
115
115
  process.exit();
116
116
  });
117
117
  });
118
118
  });
119
119
  }).catch(error => {
120
- console.error(error);
120
+ log.error(error);
121
121
  process.exit();
122
122
  });
123
123
  export {};
@@ -12,10 +12,10 @@ models.Community.findOne({
12
12
  }
13
13
  ]
14
14
  }).then(function (community) {
15
- console.log(community.CommunityUsers.length);
16
- console.log("email, Name");
15
+ log.info(community.CommunityUsers.length);
16
+ log.info("email, Name");
17
17
  async.eachSeries(community.CommunityUsers, function (user, seriesCallback) {
18
- console.log('"' + user.email + '","' + user.name + '"');
18
+ log.info('"' + user.email + '","' + user.name + '"');
19
19
  seriesCallback();
20
20
  }, function () {
21
21
  process.exit();
@@ -12,10 +12,10 @@ models.Domain.findOne({
12
12
  }
13
13
  ]
14
14
  }).then(function (domain) {
15
- console.log(domain.DomainUsers.length);
16
- console.log("email,name,kt");
15
+ log.info(domain.DomainUsers.length);
16
+ log.info("email,name,kt");
17
17
  async.eachSeries(domain.DomainUsers, function (user, seriesCallback) {
18
- console.log('"' + user.email + '","' + user.name + '"' + (user.ssn ? ',' + user.ssn : ''));
18
+ log.info('"' + user.email + '","' + user.name + '"' + (user.ssn ? ',' + user.ssn : ''));
19
19
  seriesCallback();
20
20
  }, function () {
21
21
  process.exit();
@@ -12,10 +12,10 @@ models.Group.findOne({
12
12
  }
13
13
  ]
14
14
  }).then(function (group) {
15
- console.log(group.GroupUsers.length);
16
- console.log("email, Name");
15
+ log.info(group.GroupUsers.length);
16
+ log.info("email, Name");
17
17
  async.eachSeries(group.GroupUsers, function (user, seriesCallback) {
18
- console.log('"' + user.email + '","' + user.name + '"');
18
+ log.info('"' + user.email + '","' + user.name + '"');
19
19
  seriesCallback();
20
20
  }, function () {
21
21
  process.exit();
@@ -60,12 +60,12 @@ models.Rating.findAll({
60
60
  }
61
61
  ]
62
62
  }).then((ratings) => {
63
- console.log(`"Vote distribution report for ${ratings[0].Post.Group.Community.name}"`);
64
- console.log(`"Rating value","Vote count"`);
65
- console.log(`"1+",${countRatings(1, 2, ratings)}`);
66
- console.log(`"2+",${countRatings(2, 3, ratings)}`);
67
- console.log(`"3+",${countRatings(3, 4, ratings)}`);
68
- console.log(`"4+",${countRatings(4, 5, ratings)}`);
63
+ log.info(`"Vote distribution report for ${ratings[0].Post.Group.Community.name}"`);
64
+ log.info(`"Rating value","Vote count"`);
65
+ log.info(`"1+",${countRatings(1, 2, ratings)}`);
66
+ log.info(`"2+",${countRatings(2, 3, ratings)}`);
67
+ log.info(`"3+",${countRatings(3, 4, ratings)}`);
68
+ log.info(`"4+",${countRatings(4, 5, ratings)}`);
69
69
  process.exit();
70
70
  });
71
71
  export {};
@@ -46,10 +46,10 @@ models.Endorsement.findAll({
46
46
  }
47
47
  ]
48
48
  }).then((endorsements) => {
49
- console.log(`"Up / Down","Email","Name","Post Id","Post name","Group name"\n`);
49
+ log.info(`"Up / Down","Email","Name","Post Id","Post name","Group name"\n`);
50
50
  for (let i = 0; i < endorsements.length; i++) {
51
51
  const e = endorsements[i];
52
- console.log(`${e.value},"${e.User.email}","${e.User.name}","${e.Post.id}","${e.Post.name}","${e.Post.Group.name}"`);
52
+ log.info(`${e.value},"${e.User.email}","${e.User.name}","${e.Post.id}","${e.Post.name}","${e.Post.Group.name}"`);
53
53
  }
54
54
  process.exit();
55
55
  });
@@ -15,7 +15,7 @@ var walkSync = function (dir, filelist) {
15
15
  filelist.push(path.join(dir, file));
16
16
  }
17
17
  else {
18
- //console.error("SKIP: "+ dir);
18
+ //log.error("SKIP: "+ dir);
19
19
  }
20
20
  }
21
21
  }
@@ -45,7 +45,7 @@ var checkFile = function (filePath) {
45
45
  }
46
46
  });
47
47
  if (!found) {
48
- console.error(filePath + ": " + elementObject.element + ">");
48
+ log.error(filePath + ": " + elementObject.element + ">");
49
49
  }
50
50
  });
51
51
  };
@@ -15,7 +15,7 @@ models.Post.findAll({}).then(function (posts) {
15
15
  });
16
16
  });
17
17
  }, function (error) {
18
- console.log("Done updating posts: " + postsCount);
18
+ log.info("Done updating posts: " + postsCount);
19
19
  process.exit();
20
20
  });
21
21
  });
@@ -26,7 +26,7 @@ models.User.findAll({
26
26
  }
27
27
  if (changed) {
28
28
  user.save().then(() => {
29
- console.log(`Saved ${user.email}`);
29
+ log.info(`Saved ${user.email}`);
30
30
  callback();
31
31
  }).catch((error) => {
32
32
  callback(error);
@@ -37,12 +37,12 @@ models.User.findAll({
37
37
  }
38
38
  }, (error) => {
39
39
  if (error)
40
- console.error(error);
41
- console.log(`groupChangeCount ${groupChangeCount}`);
42
- console.log(`communityChangeCount ${communityChangeCount}`);
40
+ log.error(error);
41
+ log.info(`groupChangeCount ${groupChangeCount}`);
42
+ log.info(`communityChangeCount ${communityChangeCount}`);
43
43
  process.exit();
44
44
  });
45
45
  }).catch(error => {
46
- console.error(error);
46
+ log.error(error);
47
47
  });
48
48
  export {};
@@ -3,7 +3,7 @@ var async = require('async');
3
3
  models.Group.findOne({ where: { id: 752 } }).then(function (group) {
4
4
  group.counter_points = 0;
5
5
  group.save().then(function () {
6
- console.log("log");
6
+ log.info("log");
7
7
  });
8
8
  });
9
9
  export {};
@@ -77,7 +77,7 @@ var fixOnePost = function (groupId, postId, done) {
77
77
  }).then(function (postIn) {
78
78
  oldPost = postIn;
79
79
  if (!postIn) {
80
- console.error("No post in");
80
+ log.error("No post in");
81
81
  callback("no post");
82
82
  }
83
83
  else {
@@ -108,7 +108,7 @@ var fixOnePost = function (groupId, postId, done) {
108
108
  }
109
109
  }).then(function (alreadyUpdatedEndorsement) {
110
110
  if (alreadyUpdatedEndorsement) {
111
- console.warn("Already updated endorsement");
111
+ log.warn("Already updated endorsement");
112
112
  endorsementCallback();
113
113
  }
114
114
  else {
@@ -127,12 +127,12 @@ var fixOnePost = function (groupId, postId, done) {
127
127
  });
128
128
  }
129
129
  ], function (error) {
130
- console.log("Have fixed post to group id");
130
+ log.info("Have fixed post to group id");
131
131
  callback(error);
132
132
  });
133
133
  }
134
134
  else {
135
- console.error("Did not find post");
135
+ log.error("Did not find post");
136
136
  callback();
137
137
  }
138
138
  }).catch(function (error) {
@@ -142,15 +142,15 @@ var fixOnePost = function (groupId, postId, done) {
142
142
  });
143
143
  }
144
144
  ], function (error) {
145
- console.log("Done");
145
+ log.info("Done");
146
146
  if (error)
147
- console.error(error);
147
+ log.error(error);
148
148
  done(error);
149
149
  });
150
150
  };
151
151
  var parsePosts = function (allPosts, done) {
152
152
  async.eachSeries(allPosts, function (post, seriesCallback) {
153
- console.log("Post: " + post[0]);
153
+ log.info("Post: " + post[0]);
154
154
  fixOnePost(toGroupId, getPostIdFromUrl(post[6]), function (error) {
155
155
  seriesCallback(error);
156
156
  });
@@ -172,19 +172,19 @@ var copyManyFromCsv = function (csvUrl, done) {
172
172
  if (onePostId != 'null') {
173
173
  copyOnePost(toGroupId, onePostId, null, function (error) {
174
174
  if (error)
175
- console.error(error);
175
+ log.error(error);
176
176
  process.exit();
177
177
  });
178
178
  }
179
179
  else if (csvFileName && userIdToPostNewsStory) {
180
180
  copyManyFromCsv(csvFileName, function (error) {
181
181
  if (error)
182
- console.error(error);
182
+ log.error(error);
183
183
  process.exit();
184
184
  });
185
185
  }
186
186
  else {
187
- console.error("Invalid start state");
187
+ log.error("Invalid start state");
188
188
  process.exit();
189
189
  }
190
190
  export {};
@@ -14,9 +14,9 @@ models.User.findAll({
14
14
  callback();
15
15
  }
16
16
  }, (error) => {
17
- console.log("Done");
17
+ log.info("Done");
18
18
  if (error)
19
- console.error(error);
19
+ log.error(error);
20
20
  process.exit();
21
21
  });
22
22
  });
@@ -1,15 +1,15 @@
1
1
  var models = require('../models/index.cjs');
2
2
  var async = require('async');
3
- console.log("Fix group");
3
+ log.info("Fix group");
4
4
  models.Group.findAll({ where: { access: 1 } }).then(function (groups) {
5
5
  async.eachSeries(groups, function (group, seriesCallback) {
6
6
  group.access = models.Group.ACCESS_OPEN_TO_COMMUNITY;
7
7
  group.save().then(function () {
8
- console.log("Changed to open to community " + group.name);
8
+ log.info("Changed to open to community " + group.name);
9
9
  seriesCallback();
10
10
  });
11
11
  }, function (error) {
12
- console.log("Finished");
12
+ log.info("Finished");
13
13
  process.exit();
14
14
  });
15
15
  });
@@ -32,7 +32,7 @@ async.series([
32
32
  }
33
33
  ], function (error) {
34
34
  if (error) {
35
- console.error(error);
35
+ log.error(error);
36
36
  process.exit();
37
37
  }
38
38
  else {
@@ -40,7 +40,7 @@ async.series([
40
40
  group.counter_posts = postsCount;
41
41
  group.counter_points = pointsCount;
42
42
  group.save().then(function () {
43
- console.log("Have updated group");
43
+ log.info("Have updated group");
44
44
  process.exit();
45
45
  });
46
46
  });
@@ -1,6 +1,6 @@
1
1
  var models = require('../models/index.cjs');
2
2
  var async = require('async');
3
- console.log("Fixing Notifications Settings");
3
+ log.info("Fixing Notifications Settings");
4
4
  var loopyloop = true;
5
5
  var numberOfRows = 25000;
6
6
  var offset = 0;
@@ -12,7 +12,7 @@ async.whilst(function () { return loopyloop; }, function (whilstCallback) {
12
12
  if (users && users.length > 0) {
13
13
  offset += numberOfRows;
14
14
  async.eachSeries(users, function (user, seriesCallback) {
15
- // console.log(user.email);
15
+ // log.info(user.email);
16
16
  if (user.notifications_settings) {
17
17
  user.set('notifications_settings.all_group.method', 0);
18
18
  user.set('notifications_settings.all_community.method', 0);
@@ -24,12 +24,12 @@ async.whilst(function () { return loopyloop; }, function (whilstCallback) {
24
24
  seriesCallback();
25
25
  });
26
26
  }, function (error) {
27
- console.log("Finished with rows continue");
27
+ log.info("Finished with rows continue");
28
28
  whilstCallback();
29
29
  });
30
30
  }
31
31
  else {
32
- console.log("Finished with rows ENDING");
32
+ log.info("Finished with rows ENDING");
33
33
  loopyloop = false;
34
34
  whilstCallback();
35
35
  }
@@ -1,13 +1,13 @@
1
1
  var models = require("../models/index.cjs");
2
2
  var async = require("async");
3
- console.log("Fix group");
3
+ log.info("Fix group");
4
4
  const groupId = process.argv[2];
5
5
  const getSubCodeFromRadio = (radios, answer) => {
6
6
  let subCode;
7
7
  if (radios) {
8
8
  for (let i = 0; i < radios.length; i++) {
9
- //console.log(answer);
10
- //console.log(`${radios[i].subCode.trim()} !`)
9
+ //log.info(answer);
10
+ //log.info(`${radios[i].subCode.trim()} !`)
11
11
  if (answer.startsWith(`${radios[i].subCode.trim()} `)) {
12
12
  subCode = radios[i].subCode;
13
13
  break;
@@ -18,11 +18,11 @@ const getSubCodeFromRadio = (radios, answer) => {
18
18
  };
19
19
  const fixRadioDescriptionIfNeeded = (answers, questionsById, i) => {
20
20
  let currentValue = answers[i].value;
21
- console.log(currentValue);
21
+ log.info(currentValue);
22
22
  const subCode = getSubCodeFromRadio(questionsById[answers[i].uniqueId].radioButtons, answers[i].value);
23
23
  if (subCode) {
24
24
  currentValue = currentValue.replace(`${subCode} `, '');
25
- console.log(currentValue);
25
+ log.info(currentValue);
26
26
  }
27
27
  return currentValue;
28
28
  };
@@ -56,7 +56,7 @@ models.Group.findOne({ where: { id: groupId } }).then((group) => {
56
56
  async.eachSeries(posts, (post, seriesCallback) => {
57
57
  processPost(group, post, seriesCallback);
58
58
  }, function (error) {
59
- console.log("Finished");
59
+ log.info("Finished");
60
60
  process.exit();
61
61
  });
62
62
  });