summaryrefslogtreecommitdiffstats
path: root/src/networkmanager.h
diff options
context:
space:
mode:
authorNiklas2011-10-10 17:08:35 +0200
committerNiklas2011-10-10 17:08:35 +0200
commit5aa568daae23daa7ac190e56df469e9566075257 (patch)
treef339f20eccc838640cded864bf3fe37b056b4b36 /src/networkmanager.h
parentcorrected some errors (diff)
downloadfbgui-5aa568daae23daa7ac190e56df469e9566075257.tar.gz
fbgui-5aa568daae23daa7ac190e56df469e9566075257.tar.xz
fbgui-5aa568daae23daa7ac190e56df469e9566075257.zip
new veriosn of the fbgui src (same as in fbgui-ng) combined with my networkDiscovery in front.
Diffstat (limited to 'src/networkmanager.h')
-rw-r--r--src/networkmanager.h54
1 files changed, 54 insertions, 0 deletions
diff --git a/src/networkmanager.h b/src/networkmanager.h
new file mode 100644
index 0000000..3fb1587
--- /dev/null
+++ b/src/networkmanager.h
@@ -0,0 +1,54 @@
+/*
+ * networkmanager.h
+ *
+ * Created on: Sep 5, 2011
+ * Author: niklas
+ */
+
+#ifndef NETWORKMANAGER_H_
+#define NETWORKMANAGER_H_
+
+#include <arpa/inet.h>
+#include <net/if.h>
+#include <netlink/netlink.h>
+#include <netlink/netlink-kernel.h>
+#include <netlink/route/addr.h>
+#include <netlink/route/rtnl.h>
+#include <netlink/route/route.h>
+#include <netlink/route/link.h>
+
+#include <errno.h>
+#include <QtCore>
+#include <QNetworkAddressEntry>
+
+class NetworkManager: public QObject {
+Q_OBJECT
+
+public:
+ NetworkManager();
+ virtual ~NetworkManager();
+
+ int replaceDefaultRoute(QString ifname, QString gateway, int metric,
+ int af);
+
+ int bringInterfaceUP(QString ifname);
+ int bringInterfaceDown(QString ifname);
+
+ int ip4_setManualConfiguration(QString ifname, QString ipAddress, QString netmask,
+ QString broadcast, QString gateway, int metric, int af, QString pathToResolvConf, QList<QString> nameServer);
+ int ip4_configureInterface(QString ifname, QString ipAddress,
+ QString broadcast, QString netmask, int af);
+ int writeResolvConf(QString path, QString ifname, QList<QString> nameServer);
+
+private:
+ QString _tag;
+ int bringInterfaceUpDown(QString ifname, bool up);
+ int ip4_netmaskToPrefix(QString ipAddr, QString netmask);
+
+ int sync_address(const char *iface, int ifindex, int family,
+ struct rtnl_addr *addr);
+
+
+};
+
+#endif /* NETWORKMANAGER_H_ */