Merge branch 'feature/qt6-libssh-support' of github.com:amnezia-vpn/desktop-client into feature/qt6-libssh-support
This commit is contained in:
commit
05cd4ac14b
9 changed files with 67 additions and 32 deletions
|
|
@ -7,6 +7,10 @@ if(ANDROID)
|
||||||
set(QT_ANDROID_BUILD_ALL_ABIS ON)
|
set(QT_ANDROID_BUILD_ALL_ABIS ON)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
if(APPLE AND NOT IOS)
|
||||||
|
set(CMAKE_OSX_ARCHITECTURES "x86_64")
|
||||||
|
endif()
|
||||||
|
|
||||||
add_subdirectory(client)
|
add_subdirectory(client)
|
||||||
|
|
||||||
if(NOT IOS AND NOT ANDROID)
|
if(NOT IOS AND NOT ANDROID)
|
||||||
|
|
|
||||||
|
|
@ -664,13 +664,16 @@ ErrorCode ServerController::isServerPortBusy(const ServerCredentials &credential
|
||||||
return ErrorCode::NoError;
|
return ErrorCode::NoError;
|
||||||
};
|
};
|
||||||
|
|
||||||
const QString containerString = ProtocolProps::protoToString(ContainerProps::defaultProtocol(container));
|
const Proto protocol = ContainerProps::defaultProtocol(container);
|
||||||
|
const QString containerString = ProtocolProps::protoToString(protocol);
|
||||||
const QJsonObject containerConfig = config.value(containerString).toObject();
|
const QJsonObject containerConfig = config.value(containerString).toObject();
|
||||||
|
|
||||||
QStringList fixedPorts = ContainerProps::fixedPortsForContainer(container);
|
QStringList fixedPorts = ContainerProps::fixedPortsForContainer(container);
|
||||||
|
|
||||||
QString port = containerConfig.value(config_key::port).toString(protocols::openvpn::defaultPort);
|
QString defaultPort("%1");
|
||||||
QString transportProto = containerConfig.value(config_key::transport_proto).toString(protocols::openvpn::defaultTransportProto);
|
QString port = containerConfig.value(config_key::port).toString(defaultPort.arg(ProtocolProps::defaultPort(protocol)));
|
||||||
|
QString defaultTransportProto = ProtocolProps::transportProtoToString(ProtocolProps::defaultTransportProto(protocol), protocol);
|
||||||
|
QString transportProto = containerConfig.value(config_key::transport_proto).toString(defaultTransportProto);
|
||||||
|
|
||||||
QString script = QString("sudo lsof -i -P -n | grep -E ':%1 ").arg(port);
|
QString script = QString("sudo lsof -i -P -n | grep -E ':%1 ").arg(port);
|
||||||
for (auto &port : fixedPorts) {
|
for (auto &port : fixedPorts) {
|
||||||
|
|
|
||||||
|
|
@ -69,7 +69,7 @@ void AdvancedServerSettingsLogic::onPushButtonScanServerClicked()
|
||||||
|
|
||||||
bool isServerCreated;
|
bool isServerCreated;
|
||||||
auto containersCount = m_settings->containers(uiLogic()->m_selectedServerIndex).size();
|
auto containersCount = m_settings->containers(uiLogic()->m_selectedServerIndex).size();
|
||||||
ErrorCode errorCode = uiLogic()->addAlreadyInstalledContainersGui(false, isServerCreated);
|
ErrorCode errorCode = uiLogic()->addAlreadyInstalledContainersGui(isServerCreated);
|
||||||
if (errorCode != ErrorCode::NoError) {
|
if (errorCode != ErrorCode::NoError) {
|
||||||
emit uiLogic()->showWarningMessage(tr("Error occurred while scanning the server.") + "\n" +
|
emit uiLogic()->showWarningMessage(tr("Error occurred while scanning the server.") + "\n" +
|
||||||
tr("Error message: ") + errorString(errorCode) + "\n" +
|
tr("Error message: ") + errorString(errorCode) + "\n" +
|
||||||
|
|
|
||||||
|
|
@ -8,6 +8,7 @@
|
||||||
#include <QDesktopServices>
|
#include <QDesktopServices>
|
||||||
#include <QFileDialog>
|
#include <QFileDialog>
|
||||||
#include <QStandardPaths>
|
#include <QStandardPaths>
|
||||||
|
#include <utilities.h>
|
||||||
|
|
||||||
using namespace amnezia;
|
using namespace amnezia;
|
||||||
using namespace PageEnumNS;
|
using namespace PageEnumNS;
|
||||||
|
|
@ -82,7 +83,7 @@ void AppSettingsLogic::onPushButtonBackupAppConfigClicked()
|
||||||
|
|
||||||
void AppSettingsLogic::onPushButtonRestoreAppConfigClicked()
|
void AppSettingsLogic::onPushButtonRestoreAppConfigClicked()
|
||||||
{
|
{
|
||||||
QString fileName = QFileDialog::getOpenFileName(Q_NULLPTR, tr("Open backup"),
|
QString fileName = UiLogic::getOpenFileName(Q_NULLPTR, tr("Open backup"),
|
||||||
QStandardPaths::writableLocation(QStandardPaths::DocumentsLocation), "*.backup");
|
QStandardPaths::writableLocation(QStandardPaths::DocumentsLocation), "*.backup");
|
||||||
|
|
||||||
if (fileName.isEmpty()) return;
|
if (fileName.isEmpty()) return;
|
||||||
|
|
@ -98,6 +99,5 @@ void AppSettingsLogic::onPushButtonRestoreAppConfigClicked()
|
||||||
} else {
|
} else {
|
||||||
emit uiLogic()->showWarningMessage(tr("Can't import config, file is corrupted."));
|
emit uiLogic()->showWarningMessage(tr("Can't import config, file is corrupted."));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -4,9 +4,7 @@
|
||||||
|
|
||||||
#include <QApplication>
|
#include <QApplication>
|
||||||
|
|
||||||
#include "protocols/CloakLogic.h"
|
#include "protocols/PageProtocolLogicBase.h"
|
||||||
#include "protocols/OpenVpnLogic.h"
|
|
||||||
#include "protocols/ShadowSocksLogic.h"
|
|
||||||
|
|
||||||
#include "core/servercontroller.h"
|
#include "core/servercontroller.h"
|
||||||
#include <functional>
|
#include <functional>
|
||||||
|
|
@ -92,7 +90,7 @@ void ServerContainersLogic::onPushButtonContinueClicked(DockerContainer c, int p
|
||||||
qApp->processEvents();
|
qApp->processEvents();
|
||||||
|
|
||||||
bool isServerCreated = false;
|
bool isServerCreated = false;
|
||||||
ErrorCode errorCode = uiLogic()->addAlreadyInstalledContainersGui(false, isServerCreated);
|
ErrorCode errorCode = uiLogic()->addAlreadyInstalledContainersGui(isServerCreated);
|
||||||
|
|
||||||
if (errorCode == ErrorCode::NoError) {
|
if (errorCode == ErrorCode::NoError) {
|
||||||
if (!uiLogic()->isContainerAlreadyAddedToGui(c)) {
|
if (!uiLogic()->isContainerAlreadyAddedToGui(c)) {
|
||||||
|
|
|
||||||
|
|
@ -184,7 +184,7 @@ void StartPageLogic::onPushButtonImport()
|
||||||
|
|
||||||
void StartPageLogic::onPushButtonImportOpenFile()
|
void StartPageLogic::onPushButtonImportOpenFile()
|
||||||
{
|
{
|
||||||
QString fileName = QFileDialog::getOpenFileName(Q_NULLPTR, tr("Open config file"),
|
QString fileName = UiLogic::getOpenFileName(Q_NULLPTR, tr("Open config file"),
|
||||||
QStandardPaths::writableLocation(QStandardPaths::DocumentsLocation), "*.vpn *.ovpn *.conf");
|
QStandardPaths::writableLocation(QStandardPaths::DocumentsLocation), "*.vpn *.ovpn *.conf");
|
||||||
if (fileName.isEmpty()) return;
|
if (fileName.isEmpty()) return;
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -3,7 +3,6 @@
|
||||||
#include <QDebug>
|
#include <QDebug>
|
||||||
#include <QDesktopServices>
|
#include <QDesktopServices>
|
||||||
#include <QFile>
|
#include <QFile>
|
||||||
#include <QFileDialog>
|
|
||||||
#include <QHostInfo>
|
#include <QHostInfo>
|
||||||
#include <QItemSelectionModel>
|
#include <QItemSelectionModel>
|
||||||
#include <QJsonDocument>
|
#include <QJsonDocument>
|
||||||
|
|
@ -330,7 +329,7 @@ void UiLogic::installServer(QPair<DockerContainer, QJsonObject> &container)
|
||||||
};
|
};
|
||||||
|
|
||||||
bool isServerCreated = false;
|
bool isServerCreated = false;
|
||||||
ErrorCode errorCode = addAlreadyInstalledContainersGui(true, isServerCreated);
|
ErrorCode errorCode = addAlreadyInstalledContainersGui(isServerCreated);
|
||||||
if (errorCode == ErrorCode::NoError) {
|
if (errorCode == ErrorCode::NoError) {
|
||||||
if (!isContainerAlreadyAddedToGui(container.first)) {
|
if (!isContainerAlreadyAddedToGui(container.first)) {
|
||||||
progressBarFunc.setTextFunc(QString("Installing %1").arg(ContainerProps::containerToString(container.first)));
|
progressBarFunc.setTextFunc(QString("Installing %1").arg(ContainerProps::containerToString(container.first)));
|
||||||
|
|
@ -497,6 +496,24 @@ void UiLogic::shareTempFile(const QString &suggestedName, QString ext, const QSt
|
||||||
MobileUtils::shareText(filesToSend);
|
MobileUtils::shareText(filesToSend);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
QString UiLogic::getOpenFileName(QWidget *parent, const QString &caption, const QString &dir,
|
||||||
|
const QString &filter, QString *selectedFilter, QFileDialog::Options options)
|
||||||
|
{
|
||||||
|
QString fileName = QFileDialog::getOpenFileName(parent, caption, dir, filter, selectedFilter, options);
|
||||||
|
|
||||||
|
#ifdef Q_OS_ANDROID
|
||||||
|
// patch for files containing spaces etc
|
||||||
|
const QString sep {"raw%3A%2F"};
|
||||||
|
if (fileName.startsWith("content://") && fileName.contains(sep)) {
|
||||||
|
QString contentUrl = fileName.split(sep).at(0);
|
||||||
|
QString rawUrl = fileName.split(sep).at(1);
|
||||||
|
rawUrl.replace(" ", "%20");
|
||||||
|
fileName = contentUrl + sep + rawUrl;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
return fileName;
|
||||||
|
}
|
||||||
|
|
||||||
void UiLogic::registerPagesLogic()
|
void UiLogic::registerPagesLogic()
|
||||||
{
|
{
|
||||||
amnApp->qmlEngine()->rootContext()->setContextProperty("UiLogic", this);
|
amnApp->qmlEngine()->rootContext()->setContextProperty("UiLogic", this);
|
||||||
|
|
@ -519,14 +536,22 @@ void UiLogic::registerPagesLogic()
|
||||||
registerPageLogic<AdvancedServerSettingsLogic>();
|
registerPageLogic<AdvancedServerSettingsLogic>();
|
||||||
}
|
}
|
||||||
|
|
||||||
ErrorCode UiLogic::addAlreadyInstalledContainersGui(bool createNewServer, bool &isServerCreated)
|
ErrorCode UiLogic::addAlreadyInstalledContainersGui(bool &isServerCreated)
|
||||||
{
|
{
|
||||||
isServerCreated = false;
|
isServerCreated = false;
|
||||||
ServerCredentials credentials;
|
ServerCredentials installCredentials = m_installCredentials;
|
||||||
if (createNewServer) {
|
bool createNewServer = true;
|
||||||
credentials = m_installCredentials;
|
int serverIndex;
|
||||||
} else {
|
|
||||||
credentials = m_settings->serverCredentials(m_selectedServerIndex);
|
for (int i = 0; i < m_settings->serversCount(); i++) {
|
||||||
|
const ServerCredentials credentials = m_settings->serverCredentials(i);
|
||||||
|
if (m_installCredentials.hostName == credentials.hostName && m_installCredentials.port == credentials.port) {
|
||||||
|
createNewServer = false;
|
||||||
|
isServerCreated = true;
|
||||||
|
installCredentials = credentials;
|
||||||
|
serverIndex = i;
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
QMap<DockerContainer, QJsonObject> installedContainers;
|
QMap<DockerContainer, QJsonObject> installedContainers;
|
||||||
|
|
@ -540,10 +565,10 @@ ErrorCode UiLogic::addAlreadyInstalledContainersGui(bool createNewServer, bool &
|
||||||
QJsonObject server;
|
QJsonObject server;
|
||||||
QJsonArray containerConfigs;
|
QJsonArray containerConfigs;
|
||||||
if (createNewServer) {
|
if (createNewServer) {
|
||||||
server.insert(config_key::hostName, credentials.hostName);
|
server.insert(config_key::hostName, installCredentials.hostName);
|
||||||
server.insert(config_key::userName, credentials.userName);
|
server.insert(config_key::userName, installCredentials.userName);
|
||||||
server.insert(config_key::password, credentials.password);
|
server.insert(config_key::password, installCredentials.password);
|
||||||
server.insert(config_key::port, credentials.port);
|
server.insert(config_key::port, installCredentials.port);
|
||||||
server.insert(config_key::description, m_settings->nextAvailableServerName());
|
server.insert(config_key::description, m_settings->nextAvailableServerName());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -556,8 +581,8 @@ ErrorCode UiLogic::addAlreadyInstalledContainersGui(bool createNewServer, bool &
|
||||||
containerConfigs.append(container.value());
|
containerConfigs.append(container.value());
|
||||||
server.insert(config_key::containers, containerConfigs);
|
server.insert(config_key::containers, containerConfigs);
|
||||||
} else {
|
} else {
|
||||||
m_settings->setContainerConfig(m_selectedServerIndex, container.key(), container.value());
|
m_settings->setContainerConfig(serverIndex, container.key(), container.value());
|
||||||
m_settings->setDefaultContainer(m_selectedServerIndex, installedContainers.firstKey());
|
m_settings->setDefaultContainer(serverIndex, installedContainers.firstKey());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,12 +1,13 @@
|
||||||
#ifndef UILOGIC_H
|
#ifndef UILOGIC_H
|
||||||
#define UILOGIC_H
|
#define UILOGIC_H
|
||||||
|
|
||||||
#include <QRegularExpressionValidator>
|
#include <QFileDialog>
|
||||||
#include <QQmlEngine>
|
|
||||||
#include <functional>
|
|
||||||
#include <QKeyEvent>
|
#include <QKeyEvent>
|
||||||
|
#include <QRegularExpressionValidator>
|
||||||
#include <QThread>
|
#include <QThread>
|
||||||
|
#include <QQmlEngine>
|
||||||
|
|
||||||
|
#include <functional>
|
||||||
#include <typeindex>
|
#include <typeindex>
|
||||||
#include <typeinfo>
|
#include <typeinfo>
|
||||||
#include <unordered_map>
|
#include <unordered_map>
|
||||||
|
|
@ -115,10 +116,15 @@ public:
|
||||||
Q_INVOKABLE void saveBinaryFile(const QString& desc, QString ext, const QString& data);
|
Q_INVOKABLE void saveBinaryFile(const QString& desc, QString ext, const QString& data);
|
||||||
Q_INVOKABLE void copyToClipboard(const QString& text);
|
Q_INVOKABLE void copyToClipboard(const QString& text);
|
||||||
|
|
||||||
Q_INVOKABLE amnezia::ErrorCode addAlreadyInstalledContainersGui(bool createNewServer, bool &isServerCreated);
|
Q_INVOKABLE amnezia::ErrorCode addAlreadyInstalledContainersGui(bool &isServerCreated);
|
||||||
|
|
||||||
void shareTempFile(const QString &suggestedName, QString ext, const QString& data);
|
void shareTempFile(const QString &suggestedName, QString ext, const QString& data);
|
||||||
|
static QString getOpenFileName(QWidget *parent = nullptr,
|
||||||
|
const QString &caption = QString(),
|
||||||
|
const QString &dir = QString(),
|
||||||
|
const QString &filter = QString(),
|
||||||
|
QString *selectedFilter = nullptr,
|
||||||
|
QFileDialog::Options options = QFileDialog::Options());
|
||||||
signals:
|
signals:
|
||||||
void goToPage(PageEnumNS::Page page, bool reset = true, bool slide = true);
|
void goToPage(PageEnumNS::Page page, bool reset = true, bool slide = true);
|
||||||
void goToProtocolPage(Proto protocol, bool reset = true, bool slide = true);
|
void goToProtocolPage(Proto protocol, bool reset = true, bool slide = true);
|
||||||
|
|
|
||||||
|
|
@ -50,7 +50,6 @@ public:
|
||||||
static QString wireguardExecPath();
|
static QString wireguardExecPath();
|
||||||
static QString certUtilPath();
|
static QString certUtilPath();
|
||||||
|
|
||||||
|
|
||||||
#ifdef Q_OS_WIN
|
#ifdef Q_OS_WIN
|
||||||
static bool signalCtrl(DWORD dwProcessId, DWORD dwCtrlEvent);
|
static bool signalCtrl(DWORD dwProcessId, DWORD dwCtrlEvent);
|
||||||
#endif
|
#endif
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue