Blame libnm-core/nm-setting-tun.c

Packit Service b23acc
// SPDX-License-Identifier: LGPL-2.1+
Packit Service b23acc
/*
Packit Service b23acc
 * Copyright (C) 2015 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-tun.h"
Packit Service b23acc
Packit Service b23acc
#include <stdlib.h>
Packit Service b23acc
Packit Service b23acc
#include "nm-utils.h"
Packit Service b23acc
#include "nm-setting-connection.h"
Packit Service b23acc
#include "nm-setting-private.h"
Packit Service b23acc
#include "nm-connection-private.h"
Packit Service b23acc
Packit Service b23acc
/**
Packit Service b23acc
 * SECTION:nm-setting-tun
Packit Service b23acc
 * @short_description: Describes connection properties for TUN/TAP interfaces
Packit Service b23acc
 *
Packit Service b23acc
 * The #NMSettingTun object is a #NMSetting subclass that describes properties
Packit Service b23acc
 * necessary for connection to TUN/TAP interfaces.
Packit Service b23acc
 **/
Packit Service b23acc
Packit Service b23acc
/*****************************************************************************/
Packit Service b23acc
Packit Service b23acc
NM_GOBJECT_PROPERTIES_DEFINE_BASE (
Packit Service b23acc
	PROP_MODE,
Packit Service b23acc
	PROP_OWNER,
Packit Service b23acc
	PROP_GROUP,
Packit Service b23acc
	PROP_PI,
Packit Service b23acc
	PROP_VNET_HDR,
Packit Service b23acc
	PROP_MULTI_QUEUE,
Packit Service b23acc
);
Packit Service b23acc
Packit Service b23acc
typedef struct {
Packit Service b23acc
	char *owner;
Packit Service b23acc
	char *group;
Packit Service b23acc
	NMSettingTunMode mode;
Packit Service b23acc
	bool pi:1;
Packit Service b23acc
	bool vnet_hdr:1;
Packit Service b23acc
	bool multi_queue:1;
Packit Service b23acc
} NMSettingTunPrivate;
Packit Service b23acc
Packit Service b23acc
G_DEFINE_TYPE (NMSettingTun, nm_setting_tun, NM_TYPE_SETTING)
Packit Service b23acc
Packit Service b23acc
#define NM_SETTING_TUN_GET_PRIVATE(o) (G_TYPE_INSTANCE_GET_PRIVATE ((o), NM_TYPE_SETTING_TUN, NMSettingTunPrivate))
Packit Service b23acc
Packit Service b23acc
/*****************************************************************************/
Packit Service b23acc
Packit Service b23acc
/**
Packit Service b23acc
 * nm_setting_tun_get_mode:
Packit Service b23acc
 * @setting: the #NMSettingTun
Packit Service b23acc
 *
Packit Service b23acc
 * Returns: the #NMSettingTun:mode property of the setting
Packit Service b23acc
 *
Packit Service b23acc
 * Since: 1.2
Packit Service b23acc
 **/
Packit Service b23acc
NMSettingTunMode
Packit Service b23acc
nm_setting_tun_get_mode (NMSettingTun *setting)
Packit Service b23acc
{
Packit Service b23acc
	g_return_val_if_fail (NM_IS_SETTING_TUN (setting), NM_SETTING_TUN_MODE_TUN);
Packit Service b23acc
	return NM_SETTING_TUN_GET_PRIVATE (setting)->mode;
Packit Service b23acc
}
Packit Service b23acc
Packit Service b23acc
/**
Packit Service b23acc
 * nm_setting_tun_get_owner:
Packit Service b23acc
 * @setting: the #NMSettingTun
Packit Service b23acc
 *
Packit Service b23acc
 * Returns: the #NMSettingTun:owner property of the setting
Packit Service b23acc
 *
Packit Service b23acc
 * Since: 1.2
Packit Service b23acc
 **/
Packit Service b23acc
const char *
Packit Service b23acc
nm_setting_tun_get_owner (NMSettingTun *setting)
Packit Service b23acc
{
Packit Service b23acc
	g_return_val_if_fail (NM_IS_SETTING_TUN (setting), NULL);
Packit Service b23acc
	return NM_SETTING_TUN_GET_PRIVATE (setting)->owner;
Packit Service b23acc
}
Packit Service b23acc
Packit Service b23acc
/**
Packit Service b23acc
 * nm_setting_tun_get_group:
Packit Service b23acc
 * @setting: the #NMSettingTun
Packit Service b23acc
 *
Packit Service b23acc
 * Returns: the #NMSettingTun:group property of the setting
Packit Service b23acc
 *
Packit Service b23acc
 * Since: 1.2
Packit Service b23acc
 **/
Packit Service b23acc
const char *
Packit Service b23acc
nm_setting_tun_get_group (NMSettingTun *setting)
Packit Service b23acc
{
Packit Service b23acc
	g_return_val_if_fail (NM_IS_SETTING_TUN (setting), NULL);
Packit Service b23acc
	return NM_SETTING_TUN_GET_PRIVATE (setting)->group;
Packit Service b23acc
}
Packit Service b23acc
Packit Service b23acc
/**
Packit Service b23acc
 * nm_setting_tun_get_pi:
Packit Service b23acc
 * @setting: the #NMSettingTun
Packit Service b23acc
 *
Packit Service b23acc
 * Returns: the #NMSettingTun:pi property of the setting
Packit Service b23acc
 *
Packit Service b23acc
 * Since: 1.2
Packit Service b23acc
 **/
Packit Service b23acc
gboolean
Packit Service b23acc
nm_setting_tun_get_pi (NMSettingTun *setting)
Packit Service b23acc
{
Packit Service b23acc
	g_return_val_if_fail (NM_IS_SETTING_TUN (setting), FALSE);
Packit Service b23acc
	return NM_SETTING_TUN_GET_PRIVATE (setting)->pi;
Packit Service b23acc
}
Packit Service b23acc
Packit Service b23acc
/**
Packit Service b23acc
 * nm_setting_tun_get_vnet_hdr:
Packit Service b23acc
 * @setting: the #NMSettingTun
Packit Service b23acc
 *
Packit Service b23acc
 * Returns: the #NMSettingTun:vnet_hdr property of the setting
Packit Service b23acc
 *
Packit Service b23acc
 * Since: 1.2
Packit Service b23acc
 **/
Packit Service b23acc
gboolean
Packit Service b23acc
nm_setting_tun_get_vnet_hdr (NMSettingTun *setting)
Packit Service b23acc
{
Packit Service b23acc
	g_return_val_if_fail (NM_IS_SETTING_TUN (setting), FALSE);
Packit Service b23acc
	return NM_SETTING_TUN_GET_PRIVATE (setting)->vnet_hdr;
Packit Service b23acc
}
Packit Service b23acc
Packit Service b23acc
/**
Packit Service b23acc
 * nm_setting_tun_get_multi_queue:
Packit Service b23acc
 * @setting: the #NMSettingTun
Packit Service b23acc
 *
Packit Service b23acc
 * Returns: the #NMSettingTun:multi-queue property of the setting
Packit Service b23acc
 *
Packit Service b23acc
 * Since: 1.2
Packit Service b23acc
 **/
Packit Service b23acc
gboolean
Packit Service b23acc
nm_setting_tun_get_multi_queue (NMSettingTun *setting)
Packit Service b23acc
{
Packit Service b23acc
	g_return_val_if_fail (NM_IS_SETTING_TUN (setting), FALSE);
Packit Service b23acc
	return NM_SETTING_TUN_GET_PRIVATE (setting)->multi_queue;
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
	NMSettingTunPrivate *priv = NM_SETTING_TUN_GET_PRIVATE (setting);
Packit Service b23acc
Packit Service b23acc
	if (!NM_IN_SET (priv->mode, NM_SETTING_TUN_MODE_TUN,
Packit Service b23acc
	                            NM_SETTING_TUN_MODE_TAP)) {
Packit Service b23acc
		g_set_error (error,
Packit Service b23acc
		             NM_CONNECTION_ERROR,
Packit Service b23acc
		             NM_CONNECTION_ERROR_INVALID_PROPERTY,
Packit Service b23acc
		             _("'%u': invalid mode"), (unsigned) priv->mode);
Packit Service b23acc
		g_prefix_error (error, "%s.%s: ", NM_SETTING_TUN_SETTING_NAME, NM_SETTING_TUN_MODE);
Packit Service b23acc
		return FALSE;
Packit Service b23acc
	}
Packit Service b23acc
Packit Service b23acc
	if (priv->owner) {
Packit Service b23acc
		if (_nm_utils_ascii_str_to_int64 (priv->owner, 10, 0, G_MAXINT32, -1) == -1) {
Packit Service b23acc
			g_set_error (error,
Packit Service b23acc
			             NM_CONNECTION_ERROR,
Packit Service b23acc
			             NM_CONNECTION_ERROR_INVALID_PROPERTY,
Packit Service b23acc
			             _("'%s': invalid user ID"), priv->owner);
Packit Service b23acc
			g_prefix_error (error, "%s.%s: ", NM_SETTING_TUN_SETTING_NAME, NM_SETTING_TUN_OWNER);
Packit Service b23acc
			return FALSE;
Packit Service b23acc
		}
Packit Service b23acc
	}
Packit Service b23acc
Packit Service b23acc
	if (priv->group) {
Packit Service b23acc
		if (_nm_utils_ascii_str_to_int64 (priv->group, 10, 0, G_MAXINT32, -1) == -1) {
Packit Service b23acc
			g_set_error (error,
Packit Service b23acc
			             NM_CONNECTION_ERROR,
Packit Service b23acc
			             NM_CONNECTION_ERROR_INVALID_PROPERTY,
Packit Service b23acc
			             _("'%s': invalid group ID"), priv->group);
Packit Service b23acc
			g_prefix_error (error, "%s.%s: ", NM_SETTING_TUN_SETTING_NAME, NM_SETTING_TUN_GROUP);
Packit Service b23acc
			return FALSE;
Packit Service b23acc
		}
Packit Service b23acc
	}
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
	NMSettingTun *setting = NM_SETTING_TUN (object);
Packit Service b23acc
	NMSettingTunPrivate *priv = NM_SETTING_TUN_GET_PRIVATE (setting);
Packit Service b23acc
Packit Service b23acc
	switch (prop_id) {
Packit Service b23acc
	case PROP_MODE:
Packit Service b23acc
		g_value_set_uint (value, priv->mode);
Packit Service b23acc
		break;
Packit Service b23acc
	case PROP_OWNER:
Packit Service b23acc
		g_value_set_string (value, priv->owner);
Packit Service b23acc
		break;
Packit Service b23acc
	case PROP_GROUP:
Packit Service b23acc
		g_value_set_string (value, priv->group);
Packit Service b23acc
		break;
Packit Service b23acc
	case PROP_PI:
Packit Service b23acc
		g_value_set_boolean (value, priv->pi);
Packit Service b23acc
		break;
Packit Service b23acc
	case PROP_VNET_HDR:
Packit Service b23acc
		g_value_set_boolean (value, priv->vnet_hdr);
Packit Service b23acc
		break;
Packit Service b23acc
	case PROP_MULTI_QUEUE:
Packit Service b23acc
		g_value_set_boolean (value, priv->multi_queue);
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
	NMSettingTun *setting = NM_SETTING_TUN (object);
Packit Service b23acc
	NMSettingTunPrivate *priv = NM_SETTING_TUN_GET_PRIVATE (setting);
Packit Service b23acc
Packit Service b23acc
	switch (prop_id) {
Packit Service b23acc
	case PROP_MODE:
Packit Service b23acc
		priv->mode = g_value_get_uint (value);
Packit Service b23acc
		break;
Packit Service b23acc
	case PROP_OWNER:
Packit Service b23acc
		g_free (priv->owner);
Packit Service b23acc
		priv->owner = g_value_dup_string (value);
Packit Service b23acc
		break;
Packit Service b23acc
	case PROP_GROUP:
Packit Service b23acc
		g_free (priv->group);
Packit Service b23acc
		priv->group = g_value_dup_string (value);
Packit Service b23acc
		break;
Packit Service b23acc
	case PROP_PI:
Packit Service b23acc
		priv->pi = g_value_get_boolean (value);
Packit Service b23acc
		break;
Packit Service b23acc
	case PROP_VNET_HDR:
Packit Service b23acc
		priv->vnet_hdr = g_value_get_boolean (value);
Packit Service b23acc
		break;
Packit Service b23acc
	case PROP_MULTI_QUEUE:
Packit Service b23acc
		priv->multi_queue = g_value_get_boolean (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
static void
Packit Service b23acc
nm_setting_tun_init (NMSettingTun *self)
Packit Service b23acc
{
Packit Service b23acc
	NMSettingTunPrivate *priv = NM_SETTING_TUN_GET_PRIVATE (self);
Packit Service b23acc
Packit Service b23acc
	priv->mode = NM_SETTING_TUN_MODE_TUN;
Packit Service b23acc
}
Packit Service b23acc
Packit Service b23acc
/**
Packit Service b23acc
 * nm_setting_tun_new:
Packit Service b23acc
 *
Packit Service b23acc
 * Creates a new #NMSettingTun object with default values.
Packit Service b23acc
 *
Packit Service b23acc
 * Returns: (transfer full): the new empty #NMSettingTun object
Packit Service b23acc
 *
Packit Service b23acc
 * Since: 1.2
Packit Service b23acc
 **/
Packit Service b23acc
NMSetting *
Packit Service b23acc
nm_setting_tun_new (void)
Packit Service b23acc
{
Packit Service b23acc
	return (NMSetting *) g_object_new (NM_TYPE_SETTING_TUN, NULL);
Packit Service b23acc
}
Packit Service b23acc
Packit Service b23acc
static void
Packit Service b23acc
finalize (GObject *object)
Packit Service b23acc
{
Packit Service b23acc
	NMSettingTun *setting = NM_SETTING_TUN (object);
Packit Service b23acc
	NMSettingTunPrivate *priv = NM_SETTING_TUN_GET_PRIVATE (setting);
Packit Service b23acc
Packit Service b23acc
	g_free (priv->owner);
Packit Service b23acc
	g_free (priv->group);
Packit Service b23acc
Packit Service b23acc
	G_OBJECT_CLASS (nm_setting_tun_parent_class)->finalize (object);
Packit Service b23acc
}
Packit Service b23acc
Packit Service b23acc
static void
Packit Service b23acc
nm_setting_tun_class_init (NMSettingTunClass *klass)
Packit Service b23acc
{
Packit Service b23acc
	GObjectClass *object_class = G_OBJECT_CLASS (klass);
Packit Service b23acc
	NMSettingClass *setting_class = NM_SETTING_CLASS (klass);
Packit Service b23acc
Packit Service b23acc
	g_type_class_add_private (klass, sizeof (NMSettingTunPrivate));
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
	 * NMSettingTun:mode:
Packit Service b23acc
	 *
Packit Service b23acc
	 * The operating mode of the virtual device. Allowed values are
Packit Service b23acc
	 * %NM_SETTING_TUN_MODE_TUN to create a layer 3 device and
Packit Service b23acc
	 * %NM_SETTING_TUN_MODE_TAP to create an Ethernet-like layer 2
Packit Service b23acc
	 * one.
Packit Service b23acc
	 *
Packit Service b23acc
	 * Since: 1.2
Packit Service b23acc
	 */
Packit Service b23acc
	obj_properties[PROP_MODE] =
Packit Service b23acc
	    g_param_spec_uint (NM_SETTING_TUN_MODE, "", "",
Packit Service b23acc
	                       0, G_MAXUINT, NM_SETTING_TUN_MODE_TUN,
Packit Service b23acc
	                       G_PARAM_READWRITE |
Packit Service b23acc
	                       NM_SETTING_PARAM_INFERRABLE |
Packit Service b23acc
	                       G_PARAM_STATIC_STRINGS);
Packit Service b23acc
Packit Service b23acc
	/**
Packit Service b23acc
	 * NMSettingTun:owner:
Packit Service b23acc
	 *
Packit Service b23acc
	 * The user ID which will own the device. If set to %NULL everyone
Packit Service b23acc
	 * will be able to use the device.
Packit Service b23acc
	 *
Packit Service b23acc
	 * Since: 1.2
Packit Service b23acc
	 */
Packit Service b23acc
	obj_properties[PROP_OWNER] =
Packit Service b23acc
	    g_param_spec_string (NM_SETTING_TUN_OWNER, "", "",
Packit Service b23acc
	                         NULL,
Packit Service b23acc
	                         G_PARAM_READWRITE |
Packit Service b23acc
	                         NM_SETTING_PARAM_INFERRABLE |
Packit Service b23acc
	                         G_PARAM_STATIC_STRINGS);
Packit Service b23acc
Packit Service b23acc
	/**
Packit Service b23acc
	 * NMSettingTun:group:
Packit Service b23acc
	 *
Packit Service b23acc
	 * The group ID which will own the device. If set to %NULL everyone
Packit Service b23acc
	 * will be able to use the device.
Packit Service b23acc
	 *
Packit Service b23acc
	 * Since: 1.2
Packit Service b23acc
	 */
Packit Service b23acc
	obj_properties[PROP_GROUP] =
Packit Service b23acc
	    g_param_spec_string (NM_SETTING_TUN_GROUP, "", "",
Packit Service b23acc
	                         NULL,
Packit Service b23acc
	                         G_PARAM_READWRITE |
Packit Service b23acc
	                         NM_SETTING_PARAM_INFERRABLE |
Packit Service b23acc
	                         G_PARAM_STATIC_STRINGS);
Packit Service b23acc
Packit Service b23acc
	/**
Packit Service b23acc
	 * NMSettingTun:pi:
Packit Service b23acc
	 *
Packit Service b23acc
	 * If %TRUE the interface will prepend a 4 byte header describing the
Packit Service b23acc
	 * physical interface to the packets.
Packit Service b23acc
	 *
Packit Service b23acc
	 * Since: 1.2
Packit Service b23acc
	 */
Packit Service b23acc
	obj_properties[PROP_PI] =
Packit Service b23acc
	    g_param_spec_boolean (NM_SETTING_TUN_PI, "", "",
Packit Service b23acc
	                          FALSE,
Packit Service b23acc
	                          G_PARAM_READWRITE |
Packit Service b23acc
	                          NM_SETTING_PARAM_INFERRABLE |
Packit Service b23acc
	                          G_PARAM_STATIC_STRINGS);
Packit Service b23acc
Packit Service b23acc
	/**
Packit Service b23acc
	 * NMSettingTun:vnet-hdr:
Packit Service b23acc
	 *
Packit Service b23acc
	 * If %TRUE the IFF_VNET_HDR the tunnel packets will include a virtio
Packit Service b23acc
	 * network header.
Packit Service b23acc
	 *
Packit Service b23acc
	 * Since: 1.2
Packit Service b23acc
	 */
Packit Service b23acc
	obj_properties[PROP_VNET_HDR] =
Packit Service b23acc
	    g_param_spec_boolean (NM_SETTING_TUN_VNET_HDR, "", "",
Packit Service b23acc
	                          FALSE,
Packit Service b23acc
	                          G_PARAM_READWRITE |
Packit Service b23acc
	                          NM_SETTING_PARAM_INFERRABLE |
Packit Service b23acc
	                          G_PARAM_STATIC_STRINGS);
Packit Service b23acc
Packit Service b23acc
	/**
Packit Service b23acc
	 * NMSettingTun:multi-queue:
Packit Service b23acc
	 *
Packit Service b23acc
	 * If the property is set to %TRUE, the interface will support
Packit Service b23acc
	 * multiple file descriptors (queues) to parallelize packet
Packit Service b23acc
	 * sending or receiving. Otherwise, the interface will only
Packit Service b23acc
	 * support a single queue.
Packit Service b23acc
	 *
Packit Service b23acc
	 * Since: 1.2
Packit Service b23acc
	 */
Packit Service b23acc
	obj_properties[PROP_MULTI_QUEUE] =
Packit Service b23acc
	    g_param_spec_boolean (NM_SETTING_TUN_MULTI_QUEUE, "", "",
Packit Service b23acc
	                          FALSE,
Packit Service b23acc
	                          G_PARAM_READWRITE |
Packit Service b23acc
	                          NM_SETTING_PARAM_INFERRABLE |
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_TUN);
Packit Service b23acc
}