1 /* 2 * Copyright (C) 2014 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 17 #ifndef NETD_CLIENT_FWMARK_CLIENT_H 18 #define NETD_CLIENT_FWMARK_CLIENT_H 19 20 #include <sys/socket.h> 21 22 struct FwmarkCommand; 23 struct FwmarkConnectInfo; 24 25 class FwmarkClient { 26 public: 27 // Returns true if a socket of the given |family| should be sent to the fwmark server to have 28 // its SO_MARK set. 29 static bool shouldSetFwmark(int family); 30 31 // Returns true if an additional call should be made after ON_CONNECT calls, to log extra 32 // information like latency and source IP. 33 static bool shouldReportConnectComplete(int family); 34 35 FwmarkClient(); 36 ~FwmarkClient(); 37 38 // Sends |data| to the fwmark server, along with |fd| as ancillary data using cmsg(3). 39 // For ON_CONNECT_COMPLETE |data| command, |connectInfo| should be provided. 40 // Returns 0 on success or a negative errno value on failure. 41 int send(FwmarkCommand* data, int fd, FwmarkConnectInfo* connectInfo); 42 43 // Env flag to control whether FwmarkClient sends any information at all about network events 44 // back to the system server through FwmarkServer. 45 static constexpr const char* ANDROID_NO_USE_FWMARK_CLIENT = "ANDROID_NO_USE_FWMARK_CLIENT"; 46 47 // Env flag to control whether FwmarkClient should exclude detailed information like IP 48 // addresses and only send basic information necessary for marking sockets. 49 // Has no effect if ANDROID_NO_USE_FWMARK_CLIENT is set. 50 static constexpr const char* ANDROID_FWMARK_METRICS_ONLY = "ANDROID_FWMARK_METRICS_ONLY"; 51 52 private: 53 int mChannel; 54 }; 55 56 #endif // NETD_CLIENT_FWMARK_CLIENT_H 57