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