decidim-core 0.26.9 → 0.27.0.rc1

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of decidim-core might be problematic. Click here for more details.

Files changed (643) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +1 -1
  3. data/app/cells/decidim/amendable/announcement_cell.rb +4 -9
  4. data/app/cells/decidim/announcement_cell.rb +2 -2
  5. data/app/cells/decidim/author_cell.rb +1 -1
  6. data/app/cells/decidim/card_m_cell.rb +1 -1
  7. data/app/cells/decidim/collapsible_list/show.erb +1 -1
  8. data/app/cells/decidim/content_blocks/cta/show.erb +1 -1
  9. data/app/cells/decidim/content_blocks/cta_cell.rb +1 -1
  10. data/app/cells/decidim/content_blocks/footer_sub_hero/show.erb +1 -1
  11. data/app/cells/decidim/content_blocks/hero/show.erb +2 -2
  12. data/app/cells/decidim/content_blocks/highlighted_content_banner/show.erb +5 -5
  13. data/app/cells/decidim/content_blocks/highlighted_elements_cell.rb +1 -1
  14. data/app/cells/decidim/content_blocks/how_to_participate/show.erb +1 -1
  15. data/app/cells/decidim/content_blocks/last_activity/show.erb +1 -1
  16. data/app/cells/decidim/content_blocks/last_activity_cell.rb +3 -3
  17. data/app/cells/decidim/content_blocks/stats_cell.rb +4 -5
  18. data/app/cells/decidim/content_blocks/sub_hero/show.erb +1 -1
  19. data/app/cells/decidim/content_blocks/sub_hero_cell.rb +1 -1
  20. data/app/cells/decidim/data_consent/category.erb +64 -0
  21. data/app/cells/decidim/data_consent/dialog.erb +29 -0
  22. data/app/cells/decidim/data_consent/modal.erb +39 -0
  23. data/app/cells/decidim/data_consent/show.erb +3 -0
  24. data/app/cells/decidim/data_consent_cell.rb +21 -0
  25. data/app/cells/decidim/follow_button_cell.rb +5 -7
  26. data/app/cells/decidim/newsletter_templates/base_cell.rb +0 -8
  27. data/app/cells/decidim/newsletter_templates/basic_only_text/show.erb +4 -4
  28. data/app/cells/decidim/newsletter_templates/image_text_cta/show.erb +4 -4
  29. data/app/cells/decidim/profile_sidebar_cell.rb +1 -1
  30. data/app/cells/decidim/search_results_cell.rb +1 -1
  31. data/app/cells/decidim/tos_page/refuse_btn_modal.erb +1 -1
  32. data/app/cells/decidim/upload_modal/files.erb +52 -0
  33. data/app/cells/decidim/upload_modal/modal.erb +49 -0
  34. data/app/cells/decidim/upload_modal/show.erb +3 -0
  35. data/app/cells/decidim/upload_modal_cell.rb +205 -0
  36. data/app/cells/decidim/user_conversation/reply.erb +1 -1
  37. data/app/cells/decidim/user_conversations/add_conversation_users.erb +5 -3
  38. data/app/cells/decidim/version_cell.rb +3 -14
  39. data/app/cells/decidim/versions_list_cell.rb +3 -14
  40. data/app/cells/decidim/versions_list_item_cell.rb +2 -13
  41. data/app/commands/decidim/accept_group_invitation.rb +1 -1
  42. data/app/commands/decidim/accept_user_group_join_request.rb +1 -1
  43. data/app/commands/decidim/amendable/accept.rb +1 -1
  44. data/app/commands/decidim/amendable/create_draft.rb +1 -1
  45. data/app/commands/decidim/amendable/destroy_draft.rb +1 -1
  46. data/app/commands/decidim/amendable/promote.rb +1 -1
  47. data/app/commands/decidim/amendable/publish_draft.rb +1 -1
  48. data/app/commands/decidim/amendable/reject.rb +1 -1
  49. data/app/commands/decidim/amendable/update_draft.rb +1 -1
  50. data/app/commands/decidim/amendable/withdraw.rb +1 -1
  51. data/app/commands/decidim/attachment_methods.rb +3 -2
  52. data/app/commands/decidim/create_editor_image.rb +1 -1
  53. data/app/commands/decidim/create_follow.rb +1 -1
  54. data/app/commands/decidim/create_omniauth_registration.rb +2 -3
  55. data/app/commands/decidim/create_registration.rb +1 -2
  56. data/app/commands/decidim/create_report.rb +1 -1
  57. data/app/commands/decidim/create_user_group.rb +2 -2
  58. data/app/commands/decidim/create_user_report.rb +5 -3
  59. data/app/commands/decidim/delete_follow.rb +1 -1
  60. data/app/commands/decidim/demote_membership.rb +1 -1
  61. data/app/commands/decidim/destroy_account.rb +1 -1
  62. data/app/commands/decidim/endorse_resource.rb +1 -3
  63. data/app/commands/decidim/gallery_methods.rb +45 -10
  64. data/app/commands/decidim/invite_user.rb +1 -3
  65. data/app/commands/decidim/invite_user_again.rb +1 -1
  66. data/app/commands/decidim/invite_user_to_group.rb +1 -1
  67. data/app/commands/decidim/join_user_group.rb +1 -1
  68. data/app/commands/decidim/leave_user_group.rb +8 -2
  69. data/app/commands/decidim/messaging/reply_to_conversation.rb +2 -2
  70. data/app/commands/decidim/messaging/start_conversation.rb +2 -2
  71. data/app/commands/decidim/multiple_attachments_methods.rb +44 -5
  72. data/app/commands/decidim/promote_membership.rb +1 -1
  73. data/app/commands/decidim/reject_group_invitation.rb +1 -1
  74. data/app/commands/decidim/reject_user_group_join_request.rb +1 -1
  75. data/app/commands/decidim/remove_user_from_group.rb +1 -1
  76. data/app/commands/decidim/resend_confirmation_instructions.rb +18 -0
  77. data/app/commands/decidim/search.rb +10 -9
  78. data/app/commands/decidim/unendorse_resource.rb +2 -2
  79. data/app/commands/decidim/unsubscribe_settings.rb +1 -1
  80. data/app/commands/decidim/update_account.rb +2 -2
  81. data/app/commands/decidim/update_notifications_settings.rb +3 -2
  82. data/app/commands/decidim/update_password.rb +31 -0
  83. data/app/commands/decidim/update_user_group.rb +2 -2
  84. data/app/commands/decidim/update_user_interests.rb +1 -1
  85. data/app/commands/decidim/validate_upload.rb +15 -0
  86. data/app/controllers/concerns/decidim/devise_controllers.rb +0 -1
  87. data/app/controllers/concerns/decidim/filter_resource.rb +23 -24
  88. data/app/controllers/concerns/decidim/force_authentication.rb +1 -2
  89. data/app/controllers/concerns/decidim/http_caching_disabler.rb +1 -1
  90. data/app/controllers/concerns/decidim/needs_password_change.rb +43 -0
  91. data/app/controllers/concerns/decidim/needs_tos_accepted.rb +3 -3
  92. data/app/controllers/concerns/decidim/orderable.rb +1 -1
  93. data/app/controllers/concerns/decidim/participatory_space_context.rb +2 -2
  94. data/app/controllers/concerns/decidim/resource_versions_concern.rb +0 -4
  95. data/app/controllers/decidim/account_controller.rb +45 -0
  96. data/app/controllers/decidim/application_controller.rb +1 -1
  97. data/app/controllers/decidim/authorization_modals_controller.rb +1 -1
  98. data/app/controllers/decidim/devise/invitations_controller.rb +4 -9
  99. data/app/controllers/decidim/devise/passwords_controller.rb +33 -0
  100. data/app/controllers/decidim/devise/registrations_controller.rb +3 -5
  101. data/app/controllers/decidim/devise/sessions_controller.rb +2 -0
  102. data/app/controllers/decidim/{data_portability_controller.rb → download_your_data_controller.rb} +8 -8
  103. data/app/controllers/decidim/groups_controller.rb +5 -5
  104. data/app/controllers/decidim/last_activities_controller.rb +7 -9
  105. data/app/controllers/decidim/links_controller.rb +11 -10
  106. data/app/controllers/decidim/manifests_controller.rb +11 -0
  107. data/app/controllers/decidim/newsletters_controller.rb +1 -1
  108. data/app/controllers/decidim/notifications_subscriptions_controller.rb +16 -0
  109. data/app/controllers/decidim/offline_controller.rb +7 -0
  110. data/app/controllers/decidim/profiles_controller.rb +2 -2
  111. data/app/controllers/decidim/searches_controller.rb +4 -3
  112. data/app/controllers/decidim/short_links_controller.rb +35 -0
  113. data/app/controllers/decidim/upload_validations_controller.rb +44 -0
  114. data/app/controllers/decidim/user_activities_controller.rb +32 -16
  115. data/app/controllers/decidim/user_interests_controller.rb +0 -2
  116. data/app/controllers/decidim/user_timeline_controller.rb +7 -9
  117. data/app/events/decidim/change_nickname_event.rb +21 -0
  118. data/app/events/decidim/resource_endorsed_event.rb +1 -2
  119. data/app/forms/decidim/account_form.rb +4 -4
  120. data/app/forms/decidim/amendable/form.rb +1 -2
  121. data/app/forms/decidim/form.rb +1 -1
  122. data/app/forms/decidim/messaging/conversation_form.rb +1 -1
  123. data/app/forms/decidim/notifications_settings_form.rb +16 -2
  124. data/app/forms/decidim/password_form.rb +10 -0
  125. data/app/forms/decidim/registration_form.rb +3 -3
  126. data/app/forms/decidim/upload_validation_form.rb +54 -0
  127. data/app/forms/decidim/user_group_form.rb +1 -1
  128. data/app/forms/decidim/user_interest_scope_form.rb +1 -1
  129. data/app/forms/decidim/user_interests_form.rb +1 -1
  130. data/app/forms/translatable_presence_validator.rb +2 -2
  131. data/app/forms/url_validator.rb +1 -1
  132. data/app/helpers/decidim/application_helper.rb +2 -2
  133. data/app/helpers/decidim/attachments_helper.rb +1 -1
  134. data/app/helpers/decidim/cells_helper.rb +0 -1
  135. data/app/helpers/decidim/cells_paginate_helper.rb +1 -1
  136. data/app/helpers/decidim/datalist_select_helper.rb +40 -0
  137. data/app/helpers/decidim/decidim_form_helper.rb +1 -1
  138. data/app/helpers/decidim/external_domain_helper.rb +3 -14
  139. data/app/helpers/decidim/filters_helper.rb +1 -5
  140. data/app/helpers/decidim/followable_helper.rb +1 -1
  141. data/app/helpers/decidim/icon_helper.rb +4 -4
  142. data/app/helpers/decidim/layout_helper.rb +19 -16
  143. data/app/helpers/decidim/map_helper.rb +12 -8
  144. data/app/helpers/decidim/meta_tags_helper.rb +0 -2
  145. data/app/helpers/decidim/newsletters_helper.rb +0 -1
  146. data/app/helpers/decidim/notifications_settings_helper.rb +15 -0
  147. data/app/helpers/decidim/passwords_helper.rb +41 -0
  148. data/app/helpers/decidim/resource_helper.rb +0 -2
  149. data/app/helpers/decidim/sanitize_helper.rb +6 -15
  150. data/app/helpers/decidim/searches_helper.rb +6 -6
  151. data/app/helpers/decidim/short_link_helper.rb +28 -0
  152. data/app/helpers/decidim/translations_helper.rb +2 -2
  153. data/app/jobs/decidim/{data_portability_export_job.rb → download_your_data_export_job.rb} +5 -8
  154. data/app/jobs/decidim/email_notifications_digest_generator_job.rb +21 -0
  155. data/app/jobs/decidim/notification_generator_for_recipient_job.rb +5 -3
  156. data/app/jobs/decidim/open_data_job.rb +0 -2
  157. data/app/jobs/decidim/reminder_generator_job.rb +12 -0
  158. data/app/jobs/decidim/resend_confirmation_instructions_job.rb +11 -0
  159. data/app/jobs/decidim/user_report_job.rb +2 -2
  160. data/app/mailers/concerns/decidim/multitenant_asset_host.rb +11 -3
  161. data/app/mailers/decidim/application_mailer.rb +1 -1
  162. data/app/mailers/decidim/block_user_mailer.rb +8 -7
  163. data/app/mailers/decidim/export_mailer.rb +2 -2
  164. data/app/mailers/decidim/newsletter_mailer.rb +5 -12
  165. data/app/mailers/decidim/newsletters_opt_in_mailer.rb +7 -5
  166. data/app/mailers/decidim/notification_mailer.rb +0 -1
  167. data/app/mailers/decidim/notifications_digest_mailer.rb +23 -0
  168. data/app/mailers/decidim/user_report_mailer.rb +10 -11
  169. data/app/models/decidim/action_log.rb +95 -11
  170. data/app/models/decidim/amendment.rb +0 -1
  171. data/app/models/decidim/area.rb +1 -2
  172. data/app/models/decidim/area_type.rb +5 -0
  173. data/app/models/decidim/attachment.rb +6 -0
  174. data/app/models/decidim/attachment_collection.rb +5 -0
  175. data/app/models/decidim/category.rb +9 -4
  176. data/app/models/decidim/coauthorship.rb +0 -2
  177. data/app/models/decidim/contextual_help_section.rb +5 -1
  178. data/app/models/decidim/follow.rb +2 -2
  179. data/app/models/decidim/gamification/badge_score.rb +0 -1
  180. data/app/models/decidim/identity.rb +2 -2
  181. data/app/models/decidim/messaging/conversation.rb +4 -4
  182. data/app/models/decidim/messaging/message.rb +1 -2
  183. data/app/models/decidim/messaging/participation.rb +0 -2
  184. data/app/models/decidim/messaging/receipt.rb +0 -2
  185. data/app/models/decidim/newsletter.rb +0 -28
  186. data/app/models/decidim/notification.rb +5 -2
  187. data/app/models/decidim/oauth_application.rb +12 -1
  188. data/app/models/decidim/organization.rb +7 -13
  189. data/app/models/decidim/participatory_space_private_user.rb +4 -2
  190. data/app/models/decidim/permission_action.rb +1 -0
  191. data/app/models/decidim/reminder.rb +10 -0
  192. data/app/models/decidim/reminder_delivery.rb +7 -0
  193. data/app/models/decidim/reminder_record.rb +29 -0
  194. data/app/models/decidim/report.rb +2 -2
  195. data/app/models/decidim/scope.rb +3 -4
  196. data/app/models/decidim/scope_type.rb +1 -24
  197. data/app/models/decidim/share_token.rb +0 -2
  198. data/app/models/decidim/short_link.rb +162 -0
  199. data/app/models/decidim/user.rb +35 -13
  200. data/app/models/decidim/user_base_entity.rb +1 -4
  201. data/app/models/decidim/user_block.rb +2 -2
  202. data/app/models/decidim/user_group.rb +4 -4
  203. data/app/models/decidim/user_moderation.rb +0 -2
  204. data/app/models/decidim/user_report.rb +2 -2
  205. data/app/packs/entrypoints/decidim_core.js +2 -2
  206. data/app/packs/entrypoints/decidim_sw.js +1 -0
  207. data/app/packs/images/decidim/gamification/badges/decidim_gamification_badges_invitations.svg +1 -0
  208. data/app/packs/src/decidim/autocomplete.js +298 -0
  209. data/app/packs/src/decidim/cookie_consent/consent_manager.js +133 -0
  210. data/app/packs/src/decidim/cookie_consent/cookie_consent.js +103 -0
  211. data/app/packs/src/decidim/datalist_select.js +36 -0
  212. data/app/packs/src/decidim/direct_uploads/upload_field.js +117 -0
  213. data/app/packs/src/decidim/direct_uploads/upload_modal.js +264 -0
  214. data/app/packs/src/decidim/direct_uploads/upload_utility.js +49 -0
  215. data/app/packs/src/decidim/direct_uploads/uploader.js +89 -0
  216. data/app/packs/src/decidim/editor/linebreak_module.js +8 -0
  217. data/app/packs/src/decidim/editor.js +33 -70
  218. data/app/packs/src/decidim/external_domain_warning.js +1 -1
  219. data/app/packs/src/decidim/external_link.js +14 -3
  220. data/app/packs/src/decidim/external_link.test.js +64 -0
  221. data/app/packs/src/decidim/form_filter.component.test.js +5 -148
  222. data/app/packs/src/decidim/form_filter.js +4 -26
  223. data/app/packs/src/decidim/geocoding/attach_input.js +1 -4
  224. data/app/packs/src/decidim/geocoding/provider/here.js +21 -17
  225. data/app/packs/src/decidim/geocoding/provider/photon.js +1 -1
  226. data/app/packs/src/decidim/geocoding.js +10 -35
  227. data/app/packs/src/decidim/identity_selector_dialog.js +1 -1
  228. data/app/packs/src/decidim/impersonation.js +3 -3
  229. data/app/packs/src/decidim/input_character_counter.js +177 -7
  230. data/app/packs/src/decidim/input_multiple_mentions.js +87 -187
  231. data/app/packs/src/decidim/map/controller/drag_marker.js +2 -0
  232. data/app/packs/src/decidim/map/controller/markers.js +1 -0
  233. data/app/packs/src/decidim/map/controller/static.js +1 -0
  234. data/app/packs/src/decidim/map/controller.js +2 -0
  235. data/app/packs/src/decidim/map/factory.js +1 -4
  236. data/app/packs/src/decidim/map/icon.js +3 -1
  237. data/app/packs/src/decidim/map/legacy.js +1 -0
  238. data/app/packs/src/decidim/map/provider/default.js +0 -2
  239. data/app/packs/src/decidim/map/provider/here.js +1 -2
  240. data/app/packs/src/decidim/map/svg-icon.js +248 -0
  241. data/app/packs/src/decidim/security/selfxss_warning.js +5 -1
  242. data/app/packs/src/decidim/session_timeouter.js +15 -15
  243. data/app/packs/src/decidim/sw/a2hs.js +28 -0
  244. data/app/packs/src/decidim/sw/index.js +3 -0
  245. data/app/packs/src/decidim/sw/loader.js +18 -0
  246. data/app/packs/src/decidim/sw/push-permissions.js +87 -0
  247. data/app/packs/src/decidim/sw/sw.js +80 -0
  248. data/app/packs/src/decidim/vizzs/areachart.js +33 -28
  249. data/app/packs/src/decidim/vizzs/linechart.js +23 -18
  250. data/app/packs/src/decidim/vizzs/rowchart.js +15 -11
  251. data/app/packs/stylesheets/decidim/_editor.scss +0 -129
  252. data/app/packs/stylesheets/decidim/email.scss +66 -7
  253. data/app/packs/stylesheets/decidim/extras/_quill.scss +6 -0
  254. data/app/packs/stylesheets/decidim/layouts/_user.scss +8 -0
  255. data/app/packs/stylesheets/decidim/modules/_autocomplete.scss +99 -0
  256. data/app/packs/stylesheets/decidim/modules/_buttons.scss +6 -10
  257. data/app/packs/stylesheets/decidim/modules/_cards.scss +1 -3
  258. data/app/packs/stylesheets/decidim/modules/_comments.scss +0 -26
  259. data/app/packs/stylesheets/decidim/modules/_cookie-consent.scss +115 -0
  260. data/app/packs/stylesheets/decidim/modules/_footer.scss +4 -0
  261. data/app/packs/stylesheets/decidim/modules/_forms.scss +0 -5
  262. data/app/packs/stylesheets/decidim/modules/_input-multiple-mentions.scss +29 -2
  263. data/app/packs/stylesheets/decidim/modules/_modules.scss +3 -1
  264. data/app/packs/stylesheets/decidim/modules/_reveal.scss +15 -0
  265. data/app/packs/stylesheets/decidim/modules/_upload_modal.scss +143 -0
  266. data/app/packs/stylesheets/decidim/utils/_fontface.scss +3 -0
  267. data/app/packs/stylesheets/decidim/vizzs/_linechart.scss +2 -2
  268. data/app/packs/stylesheets/decidim/vizzs/_rowchart.scss +2 -2
  269. data/app/permissions/decidim/permissions.rb +4 -8
  270. data/app/presenters/decidim/admin_log/area_type_presenter.rb +34 -0
  271. data/app/presenters/decidim/admin_log/attachment_collection_presenter.rb +35 -0
  272. data/app/presenters/decidim/admin_log/attachment_presenter.rb +27 -0
  273. data/app/presenters/decidim/admin_log/category_presenter.rb +36 -0
  274. data/app/presenters/decidim/admin_log/component_presenter.rb +35 -3
  275. data/app/presenters/decidim/admin_log/contextual_help_section_presenter.rb +33 -0
  276. data/app/presenters/decidim/admin_log/organization_presenter.rb +9 -4
  277. data/app/presenters/decidim/admin_log/scope_type_presenter.rb +34 -0
  278. data/app/presenters/decidim/admin_log/user_group_presenter.rb +1 -1
  279. data/app/presenters/decidim/admin_log/user_moderation_presenter.rb +1 -1
  280. data/app/presenters/decidim/home_stats_presenter.rb +8 -13
  281. data/app/presenters/decidim/log/base_presenter.rb +1 -1
  282. data/app/presenters/decidim/menu_item_presenter.rb +1 -1
  283. data/app/presenters/decidim/metric_charts_presenter.rb +7 -1
  284. data/app/presenters/decidim/nil_presenter.rb +3 -1
  285. data/app/presenters/decidim/notification_presenter.rb +1 -1
  286. data/app/presenters/decidim/notification_to_mailer_presenter.rb +39 -0
  287. data/app/presenters/decidim/notifications_digest_presenter.rb +42 -0
  288. data/app/presenters/decidim/official_author_presenter.rb +4 -0
  289. data/app/presenters/decidim/organization_presenter.rb +22 -0
  290. data/app/presenters/decidim/push_notification_presenter.rb +24 -0
  291. data/app/presenters/decidim/stats_presenter.rb +9 -8
  292. data/app/presenters/decidim/user_group_presenter.rb +1 -1
  293. data/app/presenters/decidim/user_presenter.rb +5 -13
  294. data/app/presenters/decidim/validation_errors_presenter.rb +1 -1
  295. data/app/queries/decidim/messaging/user_conversations.rb +1 -1
  296. data/app/queries/decidim/metric_manage.rb +1 -1
  297. data/app/queries/decidim/metrics/users_metric_manage.rb +6 -6
  298. data/app/queries/decidim/own_activities.rb +11 -0
  299. data/app/queries/decidim/participatory_processes_with_user_role.rb +1 -1
  300. data/app/{services/decidim/activity_search.rb → queries/decidim/public_activities.rb} +35 -78
  301. data/app/queries/decidim/public_components.rb +1 -1
  302. data/app/queries/decidim/similar_emendations.rb +1 -1
  303. data/app/queries/decidim/stats_users_count.rb +1 -1
  304. data/app/queries/decidim/user_groups/accepted_memberships.rb +1 -1
  305. data/app/queries/decidim/user_groups/accepted_user_groups.rb +1 -1
  306. data/app/queries/decidim/user_groups/accepted_users.rb +1 -1
  307. data/app/queries/decidim/user_groups/admin_memberships.rb +1 -1
  308. data/app/queries/decidim/user_groups/invited_memberships.rb +1 -1
  309. data/app/queries/decidim/user_groups/manageable_user_groups.rb +1 -1
  310. data/app/queries/decidim/user_groups/member_memberships.rb +1 -1
  311. data/app/scrubbers/decidim/user_input_scrubber.rb +5 -32
  312. data/app/services/decidim/{data_portability_exporter.rb → download_your_data_exporter.rb} +6 -6
  313. data/app/services/decidim/email_notification_generator.rb +2 -2
  314. data/app/services/decidim/engine_resolver.rb +66 -0
  315. data/app/services/decidim/events_manager.rb +1 -1
  316. data/app/services/decidim/iframe_disabler.rb +31 -0
  317. data/app/services/decidim/notification_generator_for_recipient.rb +1 -1
  318. data/app/services/decidim/notifications_digest_sending_decider.rb +18 -0
  319. data/app/services/decidim/notifications_subscriptions_persistor.rb +37 -0
  320. data/app/services/decidim/open_data_exporter.rb +1 -1
  321. data/app/services/decidim/resource_search.rb +17 -164
  322. data/app/services/decidim/send_push_notification.rb +59 -0
  323. data/app/services/decidim/traceability.rb +1 -2
  324. data/app/uploaders/decidim/application_uploader.rb +2 -12
  325. data/app/uploaders/decidim/cw/attachment_uploader.rb +1 -1
  326. data/app/uploaders/decidim/cw/{data_portability_uploader.rb → download_your_data_uploader.rb} +3 -3
  327. data/app/uploaders/decidim/cw/image_uploader.rb +2 -2
  328. data/app/uploaders/decidim/organization_favicon_uploader.rb +3 -2
  329. data/app/validators/etiquette_validator.rb +3 -7
  330. data/app/validators/passthru_validator.rb +29 -21
  331. data/app/validators/password_validator.rb +25 -4
  332. data/app/validators/uploader_image_dimensions_validator.rb +1 -1
  333. data/app/views/decidim/account/_account_notification.js.erb +20 -0
  334. data/app/views/decidim/account/_password_fields.html.erb +2 -2
  335. data/app/views/decidim/account/cancel_email_change.js.erb +6 -0
  336. data/app/views/decidim/account/resend_confirmation_instructions.erb +1 -0
  337. data/app/views/decidim/account/show.html.erb +19 -6
  338. data/app/views/decidim/application/{_attachments.html.erb → _attachments.erb} +2 -2
  339. data/app/views/decidim/application/_collection.html.erb +1 -1
  340. data/app/views/decidim/application/{_documents.html.erb → _documents.erb} +2 -2
  341. data/app/views/decidim/devise/confirmations/new.html.erb +1 -1
  342. data/app/views/decidim/devise/invitations/edit.html.erb +3 -4
  343. data/app/views/decidim/devise/omniauth_registrations/new.html.erb +3 -3
  344. data/app/views/decidim/devise/passwords/edit.html.erb +7 -5
  345. data/app/views/decidim/devise/passwords/new.html.erb +1 -1
  346. data/app/views/decidim/devise/registrations/edit.html.erb +41 -0
  347. data/app/views/decidim/devise/registrations/new.html.erb +5 -5
  348. data/app/views/decidim/devise/sessions/new.html.erb +2 -2
  349. data/app/views/decidim/{data_portability → download_your_data}/show.html.erb +2 -2
  350. data/app/views/decidim/export_mailer/download_your_data_export.html.erb +7 -0
  351. data/app/views/decidim/last_activities/index.html.erb +1 -1
  352. data/app/views/decidim/links/_modal.html.erb +1 -1
  353. data/app/views/decidim/links/new.html.erb +1 -1
  354. data/app/views/decidim/manifests/show.json.erb +31 -0
  355. data/app/views/decidim/messaging/conversations/_add_conversation_users.html.erb +5 -3
  356. data/app/views/decidim/messaging/conversations/_conversation.html.erb +5 -1
  357. data/app/views/decidim/messaging/conversations/_reply.html.erb +1 -1
  358. data/app/views/decidim/messaging/conversations/_start.html.erb +1 -3
  359. data/app/views/decidim/messaging/conversations/create.js.erb +1 -0
  360. data/app/views/decidim/newsletter_mailer/newsletter.html.erb +3 -3
  361. data/app/views/decidim/newsletters/show.html.erb +1 -1
  362. data/app/views/decidim/notification_mailer/event_received.html.erb +1 -1
  363. data/app/views/decidim/notifications_digest_mailer/_email_content.html.erb +11 -0
  364. data/app/views/decidim/notifications_digest_mailer/digest_mail.erb +27 -0
  365. data/app/views/decidim/notifications_settings/show.html.erb +79 -52
  366. data/app/views/decidim/offline/show.html.erb +9 -0
  367. data/app/views/decidim/pages/_standalone.html.erb +1 -1
  368. data/app/views/decidim/pages/_tabbed.html.erb +1 -1
  369. data/app/views/decidim/reported_mailer/hide.html.erb +1 -1
  370. data/app/views/decidim/reported_mailer/report.html.erb +1 -1
  371. data/app/views/decidim/scopes/picker.html.erb +1 -1
  372. data/app/views/decidim/searches/_filters.html.erb +2 -2
  373. data/app/views/decidim/shared/participatory_space_filters/_filters.html.erb +3 -3
  374. data/app/views/decidim/user_interests/show.html.erb +13 -11
  375. data/app/views/decidim/user_report_mailer/notify.html.erb +10 -3
  376. data/app/views/devise/mailer/confirmation_instructions.html.erb +3 -1
  377. data/app/views/layouts/decidim/_application.html.erb +6 -3
  378. data/app/views/layouts/decidim/_cookie_warning.html.erb +8 -8
  379. data/app/views/layouts/decidim/_decidim_javascript.html.erb +12 -0
  380. data/app/views/layouts/decidim/_head.html.erb +4 -2
  381. data/app/views/layouts/decidim/_js_configuration.html.erb +5 -1
  382. data/app/views/layouts/decidim/_mailer_logo.html.erb +2 -2
  383. data/app/views/layouts/decidim/_main_footer.html.erb +1 -0
  384. data/app/views/layouts/decidim/_offline_banner.html.erb +11 -0
  385. data/app/views/layouts/decidim/newsletter_base.html.erb +2 -2
  386. data/app/views/layouts/decidim/widget.html.erb +2 -2
  387. data/config/assets.rb +1 -0
  388. data/config/locales/am-ET.yml +1 -0
  389. data/config/locales/ar.yml +86 -461
  390. data/config/locales/bg.yml +57 -32
  391. data/config/locales/ca.yml +246 -85
  392. data/config/locales/cs.yml +256 -97
  393. data/config/locales/da.yml +1 -3
  394. data/config/locales/de.yml +93 -159
  395. data/config/locales/el.yml +53 -137
  396. data/config/locales/en.yml +220 -59
  397. data/config/locales/eo.yml +8 -13
  398. data/config/locales/es-MX.yml +234 -73
  399. data/config/locales/es-PY.yml +236 -75
  400. data/config/locales/es.yml +244 -83
  401. data/config/locales/et.yml +1 -3
  402. data/config/locales/eu.yml +416 -479
  403. data/config/locales/fi-plain.yml +222 -61
  404. data/config/locales/fi.yml +236 -75
  405. data/config/locales/fr-CA.yml +218 -71
  406. data/config/locales/fr.yml +224 -77
  407. data/config/locales/ga-IE.yml +15 -9
  408. data/config/locales/gl.yml +112 -35
  409. data/config/locales/hr.yml +1 -3
  410. data/config/locales/hu.yml +106 -266
  411. data/config/locales/id-ID.yml +61 -35
  412. data/config/locales/is-IS.yml +12 -23
  413. data/config/locales/it.yml +66 -41
  414. data/config/locales/ja.yml +235 -83
  415. data/config/locales/ko.yml +1 -0
  416. data/config/locales/lb.yml +57 -38
  417. data/config/locales/lt.yml +1 -1788
  418. data/config/locales/lv.yml +55 -28
  419. data/config/locales/mt.yml +1 -0
  420. data/config/locales/nl.yml +81 -39
  421. data/config/locales/no.yml +84 -41
  422. data/config/locales/om-ET.yml +1 -0
  423. data/config/locales/pl.yml +127 -46
  424. data/config/locales/pt-BR.yml +52 -80
  425. data/config/locales/pt.yml +54 -35
  426. data/config/locales/ro-RO.yml +55 -43
  427. data/config/locales/ru.yml +35 -29
  428. data/config/locales/si-LK.yml +1 -0
  429. data/config/locales/sk.yml +62 -45
  430. data/config/locales/sl.yml +6 -1
  431. data/config/locales/so-SO.yml +1 -0
  432. data/config/locales/sr-CS.yml +1 -10
  433. data/config/locales/sv.yml +127 -55
  434. data/config/locales/sw-KE.yml +1 -0
  435. data/config/locales/ti-ER.yml +1 -0
  436. data/config/locales/tr-TR.yml +55 -40
  437. data/config/locales/uk.yml +30 -30
  438. data/config/locales/val-ES.yml +1 -0
  439. data/config/locales/vi.yml +1 -0
  440. data/config/locales/zh-CN.yml +53 -33
  441. data/config/locales/zh-TW.yml +1 -1721
  442. data/config/routes.rb +19 -22
  443. data/db/migrate/20180508111710_add_accepted_tos_version_field_to_users.rb +1 -0
  444. data/db/migrate/20181030090144_destroy_deleted_users_follows.rb +2 -1
  445. data/db/migrate/20181204110723_remove_following_users_count_from_users.rb +2 -11
  446. data/db/migrate/20181214101250_add_notification_types_to_users.rb +1 -6
  447. data/db/migrate/20190412131728_fix_user_names.rb +2 -9
  448. data/db/migrate/20200211173227_add_direct_message_types_to_users.rb +1 -6
  449. data/db/migrate/20210302150803_invalidate_all_sessions_for_deleted_users.rb +3 -10
  450. data/db/migrate/20210310120640_add_followable_counter_cache_to_users.rb +3 -13
  451. data/db/migrate/20210831181634_add_service_name_to_active_storage_blobs.active_storage.rb +22 -0
  452. data/db/migrate/20210831181635_create_active_storage_variant_records.active_storage.rb +14 -0
  453. data/db/migrate/20211208155453_create_decidim_reminders.rb +11 -0
  454. data/db/migrate/20211209121025_create_decidim_reminder_records.rb +11 -0
  455. data/db/migrate/20211209121040_create_decidim_reminder_deliveries.rb +10 -0
  456. data/db/migrate/20220118121921_change_required_description_categories.rb +7 -0
  457. data/db/migrate/20220127113419_add_notification_settings_to_users.rb +7 -0
  458. data/db/migrate/20220203121137_add_notifications_sending_frequency_to_users.rb +7 -0
  459. data/db/migrate/20220215172439_add_digest_sent_at_to_users.rb +7 -0
  460. data/db/migrate/20220323195258_add_index_to_decidim_users_notifications_sending_frequency.rb +7 -0
  461. data/db/migrate/20220427142214_drop_emails_on_notifications_flag_from_user.rb +15 -0
  462. data/db/migrate/20220518094535_add_previous_passwords_to_users.rb +20 -0
  463. data/db/migrate/20220524195530_create_decidim_short_links.rb +23 -0
  464. data/db/seeds.rb +17 -19
  465. data/lib/decidim/acts_as_tree.rb +47 -0
  466. data/lib/decidim/api/input_sorts/component_input_sort.rb +2 -1
  467. data/lib/decidim/api/interfaces/authorable_interface.rb +6 -5
  468. data/lib/decidim/api/types/localized_string_type.rb +0 -9
  469. data/lib/decidim/api/types/translated_field_type.rb +5 -20
  470. data/lib/decidim/asset_router.rb +80 -0
  471. data/lib/decidim/attachment_attributes.rb +8 -8
  472. data/lib/decidim/attribute_object/form.rb +174 -0
  473. data/lib/decidim/attribute_object/model.rb +148 -0
  474. data/lib/decidim/attribute_object/nested_validator.rb +22 -0
  475. data/lib/decidim/attribute_object/type_map.rb +14 -0
  476. data/lib/decidim/attribute_object/type_resolver.rb +91 -0
  477. data/lib/decidim/attribute_object.rb +26 -0
  478. data/lib/decidim/attributes/array.rb +62 -0
  479. data/lib/decidim/attributes/blob.rb +20 -0
  480. data/lib/decidim/attributes/clean_string.rb +12 -6
  481. data/lib/decidim/attributes/hash.rb +36 -0
  482. data/lib/decidim/attributes/integer.rb +17 -0
  483. data/lib/decidim/attributes/localized_date.rb +8 -14
  484. data/lib/decidim/attributes/model.rb +24 -0
  485. data/lib/decidim/attributes/object.rb +28 -0
  486. data/lib/decidim/attributes/symbol.rb +23 -0
  487. data/lib/decidim/attributes/time_with_zone.rb +7 -17
  488. data/lib/decidim/attributes.rb +29 -0
  489. data/lib/decidim/authorable.rb +21 -6
  490. data/lib/decidim/authorization_form_builder.rb +9 -11
  491. data/lib/decidim/carrier_wave_migrator_service.rb +15 -15
  492. data/lib/decidim/coauthorable.rb +22 -4
  493. data/lib/decidim/command.rb +44 -0
  494. data/lib/decidim/common_passwords.rb +1 -1
  495. data/lib/decidim/component_manifest.rb +5 -5
  496. data/lib/decidim/component_validator.rb +2 -2
  497. data/lib/decidim/content_block_manifest.rb +1 -1
  498. data/lib/decidim/content_parsers/hashtag_parser.rb +2 -2
  499. data/lib/decidim/content_parsers/resource_parser.rb +1 -1
  500. data/lib/decidim/content_parsers/user_group_parser.rb +1 -1
  501. data/lib/decidim/content_parsers/user_parser.rb +4 -4
  502. data/lib/decidim/content_renderers/hashtag_renderer.rb +1 -1
  503. data/lib/decidim/content_renderers/link_renderer.rb +2 -2
  504. data/lib/decidim/content_renderers/user_group_renderer.rb +1 -1
  505. data/lib/decidim/content_renderers/user_renderer.rb +1 -1
  506. data/lib/decidim/controller_helpers.rb +41 -0
  507. data/lib/decidim/core/engine.rb +35 -19
  508. data/lib/decidim/core/test/factories.rb +54 -21
  509. data/lib/decidim/core/test/shared_examples/admin_resource_gallery_examples.rb +16 -4
  510. data/lib/decidim/core/test/shared_examples/amendable/amendment_form_examples.rb +1 -1
  511. data/lib/decidim/core/test/shared_examples/authorable_interface_examples.rb +15 -2
  512. data/lib/decidim/core/test/shared_examples/coauthorable_interface_examples.rb +2 -2
  513. data/lib/decidim/core/test/shared_examples/comments_examples.rb +203 -60
  514. data/lib/decidim/core/test/shared_examples/errors.rb +0 -2
  515. data/lib/decidim/core/test/shared_examples/localised_email.rb +1 -1
  516. data/lib/decidim/core/test/shared_examples/logo_email.rb +1 -1
  517. data/lib/decidim/core/test/shared_examples/map_examples.rb +3 -6
  518. data/lib/decidim/core/test/shared_examples/preview_component_with_share_token_examples.rb +0 -6
  519. data/lib/decidim/core/test/shared_examples/resource_search_examples.rb +120 -40
  520. data/lib/decidim/core/test/shared_examples/resourceable.rb +0 -6
  521. data/lib/decidim/core/test/shared_examples/rich_text_editor_examples.rb +3 -7
  522. data/lib/decidim/core/test/shared_examples/searchable_participatory_space_examples.rb +1 -1
  523. data/lib/decidim/core/test/shared_examples/searchable_resources_shared_context.rb +1 -1
  524. data/lib/decidim/core/test/shared_examples/system_endorse_resource_examples.rb +3 -3
  525. data/lib/decidim/core/test/shared_examples/translated_event_examples.rb +2 -2
  526. data/lib/decidim/core/test/shared_examples/with_endorsable_permissions_examples.rb +1 -1
  527. data/lib/decidim/core/test.rb +0 -4
  528. data/lib/decidim/core/version.rb +1 -1
  529. data/lib/decidim/core.rb +106 -55
  530. data/lib/decidim/{data_portability.rb → download_your_data.rb} +3 -3
  531. data/lib/decidim/{data_portability_serializers/data_portability_conversation_serializer.rb → download_your_data_serializers/download_your_data_conversation_serializer.rb} +2 -2
  532. data/lib/decidim/{data_portability_serializers/data_portability_follow_serializer.rb → download_your_data_serializers/download_your_data_follow_serializer.rb} +2 -2
  533. data/lib/decidim/{data_portability_serializers/data_portability_identity_serializer.rb → download_your_data_serializers/download_your_data_identity_serializer.rb} +2 -2
  534. data/lib/decidim/{data_portability_serializers/data_portability_notification_serializer.rb → download_your_data_serializers/download_your_data_notification_serializer.rb} +2 -2
  535. data/lib/decidim/{data_portability_serializers/data_portability_participatory_space_private_user_serializer.rb → download_your_data_serializers/download_your_data_participatory_space_private_user_serializer.rb} +2 -2
  536. data/lib/decidim/{data_portability_serializers/data_portability_report_serializer.rb → download_your_data_serializers/download_your_data_report_serializer.rb} +2 -2
  537. data/lib/decidim/{data_portability_serializers/data_portability_user_group_serializer.rb → download_your_data_serializers/download_your_data_user_group_serializer.rb} +2 -2
  538. data/lib/decidim/{data_portability_serializers/data_portability_user_serializer.rb → download_your_data_serializers/download_your_data_user_serializer.rb} +3 -3
  539. data/lib/decidim/download_your_data_serializers.rb +23 -0
  540. data/lib/decidim/endorsable.rb +1 -1
  541. data/lib/decidim/engine_router.rb +7 -1
  542. data/lib/decidim/env.rb +56 -0
  543. data/lib/decidim/event_recorder.rb +25 -0
  544. data/lib/decidim/events/base_event.rb +10 -14
  545. data/lib/decidim/events/simple_event.rb +6 -5
  546. data/lib/decidim/exporters/export_data.rb +1 -1
  547. data/lib/decidim/exporters/export_manifest.rb +2 -1
  548. data/lib/decidim/exporters.rb +1 -10
  549. data/lib/decidim/file_validator_humanizer.rb +24 -1
  550. data/lib/decidim/filterable_resource.rb +55 -0
  551. data/lib/decidim/fingerprint_calculator.rb +2 -4
  552. data/lib/decidim/form_builder.rb +174 -145
  553. data/lib/decidim/gamification/badge.rb +2 -3
  554. data/lib/decidim/gamification/badge_scorer.rb +1 -0
  555. data/lib/decidim/has_area.rb +27 -0
  556. data/lib/decidim/has_attachments.rb +2 -2
  557. data/lib/decidim/has_category.rb +36 -0
  558. data/lib/decidim/has_resource_permission.rb +2 -0
  559. data/lib/decidim/importers/import_manifest.rb +3 -21
  560. data/lib/decidim/jsonb_attributes.rb +6 -4
  561. data/lib/decidim/manifest_messages.rb +23 -0
  562. data/lib/decidim/map/autocomplete.rb +6 -4
  563. data/lib/decidim/map/frontend.rb +2 -2
  564. data/lib/decidim/map/provider/dynamic_map/here.rb +1 -46
  565. data/lib/decidim/map/provider/geocoding/here.rb +5 -5
  566. data/lib/decidim/map/provider/here.rb +3 -0
  567. data/lib/decidim/map/provider/osm.rb +3 -0
  568. data/lib/decidim/map.rb +4 -4
  569. data/lib/decidim/menu.rb +1 -1
  570. data/lib/decidim/metric_manifest.rb +2 -2
  571. data/lib/decidim/nicknamizable.rb +1 -1
  572. data/lib/decidim/notification_setting_manifest.rb +19 -0
  573. data/lib/decidim/organization_settings.rb +8 -7
  574. data/lib/decidim/participatory_space_context_manifest.rb +2 -2
  575. data/lib/decidim/participatory_space_manifest.rb +2 -2
  576. data/lib/decidim/participatory_space_resourceable.rb +1 -7
  577. data/lib/decidim/processes_file_locally.rb +31 -0
  578. data/lib/decidim/publicable.rb +0 -4
  579. data/lib/decidim/query.rb +84 -0
  580. data/lib/decidim/record_encryptor.rb +29 -8
  581. data/lib/decidim/reminder_manifest.rb +75 -0
  582. data/lib/decidim/reminder_registry.rb +67 -0
  583. data/lib/decidim/resource_manifest.rb +1 -1
  584. data/lib/decidim/resourceable.rb +15 -5
  585. data/lib/decidim/scopable.rb +15 -0
  586. data/lib/decidim/settings_manifest.rb +4 -4
  587. data/lib/decidim/spring.rb +16 -0
  588. data/lib/decidim/translatable_attributes.rb +13 -16
  589. data/lib/decidim/url_option_resolver.rb +50 -0
  590. data/lib/decidim/view_hooks.rb +1 -1
  591. data/lib/decidim/view_model.rb +5 -1
  592. data/lib/decidim/webpacker/thread_safe_compiler.rb +30 -0
  593. data/lib/decidim/webpacker/webpack/custom.js +15 -3
  594. data/lib/decidim/webpacker/webpacker.yml +1 -1
  595. data/lib/decidim/webpacker.rb +2 -0
  596. data/lib/devise/models/decidim_validatable.rb +1 -1
  597. data/lib/tasks/decidim_active_storage_migration_tasks.rake +1 -3
  598. data/lib/tasks/{decidim_data_portability_tasks.rake → decidim_download_your_data_tasks.rake} +9 -9
  599. data/lib/tasks/decidim_mailers_tasks.rake +23 -0
  600. data/lib/tasks/decidim_metrics_tasks.rake +1 -1
  601. data/lib/tasks/decidim_pwa_tasks.rake +18 -0
  602. data/lib/tasks/decidim_reminders_tasks.rake +17 -0
  603. data/lib/tasks/decidim_tasks.rake +6 -1
  604. data/lib/tasks/decidim_webpacker_tasks.rake +1 -1
  605. data/lib/tasks/upgrade/decidim_fix_nickname_uniqueness.rake +51 -0
  606. metadata +186 -105
  607. data/app/controllers/decidim/cookie_policy_controller.rb +0 -24
  608. data/app/helpers/decidim/cookies_helper.rb +0 -11
  609. data/app/packs/src/decidim/editor/clipboard_override.js +0 -147
  610. data/app/packs/src/decidim/editor/clipboard_utilities.js +0 -119
  611. data/app/packs/src/decidim/vizzs/renders.js +0 -9
  612. data/app/packs/src/decidim/vizzs.js +0 -1
  613. data/app/packs/stylesheets/decidim/modules/_cookie-bar.scss +0 -26
  614. data/app/scrubbers/decidim/admin_input_scrubber.rb +0 -27
  615. data/app/services/decidim/home_activity_search.rb +0 -80
  616. data/app/services/decidim/participatory_space_search.rb +0 -54
  617. data/app/views/decidim/cookie_policy/accept.js.erb +0 -3
  618. data/app/views/decidim/export_mailer/data_portability_export.html.erb +0 -7
  619. data/app/views/decidim/links/_invalid_url_modal.html.erb +0 -17
  620. data/app/views/decidim/links/invalid_url.js.erb +0 -24
  621. data/config/environment.rb +0 -3
  622. data/config/locales/fa-IR.yml +0 -1
  623. data/config/locales/gn-PY.yml +0 -4
  624. data/config/locales/ka-GE.yml +0 -4
  625. data/config/locales/kaa.yml +0 -5
  626. data/config/locales/lo-LA.yml +0 -1
  627. data/config/locales/oc-FR.yml +0 -3
  628. data/config/locales/sq-AL.yml +0 -1
  629. data/config/locales/th-TH.yml +0 -1
  630. data/db/migrate/20231027142329_change_default_value_for_decidim_endorsements.rb +0 -11
  631. data/lib/decidim/core/test/shared_examples/editor_shared_examples.rb +0 -10
  632. data/lib/decidim/core/test/shared_examples/mcell_examples.rb +0 -17
  633. data/lib/decidim/core/test/shared_examples/resource_endorsed_event_examples.rb +0 -60
  634. data/lib/decidim/core/test/shared_examples/versions_controller_examples.rb +0 -40
  635. data/lib/decidim/data_portability_serializers.rb +0 -23
  636. data/lib/decidim/dependency_resolver.rb +0 -278
  637. data/lib/decidim/middleware/rails_cookies.rb +0 -23
  638. data/lib/tasks/upgrade/decidim_deduplicate_endorsements.rake +0 -53
  639. data/lib/tasks/upgrade/decidim_user_moderation.rake +0 -14
  640. /data/app/packs/src/decidim/vizzs/{metrics.js → index.js} +0 -0
  641. /data/app/views/decidim/application/{_document.html.erb → _document.erb} +0 -0
  642. /data/app/views/decidim/application/{_photos.html.erb → _photos.erb} +0 -0
  643. /data/app/views/decidim/{data_portability → download_your_data}/export.html.erb +0 -0
@@ -1,100 +1,60 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module Decidim
4
- # A class to search for recent activity performed in a Decidim Organization.
5
- # It is intended to be used in the user profile, to retrieve activity and
6
- # timeline for that user.
4
+ # This query finds the public ActionLog entries that can be shown in the
5
+ # participant views of the application within a Decidim Organization. It is
6
+ # intended to be used in the user profile, to retrieve activity and timeline
7
+ # for that user.
7
8
  #
8
- # It will return any action for a given resource, except `create` on resources
9
- # that implement the `Decidim::Publicable` concern to avoid leaking private
10
- # data.
9
+ # This will create the base query for the activities but the resulting query
10
+ # needs to be scoped with either `with_resource_type` or
11
+ # `with_new_resource_type` in order to avoid leaking private data.
11
12
  #
12
13
  # Possible options:
13
14
  #
14
- # :organization - the `Decidim::Organization` to scope to search. Required.
15
- # :user - an optional `Decidim::USer` that performed the activites
15
+ # :resource_name - an optional name for a resource for searching only that
16
+ # type of resources.
17
+ # :user - an optional `Decidim::User` that performed the activites
18
+ # :current_user - an optional `Decidim::User` for defining whether to show the
19
+ # private log entries that relate to the current user.
16
20
  # :follows - a collection of `Decidim::Follow` resources. It will return any
17
21
  # activity affecting any of these resources, performed by any of them or
18
22
  # contained in any of them as spaces.
19
23
  # :scopes - a collection of `Decidim::Scope`. It will return any activity that
20
24
  # took place in any of those scopes.
21
- class ActivitySearch < Searchlight::Search
22
- # Needed by Searchlight, this is the base query that will be used to
23
- # append other criteria to the search.
24
- def base_query
25
+ class PublicActivities < Decidim::Query
26
+ def initialize(organization, options = {})
27
+ @organization = organization
28
+ @resource_name = options[:resource_name]
29
+ @user = options[:user]
30
+ @current_user = options[:current_user]
31
+ @follows = options[:follows]
32
+ @scopes = options[:scopes]
33
+ end
34
+
35
+ def query
25
36
  query = ActionLog
26
- .where(visibility: %w(public-only all))
27
- .where(organization: options.fetch(:organization))
37
+ .where(visibility: visibility)
38
+ .where(organization: organization)
28
39
 
29
- query = query.where(user: options[:user]) if options[:user]
30
- query = query.where(resource_type: options[:resource_name]) if options[:resource_name]
40
+ query = query.where(user: user) if user
41
+ query = query.where(resource_type: resource_name) if resource_name.present?
31
42
 
32
43
  query = filter_follows(query)
33
- filter_hidden(query)
34
- end
35
-
36
- # Overwrites the default Searchlight run method since we want to return
37
- # activities in an specific order but we need to set it at the end of the chain.
38
- def run
39
- super.order(created_at: :desc)
40
- end
41
-
42
- # Adds a constrain to filter by resource type(s).
43
- def search_resource_type
44
- if resource_types.include?(resource_type)
45
- scope_for(resource_type)
46
- else
47
- all_resources_scope
48
- end
49
- end
44
+ query = filter_hidden(query)
50
45
 
51
- # All the resource types that are eligible to be included as an activity.
52
- def resource_types
53
- @resource_types ||= %w(
54
- Decidim::Accountability::Result
55
- Decidim::Blogs::Post
56
- Decidim::Comments::Comment
57
- Decidim::Consultations::Question
58
- Decidim::Debates::Debate
59
- Decidim::Meetings::Meeting
60
- Decidim::Proposals::Proposal
61
- Decidim::Surveys::Survey
62
- Decidim::Assembly
63
- Decidim::Consultation
64
- Decidim::Initiative
65
- Decidim::ParticipatoryProcess
66
- ).select do |klass|
67
- klass.safe_constantize.present?
68
- end
46
+ query.order(created_at: :desc)
69
47
  end
70
48
 
71
49
  private
72
50
 
73
- def publicable_resource_types
74
- @publicable_resource_types ||= resource_types.select { |klass| klass.constantize.column_names.include?("published_at") }
75
- end
76
-
77
- def scope_for(resource_type)
78
- if publicable_resource_types.include?(resource_type)
79
- query.where(resource_type: resource_type).where.not(action: "create")
80
- else
81
- query.where(resource_type: resource_type)
82
- end
83
- end
51
+ attr_reader :organization, :resource_name, :user, :current_user, :follows, :scopes
84
52
 
85
- def all_resources_scope
86
- query
87
- .where(
88
- "(action <> ? AND resource_type IN (?)) OR (resource_type IN (?))",
89
- "create",
90
- publicable_resource_types,
91
- (resource_types - publicable_resource_types)
92
- )
53
+ def visibility
54
+ %w(public-only all)
93
55
  end
94
56
 
95
57
  def filter_follows(query)
96
- follows = options[:follows]
97
- interesting_scopes = options[:scopes]
98
58
  conditions = []
99
59
 
100
60
  if follows.present?
@@ -108,14 +68,12 @@ module Decidim
108
68
  conditions += followed_spaces_conditions(follows)
109
69
  end
110
70
 
111
- conditions += interesting_scopes_conditions(interesting_scopes)
71
+ conditions += interesting_scopes_conditions(scopes)
112
72
 
113
73
  return query if conditions.empty?
114
74
 
115
75
  chained_conditions = conditions.inject do |previous_condition, condition|
116
- next condition unless previous_condition
117
-
118
- previous_condition.or(condition)
76
+ previous_condition.present? ? previous_condition.or(condition) : condition
119
77
  end
120
78
 
121
79
  query.where(chained_conditions)
@@ -134,7 +92,7 @@ module Decidim
134
92
 
135
93
  # Filter out the private space items that should not be visible for the
136
94
  # current user.
137
- current_user_id = options.fetch(:current_user, nil)&.id.to_i
95
+ current_user_id = current_user&.id.to_i
138
96
  Decidim.participatory_space_manifests.map do |manifest|
139
97
  klass = manifest.model_class_name.constantize
140
98
  next unless klass.include?(Decidim::HasPrivateUsers)
@@ -149,7 +107,6 @@ module Decidim
149
107
  LEFT JOIN decidim_participatory_space_private_users AS #{manifest.name}_private_users
150
108
  ON #{manifest.name}_private_users.privatable_to_type = '#{manifest.model_class_name}'
151
109
  AND #{table}.id = #{manifest.name}_private_users.privatable_to_id
152
- AND #{table}.private_space = 't'
153
110
  SQL
154
111
  ).to_s
155
112
  ).where(
@@ -3,7 +3,7 @@
3
3
  module Decidim
4
4
  # This query finds the published components for all public participatory
5
5
  # spaces in the given organization. Can filter by manifest name.
6
- class PublicComponents < Rectify::Query
6
+ class PublicComponents < Decidim::Query
7
7
  def self.for(organization, manifest_name: nil)
8
8
  new(organization, manifest_name: manifest_name).query
9
9
  end
@@ -2,7 +2,7 @@
2
2
 
3
3
  module Decidim
4
4
  # Class used to retrieve similar emendations, scoped to the current component.
5
- class SimilarEmendations < Rectify::Query
5
+ class SimilarEmendations < Decidim::Query
6
6
  include Decidim::TranslationsHelper
7
7
 
8
8
  # Syntactic sugar to initialize the class and return the queried objects.
@@ -3,7 +3,7 @@
3
3
  module Decidim
4
4
  # This query counts registered users from a collection of organizations
5
5
  # in an optional interval of time.
6
- class StatsUsersCount < Rectify::Query
6
+ class StatsUsersCount < Decidim::Query
7
7
  def self.for(organization, start_at = nil, end_at = nil)
8
8
  new(organization, start_at, end_at).query
9
9
  end
@@ -3,7 +3,7 @@
3
3
  module Decidim
4
4
  module UserGroups
5
5
  # Use this class to find the accepted memberships of the given user group.
6
- class AcceptedMemberships < Rectify::Query
6
+ class AcceptedMemberships < Decidim::Query
7
7
  # Syntactic sugar to initialize the class and return the queried objects.
8
8
  #
9
9
  # user_group - a UserGroup that needs to find its accepted memberships
@@ -5,7 +5,7 @@ module Decidim
5
5
  # Use this class to find the user groups the given user is accepted. In order
6
6
  # to calculate this, we get those groups where the user has a role of
7
7
  # member, creator or admin.
8
- class AcceptedUserGroups < Rectify::Query
8
+ class AcceptedUserGroups < Decidim::Query
9
9
  # Syntactic sugar to initialize the class and return the queried objects.
10
10
  #
11
11
  # user - a User that needs to find the groups where they are accepted
@@ -3,7 +3,7 @@
3
3
  module Decidim
4
4
  module UserGroups
5
5
  # Use this class to find the accepted members of the given user group.
6
- class AcceptedUsers < Rectify::Query
6
+ class AcceptedUsers < Decidim::Query
7
7
  # Syntactic sugar to initialize the class and return the queried objects.
8
8
  #
9
9
  # user_group - a UserGroup that needs to find its accepted members
@@ -4,7 +4,7 @@ module Decidim
4
4
  module UserGroups
5
5
  # Use this class to find the the admins of the given user group with the
6
6
  # "admin" role. It returns memberships.
7
- class AdminMemberships < Rectify::Query
7
+ class AdminMemberships < Decidim::Query
8
8
  # Syntactic sugar to initialize the class and return the queried objects.
9
9
  #
10
10
  # user_group - a UserGroup that needs to find its admin users
@@ -3,7 +3,7 @@
3
3
  module Decidim
4
4
  module UserGroups
5
5
  # Use this class to find the invitations to user groups the given user has.
6
- class InvitedMemberships < Rectify::Query
6
+ class InvitedMemberships < Decidim::Query
7
7
  # Syntactic sugar to initialize the class and return the queried objects.
8
8
  #
9
9
  # user - a User that needs to find which groups they have been invited to
@@ -5,7 +5,7 @@ module Decidim
5
5
  # Use this class to find the user groups the given user can manage. In order
6
6
  # to calculate this, we get those groups where the user has a role of
7
7
  # creator or admin.
8
- class ManageableUserGroups < Rectify::Query
8
+ class ManageableUserGroups < Decidim::Query
9
9
  # Syntactic sugar to initialize the class and return the queried objects.
10
10
  #
11
11
  # user - a User that needs to find which groups can manage
@@ -4,7 +4,7 @@ module Decidim
4
4
  module UserGroups
5
5
  # Use this class to find the the members of the given user group with the
6
6
  # "member" role. It returns memberships.
7
- class MemberMemberships < Rectify::Query
7
+ class MemberMemberships < Decidim::Query
8
8
  # Syntactic sugar to initialize the class and return the queried objects.
9
9
  #
10
10
  # user_group - a UserGroup that needs to find its member users
@@ -1,7 +1,9 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module Decidim
4
- # Use this class as a scrubber to sanitize participant user input.
4
+ # Use this class as a scrubber to sanitize user input. The default
5
+ # scrubbed provided by Rails does not allow `iframe`s, and we're using
6
+ # them to embed videos, so we need to provide a whole new scrubber.
5
7
  #
6
8
  # Example:
7
9
  #
@@ -18,41 +20,12 @@ module Decidim
18
20
 
19
21
  private
20
22
 
21
- RESTRICTED_TAGS = %w(
22
- area
23
- article
24
- aside
25
- audio
26
- button
27
- canvas
28
- fieldset
29
- figcaption
30
- figure
31
- font
32
- footer
33
- form
34
- header
35
- img
36
- input
37
- label
38
- legend
39
- main
40
- map
41
- menu
42
- optgroup
43
- option
44
- output
45
- select
46
- textarea
47
- video
48
- ).freeze
49
-
50
23
  def custom_allowed_attributes
51
- Loofah::HTML5::SafeList::ALLOWED_ATTRIBUTES
24
+ Loofah::HTML5::SafeList::ALLOWED_ATTRIBUTES + %w(frameborder allowfullscreen) - %w(onerror)
52
25
  end
53
26
 
54
27
  def custom_allowed_tags
55
- Loofah::HTML5::SafeList::ACCEPTABLE_ELEMENTS - RESTRICTED_TAGS
28
+ Loofah::HTML5::SafeList::ALLOWED_ELEMENTS_WITH_LIBXML2 + %w(iframe)
56
29
  end
57
30
  end
58
31
  end
@@ -9,11 +9,11 @@ module Decidim
9
9
  # somewhere so users can download their data.
10
10
  #
11
11
  # In fact, the 7z file wraps a ZIP file which finally contains the data files.
12
- class DataPortabilityExporter
12
+ class DownloadYourDataExporter
13
13
  include ::Decidim::ZipStream::Writer
14
14
 
15
15
  DEFAULT_EXPORT_FORMAT = "CSV"
16
- ZIP_FILE_NAME = "data-portability.zip"
16
+ ZIP_FILE_NAME = "download-your-data.zip"
17
17
 
18
18
  # Public: Initializes the class.
19
19
  #
@@ -56,18 +56,18 @@ module Decidim
56
56
  export_data = []
57
57
  export_attachments = []
58
58
 
59
- data_portability_entities.each do |object|
59
+ download_your_data_entities.each do |object|
60
60
  klass = Object.const_get(object)
61
61
  export_data << [klass.model_name.name.parameterize.pluralize, Exporters.find_exporter(format).new(klass.user_collection(user), klass.export_serializer).export]
62
- attachments = klass.data_portability_images(user)
62
+ attachments = klass.download_your_data_images(user)
63
63
  export_attachments << [klass.model_name.name.parameterize.pluralize, attachments.flatten] unless attachments.nil?
64
64
  end
65
65
 
66
66
  [export_data, export_attachments]
67
67
  end
68
68
 
69
- def data_portability_entities
70
- @data_portability_entities ||= DataPortabilitySerializers.data_entities
69
+ def download_your_data_entities
70
+ @download_your_data_entities ||= DownloadYourDataSerializers.data_entities
71
71
  end
72
72
  end
73
73
  end
@@ -54,7 +54,7 @@ module Decidim
54
54
  attr_reader :event, :event_class, :resource, :followers, :affected_users, :extra
55
55
 
56
56
  # Private: sends the notification email to the user if they have the
57
- # `email_on_notification` flag active.
57
+ # `notifications_sending_frequency` set to real_time.
58
58
  #
59
59
  # recipient - The user that will receive the email.
60
60
  # user_role - the role the user takes for this notification (either
@@ -63,7 +63,7 @@ module Decidim
63
63
  # Returns nothing.
64
64
  def send_email_to(recipient, user_role:)
65
65
  return unless recipient
66
- return unless recipient.email_on_notification?
66
+ return unless recipient.notifications_sending_frequency == "real_time"
67
67
  return if resource.respond_to?(:can_participate?) && !resource.can_participate?(recipient)
68
68
 
69
69
  wait_time = 0
@@ -0,0 +1,66 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Decidim
4
+ # This class can be used to resolve the mounted route based on the current
5
+ # routes in any provided context.
6
+ class EngineResolver
7
+ # Initializes the engine resolver instance.
8
+ #
9
+ # @param current_routes [ActionDispatch::Routing::RouteSet] the route set
10
+ # for the context
11
+ def initialize(current_routes)
12
+ @current_routes = current_routes
13
+ end
14
+
15
+ # Resolves the mounted route name for the provided context.
16
+ #
17
+ # @return [String] The resolved route name or "decidim" if it could not be
18
+ # resolved
19
+ def mounted_name
20
+ return "main_app" if base_engine.routes == current_routes
21
+
22
+ route = find_mounted_route(base_engine)
23
+ route&.name || "decidim"
24
+ end
25
+
26
+ private
27
+
28
+ attr_reader :current_routes
29
+
30
+ # Provides the base engine from which the search is started from.
31
+ #
32
+ # @return [Rails::Engine] The engine to start the search from
33
+ def base_engine
34
+ Rails.application
35
+ end
36
+
37
+ # Finds the mounted route for current context based on the current routes.
38
+ #
39
+ # @param target_engine [Rails::Engine] The engine from which the search is
40
+ # performed.
41
+ # @return [ActionDispatch::Journey::Route] The defined route that matches
42
+ # the current context based on the current routes provided for the
43
+ # initializer.
44
+ def find_mounted_route(target_engine)
45
+ target_engine.routes.set.each do |route|
46
+ # If the route is a dispatcher
47
+ # (ActionDispatch::Routing::RouteSet::Dispatcher), it won't have an
48
+ # engine app mapped to it in which case the app won't respond to the
49
+ # `routes` method.
50
+ next if route.dispatcher?
51
+ next unless route.app.app.is_a?(Class)
52
+ next unless route.app.app < Rails::Engine
53
+
54
+ # route.app -> ActionDispatch::Routing::Mapper::Constraints
55
+ # route.app.app -> the target engine
56
+ return route if route.app.app.routes == current_routes
57
+
58
+ # Test the sub-engines if any engines are mounted to this engine.
59
+ sub = find_mounted_route(route.app.app)
60
+ return sub if sub
61
+ end
62
+
63
+ nil
64
+ end
65
+ end
66
+ end
@@ -27,8 +27,8 @@ module Decidim
27
27
  def self.publish(event:, resource:, event_class: Decidim::Events::BaseEvent, affected_users: [], followers: [], extra: {}, force_send: false)
28
28
  ActiveSupport::Notifications.publish(
29
29
  event,
30
- event_class: event_class.name,
31
30
  resource: resource,
31
+ event_class: event_class.name,
32
32
  affected_users: affected_users.uniq.compact,
33
33
  followers: followers.uniq.compact,
34
34
  force_send: force_send,
@@ -0,0 +1,31 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Decidim
4
+ class IframeDisabler
5
+ def initialize(text, _options = {})
6
+ @text = text
7
+ end
8
+
9
+ def perform
10
+ @document = Nokogiri::HTML::DocumentFragment.parse(@text)
11
+ disable_iframes(@document)
12
+ document.to_html
13
+ end
14
+
15
+ private
16
+
17
+ attr_reader :document
18
+
19
+ def disable_iframes(node)
20
+ if node.name == "iframe"
21
+ node.name = "div"
22
+ old_classes = node.attributes["class"].value
23
+ node.attributes["class"].value = old_classes.present? ? "#{old_classes} disabled-iframe" : "disabled-iframe"
24
+ end
25
+
26
+ node.children.each do |child|
27
+ disable_iframes(child)
28
+ end
29
+ end
30
+ end
31
+ end
@@ -31,7 +31,7 @@ module Decidim
31
31
  return unless resource
32
32
  return unless recipient
33
33
 
34
- notification.save!
34
+ notification if notification.save!
35
35
  end
36
36
 
37
37
  private
@@ -0,0 +1,18 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Decidim
4
+ class NotificationsDigestSendingDecider
5
+ class << self
6
+ def must_notify?(user, time: Time.now.utc)
7
+ return true if user.digest_sent_at.blank?
8
+
9
+ case user.notifications_sending_frequency.to_sym
10
+ when :none then false
11
+ when :daily then user.digest_sent_at < time - 1.day
12
+ when :weekly then user.digest_sent_at < time - 1.week
13
+ else true
14
+ end
15
+ end
16
+ end
17
+ end
18
+ end
@@ -0,0 +1,37 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Decidim
4
+ # This class manages the creation and deletion of user notifications
5
+
6
+ class NotificationsSubscriptionsPersistor
7
+ attr_reader :user
8
+
9
+ def initialize(user)
10
+ @user = user
11
+ end
12
+
13
+ def add_subscription(params)
14
+ subscriptions = user.notification_settings["subscriptions"] || {}
15
+ filtered_params = filter_params(params)
16
+ new_subscription = { filtered_params[:auth] => filtered_params }
17
+ user.notification_settings["subscriptions"] = subscriptions.merge(new_subscription)
18
+ user.save
19
+ end
20
+
21
+ def delete_subscription(auth_key)
22
+ subscriptions = user.notification_settings["subscriptions"] || {}
23
+ user.notification_settings["subscriptions"] = subscriptions.except(auth_key)
24
+ user.save
25
+ end
26
+
27
+ private
28
+
29
+ def filter_params(params)
30
+ {
31
+ auth: params[:keys][:auth],
32
+ p256dh: params[:keys][:p256dh],
33
+ endpoint: params[:endpoint]
34
+ }
35
+ end
36
+ end
37
+ end
@@ -23,7 +23,7 @@ module Decidim
23
23
  def export
24
24
  dirname = File.dirname(path)
25
25
  FileUtils.mkdir_p(dirname) unless File.directory?(dirname)
26
- File.open(path, "wb") { |file| file.write(data) }
26
+ File.binwrite(path, data)
27
27
  end
28
28
 
29
29
  private