diff --git a/secretservice/secretservice.c b/secretservice/secretservice.c index 676cddb2..b77a0d2b 100644 --- a/secretservice/secretservice.c +++ b/secretservice/secretservice.c @@ -17,11 +17,11 @@ const SecretSchema *docker_get_schema(void) return &docker_schema; } -GError *add(char *label, char *server, char *username, char *secret) { +GError *add(char *label, char *server, char *username, char *secret, char *displaylabel) { GError *err = NULL; secret_password_store_sync (DOCKER_SCHEMA, SECRET_COLLECTION_DEFAULT, - server, secret, NULL, &err, + displaylabel, secret, NULL, &err, "label", label, "server", server, "username", username, diff --git a/secretservice/secretservice.go b/secretservice/secretservice.go index caf0fe7c..da2c2e8e 100644 --- a/secretservice/secretservice.go +++ b/secretservice/secretservice.go @@ -33,8 +33,10 @@ func (h Secretservice) Add(creds *credentials.Credentials) error { defer C.free(unsafe.Pointer(username)) secret := C.CString(creds.Secret) defer C.free(unsafe.Pointer(secret)) + displayLabel := C.CString("Registry credentials for " + creds.ServerURL) + defer C.free(unsafe.Pointer(displayLabel)) - if err := C.add(credsLabel, server, username, secret); err != nil { + if err := C.add(credsLabel, server, username, secret, displayLabel); err != nil { defer C.g_error_free(err) errMsg := (*C.char)(unsafe.Pointer(err.message)) return errors.New(C.GoString(errMsg)) diff --git a/secretservice/secretservice.h b/secretservice/secretservice.h index a28179db..154ee8c4 100644 --- a/secretservice/secretservice.h +++ b/secretservice/secretservice.h @@ -6,7 +6,7 @@ const SecretSchema *docker_get_schema(void) G_GNUC_CONST; #define DOCKER_SCHEMA docker_get_schema() -GError *add(char *label, char *server, char *username, char *secret); +GError *add(char *label, char *server, char *username, char *secret, char *displaylabel); GError *delete(char *server); GError *get(char *server, char **username, char **secret); GError *list(char *label, char *** paths, char *** accts, unsigned int *list_l);