On (05/07/16 12:27), Jakub Hrozek wrote:
>On Wed, Jun 29, 2016 at 05:38:55PM +0200, Lukas Slebodnik wrote:
>> On (29/06/16 13:12), Jakub Hrozek wrote:
>> >On Wed, Jun 29, 2016 at 12:48:36PM +0200, Lukas Slebodnik wrote:
>> >> On (28/06/16 11:50), Jakub Hrozek wrote:
>> >> >From b493cee9976b8dd62bea3d8f09b88ce809a40980 Mon Sep 17 00:00:00 2001
>> >> >From: Jakub Hrozek <jhro...@redhat.com>
>> >> >Date: Thu, 19 Nov 2015 10:40:39 +0100
>> >> >Subject: [PATCH] LDAP: Change the default rfc2307 autofs attribute 
>> >> >mappings
>> >> >
>> >> >Resolves:
>> >> >    https://fedorahosted.org/sssd/ticket/2858
>> >> >
>> >> >The default attribute mappings we used to have:
>> >> >    ldap_autofs_map_object_class        automountMap
>> >> >    ldap_autofs_map_name                ou
>> >> >    ldap_autofs_entry_object_class      automount
>> >> >    ldap_autofs_entry_key               cn
>> >> >    ldap_autofs_entry_value             automountInformation
>> >> >
>> >> >Was wrong. Instead, this patch switches to:
>> >> >    ldap_autofs_map_object_class        nisMap
>> >> >    ldap_autofs_map_name                nisMapName
>> >> >    ldap_autofs_entry_object_class      nisObject
>> >> >    ldap_autofs_entry_key               cn
>> >> >    ldap_autofs_entry_value             nisMapEntry
>> >> >
>> >> >Which are attributes that are available with servers running the default
>> >> >rfc2307 schema. In addition, this patch adds a syslog and DEBUG message
>> >> >that warns administrators to double-check their configuration.
>> >> >
>> >> >We don't warn when the autofs provider is set to AD, because that one
>> >> >is already correct.
>> >> >---
>> >> > src/man/sssd-ldap.5.xml           | 17 ++++----
>> >> > src/providers/ldap/ldap_common.h  |  6 +++
>> >> > src/providers/ldap/ldap_options.c | 83 
>> >> > ++++++++++++++++++++++++++++++++++++++-
>> >> > src/providers/ldap/ldap_opts.c    |  8 ++--
>> >> > src/providers/ldap/sdap_autofs.c  | 17 ++++++++
>> >> > 5 files changed, 119 insertions(+), 12 deletions(-)
>> >> >
>> >> >diff --git a/src/providers/ldap/ldap_opts.c 
>> >> >b/src/providers/ldap/ldap_opts.c
>> >> >index 
>> >> >ff9bf0d8b6d4a8f677e08219e5105e3750b7a4a8..524579d4fcd478f20678bebf2c3ce18f61ed0cb9
>> >> > 100644
>> >> >--- a/src/providers/ldap/ldap_opts.c
>> >> >+++ b/src/providers/ldap/ldap_opts.c
>> >> >@@ -349,15 +349,15 @@ struct sdap_attr_map service_map[] = {
>> >> > };
>> >> > 
>> >> > struct sdap_attr_map rfc2307_autofs_mobject_map[] = {
>> >> >-    { "ldap_autofs_map_object_class", "automountMap", 
>> >> >SYSDB_AUTOFS_MAP_OC, NULL },
>> >> >-    { "ldap_autofs_map_name", "ou", SYSDB_AUTOFS_MAP_NAME, NULL },
>> >> >+    { "ldap_autofs_map_object_class", "nisMap", SYSDB_AUTOFS_MAP_OC, 
>> >> >NULL },
>> >> >+    { "ldap_autofs_map_name", "nisMapName", SYSDB_AUTOFS_MAP_NAME, NULL 
>> >> >},
>> >> >     SDAP_ATTR_MAP_TERMINATOR
>> >> > };
>> >> > 
>> >> > struct sdap_attr_map rfc2307_autofs_entry_map[] = {
>> >> >-    { "ldap_autofs_entry_object_class", "automount", 
>> >> >SYSDB_AUTOFS_ENTRY_OC, NULL },
>> >> >+    { "ldap_autofs_entry_object_class", "nisObject", 
>> >> >SYSDB_AUTOFS_ENTRY_OC, NULL },
>> >> >     { "ldap_autofs_entry_key", "cn", SYSDB_AUTOFS_ENTRY_KEY, NULL },
>> >> >-    { "ldap_autofs_entry_value", "automountInformation", 
>> >> >SYSDB_AUTOFS_ENTRY_VALUE, NULL },
>> >> >+    { "ldap_autofs_entry_value", "nisMapEntry", 
>> >> >SYSDB_AUTOFS_ENTRY_VALUE, NULL },
>> >> >     SDAP_ATTR_MAP_TERMINATOR
>> >> > };
>> >> > 
>> >> >diff --git a/src/providers/ldap/sdap_autofs.c 
>> >> >b/src/providers/ldap/sdap_autofs.c
>> >> >index 
>> >> >c02c04d5ca5addbfd1552176cac5f74fdd592503..db41b650ddcda99e6c221e856c259fcc43a10436
>> >> > 100644
>> >> >--- a/src/providers/ldap/sdap_autofs.c
>> >> >+++ b/src/providers/ldap/sdap_autofs.c
>> >> >@@ -313,6 +313,23 @@ errno_t sdap_autofs_init(TALLOC_CTX *mem_ctx,
>> >> >         return ret;
>> >> >     }
>> >> > 
>> >> >+    if (id_ctx->opts->schema_type == SDAP_SCHEMA_AD) {
>> >> >+        if (ldap_ad_autofs_schema_defaults(be_ctx->cdb,
>> >> >+                                           be_ctx->conf_path)) {
>> >> >+        DEBUG(SSSDBG_IMPORTANT_INFO,
>> >> >+              "Your configuration uses the ldap autofs provider "
>> >> >+              "with schema set to \"ad\" and default autofs attribute "
>> >> >+              "mappings. The default map changed in this release, "
>> >> >+              "please make sure the sssd configuration explicitly 
>> >> >matches "
>> >> >+              "the server attributes.");
>> >> >+        sss_log(SSS_LOG_NOTICE,
>> >> >+                _("Your configuration uses the ldap autofs provider "
>> >> >+                  "with schema set to \"ad\" and default autofs 
>> >> >attribute "
>> >> >+                  "mappings. The default map changed in this release, "
>> >> >+                  "please make sure the sssd configuration explicitly 
>> >> >matches "
>> >> >+                  "the server attributes."));
>> >> Do we really need to log message for ad schema?
>> >> I thought we will log message about change just for rfc2307.
>> >
>> >I tried to catch this scenario:
>> >    id_provider=ldap
>> >    autofs_provider=ldap
>> >    ldap_schema=ad
>> >
>> >With the previous versions, the attributes pointed to automountMap etc.
>> >And there is a chance (unlikely) the admin extended the schema to keep
>> >the config using defaults.
>> >
>> >> 
>> >> IIRC AD does not have by default schema for autofs.
>> >
>> >Right, that's the reason we should to change the defaults. AD only has
>> >the most basic rfc2307 and our previous defaults forced the AD SSSD
>> >admins to either change the mappings in the config file or extend the
>> >schema.
>> 
>> The patch should fix ticket #2858;
>> and this ticket says: autofs_provider = ldap ldap_schema = rfc2307
>> and the 4th comment says: The beauty of using older schema (rfc2307) to store
>>   automount information is, that we do not need to extend AD schema - which
>>   is in   many cases quite troublesome action.
>> 
>> So the warning should be logged for rfc2307 and not for AD.
>> BTW it looks like we needn't change defaults for AD.
>
>This only works because we have:
>    977     /* fix schema to AD  */
>    978     id_opts->schema_type = SDAP_SCHEMA_AD;
>in ad_common.c, otherwise setting ldap_schema=rfc2307 would start looking
>up usernames in memberUid and other rfc2307 stuff. If the reporter was
>using id_provider=ldap with schema set to ad, then nothing would work
>and also, we have a bit of schizophrenic situation now in the code where
>autofs_provider=ad uses a different set of options than ldap_schema=ad.
>
Fair enough and Ian confirmed that we should rather use nis* attributes
for AD. If you want we can change default for id_provider=ldap with schema set
to AD. It's up to you and it can be done later. If you do not want to change it
now.

>I'm OK with saying that the preferred way is to use the autofs_provider=ad,
>but IMO we should at least track this with a different ticket.
>
>A new patch is attached that just changes the rfc2307 schema, because I
>would like to include it in the next version, but let's also discuss
>what do we do with the AD LDAP schema.


>From 5765a2c5bf63e3caa33ae73c1e5342869c095758 Mon Sep 17 00:00:00 2001
>From: Jakub Hrozek <jhro...@redhat.com>
>Date: Thu, 19 Nov 2015 10:40:39 +0100
>Subject: [PATCH] LDAP: Change the default rfc2307 autofs attribute mappings
>
>Resolves:
>    https://fedorahosted.org/sssd/ticket/2858
>
>The default attribute mappings we used to have:
>    ldap_autofs_map_object_class        automountMap
>    ldap_autofs_map_name                ou
>    ldap_autofs_entry_object_class      automount
>    ldap_autofs_entry_key               cn
>    ldap_autofs_entry_value             automountInformation
>
>Was wrong. Instead, this patch switches to:
>    ldap_autofs_map_object_class        nisMap
>    ldap_autofs_map_name                nisMapName
>    ldap_autofs_entry_object_class      nisObject
>    ldap_autofs_entry_key               cn
>    ldap_autofs_entry_value             nisMapEntry
>
>Which are attributes that are available with servers running the default
>rfc2307 schema. In addition, this patch adds a syslog and DEBUG message
>that warns administrators to double-check their configuration.
>
>We don't warn when the autofs provider is set to AD, because that one
>is already correct.
>---
> src/man/sssd-ldap.5.xml           | 22 ++++++++-----
> src/providers/ldap/ldap_options.c | 66 +++++++++++++++++++++++++++++++++++++++
> src/providers/ldap/ldap_opts.c    |  8 ++---
> 3 files changed, 85 insertions(+), 11 deletions(-)
>
>diff --git a/src/man/sssd-ldap.5.xml b/src/man/sssd-ldap.5.xml
>index 
>a30100408c6e77f9156878cb6ff63dfbf7b041d1..48f30a98ebb714bedfd5b595e3115151432810e6
> 100644
>--- a/src/man/sssd-ldap.5.xml
>+++ b/src/man/sssd-ldap.5.xml
>@@ -2505,7 +2505,9 @@ ldap_access_filter = (employeeType=admin)
>                             The object class of an automount map entry in 
> LDAP.
>                         </para>
>                         <para>
>-                            Default: automountMap
>+                            Default: nisMap (rfc2307, autofs_provider=ad),
>+                            automountMap (rfc2307bis, ipa, LDAP provider
>+                            with AD schema)
Would it be easier to read following ?

Default: nisMap (rfc2307, autofs_provider=ad), automountMap otherwise
or use other way. You needn't change if you think this way is better.

>@@ -438,6 +490,20 @@ int ldap_get_autofs_options(TALLOC_CTX *memctx,
>               "connecting to the LDAP server.\n");
>     }
> 
>+    if (opts->schema_type == SDAP_SCHEMA_RFC2307 &&
>+            ldap_rfc2307_autofs_defaults(cdb, conf_path) == true) {
>+        DEBUG(SSSDBG_IMPORTANT_INFO,
>+              "Your configuration uses the autofs provider "
>+              "with schema set to rfc2307 and default attribute mappings. "
>+              "The default map has changed in this release, please make "
>+              "sure the configuration matches the server attributes.");
Thank you for message with schema rfc2307.
But there is missing new line at the end :-)

>+        sss_log(SSS_LOG_NOTICE,
>+                _("Your configuration uses the autofs provider "
>+                  "with schema set to rfc2307 and default attribute mappings. 
>"
>+                  "The default map has changed in this release, please make "
>+                  "sure the configuration matches the server attributes."));
>+    }
>+

I wrote some ideas but I do not insist on them.
You have an ACK if you add new line to debug message :-)

LS
_______________________________________________
sssd-devel mailing list
sssd-devel@lists.fedorahosted.org
https://lists.fedorahosted.org/admin/lists/sssd-devel@lists.fedorahosted.org

Reply via email to