1 /* 2 * Copyright (C) 2015 The Android Open Source Project 3 * 4 * Licensed urnder 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 package android.net; 17 18 import android.os.IBinder; 19 import android.os.Parcel; 20 import android.os.Parcelable; 21 import android.os.RemoteException; 22 23 /** 24 * A class allowing apps handling the {@link ConnectivityManager#ACTION_CAPTIVE_PORTAL_SIGN_IN} 25 * activity to indicate to the system different outcomes of captive portal sign in. This class is 26 * passed as an extra named {@link ConnectivityManager#EXTRA_CAPTIVE_PORTAL} with the 27 * {@code ACTION_CAPTIVE_PORTAL_SIGN_IN} activity. 28 */ 29 public class CaptivePortal implements Parcelable { 30 /** @hide */ 31 public static final int APP_RETURN_DISMISSED = 0; 32 /** @hide */ 33 public static final int APP_RETURN_UNWANTED = 1; 34 /** @hide */ 35 public static final int APP_RETURN_WANTED_AS_IS = 2; 36 37 private final IBinder mBinder; 38 39 /** @hide */ CaptivePortal(IBinder binder)40 public CaptivePortal(IBinder binder) { 41 mBinder = binder; 42 } 43 44 @Override describeContents()45 public int describeContents() { 46 return 0; 47 } 48 49 @Override writeToParcel(Parcel out, int flags)50 public void writeToParcel(Parcel out, int flags) { 51 out.writeStrongBinder(mBinder); 52 } 53 54 public static final Parcelable.Creator<CaptivePortal> CREATOR 55 = new Parcelable.Creator<CaptivePortal>() { 56 @Override 57 public CaptivePortal createFromParcel(Parcel in) { 58 return new CaptivePortal(in.readStrongBinder()); 59 } 60 61 @Override 62 public CaptivePortal[] newArray(int size) { 63 return new CaptivePortal[size]; 64 } 65 }; 66 67 /** 68 * Indicate to the system that the captive portal has been 69 * dismissed. In response the framework will re-evaluate the network's 70 * connectivity and might take further action thereafter. 71 */ reportCaptivePortalDismissed()72 public void reportCaptivePortalDismissed() { 73 try { 74 ICaptivePortal.Stub.asInterface(mBinder).appResponse(APP_RETURN_DISMISSED); 75 } catch (RemoteException e) { 76 } 77 } 78 79 /** 80 * Indicate to the system that the user does not want to pursue signing in to the 81 * captive portal and the system should continue to prefer other networks 82 * without captive portals for use as the default active data network. The 83 * system will not retest the network for a captive portal so as to avoid 84 * disturbing the user with further sign in to network notifications. 85 */ ignoreNetwork()86 public void ignoreNetwork() { 87 try { 88 ICaptivePortal.Stub.asInterface(mBinder).appResponse(APP_RETURN_UNWANTED); 89 } catch (RemoteException e) { 90 } 91 } 92 93 /** 94 * Indicate to the system the user wants to use this network as is, even though 95 * the captive portal is still in place. The system will treat the network 96 * as if it did not have a captive portal when selecting the network to use 97 * as the default active data network. This may result in this network 98 * becoming the default active data network, which could disrupt network 99 * connectivity for apps because the captive portal is still in place. 100 * @hide 101 */ useNetwork()102 public void useNetwork() { 103 try { 104 ICaptivePortal.Stub.asInterface(mBinder).appResponse(APP_RETURN_WANTED_AS_IS); 105 } catch (RemoteException e) { 106 } 107 } 108 } 109