X-Git-Url: https://uglyman.kremlin.cc/gitweb/gitweb.cgi?a=blobdiff_plain;f=src%2Fconfig.c;h=f76b42039997b056373f0b6cc7dcff1563eff4a6;hb=4241079f6154438e2ed64ee1a46b4cba6f1cde01;hp=189eb235f507788493b2e5bce8a2be97980c9078;hpb=1c38000a88055e0893fb0b6b41a490109348b950;p=systembsd.git diff --git a/src/config.c b/src/config.c index 189eb23..f76b420 100644 --- a/src/config.c +++ b/src/config.c @@ -3,6 +3,20 @@ #include static GKeyFile *config; +static int config_descr; + +static gchar *data_dir; + +static int hostnamed_ispect_xml_descr, hostnamed_dbus_xml_descr; +static int localed_ispect_xml_descr, localed_dbus_xml_descr; +static int timedated_ispect_xml_descr, timedated_dbus_xml_descr; +static int logind_ispect_xml_descr, logind_dbus_xml_descr; + +/*TODO depending on builtin xml flag, these should be matched to checksums */ +static gchar **hostnamed_ispect_xml, hostnamed_dbus_xml; +static gchar **localed_ispect_xml, localed_dbus_xml; +static gchar **timedated_ispect_xml, timedated_dbus_xml; +static gchar **logind_ispect_xml, logind_dbus_xml; static const gchar *CONFIG_KEYS[] = { "PrettyHostname", @@ -34,45 +48,143 @@ gboolean set_option(gchar *key, gchar *value, gchar *group) { } /* initial load/check */ - gboolean config_init() { - static gchar *config_path; - int tryopen = 0; - /* config is already good to go */ if(config) + return TRUE; //already init'd + + config = g_key_file_new(); + + const gchar *config_path; + GStatBuf *config_lstat; + + config_path = "/etc/systemd_compat.conf"; + + /* does conf exist? */ + if(g_lstat(config_path, config_lstat)) { + + /* if not, can we write it? */ + if(g_access("/etc/", W_OK)) { + g_printf("%s\n", "no write permissions for /etc/! exiting.."); + return FALSE; + } + + config_descr = g_open(config_path, O_CREAT, 644); + + gchar *posix_hostname; + posix_hostname = g_malloc(255); + + gethostname(posix_hostname, 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"); //TODO set these correctly + + 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_printf("wrote config to %s\n", config_path); + + g_free(posix_hostname); + return TRUE; - /* does config file exist? if not, write one */ - else if(!g_key_file_load_from_data(config, "systemd_compat.conf", &config_path, G_KEY_FILE_KEEP_COMMENTS, NULL)) { - - tryopen = g_open("/etc/systemd_compat.conf", O_CREAT, 644); - - //TODO clean this up, use g_data_dirs and g_exit - /* can we open it rw? */ - if(!g_access("/etc/systemd_compat.conf", W_OK) && !tryopen) { - g_printf("%s\n", "ERROR: cannot open systemd_compat.conf as read/write!"); - return FALSE; - } - - if(tryopen) { - config_path = "/etc/systemd_compat.conf"; - g_close(tryopen, NULL); - } - - //TODO set these properly - config = g_key_file_new(); - - 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"); - - if(!g_key_file_save_to_file(config, config_path, NULL)) - return FALSE; + /* it does exist, read it */ + } else { + 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)) { + config_descr = g_open(config_path, O_RDWR, 644); return TRUE; + } + + g_printf("could not read config at %s! exiting..", config_path); + return FALSE; + } +} + +gboolean init_xml() { + + gchar **data_dir_prefix; + + data_dir_prefix = g_get_system_data_dirs(); + data_dir = g_strconcat(data_dir_prefix[0], "systemd_compat", NULL); + + GStatBuf *xml_lstat; + + /* does xml dir exist? */ + if(g_lstat(data_dir, xml_lstat)) { + + /* if not, can we write it? */ + 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_printf("failed to create dir %s...\n", data_dir); + return FALSE; + } + + set_xml_descriptors(); +//LEFTOFF + + gchar *posix_hostname; + posix_hostname = g_malloc(255); + + gethostname(posix_hostname, 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"); //TODO set these correctly + + 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_printf("wrote config to %s\n", config_path); + + g_free(posix_hostname); - /* it does it exist and was written to config var */ - } else return TRUE; + + /* it does exist, read it */ + } else { + + 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)) { + config_descr = g_open(config_path, O_RDWR, 644); + return TRUE; + } + + g_printf("could not read config at %s! exiting..", config_path); + return FALSE; + } + + + return TRUE; +} + +static void set_xml_descriptors() { + +} + +void clean_config() { + + //TODO g_ptr_array all of this + g_free(config); + g_free(data_dir); + g_close(config_descr, NULL); }