77 struct xfrm_usersa_info xsinfo = {};
79 xsinfo.sel.family = AF_INET;
80 xsinfo.sel.saddr.a4 = INADDR_ANY;
81 xsinfo.sel.daddr.a4 = inet_addr(dest_address.c_str());
82 xsinfo.sel.prefixlen_d = 32;
84 xsinfo.id.daddr.a4 = inet_addr(dest_address.c_str());
85 xsinfo.id.spi = htonl(spi);
86 xsinfo.id.proto = IPPROTO_ESP;
88 xsinfo.saddr.a4 = INADDR_ANY;
90 xsinfo.lft.soft_byte_limit = XFRM_INF;
91 xsinfo.lft.hard_byte_limit = XFRM_INF;
92 xsinfo.lft.soft_packet_limit = XFRM_INF;
93 xsinfo.lft.hard_packet_limit = XFRM_INF;
96 xsinfo.family = AF_INET;
97 xsinfo.mode = XFRM_MODE_TRANSPORT;
104 std::vector<char> binary_key;
105 for (
unsigned int i = 0; i < key.length(); i += 2) {
106 binary_key.emplace_back((
char)strtol(key.substr(i, 2).c_str(),
nullptr, 16));
108 if (binary_key.size() > 512) {
109 throw "Key is too long";
111 strcpy(algo.xa.alg_name,
"aes");
112 algo.xa.alg_key_len = binary_key.size() * 8;
113 memcpy(algo.buf, &binary_key[0], binary_key.size());
115 msg = nlmsg_alloc_simple(XFRM_MSG_NEWSA, 0);
116 nlmsg_append(msg, &xsinfo,
sizeof(xsinfo), NLMSG_ALIGNTO);
117 nla_put(msg, XFRMA_ALG_CRYPT,
sizeof(algo), &algo);
119 sk = nl_socket_alloc();
120 nl_connect(sk, NETLINK_XFRM);
121 nl_send_auto(sk, msg);