VPN reconnection fails after manually disabling VPN

When disabling VPN manually, there was no trigger for ipsec-tools to
send “delete message” to VPN server. Therefore, connection information
is left in VPN server and next connection fails.

Fix this issue as below:
- Add “delete message” sending via flush in ipsec-tools when racoon
  daemon stops
- Keep daemon alive when VPN.java exit() to let it finish sending to
  VPN server
- Move close(socket) and stop(daemon) in VPN.java execute()
  and monitorDaemons() to run() to gather cleaning block.

Bug: 28279646
Change-Id: Ie5a9497189da8c96321a220ea21ebe63e42d0751
This commit is contained in:
Hisanobu Watanabe
2016-06-07 19:55:41 +09:00
committed by Toshiya Ikenaga
parent 8ee58b3b4e
commit 047454c759

View File

@@ -1157,9 +1157,6 @@ public class Vpn {
public void exit() {
// We assume that everything is reset after stopping the daemons.
interrupt();
for (LocalSocket socket : mSockets) {
IoUtils.closeQuietly(socket);
}
agentDisconnect();
try {
mContext.unregisterReceiver(mBroadcastReceiver);
@@ -1172,8 +1169,26 @@ public class Vpn {
Log.v(TAG, "Waiting");
synchronized (TAG) {
Log.v(TAG, "Executing");
execute();
monitorDaemons();
try {
execute();
monitorDaemons();
interrupted(); // Clear interrupt flag if execute called exit.
} catch (InterruptedException e) {
} finally {
for (LocalSocket socket : mSockets) {
IoUtils.closeQuietly(socket);
}
// This sleep is necessary for racoon to successfully complete sending delete
// message to server.
try {
Thread.sleep(50);
} catch (InterruptedException e) {
}
for (String daemon : mDaemons) {
SystemService.stop(daemon);
}
}
agentDisconnect();
}
}
@@ -1372,18 +1387,6 @@ public class Vpn {
Log.i(TAG, "Aborting", e);
updateState(DetailedState.FAILED, e.getMessage());
exit();
} finally {
// Kill the daemons if they fail to stop.
if (!initFinished) {
for (String daemon : mDaemons) {
SystemService.stop(daemon);
}
}
// Do not leave an unstable state.
if (!initFinished || mNetworkInfo.getDetailedState() == DetailedState.CONNECTING) {
agentDisconnect();
}
}
}
@@ -1391,28 +1394,17 @@ public class Vpn {
* Monitor the daemons we started, moving to disconnected state if the
* underlying services fail.
*/
private void monitorDaemons() {
private void monitorDaemons() throws InterruptedException{
if (!mNetworkInfo.isConnected()) {
return;
}
try {
while (true) {
Thread.sleep(2000);
for (int i = 0; i < mDaemons.length; i++) {
if (mArguments[i] != null && SystemService.isStopped(mDaemons[i])) {
return;
}
while (true) {
Thread.sleep(2000);
for (int i = 0; i < mDaemons.length; i++) {
if (mArguments[i] != null && SystemService.isStopped(mDaemons[i])) {
return;
}
}
} catch (InterruptedException e) {
Log.d(TAG, "interrupted during monitorDaemons(); stopping services");
} finally {
for (String daemon : mDaemons) {
SystemService.stop(daemon);
}
agentDisconnect();
}
}
}