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