diff --git a/home/nipa/nipa_out/894766/ynl/new-code/ovpn-user.c b/home/nipa/nipa_out/894766/ynl/new-code/ovpn-user.c new file mode 100644 index 000000000000..1dc48022632b --- /dev/null +++ b/home/nipa/nipa_out/894766/ynl/new-code/ovpn-user.c @@ -0,0 +1,846 @@ +// SPDX-License-Identifier: ((GPL-2.0 WITH Linux-syscall-note) OR BSD-3-Clause) +/* Do not edit directly, auto-generated from: */ +/* Documentation/netlink/specs/ovpn.yaml */ +/* YNL-GEN user source */ + +#include +#include +#include "ovpn-user.h" +#include "ynl.h" +#include + +#include + +/* Enums */ +static const char * const ovpn_op_strmap[] = { + [OVPN_CMD_DEV_NEW] = "dev-new", + [OVPN_CMD_DEV_DEL] = "dev-del", + [OVPN_CMD_PEER_NEW] = "peer-new", + [OVPN_CMD_PEER_SET] = "peer-set", + [OVPN_CMD_PEER_GET] = "peer-get", + [OVPN_CMD_PEER_DEL] = "peer-del", + [OVPN_CMD_PEER_DEL_NTF] = "peer-del-ntf", + [OVPN_CMD_KEY_NEW] = "key-new", + [OVPN_CMD_KEY_SWAP] = "key-swap", + [OVPN_CMD_KEY_SWAP_NTF] = "key-swap-ntf", + [OVPN_CMD_KEY_DEL] = "key-del", +}; + +const char *ovpn_op_str(int op) +{ + if (op < 0 || op >= (int)YNL_ARRAY_SIZE(ovpn_op_strmap)) + return NULL; + return ovpn_op_strmap[op]; +} + +static const char * const ovpn_cipher_alg_strmap[] = { + [0] = "none", + [1] = "aes-gcm", + [2] = "chacha20-poly1305", +}; + +const char *ovpn_cipher_alg_str(enum ovpn_cipher_alg value) +{ + if (value < 0 || value >= (int)YNL_ARRAY_SIZE(ovpn_cipher_alg_strmap)) + return NULL; + return ovpn_cipher_alg_strmap[value]; +} + +static const char * const ovpn_del_peer_reason_strmap[] = { + [0] = "teardown", + [1] = "userspace", + [2] = "expired", + [3] = "transport-error", + [4] = "transport-disconnect", +}; + +const char *ovpn_del_peer_reason_str(enum ovpn_del_peer_reason value) +{ + if (value < 0 || value >= (int)YNL_ARRAY_SIZE(ovpn_del_peer_reason_strmap)) + return NULL; + return ovpn_del_peer_reason_strmap[value]; +} + +static const char * const ovpn_key_slot_strmap[] = { + [0] = "primary", + [1] = "secondary", +}; + +const char *ovpn_key_slot_str(enum ovpn_key_slot value) +{ + if (value < 0 || value >= (int)YNL_ARRAY_SIZE(ovpn_key_slot_strmap)) + return NULL; + return ovpn_key_slot_strmap[value]; +} + +static const char * const ovpn_mode_strmap[] = { + [0] = "p2p", + [1] = "mp", +}; + +const char *ovpn_mode_str(enum ovpn_mode value) +{ + if (value < 0 || value >= (int)YNL_ARRAY_SIZE(ovpn_mode_strmap)) + return NULL; + return ovpn_mode_strmap[value]; +} + +/* Policies */ +const struct ynl_policy_attr ovpn_peer_policy[OVPN_A_PEER_MAX + 1] = { + [OVPN_A_PEER_ID] = { .name = "id", .type = YNL_PT_U32, }, + [OVPN_A_PEER_REMOTE_IPV4] = { .name = "remote-ipv4", .type = YNL_PT_U32, }, + [OVPN_A_PEER_REMOTE_IPV6] = { .name = "remote-ipv6", .type = YNL_PT_BINARY,}, + [OVPN_A_PEER_REMOTE_IPV6_SCOPE_ID] = { .name = "remote-ipv6-scope-id", .type = YNL_PT_U32, }, + [OVPN_A_PEER_REMOTE_PORT] = { .name = "remote-port", .type = YNL_PT_U16, }, + [OVPN_A_PEER_SOCKET] = { .name = "socket", .type = YNL_PT_U32, }, + [OVPN_A_PEER_VPN_IPV4] = { .name = "vpn-ipv4", .type = YNL_PT_U32, }, + [OVPN_A_PEER_VPN_IPV6] = { .name = "vpn-ipv6", .type = YNL_PT_BINARY,}, + [OVPN_A_PEER_LOCAL_IPV4] = { .name = "local-ipv4", .type = YNL_PT_U32, }, + [OVPN_A_PEER_LOCAL_IPV6] = { .name = "local-ipv6", .type = YNL_PT_BINARY,}, + [OVPN_A_PEER_LOCAL_PORT] = { .name = "local-port", .type = YNL_PT_U16, }, + [OVPN_A_PEER_KEEPALIVE_INTERVAL] = { .name = "keepalive-interval", .type = YNL_PT_U32, }, + [OVPN_A_PEER_KEEPALIVE_TIMEOUT] = { .name = "keepalive-timeout", .type = YNL_PT_U32, }, + [OVPN_A_PEER_DEL_REASON] = { .name = "del-reason", .type = YNL_PT_U32, }, + [OVPN_A_PEER_VPN_RX_BYTES] = { .name = "vpn-rx-bytes", .type = YNL_PT_UINT, }, + [OVPN_A_PEER_VPN_TX_BYTES] = { .name = "vpn-tx-bytes", .type = YNL_PT_UINT, }, + [OVPN_A_PEER_VPN_RX_PACKETS] = { .name = "vpn-rx-packets", .type = YNL_PT_UINT, }, + [OVPN_A_PEER_VPN_TX_PACKETS] = { .name = "vpn-tx-packets", .type = YNL_PT_UINT, }, + [OVPN_A_PEER_LINK_RX_BYTES] = { .name = "link-rx-bytes", .type = YNL_PT_UINT, }, + [OVPN_A_PEER_LINK_TX_BYTES] = { .name = "link-tx-bytes", .type = YNL_PT_UINT, }, + [OVPN_A_PEER_LINK_RX_PACKETS] = { .name = "link-rx-packets", .type = YNL_PT_U32, }, + [OVPN_A_PEER_LINK_TX_PACKETS] = { .name = "link-tx-packets", .type = YNL_PT_U32, }, +}; + +const struct ynl_policy_nest ovpn_peer_nest = { + .max_attr = OVPN_A_PEER_MAX, + .table = ovpn_peer_policy, +}; + +const struct ynl_policy_attr ovpn_keydir_policy[OVPN_A_KEYDIR_MAX + 1] = { + [OVPN_A_KEYDIR_CIPHER_KEY] = { .name = "cipher-key", .type = YNL_PT_BINARY,}, + [OVPN_A_KEYDIR_NONCE_TAIL] = { .name = "nonce-tail", .type = YNL_PT_BINARY,}, +}; + +const struct ynl_policy_nest ovpn_keydir_nest = { + .max_attr = OVPN_A_KEYDIR_MAX, + .table = ovpn_keydir_policy, +}; + +const struct ynl_policy_attr ovpn_keyconf_policy[OVPN_A_KEYCONF_MAX + 1] = { + [OVPN_A_KEYCONF_PEER_ID] = { .name = "peer-id", .type = YNL_PT_U32, }, + [OVPN_A_KEYCONF_SLOT] = { .name = "slot", .type = YNL_PT_U32, }, + [OVPN_A_KEYCONF_KEY_ID] = { .name = "key-id", .type = YNL_PT_U32, }, + [OVPN_A_KEYCONF_CIPHER_ALG] = { .name = "cipher-alg", .type = YNL_PT_U32, }, + [OVPN_A_KEYCONF_ENCRYPT_DIR] = { .name = "encrypt-dir", .type = YNL_PT_NEST, .nest = &ovpn_keydir_nest, }, + [OVPN_A_KEYCONF_DECRYPT_DIR] = { .name = "decrypt-dir", .type = YNL_PT_NEST, .nest = &ovpn_keydir_nest, }, +}; + +const struct ynl_policy_nest ovpn_keyconf_nest = { + .max_attr = OVPN_A_KEYCONF_MAX, + .table = ovpn_keyconf_policy, +}; + +const struct ynl_policy_attr ovpn_policy[OVPN_A_MAX + 1] = { + [OVPN_A_IFINDEX] = { .name = "ifindex", .type = YNL_PT_U32, }, + [OVPN_A_IFNAME] = { .name = "ifname", .type = YNL_PT_NUL_STR, }, + [OVPN_A_MODE] = { .name = "mode", .type = YNL_PT_U32, }, + [OVPN_A_PEER] = { .name = "peer", .type = YNL_PT_NEST, .nest = &ovpn_peer_nest, }, + [OVPN_A_KEYCONF] = { .name = "keyconf", .type = YNL_PT_NEST, .nest = &ovpn_keyconf_nest, }, +}; + +const struct ynl_policy_nest ovpn_nest = { + .max_attr = OVPN_A_MAX, + .table = ovpn_policy, +}; + +/* Common nested types */ +void ovpn_peer_free(struct ovpn_peer *obj) +{ + free(obj->remote_ipv6); + free(obj->vpn_ipv6); + free(obj->local_ipv6); +} + +int ovpn_peer_put(struct nlmsghdr *nlh, unsigned int attr_type, + struct ovpn_peer *obj) +{ + struct nlattr *nest; + + nest = ynl_attr_nest_start(nlh, attr_type); + if (obj->_present.id) + ynl_attr_put_u32(nlh, OVPN_A_PEER_ID, obj->id); + if (obj->_present.remote_ipv4) + ynl_attr_put_u32(nlh, OVPN_A_PEER_REMOTE_IPV4, obj->remote_ipv4); + if (obj->_present.remote_ipv6_len) + ynl_attr_put(nlh, OVPN_A_PEER_REMOTE_IPV6, obj->remote_ipv6, obj->_present.remote_ipv6_len); + if (obj->_present.remote_ipv6_scope_id) + ynl_attr_put_u32(nlh, OVPN_A_PEER_REMOTE_IPV6_SCOPE_ID, obj->remote_ipv6_scope_id); + if (obj->_present.remote_port) + ynl_attr_put_u16(nlh, OVPN_A_PEER_REMOTE_PORT, obj->remote_port); + if (obj->_present.socket) + ynl_attr_put_u32(nlh, OVPN_A_PEER_SOCKET, obj->socket); + if (obj->_present.vpn_ipv4) + ynl_attr_put_u32(nlh, OVPN_A_PEER_VPN_IPV4, obj->vpn_ipv4); + if (obj->_present.vpn_ipv6_len) + ynl_attr_put(nlh, OVPN_A_PEER_VPN_IPV6, obj->vpn_ipv6, obj->_present.vpn_ipv6_len); + if (obj->_present.local_ipv4) + ynl_attr_put_u32(nlh, OVPN_A_PEER_LOCAL_IPV4, obj->local_ipv4); + if (obj->_present.local_ipv6_len) + ynl_attr_put(nlh, OVPN_A_PEER_LOCAL_IPV6, obj->local_ipv6, obj->_present.local_ipv6_len); + if (obj->_present.local_port) + ynl_attr_put_u16(nlh, OVPN_A_PEER_LOCAL_PORT, obj->local_port); + if (obj->_present.keepalive_interval) + ynl_attr_put_u32(nlh, OVPN_A_PEER_KEEPALIVE_INTERVAL, obj->keepalive_interval); + if (obj->_present.keepalive_timeout) + ynl_attr_put_u32(nlh, OVPN_A_PEER_KEEPALIVE_TIMEOUT, obj->keepalive_timeout); + if (obj->_present.del_reason) + ynl_attr_put_u32(nlh, OVPN_A_PEER_DEL_REASON, obj->del_reason); + if (obj->_present.vpn_rx_bytes) + ynl_attr_put_uint(nlh, OVPN_A_PEER_VPN_RX_BYTES, obj->vpn_rx_bytes); + if (obj->_present.vpn_tx_bytes) + ynl_attr_put_uint(nlh, OVPN_A_PEER_VPN_TX_BYTES, obj->vpn_tx_bytes); + if (obj->_present.vpn_rx_packets) + ynl_attr_put_uint(nlh, OVPN_A_PEER_VPN_RX_PACKETS, obj->vpn_rx_packets); + if (obj->_present.vpn_tx_packets) + ynl_attr_put_uint(nlh, OVPN_A_PEER_VPN_TX_PACKETS, obj->vpn_tx_packets); + if (obj->_present.link_rx_bytes) + ynl_attr_put_uint(nlh, OVPN_A_PEER_LINK_RX_BYTES, obj->link_rx_bytes); + if (obj->_present.link_tx_bytes) + ynl_attr_put_uint(nlh, OVPN_A_PEER_LINK_TX_BYTES, obj->link_tx_bytes); + if (obj->_present.link_rx_packets) + ynl_attr_put_u32(nlh, OVPN_A_PEER_LINK_RX_PACKETS, obj->link_rx_packets); + if (obj->_present.link_tx_packets) + ynl_attr_put_u32(nlh, OVPN_A_PEER_LINK_TX_PACKETS, obj->link_tx_packets); + ynl_attr_nest_end(nlh, nest); + + return 0; +} + +int ovpn_peer_parse(struct ynl_parse_arg *yarg, const struct nlattr *nested) +{ + struct ovpn_peer *dst = yarg->data; + const struct nlattr *attr; + + ynl_attr_for_each_nested(attr, nested) { + unsigned int type = ynl_attr_type(attr); + + if (type == OVPN_A_PEER_ID) { + if (ynl_attr_validate(yarg, attr)) + return YNL_PARSE_CB_ERROR; + dst->_present.id = 1; + dst->id = ynl_attr_get_u32(attr); + } else if (type == OVPN_A_PEER_REMOTE_IPV4) { + if (ynl_attr_validate(yarg, attr)) + return YNL_PARSE_CB_ERROR; + dst->_present.remote_ipv4 = 1; + dst->remote_ipv4 = ynl_attr_get_u32(attr); + } else if (type == OVPN_A_PEER_REMOTE_IPV6) { + unsigned int len; + + if (ynl_attr_validate(yarg, attr)) + return YNL_PARSE_CB_ERROR; + + len = ynl_attr_data_len(attr); + dst->_present.remote_ipv6_len = len; + dst->remote_ipv6 = malloc(len); + memcpy(dst->remote_ipv6, ynl_attr_data(attr), len); + } else if (type == OVPN_A_PEER_REMOTE_IPV6_SCOPE_ID) { + if (ynl_attr_validate(yarg, attr)) + return YNL_PARSE_CB_ERROR; + dst->_present.remote_ipv6_scope_id = 1; + dst->remote_ipv6_scope_id = ynl_attr_get_u32(attr); + } else if (type == OVPN_A_PEER_REMOTE_PORT) { + if (ynl_attr_validate(yarg, attr)) + return YNL_PARSE_CB_ERROR; + dst->_present.remote_port = 1; + dst->remote_port = ynl_attr_get_u16(attr); + } else if (type == OVPN_A_PEER_SOCKET) { + if (ynl_attr_validate(yarg, attr)) + return YNL_PARSE_CB_ERROR; + dst->_present.socket = 1; + dst->socket = ynl_attr_get_u32(attr); + } else if (type == OVPN_A_PEER_VPN_IPV4) { + if (ynl_attr_validate(yarg, attr)) + return YNL_PARSE_CB_ERROR; + dst->_present.vpn_ipv4 = 1; + dst->vpn_ipv4 = ynl_attr_get_u32(attr); + } else if (type == OVPN_A_PEER_VPN_IPV6) { + unsigned int len; + + if (ynl_attr_validate(yarg, attr)) + return YNL_PARSE_CB_ERROR; + + len = ynl_attr_data_len(attr); + dst->_present.vpn_ipv6_len = len; + dst->vpn_ipv6 = malloc(len); + memcpy(dst->vpn_ipv6, ynl_attr_data(attr), len); + } else if (type == OVPN_A_PEER_LOCAL_IPV4) { + if (ynl_attr_validate(yarg, attr)) + return YNL_PARSE_CB_ERROR; + dst->_present.local_ipv4 = 1; + dst->local_ipv4 = ynl_attr_get_u32(attr); + } else if (type == OVPN_A_PEER_LOCAL_IPV6) { + unsigned int len; + + if (ynl_attr_validate(yarg, attr)) + return YNL_PARSE_CB_ERROR; + + len = ynl_attr_data_len(attr); + dst->_present.local_ipv6_len = len; + dst->local_ipv6 = malloc(len); + memcpy(dst->local_ipv6, ynl_attr_data(attr), len); + } else if (type == OVPN_A_PEER_LOCAL_PORT) { + if (ynl_attr_validate(yarg, attr)) + return YNL_PARSE_CB_ERROR; + dst->_present.local_port = 1; + dst->local_port = ynl_attr_get_u16(attr); + } else if (type == OVPN_A_PEER_KEEPALIVE_INTERVAL) { + if (ynl_attr_validate(yarg, attr)) + return YNL_PARSE_CB_ERROR; + dst->_present.keepalive_interval = 1; + dst->keepalive_interval = ynl_attr_get_u32(attr); + } else if (type == OVPN_A_PEER_KEEPALIVE_TIMEOUT) { + if (ynl_attr_validate(yarg, attr)) + return YNL_PARSE_CB_ERROR; + dst->_present.keepalive_timeout = 1; + dst->keepalive_timeout = ynl_attr_get_u32(attr); + } else if (type == OVPN_A_PEER_DEL_REASON) { + if (ynl_attr_validate(yarg, attr)) + return YNL_PARSE_CB_ERROR; + dst->_present.del_reason = 1; + dst->del_reason = ynl_attr_get_u32(attr); + } else if (type == OVPN_A_PEER_VPN_RX_BYTES) { + if (ynl_attr_validate(yarg, attr)) + return YNL_PARSE_CB_ERROR; + dst->_present.vpn_rx_bytes = 1; + dst->vpn_rx_bytes = ynl_attr_get_uint(attr); + } else if (type == OVPN_A_PEER_VPN_TX_BYTES) { + if (ynl_attr_validate(yarg, attr)) + return YNL_PARSE_CB_ERROR; + dst->_present.vpn_tx_bytes = 1; + dst->vpn_tx_bytes = ynl_attr_get_uint(attr); + } else if (type == OVPN_A_PEER_VPN_RX_PACKETS) { + if (ynl_attr_validate(yarg, attr)) + return YNL_PARSE_CB_ERROR; + dst->_present.vpn_rx_packets = 1; + dst->vpn_rx_packets = ynl_attr_get_uint(attr); + } else if (type == OVPN_A_PEER_VPN_TX_PACKETS) { + if (ynl_attr_validate(yarg, attr)) + return YNL_PARSE_CB_ERROR; + dst->_present.vpn_tx_packets = 1; + dst->vpn_tx_packets = ynl_attr_get_uint(attr); + } else if (type == OVPN_A_PEER_LINK_RX_BYTES) { + if (ynl_attr_validate(yarg, attr)) + return YNL_PARSE_CB_ERROR; + dst->_present.link_rx_bytes = 1; + dst->link_rx_bytes = ynl_attr_get_uint(attr); + } else if (type == OVPN_A_PEER_LINK_TX_BYTES) { + if (ynl_attr_validate(yarg, attr)) + return YNL_PARSE_CB_ERROR; + dst->_present.link_tx_bytes = 1; + dst->link_tx_bytes = ynl_attr_get_uint(attr); + } else if (type == OVPN_A_PEER_LINK_RX_PACKETS) { + if (ynl_attr_validate(yarg, attr)) + return YNL_PARSE_CB_ERROR; + dst->_present.link_rx_packets = 1; + dst->link_rx_packets = ynl_attr_get_u32(attr); + } else if (type == OVPN_A_PEER_LINK_TX_PACKETS) { + if (ynl_attr_validate(yarg, attr)) + return YNL_PARSE_CB_ERROR; + dst->_present.link_tx_packets = 1; + dst->link_tx_packets = ynl_attr_get_u32(attr); + } + } + + return 0; +} + +void ovpn_keydir_free(struct ovpn_keydir *obj) +{ + free(obj->cipher_key); + free(obj->nonce_tail); +} + +int ovpn_keydir_put(struct nlmsghdr *nlh, unsigned int attr_type, + struct ovpn_keydir *obj) +{ + struct nlattr *nest; + + nest = ynl_attr_nest_start(nlh, attr_type); + if (obj->_present.cipher_key_len) + ynl_attr_put(nlh, OVPN_A_KEYDIR_CIPHER_KEY, obj->cipher_key, obj->_present.cipher_key_len); + if (obj->_present.nonce_tail_len) + ynl_attr_put(nlh, OVPN_A_KEYDIR_NONCE_TAIL, obj->nonce_tail, obj->_present.nonce_tail_len); + ynl_attr_nest_end(nlh, nest); + + return 0; +} + +void ovpn_keyconf_free(struct ovpn_keyconf *obj) +{ + ovpn_keydir_free(&obj->encrypt_dir); + ovpn_keydir_free(&obj->decrypt_dir); +} + +int ovpn_keyconf_put(struct nlmsghdr *nlh, unsigned int attr_type, + struct ovpn_keyconf *obj) +{ + struct nlattr *nest; + + nest = ynl_attr_nest_start(nlh, attr_type); + if (obj->_present.peer_id) + ynl_attr_put_u32(nlh, OVPN_A_KEYCONF_PEER_ID, obj->peer_id); + if (obj->_present.slot) + ynl_attr_put_u32(nlh, OVPN_A_KEYCONF_SLOT, obj->slot); + if (obj->_present.key_id) + ynl_attr_put_u32(nlh, OVPN_A_KEYCONF_KEY_ID, obj->key_id); + if (obj->_present.cipher_alg) + ynl_attr_put_u32(nlh, OVPN_A_KEYCONF_CIPHER_ALG, obj->cipher_alg); + if (obj->_present.encrypt_dir) + ovpn_keydir_put(nlh, OVPN_A_KEYCONF_ENCRYPT_DIR, &obj->encrypt_dir); + if (obj->_present.decrypt_dir) + ovpn_keydir_put(nlh, OVPN_A_KEYCONF_DECRYPT_DIR, &obj->decrypt_dir); + ynl_attr_nest_end(nlh, nest); + + return 0; +} + +/* ============== OVPN_CMD_DEV_NEW ============== */ +/* OVPN_CMD_DEV_NEW - do */ +void ovpn_dev_new_req_free(struct ovpn_dev_new_req *req) +{ + free(req->ifname); + free(req); +} + +void ovpn_dev_new_rsp_free(struct ovpn_dev_new_rsp *rsp) +{ + free(rsp->ifname); + free(rsp); +} + +int ovpn_dev_new_rsp_parse(const struct nlmsghdr *nlh, + struct ynl_parse_arg *yarg) +{ + struct ovpn_dev_new_rsp *dst; + const struct nlattr *attr; + + dst = yarg->data; + + ynl_attr_for_each(attr, nlh, yarg->ys->family->hdr_len) { + unsigned int type = ynl_attr_type(attr); + + if (type == OVPN_A_IFNAME) { + unsigned int len; + + if (ynl_attr_validate(yarg, attr)) + return YNL_PARSE_CB_ERROR; + + len = strnlen(ynl_attr_get_str(attr), ynl_attr_data_len(attr)); + dst->_present.ifname_len = len; + dst->ifname = malloc(len + 1); + memcpy(dst->ifname, ynl_attr_get_str(attr), len); + dst->ifname[len] = 0; + } else if (type == OVPN_A_IFINDEX) { + if (ynl_attr_validate(yarg, attr)) + return YNL_PARSE_CB_ERROR; + dst->_present.ifindex = 1; + dst->ifindex = ynl_attr_get_u32(attr); + } + } + + return YNL_PARSE_CB_OK; +} + +struct ovpn_dev_new_rsp * +ovpn_dev_new(struct ynl_sock *ys, struct ovpn_dev_new_req *req) +{ + struct ynl_req_state yrs = { .yarg = { .ys = ys, }, }; + struct ovpn_dev_new_rsp *rsp; + struct nlmsghdr *nlh; + int err; + + nlh = ynl_gemsg_start_req(ys, ys->family_id, OVPN_CMD_DEV_NEW, 1); + ys->req_policy = &ovpn_nest; + yrs.yarg.rsp_policy = &ovpn_nest; + + if (req->_present.ifname_len) + ynl_attr_put_str(nlh, OVPN_A_IFNAME, req->ifname); + if (req->_present.mode) + ynl_attr_put_u32(nlh, OVPN_A_MODE, req->mode); + + rsp = calloc(1, sizeof(*rsp)); + yrs.yarg.data = rsp; + yrs.cb = ovpn_dev_new_rsp_parse; + yrs.rsp_cmd = OVPN_CMD_DEV_NEW; + + err = ynl_exec(ys, nlh, &yrs); + if (err < 0) + goto err_free; + + return rsp; + +err_free: + ovpn_dev_new_rsp_free(rsp); + return NULL; +} + +/* ============== OVPN_CMD_DEV_DEL ============== */ +/* OVPN_CMD_DEV_DEL - do */ +void ovpn_dev_del_req_free(struct ovpn_dev_del_req *req) +{ + free(req); +} + +int ovpn_dev_del(struct ynl_sock *ys, struct ovpn_dev_del_req *req) +{ + struct ynl_req_state yrs = { .yarg = { .ys = ys, }, }; + struct nlmsghdr *nlh; + int err; + + nlh = ynl_gemsg_start_req(ys, ys->family_id, OVPN_CMD_DEV_DEL, 1); + ys->req_policy = &ovpn_nest; + + if (req->_present.ifindex) + ynl_attr_put_u32(nlh, OVPN_A_IFINDEX, req->ifindex); + + err = ynl_exec(ys, nlh, &yrs); + if (err < 0) + return -1; + + return 0; +} + +/* ============== OVPN_CMD_PEER_NEW ============== */ +/* OVPN_CMD_PEER_NEW - do */ +void ovpn_peer_new_req_free(struct ovpn_peer_new_req *req) +{ + ovpn_peer_free(&req->peer); + free(req); +} + +int ovpn_peer_new(struct ynl_sock *ys, struct ovpn_peer_new_req *req) +{ + struct ynl_req_state yrs = { .yarg = { .ys = ys, }, }; + struct nlmsghdr *nlh; + int err; + + nlh = ynl_gemsg_start_req(ys, ys->family_id, OVPN_CMD_PEER_NEW, 1); + ys->req_policy = &ovpn_nest; + + if (req->_present.ifindex) + ynl_attr_put_u32(nlh, OVPN_A_IFINDEX, req->ifindex); + if (req->_present.peer) + ovpn_peer_put(nlh, OVPN_A_PEER, &req->peer); + + err = ynl_exec(ys, nlh, &yrs); + if (err < 0) + return -1; + + return 0; +} + +/* ============== OVPN_CMD_PEER_SET ============== */ +/* OVPN_CMD_PEER_SET - do */ +void ovpn_peer_set_req_free(struct ovpn_peer_set_req *req) +{ + ovpn_peer_free(&req->peer); + free(req); +} + +int ovpn_peer_set(struct ynl_sock *ys, struct ovpn_peer_set_req *req) +{ + struct ynl_req_state yrs = { .yarg = { .ys = ys, }, }; + struct nlmsghdr *nlh; + int err; + + nlh = ynl_gemsg_start_req(ys, ys->family_id, OVPN_CMD_PEER_SET, 1); + ys->req_policy = &ovpn_nest; + + if (req->_present.ifindex) + ynl_attr_put_u32(nlh, OVPN_A_IFINDEX, req->ifindex); + if (req->_present.peer) + ovpn_peer_put(nlh, OVPN_A_PEER, &req->peer); + + err = ynl_exec(ys, nlh, &yrs); + if (err < 0) + return -1; + + return 0; +} + +/* ============== OVPN_CMD_PEER_GET ============== */ +/* OVPN_CMD_PEER_GET - do */ +void ovpn_peer_get_req_free(struct ovpn_peer_get_req *req) +{ + ovpn_peer_free(&req->peer); + free(req); +} + +void ovpn_peer_get_rsp_free(struct ovpn_peer_get_rsp *rsp) +{ + ovpn_peer_free(&rsp->peer); + free(rsp); +} + +int ovpn_peer_get_rsp_parse(const struct nlmsghdr *nlh, + struct ynl_parse_arg *yarg) +{ + struct ovpn_peer_get_rsp *dst; + const struct nlattr *attr; + struct ynl_parse_arg parg; + + dst = yarg->data; + parg.ys = yarg->ys; + + ynl_attr_for_each(attr, nlh, yarg->ys->family->hdr_len) { + unsigned int type = ynl_attr_type(attr); + + if (type == OVPN_A_PEER) { + if (ynl_attr_validate(yarg, attr)) + return YNL_PARSE_CB_ERROR; + dst->_present.peer = 1; + + parg.rsp_policy = &ovpn_peer_nest; + parg.data = &dst->peer; + if (ovpn_peer_parse(&parg, attr)) + return YNL_PARSE_CB_ERROR; + } + } + + return YNL_PARSE_CB_OK; +} + +struct ovpn_peer_get_rsp * +ovpn_peer_get(struct ynl_sock *ys, struct ovpn_peer_get_req *req) +{ + struct ynl_req_state yrs = { .yarg = { .ys = ys, }, }; + struct ovpn_peer_get_rsp *rsp; + struct nlmsghdr *nlh; + int err; + + nlh = ynl_gemsg_start_req(ys, ys->family_id, OVPN_CMD_PEER_GET, 1); + ys->req_policy = &ovpn_nest; + yrs.yarg.rsp_policy = &ovpn_nest; + + if (req->_present.ifindex) + ynl_attr_put_u32(nlh, OVPN_A_IFINDEX, req->ifindex); + if (req->_present.peer) + ovpn_peer_put(nlh, OVPN_A_PEER, &req->peer); + + rsp = calloc(1, sizeof(*rsp)); + yrs.yarg.data = rsp; + yrs.cb = ovpn_peer_get_rsp_parse; + yrs.rsp_cmd = OVPN_CMD_PEER_GET; + + err = ynl_exec(ys, nlh, &yrs); + if (err < 0) + goto err_free; + + return rsp; + +err_free: + ovpn_peer_get_rsp_free(rsp); + return NULL; +} + +/* OVPN_CMD_PEER_GET - dump */ +void ovpn_peer_get_req_dump_free(struct ovpn_peer_get_req_dump *req) +{ + free(req); +} + +void ovpn_peer_get_list_free(struct ovpn_peer_get_list *rsp) +{ + struct ovpn_peer_get_list *next = rsp; + + while ((void *)next != YNL_LIST_END) { + rsp = next; + next = rsp->next; + + ovpn_peer_free(&rsp->obj.peer); + free(rsp); + } +} + +struct ovpn_peer_get_list * +ovpn_peer_get_dump(struct ynl_sock *ys, struct ovpn_peer_get_req_dump *req) +{ + struct ynl_dump_state yds = {}; + struct nlmsghdr *nlh; + int err; + + yds.yarg.ys = ys; + yds.yarg.rsp_policy = &ovpn_nest; + yds.yarg.data = NULL; + yds.alloc_sz = sizeof(struct ovpn_peer_get_list); + yds.cb = ovpn_peer_get_rsp_parse; + yds.rsp_cmd = OVPN_CMD_PEER_GET; + + nlh = ynl_gemsg_start_dump(ys, ys->family_id, OVPN_CMD_PEER_GET, 1); + ys->req_policy = &ovpn_nest; + + if (req->_present.ifindex) + ynl_attr_put_u32(nlh, OVPN_A_IFINDEX, req->ifindex); + + err = ynl_exec_dump(ys, nlh, &yds); + if (err < 0) + goto free_list; + + return yds.first; + +free_list: + ovpn_peer_get_list_free(yds.first); + return NULL; +} + +/* OVPN_CMD_PEER_GET - notify */ +void ovpn_peer_get_ntf_free(struct ovpn_peer_get_ntf *rsp) +{ + ovpn_peer_free(&rsp->obj.peer); + free(rsp); +} + +/* ============== OVPN_CMD_PEER_DEL ============== */ +/* OVPN_CMD_PEER_DEL - do */ +void ovpn_peer_del_req_free(struct ovpn_peer_del_req *req) +{ + ovpn_peer_free(&req->peer); + free(req); +} + +int ovpn_peer_del(struct ynl_sock *ys, struct ovpn_peer_del_req *req) +{ + struct ynl_req_state yrs = { .yarg = { .ys = ys, }, }; + struct nlmsghdr *nlh; + int err; + + nlh = ynl_gemsg_start_req(ys, ys->family_id, OVPN_CMD_PEER_DEL, 1); + ys->req_policy = &ovpn_nest; + + if (req->_present.ifindex) + ynl_attr_put_u32(nlh, OVPN_A_IFINDEX, req->ifindex); + if (req->_present.peer) + ovpn_peer_put(nlh, OVPN_A_PEER, &req->peer); + + err = ynl_exec(ys, nlh, &yrs); + if (err < 0) + return -1; + + return 0; +} + +/* ============== OVPN_CMD_KEY_NEW ============== */ +/* OVPN_CMD_KEY_NEW - do */ +void ovpn_key_new_req_free(struct ovpn_key_new_req *req) +{ + ovpn_keyconf_free(&req->keyconf); + free(req); +} + +int ovpn_key_new(struct ynl_sock *ys, struct ovpn_key_new_req *req) +{ + struct ynl_req_state yrs = { .yarg = { .ys = ys, }, }; + struct nlmsghdr *nlh; + int err; + + nlh = ynl_gemsg_start_req(ys, ys->family_id, OVPN_CMD_KEY_NEW, 1); + ys->req_policy = &ovpn_nest; + + if (req->_present.ifindex) + ynl_attr_put_u32(nlh, OVPN_A_IFINDEX, req->ifindex); + if (req->_present.keyconf) + ovpn_keyconf_put(nlh, OVPN_A_KEYCONF, &req->keyconf); + + err = ynl_exec(ys, nlh, &yrs); + if (err < 0) + return -1; + + return 0; +} + +/* OVPN_CMD_KEY_NEW - notify */ +void ovpn_key_new_ntf_free(struct ovpn_key_new_ntf *rsp) +{ + free(rsp); +} + +/* ============== OVPN_CMD_KEY_SWAP ============== */ +/* OVPN_CMD_KEY_SWAP - do */ +void ovpn_key_swap_req_free(struct ovpn_key_swap_req *req) +{ + ovpn_keyconf_free(&req->keyconf); + free(req); +} + +int ovpn_key_swap(struct ynl_sock *ys, struct ovpn_key_swap_req *req) +{ + struct ynl_req_state yrs = { .yarg = { .ys = ys, }, }; + struct nlmsghdr *nlh; + int err; + + nlh = ynl_gemsg_start_req(ys, ys->family_id, OVPN_CMD_KEY_SWAP, 1); + ys->req_policy = &ovpn_nest; + + if (req->_present.ifindex) + ynl_attr_put_u32(nlh, OVPN_A_IFINDEX, req->ifindex); + if (req->_present.keyconf) + ovpn_keyconf_put(nlh, OVPN_A_KEYCONF, &req->keyconf); + + err = ynl_exec(ys, nlh, &yrs); + if (err < 0) + return -1; + + return 0; +} + +/* ============== OVPN_CMD_KEY_DEL ============== */ +/* OVPN_CMD_KEY_DEL - do */ +void ovpn_key_del_req_free(struct ovpn_key_del_req *req) +{ + ovpn_keyconf_free(&req->keyconf); + free(req); +} + +int ovpn_key_del(struct ynl_sock *ys, struct ovpn_key_del_req *req) +{ + struct ynl_req_state yrs = { .yarg = { .ys = ys, }, }; + struct nlmsghdr *nlh; + int err; + + nlh = ynl_gemsg_start_req(ys, ys->family_id, OVPN_CMD_KEY_DEL, 1); + ys->req_policy = &ovpn_nest; + + if (req->_present.ifindex) + ynl_attr_put_u32(nlh, OVPN_A_IFINDEX, req->ifindex); + if (req->_present.keyconf) + ovpn_keyconf_put(nlh, OVPN_A_KEYCONF, &req->keyconf); + + err = ynl_exec(ys, nlh, &yrs); + if (err < 0) + return -1; + + return 0; +} + +static const struct ynl_ntf_info ovpn_ntf_info[] = { + [OVPN_CMD_PEER_DEL_NTF] = { + .alloc_sz = sizeof(struct ovpn_peer_get_ntf), + .cb = ovpn_peer_get_rsp_parse, + .policy = &ovpn_nest, + .free = (void *)ovpn_peer_get_ntf_free, + }, + [OVPN_CMD_KEY_SWAP_NTF] = { + .alloc_sz = sizeof(struct ovpn_key_new_ntf), + .cb = ovpn_key_new_rsp_parse, + .policy = &ovpn_nest, + .free = (void *)ovpn_key_new_ntf_free, + }, +}; + +const struct ynl_family ynl_ovpn_family = { + .name = "ovpn", + .hdr_len = sizeof(struct genlmsghdr), + .ntf_info = ovpn_ntf_info, + .ntf_info_size = YNL_ARRAY_SIZE(ovpn_ntf_info), +}; diff --git a/home/nipa/nipa_out/894766/ynl/new-code/ovpn-user.h b/home/nipa/nipa_out/894766/ynl/new-code/ovpn-user.h new file mode 100644 index 000000000000..ef8e68ebe25c --- /dev/null +++ b/home/nipa/nipa_out/894766/ynl/new-code/ovpn-user.h @@ -0,0 +1,1418 @@ +/* SPDX-License-Identifier: ((GPL-2.0 WITH Linux-syscall-note) OR BSD-3-Clause) */ +/* Do not edit directly, auto-generated from: */ +/* Documentation/netlink/specs/ovpn.yaml */ +/* YNL-GEN user header */ + +#ifndef _LINUX_OVPN_GEN_H +#define _LINUX_OVPN_GEN_H + +#include +#include +#include +#include + +struct ynl_sock; + +extern const struct ynl_family ynl_ovpn_family; + +/* Enums */ +const char *ovpn_op_str(int op); +const char *ovpn_cipher_alg_str(enum ovpn_cipher_alg value); +const char *ovpn_del_peer_reason_str(enum ovpn_del_peer_reason value); +const char *ovpn_key_slot_str(enum ovpn_key_slot value); +const char *ovpn_mode_str(enum ovpn_mode value); + +/* Common nested types */ +struct ovpn_peer { + struct { + __u32 id:1; + __u32 remote_ipv4:1; + __u32 remote_ipv6_len; + __u32 remote_ipv6_scope_id:1; + __u32 remote_port:1; + __u32 socket:1; + __u32 vpn_ipv4:1; + __u32 vpn_ipv6_len; + __u32 local_ipv4:1; + __u32 local_ipv6_len; + __u32 local_port:1; + __u32 keepalive_interval:1; + __u32 keepalive_timeout:1; + __u32 del_reason:1; + __u32 vpn_rx_bytes:1; + __u32 vpn_tx_bytes:1; + __u32 vpn_rx_packets:1; + __u32 vpn_tx_packets:1; + __u32 link_rx_bytes:1; + __u32 link_tx_bytes:1; + __u32 link_rx_packets:1; + __u32 link_tx_packets:1; + } _present; + + __u32 id; + __u32 remote_ipv4 /* big-endian */; + void *remote_ipv6; + __u32 remote_ipv6_scope_id; + __u16 remote_port /* big-endian */; + __u32 socket; + __u32 vpn_ipv4 /* big-endian */; + void *vpn_ipv6; + __u32 local_ipv4 /* big-endian */; + void *local_ipv6; + __u16 local_port /* big-endian */; + __u32 keepalive_interval; + __u32 keepalive_timeout; + enum ovpn_del_peer_reason del_reason; + __u64 vpn_rx_bytes; + __u64 vpn_tx_bytes; + __u64 vpn_rx_packets; + __u64 vpn_tx_packets; + __u64 link_rx_bytes; + __u64 link_tx_bytes; + __u32 link_rx_packets; + __u32 link_tx_packets; +}; + +struct ovpn_keydir { + struct { + __u32 cipher_key_len; + __u32 nonce_tail_len; + } _present; + + void *cipher_key; + void *nonce_tail; +}; + +struct ovpn_keyconf { + struct { + __u32 peer_id:1; + __u32 slot:1; + __u32 key_id:1; + __u32 cipher_alg:1; + __u32 encrypt_dir:1; + __u32 decrypt_dir:1; + } _present; + + __u32 peer_id; + enum ovpn_key_slot slot; + __u32 key_id; + enum ovpn_cipher_alg cipher_alg; + struct ovpn_keydir encrypt_dir; + struct ovpn_keydir decrypt_dir; +}; + +/* ============== OVPN_CMD_DEV_NEW ============== */ +/* OVPN_CMD_DEV_NEW - do */ +struct ovpn_dev_new_req { + struct { + __u32 ifname_len; + __u32 mode:1; + } _present; + + char *ifname; + enum ovpn_mode mode; +}; + +static inline struct ovpn_dev_new_req *ovpn_dev_new_req_alloc(void) +{ + return calloc(1, sizeof(struct ovpn_dev_new_req)); +} +void ovpn_dev_new_req_free(struct ovpn_dev_new_req *req); + +static inline void +ovpn_dev_new_req_set_ifname(struct ovpn_dev_new_req *req, const char *ifname) +{ + free(req->ifname); + req->_present.ifname_len = strlen(ifname); + req->ifname = malloc(req->_present.ifname_len + 1); + memcpy(req->ifname, ifname, req->_present.ifname_len); + req->ifname[req->_present.ifname_len] = 0; +} +static inline void +ovpn_dev_new_req_set_mode(struct ovpn_dev_new_req *req, enum ovpn_mode mode) +{ + req->_present.mode = 1; + req->mode = mode; +} + +struct ovpn_dev_new_rsp { + struct { + __u32 ifname_len; + __u32 ifindex:1; + } _present; + + char *ifname; + __u32 ifindex; +}; + +void ovpn_dev_new_rsp_free(struct ovpn_dev_new_rsp *rsp); + +/* + * Create a new interface of type ovpn + */ +struct ovpn_dev_new_rsp * +ovpn_dev_new(struct ynl_sock *ys, struct ovpn_dev_new_req *req); + +/* ============== OVPN_CMD_DEV_DEL ============== */ +/* OVPN_CMD_DEV_DEL - do */ +struct ovpn_dev_del_req { + struct { + __u32 ifindex:1; + } _present; + + __u32 ifindex; +}; + +static inline struct ovpn_dev_del_req *ovpn_dev_del_req_alloc(void) +{ + return calloc(1, sizeof(struct ovpn_dev_del_req)); +} +void ovpn_dev_del_req_free(struct ovpn_dev_del_req *req); + +static inline void +ovpn_dev_del_req_set_ifindex(struct ovpn_dev_del_req *req, __u32 ifindex) +{ + req->_present.ifindex = 1; + req->ifindex = ifindex; +} + +/* + * Delete existing interface of type ovpn + */ +int ovpn_dev_del(struct ynl_sock *ys, struct ovpn_dev_del_req *req); + +/* ============== OVPN_CMD_PEER_NEW ============== */ +/* OVPN_CMD_PEER_NEW - do */ +struct ovpn_peer_new_req { + struct { + __u32 ifindex:1; + __u32 peer:1; + } _present; + + __u32 ifindex; + struct ovpn_peer peer; +}; + +static inline struct ovpn_peer_new_req *ovpn_peer_new_req_alloc(void) +{ + return calloc(1, sizeof(struct ovpn_peer_new_req)); +} +void ovpn_peer_new_req_free(struct ovpn_peer_new_req *req); + +static inline void +ovpn_peer_new_req_set_ifindex(struct ovpn_peer_new_req *req, __u32 ifindex) +{ + req->_present.ifindex = 1; + req->ifindex = ifindex; +} +static inline void +ovpn_peer_new_req_set_peer_id(struct ovpn_peer_new_req *req, __u32 id) +{ + req->_present.peer = 1; + req->peer._present.id = 1; + req->peer.id = id; +} +static inline void +ovpn_peer_new_req_set_peer_remote_ipv4(struct ovpn_peer_new_req *req, + __u32 remote_ipv4 /* big-endian */) +{ + req->_present.peer = 1; + req->peer._present.remote_ipv4 = 1; + req->peer.remote_ipv4 = remote_ipv4; +} +static inline void +ovpn_peer_new_req_set_peer_remote_ipv6(struct ovpn_peer_new_req *req, + const void *remote_ipv6, size_t len) +{ + req->_present.peer = 1; + free(req->peer.remote_ipv6); + req->peer._present.remote_ipv6_len = len; + req->peer.remote_ipv6 = malloc(req->peer._present.remote_ipv6_len); + memcpy(req->peer.remote_ipv6, remote_ipv6, req->peer._present.remote_ipv6_len); +} +static inline void +ovpn_peer_new_req_set_peer_remote_ipv6_scope_id(struct ovpn_peer_new_req *req, + __u32 remote_ipv6_scope_id) +{ + req->_present.peer = 1; + req->peer._present.remote_ipv6_scope_id = 1; + req->peer.remote_ipv6_scope_id = remote_ipv6_scope_id; +} +static inline void +ovpn_peer_new_req_set_peer_remote_port(struct ovpn_peer_new_req *req, + __u16 remote_port /* big-endian */) +{ + req->_present.peer = 1; + req->peer._present.remote_port = 1; + req->peer.remote_port = remote_port; +} +static inline void +ovpn_peer_new_req_set_peer_socket(struct ovpn_peer_new_req *req, __u32 socket) +{ + req->_present.peer = 1; + req->peer._present.socket = 1; + req->peer.socket = socket; +} +static inline void +ovpn_peer_new_req_set_peer_vpn_ipv4(struct ovpn_peer_new_req *req, + __u32 vpn_ipv4 /* big-endian */) +{ + req->_present.peer = 1; + req->peer._present.vpn_ipv4 = 1; + req->peer.vpn_ipv4 = vpn_ipv4; +} +static inline void +ovpn_peer_new_req_set_peer_vpn_ipv6(struct ovpn_peer_new_req *req, + const void *vpn_ipv6, size_t len) +{ + req->_present.peer = 1; + free(req->peer.vpn_ipv6); + req->peer._present.vpn_ipv6_len = len; + req->peer.vpn_ipv6 = malloc(req->peer._present.vpn_ipv6_len); + memcpy(req->peer.vpn_ipv6, vpn_ipv6, req->peer._present.vpn_ipv6_len); +} +static inline void +ovpn_peer_new_req_set_peer_local_ipv4(struct ovpn_peer_new_req *req, + __u32 local_ipv4 /* big-endian */) +{ + req->_present.peer = 1; + req->peer._present.local_ipv4 = 1; + req->peer.local_ipv4 = local_ipv4; +} +static inline void +ovpn_peer_new_req_set_peer_local_ipv6(struct ovpn_peer_new_req *req, + const void *local_ipv6, size_t len) +{ + req->_present.peer = 1; + free(req->peer.local_ipv6); + req->peer._present.local_ipv6_len = len; + req->peer.local_ipv6 = malloc(req->peer._present.local_ipv6_len); + memcpy(req->peer.local_ipv6, local_ipv6, req->peer._present.local_ipv6_len); +} +static inline void +ovpn_peer_new_req_set_peer_local_port(struct ovpn_peer_new_req *req, + __u16 local_port /* big-endian */) +{ + req->_present.peer = 1; + req->peer._present.local_port = 1; + req->peer.local_port = local_port; +} +static inline void +ovpn_peer_new_req_set_peer_keepalive_interval(struct ovpn_peer_new_req *req, + __u32 keepalive_interval) +{ + req->_present.peer = 1; + req->peer._present.keepalive_interval = 1; + req->peer.keepalive_interval = keepalive_interval; +} +static inline void +ovpn_peer_new_req_set_peer_keepalive_timeout(struct ovpn_peer_new_req *req, + __u32 keepalive_timeout) +{ + req->_present.peer = 1; + req->peer._present.keepalive_timeout = 1; + req->peer.keepalive_timeout = keepalive_timeout; +} +static inline void +ovpn_peer_new_req_set_peer_del_reason(struct ovpn_peer_new_req *req, + enum ovpn_del_peer_reason del_reason) +{ + req->_present.peer = 1; + req->peer._present.del_reason = 1; + req->peer.del_reason = del_reason; +} +static inline void +ovpn_peer_new_req_set_peer_vpn_rx_bytes(struct ovpn_peer_new_req *req, + __u64 vpn_rx_bytes) +{ + req->_present.peer = 1; + req->peer._present.vpn_rx_bytes = 1; + req->peer.vpn_rx_bytes = vpn_rx_bytes; +} +static inline void +ovpn_peer_new_req_set_peer_vpn_tx_bytes(struct ovpn_peer_new_req *req, + __u64 vpn_tx_bytes) +{ + req->_present.peer = 1; + req->peer._present.vpn_tx_bytes = 1; + req->peer.vpn_tx_bytes = vpn_tx_bytes; +} +static inline void +ovpn_peer_new_req_set_peer_vpn_rx_packets(struct ovpn_peer_new_req *req, + __u64 vpn_rx_packets) +{ + req->_present.peer = 1; + req->peer._present.vpn_rx_packets = 1; + req->peer.vpn_rx_packets = vpn_rx_packets; +} +static inline void +ovpn_peer_new_req_set_peer_vpn_tx_packets(struct ovpn_peer_new_req *req, + __u64 vpn_tx_packets) +{ + req->_present.peer = 1; + req->peer._present.vpn_tx_packets = 1; + req->peer.vpn_tx_packets = vpn_tx_packets; +} +static inline void +ovpn_peer_new_req_set_peer_link_rx_bytes(struct ovpn_peer_new_req *req, + __u64 link_rx_bytes) +{ + req->_present.peer = 1; + req->peer._present.link_rx_bytes = 1; + req->peer.link_rx_bytes = link_rx_bytes; +} +static inline void +ovpn_peer_new_req_set_peer_link_tx_bytes(struct ovpn_peer_new_req *req, + __u64 link_tx_bytes) +{ + req->_present.peer = 1; + req->peer._present.link_tx_bytes = 1; + req->peer.link_tx_bytes = link_tx_bytes; +} +static inline void +ovpn_peer_new_req_set_peer_link_rx_packets(struct ovpn_peer_new_req *req, + __u32 link_rx_packets) +{ + req->_present.peer = 1; + req->peer._present.link_rx_packets = 1; + req->peer.link_rx_packets = link_rx_packets; +} +static inline void +ovpn_peer_new_req_set_peer_link_tx_packets(struct ovpn_peer_new_req *req, + __u32 link_tx_packets) +{ + req->_present.peer = 1; + req->peer._present.link_tx_packets = 1; + req->peer.link_tx_packets = link_tx_packets; +} + +/* + * Add a remote peer + */ +int ovpn_peer_new(struct ynl_sock *ys, struct ovpn_peer_new_req *req); + +/* ============== OVPN_CMD_PEER_SET ============== */ +/* OVPN_CMD_PEER_SET - do */ +struct ovpn_peer_set_req { + struct { + __u32 ifindex:1; + __u32 peer:1; + } _present; + + __u32 ifindex; + struct ovpn_peer peer; +}; + +static inline struct ovpn_peer_set_req *ovpn_peer_set_req_alloc(void) +{ + return calloc(1, sizeof(struct ovpn_peer_set_req)); +} +void ovpn_peer_set_req_free(struct ovpn_peer_set_req *req); + +static inline void +ovpn_peer_set_req_set_ifindex(struct ovpn_peer_set_req *req, __u32 ifindex) +{ + req->_present.ifindex = 1; + req->ifindex = ifindex; +} +static inline void +ovpn_peer_set_req_set_peer_id(struct ovpn_peer_set_req *req, __u32 id) +{ + req->_present.peer = 1; + req->peer._present.id = 1; + req->peer.id = id; +} +static inline void +ovpn_peer_set_req_set_peer_remote_ipv4(struct ovpn_peer_set_req *req, + __u32 remote_ipv4 /* big-endian */) +{ + req->_present.peer = 1; + req->peer._present.remote_ipv4 = 1; + req->peer.remote_ipv4 = remote_ipv4; +} +static inline void +ovpn_peer_set_req_set_peer_remote_ipv6(struct ovpn_peer_set_req *req, + const void *remote_ipv6, size_t len) +{ + req->_present.peer = 1; + free(req->peer.remote_ipv6); + req->peer._present.remote_ipv6_len = len; + req->peer.remote_ipv6 = malloc(req->peer._present.remote_ipv6_len); + memcpy(req->peer.remote_ipv6, remote_ipv6, req->peer._present.remote_ipv6_len); +} +static inline void +ovpn_peer_set_req_set_peer_remote_ipv6_scope_id(struct ovpn_peer_set_req *req, + __u32 remote_ipv6_scope_id) +{ + req->_present.peer = 1; + req->peer._present.remote_ipv6_scope_id = 1; + req->peer.remote_ipv6_scope_id = remote_ipv6_scope_id; +} +static inline void +ovpn_peer_set_req_set_peer_remote_port(struct ovpn_peer_set_req *req, + __u16 remote_port /* big-endian */) +{ + req->_present.peer = 1; + req->peer._present.remote_port = 1; + req->peer.remote_port = remote_port; +} +static inline void +ovpn_peer_set_req_set_peer_socket(struct ovpn_peer_set_req *req, __u32 socket) +{ + req->_present.peer = 1; + req->peer._present.socket = 1; + req->peer.socket = socket; +} +static inline void +ovpn_peer_set_req_set_peer_vpn_ipv4(struct ovpn_peer_set_req *req, + __u32 vpn_ipv4 /* big-endian */) +{ + req->_present.peer = 1; + req->peer._present.vpn_ipv4 = 1; + req->peer.vpn_ipv4 = vpn_ipv4; +} +static inline void +ovpn_peer_set_req_set_peer_vpn_ipv6(struct ovpn_peer_set_req *req, + const void *vpn_ipv6, size_t len) +{ + req->_present.peer = 1; + free(req->peer.vpn_ipv6); + req->peer._present.vpn_ipv6_len = len; + req->peer.vpn_ipv6 = malloc(req->peer._present.vpn_ipv6_len); + memcpy(req->peer.vpn_ipv6, vpn_ipv6, req->peer._present.vpn_ipv6_len); +} +static inline void +ovpn_peer_set_req_set_peer_local_ipv4(struct ovpn_peer_set_req *req, + __u32 local_ipv4 /* big-endian */) +{ + req->_present.peer = 1; + req->peer._present.local_ipv4 = 1; + req->peer.local_ipv4 = local_ipv4; +} +static inline void +ovpn_peer_set_req_set_peer_local_ipv6(struct ovpn_peer_set_req *req, + const void *local_ipv6, size_t len) +{ + req->_present.peer = 1; + free(req->peer.local_ipv6); + req->peer._present.local_ipv6_len = len; + req->peer.local_ipv6 = malloc(req->peer._present.local_ipv6_len); + memcpy(req->peer.local_ipv6, local_ipv6, req->peer._present.local_ipv6_len); +} +static inline void +ovpn_peer_set_req_set_peer_local_port(struct ovpn_peer_set_req *req, + __u16 local_port /* big-endian */) +{ + req->_present.peer = 1; + req->peer._present.local_port = 1; + req->peer.local_port = local_port; +} +static inline void +ovpn_peer_set_req_set_peer_keepalive_interval(struct ovpn_peer_set_req *req, + __u32 keepalive_interval) +{ + req->_present.peer = 1; + req->peer._present.keepalive_interval = 1; + req->peer.keepalive_interval = keepalive_interval; +} +static inline void +ovpn_peer_set_req_set_peer_keepalive_timeout(struct ovpn_peer_set_req *req, + __u32 keepalive_timeout) +{ + req->_present.peer = 1; + req->peer._present.keepalive_timeout = 1; + req->peer.keepalive_timeout = keepalive_timeout; +} +static inline void +ovpn_peer_set_req_set_peer_del_reason(struct ovpn_peer_set_req *req, + enum ovpn_del_peer_reason del_reason) +{ + req->_present.peer = 1; + req->peer._present.del_reason = 1; + req->peer.del_reason = del_reason; +} +static inline void +ovpn_peer_set_req_set_peer_vpn_rx_bytes(struct ovpn_peer_set_req *req, + __u64 vpn_rx_bytes) +{ + req->_present.peer = 1; + req->peer._present.vpn_rx_bytes = 1; + req->peer.vpn_rx_bytes = vpn_rx_bytes; +} +static inline void +ovpn_peer_set_req_set_peer_vpn_tx_bytes(struct ovpn_peer_set_req *req, + __u64 vpn_tx_bytes) +{ + req->_present.peer = 1; + req->peer._present.vpn_tx_bytes = 1; + req->peer.vpn_tx_bytes = vpn_tx_bytes; +} +static inline void +ovpn_peer_set_req_set_peer_vpn_rx_packets(struct ovpn_peer_set_req *req, + __u64 vpn_rx_packets) +{ + req->_present.peer = 1; + req->peer._present.vpn_rx_packets = 1; + req->peer.vpn_rx_packets = vpn_rx_packets; +} +static inline void +ovpn_peer_set_req_set_peer_vpn_tx_packets(struct ovpn_peer_set_req *req, + __u64 vpn_tx_packets) +{ + req->_present.peer = 1; + req->peer._present.vpn_tx_packets = 1; + req->peer.vpn_tx_packets = vpn_tx_packets; +} +static inline void +ovpn_peer_set_req_set_peer_link_rx_bytes(struct ovpn_peer_set_req *req, + __u64 link_rx_bytes) +{ + req->_present.peer = 1; + req->peer._present.link_rx_bytes = 1; + req->peer.link_rx_bytes = link_rx_bytes; +} +static inline void +ovpn_peer_set_req_set_peer_link_tx_bytes(struct ovpn_peer_set_req *req, + __u64 link_tx_bytes) +{ + req->_present.peer = 1; + req->peer._present.link_tx_bytes = 1; + req->peer.link_tx_bytes = link_tx_bytes; +} +static inline void +ovpn_peer_set_req_set_peer_link_rx_packets(struct ovpn_peer_set_req *req, + __u32 link_rx_packets) +{ + req->_present.peer = 1; + req->peer._present.link_rx_packets = 1; + req->peer.link_rx_packets = link_rx_packets; +} +static inline void +ovpn_peer_set_req_set_peer_link_tx_packets(struct ovpn_peer_set_req *req, + __u32 link_tx_packets) +{ + req->_present.peer = 1; + req->peer._present.link_tx_packets = 1; + req->peer.link_tx_packets = link_tx_packets; +} + +/* + * modify a remote peer + */ +int ovpn_peer_set(struct ynl_sock *ys, struct ovpn_peer_set_req *req); + +/* ============== OVPN_CMD_PEER_GET ============== */ +/* OVPN_CMD_PEER_GET - do */ +struct ovpn_peer_get_req { + struct { + __u32 ifindex:1; + __u32 peer:1; + } _present; + + __u32 ifindex; + struct ovpn_peer peer; +}; + +static inline struct ovpn_peer_get_req *ovpn_peer_get_req_alloc(void) +{ + return calloc(1, sizeof(struct ovpn_peer_get_req)); +} +void ovpn_peer_get_req_free(struct ovpn_peer_get_req *req); + +static inline void +ovpn_peer_get_req_set_ifindex(struct ovpn_peer_get_req *req, __u32 ifindex) +{ + req->_present.ifindex = 1; + req->ifindex = ifindex; +} +static inline void +ovpn_peer_get_req_set_peer_id(struct ovpn_peer_get_req *req, __u32 id) +{ + req->_present.peer = 1; + req->peer._present.id = 1; + req->peer.id = id; +} +static inline void +ovpn_peer_get_req_set_peer_remote_ipv4(struct ovpn_peer_get_req *req, + __u32 remote_ipv4 /* big-endian */) +{ + req->_present.peer = 1; + req->peer._present.remote_ipv4 = 1; + req->peer.remote_ipv4 = remote_ipv4; +} +static inline void +ovpn_peer_get_req_set_peer_remote_ipv6(struct ovpn_peer_get_req *req, + const void *remote_ipv6, size_t len) +{ + req->_present.peer = 1; + free(req->peer.remote_ipv6); + req->peer._present.remote_ipv6_len = len; + req->peer.remote_ipv6 = malloc(req->peer._present.remote_ipv6_len); + memcpy(req->peer.remote_ipv6, remote_ipv6, req->peer._present.remote_ipv6_len); +} +static inline void +ovpn_peer_get_req_set_peer_remote_ipv6_scope_id(struct ovpn_peer_get_req *req, + __u32 remote_ipv6_scope_id) +{ + req->_present.peer = 1; + req->peer._present.remote_ipv6_scope_id = 1; + req->peer.remote_ipv6_scope_id = remote_ipv6_scope_id; +} +static inline void +ovpn_peer_get_req_set_peer_remote_port(struct ovpn_peer_get_req *req, + __u16 remote_port /* big-endian */) +{ + req->_present.peer = 1; + req->peer._present.remote_port = 1; + req->peer.remote_port = remote_port; +} +static inline void +ovpn_peer_get_req_set_peer_socket(struct ovpn_peer_get_req *req, __u32 socket) +{ + req->_present.peer = 1; + req->peer._present.socket = 1; + req->peer.socket = socket; +} +static inline void +ovpn_peer_get_req_set_peer_vpn_ipv4(struct ovpn_peer_get_req *req, + __u32 vpn_ipv4 /* big-endian */) +{ + req->_present.peer = 1; + req->peer._present.vpn_ipv4 = 1; + req->peer.vpn_ipv4 = vpn_ipv4; +} +static inline void +ovpn_peer_get_req_set_peer_vpn_ipv6(struct ovpn_peer_get_req *req, + const void *vpn_ipv6, size_t len) +{ + req->_present.peer = 1; + free(req->peer.vpn_ipv6); + req->peer._present.vpn_ipv6_len = len; + req->peer.vpn_ipv6 = malloc(req->peer._present.vpn_ipv6_len); + memcpy(req->peer.vpn_ipv6, vpn_ipv6, req->peer._present.vpn_ipv6_len); +} +static inline void +ovpn_peer_get_req_set_peer_local_ipv4(struct ovpn_peer_get_req *req, + __u32 local_ipv4 /* big-endian */) +{ + req->_present.peer = 1; + req->peer._present.local_ipv4 = 1; + req->peer.local_ipv4 = local_ipv4; +} +static inline void +ovpn_peer_get_req_set_peer_local_ipv6(struct ovpn_peer_get_req *req, + const void *local_ipv6, size_t len) +{ + req->_present.peer = 1; + free(req->peer.local_ipv6); + req->peer._present.local_ipv6_len = len; + req->peer.local_ipv6 = malloc(req->peer._present.local_ipv6_len); + memcpy(req->peer.local_ipv6, local_ipv6, req->peer._present.local_ipv6_len); +} +static inline void +ovpn_peer_get_req_set_peer_local_port(struct ovpn_peer_get_req *req, + __u16 local_port /* big-endian */) +{ + req->_present.peer = 1; + req->peer._present.local_port = 1; + req->peer.local_port = local_port; +} +static inline void +ovpn_peer_get_req_set_peer_keepalive_interval(struct ovpn_peer_get_req *req, + __u32 keepalive_interval) +{ + req->_present.peer = 1; + req->peer._present.keepalive_interval = 1; + req->peer.keepalive_interval = keepalive_interval; +} +static inline void +ovpn_peer_get_req_set_peer_keepalive_timeout(struct ovpn_peer_get_req *req, + __u32 keepalive_timeout) +{ + req->_present.peer = 1; + req->peer._present.keepalive_timeout = 1; + req->peer.keepalive_timeout = keepalive_timeout; +} +static inline void +ovpn_peer_get_req_set_peer_del_reason(struct ovpn_peer_get_req *req, + enum ovpn_del_peer_reason del_reason) +{ + req->_present.peer = 1; + req->peer._present.del_reason = 1; + req->peer.del_reason = del_reason; +} +static inline void +ovpn_peer_get_req_set_peer_vpn_rx_bytes(struct ovpn_peer_get_req *req, + __u64 vpn_rx_bytes) +{ + req->_present.peer = 1; + req->peer._present.vpn_rx_bytes = 1; + req->peer.vpn_rx_bytes = vpn_rx_bytes; +} +static inline void +ovpn_peer_get_req_set_peer_vpn_tx_bytes(struct ovpn_peer_get_req *req, + __u64 vpn_tx_bytes) +{ + req->_present.peer = 1; + req->peer._present.vpn_tx_bytes = 1; + req->peer.vpn_tx_bytes = vpn_tx_bytes; +} +static inline void +ovpn_peer_get_req_set_peer_vpn_rx_packets(struct ovpn_peer_get_req *req, + __u64 vpn_rx_packets) +{ + req->_present.peer = 1; + req->peer._present.vpn_rx_packets = 1; + req->peer.vpn_rx_packets = vpn_rx_packets; +} +static inline void +ovpn_peer_get_req_set_peer_vpn_tx_packets(struct ovpn_peer_get_req *req, + __u64 vpn_tx_packets) +{ + req->_present.peer = 1; + req->peer._present.vpn_tx_packets = 1; + req->peer.vpn_tx_packets = vpn_tx_packets; +} +static inline void +ovpn_peer_get_req_set_peer_link_rx_bytes(struct ovpn_peer_get_req *req, + __u64 link_rx_bytes) +{ + req->_present.peer = 1; + req->peer._present.link_rx_bytes = 1; + req->peer.link_rx_bytes = link_rx_bytes; +} +static inline void +ovpn_peer_get_req_set_peer_link_tx_bytes(struct ovpn_peer_get_req *req, + __u64 link_tx_bytes) +{ + req->_present.peer = 1; + req->peer._present.link_tx_bytes = 1; + req->peer.link_tx_bytes = link_tx_bytes; +} +static inline void +ovpn_peer_get_req_set_peer_link_rx_packets(struct ovpn_peer_get_req *req, + __u32 link_rx_packets) +{ + req->_present.peer = 1; + req->peer._present.link_rx_packets = 1; + req->peer.link_rx_packets = link_rx_packets; +} +static inline void +ovpn_peer_get_req_set_peer_link_tx_packets(struct ovpn_peer_get_req *req, + __u32 link_tx_packets) +{ + req->_present.peer = 1; + req->peer._present.link_tx_packets = 1; + req->peer.link_tx_packets = link_tx_packets; +} + +struct ovpn_peer_get_rsp { + struct { + __u32 peer:1; + } _present; + + struct ovpn_peer peer; +}; + +void ovpn_peer_get_rsp_free(struct ovpn_peer_get_rsp *rsp); + +/* + * Retrieve data about existing remote peers (or a specific one) + */ +struct ovpn_peer_get_rsp * +ovpn_peer_get(struct ynl_sock *ys, struct ovpn_peer_get_req *req); + +/* OVPN_CMD_PEER_GET - dump */ +struct ovpn_peer_get_req_dump { + struct { + __u32 ifindex:1; + } _present; + + __u32 ifindex; +}; + +static inline struct ovpn_peer_get_req_dump *ovpn_peer_get_req_dump_alloc(void) +{ + return calloc(1, sizeof(struct ovpn_peer_get_req_dump)); +} +void ovpn_peer_get_req_dump_free(struct ovpn_peer_get_req_dump *req); + +static inline void +ovpn_peer_get_req_dump_set_ifindex(struct ovpn_peer_get_req_dump *req, + __u32 ifindex) +{ + req->_present.ifindex = 1; + req->ifindex = ifindex; +} + +struct ovpn_peer_get_list { + struct ovpn_peer_get_list *next; + struct ovpn_peer_get_rsp obj __attribute__((aligned(8))); +}; + +void ovpn_peer_get_list_free(struct ovpn_peer_get_list *rsp); + +struct ovpn_peer_get_list * +ovpn_peer_get_dump(struct ynl_sock *ys, struct ovpn_peer_get_req_dump *req); + +/* OVPN_CMD_PEER_GET - notify */ +struct ovpn_peer_get_ntf { + __u16 family; + __u8 cmd; + struct ynl_ntf_base_type *next; + void (*free)(struct ovpn_peer_get_ntf *ntf); + struct ovpn_peer_get_rsp obj __attribute__((aligned(8))); +}; + +void ovpn_peer_get_ntf_free(struct ovpn_peer_get_ntf *rsp); + +/* ============== OVPN_CMD_PEER_DEL ============== */ +/* OVPN_CMD_PEER_DEL - do */ +struct ovpn_peer_del_req { + struct { + __u32 ifindex:1; + __u32 peer:1; + } _present; + + __u32 ifindex; + struct ovpn_peer peer; +}; + +static inline struct ovpn_peer_del_req *ovpn_peer_del_req_alloc(void) +{ + return calloc(1, sizeof(struct ovpn_peer_del_req)); +} +void ovpn_peer_del_req_free(struct ovpn_peer_del_req *req); + +static inline void +ovpn_peer_del_req_set_ifindex(struct ovpn_peer_del_req *req, __u32 ifindex) +{ + req->_present.ifindex = 1; + req->ifindex = ifindex; +} +static inline void +ovpn_peer_del_req_set_peer_id(struct ovpn_peer_del_req *req, __u32 id) +{ + req->_present.peer = 1; + req->peer._present.id = 1; + req->peer.id = id; +} +static inline void +ovpn_peer_del_req_set_peer_remote_ipv4(struct ovpn_peer_del_req *req, + __u32 remote_ipv4 /* big-endian */) +{ + req->_present.peer = 1; + req->peer._present.remote_ipv4 = 1; + req->peer.remote_ipv4 = remote_ipv4; +} +static inline void +ovpn_peer_del_req_set_peer_remote_ipv6(struct ovpn_peer_del_req *req, + const void *remote_ipv6, size_t len) +{ + req->_present.peer = 1; + free(req->peer.remote_ipv6); + req->peer._present.remote_ipv6_len = len; + req->peer.remote_ipv6 = malloc(req->peer._present.remote_ipv6_len); + memcpy(req->peer.remote_ipv6, remote_ipv6, req->peer._present.remote_ipv6_len); +} +static inline void +ovpn_peer_del_req_set_peer_remote_ipv6_scope_id(struct ovpn_peer_del_req *req, + __u32 remote_ipv6_scope_id) +{ + req->_present.peer = 1; + req->peer._present.remote_ipv6_scope_id = 1; + req->peer.remote_ipv6_scope_id = remote_ipv6_scope_id; +} +static inline void +ovpn_peer_del_req_set_peer_remote_port(struct ovpn_peer_del_req *req, + __u16 remote_port /* big-endian */) +{ + req->_present.peer = 1; + req->peer._present.remote_port = 1; + req->peer.remote_port = remote_port; +} +static inline void +ovpn_peer_del_req_set_peer_socket(struct ovpn_peer_del_req *req, __u32 socket) +{ + req->_present.peer = 1; + req->peer._present.socket = 1; + req->peer.socket = socket; +} +static inline void +ovpn_peer_del_req_set_peer_vpn_ipv4(struct ovpn_peer_del_req *req, + __u32 vpn_ipv4 /* big-endian */) +{ + req->_present.peer = 1; + req->peer._present.vpn_ipv4 = 1; + req->peer.vpn_ipv4 = vpn_ipv4; +} +static inline void +ovpn_peer_del_req_set_peer_vpn_ipv6(struct ovpn_peer_del_req *req, + const void *vpn_ipv6, size_t len) +{ + req->_present.peer = 1; + free(req->peer.vpn_ipv6); + req->peer._present.vpn_ipv6_len = len; + req->peer.vpn_ipv6 = malloc(req->peer._present.vpn_ipv6_len); + memcpy(req->peer.vpn_ipv6, vpn_ipv6, req->peer._present.vpn_ipv6_len); +} +static inline void +ovpn_peer_del_req_set_peer_local_ipv4(struct ovpn_peer_del_req *req, + __u32 local_ipv4 /* big-endian */) +{ + req->_present.peer = 1; + req->peer._present.local_ipv4 = 1; + req->peer.local_ipv4 = local_ipv4; +} +static inline void +ovpn_peer_del_req_set_peer_local_ipv6(struct ovpn_peer_del_req *req, + const void *local_ipv6, size_t len) +{ + req->_present.peer = 1; + free(req->peer.local_ipv6); + req->peer._present.local_ipv6_len = len; + req->peer.local_ipv6 = malloc(req->peer._present.local_ipv6_len); + memcpy(req->peer.local_ipv6, local_ipv6, req->peer._present.local_ipv6_len); +} +static inline void +ovpn_peer_del_req_set_peer_local_port(struct ovpn_peer_del_req *req, + __u16 local_port /* big-endian */) +{ + req->_present.peer = 1; + req->peer._present.local_port = 1; + req->peer.local_port = local_port; +} +static inline void +ovpn_peer_del_req_set_peer_keepalive_interval(struct ovpn_peer_del_req *req, + __u32 keepalive_interval) +{ + req->_present.peer = 1; + req->peer._present.keepalive_interval = 1; + req->peer.keepalive_interval = keepalive_interval; +} +static inline void +ovpn_peer_del_req_set_peer_keepalive_timeout(struct ovpn_peer_del_req *req, + __u32 keepalive_timeout) +{ + req->_present.peer = 1; + req->peer._present.keepalive_timeout = 1; + req->peer.keepalive_timeout = keepalive_timeout; +} +static inline void +ovpn_peer_del_req_set_peer_del_reason(struct ovpn_peer_del_req *req, + enum ovpn_del_peer_reason del_reason) +{ + req->_present.peer = 1; + req->peer._present.del_reason = 1; + req->peer.del_reason = del_reason; +} +static inline void +ovpn_peer_del_req_set_peer_vpn_rx_bytes(struct ovpn_peer_del_req *req, + __u64 vpn_rx_bytes) +{ + req->_present.peer = 1; + req->peer._present.vpn_rx_bytes = 1; + req->peer.vpn_rx_bytes = vpn_rx_bytes; +} +static inline void +ovpn_peer_del_req_set_peer_vpn_tx_bytes(struct ovpn_peer_del_req *req, + __u64 vpn_tx_bytes) +{ + req->_present.peer = 1; + req->peer._present.vpn_tx_bytes = 1; + req->peer.vpn_tx_bytes = vpn_tx_bytes; +} +static inline void +ovpn_peer_del_req_set_peer_vpn_rx_packets(struct ovpn_peer_del_req *req, + __u64 vpn_rx_packets) +{ + req->_present.peer = 1; + req->peer._present.vpn_rx_packets = 1; + req->peer.vpn_rx_packets = vpn_rx_packets; +} +static inline void +ovpn_peer_del_req_set_peer_vpn_tx_packets(struct ovpn_peer_del_req *req, + __u64 vpn_tx_packets) +{ + req->_present.peer = 1; + req->peer._present.vpn_tx_packets = 1; + req->peer.vpn_tx_packets = vpn_tx_packets; +} +static inline void +ovpn_peer_del_req_set_peer_link_rx_bytes(struct ovpn_peer_del_req *req, + __u64 link_rx_bytes) +{ + req->_present.peer = 1; + req->peer._present.link_rx_bytes = 1; + req->peer.link_rx_bytes = link_rx_bytes; +} +static inline void +ovpn_peer_del_req_set_peer_link_tx_bytes(struct ovpn_peer_del_req *req, + __u64 link_tx_bytes) +{ + req->_present.peer = 1; + req->peer._present.link_tx_bytes = 1; + req->peer.link_tx_bytes = link_tx_bytes; +} +static inline void +ovpn_peer_del_req_set_peer_link_rx_packets(struct ovpn_peer_del_req *req, + __u32 link_rx_packets) +{ + req->_present.peer = 1; + req->peer._present.link_rx_packets = 1; + req->peer.link_rx_packets = link_rx_packets; +} +static inline void +ovpn_peer_del_req_set_peer_link_tx_packets(struct ovpn_peer_del_req *req, + __u32 link_tx_packets) +{ + req->_present.peer = 1; + req->peer._present.link_tx_packets = 1; + req->peer.link_tx_packets = link_tx_packets; +} + +/* + * Delete existing remote peer + */ +int ovpn_peer_del(struct ynl_sock *ys, struct ovpn_peer_del_req *req); + +/* ============== OVPN_CMD_KEY_NEW ============== */ +/* OVPN_CMD_KEY_NEW - do */ +struct ovpn_key_new_req { + struct { + __u32 ifindex:1; + __u32 keyconf:1; + } _present; + + __u32 ifindex; + struct ovpn_keyconf keyconf; +}; + +static inline struct ovpn_key_new_req *ovpn_key_new_req_alloc(void) +{ + return calloc(1, sizeof(struct ovpn_key_new_req)); +} +void ovpn_key_new_req_free(struct ovpn_key_new_req *req); + +static inline void +ovpn_key_new_req_set_ifindex(struct ovpn_key_new_req *req, __u32 ifindex) +{ + req->_present.ifindex = 1; + req->ifindex = ifindex; +} +static inline void +ovpn_key_new_req_set_keyconf_peer_id(struct ovpn_key_new_req *req, + __u32 peer_id) +{ + req->_present.keyconf = 1; + req->keyconf._present.peer_id = 1; + req->keyconf.peer_id = peer_id; +} +static inline void +ovpn_key_new_req_set_keyconf_slot(struct ovpn_key_new_req *req, + enum ovpn_key_slot slot) +{ + req->_present.keyconf = 1; + req->keyconf._present.slot = 1; + req->keyconf.slot = slot; +} +static inline void +ovpn_key_new_req_set_keyconf_key_id(struct ovpn_key_new_req *req, __u32 key_id) +{ + req->_present.keyconf = 1; + req->keyconf._present.key_id = 1; + req->keyconf.key_id = key_id; +} +static inline void +ovpn_key_new_req_set_keyconf_cipher_alg(struct ovpn_key_new_req *req, + enum ovpn_cipher_alg cipher_alg) +{ + req->_present.keyconf = 1; + req->keyconf._present.cipher_alg = 1; + req->keyconf.cipher_alg = cipher_alg; +} +static inline void +ovpn_key_new_req_set_keyconf_encrypt_dir_cipher_key(struct ovpn_key_new_req *req, + const void *cipher_key, + size_t len) +{ + req->_present.keyconf = 1; + req->keyconf._present.encrypt_dir = 1; + free(req->keyconf.encrypt_dir.cipher_key); + req->keyconf.encrypt_dir._present.cipher_key_len = len; + req->keyconf.encrypt_dir.cipher_key = malloc(req->keyconf.encrypt_dir._present.cipher_key_len); + memcpy(req->keyconf.encrypt_dir.cipher_key, cipher_key, req->keyconf.encrypt_dir._present.cipher_key_len); +} +static inline void +ovpn_key_new_req_set_keyconf_encrypt_dir_nonce_tail(struct ovpn_key_new_req *req, + const void *nonce_tail, + size_t len) +{ + req->_present.keyconf = 1; + req->keyconf._present.encrypt_dir = 1; + free(req->keyconf.encrypt_dir.nonce_tail); + req->keyconf.encrypt_dir._present.nonce_tail_len = len; + req->keyconf.encrypt_dir.nonce_tail = malloc(req->keyconf.encrypt_dir._present.nonce_tail_len); + memcpy(req->keyconf.encrypt_dir.nonce_tail, nonce_tail, req->keyconf.encrypt_dir._present.nonce_tail_len); +} +static inline void +ovpn_key_new_req_set_keyconf_decrypt_dir_cipher_key(struct ovpn_key_new_req *req, + const void *cipher_key, + size_t len) +{ + req->_present.keyconf = 1; + req->keyconf._present.decrypt_dir = 1; + free(req->keyconf.decrypt_dir.cipher_key); + req->keyconf.decrypt_dir._present.cipher_key_len = len; + req->keyconf.decrypt_dir.cipher_key = malloc(req->keyconf.decrypt_dir._present.cipher_key_len); + memcpy(req->keyconf.decrypt_dir.cipher_key, cipher_key, req->keyconf.decrypt_dir._present.cipher_key_len); +} +static inline void +ovpn_key_new_req_set_keyconf_decrypt_dir_nonce_tail(struct ovpn_key_new_req *req, + const void *nonce_tail, + size_t len) +{ + req->_present.keyconf = 1; + req->keyconf._present.decrypt_dir = 1; + free(req->keyconf.decrypt_dir.nonce_tail); + req->keyconf.decrypt_dir._present.nonce_tail_len = len; + req->keyconf.decrypt_dir.nonce_tail = malloc(req->keyconf.decrypt_dir._present.nonce_tail_len); + memcpy(req->keyconf.decrypt_dir.nonce_tail, nonce_tail, req->keyconf.decrypt_dir._present.nonce_tail_len); +} + +/* + * Add a cipher key for a specific peer + */ +int ovpn_key_new(struct ynl_sock *ys, struct ovpn_key_new_req *req); + +/* OVPN_CMD_KEY_NEW - notify */ +struct ovpn_key_new_ntf { + __u16 family; + __u8 cmd; + struct ynl_ntf_base_type *next; + void (*free)(struct ovpn_key_new_ntf *ntf); + struct ovpn_key_new_rsp obj __attribute__((aligned(8))); +}; + +void ovpn_key_new_ntf_free(struct ovpn_key_new_ntf *rsp); + +/* ============== OVPN_CMD_KEY_SWAP ============== */ +/* OVPN_CMD_KEY_SWAP - do */ +struct ovpn_key_swap_req { + struct { + __u32 ifindex:1; + __u32 keyconf:1; + } _present; + + __u32 ifindex; + struct ovpn_keyconf keyconf; +}; + +static inline struct ovpn_key_swap_req *ovpn_key_swap_req_alloc(void) +{ + return calloc(1, sizeof(struct ovpn_key_swap_req)); +} +void ovpn_key_swap_req_free(struct ovpn_key_swap_req *req); + +static inline void +ovpn_key_swap_req_set_ifindex(struct ovpn_key_swap_req *req, __u32 ifindex) +{ + req->_present.ifindex = 1; + req->ifindex = ifindex; +} +static inline void +ovpn_key_swap_req_set_keyconf_peer_id(struct ovpn_key_swap_req *req, + __u32 peer_id) +{ + req->_present.keyconf = 1; + req->keyconf._present.peer_id = 1; + req->keyconf.peer_id = peer_id; +} +static inline void +ovpn_key_swap_req_set_keyconf_slot(struct ovpn_key_swap_req *req, + enum ovpn_key_slot slot) +{ + req->_present.keyconf = 1; + req->keyconf._present.slot = 1; + req->keyconf.slot = slot; +} +static inline void +ovpn_key_swap_req_set_keyconf_key_id(struct ovpn_key_swap_req *req, + __u32 key_id) +{ + req->_present.keyconf = 1; + req->keyconf._present.key_id = 1; + req->keyconf.key_id = key_id; +} +static inline void +ovpn_key_swap_req_set_keyconf_cipher_alg(struct ovpn_key_swap_req *req, + enum ovpn_cipher_alg cipher_alg) +{ + req->_present.keyconf = 1; + req->keyconf._present.cipher_alg = 1; + req->keyconf.cipher_alg = cipher_alg; +} +static inline void +ovpn_key_swap_req_set_keyconf_encrypt_dir_cipher_key(struct ovpn_key_swap_req *req, + const void *cipher_key, + size_t len) +{ + req->_present.keyconf = 1; + req->keyconf._present.encrypt_dir = 1; + free(req->keyconf.encrypt_dir.cipher_key); + req->keyconf.encrypt_dir._present.cipher_key_len = len; + req->keyconf.encrypt_dir.cipher_key = malloc(req->keyconf.encrypt_dir._present.cipher_key_len); + memcpy(req->keyconf.encrypt_dir.cipher_key, cipher_key, req->keyconf.encrypt_dir._present.cipher_key_len); +} +static inline void +ovpn_key_swap_req_set_keyconf_encrypt_dir_nonce_tail(struct ovpn_key_swap_req *req, + const void *nonce_tail, + size_t len) +{ + req->_present.keyconf = 1; + req->keyconf._present.encrypt_dir = 1; + free(req->keyconf.encrypt_dir.nonce_tail); + req->keyconf.encrypt_dir._present.nonce_tail_len = len; + req->keyconf.encrypt_dir.nonce_tail = malloc(req->keyconf.encrypt_dir._present.nonce_tail_len); + memcpy(req->keyconf.encrypt_dir.nonce_tail, nonce_tail, req->keyconf.encrypt_dir._present.nonce_tail_len); +} +static inline void +ovpn_key_swap_req_set_keyconf_decrypt_dir_cipher_key(struct ovpn_key_swap_req *req, + const void *cipher_key, + size_t len) +{ + req->_present.keyconf = 1; + req->keyconf._present.decrypt_dir = 1; + free(req->keyconf.decrypt_dir.cipher_key); + req->keyconf.decrypt_dir._present.cipher_key_len = len; + req->keyconf.decrypt_dir.cipher_key = malloc(req->keyconf.decrypt_dir._present.cipher_key_len); + memcpy(req->keyconf.decrypt_dir.cipher_key, cipher_key, req->keyconf.decrypt_dir._present.cipher_key_len); +} +static inline void +ovpn_key_swap_req_set_keyconf_decrypt_dir_nonce_tail(struct ovpn_key_swap_req *req, + const void *nonce_tail, + size_t len) +{ + req->_present.keyconf = 1; + req->keyconf._present.decrypt_dir = 1; + free(req->keyconf.decrypt_dir.nonce_tail); + req->keyconf.decrypt_dir._present.nonce_tail_len = len; + req->keyconf.decrypt_dir.nonce_tail = malloc(req->keyconf.decrypt_dir._present.nonce_tail_len); + memcpy(req->keyconf.decrypt_dir.nonce_tail, nonce_tail, req->keyconf.decrypt_dir._present.nonce_tail_len); +} + +/* + * Swap primary and secondary session keys for a specific peer + */ +int ovpn_key_swap(struct ynl_sock *ys, struct ovpn_key_swap_req *req); + +/* ============== OVPN_CMD_KEY_DEL ============== */ +/* OVPN_CMD_KEY_DEL - do */ +struct ovpn_key_del_req { + struct { + __u32 ifindex:1; + __u32 keyconf:1; + } _present; + + __u32 ifindex; + struct ovpn_keyconf keyconf; +}; + +static inline struct ovpn_key_del_req *ovpn_key_del_req_alloc(void) +{ + return calloc(1, sizeof(struct ovpn_key_del_req)); +} +void ovpn_key_del_req_free(struct ovpn_key_del_req *req); + +static inline void +ovpn_key_del_req_set_ifindex(struct ovpn_key_del_req *req, __u32 ifindex) +{ + req->_present.ifindex = 1; + req->ifindex = ifindex; +} +static inline void +ovpn_key_del_req_set_keyconf_peer_id(struct ovpn_key_del_req *req, + __u32 peer_id) +{ + req->_present.keyconf = 1; + req->keyconf._present.peer_id = 1; + req->keyconf.peer_id = peer_id; +} +static inline void +ovpn_key_del_req_set_keyconf_slot(struct ovpn_key_del_req *req, + enum ovpn_key_slot slot) +{ + req->_present.keyconf = 1; + req->keyconf._present.slot = 1; + req->keyconf.slot = slot; +} +static inline void +ovpn_key_del_req_set_keyconf_key_id(struct ovpn_key_del_req *req, __u32 key_id) +{ + req->_present.keyconf = 1; + req->keyconf._present.key_id = 1; + req->keyconf.key_id = key_id; +} +static inline void +ovpn_key_del_req_set_keyconf_cipher_alg(struct ovpn_key_del_req *req, + enum ovpn_cipher_alg cipher_alg) +{ + req->_present.keyconf = 1; + req->keyconf._present.cipher_alg = 1; + req->keyconf.cipher_alg = cipher_alg; +} +static inline void +ovpn_key_del_req_set_keyconf_encrypt_dir_cipher_key(struct ovpn_key_del_req *req, + const void *cipher_key, + size_t len) +{ + req->_present.keyconf = 1; + req->keyconf._present.encrypt_dir = 1; + free(req->keyconf.encrypt_dir.cipher_key); + req->keyconf.encrypt_dir._present.cipher_key_len = len; + req->keyconf.encrypt_dir.cipher_key = malloc(req->keyconf.encrypt_dir._present.cipher_key_len); + memcpy(req->keyconf.encrypt_dir.cipher_key, cipher_key, req->keyconf.encrypt_dir._present.cipher_key_len); +} +static inline void +ovpn_key_del_req_set_keyconf_encrypt_dir_nonce_tail(struct ovpn_key_del_req *req, + const void *nonce_tail, + size_t len) +{ + req->_present.keyconf = 1; + req->keyconf._present.encrypt_dir = 1; + free(req->keyconf.encrypt_dir.nonce_tail); + req->keyconf.encrypt_dir._present.nonce_tail_len = len; + req->keyconf.encrypt_dir.nonce_tail = malloc(req->keyconf.encrypt_dir._present.nonce_tail_len); + memcpy(req->keyconf.encrypt_dir.nonce_tail, nonce_tail, req->keyconf.encrypt_dir._present.nonce_tail_len); +} +static inline void +ovpn_key_del_req_set_keyconf_decrypt_dir_cipher_key(struct ovpn_key_del_req *req, + const void *cipher_key, + size_t len) +{ + req->_present.keyconf = 1; + req->keyconf._present.decrypt_dir = 1; + free(req->keyconf.decrypt_dir.cipher_key); + req->keyconf.decrypt_dir._present.cipher_key_len = len; + req->keyconf.decrypt_dir.cipher_key = malloc(req->keyconf.decrypt_dir._present.cipher_key_len); + memcpy(req->keyconf.decrypt_dir.cipher_key, cipher_key, req->keyconf.decrypt_dir._present.cipher_key_len); +} +static inline void +ovpn_key_del_req_set_keyconf_decrypt_dir_nonce_tail(struct ovpn_key_del_req *req, + const void *nonce_tail, + size_t len) +{ + req->_present.keyconf = 1; + req->keyconf._present.decrypt_dir = 1; + free(req->keyconf.decrypt_dir.nonce_tail); + req->keyconf.decrypt_dir._present.nonce_tail_len = len; + req->keyconf.decrypt_dir.nonce_tail = malloc(req->keyconf.decrypt_dir._present.nonce_tail_len); + memcpy(req->keyconf.decrypt_dir.nonce_tail, nonce_tail, req->keyconf.decrypt_dir._present.nonce_tail_len); +} + +/* + * Delete cipher key for a specific peer + */ +int ovpn_key_del(struct ynl_sock *ys, struct ovpn_key_del_req *req); + +#endif /* _LINUX_OVPN_GEN_H */