* e_dbus: Use eina_log.
[framework/uifw/edbus.git] / src / lib / connman / e_connman.c
1 #include "e_connman_private.h"
2 #include <stdlib.h>
3 #include <string.h>
4
5 static E_DBus_Signal_Handler *cb_name_owner_changed = NULL;
6 static DBusPendingCall *pending_get_name_owner = NULL;
7 static unsigned int init_count = 0;
8 static char *unique_name = NULL;
9
10 static const char bus_name[] = "org.moblin.connman";
11 static const char fdo_bus_name[] = "org.freedesktop.DBus";
12 static const char fdo_interface[] = "org.freedesktop.DBus";
13 static const char fdo_path[] = "/org/freedesktop/DBus";
14
15 E_DBus_Connection *e_connman_conn = NULL;
16
17 EAPI int E_CONNMAN_EVENT_MANAGER_IN = 0;
18 EAPI int E_CONNMAN_EVENT_MANAGER_OUT = 0;
19 EAPI int E_CONNMAN_EVENT_ELEMENT_ADD = 0;
20 EAPI int E_CONNMAN_EVENT_ELEMENT_DEL = 0;
21 EAPI int E_CONNMAN_EVENT_ELEMENT_UPDATED = 0;
22
23 const char *e_connman_iface_manager = NULL;
24 const char *e_connman_iface_network = NULL;
25 const char *e_connman_iface_profile = NULL;
26 const char *e_connman_iface_service = NULL;
27 const char *e_connman_iface_device = NULL;
28 const char *e_connman_iface_connection = NULL;
29
30 const char *e_connman_prop_available = NULL;
31 const char *e_connman_prop_connected = NULL;
32 const char *e_connman_prop_connections = NULL;
33 const char *e_connman_prop_default = NULL;
34 const char *e_connman_prop_device = NULL;
35 const char *e_connman_prop_devices = NULL;
36 const char *e_connman_prop_interface = NULL;
37 const char *e_connman_prop_ipv4_address = NULL;
38 const char *e_connman_prop_ipv4_method = NULL;
39 const char *e_connman_prop_name = NULL;
40 const char *e_connman_prop_network = NULL;
41 const char *e_connman_prop_networks = NULL;
42 const char *e_connman_prop_offline_mode = NULL;
43 const char *e_connman_prop_policy = NULL;
44 const char *e_connman_prop_powered = NULL;
45 const char *e_connman_prop_priority = NULL;
46 const char *e_connman_prop_profiles = NULL;
47 const char *e_connman_prop_remember = NULL;
48 const char *e_connman_prop_scan_interval = NULL;
49 const char *e_connman_prop_scanning = NULL;
50 const char *e_connman_prop_state = NULL;
51 const char *e_connman_prop_strengh = NULL;
52 const char *e_connman_prop_type = NULL;
53 const char *e_connman_prop_wifi_mode = NULL;
54 const char *e_connman_prop_wifi_passphrase = NULL;
55 const char *e_connman_prop_wifi_security = NULL;
56 const char *e_connman_prop_wifi_ssid = NULL;
57
58 const char *
59 e_connman_system_bus_name_get(void)
60 {
61    return unique_name ? unique_name : bus_name;
62 }
63
64
65 /***********************************************************************
66  * Manager
67  ***********************************************************************/
68
69 /**
70  * Synchronize elements with server.
71  *
72  * This will call Manager.GetProperties() on server, retrieve properties
73  * and some element paths and then request their properties.
74  *
75  * This call will add events E_CONNMAN_EVENT_ELEMENT_ADD and
76  * E_CONNMAN_EVENT_ELEMENT_UPDATED to the main loop.
77  *
78  * This will not remove stale elements.
79  *
80  * @return 1 on success, 0 otherwise.
81  */
82 bool
83 e_connman_manager_sync_elements(void)
84 {
85    E_Connman_Element *manager;
86
87    if (!unique_name)
88      return FALSE;
89    manager = e_connman_element_register(manager_path, e_connman_iface_manager);
90    if (manager)
91      e_connman_element_properties_sync(manager);
92    else
93      return FALSE;
94
95    DBG("sync_manager: %s (%s)", unique_name, bus_name);
96
97    return TRUE;
98 }
99
100 static void
101 _e_connman_system_name_owner_exit(void)
102 {
103    e_connman_manager_clear_elements();
104    ecore_event_add(E_CONNMAN_EVENT_MANAGER_OUT, NULL, NULL, NULL);
105
106    free(unique_name);
107    unique_name = NULL;
108 }
109
110 static void
111 _e_connman_system_name_owner_enter(const char *uid)
112 {
113    DBG("E-Dbus connman: enter connman at %s (old was %s)", uid, unique_name);
114    if (unique_name && strcmp(unique_name, uid) == 0)
115      {
116         DBG("E-Dbus connman: same unique_name for connman, ignore.");
117         return;
118      }
119
120    if (unique_name)
121      _e_connman_system_name_owner_exit();
122
123    unique_name = strdup(uid);
124
125    ecore_event_add(E_CONNMAN_EVENT_MANAGER_IN, NULL, NULL, NULL);
126    e_connman_manager_sync_elements();
127 }
128
129 static void
130 _e_connman_system_name_owner_changed(void *data, DBusMessage *msg)
131 {
132    DBusError err;
133    const char *name, *from, *to;
134
135    dbus_error_init(&err);
136    if (!dbus_message_get_args(msg, &err,
137                               DBUS_TYPE_STRING, &name,
138                               DBUS_TYPE_STRING, &from,
139                               DBUS_TYPE_STRING, &to,
140                               DBUS_TYPE_INVALID))
141      {
142         ERR("E-Dbus connman: could not get NameOwnerChanged arguments: %s: %s",
143             err.name, err.message);
144         dbus_error_free(&err);
145         return;
146      }
147
148    if (strcmp(name, bus_name) != 0)
149      return;
150
151    DBG("E-Dbus connman: NameOwnerChanged from=[%s] to=[%s]", from, to);
152
153    if (from[0] == '\0' && to[0] != '\0')
154      _e_connman_system_name_owner_enter(to);
155    else if (from[0] != '\0' && to[0] == '\0')
156      {
157         DBG("E-Dbus connman: exit connman at %s", from);
158         if (strcmp(unique_name, from) != 0)
159           DBG("E-Dbus connman: %s was not the known name %s, ignored.", from, unique_name);
160         else
161           _e_connman_system_name_owner_exit();
162      }
163    else
164      DBG("E-Dbus connman: unknow change from %s to %s", from, to);
165 }
166
167 static void
168 _e_connman_get_name_owner(void *data, DBusMessage *msg, DBusError *err)
169 {
170    DBusMessageIter itr;
171    int t;
172    const char *uid;
173
174    pending_get_name_owner = NULL;
175
176    if (!_dbus_callback_check_and_init(msg, &itr, err))
177      return;
178
179    t = dbus_message_iter_get_arg_type(&itr);
180    if (!_dbus_iter_type_check(t, DBUS_TYPE_STRING))
181      return;
182
183    dbus_message_iter_get_basic(&itr, &uid);
184    if (!uid)
185      {
186         ERR("E-Dbus connman: no name owner!");
187         return;
188      }
189
190    _e_connman_system_name_owner_enter(uid);
191    return;
192 }
193
194 /**
195  * Initialize E Connection Manager (E_Connman) system.
196  *
197  * This will connect and watch org.moblin.connman.Manager and Element
198  * events and translate to Ecore main loop events, also provide a
199  * proxy for method invocation on server.
200  *
201  * Interesting events are:
202  *   - E_CONNMAN_EVENT_MANAGER_IN: issued when connman is avaiable.
203  *   - E_CONNMAN_EVENT_MANAGER_OUT: issued when connman connection is lost.
204  *   - E_CONNMAN_EVENT_ELEMENT_ADD: element was added.
205  *   - E_CONNMAN_EVENT_ELEMENT_DEL: element was deleted.
206  *   - E_CONNMAN_EVENT_ELEMENT_UPDATED: element was updated (properties
207  *     or state changed).
208  *
209  * Manager IN/OUT events do not provide any event information, just
210  * tells you that system is usable or not. After manager is out, all
211  * elements will be removed, so after this event do not use the system anymore.
212  *
213  * Element events will give you an element object. After DEL event callback
214  * returns, that element will not be valid anymore.
215  */
216 unsigned int
217 e_connman_system_init(E_DBus_Connection *edbus_conn)
218 {
219    init_count++;
220
221    if (init_count > 1)
222      return init_count;
223    
224    _e_dbus_connman_log_dom = eina_log_domain_register("e_dbus_connman",EINA_LOG_DEFAULT_COLOR);
225
226    if(_e_dbus_connman_log_dom < 0) 
227      {
228        E_DBUS_LOG_ERR("E-Dbus connman error : impossible to create a log domain for edbus_connman module");
229        return -1;
230      }
231
232    if (E_CONNMAN_EVENT_MANAGER_IN == 0)
233      E_CONNMAN_EVENT_MANAGER_IN = ecore_event_type_new();
234    if (E_CONNMAN_EVENT_MANAGER_OUT == 0)
235      E_CONNMAN_EVENT_MANAGER_OUT = ecore_event_type_new();
236    if (E_CONNMAN_EVENT_ELEMENT_ADD == 0)
237      E_CONNMAN_EVENT_ELEMENT_ADD = ecore_event_type_new();
238    if (E_CONNMAN_EVENT_ELEMENT_DEL == 0)
239      E_CONNMAN_EVENT_ELEMENT_DEL = ecore_event_type_new();
240    if (E_CONNMAN_EVENT_ELEMENT_UPDATED == 0)
241      E_CONNMAN_EVENT_ELEMENT_UPDATED = ecore_event_type_new();
242
243    if (e_connman_iface_manager == NULL)
244      e_connman_iface_manager = eina_stringshare_add("org.moblin.connman.Manager");
245    if (e_connman_iface_network == NULL)
246      e_connman_iface_network = eina_stringshare_add("org.moblin.connman.Network");
247    if (e_connman_iface_profile == NULL)
248      e_connman_iface_profile = eina_stringshare_add("org.moblin.connman.Profile");
249    if (e_connman_iface_service == NULL)
250      e_connman_iface_service = eina_stringshare_add("org.moblin.connman.Service");
251    if (e_connman_iface_device == NULL)
252      e_connman_iface_device = eina_stringshare_add("org.moblin.connman.Device");
253    if (e_connman_iface_connection == NULL)
254      e_connman_iface_connection = eina_stringshare_add("org.moblin.connman.Connection");
255
256    if (e_connman_prop_available == NULL)
257      e_connman_prop_available = eina_stringshare_add("Available");
258    if (e_connman_prop_connected == NULL)
259      e_connman_prop_connected = eina_stringshare_add("Connected");
260    if (e_connman_prop_connections == NULL)
261      e_connman_prop_connections = eina_stringshare_add("Connections");
262    if (e_connman_prop_default == NULL)
263      e_connman_prop_default = eina_stringshare_add("Default");
264    if (e_connman_prop_device == NULL)
265      e_connman_prop_device = eina_stringshare_add("Device");
266    if (e_connman_prop_devices == NULL)
267      e_connman_prop_devices = eina_stringshare_add("Devices");
268    if (e_connman_prop_interface == NULL)
269      e_connman_prop_interface = eina_stringshare_add("Interface");
270    if (e_connman_prop_ipv4_address == NULL)
271      e_connman_prop_ipv4_address = eina_stringshare_add("IPv4.Address");
272    if (e_connman_prop_ipv4_method == NULL)
273      e_connman_prop_ipv4_method = eina_stringshare_add("IPv4.Method");
274    if (e_connman_prop_name == NULL)
275      e_connman_prop_name = eina_stringshare_add("Name");
276    if (e_connman_prop_network == NULL)
277      e_connman_prop_network = eina_stringshare_add("Network");
278    if (e_connman_prop_networks == NULL)
279      e_connman_prop_networks = eina_stringshare_add("Networks");
280    if (e_connman_prop_offline_mode == NULL)
281      e_connman_prop_offline_mode = eina_stringshare_add("OfflineMode");
282    if (e_connman_prop_policy == NULL)
283      e_connman_prop_policy = eina_stringshare_add("Policy");
284    if (e_connman_prop_powered == NULL)
285      e_connman_prop_powered = eina_stringshare_add("Powered");
286    if (e_connman_prop_priority == NULL)
287      e_connman_prop_priority = eina_stringshare_add("Priority");
288    if (e_connman_prop_profiles == NULL)
289      e_connman_prop_profiles = eina_stringshare_add("Profiles");
290    if (e_connman_prop_remember == NULL)
291      e_connman_prop_remember = eina_stringshare_add("Remember");
292    if (e_connman_prop_scan_interval == NULL)
293      e_connman_prop_scan_interval = eina_stringshare_add("ScanInterval");
294    if (e_connman_prop_scanning == NULL)
295      e_connman_prop_scanning = eina_stringshare_add("Scanning");
296    if (e_connman_prop_state == NULL)
297      e_connman_prop_state = eina_stringshare_add("State");
298    if (e_connman_prop_strengh == NULL)
299      e_connman_prop_strengh = eina_stringshare_add("Strength");
300    if (e_connman_prop_type == NULL)
301      e_connman_prop_type = eina_stringshare_add("Type");
302    if (e_connman_prop_wifi_mode == NULL)
303      e_connman_prop_wifi_mode = eina_stringshare_add("WiFi.Mode");
304    if (e_connman_prop_wifi_passphrase == NULL)
305      e_connman_prop_wifi_passphrase = eina_stringshare_add("WiFi.Passphrase");
306    if (e_connman_prop_wifi_security == NULL)
307      e_connman_prop_wifi_security = eina_stringshare_add("WiFi.Security");
308    if (e_connman_prop_wifi_ssid == NULL)
309      e_connman_prop_wifi_ssid = eina_stringshare_add("WiFi.SSID");
310
311    e_connman_conn = edbus_conn;
312    cb_name_owner_changed = e_dbus_signal_handler_add
313      (e_connman_conn, fdo_bus_name, fdo_path, fdo_interface, "NameOwnerChanged",
314       _e_connman_system_name_owner_changed, NULL);
315
316    if (pending_get_name_owner)
317      dbus_pending_call_cancel(pending_get_name_owner);
318
319    pending_get_name_owner = e_dbus_get_name_owner
320      (e_connman_conn, bus_name, _e_connman_get_name_owner, NULL);
321
322    e_connman_elements_init();
323
324    return init_count;
325 }
326
327 static inline void
328 _stringshare_del(const char **str)
329 {
330    if (!*str)
331      return;
332    eina_stringshare_del(*str);
333    *str = NULL;
334 }
335
336 /**
337  * Shutdown connman system.
338  *
339  * When count drops to 0 resources will be released and no calls should be
340  * made anymore.
341  */
342 unsigned int
343 e_connman_system_shutdown(void)
344 {
345    if (init_count == 0)
346      {
347         E_DBUS_LOG_ERR("E-Dbus connman Error: connman system already shut down.");
348         return 0;
349      }
350    init_count--;
351    if (init_count > 0)
352      return init_count;
353
354    _stringshare_del(&e_connman_iface_manager);
355    _stringshare_del(&e_connman_iface_network);
356    _stringshare_del(&e_connman_iface_profile);
357    _stringshare_del(&e_connman_iface_service);
358    _stringshare_del(&e_connman_iface_device);
359    _stringshare_del(&e_connman_iface_connection);
360
361    _stringshare_del(&e_connman_prop_available);
362    _stringshare_del(&e_connman_prop_connected);
363    _stringshare_del(&e_connman_prop_connections);
364    _stringshare_del(&e_connman_prop_default);
365    _stringshare_del(&e_connman_prop_device);
366    _stringshare_del(&e_connman_prop_devices);
367    _stringshare_del(&e_connman_prop_interface);
368    _stringshare_del(&e_connman_prop_ipv4_address);
369    _stringshare_del(&e_connman_prop_ipv4_method);
370    _stringshare_del(&e_connman_prop_name);
371    _stringshare_del(&e_connman_prop_network);
372    _stringshare_del(&e_connman_prop_networks);
373    _stringshare_del(&e_connman_prop_offline_mode);
374    _stringshare_del(&e_connman_prop_policy);
375    _stringshare_del(&e_connman_prop_powered);
376    _stringshare_del(&e_connman_prop_priority);
377    _stringshare_del(&e_connman_prop_profiles);
378    _stringshare_del(&e_connman_prop_remember);
379    _stringshare_del(&e_connman_prop_scan_interval);
380    _stringshare_del(&e_connman_prop_scanning);
381    _stringshare_del(&e_connman_prop_state);
382    _stringshare_del(&e_connman_prop_strengh);
383    _stringshare_del(&e_connman_prop_type);
384    _stringshare_del(&e_connman_prop_wifi_mode);
385    _stringshare_del(&e_connman_prop_wifi_passphrase);
386    _stringshare_del(&e_connman_prop_wifi_security);
387    _stringshare_del(&e_connman_prop_wifi_ssid);
388
389    if (pending_get_name_owner)
390      {
391         dbus_pending_call_cancel(pending_get_name_owner);
392         pending_get_name_owner = NULL;
393      }
394
395    if (cb_name_owner_changed)
396      {
397         e_dbus_signal_handler_del(e_connman_conn, cb_name_owner_changed);
398         cb_name_owner_changed = NULL;
399      }
400
401    if (unique_name)
402      _e_connman_system_name_owner_exit();
403
404    e_connman_elements_shutdown();
405    eina_log_domain_unregister(_e_dbus_connman_log_dom);
406    e_connman_conn = NULL;
407
408    return init_count;
409 }