115 lines
3.3 KiB
Markdown
Raw Normal View History

2020-12-17 20:22:15 +02:00
# Always on Openconnect VPN
This script uses Openconnect to automatically connect to Cisco Anyconnect VPN server.
2023-07-06 10:12:53 +03:00
Server address, username, password and 2fa seed is retreived from macOS/Linux keychain. You can skip keychain and provide those details through environment or stdin instead.
2020-12-17 20:22:15 +02:00
2020-12-18 01:05:16 +02:00
Additionaly routing for only specific subnets can be added in `routes.txt`
2020-12-17 20:22:15 +02:00
2024-04-29 18:25:28 +03:00
![Bitbar UI](assets/bitbar.png)
2020-12-17 20:22:15 +02:00
## Setup
2024-12-02 13:53:52 +00:00
### MacOS
2020-12-17 20:22:15 +02:00
```
git clone this repo
brew install openconnect
2020-12-18 01:05:16 +02:00
brew install vpn-slice
brew install oath-toolkit
2023-07-06 09:44:38 +03:00
brew install swiftbar
brew install terminal-notifier
brew install bind
2020-12-17 20:22:15 +02:00
```
2023-07-06 10:12:53 +03:00
On Macos add server address, username, password and 2fa seed in keychain with these names:
2020-12-17 20:22:15 +02:00
* `Openconnect VPN Server`
* `Openconnect Username`
* `Openconnect Account Password`
* `Openconnect TOTP Seed`
2024-12-02 13:53:52 +00:00
### Linux
#### Fedora packages
```
sudo dnf install rpm-build git bind oathtool openconnect libnotify
# Clone repo and follow build and install instructions for vpn-slice:
# https://github.com/dlenski/vpn-slice?tab=readme-ov-file#as-an-rpm
```
2023-07-06 10:12:53 +03:00
On Linux you can use keychain (gnome-keychain/seahorse), add following entries:
```
secret-tool store --label='openconnect-server' server openconnect
secret-tool store --label='openconnect-username' username openconnect
secret-tool store --label='openconnect-password' password openconnect
secret-tool store --label='openconnect-seed' seed openconnect
```
### Security considerations
_For ease of use you can allow automatic keychain access to some of the attributs, but_ **you shouldn't allow automatic access to password and especially the 2fa seed** (but you can).
On Macos secrets might be available in the environment of the vpn process.
On Linux secrets will be shortly stored in tmpfs (memory) and deleted once they are passed to openconnect.
After setting up, change the run-vpn.sh, routing.sh and hostscan-bypass.sh ownership to root:
2023-08-22 13:13:33 +03:00
```sh
2023-07-06 10:12:53 +03:00
chown root:root run-vpn.sh
chown root:root hostscan-bypass.sh
chown root:root routing.sh
```
## Defining routes
2020-12-17 20:22:15 +02:00
2020-12-18 01:05:16 +02:00
Rename routes.txt.sample to routes.txt or create an empty routes.txt and add subnets to be routed through VPN there.
2023-07-06 10:12:53 +03:00
2020-12-17 20:22:15 +02:00
## Usage
2023-07-06 10:12:53 +03:00
### Usage from terminal
2023-08-22 13:13:33 +03:00
```sh
2023-07-06 10:12:53 +03:00
DBUS_SESSION_BUS_ADDRESS=$DBUS_SESSION_BUS_ADDRESS sudo -E ./run-vpn.sh
2020-12-17 20:22:15 +02:00
```
2023-07-06 10:12:53 +03:00
You can stop it by pressing `CTRL+C` or killing the process.
### GUI usage from bitbar/xbar/swaybar/argos
2020-12-17 20:22:15 +02:00
2023-08-22 13:13:33 +03:00
Consult the `bitbar-openconnect.6s.sh` script for sudoers entries needed to run it. Add them to `/etc/sudoers`
2023-07-06 10:12:53 +03:00
2023-08-22 13:13:33 +03:00
**Symlink**(!) the `bitbar-openconnect.6s.sh` script to your bitbar config folder:
2023-07-06 10:12:53 +03:00
2023-08-22 13:13:33 +03:00
```sh
ln -s ~/Documents/git/always-on-openconnect-vpn/bitbar-openconnect.6s.sh ~/.config/argos/
2023-07-06 10:12:53 +03:00
```
2023-08-22 13:13:33 +03:00
Enable running from your `user`, add this to /etc/sudoers:
```sh
user ALL=(ALL) NOPASSWD:SETENV: /home/user/Documents/git/always-on-openconnect-vpn/run-vpn.sh
user ALL=(ALL) NOPASSWD: /usr/bin/killall -2 openconnect
2023-07-06 10:12:53 +03:00
```
2020-12-18 02:46:55 +02:00
2024-12-02 13:53:52 +00:00
#### On Linux enable dbus access from sudo
Create `/etc/dbus-1/session-local.conf` with following content:
```xml
<busconfig>
<policy context="mandatory">
<allow user="root"/>
</policy>
</busconfig>
```
2020-12-18 02:46:55 +02:00
### Yubikey
Yubikey can be used for safe storage of TOTP seed. Configure TOTP in Yubikey Authenticator app or `ykman oath` if using command line. Then use `ykman oath list` to get the name of the entry and set that name in `OC_YUBIKEY` environment variable.
For example:
```
OC_YUBIKEY=VPN:organization sudo -E ./run-vpn.sh
```