69 lines
1.4 KiB
Go
69 lines
1.4 KiB
Go
package systemauth
|
|
|
|
import (
|
|
"errors"
|
|
|
|
"github.com/twpayne/go-pinentry"
|
|
)
|
|
|
|
func GetPassword(title string, description string) (string, error) {
|
|
client, err := pinentry.NewClient(
|
|
pinentry.WithBinaryNameFromGnuPGAgentConf(),
|
|
pinentry.WithGPGTTY(),
|
|
pinentry.WithTitle(title),
|
|
pinentry.WithDesc(description),
|
|
pinentry.WithPrompt(title),
|
|
)
|
|
log.Info("Asking for pin |%s|%s|", title, description)
|
|
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
defer client.Close()
|
|
|
|
switch pin, fromCache, err := client.GetPIN(); {
|
|
case pinentry.IsCancelled(err):
|
|
log.Info("Cancelled")
|
|
return "", errors.New("Cancelled")
|
|
case err != nil:
|
|
return "", err
|
|
case fromCache:
|
|
log.Info("Got pin from cache")
|
|
return pin, nil
|
|
default:
|
|
log.Info("Got pin from user")
|
|
return pin, nil
|
|
}
|
|
}
|
|
|
|
func GetApproval(title string, description string) (bool, error) {
|
|
if systemAuthDisabled {
|
|
return true, nil
|
|
}
|
|
|
|
client, err := pinentry.NewClient(
|
|
pinentry.WithBinaryNameFromGnuPGAgentConf(),
|
|
pinentry.WithGPGTTY(),
|
|
pinentry.WithTitle(title),
|
|
pinentry.WithDesc(description),
|
|
pinentry.WithPrompt(title),
|
|
)
|
|
log.Info("Asking for approval |%s|%s|", title, description)
|
|
|
|
if err != nil {
|
|
return false, err
|
|
}
|
|
defer client.Close()
|
|
|
|
switch _, err := client.Confirm("Confirm"); {
|
|
case pinentry.IsCancelled(err):
|
|
log.Info("Cancelled")
|
|
return false, errors.New("Cancelled")
|
|
case err != nil:
|
|
return false, err
|
|
default:
|
|
log.Info("Got approval from user")
|
|
return true, nil
|
|
}
|
|
}
|