3
0
mirror of https://git.kernel.org/pub/scm/network/wireless/iwd.git synced 2024-11-22 14:49:24 +01:00

dpp-util: add dpp_configuration_new/dpp_configuration_to_json

Allows creating a new configuration object based on settings, ssid,
and akm suite (for configurator role) as well as converting a
configuration object to JSON.
This commit is contained in:
James Prestwood 2021-12-20 13:49:09 -08:00 committed by Denis Kenzior
parent d3fca54a7e
commit 00fddaa868
2 changed files with 87 additions and 0 deletions

View File

@ -193,6 +193,87 @@ free_contents:
return NULL; return NULL;
} }
/*
* The DPP spec does not specify a difference between FT AKMs and their normal
* counterpart. Because of this any FT AKM will just result in the standard
* 'psk' or 'sae' AKM.
*/
static const char *dpp_akm_to_string(enum ie_rsn_akm_suite akm_suite)
{
switch (akm_suite) {
case IE_RSN_AKM_SUITE_PSK:
case IE_RSN_AKM_SUITE_FT_USING_PSK:
case IE_RSN_AKM_SUITE_PSK_SHA256:
return "psk";
case IE_RSN_AKM_SUITE_SAE_SHA256:
case IE_RSN_AKM_SUITE_FT_OVER_SAE_SHA256:
return "sae";
default:
return NULL;
}
}
char *dpp_configuration_to_json(struct dpp_configuration *config)
{
_auto_(l_free) char *pass_or_psk;
_auto_(l_free) char *ssid;
ssid = l_malloc(config->ssid_len + 1);
memcpy(ssid, config->ssid, config->ssid_len);
ssid[config->ssid_len] = '\0';
if (config->passphrase)
pass_or_psk = l_strdup_printf("\"pass\":\"%s\"",
config->passphrase);
else
pass_or_psk = l_strdup_printf("\"psk\":\"%s\"",
config->psk);
return l_strdup_printf("{\"wi-fi_tech\":\"infra\","
"\"discovery\":{\"ssid\":\"%s\"},"
"\"cred\":{\"akm\":\"%s\",%s}}",
ssid, dpp_akm_to_string(config->akm_suites),
pass_or_psk);
}
struct dpp_configuration *dpp_configuration_new(
const struct l_settings *settings,
const char *ssid,
enum ie_rsn_akm_suite akm_suite)
{
struct dpp_configuration *config;
_auto_(l_free) char *passphrase = NULL;
_auto_(l_free) char *psk = NULL;
size_t ssid_len = strlen(ssid);
if (!l_settings_has_group(settings, "Security"))
return NULL;
passphrase = l_settings_get_string(settings, "Security", "Passphrase");
if (!passphrase) {
psk = l_settings_get_string(settings, "Security",
"PreSharedKey");
if (!psk)
return NULL;
}
config = l_new(struct dpp_configuration, 1);
memcpy(config->ssid, ssid, ssid_len);
config->ssid[ssid_len] = '\0';
config->ssid_len = ssid_len;
if (passphrase)
config->passphrase = l_steal_ptr(passphrase);
else
config->psk = l_steal_ptr(psk);
config->akm_suites = akm_suite;
return config;
}
void dpp_configuration_free(struct dpp_configuration *config) void dpp_configuration_free(struct dpp_configuration *config)
{ {
if (config->passphrase) if (config->passphrase)

View File

@ -21,6 +21,7 @@
*/ */
struct l_ecc_point; struct l_ecc_point;
struct l_ecc_scalar; struct l_ecc_scalar;
enum ie_rsn_akm_suite;
enum dpp_frame_type { enum dpp_frame_type {
DPP_FRAME_AUTHENTICATION_REQUEST = 0, DPP_FRAME_AUTHENTICATION_REQUEST = 0,
@ -110,6 +111,11 @@ struct dpp_configuration {
struct dpp_configuration *dpp_parse_configuration_object(const char *json, struct dpp_configuration *dpp_parse_configuration_object(const char *json,
size_t json_len); size_t json_len);
struct dpp_configuration *dpp_configuration_new(
const struct l_settings *settings,
const char *ssid,
enum ie_rsn_akm_suite akm_suite);
char *dpp_configuration_to_json(struct dpp_configuration *config);
void dpp_configuration_free(struct dpp_configuration *conf); void dpp_configuration_free(struct dpp_configuration *conf);
struct dpp_attr_iter { struct dpp_attr_iter {