Ich möchte installierenOpenConnect-SSH. Die Installationsanweisungen des Projekts scheinen komplex zu sein, ich bin nicht sicher, was komplex pipx
ist.
Wie installiere ich Openconnect-SSO unter Ubuntu, ohne Pipx zu verwenden und ohne native Ubuntu-Qt-Bibliotheken zu nutzen?
Ich habe versucht, es mit zu installieren pip
, habe aber die folgenden Fehler erhalten:
Traceback (most recent call last):
File "/home/merlijn/.local/bin/openconnect-sso", line 5, in <module>
from openconnect_sso.cli import main
File "/home/merlijn/.local/lib/python3.9/site-packages/openconnect_sso/cli.py", line 10, in <module>
from openconnect_sso import app, config, __version__
File "/home/merlijn/.local/lib/python3.9/site-packages/openconnect_sso/app.py", line 16, in <module>
from openconnect_sso.authenticator import Authenticator, AuthResponseError
File "/home/merlijn/.local/lib/python3.9/site-packages/openconnect_sso/authenticator.py", line 6, in <module>
from openconnect_sso.saml_authenticator import authenticate_in_browser
File "/home/merlijn/.local/lib/python3.9/site-packages/openconnect_sso/saml_authenticator.py", line 3, in <module>
from openconnect_sso.browser import Browser
File "/home/merlijn/.local/lib/python3.9/site-packages/openconnect_sso/browser/__init__.py", line 1, in <module>
from .browser import Browser, DisplayMode, Terminated
File "/home/merlijn/.local/lib/python3.9/site-packages/openconnect_sso/browser/browser.py", line 5, in <module>
from . import webengine_process as web
File "/home/merlijn/.local/lib/python3.9/site-packages/openconnect_sso/browser/webengine_process.py", line 12, in <module>
from PyQt5.QtCore import QUrl, QTimer
ModuleNotFoundError: No module named 'PyQt5'
Traceback (most recent call last):
File "/home/merlijn/.local/bin/openconnect-sso", line 5, in <module>
from openconnect_sso.cli import main
File "/home/merlijn/.local/lib/python3.9/site-packages/openconnect_sso/cli.py", line 10, in <module>
from openconnect_sso import app, config, __version__
File "/home/merlijn/.local/lib/python3.9/site-packages/openconnect_sso/app.py", line 16, in <module>
from openconnect_sso.authenticator import Authenticator, AuthResponseError
File "/home/merlijn/.local/lib/python3.9/site-packages/openconnect_sso/authenticator.py", line 6, in <module>
from openconnect_sso.saml_authenticator import authenticate_in_browser
File "/home/merlijn/.local/lib/python3.9/site-packages/openconnect_sso/saml_authenticator.py", line 3, in <module>
from openconnect_sso.browser import Browser
File "/home/merlijn/.local/lib/python3.9/site-packages/openconnect_sso/browser/__init__.py", line 1, in <module>
from .browser import Browser, DisplayMode, Terminated
File "/home/merlijn/.local/lib/python3.9/site-packages/openconnect_sso/browser/browser.py", line 5, in <module>
from . import webengine_process as web
File "/home/merlijn/.local/lib/python3.9/site-packages/openconnect_sso/browser/webengine_process.py", line 14, in <module>
from PyQt5.QtWebEngineWidgets import QWebEngineView, QWebEngineScript, QWebEngineProfile
ModuleNotFoundError: No module named 'PyQt5.QtWebEngineWidgets'
Antwort1
Zuerst müssen Sie die Qt5 Python-Abhängigkeiten installieren:
sudo apt install python3-pyqt5 python3-pyqt5.qtwebengine vpnc-scripts openconnect
Anschließend installieren Sie openconnect-sso mit pip
pip install openconnect-sso
Anschließend können Sie die App ganz einfach ausführen:
$ openconnect-sso -s vpn.example.com --browser-display-mode shown
[info ] Authenticating to VPN endpoint [openconnect_sso.app] address=vpn.example.com name=
[info ] Response received [openconnect_sso.authenticator] id=main message=Please complete the authentication process in the AnyConnect Login window. title=Login
[info ] Browser started [webengine] startup_info=StartupInfo(url='https://vpn.example.com/...', credentials=None)
[info ] Loading page [webengine] url=https://vpn.example.com/...
[info ] Terminate requested. [webengine]
[info ] Exiting browser [webengine]
[info ] Browser exited [openconnect_sso.browser.browser]
[info ] Response received [openconnect_sso.authenticator] id=success message=
Antwort2
Hier ist ein Problem, das ich mit einem Link zu meinen Installationsanweisungen gemeldet habe:https://github.com/vlaci/openconnect-sso/issues/114<-- (geben Sie auf GitHub ein „Daumen hoch“-Zeichen, wenn Sie damit einverstanden sind und darauf aufmerksam machen möchten)
...die hier sind:So verwenden Sie „openconnect“ (über den openconnect-sso
Wrapper) mit SAML und Duo-Zwei-Faktor-Authentifizierung über Okta Single-Sign-on (SSO)<-- Vollständige Anweisungen, Einzelheiten und Screenshots finden Sie hier.
Zusamenfassend,Gehen Sie zur Installation openconnect
unter openconnect-sso
Linux Ubuntu wie folgt vor:
sudo apt update
sudo apt install vpnc-scripts openconnect # install openconnect
sudo apt install python3
python3 -m pip install --upgrade pip
python3 -m pip install openconnect-sso # install openconnect-sso
# install openconnect-sso dependencies, including forcing a reinstall of PyQt5
# uninstall
python3 -m pip uninstall PyQt5
python3 -m pip uninstall PyQt5-sip
python3 -m pip uninstall PyQtWebEngine
python3 -m pip uninstall keyring
# reinstall
python3 -m pip install PyQt5
python3 -m pip install PyQt5-sip
python3 -m pip install PyQtWebEngine
python3 -m pip install keyring
python3 -m pip install cffi
# Check the version
# My output is: `openconnect-sso 0.7.3`
openconnect-sso --version
Siehe auchmeine Hauptantwortwie man eine benutzerdefinierte ~/.my_ssl.conf
Konfigurationsdatei erstellt und was man ihr hinzufügen muss. Die Hauptantwort enthält diese notwendigen Details, um einige Fehler zu vermeiden, die Ihnen sonst möglicherweise begegnen.
Sie müssen ~/.bashrc
auch am Ende Ihrer Datei einige Zeilen hinzufügen. Siehe auchmeine Hauptantwort.
Verwendung(Hinweis: Informationen zum Finden Ihrer Serveradresse und SAML-Gruppe finden Sie unter"So finden Sie Ihre VPN-Serveradresse und SAML-Gruppe" am Ende meiner Antwort hier):
VPN_SERVER_ADDRESS="myvpn.whatever.com" # example server address to connect to
VPN_SAML_GROUP="whatever-saml-whatever" # example SAML group name
VPN_USER="[email protected]" # example username
# or perhaps just this for the username:
# VPN_USER="my.username"
# connect via `openconnect-sso`
# The first time ever, you must specify everything
openconnect-sso --server "${VPN_SERVER_ADDRESS}/${VPN_SAML_GROUP}" --user "${VPN_USER}"
# Subsequent connection attempts can be done with just this, since apparently
# the server address, SAML group, and username are cached after the first usage
openconnect-sso