WIP Add member/contributor status to users
All checks were successful
continuous-integration/drone/push Build is passing
All checks were successful
continuous-integration/drone/push Build is passing
This commit is contained in:
@@ -50,19 +50,17 @@ class LdapService < ApplicationService
|
||||
end
|
||||
|
||||
def fetch_users(args={})
|
||||
if args[:ou]
|
||||
treebase = "ou=#{args[:ou]},cn=users,#{ldap_suffix}"
|
||||
else
|
||||
treebase = ldap_config["base"]
|
||||
end
|
||||
|
||||
attributes = %w[
|
||||
dn cn uid mail displayName admin serviceEnabled
|
||||
dn cn uid mail displayName admin serviceEnabled memberStatus
|
||||
mailRoutingAddress mailpassword nostrKey pgpKey
|
||||
]
|
||||
filter = Net::LDAP::Filter.eq("uid", args[:uid] || "*")
|
||||
filter = Net::LDAP::Filter.eq('objectClass', 'person') &
|
||||
Net::LDAP::Filter.eq("cn", args[:cn] || "*")
|
||||
|
||||
entries = client.search(base: treebase, filter: filter, attributes: attributes)
|
||||
entries = client.search(
|
||||
base: ldap_config["base"], filter: filter,
|
||||
attributes: attributes
|
||||
)
|
||||
entries.sort_by! { |e| e.cn[0] }
|
||||
entries = entries.collect do |e|
|
||||
{
|
||||
@@ -71,6 +69,7 @@ class LdapService < ApplicationService
|
||||
display_name: e.try(:displayName) ? e.displayName.first : nil,
|
||||
admin: e.try(:admin) ? 'admin' : nil,
|
||||
services_enabled: e.try(:serviceEnabled),
|
||||
member_status: e.try(:memberStatus),
|
||||
email_maildrop: e.try(:mailRoutingAddress),
|
||||
email_password: e.try(:mailpassword),
|
||||
nostr_key: e.try(:nostrKey) ? e.nostrKey.first : nil,
|
||||
@@ -79,10 +78,20 @@ class LdapService < ApplicationService
|
||||
end
|
||||
end
|
||||
|
||||
def search_users(search_attr, value, return_attr)
|
||||
filter = Net::LDAP::Filter.eq('objectClass', 'person') &
|
||||
Net::LDAP::Filter.eq(search_attr.to_s, value.to_s) &
|
||||
Net::LDAP::Filter.present('cn')
|
||||
entries = client.search(
|
||||
base: ldap_config["base"], filter: filter,
|
||||
attributes: [return_attr]
|
||||
)
|
||||
entries.map { |entry| entry[return_attr].first }.compact
|
||||
end
|
||||
|
||||
def fetch_organizations
|
||||
attributes = %w{dn ou description}
|
||||
filter = Net::LDAP::Filter.eq("objectClass", "organizationalUnit")
|
||||
# filter = Net::LDAP::Filter.eq("objectClass", "*")
|
||||
treebase = "cn=users,#{ldap_suffix}"
|
||||
|
||||
entries = client.search(base: treebase, filter: filter, attributes: attributes)
|
||||
|
||||
Reference in New Issue
Block a user