blob: b2f0bff1c08adfcaf0e7bfbf1763112e9d0c86ef [file] [log] [blame]
Nathan Harold1a371532017-01-30 12:30:48 -08001/*
2 * Copyright (C) 2017 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16#ifndef _XFRM_CONTROLLER_H
17#define _XFRM_CONTROLLER_H
18
19#include <atomic>
20#include <list>
21#include <map>
22#include <string>
23#include <utility> // for pair
24
Benedict Wong319f17e2018-05-15 17:06:44 -070025#include <linux/if.h>
manojboopathi8707f232018-01-02 14:45:47 -080026#include <linux/if_link.h>
27#include <linux/if_tunnel.h>
Nathan Harold1a371532017-01-30 12:30:48 -080028#include <linux/netlink.h>
Nathan Harold420ceac2017-04-05 19:36:59 -070029#include <linux/udp.h>
Nathan Harold1a371532017-01-30 12:30:48 -080030#include <linux/xfrm.h>
Bernie Innocenti97f388f2018-10-16 19:17:08 +090031#include <unistd.h>
Nathan Harold1a371532017-01-30 12:30:48 -080032
33#include "NetdConstants.h"
Bernie Innocenti97f388f2018-10-16 19:17:08 +090034#include "android-base/unique_fd.h"
manojboopathi8707f232018-01-02 14:45:47 -080035#include "netdutils/Slice.h"
ludi6e8eccd2017-08-14 14:40:37 -070036#include "netdutils/Status.h"
Bernie Innocenti97f388f2018-10-16 19:17:08 +090037#include "sysutils/SocketClient.h"
Nathan Harold1a371532017-01-30 12:30:48 -080038
39namespace android {
40namespace net {
41
Nathan Harold39b5df42017-08-02 18:45:25 -070042// Exposed for testing
43extern const uint32_t ALGO_MASK_AUTH_ALL;
44// Exposed for testing
45extern const uint32_t ALGO_MASK_CRYPT_ALL;
46// Exposed for testing
Benedict Wongbe65b432017-08-22 21:43:14 -070047extern const uint32_t ALGO_MASK_AEAD_ALL;
48// Exposed for testing
Nathan Harold39b5df42017-08-02 18:45:25 -070049extern const uint8_t REPLAY_WINDOW_SIZE;
50
Nathan Harold1a371532017-01-30 12:30:48 -080051// Suggest we avoid the smallest and largest ints
52class XfrmMessage;
53class TransportModeSecurityAssociation;
54
55class XfrmSocket {
56public:
57 virtual void close() {
Nathan Harold420ceac2017-04-05 19:36:59 -070058 if (mSock >= 0) {
Nathan Harold1a371532017-01-30 12:30:48 -080059 ::close(mSock);
60 }
61 mSock = -1;
62 }
63
ludi6e8eccd2017-08-14 14:40:37 -070064 virtual netdutils::Status open() = 0;
Nathan Harold1a371532017-01-30 12:30:48 -080065
66 virtual ~XfrmSocket() { close(); }
67
ludie51e3862017-08-15 19:28:12 -070068 // Sends the netlink message contained in iovecs. This populates iovecs[0] with
69 // a valid netlink message header.
ludi6e8eccd2017-08-14 14:40:37 -070070 virtual netdutils::Status sendMessage(uint16_t nlMsgType, uint16_t nlMsgFlags,
71 uint16_t nlMsgSeqNum,
72 std::vector<iovec>* iovecs) const = 0;
Nathan Harold1a371532017-01-30 12:30:48 -080073
74protected:
75 int mSock;
76};
77
78enum struct XfrmDirection : uint8_t {
79 IN = XFRM_POLICY_IN,
80 OUT = XFRM_POLICY_OUT,
81 FORWARD = XFRM_POLICY_FWD,
82 MASK = XFRM_POLICY_MASK,
83};
84
85enum struct XfrmMode : uint8_t {
86 TRANSPORT = XFRM_MODE_TRANSPORT,
87 TUNNEL = XFRM_MODE_TUNNEL,
88};
89
Nathan Harold420ceac2017-04-05 19:36:59 -070090enum struct XfrmEncapType : uint16_t {
91 NONE = 0,
92 ESPINUDP_NON_IKE = UDP_ENCAP_ESPINUDP_NON_IKE,
93 ESPINUDP = UDP_ENCAP_ESPINUDP
94};
95
Nathan Harold1a371532017-01-30 12:30:48 -080096struct XfrmAlgo {
97 std::string name;
98 std::vector<uint8_t> key;
99 uint16_t truncLenBits;
100};
101
Nathan Harold420ceac2017-04-05 19:36:59 -0700102struct XfrmEncap {
103 XfrmEncapType type;
104 uint16_t srcPort;
105 uint16_t dstPort;
106};
107
Nathan Harold7441c692017-12-12 21:25:01 -0800108// minimally sufficient structure to match either an SA or a Policy
Benedict Wonga04ffa72018-05-09 21:42:42 -0700109struct XfrmCommonInfo {
Nathan Harold1a371532017-01-30 12:30:48 -0800110 xfrm_address_t dstAddr; // network order
111 xfrm_address_t srcAddr;
112 int addrFamily; // AF_INET or AF_INET6
113 int transformId; // requestId
114 int spi;
Di Lu2ccb3e52018-01-03 16:19:20 -0800115 xfrm_mark mark;
Nathan Harold1a371532017-01-30 12:30:48 -0800116};
117
Benedict Wonga04ffa72018-05-09 21:42:42 -0700118struct XfrmSaInfo : XfrmCommonInfo {
Nathan Harold1a371532017-01-30 12:30:48 -0800119 XfrmAlgo auth;
120 XfrmAlgo crypt;
Benedict Wongbe65b432017-08-22 21:43:14 -0700121 XfrmAlgo aead;
Nathan Harold1a371532017-01-30 12:30:48 -0800122 int netId;
123 XfrmMode mode;
Nathan Harold420ceac2017-04-05 19:36:59 -0700124 XfrmEncap encap;
Nathan Harold1a371532017-01-30 12:30:48 -0800125};
126
Benedict Wonga04ffa72018-05-09 21:42:42 -0700127struct XfrmSpInfo : XfrmSaInfo {
128 // Address family in XfrmCommonInfo used for template/SA matching, need separate addrFamily
129 // for selectors
130 int selAddrFamily; // AF_INET or AF_INET6
131};
132
Nathan Harold1a371532017-01-30 12:30:48 -0800133class XfrmController {
134public:
135 XfrmController();
136
Nathan Harold21299f72018-03-16 20:13:03 -0700137 static netdutils::Status Init();
Benedict Wongb2daefb2017-12-06 22:05:46 -0800138
Nathan Harold21299f72018-03-16 20:13:03 -0700139 static netdutils::Status ipSecSetEncapSocketOwner(const android::base::unique_fd& socket,
140 int newUid, uid_t callerUid);
Nathan Harold1a371532017-01-30 12:30:48 -0800141
Nathan Harold21299f72018-03-16 20:13:03 -0700142 static netdutils::Status ipSecAllocateSpi(int32_t transformId, const std::string& localAddress,
143 const std::string& remoteAddress, int32_t inSpi,
144 int32_t* outSpi);
145
146 static netdutils::Status ipSecAddSecurityAssociation(
Nathan Haroldda54f122018-01-09 16:42:57 -0800147 int32_t transformId, int32_t mode, const std::string& sourceAddress,
Benedict Wong96abf482018-01-22 13:56:41 -0800148 const std::string& destinationAddress, int32_t underlyingNetId, int32_t spi,
Di Lu2ccb3e52018-01-03 16:19:20 -0800149 int32_t markValue, int32_t markMask, const std::string& authAlgo,
150 const std::vector<uint8_t>& authKey, int32_t authTruncBits, const std::string& cryptAlgo,
151 const std::vector<uint8_t>& cryptKey, int32_t cryptTruncBits, const std::string& aeadAlgo,
152 const std::vector<uint8_t>& aeadKey, int32_t aeadIcvBits, int32_t encapType,
153 int32_t encapLocalPort, int32_t encapRemotePort);
Nathan Harold1a371532017-01-30 12:30:48 -0800154
Nathan Harold21299f72018-03-16 20:13:03 -0700155 static netdutils::Status ipSecDeleteSecurityAssociation(int32_t transformId,
156 const std::string& sourceAddress,
157 const std::string& destinationAddress,
158 int32_t spi, int32_t markValue,
159 int32_t markMask);
Nathan Harold1a371532017-01-30 12:30:48 -0800160
Nathan Harold21299f72018-03-16 20:13:03 -0700161 static netdutils::Status
162 ipSecApplyTransportModeTransform(const android::base::unique_fd& socket, int32_t transformId,
163 int32_t direction, const std::string& localAddress,
164 const std::string& remoteAddress, int32_t spi);
Nathan Harold1a371532017-01-30 12:30:48 -0800165
Nathan Harold21299f72018-03-16 20:13:03 -0700166 static netdutils::Status
167 ipSecRemoveTransportModeTransform(const android::base::unique_fd& socket);
Nathan Harold1a371532017-01-30 12:30:48 -0800168
Benedict Wonga04ffa72018-05-09 21:42:42 -0700169 static netdutils::Status ipSecAddSecurityPolicy(int32_t transformId, int32_t selAddrFamily,
170 int32_t direction,
Benedict Wongad600cb2018-05-14 17:22:35 -0700171 const std::string& tmplSrcAddress,
172 const std::string& tmplDstAddress, int32_t spi,
173 int32_t markValue, int32_t markMask);
ludi771b8002017-11-20 15:09:05 -0800174
Benedict Wonga04ffa72018-05-09 21:42:42 -0700175 static netdutils::Status ipSecUpdateSecurityPolicy(int32_t transformId, int32_t selAddrFamily,
176 int32_t direction,
Benedict Wongad600cb2018-05-14 17:22:35 -0700177 const std::string& tmplSrcAddress,
178 const std::string& tmplDstAddress,
Nathan Harold21299f72018-03-16 20:13:03 -0700179 int32_t spi, int32_t markValue,
180 int32_t markMask);
ludi771b8002017-11-20 15:09:05 -0800181
Benedict Wonga04ffa72018-05-09 21:42:42 -0700182 static netdutils::Status ipSecDeleteSecurityPolicy(int32_t transformId, int32_t selAddrFamily,
183 int32_t direction, int32_t markValue,
184 int32_t markMask);
ludi771b8002017-11-20 15:09:05 -0800185
Benedict Wong319f17e2018-05-15 17:06:44 -0700186 static netdutils::Status ipSecAddTunnelInterface(const std::string& deviceName,
187 const std::string& localAddress,
188 const std::string& remoteAddress, int32_t ikey,
189 int32_t okey, bool isUpdate);
manojboopathi8707f232018-01-02 14:45:47 -0800190
Benedict Wong319f17e2018-05-15 17:06:44 -0700191 static netdutils::Status ipSecRemoveTunnelInterface(const std::string& deviceName);
manojboopathi8707f232018-01-02 14:45:47 -0800192
Jonathan Basseric6461a62017-08-31 14:47:33 -0700193 // Some XFRM netlink attributes comprise a header, a struct, and some data
194 // after the struct. We wrap all of those in one struct for easier
195 // marshalling. The structs below must be ABI compatible with the kernel and
196 // are composed from kernel structures; thus, they use the kernel naming
197 // convention.
198
Nathan Harold39b5df42017-08-02 18:45:25 -0700199 // Exposed for testing
Benedict Wong4f60ee12017-10-10 12:27:25 -0700200 static constexpr size_t MAX_KEY_LENGTH = 128;
Nathan Harold39b5df42017-08-02 18:45:25 -0700201
Jonathan Basseric6461a62017-08-31 14:47:33 -0700202 // Container for the content of an XFRMA_ALG_CRYPT netlink attribute.
Nathan Harold39b5df42017-08-02 18:45:25 -0700203 // Exposed for testing
204 struct nlattr_algo_crypt {
205 nlattr hdr;
206 xfrm_algo crypt;
Benedict Wong4f60ee12017-10-10 12:27:25 -0700207 uint8_t key[MAX_KEY_LENGTH];
Nathan Harold39b5df42017-08-02 18:45:25 -0700208 };
209
Jonathan Basseric6461a62017-08-31 14:47:33 -0700210 // Container for the content of an XFRMA_ALG_AUTH_TRUNC netlink attribute.
Nathan Harold39b5df42017-08-02 18:45:25 -0700211 // Exposed for testing
212 struct nlattr_algo_auth {
213 nlattr hdr;
214 xfrm_algo_auth auth;
Benedict Wong4f60ee12017-10-10 12:27:25 -0700215 uint8_t key[MAX_KEY_LENGTH];
Nathan Harold39b5df42017-08-02 18:45:25 -0700216 };
217
Jonathan Basseric6461a62017-08-31 14:47:33 -0700218 // Container for the content of an XFRMA_TMPL netlink attribute.
Nathan Harold39b5df42017-08-02 18:45:25 -0700219 // Exposed for testing
Benedict Wongbe65b432017-08-22 21:43:14 -0700220 struct nlattr_algo_aead {
221 nlattr hdr;
222 xfrm_algo_aead aead;
Benedict Wong4f60ee12017-10-10 12:27:25 -0700223 uint8_t key[MAX_KEY_LENGTH];
Benedict Wongbe65b432017-08-22 21:43:14 -0700224 };
225
226 // Exposed for testing
Nathan Harold39b5df42017-08-02 18:45:25 -0700227 struct nlattr_user_tmpl {
228 nlattr hdr;
229 xfrm_user_tmpl tmpl;
230 };
231
Jonathan Basseric6461a62017-08-31 14:47:33 -0700232 // Container for the content of an XFRMA_ENCAP netlink attribute.
Nathan Harold39b5df42017-08-02 18:45:25 -0700233 // Exposed for testing
234 struct nlattr_encap_tmpl {
235 nlattr hdr;
236 xfrm_encap_tmpl tmpl;
237 };
238
Di Lu2ccb3e52018-01-03 16:19:20 -0800239 // Container for the content of an XFRMA_MARK netlink attribute.
240 // Exposed for testing
241 struct nlattr_xfrm_mark {
242 nlattr hdr;
243 xfrm_mark mark;
244 };
245
Benedict Wong96abf482018-01-22 13:56:41 -0800246 // Container for the content of an XFRMA_OUTPUT_MARK netlink attribute.
247 // Exposed for testing
248 struct nlattr_xfrm_output_mark {
249 nlattr hdr;
250 __u32 outputMark;
251 };
252
Benedict Wong319f17e2018-05-15 17:06:44 -0700253 // Container for the content of an XFRMA_IF_ID netlink attribute.
254 // Exposed for testing
255 struct nlattr_xfrm_interface_id {
256 nlattr hdr;
257 __u32 if_id;
258 };
259
260 // Exposed for testing
261 struct nlattr_payload_u32 {
262 nlattr hdr;
263 uint32_t value;
264 };
265
266 private:
Nathan Harolde2dd4c72017-04-19 11:09:11 -0700267/*
Bernie Innocentiedf68352018-07-05 17:50:38 +0900268 * This is a workaround for a kernel bug in the 32bit netlink compat layer
269 * that has been present on x86_64 kernels since 2010 with no fix on the
270 * horizon.
271 *
Nathan Harolde2dd4c72017-04-19 11:09:11 -0700272 * Below is a redefinition of the xfrm_usersa_info struct that is part
273 * of the Linux uapi <linux/xfrm.h> to align the structures to a 64-bit
274 * boundary.
Bernie Innocentiedf68352018-07-05 17:50:38 +0900275 *
276 * Note that we turn this on for all x86 32bit targets, under the assumption
277 * that nowadays all x86 targets are running 64bit kernels.
Nathan Harolde2dd4c72017-04-19 11:09:11 -0700278 */
Bernie Innocentiedf68352018-07-05 17:50:38 +0900279#if defined(__i386__)
Nathan Harolde2dd4c72017-04-19 11:09:11 -0700280 // Shadow the kernel definition of xfrm_usersa_info with a 64-bit aligned version
281 struct xfrm_usersa_info : ::xfrm_usersa_info {
282 } __attribute__((aligned(8)));
283 // Shadow the kernel's version, using the aligned version of xfrm_usersa_info
284 struct xfrm_userspi_info {
285 struct xfrm_usersa_info info;
286 __u32 min;
287 __u32 max;
288 };
Bjoern Johansson83977442018-05-25 16:55:28 -0700289 struct xfrm_userpolicy_info : ::xfrm_userpolicy_info {
290 } __attribute__((aligned(8)));
Nathan Harolde2dd4c72017-04-19 11:09:11 -0700291
292 /*
293 * Anyone who encounters a failure when sending netlink messages should look here
294 * first. Hitting the static_assert() below should be a strong hint that Android
295 * IPsec will probably not work with your current settings.
296 *
297 * Again, experimentally determined, the "flags" field should be the first byte in
298 * the final word of the xfrm_usersa_info struct. The check validates the size of
299 * the padding to be 7.
300 *
301 * This padding is verified to be correct on gcc/x86_64 kernel, and clang/x86 userspace.
302 */
303 static_assert(sizeof(::xfrm_usersa_info) % 8 != 0, "struct xfrm_usersa_info has changed "
304 "alignment. Please consider whether this "
305 "patch is needed.");
306 static_assert(sizeof(xfrm_usersa_info) - offsetof(xfrm_usersa_info, flags) == 8,
307 "struct xfrm_usersa_info probably misaligned with kernel struct.");
308 static_assert(sizeof(xfrm_usersa_info) % 8 == 0, "struct xfrm_usersa_info_t is not 64-bit "
309 "aligned. Please consider whether this patch "
310 "is needed.");
311 static_assert(sizeof(::xfrm_userspi_info) - sizeof(::xfrm_usersa_info) ==
312 sizeof(xfrm_userspi_info) - sizeof(xfrm_usersa_info),
313 "struct xfrm_userspi_info has changed and does not match the kernel struct.");
Bjoern Johansson83977442018-05-25 16:55:28 -0700314 static_assert(sizeof(::xfrm_userpolicy_info) % 8 != 0,
315 "struct xfrm_userpolicy_info has changed "
316 "alignment. Please consider whether this "
317 "patch is needed.");
318 static_assert(sizeof(xfrm_userpolicy_info) - offsetof(xfrm_userpolicy_info, share) == 5,
319 "struct xfrm_userpolicy_info probably misaligned with kernel struct.");
320 static_assert(sizeof(xfrm_userpolicy_info) % 8 == 0,
321 "struct xfrm_userpolicy_info is not 64-bit "
322 "aligned. Please consider whether this patch "
323 "is needed.");
Nathan Harolde2dd4c72017-04-19 11:09:11 -0700324#endif
325
Benedict Wonga04ffa72018-05-09 21:42:42 -0700326 // helper functions for filling in the XfrmCommonInfo (and XfrmSaInfo) structure
327 static netdutils::Status fillXfrmCommonInfo(const std::string& sourceAddress,
328 const std::string& destinationAddress, int32_t spi,
329 int32_t markValue, int32_t markMask,
330 int32_t transformId, XfrmCommonInfo* info);
331 static netdutils::Status fillXfrmCommonInfo(int32_t spi, int32_t markValue, int32_t markMask,
332 int32_t transformId, XfrmCommonInfo* info);
Nathan Harold1a371532017-01-30 12:30:48 -0800333
334 // Top level functions for managing a Transport Mode Transform
ludi6e8eccd2017-08-14 14:40:37 -0700335 static netdutils::Status addTransportModeTransform(const XfrmSaInfo& record);
Nathan Harold1a371532017-01-30 12:30:48 -0800336 static int removeTransportModeTransform(const XfrmSaInfo& record);
337
338 // TODO(messagerefactor): FACTOR OUT ALL MESSAGE BUILDING CODE BELOW HERE
339 // Shared between SA and SP
Benedict Wonga04ffa72018-05-09 21:42:42 -0700340 static void fillXfrmSelector(const int record, xfrm_selector* selector);
Nathan Harold1a371532017-01-30 12:30:48 -0800341
342 // Shared between Transport and Tunnel Mode
343 static int fillNlAttrXfrmAlgoEnc(const XfrmAlgo& in_algo, nlattr_algo_crypt* algo);
344 static int fillNlAttrXfrmAlgoAuth(const XfrmAlgo& in_algo, nlattr_algo_auth* algo);
Benedict Wongbe65b432017-08-22 21:43:14 -0700345 static int fillNlAttrXfrmAlgoAead(const XfrmAlgo& in_algo, nlattr_algo_aead* algo);
Nathan Harold420ceac2017-04-05 19:36:59 -0700346 static int fillNlAttrXfrmEncapTmpl(const XfrmSaInfo& record, nlattr_encap_tmpl* tmpl);
Nathan Harold1a371532017-01-30 12:30:48 -0800347
Di Lu0e16b5e2018-01-12 10:37:53 -0800348 // Functions for updating a Transport Mode SA
349 static netdutils::Status updateSecurityAssociation(const XfrmSaInfo& record,
manojboopathi4d2d6f12017-12-06 11:11:31 -0800350 const XfrmSocket& sock);
Nathan Harold1a371532017-01-30 12:30:48 -0800351 static int fillUserSaInfo(const XfrmSaInfo& record, xfrm_usersa_info* usersa);
352
353 // Functions for deleting a Transport Mode SA
Benedict Wonga04ffa72018-05-09 21:42:42 -0700354 static netdutils::Status deleteSecurityAssociation(const XfrmCommonInfo& record,
ludi6e8eccd2017-08-14 14:40:37 -0700355 const XfrmSocket& sock);
Benedict Wonga04ffa72018-05-09 21:42:42 -0700356 static int fillUserSaId(const XfrmCommonInfo& record, xfrm_usersa_id* said);
357 static int fillUserTemplate(const XfrmSpInfo& record, xfrm_user_tmpl* tmpl);
ludi771b8002017-11-20 15:09:05 -0800358
Benedict Wonga04ffa72018-05-09 21:42:42 -0700359 static int fillUserSpInfo(const XfrmSpInfo& record, XfrmDirection direction,
360 xfrm_userpolicy_info* usersp);
361 static int fillNlAttrUserTemplate(const XfrmSpInfo& record, nlattr_user_tmpl* tmpl);
362 static int fillUserPolicyId(const XfrmSpInfo& record, XfrmDirection direction,
ludi771b8002017-11-20 15:09:05 -0800363 xfrm_userpolicy_id* policy_id);
Benedict Wonga04ffa72018-05-09 21:42:42 -0700364 static int fillNlAttrXfrmMark(const XfrmCommonInfo& record, nlattr_xfrm_mark* mark);
Benedict Wongd8b6a382018-09-18 17:16:10 -0700365 static int fillNlAttrXfrmOutputMark(const __u32 underlyingNetId,
Benedict Wong96abf482018-01-22 13:56:41 -0800366 nlattr_xfrm_output_mark* output_mark);
Benedict Wong319f17e2018-05-15 17:06:44 -0700367 static int fillNlAttrXfrmIntfId(const __u32 intf_id_value, nlattr_xfrm_interface_id* intf_id);
Nathan Harold1a371532017-01-30 12:30:48 -0800368
ludi6e8eccd2017-08-14 14:40:37 -0700369 static netdutils::Status allocateSpi(const XfrmSaInfo& record, uint32_t minSpi, uint32_t maxSpi,
370 uint32_t* outSpi, const XfrmSocket& sock);
Nathan Harold1a371532017-01-30 12:30:48 -0800371
Benedict Wonga04ffa72018-05-09 21:42:42 -0700372 static netdutils::Status processSecurityPolicy(int32_t transformId, int32_t selAddrFamily,
373 int32_t direction,
Benedict Wongad600cb2018-05-14 17:22:35 -0700374 const std::string& tmplSrcAddress,
375 const std::string& tmplDstAddress, int32_t spi,
Nathan Harold21299f72018-03-16 20:13:03 -0700376 int32_t markValue, int32_t markMask,
377 int32_t msgType);
Benedict Wonga04ffa72018-05-09 21:42:42 -0700378 static netdutils::Status updateTunnelModeSecurityPolicy(const XfrmSpInfo& record,
ludi771b8002017-11-20 15:09:05 -0800379 const XfrmSocket& sock,
380 XfrmDirection direction,
381 uint16_t msgType);
Benedict Wonga04ffa72018-05-09 21:42:42 -0700382 static netdutils::Status deleteTunnelModeSecurityPolicy(const XfrmSpInfo& record,
ludi771b8002017-11-20 15:09:05 -0800383 const XfrmSocket& sock,
384 XfrmDirection direction);
Nathan Harold21299f72018-03-16 20:13:03 -0700385 static netdutils::Status flushInterfaces();
386 static netdutils::Status flushSaDb(const XfrmSocket& s);
387 static netdutils::Status flushPolicyDb(const XfrmSocket& s);
388
Benedict Wong319f17e2018-05-15 17:06:44 -0700389 static netdutils::Status ipSecAddXfrmInterface(const std::string& deviceName,
390 int32_t underlyingInterface, int32_t interfaceId,
391 uint16_t flags);
392 static netdutils::Status ipSecAddVirtualTunnelInterface(const std::string& deviceName,
393 const std::string& localAddress,
394 const std::string& remoteAddress,
395 int32_t ikey, int32_t okey,
396 uint16_t flags);
Nathan Harold1a371532017-01-30 12:30:48 -0800397 // END TODO(messagerefactor)
398};
399
400} // namespace net
401} // namespace android
402
403#endif /* !defined(XFRM_CONTROLLER_H) */