From b15227c696e230d86c19be18409de4c8ae23f216 Mon Sep 17 00:00:00 2001 From: Shoji Ihara Date: Wed, 19 Aug 2015 20:35:04 +0900 Subject: [PATCH] Random URL generation(Close #17) --- app/app.go | 39 +++++++++++++++++++++++++++++---------- main.go | 7 ++++++- 2 files changed, 35 insertions(+), 11 deletions(-) diff --git a/app/app.go b/app/app.go index f0a0586..4ecd4dc 100644 --- a/app/app.go +++ b/app/app.go @@ -1,11 +1,14 @@ package app import ( + "crypto/rand" "encoding/base64" "encoding/json" "log" + "math/big" "net/http" "os/exec" + "strconv" "strings" "syscall" "unsafe" @@ -20,16 +23,18 @@ type App struct { Address string Port string PermitWrite bool + RandomUrl bool Credential string Command []string } -func New(address string, port string, permitWrite bool, cred string, command []string) *App { +func New(address string, port string, permitWrite bool, cred string, randomUrl bool, command []string) *App { return &App{ Address: address, Port: port, PermitWrite: permitWrite, Credential: cred, + RandomUrl: randomUrl, Command: command, } } @@ -65,21 +70,24 @@ func basicAuthHandler(h http.Handler, cred string) http.Handler { } func (app *App) Run() error { - http.Handle("/", - http.FileServer( - &assetfs.AssetFS{Asset: Asset, AssetDir: AssetDir, Prefix: "bindata"}, - ), - ) - http.HandleFunc("/ws", app.generateHandler()) + path := "/" + if app.RandomUrl { + randomPath := generateRandomString(8) + path = "/" + randomPath + "/" + } - url := app.Address + ":" + app.Port - log.Printf("Server is running at %s, command: %s", url, strings.Join(app.Command, " ")) + fs := http.StripPrefix(path, http.FileServer(&assetfs.AssetFS{Asset: Asset, AssetDir: AssetDir, Prefix: "bindata"})) + http.Handle(path, fs) + http.HandleFunc(path+"ws", app.generateHandler()) + + endpoint := app.Address + ":" + app.Port + log.Printf("Server is running at %s, command: %s", endpoint+path, strings.Join(app.Command, " ")) handler := http.Handler(http.DefaultServeMux) handler = loggerHandler(handler) if app.Credential != "" { handler = basicAuthHandler(handler, app.Credential) } - err := http.ListenAndServe(url, handler) + err := http.ListenAndServe(endpoint, handler) if err != nil { return err } @@ -227,3 +235,14 @@ type command struct { Name string `json:"name"` Arguments map[string]interface{} `json:"arguments"` } + +func generateRandomString(length int) string { + const base = 36 + size := big.NewInt(base) + n := make([]byte, length) + for i, _ := range n { + c, _ := rand.Int(rand.Reader, size) + n[i] = strconv.FormatInt(c.Int64(), base)[0] + } + return string(n) +} diff --git a/main.go b/main.go index b58d0bc..92377ec 100644 --- a/main.go +++ b/main.go @@ -37,6 +37,11 @@ func main() { Usage: "Credential for Basic Authentication (ex: user:pass)", EnvVar: "GOTTY_CREDENTIAL", }, + cli.BoolFlag{ + Name: "random-url, r", + Usage: "Add a random string to the URL", + EnvVar: "GOTTY_RANDOM_URL", + }, } cmd.Action = func(c *cli.Context) { if len(c.Args()) == 0 { @@ -44,7 +49,7 @@ func main() { cli.ShowAppHelp(c) os.Exit(1) } - app := app.New(c.String("addr"), c.String("port"), c.Bool("permit-write"), c.String("credential"), c.Args()) + app := app.New(c.String("addr"), c.String("port"), c.Bool("permit-write"), c.String("credential"), c.Bool("random-url"), c.Args()) err := app.Run() if err != nil { fmt.Println(err)