1 /*
2 * Copyright (C) 2021 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 #define LOG_TAG "Netd"
18
19 #include "UnreachableNetwork.h"
20
21 #include "RouteController.h"
22
23 namespace android {
24 namespace net {
25
26 // The unreachable network is used to reject traffic. It is used for system purposes only.
UnreachableNetwork(unsigned netId)27 UnreachableNetwork::UnreachableNetwork(unsigned netId) : Network(netId) {}
28
addUsers(const UidRanges & uidRanges,int32_t subPriority)29 int UnreachableNetwork::addUsers(const UidRanges& uidRanges, int32_t subPriority) {
30 if (!isValidSubPriority(subPriority) || !canAddUidRanges(uidRanges)) {
31 return -EINVAL;
32 }
33
34 int ret = RouteController::addUsersToUnreachableNetwork(mNetId, {{subPriority, uidRanges}});
35 if (ret) {
36 ALOGE("failed to add users to unreachable network");
37 return ret;
38 }
39 addToUidRangeMap(uidRanges, subPriority);
40 return 0;
41 }
42
removeUsers(const UidRanges & uidRanges,int32_t subPriority)43 int UnreachableNetwork::removeUsers(const UidRanges& uidRanges, int32_t subPriority) {
44 if (!isValidSubPriority(subPriority)) return -EINVAL;
45
46 int ret =
47 RouteController::removeUsersFromUnreachableNetwork(mNetId, {{subPriority, uidRanges}});
48 if (ret) {
49 ALOGE("failed to remove users from unreachable network");
50 return ret;
51 }
52 removeFromUidRangeMap(uidRanges, subPriority);
53 return 0;
54 }
55
isValidSubPriority(int32_t priority)56 bool UnreachableNetwork::isValidSubPriority(int32_t priority) {
57 return priority >= UidRanges::SUB_PRIORITY_HIGHEST &&
58 priority <= UidRanges::SUB_PRIORITY_LOWEST;
59 }
60
61 } // namespace net
62 } // namespace android
63