WireGuard rework for MacOS and Windows (#314)
WireGuard rework for MacOS and Windows
This commit is contained in:
parent
421a27ceae
commit
07c38e9b6c
60 changed files with 4779 additions and 434 deletions
|
@ -6,13 +6,16 @@
|
|||
|
||||
#include <QMetaEnum>
|
||||
|
||||
//#include "controller.h"
|
||||
#include "leakdetector.h"
|
||||
#include "logger.h"
|
||||
//#include "mozillavpn.h"
|
||||
#include "networkwatcherimpl.h"
|
||||
#include "platforms/dummy/dummynetworkwatcher.h"
|
||||
//#include "settingsholder.h"
|
||||
|
||||
#ifdef MZ_WINDOWS
|
||||
//# include "platforms/windows/windowsnetworkwatcher.h"
|
||||
# include "platforms/windows/windowsnetworkwatcher.h"
|
||||
#endif
|
||||
|
||||
#ifdef MZ_LINUX
|
||||
|
@ -51,9 +54,9 @@ void NetworkWatcher::initialize() {
|
|||
logger.debug() << "Initialize";
|
||||
|
||||
#if defined(MZ_WINDOWS)
|
||||
//m_impl = new WindowsNetworkWatcher(this);
|
||||
m_impl = new WindowsNetworkWatcher(this);
|
||||
#elif defined(MZ_LINUX)
|
||||
//m_impl = new LinuxNetworkWatcher(this);
|
||||
// m_impl = new LinuxNetworkWatcher(this);
|
||||
#elif defined(MZ_MACOS)
|
||||
m_impl = new MacOSNetworkWatcher(this);
|
||||
#elif defined(MZ_WASM)
|
||||
|
@ -73,11 +76,34 @@ void NetworkWatcher::initialize() {
|
|||
|
||||
m_impl->initialize();
|
||||
|
||||
//TODO IMPL FOR AMNEZIA
|
||||
|
||||
// TODO: IMPL FOR AMNEZIA
|
||||
#if 0
|
||||
SettingsHolder* settingsHolder = SettingsHolder::instance();
|
||||
Q_ASSERT(settingsHolder);
|
||||
|
||||
m_active = settingsHolder->unsecuredNetworkAlert() ||
|
||||
settingsHolder->captivePortalAlert();
|
||||
m_reportUnsecuredNetwork = settingsHolder->unsecuredNetworkAlert();
|
||||
if (m_active) {
|
||||
m_impl->start();
|
||||
}
|
||||
|
||||
connect(settingsHolder, &SettingsHolder::unsecuredNetworkAlertChanged, this,
|
||||
&NetworkWatcher::settingsChanged);
|
||||
connect(settingsHolder, &SettingsHolder::captivePortalAlertChanged, this,
|
||||
&NetworkWatcher::settingsChanged);
|
||||
|
||||
#endif
|
||||
}
|
||||
|
||||
void NetworkWatcher::settingsChanged() {
|
||||
//TODO IMPL FOR AMNEZIA
|
||||
// TODO: IMPL FOR AMNEZIA
|
||||
#if 0
|
||||
SettingsHolder* settingsHolder = SettingsHolder::instance();
|
||||
m_active = settingsHolder->unsecuredNetworkAlert() ||
|
||||
settingsHolder->captivePortalAlert();
|
||||
m_reportUnsecuredNetwork = settingsHolder->unsecuredNetworkAlert();
|
||||
|
||||
if (m_active) {
|
||||
logger.debug()
|
||||
|
@ -88,6 +114,7 @@ void NetworkWatcher::settingsChanged() {
|
|||
logger.debug() << "Stopping Network Watcher";
|
||||
m_impl->stop();
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
void NetworkWatcher::unsecuredNetwork(const QString& networkName,
|
||||
|
@ -95,9 +122,55 @@ void NetworkWatcher::unsecuredNetwork(const QString& networkName,
|
|||
logger.debug() << "Unsecured network:" << logger.sensitive(networkName)
|
||||
<< "id:" << logger.sensitive(networkId);
|
||||
|
||||
//TODO IMPL FOR AMNEZIA
|
||||
#ifndef UNIT_TEST
|
||||
if (!m_reportUnsecuredNetwork) {
|
||||
logger.debug() << "Disabled. Ignoring unsecured network";
|
||||
return;
|
||||
}
|
||||
// TODO: IMPL FOR AMNEZIA
|
||||
#if 0
|
||||
MozillaVPN* vpn = MozillaVPN::instance();
|
||||
|
||||
if (vpn->state() != App::StateMain) {
|
||||
logger.debug() << "VPN not ready. Ignoring unsecured network";
|
||||
return;
|
||||
}
|
||||
|
||||
Controller::State state = vpn->controller()->state();
|
||||
if (state == Controller::StateOn || state == Controller::StateConnecting ||
|
||||
state == Controller::StateCheckSubscription ||
|
||||
state == Controller::StateSwitching ||
|
||||
state == Controller::StateSilentSwitching) {
|
||||
logger.debug() << "VPN on. Ignoring unsecured network";
|
||||
return;
|
||||
}
|
||||
|
||||
if (!m_networks.contains(networkId)) {
|
||||
m_networks.insert(networkId, QElapsedTimer());
|
||||
} else if (!m_networks[networkId].hasExpired(NETWORK_WATCHER_TIMER_MSEC)) {
|
||||
logger.debug() << "Notification already shown. Ignoring unsecured network";
|
||||
return;
|
||||
}
|
||||
|
||||
// Let's activate the QElapsedTimer to avoid notification loops.
|
||||
m_networks[networkId].start();
|
||||
|
||||
// We don't connect the system tray handler in the CTOR because it can be too
|
||||
// early. Maybe the NotificationHandler has not been created yet. We do it at
|
||||
// the first detection of an unsecured network.
|
||||
if (m_firstNotification) {
|
||||
connect(NotificationHandler::instance(),
|
||||
&NotificationHandler::notificationClicked, this,
|
||||
&NetworkWatcher::notificationClicked);
|
||||
m_firstNotification = false;
|
||||
}
|
||||
|
||||
NotificationHandler::instance()->unsecuredNetworkNotification(networkName);
|
||||
#endif
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
QString NetworkWatcher::getCurrentTransport() {
|
||||
auto type = m_impl->getTransportType();
|
||||
QMetaEnum metaEnum = QMetaEnum::fromType<NetworkWatcherImpl::TransportType>();
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue