mirror of
https://gitlab.freedesktop.org/NetworkManager/NetworkManager
synced 2024-09-20 00:21:29 +00:00
ce7fc351db
https://bugzilla.gnome.org/show_bug.cgi?id=735512 https://bugzilla.redhat.com/show_bug.cgi?id=663730 Signed-off-by: Thomas Haller <thaller@redhat.com>
234 lines
11 KiB
C
234 lines
11 KiB
C
/* -*- 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.
|
|
* Copyright 2007 - 2008 Novell, Inc.
|
|
*/
|
|
|
|
#ifndef NM_SETTING_IP4_CONFIG_H
|
|
#define NM_SETTING_IP4_CONFIG_H
|
|
|
|
#include "nm-setting.h"
|
|
|
|
G_BEGIN_DECLS
|
|
|
|
#define NM_TYPE_SETTING_IP4_CONFIG (nm_setting_ip4_config_get_type ())
|
|
#define NM_SETTING_IP4_CONFIG(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), NM_TYPE_SETTING_IP4_CONFIG, NMSettingIP4Config))
|
|
#define NM_SETTING_IP4_CONFIG_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), NM_TYPE_SETTING_IP4CONFIG, NMSettingIP4ConfigClass))
|
|
#define NM_IS_SETTING_IP4_CONFIG(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), NM_TYPE_SETTING_IP4_CONFIG))
|
|
#define NM_IS_SETTING_IP4_CONFIG_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), NM_TYPE_SETTING_IP4_CONFIG))
|
|
#define NM_SETTING_IP4_CONFIG_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), NM_TYPE_SETTING_IP4_CONFIG, NMSettingIP4ConfigClass))
|
|
|
|
#define NM_SETTING_IP4_CONFIG_SETTING_NAME "ipv4"
|
|
|
|
/**
|
|
* NMSettingIP4ConfigError:
|
|
* @NM_SETTING_IP4_CONFIG_ERROR_UNKNOWN: unknown or unclassified error
|
|
* @NM_SETTING_IP4_CONFIG_ERROR_INVALID_PROPERTY: the property was invalid
|
|
* @NM_SETTING_IP4_CONFIG_ERROR_MISSING_PROPERTY: the property was missing and is
|
|
* required
|
|
* @NM_SETTING_IP4_CONFIG_ERROR_NOT_ALLOWED_FOR_METHOD: the property's value is
|
|
* not valid with the given IP4 method
|
|
*/
|
|
typedef enum {
|
|
NM_SETTING_IP4_CONFIG_ERROR_UNKNOWN = 0, /*< nick=UnknownError >*/
|
|
NM_SETTING_IP4_CONFIG_ERROR_INVALID_PROPERTY, /*< nick=InvalidProperty >*/
|
|
NM_SETTING_IP4_CONFIG_ERROR_MISSING_PROPERTY, /*< nick=MissingProperty >*/
|
|
NM_SETTING_IP4_CONFIG_ERROR_NOT_ALLOWED_FOR_METHOD /*< nick=NotAllowedForMethod >*/
|
|
} NMSettingIP4ConfigError;
|
|
|
|
#define NM_SETTING_IP4_CONFIG_ERROR nm_setting_ip4_config_error_quark ()
|
|
GQuark nm_setting_ip4_config_error_quark (void);
|
|
|
|
#define NM_SETTING_IP4_CONFIG_METHOD "method"
|
|
#define NM_SETTING_IP4_CONFIG_DNS "dns"
|
|
#define NM_SETTING_IP4_CONFIG_DNS_SEARCH "dns-search"
|
|
#define NM_SETTING_IP4_CONFIG_ADDRESSES "addresses"
|
|
#define NM_SETTING_IP4_CONFIG_ROUTES "routes"
|
|
#define NM_SETTING_IP4_CONFIG_ROUTE_METRIC "route-metric"
|
|
#define NM_SETTING_IP4_CONFIG_IGNORE_AUTO_ROUTES "ignore-auto-routes"
|
|
#define NM_SETTING_IP4_CONFIG_IGNORE_AUTO_DNS "ignore-auto-dns"
|
|
#define NM_SETTING_IP4_CONFIG_DHCP_CLIENT_ID "dhcp-client-id"
|
|
#define NM_SETTING_IP4_CONFIG_DHCP_SEND_HOSTNAME "dhcp-send-hostname"
|
|
#define NM_SETTING_IP4_CONFIG_DHCP_HOSTNAME "dhcp-hostname"
|
|
#define NM_SETTING_IP4_CONFIG_NEVER_DEFAULT "never-default"
|
|
#define NM_SETTING_IP4_CONFIG_MAY_FAIL "may-fail"
|
|
|
|
/**
|
|
* NM_SETTING_IP4_CONFIG_METHOD_AUTO:
|
|
*
|
|
* IPv4 configuration should be automatically determined via a method appropriate
|
|
* for the hardware interface, ie DHCP or PPP or some other device-specific
|
|
* manner.
|
|
*/
|
|
#define NM_SETTING_IP4_CONFIG_METHOD_AUTO "auto"
|
|
|
|
/**
|
|
* NM_SETTING_IP4_CONFIG_METHOD_LINK_LOCAL:
|
|
*
|
|
* IPv4 configuration should be automatically configured for link-local-only
|
|
* operation.
|
|
*/
|
|
#define NM_SETTING_IP4_CONFIG_METHOD_LINK_LOCAL "link-local"
|
|
|
|
/**
|
|
* NM_SETTING_IP4_CONFIG_METHOD_MANUAL:
|
|
*
|
|
* All necessary IPv4 configuration (addresses, prefix, DNS, etc) is specified
|
|
* in the setting's properties.
|
|
*/
|
|
#define NM_SETTING_IP4_CONFIG_METHOD_MANUAL "manual"
|
|
|
|
/**
|
|
* NM_SETTING_IP4_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 a DHCP server,
|
|
* 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.
|
|
*/
|
|
#define NM_SETTING_IP4_CONFIG_METHOD_SHARED "shared"
|
|
|
|
/**
|
|
* NM_SETTING_IP4_CONFIG_METHOD_DISABLED:
|
|
*
|
|
* This connection does not use or require IPv4 address and it should be disabled.
|
|
*/
|
|
#define NM_SETTING_IP4_CONFIG_METHOD_DISABLED "disabled"
|
|
|
|
typedef struct NMIP4Address NMIP4Address;
|
|
|
|
GType nm_ip4_address_get_type (void);
|
|
|
|
NMIP4Address * nm_ip4_address_new (void);
|
|
NMIP4Address * nm_ip4_address_dup (NMIP4Address *source);
|
|
void nm_ip4_address_ref (NMIP4Address *address);
|
|
void nm_ip4_address_unref (NMIP4Address *address);
|
|
/* Return TRUE if addresses are identical */
|
|
gboolean nm_ip4_address_compare (NMIP4Address *address, NMIP4Address *other);
|
|
|
|
guint32 nm_ip4_address_get_address (NMIP4Address *address);
|
|
void nm_ip4_address_set_address (NMIP4Address *address,
|
|
guint32 addr); /* network byte order */
|
|
|
|
guint32 nm_ip4_address_get_prefix (NMIP4Address *address);
|
|
void nm_ip4_address_set_prefix (NMIP4Address *address,
|
|
guint32 prefix);
|
|
|
|
guint32 nm_ip4_address_get_gateway (NMIP4Address *address);
|
|
void nm_ip4_address_set_gateway (NMIP4Address *address,
|
|
guint32 gateway); /* network byte order */
|
|
|
|
typedef struct NMIP4Route NMIP4Route;
|
|
|
|
GType nm_ip4_route_get_type (void);
|
|
|
|
NMIP4Route * nm_ip4_route_new (void);
|
|
NMIP4Route * nm_ip4_route_dup (NMIP4Route *source);
|
|
void nm_ip4_route_ref (NMIP4Route *route);
|
|
void nm_ip4_route_unref (NMIP4Route *route);
|
|
/* Return TRUE if routes are identical */
|
|
gboolean nm_ip4_route_compare (NMIP4Route *route, NMIP4Route *other);
|
|
|
|
guint32 nm_ip4_route_get_dest (NMIP4Route *route);
|
|
void nm_ip4_route_set_dest (NMIP4Route *route,
|
|
guint32 dest); /* network byte order */
|
|
|
|
guint32 nm_ip4_route_get_prefix (NMIP4Route *route);
|
|
void nm_ip4_route_set_prefix (NMIP4Route *route,
|
|
guint32 prefix);
|
|
|
|
guint32 nm_ip4_route_get_next_hop (NMIP4Route *route);
|
|
void nm_ip4_route_set_next_hop (NMIP4Route *route,
|
|
guint32 next_hop); /* network byte order */
|
|
|
|
guint32 nm_ip4_route_get_metric (NMIP4Route *route);
|
|
void nm_ip4_route_set_metric (NMIP4Route *route,
|
|
guint32 metric);
|
|
|
|
|
|
typedef struct {
|
|
NMSetting parent;
|
|
} NMSettingIP4Config;
|
|
|
|
typedef struct {
|
|
NMSettingClass parent;
|
|
|
|
/* Padding for future expansion */
|
|
void (*_reserved1) (void);
|
|
void (*_reserved2) (void);
|
|
void (*_reserved3) (void);
|
|
void (*_reserved4) (void);
|
|
} NMSettingIP4ConfigClass;
|
|
|
|
GType nm_setting_ip4_config_get_type (void);
|
|
|
|
NMSetting * nm_setting_ip4_config_new (void);
|
|
const char * nm_setting_ip4_config_get_method (NMSettingIP4Config *setting);
|
|
|
|
guint32 nm_setting_ip4_config_get_num_dns (NMSettingIP4Config *setting);
|
|
guint32 nm_setting_ip4_config_get_dns (NMSettingIP4Config *setting, guint32 i);
|
|
gboolean nm_setting_ip4_config_add_dns (NMSettingIP4Config *setting, guint32 dns);
|
|
void nm_setting_ip4_config_remove_dns (NMSettingIP4Config *setting, guint32 i);
|
|
NM_AVAILABLE_IN_0_9_10
|
|
gboolean nm_setting_ip4_config_remove_dns_by_value (NMSettingIP4Config *setting, guint32 dns);
|
|
void nm_setting_ip4_config_clear_dns (NMSettingIP4Config *setting);
|
|
|
|
guint32 nm_setting_ip4_config_get_num_dns_searches (NMSettingIP4Config *setting);
|
|
const char * nm_setting_ip4_config_get_dns_search (NMSettingIP4Config *setting, guint32 i);
|
|
gboolean nm_setting_ip4_config_add_dns_search (NMSettingIP4Config *setting, const char *dns_search);
|
|
void nm_setting_ip4_config_remove_dns_search (NMSettingIP4Config *setting, guint32 i);
|
|
NM_AVAILABLE_IN_0_9_10
|
|
gboolean nm_setting_ip4_config_remove_dns_search_by_value (NMSettingIP4Config *setting, const char *dns_search);
|
|
void nm_setting_ip4_config_clear_dns_searches (NMSettingIP4Config *setting);
|
|
|
|
guint32 nm_setting_ip4_config_get_num_addresses (NMSettingIP4Config *setting);
|
|
NMIP4Address *nm_setting_ip4_config_get_address (NMSettingIP4Config *setting, guint32 i);
|
|
gboolean nm_setting_ip4_config_add_address (NMSettingIP4Config *setting, NMIP4Address *address);
|
|
void nm_setting_ip4_config_remove_address (NMSettingIP4Config *setting, guint32 i);
|
|
NM_AVAILABLE_IN_0_9_10
|
|
gboolean nm_setting_ip4_config_remove_address_by_value (NMSettingIP4Config *setting, NMIP4Address *address);
|
|
void nm_setting_ip4_config_clear_addresses (NMSettingIP4Config *setting);
|
|
|
|
guint32 nm_setting_ip4_config_get_num_routes (NMSettingIP4Config *setting);
|
|
NMIP4Route * nm_setting_ip4_config_get_route (NMSettingIP4Config *setting, guint32 i);
|
|
gboolean nm_setting_ip4_config_add_route (NMSettingIP4Config *setting, NMIP4Route *route);
|
|
void nm_setting_ip4_config_remove_route (NMSettingIP4Config *setting, guint32 i);
|
|
NM_AVAILABLE_IN_0_9_10
|
|
gboolean nm_setting_ip4_config_remove_route_by_value (NMSettingIP4Config *setting, NMIP4Route *route);
|
|
void nm_setting_ip4_config_clear_routes (NMSettingIP4Config *setting);
|
|
|
|
NM_AVAILABLE_IN_1_0
|
|
gint64 nm_setting_ip4_config_get_route_metric (NMSettingIP4Config *setting);
|
|
|
|
gboolean nm_setting_ip4_config_get_ignore_auto_routes (NMSettingIP4Config *setting);
|
|
gboolean nm_setting_ip4_config_get_ignore_auto_dns (NMSettingIP4Config *setting);
|
|
const char * nm_setting_ip4_config_get_dhcp_client_id (NMSettingIP4Config *setting);
|
|
gboolean nm_setting_ip4_config_get_dhcp_send_hostname (NMSettingIP4Config *setting);
|
|
const char * nm_setting_ip4_config_get_dhcp_hostname (NMSettingIP4Config *setting);
|
|
|
|
gboolean nm_setting_ip4_config_get_never_default (NMSettingIP4Config *setting);
|
|
|
|
gboolean nm_setting_ip4_config_get_may_fail (NMSettingIP4Config *setting);
|
|
|
|
G_END_DECLS
|
|
|
|
#endif /* NM_SETTING_IP4_CONFIG_H */
|