72 lines
1.3 KiB
Go
72 lines
1.3 KiB
Go
package main
|
|
|
|
import (
|
|
"fmt"
|
|
"os"
|
|
|
|
"github.com/naggie/dsnet"
|
|
)
|
|
|
|
func main() {
|
|
var cmd string
|
|
|
|
if len(os.Args) == 1 {
|
|
cmd = "help"
|
|
} else {
|
|
cmd = os.Args[1]
|
|
}
|
|
|
|
switch cmd {
|
|
case "init":
|
|
dsnet.Init()
|
|
|
|
case "add":
|
|
dsnet.Add()
|
|
|
|
case "up":
|
|
dsnet.Up()
|
|
|
|
case "sync":
|
|
dsnet.Sync()
|
|
|
|
case "report":
|
|
dsnet.Report()
|
|
|
|
case "remove":
|
|
dsnet.Remove()
|
|
|
|
case "down":
|
|
dsnet.Down()
|
|
|
|
default:
|
|
help()
|
|
}
|
|
}
|
|
|
|
func help() {
|
|
fmt.Printf(`dsnet is a simple tool to manage a centralised wireguard VPN.
|
|
|
|
Usage: dsnet <cmd>
|
|
|
|
Available commands:
|
|
|
|
init : Create %[1]s containing default configuration + new keys without loading. Edit to taste.
|
|
add : Add a new peer + sync
|
|
up : Create the interface, run pre/post up, sync
|
|
report : Generate a JSON status report to the location configured in %[1]s.
|
|
remove : Remove a peer by hostname provided as argument + sync
|
|
down : Destroy the interface, run pre/post down
|
|
sync : Update wireguard configuration from %[1]s after validating
|
|
|
|
Environment variables:
|
|
|
|
DSNET_OUTPUT=wg-quick : The add command will generate a wg-quick config (default)
|
|
DSNET_OUTPUT=vyatta : The add command will generate a vyatta (edgeos) config
|
|
|
|
dsnet version %[2]s
|
|
commit %[3]s
|
|
built %[4]s
|
|
|
|
`, dsnet.CONFIG_FILE, dsnet.VERSION, dsnet.GIT_COMMIT, dsnet.BUILD_DATE)
|
|
}
|