Sen descrición

Mustafa Arici 46982f21f7 refactor(user): use consistent datetime standart within gRPC %!s(int64=7) %!d(string=hai) anos
api 34f46e7302 chore(webui): add static files to bindata %!s(int64=7) %!d(string=hai) anos
bindata 34fe513f89 feat(webui): ensure assets are fetched from the OVPM HTTP server only %!s(int64=7) %!d(string=hai) anos
cmd 46982f21f7 refactor(user): use consistent datetime standart within gRPC %!s(int64=7) %!d(string=hai) anos
contrib 29fe7fcd76 chore(build): ensure nogroup does exist on the target %!s(int64=7) %!d(string=hai) anos
errors fc6ff58592 refactor(cmd/ovpm): refactor ovpm commands %!s(int64=7) %!d(string=hai) anos
permset 5b9fdc5548 doc(permset): add package docstring %!s(int64=8) %!d(string=hai) anos
pki 3c59a7469c doc: fix the word usage whether %!s(int64=8) %!d(string=hai) anos
supervisor 50f831d884 fix(vpn): ensure Emit() when restarting %!s(int64=8) %!d(string=hai) anos
template 34fe513f89 feat(webui): ensure assets are fetched from the OVPM HTTP server only %!s(int64=7) %!d(string=hai) anos
webui 34fe513f89 feat(webui): ensure assets are fetched from the OVPM HTTP server only %!s(int64=7) %!d(string=hai) anos
.gitignore fc6ff58592 refactor(cmd/ovpm): refactor ovpm commands %!s(int64=7) %!d(string=hai) anos
.travis.yml 5c4c565601 chore(ci): fix on fix %!s(int64=8) %!d(string=hai) anos
CHANGELOG.md 19eabf865e release: v0.2.6 %!s(int64=8) %!d(string=hai) anos
Dockerfile 9e1f03e051 chore(Dockerfile): drop MAINTAINER keyword %!s(int64=7) %!d(string=hai) anos
Gopkg.lock 4cb50d916b chore: update dependencies %!s(int64=7) %!d(string=hai) anos
Gopkg.toml 4cb50d916b chore: update dependencies %!s(int64=7) %!d(string=hai) anos
LICENSE cd22d83ab6 Create LICENSE %!s(int64=8) %!d(string=hai) anos
Makefile 5622b954fb chore(build): update build env to include npm %!s(int64=8) %!d(string=hai) anos
README.md 3ae849d6e7 doc(readme): improve the wording of quickstart instructions %!s(int64=7) %!d(string=hai) anos
build.sh d42c20dc41 chore: fix user generation after package install %!s(int64=8) %!d(string=hai) anos
const.go 0de988f873 chore: bump to 0.2.7-beta %!s(int64=7) %!d(string=hai) anos
db.go 55acfb6b25 refactor: major refactor of all service %!s(int64=8) %!d(string=hai) anos
db_test.go 55acfb6b25 refactor: major refactor of all service %!s(int64=8) %!d(string=hai) anos
doc.go 6006fb9610 feat(api): implement authentication service %!s(int64=8) %!d(string=hai) anos
generate.go 34f46e7302 chore(webui): add static files to bindata %!s(int64=7) %!d(string=hai) anos
net.go 9ce7db14b1 refactor(vpn): move all funcs under Server struct %!s(int64=7) %!d(string=hai) anos
net_test.go 9ce7db14b1 refactor(vpn): move all funcs under Server struct %!s(int64=7) %!d(string=hai) anos
parselog.go 85478d5e5a refactor(parselog): accept io.Reader instead of path %!s(int64=7) %!d(string=hai) anos
parselog_test.go 5a547099f7 test(parselog): add test for parseStatusLog %!s(int64=7) %!d(string=hai) anos
perms.go 0ec54061e3 doc(perms): improve docstrings %!s(int64=8) %!d(string=hai) anos
user.go 46982f21f7 refactor(user): use consistent datetime standart within gRPC %!s(int64=7) %!d(string=hai) anos
user_internal_test.go c45c1786f9 test(user): add tests for ConectionStatus %!s(int64=7) %!d(string=hai) anos
user_test.go 645c27dba1 feat(user): impl. ExpiresAtExpiresAt returns date time for which the user certificate gets expired. %!s(int64=7) %!d(string=hai) anos
vpn.go eb561943de refactor(vpn): remove unnecessary line %!s(int64=7) %!d(string=hai) anos
vpn_test.go cf1e09661d chore: remove debug line %!s(int64=7) %!d(string=hai) anos

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.

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-config-manager --add-repo https://cad.github.io/ovpm/rpm/ovpm.repo

# Install OVPM
$ sudo yum install ovpm

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