decidim-core 0.23.0 → 0.24.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 (469) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +2 -2
  3. data/app/assets/images/decidim/icons.svg +1 -1
  4. data/app/assets/javascripts/decidim.js.es6 +1 -0
  5. data/app/assets/javascripts/decidim/core/bundle.js +1 -1
  6. data/app/assets/javascripts/decidim/core/bundle.js.map +1 -1
  7. data/app/assets/javascripts/decidim/editor.js.es6 +15 -4
  8. data/app/assets/javascripts/decidim/editor/history_override.js.es6 +117 -0
  9. data/app/assets/javascripts/decidim/editor/linebreak_module.js.es6 +83 -0
  10. data/app/assets/javascripts/decidim/editor/modified_backspace_offset1.js.es6 +98 -0
  11. data/app/assets/javascripts/decidim/editor/modified_backspace_offset_any.js.es6 +48 -0
  12. data/app/assets/javascripts/decidim/editor/modified_backspace_utils.js.es6 +31 -0
  13. data/app/assets/javascripts/decidim/editor/modified_enter.js.es6 +118 -0
  14. data/app/assets/javascripts/decidim/form_filter.component.js.es6 +25 -0
  15. data/app/assets/javascripts/decidim/geocoding/attach_input.js.es6 +41 -4
  16. data/app/assets/javascripts/decidim/input_character_counter.js.es6 +6 -1
  17. data/app/assets/javascripts/decidim/map/controller/markers.js.es6 +27 -9
  18. data/app/assets/javascripts/decidim/session_timeouter.js.es6 +78 -0
  19. data/app/assets/stylesheets/decidim/_variables.scss +9 -0
  20. data/app/assets/stylesheets/decidim/email.scss +14 -2
  21. data/app/assets/stylesheets/decidim/extras/_external-links.scss +0 -1
  22. data/app/assets/stylesheets/decidim/extras/_process_stats.scss +1 -1
  23. data/app/assets/stylesheets/decidim/extras/_results-per-page.scss +1 -0
  24. data/app/assets/stylesheets/decidim/layouts/_home.scss +5 -0
  25. data/app/assets/stylesheets/decidim/modules/_author-avatar.scss +2 -2
  26. data/app/assets/stylesheets/decidim/modules/_buttons.scss +2 -2
  27. data/app/assets/stylesheets/decidim/modules/_cards.scss +18 -1
  28. data/app/assets/stylesheets/decidim/modules/_collapsible-list.scss +1 -1
  29. data/app/assets/stylesheets/decidim/modules/_comments.scss +5 -1
  30. data/app/assets/stylesheets/decidim/modules/_conference-speaker.scss +4 -3
  31. data/app/assets/stylesheets/decidim/modules/_data-picker.scss +7 -0
  32. data/app/assets/stylesheets/decidim/modules/_extra.scss +4 -0
  33. data/app/assets/stylesheets/decidim/modules/_forms.scss +4 -0
  34. data/app/assets/stylesheets/decidim/modules/_loading-spinner.scss +34 -0
  35. data/app/assets/stylesheets/decidim/modules/_modules.scss +1 -1
  36. data/app/assets/stylesheets/decidim/modules/_opinion-toggle.scss +1 -1
  37. data/app/assets/stylesheets/decidim/modules/_reveal.scss +6 -0
  38. data/app/assets/stylesheets/decidim/modules/_signup.scss +1 -0
  39. data/app/assets/stylesheets/decidim/modules/{_process-stats.scss → _space-stats.scss} +1 -1
  40. data/app/cells/decidim/activity_cell.rb +11 -8
  41. data/app/cells/decidim/announcement/show.erb +4 -4
  42. data/app/cells/decidim/announcement_cell.rb +22 -2
  43. data/app/cells/decidim/author/flag_user.erb +10 -0
  44. data/app/cells/decidim/author/profile_minicard.erb +1 -1
  45. data/app/cells/decidim/author_cell.rb +9 -1
  46. data/app/cells/decidim/card_m/top.erb +1 -1
  47. data/app/cells/decidim/card_m_cell.rb +1 -1
  48. data/app/cells/decidim/content_blocks/cta/show.erb +14 -0
  49. data/app/cells/decidim/content_blocks/cta_cell.rb +35 -0
  50. data/app/cells/decidim/content_blocks/cta_settings_form/show.erb +9 -0
  51. data/app/cells/decidim/content_blocks/cta_settings_form_cell.rb +13 -0
  52. data/app/cells/decidim/content_blocks/hero_cell.rb +14 -0
  53. data/app/cells/decidim/content_blocks/highlighted_elements/elements.erb +0 -0
  54. data/app/cells/decidim/content_blocks/highlighted_elements/heading.erb +0 -0
  55. data/app/cells/decidim/content_blocks/highlighted_elements/show.erb +4 -0
  56. data/app/cells/decidim/content_blocks/highlighted_elements_cell.rb +51 -0
  57. data/app/cells/decidim/content_blocks/highlighted_elements_settings_form/show.erb +3 -0
  58. data/app/cells/decidim/content_blocks/highlighted_elements_settings_form_cell.rb +28 -0
  59. data/app/cells/decidim/content_blocks/last_activity_cell.rb +11 -0
  60. data/app/cells/decidim/content_blocks/metrics_cell.rb +0 -6
  61. data/app/cells/decidim/content_blocks/stats_cell.rb +0 -6
  62. data/app/cells/decidim/content_blocks/sub_hero/show.erb +3 -1
  63. data/app/cells/decidim/date/show.erb +31 -0
  64. data/app/cells/decidim/date_cell.rb +50 -0
  65. data/app/cells/decidim/endorsement_buttons_cell.rb +3 -3
  66. data/app/cells/decidim/flag_modal/flag_user.erb +24 -0
  67. data/app/cells/decidim/flag_modal/show.erb +24 -0
  68. data/app/cells/decidim/flag_modal_cell.rb +25 -0
  69. data/app/cells/decidim/profile/inaccessible.erb +9 -0
  70. data/app/cells/decidim/profile_cell.rb +9 -1
  71. data/app/cells/decidim/profile_sidebar/show.erb +10 -1
  72. data/app/cells/decidim/profile_sidebar_cell.rb +1 -0
  73. data/app/cells/decidim/reported_content/show.erb +5 -0
  74. data/app/cells/decidim/reported_content_cell.rb +44 -0
  75. data/app/cells/decidim/scopes_picker/scope_picker_prompt.erb +3 -0
  76. data/app/cells/decidim/scopes_picker/scope_picker_values.erb +5 -0
  77. data/app/cells/decidim/scopes_picker/show.erb +14 -0
  78. data/app/cells/decidim/scopes_picker_cell.rb +93 -0
  79. data/app/cells/decidim/tos_page/announcement.erb +1 -2
  80. data/app/cells/decidim/tos_page/form.erb +19 -0
  81. data/app/cells/decidim/tos_page_cell.rb +10 -8
  82. data/app/cells/decidim/translation_bar_cell.rb +1 -1
  83. data/app/cells/decidim/user_conversation/conversation_header.erb +1 -1
  84. data/app/cells/decidim/user_conversations_cell.rb +1 -1
  85. data/app/commands/decidim/attachment_methods.rb +8 -0
  86. data/app/commands/decidim/create_report.rb +11 -1
  87. data/app/commands/decidim/create_user_report.rb +67 -0
  88. data/app/commands/decidim/gallery_methods.rb +2 -2
  89. data/app/commands/decidim/multiple_attachments_methods.rb +14 -10
  90. data/app/commands/decidim/search.rb +5 -2
  91. data/app/commands/decidim/update_notifications_settings.rb +1 -0
  92. data/app/commands/decidim/update_user_group.rb +1 -0
  93. data/app/controllers/concerns/decidim/devise_controllers.rb +1 -0
  94. data/app/controllers/concerns/decidim/flaggable.rb +5 -1
  95. data/app/controllers/concerns/decidim/force_authentication.rb +11 -3
  96. data/app/controllers/concerns/decidim/locale_switcher.rb +5 -0
  97. data/app/controllers/concerns/decidim/needs_permission.rb +7 -1
  98. data/app/controllers/concerns/decidim/orderable.rb +3 -1
  99. data/app/controllers/concerns/decidim/user_blocked_checker.rb +26 -0
  100. data/app/controllers/decidim/application_controller.rb +22 -0
  101. data/app/controllers/decidim/devise/omniauth_registrations_controller.rb +3 -1
  102. data/app/controllers/decidim/devise/sessions_controller.rb +10 -6
  103. data/app/controllers/decidim/errors_controller.rb +1 -1
  104. data/app/controllers/decidim/locales_controller.rb +1 -1
  105. data/app/controllers/decidim/profiles_controller.rb +6 -0
  106. data/app/controllers/decidim/report_users_controller.rb +42 -0
  107. data/app/controllers/decidim/scopes_controller.rb +19 -10
  108. data/app/controllers/decidim/timeouts_controller.rb +28 -0
  109. data/app/controllers/decidim/user_activities_controller.rb +5 -0
  110. data/app/controllers/decidim/user_timeline_controller.rb +1 -0
  111. data/app/events/decidim/demoted_membership_event.rb +2 -2
  112. data/app/events/decidim/invited_to_group_event.rb +2 -2
  113. data/app/events/decidim/join_request_accepted_event.rb +2 -2
  114. data/app/events/decidim/join_request_created_event.rb +2 -2
  115. data/app/events/decidim/join_request_rejected_event.rb +2 -2
  116. data/app/events/decidim/promoted_to_admin_event.rb +2 -2
  117. data/app/events/decidim/removed_from_group_event.rb +2 -2
  118. data/app/forms/decidim/account_form.rb +1 -1
  119. data/app/forms/decidim/attachment_form.rb +1 -0
  120. data/app/forms/decidim/invite_user_form.rb +2 -2
  121. data/app/forms/decidim/messaging/conversation_form.rb +1 -1
  122. data/app/forms/decidim/messaging/message_form.rb +1 -1
  123. data/app/forms/decidim/notifications_settings_form.rb +20 -0
  124. data/app/forms/url_validator.rb +20 -0
  125. data/app/helpers/decidim/action_authorization_helper.rb +2 -0
  126. data/app/helpers/decidim/application_helper.rb +1 -2
  127. data/app/helpers/decidim/cells_helper.rb +6 -0
  128. data/app/helpers/decidim/filters_helper.rb +9 -0
  129. data/app/helpers/decidim/messaging/conversation_helper.rb +11 -1
  130. data/app/helpers/decidim/newsletters_helper.rb +7 -9
  131. data/app/helpers/decidim/paginate_helper.rb +1 -10
  132. data/app/helpers/decidim/sanitize_helper.rb +8 -0
  133. data/app/helpers/decidim/scopes_helper.rb +2 -2
  134. data/app/jobs/decidim/block_user_job.rb +11 -0
  135. data/app/jobs/decidim/data_portability_export_job.rb +3 -3
  136. data/app/jobs/decidim/export_job.rb +2 -2
  137. data/app/jobs/decidim/find_and_update_descendants_job.rb +48 -0
  138. data/app/jobs/decidim/machine_translation_resource_job.rb +3 -0
  139. data/app/jobs/decidim/machine_translation_save_job.rb +29 -0
  140. data/app/jobs/decidim/open_data_job.rb +1 -1
  141. data/app/jobs/decidim/update_search_indexes_job.rb +11 -0
  142. data/app/jobs/decidim/user_report_job.rb +11 -0
  143. data/app/mailers/decidim/application_mailer.rb +1 -0
  144. data/app/mailers/decidim/block_user_mailer.rb +21 -0
  145. data/app/mailers/decidim/reported_mailer.rb +33 -3
  146. data/app/mailers/decidim/user_report_mailer.rb +21 -0
  147. data/app/models/decidim/area.rb +0 -1
  148. data/app/models/decidim/area_type.rb +1 -1
  149. data/app/models/decidim/attachment.rb +3 -2
  150. data/app/models/decidim/attachment_collection.rb +1 -1
  151. data/app/models/decidim/authorization.rb +4 -0
  152. data/app/models/decidim/category.rb +6 -1
  153. data/app/models/decidim/impersonation_log.rb +5 -7
  154. data/app/models/decidim/metric.rb +2 -2
  155. data/app/models/decidim/moderation.rb +12 -0
  156. data/app/models/decidim/organization.rb +6 -2
  157. data/app/models/decidim/scope.rb +5 -2
  158. data/app/models/decidim/scope_type.rb +1 -1
  159. data/app/models/decidim/share_token.rb +1 -1
  160. data/app/models/decidim/static_page.rb +11 -1
  161. data/app/models/decidim/static_page_topic.rb +4 -0
  162. data/app/models/decidim/user.rb +23 -4
  163. data/app/models/decidim/user_base_entity.rb +12 -12
  164. data/app/models/decidim/user_block.rb +10 -0
  165. data/app/models/decidim/user_group.rb +1 -0
  166. data/app/models/decidim/user_moderation.rb +22 -0
  167. data/app/models/decidim/user_report.rb +31 -0
  168. data/app/permissions/decidim/permissions.rb +1 -3
  169. data/app/permissions/decidim/report_user_permissions.rb +13 -0
  170. data/app/presenters/decidim/admin_log/component_presenter.rb +2 -2
  171. data/app/presenters/decidim/admin_log/impersonation_log_presenter.rb +39 -0
  172. data/app/presenters/decidim/admin_log/moderation_presenter.rb +2 -2
  173. data/app/presenters/decidim/admin_log/organization_presenter.rb +3 -4
  174. data/app/presenters/decidim/admin_log/user_moderation_presenter.rb +63 -0
  175. data/app/presenters/decidim/admin_log/user_presenter.rb +19 -10
  176. data/app/presenters/decidim/home_stats_presenter.rb +3 -3
  177. data/app/presenters/decidim/log/base_presenter.rb +9 -1
  178. data/app/presenters/decidim/log/diff_presenter.rb +4 -3
  179. data/app/presenters/decidim/log/resource_presenter.rb +4 -4
  180. data/app/presenters/decidim/log/user_presenter.rb +1 -1
  181. data/app/presenters/decidim/menu_presenter.rb +12 -7
  182. data/app/presenters/decidim/nil_presenter.rb +0 -2
  183. data/app/presenters/decidim/user_presenter.rb +1 -1
  184. data/app/queries/decidim/metrics/blocked_users_metric_manage.rb +26 -0
  185. data/app/queries/decidim/metrics/followers_metric_manage.rb +3 -0
  186. data/app/queries/decidim/metrics/participants_metric_manage.rb +3 -0
  187. data/app/queries/decidim/metrics/reported_users_metric_manage.rb +26 -0
  188. data/app/queries/decidim/metrics/user_reports_metric_manage.rb +26 -0
  189. data/app/scrubbers/decidim/newsletter_scrubber.rb +31 -0
  190. data/app/services/decidim/activity_search.rb +1 -3
  191. data/app/services/decidim/base_diff_renderer.rb +1 -1
  192. data/app/services/decidim/data_portability_exporter.rb +1 -0
  193. data/app/services/decidim/email_notification_generator.rb +2 -2
  194. data/app/services/decidim/events_manager.rb +1 -1
  195. data/app/services/decidim/open_data_exporter.rb +36 -7
  196. data/app/services/decidim/tokenizer.rb +38 -0
  197. data/app/services/decidim/traceability.rb +3 -0
  198. data/app/services/decidim/zip_stream/zip_stream_writer.rb +3 -3
  199. data/app/uploaders/decidim/application_uploader.rb +24 -0
  200. data/app/uploaders/decidim/attachment_uploader.rb +2 -4
  201. data/app/uploaders/decidim/downloader.rb +9 -0
  202. data/app/uploaders/decidim/image_uploader.rb +9 -21
  203. data/app/uploaders/decidim/open_data_uploader.rb +5 -0
  204. data/app/uploaders/decidim/record_image_uploader.rb +2 -2
  205. data/app/validators/etiquette_validator.rb +0 -7
  206. data/app/validators/uploader_content_type_validator.rb +4 -2
  207. data/app/views/decidim/block_user_mailer/notify.html.erb +7 -0
  208. data/app/views/decidim/devise/confirmations/new.html.erb +1 -1
  209. data/app/views/decidim/devise/registrations/edit.html.erb +1 -1
  210. data/app/views/decidim/devise/unlocks/new.html.erb +1 -1
  211. data/app/views/decidim/messaging/conversations/_conversation.html.erb +1 -1
  212. data/app/views/decidim/messaging/conversations/_messages.html.erb +1 -1
  213. data/app/views/decidim/messaging/conversations/_show.html.erb +4 -4
  214. data/app/views/decidim/newsletter_mailer/newsletter.html.erb +1 -1
  215. data/app/views/decidim/notifications_settings/show.html.erb +11 -0
  216. data/app/views/decidim/pages/_standalone.html.erb +3 -1
  217. data/app/views/decidim/pages/_tabbed.html.erb +1 -1
  218. data/app/views/decidim/reported_mailer/report.html.erb +8 -8
  219. data/app/views/decidim/shared/_check_boxes_tree.html.erb +3 -3
  220. data/app/views/decidim/shared/_component_announcement.html.erb +2 -2
  221. data/app/views/decidim/shared/participatory_space_filters/_filters.html.erb +1 -1
  222. data/app/views/decidim/user_report_mailer/notify.html.erb +7 -0
  223. data/app/views/decidim/widgets/_data_picker.html.erb +1 -1
  224. data/app/views/layouts/decidim/_application.html.erb +1 -0
  225. data/app/views/layouts/decidim/_js_configuration.html.erb +1 -1
  226. data/app/views/layouts/decidim/_main_footer.html.erb +6 -4
  227. data/app/views/layouts/decidim/_timeout_modal.html.erb +21 -0
  228. data/config/initializers/active_support.rb +7 -0
  229. data/config/initializers/devise.rb +1 -1
  230. data/config/initializers/omniauth.rb +1 -1
  231. data/config/locales/ar.yml +1 -9
  232. data/config/locales/bg.yml +1 -15
  233. data/config/locales/ca.yml +43 -16
  234. data/config/locales/cs.yml +100 -35
  235. data/config/locales/de.yml +212 -138
  236. data/config/locales/el.yml +1 -16
  237. data/config/locales/en.yml +79 -14
  238. data/config/locales/eo.yml +0 -1
  239. data/config/locales/es-MX.yml +31 -16
  240. data/config/locales/es-PY.yml +30 -15
  241. data/config/locales/es.yml +30 -15
  242. data/config/locales/eu.yml +7 -9
  243. data/config/locales/fi-plain.yml +76 -12
  244. data/config/locales/fi.yml +82 -18
  245. data/config/locales/fr-CA.yml +79 -14
  246. data/config/locales/fr.yml +80 -15
  247. data/config/locales/gl.yml +1 -9
  248. data/config/locales/hu.yml +1 -15
  249. data/config/locales/id-ID.yml +1 -9
  250. data/config/locales/is-IS.yml +0 -2
  251. data/config/locales/it.yml +65 -14
  252. data/config/locales/ja.yml +7 -22
  253. data/config/locales/lv.yml +3 -15
  254. data/config/locales/nl.yml +48 -25
  255. data/config/locales/no.yml +24 -18
  256. data/config/locales/pl.yml +98 -23
  257. data/config/locales/pt-BR.yml +1 -9
  258. data/config/locales/pt.yml +1 -16
  259. data/config/locales/ro-RO.yml +20 -16
  260. data/config/locales/ru.yml +1 -10
  261. data/config/locales/si-LK.yml +1 -0
  262. data/config/locales/sk.yml +1 -15
  263. data/config/locales/sr-CS.yml +0 -11
  264. data/config/locales/sv.yml +6 -17
  265. data/config/locales/sw-KE.yml +1 -0
  266. data/config/locales/tr-TR.yml +639 -248
  267. data/config/locales/uk.yml +1 -7
  268. data/config/locales/zh-CN.yml +1 -16
  269. data/config/routes.rb +9 -4
  270. data/db/migrate/20170713131206_add_admin_to_users.rb +1 -1
  271. data/db/migrate/20180206143340_fix_reference_for_all_resources.rb +2 -0
  272. data/db/migrate/20180314085339_rename_maximum_votes_per_proposal_to_threshold_per_proposal.rb +2 -2
  273. data/db/migrate/20200929171508_remove_show_statistics_from_organizations.rb +7 -0
  274. data/db/migrate/20201010124755_create_decidim_user_moderations.rb +12 -0
  275. data/db/migrate/20201010124756_create_decidim_user_reports.rb +16 -0
  276. data/db/migrate/20201010224433_add_suspension_fields_to_decidim_users.rb +8 -0
  277. data/db/migrate/20201011074641_create_decidim_user_suspensions.rb +14 -0
  278. data/db/migrate/20201011081626_add_current_suspension_id_to_decidim_users.rb +7 -0
  279. data/db/migrate/20201013071533_add_reported_content_to_moderations.rb +7 -0
  280. data/db/migrate/20201019074554_add_locale_to_moderation_reports.rb +7 -0
  281. data/db/migrate/20201127114444_encrypt_authorization_metadatas.rb +35 -0
  282. data/db/migrate/20201128130723_add_allow_public_access_to_static_pages.rb +17 -0
  283. data/db/migrate/20201218144706_update_table_block_user_functionality.rb +8 -0
  284. data/db/migrate/20201218145252_rename_decidim_user_fields_for_block_functionality.rb +9 -0
  285. data/db/migrate/20210208134328_add_email_on_moderations_to_users.rb +7 -0
  286. data/db/seeds.rb +18 -12
  287. data/lib/decidim/amendable.rb +3 -2
  288. data/{app/functions/decidim/core → lib/decidim/api/functions}/component_finder_base.rb +1 -1
  289. data/{app/functions/decidim/core → lib/decidim/api/functions}/component_list.rb +4 -4
  290. data/{app/functions/decidim/core → lib/decidim/api/functions}/component_list_base.rb +3 -1
  291. data/lib/decidim/api/functions/needs_api_default_order.rb +24 -0
  292. data/{app/functions/decidim/core → lib/decidim/api/functions}/needs_api_filter_and_order.rb +0 -0
  293. data/{app/functions/decidim/core → lib/decidim/api/functions}/participatory_space_finder_base.rb +2 -2
  294. data/{app/functions/decidim/core → lib/decidim/api/functions}/participatory_space_list_base.rb +3 -1
  295. data/{app/functions/decidim/core → lib/decidim/api/functions}/user_entity_finder.rb +1 -4
  296. data/{app/functions/decidim/core → lib/decidim/api/functions}/user_entity_list.rb +1 -3
  297. data/{app/types/decidim/core → lib/decidim/api/input_filters}/base_input_filter.rb +0 -0
  298. data/{app/types/decidim/core → lib/decidim/api/input_filters}/component_input_filter.rb +20 -22
  299. data/{app/types/decidim/core → lib/decidim/api/input_filters}/has_hastaggable_input_filter.rb +1 -1
  300. data/{app/types/decidim/core → lib/decidim/api/input_filters}/has_localized_input_filter.rb +3 -3
  301. data/{app/types/decidim/core → lib/decidim/api/input_filters}/has_publishable_input_filter.rb +6 -6
  302. data/{app/types/decidim/core → lib/decidim/api/input_filters}/has_timestamp_input_filter.rb +12 -12
  303. data/{app/types/decidim/core → lib/decidim/api/input_filters}/participatory_space_input_filter.rb +0 -1
  304. data/lib/decidim/api/input_filters/user_entity_input_filter.rb +89 -0
  305. data/{app/types/decidim/core → lib/decidim/api/input_sorts}/base_input_sort.rb +3 -2
  306. data/{app/types/decidim/core → lib/decidim/api/input_sorts}/component_input_sort.rb +10 -11
  307. data/{app/types/decidim/core → lib/decidim/api/input_sorts}/has_endorsable_input_sort.rb +2 -4
  308. data/{app/types/decidim/core → lib/decidim/api/input_sorts}/has_localized_input_sort.rb +3 -3
  309. data/{app/types/decidim/core → lib/decidim/api/input_sorts}/has_publishable_input_sort.rb +1 -1
  310. data/lib/decidim/api/input_sorts/has_timestamp_input_sort.rb +12 -0
  311. data/{app/types/decidim/core → lib/decidim/api/input_sorts}/participatory_space_input_sort.rb +1 -1
  312. data/{app/types/decidim/core → lib/decidim/api/input_sorts}/user_entity_input_sort.rb +4 -4
  313. data/lib/decidim/api/{amendable_entity_interface.rb → interfaces/amendable_entity_interface.rb} +5 -5
  314. data/lib/decidim/api/interfaces/amendable_interface.rb +17 -0
  315. data/lib/decidim/api/{attachable_interface.rb → interfaces/attachable_interface.rb} +3 -3
  316. data/lib/decidim/api/interfaces/author_interface.rb +32 -0
  317. data/lib/decidim/api/interfaces/authorable_interface.rb +23 -0
  318. data/lib/decidim/api/{categorizable_interface.rb → interfaces/categorizable_interface.rb} +3 -3
  319. data/lib/decidim/api/interfaces/coauthorable_interface.rb +30 -0
  320. data/lib/decidim/api/interfaces/component_interface.rb +22 -0
  321. data/lib/decidim/api/interfaces/endorsable_interface.rb +19 -0
  322. data/lib/decidim/api/{fingerprint_interface.rb → interfaces/fingerprint_interface.rb} +3 -3
  323. data/lib/decidim/api/interfaces/participatory_space_interface.rb +48 -0
  324. data/lib/decidim/api/interfaces/participatory_space_resourceable_interface.rb +25 -0
  325. data/lib/decidim/api/{scopable_interface.rb → interfaces/scopable_interface.rb} +3 -3
  326. data/lib/decidim/api/interfaces/timestamps_interface.rb +15 -0
  327. data/lib/decidim/api/interfaces/traceable_interface.rb +14 -0
  328. data/lib/decidim/api/scalars/date_time_type.rb +17 -0
  329. data/lib/decidim/api/scalars/date_type.rb +17 -0
  330. data/lib/decidim/api/types/amendment_type.rb +19 -0
  331. data/lib/decidim/api/types/area_api_type.rb +16 -0
  332. data/lib/decidim/api/types/area_type_type.rb +13 -0
  333. data/lib/decidim/api/types/attachment_type.rb +13 -0
  334. data/lib/decidim/api/types/category_type.rb +14 -0
  335. data/{app/types/decidim/core → lib/decidim/api/types}/component_type.rb +2 -4
  336. data/lib/decidim/api/types/coordinates_type.rb +21 -0
  337. data/lib/decidim/api/types/decidim_type.rb +13 -0
  338. data/lib/decidim/api/types/fingerprint_type.rb +12 -0
  339. data/lib/decidim/api/types/hashtag_type.rb +13 -0
  340. data/lib/decidim/api/types/localized_string_type.rb +13 -0
  341. data/lib/decidim/api/types/metric_history_type.rb +18 -0
  342. data/lib/decidim/api/types/metric_type.rb +13 -0
  343. data/lib/decidim/api/types/organization_type.rb +17 -0
  344. data/lib/decidim/api/types/participatory_space_link_type.rb +22 -0
  345. data/lib/decidim/api/types/participatory_space_type.rb +10 -0
  346. data/lib/decidim/api/types/scope_api_type.rb +16 -0
  347. data/lib/decidim/api/types/session_type.rb +22 -0
  348. data/lib/decidim/api/types/statistic_type.rb +20 -0
  349. data/lib/decidim/api/types/trace_version_type.rb +21 -0
  350. data/lib/decidim/api/types/translated_field_type.rb +36 -0
  351. data/lib/decidim/api/types/user_group_type.rb +64 -0
  352. data/lib/decidim/api/types/user_type.rb +67 -0
  353. data/lib/decidim/attachment_attributes.rb +57 -0
  354. data/lib/decidim/attributes.rb +1 -0
  355. data/lib/decidim/attributes/clean_string.rb +37 -0
  356. data/lib/decidim/coauthorable.rb +3 -3
  357. data/lib/decidim/component_manifest.rb +17 -0
  358. data/lib/decidim/content_block_manifest.rb +1 -1
  359. data/lib/decidim/content_parsers/hashtag_parser.rb +3 -6
  360. data/lib/decidim/content_parsers/user_group_parser.rb +2 -5
  361. data/lib/decidim/content_parsers/user_parser.rb +2 -5
  362. data/lib/decidim/content_processor.rb +1 -1
  363. data/lib/decidim/content_renderers/hashtag_renderer.rb +3 -6
  364. data/lib/decidim/core.rb +11 -3
  365. data/lib/decidim/core/api.rb +71 -16
  366. data/lib/decidim/core/engine.rb +40 -6
  367. data/lib/decidim/core/test.rb +4 -0
  368. data/lib/decidim/core/test/factories.rb +53 -15
  369. data/lib/decidim/core/test/shared_examples/admin_log_presenter_examples.rb +34 -0
  370. data/lib/decidim/core/test/shared_examples/admin_resource_gallery_examples.rb +1 -1
  371. data/lib/decidim/core/test/shared_examples/amendable/amendment_accepted_event_examples.rb +1 -1
  372. data/lib/decidim/core/test/shared_examples/amendable/amendment_promoted_event_examples.rb +1 -1
  373. data/lib/decidim/core/test/shared_examples/amendable/amendment_rejected_event_examples.rb +1 -1
  374. data/lib/decidim/core/test/shared_examples/comments_examples.rb +11 -9
  375. data/lib/decidim/core/test/shared_examples/component_type.rb +1 -1
  376. data/lib/decidim/core/test/shared_examples/controller_render_views.rb +28 -0
  377. data/lib/decidim/core/test/shared_examples/counts_commentators_as_newsletter_participants.rb +31 -0
  378. data/lib/decidim/core/test/shared_examples/follows_examples.rb +1 -1
  379. data/lib/decidim/core/test/shared_examples/logo_email.rb +1 -1
  380. data/lib/decidim/core/test/shared_examples/map_examples.rb +1 -1
  381. data/lib/decidim/core/test/shared_examples/process_announcements_examples.rb +1 -1
  382. data/lib/decidim/core/test/shared_examples/reportable.rb +8 -0
  383. data/lib/decidim/core/test/shared_examples/rich_text_editor_examples.rb +1 -1
  384. data/lib/decidim/core/test/shared_examples/searchable_participatory_space_examples.rb +2 -3
  385. data/lib/decidim/core/test/shared_examples/searchable_results_examples.rb +46 -0
  386. data/lib/decidim/core/test/shared_examples/static_pages_examples.rb +43 -0
  387. data/lib/decidim/core/version.rb +1 -1
  388. data/lib/decidim/diffy_extension.rb +2 -2
  389. data/lib/decidim/events/base_event.rb +18 -2
  390. data/lib/decidim/exporters/csv.rb +3 -2
  391. data/lib/decidim/exporters/export_data.rb +1 -1
  392. data/lib/decidim/faker/internet.rb +17 -0
  393. data/lib/decidim/faker/localized.rb +43 -20
  394. data/lib/decidim/file_validator_humanizer.rb +6 -4
  395. data/lib/decidim/form_builder.rb +36 -24
  396. data/lib/decidim/gamification/badge_scorer.rb +3 -2
  397. data/lib/decidim/gamification/base_event.rb +2 -2
  398. data/lib/decidim/geocodable.rb +2 -0
  399. data/lib/decidim/has_category.rb +1 -1
  400. data/lib/decidim/has_private_users.rb +2 -2
  401. data/lib/decidim/importers/import_manifest.rb +36 -0
  402. data/lib/decidim/map/autocomplete.rb +11 -1
  403. data/lib/decidim/metric_operation.rb +5 -6
  404. data/lib/decidim/newsletter_participant.rb +2 -4
  405. data/lib/decidim/paddable.rb +11 -4
  406. data/lib/decidim/participatory_space_resourceable.rb +1 -3
  407. data/lib/decidim/query_extensions.rb +90 -69
  408. data/lib/decidim/randomable.rb +6 -1
  409. data/lib/decidim/record_encryptor.rb +131 -0
  410. data/lib/decidim/reportable.rb +26 -0
  411. data/lib/decidim/resource_manifest.rb +3 -0
  412. data/lib/decidim/resourceable.rb +6 -6
  413. data/lib/decidim/scopable.rb +1 -1
  414. data/lib/decidim/search_resource_fields_mapper.rb +3 -3
  415. data/lib/decidim/searchable.rb +11 -0
  416. data/lib/decidim/settings_manifest.rb +2 -1
  417. data/lib/decidim/shareable_with_token.rb +0 -1
  418. data/lib/decidim/translatable_attributes.rb +2 -1
  419. data/lib/decidim/translatable_resource.rb +10 -0
  420. data/lib/decidim/user_reportable.rb +33 -0
  421. data/lib/decidim/view_model.rb +26 -0
  422. data/lib/premailer/adapter/decidim.rb +33 -0
  423. data/lib/tasks/decidim_data_portability_tasks.rake +4 -4
  424. data/vendor/assets/javascripts/datepicker-locales/foundation-datepicker.ko.js +18 -0
  425. data/vendor/assets/javascripts/datepicker-locales/foundation-datepicker.vi.js +14 -0
  426. data/vendor/assets/javascripts/datepicker-locales/foundation-datepicker.zh-CN.js +14 -0
  427. data/vendor/assets/javascripts/datepicker-locales/foundation-datepicker.zh-TW.js +14 -0
  428. metadata +203 -105
  429. data/app/cells/decidim/tos_page/sticky_form.erb +0 -29
  430. data/app/functions/decidim/core/participatory_space_finder.rb +0 -11
  431. data/app/functions/decidim/core/participatory_space_list.rb +0 -11
  432. data/app/types/decidim/core/amendment_type.rb +0 -26
  433. data/app/types/decidim/core/area_api_type.rb +0 -16
  434. data/app/types/decidim/core/area_type_type.rb +0 -14
  435. data/app/types/decidim/core/attachment_type.rb +0 -14
  436. data/app/types/decidim/core/category_type.rb +0 -16
  437. data/app/types/decidim/core/coordinates_type.rb +0 -19
  438. data/app/types/decidim/core/date_time_type.rb +0 -12
  439. data/app/types/decidim/core/date_type.rb +0 -13
  440. data/app/types/decidim/core/decidim_type.rb +0 -19
  441. data/app/types/decidim/core/fingerprint_type.rb +0 -15
  442. data/app/types/decidim/core/has_timestamp_input_sort.rb +0 -12
  443. data/app/types/decidim/core/hashtag_type.rb +0 -13
  444. data/app/types/decidim/core/localized_string_type.rb +0 -14
  445. data/app/types/decidim/core/metric_history_type.rb +0 -17
  446. data/app/types/decidim/core/metric_type.rb +0 -14
  447. data/app/types/decidim/core/organization_type.rb +0 -20
  448. data/app/types/decidim/core/participatory_space_link_type.rb +0 -24
  449. data/app/types/decidim/core/participatory_space_type.rb +0 -12
  450. data/app/types/decidim/core/scope_api_type.rb +0 -16
  451. data/app/types/decidim/core/session_type.rb +0 -19
  452. data/app/types/decidim/core/statistic_type.rb +0 -22
  453. data/app/types/decidim/core/trace_version_type.rb +0 -29
  454. data/app/types/decidim/core/translated_field_type.rb +0 -45
  455. data/app/types/decidim/core/user_entity_input_filter.rb +0 -81
  456. data/app/types/decidim/core/user_group_type.rb +0 -51
  457. data/app/types/decidim/core/user_type.rb +0 -52
  458. data/app/views/decidim/shared/_announcement.html.erb +0 -1
  459. data/app/views/decidim/shared/_flag_modal.html.erb +0 -20
  460. data/lib/decidim/api/amendable_interface.rb +0 -18
  461. data/lib/decidim/api/author_interface.rb +0 -29
  462. data/lib/decidim/api/authorable_interface.rb +0 -22
  463. data/lib/decidim/api/coauthorable_interface.rb +0 -29
  464. data/lib/decidim/api/component_interface.rb +0 -20
  465. data/lib/decidim/api/endorsable_interface.rb +0 -22
  466. data/lib/decidim/api/participatory_space_interface.rb +0 -47
  467. data/lib/decidim/api/participatory_space_resourceable_interface.rb +0 -21
  468. data/lib/decidim/api/timestamps_interface.rb +0 -21
  469. data/lib/decidim/api/traceable_interface.rb +0 -14
@@ -39,13 +39,13 @@ module Decidim
39
39
  @gallery.map! do |photo|
40
40
  photo.attached_to = gallery_attached_to
41
41
  photo.save!
42
- @form.photos << photo.id.to_s
42
+ @form.photos << photo
43
43
  end
44
44
  end
45
45
 
46
46
  def photo_cleanup!
47
47
  gallery_attached_to.photos.each do |photo|
48
- photo.destroy! if @form.photos.exclude? photo.id.to_s
48
+ photo.destroy! if @form.photos.map(&:id).exclude? photo.id
49
49
  end
50
50
  # manually reset cached photos
51
51
  gallery_attached_to.reload
@@ -16,26 +16,30 @@ module Decidim
16
16
  end
17
17
 
18
18
  def attachments_invalid?
19
- @documents.each do |file|
20
- if file.invalid? && file.errors.has_key?(:file)
21
- @form.errors.add(:add_documents, file.errors[:file])
22
- return true
19
+ @documents.each do |document|
20
+ next if document.valid? || !document.errors.has_key?(:file)
21
+
22
+ document.errors[:file].each do |error|
23
+ @form.errors.add(:add_documents, error)
23
24
  end
25
+
26
+ return true
24
27
  end
28
+
25
29
  false
26
30
  end
27
31
 
28
32
  def create_attachments
29
- @documents.map! do |file|
30
- file.attached_to = documents_attached_to
31
- file.save!
32
- @form.documents << file.id.to_s
33
+ @documents.map! do |document|
34
+ document.attached_to = documents_attached_to
35
+ document.save!
36
+ @form.documents << document
33
37
  end
34
38
  end
35
39
 
36
40
  def document_cleanup!
37
- documents_attached_to.documents.each do |file|
38
- file.destroy! if @form.documents.exclude? file.id.to_s
41
+ documents_attached_to.documents.each do |document|
42
+ document.destroy! if @form.documents.map(&:id).exclude? document.id
39
43
  end
40
44
 
41
45
  documents_attached_to.reload
@@ -82,8 +82,11 @@ module Decidim
82
82
  end
83
83
 
84
84
  def filtered_query_for(class_name)
85
- query = SearchableResource.where(organization: organization, locale: I18n.locale)
86
- query = query.where(resource_type: class_name)
85
+ query = SearchableResource.where(
86
+ organization: organization,
87
+ locale: I18n.locale,
88
+ resource_type: class_name
89
+ )
87
90
 
88
91
  clean_filters.each_pair do |attribute_name, value|
89
92
  query = query.where(attribute_name => value)
@@ -28,6 +28,7 @@ module Decidim
28
28
  @user.newsletter_notifications_at = @form.newsletter_notifications_at
29
29
  @user.notification_types = @form.notification_types
30
30
  @user.direct_message_types = @form.direct_message_types
31
+ @user.email_on_moderations = @form.email_on_moderations
31
32
  end
32
33
  end
33
34
  end
@@ -8,6 +8,7 @@ module Decidim
8
8
  # form - A form object with the params.
9
9
  # user_group - The user group to update
10
10
  def initialize(form, user_group)
11
+ form.avatar = user_group.avatar if form.avatar.blank?
11
12
  @form = form
12
13
  @user_group = user_group
13
14
  end
@@ -19,6 +19,7 @@ module Decidim
19
19
  include NeedsPermission
20
20
  include Decidim::SafeRedirect
21
21
  include NeedsSnippets
22
+ include UserBlockedChecker
22
23
 
23
24
  helper Decidim::TranslationsHelper
24
25
  helper Decidim::MetaTagsHelper
@@ -10,11 +10,15 @@ module Decidim
10
10
  extend ActiveSupport::Concern
11
11
 
12
12
  included do
13
- helper_method :flaggable_controller?
13
+ helper_method :flaggable_controller?, :report_form
14
14
 
15
15
  def flaggable_controller?
16
16
  true
17
17
  end
18
+
19
+ def report_form
20
+ Decidim::ReportForm.from_params(reason: "spam")
21
+ end
18
22
  end
19
23
  end
20
24
  end
@@ -23,17 +23,25 @@ module Decidim
23
23
  unless user_signed_in?
24
24
  flash[:warning] = t("actions.login_before_access", scope: "decidim.core")
25
25
  store_location_for(:user, request.path)
26
- return redirect_to decidim.new_user_session_path
26
+ redirect_to decidim.new_user_session_path
27
27
  end
28
28
  end
29
29
 
30
30
  # Check for all paths that should be allowed even if the user is not yet
31
31
  # authorized
32
32
  def allow_unauthorized_path?
33
- # Changing the locale
34
- return true if %r{^\/locale}.match?(request.path) || %r{^\/cookies}.match?(request.path)
33
+ return true if unauthorized_paths.any? { |path| /^#{path}/.match?(request.path) }
35
34
 
36
35
  false
37
36
  end
37
+
38
+ def unauthorized_paths
39
+ # /locale is for changing the locale
40
+ # /cookies is for accepting the cookies
41
+ %w(/locale /cookies) + Decidim::StaticPage.where(
42
+ organization: current_organization,
43
+ allow_public_access: true
44
+ ).pluck(Arel.sql("CONCAT('/pages/', slug)"))
45
+ end
38
46
  end
39
47
  end
@@ -69,6 +69,9 @@ module Decidim
69
69
  end
70
70
  end
71
71
 
72
+ # rubocop: disable Metrics/CyclomaticComplexity
73
+ # rubocop: disable Metrics/PerceivedComplexity
74
+
72
75
  # Finds a suitable language or returns nil
73
76
  # Follows the RFC 2616 rules with this particularities:
74
77
  # if no language matches, goes for the 2 chars prefixes
@@ -96,6 +99,8 @@ module Decidim
96
99
  end
97
100
  lang == "*" ? nil : lang
98
101
  end
102
+ # rubocop: enable Metrics/CyclomaticComplexity
103
+ # rubocop: enable Metrics/PerceivedComplexity
99
104
  end
100
105
  end
101
106
  end
@@ -21,7 +21,13 @@ module Decidim
21
21
  # them they are not authorized.
22
22
  def user_has_no_permission
23
23
  flash[:alert] = t("actions.unauthorized", scope: "decidim.core")
24
- redirect_to(request.referer || user_has_no_permission_path)
24
+ redirect_to(user_has_no_permission_referer || user_has_no_permission_path)
25
+ end
26
+
27
+ def user_has_no_permission_referer
28
+ return if request.referer == request.original_url
29
+
30
+ request.referer
25
31
  end
26
32
 
27
33
  def user_has_no_permission_path
@@ -29,7 +29,9 @@ module Decidim
29
29
  # Returns: A random float number between -1 and 1 to be used as a
30
30
  # random seed at the database.
31
31
  def random_seed
32
- @random_seed ||= session.fetch(:random_seed, (rand * 2 - 1)).to_f
32
+ @random_seed ||= begin
33
+ session[:random_seed] ||= rand * 2 - 1
34
+ end.to_f
33
35
  end
34
36
  end
35
37
  end
@@ -0,0 +1,26 @@
1
+ # frozen_string_literal: true
2
+
3
+ require "active_support/concern"
4
+
5
+ module Decidim
6
+ module UserBlockedChecker
7
+ extend ActiveSupport::Concern
8
+
9
+ included do
10
+ before_action :check_user_not_blocked
11
+ end
12
+
13
+ def check_user_not_blocked
14
+ check_user_block_status(current_user)
15
+ end
16
+
17
+ def check_user_block_status(user)
18
+ if user.present? && user.blocked?
19
+ sign_out user
20
+ flash.delete(:notice)
21
+ flash[:error] = t("decidim.account.blocked")
22
+ root_path
23
+ end
24
+ end
25
+ end
26
+ end
@@ -17,6 +17,7 @@ module Decidim
17
17
  include ForceAuthentication
18
18
  include SafeRedirect
19
19
  include NeedsSnippets
20
+ include UserBlockedChecker
20
21
 
21
22
  helper Decidim::MetaTagsHelper
22
23
  helper Decidim::DecidimFormHelper
@@ -63,6 +64,27 @@ module Decidim
63
64
  store_location_for(:user, value)
64
65
  end
65
66
 
67
+ # This overrides Devise's method for extracting the path from the URL. We
68
+ # want to ensure the path to be stored in the cookie is not too long in
69
+ # order to avoid ActionDispatch::Cookies::CookieOverflow exception. If the
70
+ # session cookie (containing all the session data) is over 4 KB in length,
71
+ # it would lead to an exception if the cookie store is being used. This is
72
+ # a hard constraint set by ActionDispatch because some browsers do not allow
73
+ # cookies over 4 KB.
74
+ #
75
+ # Original code in Devise: https://git.io/Jt6wt
76
+ def extract_path_from_location(location)
77
+ path = super
78
+ return path unless Rails.application.config.session_store == ActionDispatch::Session::CookieStore
79
+
80
+ # Allow 3 KB size for the path because there can be also some other
81
+ # session variables out there.
82
+ return path if path.bytesize <= ActionDispatch::Cookies::MAX_COOKIE_SIZE - 1024
83
+
84
+ # For too long paths, remove the URL parameters
85
+ path.split("?").first
86
+ end
87
+
66
88
  # We store whether the user is requesting to toggle the translations or not.
67
89
  # We need to store it this way because if we use an instance variable, then
68
90
  # we're not able to access that value from inside the presenters, and we
@@ -46,7 +46,9 @@ module Decidim
46
46
  end
47
47
 
48
48
  def after_sign_in_path_for(user)
49
- if !pending_redirect?(user) && first_login_and_not_authorized?(user)
49
+ if user.present? && user.blocked?
50
+ check_user_block_status(user)
51
+ elsif !pending_redirect?(user) && first_login_and_not_authorized?(user)
50
52
  decidim_verifications.authorizations_path
51
53
  else
52
54
  super
@@ -6,19 +6,23 @@ module Decidim
6
6
  class SessionsController < ::Devise::SessionsController
7
7
  include Decidim::DeviseControllers
8
8
 
9
+ # rubocop: disable Rails/LexicallyScopedActionFilter
9
10
  before_action :check_sign_in_enabled, only: :create
10
-
11
- def create
12
- super
13
- end
11
+ # rubocop: enable Rails/LexicallyScopedActionFilter
14
12
 
15
13
  def destroy
16
14
  current_user.invalidate_all_sessions!
17
- super
15
+ if params[:translation_suffix].present?
16
+ super { set_flash_message! :notice, params[:translation_suffix], { scope: "decidim.devise.sessions" } }
17
+ else
18
+ super
19
+ end
18
20
  end
19
21
 
20
22
  def after_sign_in_path_for(user)
21
- if first_login_and_not_authorized?(user) && !user.admin? && !pending_redirect?(user)
23
+ if user.present? && user.blocked?
24
+ check_user_block_status(user)
25
+ elsif first_login_and_not_authorized?(user) && !user.admin? && !pending_redirect?(user)
22
26
  decidim_verifications.first_login_authorizations_path
23
27
  else
24
28
  super
@@ -2,7 +2,7 @@
2
2
 
3
3
  module Decidim
4
4
  class ErrorsController < Decidim::ApplicationController
5
- skip_before_action :verify_authenticity_token
5
+ skip_before_action :verify_authenticity_token, :tos_accepted_by_user
6
6
  skip_after_action :verify_same_origin_request
7
7
 
8
8
  def not_found
@@ -16,7 +16,7 @@ module Decidim
16
16
 
17
17
  def referer_with_new_locale
18
18
  uri = URI(request.referer || "/")
19
- query = uri.query.to_s.gsub(/locale\=[a-zA-Z\-]{2,5}/, "")
19
+ query = uri.query.to_s.gsub(/locale=[a-zA-Z\-]{2,5}/, "")
20
20
  params = URI.decode_www_form(query) << ["locale", current_locale]
21
21
  uri.query = URI.encode_www_form(params)
22
22
 
@@ -4,6 +4,7 @@ module Decidim
4
4
  # The controller to handle the user's public profile page.
5
5
  class ProfilesController < Decidim::ApplicationController
6
6
  include UserGroups
7
+ include Flaggable
7
8
 
8
9
  helper Decidim::Messaging::ConversationHelper
9
10
 
@@ -12,6 +13,7 @@ module Decidim
12
13
  before_action :ensure_profile_holder
13
14
  before_action :ensure_profile_holder_is_a_group, only: [:members]
14
15
  before_action :ensure_profile_holder_is_a_user, only: [:groups, :following]
16
+ before_action :ensure_user_not_blocked, only: [:following, :followers, :badges]
15
17
 
16
18
  def show
17
19
  return redirect_to profile_timeline_path(nickname: params[:nickname]) if profile_holder == current_user
@@ -62,6 +64,10 @@ module Decidim
62
64
 
63
65
  private
64
66
 
67
+ def ensure_user_not_blocked
68
+ raise ActionController::RoutingError, "Blocked User" if profile_holder&.blocked? && !current_user&.admin?
69
+ end
70
+
65
71
  def ensure_profile_holder_is_a_group
66
72
  raise ActionController::RoutingError, "No user group with the given nickname" unless profile_holder.is_a?(Decidim::UserGroup)
67
73
  end
@@ -0,0 +1,42 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Decidim
4
+ class ReportUsersController < ApplicationController
5
+ include FormFactory
6
+ include NeedsPermission
7
+
8
+ before_action :authenticate_user!
9
+
10
+ def create
11
+ enforce_permission_to :create, :user_report
12
+
13
+ @form = form(Decidim::ReportForm).from_params(params)
14
+
15
+ CreateUserReport.call(@form, reportable, current_user) do
16
+ on(:ok) do
17
+ flash[:notice] = I18n.t("decidim.reports.create.success")
18
+ redirect_back fallback_location: root_path
19
+ end
20
+
21
+ on(:invalid) do
22
+ flash[:alert] = I18n.t("decidim.reports.create.error")
23
+ redirect_back fallback_location: root_path
24
+ end
25
+ end
26
+ end
27
+
28
+ private
29
+
30
+ def reportable
31
+ @reportable ||= GlobalID::Locator.locate_signed params[:sgid]
32
+ end
33
+
34
+ def permission_class_chain
35
+ [Decidim::ReportUserPermissions, Decidim::Permissions]
36
+ end
37
+
38
+ def permission_scope
39
+ :public
40
+ end
41
+ end
42
+ end
@@ -8,17 +8,10 @@ module Decidim
8
8
  def picker
9
9
  enforce_permission_to :pick, :scope
10
10
 
11
- context = root ? { root: root.id, title: title, max_depth: max_depth } : { title: title, max_depth: max_depth }
12
- required = params[:required] && params[:required] != "false"
11
+ context = picker_context(root, title, max_depth)
12
+ required = params&.[](:required) != "false"
13
13
 
14
- if current
15
- scopes = current.children unless scope_depth_limit?
16
- parent_scopes = current.part_of_scopes(root)
17
- else
18
- scopes = root&.children || current_organization.scopes.top_level unless scope_depth_limit?
19
-
20
- parent_scopes = [root].compact
21
- end
14
+ scopes, parent_scopes = resolve_picker_scopes(root, current)
22
15
 
23
16
  render(
24
17
  :picker,
@@ -40,6 +33,22 @@ module Decidim
40
33
 
41
34
  private
42
35
 
36
+ def picker_context(root, title, max_depth)
37
+ root ? { root: root.id, title: title, max_depth: max_depth } : { title: title, max_depth: max_depth }
38
+ end
39
+
40
+ def resolve_picker_scopes(root, current)
41
+ scopes = nil
42
+ if current
43
+ scopes = current.children unless scope_depth_limit?
44
+ parent_scopes = current.part_of_scopes(root)
45
+ else
46
+ scopes = root&.children || current_organization.scopes.top_level unless scope_depth_limit?
47
+ parent_scopes = [root].compact
48
+ end
49
+ [scopes, parent_scopes]
50
+ end
51
+
43
52
  def title
44
53
  @title ||= params[:title] || t("decidim.scopes.picker.title", field: params[:field]&.downcase)
45
54
  end
@@ -0,0 +1,28 @@
1
+ # frozen_string_literal: true
2
+
3
+ require "active_support/concern"
4
+
5
+ module Decidim
6
+ # Tells/Extends time before inactivity warning or automatic logout.
7
+ class TimeoutsController < Decidim::ApplicationController
8
+ prepend_before_action :skip_timeout, only: :seconds_until_timeout
9
+
10
+ def skip_timeout
11
+ request.env["devise.skip_timeoutable"] = true
12
+ end
13
+
14
+ def seconds_until_timeout
15
+ time_remaining = current_user ? ::Devise.timeout_in - (Time.current - Time.zone.at(user_session["last_request_at"])) : 0
16
+ respond_to do |format|
17
+ format.json { render json: { seconds_remaining: time_remaining.to_i }, status: :ok }
18
+ end
19
+ end
20
+
21
+ # If user wants to continue session after inactivity warning.
22
+ def heartbeat
23
+ respond_to do |format|
24
+ format.js
25
+ end
26
+ end
27
+ end
28
+ end