Project

General

Profile

Actions

Feature #16112

closed

Netgroup LDAP Authentication in ldap_fluff

Added by Marek Hulán over 7 years ago. Updated almost 6 years ago.

Status:
Closed
Priority:
Normal
Category:
Authentication
Target version:
Fixed in Releases:
Found in Releases:

Description

Cloned from https://bugzilla.redhat.com/show_bug.cgi?id=1293538

Description of problem:

Netgroup LDAP Authentication

A RHEL 7.1 installation configured to use external LDAP authentication (created using hammer)

# hammer auth-source ldap create --name LDAP1 --host ldap.example.org --server-type posix --tls yes --port 636 \
--base-dn ou=People,ou=example,o=org,c=au --groups-base ou=netgroup,ou=example,o=org,c=au --attr-login uid

The User Group can then be created and an External Group linked to it (also using hammer)...

# hammer user-group create --name Test 
# hammer user-group external create --auth-source-id 3 --name test-netgroup --user-group Test

Actual results:

This returns a "500 Internal Server Error" - but checking in the Web UI the external group is displayed as linked correctly.
Trying to then refresh the display to show the users in the LDAP netgroup does nothing - no users are found within the group.
(Creating the user group and external linking via the Web UI returns NO errors - only via hammer do we get a clue something is wrong)

In the foreman production.log we see the 500 error:

2015-12-09 09:30:19 [I] Processing by Api::V2::ExternalUsergroupsController#create as JSON
2015-12-09 09:30:19 [I]    Parameters: {"external_usergroup"=>{"name"=>"test-netgroup", "auth_source_id"=>"3"}, "apiv"=>"2", "usergroup-id"=>"5"}
2015-12-09 09:30:20 [W] Creating scope :completer_scope. Overwriting existing method Organization.completer_scope.
2015-12-09 09:30:20 [I] Authorized user ggatward(Geoff Gatward)
2015-12-09 09:30:20 [I]   Rendered api/v2/external_usergroups/create.json.rabl (2.3ms)
2015-12-09 09:30:20 [E] Group does not have any members (RuntimeError)
/opt/rh/ruby193/root/usr/share/gems/gems/ldap_fluff-0.3.2/lib/ldap_fluff/generic.rb:47:in 'users_for_gid'
/opt/rh/ruby193/root/usr/share/gems/gems/ldap_fluff-0.3.2/lib/ldap_fluff/ldap_fluff.rb:35:in 'user_list'
/usr/share/foreman/app/models/auth_sources/auth_source_ldap.rb:107:in 'users_in_group'
/usr/share/foreman/app/models/external_usergroup.rb:33:in 'users'
...
...
2015-12-09 09:30:20 [I] Completed 500 Internal Server Error in 441ms
2015-12-09 09:30:20 [F]

If we do the same setup but use a posix group from LDAP instead, everything works as expected (no 500 error and users are resolved)

Expected results:

everything works as expected (no 500 error)

Additional info:

Netgroup grouping is alternative to posix usergroups. It works differently, they are to be found at ou=Netgroup,dc=example,dc=com tree with cn as their name. For association with user, attribute nisNetgroupTriple is defined in this object. Attribute is defined multiple times for each user in a given netgroup. The structure is triple ($server, $user, $domain).

While users can set group base DN today, we hardcode "memberuid" that we use for searching posix groups. We could make this also configurable per LDAP auth source and let ldap_fluff search in this triple.


Related issues 2 (0 open2 closed)

Related to Foreman - Bug #21167: ldap_fluff 0.4.7 needed in repos for netgroupsResolved10/02/2017Actions
Related to Foreman - Bug #21175: Unable to add AD LDAP Auth SourceClosedTomáš Strachota10/03/2017Actions
Actions #1

Updated by Marek Hulán over 7 years ago

  • Subject changed from Netgroup LDAP Authentication with Satellite 6. to Netgroup LDAP Authentication in ldap_fluff
  • Category set to Authentication
  • Priority changed from High to Normal
Actions #2

Updated by Marek Hulán over 7 years ago

  • Description updated (diff)
Actions #3

Updated by Marek Hulán over 7 years ago

  • Description updated (diff)
Actions #4

Updated by Marek Hulán over 7 years ago

  • Target version set to 115
Actions #5

Updated by Marek Hulán over 7 years ago

  • Assignee set to Tomáš Strachota
  • Target version changed from 115 to 1.4.2
Actions #6

Updated by Marek Hulán over 7 years ago

  • Target version changed from 1.4.2 to 1.4.4
Actions #7

Updated by Tomáš Strachota over 7 years ago

  • Status changed from New to Assigned
Actions #8

Updated by Marek Hulán over 7 years ago

  • Target version changed from 1.4.4 to 1.10.1
Actions #9

Updated by Marek Hulán over 7 years ago

  • Status changed from Assigned to New
  • Target version changed from 1.10.1 to 115
Actions #10

Updated by Tomáš Strachota about 7 years ago

  • Status changed from New to Assigned
Actions #11

Updated by Marek Hulán almost 7 years ago

  • Target version changed from 115 to 1.13.4
Actions #12

Updated by The Foreman Bot almost 7 years ago

  • Status changed from Assigned to Ready For Testing
  • Pull request https://github.com/theforeman/foreman/pull/4581 added
Actions #13

Updated by Marek Hulán almost 7 years ago

  • Target version changed from 1.13.4 to 1.14.0
Actions #14

Updated by Marek Hulán almost 7 years ago

  • Pull request https://github.com/theforeman/ldap_fluff/pull/57 added
Actions #15

Updated by Marek Hulán almost 7 years ago

  • Target version changed from 1.14.0 to 1.14.3
Actions #16

Updated by Marek Hulán almost 7 years ago

  • translation missing: en.field_release set to 240
Actions #17

Updated by Anonymous almost 7 years ago

  • Status changed from Ready For Testing to Closed
  • % Done changed from 0 to 100
Actions #18

Updated by Ivan Necas over 6 years ago

  • Related to Bug #21167: ldap_fluff 0.4.7 needed in repos for netgroups added
Actions #19

Updated by Marek Hulán over 6 years ago

  • Related to Bug #21175: Unable to add AD LDAP Auth Source added
Actions

Also available in: Atom PDF