Move more config file code from krb5 to base
This commit is contained in:
@@ -90,7 +90,7 @@ libheimbase_OBJS = \
|
||||
libheimbase_gen_OBJS= $(OBJ)\heim_err.obj
|
||||
|
||||
$(LIBHEIMBASE): $(libheimbase_OBJS) $(libheimbase_gen_OBJS)
|
||||
$(LIBCON_C) -OUT:$@ $(LIBROKEN) $(PTHREAD_LIB) Secur32.lib Shell32.lib Advapi32.lib @<<
|
||||
$(LIBCON_C) -OUT:$@ $(LIBROKEN) $(PTHREAD_LIB) Secur32.lib Shell32.lib Advapi32.lib Shlwapi.lib @<<
|
||||
$(libheimbase_OBJS: =
|
||||
)
|
||||
$(libheimbase_gen_OBJS: =
|
||||
|
@@ -232,3 +232,207 @@ heim_set_debug_dest(heim_context context, heim_log_facility *fac)
|
||||
context->debug_dest = fac;
|
||||
return 0;
|
||||
}
|
||||
|
||||
#define PATH_SEP ":"
|
||||
|
||||
static heim_error_code
|
||||
add_file(char ***pfilenames, int *len, char *file)
|
||||
{
|
||||
char **pp = *pfilenames;
|
||||
int i;
|
||||
|
||||
for(i = 0; i < *len; i++) {
|
||||
if(strcmp(pp[i], file) == 0) {
|
||||
free(file);
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
|
||||
pp = realloc(*pfilenames, (*len + 2) * sizeof(*pp));
|
||||
if (pp == NULL) {
|
||||
free(file);
|
||||
return ENOMEM;
|
||||
}
|
||||
|
||||
pp[*len] = file;
|
||||
pp[*len + 1] = NULL;
|
||||
*pfilenames = pp;
|
||||
*len += 1;
|
||||
return 0;
|
||||
}
|
||||
|
||||
#ifdef WIN32
|
||||
static char *
|
||||
get_default_config_config_files_from_registry(void)
|
||||
{
|
||||
static const char *KeyName = "Software\\Heimdal"; /* XXX #define this */
|
||||
char *config_file = NULL;
|
||||
LONG rcode;
|
||||
HKEY key;
|
||||
|
||||
rcode = RegOpenKeyEx(HKEY_CURRENT_USER, KeyName, 0, KEY_READ, &key);
|
||||
if (rcode == ERROR_SUCCESS) {
|
||||
config_file = heim_parse_reg_value_as_multi_string(NULL, key, "config",
|
||||
REG_NONE, 0, PATH_SEP);
|
||||
RegCloseKey(key);
|
||||
}
|
||||
|
||||
if (config_file)
|
||||
return config_file;
|
||||
|
||||
rcode = RegOpenKeyEx(HKEY_LOCAL_MACHINE, KeyName, 0, KEY_READ, &key);
|
||||
if (rcode == ERROR_SUCCESS) {
|
||||
config_file = heim_parse_reg_value_as_multi_string(NULL, key, "config",
|
||||
REG_NONE, 0, PATH_SEP);
|
||||
RegCloseKey(key);
|
||||
}
|
||||
|
||||
return config_file;
|
||||
}
|
||||
#endif
|
||||
|
||||
heim_error_code
|
||||
heim_prepend_config_files(const char *filelist,
|
||||
char **pq,
|
||||
char ***ret_pp)
|
||||
{
|
||||
heim_error_code ret;
|
||||
const char *p, *q;
|
||||
char **pp;
|
||||
int len;
|
||||
char *fn;
|
||||
|
||||
pp = NULL;
|
||||
|
||||
len = 0;
|
||||
p = filelist;
|
||||
while(1) {
|
||||
ssize_t l;
|
||||
q = p;
|
||||
l = strsep_copy(&q, PATH_SEP, NULL, 0);
|
||||
if(l == -1)
|
||||
break;
|
||||
fn = malloc(l + 1);
|
||||
if(fn == NULL) {
|
||||
heim_free_config_files(pp);
|
||||
return ENOMEM;
|
||||
}
|
||||
(void) strsep_copy(&p, PATH_SEP, fn, l + 1);
|
||||
ret = add_file(&pp, &len, fn);
|
||||
if (ret) {
|
||||
heim_free_config_files(pp);
|
||||
return ret;
|
||||
}
|
||||
}
|
||||
|
||||
if (pq != NULL) {
|
||||
int i;
|
||||
|
||||
for (i = 0; pq[i] != NULL; i++) {
|
||||
fn = strdup(pq[i]);
|
||||
if (fn == NULL) {
|
||||
heim_free_config_files(pp);
|
||||
return ENOMEM;
|
||||
}
|
||||
ret = add_file(&pp, &len, fn);
|
||||
if (ret) {
|
||||
heim_free_config_files(pp);
|
||||
return ret;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
*ret_pp = pp;
|
||||
return 0;
|
||||
}
|
||||
|
||||
heim_error_code
|
||||
heim_prepend_config_files_default(const char *prepend,
|
||||
const char *def,
|
||||
const char *envvar,
|
||||
char ***pfilenames)
|
||||
{
|
||||
heim_error_code ret;
|
||||
char **defpp, **pp = NULL;
|
||||
|
||||
ret = heim_get_default_config_files(def, envvar, &defpp);
|
||||
if (ret)
|
||||
return ret;
|
||||
|
||||
ret = heim_prepend_config_files(prepend, defpp, &pp);
|
||||
heim_free_config_files(defpp);
|
||||
if (ret) {
|
||||
return ret;
|
||||
}
|
||||
*pfilenames = pp;
|
||||
return 0;
|
||||
}
|
||||
|
||||
heim_error_code
|
||||
heim_get_default_config_files(const char *def,
|
||||
const char *envvar,
|
||||
char ***pfilenames)
|
||||
{
|
||||
const char *files = NULL;
|
||||
|
||||
files = secure_getenv(envvar);
|
||||
|
||||
#ifdef _WIN32
|
||||
if (files == NULL) {
|
||||
char * reg_files;
|
||||
reg_files = get_default_config_config_files_from_registry();
|
||||
if (reg_files != NULL) {
|
||||
heim_error_code code;
|
||||
|
||||
code = heim_prepend_config_files(reg_files, NULL, pfilenames);
|
||||
free(reg_files);
|
||||
|
||||
return code;
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
if (files == NULL)
|
||||
files = def;
|
||||
return heim_prepend_config_files(files, NULL, pfilenames);
|
||||
}
|
||||
|
||||
#ifdef _WIN32
|
||||
#define REGPATH_KERBEROS "SOFTWARE\\Kerberos"
|
||||
#define REGPATH_HEIMDAL "SOFTWARE\\Heimdal"
|
||||
#endif
|
||||
|
||||
heim_error_code
|
||||
heim_set_config_files(heim_context context, char **filenames,
|
||||
heim_config_binding **res)
|
||||
{
|
||||
heim_error_code ret;
|
||||
|
||||
*res = NULL;
|
||||
while (filenames != NULL && *filenames != NULL && **filenames != '\0') {
|
||||
ret = heim_config_parse_file_multi(context, *filenames, res);
|
||||
if (ret != 0 && ret != ENOENT && ret != EACCES && ret != EPERM
|
||||
&& ret != HEIM_ERR_CONFIG_BADFORMAT) {
|
||||
heim_config_file_free(context, *res);
|
||||
*res = NULL;
|
||||
return ret;
|
||||
}
|
||||
filenames++;
|
||||
}
|
||||
|
||||
#ifdef _WIN32
|
||||
heim_load_config_from_registry(context, REGPATH_KERBEROS,
|
||||
REGPATH_HEIMDAL, res);
|
||||
#endif
|
||||
return ret;
|
||||
}
|
||||
|
||||
void
|
||||
heim_free_config_files(char **filenames)
|
||||
{
|
||||
char **p;
|
||||
|
||||
for (p = filenames; p && *p != NULL; p++)
|
||||
free(*p);
|
||||
free(filenames);
|
||||
}
|
||||
|
@@ -1,4 +1,3 @@
|
||||
|
||||
HEIMDAL_BASE_1.0 {
|
||||
global:
|
||||
_bsearch_file;
|
||||
@@ -117,8 +116,10 @@ HEIMDAL_BASE_1.0 {
|
||||
heim_error_get_code;
|
||||
heim_expand_path_tokens;
|
||||
heim_expand_path_tokensv;
|
||||
heim_free_config_files;
|
||||
heim_free_error_message;
|
||||
heim_get_debug_dest;
|
||||
heim_get_default_config_files;
|
||||
heim_get_error_message;
|
||||
heim_get_hash;
|
||||
_heim_get_isa;
|
||||
@@ -149,9 +150,12 @@ HEIMDAL_BASE_1.0 {
|
||||
heim_path_vget;
|
||||
heim_plugin_register;
|
||||
heim_plugin_run_f;
|
||||
heim_prepend_config_files;
|
||||
heim_prepend_config_files_default;
|
||||
heim_prepend_error_message;
|
||||
heim_release;
|
||||
heim_retain;
|
||||
heim_set_config_files;
|
||||
heim_set_debug_dest;
|
||||
heim_set_error_message;
|
||||
heim_set_warn_dest;
|
||||
|
@@ -712,11 +712,6 @@ krb5_free_context(krb5_context context)
|
||||
free(context);
|
||||
}
|
||||
|
||||
#ifdef _WIN32
|
||||
#define REGPATH_KERBEROS "SOFTWARE\\Kerberos"
|
||||
#define REGPATH_HEIMDAL "SOFTWARE\\Heimdal"
|
||||
#endif
|
||||
|
||||
/**
|
||||
* Reinit the context from a new set of filenames.
|
||||
*
|
||||
@@ -733,31 +728,10 @@ KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
|
||||
krb5_set_config_files(krb5_context context, char **filenames)
|
||||
{
|
||||
krb5_error_code ret;
|
||||
krb5_config_binding *tmp = NULL;
|
||||
while(filenames != NULL && *filenames != NULL && **filenames != '\0') {
|
||||
ret = krb5_config_parse_file_multi(context, *filenames, &tmp);
|
||||
if (ret != 0 && ret != ENOENT && ret != EACCES && ret != EPERM
|
||||
&& ret != KRB5_CONFIG_BADFORMAT) {
|
||||
krb5_config_file_free(context, tmp);
|
||||
return ret;
|
||||
}
|
||||
filenames++;
|
||||
}
|
||||
#if 0
|
||||
/* with this enabled and if there are no config files, Kerberos is
|
||||
considererd disabled */
|
||||
if(tmp == NULL)
|
||||
return ENXIO;
|
||||
#endif
|
||||
|
||||
#ifdef _WIN32
|
||||
heim_load_config_from_registry(context->hcontext, REGPATH_KERBEROS,
|
||||
REGPATH_HEIMDAL, &tmp);
|
||||
#endif
|
||||
|
||||
krb5_config_file_free(context, context->cf);
|
||||
context->cf = tmp;
|
||||
ret = init_context_from_config_file(context);
|
||||
if ((ret = heim_set_config_files(context->hcontext, filenames,
|
||||
&context->cf)) == 0)
|
||||
ret = init_context_from_config_file(context);
|
||||
return ret;
|
||||
}
|
||||
|
||||
@@ -830,54 +804,7 @@ add_file(char ***pfilenames, int *len, char *file)
|
||||
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
|
||||
krb5_prepend_config_files(const char *filelist, char **pq, char ***ret_pp)
|
||||
{
|
||||
krb5_error_code ret;
|
||||
const char *p, *q;
|
||||
char **pp;
|
||||
int len;
|
||||
char *fn;
|
||||
|
||||
pp = NULL;
|
||||
|
||||
len = 0;
|
||||
p = filelist;
|
||||
while(1) {
|
||||
ssize_t l;
|
||||
q = p;
|
||||
l = strsep_copy(&q, PATH_SEP, NULL, 0);
|
||||
if(l == -1)
|
||||
break;
|
||||
fn = malloc(l + 1);
|
||||
if(fn == NULL) {
|
||||
krb5_free_config_files(pp);
|
||||
return ENOMEM;
|
||||
}
|
||||
(void)strsep_copy(&p, PATH_SEP, fn, l + 1);
|
||||
ret = add_file(&pp, &len, fn);
|
||||
if (ret) {
|
||||
krb5_free_config_files(pp);
|
||||
return ret;
|
||||
}
|
||||
}
|
||||
|
||||
if (pq != NULL) {
|
||||
int i;
|
||||
|
||||
for (i = 0; pq[i] != NULL; i++) {
|
||||
fn = strdup(pq[i]);
|
||||
if (fn == NULL) {
|
||||
krb5_free_config_files(pp);
|
||||
return ENOMEM;
|
||||
}
|
||||
ret = add_file(&pp, &len, fn);
|
||||
if (ret) {
|
||||
krb5_free_config_files(pp);
|
||||
return ret;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
*ret_pp = pp;
|
||||
return 0;
|
||||
return heim_prepend_config_files(filelist, pq, ret_pp);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -895,61 +822,10 @@ krb5_prepend_config_files(const char *filelist, char **pq, char ***ret_pp)
|
||||
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
|
||||
krb5_prepend_config_files_default(const char *filelist, char ***pfilenames)
|
||||
{
|
||||
krb5_error_code ret;
|
||||
char **defpp, **pp = NULL;
|
||||
|
||||
ret = krb5_get_default_config_files(&defpp);
|
||||
if (ret)
|
||||
return ret;
|
||||
|
||||
ret = krb5_prepend_config_files(filelist, defpp, &pp);
|
||||
krb5_free_config_files(defpp);
|
||||
if (ret) {
|
||||
return ret;
|
||||
}
|
||||
*pfilenames = pp;
|
||||
return 0;
|
||||
return heim_prepend_config_files_default(filelist, krb5_config_file,
|
||||
"KRB5_CONFIG", pfilenames);
|
||||
}
|
||||
|
||||
#ifdef _WIN32
|
||||
|
||||
/**
|
||||
* Checks the registry for configuration file location
|
||||
*
|
||||
* Kerberos for Windows and other legacy Kerberos applications expect
|
||||
* to find the configuration file location in the
|
||||
* SOFTWARE\MIT\Kerberos registry key under the value "config".
|
||||
*/
|
||||
KRB5_LIB_FUNCTION char * KRB5_LIB_CALL
|
||||
_krb5_get_default_config_config_files_from_registry()
|
||||
{
|
||||
static const char * KeyName = "Software\\MIT\\Kerberos";
|
||||
char *config_file = NULL;
|
||||
LONG rcode;
|
||||
HKEY key;
|
||||
|
||||
rcode = RegOpenKeyEx(HKEY_CURRENT_USER, KeyName, 0, KEY_READ, &key);
|
||||
if (rcode == ERROR_SUCCESS) {
|
||||
config_file = heim_parse_reg_value_as_multi_string(NULL, key, "config",
|
||||
REG_NONE, 0, PATH_SEP);
|
||||
RegCloseKey(key);
|
||||
}
|
||||
|
||||
if (config_file)
|
||||
return config_file;
|
||||
|
||||
rcode = RegOpenKeyEx(HKEY_LOCAL_MACHINE, KeyName, 0, KEY_READ, &key);
|
||||
if (rcode == ERROR_SUCCESS) {
|
||||
config_file = heim_parse_reg_value_as_multi_string(NULL, key, "config",
|
||||
REG_NONE, 0, PATH_SEP);
|
||||
RegCloseKey(key);
|
||||
}
|
||||
|
||||
return config_file;
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
/**
|
||||
* Get the global configuration list.
|
||||
*
|
||||
@@ -964,31 +840,10 @@ _krb5_get_default_config_config_files_from_registry()
|
||||
KRB5_LIB_FUNCTION krb5_error_code KRB5_LIB_CALL
|
||||
krb5_get_default_config_files(char ***pfilenames)
|
||||
{
|
||||
const char *files = NULL;
|
||||
|
||||
if (pfilenames == NULL)
|
||||
return EINVAL;
|
||||
files = secure_getenv("KRB5_CONFIG");
|
||||
|
||||
#ifdef _WIN32
|
||||
if (files == NULL) {
|
||||
char * reg_files;
|
||||
reg_files = _krb5_get_default_config_config_files_from_registry();
|
||||
if (reg_files != NULL) {
|
||||
krb5_error_code code;
|
||||
|
||||
code = krb5_prepend_config_files(reg_files, NULL, pfilenames);
|
||||
free(reg_files);
|
||||
|
||||
return code;
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
if (files == NULL)
|
||||
files = krb5_config_file;
|
||||
|
||||
return krb5_prepend_config_files(files, NULL, pfilenames);
|
||||
return heim_get_default_config_files(krb5_config_file, "KRB5_CONFIG",
|
||||
pfilenames);
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -1006,10 +861,7 @@ krb5_get_default_config_files(char ***pfilenames)
|
||||
KRB5_LIB_FUNCTION void KRB5_LIB_CALL
|
||||
krb5_free_config_files(char **filenames)
|
||||
{
|
||||
char **p;
|
||||
for(p = filenames; p && *p != NULL; p++)
|
||||
free(*p);
|
||||
free(filenames);
|
||||
heim_free_config_files(filenames);
|
||||
}
|
||||
|
||||
/**
|
||||
|
Reference in New Issue
Block a user