Blame libnm-core/nm-setting-wireless-security.h

Packit Service b23acc
// SPDX-License-Identifier: LGPL-2.1+
Packit Service b23acc
/*
Packit Service b23acc
 * Copyright (C) 2007 - 2017 Red Hat, Inc.
Packit Service b23acc
 * Copyright (C) 2007 - 2008 Novell, Inc.
Packit Service b23acc
 */
Packit Service b23acc
Packit Service b23acc
#ifndef __NM_SETTING_WIRELESS_SECURITY_H__
Packit Service b23acc
#define __NM_SETTING_WIRELESS_SECURITY_H__
Packit Service b23acc
Packit Service b23acc
#if !defined (__NETWORKMANAGER_H_INSIDE__) && !defined (NETWORKMANAGER_COMPILATION)
Packit Service b23acc
#error "Only <NetworkManager.h> can be included directly."
Packit Service b23acc
#endif
Packit Service b23acc
Packit Service b23acc
#include "nm-setting.h"
Packit Service b23acc
Packit Service b23acc
G_BEGIN_DECLS
Packit Service b23acc
Packit Service b23acc
#define NM_TYPE_SETTING_WIRELESS_SECURITY            (nm_setting_wireless_security_get_type ())
Packit Service b23acc
#define NM_SETTING_WIRELESS_SECURITY(obj)            (G_TYPE_CHECK_INSTANCE_CAST ((obj), NM_TYPE_SETTING_WIRELESS_SECURITY, NMSettingWirelessSecurity))
Packit Service b23acc
#define NM_SETTING_WIRELESS_SECURITY_CLASS(klass)    (G_TYPE_CHECK_CLASS_CAST ((klass), NM_TYPE_SETTING_WIRELESS_SECURITY, NMSettingWirelessSecurityClass))
Packit Service b23acc
#define NM_IS_SETTING_WIRELESS_SECURITY(obj)         (G_TYPE_CHECK_INSTANCE_TYPE ((obj), NM_TYPE_SETTING_WIRELESS_SECURITY))
Packit Service b23acc
#define NM_IS_SETTING_WIRELESS_SECURITY_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), NM_TYPE_SETTING_WIRELESS_SECURITY))
Packit Service b23acc
#define NM_SETTING_WIRELESS_SECURITY_GET_CLASS(obj)  (G_TYPE_INSTANCE_GET_CLASS ((obj), NM_TYPE_SETTING_WIRELESS_SECURITY, NMSettingWirelessSecurityClass))
Packit Service b23acc
Packit Service b23acc
#define NM_SETTING_WIRELESS_SECURITY_SETTING_NAME "802-11-wireless-security"
Packit Service b23acc
Packit Service b23acc
/**
Packit Service b23acc
 * NMWepKeyType:
Packit Service b23acc
 * @NM_WEP_KEY_TYPE_UNKNOWN: unknown WEP key type
Packit Service b23acc
 * @NM_WEP_KEY_TYPE_KEY: indicates a hexadecimal or ASCII formatted WEP key.
Packit Service b23acc
 * Hex keys are either 10 or 26 hexadecimal characters (ie "5f782f2f5f" or
Packit Service b23acc
 * "732f2d712e4a394a375d366931"), while ASCII keys are either 5 or 13 ASCII
Packit Service b23acc
 * characters (ie "abcde" or "blahblah99$*1").
Packit Service b23acc
 * @NM_WEP_KEY_TYPE_PASSPHRASE: indicates a WEP passphrase (ex "I bought a duck
Packit Service b23acc
 * on my way back from the market 235Q&^%^*%") instead of a hexadecimal or ASCII
Packit Service b23acc
 * key.  Passphrases are between 8 and 64 characters inclusive and are hashed
Packit Service b23acc
 * the actual WEP key using the MD5 hash algorithm.
Packit Service b23acc
 * @NM_WEP_KEY_TYPE_LAST: placeholder value for bounds-checking
Packit Service b23acc
 *
Packit Service b23acc
 * The #NMWepKeyType values specify how any WEP keys present in the setting
Packit Service b23acc
 * are interpreted.  There are no standards governing how to hash the various WEP
Packit Service b23acc
 * key/passphrase formats into the actual WEP key.  Unfortunately some WEP keys
Packit Service b23acc
 * can be interpreted in multiple ways, requiring the setting to specify how to
Packit Service b23acc
 * interpret the any WEP keys.  For example, the key "732f2d712e4a394a375d366931"
Packit Service b23acc
 * is both a valid Hexadecimal WEP key and a WEP passphrase.  Further, many
Packit Service b23acc
 * ASCII keys are also valid WEP passphrases, but since passphrases and ASCII
Packit Service b23acc
 * keys are hashed differently to determine the actual WEP key the type must be
Packit Service b23acc
 * specified.
Packit Service b23acc
 */
Packit Service b23acc
typedef enum {
Packit Service b23acc
	NM_WEP_KEY_TYPE_UNKNOWN = 0,
Packit Service b23acc
	NM_WEP_KEY_TYPE_KEY = 1,          /* Hex or ASCII */
Packit Service b23acc
	NM_WEP_KEY_TYPE_PASSPHRASE = 2,   /* 104/128-bit Passphrase */
Packit Service b23acc
Packit Service b23acc
	NM_WEP_KEY_TYPE_LAST = NM_WEP_KEY_TYPE_PASSPHRASE, /*< skip >*/
Packit Service b23acc
} NMWepKeyType;
Packit Service b23acc
Packit Service b23acc
/**
Packit Service b23acc
 * NMSettingWirelessSecurityPmf:
Packit Service b23acc
 * @NM_SETTING_WIRELESS_SECURITY_PMF_DEFAULT: use the default value
Packit Service b23acc
 * @NM_SETTING_WIRELESS_SECURITY_PMF_DISABLE: disable PMF
Packit Service b23acc
 * @NM_SETTING_WIRELESS_SECURITY_PMF_OPTIONAL: enable PMF if the supplicant and the AP support it
Packit Service b23acc
 * @NM_SETTING_WIRELESS_SECURITY_PMF_REQUIRED: require PMF and fail if not available
Packit Service b23acc
 *
Packit Service b23acc
 * These flags indicate whether PMF must be enabled.
Packit Service b23acc
 **/
Packit Service b23acc
typedef enum {
Packit Service b23acc
	NM_SETTING_WIRELESS_SECURITY_PMF_DEFAULT       = 0,
Packit Service b23acc
	NM_SETTING_WIRELESS_SECURITY_PMF_DISABLE       = 1,
Packit Service b23acc
	NM_SETTING_WIRELESS_SECURITY_PMF_OPTIONAL      = 2,
Packit Service b23acc
	NM_SETTING_WIRELESS_SECURITY_PMF_REQUIRED      = 3,
Packit Service b23acc
	_NM_SETTING_WIRELESS_SECURITY_PMF_NUM, /*< skip >*/
Packit Service b23acc
	NM_SETTING_WIRELESS_SECURITY_PMF_LAST          =  _NM_SETTING_WIRELESS_SECURITY_PMF_NUM - 1, /*< skip >*/
Packit Service b23acc
} NMSettingWirelessSecurityPmf;
Packit Service b23acc
Packit Service b23acc
/**
Packit Service b23acc
 * NMSettingWirelessSecurityWpsMethod:
Packit Service b23acc
 * @NM_SETTING_WIRELESS_SECURITY_WPS_METHOD_DEFAULT: Attempt whichever method AP supports
Packit Service b23acc
 * @NM_SETTING_WIRELESS_SECURITY_WPS_METHOD_DISABLED: WPS can not be used.
Packit Service b23acc
 * @NM_SETTING_WIRELESS_SECURITY_WPS_METHOD_AUTO: Use WPS, any method
Packit Service b23acc
 * @NM_SETTING_WIRELESS_SECURITY_WPS_METHOD_PBC: use WPS push-buthon method
Packit Service b23acc
 * @NM_SETTING_WIRELESS_SECURITY_WPS_METHOD_PIN: use PIN method
Packit Service b23acc
 *
Packit Service b23acc
 * Configure the use of WPS by a connection while it activates.
Packit Service b23acc
 *
Packit Service b23acc
 * Note: prior to 1.16, this was a GEnum type instead of a GFlags type
Packit Service b23acc
 * although, with the same numeric values.
Packit Service b23acc
 *
Packit Service b23acc
 * Since: 1.10
Packit Service b23acc
 **/
Packit Service b23acc
typedef enum { /*< flags >*/
Packit Service b23acc
	NM_SETTING_WIRELESS_SECURITY_WPS_METHOD_DEFAULT     = 0x00000000,
Packit Service b23acc
	NM_SETTING_WIRELESS_SECURITY_WPS_METHOD_DISABLED    = 0x00000001,
Packit Service b23acc
	NM_SETTING_WIRELESS_SECURITY_WPS_METHOD_AUTO        = 0x00000002,
Packit Service b23acc
	NM_SETTING_WIRELESS_SECURITY_WPS_METHOD_PBC         = 0x00000004,
Packit Service b23acc
	NM_SETTING_WIRELESS_SECURITY_WPS_METHOD_PIN         = 0x00000008,
Packit Service b23acc
} NMSettingWirelessSecurityWpsMethod;
Packit Service b23acc
Packit Service b23acc
/**
Packit Service b23acc
 * NMSettingWirelessSecurityFils:
Packit Service b23acc
 * @NM_SETTING_WIRELESS_SECURITY_FILS_DEFAULT: use the default value
Packit Service b23acc
 * @NM_SETTING_WIRELESS_SECURITY_FILS_DISABLE: disable FILS
Packit Service b23acc
 * @NM_SETTING_WIRELESS_SECURITY_FILS_OPTIONAL: enable FILS if the supplicant and the AP support it
Packit Service b23acc
 * @NM_SETTING_WIRELESS_SECURITY_FILS_REQUIRED: require FILS and fail if not available
Packit Service b23acc
 * @_NM_SETTING_WIRELESS_SECURITY_FILS_NUM: placeholder value for bounds-checking
Packit Service b23acc
 * @NM_SETTING_WIRELESS_SECURITY_FILS_LAST: placeholder value for bounds-checking
Packit Service b23acc
 *
Packit Service b23acc
 * These flags indicate whether FILS must be enabled.
Packit Service b23acc
 *
Packit Service b23acc
 * Since: 1.12
Packit Service b23acc
 **/
Packit Service b23acc
typedef enum {
Packit Service b23acc
	NM_SETTING_WIRELESS_SECURITY_FILS_DEFAULT       = 0,
Packit Service b23acc
	NM_SETTING_WIRELESS_SECURITY_FILS_DISABLE       = 1,
Packit Service b23acc
	NM_SETTING_WIRELESS_SECURITY_FILS_OPTIONAL      = 2,
Packit Service b23acc
	NM_SETTING_WIRELESS_SECURITY_FILS_REQUIRED      = 3,
Packit Service b23acc
	_NM_SETTING_WIRELESS_SECURITY_FILS_NUM, /*< skip >*/
Packit Service b23acc
	NM_SETTING_WIRELESS_SECURITY_FILS_LAST          =  _NM_SETTING_WIRELESS_SECURITY_FILS_NUM - 1, /*< skip >*/
Packit Service b23acc
} NMSettingWirelessSecurityFils;
Packit Service b23acc
Packit Service b23acc
#define NM_SETTING_WIRELESS_SECURITY_KEY_MGMT "key-mgmt"
Packit Service b23acc
#define NM_SETTING_WIRELESS_SECURITY_WEP_TX_KEYIDX "wep-tx-keyidx"
Packit Service b23acc
#define NM_SETTING_WIRELESS_SECURITY_AUTH_ALG "auth-alg"
Packit Service b23acc
#define NM_SETTING_WIRELESS_SECURITY_PROTO "proto"
Packit Service b23acc
#define NM_SETTING_WIRELESS_SECURITY_PAIRWISE "pairwise"
Packit Service b23acc
#define NM_SETTING_WIRELESS_SECURITY_GROUP "group"
Packit Service b23acc
#define NM_SETTING_WIRELESS_SECURITY_PMF "pmf"
Packit Service b23acc
#define NM_SETTING_WIRELESS_SECURITY_LEAP_USERNAME "leap-username"
Packit Service b23acc
#define NM_SETTING_WIRELESS_SECURITY_WEP_KEY0 "wep-key0"
Packit Service b23acc
#define NM_SETTING_WIRELESS_SECURITY_WEP_KEY1 "wep-key1"
Packit Service b23acc
#define NM_SETTING_WIRELESS_SECURITY_WEP_KEY2 "wep-key2"
Packit Service b23acc
#define NM_SETTING_WIRELESS_SECURITY_WEP_KEY3 "wep-key3"
Packit Service b23acc
#define NM_SETTING_WIRELESS_SECURITY_WEP_KEY_FLAGS "wep-key-flags"
Packit Service b23acc
#define NM_SETTING_WIRELESS_SECURITY_WEP_KEY_TYPE "wep-key-type"
Packit Service b23acc
#define NM_SETTING_WIRELESS_SECURITY_PSK "psk"
Packit Service b23acc
#define NM_SETTING_WIRELESS_SECURITY_PSK_FLAGS "psk-flags"
Packit Service b23acc
#define NM_SETTING_WIRELESS_SECURITY_LEAP_PASSWORD "leap-password"
Packit Service b23acc
#define NM_SETTING_WIRELESS_SECURITY_LEAP_PASSWORD_FLAGS "leap-password-flags"
Packit Service b23acc
#define NM_SETTING_WIRELESS_SECURITY_WPS_METHOD "wps-method"
Packit Service b23acc
#define NM_SETTING_WIRELESS_SECURITY_FILS "fils"
Packit Service b23acc
Packit Service b23acc
/**
Packit Service b23acc
 * NMSettingWirelessSecurity:
Packit Service b23acc
 *
Packit Service b23acc
 * Wi-Fi Security Settings
Packit Service b23acc
 */
Packit Service b23acc
struct _NMSettingWirelessSecurity {
Packit Service b23acc
	NMSetting parent;
Packit Service b23acc
};
Packit Service b23acc
Packit Service b23acc
typedef struct {
Packit Service b23acc
	NMSettingClass parent;
Packit Service b23acc
Packit Service b23acc
	/*< private >*/
Packit Service b23acc
	gpointer padding[4];
Packit Service b23acc
} NMSettingWirelessSecurityClass;
Packit Service b23acc
Packit Service b23acc
GType nm_setting_wireless_security_get_type (void);
Packit Service b23acc
Packit Service b23acc
NMSetting * nm_setting_wireless_security_new               (void);
Packit Service b23acc
Packit Service b23acc
const char *nm_setting_wireless_security_get_key_mgmt      (NMSettingWirelessSecurity *setting);
Packit Service b23acc
Packit Service b23acc
guint32     nm_setting_wireless_security_get_num_protos        (NMSettingWirelessSecurity *setting);
Packit Service b23acc
const char *nm_setting_wireless_security_get_proto             (NMSettingWirelessSecurity *setting, guint32 i);
Packit Service b23acc
gboolean    nm_setting_wireless_security_add_proto             (NMSettingWirelessSecurity *setting, const char *proto);
Packit Service b23acc
void        nm_setting_wireless_security_remove_proto          (NMSettingWirelessSecurity *setting, guint32 i);
Packit Service b23acc
gboolean    nm_setting_wireless_security_remove_proto_by_value (NMSettingWirelessSecurity *setting, const char *proto);
Packit Service b23acc
void        nm_setting_wireless_security_clear_protos          (NMSettingWirelessSecurity *setting);
Packit Service b23acc
Packit Service b23acc
guint32     nm_setting_wireless_security_get_num_pairwise         (NMSettingWirelessSecurity *setting);
Packit Service b23acc
const char *nm_setting_wireless_security_get_pairwise             (NMSettingWirelessSecurity *setting, guint32 i);
Packit Service b23acc
gboolean    nm_setting_wireless_security_add_pairwise             (NMSettingWirelessSecurity *setting, const char *pairwise);
Packit Service b23acc
void        nm_setting_wireless_security_remove_pairwise          (NMSettingWirelessSecurity *setting, guint32 i);
Packit Service b23acc
gboolean    nm_setting_wireless_security_remove_pairwise_by_value (NMSettingWirelessSecurity *setting, const char *pairwise);
Packit Service b23acc
void        nm_setting_wireless_security_clear_pairwise           (NMSettingWirelessSecurity *setting);
Packit Service b23acc
Packit Service b23acc
guint32     nm_setting_wireless_security_get_num_groups        (NMSettingWirelessSecurity *setting);
Packit Service b23acc
const char *nm_setting_wireless_security_get_group             (NMSettingWirelessSecurity *setting, guint32 i);
Packit Service b23acc
gboolean    nm_setting_wireless_security_add_group             (NMSettingWirelessSecurity *setting, const char *group);
Packit Service b23acc
void        nm_setting_wireless_security_remove_group          (NMSettingWirelessSecurity *setting, guint32 i);
Packit Service b23acc
gboolean    nm_setting_wireless_security_remove_group_by_value (NMSettingWirelessSecurity *setting, const char *group);
Packit Service b23acc
void        nm_setting_wireless_security_clear_groups          (NMSettingWirelessSecurity *setting);
Packit Service b23acc
Packit Service b23acc
NM_AVAILABLE_IN_1_10
Packit Service b23acc
NMSettingWirelessSecurityPmf nm_setting_wireless_security_get_pmf (NMSettingWirelessSecurity *setting);
Packit Service b23acc
Packit Service b23acc
const char *nm_setting_wireless_security_get_psk           (NMSettingWirelessSecurity *setting);
Packit Service b23acc
NMSettingSecretFlags nm_setting_wireless_security_get_psk_flags (NMSettingWirelessSecurity *setting);
Packit Service b23acc
Packit Service b23acc
const char *nm_setting_wireless_security_get_leap_username (NMSettingWirelessSecurity *setting);
Packit Service b23acc
const char *nm_setting_wireless_security_get_leap_password (NMSettingWirelessSecurity *setting);
Packit Service b23acc
NMSettingSecretFlags nm_setting_wireless_security_get_leap_password_flags (NMSettingWirelessSecurity *setting);
Packit Service b23acc
Packit Service b23acc
const char *nm_setting_wireless_security_get_wep_key       (NMSettingWirelessSecurity *setting, guint32 idx);
Packit Service b23acc
void        nm_setting_wireless_security_set_wep_key       (NMSettingWirelessSecurity *setting, guint32 idx, const char *key);
Packit Service b23acc
guint32     nm_setting_wireless_security_get_wep_tx_keyidx (NMSettingWirelessSecurity *setting);
Packit Service b23acc
const char *nm_setting_wireless_security_get_auth_alg      (NMSettingWirelessSecurity *setting);
Packit Service b23acc
Packit Service b23acc
NMSettingSecretFlags nm_setting_wireless_security_get_wep_key_flags (NMSettingWirelessSecurity *setting);
Packit Service b23acc
NMWepKeyType nm_setting_wireless_security_get_wep_key_type (NMSettingWirelessSecurity *setting);
Packit Service b23acc
Packit Service b23acc
NM_AVAILABLE_IN_1_10
Packit Service b23acc
NMSettingWirelessSecurityWpsMethod nm_setting_wireless_security_get_wps_method (NMSettingWirelessSecurity *setting);
Packit Service b23acc
Packit Service b23acc
NM_AVAILABLE_IN_1_12
Packit Service b23acc
NMSettingWirelessSecurityFils nm_setting_wireless_security_get_fils (NMSettingWirelessSecurity *setting);
Packit Service b23acc
Packit Service b23acc
G_END_DECLS
Packit Service b23acc
Packit Service b23acc
#endif /* __NM_SETTING_WIRELESS_SECURITY_H__ */