Blame libnm-core/nm-setting-wifi-p2p.c

Packit Service b23acc
// SPDX-License-Identifier: LGPL-2.1+
Packit Service b23acc
/*
Packit Service b23acc
 * Copyright (C) 2019 Red Hat, Inc.
Packit Service b23acc
 */
Packit Service b23acc
Packit Service b23acc
#include "nm-default.h"
Packit Service b23acc
Packit Service b23acc
#include "nm-setting-wifi-p2p.h"
Packit Service b23acc
Packit Service b23acc
#include <net/ethernet.h>
Packit Service b23acc
Packit Service b23acc
#include "nm-utils.h"
Packit Service b23acc
#include "nm-libnm-core-intern/nm-common-macros.h"
Packit Service b23acc
#include "nm-utils-private.h"
Packit Service b23acc
#include "nm-setting-private.h"
Packit Service b23acc
Packit Service b23acc
/**
Packit Service b23acc
 * SECTION:nm-setting-wifi-p2p
Packit Service b23acc
 * @short_description: Describes connection properties for 802.11 Wi-Fi P2P networks
Packit Service b23acc
 *
Packit Service b23acc
 * The #NMSettingWifiP2P object is a #NMSetting subclass that describes properties
Packit Service b23acc
 * necessary for connection to 802.11 Wi-Fi P2P networks (aka Wi-Fi Direct).
Packit Service b23acc
 **/
Packit Service b23acc
Packit Service b23acc
/**
Packit Service b23acc
 * NMSettingWifiP2P:
Packit Service b23acc
 *
Packit Service b23acc
 * Wi-Fi P2P Settings
Packit Service b23acc
 *
Packit Service b23acc
 * Since: 1.16
Packit Service b23acc
 */
Packit Service b23acc
Packit Service b23acc
/*****************************************************************************/
Packit Service b23acc
Packit Service b23acc
NM_GOBJECT_PROPERTIES_DEFINE_BASE (
Packit Service b23acc
	PROP_PEER,
Packit Service b23acc
	PROP_WPS_METHOD,
Packit Service b23acc
	PROP_WFD_IES,
Packit Service b23acc
);
Packit Service b23acc
Packit Service b23acc
typedef struct {
Packit Service b23acc
	char *peer_mac_address;
Packit Service b23acc
	GBytes *wfd_ies;
Packit Service b23acc
Packit Service b23acc
	NMSettingWirelessSecurityWpsMethod wps_method;
Packit Service b23acc
} NMSettingWifiP2PPrivate;
Packit Service b23acc
Packit Service b23acc
struct _NMSettingWifiP2P {
Packit Service b23acc
	NMSetting parent;
Packit Service b23acc
	NMSettingWifiP2PPrivate _priv;
Packit Service b23acc
};
Packit Service b23acc
Packit Service b23acc
struct _NMSettingWifiP2PClass {
Packit Service b23acc
	NMSettingClass parent;
Packit Service b23acc
};
Packit Service b23acc
Packit Service b23acc
G_DEFINE_TYPE (NMSettingWifiP2P, nm_setting_wifi_p2p, NM_TYPE_SETTING)
Packit Service b23acc
Packit Service b23acc
#define NM_SETTING_WIFI_P2P_GET_PRIVATE(self) _NM_GET_PRIVATE (self, NMSettingWifiP2P, NM_IS_SETTING_WIFI_P2P, NMSetting)
Packit Service b23acc
Packit Service b23acc
/*****************************************************************************/
Packit Service b23acc
Packit Service b23acc
/**
Packit Service b23acc
 * nm_setting_wifi_p2p_get_peer:
Packit Service b23acc
 * @setting: the #NMSettingWifiP2P
Packit Service b23acc
 *
Packit Service b23acc
 * Returns: the #NMSettingWifiP2P:peer property of the setting
Packit Service b23acc
 *
Packit Service b23acc
 * Since: 1.16
Packit Service b23acc
 **/
Packit Service b23acc
const char *
Packit Service b23acc
nm_setting_wifi_p2p_get_peer (NMSettingWifiP2P *setting)
Packit Service b23acc
{
Packit Service b23acc
	g_return_val_if_fail (NM_IS_SETTING_WIFI_P2P (setting), NULL);
Packit Service b23acc
Packit Service b23acc
	return NM_SETTING_WIFI_P2P_GET_PRIVATE (setting)->peer_mac_address;
Packit Service b23acc
}
Packit Service b23acc
Packit Service b23acc
/**
Packit Service b23acc
 * nm_setting_wifi_p2p_get_wps_method:
Packit Service b23acc
 * @setting: the #NMSettingWifiP2P
Packit Service b23acc
 *
Packit Service b23acc
 * Returns: the #NMSettingWifiP2P:wps-method property of the setting
Packit Service b23acc
 *
Packit Service b23acc
 * Since: 1.16
Packit Service b23acc
 **/
Packit Service b23acc
NMSettingWirelessSecurityWpsMethod
Packit Service b23acc
nm_setting_wifi_p2p_get_wps_method (NMSettingWifiP2P *setting)
Packit Service b23acc
{
Packit Service b23acc
	g_return_val_if_fail (NM_IS_SETTING_WIFI_P2P (setting), NM_SETTING_WIRELESS_SECURITY_WPS_METHOD_DEFAULT);
Packit Service b23acc
Packit Service b23acc
	return NM_SETTING_WIFI_P2P_GET_PRIVATE (setting)->wps_method;
Packit Service b23acc
}
Packit Service b23acc
Packit Service b23acc
/**
Packit Service b23acc
 * nm_setting_wifi_p2p_get_wfd_ies:
Packit Service b23acc
 * @setting: the #NMSettingWiFiP2P
Packit Service b23acc
 *
Packit Service b23acc
 * Returns: (transfer none): the #NMSettingWiFiP2P:wfd-ies property of the setting
Packit Service b23acc
 *
Packit Service b23acc
 * Since: 1.16
Packit Service b23acc
 **/
Packit Service b23acc
GBytes *
Packit Service b23acc
nm_setting_wifi_p2p_get_wfd_ies (NMSettingWifiP2P *setting)
Packit Service b23acc
{
Packit Service b23acc
	g_return_val_if_fail (NM_IS_SETTING_WIFI_P2P (setting), NULL);
Packit Service b23acc
Packit Service b23acc
	return NM_SETTING_WIFI_P2P_GET_PRIVATE (setting)->wfd_ies;
Packit Service b23acc
}
Packit Service b23acc
Packit Service b23acc
/*****************************************************************************/
Packit Service b23acc
Packit Service b23acc
static gboolean
Packit Service b23acc
verify (NMSetting *setting, NMConnection *connection, GError **error)
Packit Service b23acc
{
Packit Service b23acc
	NMSettingWifiP2PPrivate *priv = NM_SETTING_WIFI_P2P_GET_PRIVATE (setting);
Packit Service b23acc
Packit Service b23acc
	if (!priv->peer_mac_address) {
Packit Service b23acc
		g_set_error_literal (error,
Packit Service b23acc
		                     NM_CONNECTION_ERROR,
Packit Service b23acc
		                     NM_CONNECTION_ERROR_MISSING_PROPERTY,
Packit Service b23acc
		                     _("property is missing"));
Packit Service b23acc
		g_prefix_error (error, "%s.%s: ", NM_SETTING_WIFI_P2P_SETTING_NAME, NM_SETTING_WIFI_P2P_PEER);
Packit Service b23acc
		return FALSE;
Packit Service b23acc
	}
Packit Service b23acc
Packit Service b23acc
	if (!nm_utils_hwaddr_valid (priv->peer_mac_address, ETH_ALEN)) {
Packit Service b23acc
		g_set_error_literal (error,
Packit Service b23acc
		                     NM_CONNECTION_ERROR,
Packit Service b23acc
		                     NM_CONNECTION_ERROR_INVALID_PROPERTY,
Packit Service b23acc
		                     _("property is invalid"));
Packit Service b23acc
		g_prefix_error (error, "%s.%s: ", NM_SETTING_WIFI_P2P_SETTING_NAME, NM_SETTING_WIFI_P2P_PEER);
Packit Service b23acc
		return FALSE;
Packit Service b23acc
	}
Packit Service b23acc
Packit Service b23acc
	if (!_nm_utils_wps_method_validate (priv->wps_method,
Packit Service b23acc
	                                    NM_SETTING_WIFI_P2P_SETTING_NAME,
Packit Service b23acc
	                                    NM_SETTING_WIFI_P2P_WPS_METHOD,
Packit Service b23acc
	                                    TRUE,
Packit Service b23acc
	                                    error))
Packit Service b23acc
		return FALSE;
Packit Service b23acc
Packit Service b23acc
	return TRUE;
Packit Service b23acc
}
Packit Service b23acc
Packit Service b23acc
/*****************************************************************************/
Packit Service b23acc
Packit Service b23acc
static void
Packit Service b23acc
get_property (GObject *object, guint prop_id,
Packit Service b23acc
              GValue *value, GParamSpec *pspec)
Packit Service b23acc
{
Packit Service b23acc
	NMSettingWifiP2P *setting = NM_SETTING_WIFI_P2P (object);
Packit Service b23acc
Packit Service b23acc
	switch (prop_id) {
Packit Service b23acc
	case PROP_PEER:
Packit Service b23acc
		g_value_set_string (value, nm_setting_wifi_p2p_get_peer (setting));
Packit Service b23acc
		break;
Packit Service b23acc
	case PROP_WPS_METHOD:
Packit Service b23acc
		g_value_set_uint (value, nm_setting_wifi_p2p_get_wps_method (setting));
Packit Service b23acc
		break;
Packit Service b23acc
	case PROP_WFD_IES:
Packit Service b23acc
		g_value_set_boxed (value, nm_setting_wifi_p2p_get_wfd_ies (setting));
Packit Service b23acc
		break;
Packit Service b23acc
	default:
Packit Service b23acc
		G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
Packit Service b23acc
		break;
Packit Service b23acc
	}
Packit Service b23acc
}
Packit Service b23acc
Packit Service b23acc
static void
Packit Service b23acc
set_property (GObject *object, guint prop_id,
Packit Service b23acc
              const GValue *value, GParamSpec *pspec)
Packit Service b23acc
{
Packit Service b23acc
	NMSettingWifiP2PPrivate *priv = NM_SETTING_WIFI_P2P_GET_PRIVATE (object);
Packit Service b23acc
Packit Service b23acc
	switch (prop_id) {
Packit Service b23acc
	case PROP_PEER:
Packit Service b23acc
		g_free (priv->peer_mac_address);
Packit Service b23acc
		priv->peer_mac_address = _nm_utils_hwaddr_canonical_or_invalid (g_value_get_string (value),
Packit Service b23acc
		                                                                ETH_ALEN);
Packit Service b23acc
		break;
Packit Service b23acc
	case PROP_WPS_METHOD:
Packit Service b23acc
		priv->wps_method = g_value_get_uint (value);
Packit Service b23acc
		break;
Packit Service b23acc
	case PROP_WFD_IES:
Packit Service b23acc
		nm_clear_pointer (&priv->wfd_ies, g_bytes_unref);
Packit Service b23acc
		priv->wfd_ies = g_value_dup_boxed (value);
Packit Service b23acc
		break;
Packit Service b23acc
	default:
Packit Service b23acc
		G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
Packit Service b23acc
		break;
Packit Service b23acc
	}
Packit Service b23acc
}
Packit Service b23acc
Packit Service b23acc
/*****************************************************************************/
Packit Service b23acc
Packit Service b23acc
static void
Packit Service b23acc
nm_setting_wifi_p2p_init (NMSettingWifiP2P *setting)
Packit Service b23acc
{
Packit Service b23acc
}
Packit Service b23acc
Packit Service b23acc
/**
Packit Service b23acc
 * nm_setting_wifi_p2p_new:
Packit Service b23acc
 *
Packit Service b23acc
 * Creates a new #NMSettingWifiP2P object with default values.
Packit Service b23acc
 *
Packit Service b23acc
 * Returns: (transfer full): the new empty #NMSettingWifiP2P object
Packit Service b23acc
 *
Packit Service b23acc
 * Since: 1.16
Packit Service b23acc
 **/
Packit Service b23acc
NMSetting *
Packit Service b23acc
nm_setting_wifi_p2p_new (void)
Packit Service b23acc
{
Packit Service b23acc
	return g_object_new (NM_TYPE_SETTING_WIFI_P2P, NULL);
Packit Service b23acc
}
Packit Service b23acc
Packit Service b23acc
static void
Packit Service b23acc
finalize (GObject *object)
Packit Service b23acc
{
Packit Service b23acc
	NMSettingWifiP2PPrivate *priv = NM_SETTING_WIFI_P2P_GET_PRIVATE (object);
Packit Service b23acc
Packit Service b23acc
	g_free (priv->peer_mac_address);
Packit Service b23acc
	g_bytes_unref (priv->wfd_ies);
Packit Service b23acc
Packit Service b23acc
	G_OBJECT_CLASS (nm_setting_wifi_p2p_parent_class)->finalize (object);
Packit Service b23acc
}
Packit Service b23acc
Packit Service b23acc
static void
Packit Service b23acc
nm_setting_wifi_p2p_class_init (NMSettingWifiP2PClass *setting_wifi_p2p_class)
Packit Service b23acc
{
Packit Service b23acc
	GObjectClass *object_class = G_OBJECT_CLASS (setting_wifi_p2p_class);
Packit Service b23acc
	NMSettingClass *setting_class = NM_SETTING_CLASS (setting_wifi_p2p_class);
Packit Service b23acc
Packit Service b23acc
	object_class->get_property = get_property;
Packit Service b23acc
	object_class->set_property = set_property;
Packit Service b23acc
	object_class->finalize     = finalize;
Packit Service b23acc
Packit Service b23acc
	setting_class->verify      = verify;
Packit Service b23acc
Packit Service b23acc
	/**
Packit Service b23acc
	 * NMSettingWifiP2P:peer:
Packit Service b23acc
	 *
Packit Service b23acc
	 * The P2P device that should be connected to. Currently this is the only
Packit Service b23acc
	 * way to create or join a group.
Packit Service b23acc
	 *
Packit Service b23acc
	 * Since: 1.16
Packit Service b23acc
	 */
Packit Service b23acc
	/* ---keyfile---
Packit Service b23acc
	 * property: peer
Packit Service b23acc
	 * format: usual hex-digits-and-colons notation
Packit Service b23acc
	 * description: MAC address in traditional hex-digits-and-colons notation
Packit Service b23acc
	 *   (e.g. 00:22:68:12:79:A2), or semicolon separated list of 6 bytes (obsolete)
Packit Service b23acc
	 *   (e.g. 0;34;104;18;121;162).
Packit Service b23acc
	 * ---end---
Packit Service b23acc
	 */
Packit Service b23acc
	obj_properties[PROP_PEER] =
Packit Service b23acc
	    g_param_spec_string (NM_SETTING_WIFI_P2P_PEER, "", "",
Packit Service b23acc
	                         NULL,
Packit Service b23acc
	                         G_PARAM_READWRITE |
Packit Service b23acc
	                         G_PARAM_STATIC_STRINGS);
Packit Service b23acc
Packit Service b23acc
	/**
Packit Service b23acc
	 * NMSettingWifiP2P:wps-method:
Packit Service b23acc
	 *
Packit Service b23acc
	 * Flags indicating which mode of WPS is to be used.
Packit Service b23acc
	 *
Packit Service b23acc
	 * There's little point in changing the default setting as NetworkManager will
Packit Service b23acc
	 * automatically determine the best method to use.
Packit Service b23acc
	 *
Packit Service b23acc
	 * Since: 1.16
Packit Service b23acc
	 */
Packit Service b23acc
	obj_properties[PROP_WPS_METHOD] =
Packit Service b23acc
	    g_param_spec_uint (NM_SETTING_WIFI_P2P_WPS_METHOD, "", "",
Packit Service b23acc
	                       0,
Packit Service b23acc
	                       G_MAXUINT32,
Packit Service b23acc
	                       NM_SETTING_WIRELESS_SECURITY_WPS_METHOD_DEFAULT,
Packit Service b23acc
	                       G_PARAM_READWRITE |
Packit Service b23acc
	                       NM_SETTING_PARAM_FUZZY_IGNORE |
Packit Service b23acc
	                       G_PARAM_STATIC_STRINGS);
Packit Service b23acc
Packit Service b23acc
	/**
Packit Service b23acc
	 * NMSettingWifiP2P:wfd-ies:
Packit Service b23acc
	 *
Packit Service b23acc
	 * The Wi-Fi Display (WFD) Information Elements (IEs) to set.
Packit Service b23acc
	 *
Packit Service b23acc
	 * Wi-Fi Display requires a protocol specific information element to be
Packit Service b23acc
	 * set in certain Wi-Fi frames. These can be specified here for the
Packit Service b23acc
	 * purpose of establishing a connection.
Packit Service b23acc
	 * This setting is only useful when implementing a Wi-Fi Display client.
Packit Service b23acc
	 *
Packit Service b23acc
	 * Since: 1.16
Packit Service b23acc
	 */
Packit Service b23acc
	obj_properties[PROP_WFD_IES] =
Packit Service b23acc
	    g_param_spec_boxed (NM_SETTING_WIFI_P2P_WFD_IES, "", "",
Packit Service b23acc
	                        G_TYPE_BYTES,
Packit Service b23acc
	                        G_PARAM_READWRITE |
Packit Service b23acc
	                        NM_SETTING_PARAM_FUZZY_IGNORE |
Packit Service b23acc
	                        G_PARAM_STATIC_STRINGS);
Packit Service b23acc
Packit Service b23acc
	g_object_class_install_properties (object_class, _PROPERTY_ENUMS_LAST, obj_properties);
Packit Service b23acc
Packit Service b23acc
	_nm_setting_class_commit (setting_class, NM_META_SETTING_TYPE_WIFI_P2P);
Packit Service b23acc
}