diff options
| author | Andrew Bartlett <abartlet@samba.org> | 2008-07-15 20:27:43 +1000 | 
|---|---|---|
| committer | Andrew Bartlett <abartlet@samba.org> | 2008-07-15 20:27:43 +1000 | 
| commit | d904b71879cf980f602bfd400cf98396616c13e1 (patch) | |
| tree | faffbb30f594b04903813f5267bd0c7d01c5d575 /source4/scripting | |
| parent | cc44b10c240e22a7db83c641a9015dad3ec2e0de (diff) | |
| parent | 63d91e9ab0ecc1e80edff27ae09b249c68453106 (diff) | |
| download | samba-d904b71879cf980f602bfd400cf98396616c13e1.tar.gz samba-d904b71879cf980f602bfd400cf98396616c13e1.tar.bz2 samba-d904b71879cf980f602bfd400cf98396616c13e1.zip  | |
Merge branch 'v4-0-test' of ssh://git.samba.org/data/git/samba into 4-0-local
(This used to be commit 7fb8179f214bbba95eb35d221cb9892b55afe121)
Diffstat (limited to 'source4/scripting')
| -rw-r--r-- | source4/scripting/python/samba/provision.py | 51 | 
1 files changed, 41 insertions, 10 deletions
diff --git a/source4/scripting/python/samba/provision.py b/source4/scripting/python/samba/provision.py index 504044253e..6102dc77ff 100644 --- a/source4/scripting/python/samba/provision.py +++ b/source4/scripting/python/samba/provision.py @@ -604,6 +604,20 @@ def setup_secretsdb(path, setup_path, session_info, credentials, lp):      secrets_ldb = Ldb(path, session_info=session_info, credentials=credentials,                        lp=lp)      secrets_ldb.load_ldif_file_add(setup_path("secrets.ldif")) + +    if credentials is not None and credentials.authentication_requested(): +        if credentials.get_bind_dn() is not None: +            setup_add_ldif(secrets_ldb, setup_path("secrets_simple_ldap.ldif"), { +                    "LDAPMANAGERDN": credentials.get_bind_dn(), +                    "LDAPMANAGERPASS_B64": b64encode(credentials.get_password()) +                    }) +        else: +            setup_add_ldif(secrets_ldb, setup_path("secrets_sasl_ldap.ldif"), { +                    "LDAPADMINUSER": credentials.get_username(), +                    "LDAPADMINREALM": credentials.get_realm(), +                    "LDAPADMINPASS_B64": b64encode(credentials.get_password()) +                    }) +      return secrets_ldb @@ -754,10 +768,10 @@ def setup_samdb(path, setup_path, session_info, credentials, lp,              domain_oc = "samba4LocalDomain"          setup_add_ldif(samdb, setup_path("provision_basedn.ldif"), { -            "DOMAINDN": names.domaindn, -            "ACI": aci, -            "DOMAIN_OC": domain_oc -            }) +                "DOMAINDN": names.domaindn, +                "ACI": aci, +                "DOMAIN_OC": domain_oc +                })          message("Modifying DomainDN: " + names.domaindn + "")          if domainguid is not None: @@ -1265,15 +1279,27 @@ refint_attributes""" + refint_attributes + "\n"                      "DOMAINDN": names.domaindn,                      "CONFIGDN": names.configdn,                      "SCHEMADN": names.schemadn, -                    "LDAPMANAGERDN": names.ldapmanagerdn, -                    "LDAPMANAGERPASS": adminpass,                      "MEMBEROF_CONFIG": memberof_config})          setup_file(setup_path("modules.conf"), paths.modulesconf,                     {"REALM": names.realm}) -        setup_db_config(setup_path, os.path.join(paths.ldapdir, os.path.join("db", "user"))) -        setup_db_config(setup_path, os.path.join(paths.ldapdir, os.path.join("db", "config"))) -        setup_db_config(setup_path, os.path.join(paths.ldapdir, os.path.join("db", "schema"))) +        setup_db_config(setup_path, os.path.join(paths.ldapdir, "db", "user")) +        setup_db_config(setup_path, os.path.join(paths.ldapdir, "db", "config")) +        setup_db_config(setup_path, os.path.join(paths.ldapdir, "db", "schema")) + +        if not os.path.exists(os.path.join(paths.ldapdir, "db", "samba",  "cn=samba")): +            os.makedirs(os.path.join(paths.ldapdir, "db", "samba",  "cn=samba")) + +        setup_file(setup_path("cn=samba.ldif"),  +                   os.path.join(paths.ldapdir, "db", "samba",  "cn=samba.ldif"), +                   { "UUID": str(uuid.uuid4()),  +                     "LDAPTIME": timestring(int(time.time()))} ) +        setup_file(setup_path("cn=samba-admin.ldif"),  +                              os.path.join(paths.ldapdir, "db", "samba",  "cn=samba", "cn=samba-admin.ldif"), +                              {"LDAPADMINPASS_B64": b64encode(adminpass), +                               "UUID": str(uuid.uuid4()),  +                               "LDAPTIME": timestring(int(time.time()))} ) +          mapping = "schema-map-openldap-2.3"          backend_schema = "backend-schema.schema" @@ -1294,7 +1320,12 @@ refint_attributes""" + refint_attributes + "\n"      message("Hostname:            %s" % names.hostname)      message("DNS Domain:          %s" % names.dnsdomain)      message("Base DN:             %s" % names.domaindn) -    message("LDAP admin DN:       %s" % names.ldapmanagerdn) + +    if ldap_backend_type == "openldap": +        message("LDAP admin user:     samba-admin") +    else: +        message("LDAP admin DN:       %s" % names.ldapmanagerdn) +      message("LDAP admin password: %s" % adminpass)      message(slapdcommand)  | 
