2019-09-13 03:08:41 +00:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"os"
|
|
|
|
|
|
|
|
"github.com/ehazlett/gatekeeper/version"
|
|
|
|
"github.com/sirupsen/logrus"
|
|
|
|
"github.com/urfave/cli"
|
|
|
|
)
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
app := cli.NewApp()
|
|
|
|
app.Name = version.Name
|
|
|
|
app.Author = "@darknet"
|
|
|
|
app.Description = version.Description
|
|
|
|
app.Version = version.BuildVersion()
|
|
|
|
app.Flags = []cli.Flag{
|
|
|
|
cli.BoolFlag{
|
|
|
|
Name: "debug, D",
|
|
|
|
Usage: "enable debug logging",
|
|
|
|
},
|
|
|
|
cli.IntFlag{
|
|
|
|
Name: "port, p",
|
|
|
|
Usage: "listen port",
|
|
|
|
Value: 2222,
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
Name: "key-dir, d",
|
|
|
|
Usage: "path to authorized public keys",
|
|
|
|
Value: "",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
Name: "host-key, k",
|
|
|
|
Usage: "path to host key",
|
|
|
|
Value: "/etc/ssh/ssh_host_rsa_key",
|
|
|
|
},
|
2019-09-13 04:13:38 +00:00
|
|
|
cli.StringFlag{
|
|
|
|
Name: "subnet, s",
|
|
|
|
Usage: "subnet for ip allocation",
|
|
|
|
Value: "10.199.254.0/24",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
Name: "redis, r",
|
|
|
|
Usage: "redis url",
|
|
|
|
Value: "redis://127.0.0.1:6379",
|
|
|
|
},
|
2019-09-13 15:26:20 +00:00
|
|
|
cli.StringFlag{
|
|
|
|
Name: "guard-addr",
|
|
|
|
Usage: "guard server address",
|
|
|
|
Value: "10.199.199.1:10100",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
Name: "guard-tunnel",
|
|
|
|
Usage: "guard tunnel to use for peers",
|
|
|
|
Value: "guard0",
|
|
|
|
},
|
|
|
|
cli.StringFlag{
|
|
|
|
Name: "guard-dns",
|
|
|
|
Usage: "dns to use for peers",
|
|
|
|
Value: "10.199.254.1",
|
|
|
|
},
|
2019-09-13 03:08:41 +00:00
|
|
|
}
|
|
|
|
app.Before = func(cx *cli.Context) error {
|
|
|
|
if cx.Bool("debug") {
|
|
|
|
logrus.SetLevel(logrus.DebugLevel)
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
app.Action = func(cx *cli.Context) error {
|
|
|
|
cfg := &ServerConfig{
|
|
|
|
ListenPort: cx.Int("port"),
|
|
|
|
KeysPath: cx.String("key-dir"),
|
|
|
|
HostKeyPath: cx.String("host-key"),
|
2019-09-13 04:13:38 +00:00
|
|
|
RedisURL: cx.String("redis"),
|
|
|
|
Subnet: cx.String("subnet"),
|
2019-09-13 15:26:20 +00:00
|
|
|
GuardAddr: cx.String("guard-addr"),
|
|
|
|
GuardTunnel: cx.String("guard-tunnel"),
|
|
|
|
GuardDNS: cx.String("guard-dns"),
|
2019-09-13 03:08:41 +00:00
|
|
|
}
|
|
|
|
srv, err := NewServer(cfg)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
return srv.Run()
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := app.Run(os.Args); err != nil {
|
|
|
|
logrus.Fatal(err)
|
|
|
|
}
|
|
|
|
}
|