Skip to main content

Wrapper script around openconnect forJMU VPN authentication on Linux.

Project description

JMU OpenConnect

PyPI Downloads License Maintenance GitHub Issues GitHub followers
Kofi Badge

This is a wrapper script around openconnect to help with authentication for the JMU VPN on Linux. Openconnect used to work fine until Ivanti purchased Pulse Secure, and then that broke something. This script opens up a web browser to allow the user to authenticate with Duo, and then grabs the DSID cookie to use for openconnect authentication.

Installation

This script can easily be installed with pip or pipx with the following commands:

$ pip3 install jmu-openconnect
$ # OR
$ pipx install jmu-openconnect

This script can also be used as a standalone script by downloading the main.py file and ensuring that selenium is installed with pip3 install selenium, or by cloning the repository and running poetry install.

Usage

Once the script is installed, you can run the following command in your terminal:

$ jmu-openconnect

You can also specify a username and password to be automatically typed in, however you will still have to do 2FA manually. You can specify one or the other or both, and if both are specified, the "Log in" button will automatically be clicked.

$ jmu-openconnect -u <EID> -p <PASSWORD>

You can alternatively specify the --prompt-password option instead of using -p, which will prompt the user for a password without echoing, much like sudo. This is more secure as your password won't be saved in your command line history.

JMU OpenConnect defaults to using firefox, but you can easily change which browser you're using by specifying --browser, which accepts firefox, chrome, or edge.

$ jmu-openconnect --browser chrome

To see all of the available options, run jmu-openconnect --help.

Dependencies

This script just requires openconnect, selenium, and a webdriver. On my machine, it seems that the webdrivers are automatically installed if you have Firefox or Chromium installed, so you probably don't need to worry about this. If you are having problems, check the Selenium Python Documentation.

Why is this all in one script?

I heavily considered splitting this up into multiple files, but I really wanted to preserve the ability to just have this script up on a website somewhere where people could just download this script, install selenium, and run it with Python. This may change in the future but this is what I've gone with for now.

DSID Cookie was not found

If you get the error that the DSID cookie was not found, then you may be logged on in multiple places at once. Navigate to https://vpn.jmu.edu and after signing in, you should see a screen like this:

Maximum number of open user sessions screenshot

If this is the case, just select the box to remove that sign in and retry the script after verifying that you are signed out of all browser sessions. If this is not the problem, try running the script with jmu-openconnect --debug-auth-error to see the error for a longer period of time.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

jmu_openconnect-0.1.0.tar.gz (6.5 kB view hashes)

Uploaded Source

Built Distribution

jmu_openconnect-0.1.0-py3-none-any.whl (6.8 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page