Skip to content

Commit 98a7278

Browse files
committed
feat: add support for gopass as a credential store
This change adds support for `gopass` as a credential store, based on the `pass` implementation. Closes: #138 Closes: #166 Signed-off-by: sudoforge <[email protected]>
1 parent fd86e95 commit 98a7278

File tree

7 files changed

+395
-12
lines changed

7 files changed

+395
-12
lines changed

.github/workflows/build.yml

Lines changed: 17 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -69,6 +69,11 @@ jobs:
6969
if: startsWith(matrix.os, 'macOS-')
7070
run: |
7171
brew install pass
72+
-
73+
name: Install gopass
74+
env:
75+
GOPASS_VERSION: v1.15.5
76+
run: go install github.com/gopasspw/gopass@${{ env.GOPASS_VERSION }}
7277
-
7378
name: GPG conf
7479
if: ${{ !startsWith(matrix.os, 'windows-') }}
@@ -100,6 +105,18 @@ jobs:
100105
run: |
101106
pass init 7D851EB72D73BDA0
102107
shell: bash
108+
-
109+
name: Init gopass
110+
run: |
111+
gopass config mounts.path "${HOME}/.gopass-password-store" 1>/dev/null
112+
gopass config core.autopush false 1>/dev/null
113+
gopass config core.autosync false 1>/dev/null
114+
gopass config core.exportkeys false 1>/dev/null
115+
gopass config core.notifications false 1>/dev/null
116+
gopass config core.color false 1>/dev/null
117+
gopass config core.nopager true 1>/dev/null
118+
gopass init --crypto gpgcli --storage fs 7D851EB72D73BDA0
119+
shell: bash
103120
-
104121
name: Test
105122
run: |

Dockerfile

Lines changed: 28 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -5,6 +5,7 @@ ARG XX_VERSION=1.4.0
55
ARG OSXCROSS_VERSION=11.3-r7-debian
66
ARG GOLANGCI_LINT_VERSION=v1.55.2
77
ARG DEBIAN_FRONTEND=noninteractive
8+
ARG GOPASS_VERSION=v1.15.5
89

910
ARG PACKAGE=github.com/docker/docker-credential-helpers
1011

@@ -68,12 +69,19 @@ RUN xx-apt-get install -y binutils gcc libc6-dev libgcc-10-dev libsecret-1-dev p
6869

6970
FROM base AS test
7071
ARG DEBIAN_FRONTEND
72+
ARG GOPASS_VERSION
7173
RUN xx-apt-get install -y dbus-x11 gnome-keyring gpg-agent gpgconf libsecret-1-dev pass
74+
RUN --mount=type=bind,target=. \
75+
--mount=type=cache,target=/root/.cache \
76+
--mount=type=cache,target=/go/pkg/mod \
77+
GOFLAGS='' go install github.com/gopasspw/gopass@${GOPASS_VERSION}
7278
RUN --mount=type=bind,target=. \
7379
--mount=type=cache,target=/root/.cache \
7480
--mount=type=cache,target=/go/pkg/mod <<EOT
7581
set -e
82+
7683
cp -r .github/workflows/fixtures /root/.gnupg
84+
chmod 0400 /root/.gnupg
7785
gpg-connect-agent "RELOADAGENT" /bye
7886
gpg --import --batch --yes /root/.gnupg/7D851EB72D73BDA0.key
7987
gpg --update-trustdb
@@ -82,7 +90,20 @@ RUN --mount=type=bind,target=. \
8290
gpg-connect-agent "KEYINFO 3E2D1142AA59E08E16B7E2C64BA6DDC773B1A627" /bye
8391
gpg-connect-agent "PRESET_PASSPHRASE BA83FC8947213477F28ADC019F6564A956456163 -1 77697468207374757069642070617373706872617365" /bye
8492
gpg-connect-agent "KEYINFO BA83FC8947213477F28ADC019F6564A956456163" /bye
93+
94+
# initialize password store for `pass`
8595
pass init 7D851EB72D73BDA0
96+
97+
# initialize password store for `gopass`
98+
gopass config mounts.path /root/.gopass-password-store 1>/dev/null
99+
gopass config core.autopush false 1>/dev/null
100+
gopass config core.autosync false 1>/dev/null
101+
gopass config core.exportkeys false 1>/dev/null
102+
gopass config core.notifications false 1>/dev/null
103+
gopass config core.color false 1>/dev/null
104+
gopass config core.nopager true 1>/dev/null
105+
gopass init --crypto gpgcli --storage fs 7D851EB72D73BDA0
106+
86107
gpg -k
87108

88109
mkdir /out
@@ -106,7 +127,8 @@ RUN --mount=type=bind,target=. \
106127
--mount=type=bind,source=/tmp/.revision,target=/tmp/.revision,from=version <<EOT
107128
set -ex
108129
xx-go --wrap
109-
make build-pass build-secretservice PACKAGE=$PACKAGE VERSION=$(cat /tmp/.version) REVISION=$(cat /tmp/.revision) DESTDIR=/out
130+
make build-gopass build-pass build-secretservice PACKAGE=$PACKAGE VERSION=$(cat /tmp/.version) REVISION=$(cat /tmp/.revision) DESTDIR=/out
131+
xx-verify /out/docker-credential-gopass
110132
xx-verify /out/docker-credential-pass
111133
xx-verify /out/docker-credential-secretservice
112134
EOT
@@ -123,7 +145,8 @@ RUN --mount=type=bind,target=. \
123145
export MACOSX_VERSION_MIN=$(make print-MACOSX_DEPLOYMENT_TARGET)
124146
xx-go --wrap
125147
go install std
126-
make build-osxkeychain build-pass PACKAGE=$PACKAGE VERSION=$(cat /tmp/.version) REVISION=$(cat /tmp/.revision) DESTDIR=/out
148+
make build-gopass build-osxkeychain build-pass PACKAGE=$PACKAGE VERSION=$(cat /tmp/.version) REVISION=$(cat /tmp/.revision) DESTDIR=/out
149+
xx-verify /out/docker-credential-gopass
127150
xx-verify /out/docker-credential-osxkeychain
128151
xx-verify /out/docker-credential-pass
129152
EOT
@@ -137,7 +160,9 @@ RUN --mount=type=bind,target=. \
137160
--mount=type=bind,source=/tmp/.revision,target=/tmp/.revision,from=version <<EOT
138161
set -ex
139162
xx-go --wrap
140-
make build-wincred PACKAGE=$PACKAGE VERSION=$(cat /tmp/.version) REVISION=$(cat /tmp/.revision) DESTDIR=/out
163+
make build-gopass build-wincred PACKAGE=$PACKAGE VERSION=$(cat /tmp/.version) REVISION=$(cat /tmp/.revision) DESTDIR=/out
164+
mv /out/docker-credential-gopass /out/docker-credential-gopass.exe
165+
xx-verify /out/docker-credential-gopass.exe
141166
mv /out/docker-credential-wincred /out/docker-credential-wincred.exe
142167
xx-verify /out/docker-credential-wincred.exe
143168
EOT

Makefile

Lines changed: 3 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -23,11 +23,12 @@ clean:
2323
rm -rf bin
2424

2525
.PHONY: build-%
26-
build-%: # build, can be one of build-osxkeychain build-pass build-secretservice build-wincred
26+
build-%: # build, can be one of build-gopass build-osxkeychain build-pass build-secretservice build-wincred
2727
go build -trimpath -ldflags="$(GO_LDFLAGS) -X ${GO_PKG}/credentials.Name=docker-credential-$*" -o "$(DESTDIR)/docker-credential-$*" ./$*/cmd/
2828

2929
# aliases for build-* targets
30-
.PHONY: osxkeychain secretservice pass wincred
30+
.PHONY: gopass osxkeychain secretservice pass wincred
31+
gopass: build-gopass
3132
osxkeychain: build-osxkeychain
3233
secretservice: build-secretservice
3334
pass: build-pass

README.md

Lines changed: 18 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -80,15 +80,26 @@ You can see examples of each function in the [client](https://godoc.org/github.c
8080

8181
### Available programs
8282

83-
1. osxkeychain: Provides a helper to use the OS X keychain as credentials store.
84-
2. secretservice: Provides a helper to use the D-Bus secret service as credentials store.
85-
3. wincred: Provides a helper to use Windows credentials manager as store.
86-
4. pass: Provides a helper to use `pass` as credentials store.
83+
- gopass: Provides a helper to use `gopass` as credentials store.
84+
- osxkeychain: Provides a helper to use the OS X keychain as credentials store.
85+
- pass: Provides a helper to use `pass` as credentials store.
86+
- secretservice: Provides a helper to use the D-Bus secret service as credentials store.
87+
- wincred: Provides a helper to use Windows credentials manager as store.
8788

88-
#### Note
89+
#### Note regarding `gopass`
8990

90-
`pass` needs to be configured for `docker-credential-pass` to work properly.
91-
It must be initialized with a `gpg2` key ID. Make sure your GPG key exists is in `gpg2` keyring as `pass` uses `gpg2` instead of the regular `gpg`.
91+
`gopass` requires manual intervention in order for `docker-credential-gopass` to
92+
work properly: a password store must be initialized. Please ensure to review the
93+
upstream [quick start guide][gopass-quick-start] for more information.
94+
95+
[gopass-quick-start]: https://github.com/gopasspw/gopass#quick-start-guide
96+
97+
#### Note regarding `pass`
98+
99+
`pass` requires manual interview in order for `docker-credential-pass` to
100+
work properly. It must be initialized with a `gpg2` key ID. Make sure your GPG
101+
key exists is in `gpg2` keyring as `pass` uses `gpg2` instead of the regular
102+
`gpg`.
92103

93104
## Development
94105

gopass/cmd/main.go

Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,10 @@
1+
package main
2+
3+
import (
4+
"github.com/docker/docker-credential-helpers/credentials"
5+
"github.com/docker/docker-credential-helpers/gopass"
6+
)
7+
8+
func main() {
9+
credentials.Serve(gopass.Gopass{})
10+
}

0 commit comments

Comments
 (0)