blob: 798284c95dfe88f5fcb912b56f243cc415f00ae2 [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;
Benedict Wongea2001b2023-06-15 20:18:43 +000051// Exposed for testing
52extern const uint32_t REPLAY_WINDOW_SIZE_ESN;
Nathan Harold39b5df42017-08-02 18:45:25 -070053
Nathan Harold1a371532017-01-30 12:30:48 -080054// Suggest we avoid the smallest and largest ints
55class XfrmMessage;
56class TransportModeSecurityAssociation;
57
58class XfrmSocket {
59public:
Maciej Żenczykowski8dc60de2020-04-30 16:44:50 -070060 // called from destructor and thus cannot be virtual
61 void close() {
Nathan Harold420ceac2017-04-05 19:36:59 -070062 if (mSock >= 0) {
Nathan Harold1a371532017-01-30 12:30:48 -080063 ::close(mSock);
64 }
65 mSock = -1;
66 }
67
ludi6e8eccd2017-08-14 14:40:37 -070068 virtual netdutils::Status open() = 0;
Nathan Harold1a371532017-01-30 12:30:48 -080069
70 virtual ~XfrmSocket() { close(); }
71
ludie51e3862017-08-15 19:28:12 -070072 // Sends the netlink message contained in iovecs. This populates iovecs[0] with
73 // a valid netlink message header.
ludi6e8eccd2017-08-14 14:40:37 -070074 virtual netdutils::Status sendMessage(uint16_t nlMsgType, uint16_t nlMsgFlags,
75 uint16_t nlMsgSeqNum,
76 std::vector<iovec>* iovecs) const = 0;
Nathan Harold1a371532017-01-30 12:30:48 -080077
78protected:
79 int mSock;
80};
81
82enum struct XfrmDirection : uint8_t {
83 IN = XFRM_POLICY_IN,
84 OUT = XFRM_POLICY_OUT,
85 FORWARD = XFRM_POLICY_FWD,
86 MASK = XFRM_POLICY_MASK,
87};
88
89enum struct XfrmMode : uint8_t {
90 TRANSPORT = XFRM_MODE_TRANSPORT,
91 TUNNEL = XFRM_MODE_TUNNEL,
92};
93
Nathan Harold420ceac2017-04-05 19:36:59 -070094enum struct XfrmEncapType : uint16_t {
95 NONE = 0,
96 ESPINUDP_NON_IKE = UDP_ENCAP_ESPINUDP_NON_IKE,
97 ESPINUDP = UDP_ENCAP_ESPINUDP
98};
99
Nathan Harold1a371532017-01-30 12:30:48 -0800100struct XfrmAlgo {
101 std::string name;
102 std::vector<uint8_t> key;
103 uint16_t truncLenBits;
104};
105
Nathan Harold420ceac2017-04-05 19:36:59 -0700106struct XfrmEncap {
107 XfrmEncapType type;
108 uint16_t srcPort;
109 uint16_t dstPort;
110};
111
Nathan Harolddf59bc02021-02-05 15:12:49 -0800112struct XfrmEndpointPair {
Nathan Harold1a371532017-01-30 12:30:48 -0800113 xfrm_address_t dstAddr; // network order
114 xfrm_address_t srcAddr;
115 int addrFamily; // AF_INET or AF_INET6
Nathan Harolddf59bc02021-02-05 15:12:49 -0800116};
117
118// minimally sufficient structure to match either an SA or a Policy
119struct XfrmCommonInfo : XfrmEndpointPair {
Yan Yanf9c46792022-10-13 00:25:43 +0000120 // TODO: b/259298885 rename "transformId" to "requestId" and update
121 // all the related methods/fields/logs
Nathan Harold1a371532017-01-30 12:30:48 -0800122 int transformId; // requestId
123 int spi;
Di Lu2ccb3e52018-01-03 16:19:20 -0800124 xfrm_mark mark;
Benedict Wonga450e722018-05-07 10:29:02 -0700125 int xfrm_if_id;
Nathan Harold47189212021-02-05 15:30:47 -0800126 XfrmMode mode;
Nathan Harold1a371532017-01-30 12:30:48 -0800127};
128
Benedict Wonga04ffa72018-05-09 21:42:42 -0700129struct XfrmSaInfo : XfrmCommonInfo {
Nathan Harold1a371532017-01-30 12:30:48 -0800130 XfrmAlgo auth;
131 XfrmAlgo crypt;
Benedict Wongbe65b432017-08-22 21:43:14 -0700132 XfrmAlgo aead;
Nathan Harold1a371532017-01-30 12:30:48 -0800133 int netId;
Nathan Harold420ceac2017-04-05 19:36:59 -0700134 XfrmEncap encap;
Nathan Harold1a371532017-01-30 12:30:48 -0800135};
136
Nathan Harold47189212021-02-05 15:30:47 -0800137struct XfrmSpInfo : XfrmCommonInfo {
Benedict Wonga04ffa72018-05-09 21:42:42 -0700138 // Address family in XfrmCommonInfo used for template/SA matching, need separate addrFamily
139 // for selectors
140 int selAddrFamily; // AF_INET or AF_INET6
Nathan Harolda5d6c9d2021-02-05 15:30:47 -0800141 XfrmDirection direction;
Benedict Wonga04ffa72018-05-09 21:42:42 -0700142};
143
Nathan Harold47189212021-02-05 15:30:47 -0800144struct XfrmMigrateInfo : XfrmSpInfo {
145 XfrmEndpointPair newEndpointInfo;
146};
147
Nathan Haroldc8737b82019-02-25 09:45:38 -0800148/*
149 * This is a workaround for a kernel bug in the 32bit netlink compat layer
150 * that has been present on x86_64 kernels since 2010 with no fix on the
151 * horizon.
152 *
153 * Below is a redefinition of the xfrm_usersa_info struct that is part
154 * of the Linux uapi <linux/xfrm.h> to align the structures to a 64-bit
155 * boundary.
156 *
157 * Note that we turn this on for all x86 32bit targets, under the assumption
158 * that nowadays all x86 targets are running 64bit kernels.
159 */
160#if defined(__i386__)
161// Shadow the kernel definition of xfrm_usersa_info with a 64-bit aligned version
162struct xfrm_usersa_info : ::xfrm_usersa_info {
163} __attribute__((aligned(8)));
164// Shadow the kernel's version, using the aligned version of xfrm_usersa_info
165struct xfrm_userspi_info {
166 struct xfrm_usersa_info info;
167 __u32 min;
168 __u32 max;
169};
170struct xfrm_userpolicy_info : ::xfrm_userpolicy_info {
171} __attribute__((aligned(8)));
172
173/*
174 * Anyone who encounters a failure when sending netlink messages should look here
175 * first. Hitting the static_assert() below should be a strong hint that Android
176 * IPsec will probably not work with your current settings.
177 *
178 * Again, experimentally determined, the "flags" field should be the first byte in
179 * the final word of the xfrm_usersa_info struct. The check validates the size of
180 * the padding to be 7.
181 *
182 * This padding is verified to be correct on gcc/x86_64 kernel, and clang/x86 userspace.
183 */
184static_assert(sizeof(::xfrm_usersa_info) % 8 != 0,
185 "struct xfrm_usersa_info has changed "
186 "alignment. Please consider whether this "
187 "patch is needed.");
188static_assert(sizeof(xfrm_usersa_info) - offsetof(xfrm_usersa_info, flags) == 8,
189 "struct xfrm_usersa_info probably misaligned with kernel struct.");
190static_assert(sizeof(xfrm_usersa_info) % 8 == 0,
191 "struct xfrm_usersa_info_t is not 64-bit "
192 "aligned. Please consider whether this patch "
193 "is needed.");
194static_assert(sizeof(::xfrm_userspi_info) - sizeof(::xfrm_usersa_info) ==
195 sizeof(xfrm_userspi_info) - sizeof(xfrm_usersa_info),
196 "struct xfrm_userspi_info has changed and does not match the kernel struct.");
197static_assert(sizeof(::xfrm_userpolicy_info) % 8 != 0,
198 "struct xfrm_userpolicy_info has changed "
199 "alignment. Please consider whether this "
200 "patch is needed.");
201static_assert(sizeof(xfrm_userpolicy_info) - offsetof(xfrm_userpolicy_info, share) == 5,
202 "struct xfrm_userpolicy_info probably misaligned with kernel struct.");
203static_assert(sizeof(xfrm_userpolicy_info) % 8 == 0,
204 "struct xfrm_userpolicy_info is not 64-bit "
205 "aligned. Please consider whether this patch "
206 "is needed.");
207#endif
208
Nathan Harold1a371532017-01-30 12:30:48 -0800209class XfrmController {
210public:
211 XfrmController();
212
Benedict Wongaf855432018-05-10 17:07:37 -0700213 // Initializer to override XFRM-I support for unit-testing purposes
214 explicit XfrmController(bool xfrmIntfSupport);
215
Nathan Harold21299f72018-03-16 20:13:03 -0700216 static netdutils::Status Init();
Benedict Wongb2daefb2017-12-06 22:05:46 -0800217
Luke Huange203a152018-11-23 11:47:28 +0800218 static netdutils::Status ipSecSetEncapSocketOwner(int socketFd, int newUid, uid_t callerUid);
Nathan Harold1a371532017-01-30 12:30:48 -0800219
Nathan Harold21299f72018-03-16 20:13:03 -0700220 static netdutils::Status ipSecAllocateSpi(int32_t transformId, const std::string& localAddress,
221 const std::string& remoteAddress, int32_t inSpi,
222 int32_t* outSpi);
223
224 static netdutils::Status ipSecAddSecurityAssociation(
Benedict Wonga450e722018-05-07 10:29:02 -0700225 int32_t transformId, int32_t mode, const std::string& sourceAddress,
226 const std::string& destinationAddress, int32_t underlyingNetId, int32_t spi,
227 int32_t markValue, int32_t markMask, const std::string& authAlgo,
228 const std::vector<uint8_t>& authKey, int32_t authTruncBits,
229 const std::string& cryptAlgo, const std::vector<uint8_t>& cryptKey,
230 int32_t cryptTruncBits, const std::string& aeadAlgo,
231 const std::vector<uint8_t>& aeadKey, int32_t aeadIcvBits, int32_t encapType,
232 int32_t encapLocalPort, int32_t encapRemotePort, int32_t xfrmInterfaceId);
Nathan Harold1a371532017-01-30 12:30:48 -0800233
Nathan Harold21299f72018-03-16 20:13:03 -0700234 static netdutils::Status ipSecDeleteSecurityAssociation(int32_t transformId,
235 const std::string& sourceAddress,
236 const std::string& destinationAddress,
237 int32_t spi, int32_t markValue,
Benedict Wonga450e722018-05-07 10:29:02 -0700238 int32_t markMask,
239 int32_t xfrmInterfaceId);
Nathan Harold1a371532017-01-30 12:30:48 -0800240
Luke Huange203a152018-11-23 11:47:28 +0800241 static netdutils::Status ipSecApplyTransportModeTransform(int socketFd, int32_t transformId,
242 int32_t direction,
243 const std::string& localAddress,
244 const std::string& remoteAddress,
245 int32_t spi);
Nathan Harold1a371532017-01-30 12:30:48 -0800246
Luke Huange203a152018-11-23 11:47:28 +0800247 static netdutils::Status ipSecRemoveTransportModeTransform(int socketFd);
Nathan Harold1a371532017-01-30 12:30:48 -0800248
Benedict Wonga04ffa72018-05-09 21:42:42 -0700249 static netdutils::Status ipSecAddSecurityPolicy(int32_t transformId, int32_t selAddrFamily,
250 int32_t direction,
Benedict Wongad600cb2018-05-14 17:22:35 -0700251 const std::string& tmplSrcAddress,
252 const std::string& tmplDstAddress, int32_t spi,
Benedict Wonga450e722018-05-07 10:29:02 -0700253 int32_t markValue, int32_t markMask,
254 int32_t xfrmInterfaceId);
ludi771b8002017-11-20 15:09:05 -0800255
Benedict Wonga04ffa72018-05-09 21:42:42 -0700256 static netdutils::Status ipSecUpdateSecurityPolicy(int32_t transformId, int32_t selAddrFamily,
257 int32_t direction,
Benedict Wongad600cb2018-05-14 17:22:35 -0700258 const std::string& tmplSrcAddress,
259 const std::string& tmplDstAddress,
Nathan Harold21299f72018-03-16 20:13:03 -0700260 int32_t spi, int32_t markValue,
Benedict Wonga450e722018-05-07 10:29:02 -0700261 int32_t markMask, int32_t xfrmInterfaceId);
ludi771b8002017-11-20 15:09:05 -0800262
Benedict Wonga04ffa72018-05-09 21:42:42 -0700263 static netdutils::Status ipSecDeleteSecurityPolicy(int32_t transformId, int32_t selAddrFamily,
264 int32_t direction, int32_t markValue,
Benedict Wonga450e722018-05-07 10:29:02 -0700265 int32_t markMask, int32_t xfrmInterfaceId);
ludi771b8002017-11-20 15:09:05 -0800266
Benedict Wong319f17e2018-05-15 17:06:44 -0700267 static netdutils::Status ipSecAddTunnelInterface(const std::string& deviceName,
268 const std::string& localAddress,
269 const std::string& remoteAddress, int32_t ikey,
Benedict Wonga450e722018-05-07 10:29:02 -0700270 int32_t okey, int32_t interfaceId,
271 bool isUpdate);
manojboopathi8707f232018-01-02 14:45:47 -0800272
Benedict Wong319f17e2018-05-15 17:06:44 -0700273 static netdutils::Status ipSecRemoveTunnelInterface(const std::string& deviceName);
manojboopathi8707f232018-01-02 14:45:47 -0800274
Nathan Harold47189212021-02-05 15:30:47 -0800275 // Only available for Tunnel must already have a matching tunnel SA and policy
276 static netdutils::Status ipSecMigrate(int32_t transformId, int32_t selAddrFamily,
277 int32_t direction, const std::string& oldSourceAddress,
278 const std::string& oldDestinationAddress,
279 const std::string& newSourceAddress,
280 const std::string& newDestinationAddress,
281 int32_t xfrmInterfaceId);
Luke Huangb257d612019-03-14 21:19:13 +0800282 void dump(netdutils::DumpWriter& dw);
Benedict Wongaf855432018-05-10 17:07:37 -0700283
Jonathan Basseric6461a62017-08-31 14:47:33 -0700284 // Some XFRM netlink attributes comprise a header, a struct, and some data
285 // after the struct. We wrap all of those in one struct for easier
286 // marshalling. The structs below must be ABI compatible with the kernel and
287 // are composed from kernel structures; thus, they use the kernel naming
288 // convention.
289
Nathan Harold39b5df42017-08-02 18:45:25 -0700290 // Exposed for testing
Benedict Wong4f60ee12017-10-10 12:27:25 -0700291 static constexpr size_t MAX_KEY_LENGTH = 128;
Nathan Harold39b5df42017-08-02 18:45:25 -0700292
Christopher Ferrisdb245df2022-10-04 20:24:33 -0700293 // Disable this warning since avoiding it makes the code unreadable.
294#pragma clang diagnostic push
295#pragma clang diagnostic ignored "-Wgnu-variable-sized-type-not-at-end"
296
Jonathan Basseric6461a62017-08-31 14:47:33 -0700297 // Container for the content of an XFRMA_ALG_CRYPT netlink attribute.
Nathan Harold39b5df42017-08-02 18:45:25 -0700298 // Exposed for testing
299 struct nlattr_algo_crypt {
300 nlattr hdr;
301 xfrm_algo crypt;
Benedict Wong4f60ee12017-10-10 12:27:25 -0700302 uint8_t key[MAX_KEY_LENGTH];
Nathan Harold39b5df42017-08-02 18:45:25 -0700303 };
304
Jonathan Basseric6461a62017-08-31 14:47:33 -0700305 // Container for the content of an XFRMA_ALG_AUTH_TRUNC netlink attribute.
Nathan Harold39b5df42017-08-02 18:45:25 -0700306 // Exposed for testing
307 struct nlattr_algo_auth {
308 nlattr hdr;
309 xfrm_algo_auth auth;
Benedict Wong4f60ee12017-10-10 12:27:25 -0700310 uint8_t key[MAX_KEY_LENGTH];
Nathan Harold39b5df42017-08-02 18:45:25 -0700311 };
312
Jonathan Basseric6461a62017-08-31 14:47:33 -0700313 // Container for the content of an XFRMA_TMPL netlink attribute.
Nathan Harold39b5df42017-08-02 18:45:25 -0700314 // Exposed for testing
Benedict Wongbe65b432017-08-22 21:43:14 -0700315 struct nlattr_algo_aead {
316 nlattr hdr;
317 xfrm_algo_aead aead;
Benedict Wong4f60ee12017-10-10 12:27:25 -0700318 uint8_t key[MAX_KEY_LENGTH];
Benedict Wongbe65b432017-08-22 21:43:14 -0700319 };
320
Benedict Wongea2001b2023-06-15 20:18:43 +0000321 // Container for the content of an XFRMA_REPLAY_ESN_VAL netlink attribute.
322 // Exposed for testing
323 struct nlattr_xfrm_replay_esn {
324 nlattr hdr;
325 xfrm_replay_state_esn replay_state;
326 };
327
Christopher Ferrisdb245df2022-10-04 20:24:33 -0700328#pragma clang diagnostic pop
329
Benedict Wongbe65b432017-08-22 21:43:14 -0700330 // Exposed for testing
Nathan Harold39b5df42017-08-02 18:45:25 -0700331 struct nlattr_user_tmpl {
332 nlattr hdr;
333 xfrm_user_tmpl tmpl;
334 };
335
Jonathan Basseric6461a62017-08-31 14:47:33 -0700336 // Container for the content of an XFRMA_ENCAP netlink attribute.
Nathan Harold39b5df42017-08-02 18:45:25 -0700337 // Exposed for testing
338 struct nlattr_encap_tmpl {
339 nlattr hdr;
340 xfrm_encap_tmpl tmpl;
341 };
342
Di Lu2ccb3e52018-01-03 16:19:20 -0800343 // Container for the content of an XFRMA_MARK netlink attribute.
344 // Exposed for testing
345 struct nlattr_xfrm_mark {
346 nlattr hdr;
347 xfrm_mark mark;
348 };
349
Benedict Wong96abf482018-01-22 13:56:41 -0800350 // Container for the content of an XFRMA_OUTPUT_MARK netlink attribute.
351 // Exposed for testing
352 struct nlattr_xfrm_output_mark {
353 nlattr hdr;
354 __u32 outputMark;
355 };
356
Benedict Wong319f17e2018-05-15 17:06:44 -0700357 // Container for the content of an XFRMA_IF_ID netlink attribute.
358 // Exposed for testing
359 struct nlattr_xfrm_interface_id {
360 nlattr hdr;
361 __u32 if_id;
362 };
363
Nathan Harold47189212021-02-05 15:30:47 -0800364 // Container for the content of an XFRMA_MIGRATE netlink attribute.
365 // Exposed for testing
366 struct nlattr_xfrm_user_migrate {
367 nlattr hdr;
368 xfrm_user_migrate migrate;
369 };
370
Benedict Wong319f17e2018-05-15 17:06:44 -0700371 // Exposed for testing
372 struct nlattr_payload_u32 {
373 nlattr hdr;
374 uint32_t value;
375 };
376
377 private:
Benedict Wongaf855432018-05-10 17:07:37 -0700378 static bool isXfrmIntfSupported();
379
Nathan Harolddf59bc02021-02-05 15:12:49 -0800380 static netdutils::Status fillXfrmEndpointPair(const std::string& sourceAddress,
381 const std::string& destinationAddress,
382 XfrmEndpointPair* info);
Benedict Wonga04ffa72018-05-09 21:42:42 -0700383 // helper functions for filling in the XfrmCommonInfo (and XfrmSaInfo) structure
384 static netdutils::Status fillXfrmCommonInfo(const std::string& sourceAddress,
385 const std::string& destinationAddress, int32_t spi,
386 int32_t markValue, int32_t markMask,
Benedict Wonga450e722018-05-07 10:29:02 -0700387 int32_t transformId, int32_t xfrmInterfaceId,
388 XfrmCommonInfo* info);
Benedict Wonga04ffa72018-05-09 21:42:42 -0700389 static netdutils::Status fillXfrmCommonInfo(int32_t spi, int32_t markValue, int32_t markMask,
Benedict Wonga450e722018-05-07 10:29:02 -0700390 int32_t transformId, int32_t xfrmInterfaceId,
391 XfrmCommonInfo* info);
Nathan Harold1a371532017-01-30 12:30:48 -0800392
393 // Top level functions for managing a Transport Mode Transform
ludi6e8eccd2017-08-14 14:40:37 -0700394 static netdutils::Status addTransportModeTransform(const XfrmSaInfo& record);
Nathan Harold1a371532017-01-30 12:30:48 -0800395 static int removeTransportModeTransform(const XfrmSaInfo& record);
396
397 // TODO(messagerefactor): FACTOR OUT ALL MESSAGE BUILDING CODE BELOW HERE
398 // Shared between SA and SP
Benedict Wonga04ffa72018-05-09 21:42:42 -0700399 static void fillXfrmSelector(const int record, xfrm_selector* selector);
Nathan Harold1a371532017-01-30 12:30:48 -0800400
401 // Shared between Transport and Tunnel Mode
402 static int fillNlAttrXfrmAlgoEnc(const XfrmAlgo& in_algo, nlattr_algo_crypt* algo);
403 static int fillNlAttrXfrmAlgoAuth(const XfrmAlgo& in_algo, nlattr_algo_auth* algo);
Benedict Wongbe65b432017-08-22 21:43:14 -0700404 static int fillNlAttrXfrmAlgoAead(const XfrmAlgo& in_algo, nlattr_algo_aead* algo);
Nathan Harold420ceac2017-04-05 19:36:59 -0700405 static int fillNlAttrXfrmEncapTmpl(const XfrmSaInfo& record, nlattr_encap_tmpl* tmpl);
Nathan Harold1a371532017-01-30 12:30:48 -0800406
Di Lu0e16b5e2018-01-12 10:37:53 -0800407 // Functions for updating a Transport Mode SA
408 static netdutils::Status updateSecurityAssociation(const XfrmSaInfo& record,
manojboopathi4d2d6f12017-12-06 11:11:31 -0800409 const XfrmSocket& sock);
Nathan Harold1a371532017-01-30 12:30:48 -0800410 static int fillUserSaInfo(const XfrmSaInfo& record, xfrm_usersa_info* usersa);
411
412 // Functions for deleting a Transport Mode SA
Benedict Wonga04ffa72018-05-09 21:42:42 -0700413 static netdutils::Status deleteSecurityAssociation(const XfrmCommonInfo& record,
ludi6e8eccd2017-08-14 14:40:37 -0700414 const XfrmSocket& sock);
Benedict Wonga04ffa72018-05-09 21:42:42 -0700415 static int fillUserSaId(const XfrmCommonInfo& record, xfrm_usersa_id* said);
Maciej Żenczykowski322c9ee2020-04-22 09:44:19 -0700416 static void fillUserTemplate(const XfrmSpInfo& record, xfrm_user_tmpl* tmpl);
ludi771b8002017-11-20 15:09:05 -0800417
Nathan Harolda5d6c9d2021-02-05 15:30:47 -0800418 static int fillUserSpInfo(const XfrmSpInfo& record, xfrm_userpolicy_info* usersp);
Benedict Wonga04ffa72018-05-09 21:42:42 -0700419 static int fillNlAttrUserTemplate(const XfrmSpInfo& record, nlattr_user_tmpl* tmpl);
Nathan Harolda5d6c9d2021-02-05 15:30:47 -0800420 static int fillUserPolicyId(const XfrmSpInfo& record, xfrm_userpolicy_id* policy_id);
Benedict Wonga04ffa72018-05-09 21:42:42 -0700421 static int fillNlAttrXfrmMark(const XfrmCommonInfo& record, nlattr_xfrm_mark* mark);
Benedict Wong73119c22021-04-20 00:07:13 -0700422 static int fillNlAttrXfrmOutputMark(const XfrmSaInfo& record,
Benedict Wong96abf482018-01-22 13:56:41 -0800423 nlattr_xfrm_output_mark* output_mark);
Benedict Wong319f17e2018-05-15 17:06:44 -0700424 static int fillNlAttrXfrmIntfId(const __u32 intf_id_value, nlattr_xfrm_interface_id* intf_id);
Benedict Wongea2001b2023-06-15 20:18:43 +0000425 static int fillNlAttrXfrmReplayEsn(nlattr_xfrm_replay_esn* replay_esn);
Nathan Harold47189212021-02-05 15:30:47 -0800426 static int fillNlAttrXfrmMigrate(const XfrmMigrateInfo& record,
427 nlattr_xfrm_user_migrate* migrate);
Nathan Harold1a371532017-01-30 12:30:48 -0800428
ludi6e8eccd2017-08-14 14:40:37 -0700429 static netdutils::Status allocateSpi(const XfrmSaInfo& record, uint32_t minSpi, uint32_t maxSpi,
430 uint32_t* outSpi, const XfrmSocket& sock);
Nathan Harold1a371532017-01-30 12:30:48 -0800431
Benedict Wonga04ffa72018-05-09 21:42:42 -0700432 static netdutils::Status processSecurityPolicy(int32_t transformId, int32_t selAddrFamily,
433 int32_t direction,
Benedict Wongad600cb2018-05-14 17:22:35 -0700434 const std::string& tmplSrcAddress,
435 const std::string& tmplDstAddress, int32_t spi,
Nathan Harold21299f72018-03-16 20:13:03 -0700436 int32_t markValue, int32_t markMask,
Benedict Wonga450e722018-05-07 10:29:02 -0700437 int32_t xfrmInterfaceId, int32_t msgType);
Benedict Wonga04ffa72018-05-09 21:42:42 -0700438 static netdutils::Status updateTunnelModeSecurityPolicy(const XfrmSpInfo& record,
ludi771b8002017-11-20 15:09:05 -0800439 const XfrmSocket& sock,
ludi771b8002017-11-20 15:09:05 -0800440 uint16_t msgType);
Benedict Wonga04ffa72018-05-09 21:42:42 -0700441 static netdutils::Status deleteTunnelModeSecurityPolicy(const XfrmSpInfo& record,
Nathan Harolda5d6c9d2021-02-05 15:30:47 -0800442 const XfrmSocket& sock);
Nathan Harold47189212021-02-05 15:30:47 -0800443 static netdutils::Status migrate(const XfrmMigrateInfo& record, const XfrmSocket& sock);
Nathan Harold21299f72018-03-16 20:13:03 -0700444 static netdutils::Status flushInterfaces();
445 static netdutils::Status flushSaDb(const XfrmSocket& s);
446 static netdutils::Status flushPolicyDb(const XfrmSocket& s);
447
Benedict Wong319f17e2018-05-15 17:06:44 -0700448 static netdutils::Status ipSecAddXfrmInterface(const std::string& deviceName,
Benedict Wongaf855432018-05-10 17:07:37 -0700449 int32_t interfaceId, uint16_t flags);
Benedict Wong319f17e2018-05-15 17:06:44 -0700450 static netdutils::Status ipSecAddVirtualTunnelInterface(const std::string& deviceName,
451 const std::string& localAddress,
452 const std::string& remoteAddress,
453 int32_t ikey, int32_t okey,
454 uint16_t flags);
Nathan Harold1a371532017-01-30 12:30:48 -0800455 // END TODO(messagerefactor)
456};
457
458} // namespace net
459} // namespace android
460
461#endif /* !defined(XFRM_CONTROLLER_H) */