Remove codes to launch mdnsd
[platform/core/connectivity/net-config.git] / src / network-clock.c
old mode 100644 (file)
new mode 100755 (executable)
index eeaa798..98bf2e8
@@ -40,6 +40,7 @@ static void __netconfig_clock_clear_timeserver(void)
        g_key_file_remove_key(keyfile, "global", "Timeservers", NULL);
 
        netconfig_keyfile_save(keyfile, CONNMAN_GLOBAL_SETTING);
+       g_key_file_free(keyfile);
 }
 
 static gboolean __netconfig_clock_clear_timeserver_timer(gpointer data)
@@ -58,10 +59,10 @@ static void __netconfig_clock_set_timeserver(const char *server)
        GVariant *params = NULL;
        GVariantBuilder *builder;
 
-       builder = g_variant_builder_new(G_VARIANT_TYPE ("as"));
+       builder = g_variant_builder_new(G_VARIANT_TYPE("as"));
        g_variant_builder_add(builder, "s", server);
 
-       params = g_variant_new("(sv)",param0, g_variant_builder_end(builder));
+       params = g_variant_new("(sv)", param0, g_variant_builder_end(builder));
        g_variant_builder_unref(builder);
 
        reply = netconfig_invoke_dbus_method(CONNMAN_SERVICE,
@@ -76,9 +77,41 @@ static void __netconfig_clock_set_timeserver(const char *server)
        return;
 }
 
+static void __netconfig_clock_unset_timeserver(void)
+{
+       GVariant* reply = NULL;
+       const char param0[] = "Timeservers";
+       const char server[] = "";
+       GVariant *params = NULL;
+       GVariantBuilder *builder;
+
+       builder = g_variant_builder_new(G_VARIANT_TYPE("as"));
+       g_variant_builder_add(builder, "s", server);
+
+       params = g_variant_new("(sv)", param0, g_variant_builder_end(builder));
+       g_variant_builder_unref(builder);
+
+       reply = netconfig_invoke_dbus_method(CONNMAN_SERVICE,
+                       CONNMAN_MANAGER_PATH, CONNMAN_CLOCK_INTERFACE,
+                       "SetProperty", params);
+
+       if (reply == NULL)
+               ERR("Failed to clear NTP server");
+       else
+               g_variant_unref(reply);
+
+       return;
+}
+
 static void __netconfig_set_timeserver(void)
 {
        guint timeserver_clear_timer = 0;
+       int nitz_updated = 0;
+
+       netconfig_vconf_get_int(VCONFKEY_TELEPHONY_NITZ_EVENT_GMT, &nitz_updated);
+
+       if (nitz_updated != 0)
+               return;
 
        __netconfig_clock_set_timeserver((const char *)NTP_SERVER);
 
@@ -86,15 +119,20 @@ static void __netconfig_set_timeserver(void)
                        NULL, &timeserver_clear_timer);
 }
 
-static void __netconfig_clock(
-               enum netconfig_wifi_service_state state, void *user_data)
+static void __network_changed_cb(keynode_t *node, void *user_data)
 {
+       int status = VCONFKEY_NETWORK_OFF;
        gboolean automatic_time_update = 0;
 
-       if (state != NETCONFIG_WIFI_CONNECTED)
+       if (node != NULL)
+               status = vconf_keynode_get_int(node);
+       else
+               netconfig_vconf_get_int(VCONFKEY_NETWORK_STATUS, &status);
+
+       if (status == VCONFKEY_NETWORK_OFF)
                return;
 
-       vconf_get_bool(
+       netconfig_vconf_get_bool(
                        VCONFKEY_SETAPPL_STATE_AUTOMATIC_TIME_UPDATE_BOOL,
                        &automatic_time_update);
 
@@ -106,47 +144,65 @@ static void __netconfig_clock(
        __netconfig_set_timeserver();
 }
 
-static struct netconfig_wifi_state_notifier netconfig_clock_notifier = {
-               .netconfig_wifi_state_changed = __netconfig_clock,
-               .user_data = NULL,
-};
-
 static void __automatic_time_update_changed_cb(keynode_t *node, void *user_data)
 {
+       int status = VCONFKEY_NETWORK_OFF;
        gboolean automatic_time_update = FALSE;
-       enum netconfig_wifi_service_state wifi_state = NETCONFIG_WIFI_UNKNOWN;
 
-       if (node != NULL) {
+       if (node != NULL)
                automatic_time_update = vconf_keynode_get_bool(node);
-       } else {
-               vconf_get_bool(VCONFKEY_SETAPPL_STATE_AUTOMATIC_TIME_UPDATE_BOOL, &automatic_time_update);
-       }
+       else
+               netconfig_vconf_get_bool(VCONFKEY_SETAPPL_STATE_AUTOMATIC_TIME_UPDATE_BOOL, &automatic_time_update);
 
        if (automatic_time_update == FALSE) {
                INFO("Automatic time update is changed to 'FALSE'");
+               __netconfig_clock_unset_timeserver();
                return;
        }
 
-        wifi_state = netconfig_wifi_state_get_service_state();
+       netconfig_vconf_get_int(VCONFKEY_NETWORK_STATUS, &status);
 
-        if (wifi_state != NETCONFIG_WIFI_CONNECTED) {
-               INFO("WiFi state is not NETCONFIG_WIFI_CONNECTED");
+        if (status == VCONFKEY_NETWORK_OFF) {
+               INFO("There is no connection");
                return;
         }
 
        __netconfig_set_timeserver();
 }
 
+static void __nitz_event_cb(keynode_t *node, void *user_data)
+{
+       int nitz_updated = 0;
+
+       if (node != NULL)
+               nitz_updated = vconf_keynode_get_int(node);
+       else
+               netconfig_vconf_get_int(VCONFKEY_TELEPHONY_NITZ_EVENT_GMT, &nitz_updated);
+
+       if (nitz_updated != 0) {
+               INFO("Time is updated by NITZ");
+               __netconfig_clock_unset_timeserver();
+               return;
+       }
+}
+
 void netconfig_clock_init(void)
 {
        INFO("netconfig_clock_init is called");
        vconf_notify_key_changed(VCONFKEY_SETAPPL_STATE_AUTOMATIC_TIME_UPDATE_BOOL,
                        __automatic_time_update_changed_cb, NULL);
-
-       netconfig_wifi_state_notifier_register(&netconfig_clock_notifier);
+       vconf_notify_key_changed(VCONFKEY_TELEPHONY_NITZ_EVENT_GMT,
+                       __nitz_event_cb, NULL);
+       vconf_notify_key_changed(VCONFKEY_NETWORK_STATUS,
+                       __network_changed_cb, NULL);
 }
 
 void netconfig_clock_deinit(void)
 {
-       netconfig_wifi_state_notifier_unregister(&netconfig_clock_notifier);
+       vconf_ignore_key_changed(VCONFKEY_SETAPPL_STATE_AUTOMATIC_TIME_UPDATE_BOOL,
+                       __automatic_time_update_changed_cb);
+       vconf_ignore_key_changed(VCONFKEY_TELEPHONY_NITZ_EVENT_GMT,
+                       __nitz_event_cb);
+       vconf_ignore_key_changed(VCONFKEY_NETWORK_STATUS,
+                       __network_changed_cb);
 }