| /* |
| * Copyright (C) 2016 Google Inc. |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); you may not |
| * use this file except in compliance with the License. You may obtain a copy of |
| * the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT |
| * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the |
| * License for the specific language governing permissions and limitations under |
| * the License. |
| */ |
| |
| package com.googlecode.android_scripting.facade; |
| |
| import java.util.ArrayList; |
| import java.util.List; |
| |
| import org.json.JSONObject; |
| |
| import com.android.internal.net.LegacyVpnInfo; |
| import com.android.internal.net.VpnConfig; |
| import com.android.internal.net.VpnProfile; |
| import com.android.internal.util.ArrayUtils; |
| import com.google.android.collect.Lists; |
| import com.googlecode.android_scripting.jsonrpc.RpcReceiver; |
| import com.googlecode.android_scripting.rpc.Rpc; |
| import com.googlecode.android_scripting.rpc.RpcParameter; |
| |
| import android.app.Service; |
| import android.content.Context; |
| import android.net.IConnectivityManager; |
| import android.os.RemoteException; |
| import android.os.ServiceManager; |
| import android.security.Credentials; |
| import android.security.KeyStore; |
| |
| /** |
| * Access NFC functions. |
| */ |
| public class VpnFacade extends RpcReceiver { |
| |
| private final Service mService; |
| private final IConnectivityManager mConService; |
| |
| public VpnFacade(FacadeManager manager) { |
| super(manager); |
| mService = manager.getService(); |
| mConService = IConnectivityManager.Stub |
| .asInterface(ServiceManager.getService(Context.CONNECTIVITY_SERVICE)); |
| } |
| |
| static List<VpnProfile> loadVpnProfiles(KeyStore keyStore, int... excludeTypes) { |
| final ArrayList<VpnProfile> result = Lists.newArrayList(); |
| |
| for (String key : keyStore.list(Credentials.VPN)) { |
| final VpnProfile profile = VpnProfile.decode(key, keyStore.get(Credentials.VPN + key)); |
| if (profile != null && !ArrayUtils.contains(excludeTypes, profile.type)) { |
| result.add(profile); |
| } |
| } |
| return result; |
| } |
| |
| private VpnProfile genLegacyVpnProfile(JSONObject vpnProfileJson) { |
| VpnProfile vp = new VpnProfile(vpnProfileJson.optString("key", "")); |
| vp.name = vpnProfileJson.optString("name", ""); |
| vp.type = vpnProfileJson.optInt("type", VpnProfile.TYPE_PPTP); |
| vp.server = vpnProfileJson.optString("server", ""); |
| vp.username = vpnProfileJson.optString("username", ""); |
| vp.password = vpnProfileJson.optString("password", ""); |
| vp.dnsServers = vpnProfileJson.optString("dnsServers", ""); |
| vp.searchDomains = vpnProfileJson.optString("searchDomains", ""); |
| vp.routes = vpnProfileJson.optString("routes", ""); |
| vp.mppe = vpnProfileJson.optBoolean("mppe", true); |
| vp.l2tpSecret = vpnProfileJson.optString("l2tpSecret", ""); |
| vp.ipsecIdentifier = vpnProfileJson.optString("ipsecIdentifier", ""); |
| vp.ipsecSecret = vpnProfileJson.optString("ipsecSecret", ""); |
| vp.ipsecUserCert = vpnProfileJson.optString("ipsecUserCert", ""); |
| vp.ipsecCaCert = vpnProfileJson.optString("ipsecCaCert", ""); |
| vp.ipsecServerCert = vpnProfileJson.optString("ipsecServerCert", ""); |
| vp.saveLogin = vpnProfileJson.optBoolean("saveLogin", false); |
| return vp; |
| } |
| |
| @Rpc(description = "Start legacy VPN with a profile.") |
| public void vpnStartLegacyVpn(@RpcParameter(name = "vpnProfile") JSONObject vpnProfile) |
| throws RemoteException { |
| VpnProfile profile = genLegacyVpnProfile(vpnProfile); |
| mConService.startLegacyVpn(profile); |
| } |
| |
| @Rpc(description = "Stop the current legacy VPN connection.") |
| public void vpnStopLegacyVpn() throws RemoteException { |
| mConService.prepareVpn(VpnConfig.LEGACY_VPN, VpnConfig.LEGACY_VPN, mService.getUserId()); |
| } |
| |
| @Rpc(description = "Get the info object of the currently active legacy VPN connection.") |
| public LegacyVpnInfo vpnGetLegacyVpnInfo() throws RemoteException { |
| return mConService.getLegacyVpnInfo(mService.getUserId()); |
| } |
| |
| @Override |
| public void shutdown() { |
| } |
| |
| } |