Skip to content
Snippets Groups Projects
  • Rafael Guterres Jeffman's avatar
    6925503a
    ipagroup: Fix management of AD objects · 6925503a
    Rafael Guterres Jeffman authored
    When using AD objects, a user expects to use the more human readable
    form, like "user@ad.domain", but this impose some dificulties on
    evaluating which object is being referenced as AD has several forms to
    refer to the same object.
    
    Each object is AD is identified uniquely by its SID, and this is the
    identifier that IPA stores in its database. When managing AD objects,
    IPA finds its SID and works with that value.
    
    ansible-freeipa tried to process these objects using the human readable
    values, and it cause idempontence error when ensuring the values were
    present or modified, and, at least in some cases, prevented the objects
    to be made absent, as the object list created didn't match the SID to
    the value used as module parameter.
    
    By using SID to process the AD objects in ipagroup, the addition or
    removal of members works and idempotence of these members is ensured.
    
    The only issue with thils approach is that it only works no server
    nodes. In client nodes, the conversion to SID is not available and the
    same issues that existed before will still be present.
    
    Tests were updated to reflect these changes, a new test, specific to
    idempotence issues of AD objects was added:
    
       tests/group/test_group_ad_users.yml
    
    Resolves: https://issues.redhat.com/browse/RHEL-70023
    6925503a
    History
    ipagroup: Fix management of AD objects
    Rafael Guterres Jeffman authored
    When using AD objects, a user expects to use the more human readable
    form, like "user@ad.domain", but this impose some dificulties on
    evaluating which object is being referenced as AD has several forms to
    refer to the same object.
    
    Each object is AD is identified uniquely by its SID, and this is the
    identifier that IPA stores in its database. When managing AD objects,
    IPA finds its SID and works with that value.
    
    ansible-freeipa tried to process these objects using the human readable
    values, and it cause idempontence error when ensuring the values were
    present or modified, and, at least in some cases, prevented the objects
    to be made absent, as the object list created didn't match the SID to
    the value used as module parameter.
    
    By using SID to process the AD objects in ipagroup, the addition or
    removal of members works and idempotence of these members is ensured.
    
    The only issue with thils approach is that it only works no server
    nodes. In client nodes, the conversion to SID is not available and the
    same issues that existed before will still be present.
    
    Tests were updated to reflect these changes, a new test, specific to
    idempotence issues of AD objects was added:
    
       tests/group/test_group_ad_users.yml
    
    Resolves: https://issues.redhat.com/browse/RHEL-70023