Tidak Ada Deskripsi

Mustafa ARICI 2197e9a44c fix(grpcgw): make sure grpc gw generated fields in original case 4 tahun lalu
.github e30b3100db chore(ci): update deployer version 4 tahun lalu
api 2197e9a44c fix(grpcgw): make sure grpc gw generated fields in original case 4 tahun lalu
cmd ab8b02ddd0 refactor(cmd/ovpmd): force listeners on tcp4 network 4 tahun lalu
contrib ed42f8828f fix(CI): split unit files according to the OS 5 tahun lalu
errors b07cbde9ce Feature: Added keepalive-period, keepalive-timeout and use-lzo params support 6 tahun lalu
permset 5b9fdc5548 doc(permset): add package docstring 8 tahun lalu
pki 6ec7bb72d2 chore: switch to go mod 7 tahun lalu
scripts 6e266184bc chore: move scripts from contrib to scripts/ dir 5 tahun lalu
supervisor 6ec7bb72d2 chore: switch to go mod 7 tahun lalu
webui 4fbde780ed chore(webui): update dependencies 4 tahun lalu
.gitignore 39c62f5be5 chore(gitignore): ignore build dirs 5 tahun lalu
CHANGELOG.md 21197c9048 release: v0.2.11 4 tahun lalu
Dockerfile 9bbfc4521a chore: make sure dockerfile is up to date 4 tahun lalu
LICENSE cd22d83ab6 Create LICENSE 8 tahun lalu
Makefile 2197e9a44c fix(grpcgw): make sure grpc gw generated fields in original case 4 tahun lalu
README.md 22399f96c9 release: v0.2.9 5 tahun lalu
build.sh d42c20dc41 chore: fix user generation after package install 8 tahun lalu
const.go 9694cc34f2 refactor: make ovpm.Version a variable not a constant 5 tahun lalu
db.go 6ec7bb72d2 chore: switch to go mod 7 tahun lalu
db_test.go 55acfb6b25 refactor: major refactor of all service 8 tahun lalu
doc.go 6006fb9610 feat(api): implement authentication service 8 tahun lalu
generate.go 4f34e07500 chore: use makefile for code generation 5 tahun lalu
go.mod a2c59a06d9 chore(ci): use Ubuntu 18.04 4 tahun lalu
go.sum a2c59a06d9 chore(ci): use Ubuntu 18.04 4 tahun lalu
net.go 6ec7bb72d2 chore: switch to go mod 7 tahun lalu
net_test.go c8b8f213e0 test(net): handle error message for test case 4 tahun lalu
nfpm.yaml ed42f8828f fix(CI): split unit files according to the OS 5 tahun lalu
parselog.go 9f97850442 fix(parselog): recover panic from parsing OpenVPN log 7 tahun lalu
parselog_test.go 9f97850442 fix(parselog): recover panic from parsing OpenVPN log 7 tahun lalu
perms.go 0ec54061e3 doc(perms): improve docstrings 8 tahun lalu
templates.go 5546a03af6 refactor: relocate actual templates from bindata to code itself 5 tahun lalu
user.go ec7f296253 created description field in user profile 6 tahun lalu
user_internal_test.go ec7f296253 created description field in user profile 6 tahun lalu
user_test.go ec7f296253 created description field in user profile 6 tahun lalu
vpn.go 133e350a70 feat: vpn update option enable|disable use-lzo 5 tahun lalu
vpn_test.go a2c59a06d9 chore(ci): use Ubuntu 18.04 4 tahun lalu

README.md

OVPM - OpenVPN Management Server

Build Status GitHub version codecov GoDoc

OVPM allows you to administrate an OpenVPN server on linux easily via command line and web interface.

With OVPM you can create and run an OpenVPN server, add/remove VPN users, generate client .ovpn files for your users etc.

This software is not stable yet. We recommend against using it for anything serious until, version 1.0 is released.

NOTICE: Version 0.2.8 comes with comp-lzo option disabled by default as it is deprecated by OpenVPN.

Roadmap

  • OpenVPN management functionality
  • User management functionality
  • Network management functionality
  • Command Line Interface (CLI)
  • API (REST and gRPC)
  • Web User Interface (WebUI)
  • Import/Export/Backup OVPM config
  • Effortless client profile (.ovpn file) delivery over Web
  • Monitoring and Quota functionality

Demo Here is a little demo of what it looks on terminal to init the server, create a vpn user and generate .ovpn file for the created user.

asciicast

Installation

from RPM (CentOS/Fedora):

# Add YUM Repo
$ sudo yum install yum-utils -y
$ sudo yum install epel-release -y
$ sudo yum-config-manager --add-repo https://cad.github.io/ovpm/rpm/ovpm.repo

# Install OVPM
$ sudo yum install ovpm

# Enable and start ovpmd service
$ systemctl start ovpmd
$ systemctl enable ovpmd

from DEB (Ubuntu/Debian):

This is tested only on Ubuntu >=16.04.3 LTS

# Add APT Repo
$ sudo sh -c 'echo "deb [trusted=yes] https://cad.github.io/ovpm/deb/ ovpm main" >> /etc/apt/sources.list'
$ sudo apt update

# Install OVPM
$ sudo apt install ovpm

# Enable and start ovpmd service
$ systemctl start ovpmd
$ systemctl enable ovpmd  

from Source (go get):

Only dependency for ovpm is OpenVPN>=2.3.3.

$ go get -u github.com/cad/ovpm/...

# Make sure user nobody and group nogroup is available
# on the system
$ sudo useradd nobody
$ sudo groupadd nogroup

# Start ovpmd on a seperate terminal
$ sudo ovpmd

Now ovpmd should be running.

Quickstart

Create a vpn user and export vpn profile for the created user.

# We should init the server after fresh install
$ ovpm vpn init --hostname <vpn.example.com>
INFO[0004] ovpm server initialized

# Now, lets create a new vpn user
$ ovpm user create -u joe -p verySecretPassword
INFO[0000] user created: joe

# Finally export the vpn profile for, the created user, joe
$ ovpm user genconfig -u joe
INFO[0000] exported to joe.ovpn

OpenVPN profile for user joe is exported to joe.ovpn file. You can simply use this file with OpenVPN to connect to the vpn server from another computer.

Next Steps

Troubleshooting

Q: My clients cannot connect to VPN after updating OVPM to v0.2.8

Since comp-lzo is disabled by default in OVPM v0.2.8, existing clients' .ovpn profiles became invalid.

In order to solve this you have the options below:

  • Generate new .ovpn profile for existing clients
  • Or manually remove comp-lzo line from clients .ovpn profiles yourself.
  • Or you can upgrade to v0.2.9 and enable lzo option back by invoking the following command.

    $ ovpm vpn update --enable-use-lzo
    

    But please note that this is not recommended as lzo option is deprecated in OpenVPN.