param: remove lp_get_parameter
[obnox/samba/samba-obnox.git] / source3 / param / loadparm_ctx.c
index 3bcf80954a6a9c7a699b3c2aace9f1af1852d36f..8f1572fdaac5ccd15a8ee1c065b6e2cbb410a5a8 100644 (file)
@@ -1,43 +1,85 @@
+/* 
+   Unix SMB/CIFS implementation.
+   Parameter loading functions
+   Copyright (C) Andrew Bartlett 2011
+
+   This program is free software; you can redistribute it and/or modify
+   it under the terms of the GNU General Public License as published by
+   the Free Software Foundation; either version 3 of the License, or
+   (at your option) any later version.
+
+   This program is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+   GNU General Public License for more details.
+
+   You should have received a copy of the GNU General Public License
+   along with this program.  If not, see <http://www.gnu.org/licenses/>.
+*/
+
 #include "includes.h"
-#include "../source4/param/s3_param.h"
+#include "lib/param/s3_param.h"
 
-/* These are in the order that they appear in the s4 loadparm file.
- * All of the s4 loadparm functions should be here eventually, once
- * they are implemented in the s3 loadparm, have the same format (enum
- * values in particular) and defaults. */
-static const struct loadparm_s3_context s3_fns = 
+static struct loadparm_service *lp_service_for_s4_ctx(const char *servicename)
 {
-       .server_role = lp_server_role,
+       TALLOC_CTX *mem_ctx;
+       struct loadparm_service *service;
+
+       mem_ctx = talloc_stackframe();
+       service = lp_service(servicename);
+       talloc_free(mem_ctx);
+
+       return service;
+}
 
-       .winbind_separator = lp_winbind_separator,
-       .template_homedir = lp_template_homedir,
-       .template_shell = lp_template_shell,
+static struct loadparm_service *lp_servicebynum_for_s4_ctx(int servicenum)
+{
+       TALLOC_CTX *mem_ctx;
+       struct loadparm_service *service;
 
-       .dos_charset = lp_dos_charset,
-       .unix_charset = lp_unix_charset,
-       .display_charset = lp_display_charset,
+       mem_ctx = talloc_stackframe();
+       service = lp_servicebynum(servicenum);
+       talloc_free(mem_ctx);
 
-       .realm = lp_realm,
-       .dnsdomain = lp_dnsdomain,
-       .socket_options = lp_socket_options,
-       .workgroup = lp_workgroup,
+       return service;
+}
 
-       .netbios_name = global_myname,
-       .netbios_scope = global_scope,
+static bool lp_load_for_s4_ctx(const char *filename)
+{
+       TALLOC_CTX *mem_ctx;
+       bool status;
 
-       .lanman_auth = lp_lanman_auth,
-       .ntlm_auth = lp_ntlm_auth,
+       mem_ctx = talloc_stackframe();
+       status =  lp_load(filename, false, false, false, false);
+       talloc_free(mem_ctx);
 
-       .client_plaintext_auth = lp_client_plaintext_auth,
-       .client_lanman_auth = lp_client_lanman_auth,
-       .client_ntlmv2_auth = lp_client_ntlmv2_auth,
+       return status;
+}
 
-       .private_dir = lp_private_dir,
-       .ncalrpc_dir = lp_ncalrpc_dir,
-       .lockdir = lp_lockdir
+static struct loadparm_s3_helpers s3_fns =
+{
+       .get_parm_ptr = lp_parm_ptr,
+       .get_service = lp_service_for_s4_ctx,
+       .get_servicebynum = lp_servicebynum_for_s4_ctx,
+       .getservicebyname = getservicebyname,
+       .get_default_loadparm_service = lp_default_loadparm_service,
+       .get_numservices = lp_numservices,
+       .load = lp_load_for_s4_ctx,
+       .store_cmdline = store_lp_set_cmdline,
+       .dump = lp_dump,
+       .lp_string = lp_string,
+       .lp_include = lp_include,
+       .init_ldap_debugging = init_ldap_debugging,
+       .set_netbios_aliases = set_netbios_aliases,
+       .lp_do_parameter = lp_do_parameter,
+       .do_section = lp_do_section,
 };
 
-const struct loadparm_s3_context *loadparm_s3_context(void)
+const struct loadparm_s3_helpers *loadparm_s3_helpers(void)
 {
-       return &s3_fns;
+       struct loadparm_s3_helpers *helpers;
+       helpers = &s3_fns;
+       helpers->globals = get_globals();
+       helpers->flags = get_flags();
+       return helpers;
 }