thecore_auth_commons 3.2.3 → 3.3.0

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: d01976e6049e0a9167596a63997019663b04bab90675d7d4e3386517a9f38c93
4
- data.tar.gz: 6a0b3e04d0f92840aff1b4af73df107b98949243500126779d29f201f03a4c0b
3
+ metadata.gz: c8907d856764c6dd40d87e0ed599bc85b55f213dbb25a0b112d0aa90605bfbc4
4
+ data.tar.gz: 6d14fc2c60062b4c3a1d64f68e72e096ccc5059b3ac7c226667ca98d51c54d18
5
5
  SHA512:
6
- metadata.gz: 97e08cc352e3024d2f68d43f71e7e9836a9d2d6e0cbe4df5dc796853374009d17291904a70907f50f57ed38aab023434324a0e1d2bc756734c18c8261f9b4458
7
- data.tar.gz: c420c037d2d559e495347e72dcb4f835b57c0d2581e1b8dcd99aa3db42e64dddcfb243303144be0a11f1d5b851f40af928e78f286ca5c712fd05d827a790488b
6
+ metadata.gz: b7760e5a2998c8fa4325f54ae9be8f8010c90c7df4b98272d8277da3252b2a80e2c230771a6fdbd17a1764797c5ed711b41103da36ef305efff2cd6f9125e0f9
7
+ data.tar.gz: c912d733c2160b9699abad8d76a339406eb82c398beedd9245204197e79dac35334901f42845f72251f76a7a438e9a41b49ab97c9e897b43b5ee84c11da259fe
@@ -10,6 +10,10 @@ module ThecoreAuthCommonsUserConcern
10
10
  validates :password, presence: true, on: :create
11
11
  validates :password_confirmation, presence: true, on: :create
12
12
  validate :check_password_and_confirmation_equal
13
+ validates_each :password do |record, attr, value|
14
+ # Password must contain at least one uppercase letter, one lowercase letter, one number, and one special character or be blank
15
+ record.errors.add(attr, I18n.t("validation.errors.password_must_contain_uppercase_lowercase_number_special_character")) unless value.blank? || (value =~ /[A-Z]/ && value =~ /[a-z]/ && value =~ /[0-9]/ && value =~ /[^A-Za-z0-9]/)
16
+ end
13
17
  validates_each :admin do |record, attr, value|
14
18
  # Don't want admin == false if the current user is the only admin
15
19
  record.errors.add(attr, I18n.t("validation.errors.cannot_unadmin_last_admin")) if record.admin_changed? && record.admin_was == true && User.where(admin: true).count == 1
@@ -1,4 +1,15 @@
1
1
  en:
2
+ error:
3
+ messages:
4
+ password_requires_letters_and_numbers: "must contain at least one letter and one number"
5
+ password_requires_special_characters: "must contain at least one special character"
6
+ validation:
7
+ errors:
8
+ password_must_contain_uppercase_lowercase_number_special_character: "must contain at least one uppercase letter, one lowercase letter, one number and one special character"
9
+ cannot_unadmin_last_admin: "at least one user must be an administrator"
10
+ cannot_unlock_last_admin: "at least one user must be unlocked"
11
+ cannot_delete_last_admin: "at least one user must be an administrator"
12
+ cannot_delete_last_role: "at least one role must exist"
2
13
  activerecord:
3
14
  models:
4
15
  user:
@@ -1,4 +1,15 @@
1
1
  it:
2
+ error:
3
+ messages:
4
+ password_requires_letters_and_numbers: "deve contenere almeno una lettera e un numero"
5
+ password_requires_special_characters: "deve contenere almeno un carattere speciale"
6
+ validation:
7
+ errors:
8
+ password_must_contain_uppercase_lowercase_number_special_character: "deve contenere almeno una lettera maiuscola, una lettera minuscola, un numero e un carattere speciale"
9
+ cannot_unadmin_last_admin: "almeno un utente deve essere un amministratore"
10
+ cannot_unlock_last_admin: "almeno un utente deve essere sbloccato"
11
+ cannot_delete_last_admin: "almeno un utente deve essere un amministratore"
12
+ cannot_delete_last_role: "deve esistere almeno un ruolo"
2
13
  activerecord:
3
14
  models:
4
15
  user:
data/db/seeds.rb CHANGED
@@ -4,7 +4,7 @@ puts "Loading ThecoreAuthCommons seeds"
4
4
  Zeitwerk::Loader.eager_load_all
5
5
 
6
6
  email = "admin@#{ENV["BASE_DOMAIN"].presence || "example.com"}"
7
- psswd = ENV["ADMIN_PASSWORD"].presence || "changeme"
7
+ psswd = ENV["ADMIN_PASSWORD"].presence || "Change#1"
8
8
 
9
9
  unless User.where(admin: true).exists?
10
10
  u = User.find_or_initialize_by(email: email)
@@ -1,3 +1,3 @@
1
1
  module ThecoreAuthCommons
2
- VERSION = "3.2.3".freeze
2
+ VERSION = "3.3.0".freeze
3
3
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: thecore_auth_commons
3
3
  version: !ruby/object:Gem::Version
4
- version: 3.2.3
4
+ version: 3.3.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Gabriele Tassoni
@@ -72,6 +72,9 @@ dependencies:
72
72
  - - "~>"
73
73
  - !ruby/object:Gem::Version
74
74
  version: '3.0'
75
+ - - ">"
76
+ - !ruby/object:Gem::Version
77
+ version: 3.0.5
75
78
  type: :runtime
76
79
  prerelease: false
77
80
  version_requirements: !ruby/object:Gem::Requirement
@@ -79,6 +82,9 @@ dependencies:
79
82
  - - "~>"
80
83
  - !ruby/object:Gem::Version
81
84
  version: '3.0'
85
+ - - ">"
86
+ - !ruby/object:Gem::Version
87
+ version: 3.0.5
82
88
  - !ruby/object:Gem::Dependency
83
89
  name: simplecov
84
90
  requirement: !ruby/object:Gem::Requirement