forked from TrueCloudLab/rclone
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:
parent
6ecbbf796e
commit
54c9c3156c
4 changed files with 11 additions and 13 deletions
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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
2
go.mod
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in a new issue