X-Git-Url: https://uglyman.kremlin.cc/gitweb/gitweb.cgi?a=blobdiff_plain;f=src%2Fconfig.c;h=21396a522c8e0f91de4ade1972a2422ecb33b829;hb=76b67a1868f8e9f47121d87819147ac157889432;hp=3376fb8be90fcdb0cb2d85f4a58ac18906043602;hpb=3b82e3c1701831a4cc48a42a992997610bdd6266;p=systembsd.git diff --git a/src/config.c b/src/config.c index 3376fb8..21396a5 100644 --- a/src/config.c +++ b/src/config.c @@ -17,95 +17,156 @@ #include #include #include +#include "config.h" static GKeyFile *config; - -static const gchar *CONFIG_KEYS[] = { - "PrettyHostname", - "IconName", - "ChassisType" -}; +static int config_descr; +static gchar *data_dir; /* NULL if key doesn't exist */ gchar *get_option(gchar *key, gchar *group) { - if(!group) - group = "default"; + if(!group) + group = "default"; - return g_key_file_get_string(config, group, key, NULL); + return g_key_file_get_string(config, group, key, NULL); } /* false if key isn't already defined or value is invalid */ gboolean set_option(gchar *key, gchar *value, gchar *group) { - if(!group) - group = "default"; + if(!group) + group = "default"; - if(!g_key_file_get_string(config, group, key, NULL)) - return FALSE; + if(!g_key_file_get_string(config, group, key, NULL)) + return FALSE; - //TODO safteycheck value - g_key_file_set_string(config, group, key, value); - return TRUE; + /* TODO safteycheck value */ + g_key_file_set_string(config, group, key, value); + return TRUE; } /* initial load/check */ gboolean config_init() { - if(config) - return TRUE; //already init'd + /* config is already set */ + if(config) + return TRUE; + + config = g_key_file_new(); + + const gchar *config_path; + GStatBuf *config_lstat; + int config_lstat_ret; + + config_path = "/etc/systemd_compat.conf"; + config_lstat_ret = g_lstat(config_path, config_lstat); - config = g_key_file_new(); - - const gchar *config_path; - GStatBuf *config_lstat; + /* this should all be handled in the makefile + * does conf exist? + if(config_lstat_ret) { - config_path = "/etc/systemd_compat.conf"; + if(g_access("/etc/", W_OK)) { + g_printf("%s\n", "no write permissions for /etc/! exiting.."); + return FALSE; + } - /* does conf exist? */ - if(g_lstat(config_path, config_lstat)) { + int config_descr; + config_descr = g_open(config_path, O_CREAT, 644); - /* if not, can we write it */ - if(g_access("/etc/", W_OK)) { - g_printf("%s\n", "no write permissions for /etc/! exiting.."); - return FALSE; - } + gchar *posix_hostname; + posix_hostname = g_malloc(HOST_NAME_MAX); - int config_descr; - config_descr = g_open(config_path, O_CREAT, 644); + gethostname(posix_hostname, HOST_NAME_MAX); - gchar *posix_hostname; - posix_hostname = g_malloc(255); + g_key_file_set_string(config, "hostnamed", "Hostname", posix_hostname); + g_key_file_set_string(config, "hostnamed", "PrettyHostname", ""); + g_key_file_set_string(config, "hostnamed", "IconName", "Computer"); + g_key_file_set_string(config, "hostnamed", "ChassisType","laptop"); - gethostname(posix_hostname, 255); + if(!g_key_file_save_to_file(config, config_path, NULL)) { + g_printf("failed to write config to %s!\n", config_path); + g_free(posix_hostname); + return FALSE; + } - g_key_file_set_string(config, "hostnamed", "Hostname", posix_hostname); - g_key_file_set_string(config, "hostnamed", "PrettyHostname", ""); - g_key_file_set_string(config, "hostnamed", "IconName", "Computer"); - g_key_file_set_string(config, "hostnamed", "ChassisType", "laptop"); //TODO set these correctly + g_printf("wrote config to %s\n", config_path); - if(!g_key_file_save_to_file(config, config_path, NULL)) { - g_printf("failed to write config to %s!\n", config_path); - g_free(posix_hostname); - return FALSE; - } + g_free(posix_hostname); - g_printf("wrote config to %s\n", config_path); + return TRUE; - g_free(posix_hostname); + } else { */ - return TRUE; + if(g_access(config_path, W_OK)) { - /* it does exist, read it */ - } else { + g_printf("%s\n", "no write permissions for /etc/! exiting.."); + return FALSE; - if(!g_access(config_path, W_OK)) { - g_printf("%s\n", "no write permissions for /etc/! exiting.."); - return FALSE; - } else if(g_key_file_load_from_file(config, config_path, G_KEY_FILE_KEEP_COMMENTS, NULL)) - return TRUE; + } else if(g_key_file_load_from_file(config, config_path, G_KEY_FILE_KEEP_COMMENTS, NULL)) + return TRUE; - g_printf("could not read config at %s! exiting..", config_path); - return FALSE; - } + g_printf("could not read config at %s! exiting..", config_path); + return FALSE; +} +/* this definitely does not need to exist +gboolean init_xml() { + + const gchar * const *data_dir_prefix; + int xml_lstat_ret; + GStatBuf *xml_lstat; + + data_dir_prefix = g_get_system_data_dirs(); + data_dir = g_strconcat(data_dir_prefix[0], "systemd_compat", NULL); + + xml_lstat_ret = g_lstat(data_dir, xml_lstat); + + if(xml_lstat_ret) { + + if(g_access(data_dir_prefix[0], W_OK)) { + g_printf("no write permissions for %s! exiting...\n", data_dir_prefix[0]); + return FALSE; + } + + g_printf("creating xml data directory %s...\n", data_dir); + + if(g_mkdir(data_dir, 644) || g_access) { + g_printf("failed to create dir %s...\n", data_dir); + return FALSE; + } + + if(!read_xml_from_installconf()) { + g_printf("failed to read xml configs in conf/...\n"); + return FALSE; + } + + if(!populate_xml_data_dir()) { + g_printf("failed to write xml configs to %s...\n", data_dir); + return FALSE; + } + + if(!set_xml_descriptors()) { + g_printf("failed to fopen xml configs...\n"); + return FALSE; + } + + return TRUE; + + } else { + + if(!set_xml_descriptors()) { + g_printf("failed to fopen xml configs...\n"); + return FALSE; + } + + return TRUE; + } +} */ + +void clean_config() { + + /* TODO g_ptr_array all of this */ + g_free(config); + g_free(data_dir); + g_close(config_descr, NULL); }