param: make server role list common and include auto (for the new default)
[gd/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 "lib/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         .domain_logons = lp_domain_logons,
78         .domain_master = lp_domain_master,
79
80         .winbind_separator = lp_winbind_separator,
81         .template_homedir = lp_template_homedir,
82         .template_shell = lp_template_shell,
83
84         .dos_charset = lp_dos_charset,
85         .unix_charset = lp_unix_charset,
86
87         .realm = lp_realm,
88         .dnsdomain = lp_dnsdomain,
89         .socket_options = lp_socket_options,
90         .workgroup = lp_workgroup,
91
92         .netbios_name = lp_netbios_name,
93         .netbios_scope = lp_netbios_scope,
94         .netbios_aliases = lp_netbios_aliases,
95
96         .lanman_auth = lp_lanman_auth,
97         .ntlm_auth = lp_ntlm_auth,
98
99         .client_plaintext_auth = lp_client_plaintext_auth,
100         .client_lanman_auth = lp_client_lanman_auth,
101         .client_ntlmv2_auth = lp_client_ntlmv2_auth,
102
103         .private_dir = lp_private_dir,
104         .ncalrpc_dir = lp_ncalrpc_dir,
105         .lockdir = lp_lockdir,
106
107         .passdb_backend = lp_passdb_backend,
108
109         .host_msdfs = lp_host_msdfs,
110         .unix_extensions = lp_unix_extensions,
111         .use_spnego = lp_use_spnego,
112         .use_mmap = lp_use_mmap,
113 };
114
115 const struct loadparm_s3_context *loadparm_s3_context(void)
116 {
117         return &s3_fns;
118 }