package token import ( "fmt" "github.com/cli/cli/v2/internal/config" "github.com/cli/cli/v2/pkg/cmdutil" "github.com/cli/cli/v2/pkg/iostreams" "github.com/spf13/cobra" ) type TokenOptions struct { IO *iostreams.IOStreams Config func() (config.Config, error) Hostname string SecureStorage bool } func NewCmdToken(f *cmdutil.Factory, runF func(*TokenOptions) error) *cobra.Command { opts := &TokenOptions{ IO: f.IOStreams, Config: f.Config, } cmd := &cobra.Command{ Use: "token", Short: "Print the auth token gh is configured to use", Args: cobra.ExactArgs(0), RunE: func(cmd *cobra.Command, args []string) error { if runF != nil { return runF(opts) } return tokenRun(opts) }, } cmd.Flags().StringVarP(&opts.Hostname, "hostname", "h", "", "The hostname of the GitHub instance authenticated with") cmd.Flags().BoolVarP(&opts.SecureStorage, "secure-storage", "", false, "Search only secure credential store for authentication token") _ = cmd.Flags().MarkHidden("secure-storage") return cmd } func tokenRun(opts *TokenOptions) error { cfg, err := opts.Config() if err != nil { return err } authCfg := cfg.Authentication() hostname := opts.Hostname if hostname == "" { hostname, _ = authCfg.DefaultHost() } var val string if opts.SecureStorage { val, _ = authCfg.TokenFromKeyring(hostname) } else { val, _ = authCfg.Token(hostname) } if val == "" { return fmt.Errorf("no oauth token") } if val != "" { fmt.Fprintf(opts.IO.Out, "%s\n", val) } return nil }