Add aul dependency and Use syspopup API to lauch syspopup app
[platform/core/connectivity/net-config.git] / src / utils / util.c
1 /*
2  * Network Configuration Module
3  *
4  * Copyright (c) 2000 - 2012 Samsung Electronics Co., Ltd. All rights reserved.
5  *
6  * Licensed under the Apache License, Version 2.0 (the "License");
7  * you may not use this file except in compliance with the License.
8  * You may obtain a copy of the License at
9  *
10  * http://www.apache.org/licenses/LICENSE-2.0
11  *
12  * Unless required by applicable law or agreed to in writing, software
13  * distributed under the License is distributed on an "AS IS" BASIS,
14  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15  * See the License for the specific language governing permissions and
16  * limitations under the License.
17  *
18  */
19
20 #if defined TIZEN_WEARABLE
21 #include <aul.h>
22 #endif
23 #include <app.h>
24 #include <errno.h>
25 #include <vconf.h>
26 #include <stdio.h>
27 #include <stdlib.h>
28 #include <string.h>
29 #include <unistd.h>
30 #include <net/if.h>
31 #include <net/route.h>
32 #include <arpa/inet.h>
33 #include <sys/wait.h>
34 #include <sys/stat.h>
35 #include <sys/ioctl.h>
36 #include <vconf-keys.h>
37 #include <syspopup_caller.h>
38 #include <bundle.h>
39 #include <bundle_internal.h>
40 #include <eventsystem.h>
41
42 #include "log.h"
43 #include "util.h"
44 #include "neterror.h"
45 #include "wifi-state.h"
46
47 #define WC_POPUP_EXTRA_DATA_KEY "http://tizen.org/appcontrol/data/connection_type"
48 #define MAC_INFO_FILEPATH               "/opt/etc/.mac.info"
49 #define MAC_ADDRESS_MAX_LEN             18
50
51 static gboolean netconfig_device_picker_test = FALSE;
52
53 GKeyFile *netconfig_keyfile_load(const char *pathname)
54 {
55         GKeyFile *keyfile = NULL;
56         GError *error = NULL;
57
58         keyfile = g_key_file_new();
59         if (g_key_file_load_from_file(keyfile, pathname, 0, &error) != TRUE) {
60                 DBG("Unable to open %s, error %s", pathname, error->message);
61                 g_error_free(error);
62
63                 g_key_file_free(keyfile);
64                 keyfile = NULL;
65         }
66
67         return keyfile;
68 }
69
70 void netconfig_keyfile_save(GKeyFile *keyfile, const char *pathname)
71 {
72         gsize size = 0;
73         GError *error = NULL;
74         gchar *keydata = NULL;
75         gchar *needle = NULL, *directory = NULL;
76
77         directory = g_strdup(pathname);
78         needle = g_strrstr(directory, "/");
79
80         if (needle != NULL)
81                 *needle = '\0';
82
83         if (directory == NULL || (*directory) == '\0') {
84                 g_free(directory);
85                 return;
86         }
87
88         if (g_file_test(directory, G_FILE_TEST_IS_DIR) != TRUE) {
89                 if (g_mkdir_with_parents(directory,
90                                 S_IRUSR | S_IWUSR | S_IXUSR) != 0) {
91                         g_free(directory);
92                         return;
93                 }
94         }
95         g_free(directory);
96
97         keydata = g_key_file_to_data(keyfile, &size, &error);
98         if (g_file_set_contents(pathname, keydata, size, &error) != TRUE) {
99                 DBG("Unable to save %s, error %s", pathname, error->message);
100                 g_error_free(error);
101         }
102
103         chmod(pathname, S_IRUSR | S_IWUSR);
104
105         g_free(keydata);
106 }
107
108 void netconfig_start_timer_seconds(guint secs,
109                 gboolean(*callback) (gpointer), void *user_data, guint *timer_id)
110 {
111         guint t_id = 0;
112
113         if (callback == NULL) {
114                 ERR("callback function is NULL");
115                 return;
116         }
117
118         if ((timer_id != NULL && *timer_id != 0)) {
119                 ERR("timer already is registered");
120                 return;
121         }
122
123         t_id = g_timeout_add_seconds(secs, callback, user_data);
124
125         if (t_id == 0) {
126                 ERR("Can't add timer");
127                 return;
128         }
129
130         if (timer_id != NULL)
131                 *timer_id = t_id;
132 }
133
134 void netconfig_start_timer(guint msecs,
135                 gboolean(*callback) (gpointer), void *user_data, guint *timer_id)
136 {
137         guint t_id = 0;
138
139         INFO("Register timer with callback pointer (%p)", callback);
140
141         if (callback == NULL) {
142                 ERR("callback function is NULL");
143                 return;
144         }
145
146         if ((timer_id != NULL && *timer_id != 0)) {
147                 ERR("timer already is registered");
148                 return;
149         }
150
151         t_id = g_timeout_add(msecs, callback, user_data);
152
153         if (t_id == 0) {
154                 ERR("Can't add timer");
155                 return;
156         }
157
158         if (timer_id != NULL)
159                 *timer_id = t_id;
160 }
161
162 void netconfig_stop_timer(guint *timer_id)
163 {
164         if (timer_id == NULL) {
165                 ERR("timer is NULL");
166                 return;
167         }
168
169         if (*timer_id != 0) {
170                 g_source_remove(*timer_id);
171                 *timer_id = 0;
172         }
173 }
174
175 static gboolean __netconfig_test_device_picker()
176 {
177         char *favorite_wifi_service = NULL;
178
179         favorite_wifi_service = wifi_get_favorite_service();
180         if (favorite_wifi_service != NULL) {
181                 ERR("favorite_wifi_service is existed[%s] : Donot launch device picker", favorite_wifi_service);
182                 g_free(favorite_wifi_service);
183                 return FALSE;
184         }
185
186         return TRUE;
187 }
188
189 static void __netconfig_pop_device_picker(void)
190 {
191 #if defined TIZEN_WEARABLE
192         int ret = 0;
193         app_control_h   control = NULL;
194
195         ret = app_control_create(&control);
196         if (APP_CONTROL_ERROR_NONE != ret) {
197                 DBG("failed to create app control");
198                 return ;
199         }
200
201         app_control_add_extra_data(control, "viewtype", "scanlist");
202
203         app_control_set_app_id(control, "org.tizen.wifi");
204         ret = app_control_send_launch_request(control, NULL, NULL);
205         if (APP_CONTROL_ERROR_NONE == ret)
206                 DBG("Launch request sent successfully");
207
208         app_control_destroy(control);
209 #else
210         bundle *b = NULL;
211         int wifi_ug_state = 0;
212
213         vconf_get_int(VCONFKEY_WIFI_UG_RUN_STATE, &wifi_ug_state);
214         if (wifi_ug_state == VCONFKEY_WIFI_UG_RUN_STATE_ON_FOREGROUND)
215                 return;
216
217         b = bundle_create();
218
219         DBG("Launch Wi-Fi device picker");
220         syspopup_launch("wifi-qs", b);
221
222         bundle_free(b);
223 #endif
224 }
225
226 static gboolean __netconfig_wifi_try_device_picker(gpointer data)
227 {
228         if (__netconfig_test_device_picker() == TRUE)
229                 __netconfig_pop_device_picker();
230
231         return FALSE;
232 }
233
234 static guint __netconfig_wifi_device_picker_timer_id(gboolean is_set_method, guint timer_id)
235 {
236         static guint netconfig_wifi_device_picker_service_timer = 0;
237
238         if (is_set_method != TRUE)
239                 return netconfig_wifi_device_picker_service_timer;
240
241         if (netconfig_wifi_device_picker_service_timer != timer_id)
242                 netconfig_wifi_device_picker_service_timer = timer_id;
243
244         return netconfig_wifi_device_picker_service_timer;
245 }
246
247 static void __netconfig_wifi_device_picker_set_timer_id(guint timer_id)
248 {
249         __netconfig_wifi_device_picker_timer_id(TRUE, timer_id);
250 }
251
252 static guint __netconfig_wifi_device_picker_get_timer_id(void)
253 {
254         return __netconfig_wifi_device_picker_timer_id(FALSE, -1);
255 }
256
257 void netconfig_wifi_enable_device_picker_test(void)
258 {
259         netconfig_device_picker_test = TRUE;
260 }
261
262 void netconfig_wifi_device_picker_service_start(void)
263 {
264         const int NETCONFIG_WIFI_DEVICE_PICKER_INTERVAL = 700;
265         guint timer_id = 0;
266
267         if (netconfig_device_picker_test == TRUE)
268                 netconfig_device_picker_test = FALSE;
269         else
270                 return;
271
272 #if defined TIZEN_WEARABLE
273         if (aul_app_is_running("org.tizen.wifi") > 0) {
274                 DBG("wifi app is running");
275                 return;
276         }
277 #else
278         int wifi_ug_state;
279
280         vconf_get_int(VCONFKEY_WIFI_UG_RUN_STATE, &wifi_ug_state);
281         if (wifi_ug_state == VCONFKEY_WIFI_UG_RUN_STATE_ON_FOREGROUND)
282                 return;
283 #endif
284
285         DBG("Register device picker timer with %d milliseconds", NETCONFIG_WIFI_DEVICE_PICKER_INTERVAL);
286         netconfig_start_timer(NETCONFIG_WIFI_DEVICE_PICKER_INTERVAL, __netconfig_wifi_try_device_picker, NULL, &timer_id);
287
288         __netconfig_wifi_device_picker_set_timer_id(timer_id);
289 }
290
291 void netconfig_wifi_device_picker_service_stop(void)
292 {
293         guint timer_id = 0;
294
295         timer_id = __netconfig_wifi_device_picker_get_timer_id();
296         if (timer_id == 0)
297                 return;
298
299         DBG("Clear device picker timer with timer_id %d", timer_id);
300
301         netconfig_stop_timer(&timer_id);
302
303         __netconfig_wifi_device_picker_set_timer_id(timer_id);
304 }
305
306 gboolean netconfig_is_wifi_direct_on(void)
307 {
308 #if defined TIZEN_P2P_ENABLE
309         int wifi_direct_state = 0;
310
311         vconf_get_int(VCONFKEY_WIFI_DIRECT_STATE, &wifi_direct_state);
312
313         DBG("Wi-Fi direct mode %d", wifi_direct_state);
314         return (wifi_direct_state != 0) ? TRUE : FALSE;
315 #else
316         return FALSE;
317 #endif
318 }
319
320 gboolean netconfig_is_wifi_tethering_on(void)
321 {
322 #if defined TIZEN_TETHERING_ENABLE
323         int wifi_tethering_state = 0;
324
325         vconf_get_int(VCONFKEY_MOBILE_HOTSPOT_MODE, &wifi_tethering_state);
326
327         DBG("Wi-Ti tethering mode %d", wifi_tethering_state);
328         if (wifi_tethering_state & VCONFKEY_MOBILE_HOTSPOT_MODE_WIFI)
329                 return TRUE;
330 #endif
331         return FALSE;
332 }
333
334 gboolean netconfig_interface_up(const char *ifname)
335 {
336         int fd;
337         struct ifreq ifr;
338
339         fd = socket(PF_INET, SOCK_DGRAM | SOCK_CLOEXEC, 0);
340         if (fd < 0)
341                 return FALSE;
342
343         memset(&ifr, 0, sizeof(ifr));
344         g_strlcpy((char *)ifr.ifr_name, ifname, sizeof(ifr.ifr_name));
345
346         if (ioctl(fd, SIOCGIFFLAGS, &ifr) < 0) {
347                 close(fd);
348                 return FALSE;
349         }
350
351         ifr.ifr_flags |= (IFF_UP | IFF_DYNAMIC);
352         if (ioctl(fd, SIOCSIFFLAGS, &ifr) < 0) {
353                 close(fd);
354                 return FALSE;
355         }
356
357         close(fd);
358
359         DBG("Successfully activated wireless interface");
360         return TRUE;
361 }
362
363 gboolean netconfig_interface_down(const char *ifname)
364 {
365         int fd;
366         struct ifreq ifr;
367
368         fd = socket(PF_INET, SOCK_DGRAM | SOCK_CLOEXEC, 0);
369         if (fd < 0)
370                 return FALSE;
371
372         memset(&ifr, 0, sizeof(ifr));
373         g_strlcpy((char *)ifr.ifr_name, ifname, sizeof(ifr.ifr_name));
374
375         if (ioctl(fd, SIOCGIFFLAGS, &ifr) < 0) {
376                 close(fd);
377                 return FALSE;
378         }
379
380         ifr.ifr_flags = (ifr.ifr_flags & ~IFF_UP) | IFF_DYNAMIC;
381         if (ioctl(fd, SIOCSIFFLAGS, &ifr) < 0) {
382                 close(fd);
383                 return FALSE;
384         }
385
386         close(fd);
387
388         DBG("Successfully de-activated wireless interface");
389         return TRUE;
390 }
391
392 int netconfig_execute_file(const char *file_path,
393                 char *const args[], char *const envs[])
394 {
395         pid_t pid = 0;
396         int status = 0;
397         int rv = 0;
398         errno = 0;
399         register unsigned int index = 0;
400
401         while (args[index] != NULL) {
402                 DBG("%s", args[index]);
403                 index++;
404         }
405
406         if (!(pid = fork())) {
407                 DBG("pid(%d), ppid (%d)", getpid(), getppid());
408                 DBG("Inside child, exec (%s) command", file_path);
409
410                 errno = 0;
411                 if (execve(file_path, args, envs) == -1) {
412                         DBG("Fail to execute command (%s)", strerror(errno));
413                         exit(1);
414                 }
415         } else if (pid > 0) {
416                 if (waitpid(pid, &status, 0) == -1)
417                         DBG("wait pid (%u) status (%d)", pid, status);
418
419                 if (WIFEXITED(status)) {
420                         rv = WEXITSTATUS(status);
421                         DBG("exited, status=%d", rv);
422                 } else if (WIFSIGNALED(status)) {
423                         DBG("killed by signal %d", WTERMSIG(status));
424                 } else if (WIFSTOPPED(status)) {
425                         DBG("stopped by signal %d", WSTOPSIG(status));
426                 } else if (WIFCONTINUED(status)) {
427                         DBG("continued");
428                 }
429
430                 return rv;
431         }
432
433         DBG("failed to fork(%s)", strerror(errno));
434         return -EIO;
435 }
436
437 static void on_clat_handler()
438 {
439         pid_t clat_pid = 0;
440         int state = 0;
441
442         clat_pid = waitpid(-1, &state, WNOHANG);
443
444         DBG("clat(%d) state(%d)", clat_pid, WEXITSTATUS(state));
445 }
446
447 int netconfig_execute_clatd(const char *file_path, char *const args[])
448 {
449         pid_t pid = 0;
450         int rv = 0;
451         errno = 0;
452         register unsigned int index = 0;
453
454         struct sigaction act;
455         int state = 0;
456
457         act.sa_handler = on_clat_handler;
458         sigemptyset(&act.sa_mask);
459         act.sa_flags = 0;
460
461         state = sigaction(SIGCHLD, &act, 0);
462         if (state != 0) {
463                 DBG("sigaction() : %d");
464                 return -1;
465         }
466
467         while (args[index] != NULL) {
468                 DBG("%s", args[index]);
469                 index++;
470         }
471
472         if (!(pid = fork())) {
473                 DBG("pid(%d), ppid (%d)", getpid(), getppid());
474                 DBG("Inside child, exec (%s) command", file_path);
475
476                 errno = 0;
477                 if (execvp(file_path, args) == -1) {
478                         ERR("Fail to execute command (%s)", strerror(errno));
479                         return -1;
480                 }
481         } else if (pid > 0) {
482                 ERR("Success to launch clatd");
483                 return rv;
484         }
485
486         DBG("failed to fork(%s)", strerror(errno));
487         return -EIO;
488 }
489
490 int __netconfig_get_interface_index(const char *interface_name)
491 {
492         struct ifreq ifr;
493         int sock = 0;
494         int result = 0;
495
496         if (interface_name == NULL) {
497                 DBG("Inteface name is NULL");
498                 return -1;
499         }
500
501         errno = 0;
502         sock = socket(PF_INET, SOCK_DGRAM | SOCK_CLOEXEC, 0);
503         if (sock < 0) {
504                 DBG("Failed to create socket : %s", strerror(errno));
505                 return -1;
506         }
507
508         memset(&ifr, 0, sizeof(ifr));
509         strncpy(ifr.ifr_name, interface_name, sizeof(ifr.ifr_name) - 1);
510         result = ioctl(sock, SIOCGIFINDEX, &ifr);
511         close(sock);
512
513         if (result < 0) {
514                 DBG("Failed to get ifr index: %s", strerror(errno));
515                 return -1;
516         }
517
518         return ifr.ifr_ifindex;
519 }
520
521 int netconfig_add_route_ipv4(gchar *ip_addr, gchar *subnet, gchar *interface, gint address_family)
522 {
523         struct ifreq ifr;
524         struct rtentry rt;
525         struct sockaddr_in addr_in;
526         int sock;
527
528         memset(&ifr, 0, sizeof(ifr));
529
530         ifr.ifr_ifindex = __netconfig_get_interface_index(interface);
531
532         if (ifr.ifr_ifindex < 0)
533                 return -1;
534
535         strncpy(ifr.ifr_name, interface, IFNAMSIZ-1);
536
537         memset(&rt, 0, sizeof(rt));
538
539         rt.rt_flags = RTF_UP | RTF_HOST;
540         memset(&addr_in, 0, sizeof(struct sockaddr_in));
541         addr_in.sin_family = address_family;
542         addr_in.sin_addr.s_addr = inet_addr(ip_addr);
543         memcpy(&rt.rt_dst, &addr_in, sizeof(rt.rt_dst));
544
545         memset(&addr_in, 0, sizeof(struct sockaddr_in));
546         addr_in.sin_family = address_family;
547         addr_in.sin_addr.s_addr = INADDR_ANY;
548         memcpy(&rt.rt_gateway, &addr_in, sizeof(rt.rt_gateway));
549
550         memset(&addr_in, 0, sizeof(struct sockaddr_in));
551         addr_in.sin_family = AF_INET;
552         addr_in.sin_addr.s_addr = inet_addr(subnet);
553         memcpy(&rt.rt_genmask, &addr_in, sizeof(rt.rt_genmask));
554
555         rt.rt_dev = ifr.ifr_name;
556
557         errno = 0;
558         sock = socket(PF_INET, SOCK_DGRAM, 0);
559
560         if (sock < 0) {
561                 DBG("Failed to create socket : %s", strerror(errno));
562                 return -1;
563         }
564
565         if (ioctl(sock, SIOCADDRT, &rt) < 0) {
566                 DBG("Failed to set route address : %s", strerror(errno));
567                 close(sock);
568                 return -1;
569         }
570
571         close(sock);
572
573         return 1;
574 }
575
576 int netconfig_del_route_ipv4(gchar *ip_addr, gchar *subnet, gchar *interface, gint address_family)
577 {
578         struct ifreq ifr;
579         struct rtentry rt;
580         struct sockaddr_in addr_in;
581         int sock;
582
583         memset(&ifr, 0, sizeof(ifr));
584         ifr.ifr_ifindex = __netconfig_get_interface_index(interface);
585
586         if (ifr.ifr_ifindex < 0)
587                 return -1;
588
589         strncpy(ifr.ifr_name, interface, IFNAMSIZ-1);
590
591         memset(&rt, 0, sizeof(rt));
592
593         rt.rt_flags = RTF_UP;
594         memset(&addr_in, 0, sizeof(struct sockaddr_in));
595         addr_in.sin_family = address_family;
596         addr_in.sin_addr.s_addr = inet_addr(ip_addr);
597         memcpy(&rt.rt_dst, &addr_in, sizeof(rt.rt_dst));
598
599         memset(&addr_in, 0, sizeof(struct sockaddr_in));
600         addr_in.sin_family = address_family;
601         addr_in.sin_addr.s_addr = inet_addr(subnet);
602         memcpy(&rt.rt_genmask, &addr_in, sizeof(rt.rt_genmask));
603         rt.rt_dev = ifr.ifr_name;
604
605         errno = 0;
606         sock = socket(PF_INET, SOCK_DGRAM, 0);
607
608         if (sock < 0) {
609                 DBG("Failed to create socket : %s", strerror(errno));
610                 return -1;
611         }
612
613         if (ioctl(sock, SIOCDELRT, &rt) < 0) {
614                 DBG("Failed to set route address : %s", strerror(errno));
615                 close(sock);
616                 return -1;
617         }
618
619         close(sock);
620
621         return 1;
622 }
623
624 int netconfig_add_route_ipv6(gchar *ip_addr, gchar *interface, gchar *gateway, unsigned char prefix_len)
625 {
626         struct in6_rtmsg rt;
627         int fd = 0;
628         int err = 0;
629
630         memset(&rt, 0, sizeof(rt));
631
632         rt.rtmsg_dst_len = prefix_len;
633
634         rt.rtmsg_flags = RTF_UP | RTF_HOST;
635
636         errno = 0;
637         if (inet_pton(AF_INET6, ip_addr, &rt.rtmsg_dst) < 0) {
638                 DBG("inet_pton failed : %s", strerror(errno));
639                 return -1;
640         }
641
642         if (gateway != NULL) {
643                 rt.rtmsg_flags |= RTF_GATEWAY;
644                 if (inet_pton(AF_INET6, gateway, &rt.rtmsg_gateway) < 0) {
645                         DBG("inet_pton failed : %s", strerror(errno));
646                         return -1;
647                 }
648         }
649
650         rt.rtmsg_metric = 1;
651
652         fd = socket(AF_INET6, SOCK_DGRAM, 0);
653         if (fd < 0) {
654                 DBG("Failed to create socket : %s", strerror(errno));
655                 return -1;
656         }
657
658         rt.rtmsg_ifindex = 0;
659
660         if (interface) {
661                 struct ifreq ifr;
662                 memset(&ifr, 0, sizeof(ifr));
663                 strncpy(ifr.ifr_name, interface, sizeof(ifr.ifr_name)-1);
664                 ioctl(fd, SIOCGIFINDEX, &ifr);
665                 rt.rtmsg_ifindex = ifr.ifr_ifindex;
666         }
667
668         if ((err = ioctl(fd, SIOCADDRT, &rt)) < 0) {
669                 DBG("Failed to add route: %s", strerror(errno));
670                 close(fd);
671                 return -1;
672         }
673
674         close(fd);
675
676         return 1;
677 }
678
679 int netconfig_del_route_ipv6(gchar *ip_addr, gchar *interface, gchar *gateway, unsigned char prefix_len)
680 {
681         struct in6_rtmsg rt;
682         int fd = 0;
683         int err = 0;
684
685         memset(&rt, 0, sizeof(rt));
686
687         rt.rtmsg_dst_len = prefix_len;
688
689         rt.rtmsg_flags = RTF_UP | RTF_HOST;
690
691         if (inet_pton(AF_INET6, ip_addr, &rt.rtmsg_dst) < 0) {
692                 err = -errno;
693                 return err;
694         }
695
696         if (gateway != NULL) {
697                 rt.rtmsg_flags |= RTF_GATEWAY;
698                 if (inet_pton(AF_INET6, gateway, &rt.rtmsg_gateway) < 0) {
699                         err = -errno;
700                         return err;
701                 }
702         }
703
704         rt.rtmsg_metric = 1;
705
706         fd = socket(AF_INET6, SOCK_DGRAM, 0);
707         if (fd < 0)
708                 return -1;
709
710         rt.rtmsg_ifindex = 0;
711
712         if (interface) {
713                 struct ifreq ifr;
714                 memset(&ifr, 0, sizeof(ifr));
715                 strncpy(ifr.ifr_name, interface, sizeof(ifr.ifr_name)-1);
716                 ioctl(fd, SIOCGIFINDEX, &ifr);
717                 rt.rtmsg_ifindex = ifr.ifr_ifindex;
718         }
719
720         if ((err = ioctl(fd, SIOCDELRT, &rt)) < 0) {
721                 DBG("Failed to del route: %d\n", err);
722                 close(fd);
723                 return -1;
724         }
725
726         close(fd);
727
728         return 1;
729 }
730
731 gboolean handle_launch_direct(Wifi *wifi, GDBusMethodInvocation *context)
732 {
733 #if defined TIZEN_P2P_ENABLE
734         int ret = 0;
735         DBG("Launch Wi-Fi direct daemon");
736
737         const char *path = "/usr/bin/wifi-direct-server.sh";
738         char *const args[] = { "wifi-direct-server.sh", "start", NULL };
739         char *const envs[] = { NULL };
740
741         ret = netconfig_execute_file(path, args, envs);
742         if (ret < 0) {
743                 ERR("Failed to launch Wi-Fi direct daemon");
744                 netconfig_error_wifi_direct_failed(context);
745                 return FALSE;
746         }
747         wifi_complete_launch_direct(wifi, context);
748         return TRUE;
749 #else
750         wifi_complete_launch_direct(wifi, context);
751         return FALSE;
752 #endif
753 }
754
755 gboolean netconfig_send_notification_to_net_popup(const char * noti, const char * ssid)
756 {
757         int ret = 0;
758         bundle *b;
759         static gboolean is_found_noti_exists = FALSE;
760         static gboolean is_portal_noti_exists = FALSE;
761
762         if (noti == NULL) {
763                 ERR("Invalid notification");
764                 return FALSE;
765         }
766
767         if (g_strcmp0(noti, NETCONFIG_DEL_FOUND_AP_NOTI) == 0) {
768                 if (is_found_noti_exists == FALSE)
769                         return TRUE;
770
771                 is_found_noti_exists = FALSE;
772         } else if (g_strcmp0(noti, NETCONFIG_ADD_FOUND_AP_NOTI) == 0) {
773                 if (is_found_noti_exists == TRUE)
774                         return TRUE;
775
776                 is_found_noti_exists = TRUE;
777         } else if (g_strcmp0(noti, NETCONFIG_ADD_PORTAL_NOTI) == 0) {
778                 if (is_portal_noti_exists == TRUE)
779                         return TRUE;
780
781                 is_portal_noti_exists = TRUE;
782         } else if (g_strcmp0(noti, NETCONFIG_DEL_PORTAL_NOTI) == 0) {
783                 if (is_portal_noti_exists == FALSE)
784                         return TRUE;
785
786                 is_portal_noti_exists = FALSE;
787         }
788
789         b = bundle_create();
790         bundle_add(b, "_SYSPOPUP_TYPE_", noti);
791
792         if (ssid != NULL) {
793                 DBG("ssid (%s)", ssid);
794                 bundle_add(b, "_AP_NAME_", ssid);
795         }
796
797         ret = syspopup_launch("net.netpopup", b);
798
799         bundle_free(b);
800
801         if (ret < 0) {
802                 ERR("Unable to launch noti-popup. Err = %d", ret);
803                 return FALSE;
804         }
805
806         DBG("Successfully sent notification (%s)", noti);
807         return TRUE;
808 }
809
810 int netconfig_send_message_to_net_popup(const char *title,
811                 const char *content, const char *type, const char *ssid)
812 {
813         int ret = 0;
814         bundle *b = bundle_create();
815
816         bundle_add(b, "_SYSPOPUP_TITLE_", title);
817         bundle_add(b, "_SYSPOPUP_CONTENT_", content);
818         bundle_add(b, "_SYSPOPUP_TYPE_", type);
819         bundle_add(b, "_AP_NAME_", ssid);
820
821         ret = syspopup_launch("net.netpopup", b);
822
823         bundle_free(b);
824
825         return ret;
826 }
827
828 void netconfig_set_system_event(const char * sys_evt, const char * evt_key, const char * evt_val)
829 {
830         bundle *b = NULL;
831
832         DBG("System event set [%s : %s : %s]", sys_evt, evt_key, evt_val);
833
834         b = bundle_create();
835         bundle_add_str(b, evt_key, evt_val);
836         eventsystem_send_system_event(sys_evt, b);
837         bundle_free(b);
838 }
839
840 #if defined TIZEN_WEARABLE
841 int wc_launch_syspopup(netconfig_wcpopup_type_e type)
842 {
843         int ret;
844         bundle* b;
845         char *ssid = NULL;
846
847         b = bundle_create();
848         if (!b) {
849                 ERR("Failed to create bundle");
850                 return -1;
851         }
852
853         switch (type) {
854         case WC_POPUP_TYPE_SESSION_OVERLAPPED:
855                 bundle_add(b, "event-type", "wps-session-overlapped");
856                 break;
857         case WC_POPUP_TYPE_WIFI_CONNECTED:
858                 ssid = vconf_get_str(VCONFKEY_WIFI_CONNECTED_AP_NAME);
859                 if (ssid == NULL) {
860                         ERR("Failed to get connected ap ssid");
861                         ssid = g_strdup(" ");
862                 }
863                 bundle_add(b, "event-type", "wifi-connected");
864                 bundle_add(b, "ssid", ssid);
865                 if (ssid)
866                         g_free(ssid);
867                 break;
868         case WC_POPUP_TYPE_WIFI_RESTRICT:
869                                 bundle_add(b, "event-type", "wifi-restrict");
870                                 break;
871         default:
872                 ERR("Popup is not supported[%d]", type);
873                 bundle_free(b);
874                 return -1;
875         }
876
877         ret = syspopup_launch("wc-syspopup", b);
878         if (ret < 0)
879                 ERR("Failed to launch syspopup");
880
881         bundle_free(b);
882
883         return ret;
884 }
885
886 int wc_launch_popup(netconfig_wcpopup_type_e type)
887 {
888         int ret;
889         app_control_h app_control = NULL;
890
891         ret = app_control_create(&app_control);
892         if (ret != APP_CONTROL_ERROR_NONE) {
893                 ERR("Failed to create appcontrol[%d]", ret);
894                 return -1;
895         }
896
897         switch (type) {
898         case WC_POPUP_TYPE_CAPTIVE_PORTAL:
899                 app_control_add_extra_data(app_control, WC_POPUP_EXTRA_DATA_KEY, "captive-portal");
900                 break;
901         default:
902                 ERR("Popup is not supported[%d]", type);
903                 app_control_destroy(app_control);
904                 return -1;
905         }
906
907         app_control_set_app_id(app_control, "com.samsung.weconn-popup");
908         ret = app_control_send_launch_request(app_control, NULL, NULL);
909         if (ret != APP_CONTROL_ERROR_NONE) {
910                 DBG("failed appcontrol launch request [%d]", ret);
911                 app_control_destroy(app_control);
912                 return -1;
913         }
914
915         app_control_destroy(app_control);
916
917         return 0;
918 }
919 #endif
920
921 void netconfig_set_vconf_int(const char * key, int value)
922 {
923         int ret = 0;
924
925         DBG("[%s: %d]", key, value);
926
927         ret = vconf_set_int(key, value);
928         if (ret != VCONF_OK)
929                 ERR("Failed to set");
930 }
931
932 void netconfig_set_vconf_str(const char * key, const char * value)
933 {
934         int ret = 0;
935
936         DBG("[%s: %s]", key, value);
937
938         ret = vconf_set_str(key, value);
939         if (ret != VCONF_OK)
940                 ERR("Failed to set");
941 }
942
943 char* netconfig_get_env(const char *key)
944 {
945         FILE *fp;
946         char buf[256], *entry = NULL, *value = NULL, *last;
947         int len=0;
948
949         if (!key)
950                 return NULL;
951
952         fp = fopen(NETCONFIG_TIZENMOBILEENV, "r");
953         if (!fp)
954                 return NULL;
955
956         while (fgets(buf, sizeof(buf), fp)) {
957                 entry = buf;
958                 entry = strtok_r(entry, "=", &last);
959                 if (entry) {
960                         if (strstr(entry, key)) {
961                                 entry = strtok_r(NULL, "\n", &last);
962                                 if(entry){
963                                         len = strlen(entry);
964                                         value = (char*)malloc(len+1);
965                                         g_strlcpy(value, entry, len+1);
966                                 }
967                                 else{
968                                         value = (char*)malloc(sizeof(char));
969                                         g_strlcpy(value, "\n", sizeof(char));
970                                 }
971                                 break;
972                         }
973                 }
974         }
975
976         fclose(fp);
977         return value;
978 }
979
980 void netconfig_set_mac_address_from_file(void)
981 {
982         FILE *file = NULL;
983         char mac_str[MAC_ADDRESS_MAX_LEN];
984         gchar *mac_lower_str = NULL;
985         int mac_len = 0;
986
987         file = fopen(MAC_INFO_FILEPATH, "r");
988         if (file == NULL) {
989                 ERR("Fail to open %s", MAC_INFO_FILEPATH);
990                 return;
991         }
992         if (fgets(mac_str, sizeof(mac_str), file) == NULL ) {
993                 ERR("Fail to read mac address");
994                 fclose(file);
995                 return;
996         }
997
998         mac_len = strlen(mac_str);
999         if (mac_len < 17) {
1000                 ERR("mac.info is empty");
1001                 fclose(file);
1002                 return;
1003         }
1004
1005         mac_lower_str = g_ascii_strup(mac_str, (gssize)mac_len);
1006         netconfig_set_vconf_str(VCONFKEY_WIFI_BSSID_ADDRESS, mac_lower_str);
1007
1008         g_free(mac_lower_str);
1009         fclose(file);
1010 }