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

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