goodnight
authorkremlin <ian@kremlin.cc>
Fri, 20 Jun 2014 05:26:47 +0000 (00:26 -0500)
committerkremlin <ian@kremlin.cc>
Fri, 20 Jun 2014 05:26:47 +0000 (00:26 -0500)
TODO
src/config.c
src/main.c

diff --git a/TODO b/TODO
index 1f986f42e727fc859c99b1644546b8e12ffd6a4f..8463eba0eb407c926fdf3d8406fc549fbc7409cb 100644 (file)
--- a/TODO
+++ b/TODO
@@ -1 +1,2 @@
  * get autoconf stuff figured out
+ * handle SIGINTs so file descriptors are dropped properly, otherwise we get bus errors next run
index 2b5ec0610cfa1d58d0fbff659c11e562ec21d245..f76b42039997b056373f0b6cc7dcff1563eff4a6 100644 (file)
@@ -5,6 +5,19 @@
 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",
        "IconName",
@@ -50,7 +63,7 @@ gboolean config_init() {
        /* does conf exist? */
        if(g_lstat(config_path, config_lstat)) {
 
-               /* if not, can we write it */
+               /* if not, can we write it? */
                if(g_access("/etc/", W_OK)) {
                        g_printf("%s\n", "no write permissions for /etc/! exiting..");
                        return FALSE;
@@ -96,12 +109,82 @@ gboolean config_init() {
        }
 }
 
-void clean_config() {
+gboolean init_xml() {
 
-       if(config)
-               g_free(config);
+       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;
+               }
 
-       if(config_descr)
-               g_close(config_descr, NULL);
+               g_printf("wrote config to %s\n", config_path);
+
+               g_free(posix_hostname);
+
+               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);
 }
index 82d68f8da7f1f5397d05ae468d631dc3214bc88f..3e80e28e989d91de16cd8470ab6ce746fff16b3d 100644 (file)
 gboolean systemd_utils_init() {
        #ifdef INSTALL
                if(!config_init()) {
-                       g_printf("%s\n", "FAILED to install configs in /etc/!");
-                       return FALSE; 
+                       gchar *tmp;
+                       tmp = "/etc/"; //what the hell is /etc/xdg anyway
+
+                       g_printf("FAILED to install configs in %s!\n", tmp);
+                       return FALSE;
+               } 
+               if(!init_xml()) {
+                       gchar **tmp;
+                       tmp = g_get_system_data_dirs();
+
+                       g_printf("FAILED to install xml configs in %s!\n", tmp[0]);
+                       return FALSE;
                }
        #endif
        return TRUE;