blob: 3e45d40189bdf52961e7fbb6cfcf385d1d24b91c [file] [log] [blame]
JP Abgrall4a5f5ca2011-06-15 18:37:39 -07001/*
2 * Copyright (C) 2011 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 _BANDWIDTH_CONTROLLER_H
17#define _BANDWIDTH_CONTROLLER_H
18
19#include <list>
20#include <string>
JP Abgrallfa6f46d2011-06-17 23:17:28 -070021#include <utility> // for pair
JP Abgrall4a5f5ca2011-06-15 18:37:39 -070022class BandwidthController {
23public:
JP Abgrallfa6f46d2011-06-17 23:17:28 -070024 BandwidthController();
25 int enableBandwidthControl(void);
26 int disableBandwidthControl(void);
27
JP Abgrall0dad7c22011-06-24 11:58:14 -070028 int setInterfaceSharedQuota(const char *iface, int64_t bytes);
JP Abgrall8a932722011-07-13 19:17:35 -070029 int getInterfaceSharedQuota(int64_t *bytes);
JP Abgrallfa6f46d2011-06-17 23:17:28 -070030 int removeInterfaceSharedQuota(const char *iface);
31
JP Abgrall0dad7c22011-06-24 11:58:14 -070032 int setInterfaceQuota(const char *iface, int64_t bytes);
JP Abgrall8a932722011-07-13 19:17:35 -070033 int getInterfaceQuota(const char *iface, int64_t *bytes);
JP Abgrall0dad7c22011-06-24 11:58:14 -070034 int removeInterfaceQuota(const char *iface);
35
JP Abgrallfa6f46d2011-06-17 23:17:28 -070036 int addNaughtyApps(int numUids, char *appUids[]);
37 int removeNaughtyApps(int numUids, char *appUids[]);
JP Abgrall4a5f5ca2011-06-15 18:37:39 -070038
JP Abgrall8a932722011-07-13 19:17:35 -070039 int setGlobalAlert(int64_t bytes);
40 int removeGlobalAlert(void);
41
42 int setSharedAlert(int64_t bytes);
43 int removeSharedAlert(void);
44
45 int setInterfaceAlert(const char *iface, int64_t bytes);
46 int removeInterfaceAlert(const char *iface);
JP Abgrall0dad7c22011-06-24 11:58:14 -070047
JP Abgrall4a5f5ca2011-06-15 18:37:39 -070048protected:
JP Abgrall8a932722011-07-13 19:17:35 -070049 class QuotaInfo {
50 public:
51 QuotaInfo(std::string ifn, int64_t q, int64_t a)
52 : ifaceName(ifn), quota(q), alert(a) {};
53 std::string ifaceName;
54 int64_t quota;
55 int64_t alert;
56 };
JP Abgrall26e0d492011-06-24 19:21:51 -070057 enum IptIpVer { IptIpV4, IptIpV6 };
58 enum IptOp { IptOpInsert, IptOpReplace, IptOpDelete };
59 enum IptRejectOp { IptRejectAdd, IptRejectNoAdd };
60 enum NaughtyAppOp { NaughtyAppOpAdd, NaughtyAppOpRemove };
61 enum QuotaType { QuotaUnique, QuotaShared };
62 enum RunCmdErrHandling { RunCmdFailureBad, RunCmdFailureOk };
JP Abgrall0dad7c22011-06-24 11:58:14 -070063
JP Abgrall0dad7c22011-06-24 11:58:14 -070064 std::list<std::string> sharedQuotaIfaces;
JP Abgrall8a932722011-07-13 19:17:35 -070065 int64_t sharedQuotaBytes;
66 int64_t sharedAlertBytes;
JP Abgrall0dad7c22011-06-24 11:58:14 -070067
68 std::list<QuotaInfo> quotaIfaces;
69
JP Abgrallfa6f46d2011-06-17 23:17:28 -070070 std::list<int /*appUid*/> naughtyAppUids;
JP Abgrall26e0d492011-06-24 19:21:51 -070071 int maninpulateNaughtyApps(int numUids, char *appStrUids[], NaughtyAppOp appOp);
JP Abgrall4a5f5ca2011-06-15 18:37:39 -070072
JP Abgrall26e0d492011-06-24 19:21:51 -070073 int prepCostlyIface(const char *ifn, QuotaType quotaType);
74 int cleanupCostlyIface(const char *ifn, QuotaType quotaType);
JP Abgrall0dad7c22011-06-24 11:58:14 -070075
76 std::string makeIptablesNaughtyCmd(IptOp op, int uid);
JP Abgrall26e0d492011-06-24 19:21:51 -070077 std::string makeIptablesQuotaCmd(IptOp op, const char *costName, int64_t quota);
JP Abgrall0dad7c22011-06-24 11:58:14 -070078
JP Abgrall8a932722011-07-13 19:17:35 -070079 int runIptablesAlertCmd(IptOp op, const char *alertName, int64_t bytes);
80
JP Abgrall0dad7c22011-06-24 11:58:14 -070081 /* Runs for both ipv4 and ipv6 iptables */
JP Abgrall26e0d492011-06-24 19:21:51 -070082 int runCommands(int numCommands, const char *commands[], RunCmdErrHandling cmdErrHandling);
JP Abgrall0dad7c22011-06-24 11:58:14 -070083 /* Runs for both ipv4 and ipv6 iptables, appends -j REJECT --reject-with ... */
JP Abgrall26e0d492011-06-24 19:21:51 -070084 static int runIpxtablesCmd(const char *cmd, IptRejectOp rejectHandling);
85 static int runIptablesCmd(const char *cmd, IptRejectOp rejectHandling, IptIpVer iptIpVer);
86
87 // Provides strncpy() + check overflow.
88 static int StrncpyAndCheck(char *buffer, const char *src, size_t buffSize);
JP Abgrall0dad7c22011-06-24 11:58:14 -070089
JP Abgrall8a932722011-07-13 19:17:35 -070090 int updateQuota(const char *alertName, int64_t bytes);
91
92 int64_t globalAlertBytes;
93 int setCostlyAlert(const char *costName, int64_t bytes, int64_t *alertBytes);
94 int removeCostlyAlert(const char *costName, int64_t *alertBytes);
95
JP Abgrall11b4e9b2011-08-11 15:34:49 -070096 /*
97 * When false, it will directly use system() instead of logwrap()
98 */
99 static bool useLogwrapCall;
JP Abgrall8a932722011-07-13 19:17:35 -0700100
JP Abgrall4a5f5ca2011-06-15 18:37:39 -0700101private:
JP Abgrallfa6f46d2011-06-17 23:17:28 -0700102 static const char *cleanupCommands[];
103 static const char *setupCommands[];
104 static const char *basicAccountingCommands[];
105 static const int MAX_CMD_LEN;
106 static const int MAX_IFACENAME_LEN;
107 static const int MAX_CMD_ARGS;
108 static const char IPTABLES_PATH[];
109 static const char IP6TABLES_PATH[];
JP Abgrall8a932722011-07-13 19:17:35 -0700110 static const char ALERT_IPT_TEMPLATE[];
111 static const int ALERT_RULE_POS_IN_COSTLY_CHAIN;
JP Abgrall4a5f5ca2011-06-15 18:37:39 -0700112};
113
114#endif