mirror of
https://github.com/docker/docker-credential-helpers.git
synced 2026-06-13 16:01:28 +05:30
Add support for Windows credential manager.
Signed-off-by: David Calavera <david.calavera@gmail.com>
This commit is contained in:
@@ -10,6 +10,10 @@ osxkeychain:
|
|||||||
mkdir -p bin
|
mkdir -p bin
|
||||||
go build -o bin/docker-credential-osxkeychain osxkeychain/cmd/main_darwin.go
|
go build -o bin/docker-credential-osxkeychain osxkeychain/cmd/main_darwin.go
|
||||||
|
|
||||||
|
wincred:
|
||||||
|
mkdir -p bin
|
||||||
|
go build -o bin/docker-credential-wincred wincred/cmd/main_windows.go
|
||||||
|
|
||||||
test:
|
test:
|
||||||
go test -v ./...
|
go test -v ./...
|
||||||
|
|
||||||
|
|||||||
@@ -38,6 +38,7 @@ Set the `credsStore` option in your `.docker/config.json` file with the suffix o
|
|||||||
### Available programs
|
### Available programs
|
||||||
|
|
||||||
1. osxkeychain: Provides a helper to use the OS X keychain as credentials store.
|
1. osxkeychain: Provides a helper to use the OS X keychain as credentials store.
|
||||||
|
2. wincred: Provides a helper to use Windows credentials manager as store.
|
||||||
|
|
||||||
## Development
|
## Development
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,10 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/docker/docker-credential-helpers/credentials"
|
||||||
|
"github.com/docker/docker-credential-helpers/wincred"
|
||||||
|
)
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
credentials.Serve(wincred.New())
|
||||||
|
}
|
||||||
@@ -0,0 +1,43 @@
|
|||||||
|
package wincred
|
||||||
|
|
||||||
|
import (
|
||||||
|
winc "github.com/danieljoos/wincred"
|
||||||
|
"github.com/docker/docker-credential-helpers/credentials"
|
||||||
|
)
|
||||||
|
|
||||||
|
type wincred struct{}
|
||||||
|
|
||||||
|
// New creates a new wincred.
|
||||||
|
func New() credentials.Helper {
|
||||||
|
return wincred{}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Add adds new credentials to the windows credentials manager.
|
||||||
|
func (h wincred) Add(creds *credentials.Credentials) error {
|
||||||
|
g := winc.NewGenericCredential(creds.ServerURL)
|
||||||
|
g.UserName = creds.Username
|
||||||
|
g.CredentialBlob = []byte(creds.Password)
|
||||||
|
g.Persist = winc.PersistLocalMachine
|
||||||
|
return g.Write()
|
||||||
|
}
|
||||||
|
|
||||||
|
// Delete removes credentials from the windows credentials manager.
|
||||||
|
func (h wincred) Delete(serverURL string) error {
|
||||||
|
g, err := winc.GetGenericCredential(serverURL)
|
||||||
|
if g == nil {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
return g.Delete()
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get retrieves credentials from the windows credentials manager.
|
||||||
|
func (h wincred) Get(serverURL string) (string, string, error) {
|
||||||
|
g, _ := winc.GetGenericCredential(serverURL)
|
||||||
|
if g == nil {
|
||||||
|
return "", "", credentials.ErrCredentialsNotFound
|
||||||
|
}
|
||||||
|
return g.UserName, string(g.CredentialBlob), nil
|
||||||
|
}
|
||||||
@@ -0,0 +1,45 @@
|
|||||||
|
package wincred
|
||||||
|
|
||||||
|
import (
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/docker/docker-credential-helpers/credentials"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestWinCredHelper(t *testing.T) {
|
||||||
|
creds := &credentials.Credentials{
|
||||||
|
ServerURL: "https://foobar.docker.io:2376/v1",
|
||||||
|
Username: "foobar",
|
||||||
|
Password: "foobarbaz",
|
||||||
|
}
|
||||||
|
|
||||||
|
helper := New()
|
||||||
|
if err := helper.Add(creds); err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
username, password, err := helper.Get(creds.ServerURL)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if username != "foobar" {
|
||||||
|
t.Fatalf("expected %s, got %s\n", "foobar", username)
|
||||||
|
}
|
||||||
|
|
||||||
|
if password != "foobarbaz" {
|
||||||
|
t.Fatalf("expected %s, got %s\n", "foobarbaz", password)
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := helper.Delete(creds.ServerURL); err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestMissingCredentials(t *testing.T) {
|
||||||
|
helper := New()
|
||||||
|
_, _, err := helper.Get("https://adsfasdf.wrewerwer.com/asdfsdddd")
|
||||||
|
if err != credentials.ErrCredentialsNotFound {
|
||||||
|
t.Fatalf("exptected ErrCredentialsNotFound, got %v", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user