mirror of
				https://github.com/tailscale/tailscale.git
				synced 2025-10-25 02:02:51 +00:00 
			
		
		
		
	cmd/tailscale: make cert give hints on usage failure
Like mentioning which cert domain(s) are valid. (cherry picked from commit891e7986cc) (cherry picked from commitb10a55e4ed) Signed-off-by: Brad Fitzpatrick <bradfitz@tailscale.com>
This commit is contained in:
		| @@ -18,6 +18,7 @@ import ( | ||||
| 	"github.com/peterbourgon/ff/v2/ffcli" | ||||
| 	"tailscale.com/atomicfile" | ||||
| 	"tailscale.com/client/tailscale" | ||||
| 	"tailscale.com/ipn" | ||||
| ) | ||||
|  | ||||
| var certCmd = &ffcli.Command{ | ||||
| @@ -61,7 +62,19 @@ func runCert(ctx context.Context, args []string) error { | ||||
| 	} | ||||
|  | ||||
| 	if len(args) != 1 { | ||||
| 		return fmt.Errorf("Usage: tailscale cert [flags] <domain>") | ||||
| 		var hint bytes.Buffer | ||||
| 		if st, err := tailscale.Status(ctx); err == nil { | ||||
| 			if st.BackendState != ipn.Running.String() { | ||||
| 				fmt.Fprintf(&hint, "\nTailscale is not running.\n") | ||||
| 			} else if len(st.CertDomains) == 0 { | ||||
| 				fmt.Fprintf(&hint, "\nHTTPS cert support is not enabled/configured for your tailnet.\n") | ||||
| 			} else if len(st.CertDomains) == 1 { | ||||
| 				fmt.Fprintf(&hint, "\nFor domain, use %q.\n", st.CertDomains[0]) | ||||
| 			} else { | ||||
| 				fmt.Fprintf(&hint, "\nValid domain options: %q.\n", st.CertDomains) | ||||
| 			} | ||||
| 		} | ||||
| 		return fmt.Errorf("Usage: tailscale cert [flags] <domain>%s", hint.Bytes()) | ||||
| 	} | ||||
| 	domain := args[0] | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Brad Fitzpatrick
					Brad Fitzpatrick