mirror of
https://github.com/docker/docker-credential-helpers.git
synced 2026-06-14 00:11:28 +05:30
Merge pull request #278 from thaJeztah/osxkeychain_typed_error
osxkeychain: Delete(): return typed errors
This commit is contained in:
@@ -34,7 +34,7 @@ type Osxkeychain struct{}
|
|||||||
|
|
||||||
// Add adds new credentials to the keychain.
|
// Add adds new credentials to the keychain.
|
||||||
func (h Osxkeychain) Add(creds *credentials.Credentials) error {
|
func (h Osxkeychain) Add(creds *credentials.Credentials) error {
|
||||||
h.Delete(creds.ServerURL)
|
_ = h.Delete(creds.ServerURL) // ignore errors as existing credential may not exist.
|
||||||
|
|
||||||
s, err := splitServer(creds.ServerURL)
|
s, err := splitServer(creds.ServerURL)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@@ -66,10 +66,16 @@ func (h Osxkeychain) Delete(serverURL string) error {
|
|||||||
}
|
}
|
||||||
defer freeServer(s)
|
defer freeServer(s)
|
||||||
|
|
||||||
errMsg := C.keychain_delete(s)
|
if errMsg := C.keychain_delete(s); errMsg != nil {
|
||||||
if errMsg != nil {
|
|
||||||
defer C.free(unsafe.Pointer(errMsg))
|
defer C.free(unsafe.Pointer(errMsg))
|
||||||
return errors.New(C.GoString(errMsg))
|
switch goMsg := C.GoString(errMsg); goMsg {
|
||||||
|
case errCredentialsNotFound:
|
||||||
|
return credentials.NewErrCredentialsNotFound()
|
||||||
|
case errInteractionNotAllowed:
|
||||||
|
return ErrInteractionNotAllowed
|
||||||
|
default:
|
||||||
|
return errors.New(goMsg)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
@@ -93,15 +99,14 @@ func (h Osxkeychain) Get(serverURL string) (string, string, error) {
|
|||||||
errMsg := C.keychain_get(s, &usernameLen, &username, &secretLen, &secret)
|
errMsg := C.keychain_get(s, &usernameLen, &username, &secretLen, &secret)
|
||||||
if errMsg != nil {
|
if errMsg != nil {
|
||||||
defer C.free(unsafe.Pointer(errMsg))
|
defer C.free(unsafe.Pointer(errMsg))
|
||||||
goMsg := C.GoString(errMsg)
|
switch goMsg := C.GoString(errMsg); goMsg {
|
||||||
if goMsg == errCredentialsNotFound {
|
case errCredentialsNotFound:
|
||||||
return "", "", credentials.NewErrCredentialsNotFound()
|
return "", "", credentials.NewErrCredentialsNotFound()
|
||||||
}
|
case errInteractionNotAllowed:
|
||||||
if goMsg == errInteractionNotAllowed {
|
|
||||||
return "", "", ErrInteractionNotAllowed
|
return "", "", ErrInteractionNotAllowed
|
||||||
|
default:
|
||||||
|
return "", "", errors.New(goMsg)
|
||||||
}
|
}
|
||||||
|
|
||||||
return "", "", errors.New(goMsg)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
user := C.GoStringN(username, C.int(usernameLen))
|
user := C.GoStringN(username, C.int(usernameLen))
|
||||||
@@ -124,15 +129,14 @@ func (h Osxkeychain) List() (map[string]string, error) {
|
|||||||
defer C.freeListData(&acctsC, listLenC)
|
defer C.freeListData(&acctsC, listLenC)
|
||||||
if errMsg != nil {
|
if errMsg != nil {
|
||||||
defer C.free(unsafe.Pointer(errMsg))
|
defer C.free(unsafe.Pointer(errMsg))
|
||||||
goMsg := C.GoString(errMsg)
|
switch goMsg := C.GoString(errMsg); goMsg {
|
||||||
if goMsg == errCredentialsNotFound {
|
case errCredentialsNotFound:
|
||||||
return make(map[string]string), nil
|
return make(map[string]string), nil
|
||||||
}
|
case errInteractionNotAllowed:
|
||||||
if goMsg == errInteractionNotAllowed {
|
|
||||||
return nil, ErrInteractionNotAllowed
|
return nil, ErrInteractionNotAllowed
|
||||||
|
default:
|
||||||
|
return nil, errors.New(goMsg)
|
||||||
}
|
}
|
||||||
|
|
||||||
return nil, errors.New(goMsg)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
var listLen int
|
var listLen int
|
||||||
|
|||||||
@@ -205,9 +205,14 @@ func TestOSXKeychainHelperStoreRetrieve(t *testing.T) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestMissingCredentials(t *testing.T) {
|
func TestMissingCredentials(t *testing.T) {
|
||||||
|
const nonExistingCred = "https://adsfasdf.invalid/asdfsdddd"
|
||||||
helper := Osxkeychain{}
|
helper := Osxkeychain{}
|
||||||
_, _, err := helper.Get("https://adsfasdf.wrewerwer.com/asdfsdddd")
|
_, _, err := helper.Get(nonExistingCred)
|
||||||
if !credentials.IsErrCredentialsNotFound(err) {
|
if !credentials.IsErrCredentialsNotFound(err) {
|
||||||
t.Fatalf("expected ErrCredentialsNotFound, got %v", err)
|
t.Errorf("expected ErrCredentialsNotFound, got %v", err)
|
||||||
|
}
|
||||||
|
err = helper.Delete(nonExistingCred)
|
||||||
|
if !credentials.IsErrCredentialsNotFound(err) {
|
||||||
|
t.Errorf("expected ErrCredentialsNotFound, got %v", err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user