2016-03-31 12:01:32 -07:00
|
|
|
package model
|
|
|
|
|
2016-07-31 22:29:56 +02:00
|
|
|
import (
|
2017-04-11 19:06:45 +02:00
|
|
|
"errors"
|
2016-07-31 22:29:56 +02:00
|
|
|
"path/filepath"
|
|
|
|
)
|
2016-04-21 01:18:20 -07:00
|
|
|
|
2017-04-11 19:06:45 +02:00
|
|
|
var (
|
|
|
|
errSecretNameInvalid = errors.New("Invalid Secret Name")
|
|
|
|
errSecretValueInvalid = errors.New("Invalid Secret Value")
|
|
|
|
)
|
2016-11-16 11:28:36 -08:00
|
|
|
|
2017-04-11 19:06:45 +02:00
|
|
|
// SecretService defines a service for managing secrets.
|
|
|
|
type SecretService interface {
|
|
|
|
SecretFind(*Repo, string) (*Secret, error)
|
|
|
|
SecretList(*Repo) ([]*Secret, error)
|
2017-05-12 12:30:19 +02:00
|
|
|
SecretListBuild(*Repo, *Build) ([]*Secret, error)
|
2017-04-11 19:06:45 +02:00
|
|
|
SecretCreate(*Repo, *Secret) error
|
|
|
|
SecretUpdate(*Repo, *Secret) error
|
|
|
|
SecretDelete(*Repo, string) error
|
2016-03-31 12:01:32 -07:00
|
|
|
}
|
|
|
|
|
2017-04-11 19:06:45 +02:00
|
|
|
// SecretStore persists secret information to storage.
|
|
|
|
type SecretStore interface {
|
|
|
|
SecretFind(*Repo, string) (*Secret, error)
|
|
|
|
SecretList(*Repo) ([]*Secret, error)
|
|
|
|
SecretCreate(*Secret) error
|
|
|
|
SecretUpdate(*Secret) error
|
|
|
|
SecretDelete(*Secret) error
|
2016-04-21 00:25:30 -07:00
|
|
|
}
|
|
|
|
|
2017-04-11 19:06:45 +02:00
|
|
|
// Secret represents a secret variable, such as a password or token.
|
|
|
|
// swagger:model registry
|
|
|
|
type Secret struct {
|
|
|
|
ID int64 `json:"id" meddler:"secret_id,pk"`
|
|
|
|
RepoID int64 `json:"-" meddler:"secret_repo_id"`
|
|
|
|
Name string `json:"name" meddler:"secret_name"`
|
|
|
|
Value string `json:"value,omitempty" meddler:"secret_value"`
|
|
|
|
Images []string `json:"image" meddler:"secret_images,json"`
|
|
|
|
Events []string `json:"event" meddler:"secret_events,json"`
|
|
|
|
SkipVerify bool `json:"-" meddler:"secret_skip_verify"`
|
|
|
|
Conceal bool `json:"-" meddler:"secret_conceal"`
|
2016-04-21 00:25:30 -07:00
|
|
|
}
|
|
|
|
|
2017-04-11 19:06:45 +02:00
|
|
|
// Match returns true if an image and event match the restricted list.
|
|
|
|
func (s *Secret) Match(event string) bool {
|
2017-05-20 01:01:30 +02:00
|
|
|
if len(s.Events) == 0 {
|
|
|
|
return true
|
|
|
|
}
|
2016-04-21 01:18:20 -07:00
|
|
|
for _, pattern := range s.Events {
|
|
|
|
if match, _ := filepath.Match(pattern, event); match {
|
2016-04-21 00:25:30 -07:00
|
|
|
return true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
// Validate validates the required fields and formats.
|
2016-03-31 12:01:32 -07:00
|
|
|
func (s *Secret) Validate() error {
|
2017-04-11 19:06:45 +02:00
|
|
|
switch {
|
|
|
|
case len(s.Name) == 0:
|
|
|
|
return errSecretNameInvalid
|
|
|
|
case len(s.Value) == 0:
|
|
|
|
return errSecretValueInvalid
|
|
|
|
default:
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Copy makes a copy of the secret without the value.
|
|
|
|
func (s *Secret) Copy() *Secret {
|
|
|
|
return &Secret{
|
|
|
|
ID: s.ID,
|
|
|
|
RepoID: s.RepoID,
|
|
|
|
Name: s.Name,
|
|
|
|
Images: s.Images,
|
|
|
|
Events: s.Events,
|
|
|
|
}
|
2016-03-31 12:01:32 -07:00
|
|
|
}
|