decidim-system 0.31.3 → 0.31.4

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.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: f6ededb8553c40e2cd1b418c798ea8d84bb6718ffeb4383079b0ae3b78844fde
4
- data.tar.gz: 7cfaeb907e7403de4ff432cccca19669770eae539c0484ea3e2d4f04d38c94a1
3
+ metadata.gz: 1945d6b48f72e942d86b1f51b6b32b2b25052f6a953861a891f6fa1fb56714e6
4
+ data.tar.gz: 58f2bc5a79edd914b97328d4800c6beac7bb7c77ab179fccb865dba7154d4906
5
5
  SHA512:
6
- metadata.gz: 8ca3f2e0d6b3f2afd74b5eeb5013f85c6690eca772c6300122b1cef341ebfb47a33b12bad569e6ce46ce6a820fb41e24d9f3b1f23705b539a0bafddafd4d1b4b
7
- data.tar.gz: 3f40191955185219fd99ac575ffefaf39ca9a7a912559bfab38d57dad42ac29581772d7f67f3ec8afd1b1a3abb33bf0d83cdd4ef1ad1bca719c6258726bcf23c
6
+ metadata.gz: 0430ef7bbce0ea11a70bcc205552a50e3cfba6bb740117808d6c2972bec9cbc3f633c6d98e096a6711919828dacd1474335c8933ea2aa893042c26b82b6fa1a8
7
+ data.tar.gz: 753edc545e2d65e897ab210515f0f7e066c46cec4be1bf18a2f95dc9ac1815e62765d63468a8036dcb4cfca508c96682e29a2cffdd98a9a7e56c12be47b3290f
@@ -65,6 +65,8 @@ module Decidim
65
65
  validate :validate_short_name_uniqueness
66
66
  validate :validate_short_name_format
67
67
  validate :validate_secret_key_base_for_encryption
68
+ validate :validate_host_format
69
+ validate :validate_secondary_hosts_format
68
70
 
69
71
  def map_model(model)
70
72
  self.default_locale = model.default_locale
@@ -134,6 +136,63 @@ module Decidim
134
136
  def validate_short_name_format
135
137
  raise "#{self.class.name} is expected to implement #validate_short_name_format"
136
138
  end
139
+
140
+ # Validates the host format for organization domains.
141
+ #
142
+ # Valid formats:
143
+ # - Fully Qualified Domain Names (FQDN): example.org, sub.example.org, my-site.example.org
144
+ # - Localhost: localhost (common for development)
145
+ # - IPv4 addresses: 127.0.0.1, 192.168.1.1
146
+ # - IPv6 addresses: ::1, 2001:db8::1, [::1]
147
+ #
148
+ # Invalid formats (will be rejected):
149
+ # - Hosts containing spaces
150
+ # - Hosts with invalid characters (!@#$%^&* etc.)
151
+ # - Hosts with leading/trailing hyphens in labels (e.g., -example.com or example-.com)
152
+ # - Labels longer than 63 characters
153
+ # - Total host length exceeding 253 characters
154
+ #
155
+ # @see https://en.wikipedia.org/wiki/Fully_qualified_domain_name
156
+ # @see https://en.wikipedia.org/wiki/IPv4_address
157
+ # @see https://en.wikipedia.org/wiki/IPv6_address
158
+ #
159
+ HOST_FORMAT_REGEX = %r{
160
+ \A
161
+ (?:
162
+ # FQDN: requires at least one dot, labels separated by dots.
163
+ # Each label: alphanumeric start/end, alphanumerics and hyphens inside, max 63 chars.
164
+ (?:[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?\.)+[a-z]{2,}
165
+ |
166
+ # Localhost: common development hostname.
167
+ localhost
168
+ |
169
+ # IPv4: four octets (0-255 each).
170
+ (?:(?:25[0-5]|2[0-4]\d|1\d{2}|[1-9]?\d)\.){3}(?:25[0-5]|2[0-4]\d|1\d{2}|[1-9]?\d)
171
+ |
172
+ # IPv6: bracketed form [::1] or unbracketed (standard and compressed forms).
173
+ (?:\[[\da-fA-F:]+\]|[\da-fA-F:]+\z)
174
+ )
175
+ \z
176
+ }x
177
+
178
+ def validate_host_format
179
+ return if host.blank?
180
+
181
+ return if host.match?(HOST_FORMAT_REGEX)
182
+
183
+ errors.add(:host, :invalid)
184
+ end
185
+
186
+ def validate_secondary_hosts_format
187
+ return if secondary_hosts.blank?
188
+
189
+ clean_secondary_hosts.each do |secondary_host|
190
+ next if secondary_host.match?(HOST_FORMAT_REGEX)
191
+
192
+ errors.add(:secondary_hosts, :invalid)
193
+ break
194
+ end
195
+ end
137
196
  end
138
197
  end
139
198
  end
@@ -37,8 +37,12 @@ ca-IT:
37
37
  must_be_ssl: L'URI de redirecció ha de ser una URI SSL
38
38
  organization:
39
39
  attributes:
40
+ host:
41
+ invalid: no és vàlid
40
42
  password:
41
43
  secret_key: Cal que defineixis la variable d'entorn SECRET_KEY_BASE per a poder guardar aquest camp
44
+ secondary_hosts:
45
+ invalid: no és vàlid
42
46
  decidim:
43
47
  system:
44
48
  actions:
@@ -3,7 +3,7 @@ ca:
3
3
  activemodel:
4
4
  attributes:
5
5
  oauth_application:
6
- name: Nom de l'aplicació OAuth
6
+ name: Nom de l'aplicació
7
7
  organization_logo: Logo de l'organització (quadrat)
8
8
  organization_name: Organització
9
9
  organization_url: URL de l'organització
@@ -37,8 +37,12 @@ ca:
37
37
  must_be_ssl: L'URI de redirecció ha de ser una URI SSL
38
38
  organization:
39
39
  attributes:
40
+ host:
41
+ invalid: no és vàlid
40
42
  password:
41
43
  secret_key: Cal que defineixis la variable d'entorn SECRET_KEY_BASE per a poder guardar aquest camp
44
+ secondary_hosts:
45
+ invalid: no és vàlid
42
46
  decidim:
43
47
  system:
44
48
  actions:
@@ -295,7 +299,7 @@ ca:
295
299
  organization_admin_email_hint: T'enviarem un correu electrònic a aquesta adreça perquè puguis confirmar-la i configurar la teva contrasenya.
296
300
  reference_prefix_hint: El prefix de la referència s'utilitza per identificar de forma única els recursos del conjunt de l'organització.
297
301
  secondary_hosts_hint: Introdueix cada un d'ells en una nova línia.
298
- 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.
302
+ 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.
299
303
  title: Nova organització
300
304
  omniauth_settings:
301
305
  decidim:
@@ -37,8 +37,12 @@ cs:
37
37
  must_be_ssl: URI přesměrování musí být SSL URI
38
38
  organization:
39
39
  attributes:
40
+ host:
41
+ invalid: je neplatný
40
42
  password:
41
43
  secret_key: Abyste mohli toto pole uložit, musíte definovat proměnnou prostředí SECRET_KEY_BASE.
44
+ secondary_hosts:
45
+ invalid: je neplatný
42
46
  decidim:
43
47
  system:
44
48
  actions:
@@ -53,6 +57,7 @@ cs:
53
57
  remove: Odebrat uživatele
54
58
  confirm_destroy: Opravdu to chcete smazat?
55
59
  confirm_refresh_api_secret: Opravdu chcete obnovit tajný klíč pro tohoto uživatele API? Po obnově bude starý tajný klíč neplatný a již nemůže být použit.
60
+ confirm_remove_api_user: Opravdu chcete odstranit tohoto uživatele API?
56
61
  copied: Zkopírováno
57
62
  copy_secret: Kopírovat tajný klíč
58
63
  copy_secret_clarification: Zkopírovat tajný klíč do schránky
@@ -92,6 +97,10 @@ cs:
92
97
  success: Tajný klíč byl úspěšně obnoven. Tajný klíč pro uživatele je viditelný pouze po vytvoření. Zkopírujte jej a uložte jej bezpečně před opuštěním této stránky!
93
98
  api_users:
94
99
  index:
100
+ explanation_html: |
101
+ <p>Uživatelé API umožňují integračním vývojářům přidávat do systému účty pro administrátorské uživatele. Tito uživatelé mohou působit jako správci na platformě pro provádění aktualizací, které by běžní správci prováděli prostřednictvím administrátorského panelu. Typickým případem použití je vnější platforma řízení, kde by automatizovaný skript prováděl administrativní úkoly s platformou, aniž by se skutečný uživatel musel přihlásit do systému. Například systém automatizace může chtít poslat odpovědi na návrhy, v kterémžto případě potřebujeme, aby integrovaný uživatel provedl tento úkol v rámci této platformy.</p>
102
+ <p>Hlavní rozdíl mezi těmito účty a běžnými účty správce spočívá v tom, že tito uživatelé jsou určeni k používání na strojích, a proto se jejich požadavky na heslo liší. Tito uživatelé nemusí pravidelně aktualizovat své heslo a v případě potřeby může dojít ke změně hesla k účtu řízeným způsobem.</p>
103
+ <p>Tyto přihlašovací údaje jsou určeny pro použití stroji. Účastnické aplikace by měly být integrovány s <a href="%{oauth_link}">OAuth aplikacemi</a>.</p>
95
104
  manage: Správa uživatelů API
96
105
  new:
97
106
  select_organization: Vyberte vaši organizaci
@@ -175,7 +184,9 @@ cs:
175
184
  explanation: Aplikace, které se mohou bezpečně autentizovat s autorizačním serverem, například udržovat registrované klienty zabezpečené. Obvykle aplikace běžící na serveru, kde je uložen tajný kód klienta.
176
185
  name: Důvěrné
177
186
  public:
187
+ explanation: Aplikace, které nemohou používat registrované zákaznické tajemství, jako jsou aplikace běžící v prohlížeči nebo na mobilním zařízení.
178
188
  name: Veřejné
189
+ application_type_help_html: 'Typ OAuth klienta definovaný <a href="%{client_type_link}" target="_blank">RFC 6749 Oddíl 2.1</a>. Veřejní klienti musí realizovat tok PKCE definovaný <a href="%{pkce_link}" target="_blank">RFC 7636</a>. '
179
190
  select_organization: Vybrat organizaci
180
191
  index:
181
192
  confirm_delete: Jste si jisti, že chcete odstranit tuto žádost?
@@ -246,6 +257,7 @@ cs:
246
257
  confirm_resend_invitation: Opravdu chcete znovu odeslat pozvánku?
247
258
  resend_invitation: Znovu odeslat pozvánku
248
259
  secondary_hosts_hint: Zadejte každý z nich do nového řádku
260
+ short_name_hint: Krátký název použitý pro progresivní webovou aplikaci. Musí mít maximálně 12 znaků.
249
261
  title: Upravit organizaci
250
262
  file_upload_settings:
251
263
  content_types:
@@ -37,8 +37,12 @@ en:
37
37
  must_be_ssl: The redirect URI must be a SSL URI
38
38
  organization:
39
39
  attributes:
40
+ host:
41
+ invalid: is invalid
40
42
  password:
41
43
  secret_key: You need to define the SECRET_KEY_BASE environment variable to be able to save this field
44
+ secondary_hosts:
45
+ invalid: is invalid
42
46
  decidim:
43
47
  system:
44
48
  actions:
@@ -37,8 +37,12 @@ es-MX:
37
37
  must_be_ssl: La URI de redirección debe ser una URI SSL
38
38
  organization:
39
39
  attributes:
40
+ host:
41
+ invalid: no es válido
40
42
  password:
41
43
  secret_key: Necesitas definir la variable de entorno SECRETA_KEY_BASE para poder guardar este campo
44
+ secondary_hosts:
45
+ invalid: no es válido
42
46
  decidim:
43
47
  system:
44
48
  actions:
@@ -37,8 +37,12 @@ es-PY:
37
37
  must_be_ssl: La URI de redirección debe ser una URI SSL
38
38
  organization:
39
39
  attributes:
40
+ host:
41
+ invalid: no es válido
40
42
  password:
41
43
  secret_key: Necesitas definir la variable de entorno SECRETA_KEY_BASE para poder guardar este campo
44
+ secondary_hosts:
45
+ invalid: no es válido
42
46
  decidim:
43
47
  system:
44
48
  actions:
@@ -37,8 +37,12 @@ es:
37
37
  must_be_ssl: La URI de redirección debe ser una URI SSL
38
38
  organization:
39
39
  attributes:
40
+ host:
41
+ invalid: no es válido
40
42
  password:
41
43
  secret_key: Necesitas definir la variable de entorno SECRETA_KEY_BASE para poder guardar este campo
44
+ secondary_hosts:
45
+ invalid: no es válido
42
46
  decidim:
43
47
  system:
44
48
  actions:
@@ -37,8 +37,12 @@ eu:
37
37
  must_be_ssl: Berbideratzeko URIa URI SSL izan behar da
38
38
  organization:
39
39
  attributes:
40
+ host:
41
+ invalid: baliogabea da
40
42
  password:
41
43
  secret_key: SECRET_KEY_BASE ingurunearen aldagaia definitu behar duzu eremu hau gorde ahal izateko
44
+ secondary_hosts:
45
+ invalid: baliogabea da
42
46
  decidim:
43
47
  system:
44
48
  actions:
@@ -37,8 +37,12 @@ fi-pl:
37
37
  must_be_ssl: Uudelleenohjaus osoite (URI) on oltava SSL-muotoinen osoite (URI)
38
38
  organization:
39
39
  attributes:
40
+ host:
41
+ invalid: on virheellinen
40
42
  password:
41
43
  secret_key: Sinun täytyy määritellä SECRET_KEY_BASE ympäristömuuttuja, jotta voit tallentaa tämän kentän.
44
+ secondary_hosts:
45
+ invalid: on virheellinen
42
46
  decidim:
43
47
  system:
44
48
  actions:
@@ -37,8 +37,12 @@ fi:
37
37
  must_be_ssl: Uudelleenohjaus osoite (URI) on oltava SSL-muotoinen osoite (URI)
38
38
  organization:
39
39
  attributes:
40
+ host:
41
+ invalid: on virheellinen
40
42
  password:
41
43
  secret_key: Sinun täytyy määritellä SECRET_KEY_BASE ympäristömuuttuja, jotta voit tallentaa tämän kentän.
44
+ secondary_hosts:
45
+ invalid: on virheellinen
42
46
  decidim:
43
47
  system:
44
48
  actions:
@@ -34,8 +34,12 @@ fr-CA:
34
34
  must_be_ssl: L'URI de redirection doit être une URI SSL
35
35
  organization:
36
36
  attributes:
37
+ host:
38
+ invalid: est invalide
37
39
  password:
38
40
  secret_key: Vous devez définir la variable d'environnement SECRET_KEY_BASE pour pouvoir enregistrer ce champ
41
+ secondary_hosts:
42
+ invalid: est invalide
39
43
  decidim:
40
44
  system:
41
45
  actions:
@@ -34,8 +34,12 @@ fr:
34
34
  must_be_ssl: L'URI de redirection doit être une URI SSL
35
35
  organization:
36
36
  attributes:
37
+ host:
38
+ invalid: est invalide
37
39
  password:
38
40
  secret_key: Vous devez définir la variable d'environnement SECRET_KEY_BASE pour pouvoir enregistrer ce champ
41
+ secondary_hosts:
42
+ invalid: est invalide
39
43
  decidim:
40
44
  system:
41
45
  actions:
@@ -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.3"
7
+ "0.31.4"
8
8
  end
9
9
  end
10
10
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: decidim-system
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.31.3
4
+ version: 0.31.4
5
5
  platform: ruby
6
6
  authors:
7
7
  - Josep Jaume Rey Peroy
@@ -10,7 +10,7 @@ authors:
10
10
  autorequire:
11
11
  bindir: bin
12
12
  cert_chain: []
13
- date: 2026-03-26 00:00:00.000000000 Z
13
+ date: 2026-04-24 00:00:00.000000000 Z
14
14
  dependencies:
15
15
  - !ruby/object:Gem::Dependency
16
16
  name: active_link_to
@@ -32,14 +32,14 @@ dependencies:
32
32
  requirements:
33
33
  - - '='
34
34
  - !ruby/object:Gem::Version
35
- version: 0.31.3
35
+ version: 0.31.4
36
36
  type: :runtime
37
37
  prerelease: false
38
38
  version_requirements: !ruby/object:Gem::Requirement
39
39
  requirements:
40
40
  - - '='
41
41
  - !ruby/object:Gem::Version
42
- version: 0.31.3
42
+ version: 0.31.4
43
43
  - !ruby/object:Gem::Dependency
44
44
  name: devise
45
45
  requirement: !ruby/object:Gem::Requirement
@@ -94,14 +94,14 @@ dependencies:
94
94
  requirements:
95
95
  - - '='
96
96
  - !ruby/object:Gem::Version
97
- version: 0.31.3
97
+ version: 0.31.4
98
98
  type: :development
99
99
  prerelease: false
100
100
  version_requirements: !ruby/object:Gem::Requirement
101
101
  requirements:
102
102
  - - '='
103
103
  - !ruby/object:Gem::Version
104
- version: 0.31.3
104
+ version: 0.31.4
105
105
  description: System administration to create new organization in an installation.
106
106
  email:
107
107
  - josepjaume@gmail.com