#ifndef _LIBILB_IMPL_H
#define _LIBILB_IMPL_H
#ifdef __cplusplus
extern "C" {
#endif
#include <sys/types.h>
#include <sys/socket.h>
#include <sys/note.h>
#include <netinet/in.h>
#include <netdb.h>
#include <net/if.h>
#include <inet/ilb.h>
#include <libilb.h>
#include <thread.h>
#include <synch.h>
#if !defined max
#define max(a, b) ((a) > (b) ? (a) : (b))
#endif
#define SOCKET_PATH "/var/run/daemon/ilb_sock"
#define ILBD_MSG_SIZE 102400
#define INV6_N2H_MSB64(addr) \
(((uint64_t)ntohl((addr)->_S6_un._S6_u32[0]) << 32) + \
(ntohl((addr)->_S6_un._S6_u32[1])))
#define INV6_N2H_LSB64(addr) \
(((uint64_t)ntohl((addr)->_S6_un._S6_u32[2]) << 32) + \
(ntohl((addr)->_S6_un._S6_u32[3])))
#define INV6_H2N_MSB64(addr, msb) \
(addr)->_S6_un._S6_u32[0] = htonl((msb) >> 32); \
(addr)->_S6_un._S6_u32[1] = htonl((msb) & 0xffffffff)
#define INV6_H2N_LSB64(addr, lsb) \
(addr)->_S6_un._S6_u32[2] = htonl((lsb) >> 32); \
(addr)->_S6_un._S6_u32[3] = htonl((lsb) & 0xffffffff)
#define IP_COPY_CLI_2_IMPL(_e, _i) \
bzero(_i, sizeof (*(_i))); \
if ((_e)->ia_af == AF_INET6) \
(void) memcpy((_i), &(_e)->ia_v6, sizeof (*(_i))); \
else \
IN6_INADDR_TO_V4MAPPED(&(_e)->ia_v4, (_i))
#define IP_COPY_IMPL_2_CLI(_i, _e) \
do { \
bzero(_e, sizeof (*(_e))); \
if (IN6_IS_ADDR_V4MAPPED(_i)) { \
(_e)->ia_af = AF_INET; \
IN6_V4MAPPED_TO_INADDR((_i), &(_e)->ia_v4); \
} else { \
(_e)->ia_af = AF_INET6; \
(void) memcpy(&(_e)->ia_v6, (_i), \
sizeof ((_e)->ia_v6)); \
} \
_NOTE(CONSTCOND) \
} while (0)
#define GET_AF(_a) IN6_IS_ADDR_V4MAPPED(_a)?AF_INET:AF_INET6
#define IS_AF_VALID(_af) (_af == AF_INET || _af == AF_INET6)
typedef enum {
ILBD_BAD_CMD = 0,
ILBD_CREATE_SERVERGROUP,
ILBD_ADD_SERVER_TO_GROUP,
ILBD_REM_SERVER_FROM_GROUP,
ILBD_ENABLE_SERVER,
ILBD_DISABLE_SERVER,
ILBD_DESTROY_SERVERGROUP,
ILBD_RETRIEVE_SG_NAMES,
ILBD_RETRIEVE_SG_HOSTS,
ILBD_SRV_ADDR2ID,
ILBD_SRV_ID2ADDR,
ILBD_CREATE_RULE,
ILBD_DESTROY_RULE,
ILBD_ENABLE_RULE,
ILBD_DISABLE_RULE,
ILBD_RETRIEVE_RULE_NAMES,
ILBD_RETRIEVE_RULE,
ILBD_CREATE_HC,
ILBD_DESTROY_HC,
ILBD_GET_HC_INFO,
ILBD_GET_HC_SRVS,
ILBD_GET_HC_RULES,
ILBD_RETRIEVE_HC_NAMES,
ILBD_SHOW_NAT,
ILBD_SHOW_PERSIST,
ILBD_CMD_OK,
ILBD_CMD_ERROR
} ilbd_cmd_t;
typedef struct sg_srv {
int32_t sgs_flags;
struct in6_addr sgs_addr;
int32_t sgs_minport;
int32_t sgs_maxport;
int32_t sgs_id;
char sgs_srvID[ILB_NAMESZ];
} ilb_sg_srv_t;
typedef struct sg_info {
int32_t sg_flags;
char sg_name[ILB_SGNAME_SZ];
int32_t sg_srvcount;
ilb_sg_srv_t sg_servers[];
} ilb_sg_info_t;
typedef char ilbd_name_t[ILB_NAMESZ];
typedef struct ilbd_namelist {
int32_t ilbl_flags;
int32_t ilbl_count;
ilbd_name_t ilbl_name[];
} ilbd_namelist_t;
#define ILBL_NAME_OFFSET (offsetof(ilbd_namelist_t, ilbl_name))
typedef struct rule_info {
int32_t rl_flags;
char rl_name[ILB_NAMESZ];
struct in6_addr rl_vip;
uint16_t rl_proto;
uint16_t rl_ipversion;
int32_t rl_minport;
int32_t rl_maxport;
ilb_algo_t rl_algo;
ilb_topo_t rl_topo;
struct in6_addr rl_nat_src_start;
struct in6_addr rl_nat_src_end;
struct in6_addr rl_stickymask;
uint32_t rl_conndrain;
uint32_t rl_nat_timeout;
uint32_t rl_sticky_timeout;
in_port_t rl_hcport;
ilb_hcp_flags_t rl_hcpflag;
char rl_sgname[ILB_SGNAME_SZ];
char rl_hcname[ILB_NAMESZ];
} ilb_rule_info_t;
typedef struct {
uint32_t sn_num;
uint32_t sn_data[];
} ilb_show_info_t;
typedef struct {
uint32_t rs_num_srvs;
ilb_hc_srv_t rs_srvs[];
} ilb_hc_rule_srv_t;
typedef struct ilb_handle_impl {
mutex_t h_lock;
cond_t h_cv;
boolean_t h_busy;
boolean_t h_valid;
boolean_t h_closing;
uint32_t h_waiter;
int h_socket;
ilb_status_t h_error;
} ilb_handle_impl_t;
#define ILB_COMM_END 0x1
typedef struct {
ilbd_cmd_t ic_cmd;
int32_t ic_flags;
uint32_t ic_data[];
} ilb_comm_t;
ilb_status_t i_check_ip_range(ilb_ip_addr_t *, ilb_ip_addr_t *);
ilb_status_t i_ilb_do_comm(ilb_handle_t, ilb_comm_t *, size_t, ilb_comm_t *,
size_t *);
void i_ilb_close_comm(ilb_handle_t);
struct in6_addr i_next_ip_addr(struct in6_addr *, int);
ilb_status_t i_ilb_retrieve_rule_names(ilb_handle_t, ilb_comm_t **,
size_t *);
ilb_comm_t *i_ilb_alloc_req(ilbd_cmd_t, size_t *);
#ifdef __cplusplus
}
#endif
#endif