1 /*
2  * Copyright 2019 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 package android.media.tv.tuner.filter;
18 
19 import android.annotation.IntRange;
20 import android.annotation.NonNull;
21 import android.annotation.Nullable;
22 import android.annotation.Size;
23 import android.annotation.SystemApi;
24 import android.hardware.tv.tuner.Constant;
25 import android.media.tv.tuner.TunerVersionChecker;
26 
27 /**
28  * Filter configuration for a IP filter.
29  *
30  * @hide
31  */
32 @SystemApi
33 public final class IpFilterConfiguration extends FilterConfiguration {
34     /**
35      * Undefined filter type.
36      */
37     public static final int INVALID_IP_FILTER_CONTEXT_ID = Constant.INVALID_IP_FILTER_CONTEXT_ID;
38 
39     private final byte[] mSrcIpAddress;
40     private final byte[] mDstIpAddress;
41     private final int mSrcPort;
42     private final int mDstPort;
43     private final boolean mPassthrough;
44     private final int mIpFilterContextId;
45 
IpFilterConfiguration(Settings settings, byte[] srcAddr, byte[] dstAddr, int srcPort, int dstPort, boolean passthrough, int ipCid)46     private IpFilterConfiguration(Settings settings, byte[] srcAddr, byte[] dstAddr, int srcPort,
47             int dstPort, boolean passthrough, int ipCid) {
48         super(settings);
49         mSrcIpAddress = srcAddr;
50         mDstIpAddress = dstAddr;
51         mSrcPort = srcPort;
52         mDstPort = dstPort;
53         mPassthrough = passthrough;
54         mIpFilterContextId = ipCid;
55     }
56 
57     @Override
getType()58     public int getType() {
59         return Filter.TYPE_IP;
60     }
61 
62     /**
63      * Gets source IP address.
64      */
65     @Size(min = 4, max = 16)
66     @NonNull
getSrcIpAddress()67     public byte[] getSrcIpAddress() {
68         return mSrcIpAddress;
69     }
70     /**
71      * Gets destination IP address.
72      */
73     @Size(min = 4, max = 16)
74     @NonNull
getDstIpAddress()75     public byte[] getDstIpAddress() {
76         return mDstIpAddress;
77     }
78     /**
79      * Gets source port.
80      */
getSrcPort()81     public int getSrcPort() {
82         return mSrcPort;
83     }
84     /**
85      * Gets destination port.
86      */
getDstPort()87     public int getDstPort() {
88         return mDstPort;
89     }
90     /**
91      * Checks whether the filter is passthrough.
92      *
93      * @return {@code true} if the data from IP subtype go to next filter directly;
94      *         {@code false} otherwise.
95      */
isPassthrough()96     public boolean isPassthrough() {
97         return mPassthrough;
98     }
99     /**
100      * Gets the ip filter context id. Default value is {@link #INVALID_IP_FILTER_CONTEXT_ID}.
101      *
102      * <p>This API is only supported by Tuner HAL 1.1 or higher. Unsupported version would return
103      * default value. Use {@link TunerVersionChecker#getTunerVersion()} to check the version.
104      */
105     @IntRange(from = 0, to = 0xefff)
getIpFilterContextId()106     public int getIpFilterContextId() {
107         return mIpFilterContextId;
108     }
109 
110     /**
111      * Creates a builder for {@link IpFilterConfiguration}.
112      */
113     @NonNull
builder()114     public static Builder builder() {
115         return new Builder();
116     }
117 
118     /**
119      * Builder for {@link IpFilterConfiguration}.
120      */
121     public static final class Builder {
122         private byte[] mSrcIpAddress = {0, 0, 0, 0};
123         private byte[] mDstIpAddress = {0, 0, 0, 0};
124         private int mSrcPort = 0;
125         private int mDstPort = 0;
126         private boolean mPassthrough = false;
127         private Settings mSettings;
128         private int mIpCid = INVALID_IP_FILTER_CONTEXT_ID;
129 
Builder()130         private Builder() {
131         }
132 
133         /**
134          * Sets source IP address.
135          *
136          * <p>Default value is 0.0.0.0, an invalid IP address.
137          */
138         @NonNull
setSrcIpAddress(@onNull byte[] srcIpAddress)139         public Builder setSrcIpAddress(@NonNull byte[] srcIpAddress) {
140             mSrcIpAddress = srcIpAddress;
141             return this;
142         }
143         /**
144          * Sets destination IP address.
145          *
146          * <p>Default value is 0.0.0.0, an invalid IP address.
147          */
148         @NonNull
setDstIpAddress(@onNull byte[] dstIpAddress)149         public Builder setDstIpAddress(@NonNull byte[] dstIpAddress) {
150             mDstIpAddress = dstIpAddress;
151             return this;
152         }
153         /**
154          * Sets source port.
155          *
156          * <p>Default value is 0.
157          */
158         @NonNull
setSrcPort(int srcPort)159         public Builder setSrcPort(int srcPort) {
160             mSrcPort = srcPort;
161             return this;
162         }
163         /**
164          * Sets destination port.
165          *
166          * <p>Default value is 0.
167          */
168         @NonNull
setDstPort(int dstPort)169         public Builder setDstPort(int dstPort) {
170             mDstPort = dstPort;
171             return this;
172         }
173         /**
174          * Sets passthrough.
175          *
176          * <p>Default value is {@code false}.
177          */
178         @NonNull
setPassthrough(boolean passthrough)179         public Builder setPassthrough(boolean passthrough) {
180             mPassthrough = passthrough;
181             return this;
182         }
183 
184         /**
185          * Sets filter settings.
186          */
187         @NonNull
setSettings(@ullable Settings settings)188         public Builder setSettings(@Nullable Settings settings) {
189             mSettings = settings;
190             return this;
191         }
192 
193         /**
194          * Sets the ip filter context id. Default value is {@link #INVALID_IP_FILTER_CONTEXT_ID}.
195          *
196          * <p>This API is only supported by Tuner HAL 1.1 or higher. Unsupported version would cause
197          * no-op. Use {@link TunerVersionChecker#getTunerVersion()} to check the version.
198          */
199         @NonNull
setIpFilterContextId(int ipContextId)200         public Builder setIpFilterContextId(int ipContextId) {
201             if (TunerVersionChecker.checkHigherOrEqualVersionTo(
202                         TunerVersionChecker.TUNER_VERSION_1_1, "setIpFilterContextId")) {
203                 mIpCid = ipContextId;
204             }
205             return this;
206         }
207 
208         /**
209          * Builds a {@link IpFilterConfiguration} object.
210          */
211         @NonNull
build()212         public IpFilterConfiguration build() {
213             int ipAddrLength = mSrcIpAddress.length;
214             if (ipAddrLength != mDstIpAddress.length || (ipAddrLength != 4 && ipAddrLength != 16)) {
215                 throw new IllegalArgumentException(
216                     "The lengths of src and dst IP address must be 4 or 16 and must be the same."
217                             + "srcLength=" + ipAddrLength + ", dstLength=" + mDstIpAddress.length);
218             }
219             return new IpFilterConfiguration(mSettings, mSrcIpAddress, mDstIpAddress, mSrcPort,
220                     mDstPort, mPassthrough, mIpCid);
221         }
222     }
223 }
224