Skip to content
You're viewing an older version of this GitHub Action. Do you want to see the latest version instead?
lock

GitHub Action

OpenVPN-Connect

v1.0.0

OpenVPN-Connect

lock

OpenVPN-Connect

connect to OpenVPN server

Installation

Copy and paste the following snippet into your .yml file.

              

- name: OpenVPN-Connect

uses: kota65535/github-openvpn-connect-action@v1.0.0

Learn more about this action in kota65535/github-openvpn-connect-action

Choose a version

github-openvpn-connect-action

Github action for connecting to OpenVPN server.

Inputs

General Inputs

Name Description Required
config_file Location of OpenVPN client config file yes

Authentication Inputs

Supported authentication methods:

  • Username & password auth
  • Client certificate auth
  • Both of them
Name Description Required when
username Username Username-password auth
password Password Username-password auth
client_key Local peer's private key Client certificate auth
tls_auth_key Pre-shared secret for TLS-auth HMAC signature Optional

All authentication inputs should be provided by encrypted secrets environment variables.

Usage

  • Create client configuration file based on the official sample. It is recommended to use inline certificates to include them directly in configuration file like this.
  • Usage in your workflow is like following:
      - name: Checkout
        uses: actions/checkout@v2
      - name: Install OpenVPN
        run: sudo apt install -y openvpn openvpn-systemd-resolved
      - name: Connect to VPN
        uses: "kota65535/github-openvpn-connect-action@master"
        with:
          config_file: ./github/workflows/client.ovpn
          username: ${{ secrets.USERNAME }}
          password: ${{ secrets.PASSWORD }}
          client_key: ${{ secrets.OVPN_CLIENT_KEY }}
          tls_auth_key: ${{ secrets.OVPN_TLS_AUTH_KEY }}
      - name: Build something
        run: ./gradlew clean build
      # The openvpn process is automatically terminated in post-action phase