5 * Copyright (C) 2007-2009 Intel Corporation. All rights reserved.
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License version 2 as
9 * published by the Free Software Foundation.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
32 struct connman_network {
33 struct connman_element element;
34 enum connman_network_type type;
35 enum connman_network_protocol protocol;
36 connman_bool_t available;
37 connman_bool_t connected;
38 connman_bool_t remember;
39 connman_uint8_t priority;
40 connman_uint8_t strength;
45 struct connman_network_driver *driver;
48 connman_bool_t registered;
50 struct connman_device *device;
61 static const char *type2string(enum connman_network_type type)
64 case CONNMAN_NETWORK_TYPE_UNKNOWN:
65 case CONNMAN_NETWORK_TYPE_VENDOR:
67 case CONNMAN_NETWORK_TYPE_WIFI:
69 case CONNMAN_NETWORK_TYPE_BLUETOOTH_PAN:
70 case CONNMAN_NETWORK_TYPE_BLUETOOTH_DUN:
72 case CONNMAN_NETWORK_TYPE_HSO:
79 static DBusMessage *get_properties(DBusConnection *conn,
80 DBusMessage *msg, void *data)
82 struct connman_network *network = data;
84 DBusMessageIter array, dict;
88 if (__connman_security_check_privilege(msg,
89 CONNMAN_SECURITY_PRIVILEGE_PUBLIC) < 0)
90 return __connman_error_permission_denied(msg);
92 reply = dbus_message_new_method_return(msg);
96 dbus_message_iter_init_append(reply, &array);
98 dbus_message_iter_open_container(&array, DBUS_TYPE_ARRAY,
99 DBUS_DICT_ENTRY_BEGIN_CHAR_AS_STRING
100 DBUS_TYPE_STRING_AS_STRING DBUS_TYPE_VARIANT_AS_STRING
101 DBUS_DICT_ENTRY_END_CHAR_AS_STRING, &dict);
103 if (network->device) {
104 const char *path = connman_device_get_path(network->device);
106 connman_dbus_dict_append_variant(&dict, "Device",
107 DBUS_TYPE_OBJECT_PATH, &path);
110 if (network->name != NULL)
111 connman_dbus_dict_append_variant(&dict, "Name",
112 DBUS_TYPE_STRING, &network->name);
114 connman_dbus_dict_append_variant(&dict, "Available",
115 DBUS_TYPE_BOOLEAN, &network->available);
117 connman_dbus_dict_append_variant(&dict, "Connected",
118 DBUS_TYPE_BOOLEAN, &network->connected);
120 connman_dbus_dict_append_variant(&dict, "Remember",
121 DBUS_TYPE_BOOLEAN, &network->remember);
123 if (network->priority > 0)
124 connman_dbus_dict_append_variant(&dict, "Priority",
125 DBUS_TYPE_BYTE, &network->priority);
127 if (network->strength > 0)
128 connman_dbus_dict_append_variant(&dict, "Strength",
129 DBUS_TYPE_BYTE, &network->strength);
131 if (network->wifi.ssid != NULL && network->wifi.ssid_len > 0)
132 connman_dbus_dict_append_array(&dict, "WiFi.SSID",
133 DBUS_TYPE_BYTE, &network->wifi.ssid,
134 network->wifi.ssid_len);
136 if (network->wifi.mode != NULL)
137 connman_dbus_dict_append_variant(&dict, "WiFi.Mode",
138 DBUS_TYPE_STRING, &network->wifi.mode);
140 if (network->wifi.security != NULL)
141 connman_dbus_dict_append_variant(&dict, "WiFi.Security",
142 DBUS_TYPE_STRING, &network->wifi.security);
144 if (network->wifi.passphrase != NULL &&
145 __connman_security_check_privilege(msg,
146 CONNMAN_SECURITY_PRIVILEGE_SECRET) == 0)
147 connman_dbus_dict_append_variant(&dict, "WiFi.Passphrase",
148 DBUS_TYPE_STRING, &network->wifi.passphrase);
150 dbus_message_iter_close_container(&array, &dict);
155 static DBusMessage *set_property(DBusConnection *conn,
156 DBusMessage *msg, void *data)
158 struct connman_network *network = data;
159 DBusMessageIter iter, value;
162 DBG("conn %p", conn);
164 if (dbus_message_iter_init(msg, &iter) == FALSE)
165 return __connman_error_invalid_arguments(msg);
167 dbus_message_iter_get_basic(&iter, &name);
168 dbus_message_iter_next(&iter);
169 dbus_message_iter_recurse(&iter, &value);
171 if (__connman_security_check_privilege(msg,
172 CONNMAN_SECURITY_PRIVILEGE_MODIFY) < 0)
173 return __connman_error_permission_denied(msg);
175 if (g_str_equal(name, "Remember") == TRUE) {
176 connman_bool_t remember;
178 dbus_message_iter_get_basic(&value, &remember);
180 if (network->remember == remember)
181 return __connman_error_invalid_arguments(msg);
183 network->remember = remember;
184 } else if (g_str_equal(name, "WiFi.Passphrase") == TRUE) {
185 const char *passphrase;
187 if (__connman_security_check_privilege(msg,
188 CONNMAN_SECURITY_PRIVILEGE_SECRET) < 0)
189 return __connman_error_permission_denied(msg);
191 dbus_message_iter_get_basic(&value, &passphrase);
193 g_free(network->wifi.passphrase);
194 network->wifi.passphrase = g_strdup(passphrase);
195 } else if (g_str_equal(name, "Priority") == TRUE) {
196 connman_uint8_t priority;
198 dbus_message_iter_get_basic(&value, &priority);
200 network->priority = priority;
203 __connman_storage_save_network(network);
205 return g_dbus_create_reply(msg, DBUS_TYPE_INVALID);
208 static DBusMessage *do_connect(DBusConnection *conn,
209 DBusMessage *msg, void *data)
211 struct connman_network *network = data;
214 DBG("conn %p", conn);
216 if (__connman_security_check_privilege(msg,
217 CONNMAN_SECURITY_PRIVILEGE_MODIFY) < 0)
218 return __connman_error_permission_denied(msg);
220 if (network->connected == TRUE)
221 return __connman_error_failed(msg);
223 if (network->driver && network->driver->connect) {
224 err = network->driver->connect(network);
225 if (err < 0 && err != -EINPROGRESS)
226 return __connman_error_failed(msg);
228 network->connected = TRUE;
230 return g_dbus_create_reply(msg, DBUS_TYPE_INVALID);
233 static DBusMessage *do_disconnect(DBusConnection *conn,
234 DBusMessage *msg, void *data)
236 struct connman_network *network = data;
239 DBG("conn %p", conn);
241 if (__connman_security_check_privilege(msg,
242 CONNMAN_SECURITY_PRIVILEGE_MODIFY) < 0)
243 return __connman_error_permission_denied(msg);
245 if (network->connected == FALSE)
246 return __connman_error_failed(msg);
248 connman_element_unregister_children(&network->element);
250 if (network->driver && network->driver->disconnect) {
251 err = network->driver->disconnect(network);
252 if (err < 0 && err != -EINPROGRESS)
253 return __connman_error_failed(msg);
255 network->connected = FALSE;
257 return g_dbus_create_reply(msg, DBUS_TYPE_INVALID);
260 static GDBusMethodTable network_methods[] = {
261 { "GetProperties", "", "a{sv}", get_properties },
262 { "SetProperty", "sv", "", set_property },
263 { "Connect", "", "", do_connect },
264 { "Disconnect", "", "", do_disconnect },
268 static GDBusSignalTable network_signals[] = {
269 { "PropertyChanged", "sv" },
273 static DBusConnection *connection;
275 static void append_networks(struct connman_device *device,
276 DBusMessageIter *entry)
278 DBusMessageIter value, iter;
279 const char *key = "Networks";
281 dbus_message_iter_append_basic(entry, DBUS_TYPE_STRING, &key);
283 dbus_message_iter_open_container(entry, DBUS_TYPE_VARIANT,
284 DBUS_TYPE_ARRAY_AS_STRING DBUS_TYPE_OBJECT_PATH_AS_STRING,
287 dbus_message_iter_open_container(&value, DBUS_TYPE_ARRAY,
288 DBUS_TYPE_OBJECT_PATH_AS_STRING, &iter);
289 __connman_element_list((struct connman_element *) device,
290 CONNMAN_ELEMENT_TYPE_NETWORK, &iter);
291 dbus_message_iter_close_container(&value, &iter);
293 dbus_message_iter_close_container(entry, &value);
296 static void emit_networks_signal(struct connman_device *device)
298 const char *path = connman_device_get_path(device);
300 DBusMessageIter entry;
302 signal = dbus_message_new_signal(path,
303 CONNMAN_DEVICE_INTERFACE, "PropertyChanged");
307 dbus_message_iter_init_append(signal, &entry);
309 append_networks(device, &entry);
311 g_dbus_send_message(connection, signal);
314 static int register_interface(struct connman_element *element)
316 struct connman_network *network = element->network;
318 DBG("element %p name %s", element, element->name);
320 if (g_dbus_register_interface(connection, element->path,
321 CONNMAN_NETWORK_INTERFACE,
322 network_methods, network_signals,
323 NULL, network, NULL) == FALSE) {
324 connman_error("Failed to register %s network", element->path);
328 network->registered = TRUE;
330 emit_networks_signal(network->device);
335 static void unregister_interface(struct connman_element *element)
337 struct connman_network * network = element->network;
339 DBG("element %p name %s", element, element->name);
341 network->registered = FALSE;
343 emit_networks_signal(network->device);
345 g_dbus_unregister_interface(connection, element->path,
346 CONNMAN_NETWORK_INTERFACE);
349 connman_bool_t __connman_network_has_driver(struct connman_network *network)
351 if (network == NULL || network->driver == NULL)
354 return network->registered;
357 static GSList *driver_list = NULL;
359 static gint compare_priority(gconstpointer a, gconstpointer b)
361 const struct connman_network_driver *driver1 = a;
362 const struct connman_network_driver *driver2 = b;
364 return driver2->priority - driver1->priority;
368 * connman_network_driver_register:
369 * @driver: network driver definition
371 * Register a new network driver
373 * Returns: %0 on success
375 int connman_network_driver_register(struct connman_network_driver *driver)
377 DBG("driver %p name %s", driver, driver->name);
379 driver_list = g_slist_insert_sorted(driver_list, driver,
386 * connman_network_driver_unregister:
387 * @driver: network driver definition
389 * Remove a previously registered network driver
391 void connman_network_driver_unregister(struct connman_network_driver *driver)
393 DBG("driver %p name %s", driver, driver->name);
395 driver_list = g_slist_remove(driver_list, driver);
398 static void network_destruct(struct connman_element *element)
400 struct connman_network *network = element->network;
402 DBG("element %p name %s", element, element->name);
404 g_free(network->wifi.ssid);
405 g_free(network->wifi.mode);
406 g_free(network->wifi.security);
407 g_free(network->wifi.passphrase);
409 g_free(network->node);
410 g_free(network->name);
411 g_free(network->identifier);
415 * connman_network_create:
416 * @identifier: network identifier (for example an unqiue name)
418 * Allocate a new network and assign the #identifier to it.
420 * Returns: a newly-allocated #connman_network structure
422 struct connman_network *connman_network_create(const char *identifier,
423 enum connman_network_type type)
425 struct connman_network *network;
426 connman_uint8_t strength = 0;
429 DBG("identifier %s type %d", identifier, type);
431 network = g_try_new0(struct connman_network, 1);
435 DBG("network %p", network);
437 network->element.refcount = 1;
439 network->element.name = g_strdup(identifier);
440 network->element.type = CONNMAN_ELEMENT_TYPE_NETWORK;
441 network->element.index = -1;
443 network->element.network = network;
444 network->element.destruct = network_destruct;
446 str = type2string(type);
448 connman_element_add_static_property(&network->element,
449 "Type", DBUS_TYPE_STRING, &str);
451 connman_element_add_static_property(&network->element,
452 "Strength", DBUS_TYPE_BYTE, &strength);
454 network->type = type;
455 network->identifier = g_strdup(identifier);
461 * connman_network_ref:
462 * @network: network structure
464 * Increase reference counter of network
466 struct connman_network *connman_network_ref(struct connman_network *network)
468 if (connman_element_ref(&network->element) == NULL)
475 * connman_network_unref:
476 * @network: network structure
478 * Decrease reference counter of network
480 void connman_network_unref(struct connman_network *network)
482 connman_element_unref(&network->element);
486 * connman_network_get_identifier:
487 * @network: network structure
489 * Get identifier of network
491 const char *connman_network_get_identifier(struct connman_network *network)
493 return network->identifier;
497 * connman_network_get_path:
498 * @network: network structure
500 * Get path name of network
502 const char *connman_network_get_path(struct connman_network *network)
504 return network->element.path;
508 * connman_network_set_index:
509 * @network: network structure
510 * @index: index number
512 * Set index number of network
514 void connman_network_set_index(struct connman_network *network, int index)
516 network->element.index = index;
520 * connman_network_get_index:
521 * @network: network structure
523 * Get index number of network
525 int connman_network_get_index(struct connman_network *network)
527 return network->element.index;
531 * connman_network_set_protocol:
532 * @network: network structure
533 * @protocol: network protocol
535 * Change protocol of network
537 void connman_network_set_protocol(struct connman_network *network,
538 enum connman_network_protocol protocol)
540 network->protocol = protocol;
544 * connman_network_set_available:
545 * @network: network structure
546 * @available: availability state
548 * Change availability state of network (in range)
550 int connman_network_set_available(struct connman_network *network,
551 connman_bool_t available)
554 DBusMessageIter entry, value;
555 const char *key = "Available";
557 DBG("network %p available %d", network, available);
559 if (network->available == available)
562 network->available = available;
564 if (network->registered == FALSE)
567 if (network->connected == FALSE && network->remember == FALSE)
570 signal = dbus_message_new_signal(network->element.path,
571 CONNMAN_NETWORK_INTERFACE, "PropertyChanged");
575 dbus_message_iter_init_append(signal, &entry);
577 dbus_message_iter_append_basic(&entry, DBUS_TYPE_STRING, &key);
579 dbus_message_iter_open_container(&entry, DBUS_TYPE_VARIANT,
580 DBUS_TYPE_BOOLEAN_AS_STRING, &value);
581 dbus_message_iter_append_basic(&value, DBUS_TYPE_BOOLEAN, &available);
582 dbus_message_iter_close_container(&entry, &value);
584 g_dbus_send_message(connection, signal);
590 * connman_network_get_available:
591 * @network: network structure
593 * Get network available setting
595 connman_bool_t connman_network_get_available(struct connman_network *network)
597 return network->available;
601 * connman_network_set_connected:
602 * @network: network structure
603 * @connected: connected state
605 * Change connected state of network
607 int connman_network_set_connected(struct connman_network *network,
608 connman_bool_t connected)
611 DBusMessageIter entry, value;
612 const char *key = "Connected";
614 DBG("network %p connected %d", network, connected);
616 if (network->connected == connected)
619 network->connected = connected;
621 if (network->registered == FALSE)
624 signal = dbus_message_new_signal(network->element.path,
625 CONNMAN_NETWORK_INTERFACE, "PropertyChanged");
629 dbus_message_iter_init_append(signal, &entry);
631 dbus_message_iter_append_basic(&entry, DBUS_TYPE_STRING, &key);
633 dbus_message_iter_open_container(&entry, DBUS_TYPE_VARIANT,
634 DBUS_TYPE_BOOLEAN_AS_STRING, &value);
635 dbus_message_iter_append_basic(&value, DBUS_TYPE_BOOLEAN, &connected);
636 dbus_message_iter_close_container(&entry, &value);
638 g_dbus_send_message(connection, signal);
640 if (connected == TRUE) {
641 struct connman_element *element;
642 enum connman_element_type type = CONNMAN_ELEMENT_TYPE_UNKNOWN;
644 switch (network->protocol) {
645 case CONNMAN_NETWORK_PROTOCOL_UNKNOWN:
647 case CONNMAN_NETWORK_PROTOCOL_IP:
648 type = CONNMAN_ELEMENT_TYPE_DHCP;
650 case CONNMAN_NETWORK_PROTOCOL_PPP:
651 type = CONNMAN_ELEMENT_TYPE_PPP;
655 __connman_device_increase_connections(network->device);
657 element = connman_element_create(NULL);
658 if (element != NULL) {
659 element->type = type;
660 element->index = network->element.index;
662 if (connman_element_register(element,
663 &network->element) < 0)
664 connman_element_unref(element);
667 connman_element_unregister_children(&network->element);
669 __connman_device_decrease_connections(network->device);
676 * connman_network_set_remember:
677 * @network: network structure
678 * @remember: remember state
680 * Change remember state of network (known networks)
682 int connman_network_set_remember(struct connman_network *network,
683 connman_bool_t remember)
686 DBusMessageIter entry, value;
687 const char *key = "Remember";
689 DBG("network %p remember %d", network, remember);
691 if (network->remember == remember)
694 network->remember = remember;
696 if (network->registered == FALSE)
699 signal = dbus_message_new_signal(network->element.path,
700 CONNMAN_NETWORK_INTERFACE, "PropertyChanged");
704 dbus_message_iter_init_append(signal, &entry);
706 dbus_message_iter_append_basic(&entry, DBUS_TYPE_STRING, &key);
708 dbus_message_iter_open_container(&entry, DBUS_TYPE_VARIANT,
709 DBUS_TYPE_BOOLEAN_AS_STRING, &value);
710 dbus_message_iter_append_basic(&value, DBUS_TYPE_BOOLEAN, &remember);
711 dbus_message_iter_close_container(&entry, &value);
713 g_dbus_send_message(connection, signal);
719 * connman_network_get_remember:
720 * @network: network structure
722 * Get network remember setting
724 connman_bool_t connman_network_get_remember(struct connman_network *network)
726 return network->remember;
730 * connman_network_connect:
731 * @network: network structure
735 int connman_network_connect(struct connman_network *network)
737 if (network->connected == TRUE)
740 if (network->driver && network->driver->connect)
741 return network->driver->connect(network);
743 network->connected = TRUE;
749 * connman_network_set_string:
750 * @network: network structure
751 * @key: unique identifier
752 * @value: string value
754 * Set string value for specific key
756 int connman_network_set_string(struct connman_network *network,
757 const char *key, const char *value)
759 DBG("network %p key %s value %s", network, key, value);
761 if (g_str_equal(key, "Name") == TRUE) {
762 g_free(network->name);
763 network->name = g_strdup(value);
764 } else if (g_str_equal(key, "Node") == TRUE) {
765 g_free(network->node);
766 network->node = g_strdup(value);
767 } else if (g_str_equal(key, "WiFi.Mode") == TRUE) {
768 g_free(network->wifi.mode);
769 network->wifi.mode = g_strdup(value);
770 } else if (g_str_equal(key, "WiFi.Security") == TRUE) {
771 g_free(network->wifi.security);
772 network->wifi.security = g_strdup(value);
773 } else if (g_str_equal(key, "WiFi.Passphrase") == TRUE) {
774 g_free(network->wifi.passphrase);
775 network->wifi.passphrase = g_strdup(value);
782 * connman_network_get_string:
783 * @network: network structure
784 * @key: unique identifier
786 * Get string value for specific key
788 const char *connman_network_get_string(struct connman_network *network,
791 DBG("network %p key %s", network, key);
793 if (g_str_equal(key, "Name") == TRUE)
794 return network->name;
795 else if (g_str_equal(key, "Node") == TRUE)
796 return network->node;
797 else if (g_str_equal(key, "WiFi.Mode") == TRUE)
798 return network->wifi.mode;
799 else if (g_str_equal(key, "WiFi.Security") == TRUE)
800 return network->wifi.security;
801 else if (g_str_equal(key, "WiFi.Passphrase") == TRUE)
802 return network->wifi.passphrase;
808 * connman_network_set_uint8:
809 * @network: network structure
810 * @key: unique identifier
811 * @value: integer value
813 * Set integer value for specific key
815 int connman_network_set_uint8(struct connman_network *network,
816 const char *key, connman_uint8_t value)
818 DBG("network %p key %s value %d", network, key, value);
820 if (g_str_equal(key, "Priority") == TRUE)
821 network->priority = value;
822 else if (g_str_equal(key, "Strength") == TRUE) {
823 network->strength = value;
824 connman_element_set_static_property(&network->element,
825 "Strength", DBUS_TYPE_BYTE, &value);
832 * connman_network_get_uint8:
833 * @network: network structure
834 * @key: unique identifier
836 * Get integer value for specific key
838 connman_uint8_t connman_network_get_uint8(struct connman_network *network,
841 DBG("network %p key %s", network, key);
843 if (g_str_equal(key, "Priority") == TRUE)
844 return network->priority;
845 else if (g_str_equal(key, "Strength") == TRUE)
846 return network->strength;
852 * connman_network_set_blob:
853 * @network: network structure
854 * @key: unique identifier
858 * Set binary blob value for specific key
860 int connman_network_set_blob(struct connman_network *network,
861 const char *key, const void *data, unsigned int size)
863 DBG("network %p key %s size %d", network, key, size);
865 if (g_str_equal(key, "WiFi.SSID") == TRUE) {
866 g_free(network->wifi.ssid);
867 network->wifi.ssid = g_try_malloc(size);
868 if (network->wifi.ssid != NULL) {
869 memcpy(network->wifi.ssid, data, size);
870 network->wifi.ssid_len = size;
872 network->wifi.ssid_len = 0;
879 * connman_network_get_blob:
880 * @network: network structure
881 * @key: unique identifier
882 * @size: pointer to blob size
884 * Get binary blob value for specific key
886 const void *connman_network_get_blob(struct connman_network *network,
887 const char *key, unsigned int *size)
889 DBG("network %p key %s", network, key);
891 if (g_str_equal(key, "WiFi.SSID") == TRUE) {
893 *size = network->wifi.ssid_len;
894 return network->wifi.ssid;
900 void __connman_network_set_device(struct connman_network *network,
901 struct connman_device *device)
903 network->device = device;
907 * connman_network_get_device:
908 * @network: network structure
910 * Get parent device of network
912 struct connman_device *connman_network_get_device(struct connman_network *network)
914 return network->device;
918 * connman_network_get_data:
919 * @network: network structure
921 * Get private network data pointer
923 void *connman_network_get_data(struct connman_network *network)
925 return network->driver_data;
929 * connman_network_set_data:
930 * @network: network structure
931 * @data: data pointer
933 * Set private network data pointer
935 void connman_network_set_data(struct connman_network *network, void *data)
937 network->driver_data = data;
940 static gboolean match_driver(struct connman_network *network,
941 struct connman_network_driver *driver)
943 if (network->type == driver->type ||
944 driver->type == CONNMAN_NETWORK_TYPE_UNKNOWN)
950 static int network_probe(struct connman_element *element)
952 struct connman_network *network = element->network;
956 DBG("element %p name %s", element, element->name);
961 for (list = driver_list; list; list = list->next) {
962 struct connman_network_driver *driver = list->data;
964 if (match_driver(network, driver) == FALSE)
967 DBG("driver %p name %s", driver, driver->name);
969 if (driver->probe(network) == 0) {
970 network->driver = driver;
975 if (network->driver == NULL)
978 err = register_interface(element);
980 if (network->driver->remove)
981 network->driver->remove(network);
988 static void network_remove(struct connman_element *element)
990 struct connman_network *network = element->network;
992 DBG("element %p name %s", element, element->name);
997 if (network->driver == NULL)
1000 unregister_interface(element);
1002 if (network->driver->remove)
1003 network->driver->remove(network);
1006 static struct connman_driver network_driver = {
1008 .type = CONNMAN_ELEMENT_TYPE_NETWORK,
1009 .priority = CONNMAN_DRIVER_PRIORITY_LOW,
1010 .probe = network_probe,
1011 .remove = network_remove,
1014 static int network_init(struct connman_device *device)
1016 DBG("device %p", device);
1021 static int network_load(struct connman_network *network)
1024 gchar *pathname, *data = NULL;
1029 DBG("network %p", network);
1031 name = connman_device_get_name(network->device);
1035 pathname = g_strdup_printf("%s/%s.conf", STORAGEDIR, name);
1036 if (pathname == NULL)
1039 keyfile = g_key_file_new();
1041 if (g_file_get_contents(pathname, &data, &length, NULL) == FALSE) {
1048 if (g_key_file_load_from_data(keyfile, data, length,
1049 0, NULL) == FALSE) {
1056 network->remember = g_key_file_get_boolean(keyfile,
1057 network->identifier, "Remember", NULL);
1059 val = g_key_file_get_integer(keyfile, network->identifier,
1062 network->priority = val;
1064 if (network->remember == TRUE) {
1065 g_free(network->wifi.security);
1066 network->wifi.security = g_key_file_get_string(keyfile,
1067 network->identifier, "WiFi.Security", NULL);
1069 g_free(network->wifi.passphrase);
1070 network->wifi.passphrase = g_key_file_get_string(keyfile,
1071 network->identifier, "WiFi.Passphrase", NULL);
1074 g_key_file_free(keyfile);
1079 static int network_save(struct connman_network *network)
1082 gchar *pathname, *data = NULL;
1086 DBG("network %p", network);
1088 name = connman_device_get_name(network->device);
1092 pathname = g_strdup_printf("%s/%s.conf", STORAGEDIR, name);
1093 if (pathname == NULL)
1096 keyfile = g_key_file_new();
1098 if (g_file_get_contents(pathname, &data, &length, NULL) == FALSE)
1102 if (g_key_file_load_from_data(keyfile, data, length,
1110 g_key_file_set_boolean(keyfile, network->identifier,
1111 "Remember", network->remember);
1113 if (network->priority > 0)
1114 g_key_file_set_integer(keyfile, network->identifier,
1115 "Priority", network->priority);
1117 if (network->remember == TRUE) {
1118 if (network->wifi.security != NULL)
1119 g_key_file_set_string(keyfile, network->identifier,
1120 "WiFi.Security", network->wifi.security);
1122 if (network->wifi.passphrase != NULL)
1123 g_key_file_set_string(keyfile, network->identifier,
1124 "WiFi.Passphrase", network->wifi.passphrase);
1127 data = g_key_file_to_data(keyfile, &length, NULL);
1129 g_file_set_contents(pathname, data, length, NULL);
1134 g_key_file_free(keyfile);
1141 static struct connman_storage network_storage = {
1143 .priority = CONNMAN_STORAGE_PRIORITY_LOW,
1144 .network_init = network_init,
1145 .network_load = network_load,
1146 .network_save = network_save,
1149 int __connman_network_init(void)
1153 connection = connman_dbus_get_connection();
1155 if (connman_storage_register(&network_storage) < 0)
1156 connman_error("Failed to register network storage");
1158 return connman_driver_register(&network_driver);
1161 void __connman_network_cleanup(void)
1165 connman_driver_unregister(&network_driver);
1167 connman_storage_unregister(&network_storage);
1169 dbus_connection_unref(connection);