2014-07-24 12:53:33 +00:00
|
|
|
/* -*- Mode: C; tab-width: 4; indent-tabs-mode: t; c-basic-offset: 4 -*- */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
|
|
* License along with this library; if not, write to the
|
|
|
|
* Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
|
|
|
|
* Boston, MA 02110-1301 USA.
|
|
|
|
*
|
|
|
|
* Copyright 2007 - 2014 Red Hat, Inc.
|
|
|
|
*/
|
|
|
|
|
all: fix up multiple-include-guard defines
Previously, src/nm-ip4-config.h, libnm/nm-ip4-config.h, and
libnm-glib/nm-ip4-config.h all used "NM_IP4_CONFIG_H" as an include
guard, which meant that nm-test-utils.h could not tell which of them
was being included (and so, eg, if you tried to include
nm-ip4-config.h in a libnm test, it would fail to compile because
nm-test-utils.h was referring to symbols in src/nm-ip4-config.h).
Fix this by changing the include guards in the non-API-stable parts of
the tree:
- libnm-glib/nm-ip4-config.h remains NM_IP4_CONFIG_H
- libnm/nm-ip4-config.h now uses __NM_IP4_CONFIG_H__
- src/nm-ip4-config.h now uses __NETWORKMANAGER_IP4_CONFIG_H__
And likewise for all other headers.
The two non-"nm"-prefixed headers, libnm/NetworkManager.h and
src/NetworkManagerUtils.h are now __NETWORKMANAGER_H__ and
__NETWORKMANAGER_UTILS_H__ respectively, which, while not entirely
consistent with the general scheme, do still mostly make sense in
isolation.
2014-08-13 18:10:11 +00:00
|
|
|
#ifndef __NM_SETTING_IP6_CONFIG_H__
|
|
|
|
#define __NM_SETTING_IP6_CONFIG_H__
|
2014-07-24 12:53:33 +00:00
|
|
|
|
2014-07-06 20:53:02 +00:00
|
|
|
#if !defined (__NETWORKMANAGER_H_INSIDE__) && !defined (NETWORKMANAGER_COMPILATION)
|
|
|
|
#error "Only <NetworkManager.h> can be included directly."
|
|
|
|
#endif
|
|
|
|
|
2014-09-16 20:42:46 +00:00
|
|
|
#include "nm-setting-ip-config.h"
|
2014-07-24 12:53:33 +00:00
|
|
|
|
|
|
|
G_BEGIN_DECLS
|
|
|
|
|
|
|
|
#define NM_TYPE_SETTING_IP6_CONFIG (nm_setting_ip6_config_get_type ())
|
|
|
|
#define NM_SETTING_IP6_CONFIG(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), NM_TYPE_SETTING_IP6_CONFIG, NMSettingIP6Config))
|
|
|
|
#define NM_SETTING_IP6_CONFIG_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), NM_TYPE_SETTING_IP6CONFIG, NMSettingIP6ConfigClass))
|
|
|
|
#define NM_IS_SETTING_IP6_CONFIG(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), NM_TYPE_SETTING_IP6_CONFIG))
|
|
|
|
#define NM_IS_SETTING_IP6_CONFIG_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), NM_TYPE_SETTING_IP6_CONFIG))
|
|
|
|
#define NM_SETTING_IP6_CONFIG_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), NM_TYPE_SETTING_IP6_CONFIG, NMSettingIP6ConfigClass))
|
|
|
|
|
|
|
|
#define NM_SETTING_IP6_CONFIG_SETTING_NAME "ipv6"
|
|
|
|
|
2014-10-19 21:30:10 +00:00
|
|
|
#define NM_SETTING_IP6_CONFIG_IP6_PRIVACY "ip6-privacy"
|
2014-07-24 12:53:33 +00:00
|
|
|
|
2015-09-08 18:22:17 +00:00
|
|
|
#define NM_SETTING_IP6_CONFIG_ADDR_GEN_MODE "addr-gen-mode"
|
|
|
|
|
2016-04-30 14:48:02 +00:00
|
|
|
#define NM_SETTING_IP6_CONFIG_TOKEN "token"
|
|
|
|
|
2014-07-24 12:53:33 +00:00
|
|
|
/**
|
|
|
|
* NM_SETTING_IP6_CONFIG_METHOD_IGNORE:
|
|
|
|
*
|
|
|
|
* IPv6 is not required or is handled by some other mechanism, and NetworkManager
|
|
|
|
* should not configure IPv6 for this connection.
|
|
|
|
*/
|
|
|
|
#define NM_SETTING_IP6_CONFIG_METHOD_IGNORE "ignore"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* NM_SETTING_IP6_CONFIG_METHOD_AUTO:
|
|
|
|
*
|
|
|
|
* IPv6 configuration should be automatically determined via a method appropriate
|
|
|
|
* for the hardware interface, ie router advertisements, DHCP, or PPP or some
|
|
|
|
* other device-specific manner.
|
|
|
|
*/
|
|
|
|
#define NM_SETTING_IP6_CONFIG_METHOD_AUTO "auto"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* NM_SETTING_IP6_CONFIG_METHOD_DHCP:
|
|
|
|
*
|
|
|
|
* IPv6 configuration should be automatically determined via DHCPv6 only and
|
|
|
|
* router advertisements should be ignored.
|
|
|
|
*/
|
|
|
|
#define NM_SETTING_IP6_CONFIG_METHOD_DHCP "dhcp"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* NM_SETTING_IP6_CONFIG_METHOD_LINK_LOCAL:
|
|
|
|
*
|
|
|
|
* IPv6 configuration should be automatically configured for link-local-only
|
|
|
|
* operation.
|
|
|
|
*/
|
|
|
|
#define NM_SETTING_IP6_CONFIG_METHOD_LINK_LOCAL "link-local"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* NM_SETTING_IP6_CONFIG_METHOD_MANUAL:
|
|
|
|
*
|
|
|
|
* All necessary IPv6 configuration (addresses, prefix, DNS, etc) is specified
|
|
|
|
* in the setting's properties.
|
|
|
|
*/
|
|
|
|
#define NM_SETTING_IP6_CONFIG_METHOD_MANUAL "manual"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* NM_SETTING_IP6_CONFIG_METHOD_SHARED:
|
|
|
|
*
|
|
|
|
* This connection specifies configuration that allows other computers to
|
|
|
|
* connect through it to the default network (usually the Internet). The
|
|
|
|
* connection's interface will be assigned a private address, and router
|
|
|
|
* advertisements, a caching DNS server, and Network Address Translation (NAT)
|
|
|
|
* functionality will be started on this connection's interface to allow other
|
|
|
|
* devices to connect through that interface to the default network. (not yet
|
|
|
|
* supported for IPv6)
|
|
|
|
*/
|
|
|
|
#define NM_SETTING_IP6_CONFIG_METHOD_SHARED "shared"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* NMSettingIP6ConfigPrivacy:
|
|
|
|
* @NM_SETTING_IP6_CONFIG_PRIVACY_UNKNOWN: unknown or no value specified
|
|
|
|
* @NM_SETTING_IP6_CONFIG_PRIVACY_DISABLED: IPv6 Privacy Extensions are disabled
|
|
|
|
* @NM_SETTING_IP6_CONFIG_PRIVACY_PREFER_PUBLIC_ADDR: IPv6 Privacy Extensions
|
|
|
|
* are enabled, but public addresses are preferred over temporary addresses
|
|
|
|
* @NM_SETTING_IP6_CONFIG_PRIVACY_PREFER_TEMP_ADDR: IPv6 Privacy Extensions
|
|
|
|
* are enabled and temporary addresses are preferred over public addresses
|
|
|
|
*
|
|
|
|
* #NMSettingIP6ConfigPrivacy values indicate if and how IPv6 Privacy
|
|
|
|
* Extensions are used (RFC4941).
|
|
|
|
*/
|
|
|
|
typedef enum {
|
|
|
|
NM_SETTING_IP6_CONFIG_PRIVACY_UNKNOWN = -1,
|
|
|
|
NM_SETTING_IP6_CONFIG_PRIVACY_DISABLED = 0,
|
|
|
|
NM_SETTING_IP6_CONFIG_PRIVACY_PREFER_PUBLIC_ADDR = 1,
|
|
|
|
NM_SETTING_IP6_CONFIG_PRIVACY_PREFER_TEMP_ADDR = 2
|
|
|
|
} NMSettingIP6ConfigPrivacy;
|
|
|
|
|
2015-09-08 18:22:17 +00:00
|
|
|
/**
|
|
|
|
* NMSettingIP6ConfigAddrGenMode:
|
2015-12-18 09:27:27 +00:00
|
|
|
* @NM_SETTING_IP6_CONFIG_ADDR_GEN_MODE_EUI64: The Interface Identifier is derived
|
2015-09-08 18:22:17 +00:00
|
|
|
* from the interface hardware address.
|
2015-12-18 09:27:27 +00:00
|
|
|
* @NM_SETTING_IP6_CONFIG_ADDR_GEN_MODE_STABLE_PRIVACY: The Interface Identifier
|
2015-09-08 18:22:17 +00:00
|
|
|
* is created by using a cryptographically secure hash of a secret host-specific
|
|
|
|
* key along with the connection identification and the network address as
|
|
|
|
* specified by RFC7217.
|
|
|
|
*
|
2016-08-26 16:04:47 +00:00
|
|
|
* #NMSettingIP6ConfigAddrGenMode controls how the Interface Identifier for
|
2015-09-08 18:22:17 +00:00
|
|
|
* RFC4862 Stateless Address Autoconfiguration is created.
|
|
|
|
*
|
|
|
|
* Since: 1.2
|
|
|
|
*/
|
|
|
|
typedef enum {
|
|
|
|
NM_SETTING_IP6_CONFIG_ADDR_GEN_MODE_EUI64 = 0,
|
|
|
|
NM_SETTING_IP6_CONFIG_ADDR_GEN_MODE_STABLE_PRIVACY = 1,
|
|
|
|
} NMSettingIP6ConfigAddrGenMode;
|
|
|
|
|
2016-05-05 07:36:32 +00:00
|
|
|
/**
|
|
|
|
* NMSettingIP6Config:
|
|
|
|
*/
|
2014-10-22 02:09:52 +00:00
|
|
|
struct _NMSettingIP6Config {
|
2014-10-19 21:30:10 +00:00
|
|
|
NMSettingIPConfig parent;
|
2014-10-22 02:09:52 +00:00
|
|
|
};
|
2014-07-24 12:53:33 +00:00
|
|
|
|
|
|
|
typedef struct {
|
2014-10-19 21:30:10 +00:00
|
|
|
NMSettingIPConfigClass parent;
|
2014-07-24 12:53:33 +00:00
|
|
|
|
2014-05-15 13:55:18 +00:00
|
|
|
/*< private >*/
|
|
|
|
gpointer padding[4];
|
2014-07-24 12:53:33 +00:00
|
|
|
} NMSettingIP6ConfigClass;
|
|
|
|
|
|
|
|
GType nm_setting_ip6_config_get_type (void);
|
|
|
|
|
2014-10-19 21:30:10 +00:00
|
|
|
NMSetting *nm_setting_ip6_config_new (void);
|
|
|
|
|
2014-07-24 12:53:33 +00:00
|
|
|
NMSettingIP6ConfigPrivacy nm_setting_ip6_config_get_ip6_privacy (NMSettingIP6Config *setting);
|
2015-09-08 18:22:17 +00:00
|
|
|
NM_AVAILABLE_IN_1_2
|
|
|
|
NMSettingIP6ConfigAddrGenMode nm_setting_ip6_config_get_addr_gen_mode (NMSettingIP6Config *setting);
|
2016-04-30 14:48:02 +00:00
|
|
|
NM_AVAILABLE_IN_1_4
|
|
|
|
const char *nm_setting_ip6_config_get_token (NMSettingIP6Config *setting);
|
2014-07-24 12:53:33 +00:00
|
|
|
|
|
|
|
G_END_DECLS
|
|
|
|
|
all: fix up multiple-include-guard defines
Previously, src/nm-ip4-config.h, libnm/nm-ip4-config.h, and
libnm-glib/nm-ip4-config.h all used "NM_IP4_CONFIG_H" as an include
guard, which meant that nm-test-utils.h could not tell which of them
was being included (and so, eg, if you tried to include
nm-ip4-config.h in a libnm test, it would fail to compile because
nm-test-utils.h was referring to symbols in src/nm-ip4-config.h).
Fix this by changing the include guards in the non-API-stable parts of
the tree:
- libnm-glib/nm-ip4-config.h remains NM_IP4_CONFIG_H
- libnm/nm-ip4-config.h now uses __NM_IP4_CONFIG_H__
- src/nm-ip4-config.h now uses __NETWORKMANAGER_IP4_CONFIG_H__
And likewise for all other headers.
The two non-"nm"-prefixed headers, libnm/NetworkManager.h and
src/NetworkManagerUtils.h are now __NETWORKMANAGER_H__ and
__NETWORKMANAGER_UTILS_H__ respectively, which, while not entirely
consistent with the general scheme, do still mostly make sense in
isolation.
2014-08-13 18:10:11 +00:00
|
|
|
#endif /* __NM_SETTING_IP6_CONFIG_H__ */
|