/*
- * Copyright (C) 2012-2016 Tobias Brunner
+ * Copyright (C) 2012-2017 Tobias Brunner
* Copyright (C) 2012 Giuliano Grassi
* Copyright (C) 2012 Ralf Sager
* HSR Hochschule fuer Technik Rapperswil
public class CharonVpnService extends VpnService implements Runnable, VpnStateService.VpnStateListener
{
private static final String TAG = CharonVpnService.class.getSimpleName();
+ public static final String DISCONNECT_ACTION = "org.strongswan.android.CharonVpnService.DISCONNECT";
public static final String LOG_FILE = "charon.log";
public static final int VPN_STATE_NOTIFICATION_ID = 1;
{
if (intent != null)
{
- Bundle bundle = intent.getExtras();
- VpnProfile profile = null;
- if (bundle != null)
+ if (DISCONNECT_ACTION.equals(intent.getAction()))
{
- profile = mDataSource.getVpnProfile(bundle.getLong(VpnProfileDataSource.KEY_ID));
- if (profile != null)
+ setNextProfile(null);
+ }
+ else
+ {
+ Bundle bundle = intent.getExtras();
+ VpnProfile profile = null;
+ if (bundle != null)
{
- String password = bundle.getString(VpnProfileDataSource.KEY_PASSWORD);
- profile.setPassword(password);
+ profile = mDataSource.getVpnProfile(bundle.getLong(VpnProfileDataSource.KEY_ID));
+ if (profile != null)
+ {
+ String password = bundle.getString(VpnProfileDataSource.KEY_PASSWORD);
+ profile.setPassword(password);
+ }
}
+ setNextProfile(profile);
}
- setNextProfile(profile);
}
return START_NOT_STICKY;
}
/*
- * Copyright (C) 2012-2013 Tobias Brunner
- * Hochschule fuer Technik Rapperswil
+ * Copyright (C) 2012-2017 Tobias Brunner
+ * HSR Hochschule fuer Technik Rapperswil
*
* This program is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by the
* VpnService.Builder object the system binds to the service and keeps
* bound until the file descriptor of the TUN device is closed. thus
* calling stopService() here would not stop (destroy) the service yet,
- * instead we call startService() with an empty Intent which shuts down
+ * instead we call startService() with a specific action which shuts down
* the daemon (and closes the TUN device, if any) */
Context context = getApplicationContext();
Intent intent = new Intent(context, CharonVpnService.class);
+ intent.setAction(CharonVpnService.DISCONNECT_ACTION);
context.startService(intent);
}