fs/config, lib/terminal: use golang.org/x/term

golang.org/x/crypto/ssh/terminal is deprecated in favor of
golang.org/x/term, see https://pkg.go.dev/golang.org/x/crypto/ssh/terminal

The latter also supports ReadPassword on solaris, so enable the
respective functionality in fs/config for solaris as well.
This commit is contained in:
Tobias Klauser 2022-03-30 23:13:53 +02:00 committed by Nick Craig-Wood
parent 6ecbbf796e
commit 54c9c3156c
4 changed files with 11 additions and 13 deletions

View file

@ -1,9 +1,8 @@
// ReadPassword for OSes which are supported by golang.org/x/crypto/ssh/terminal // ReadPassword for OSes which are supported by golang.org/x/term
// See https://github.com/golang/go/issues/14441 - plan9 // See https://github.com/golang/go/issues/14441 - plan9
// https://github.com/golang/go/issues/13085 - solaris
//go:build !solaris && !plan9 //go:build !plan9
// +build !solaris,!plan9 // +build !plan9
package config package config

View file

@ -1,9 +1,8 @@
// ReadPassword for OSes which are not supported by golang.org/x/crypto/ssh/terminal // ReadPassword for OSes which are not supported by golang.org/x/term
// See https://github.com/golang/go/issues/14441 - plan9 // See https://github.com/golang/go/issues/14441 - plan9
// https://github.com/golang/go/issues/13085 - solaris
//go:build solaris || plan9 //go:build plan9
// +build solaris plan9 // +build plan9
package config package config

2
go.mod
View file

@ -64,6 +64,7 @@ require (
golang.org/x/oauth2 v0.0.0-20211104180415-d3ed0bb246c8 golang.org/x/oauth2 v0.0.0-20211104180415-d3ed0bb246c8
golang.org/x/sync v0.0.0-20210220032951-036812b2e83c golang.org/x/sync v0.0.0-20210220032951-036812b2e83c
golang.org/x/sys v0.0.0-20211216021012-1d35b9e2eb4e golang.org/x/sys v0.0.0-20211216021012-1d35b9e2eb4e
golang.org/x/term v0.0.0-20210927222741-03fcf44c2211
golang.org/x/text v0.3.7 golang.org/x/text v0.3.7
golang.org/x/time v0.0.0-20210723032227-1f47c861a9ac golang.org/x/time v0.0.0-20210723032227-1f47c861a9ac
google.golang.org/api v0.60.0 google.golang.org/api v0.60.0
@ -117,7 +118,6 @@ require (
github.com/vivint/infectious v0.0.0-20200605153912-25a574ae18a3 // indirect github.com/vivint/infectious v0.0.0-20200605153912-25a574ae18a3 // indirect
github.com/zeebo/errs v1.2.2 // indirect github.com/zeebo/errs v1.2.2 // indirect
go.opencensus.io v0.23.0 // indirect go.opencensus.io v0.23.0 // indirect
golang.org/x/term v0.0.0-20210927222741-03fcf44c2211 // indirect
google.golang.org/appengine v1.6.7 // indirect google.golang.org/appengine v1.6.7 // indirect
google.golang.org/genproto v0.0.0-20211104193956-4c6863e31247 // indirect google.golang.org/genproto v0.0.0-20211104193956-4c6863e31247 // indirect
google.golang.org/grpc v1.42.0 // indirect google.golang.org/grpc v1.42.0 // indirect

View file

@ -7,13 +7,13 @@ import (
"fmt" "fmt"
"os" "os"
"golang.org/x/crypto/ssh/terminal" "golang.org/x/term"
) )
// GetSize reads the dimensions of the current terminal or returns a // GetSize reads the dimensions of the current terminal or returns a
// sensible default // sensible default
func GetSize() (w, h int) { func GetSize() (w, h int) {
w, h, err := terminal.GetSize(int(os.Stdout.Fd())) w, h, err := term.GetSize(int(os.Stdout.Fd()))
if err != nil { if err != nil {
w, h = 80, 25 w, h = 80, 25
} }
@ -22,14 +22,14 @@ func GetSize() (w, h int) {
// IsTerminal returns whether the fd passed in is a terminal or not // IsTerminal returns whether the fd passed in is a terminal or not
func IsTerminal(fd int) bool { func IsTerminal(fd int) bool {
return terminal.IsTerminal(fd) return term.IsTerminal(fd)
} }
// ReadPassword reads a line of input from a terminal without local echo. This // ReadPassword reads a line of input from a terminal without local echo. This
// is commonly used for inputting passwords and other sensitive data. The slice // is commonly used for inputting passwords and other sensitive data. The slice
// returned does not include the \n. // returned does not include the \n.
func ReadPassword(fd int) ([]byte, error) { func ReadPassword(fd int) ([]byte, error) {
return terminal.ReadPassword(fd) return term.ReadPassword(fd)
} }
// WriteTerminalTitle writes a string to the terminal title // WriteTerminalTitle writes a string to the terminal title