decidim-core 0.23.2 → 0.24.0
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.
- checksums.yaml +4 -4
- data/README.md +2 -2
- data/app/assets/images/decidim/icons.svg +1 -1
- data/app/assets/javascripts/decidim.js.es6 +2 -0
- data/app/assets/javascripts/decidim/core/bundle.js +1 -1
- data/app/assets/javascripts/decidim/core/bundle.js.map +1 -1
- data/app/assets/javascripts/decidim/editor.js.es6 +15 -4
- data/app/assets/javascripts/decidim/editor/history_override.js.es6 +117 -0
- data/app/assets/javascripts/decidim/editor/linebreak_module.js.es6 +83 -0
- data/app/assets/javascripts/decidim/editor/modified_backspace_offset1.js.es6 +98 -0
- data/app/assets/javascripts/decidim/editor/modified_backspace_offset_any.js.es6 +48 -0
- data/app/assets/javascripts/decidim/editor/modified_backspace_utils.js.es6 +31 -0
- data/app/assets/javascripts/decidim/editor/modified_enter.js.es6 +118 -0
- data/app/assets/javascripts/decidim/form_filter.component.js.es6 +25 -0
- data/app/assets/javascripts/decidim/gallery.js.es6 +5 -0
- data/app/assets/javascripts/decidim/geocoding/attach_input.js.es6 +41 -4
- data/app/assets/javascripts/decidim/input_character_counter.js.es6 +6 -1
- data/app/assets/javascripts/decidim/map/controller/markers.js.es6 +40 -10
- data/app/assets/javascripts/decidim/session_timeouter.js.es6 +78 -0
- data/app/assets/stylesheets/decidim/_variables.scss +9 -0
- data/app/assets/stylesheets/decidim/email.scss +14 -2
- data/app/assets/stylesheets/decidim/extras/_external-links.scss +0 -1
- data/app/assets/stylesheets/decidim/extras/_process_stats.scss +1 -1
- data/app/assets/stylesheets/decidim/extras/_results-per-page.scss +1 -0
- data/app/assets/stylesheets/decidim/layouts/_home.scss +5 -0
- data/app/assets/stylesheets/decidim/modules/_author-avatar.scss +2 -2
- data/app/assets/stylesheets/decidim/modules/_buttons.scss +2 -2
- data/app/assets/stylesheets/decidim/modules/_cards.scss +18 -1
- data/app/assets/stylesheets/decidim/modules/_collapsible-list.scss +1 -1
- data/app/assets/stylesheets/decidim/modules/_comments.scss +5 -1
- data/app/assets/stylesheets/decidim/modules/_conference-speaker.scss +4 -3
- data/app/assets/stylesheets/decidim/modules/_data-picker.scss +7 -0
- data/app/assets/stylesheets/decidim/modules/_extra.scss +4 -0
- data/app/assets/stylesheets/decidim/modules/_forms.scss +4 -0
- data/app/assets/stylesheets/decidim/modules/_loading-spinner.scss +34 -0
- data/app/assets/stylesheets/decidim/modules/_modules.scss +1 -1
- data/app/assets/stylesheets/decidim/modules/_opinion-toggle.scss +1 -1
- data/app/assets/stylesheets/decidim/modules/_reveal.scss +6 -0
- data/app/assets/stylesheets/decidim/modules/_signup.scss +1 -0
- data/app/assets/stylesheets/decidim/modules/{_process-stats.scss → _space-stats.scss} +1 -1
- data/app/cells/decidim/activity/show.erb +1 -1
- data/app/cells/decidim/activity_cell.rb +17 -8
- data/app/cells/decidim/address/details.erb +5 -5
- data/app/cells/decidim/address_cell.rb +21 -0
- data/app/cells/decidim/announcement/show.erb +4 -4
- data/app/cells/decidim/announcement_cell.rb +43 -8
- data/app/cells/decidim/author/flag_user.erb +10 -0
- data/app/cells/decidim/author/profile_minicard.erb +1 -1
- data/app/cells/decidim/author_cell.rb +9 -1
- data/app/cells/decidim/card_m/top.erb +1 -1
- data/app/cells/decidim/card_m_cell.rb +1 -1
- data/app/cells/decidim/content_blocks/cta/show.erb +14 -0
- data/app/cells/decidim/content_blocks/cta_cell.rb +35 -0
- data/app/cells/decidim/content_blocks/cta_settings_form/show.erb +9 -0
- data/app/cells/decidim/content_blocks/cta_settings_form_cell.rb +13 -0
- data/app/cells/decidim/content_blocks/hero_cell.rb +14 -0
- data/app/cells/decidim/content_blocks/highlighted_elements/elements.erb +0 -0
- data/app/cells/decidim/content_blocks/highlighted_elements/heading.erb +0 -0
- data/app/cells/decidim/content_blocks/highlighted_elements/show.erb +4 -0
- data/app/cells/decidim/content_blocks/highlighted_elements_cell.rb +51 -0
- data/app/cells/decidim/content_blocks/highlighted_elements_settings_form/show.erb +3 -0
- data/app/cells/decidim/content_blocks/highlighted_elements_settings_form_cell.rb +28 -0
- data/app/cells/decidim/content_blocks/last_activity_cell.rb +11 -0
- data/app/cells/decidim/content_blocks/metrics_cell.rb +0 -6
- data/app/cells/decidim/content_blocks/stats_cell.rb +0 -6
- data/app/cells/decidim/content_blocks/sub_hero/show.erb +3 -1
- data/app/cells/decidim/date/show.erb +31 -0
- data/app/cells/decidim/date_cell.rb +50 -0
- data/app/cells/decidim/endorsement_buttons_cell.rb +3 -3
- data/app/cells/decidim/flag_modal/flag_user.erb +24 -0
- data/app/cells/decidim/flag_modal/show.erb +24 -0
- data/app/cells/decidim/flag_modal_cell.rb +25 -0
- data/app/cells/decidim/profile/inaccessible.erb +9 -0
- data/app/cells/decidim/profile_cell.rb +9 -1
- data/app/cells/decidim/profile_sidebar/show.erb +10 -1
- data/app/cells/decidim/profile_sidebar_cell.rb +1 -0
- data/app/cells/decidim/reported_content/show.erb +5 -0
- data/app/cells/decidim/reported_content_cell.rb +44 -0
- data/app/cells/decidim/scopes_picker/scope_picker_prompt.erb +3 -0
- data/app/cells/decidim/scopes_picker/scope_picker_values.erb +5 -0
- data/app/cells/decidim/scopes_picker/show.erb +14 -0
- data/app/cells/decidim/scopes_picker_cell.rb +93 -0
- data/app/cells/decidim/tos_page/announcement.erb +1 -1
- data/app/cells/decidim/tos_page/form.erb +15 -13
- data/app/cells/decidim/tos_page_cell.rb +10 -8
- data/app/cells/decidim/translation_bar_cell.rb +1 -1
- data/app/cells/decidim/user_conversation/conversation_header.erb +1 -1
- data/app/cells/decidim/user_conversations_cell.rb +1 -1
- data/app/commands/decidim/attachment_methods.rb +8 -0
- data/app/commands/decidim/create_report.rb +11 -1
- data/app/commands/decidim/create_user_report.rb +67 -0
- data/app/commands/decidim/destroy_account.rb +2 -0
- data/app/commands/decidim/gallery_methods.rb +2 -2
- data/app/commands/decidim/multiple_attachments_methods.rb +14 -10
- data/app/commands/decidim/search.rb +5 -2
- data/app/commands/decidim/update_notifications_settings.rb +1 -0
- data/app/commands/decidim/update_user_group.rb +1 -0
- data/app/controllers/concerns/decidim/devise_controllers.rb +1 -0
- data/app/controllers/concerns/decidim/flaggable.rb +5 -1
- data/app/controllers/concerns/decidim/force_authentication.rb +11 -3
- data/app/controllers/concerns/decidim/locale_switcher.rb +5 -0
- data/app/controllers/concerns/decidim/needs_permission.rb +7 -1
- data/app/controllers/concerns/decidim/orderable.rb +3 -1
- data/app/controllers/concerns/decidim/paginable.rb +8 -1
- data/app/controllers/concerns/decidim/user_blocked_checker.rb +26 -0
- data/app/controllers/decidim/application_controller.rb +22 -0
- data/app/controllers/decidim/devise/omniauth_registrations_controller.rb +3 -1
- data/app/controllers/decidim/devise/sessions_controller.rb +10 -6
- data/app/controllers/decidim/errors_controller.rb +1 -1
- data/app/controllers/decidim/locales_controller.rb +1 -1
- data/app/controllers/decidim/profiles_controller.rb +6 -0
- data/app/controllers/decidim/report_users_controller.rb +42 -0
- data/app/controllers/decidim/scopes_controller.rb +19 -10
- data/app/controllers/decidim/timeouts_controller.rb +28 -0
- data/app/controllers/decidim/user_activities_controller.rb +5 -0
- data/app/controllers/decidim/user_timeline_controller.rb +1 -0
- data/app/events/decidim/demoted_membership_event.rb +2 -2
- data/app/events/decidim/invited_to_group_event.rb +2 -2
- data/app/events/decidim/join_request_accepted_event.rb +2 -2
- data/app/events/decidim/join_request_created_event.rb +2 -2
- data/app/events/decidim/join_request_rejected_event.rb +2 -2
- data/app/events/decidim/promoted_to_admin_event.rb +2 -2
- data/app/events/decidim/removed_from_group_event.rb +2 -2
- data/app/forms/decidim/account_form.rb +1 -1
- data/app/forms/decidim/attachment_form.rb +1 -0
- data/app/forms/decidim/invite_user_form.rb +2 -2
- data/app/forms/decidim/messaging/conversation_form.rb +1 -1
- data/app/forms/decidim/messaging/message_form.rb +1 -1
- data/app/forms/decidim/notifications_settings_form.rb +20 -0
- data/app/forms/url_validator.rb +20 -0
- data/app/helpers/decidim/action_authorization_helper.rb +2 -0
- data/app/helpers/decidim/application_helper.rb +1 -2
- data/app/helpers/decidim/cells_helper.rb +6 -0
- data/app/helpers/decidim/filters_helper.rb +10 -0
- data/app/helpers/decidim/messaging/conversation_helper.rb +11 -1
- data/app/helpers/decidim/newsletters_helper.rb +7 -9
- data/app/helpers/decidim/scopes_helper.rb +2 -2
- data/app/jobs/decidim/block_user_job.rb +11 -0
- data/app/jobs/decidim/export_job.rb +2 -2
- data/app/jobs/decidim/find_and_update_descendants_job.rb +48 -0
- data/app/jobs/decidim/machine_translation_resource_job.rb +3 -0
- data/app/jobs/decidim/machine_translation_save_job.rb +29 -0
- data/app/jobs/decidim/update_search_indexes_job.rb +11 -0
- data/app/jobs/decidim/user_report_job.rb +11 -0
- data/app/mailers/concerns/decidim/localised_mailer.rb +4 -2
- data/app/mailers/decidim/block_user_mailer.rb +21 -0
- data/app/mailers/decidim/notification_mailer.rb +0 -2
- data/app/mailers/decidim/reported_mailer.rb +33 -3
- data/app/mailers/decidim/user_report_mailer.rb +21 -0
- data/app/models/decidim/area.rb +0 -1
- data/app/models/decidim/area_type.rb +1 -1
- data/app/models/decidim/attachment.rb +3 -2
- data/app/models/decidim/attachment_collection.rb +1 -1
- data/app/models/decidim/authorization.rb +4 -0
- data/app/models/decidim/category.rb +6 -1
- data/app/models/decidim/follow.rb +1 -1
- data/app/models/decidim/impersonation_log.rb +5 -7
- data/app/models/decidim/metric.rb +2 -2
- data/app/models/decidim/moderation.rb +12 -0
- data/app/models/decidim/organization.rb +5 -1
- data/app/models/decidim/scope.rb +5 -2
- data/app/models/decidim/scope_type.rb +1 -1
- data/app/models/decidim/share_token.rb +1 -1
- data/app/models/decidim/static_page.rb +11 -1
- data/app/models/decidim/static_page_topic.rb +4 -0
- data/app/models/decidim/user.rb +12 -1
- data/app/models/decidim/user_base_entity.rb +12 -12
- data/app/models/decidim/user_block.rb +10 -0
- data/app/models/decidim/user_group.rb +5 -0
- data/app/models/decidim/user_moderation.rb +22 -0
- data/app/models/decidim/user_report.rb +31 -0
- data/app/permissions/decidim/permissions.rb +1 -3
- data/app/permissions/decidim/report_user_permissions.rb +13 -0
- data/app/presenters/decidim/admin_log/impersonation_log_presenter.rb +39 -0
- data/app/presenters/decidim/admin_log/organization_presenter.rb +1 -2
- data/app/presenters/decidim/admin_log/user_moderation_presenter.rb +63 -0
- data/app/presenters/decidim/admin_log/user_presenter.rb +18 -9
- data/app/presenters/decidim/home_stats_presenter.rb +3 -3
- data/app/presenters/decidim/log/diff_presenter.rb +4 -3
- data/app/presenters/decidim/log/resource_presenter.rb +4 -4
- data/app/presenters/decidim/log/user_presenter.rb +1 -1
- data/app/presenters/decidim/menu_presenter.rb +12 -7
- data/app/presenters/decidim/nil_presenter.rb +0 -2
- data/app/presenters/decidim/user_presenter.rb +1 -1
- data/app/queries/decidim/metrics/blocked_users_metric_manage.rb +26 -0
- data/app/queries/decidim/metrics/followers_metric_manage.rb +3 -0
- data/app/queries/decidim/metrics/participants_metric_manage.rb +3 -0
- data/app/queries/decidim/metrics/reported_users_metric_manage.rb +26 -0
- data/app/queries/decidim/metrics/user_reports_metric_manage.rb +26 -0
- data/app/queries/decidim/user_groups/accepted_memberships.rb +1 -1
- data/app/queries/decidim/user_groups/admin_memberships.rb +1 -1
- data/app/queries/decidim/user_groups/member_memberships.rb +1 -1
- data/app/services/decidim/activity_search.rb +1 -3
- data/app/services/decidim/base_diff_renderer.rb +1 -1
- data/app/services/decidim/data_portability_exporter.rb +1 -0
- data/app/services/decidim/email_notification_generator.rb +2 -2
- data/app/services/decidim/events_manager.rb +1 -1
- data/app/services/decidim/open_data_exporter.rb +36 -7
- data/app/services/decidim/zip_stream/zip_stream_writer.rb +3 -3
- data/app/uploaders/decidim/application_uploader.rb +22 -2
- data/app/uploaders/decidim/attachment_uploader.rb +2 -4
- data/app/uploaders/decidim/downloader.rb +9 -0
- data/app/uploaders/decidim/image_uploader.rb +9 -21
- data/app/uploaders/decidim/open_data_uploader.rb +5 -0
- data/app/uploaders/decidim/record_image_uploader.rb +2 -2
- data/app/validators/etiquette_validator.rb +0 -7
- data/app/validators/uploader_content_type_validator.rb +4 -2
- data/app/views/decidim/block_user_mailer/notify.html.erb +7 -0
- data/app/views/decidim/devise/confirmations/new.html.erb +1 -1
- data/app/views/decidim/devise/registrations/edit.html.erb +1 -1
- data/app/views/decidim/devise/unlocks/new.html.erb +1 -1
- data/app/views/decidim/messaging/conversations/_conversation.html.erb +1 -1
- data/app/views/decidim/messaging/conversations/_messages.html.erb +1 -1
- data/app/views/decidim/messaging/conversations/_show.html.erb +4 -4
- data/app/views/decidim/notifications_settings/show.html.erb +11 -0
- data/app/views/decidim/pages/_standalone.html.erb +3 -1
- data/app/views/decidim/reported_mailer/report.html.erb +17 -9
- data/app/views/decidim/searches/_filters_small_view.html.erb +1 -1
- data/app/views/decidim/shared/_check_boxes_tree.html.erb +3 -3
- data/app/views/decidim/shared/_component_announcement.html.erb +2 -2
- data/app/views/decidim/shared/participatory_space_filters/_filters.html.erb +1 -1
- data/app/views/decidim/user_report_mailer/notify.html.erb +7 -0
- data/app/views/decidim/widgets/_data_picker.html.erb +1 -1
- data/app/views/layouts/decidim/_application.html.erb +1 -0
- data/app/views/layouts/decidim/_js_configuration.html.erb +1 -1
- data/app/views/layouts/decidim/_main_footer.html.erb +6 -4
- data/app/views/layouts/decidim/_timeout_modal.html.erb +21 -0
- data/config/initializers/active_support.rb +7 -0
- data/config/initializers/devise.rb +1 -1
- data/config/initializers/omniauth.rb +1 -1
- data/config/locales/ar.yml +1 -9
- data/config/locales/bg.yml +1 -15
- data/config/locales/ca.yml +80 -15
- data/config/locales/cs.yml +100 -35
- data/config/locales/de.yml +83 -18
- data/config/locales/el.yml +1 -16
- data/config/locales/en.yml +79 -14
- data/config/locales/eo.yml +0 -1
- data/config/locales/es-MX.yml +77 -12
- data/config/locales/es-PY.yml +77 -12
- data/config/locales/es.yml +80 -15
- data/config/locales/eu.yml +4 -12
- data/config/locales/fi-plain.yml +80 -16
- data/config/locales/fi.yml +84 -20
- data/config/locales/fr-CA.yml +79 -14
- data/config/locales/fr.yml +78 -13
- data/config/locales/gl.yml +1 -15
- data/config/locales/hu.yml +1 -15
- data/config/locales/id-ID.yml +1 -9
- data/config/locales/is-IS.yml +7 -2
- data/config/locales/it.yml +70 -19
- data/config/locales/ja.yml +1 -16
- data/config/locales/lv.yml +1 -14
- data/config/locales/nl.yml +39 -16
- data/config/locales/no.yml +12 -18
- data/config/locales/pl.yml +100 -25
- data/config/locales/pt-BR.yml +1 -9
- data/config/locales/pt.yml +1 -16
- data/config/locales/ro-RO.yml +80 -13
- data/config/locales/ru.yml +5 -16
- data/config/locales/sk.yml +2 -16
- data/config/locales/sr-CS.yml +0 -11
- data/config/locales/sv.yml +5 -16
- data/config/locales/tr-TR.yml +64 -15
- data/config/locales/uk.yml +5 -13
- data/config/locales/zh-CN.yml +1 -16
- data/config/routes.rb +9 -4
- data/db/migrate/20170713131206_add_admin_to_users.rb +1 -1
- data/db/migrate/20180206143340_fix_reference_for_all_resources.rb +2 -0
- data/db/migrate/20180314085339_rename_maximum_votes_per_proposal_to_threshold_per_proposal.rb +2 -2
- data/db/migrate/20200929171508_remove_show_statistics_from_organizations.rb +7 -0
- data/db/migrate/20201010124755_create_decidim_user_moderations.rb +12 -0
- data/db/migrate/20201010124756_create_decidim_user_reports.rb +16 -0
- data/db/migrate/20201010224433_add_suspension_fields_to_decidim_users.rb +8 -0
- data/db/migrate/20201011074641_create_decidim_user_suspensions.rb +14 -0
- data/db/migrate/20201011081626_add_current_suspension_id_to_decidim_users.rb +7 -0
- data/db/migrate/20201013071533_add_reported_content_to_moderations.rb +7 -0
- data/db/migrate/20201019074554_add_locale_to_moderation_reports.rb +7 -0
- data/db/migrate/20201127114444_encrypt_authorization_metadatas.rb +35 -0
- data/db/migrate/20201128130723_add_allow_public_access_to_static_pages.rb +17 -0
- data/db/migrate/20201218144706_update_table_block_user_functionality.rb +8 -0
- data/db/migrate/20201218145252_rename_decidim_user_fields_for_block_functionality.rb +9 -0
- data/db/migrate/20210208134328_add_email_on_moderations_to_users.rb +7 -0
- data/db/migrate/20210302150803_invalidate_all_sessions_for_deleted_users.rb +11 -0
- data/db/migrate/20210310120640_add_followable_counter_cache_to_users.rb +16 -0
- data/db/seeds.rb +14 -13
- data/lib/decidim/amendable.rb +3 -2
- data/{app/functions/decidim/core → lib/decidim/api/functions}/component_finder_base.rb +1 -1
- data/{app/functions/decidim/core → lib/decidim/api/functions}/component_list.rb +4 -4
- data/{app/functions/decidim/core → lib/decidim/api/functions}/component_list_base.rb +3 -1
- data/lib/decidim/api/functions/needs_api_default_order.rb +24 -0
- data/{app/functions/decidim/core → lib/decidim/api/functions}/needs_api_filter_and_order.rb +0 -0
- data/{app/functions/decidim/core → lib/decidim/api/functions}/participatory_space_finder_base.rb +2 -2
- data/{app/functions/decidim/core → lib/decidim/api/functions}/participatory_space_list_base.rb +3 -1
- data/{app/functions/decidim/core → lib/decidim/api/functions}/user_entity_finder.rb +1 -4
- data/{app/functions/decidim/core → lib/decidim/api/functions}/user_entity_list.rb +1 -3
- data/{app/types/decidim/core → lib/decidim/api/input_filters}/base_input_filter.rb +0 -0
- data/{app/types/decidim/core → lib/decidim/api/input_filters}/component_input_filter.rb +20 -22
- data/{app/types/decidim/core → lib/decidim/api/input_filters}/has_hastaggable_input_filter.rb +1 -1
- data/{app/types/decidim/core → lib/decidim/api/input_filters}/has_localized_input_filter.rb +3 -3
- data/{app/types/decidim/core → lib/decidim/api/input_filters}/has_publishable_input_filter.rb +6 -6
- data/{app/types/decidim/core → lib/decidim/api/input_filters}/has_timestamp_input_filter.rb +12 -12
- data/{app/types/decidim/core → lib/decidim/api/input_filters}/participatory_space_input_filter.rb +0 -1
- data/lib/decidim/api/input_filters/user_entity_input_filter.rb +89 -0
- data/{app/types/decidim/core → lib/decidim/api/input_sorts}/base_input_sort.rb +3 -2
- data/{app/types/decidim/core → lib/decidim/api/input_sorts}/component_input_sort.rb +10 -11
- data/{app/types/decidim/core → lib/decidim/api/input_sorts}/has_endorsable_input_sort.rb +2 -4
- data/{app/types/decidim/core → lib/decidim/api/input_sorts}/has_localized_input_sort.rb +3 -3
- data/{app/types/decidim/core → lib/decidim/api/input_sorts}/has_publishable_input_sort.rb +1 -1
- data/lib/decidim/api/input_sorts/has_timestamp_input_sort.rb +12 -0
- data/{app/types/decidim/core → lib/decidim/api/input_sorts}/participatory_space_input_sort.rb +1 -1
- data/{app/types/decidim/core → lib/decidim/api/input_sorts}/user_entity_input_sort.rb +4 -4
- data/lib/decidim/api/{amendable_entity_interface.rb → interfaces/amendable_entity_interface.rb} +5 -5
- data/lib/decidim/api/interfaces/amendable_interface.rb +17 -0
- data/lib/decidim/api/{attachable_interface.rb → interfaces/attachable_interface.rb} +3 -3
- data/lib/decidim/api/interfaces/author_interface.rb +32 -0
- data/lib/decidim/api/interfaces/authorable_interface.rb +23 -0
- data/lib/decidim/api/{categorizable_interface.rb → interfaces/categorizable_interface.rb} +3 -3
- data/lib/decidim/api/interfaces/coauthorable_interface.rb +30 -0
- data/lib/decidim/api/interfaces/component_interface.rb +22 -0
- data/lib/decidim/api/interfaces/endorsable_interface.rb +19 -0
- data/lib/decidim/api/{fingerprint_interface.rb → interfaces/fingerprint_interface.rb} +3 -3
- data/lib/decidim/api/interfaces/participatory_space_interface.rb +48 -0
- data/lib/decidim/api/interfaces/participatory_space_resourceable_interface.rb +25 -0
- data/lib/decidim/api/{scopable_interface.rb → interfaces/scopable_interface.rb} +3 -3
- data/lib/decidim/api/interfaces/timestamps_interface.rb +15 -0
- data/lib/decidim/api/interfaces/traceable_interface.rb +14 -0
- data/lib/decidim/api/scalars/date_time_type.rb +17 -0
- data/lib/decidim/api/scalars/date_type.rb +17 -0
- data/lib/decidim/api/types/amendment_type.rb +19 -0
- data/lib/decidim/api/types/area_api_type.rb +16 -0
- data/lib/decidim/api/types/area_type_type.rb +13 -0
- data/lib/decidim/api/types/attachment_type.rb +13 -0
- data/lib/decidim/api/types/category_type.rb +14 -0
- data/{app/types/decidim/core → lib/decidim/api/types}/component_type.rb +2 -4
- data/lib/decidim/api/types/coordinates_type.rb +21 -0
- data/lib/decidim/api/types/decidim_type.rb +13 -0
- data/lib/decidim/api/types/fingerprint_type.rb +12 -0
- data/lib/decidim/api/types/hashtag_type.rb +13 -0
- data/lib/decidim/api/types/localized_string_type.rb +13 -0
- data/lib/decidim/api/types/metric_history_type.rb +18 -0
- data/lib/decidim/api/types/metric_type.rb +13 -0
- data/lib/decidim/api/types/organization_type.rb +17 -0
- data/lib/decidim/api/types/participatory_space_link_type.rb +22 -0
- data/lib/decidim/api/types/participatory_space_type.rb +10 -0
- data/lib/decidim/api/types/scope_api_type.rb +16 -0
- data/lib/decidim/api/types/session_type.rb +22 -0
- data/lib/decidim/api/types/statistic_type.rb +20 -0
- data/lib/decidim/api/types/trace_version_type.rb +21 -0
- data/lib/decidim/api/types/translated_field_type.rb +36 -0
- data/lib/decidim/api/types/user_group_type.rb +64 -0
- data/lib/decidim/api/types/user_type.rb +67 -0
- data/lib/decidim/attachment_attributes.rb +57 -0
- data/lib/decidim/attribute_encryptor.rb +9 -1
- data/lib/decidim/attributes.rb +1 -0
- data/lib/decidim/attributes/clean_string.rb +37 -0
- data/lib/decidim/coauthorable.rb +3 -3
- data/lib/decidim/component_manifest.rb +17 -0
- data/lib/decidim/content_block_manifest.rb +1 -1
- data/lib/decidim/content_parsers/hashtag_parser.rb +3 -6
- data/lib/decidim/content_parsers/user_group_parser.rb +2 -5
- data/lib/decidim/content_parsers/user_parser.rb +2 -5
- data/lib/decidim/content_processor.rb +1 -1
- data/lib/decidim/content_renderers/hashtag_renderer.rb +3 -6
- data/lib/decidim/core.rb +11 -3
- data/lib/decidim/core/api.rb +71 -16
- data/lib/decidim/core/engine.rb +35 -6
- data/lib/decidim/core/test.rb +2 -1
- data/lib/decidim/core/test/factories.rb +53 -15
- data/lib/decidim/core/test/shared_examples/admin_resource_gallery_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/amendable/amendment_accepted_event_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/amendable/amendment_promoted_event_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/amendable/amendment_rejected_event_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/categorizable_interface_examples.rb +14 -6
- data/lib/decidim/core/test/shared_examples/comments_examples.rb +11 -9
- data/lib/decidim/core/test/shared_examples/component_type.rb +1 -1
- data/lib/decidim/core/test/shared_examples/controller_render_views.rb +28 -0
- data/lib/decidim/core/test/shared_examples/follows_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/localised_email.rb +8 -0
- data/lib/decidim/core/test/shared_examples/logo_email.rb +1 -1
- data/lib/decidim/core/test/shared_examples/map_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/process_announcements_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/reportable.rb +8 -0
- data/lib/decidim/core/test/shared_examples/rich_text_editor_examples.rb +1 -1
- data/lib/decidim/core/test/shared_examples/searchable_participatory_space_examples.rb +2 -3
- data/lib/decidim/core/test/shared_examples/searchable_results_examples.rb +46 -0
- data/lib/decidim/core/test/shared_examples/static_pages_examples.rb +43 -0
- data/lib/decidim/core/version.rb +1 -1
- data/lib/decidim/diffy_extension.rb +2 -2
- data/lib/decidim/exporters/csv.rb +3 -2
- data/lib/decidim/exporters/export_data.rb +1 -1
- data/lib/decidim/faker/internet.rb +17 -0
- data/lib/decidim/faker/localized.rb +43 -20
- data/lib/decidim/file_validator_humanizer.rb +6 -4
- data/lib/decidim/followable.rb +6 -1
- data/lib/decidim/form_builder.rb +33 -22
- data/lib/decidim/gamification/badge_scorer.rb +3 -2
- data/lib/decidim/gamification/base_event.rb +2 -2
- data/lib/decidim/geocodable.rb +2 -0
- data/lib/decidim/has_category.rb +1 -1
- data/lib/decidim/has_private_users.rb +1 -1
- data/lib/decidim/importers/import_manifest.rb +36 -0
- data/lib/decidim/map/autocomplete.rb +11 -1
- data/lib/decidim/metric_operation.rb +5 -6
- data/lib/decidim/participatory_space_resourceable.rb +1 -3
- data/lib/decidim/query_extensions.rb +90 -69
- data/lib/decidim/randomable.rb +6 -1
- data/lib/decidim/record_encryptor.rb +149 -0
- data/lib/decidim/reportable.rb +26 -0
- data/lib/decidim/resource_manifest.rb +3 -0
- data/lib/decidim/resourceable.rb +6 -6
- data/lib/decidim/scopable.rb +1 -1
- data/lib/decidim/search_resource_fields_mapper.rb +1 -1
- data/lib/decidim/searchable.rb +9 -0
- data/lib/decidim/settings_manifest.rb +2 -1
- data/lib/decidim/shareable_with_token.rb +0 -1
- data/lib/decidim/translatable_attributes.rb +2 -1
- data/lib/decidim/translatable_resource.rb +10 -0
- data/lib/decidim/user_reportable.rb +33 -0
- data/lib/decidim/view_model.rb +26 -0
- data/lib/premailer/adapter/decidim.rb +4 -4
- data/lib/tasks/decidim_data_portability_tasks.rake +4 -4
- data/vendor/assets/javascripts/datepicker-locales/foundation-datepicker.ko.js +18 -0
- data/vendor/assets/javascripts/datepicker-locales/foundation-datepicker.vi.js +14 -0
- data/vendor/assets/javascripts/datepicker-locales/foundation-datepicker.zh-CN.js +14 -0
- data/vendor/assets/javascripts/datepicker-locales/foundation-datepicker.zh-TW.js +14 -0
- metadata +193 -100
- data/app/functions/decidim/core/participatory_space_finder.rb +0 -11
- data/app/functions/decidim/core/participatory_space_list.rb +0 -11
- data/app/types/decidim/core/amendment_type.rb +0 -26
- data/app/types/decidim/core/area_api_type.rb +0 -16
- data/app/types/decidim/core/area_type_type.rb +0 -14
- data/app/types/decidim/core/attachment_type.rb +0 -14
- data/app/types/decidim/core/category_type.rb +0 -16
- data/app/types/decidim/core/coordinates_type.rb +0 -19
- data/app/types/decidim/core/date_time_type.rb +0 -12
- data/app/types/decidim/core/date_type.rb +0 -13
- data/app/types/decidim/core/decidim_type.rb +0 -19
- data/app/types/decidim/core/fingerprint_type.rb +0 -15
- data/app/types/decidim/core/has_timestamp_input_sort.rb +0 -12
- data/app/types/decidim/core/hashtag_type.rb +0 -13
- data/app/types/decidim/core/localized_string_type.rb +0 -14
- data/app/types/decidim/core/metric_history_type.rb +0 -17
- data/app/types/decidim/core/metric_type.rb +0 -14
- data/app/types/decidim/core/organization_type.rb +0 -20
- data/app/types/decidim/core/participatory_space_link_type.rb +0 -24
- data/app/types/decidim/core/participatory_space_type.rb +0 -12
- data/app/types/decidim/core/scope_api_type.rb +0 -16
- data/app/types/decidim/core/session_type.rb +0 -19
- data/app/types/decidim/core/statistic_type.rb +0 -22
- data/app/types/decidim/core/trace_version_type.rb +0 -29
- data/app/types/decidim/core/translated_field_type.rb +0 -45
- data/app/types/decidim/core/user_entity_input_filter.rb +0 -81
- data/app/types/decidim/core/user_group_type.rb +0 -51
- data/app/types/decidim/core/user_type.rb +0 -52
- data/app/views/decidim/shared/_announcement.html.erb +0 -1
- data/app/views/decidim/shared/_flag_modal.html.erb +0 -20
- data/lib/decidim/api/amendable_interface.rb +0 -18
- data/lib/decidim/api/author_interface.rb +0 -29
- data/lib/decidim/api/authorable_interface.rb +0 -22
- data/lib/decidim/api/coauthorable_interface.rb +0 -29
- data/lib/decidim/api/component_interface.rb +0 -20
- data/lib/decidim/api/endorsable_interface.rb +0 -22
- data/lib/decidim/api/participatory_space_interface.rb +0 -47
- data/lib/decidim/api/participatory_space_resourceable_interface.rb +0 -21
- data/lib/decidim/api/timestamps_interface.rb +0 -21
- data/lib/decidim/api/traceable_interface.rb +0 -14
- data/lib/decidim/core/test/shared_examples/user_localised_email_examples.rb +0 -25
@@ -4,7 +4,7 @@
|
|
4
4
|
<%= icon "chevron-left", role: "img" %>
|
5
5
|
<% end %>
|
6
6
|
</div>
|
7
|
-
<%= link_to
|
7
|
+
<%= link_to profile_path(user.nickname) do %>
|
8
8
|
<%= image_tag conversation_avatar, alt: t("decidim.author.avatar") %>
|
9
9
|
<% end %>
|
10
10
|
|
@@ -32,7 +32,7 @@ module Decidim
|
|
32
32
|
end
|
33
33
|
|
34
34
|
def conversation_interlocutors(conversation)
|
35
|
-
return username_list(conversation.interlocutors(user), true) unless conversation.interlocutors(user).count == 1
|
35
|
+
return username_list(conversation.interlocutors(user), shorten: true) unless conversation.interlocutors(user).count == 1
|
36
36
|
|
37
37
|
"#{conversation.interlocutors(user).first.name} <span class=\"muted\">@#{conversation.interlocutors(user).first.nickname}</span>"
|
38
38
|
end
|
@@ -16,6 +16,10 @@ module Decidim
|
|
16
16
|
)
|
17
17
|
end
|
18
18
|
|
19
|
+
def delete_attachment(attachment)
|
20
|
+
Attachment.find(attachment.id).delete if attachment.id == proposal.documents.first.id
|
21
|
+
end
|
22
|
+
|
19
23
|
def attachment_invalid?
|
20
24
|
if attachment.invalid? && attachment.errors.has_key?(:file)
|
21
25
|
@form.attachment.errors.add :file, attachment.errors[:file]
|
@@ -43,5 +47,9 @@ module Decidim
|
|
43
47
|
def process_attachments?
|
44
48
|
attachments_allowed? && attachment_present? && attachment_file_uploaded?
|
45
49
|
end
|
50
|
+
|
51
|
+
def delete_attachment?
|
52
|
+
@form.attachment&.delete_file.present?
|
53
|
+
end
|
46
54
|
end
|
47
55
|
end
|
@@ -25,6 +25,7 @@ module Decidim
|
|
25
25
|
|
26
26
|
transaction do
|
27
27
|
find_or_create_moderation!
|
28
|
+
update_reported_content!
|
28
29
|
create_report!
|
29
30
|
update_report_count!
|
30
31
|
end
|
@@ -47,12 +48,17 @@ module Decidim
|
|
47
48
|
@moderation = Moderation.find_or_create_by!(reportable: @reportable, participatory_space: participatory_space)
|
48
49
|
end
|
49
50
|
|
51
|
+
def update_reported_content!
|
52
|
+
@moderation.update!(reported_content: @reportable.reported_searchable_content_text)
|
53
|
+
end
|
54
|
+
|
50
55
|
def create_report!
|
51
56
|
@report = Report.create!(
|
52
57
|
moderation: @moderation,
|
53
58
|
user: @current_user,
|
54
59
|
reason: form.reason,
|
55
|
-
details: form.details
|
60
|
+
details: form.details,
|
61
|
+
locale: I18n.locale
|
56
62
|
)
|
57
63
|
end
|
58
64
|
|
@@ -66,6 +72,8 @@ module Decidim
|
|
66
72
|
|
67
73
|
def send_report_notification_to_moderators
|
68
74
|
participatory_space_moderators.each do |moderator|
|
75
|
+
next unless moderator.email_on_moderations
|
76
|
+
|
69
77
|
ReportedMailer.report(moderator, @report).deliver_later
|
70
78
|
end
|
71
79
|
end
|
@@ -80,6 +88,8 @@ module Decidim
|
|
80
88
|
|
81
89
|
def send_hide_notification_to_moderators
|
82
90
|
participatory_space_moderators.each do |moderator|
|
91
|
+
next unless moderator.email_on_moderations
|
92
|
+
|
83
93
|
ReportedMailer.hide(moderator, @report).deliver_later
|
84
94
|
end
|
85
95
|
end
|
@@ -0,0 +1,67 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Decidim
|
4
|
+
# A command with all the business logic when a user creates a report.
|
5
|
+
class CreateUserReport < Rectify::Command
|
6
|
+
# Public: Initializes the command.
|
7
|
+
#
|
8
|
+
# form - A form object with the params.
|
9
|
+
# reportable - The resource being reported
|
10
|
+
# current_user - The current user.
|
11
|
+
def initialize(form, reportable, current_user)
|
12
|
+
@form = form
|
13
|
+
@reportable = reportable
|
14
|
+
@current_user = current_user
|
15
|
+
end
|
16
|
+
|
17
|
+
# Executes the command. Broadcasts these events:
|
18
|
+
#
|
19
|
+
# - :ok when everything is valid, together with the report.
|
20
|
+
# - :invalid if the form wasn't valid and we couldn't proceed.
|
21
|
+
#
|
22
|
+
# Returns nothing.
|
23
|
+
def call
|
24
|
+
return broadcast(:invalid) if form.invalid?
|
25
|
+
|
26
|
+
transaction do
|
27
|
+
find_or_create_moderation!
|
28
|
+
create_report!
|
29
|
+
update_report_count!
|
30
|
+
send_notification_to_admins!
|
31
|
+
end
|
32
|
+
|
33
|
+
broadcast(:ok, report)
|
34
|
+
end
|
35
|
+
|
36
|
+
private
|
37
|
+
|
38
|
+
attr_reader :form, :report
|
39
|
+
|
40
|
+
def find_or_create_moderation!
|
41
|
+
@moderation = UserModeration.find_or_create_by!(user: @reportable)
|
42
|
+
end
|
43
|
+
|
44
|
+
def create_report!
|
45
|
+
@report = UserReport.create!(
|
46
|
+
moderation: @moderation,
|
47
|
+
user: @current_user,
|
48
|
+
reason: form.reason,
|
49
|
+
details: form.details
|
50
|
+
)
|
51
|
+
end
|
52
|
+
|
53
|
+
def update_report_count!
|
54
|
+
@moderation.update!(report_count: @moderation.report_count + 1)
|
55
|
+
end
|
56
|
+
|
57
|
+
def send_notification_to_admins!
|
58
|
+
current_organization.admins.each do |admin|
|
59
|
+
Decidim::UserReportJob.perform_later(admin, current_user, form.reason, reportable)
|
60
|
+
end
|
61
|
+
end
|
62
|
+
|
63
|
+
def hideable?
|
64
|
+
false
|
65
|
+
end
|
66
|
+
end
|
67
|
+
end
|
@@ -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
|
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
|
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 |
|
20
|
-
if
|
21
|
-
|
22
|
-
|
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 |
|
30
|
-
|
31
|
-
|
32
|
-
@form.documents <<
|
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 |
|
38
|
-
|
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(
|
86
|
-
|
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
|
@@ -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
|
-
|
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
|
-
|
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(
|
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 ||=
|
32
|
+
@random_seed ||= begin
|
33
|
+
session[:random_seed] ||= rand * 2 - 1
|
34
|
+
end.to_f
|
33
35
|
end
|
34
36
|
end
|
35
37
|
end
|
@@ -18,7 +18,14 @@ module Decidim
|
|
18
18
|
end
|
19
19
|
|
20
20
|
def per_page
|
21
|
-
params[:per_page]
|
21
|
+
if OPTIONS.include?(params[:per_page])
|
22
|
+
params[:per_page]
|
23
|
+
elsif params[:per_page]
|
24
|
+
sorted = OPTIONS.sort
|
25
|
+
params[:per_page].to_i.clamp(sorted.first, sorted.last)
|
26
|
+
else
|
27
|
+
OPTIONS.first
|
28
|
+
end
|
22
29
|
end
|
23
30
|
|
24
31
|
def page_offset
|
@@ -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
|