3
0
mirror of https://git.kernel.org/pub/scm/network/wireless/iwd.git synced 2025-01-03 10:32:33 +01:00

hotspot: require 'Name' value in provisioning file

In order to implement get_name/get_type we need some value for the name
of the hotspot network. For simplicity we now require a 'Name' value
be provided inside the hotspot provisioning file. Eventually this may
change (e.g. obtained via ANQP).
This commit is contained in:
James Prestwood 2019-08-21 12:06:14 -07:00 committed by Denis Kenzior
parent a6a77ddc07
commit 313553aadd

View File

@ -51,6 +51,7 @@ struct hs20_config {
uint8_t *rc; /* roaming consortium */ uint8_t *rc; /* roaming consortium */
size_t rc_len; size_t rc_len;
char *object_path; char *object_path;
char *name;
}; };
static bool match_filename(const void *a, const void *b) static bool match_filename(const void *a, const void *b)
@ -74,6 +75,7 @@ static void hs20_config_free(void *user_data)
l_free(config->rc); l_free(config->rc);
l_free(config->object_path); l_free(config->object_path);
l_free(config->filename); l_free(config->filename);
l_free(config->name);
l_free(config); l_free(config);
} }
@ -166,6 +168,19 @@ static const char *hotspot_network_get_path(const struct network_info *info)
return config->object_path; return config->object_path;
} }
static const char *hotspot_network_get_name(const struct network_info *info)
{
struct hs20_config *config = l_container_of(info, struct hs20_config,
super);
return config->name;
}
static const char *hotspot_network_get_type(const struct network_info *info)
{
return "hotspot";
}
static bool hotspot_match_hessid(const struct network_info *info, static bool hotspot_match_hessid(const struct network_info *info,
const uint8_t *hessid) const uint8_t *hessid)
{ {
@ -237,6 +252,8 @@ static struct network_info_ops hotspot_ops = {
.remove = hotspot_network_remove, .remove = hotspot_network_remove,
.free = hotspot_network_free, .free = hotspot_network_free,
.get_path = hotspot_network_get_path, .get_path = hotspot_network_get_path,
.get_name = hotspot_network_get_name,
.get_type = hotspot_network_get_type,
.match_hessid = hotspot_match_hessid, .match_hessid = hotspot_match_hessid,
.match_roaming_consortium = hotspot_match_roaming_consortium, .match_roaming_consortium = hotspot_match_roaming_consortium,
@ -250,6 +267,7 @@ static struct hs20_config *hs20_config_new(struct l_settings *settings,
char *hessid_str; char *hessid_str;
char **nai_realms = NULL; char **nai_realms = NULL;
const char *rc_str; const char *rc_str;
char *name;
bool autoconnect = true; bool autoconnect = true;
/* One of HESSID, NAI realms, or Roaming Consortium must be included */ /* One of HESSID, NAI realms, or Roaming Consortium must be included */
@ -262,8 +280,12 @@ static struct hs20_config *hs20_config_new(struct l_settings *settings,
l_settings_get_bool(settings, "Settings", "Autoconnect", &autoconnect); l_settings_get_bool(settings, "Settings", "Autoconnect", &autoconnect);
if (!hessid_str && !nai_realms && !rc_str) name = l_settings_get_string(settings, "Hotspot", "Name");
return NULL;
if ((!hessid_str && !nai_realms && !rc_str) || !name) {
l_error("Could not parse hotspot config %s", filename);
goto free_values;
}
config = l_new(struct hs20_config, 1); config = l_new(struct hs20_config, 1);
@ -298,12 +320,20 @@ static struct hs20_config *hs20_config_new(struct l_settings *settings,
config->super.type = SECURITY_8021X; config->super.type = SECURITY_8021X;
config->super.ops = &hotspot_ops; config->super.ops = &hotspot_ops;
config->super.connected_time = l_path_get_mtime(filename); config->super.connected_time = l_path_get_mtime(filename);
config->name = name;
config->filename = l_strdup(filename); config->filename = l_strdup(filename);
known_networks_add(&config->super); known_networks_add(&config->super);
return config; return config;
free_values:
l_strv_free(nai_realms);
l_free(hessid_str);
l_free(name);
return NULL;
} }
static void hs20_dir_watch_cb(const char *filename, static void hs20_dir_watch_cb(const char *filename,