Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 4a59d0fb authored by lucaslin's avatar lucaslin Committed by Automerger Merge Worker
Browse files

Have a new method in NetworkAgentConfig.Builder to set allowBypass am: 0ad17553

Original change: https://googleplex-android-review.googlesource.com/c/platform/frameworks/base/+/13927662

Change-Id: I5c527cdf926aaa3b136371b56418bfbe4186bf6b
parents 22ee34b0 0ad17553
Loading
Loading
Loading
Loading
+2 −0
Original line number Diff line number Diff line
@@ -36,9 +36,11 @@ package android.net {

  public final class NetworkAgentConfig implements android.os.Parcelable {
    method @Nullable public String getSubscriberId();
    method public boolean isBypassableVpn();
  }

  public static final class NetworkAgentConfig.Builder {
    method @NonNull public android.net.NetworkAgentConfig.Builder setBypassableVpn(boolean);
    method @NonNull public android.net.NetworkAgentConfig.Builder setSubscriberId(@Nullable String);
  }

+23 −0
Original line number Diff line number Diff line
@@ -63,6 +63,16 @@ public final class NetworkAgentConfig implements Parcelable {
        return explicitlySelected;
    }

    /**
     * @return whether this VPN connection can be bypassed by the apps.
     *
     * @hide
     */
    @SystemApi(client = MODULE_LIBRARIES)
    public boolean isBypassableVpn() {
        return allowBypass;
    }

    /**
     * Set if the user desires to use this network even if it is unvalidated. This field has meaning
     * only if {@link explicitlySelected} is true. If it is, this field must also be set to the
@@ -346,6 +356,19 @@ public final class NetworkAgentConfig implements Parcelable {
            return this;
        }

        /**
         * Sets whether the apps can bypass the VPN connection.
         *
         * @return this builder, to facilitate chaining.
         * @hide
         */
        @NonNull
        @SystemApi(client = MODULE_LIBRARIES)
        public Builder setBypassableVpn(boolean allowBypass) {
            mConfig.allowBypass = allowBypass;
            return this;
        }

        /**
         * Returns the constructed {@link NetworkAgentConfig} object.
         */
+3 −2
Original line number Diff line number Diff line
@@ -1248,8 +1248,9 @@ public class Vpn {
        mLegacyState = LegacyVpnInfo.STATE_CONNECTING;
        updateState(DetailedState.CONNECTING, "agentConnect");

        NetworkAgentConfig networkAgentConfig = new NetworkAgentConfig.Builder().build();
        networkAgentConfig.allowBypass = mConfig.allowBypass && !mLockdown;
        final NetworkAgentConfig networkAgentConfig = new NetworkAgentConfig.Builder()
                .setBypassableVpn(mConfig.allowBypass && !mLockdown)
                .build();

        capsBuilder.setOwnerUid(mOwnerUID);
        capsBuilder.setAdministratorUids(new int[] {mOwnerUID});