mirror of
https://github.com/0rangebananaspy/authelia.git
synced 2024-09-14 22:47:21 +07:00
3c81e75d79
This adds an access-control command that checks the policy enforcement for a given criteria using a configuration file and refactors the configuration validation command to include all configuration sources.
37 lines
954 B
Go
37 lines
954 B
Go
package validator
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/authelia/authelia/v4/internal/configuration/schema"
|
|
"github.com/authelia/authelia/v4/internal/utils"
|
|
)
|
|
|
|
// ValidateNTP validates and update NTP configuration.
|
|
func ValidateNTP(config *schema.Configuration, validator *schema.StructValidator) {
|
|
if config.NTP == nil {
|
|
config.NTP = &schema.DefaultNTPConfiguration
|
|
|
|
return
|
|
}
|
|
|
|
if config.NTP.Address == "" {
|
|
config.NTP.Address = schema.DefaultNTPConfiguration.Address
|
|
}
|
|
|
|
if config.NTP.Version == 0 {
|
|
config.NTP.Version = schema.DefaultNTPConfiguration.Version
|
|
} else if config.NTP.Version < 3 || config.NTP.Version > 4 {
|
|
validator.Push(fmt.Errorf(errFmtNTPVersion, config.NTP.Version))
|
|
}
|
|
|
|
if config.NTP.MaximumDesync == "" {
|
|
config.NTP.MaximumDesync = schema.DefaultNTPConfiguration.MaximumDesync
|
|
}
|
|
|
|
_, err := utils.ParseDurationString(config.NTP.MaximumDesync)
|
|
if err != nil {
|
|
validator.Push(fmt.Errorf(errFmtNTPMaxDesync, err))
|
|
}
|
|
}
|