From 1e0dd58661c9097fb41218ee7e3515f2d8ba8dac Mon Sep 17 00:00:00 2001 From: tpearson Date: Mon, 17 Oct 2011 17:38:53 +0000 Subject: Add dead-ended knetworkmanager 0.8 source Add copy of same for knetworkmanager 0.9 starting point git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/applications/knetworkmanager8@1259314 283d02a7-25f6-0310-bc7c-ecb5cbfe19da --- .../src/knetworkmanager-connection_setting_vpn.cpp | 206 +++++++++++++++++++++ 1 file changed, 206 insertions(+) create mode 100644 knetworkmanager-0.8/src/knetworkmanager-connection_setting_vpn.cpp (limited to 'knetworkmanager-0.8/src/knetworkmanager-connection_setting_vpn.cpp') diff --git a/knetworkmanager-0.8/src/knetworkmanager-connection_setting_vpn.cpp b/knetworkmanager-0.8/src/knetworkmanager-connection_setting_vpn.cpp new file mode 100644 index 0000000..22e8b20 --- /dev/null +++ b/knetworkmanager-0.8/src/knetworkmanager-connection_setting_vpn.cpp @@ -0,0 +1,206 @@ +/*************************************************************************** + * + * knetworkmanager-connection_setting_vpn.cpp - A NetworkManager frontend for KDE + * + * Copyright (C) 2005, 2006 Novell, Inc. + * + * Author: Helmut Schaa , + * + * 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 Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + * + **************************************************************************/ + +/* qt headers */ +#include +#include + +/* kde headers */ +#include +#include + +/* TQT_DBus headers*/ +#include +#include + +/* knetworkmanager headers */ +#include "knetworkmanager.h" +#include "knetworkmanager-connection_setting_vpn.h" + +using namespace ConnectionSettings; + +/* + class VPN +*/ +VPN::VPN(Connection* conn) + : ConnectionSetting(conn, NM_SETTING_VPN_SETTING_NAME) +{ + +} + +TQString VPN::getUserName() const +{ + return _userName; +} + +void VPN::setUserName(const TQString& u) +{ + _userName = u; + emitValidityChanged(); +} + +TQString VPN::getServiceType() const +{ + return _serviceType; +} + +void VPN::setServiceType(const TQString& s) +{ + _serviceType = s; + emitValidityChanged(); +} + +TQValueList VPN::getRoutes() const +{ + return _routes; +} + +void VPN::setRoutes(const TQValueList& r) +{ + _routes = r; + emitValidityChanged(); +} + +void VPN::setData(TQMap data) +{ + _data = data; + emitValidityChanged(); +} + +TQMap VPN::getData() const +{ + return _data; +} + +void VPN::setSecrets(const TQMap& data) +{ + _secrets = data; + emitValidityChanged(); +} + +TQMap VPN::getSecrets() const +{ + return _secrets; +} + + +SettingsMap +VPN::toMap() const +{ + SettingsMap map; + + map.insert(NM_SETTING_VPN_SERVICE_TYPE, TQT_DBusData::fromString(_serviceType)); + map.insert(NM_SETTING_VPN_USER_NAME, TQT_DBusData::fromString(_userName)); + + if (!_routes.isEmpty()) + { + TQValueList list; + for (TQValueList::ConstIterator it = _routes.begin(); it != _routes.end(); ++it) + { + list.append(TQT_DBusData::fromString(*it)); + } + } + + // NM expects a String/String map -> convert + TQT_DBusDataMap data; + + for (TQMap::ConstIterator it = _data.begin(); it != _data.end(); ++it) + { + data.insert(it.key(), TQT_DBusData::fromString(it.data())); + } + + map.insert(NM_SETTING_VPN_DATA, TQT_DBusData::fromStringKeyMap(data)); + + + return map; +} + +void +VPN::fromMap(const SettingsMap& map) +{ + SettingsMap::ConstIterator it; + + if ((it = map.find(NM_SETTING_VPN_SERVICE_TYPE)) != map.end()) + _serviceType = it.data().toString(); + + if ((it = map.find(NM_SETTING_VPN_USER_NAME)) != map.end()) + _userName = it.data().toString(); + + TQT_DBusDataMap data; + _data.clear(); + + if ((it = map.find(NM_SETTING_VPN_DATA)) != map.end()) + { + data = it.data().toStringKeyMap(); + for (TQMap::ConstIterator it = data.begin(); it != data.end(); ++it) + { + _data.insert(it.key(), it.data().toString()); + } + } +} + +SettingsMap +VPN::toSecretsMap(bool with_settings) const +{ + SettingsMap map; + + // NM does not want the settings too +/* if (with_settings) + map = toMap();*/ + + // copy all secrets into the map + for (TQMap::ConstIterator it = _secrets.begin(); it != _secrets.end(); ++it) + map.insert(it.key(), TQT_DBusData::fromString(it.data())); + + return map; +} + +bool +VPN::fromSecretsMap(const SettingsMap& map) +{ +/* SettingsMap::ConstIterator it; + TQT_DBusDataMap data; + + if ((it = map.find(NM_SETTING_VPN_DATA)) != map.end()) + { + data = it.data().toStringKeyMap(); + _data = data.toTQMap(); + }*/ + // FIXME + return false; +} + +bool +VPN::isValid() const +{ + // name is essential + if (_userName.isEmpty() || _serviceType.isEmpty()) + return false; + + // data is essential + if (_data.isEmpty()) + return false; + + return true; +} -- cgit v1.2.3