mirror of
https://github.com/yuezk/GlobalProtect-openconnect.git
synced 2025-05-20 07:26:58 -04:00
Compare commits
7 Commits
Author | SHA1 | Date | |
---|---|---|---|
|
edc13ed14d | ||
|
dd737bc8c5 | ||
|
939f2bd94a | ||
|
abffa21268 | ||
|
705b03c0bb | ||
|
7bef2ccc68 | ||
|
bffc5d733b |
@@ -17,6 +17,7 @@ add_executable(gpclient
|
|||||||
cdpcommand.cpp
|
cdpcommand.cpp
|
||||||
cdpcommandmanager.cpp
|
cdpcommandmanager.cpp
|
||||||
enhancedwebview.cpp
|
enhancedwebview.cpp
|
||||||
|
enhancedwebpage.cpp
|
||||||
gatewayauthenticator.cpp
|
gatewayauthenticator.cpp
|
||||||
gatewayauthenticatorparams.cpp
|
gatewayauthenticatorparams.cpp
|
||||||
gpgateway.cpp
|
gpgateway.cpp
|
||||||
|
8
GPClient/enhancedwebpage.cpp
Normal file
8
GPClient/enhancedwebpage.cpp
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
#include "enhancedwebpage.h"
|
||||||
|
#include <QWebEngineCertificateError>
|
||||||
|
#include <plog/Log.h>
|
||||||
|
|
||||||
|
bool EnhancedWebPage::certificateError(const QWebEngineCertificateError &certificateError) {
|
||||||
|
LOGI << "An error occurred during certificate verification for " << certificateError.url().toString() << "; " << certificateError.errorDescription();
|
||||||
|
return certificateError.isOverridable();
|
||||||
|
};
|
12
GPClient/enhancedwebpage.h
Normal file
12
GPClient/enhancedwebpage.h
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
#ifndef ENHANCEDWEBPAGE_H
|
||||||
|
#define ENHANCEDWEBPAGE_H
|
||||||
|
|
||||||
|
#include <QtWebEngineWidgets/qwebenginepage.h>
|
||||||
|
|
||||||
|
class EnhancedWebPage : public QWebEnginePage
|
||||||
|
{
|
||||||
|
protected:
|
||||||
|
bool certificateError(const QWebEngineCertificateError &certificateError) override;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // !ECHANCEDWEBPAG
|
@@ -1,6 +1,7 @@
|
|||||||
#include <QtCore/QProcessEnvironment>
|
#include <QtCore/QProcessEnvironment>
|
||||||
#include <QtWebEngineWidgets/QWebEngineView>
|
#include <QtWebEngineWidgets/QWebEngineView>
|
||||||
|
|
||||||
|
#include "enhancedwebpage.h"
|
||||||
#include "enhancedwebview.h"
|
#include "enhancedwebview.h"
|
||||||
#include "cdpcommandmanager.h"
|
#include "cdpcommandmanager.h"
|
||||||
|
|
||||||
@@ -14,6 +15,7 @@ EnhancedWebView::EnhancedWebView(QWidget *parent)
|
|||||||
|
|
||||||
void EnhancedWebView::initialize()
|
void EnhancedWebView::initialize()
|
||||||
{
|
{
|
||||||
|
setPage(new EnhancedWebPage());
|
||||||
auto port = QProcessEnvironment::systemEnvironment().value(ENV_CDP_PORT);
|
auto port = QProcessEnvironment::systemEnvironment().value(ENV_CDP_PORT);
|
||||||
cdp->initialize("http://127.0.0.1:" + port + "/json");
|
cdp->initialize("http://127.0.0.1:" + port + "/json");
|
||||||
}
|
}
|
||||||
|
@@ -64,4 +64,3 @@ void GatewayAuthenticatorParams::setInputStr(const QString &inputStr)
|
|||||||
{
|
{
|
||||||
m_inputStr = inputStr;
|
m_inputStr = inputStr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -339,7 +339,7 @@ void GPClient::onPortalFail(const QString &msg)
|
|||||||
|
|
||||||
void GPClient::tryGatewayLogin()
|
void GPClient::tryGatewayLogin()
|
||||||
{
|
{
|
||||||
LOGI << "Try to preform login on the the gateway interface...";
|
LOGI << "Try to perform login on the the gateway interface...";
|
||||||
|
|
||||||
// Treat the portal input as the gateway address
|
// Treat the portal input as the gateway address
|
||||||
GPGateway g;
|
GPGateway g;
|
||||||
|
@@ -32,7 +32,7 @@ void PortalAuthenticator::authenticate()
|
|||||||
{
|
{
|
||||||
attempts++;
|
attempts++;
|
||||||
|
|
||||||
LOGI << QString("(%1/%2) attempts").arg(attempts).arg(MAX_ATTEMPTS) << ", preform portal prelogin at " << preloginUrl;
|
LOGI << QString("(%1/%2) attempts").arg(attempts).arg(MAX_ATTEMPTS) << ", perform portal prelogin at " << preloginUrl;
|
||||||
|
|
||||||
QNetworkReply *reply = createRequest(preloginUrl);
|
QNetworkReply *reply = createRequest(preloginUrl);
|
||||||
connect(reply, &QNetworkReply::finished, this, &PortalAuthenticator::onPreloginFinished);
|
connect(reply, &QNetworkReply::finished, this, &PortalAuthenticator::onPreloginFinished);
|
||||||
|
@@ -172,4 +172,3 @@ void PortalConfigResponse::setPrelogonUserAuthCookie(const QString cookie)
|
|||||||
{
|
{
|
||||||
m_prelogonAuthCookie = cookie;
|
m_prelogonAuthCookie = cookie;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -34,9 +34,9 @@ GPService::~GPService()
|
|||||||
|
|
||||||
QString GPService::findBinary()
|
QString GPService::findBinary()
|
||||||
{
|
{
|
||||||
for (int i = 0; i < binaryPaths->length(); i++) {
|
for (auto& binaryPath : binaryPaths) {
|
||||||
if (QFileInfo::exists(binaryPaths[i])) {
|
if (QFileInfo::exists(binaryPath)) {
|
||||||
return binaryPaths[i];
|
return binaryPath;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return nullptr;
|
return nullptr;
|
||||||
@@ -136,7 +136,7 @@ void GPService::connect(QString server, QString username, QString passwd)
|
|||||||
<< "--cookie-on-stdin"
|
<< "--cookie-on-stdin"
|
||||||
<< server;
|
<< server;
|
||||||
|
|
||||||
log("Start process with arugments: " + args.join(", "));
|
log("Start process with arguments: " + args.join(", "));
|
||||||
|
|
||||||
openconnect->start(bin, args);
|
openconnect->start(bin, args);
|
||||||
openconnect->write((passwd + "\n").toUtf8());
|
openconnect->write((passwd + "\n").toUtf8());
|
||||||
|
@@ -4,14 +4,13 @@
|
|||||||
#include <QtCore/QObject>
|
#include <QtCore/QObject>
|
||||||
#include <QtCore/QProcess>
|
#include <QtCore/QProcess>
|
||||||
|
|
||||||
static const QString binaryPaths[] {
|
static QList<QString> binaryPaths = QList<QString>() <<
|
||||||
"/usr/local/bin/openconnect",
|
"/usr/local/bin/openconnect" <<
|
||||||
"/usr/local/sbin/openconnect",
|
"/usr/local/sbin/openconnect" <<
|
||||||
"/usr/bin/openconnect",
|
"/usr/bin/openconnect" <<
|
||||||
"/usr/sbin/openconnect",
|
"/usr/sbin/openconnect" <<
|
||||||
"/opt/bin/openconnect",
|
"/opt/bin/openconnect" <<
|
||||||
"/opt/sbin/openconnect"
|
"/opt/sbin/openconnect";
|
||||||
};
|
|
||||||
|
|
||||||
class GPService : public QObject
|
class GPService : public QObject
|
||||||
{
|
{
|
||||||
|
@@ -23,7 +23,7 @@ A GlobalProtect VPN client (GUI) for Linux based on Openconnect and built with Q
|
|||||||
|OS|Stable version | Development version|
|
|OS|Stable version | Development version|
|
||||||
|---|--------------|--------------------|
|
|---|--------------|--------------------|
|
||||||
|Linux Mint, Ubuntu 18.04 or later|[ppa:yuezk/globalprotect-openconnect](https://launchpad.net/~yuezk/+archive/ubuntu/globalprotect-openconnect)|[ppa:yuezk/globalprotect-openconnect-snapshot](https://launchpad.net/~yuezk/+archive/ubuntu/globalprotect-openconnect-snapshot)|
|
|Linux Mint, Ubuntu 18.04 or later|[ppa:yuezk/globalprotect-openconnect](https://launchpad.net/~yuezk/+archive/ubuntu/globalprotect-openconnect)|[ppa:yuezk/globalprotect-openconnect-snapshot](https://launchpad.net/~yuezk/+archive/ubuntu/globalprotect-openconnect-snapshot)|
|
||||||
|Arch, Manjaro|[globalprotect-openconnect](https://archlinux.org/packages/community/x86_64/globalprotect-openconnect/)|[AUR: globalprotect-openconnect-git](https://aur.archlinux.org/packages/globalprotect-openconnect-git/)|
|
|Arch, Manjaro|[globalprotect-openconnect](https://archlinux.org/packages/extra/x86_64/globalprotect-openconnect/)|[AUR: globalprotect-openconnect-git](https://aur.archlinux.org/packages/globalprotect-openconnect-git/)|
|
||||||
|Fedora|[copr: yuezk/globalprotect-openconnect](https://copr.fedorainfracloud.org/coprs/yuezk/globalprotect-openconnect/)|[copr: yuezk/globalprotect-openconnect](https://copr.fedorainfracloud.org/coprs/yuezk/globalprotect-openconnect/)|
|
|Fedora|[copr: yuezk/globalprotect-openconnect](https://copr.fedorainfracloud.org/coprs/yuezk/globalprotect-openconnect/)|[copr: yuezk/globalprotect-openconnect](https://copr.fedorainfracloud.org/coprs/yuezk/globalprotect-openconnect/)|
|
||||||
|openSUSE, CentOS 8|[OBS: globalprotect-openconnect](https://build.opensuse.org/package/show/home:yuezk/globalprotect-openconnect)|[OBS: globalprotect-openconnect-snapshot](https://build.opensuse.org/package/show/home:yuezk/globalprotect-openconnect-snapshot)|
|
|openSUSE, CentOS 8|[OBS: globalprotect-openconnect](https://build.opensuse.org/package/show/home:yuezk/globalprotect-openconnect)|[OBS: globalprotect-openconnect-snapshot](https://build.opensuse.org/package/show/home:yuezk/globalprotect-openconnect-snapshot)|
|
||||||
|
|
||||||
@@ -78,7 +78,8 @@ sudo dnf install globalprotect-openconnect
|
|||||||
- openSUSE Leap
|
- openSUSE Leap
|
||||||
|
|
||||||
```sh
|
```sh
|
||||||
sudo zypper ar https://download.opensuse.org/repositories/home:/yuezk/openSUSE_Leap_15.2/home:yuezk.repo
|
sudo zypper ar https://download.opensuse.org/repositories/home:/yuezk/15.4/home:yuezk.repo
|
||||||
|
|
||||||
sudo zypper ref
|
sudo zypper ref
|
||||||
sudo zypper install globalprotect-openconnect
|
sudo zypper install globalprotect-openconnect
|
||||||
```
|
```
|
||||||
|
2
cmakew
2
cmakew
@@ -36,7 +36,7 @@ fi
|
|||||||
cmake_base="./.cmake"
|
cmake_base="./.cmake"
|
||||||
cmake_bin="${cmake_base}/cmake-$cmake_version/bin/cmake"
|
cmake_bin="${cmake_base}/cmake-$cmake_version/bin/cmake"
|
||||||
|
|
||||||
# download cmake if neccessary
|
# download cmake if necessary
|
||||||
if [ ! -f "$cmake_bin" ]; then
|
if [ ! -f "$cmake_bin" ]; then
|
||||||
download_link=""
|
download_link=""
|
||||||
|
|
||||||
|
4
debian/changelog
vendored
4
debian/changelog
vendored
@@ -57,7 +57,7 @@ globalprotect-openconnect (1.4.6-1) unstable; urgency=medium
|
|||||||
|
|
||||||
* Updated VERSION, Bumped 1.4.5 –> 1.4.6
|
* Updated VERSION, Bumped 1.4.5 –> 1.4.6
|
||||||
* feat: display address in gateway menu item
|
* feat: display address in gateway menu item
|
||||||
* fix: fix bug of parsing the portal respponse
|
* fix: fix bug of parsing the portal response
|
||||||
|
|
||||||
-- Kevin Yue <k3vinyue@gmail.com> Wed, 01 Jun 2022 23:55:50 +0800
|
-- Kevin Yue <k3vinyue@gmail.com> Wed, 01 Jun 2022 23:55:50 +0800
|
||||||
|
|
||||||
@@ -70,7 +70,7 @@ globalprotect-openconnect (1.4.5-1) unstable; urgency=medium
|
|||||||
* packaging: fix postinst for debian
|
* packaging: fix postinst for debian
|
||||||
* packaging: add postinst for debian
|
* packaging: add postinst for debian
|
||||||
* test: test debian packaging
|
* test: test debian packaging
|
||||||
* ci: fix the foder path
|
* ci: fix the folder path
|
||||||
* chore: apt -> apt-get
|
* chore: apt -> apt-get
|
||||||
* ci: verify debian package
|
* ci: verify debian package
|
||||||
* Revert "Revert "fix: improve the dbus security""
|
* Revert "Revert "fix: improve the dbus security""
|
||||||
|
@@ -25,7 +25,7 @@ Sun Jan 8 12:58:32 UTC 2023 - k3vinyue@gmail.com - 1.4.9
|
|||||||
* Credentials autocompleting (secure version) (#179)
|
* Credentials autocompleting (secure version) (#179)
|
||||||
* Read all saved Gateways (for selecting in Systray) (#181)
|
* Read all saved Gateways (for selecting in Systray) (#181)
|
||||||
* copy install script for debian (#180)
|
* copy install script for debian (#180)
|
||||||
* add es and pt support to shange status when connected to vpn (#162)
|
* add es and pt support to change status when connected to vpn (#162)
|
||||||
* fix: improve the cli support
|
* fix: improve the cli support
|
||||||
* feat: add --reset option to gpclient
|
* feat: add --reset option to gpclient
|
||||||
|
|
||||||
@@ -59,7 +59,7 @@ Wed Jun 1 15:55:50 UTC 2022 - k3vinyue@gmail.com - 1.4.6
|
|||||||
- Update to 1.4.6
|
- Update to 1.4.6
|
||||||
* Updated VERSION, Bumped 1.4.5 –> 1.4.6
|
* Updated VERSION, Bumped 1.4.5 –> 1.4.6
|
||||||
* feat: display address in gateway menu item
|
* feat: display address in gateway menu item
|
||||||
* fix: fix bug of parsing the portal respponse
|
* fix: fix bug of parsing the portal response
|
||||||
|
|
||||||
-------------------------------------------------------------------
|
-------------------------------------------------------------------
|
||||||
Sun May 29 13:15:40 UTC 2022 - k3vinyue@gmail.com - 1.4.5
|
Sun May 29 13:15:40 UTC 2022 - k3vinyue@gmail.com - 1.4.5
|
||||||
@@ -72,7 +72,7 @@ Sun May 29 13:15:40 UTC 2022 - k3vinyue@gmail.com - 1.4.5
|
|||||||
* packaging: fix postinst for debian
|
* packaging: fix postinst for debian
|
||||||
* packaging: add postinst for debian
|
* packaging: add postinst for debian
|
||||||
* test: test debian packaging
|
* test: test debian packaging
|
||||||
* ci: fix the foder path
|
* ci: fix the folder path
|
||||||
* chore: apt -> apt-get
|
* chore: apt -> apt-get
|
||||||
* ci: verify debian package
|
* ci: verify debian package
|
||||||
* Revert "Revert "fix: improve the dbus security""
|
* Revert "Revert "fix: improve the dbus security""
|
||||||
|
Reference in New Issue
Block a user