mirror of
https://github.com/taigrr/wtf
synced 2025-01-18 04:03:14 -08:00
Store service credentials securely in the stores supported by docker: - https://github.com/docker/docker-credential-helpers#available-programs Introduces a top-level config property, "secretStore" and additional command line arguments to manage the stored secrets. The value of secretStore is used to find a helper command, `docker-credential-<secretStore>`. The docker project currently provides 4 store helpers: - "osxkeychain" (OS X only) - "secretservice" (Linux only) - "wincred" (Windows only) - "pass" (any OS supporting pass, which uses gpg2) Docker-for-desktop installs the credential helpers above, as well as "desktop" (docker-credential-desktop). Generic installation instructions for the helpers: - https://github.com/docker/docker-credential-helpers#installation Users could provide additional helpers, the only requirement is that the helper implements the credential store protocol: - https://github.com/docker/docker-credential-helpers#development The credential protocol is open, and new credential stores can be implemented by any CLI satisfying the protocol: - https://github.com/docker/docker-credential-helpers#development The modifications to existing modules is not tested due to lack of API keys, but demonstrates the unobtrusive changes required to use the secret store.
52 lines
1.8 KiB
Go
52 lines
1.8 KiB
Go
package gerrit
|
||
|
||
import (
|
||
"os"
|
||
|
||
"github.com/olebedev/config"
|
||
"github.com/wtfutil/wtf/cfg"
|
||
)
|
||
|
||
const (
|
||
defaultFocusable = true
|
||
defaultTitle = "Gerrit"
|
||
)
|
||
|
||
type colors struct {
|
||
rows struct {
|
||
even string `help:"Define the foreground color for even-numbered rows." values:"Any X11 color name." optional:"true"`
|
||
odd string `help:"Define the foreground color for odd-numbered rows." values:"Any X11 color name." optional:"true"`
|
||
}
|
||
}
|
||
|
||
type Settings struct {
|
||
colors
|
||
common *cfg.Common
|
||
|
||
domain string `help:"Your Gerrit corporate domain."`
|
||
password string `help:"Your Gerrit HTTP Password."`
|
||
projects []interface{} `help:"A list of Gerrit project names to fetch data for."`
|
||
username string `help:"Your Gerrit username."`
|
||
verifyServerCertificate bool `help:"Determines whether or not the server’s certificate chain and host name are verified." values:"true or false" optional:"true"`
|
||
}
|
||
|
||
func NewSettingsFromYAML(name string, ymlConfig *config.Config, globalConfig *config.Config) *Settings {
|
||
settings := Settings{
|
||
common: cfg.NewCommonSettingsFromModule(name, defaultTitle, defaultFocusable, ymlConfig, globalConfig),
|
||
|
||
domain: ymlConfig.UString("domain", ""),
|
||
password: ymlConfig.UString("password", os.Getenv("WTF_GERRIT_PASSWORD")),
|
||
projects: ymlConfig.UList("projects"),
|
||
username: ymlConfig.UString("username", ""),
|
||
verifyServerCertificate: ymlConfig.UBool("verifyServerCertificate", true),
|
||
}
|
||
|
||
cfg.ModuleSecret(name, globalConfig, &settings.password).
|
||
Service(settings.domain).Load()
|
||
|
||
settings.colors.rows.even = ymlConfig.UString("colors.rows.even", "white")
|
||
settings.colors.rows.odd = ymlConfig.UString("colors.rows.odd", "blue")
|
||
|
||
return &settings
|
||
}
|