Я хотел бы установитьopenconnect-ssh. Инструкции по установке из проекта кажутся сложными, я не уверен, что это pipx
такое.
Как установить openconnect-sso в Ubuntu без использования pipx и использования собственных библиотек Ubuntu qt?
Я попытался установить его с помощью pip
, но получил следующие ошибки:
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'
решение1
Сначала вам необходимо установить зависимости Qt5 Python:
sudo apt install python3-pyqt5 python3-pyqt5.qtwebengine vpnc-scripts openconnect
Затем вы устанавливаете openconnect-sso с помощью pip
pip install openconnect-sso
После этого вы сможете легко запустить приложение:
$ 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=
решение2
Вот ссылка на мою инструкцию по установке:https://github.com/vlaci/openconnect-sso/issues/114<-- (поставьте лайк на GitHub, если вы согласны и хотите привлечь внимание)
...которые находятся здесь:Как использовать «openconnect» (через openconnect-sso
оболочку) с двухфакторной аутентификацией SAML и Duo через Okta Single-Sign-on (SSO)<-- см. здесь полные инструкции, подробности и скриншоты.
Суммируя,openconnect
Для установки на Linux Ubuntu выполните следующее openconnect-sso
:
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
Смотрите такжемой главный ответдля того, как создать пользовательский ~/.my_ssl.conf
файл конфигурации и что добавить в него. Основной ответ содержит эти необходимые детали, чтобы избежать некоторых ошибок, с которыми вы в противном случае можете столкнуться.
Вам также нужно будет добавить несколько строк в конец вашего ~/.bashrc
файла. Опять же, см.мой главный ответ.
Применение(примечание: как узнать адрес вашего сервера и группу SAML, см.«Как узнать адрес вашего VPN-сервера и группу SAML» в конце моего ответа здесь):
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