nexus: Introduce skelaton OpenVpnController class + remove some debug messages

Signed-off-by: San Mehat <san@google.com>
This commit is contained in:
San Mehat 2009-05-13 11:54:16 -07:00
parent fa49e2860b
commit 94447ca34b
7 changed files with 150 additions and 10 deletions

View file

@ -21,6 +21,7 @@ LOCAL_SRC_FILES:= \
ScanResult.cpp \
WifiScanner.cpp \
WifiNetwork.cpp \
OpenVpnController.cpp \
LOCAL_MODULE:= nexus

104
nexus/OpenVpnController.cpp Normal file
View file

@ -0,0 +1,104 @@
/*
* Copyright (C) 2008 The Android Open Source Project
*
* 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.
*/
#include <errno.h>
#define LOG_TAG "OpenVpnController"
#include <cutils/log.h>
#include <cutils/properties.h>
#include "OpenVpnController.h"
#define DAEMON_PROP_NAME "vpn.openvpn.status"
OpenVpnController::OpenVpnController() :
VpnController() {
}
int OpenVpnController::start() {
return 0;
}
int OpenVpnController::stop() {
return 0;
}
int OpenVpnController::enable() {
// Validate configuration file
// Validate key file
if (startServiceDaemon())
return -1;
errno = -ENOSYS;
return -1;
}
int OpenVpnController::startServiceDaemon() {
char status[PROPERTY_VALUE_MAX];
int count = 100;
property_set("ctl.start", "openvpn");
sched_yield();
while (count-- > 0) {
if (property_get(DAEMON_PROP_NAME, status, NULL)) {
if (strcmp(status, "ok") == 0)
return 0;
else if (strcmp(DAEMON_PROP_NAME, "failed") == 0)
return -1;
}
usleep(200000);
}
property_set(DAEMON_PROP_NAME, "timeout");
return -1;
}
int OpenVpnController::stopServiceDaemon() {
char status[PROPERTY_VALUE_MAX] = {'\0'};
int count = 50;
if (property_get(DAEMON_PROP_NAME, status, NULL) &&
!strcmp(status, "stopped")) {
LOGD("Service already stopped");
return 0;
}
property_set("ctl.stop", "openvpn");
sched_yield();
while (count-- > 0) {
if (property_get(DAEMON_PROP_NAME, status, NULL)) {
if (!strcmp(status, "stopped"))
break;
}
usleep(100000);
}
if (!count) {
LOGD("Timed out waiting for openvpn to stop");
errno = ETIMEDOUT;
return -1;
}
return 0;
}
int OpenVpnController::disable() {
errno = -ENOSYS;
return -1;
}

40
nexus/OpenVpnController.h Normal file
View file

@ -0,0 +1,40 @@
/*
* Copyright (C) 2008 The Android Open Source Project
*
* 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.
*/
#ifndef _OPEN_VPN_CONTROLLER_H
#define _OPEN_VPN_CONTROLLER_H
#include "VpnController.h"
class OpenVpnController : public VpnController {
public:
OpenVpnController();
virtual ~OpenVpnController() {}
int start();
int stop();
int enable();
int disable();
protected:
private:
int startServiceDaemon();
int stopServiceDaemon();
};
#endif

View file

@ -48,7 +48,6 @@ int TiwlanWifiController::loadFirmware() {
char driver_status[PROPERTY_VALUE_MAX];
int count = 100;
LOGD("loadFirmware()");
property_set("ctl.start", "wlan_loader");
sched_yield();

View file

@ -31,9 +31,6 @@ int VpnController::stop() {
}
int VpnController::enable() {
// Load modules
// Start daemons
errno = -ENOSYS;
return -1;
}

View file

@ -31,8 +31,6 @@ public:
virtual int disable();
protected:
private:
};
#endif

View file

@ -23,7 +23,7 @@
#include "CommandListener.h"
#include "LoopController.h"
#include "VpnController.h"
#include "OpenVpnController.h"
#include "TiwlanWifiController.h"
int main() {
@ -41,7 +41,8 @@ int main() {
nm->attachController(new LoopController());
nm->attachController(new TiwlanWifiController("/system/lib/modules/wlan.ko", "wlan", ""));
nm->attachController(new VpnController());
// nm->attachController(new AndroidL2TPVpnController());
nm->attachController(new OpenVpnController());
if (NetworkManager::Instance()->run()) {
@ -50,11 +51,11 @@ int main() {
}
if (cl->startListener()) {
LOGE("Unable to start CommandListener (%s)", strerror(errno));
LOGE("Unable to start CommandListener (%s)", strerror(errno));
exit (1);
}
// XXX: we'll use the main thread for the NetworkManager eventuall
// XXX: we'll use the main thread for the NetworkManager eventually
while(1) {
sleep(1000);