Add some basic normalize/validation logic for config entries

pull/5539/head
Kyle Havlovitz 2019-03-22 09:25:37 -07:00
parent d92577c16b
commit e199c37ee4
No known key found for this signature in database
GPG Key ID: 8A5E6B173056AD6C
1 changed files with 40 additions and 0 deletions

View File

@ -1,8 +1,12 @@
package structs package structs
import "fmt"
const ( const (
ServiceDefaults string = "service-defaults" ServiceDefaults string = "service-defaults"
ProxyDefaults string = "proxy-defaults" ProxyDefaults string = "proxy-defaults"
ProxyConfigGlobal string = "global"
) )
// ConfigEntry is the // ConfigEntry is the
@ -34,10 +38,20 @@ func (e *ServiceConfigEntry) GetKind() string {
} }
func (e *ServiceConfigEntry) GetName() string { func (e *ServiceConfigEntry) GetName() string {
if e == nil {
return ""
}
return e.Name return e.Name
} }
func (e *ServiceConfigEntry) Normalize() error { func (e *ServiceConfigEntry) Normalize() error {
if e == nil {
return fmt.Errorf("config entry is nil")
}
e.Kind = ServiceDefaults
return nil return nil
} }
@ -46,6 +60,10 @@ func (e *ServiceConfigEntry) Validate() error {
} }
func (e *ServiceConfigEntry) GetRaftIndex() *RaftIndex { func (e *ServiceConfigEntry) GetRaftIndex() *RaftIndex {
if e == nil {
return &RaftIndex{}
}
return &e.RaftIndex return &e.RaftIndex
} }
@ -96,18 +114,40 @@ func (e *ProxyConfigEntry) GetKind() string {
} }
func (e *ProxyConfigEntry) GetName() string { func (e *ProxyConfigEntry) GetName() string {
if e == nil {
return ""
}
return e.Name return e.Name
} }
func (e *ProxyConfigEntry) Normalize() error { func (e *ProxyConfigEntry) Normalize() error {
if e == nil {
return fmt.Errorf("config entry is nil")
}
e.Kind = ProxyDefaults
return nil return nil
} }
func (e *ProxyConfigEntry) Validate() error { func (e *ProxyConfigEntry) Validate() error {
if e == nil {
return fmt.Errorf("config entry is nil")
}
if e.Name != ProxyConfigGlobal {
return fmt.Errorf("invalid name (%q), only %q is supported", e.Name, ProxyConfigGlobal)
}
return nil return nil
} }
func (e *ProxyConfigEntry) GetRaftIndex() *RaftIndex { func (e *ProxyConfigEntry) GetRaftIndex() *RaftIndex {
if e == nil {
return &RaftIndex{}
}
return &e.RaftIndex return &e.RaftIndex
} }