openvpn-mgt/main.go

63 lines
1.4 KiB
Go
Raw Normal View History

2019-07-08 14:36:56 +00:00
package main
2019-07-08 20:32:12 +00:00
import (
"flag"
"log"
"log/syslog"
2019-07-10 16:40:15 +00:00
"math/rand"
2019-07-08 20:32:12 +00:00
"os"
2019-07-10 16:40:15 +00:00
"time"
2019-07-08 20:32:12 +00:00
"github.com/pyke369/golang-support/uconfig"
)
2019-07-08 14:36:56 +00:00
func main() {
2019-07-08 20:32:12 +00:00
var err error
2019-07-08 23:44:18 +00:00
var config *uconfig.UConfig
2019-07-11 06:14:38 +00:00
// default configuration file is /etc/openvpn/dm-mgt-server.conf
configFile := flag.String("config", "/etc/openvpn/dm-mgt-server.conf", "configuration file")
2019-07-08 20:32:12 +00:00
logToSyslog := flag.Bool("syslog", false, "Log to syslog")
2019-07-11 06:14:38 +00:00
debug := flag.Bool("debug", false, "log every message received")
2019-07-08 20:32:12 +00:00
flag.Parse()
// parseconfig
if config, err = uconfig.New(*configFile); err != nil {
log.Println(err)
os.Exit(1)
}
2019-07-10 16:40:15 +00:00
// seed the prng
rand.Seed(time.Now().UnixNano())
2019-07-08 20:32:12 +00:00
server := NewVPNServer(config.GetString("config.openvpnPort", "127.0.0.01:5000"))
server.syslog = false
if *logToSyslog {
log.SetFlags(0)
server.syslog = true
logWriter, e := syslog.New(syslog.LOG_NOTICE, "vpnauth")
2019-07-08 20:32:12 +00:00
if e == nil {
log.SetOutput(logWriter)
defer logWriter.Close()
}
}
2019-07-11 06:14:38 +00:00
server.debug = false
if *debug {
server.debug = true
}
2019-07-30 14:34:12 +00:00
log.Println(getServerList("https://www.expressvpn.com/vpn-server"))
2019-07-08 23:44:18 +00:00
// time to start the listeners
2019-07-08 14:36:56 +00:00
go server.Run()
2019-07-08 20:32:12 +00:00
NewHTTPServer(
2019-07-11 10:20:08 +00:00
config.GetString("config.http.port", "127.0.0.01:8080"),
config.GetString("config.http.key", ""),
config.GetString("config.http.cert", ""),
config.GetString("config.http.ca", ""),
config.GetString("config.http.startAuth", "CORP"),
2019-07-17 17:12:00 +00:00
parseConfigArray(config, "config.http.reqAuth"),
2019-07-08 20:32:12 +00:00
server)
2019-07-08 14:36:56 +00:00
}