Blame src/dhcp/nm-dhcp-client.h

Packit Service b23acc
// SPDX-License-Identifier: GPL-2.0+
Packit Service b23acc
/*
Packit Service b23acc
 * Copyright (C) 2005 - 2010 Red Hat, Inc.
Packit Service b23acc
 */
Packit Service b23acc
Packit Service b23acc
#ifndef __NETWORKMANAGER_DHCP_CLIENT_H__
Packit Service b23acc
#define __NETWORKMANAGER_DHCP_CLIENT_H__
Packit Service b23acc
Packit Service b23acc
#include "nm-setting-ip4-config.h"
Packit Service b23acc
#include "nm-setting-ip6-config.h"
Packit Service b23acc
#include "nm-ip4-config.h"
Packit Service b23acc
#include "nm-ip6-config.h"
Packit Service b23acc
#include "nm-dhcp-utils.h"
Packit Service b23acc
Packit Service b23acc
#define NM_DHCP_TIMEOUT_DEFAULT  ((guint32) 45) /* default DHCP timeout, in seconds */
Packit Service b23acc
#define NM_DHCP_TIMEOUT_INFINITY ((guint32) G_MAXINT32)
Packit Service b23acc
Packit Service b23acc
#define NM_TYPE_DHCP_CLIENT            (nm_dhcp_client_get_type ())
Packit Service b23acc
#define NM_DHCP_CLIENT(obj)            (G_TYPE_CHECK_INSTANCE_CAST ((obj), NM_TYPE_DHCP_CLIENT, NMDhcpClient))
Packit Service b23acc
#define NM_DHCP_CLIENT_CLASS(klass)    (G_TYPE_CHECK_CLASS_CAST ((klass), NM_TYPE_DHCP_CLIENT, NMDhcpClientClass))
Packit Service b23acc
#define NM_IS_DHCP_CLIENT(obj)         (G_TYPE_CHECK_INSTANCE_TYPE ((obj), NM_TYPE_DHCP_CLIENT))
Packit Service b23acc
#define NM_IS_DHCP_CLIENT_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), NM_TYPE_DHCP_CLIENT))
Packit Service b23acc
#define NM_DHCP_CLIENT_GET_CLASS(obj)  (G_TYPE_INSTANCE_GET_CLASS ((obj), NM_TYPE_DHCP_CLIENT, NMDhcpClientClass))
Packit Service b23acc
Packit Service b23acc
#define NM_DHCP_CLIENT_ADDR_FAMILY      "addr-family"
Packit Service b23acc
#define NM_DHCP_CLIENT_FLAGS            "flags"
Packit Service b23acc
#define NM_DHCP_CLIENT_HWADDR           "hwaddr"
Packit Service b23acc
#define NM_DHCP_CLIENT_BROADCAST_HWADDR "broadcast-hwaddr"
Packit Service b23acc
#define NM_DHCP_CLIENT_IFINDEX          "ifindex"
Packit Service b23acc
#define NM_DHCP_CLIENT_INTERFACE        "iface"
Packit Service b23acc
#define NM_DHCP_CLIENT_MULTI_IDX        "multi-idx"
Packit Service b23acc
#define NM_DHCP_CLIENT_HOSTNAME         "hostname"
Packit Service b23acc
#define NM_DHCP_CLIENT_MUD_URL          "mud-url"
Packit Service b23acc
#define NM_DHCP_CLIENT_ROUTE_METRIC     "route-metric"
Packit Service b23acc
#define NM_DHCP_CLIENT_ROUTE_TABLE      "route-table"
Packit Service b23acc
#define NM_DHCP_CLIENT_TIMEOUT          "timeout"
Packit Service b23acc
#define NM_DHCP_CLIENT_UUID             "uuid"
Packit Service b23acc
#define NM_DHCP_CLIENT_IAID             "iaid"
Packit Service b23acc
#define NM_DHCP_CLIENT_IAID_EXPLICIT    "iaid-explicit"
Packit Service b23acc
#define NM_DHCP_CLIENT_HOSTNAME_FLAGS   "hostname-flags"
Packit Service b23acc
Packit Service b23acc
#define NM_DHCP_CLIENT_SIGNAL_STATE_CHANGED "state-changed"
Packit Service b23acc
#define NM_DHCP_CLIENT_SIGNAL_PREFIX_DELEGATED "prefix-delegated"
Packit Service b23acc
Packit Service b23acc
typedef enum {
Packit Service b23acc
	NM_DHCP_STATE_UNKNOWN = 0,
Packit Service b23acc
	NM_DHCP_STATE_BOUND,        /* new lease */
Packit Service b23acc
	NM_DHCP_STATE_EXTENDED,     /* lease extended */
Packit Service b23acc
	NM_DHCP_STATE_TIMEOUT,      /* timed out contacting server */
Packit Service b23acc
	NM_DHCP_STATE_DONE,         /* client quit or stopped */
Packit Service b23acc
	NM_DHCP_STATE_EXPIRE,       /* lease expired or NAKed */
Packit Service b23acc
	NM_DHCP_STATE_FAIL,         /* failed for some reason */
Packit Service b23acc
	NM_DHCP_STATE_TERMINATED,   /* client is no longer running */
Packit Service b23acc
	__NM_DHCP_STATE_MAX,
Packit Service b23acc
	NM_DHCP_STATE_MAX = __NM_DHCP_STATE_MAX - 1,
Packit Service b23acc
} NMDhcpState;
Packit Service b23acc
Packit Service b23acc
struct _NMDhcpClientPrivate;
Packit Service b23acc
Packit Service b23acc
typedef struct {
Packit Service b23acc
	GObject parent;
Packit Service b23acc
	struct _NMDhcpClientPrivate *_priv;
Packit Service b23acc
	CList dhcp_client_lst;
Packit Service b23acc
} NMDhcpClient;
Packit Service b23acc
Packit Service b23acc
typedef enum {
Packit Service b23acc
	NM_DHCP_CLIENT_FLAGS_INFO_ONLY = (1LL <<  0),
Packit Service b23acc
	NM_DHCP_CLIENT_FLAGS_USE_FQDN  = (1LL <<  1),
Packit Service b23acc
} NMDhcpClientFlags;
Packit Service b23acc
Packit Service b23acc
typedef struct {
Packit Service b23acc
	GObjectClass parent;
Packit Service b23acc
Packit Service b23acc
	gboolean (*ip4_start)     (NMDhcpClient *self,
Packit Service b23acc
	                           const char *anycast_addr,
Packit Service b23acc
	                           const char *last_ip4_address,
Packit Service b23acc
	                           GError **error);
Packit Service b23acc
Packit Service b23acc
	gboolean (*accept)        (NMDhcpClient *self,
Packit Service b23acc
	                           GError **error);
Packit Service b23acc
Packit Service b23acc
	gboolean (*decline)       (NMDhcpClient *self,
Packit Service b23acc
	                           const char *error_message,
Packit Service b23acc
	                           GError **error);
Packit Service b23acc
Packit Service b23acc
	gboolean (*ip6_start)     (NMDhcpClient *self,
Packit Service b23acc
	                           const char *anycast_addr,
Packit Service b23acc
	                           const struct in6_addr *ll_addr,
Packit Service b23acc
	                           NMSettingIP6ConfigPrivacy privacy,
Packit Service b23acc
	                           guint needed_prefixes,
Packit Service b23acc
	                           GError **error);
Packit Service b23acc
Packit Service b23acc
	void (*stop)              (NMDhcpClient *self,
Packit Service b23acc
	                           gboolean release);
Packit Service b23acc
Packit Service b23acc
	/**
Packit Service b23acc
	 * get_duid:
Packit Service b23acc
	 * @self: the #NMDhcpClient
Packit Service b23acc
	 *
Packit Service b23acc
	 * Attempts to find an existing DHCPv6 DUID for this client in the DHCP
Packit Service b23acc
	 * client's persistent configuration.  Returned DUID should be the binary
Packit Service b23acc
	 * representation of the DUID.  If no DUID is found, %NULL should be
Packit Service b23acc
	 * returned.
Packit Service b23acc
	 */
Packit Service b23acc
	GBytes *(*get_duid) (NMDhcpClient *self);
Packit Service b23acc
} NMDhcpClientClass;
Packit Service b23acc
Packit Service b23acc
GType nm_dhcp_client_get_type (void);
Packit Service b23acc
Packit Service b23acc
struct _NMDedupMultiIndex *nm_dhcp_client_get_multi_idx (NMDhcpClient *self);
Packit Service b23acc
Packit Service b23acc
pid_t nm_dhcp_client_get_pid (NMDhcpClient *self);
Packit Service b23acc
Packit Service b23acc
int nm_dhcp_client_get_addr_family (NMDhcpClient *self);
Packit Service b23acc
Packit Service b23acc
const char *nm_dhcp_client_get_iface (NMDhcpClient *self);
Packit Service b23acc
Packit Service b23acc
int         nm_dhcp_client_get_ifindex (NMDhcpClient *self);
Packit Service b23acc
Packit Service b23acc
const char *nm_dhcp_client_get_uuid (NMDhcpClient *self);
Packit Service b23acc
Packit Service b23acc
GBytes *nm_dhcp_client_get_duid (NMDhcpClient *self);
Packit Service b23acc
Packit Service b23acc
GBytes *nm_dhcp_client_get_hw_addr (NMDhcpClient *self);
Packit Service b23acc
Packit Service b23acc
GBytes *nm_dhcp_client_get_broadcast_hw_addr (NMDhcpClient *self);
Packit Service b23acc
Packit Service b23acc
guint32 nm_dhcp_client_get_route_table (NMDhcpClient *self);
Packit Service b23acc
Packit Service b23acc
void nm_dhcp_client_set_route_table (NMDhcpClient *self, guint32 route_table);
Packit Service b23acc
Packit Service b23acc
guint32 nm_dhcp_client_get_route_metric (NMDhcpClient *self);
Packit Service b23acc
Packit Service b23acc
void nm_dhcp_client_set_route_metric (NMDhcpClient *self, guint32 route_metric);
Packit Service b23acc
Packit Service b23acc
guint32 nm_dhcp_client_get_timeout (NMDhcpClient *self);
Packit Service b23acc
Packit Service b23acc
guint32 nm_dhcp_client_get_iaid (NMDhcpClient *self);
Packit Service b23acc
Packit Service b23acc
gboolean nm_dhcp_client_get_iaid_explicit (NMDhcpClient *self);
Packit Service b23acc
Packit Service b23acc
GBytes *nm_dhcp_client_get_client_id (NMDhcpClient *self);
Packit Service b23acc
Packit Service b23acc
const char *nm_dhcp_client_get_hostname (NMDhcpClient *self);
Packit Service b23acc
const char *nm_dhcp_client_get_mud_url (NMDhcpClient *self);
Packit Service b23acc
Packit Service b23acc
NMDhcpHostnameFlags nm_dhcp_client_get_hostname_flags (NMDhcpClient *self);
Packit Service b23acc
Packit Service b23acc
gboolean nm_dhcp_client_get_info_only (NMDhcpClient *self);
Packit Service b23acc
Packit Service b23acc
gboolean nm_dhcp_client_get_use_fqdn (NMDhcpClient *self);
Packit Service b23acc
Packit Service b23acc
gboolean nm_dhcp_client_start_ip4 (NMDhcpClient *self,
Packit Service b23acc
                                   GBytes *client_id,
Packit Service b23acc
                                   const char *dhcp_anycast_addr,
Packit Service b23acc
                                   const char *last_ip4_address,
Packit Service b23acc
                                   GError **error);
Packit Service b23acc
Packit Service b23acc
gboolean nm_dhcp_client_start_ip6 (NMDhcpClient *self,
Packit Service b23acc
                                   GBytes *client_id,
Packit Service b23acc
                                   gboolean enforce_duid,
Packit Service b23acc
                                   const char *dhcp_anycast_addr,
Packit Service b23acc
                                   const struct in6_addr *ll_addr,
Packit Service b23acc
                                   NMSettingIP6ConfigPrivacy privacy,
Packit Service b23acc
                                   guint needed_prefixes,
Packit Service b23acc
                                   GError **error);
Packit Service b23acc
Packit Service b23acc
gboolean nm_dhcp_client_accept (NMDhcpClient *self,
Packit Service b23acc
                                GError **error);
Packit Service b23acc
Packit Service b23acc
gboolean nm_dhcp_client_decline (NMDhcpClient *self,
Packit Service b23acc
                                 const char *error_message,
Packit Service b23acc
                                 GError **error);
Packit Service b23acc
Packit Service b23acc
void nm_dhcp_client_stop (NMDhcpClient *self, gboolean release);
Packit Service b23acc
Packit Service b23acc
/* Backend helpers for subclasses */
Packit Service b23acc
void nm_dhcp_client_stop_existing (const char *pid_file, const char *binary_name);
Packit Service b23acc
Packit Service b23acc
void nm_dhcp_client_stop_pid (pid_t pid, const char *iface);
Packit Service b23acc
Packit Service b23acc
void nm_dhcp_client_start_timeout (NMDhcpClient *self);
Packit Service b23acc
Packit Service b23acc
void nm_dhcp_client_watch_child (NMDhcpClient *self, pid_t pid);
Packit Service b23acc
Packit Service b23acc
void nm_dhcp_client_set_state (NMDhcpClient *self,
Packit Service b23acc
                               NMDhcpState new_state,
Packit Service b23acc
                               NMIPConfig *ip_config,
Packit Service b23acc
                               GHashTable *options); /* str:str hash */
Packit Service b23acc
Packit Service b23acc
gboolean nm_dhcp_client_handle_event (gpointer unused,
Packit Service b23acc
                                      const char *iface,
Packit Service b23acc
                                      int pid,
Packit Service b23acc
                                      GVariant *options,
Packit Service b23acc
                                      const char *reason,
Packit Service b23acc
                                      NMDhcpClient *self);
Packit Service b23acc
Packit Service b23acc
void nm_dhcp_client_set_client_id (NMDhcpClient *self,
Packit Service b23acc
                                   GBytes *client_id);
Packit Service b23acc
void nm_dhcp_client_set_client_id_bin (NMDhcpClient *self,
Packit Service b23acc
                                       guint8 type,
Packit Service b23acc
                                       const guint8 *client_id,
Packit Service b23acc
                                       gsize len);
Packit Service b23acc
Packit Service b23acc
void nm_dhcp_client_emit_ipv6_prefix_delegated (NMDhcpClient *self,
Packit Service b23acc
                                                const NMPlatformIP6Address *prefix);
Packit Service b23acc
Packit Service b23acc
/*****************************************************************************
Packit Service b23acc
 * Client data
Packit Service b23acc
 *****************************************************************************/
Packit Service b23acc
Packit Service b23acc
typedef struct {
Packit Service b23acc
	GType (*get_type) (void);
Packit Service b23acc
	GType (*get_type_per_addr_family) (int addr_family);
Packit Service b23acc
	const char *name;
Packit Service b23acc
	const char *(*get_path) (void);
Packit Service b23acc
	bool experimental:1;
Packit Service b23acc
} NMDhcpClientFactory;
Packit Service b23acc
Packit Service b23acc
GType nm_dhcp_nettools_get_type (void);
Packit Service b23acc
Packit Service b23acc
extern const NMDhcpClientFactory _nm_dhcp_client_factory_dhcpcanon;
Packit Service b23acc
extern const NMDhcpClientFactory _nm_dhcp_client_factory_dhclient;
Packit Service b23acc
extern const NMDhcpClientFactory _nm_dhcp_client_factory_dhcpcd;
Packit Service b23acc
extern const NMDhcpClientFactory _nm_dhcp_client_factory_internal;
Packit Service b23acc
extern const NMDhcpClientFactory _nm_dhcp_client_factory_systemd;
Packit Service b23acc
extern const NMDhcpClientFactory _nm_dhcp_client_factory_nettools;
Packit Service b23acc
Packit Service b23acc
#endif /* __NETWORKMANAGER_DHCP_CLIENT_H__ */