decidim-system 0.31.4 → 0.32.0.rc1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (58) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +2 -14
  3. data/app/controllers/decidim/system/admins_controller.rb +2 -2
  4. data/app/controllers/decidim/system/api_users_controller.rb +4 -4
  5. data/app/controllers/decidim/system/devise/sessions_controller.rb +1 -1
  6. data/app/controllers/decidim/system/oauth_applications_controller.rb +2 -2
  7. data/app/controllers/decidim/system/organizations_controller.rb +3 -3
  8. data/app/forms/decidim/system/register_organization_form.rb +1 -0
  9. data/app/views/decidim/system/organizations/new.html.erb +1 -1
  10. data/config/locales/ar.yml +0 -1
  11. data/config/locales/bg.yml +0 -1
  12. data/config/locales/bs-BA.yml +0 -1
  13. data/config/locales/ca-IT.yml +2 -3
  14. data/config/locales/ca.yml +0 -1
  15. data/config/locales/cs.yml +0 -1
  16. data/config/locales/de.yml +0 -1
  17. data/config/locales/el.yml +0 -1
  18. data/config/locales/eo.yml +0 -1
  19. data/config/locales/es-MX.yml +0 -1
  20. data/config/locales/es-PY.yml +0 -1
  21. data/config/locales/es.yml +0 -1
  22. data/config/locales/eu.yml +0 -1
  23. data/config/locales/fa-IR.yml +0 -1
  24. data/config/locales/fi-plain.yml +0 -1
  25. data/config/locales/fi.yml +0 -1
  26. data/config/locales/fr-CA.yml +0 -1
  27. data/config/locales/fr.yml +0 -1
  28. data/config/locales/ga-IE.yml +0 -1
  29. data/config/locales/gl.yml +0 -1
  30. data/config/locales/hu.yml +0 -1
  31. data/config/locales/id-ID.yml +0 -1
  32. data/config/locales/is-IS.yml +1 -2
  33. data/config/locales/it.yml +0 -1
  34. data/config/locales/ja.yml +0 -1
  35. data/config/locales/kaa.yml +0 -1
  36. data/config/locales/lb.yml +0 -1
  37. data/config/locales/lt.yml +0 -1
  38. data/config/locales/lv.yml +0 -1
  39. data/config/locales/nl.yml +0 -1
  40. data/config/locales/no.yml +0 -1
  41. data/config/locales/pl.yml +0 -1
  42. data/config/locales/pt-BR.yml +0 -1
  43. data/config/locales/pt.yml +0 -1
  44. data/config/locales/ro-RO.yml +0 -1
  45. data/config/locales/ru.yml +0 -1
  46. data/config/locales/sk.yml +0 -1
  47. data/config/locales/sl.yml +0 -1
  48. data/config/locales/sr-CS.yml +0 -1
  49. data/config/locales/sv.yml +0 -1
  50. data/config/locales/tr-TR.yml +0 -1
  51. data/config/locales/uk.yml +0 -1
  52. data/config/locales/zh-CN.yml +0 -1
  53. data/config/locales/zh-TW.yml +0 -1
  54. data/decidim-system.gemspec +6 -9
  55. data/lib/decidim/system/menu.rb +1 -1
  56. data/lib/decidim/system/version.rb +1 -1
  57. data/lib/decidim/system.rb +8 -4
  58. metadata +16 -13
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 1945d6b48f72e942d86b1f51b6b32b2b25052f6a953861a891f6fa1fb56714e6
4
- data.tar.gz: 58f2bc5a79edd914b97328d4800c6beac7bb7c77ab179fccb865dba7154d4906
3
+ metadata.gz: da5cdf4aa1b70b51c9dd6ddfc54b3955b4a6ba33bee1ad89346993527de4b11e
4
+ data.tar.gz: 8f88aeda85929d086bd2021704dafce5279b9fdb58e4a5654eafa29bcdc4ea30
5
5
  SHA512:
6
- metadata.gz: 0430ef7bbce0ea11a70bcc205552a50e3cfba6bb740117808d6c2972bec9cbc3f633c6d98e096a6711919828dacd1474335c8933ea2aa893042c26b82b6fa1a8
7
- data.tar.gz: 753edc545e2d65e897ab210515f0f7e066c46cec4be1bf18a2f95dc9ac1815e62765d63468a8036dcb4cfca508c96682e29a2cffdd98a9a7e56c12be47b3290f
6
+ metadata.gz: c2cb0273741a8ec3ad00816daf2ceafb913ff062c50ad373d72e7f8668f2570e538fb22d9fdb716efea44c04b9eb5493a91e92ff1cefeb919849ef44059308e8
7
+ data.tar.gz: 0ea01b28e31c1241ee54dbf901311de79dfec8df92e23503421790900f00a136f5be6befa0a2f77049d9dfc4d92fafbdbccb57d560256be5006ab7a3989d405d
data/README.md CHANGED
@@ -1,23 +1,11 @@
1
- # Decidim::System
1
+ # decidim-system
2
2
 
3
3
  This engine adds an administration dashboard so admin can manage a Decidim deploy
4
4
  and its organizations when working in a multi-tenant environment.
5
5
 
6
6
  ## Usage
7
7
 
8
- `decidim-system` is already included in the `decidim` gem, but you can also include it separately:
9
-
10
- Add this line to your application's Gemfile:
11
-
12
- ```ruby
13
- gem 'decidim-system'
14
- ```
15
-
16
- And then execute:
17
-
18
- ```bash
19
- bundle
20
- ```
8
+ This is on the default Decidim installation so you should not change anything to use this feature.
21
9
 
22
10
  ## Multi-tenancy in Decidim
23
11
 
@@ -24,7 +24,7 @@ module Decidim
24
24
 
25
25
  on(:invalid) do
26
26
  flash.now[:alert] = I18n.t("admins.create.error", scope: "decidim.system")
27
- render :new, status: :unprocessable_entity
27
+ render :new, status: :unprocessable_content
28
28
  end
29
29
  end
30
30
  end
@@ -46,7 +46,7 @@ module Decidim
46
46
 
47
47
  on(:invalid) do
48
48
  flash.now[:alert] = I18n.t("admins.update.error", scope: "decidim.system")
49
- render :edit, status: :unprocessable_entity
49
+ render :edit, status: :unprocessable_content
50
50
  end
51
51
  end
52
52
  end
@@ -29,7 +29,7 @@ module Decidim
29
29
  RefreshApiUserSecret.call(api_user, current_admin) do
30
30
  on(:ok) do |secret|
31
31
  flash[:notice] = I18n.t("api_user.refresh.success", scope: "decidim.system", user: api_user.api_key)
32
- session[:api_user] = { id: api_user.id, secret: secret }
32
+ session[:api_user] = { id: api_user.id, secret: }
33
33
  redirect_to action: :index
34
34
  end
35
35
 
@@ -41,17 +41,17 @@ module Decidim
41
41
  end
42
42
 
43
43
  def create
44
- @form = ::Decidim::System::ApiUserForm.from_params(params.merge!(name: params[:admin][:name], organization: organization))
44
+ @form = ::Decidim::System::ApiUserForm.from_params(params.merge!(name: params[:admin][:name], organization:))
45
45
  CreateApiUser.call(@form, current_admin) do
46
46
  on(:ok) do |api_user, secret|
47
47
  flash[:notice] = I18n.t("api_user.create.success", scope: "decidim.system", user: api_user.api_key)
48
- session[:api_user] = { id: api_user.id, secret: secret }
48
+ session[:api_user] = { id: api_user.id, secret: }
49
49
  redirect_to action: :index
50
50
  end
51
51
 
52
52
  on(:invalid) do
53
53
  flash[:error] = I18n.t("api_user.create.error", scope: "decidim.system")
54
- render :new, status: :unprocessable_entity
54
+ render :new, status: :unprocessable_content
55
55
  end
56
56
  end
57
57
  end
@@ -18,7 +18,7 @@ module Decidim
18
18
 
19
19
  def redirect_to_referer_or_path
20
20
  set_flash_message(:alert, "csrf_token", scope: "devise.failure")
21
- redirect_back(fallback_location: root_path)
21
+ redirect_back_or_to(root_path)
22
22
  end
23
23
 
24
24
  def current_organization; end
@@ -30,7 +30,7 @@ module Decidim
30
30
 
31
31
  on(:invalid) do
32
32
  flash.now[:alert] = I18n.t("oauth_applications.create.error", scope: "decidim.system")
33
- render :new, status: :unprocessable_entity
33
+ render :new, status: :unprocessable_content
34
34
  end
35
35
  end
36
36
  end
@@ -55,7 +55,7 @@ module Decidim
55
55
  on(:invalid) do |application|
56
56
  @oauth_application = application
57
57
  flash.now[:error] = I18n.t("oauth_applications.update.error", scope: "decidim.system")
58
- render action: :edit, status: :unprocessable_entity
58
+ render action: :edit, status: :unprocessable_content
59
59
  end
60
60
  end
61
61
  end
@@ -24,12 +24,12 @@ module Decidim
24
24
 
25
25
  on(:invalid_invitation) do
26
26
  flash.now[:alert] = t("organizations.create.error_invitation", scope: "decidim.system")
27
- render :new, status: :unprocessable_entity
27
+ render :new, status: :unprocessable_content
28
28
  end
29
29
 
30
30
  on(:invalid) do
31
31
  flash.now[:alert] = t("organizations.create.error", scope: "decidim.system")
32
- render :new, status: :unprocessable_entity
32
+ render :new, status: :unprocessable_content
33
33
  end
34
34
  end
35
35
  end
@@ -55,7 +55,7 @@ module Decidim
55
55
 
56
56
  on(:invalid) do
57
57
  flash.now[:alert] = I18n.t("organizations.update.error", scope: "decidim.system")
58
- render :edit, status: :unprocessable_entity
58
+ render :edit, status: :unprocessable_content
59
59
  end
60
60
  end
61
61
  end
@@ -8,6 +8,7 @@ module Decidim
8
8
  #
9
9
  class RegisterOrganizationForm < BaseOrganizationForm
10
10
  include JsonbAttributes
11
+
11
12
  mimic :organization
12
13
 
13
14
  attribute :name, String
@@ -33,7 +33,7 @@
33
33
  <tbody>
34
34
  <% localized_locales.each do |locale| %>
35
35
  <tr>
36
- <td><%= locale.name %></td>
36
+ <td><%= locale.name %> (<%= locale.id %>)</td>
37
37
  <td><%= check_box_tag "organization[available_locales][#{locale.id}]", locale.id, @form.available_locales.include?(locale.id), class: "!m-0" %></td>
38
38
  <td><%= radio_button_tag "organization[default_locale]", locale.id, @form.default_locale == locale.id, class: "!m-0" %></td>
39
39
  </tr>
@@ -1,4 +1,3 @@
1
- ---
2
1
  ar:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  bg:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  bs:
3
2
  activemodel:
4
3
  attributes:
@@ -1,9 +1,8 @@
1
- ---
2
1
  ca-IT:
3
2
  activemodel:
4
3
  attributes:
5
4
  oauth_application:
6
- name: Nom de l'aplicació OAuth
5
+ name: Nom de l'aplicació
7
6
  organization_logo: Logo de l'organització (quadrat)
8
7
  organization_name: Organització
9
8
  organization_url: URL de l'organització
@@ -299,7 +298,7 @@ ca-IT:
299
298
  organization_admin_email_hint: T'enviarem un correu electrònic a aquesta adreça perquè puguis confirmar-la i configurar la teva contrasenya.
300
299
  reference_prefix_hint: El prefix de la referència s'utilitza per identificar de forma única els recursos del conjunt de l'organització.
301
300
  secondary_hosts_hint: Introdueix cada un d'ells en una nova línia.
302
- short_name_hint: Nom curt que es farà servir per a l'Aplicació Web Progressiva (PWA). Ha de tenir un màxim de 12 caràcters.
301
+ short_name_hint: Nom curt que es farà servir per a l'Aplicació Web Progressiva. Ha de tenir un màxim de 12 caràcters.
303
302
  title: Nova organització
304
303
  omniauth_settings:
305
304
  decidim:
@@ -1,4 +1,3 @@
1
- ---
2
1
  ca:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  cs:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  de:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  el:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  eo:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  es-MX:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  es-PY:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  es:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  eu:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  fa:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  fi-pl:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  fi:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  fr-CA:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  fr:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  ga:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  gl:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  hu:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  id:
3
2
  decidim:
4
3
  system:
@@ -1,5 +1,4 @@
1
- ---
2
- is:
1
+ is-IS:
3
2
  activemodel:
4
3
  attributes:
5
4
  organization:
@@ -1,4 +1,3 @@
1
- ---
2
1
  it:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  ja:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  kaa:
3
2
  decidim:
4
3
  system:
@@ -1,4 +1,3 @@
1
- ---
2
1
  lb:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  lt:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  lv:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  nl:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  "no":
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  pl:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  pt-BR:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  pt:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  ro:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  ru:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  sk:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  sl:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  sr:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  sv:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  tr:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  uk:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  zh-CN:
3
2
  activemodel:
4
3
  attributes:
@@ -1,4 +1,3 @@
1
- ---
2
1
  zh-TW:
3
2
  activemodel:
4
3
  attributes:
@@ -2,12 +2,9 @@
2
2
 
3
3
  $LOAD_PATH.push File.expand_path("lib", __dir__)
4
4
 
5
- # Maintain your gem's version:
6
- require "decidim/system/version"
7
-
8
- # Describe your gem and declare its dependencies:
9
5
  Gem::Specification.new do |s|
10
- s.version = Decidim::System.version
6
+ version = "0.32.0.rc1"
7
+ s.version = version
11
8
  s.authors = ["Josep Jaume Rey Peroy", "Marc Riera Casals", "Oriol Gual Oliva"]
12
9
  s.email = ["josepjaume@gmail.com", "mrc2407@gmail.com", "oriolgual@gmail.com"]
13
10
  s.license = "AGPL-3.0-or-later"
@@ -19,7 +16,7 @@ Gem::Specification.new do |s|
19
16
  "homepage_uri" => "https://decidim.org",
20
17
  "source_code_uri" => "https://github.com/decidim/decidim"
21
18
  }
22
- s.required_ruby_version = "~> 3.3.0"
19
+ s.required_ruby_version = "~> 3.4.0"
23
20
 
24
21
  s.name = "decidim-system"
25
22
  s.summary = "Decidim system administration"
@@ -33,10 +30,10 @@ Gem::Specification.new do |s|
33
30
  end
34
31
 
35
32
  s.add_dependency "active_link_to", "~> 1.0"
36
- s.add_dependency "decidim-core", Decidim::System.version
37
- s.add_dependency "devise", "~> 4.7"
33
+ s.add_dependency "decidim-core", version
34
+ s.add_dependency "devise", ">= 4.7", "< 6.0"
38
35
  s.add_dependency "devise-i18n", "~> 1.2"
39
36
  s.add_dependency "devise_invitable", "~> 2.0", ">= 2.0.9"
40
37
 
41
- s.add_development_dependency "decidim-dev", Decidim::System.version
38
+ s.add_development_dependency "decidim-dev", version
42
39
  end
@@ -9,7 +9,7 @@ module Decidim
9
9
  I18n.t("menu.dashboard", scope: "decidim.system"),
10
10
  decidim_system.root_path,
11
11
  position: 1,
12
- active: ["decidim/system/dashboard" => :show]
12
+ active: [{ "decidim/system/dashboard" => :show }]
13
13
  if Decidim.module_installed?(:api)
14
14
  menu.add_item :api_credentials,
15
15
  I18n.t("menu.api_credentials", scope: "decidim.system"),
@@ -4,7 +4,7 @@ module Decidim
4
4
  # This holds the decidim-system version.
5
5
  module System
6
6
  def self.version
7
- "0.31.4"
7
+ "0.32.0.rc1"
8
8
  end
9
9
  end
10
10
  end
@@ -9,11 +9,15 @@ module Decidim
9
9
  # eye view of the whole system.
10
10
  #
11
11
  module System
12
- include ActiveSupport::Configurable
12
+ class << self
13
+ def config = self
13
14
 
14
- # The length of API secrets generated for API users.
15
- config_accessor :api_users_secret_length do
16
- ENV.fetch("DECIDIM_SYSTEM_API_USERS_SECRET_LENGTH", 32)
15
+ def configure
16
+ yield self
17
+ end
17
18
  end
19
+
20
+ # The length of API secrets generated for API users.
21
+ mattr_accessor :api_users_secret_length, default: ENV.fetch("DECIDIM_SYSTEM_API_USERS_SECRET_LENGTH", 32).to_i
18
22
  end
19
23
  end
metadata CHANGED
@@ -1,16 +1,15 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: decidim-system
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.31.4
4
+ version: 0.32.0.rc1
5
5
  platform: ruby
6
6
  authors:
7
7
  - Josep Jaume Rey Peroy
8
8
  - Marc Riera Casals
9
9
  - Oriol Gual Oliva
10
- autorequire:
11
10
  bindir: bin
12
11
  cert_chain: []
13
- date: 2026-04-24 00:00:00.000000000 Z
12
+ date: 1980-01-02 00:00:00.000000000 Z
14
13
  dependencies:
15
14
  - !ruby/object:Gem::Dependency
16
15
  name: active_link_to
@@ -32,28 +31,34 @@ dependencies:
32
31
  requirements:
33
32
  - - '='
34
33
  - !ruby/object:Gem::Version
35
- version: 0.31.4
34
+ version: 0.32.0.rc1
36
35
  type: :runtime
37
36
  prerelease: false
38
37
  version_requirements: !ruby/object:Gem::Requirement
39
38
  requirements:
40
39
  - - '='
41
40
  - !ruby/object:Gem::Version
42
- version: 0.31.4
41
+ version: 0.32.0.rc1
43
42
  - !ruby/object:Gem::Dependency
44
43
  name: devise
45
44
  requirement: !ruby/object:Gem::Requirement
46
45
  requirements:
47
- - - "~>"
46
+ - - ">="
48
47
  - !ruby/object:Gem::Version
49
48
  version: '4.7'
49
+ - - "<"
50
+ - !ruby/object:Gem::Version
51
+ version: '6.0'
50
52
  type: :runtime
51
53
  prerelease: false
52
54
  version_requirements: !ruby/object:Gem::Requirement
53
55
  requirements:
54
- - - "~>"
56
+ - - ">="
55
57
  - !ruby/object:Gem::Version
56
58
  version: '4.7'
59
+ - - "<"
60
+ - !ruby/object:Gem::Version
61
+ version: '6.0'
57
62
  - !ruby/object:Gem::Dependency
58
63
  name: devise-i18n
59
64
  requirement: !ruby/object:Gem::Requirement
@@ -94,14 +99,14 @@ dependencies:
94
99
  requirements:
95
100
  - - '='
96
101
  - !ruby/object:Gem::Version
97
- version: 0.31.4
102
+ version: 0.32.0.rc1
98
103
  type: :development
99
104
  prerelease: false
100
105
  version_requirements: !ruby/object:Gem::Requirement
101
106
  requirements:
102
107
  - - '='
103
108
  - !ruby/object:Gem::Version
104
- version: 0.31.4
109
+ version: 0.32.0.rc1
105
110
  description: System administration to create new organization in an installation.
106
111
  email:
107
112
  - josepjaume@gmail.com
@@ -294,7 +299,6 @@ metadata:
294
299
  funding_uri: https://opencollective.com/decidim
295
300
  homepage_uri: https://decidim.org
296
301
  source_code_uri: https://github.com/decidim/decidim
297
- post_install_message:
298
302
  rdoc_options: []
299
303
  require_paths:
300
304
  - lib
@@ -302,15 +306,14 @@ required_ruby_version: !ruby/object:Gem::Requirement
302
306
  requirements:
303
307
  - - "~>"
304
308
  - !ruby/object:Gem::Version
305
- version: 3.3.0
309
+ version: 3.4.0
306
310
  required_rubygems_version: !ruby/object:Gem::Requirement
307
311
  requirements:
308
312
  - - ">="
309
313
  - !ruby/object:Gem::Version
310
314
  version: '0'
311
315
  requirements: []
312
- rubygems_version: 3.5.11
313
- signing_key:
316
+ rubygems_version: 3.6.9
314
317
  specification_version: 4
315
318
  summary: Decidim system administration
316
319
  test_files: []