summaryrefslogtreecommitdiffstats
path: root/knetworkmanager-0.9/src/knetworkmanager-connection_setting_vpn.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'knetworkmanager-0.9/src/knetworkmanager-connection_setting_vpn.cpp')
-rw-r--r--knetworkmanager-0.9/src/knetworkmanager-connection_setting_vpn.cpp206
1 files changed, 206 insertions, 0 deletions
diff --git a/knetworkmanager-0.9/src/knetworkmanager-connection_setting_vpn.cpp b/knetworkmanager-0.9/src/knetworkmanager-connection_setting_vpn.cpp
new file mode 100644
index 0000000..22e8b20
--- /dev/null
+++ b/knetworkmanager-0.9/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 <[email protected]>, <[email protected]>
+ *
+ * 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 <tqhostaddress.h>
+#include <tqvariant.h>
+
+/* kde headers */
+#include <kdebug.h>
+#include <klocale.h>
+
+/* TQT_DBus headers*/
+#include <tqdbusdata.h>
+#include <tqdbusdatamap.h>
+
+/* 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<TQString> VPN::getRoutes() const
+{
+ return _routes;
+}
+
+void VPN::setRoutes(const TQValueList<TQString>& r)
+{
+ _routes = r;
+ emitValidityChanged();
+}
+
+void VPN::setData(TQMap<TQString, TQString> data)
+{
+ _data = data;
+ emitValidityChanged();
+}
+
+TQMap<TQString, TQString> VPN::getData() const
+{
+ return _data;
+}
+
+void VPN::setSecrets(const TQMap<TQString, TQString>& data)
+{
+ _secrets = data;
+ emitValidityChanged();
+}
+
+TQMap<TQString, TQString> 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<TQT_DBusData> list;
+ for (TQValueList<TQString>::ConstIterator it = _routes.begin(); it != _routes.end(); ++it)
+ {
+ list.append(TQT_DBusData::fromString(*it));
+ }
+ }
+
+ // NM expects a String/String map -> convert
+ TQT_DBusDataMap<TQString> data;
+
+ for (TQMap<TQString, TQString>::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<TQString> data;
+ _data.clear();
+
+ if ((it = map.find(NM_SETTING_VPN_DATA)) != map.end())
+ {
+ data = it.data().toStringKeyMap();
+ for (TQMap<TQString, TQT_DBusData>::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<TQString, TQString>::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<TQString> 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;
+}