r9700: Change DATA_BLOB in ejs back to struct datablob
[kai/samba.git] / source / lib / samba3 / samba3.c
index 37576a8642a6a1ce94355b1fd4e7e4ee4aee4645..08debe96b193a5d42fb5d44a8722e50a6ac755a8 100644 (file)
 #include "includes.h"
 #include "lib/samba3/samba3.h"
 
-struct samba3 *samba3_read(const char *libdir, TALLOC_CTX *ctx)
+struct smbconf_data {
+       TALLOC_CTX *ctx;
+       struct samba3 *db;
+       struct samba3_share_info *current_share;
+};
+
+struct samba3_share_info *samba3_find_share(struct samba3 *db, TALLOC_CTX* ctx, const char *name)
+{
+       int i;
+       for (i = 0; i < db->share_count; i++) {
+               if (!StrCaseCmp(db->shares[i].name, name)) 
+                       return &db->shares[i];
+       }
+
+       db->shares = talloc_realloc(ctx, db->shares, struct samba3_share_info, db->share_count+1);
+       ZERO_STRUCT(db->shares[i]);
+       db->shares[i].name = talloc_strdup(ctx, name);
+       db->share_count++;
+       
+       return &db->shares[i];
+}
+
+static BOOL samba3_sfunc (const char *name, void *_db)
+{
+       struct smbconf_data *privdat = _db;
+
+       privdat->current_share = samba3_find_share(privdat->db, privdat->ctx, name);
+
+       return True;
+}
+
+static BOOL samba3_pfunc (const char *name, const char *value, void *_db)
+{
+       struct smbconf_data *privdat = _db;
+       struct samba3_parameter *p;
+
+       privdat->current_share->parameters = 
+               talloc_realloc(privdat->ctx, privdat->current_share->parameters,
+                                          struct samba3_parameter, 
+                                          privdat->current_share->parameter_count+1);
+
+       p = &privdat->current_share->parameters[privdat->current_share->parameter_count];
+       p->name = talloc_strdup(privdat->ctx, name);
+       p->value = talloc_strdup(privdat->ctx, value);
+
+       privdat->current_share->parameter_count++;
+
+       return True;
+}
+
+NTSTATUS samba3_read_smbconf(const char *fn, TALLOC_CTX *ctx, struct samba3 *db)
+{
+       struct smbconf_data privdat;
+
+       privdat.ctx = ctx;
+       privdat.db = db;
+       privdat.current_share = samba3_find_share(db, ctx, "global");
+       
+       if (!pm_process( fn, samba3_sfunc, samba3_pfunc, &privdat )) {
+               return NT_STATUS_UNSUCCESSFUL;
+       }
+
+       return NT_STATUS_OK;
+}
+
+NTSTATUS samba3_read(const char *smbconf, const char *libdir, TALLOC_CTX *ctx, struct samba3 **samba3)
 {
        struct samba3 *ret;
        char *dbfile;
 
-       ret = talloc(ctx, struct samba3);
-       
-       asprintf(&dbfile, "%s/winsdb.dat", libdir);
+       ret = talloc_zero(ctx, struct samba3);
+
+       if (smbconf) 
+               samba3_read_smbconf(smbconf, ctx, ret);
+
+       asprintf(&dbfile, "%s/wins.dat", libdir);
        samba3_read_winsdb(dbfile, ret, &ret->winsdb_entries, &ret->winsdb_count);
        SAFE_FREE(dbfile);
 
@@ -35,11 +103,11 @@ struct samba3 *samba3_read(const char *libdir, TALLOC_CTX *ctx)
        samba3_read_tdbsam(dbfile, ctx, &ret->samaccounts, &ret->samaccount_count);
        SAFE_FREE(dbfile);
 
-       asprintf(&dbfile, "%s/groupdb.tdb", libdir);
+       asprintf(&dbfile, "%s/group_mapping.tdb", libdir);
        samba3_read_grouptdb(dbfile, ctx, &ret->group);
        SAFE_FREE(dbfile);
 
-       asprintf(&dbfile, "%s/idmap.tdb", libdir);
+       asprintf(&dbfile, "%s/winbindd_idmap.tdb", libdir);
        samba3_read_idmap(dbfile, ctx, &ret->idmap);
        SAFE_FREE(dbfile);
 
@@ -47,5 +115,19 @@ struct samba3 *samba3_read(const char *libdir, TALLOC_CTX *ctx)
        samba3_read_account_policy(dbfile, ctx, &ret->policy);
        SAFE_FREE(dbfile);
 
-       return ret;
+       asprintf(&dbfile, "%s/registry.tdb", libdir);
+       samba3_read_regdb(dbfile, ctx, &ret->registry);
+       SAFE_FREE(dbfile);
+
+       asprintf(&dbfile, "%s/secrets.tdb", libdir);
+       samba3_read_secrets(dbfile, ctx, &ret->secrets);
+       SAFE_FREE(dbfile);
+
+       asprintf(&dbfile, "%s/share_info.tdb", libdir);
+       samba3_read_share_info(dbfile, ctx, ret);
+       SAFE_FREE(dbfile);
+
+       *samba3 = ret;
+
+       return NT_STATUS_OK;
 }