Blame shared/nm-meta-setting.h

Packit Service 87a54e
/* SPDX-License-Identifier: LGPL-2.1-or-later */
Packit 5756e2
/*
Packit 5756e2
 * Copyright (C) 2017 - 2018 Red Hat, Inc.
Packit 5756e2
 */
Packit 5756e2
Packit 5756e2
#ifndef __NM_META_SETTING_H__
Packit 5756e2
#define __NM_META_SETTING_H__
Packit 5756e2
Packit 5756e2
#include "nm-setting-8021x.h"
Packit 5756e2
Packit 5756e2
/*****************************************************************************/
Packit 5756e2
Packit 5756e2
/*
Packit 5756e2
 * A setting's priority should roughly follow the OSI layer model, but it also
Packit 5756e2
 * controls which settings get asked for secrets first.  Thus settings which
Packit 5756e2
 * relate to things that must be working first, like hardware, should get a
Packit 5756e2
 * higher priority than things which layer on top of the hardware.  For example,
Packit 5756e2
 * the GSM/CDMA settings should provide secrets before the PPP setting does,
Packit 5756e2
 * because a PIN is required to unlock the device before PPP can even start.
Packit 5756e2
 * Even settings without secrets should be assigned the right priority.
Packit 5756e2
 *
Packit 5756e2
 * 0: reserved for invalid
Packit 5756e2
 *
Packit 5756e2
 * 1: reserved for the Connection setting
Packit 5756e2
 *
Packit 5756e2
 * 2,3: hardware-related settings like Ethernet, Wi-Fi, InfiniBand, Bridge, etc.
Packit 5756e2
 * These priority 1 settings are also "base types", which means that at least
Packit 5756e2
 * one of them is required for the connection to be valid, and their name is
Packit 5756e2
 * valid in the 'type' property of the Connection setting.
Packit 5756e2
 *
Packit 5756e2
 * 4: hardware-related auxiliary settings that require a base setting to be
Packit 5756e2
 * successful first, like Wi-Fi security, 802.1x, etc.
Packit 5756e2
 *
Packit 5756e2
 * 5: hardware-independent settings that are required before IP connectivity
Packit 5756e2
 * can be established, like PPP, PPPoE, etc.
Packit 5756e2
 *
Packit 5756e2
 * 6: IP-level stuff
Packit 5756e2
 *
Packit 5756e2
 * 10: NMSettingUser
Packit 5756e2
 */
Packit 5756e2
typedef enum { /*< skip >*/
Packit Service a1bd4f
               NM_SETTING_PRIORITY_INVALID     = 0,
Packit Service a1bd4f
               NM_SETTING_PRIORITY_CONNECTION  = 1,
Packit Service a1bd4f
               NM_SETTING_PRIORITY_HW_BASE     = 2,
Packit Service a1bd4f
               NM_SETTING_PRIORITY_HW_NON_BASE = 3,
Packit Service a1bd4f
               NM_SETTING_PRIORITY_HW_AUX      = 4,
Packit Service a1bd4f
               NM_SETTING_PRIORITY_AUX         = 5,
Packit Service a1bd4f
               NM_SETTING_PRIORITY_IP          = 6,
Packit Service a1bd4f
               NM_SETTING_PRIORITY_USER        = 10,
Packit 5756e2
} NMSettingPriority;
Packit 5756e2
Packit 5756e2
/*****************************************************************************/
Packit 5756e2
Packit 5756e2
typedef enum {
Packit Service a1bd4f
    NM_SETTING_802_1X_SCHEME_TYPE_CA_CERT,
Packit Service a1bd4f
    NM_SETTING_802_1X_SCHEME_TYPE_PHASE2_CA_CERT,
Packit Service a1bd4f
    NM_SETTING_802_1X_SCHEME_TYPE_CLIENT_CERT,
Packit Service a1bd4f
    NM_SETTING_802_1X_SCHEME_TYPE_PHASE2_CLIENT_CERT,
Packit Service a1bd4f
    NM_SETTING_802_1X_SCHEME_TYPE_PRIVATE_KEY,
Packit Service a1bd4f
    NM_SETTING_802_1X_SCHEME_TYPE_PHASE2_PRIVATE_KEY,
Packit 5756e2
Packit Service a1bd4f
    NM_SETTING_802_1X_SCHEME_TYPE_UNKNOWN,
Packit 5756e2
Packit Service a1bd4f
    _NM_SETTING_802_1X_SCHEME_TYPE_NUM = NM_SETTING_802_1X_SCHEME_TYPE_UNKNOWN,
Packit 5756e2
} NMSetting8021xSchemeType;
Packit 5756e2
Packit 5756e2
typedef struct {
Packit Service a1bd4f
    const char *setting_key;
Packit Service a1bd4f
    NMSetting8021xCKScheme (*scheme_func)(NMSetting8021x *setting);
Packit Service a1bd4f
    NMSetting8021xCKFormat (*format_func)(NMSetting8021x *setting);
Packit Service a1bd4f
    const char *(*path_func)(NMSetting8021x *setting);
Packit Service a1bd4f
    GBytes *(*blob_func)(NMSetting8021x *setting);
Packit Service a1bd4f
    const char *(*uri_func)(NMSetting8021x *setting);
Packit Service a1bd4f
    const char *(*passwd_func)(NMSetting8021x *setting);
Packit Service a1bd4f
    NMSettingSecretFlags (*pwflag_func)(NMSetting8021x *setting);
Packit Service a1bd4f
    gboolean (*set_cert_func)(NMSetting8021x *        setting,
Packit Service a1bd4f
                              const char *            value,
Packit Service a1bd4f
                              NMSetting8021xCKScheme  scheme,
Packit Service a1bd4f
                              NMSetting8021xCKFormat *out_format,
Packit Service a1bd4f
                              GError **               error);
Packit Service a1bd4f
    gboolean (*set_private_key_func)(NMSetting8021x *        setting,
Packit Service a1bd4f
                                     const char *            value,
Packit Service a1bd4f
                                     const char *            password,
Packit Service a1bd4f
                                     NMSetting8021xCKScheme  scheme,
Packit Service a1bd4f
                                     NMSetting8021xCKFormat *out_format,
Packit Service a1bd4f
                                     GError **               error);
Packit Service a1bd4f
    const char *             file_suffix;
Packit Service a1bd4f
    NMSetting8021xSchemeType scheme_type;
Packit Service a1bd4f
    bool                     is_secret : 1;
Packit 5756e2
} NMSetting8021xSchemeVtable;
Packit 5756e2
Packit Service a1bd4f
extern const NMSetting8021xSchemeVtable
Packit Service a1bd4f
    nm_setting_8021x_scheme_vtable[_NM_SETTING_802_1X_SCHEME_TYPE_NUM + 1];
Packit 5756e2
Packit 5756e2
/*****************************************************************************/
Packit 5756e2
Packit 5756e2
typedef enum {
Packit Service a1bd4f
    /* the enum (and their numeric values) are internal API. Do not assign
Packit Service a1bd4f
     * any meaning the numeric values, because they already have one:
Packit Service a1bd4f
     *
Packit Service a1bd4f
     * they are sorted in a way, that corresponds to the asciibetical sort
Packit Service a1bd4f
     * order of the corresponding setting-name. */
Packit Service a1bd4f
Packit Service a1bd4f
    NM_META_SETTING_TYPE_6LOWPAN,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_OLPC_MESH,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_WIRELESS,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_WIRELESS_SECURITY,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_802_1X,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_WIRED,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_ADSL,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_BLUETOOTH,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_BOND,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_BRIDGE,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_BRIDGE_PORT,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_CDMA,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_CONNECTION,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_DCB,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_DUMMY,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_ETHTOOL,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_GENERIC,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_GSM,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_HOSTNAME,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_INFINIBAND,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_IP_TUNNEL,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_IP4_CONFIG,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_IP6_CONFIG,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_MACSEC,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_MACVLAN,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_MATCH,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_OVS_BRIDGE,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_OVS_DPDK,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_OVS_EXTERNAL_IDS,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_OVS_INTERFACE,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_OVS_PATCH,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_OVS_PORT,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_PPP,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_PPPOE,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_PROXY,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_SERIAL,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_SRIOV,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_TC_CONFIG,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_TEAM,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_TEAM_PORT,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_TUN,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_USER,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_VETH,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_VLAN,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_VPN,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_VRF,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_VXLAN,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_WIFI_P2P,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_WIMAX,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_WIREGUARD,
Packit Service a1bd4f
    NM_META_SETTING_TYPE_WPAN,
Packit Service a1bd4f
Packit Service a1bd4f
    NM_META_SETTING_TYPE_UNKNOWN,
Packit Service a1bd4f
Packit Service a1bd4f
    _NM_META_SETTING_TYPE_NUM = NM_META_SETTING_TYPE_UNKNOWN,
Packit 5756e2
} NMMetaSettingType;
Packit 5756e2
Packit 5756e2
/* this header is statically linked with both libnm-core.la and libnmc.la.
Packit 5756e2
 * Though, there is no stable API/ABI, so whenever on of these components
Packit 5756e2
 * accesses NMMetaSettingInfo or NMMetaSettingType, it only has meaning
Packit 5756e2
 * inside the same component.
Packit 5756e2
 *
Packit 5756e2
 * Note how NMSettingClass has field of type "struct _NMMetaSettingInfo".
Packit 5756e2
 * It would be a serious bug, if libnmc tries to interpret this pointer
Packit 5756e2
 * with the meaning of NMMetaSettingInfo. They might be different, because
Packit 5756e2
 * libnm.so (libnm-core.la) might be a newer version than nmcli (libnmc.la).
Packit 5756e2
 *
Packit 5756e2
 * This define helps to ensure that we don't accidentally use the pointer
Packit 5756e2
 * in different contexts. */
Packit Service a1bd4f
#if ((NETWORKMANAGER_COMPILATION) &NM_NETWORKMANAGER_COMPILATION_WITH_LIBNM_CORE_INTERNAL)
Packit Service a1bd4f
    #define _NMMetaSettingInfoXX _NMMetaSettingInfo
Packit 5756e2
#else
Packit Service a1bd4f
    #define _NMMetaSettingInfoXX _NMMetaSettingInfoCli
Packit 5756e2
#endif
Packit 5756e2
struct _NMMetaSettingInfoXX {
Packit Service a1bd4f
    const char *setting_name;
Packit Service a1bd4f
    GType (*get_setting_gtype)(void);
Packit Service a1bd4f
    NMMetaSettingType meta_type;
Packit Service a1bd4f
    NMSettingPriority setting_priority;
Packit 5756e2
};
Packit 5756e2
Packit 5756e2
typedef struct _NMMetaSettingInfoXX NMMetaSettingInfo;
Packit 5756e2
Packit 5756e2
/* note that we statically link nm-meta-setting.h both to libnm-core.la and
Packit 5756e2
 * libnmc.la. That means, there are two versions of nm_meta_setting_infos
Packit 5756e2
 * in nmcli. That is not easily avoidable, because at this point, we don't
Packit 5756e2
 * want yet to making it public API.
Packit 5756e2
 *
Packit 5756e2
 * Eventually, this should become public API of libnm, and nmcli/libnmc.la
Packit 5756e2
 * should use that version.
Packit 5756e2
 *
Packit 5756e2
 * Downsides of the current solution:
Packit 5756e2
 *
Packit 5756e2
 * - duplication of the array in nmcli.
Packit 5756e2
 *
Packit 5756e2
 * - there is no stable API/ABI. That means, when you have a NMMetaSettingInfo
Packit 5756e2
 *   pointer, or a NMMetaSettingType value, the value can only be used within
Packit 5756e2
 *   the current context (libnm-core.la or libnmc.la). In other words, libnmc.la
Packit 5756e2
 *   (and nmcli) must never access a NMMetaSettingInfo/NMMetaSettingType value,
Packit 5756e2
 *   that comes from libnm-core.la.
Packit 5756e2
 */
Packit 5756e2
extern const NMMetaSettingInfo nm_meta_setting_infos[_NM_META_SETTING_TYPE_NUM + 1];
Packit 5756e2
Packit Service a1bd4f
const NMMetaSettingInfo *nm_meta_setting_infos_by_name(const char *name);
Packit Service a1bd4f
const NMMetaSettingInfo *nm_meta_setting_infos_by_gtype(GType gtype);
Packit 5756e2
Packit 5756e2
/*****************************************************************************/
Packit 5756e2
Packit Service a1bd4f
NMSettingPriority nm_meta_setting_info_get_base_type_priority(const NMMetaSettingInfo *setting_info,
Packit Service a1bd4f
                                                              GType                    gtype);
Packit Service a1bd4f
NMSettingPriority _nm_setting_type_get_base_type_priority(GType type);
Packit Service a1bd4f
Packit 5756e2
#endif /* __NM_META_SETTING_H__ */