3
0
mirror of https://git.kernel.org/pub/scm/network/wireless/iwd.git synced 2025-01-05 12:52:37 +01:00

knownnetworks: add known_networks_{add,remove}

These two API's have been added to allow hotspot to add its
own networks to the known network list. This will allow any
added networks to behave exactly like they do now, including
all the dbus and watchlist functionality.
This commit is contained in:
James Prestwood 2019-08-15 13:15:16 -07:00 committed by Denis Kenzior
parent c91bbe42a0
commit 630c487534
2 changed files with 18 additions and 8 deletions

View File

@ -247,12 +247,7 @@ static void known_network_update(struct network_info *orig_network,
if (orig_network) if (orig_network)
return; return;
l_queue_insert(known_networks, network, connected_time_compare, NULL); known_networks_add(network);
known_network_register_dbus(network);
WATCHLIST_NOTIFY(&known_network_watches,
known_networks_watch_func_t,
KNOWN_NETWORKS_EVENT_ADDED, network);
} }
bool known_networks_foreach(known_networks_foreach_func_t function, bool known_networks_foreach(known_networks_foreach_func_t function,
@ -504,7 +499,7 @@ static void setup_known_network_interface(struct l_dbus_interface *interface)
NULL); NULL);
} }
static void known_network_removed(struct network_info *network) void known_networks_remove(struct network_info *network)
{ {
if (network->is_hidden) if (network->is_hidden)
num_known_hidden_networks--; num_known_hidden_networks--;
@ -517,9 +512,21 @@ static void known_network_removed(struct network_info *network)
known_networks_watch_func_t, known_networks_watch_func_t,
KNOWN_NETWORKS_EVENT_REMOVED, network); KNOWN_NETWORKS_EVENT_REMOVED, network);
network->ops->remove(network);
network_info_free(network); network_info_free(network);
} }
void known_networks_add(struct network_info *network)
{
l_queue_insert(known_networks, network, connected_time_compare, NULL);
known_network_register_dbus(network);
WATCHLIST_NOTIFY(&known_network_watches,
known_networks_watch_func_t,
KNOWN_NETWORKS_EVENT_ADDED, network);
}
static void known_networks_watch_cb(const char *filename, static void known_networks_watch_cb(const char *filename,
enum l_dir_watch_event event, enum l_dir_watch_event event,
void *user_data) void *user_data)
@ -566,7 +573,7 @@ static void known_networks_watch_cb(const char *filename,
settings, &connected_time); settings, &connected_time);
else { else {
if (network_before) if (network_before)
known_network_removed(network_before); known_networks_remove(network_before);
} }
l_settings_free(settings); l_settings_free(settings);

View File

@ -81,3 +81,6 @@ void known_networks_watch_remove(uint32_t id);
struct l_settings *network_info_open_settings(struct network_info *info); struct l_settings *network_info_open_settings(struct network_info *info);
int network_info_touch(struct network_info *info); int network_info_touch(struct network_info *info);
const char *network_info_get_path(const struct network_info *info); const char *network_info_get_path(const struct network_info *info);
void known_networks_add(struct network_info *info);
void known_networks_remove(struct network_info *info);