harness-drone/model/secret.go

60 lines
1.5 KiB
Go
Raw Normal View History

package model
2016-07-31 20:29:56 +00:00
import (
"path/filepath"
)
2016-04-21 08:18:20 +00:00
type Secret struct {
2016-04-21 08:18:20 +00:00
// the name of the secret which will be used as the environment variable
// name at runtime.
2016-07-31 20:29:56 +00:00
Name string `json:"name"`
2016-04-21 08:18:20 +00:00
// the value of the secret which will be provided to the runtime environment
// as a named environment variable.
2016-07-31 20:29:56 +00:00
Value string `json:"value"`
// the secret is restricted to this list of images.
2016-07-31 20:29:56 +00:00
Images []string `json:"image,omitempty"`
// the secret is restricted to this list of events.
2016-07-31 20:29:56 +00:00
Events []string `json:"event,omitempty"`
2016-10-19 18:50:09 +00:00
// whether the secret requires verification
SkipVerify bool `json:"skip_verify"`
// whether the secret should be concealed in the build log
Conceal bool `json:"conceal"`
}
// Match returns true if an image and event match the restricted list.
func (s *Secret) Match(image, event string) bool {
return s.MatchImage(image) && s.MatchEvent(event)
}
// MatchImage returns true if an image matches the restricted list.
2016-04-21 08:18:20 +00:00
func (s *Secret) MatchImage(image string) bool {
for _, pattern := range s.Images {
if match, _ := filepath.Match(pattern, image); match {
return true
2016-04-23 20:51:12 +00:00
} else if pattern == "*" {
return true
}
}
return false
}
// MatchEvent returns true if an event matches the restricted list.
2016-04-21 08:18:20 +00:00
func (s *Secret) MatchEvent(event string) bool {
for _, pattern := range s.Events {
if match, _ := filepath.Match(pattern, event); match {
return true
}
}
return false
}
// Validate validates the required fields and formats.
func (s *Secret) Validate() error {
return nil
}