commands: add flags/config to control the automatic opening in the default browser

This commit is contained in:
Michael Muré 2019-05-27 21:47:26 +02:00
parent d564e37b31
commit 8bfc65df6c
7 changed files with 96 additions and 22 deletions

View File

@ -13,28 +13,35 @@ import (
"time" "time"
"github.com/99designs/gqlgen/handler" "github.com/99designs/gqlgen/handler"
"github.com/MichaelMure/git-bug/graphql"
"github.com/MichaelMure/git-bug/repository"
"github.com/MichaelMure/git-bug/util/git"
"github.com/MichaelMure/git-bug/webui"
"github.com/gorilla/mux" "github.com/gorilla/mux"
"github.com/phayes/freeport" "github.com/phayes/freeport"
"github.com/skratchdot/open-golang/open" "github.com/skratchdot/open-golang/open"
"github.com/spf13/cobra" "github.com/spf13/cobra"
"github.com/MichaelMure/git-bug/graphql"
"github.com/MichaelMure/git-bug/repository"
"github.com/MichaelMure/git-bug/util/git"
"github.com/MichaelMure/git-bug/webui"
) )
var port int var (
webUIPort int
webUIOpen bool
webUINoOpen bool
)
const webUIOpenConfigKey = "git-bug.webui.open"
func runWebUI(cmd *cobra.Command, args []string) error { func runWebUI(cmd *cobra.Command, args []string) error {
if port == 0 { if webUIPort == 0 {
var err error var err error
port, err = freeport.GetFreePort() webUIPort, err = freeport.GetFreePort()
if err != nil { if err != nil {
return err return err
} }
} }
addr := fmt.Sprintf("127.0.0.1:%d", port) addr := fmt.Sprintf("127.0.0.1:%d", webUIPort)
webUiAddr := fmt.Sprintf("http://%s", addr) webUiAddr := fmt.Sprintf("http://%s", addr)
router := mux.NewRouter() router := mux.NewRouter()
@ -93,9 +100,21 @@ func runWebUI(cmd *cobra.Command, args []string) error {
fmt.Printf("Graphql Playground: http://%s/playground\n", addr) fmt.Printf("Graphql Playground: http://%s/playground\n", addr)
fmt.Println("Press Ctrl+c to quit") fmt.Println("Press Ctrl+c to quit")
err = open.Run(webUiAddr) configOpen, err := repo.ReadConfigBool(webUIOpenConfigKey)
if err != nil { if err == repository.ErrNoConfigEntry {
fmt.Println(err) // default to true
configOpen = true
} else if err != nil {
return err
}
shouldOpen := (configOpen && !webUINoOpen) || webUIOpen
if shouldOpen {
err = open.Run(webUiAddr)
if err != nil {
fmt.Println(err)
}
} }
err = srv.ListenAndServe() err = srv.ListenAndServe()
@ -223,8 +242,13 @@ func (gufh *gitUploadFileHandler) ServeHTTP(rw http.ResponseWriter, r *http.Requ
} }
var webUICmd = &cobra.Command{ var webUICmd = &cobra.Command{
Use: "webui", Use: "webui",
Short: "Launch the web UI.", Short: "Launch the web UI.",
Long: `Launch the web UI.
Available git config:
git-bug.webui.open [bool]: control the automatic opening of the web UI in the default browser
`,
PreRunE: loadRepo, PreRunE: loadRepo,
RunE: runWebUI, RunE: runWebUI,
} }
@ -234,5 +258,8 @@ func init() {
webUICmd.Flags().SortFlags = false webUICmd.Flags().SortFlags = false
webUICmd.Flags().IntVarP(&port, "port", "p", 0, "Port to listen to") webUICmd.Flags().BoolVar(&webUIOpen, "open", false, "Automatically open the web UI in the default browser")
webUICmd.Flags().BoolVar(&webUINoOpen, "no-open", false, "Prevent the automatic opening of the web UI in the default browser")
webUICmd.Flags().IntVarP(&webUIPort, "port", "p", 0, "Port to listen to (default is random)")
} }

View File

@ -17,11 +17,23 @@ git\-bug\-webui \- Launch the web UI.
.PP .PP
Launch the web UI. Launch the web UI.
.PP
Available git config:
git\-bug.webui.open [bool]: control the automatic opening of the web UI in the default browser
.SH OPTIONS .SH OPTIONS
.PP
\fB\-\-open\fP[=false]
Automatically open the web UI in the default browser
.PP
\fB\-\-no\-open\fP[=false]
Prevent the automatic opening of the web UI in the default browser
.PP .PP
\fB\-p\fP, \fB\-\-port\fP=0 \fB\-p\fP, \fB\-\-port\fP=0
Port to listen to Port to listen to (default is random)
.PP .PP
\fB\-h\fP, \fB\-\-help\fP[=false] \fB\-h\fP, \fB\-\-help\fP[=false]

View File

@ -31,7 +31,7 @@ git-bug [flags]
* [git-bug deselect](git-bug_deselect.md) - Clear the implicitly selected bug. * [git-bug deselect](git-bug_deselect.md) - Clear the implicitly selected bug.
* [git-bug label](git-bug_label.md) - Display, add or remove labels to/from a bug. * [git-bug label](git-bug_label.md) - Display, add or remove labels to/from a bug.
* [git-bug ls](git-bug_ls.md) - List bugs. * [git-bug ls](git-bug_ls.md) - List bugs.
* [git-bug ls-id](git-bug_ls-id.md) - List Bug Id * [git-bug ls-id](git-bug_ls-id.md) - List bug identifiers.
* [git-bug ls-label](git-bug_ls-label.md) - List valid labels. * [git-bug ls-label](git-bug_ls-label.md) - List valid labels.
* [git-bug pull](git-bug_pull.md) - Pull bugs update from a git remote. * [git-bug pull](git-bug_pull.md) - Pull bugs update from a git remote.
* [git-bug push](git-bug_push.md) - Push bugs update to a git remote. * [git-bug push](git-bug_push.md) - Push bugs update to a git remote.

View File

@ -1,10 +1,10 @@
## git-bug ls-id ## git-bug ls-id
List Bug Id List bug identifiers.
### Synopsis ### Synopsis
List Bug Id List bug identifiers.
``` ```
git-bug ls-id [<prefix>] [flags] git-bug ls-id [<prefix>] [flags]

View File

@ -6,6 +6,10 @@ Launch the web UI.
Launch the web UI. Launch the web UI.
Available git config:
git-bug.webui.open [bool]: control the automatic opening of the web UI in the default browser
``` ```
git-bug webui [flags] git-bug webui [flags]
``` ```
@ -13,7 +17,9 @@ git-bug webui [flags]
### Options ### Options
``` ```
-p, --port int Port to listen to --open Automatically open the web UI in the default browser
--no-open Prevent the automatic opening of the web UI in the default browser
-p, --port int Port to listen to (default is random)
-h, --help help for webui -h, --help help for webui
``` ```

View File

@ -107,7 +107,13 @@ __git-bug_handle_reply()
fi fi
if [[ ${#COMPREPLY[@]} -eq 0 ]]; then if [[ ${#COMPREPLY[@]} -eq 0 ]]; then
declare -F __custom_func >/dev/null && __custom_func if declare -F __git-bug_custom_func >/dev/null; then
# try command name qualified custom func
__git-bug_custom_func
else
# otherwise fall back to unqualified for compatibility
declare -F __custom_func >/dev/null && __custom_func
fi
fi fi
# available in bash-completion >= 2, not always present on macOS # available in bash-completion >= 2, not always present on macOS
@ -171,7 +177,8 @@ __git-bug_handle_flag()
fi fi
# skip the argument to a two word flag # skip the argument to a two word flag
if __git-bug_contains_word "${words[c]}" "${two_word_flags[@]}"; then if [[ ${words[c]} != *"="* ]] && __git-bug_contains_word "${words[c]}" "${two_word_flags[@]}"; then
__git-bug_debug "${FUNCNAME[0]}: found a flag ${words[c]}, skip the next argument"
c=$((c+1)) c=$((c+1))
# if we are looking for a flags value, don't show commands # if we are looking for a flags value, don't show commands
if [[ $c -eq $cword ]]; then if [[ $c -eq $cword ]]; then
@ -263,12 +270,15 @@ _git-bug_add()
flags_completion=() flags_completion=()
flags+=("--title=") flags+=("--title=")
two_word_flags+=("--title")
two_word_flags+=("-t") two_word_flags+=("-t")
local_nonpersistent_flags+=("--title=") local_nonpersistent_flags+=("--title=")
flags+=("--message=") flags+=("--message=")
two_word_flags+=("--message")
two_word_flags+=("-m") two_word_flags+=("-m")
local_nonpersistent_flags+=("--message=") local_nonpersistent_flags+=("--message=")
flags+=("--file=") flags+=("--file=")
two_word_flags+=("--file")
two_word_flags+=("-F") two_word_flags+=("-F")
local_nonpersistent_flags+=("--file=") local_nonpersistent_flags+=("--file=")
@ -398,9 +408,11 @@ _git-bug_comment_add()
flags_completion=() flags_completion=()
flags+=("--file=") flags+=("--file=")
two_word_flags+=("--file")
two_word_flags+=("-F") two_word_flags+=("-F")
local_nonpersistent_flags+=("--file=") local_nonpersistent_flags+=("--file=")
flags+=("--message=") flags+=("--message=")
two_word_flags+=("--message")
two_word_flags+=("-m") two_word_flags+=("-m")
local_nonpersistent_flags+=("--message=") local_nonpersistent_flags+=("--message=")
@ -527,30 +539,39 @@ _git-bug_ls()
flags_completion=() flags_completion=()
flags+=("--status=") flags+=("--status=")
two_word_flags+=("--status")
two_word_flags+=("-s") two_word_flags+=("-s")
local_nonpersistent_flags+=("--status=") local_nonpersistent_flags+=("--status=")
flags+=("--author=") flags+=("--author=")
two_word_flags+=("--author")
two_word_flags+=("-a") two_word_flags+=("-a")
local_nonpersistent_flags+=("--author=") local_nonpersistent_flags+=("--author=")
flags+=("--participant=") flags+=("--participant=")
two_word_flags+=("--participant")
two_word_flags+=("-p") two_word_flags+=("-p")
local_nonpersistent_flags+=("--participant=") local_nonpersistent_flags+=("--participant=")
flags+=("--actor=") flags+=("--actor=")
two_word_flags+=("--actor")
two_word_flags+=("-A") two_word_flags+=("-A")
local_nonpersistent_flags+=("--actor=") local_nonpersistent_flags+=("--actor=")
flags+=("--label=") flags+=("--label=")
two_word_flags+=("--label")
two_word_flags+=("-l") two_word_flags+=("-l")
local_nonpersistent_flags+=("--label=") local_nonpersistent_flags+=("--label=")
flags+=("--title=") flags+=("--title=")
two_word_flags+=("--title")
two_word_flags+=("-t") two_word_flags+=("-t")
local_nonpersistent_flags+=("--title=") local_nonpersistent_flags+=("--title=")
flags+=("--no=") flags+=("--no=")
two_word_flags+=("--no")
two_word_flags+=("-n") two_word_flags+=("-n")
local_nonpersistent_flags+=("--no=") local_nonpersistent_flags+=("--no=")
flags+=("--by=") flags+=("--by=")
two_word_flags+=("--by")
two_word_flags+=("-b") two_word_flags+=("-b")
local_nonpersistent_flags+=("--by=") local_nonpersistent_flags+=("--by=")
flags+=("--direction=") flags+=("--direction=")
two_word_flags+=("--direction")
two_word_flags+=("-d") two_word_flags+=("-d")
local_nonpersistent_flags+=("--direction=") local_nonpersistent_flags+=("--direction=")
@ -674,6 +695,7 @@ _git-bug_show()
flags_completion=() flags_completion=()
flags+=("--field=") flags+=("--field=")
two_word_flags+=("--field")
two_word_flags+=("-f") two_word_flags+=("-f")
local_nonpersistent_flags+=("--field=") local_nonpersistent_flags+=("--field=")
@ -779,6 +801,7 @@ _git-bug_title_edit()
flags_completion=() flags_completion=()
flags+=("--title=") flags+=("--title=")
two_word_flags+=("--title")
two_word_flags+=("-t") two_word_flags+=("-t")
local_nonpersistent_flags+=("--title=") local_nonpersistent_flags+=("--title=")
@ -886,6 +909,7 @@ _git-bug_user()
flags_completion=() flags_completion=()
flags+=("--field=") flags+=("--field=")
two_word_flags+=("--field")
two_word_flags+=("-f") two_word_flags+=("-f")
local_nonpersistent_flags+=("--field=") local_nonpersistent_flags+=("--field=")
@ -937,7 +961,12 @@ _git-bug_webui()
flags_with_completion=() flags_with_completion=()
flags_completion=() flags_completion=()
flags+=("--open")
local_nonpersistent_flags+=("--open")
flags+=("--no-open")
local_nonpersistent_flags+=("--no-open")
flags+=("--port=") flags+=("--port=")
two_word_flags+=("--port")
two_word_flags+=("-p") two_word_flags+=("-p")
local_nonpersistent_flags+=("--port=") local_nonpersistent_flags+=("--port=")

View File

@ -8,7 +8,7 @@ case $state in
level1) level1)
case $words[1] in case $words[1] in
git-bug) git-bug)
_arguments '1: :(add bridge commands comment deselect label ls ls-id ls-label pull push select show status termui title user version webui)' _arguments '1: :(add bridge commands comment deselect export label ls ls-id ls-label pull push select show status termui title user version webui)'
;; ;;
*) *)
_arguments '*: :_files' _arguments '*: :_files'