blob: 15eef3d7f02f308191d522888caae2c8bea4fe2b [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"
Luke Huangb257d612019-03-14 21:19:13 +080035#include "netdutils/DumpWriter.h"
manojboopathi8707f232018-01-02 14:45:47 -080036#include "netdutils/Slice.h"
ludi6e8eccd2017-08-14 14:40:37 -070037#include "netdutils/Status.h"
Bernie Innocenti97f388f2018-10-16 19:17:08 +090038#include "sysutils/SocketClient.h"
Nathan Harold1a371532017-01-30 12:30:48 -080039
40namespace android {
41namespace net {
42
Nathan Harold39b5df42017-08-02 18:45:25 -070043// Exposed for testing
44extern const uint32_t ALGO_MASK_AUTH_ALL;
45// Exposed for testing
46extern const uint32_t ALGO_MASK_CRYPT_ALL;
47// Exposed for testing
Benedict Wongbe65b432017-08-22 21:43:14 -070048extern const uint32_t ALGO_MASK_AEAD_ALL;
49// Exposed for testing
Nathan Harold39b5df42017-08-02 18:45:25 -070050extern const uint8_t REPLAY_WINDOW_SIZE;
51
Nathan Harold1a371532017-01-30 12:30:48 -080052// Suggest we avoid the smallest and largest ints
53class XfrmMessage;
54class TransportModeSecurityAssociation;
55
56class XfrmSocket {
57public:
Maciej Żenczykowskif4d444e2020-05-01 01:30:26 +000058 // called from destructor and thus cannot be virtual
59 void close() {
Nathan Harold420ceac2017-04-05 19:36:59 -070060 if (mSock >= 0) {
Nathan Harold1a371532017-01-30 12:30:48 -080061 ::close(mSock);
62 }
63 mSock = -1;
64 }
65
ludi6e8eccd2017-08-14 14:40:37 -070066 virtual netdutils::Status open() = 0;
Nathan Harold1a371532017-01-30 12:30:48 -080067
68 virtual ~XfrmSocket() { close(); }
69
ludie51e3862017-08-15 19:28:12 -070070 // Sends the netlink message contained in iovecs. This populates iovecs[0] with
71 // a valid netlink message header.
ludi6e8eccd2017-08-14 14:40:37 -070072 virtual netdutils::Status sendMessage(uint16_t nlMsgType, uint16_t nlMsgFlags,
73 uint16_t nlMsgSeqNum,
74 std::vector<iovec>* iovecs) const = 0;
Nathan Harold1a371532017-01-30 12:30:48 -080075
76protected:
77 int mSock;
78};
79
80enum struct XfrmDirection : uint8_t {
81 IN = XFRM_POLICY_IN,
82 OUT = XFRM_POLICY_OUT,
83 FORWARD = XFRM_POLICY_FWD,
84 MASK = XFRM_POLICY_MASK,
85};
86
87enum struct XfrmMode : uint8_t {
88 TRANSPORT = XFRM_MODE_TRANSPORT,
89 TUNNEL = XFRM_MODE_TUNNEL,
90};
91
Nathan Harold420ceac2017-04-05 19:36:59 -070092enum struct XfrmEncapType : uint16_t {
93 NONE = 0,
94 ESPINUDP_NON_IKE = UDP_ENCAP_ESPINUDP_NON_IKE,
95 ESPINUDP = UDP_ENCAP_ESPINUDP
96};
97
Nathan Harold1a371532017-01-30 12:30:48 -080098struct XfrmAlgo {
99 std::string name;
100 std::vector<uint8_t> key;
101 uint16_t truncLenBits;
102};
103
Nathan Harold420ceac2017-04-05 19:36:59 -0700104struct XfrmEncap {
105 XfrmEncapType type;
106 uint16_t srcPort;
107 uint16_t dstPort;
108};
109
Nathan Harold7441c692017-12-12 21:25:01 -0800110// minimally sufficient structure to match either an SA or a Policy
Benedict Wonga04ffa72018-05-09 21:42:42 -0700111struct XfrmCommonInfo {
Nathan Harold1a371532017-01-30 12:30:48 -0800112 xfrm_address_t dstAddr; // network order
113 xfrm_address_t srcAddr;
114 int addrFamily; // AF_INET or AF_INET6
115 int transformId; // requestId
116 int spi;
Di Lu2ccb3e52018-01-03 16:19:20 -0800117 xfrm_mark mark;
Benedict Wonga450e722018-05-07 10:29:02 -0700118 int xfrm_if_id;
Nathan Harold1a371532017-01-30 12:30:48 -0800119};
120
Benedict Wonga04ffa72018-05-09 21:42:42 -0700121struct XfrmSaInfo : XfrmCommonInfo {
Nathan Harold1a371532017-01-30 12:30:48 -0800122 XfrmAlgo auth;
123 XfrmAlgo crypt;
Benedict Wongbe65b432017-08-22 21:43:14 -0700124 XfrmAlgo aead;
Nathan Harold1a371532017-01-30 12:30:48 -0800125 int netId;
126 XfrmMode mode;
Nathan Harold420ceac2017-04-05 19:36:59 -0700127 XfrmEncap encap;
Nathan Harold1a371532017-01-30 12:30:48 -0800128};
129
Benedict Wonga04ffa72018-05-09 21:42:42 -0700130struct XfrmSpInfo : XfrmSaInfo {
131 // Address family in XfrmCommonInfo used for template/SA matching, need separate addrFamily
132 // for selectors
133 int selAddrFamily; // AF_INET or AF_INET6
134};
135
Nathan Haroldc8737b82019-02-25 09:45:38 -0800136/*
137 * This is a workaround for a kernel bug in the 32bit netlink compat layer
138 * that has been present on x86_64 kernels since 2010 with no fix on the
139 * horizon.
140 *
141 * Below is a redefinition of the xfrm_usersa_info struct that is part
142 * of the Linux uapi <linux/xfrm.h> to align the structures to a 64-bit
143 * boundary.
144 *
145 * Note that we turn this on for all x86 32bit targets, under the assumption
146 * that nowadays all x86 targets are running 64bit kernels.
147 */
148#if defined(__i386__)
149// Shadow the kernel definition of xfrm_usersa_info with a 64-bit aligned version
150struct xfrm_usersa_info : ::xfrm_usersa_info {
151} __attribute__((aligned(8)));
152// Shadow the kernel's version, using the aligned version of xfrm_usersa_info
153struct xfrm_userspi_info {
154 struct xfrm_usersa_info info;
155 __u32 min;
156 __u32 max;
157};
158struct xfrm_userpolicy_info : ::xfrm_userpolicy_info {
159} __attribute__((aligned(8)));
160
161/*
162 * Anyone who encounters a failure when sending netlink messages should look here
163 * first. Hitting the static_assert() below should be a strong hint that Android
164 * IPsec will probably not work with your current settings.
165 *
166 * Again, experimentally determined, the "flags" field should be the first byte in
167 * the final word of the xfrm_usersa_info struct. The check validates the size of
168 * the padding to be 7.
169 *
170 * This padding is verified to be correct on gcc/x86_64 kernel, and clang/x86 userspace.
171 */
172static_assert(sizeof(::xfrm_usersa_info) % 8 != 0,
173 "struct xfrm_usersa_info has changed "
174 "alignment. Please consider whether this "
175 "patch is needed.");
176static_assert(sizeof(xfrm_usersa_info) - offsetof(xfrm_usersa_info, flags) == 8,
177 "struct xfrm_usersa_info probably misaligned with kernel struct.");
178static_assert(sizeof(xfrm_usersa_info) % 8 == 0,
179 "struct xfrm_usersa_info_t is not 64-bit "
180 "aligned. Please consider whether this patch "
181 "is needed.");
182static_assert(sizeof(::xfrm_userspi_info) - sizeof(::xfrm_usersa_info) ==
183 sizeof(xfrm_userspi_info) - sizeof(xfrm_usersa_info),
184 "struct xfrm_userspi_info has changed and does not match the kernel struct.");
185static_assert(sizeof(::xfrm_userpolicy_info) % 8 != 0,
186 "struct xfrm_userpolicy_info has changed "
187 "alignment. Please consider whether this "
188 "patch is needed.");
189static_assert(sizeof(xfrm_userpolicy_info) - offsetof(xfrm_userpolicy_info, share) == 5,
190 "struct xfrm_userpolicy_info probably misaligned with kernel struct.");
191static_assert(sizeof(xfrm_userpolicy_info) % 8 == 0,
192 "struct xfrm_userpolicy_info is not 64-bit "
193 "aligned. Please consider whether this patch "
194 "is needed.");
195#endif
196
Nathan Harold1a371532017-01-30 12:30:48 -0800197class XfrmController {
198public:
199 XfrmController();
200
Benedict Wongaf855432018-05-10 17:07:37 -0700201 // Initializer to override XFRM-I support for unit-testing purposes
202 explicit XfrmController(bool xfrmIntfSupport);
203
Nathan Harold21299f72018-03-16 20:13:03 -0700204 static netdutils::Status Init();
Benedict Wongb2daefb2017-12-06 22:05:46 -0800205
Luke Huange203a152018-11-23 11:47:28 +0800206 static netdutils::Status ipSecSetEncapSocketOwner(int socketFd, int newUid, uid_t callerUid);
Nathan Harold1a371532017-01-30 12:30:48 -0800207
Nathan Harold21299f72018-03-16 20:13:03 -0700208 static netdutils::Status ipSecAllocateSpi(int32_t transformId, const std::string& localAddress,
209 const std::string& remoteAddress, int32_t inSpi,
210 int32_t* outSpi);
211
212 static netdutils::Status ipSecAddSecurityAssociation(
Benedict Wonga450e722018-05-07 10:29:02 -0700213 int32_t transformId, int32_t mode, const std::string& sourceAddress,
214 const std::string& destinationAddress, int32_t underlyingNetId, int32_t spi,
215 int32_t markValue, int32_t markMask, const std::string& authAlgo,
216 const std::vector<uint8_t>& authKey, int32_t authTruncBits,
217 const std::string& cryptAlgo, const std::vector<uint8_t>& cryptKey,
218 int32_t cryptTruncBits, const std::string& aeadAlgo,
219 const std::vector<uint8_t>& aeadKey, int32_t aeadIcvBits, int32_t encapType,
220 int32_t encapLocalPort, int32_t encapRemotePort, int32_t xfrmInterfaceId);
Nathan Harold1a371532017-01-30 12:30:48 -0800221
Nathan Harold21299f72018-03-16 20:13:03 -0700222 static netdutils::Status ipSecDeleteSecurityAssociation(int32_t transformId,
223 const std::string& sourceAddress,
224 const std::string& destinationAddress,
225 int32_t spi, int32_t markValue,
Benedict Wonga450e722018-05-07 10:29:02 -0700226 int32_t markMask,
227 int32_t xfrmInterfaceId);
Nathan Harold1a371532017-01-30 12:30:48 -0800228
Luke Huange203a152018-11-23 11:47:28 +0800229 static netdutils::Status ipSecApplyTransportModeTransform(int socketFd, int32_t transformId,
230 int32_t direction,
231 const std::string& localAddress,
232 const std::string& remoteAddress,
233 int32_t spi);
Nathan Harold1a371532017-01-30 12:30:48 -0800234
Luke Huange203a152018-11-23 11:47:28 +0800235 static netdutils::Status ipSecRemoveTransportModeTransform(int socketFd);
Nathan Harold1a371532017-01-30 12:30:48 -0800236
Benedict Wonga04ffa72018-05-09 21:42:42 -0700237 static netdutils::Status ipSecAddSecurityPolicy(int32_t transformId, int32_t selAddrFamily,
238 int32_t direction,
Benedict Wongad600cb2018-05-14 17:22:35 -0700239 const std::string& tmplSrcAddress,
240 const std::string& tmplDstAddress, int32_t spi,
Benedict Wonga450e722018-05-07 10:29:02 -0700241 int32_t markValue, int32_t markMask,
242 int32_t xfrmInterfaceId);
ludi771b8002017-11-20 15:09:05 -0800243
Benedict Wonga04ffa72018-05-09 21:42:42 -0700244 static netdutils::Status ipSecUpdateSecurityPolicy(int32_t transformId, int32_t selAddrFamily,
245 int32_t direction,
Benedict Wongad600cb2018-05-14 17:22:35 -0700246 const std::string& tmplSrcAddress,
247 const std::string& tmplDstAddress,
Nathan Harold21299f72018-03-16 20:13:03 -0700248 int32_t spi, int32_t markValue,
Benedict Wonga450e722018-05-07 10:29:02 -0700249 int32_t markMask, int32_t xfrmInterfaceId);
ludi771b8002017-11-20 15:09:05 -0800250
Benedict Wonga04ffa72018-05-09 21:42:42 -0700251 static netdutils::Status ipSecDeleteSecurityPolicy(int32_t transformId, int32_t selAddrFamily,
252 int32_t direction, int32_t markValue,
Benedict Wonga450e722018-05-07 10:29:02 -0700253 int32_t markMask, int32_t xfrmInterfaceId);
ludi771b8002017-11-20 15:09:05 -0800254
Benedict Wong319f17e2018-05-15 17:06:44 -0700255 static netdutils::Status ipSecAddTunnelInterface(const std::string& deviceName,
256 const std::string& localAddress,
257 const std::string& remoteAddress, int32_t ikey,
Benedict Wonga450e722018-05-07 10:29:02 -0700258 int32_t okey, int32_t interfaceId,
259 bool isUpdate);
manojboopathi8707f232018-01-02 14:45:47 -0800260
Benedict Wong319f17e2018-05-15 17:06:44 -0700261 static netdutils::Status ipSecRemoveTunnelInterface(const std::string& deviceName);
manojboopathi8707f232018-01-02 14:45:47 -0800262
Luke Huangb257d612019-03-14 21:19:13 +0800263 void dump(netdutils::DumpWriter& dw);
Benedict Wongaf855432018-05-10 17:07:37 -0700264
Jonathan Basseric6461a62017-08-31 14:47:33 -0700265 // Some XFRM netlink attributes comprise a header, a struct, and some data
266 // after the struct. We wrap all of those in one struct for easier
267 // marshalling. The structs below must be ABI compatible with the kernel and
268 // are composed from kernel structures; thus, they use the kernel naming
269 // convention.
270
Nathan Harold39b5df42017-08-02 18:45:25 -0700271 // Exposed for testing
Benedict Wong4f60ee12017-10-10 12:27:25 -0700272 static constexpr size_t MAX_KEY_LENGTH = 128;
Nathan Harold39b5df42017-08-02 18:45:25 -0700273
Jonathan Basseric6461a62017-08-31 14:47:33 -0700274 // Container for the content of an XFRMA_ALG_CRYPT netlink attribute.
Nathan Harold39b5df42017-08-02 18:45:25 -0700275 // Exposed for testing
276 struct nlattr_algo_crypt {
277 nlattr hdr;
278 xfrm_algo crypt;
Benedict Wong4f60ee12017-10-10 12:27:25 -0700279 uint8_t key[MAX_KEY_LENGTH];
Nathan Harold39b5df42017-08-02 18:45:25 -0700280 };
281
Jonathan Basseric6461a62017-08-31 14:47:33 -0700282 // Container for the content of an XFRMA_ALG_AUTH_TRUNC netlink attribute.
Nathan Harold39b5df42017-08-02 18:45:25 -0700283 // Exposed for testing
284 struct nlattr_algo_auth {
285 nlattr hdr;
286 xfrm_algo_auth auth;
Benedict Wong4f60ee12017-10-10 12:27:25 -0700287 uint8_t key[MAX_KEY_LENGTH];
Nathan Harold39b5df42017-08-02 18:45:25 -0700288 };
289
Jonathan Basseric6461a62017-08-31 14:47:33 -0700290 // Container for the content of an XFRMA_TMPL netlink attribute.
Nathan Harold39b5df42017-08-02 18:45:25 -0700291 // Exposed for testing
Benedict Wongbe65b432017-08-22 21:43:14 -0700292 struct nlattr_algo_aead {
293 nlattr hdr;
294 xfrm_algo_aead aead;
Benedict Wong4f60ee12017-10-10 12:27:25 -0700295 uint8_t key[MAX_KEY_LENGTH];
Benedict Wongbe65b432017-08-22 21:43:14 -0700296 };
297
298 // Exposed for testing
Nathan Harold39b5df42017-08-02 18:45:25 -0700299 struct nlattr_user_tmpl {
300 nlattr hdr;
301 xfrm_user_tmpl tmpl;
302 };
303
Jonathan Basseric6461a62017-08-31 14:47:33 -0700304 // Container for the content of an XFRMA_ENCAP netlink attribute.
Nathan Harold39b5df42017-08-02 18:45:25 -0700305 // Exposed for testing
306 struct nlattr_encap_tmpl {
307 nlattr hdr;
308 xfrm_encap_tmpl tmpl;
309 };
310
Di Lu2ccb3e52018-01-03 16:19:20 -0800311 // Container for the content of an XFRMA_MARK netlink attribute.
312 // Exposed for testing
313 struct nlattr_xfrm_mark {
314 nlattr hdr;
315 xfrm_mark mark;
316 };
317
Benedict Wong96abf482018-01-22 13:56:41 -0800318 // Container for the content of an XFRMA_OUTPUT_MARK netlink attribute.
319 // Exposed for testing
320 struct nlattr_xfrm_output_mark {
321 nlattr hdr;
322 __u32 outputMark;
323 };
324
Benedict Wong319f17e2018-05-15 17:06:44 -0700325 // Container for the content of an XFRMA_IF_ID netlink attribute.
326 // Exposed for testing
327 struct nlattr_xfrm_interface_id {
328 nlattr hdr;
329 __u32 if_id;
330 };
331
332 // Exposed for testing
333 struct nlattr_payload_u32 {
334 nlattr hdr;
335 uint32_t value;
336 };
337
338 private:
Benedict Wongaf855432018-05-10 17:07:37 -0700339 static bool isXfrmIntfSupported();
340
Benedict Wonga04ffa72018-05-09 21:42:42 -0700341 // helper functions for filling in the XfrmCommonInfo (and XfrmSaInfo) structure
342 static netdutils::Status fillXfrmCommonInfo(const std::string& sourceAddress,
343 const std::string& destinationAddress, int32_t spi,
344 int32_t markValue, int32_t markMask,
Benedict Wonga450e722018-05-07 10:29:02 -0700345 int32_t transformId, int32_t xfrmInterfaceId,
346 XfrmCommonInfo* info);
Benedict Wonga04ffa72018-05-09 21:42:42 -0700347 static netdutils::Status fillXfrmCommonInfo(int32_t spi, int32_t markValue, int32_t markMask,
Benedict Wonga450e722018-05-07 10:29:02 -0700348 int32_t transformId, int32_t xfrmInterfaceId,
349 XfrmCommonInfo* info);
Nathan Harold1a371532017-01-30 12:30:48 -0800350
351 // Top level functions for managing a Transport Mode Transform
ludi6e8eccd2017-08-14 14:40:37 -0700352 static netdutils::Status addTransportModeTransform(const XfrmSaInfo& record);
Nathan Harold1a371532017-01-30 12:30:48 -0800353 static int removeTransportModeTransform(const XfrmSaInfo& record);
354
355 // TODO(messagerefactor): FACTOR OUT ALL MESSAGE BUILDING CODE BELOW HERE
356 // Shared between SA and SP
Benedict Wonga04ffa72018-05-09 21:42:42 -0700357 static void fillXfrmSelector(const int record, xfrm_selector* selector);
Nathan Harold1a371532017-01-30 12:30:48 -0800358
359 // Shared between Transport and Tunnel Mode
360 static int fillNlAttrXfrmAlgoEnc(const XfrmAlgo& in_algo, nlattr_algo_crypt* algo);
361 static int fillNlAttrXfrmAlgoAuth(const XfrmAlgo& in_algo, nlattr_algo_auth* algo);
Benedict Wongbe65b432017-08-22 21:43:14 -0700362 static int fillNlAttrXfrmAlgoAead(const XfrmAlgo& in_algo, nlattr_algo_aead* algo);
Nathan Harold420ceac2017-04-05 19:36:59 -0700363 static int fillNlAttrXfrmEncapTmpl(const XfrmSaInfo& record, nlattr_encap_tmpl* tmpl);
Nathan Harold1a371532017-01-30 12:30:48 -0800364
Di Lu0e16b5e2018-01-12 10:37:53 -0800365 // Functions for updating a Transport Mode SA
366 static netdutils::Status updateSecurityAssociation(const XfrmSaInfo& record,
manojboopathi4d2d6f12017-12-06 11:11:31 -0800367 const XfrmSocket& sock);
Nathan Harold1a371532017-01-30 12:30:48 -0800368 static int fillUserSaInfo(const XfrmSaInfo& record, xfrm_usersa_info* usersa);
369
370 // Functions for deleting a Transport Mode SA
Benedict Wonga04ffa72018-05-09 21:42:42 -0700371 static netdutils::Status deleteSecurityAssociation(const XfrmCommonInfo& record,
ludi6e8eccd2017-08-14 14:40:37 -0700372 const XfrmSocket& sock);
Benedict Wonga04ffa72018-05-09 21:42:42 -0700373 static int fillUserSaId(const XfrmCommonInfo& record, xfrm_usersa_id* said);
Maciej Żenczykowskie1161a42020-04-23 13:23:26 +0000374 static void fillUserTemplate(const XfrmSpInfo& record, xfrm_user_tmpl* tmpl);
ludi771b8002017-11-20 15:09:05 -0800375
Benedict Wonga04ffa72018-05-09 21:42:42 -0700376 static int fillUserSpInfo(const XfrmSpInfo& record, XfrmDirection direction,
377 xfrm_userpolicy_info* usersp);
378 static int fillNlAttrUserTemplate(const XfrmSpInfo& record, nlattr_user_tmpl* tmpl);
379 static int fillUserPolicyId(const XfrmSpInfo& record, XfrmDirection direction,
ludi771b8002017-11-20 15:09:05 -0800380 xfrm_userpolicy_id* policy_id);
Benedict Wonga04ffa72018-05-09 21:42:42 -0700381 static int fillNlAttrXfrmMark(const XfrmCommonInfo& record, nlattr_xfrm_mark* mark);
Benedict Wongd8b6a382018-09-18 17:16:10 -0700382 static int fillNlAttrXfrmOutputMark(const __u32 underlyingNetId,
Benedict Wong96abf482018-01-22 13:56:41 -0800383 nlattr_xfrm_output_mark* output_mark);
Benedict Wong319f17e2018-05-15 17:06:44 -0700384 static int fillNlAttrXfrmIntfId(const __u32 intf_id_value, nlattr_xfrm_interface_id* intf_id);
Nathan Harold1a371532017-01-30 12:30:48 -0800385
ludi6e8eccd2017-08-14 14:40:37 -0700386 static netdutils::Status allocateSpi(const XfrmSaInfo& record, uint32_t minSpi, uint32_t maxSpi,
387 uint32_t* outSpi, const XfrmSocket& sock);
Nathan Harold1a371532017-01-30 12:30:48 -0800388
Benedict Wonga04ffa72018-05-09 21:42:42 -0700389 static netdutils::Status processSecurityPolicy(int32_t transformId, int32_t selAddrFamily,
390 int32_t direction,
Benedict Wongad600cb2018-05-14 17:22:35 -0700391 const std::string& tmplSrcAddress,
392 const std::string& tmplDstAddress, int32_t spi,
Nathan Harold21299f72018-03-16 20:13:03 -0700393 int32_t markValue, int32_t markMask,
Benedict Wonga450e722018-05-07 10:29:02 -0700394 int32_t xfrmInterfaceId, int32_t msgType);
Benedict Wonga04ffa72018-05-09 21:42:42 -0700395 static netdutils::Status updateTunnelModeSecurityPolicy(const XfrmSpInfo& record,
ludi771b8002017-11-20 15:09:05 -0800396 const XfrmSocket& sock,
397 XfrmDirection direction,
398 uint16_t msgType);
Benedict Wonga04ffa72018-05-09 21:42:42 -0700399 static netdutils::Status deleteTunnelModeSecurityPolicy(const XfrmSpInfo& record,
ludi771b8002017-11-20 15:09:05 -0800400 const XfrmSocket& sock,
401 XfrmDirection direction);
Nathan Harold21299f72018-03-16 20:13:03 -0700402 static netdutils::Status flushInterfaces();
403 static netdutils::Status flushSaDb(const XfrmSocket& s);
404 static netdutils::Status flushPolicyDb(const XfrmSocket& s);
405
Benedict Wong319f17e2018-05-15 17:06:44 -0700406 static netdutils::Status ipSecAddXfrmInterface(const std::string& deviceName,
Benedict Wongaf855432018-05-10 17:07:37 -0700407 int32_t interfaceId, uint16_t flags);
Benedict Wong319f17e2018-05-15 17:06:44 -0700408 static netdutils::Status ipSecAddVirtualTunnelInterface(const std::string& deviceName,
409 const std::string& localAddress,
410 const std::string& remoteAddress,
411 int32_t ikey, int32_t okey,
412 uint16_t flags);
Nathan Harold1a371532017-01-30 12:30:48 -0800413 // END TODO(messagerefactor)
414};
415
416} // namespace net
417} // namespace android
418
419#endif /* !defined(XFRM_CONTROLLER_H) */