15a6a7d29edd2fe674ee7c6d56c99b35c52432e0
[sfrench/samba-autobuild/.git] / source3 / param / loadparm_ctx.c
1 /* 
2    Unix SMB/CIFS implementation.
3    Parameter loading functions
4    Copyright (C) Andrew Bartlett 2011
5
6    This program is free software; you can redistribute it and/or modify
7    it under the terms of the GNU General Public License as published by
8    the Free Software Foundation; either version 3 of the License, or
9    (at your option) any later version.
10
11    This program is distributed in the hope that it will be useful,
12    but WITHOUT ANY WARRANTY; without even the implied warranty of
13    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14    GNU General Public License for more details.
15
16    You should have received a copy of the GNU General Public License
17    along with this program.  If not, see <http://www.gnu.org/licenses/>.
18 */
19
20 #include "includes.h"
21 #include "../source4/param/s3_param.h"
22
23 static struct loadparm_service *lp_service_for_s4_ctx(const char *servicename)
24 {
25         TALLOC_CTX *mem_ctx;
26         struct loadparm_service *service;
27
28         mem_ctx = talloc_stackframe();
29         service = lp_service(servicename);
30         talloc_free(mem_ctx);
31
32         return service;
33 }
34
35 static struct loadparm_service *lp_servicebynum_for_s4_ctx(int servicenum)
36 {
37         TALLOC_CTX *mem_ctx;
38         struct loadparm_service *service;
39
40         mem_ctx = talloc_stackframe();
41         service = lp_servicebynum(servicenum);
42         talloc_free(mem_ctx);
43
44         return service;
45 }
46
47 static bool lp_load_for_s4_ctx(const char *filename)
48 {
49         TALLOC_CTX *mem_ctx;
50         bool status;
51
52         mem_ctx = talloc_stackframe();
53         status =  lp_load(filename, false, false, false, false);
54         talloc_free(mem_ctx);
55
56         return status;
57 }
58
59 /* These are in the order that they appear in the s4 loadparm file.
60  * All of the s4 loadparm functions should be here eventually, once
61  * they are implemented in the s3 loadparm, have the same format (enum
62  * values in particular) and defaults. */
63 static const struct loadparm_s3_context s3_fns = 
64 {
65         .get_parametric = lp_parm_const_string_service,
66         .get_parm_struct = lp_get_parameter,
67         .get_parm_ptr = lp_parm_ptr,
68         .get_service = lp_service_for_s4_ctx,
69         .get_servicebynum = lp_servicebynum_for_s4_ctx,
70         .get_default_loadparm_service = lp_default_loadparm_service,
71         .get_numservices = lp_numservices,
72         .load = lp_load_for_s4_ctx,
73         .set_cmdline = lp_set_cmdline,
74         .dump = lp_dump,
75
76         .server_role = lp_server_role,
77
78         .winbind_separator = lp_winbind_separator,
79         .template_homedir = lp_template_homedir,
80         .template_shell = lp_template_shell,
81
82         .dos_charset = lp_dos_charset,
83         .unix_charset = lp_unix_charset,
84
85         .realm = lp_realm,
86         .dnsdomain = lp_dnsdomain,
87         .socket_options = lp_socket_options,
88         .workgroup = lp_workgroup,
89
90         .netbios_name = lp_netbios_name,
91         .netbios_scope = lp_netbios_scope,
92         .netbios_aliases = lp_netbios_aliases,
93
94         .lanman_auth = lp_lanman_auth,
95         .ntlm_auth = lp_ntlm_auth,
96
97         .client_plaintext_auth = lp_client_plaintext_auth,
98         .client_lanman_auth = lp_client_lanman_auth,
99         .client_ntlmv2_auth = lp_client_ntlmv2_auth,
100
101         .private_dir = lp_private_dir,
102         .ncalrpc_dir = lp_ncalrpc_dir,
103         .lockdir = lp_lockdir,
104
105         .passdb_backend = lp_passdb_backend,
106
107         .host_msdfs = lp_host_msdfs,
108 };
109
110 const struct loadparm_s3_context *loadparm_s3_context(void)
111 {
112         return &s3_fns;
113 }