2020-07-14 15:50:14 +00:00
|
|
|
/*
|
2020-09-16 14:05:51 +00:00
|
|
|
Copyright 2020 the Pinniped contributors. All Rights Reserved.
|
2020-07-14 15:50:14 +00:00
|
|
|
SPDX-License-Identifier: Apache-2.0
|
|
|
|
*/
|
|
|
|
|
|
|
|
// Package config contains functionality to load/store api.Config's from/to
|
|
|
|
// some source.
|
|
|
|
package config
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"io/ioutil"
|
|
|
|
|
|
|
|
"sigs.k8s.io/yaml"
|
|
|
|
|
2020-08-20 19:17:18 +00:00
|
|
|
"github.com/suzerain-io/pinniped/internal/constable"
|
2020-08-20 17:54:15 +00:00
|
|
|
"github.com/suzerain-io/pinniped/pkg/config/api"
|
2020-07-14 15:50:14 +00:00
|
|
|
)
|
|
|
|
|
2020-08-20 19:17:18 +00:00
|
|
|
const (
|
|
|
|
aboutAYear = 60 * 60 * 24 * 365
|
|
|
|
about9Months = 60 * 60 * 24 * 30 * 9
|
|
|
|
)
|
|
|
|
|
|
|
|
// FromPath loads an api.Config from a provided local file path, inserts any
|
|
|
|
// defaults (from the api.Config documentation), and verifies that the config is
|
|
|
|
// valid (per the api.Config documentation).
|
2020-07-14 15:50:14 +00:00
|
|
|
//
|
|
|
|
// Note! The api.Config file should contain base64-encoded WebhookCABundle data.
|
|
|
|
// This function will decode that base64-encoded data to PEM bytes to be stored
|
|
|
|
// in the api.Config.
|
|
|
|
func FromPath(path string) (*api.Config, error) {
|
|
|
|
data, err := ioutil.ReadFile(path)
|
|
|
|
if err != nil {
|
|
|
|
return nil, fmt.Errorf("read file: %w", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
var config api.Config
|
|
|
|
if err := yaml.Unmarshal(data, &config); err != nil {
|
|
|
|
return nil, fmt.Errorf("decode yaml: %w", err)
|
|
|
|
}
|
|
|
|
|
2020-08-20 19:17:18 +00:00
|
|
|
maybeSetAPIDefaults(&config.APIConfig)
|
|
|
|
|
|
|
|
if err := validateAPI(&config.APIConfig); err != nil {
|
|
|
|
return nil, fmt.Errorf("validate api: %w", err)
|
|
|
|
}
|
|
|
|
|
2020-07-14 15:50:14 +00:00
|
|
|
return &config, nil
|
|
|
|
}
|
2020-08-20 19:17:18 +00:00
|
|
|
|
|
|
|
func maybeSetAPIDefaults(apiConfig *api.APIConfigSpec) {
|
|
|
|
if apiConfig.ServingCertificateConfig.DurationSeconds == nil {
|
|
|
|
apiConfig.ServingCertificateConfig.DurationSeconds = int64Ptr(aboutAYear)
|
|
|
|
}
|
|
|
|
|
|
|
|
if apiConfig.ServingCertificateConfig.RenewBeforeSeconds == nil {
|
|
|
|
apiConfig.ServingCertificateConfig.RenewBeforeSeconds = int64Ptr(about9Months)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func validateAPI(apiConfig *api.APIConfigSpec) error {
|
|
|
|
if *apiConfig.ServingCertificateConfig.DurationSeconds < *apiConfig.ServingCertificateConfig.RenewBeforeSeconds {
|
|
|
|
return constable.Error("durationSeconds cannot be smaller than renewBeforeSeconds")
|
|
|
|
}
|
|
|
|
|
2020-08-20 22:14:07 +00:00
|
|
|
if *apiConfig.ServingCertificateConfig.RenewBeforeSeconds <= 0 {
|
|
|
|
return constable.Error("renewBefore must be positive")
|
|
|
|
}
|
|
|
|
|
2020-08-20 19:17:18 +00:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func int64Ptr(i int64) *int64 {
|
|
|
|
return &i
|
|
|
|
}
|