1 /* 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 17 package com.android.tv.settings.connectivity.setup; 18 19 import android.net.IpConfiguration; 20 import android.net.LinkAddress; 21 import android.net.ProxyInfo; 22 import android.text.TextUtils; 23 24 import androidx.annotation.IntDef; 25 import androidx.lifecycle.ViewModel; 26 27 import java.lang.annotation.Retention; 28 import java.lang.annotation.RetentionPolicy; 29 import java.net.InetAddress; 30 import java.util.HashMap; 31 32 /** 33 * Class that stores the page information for advanced flow. 34 */ 35 public class AdvancedOptionsFlowInfo extends ViewModel { 36 public static final int ADVANCED_OPTIONS = 1; 37 public static final int PROXY_SETTINGS = 2; 38 public static final int PROXY_HOSTNAME = 3; 39 public static final int PROXY_PORT = 4; 40 public static final int PROXY_BYPASS = 5; 41 public static final int IP_SETTINGS = 6; 42 public static final int IP_ADDRESS = 7; 43 public static final int NETWORK_PREFIX_LENGTH = 8; 44 public static final int GATEWAY = 9; 45 public static final int DNS1 = 10; 46 public static final int DNS2 = 11; 47 48 @IntDef({ 49 ADVANCED_OPTIONS, 50 PROXY_SETTINGS, 51 PROXY_HOSTNAME, 52 PROXY_PORT, 53 PROXY_BYPASS, 54 IP_SETTINGS, 55 IP_ADDRESS, 56 NETWORK_PREFIX_LENGTH, 57 GATEWAY, 58 DNS1, 59 DNS2 60 }) 61 @Retention(RetentionPolicy.SOURCE) 62 public @interface PAGE { 63 } 64 65 private IpConfiguration mIpConfiguration; 66 private String mPrintableSsid; 67 private boolean mSettingsFlow; 68 private boolean mCanStart = false; 69 70 private HashMap<Integer, CharSequence> mPageSummary = new HashMap<>(); 71 72 /** 73 * Store the page summary into a HashMap. 74 * 75 * @param page The page as the key. 76 * @param info The info as the value. 77 */ put(@AGE int page, CharSequence info)78 public void put(@PAGE int page, CharSequence info) { 79 mPageSummary.put(page, info); 80 } 81 82 /** 83 * Check if the summary of the queried page matches with expected string. 84 * 85 * @param choice The expected string. 86 * @param page The page queried. 87 * @return true if matched. 88 */ choiceChosen(CharSequence choice, @PAGE int page)89 public boolean choiceChosen(CharSequence choice, @PAGE int page) { 90 if (!mPageSummary.containsKey(page)) { 91 return false; 92 } 93 return TextUtils.equals(choice, mPageSummary.get(page)); 94 } 95 96 /** 97 * Check if the Hashmap contains the summary of a particular page. 98 * 99 * @param page the queried page 100 * @return true if contains. 101 */ containsPage(@AGE int page)102 public boolean containsPage(@PAGE int page) { 103 return mPageSummary.containsKey(page); 104 } 105 106 /** 107 * Get summary of a page. 108 * 109 * @param page The queried page. 110 * @return The summary of the page. 111 */ get(@AGE int page)112 public String get(@PAGE int page) { 113 if (!mPageSummary.containsKey(page)) { 114 return ""; 115 } 116 return mPageSummary.get(page).toString(); 117 } 118 119 /** 120 * Remove the summary of a page. 121 * 122 * @param page The page. 123 */ remove(@AGE int page)124 public void remove(@PAGE int page) { 125 mPageSummary.remove(page); 126 } 127 getIpConfiguration()128 public IpConfiguration getIpConfiguration() { 129 return mIpConfiguration; 130 } 131 setIpConfiguration(IpConfiguration ipConfiguration)132 public void setIpConfiguration(IpConfiguration ipConfiguration) { 133 this.mIpConfiguration = ipConfiguration; 134 } 135 isSettingsFlow()136 public boolean isSettingsFlow() { 137 return mSettingsFlow; 138 } 139 setSettingsFlow(boolean settingsFlow)140 public void setSettingsFlow(boolean settingsFlow) { 141 mSettingsFlow = settingsFlow; 142 } 143 setCanStart(boolean canStart)144 public void setCanStart(boolean canStart) { 145 this.mCanStart = canStart; 146 } 147 148 /** 149 * Determine whether can start advanced flow. 150 * 151 * @return true if can. 152 */ canStart()153 public boolean canStart() { 154 return mCanStart; 155 } 156 getPrintableSsid()157 public String getPrintableSsid() { 158 return mPrintableSsid; 159 } 160 setPrintableSsid(String ssid)161 public void setPrintableSsid(String ssid) { 162 this.mPrintableSsid = ssid; 163 } 164 165 /** 166 * Get the initial DNS. 167 */ getInitialDns(int index)168 public InetAddress getInitialDns(int index) { 169 if (mIpConfiguration != null && mIpConfiguration.getStaticIpConfiguration() != null 170 && mIpConfiguration.getStaticIpConfiguration().dnsServers == null) { 171 try { 172 return mIpConfiguration.getStaticIpConfiguration().dnsServers.get(index); 173 } catch (IndexOutOfBoundsException e) { 174 return null; 175 } 176 } 177 return null; 178 } 179 180 /** 181 * Get the initial gateway. 182 */ getInitialGateway()183 public InetAddress getInitialGateway() { 184 if (mIpConfiguration != null && mIpConfiguration.getStaticIpConfiguration() != null) { 185 return mIpConfiguration.getStaticIpConfiguration().gateway; 186 } else { 187 return null; 188 } 189 } 190 191 /** 192 * Get the initial static ip configuration address. 193 */ getInitialLinkAddress()194 public LinkAddress getInitialLinkAddress() { 195 if (mIpConfiguration != null && mIpConfiguration.getStaticIpConfiguration() != null) { 196 return mIpConfiguration.getStaticIpConfiguration().ipAddress; 197 } else { 198 return null; 199 } 200 } 201 202 /** 203 * Get the initial proxy info. 204 */ getInitialProxyInfo()205 public ProxyInfo getInitialProxyInfo() { 206 if (mIpConfiguration != null) { 207 return mIpConfiguration.getHttpProxy(); 208 } else { 209 return null; 210 } 211 } 212 } 213