2019-06-20 16:36:40 -07:00
|
|
|
package api
|
|
|
|
|
|
|
|
import (
|
2020-06-24 12:38:42 -07:00
|
|
|
"time"
|
|
|
|
|
2019-08-15 09:34:54 -07:00
|
|
|
"github.com/anuvu/zot/errors"
|
2019-11-25 14:33:58 -08:00
|
|
|
"github.com/anuvu/zot/pkg/log"
|
2019-08-15 09:34:54 -07:00
|
|
|
"github.com/getlantern/deepcopy"
|
2019-06-20 16:36:40 -07:00
|
|
|
dspec "github.com/opencontainers/distribution-spec"
|
|
|
|
)
|
|
|
|
|
2020-05-11 15:13:24 -07:00
|
|
|
// Commit ...
|
|
|
|
var Commit string //nolint: gochecknoglobals
|
2019-09-16 11:01:59 -07:00
|
|
|
|
2020-06-24 12:38:42 -07:00
|
|
|
const updateInterval = 24
|
|
|
|
|
2019-06-20 16:36:40 -07:00
|
|
|
type StorageConfig struct {
|
|
|
|
RootDirectory string
|
2020-04-15 16:24:05 -07:00
|
|
|
GC bool
|
|
|
|
Dedupe bool
|
2019-06-20 16:36:40 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
type TLSConfig struct {
|
|
|
|
Cert string
|
|
|
|
Key string
|
|
|
|
CACert string
|
|
|
|
}
|
|
|
|
|
|
|
|
type AuthHTPasswd struct {
|
|
|
|
Path string
|
|
|
|
}
|
|
|
|
|
|
|
|
type AuthConfig struct {
|
|
|
|
FailDelay int
|
|
|
|
HTPasswd AuthHTPasswd
|
2019-08-15 09:34:54 -07:00
|
|
|
LDAP *LDAPConfig
|
2020-01-24 15:32:38 -06:00
|
|
|
Bearer *BearerConfig
|
|
|
|
}
|
|
|
|
|
|
|
|
type BearerConfig struct {
|
|
|
|
Realm string
|
|
|
|
Service string
|
|
|
|
Cert string
|
2019-06-20 16:36:40 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
type HTTPConfig struct {
|
2019-08-28 14:05:16 -07:00
|
|
|
Address string
|
|
|
|
Port string
|
2019-08-15 09:34:54 -07:00
|
|
|
TLS *TLSConfig
|
|
|
|
Auth *AuthConfig
|
2019-08-28 14:05:16 -07:00
|
|
|
Realm string
|
|
|
|
AllowReadAccess bool `mapstructure:",omitempty"`
|
2020-07-10 14:32:58 -07:00
|
|
|
ReadOnly bool `mapstructure:",omitempty"`
|
2019-06-20 16:36:40 -07:00
|
|
|
}
|
|
|
|
|
2019-08-15 09:34:54 -07:00
|
|
|
type LDAPConfig struct {
|
|
|
|
Port int
|
|
|
|
Insecure bool
|
|
|
|
StartTLS bool // if !Insecure, then StartTLS or LDAPs
|
|
|
|
SkipVerify bool
|
|
|
|
SubtreeSearch bool
|
|
|
|
Address string
|
|
|
|
BindDN string
|
|
|
|
BindPassword string
|
|
|
|
BaseDN string
|
|
|
|
UserAttribute string
|
|
|
|
CACert string
|
|
|
|
}
|
|
|
|
|
2019-06-20 16:36:40 -07:00
|
|
|
type LogConfig struct {
|
|
|
|
Level string
|
|
|
|
Output string
|
|
|
|
}
|
|
|
|
|
2020-06-24 12:38:42 -07:00
|
|
|
type ExtensionConfig struct {
|
|
|
|
Search *SearchConfig
|
|
|
|
}
|
|
|
|
|
|
|
|
type SearchConfig struct {
|
|
|
|
// CVE search
|
|
|
|
CVE *CVEConfig
|
|
|
|
}
|
|
|
|
|
|
|
|
type CVEConfig struct {
|
|
|
|
UpdateInterval time.Duration // should be 2 hours or more, if not specified default be kept as 24 hours
|
|
|
|
}
|
|
|
|
|
2019-06-20 16:36:40 -07:00
|
|
|
type Config struct {
|
2020-06-24 12:38:42 -07:00
|
|
|
Version string
|
|
|
|
Commit string
|
|
|
|
Storage StorageConfig
|
|
|
|
HTTP HTTPConfig
|
|
|
|
Log *LogConfig
|
|
|
|
Extensions *ExtensionConfig
|
2019-06-20 16:36:40 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
func NewConfig() *Config {
|
|
|
|
return &Config{
|
2020-06-24 12:38:42 -07:00
|
|
|
Version: dspec.Version,
|
|
|
|
Commit: Commit,
|
|
|
|
Storage: StorageConfig{GC: true, Dedupe: true},
|
|
|
|
HTTP: HTTPConfig{Address: "127.0.0.1", Port: "8080"},
|
|
|
|
Log: &LogConfig{Level: "debug"},
|
|
|
|
Extensions: &ExtensionConfig{&SearchConfig{CVE: &CVEConfig{UpdateInterval: updateInterval}}},
|
2019-08-15 09:34:54 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-05-11 15:13:24 -07:00
|
|
|
// Sanitize makes a sanitized copy of the config removing any secrets.
|
2019-08-15 09:34:54 -07:00
|
|
|
func (c *Config) Sanitize() *Config {
|
|
|
|
if c.HTTP.Auth != nil && c.HTTP.Auth.LDAP != nil && c.HTTP.Auth.LDAP.BindPassword != "" {
|
|
|
|
s := &Config{}
|
|
|
|
if err := deepcopy.Copy(s, c); err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
2019-12-13 00:53:18 -05:00
|
|
|
|
2019-08-15 09:34:54 -07:00
|
|
|
s.HTTP.Auth.LDAP = &LDAPConfig{}
|
2019-12-13 00:53:18 -05:00
|
|
|
|
2019-08-15 09:34:54 -07:00
|
|
|
if err := deepcopy.Copy(s.HTTP.Auth.LDAP, c.HTTP.Auth.LDAP); err != nil {
|
|
|
|
panic(err)
|
|
|
|
}
|
2019-12-13 00:53:18 -05:00
|
|
|
|
2019-08-15 09:34:54 -07:00
|
|
|
s.HTTP.Auth.LDAP.BindPassword = "******"
|
2019-12-13 00:53:18 -05:00
|
|
|
|
2019-08-15 09:34:54 -07:00
|
|
|
return s
|
|
|
|
}
|
2019-12-13 00:53:18 -05:00
|
|
|
|
2019-08-15 09:34:54 -07:00
|
|
|
return c
|
|
|
|
}
|
|
|
|
|
2019-11-25 14:33:58 -08:00
|
|
|
func (c *Config) Validate(log log.Logger) error {
|
2019-08-15 09:34:54 -07:00
|
|
|
// LDAP configuration
|
|
|
|
if c.HTTP.Auth != nil && c.HTTP.Auth.LDAP != nil {
|
|
|
|
l := c.HTTP.Auth.LDAP
|
|
|
|
if l.UserAttribute == "" {
|
|
|
|
log.Error().Str("userAttribute", l.UserAttribute).Msg("invalid LDAP configuration")
|
|
|
|
return errors.ErrLDAPConfig
|
|
|
|
}
|
2019-06-20 16:36:40 -07:00
|
|
|
}
|
2019-12-13 00:53:18 -05:00
|
|
|
|
2019-08-15 09:34:54 -07:00
|
|
|
return nil
|
2019-06-20 16:36:40 -07:00
|
|
|
}
|