diff options
author | Matthias Dieter Wallnöfer <mwallnoefer@yahoo.de> | 2009-10-13 18:18:50 +0200 |
---|---|---|
committer | Matthias Dieter Wallnöfer <mwallnoefer@yahoo.de> | 2009-10-14 09:32:16 +0200 |
commit | ccfbe7bcb1f09530091ad6c986eae19a378bd2ea (patch) | |
tree | cfea8b21268c2b74cec8ec897a491a9a631e9f13 /source4 | |
parent | 8e91c40574ce30a053ff8979e69205d15fb89a5c (diff) | |
download | samba-ccfbe7bcb1f09530091ad6c986eae19a378bd2ea.tar.gz samba-ccfbe7bcb1f09530091ad6c986eae19a378bd2ea.tar.bz2 samba-ccfbe7bcb1f09530091ad6c986eae19a378bd2ea.zip |
s4:loadparm - adapt "realm" handling
Change "lp_realm" behaviour to return the realm always upcased and add a
function "lp_dnsdomain" which returns it always lowcased.
Diffstat (limited to 'source4')
-rw-r--r-- | source4/param/loadparm.c | 26 | ||||
-rw-r--r-- | source4/param/param.h | 1 |
2 files changed, 24 insertions, 3 deletions
diff --git a/source4/param/loadparm.c b/source4/param/loadparm.c index f7cd95bf4c..882de1330e 100644 --- a/source4/param/loadparm.c +++ b/source4/param/loadparm.c @@ -103,6 +103,8 @@ struct loadparm_global const char **szPasswordServers; char *szSocketOptions; char *szRealm; + char *szRealm_upper; + char *szRealm_lower; const char **szWINSservers; const char **szInterfaces; char *szSocketAddress; @@ -234,6 +236,8 @@ struct loadparm_service /* prototypes for the special type handlers */ static bool handle_include(struct loadparm_context *lp_ctx, const char *pszParmValue, char **ptr); +static bool handle_realm(struct loadparm_context *lp_ctx, + const char *pszParmValue, char **ptr); static bool handle_copy(struct loadparm_context *lp_ctx, const char *pszParmValue, char **ptr); static bool handle_debuglevel(struct loadparm_context *lp_ctx, @@ -339,7 +343,7 @@ static struct parm_struct parm_table[] = { {"path", P_STRING, P_LOCAL, LOCAL_VAR(szPath), NULL, NULL}, {"directory", P_STRING, P_LOCAL, LOCAL_VAR(szPath), NULL, NULL}, {"workgroup", P_USTRING, P_GLOBAL, GLOBAL_VAR(szWorkgroup), NULL, NULL}, - {"realm", P_STRING, P_GLOBAL, GLOBAL_VAR(szRealm), NULL, NULL}, + {"realm", P_STRING, P_GLOBAL, GLOBAL_VAR(szRealm), handle_realm, NULL}, {"netbios name", P_USTRING, P_GLOBAL, GLOBAL_VAR(szNetbiosName), NULL, NULL}, {"netbios aliases", P_LIST, P_GLOBAL, GLOBAL_VAR(szNetbiosAliases), NULL, NULL}, {"netbios scope", P_USTRING, P_GLOBAL, GLOBAL_VAR(szNetbiosScope), NULL, NULL}, @@ -648,7 +652,8 @@ _PUBLIC_ FN_GLOBAL_STRING(lp_auto_services, szAutoServices) _PUBLIC_ FN_GLOBAL_STRING(lp_passwd_chat, szPasswdChat) _PUBLIC_ FN_GLOBAL_LIST(lp_passwordserver, szPasswordServers) _PUBLIC_ FN_GLOBAL_LIST(lp_name_resolve_order, szNameResolveOrder) -_PUBLIC_ FN_GLOBAL_STRING(lp_realm, szRealm) +_PUBLIC_ FN_GLOBAL_STRING(lp_realm, szRealm_upper) +_PUBLIC_ FN_GLOBAL_STRING(lp_dnsdomain, szRealm_lower) _PUBLIC_ FN_GLOBAL_STRING(lp_socket_options, socket_options) _PUBLIC_ FN_GLOBAL_STRING(lp_workgroup, szWorkgroup) _PUBLIC_ FN_GLOBAL_STRING(lp_netbios_name, szNetbiosName) @@ -657,7 +662,6 @@ _PUBLIC_ FN_GLOBAL_LIST(lp_wins_server_list, szWINSservers) _PUBLIC_ FN_GLOBAL_LIST(lp_interfaces, szInterfaces) _PUBLIC_ FN_GLOBAL_STRING(lp_socket_address, szSocketAddress) _PUBLIC_ FN_GLOBAL_LIST(lp_netbios_aliases, szNetbiosAliases) - _PUBLIC_ FN_GLOBAL_BOOL(lp_disable_netbios, bDisableNetbios) _PUBLIC_ FN_GLOBAL_BOOL(lp_wins_support, bWINSsupport) _PUBLIC_ FN_GLOBAL_BOOL(lp_wins_dns_proxy, bWINSdnsProxy) @@ -695,6 +699,7 @@ _PUBLIC_ FN_GLOBAL_INTEGER(lp_cli_minprotocol, cli_minprotocol) _PUBLIC_ FN_GLOBAL_INTEGER(lp_security, security) _PUBLIC_ FN_GLOBAL_BOOL(lp_paranoid_server_security, paranoid_server_security) _PUBLIC_ FN_GLOBAL_INTEGER(lp_announce_as, announce_as) + const char *lp_servicename(const struct loadparm_service *service) { return lp_string((const char *)service->szService); @@ -1448,6 +1453,21 @@ bool lp_file_list_changed(struct loadparm_context *lp_ctx) } /*************************************************************************** + Handle the "realm" parameter +***************************************************************************/ + +static bool handle_realm(struct loadparm_context *lp_ctx, + const char *pszParmValue, char **ptr) +{ + string_set(lp_ctx, ptr, pszParmValue); + + lp_ctx->globals->szRealm_upper = strupper_talloc(lp_ctx, pszParmValue); + lp_ctx->globals->szRealm_lower = strlower_talloc(lp_ctx, pszParmValue); + + return true; +} + +/*************************************************************************** Handle the include operation. ***************************************************************************/ diff --git a/source4/param/param.h b/source4/param/param.h index 5c49f34e2a..0c8e73ecaa 100644 --- a/source4/param/param.h +++ b/source4/param/param.h @@ -115,6 +115,7 @@ const char *lp_passwd_chat(struct loadparm_context *); const char **lp_passwordserver(struct loadparm_context *); const char **lp_name_resolve_order(struct loadparm_context *); const char *lp_realm(struct loadparm_context *); +const char *lp_dnsdomain(struct loadparm_context *); const char *lp_socket_options(struct loadparm_context *); const char *lp_workgroup(struct loadparm_context *); const char *lp_netbios_name(struct loadparm_context *); |