egov_utils 1.5.0 → 1.5.2
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 +4 -4
- data/app/models/egov_utils/person.rb +38 -0
- data/app/models/egov_utils/user.rb +14 -1
- data/app/services/egov_utils/refresh_user_groups.rb +1 -1
- data/lib/egov_utils/iszr/np_addresses.json +11 -0
- data/lib/egov_utils/iszr/np_results.json +7 -0
- data/lib/egov_utils/version.rb +1 -1
- metadata +16 -2
checksums.yaml
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
---
|
|
2
2
|
SHA256:
|
|
3
|
-
metadata.gz:
|
|
4
|
-
data.tar.gz:
|
|
3
|
+
metadata.gz: 00a812c26a6b677a4a10133a12d51d5ebaf45d3b26153cc3cf98500c54c6a0e4
|
|
4
|
+
data.tar.gz: 55fb7eb4ff838991649061d715dbb6d0835ab6b90e611a71163e4bf8f3b07688
|
|
5
5
|
SHA512:
|
|
6
|
-
metadata.gz:
|
|
7
|
-
data.tar.gz:
|
|
6
|
+
metadata.gz: 99707ae89bc0a01b0510da1859267a00bf16bca2aaa35e3d70ce6f6af6a96512b57dfc852f19a60c5604dfa5c5d9ea5c597c0c9ec662c73b81096a8f133739a8
|
|
7
|
+
data.tar.gz: 45f59f259aa0010bca3b153a680d2a0ec171ef3d55562e7fc4e0c75e8d8775a129ec531bc7175a443858936d884c60d1042ecdc60257cef31d46fa5a4fc14ce9
|
|
@@ -59,6 +59,44 @@ module EgovUtils
|
|
|
59
59
|
person_entity.to_s
|
|
60
60
|
end
|
|
61
61
|
|
|
62
|
+
def self.find_or_create_from_remote_id(create_attrs)
|
|
63
|
+
remote_id = create_attrs[:remote_id].presence
|
|
64
|
+
person_type = create_attrs[:person_type].presence
|
|
65
|
+
|
|
66
|
+
person = if remote_id.present?
|
|
67
|
+
EgovUtils::Person.find_by(
|
|
68
|
+
remote_id: remote_id.presence,
|
|
69
|
+
person_type: person_type.presence
|
|
70
|
+
)
|
|
71
|
+
end
|
|
72
|
+
return person if person
|
|
73
|
+
|
|
74
|
+
if remote_id
|
|
75
|
+
attributes =
|
|
76
|
+
if person_type == 'natural'
|
|
77
|
+
Iszr::NaturalPeople::SearchByRemoteId.run!(remote_id:)
|
|
78
|
+
else
|
|
79
|
+
Iszr::LegalPeople::SearchByRemoteId.run!(remote_id:)
|
|
80
|
+
end.to_h
|
|
81
|
+
|
|
82
|
+
person_entity =
|
|
83
|
+
if person_type == 'natural'
|
|
84
|
+
NaturalPerson.find_or_initialize_by(attributes.except(:remote_id))
|
|
85
|
+
else
|
|
86
|
+
LegalPerson.find_or_initialize_by(attributes.except(:remote_id))
|
|
87
|
+
end
|
|
88
|
+
|
|
89
|
+
if person_entity.persisted?
|
|
90
|
+
person_entity.person.update!(remote_id:)
|
|
91
|
+
person_entity.person
|
|
92
|
+
end
|
|
93
|
+
else
|
|
94
|
+
new(create_attrs).tap do
|
|
95
|
+
_1.save(validate: false)
|
|
96
|
+
end
|
|
97
|
+
end
|
|
98
|
+
end
|
|
99
|
+
|
|
62
100
|
private
|
|
63
101
|
|
|
64
102
|
def set_person_from_remote_id
|
|
@@ -161,8 +161,21 @@ module EgovUtils
|
|
|
161
161
|
end
|
|
162
162
|
end
|
|
163
163
|
|
|
164
|
+
def groups
|
|
165
|
+
super.to_a.concat(Array.wrap(ldap_groups))
|
|
166
|
+
end
|
|
167
|
+
|
|
164
168
|
def ldap_groups
|
|
165
|
-
|
|
169
|
+
if provider.present?
|
|
170
|
+
group_ids = persisted? && Rails.cache.read("#{cache_key}/ldap_group_ids", expires_in: 30.minutes)
|
|
171
|
+
if group_ids
|
|
172
|
+
groups = EgovUtils::Group.where(id: group_ids).to_a
|
|
173
|
+
else
|
|
174
|
+
groups = EgovUtils::Group.where(provider: provider).to_a.select{|g| auth_source.member?(ldap_dn, g.external_uid) }
|
|
175
|
+
Rails.cache.write("#{cache_key}/ldap_group_ids", groups.collect(&:id), expires_in: 30.minutes) if persisted?
|
|
176
|
+
end
|
|
177
|
+
groups
|
|
178
|
+
end
|
|
166
179
|
end
|
|
167
180
|
|
|
168
181
|
def must_change_password?
|
|
@@ -86,5 +86,16 @@
|
|
|
86
86
|
"district": "Hlavní město Praha",
|
|
87
87
|
"region": "Hlavní město Praha",
|
|
88
88
|
"country": 203
|
|
89
|
+
},
|
|
90
|
+
{
|
|
91
|
+
"remote_id": "1234",
|
|
92
|
+
"street": "Vzorová",
|
|
93
|
+
"house_number": "123",
|
|
94
|
+
"orientation_number": "1",
|
|
95
|
+
"city": "Praha",
|
|
96
|
+
"postcode": "13000",
|
|
97
|
+
"district": "Hlavní město Praha",
|
|
98
|
+
"region": "Hlavní město Praha",
|
|
99
|
+
"country": 203
|
|
89
100
|
}
|
|
90
101
|
]
|
data/lib/egov_utils/version.rb
CHANGED
metadata
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
|
2
2
|
name: egov_utils
|
|
3
3
|
version: !ruby/object:Gem::Version
|
|
4
|
-
version: 1.5.
|
|
4
|
+
version: 1.5.2
|
|
5
5
|
platform: ruby
|
|
6
6
|
authors:
|
|
7
7
|
- Ondřej Ezr
|
|
8
8
|
autorequire:
|
|
9
9
|
bindir: bin
|
|
10
10
|
cert_chain: []
|
|
11
|
-
date: 2025-
|
|
11
|
+
date: 2025-11-03 00:00:00.000000000 Z
|
|
12
12
|
dependencies:
|
|
13
13
|
- !ruby/object:Gem::Dependency
|
|
14
14
|
name: rails
|
|
@@ -220,6 +220,20 @@ dependencies:
|
|
|
220
220
|
- - ">="
|
|
221
221
|
- !ruby/object:Gem::Version
|
|
222
222
|
version: '0'
|
|
223
|
+
- !ruby/object:Gem::Dependency
|
|
224
|
+
name: nkf
|
|
225
|
+
requirement: !ruby/object:Gem::Requirement
|
|
226
|
+
requirements:
|
|
227
|
+
- - ">="
|
|
228
|
+
- !ruby/object:Gem::Version
|
|
229
|
+
version: '0'
|
|
230
|
+
type: :runtime
|
|
231
|
+
prerelease: false
|
|
232
|
+
version_requirements: !ruby/object:Gem::Requirement
|
|
233
|
+
requirements:
|
|
234
|
+
- - ">="
|
|
235
|
+
- !ruby/object:Gem::Version
|
|
236
|
+
version: '0'
|
|
223
237
|
- !ruby/object:Gem::Dependency
|
|
224
238
|
name: request_store_rails
|
|
225
239
|
requirement: !ruby/object:Gem::Requirement
|