You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
102 lines
2.6 KiB
102 lines
2.6 KiB
package config
|
|
|
|
import (
|
|
"encoding/json"
|
|
"os"
|
|
"time"
|
|
|
|
"gopkg.in/yaml.v3"
|
|
"repository.basistech.ru/BASIS/decort-golang-sdk/internal/validators"
|
|
)
|
|
|
|
// Configuration for creating request to platform
|
|
type Config struct {
|
|
// JWT platform token
|
|
// Required: false
|
|
// Example: "qwqwdfwv68979we0q9bfv7e9sbvd89798qrwv97ff"
|
|
Token string `json:"token" yaml:"token"`
|
|
|
|
// Application (client) identifier for authorization
|
|
// in the cloud platform controller in oauth2 mode.
|
|
// Required: true
|
|
// Example: "ewqfrvea7s890avw804389qwguf234h0otfi3w4eiu"
|
|
AppID string `json:"appId" yaml:"appId" validate:"required"`
|
|
|
|
// Application (client) secret code for authorization
|
|
// in the cloud platform controller in oauth2 mode.
|
|
// Example: "frvet09rvesfis0c9erv9fsov0vsdfi09ovds0f"
|
|
AppSecret string `json:"appSecret" yaml:"appSecret" validate:"required"`
|
|
|
|
// Platform authentication service address
|
|
// Required: true
|
|
// Example: "https://sso.digitalenergy.online"
|
|
SSOURL string `json:"ssoUrl" yaml:"ssoUrl" validate:"url"`
|
|
|
|
// The address of the platform on which the actions are planned
|
|
// Required: true
|
|
// Example: "https://mr4.digitalenergy.online"
|
|
DecortURL string `json:"decortUrl" yaml:"decortUrl" validate:"url"`
|
|
|
|
// Amount platform request attempts
|
|
// Default value: 5
|
|
// Required: false
|
|
Retries uint64 `json:"retries" yaml:"retries"`
|
|
|
|
// Skip verify
|
|
// Required: false
|
|
SSLSkipVerify bool `json:"sslSkipVerify" yaml:"sslSkipVerify"`
|
|
|
|
// HTTP client timeout, unlimited if left empty
|
|
// Required: false
|
|
Timeout Duration `json:"timeout" yaml:"timeout"`
|
|
}
|
|
|
|
// SetTimeout is used to set HTTP client timeout.
|
|
func (c *Config) SetTimeout(dur time.Duration) {
|
|
c.Timeout = Duration(dur)
|
|
}
|
|
|
|
// ParseConfigJSON parses Config from specified JSON-formatted file.
|
|
func ParseConfigJSON(path string) (Config, error) {
|
|
file, err := os.ReadFile(path)
|
|
if err != nil {
|
|
return Config{}, err
|
|
}
|
|
|
|
var config Config
|
|
|
|
err = json.Unmarshal(file, &config)
|
|
if err != nil {
|
|
return Config{}, err
|
|
}
|
|
|
|
err = validators.ValidateConfig(config)
|
|
if err != nil {
|
|
return Config{}, validators.ValidationErrors(validators.GetErrors(err))
|
|
}
|
|
|
|
return config, nil
|
|
}
|
|
|
|
// ParseConfigYAML parses Config from specified YAML-formatted file.
|
|
func ParseConfigYAML(path string) (Config, error) {
|
|
file, err := os.ReadFile(path)
|
|
if err != nil {
|
|
return Config{}, err
|
|
}
|
|
|
|
var config Config
|
|
|
|
err = yaml.Unmarshal(file, &config)
|
|
if err != nil {
|
|
return Config{}, err
|
|
}
|
|
|
|
err = validators.ValidateConfig(config)
|
|
if err != nil {
|
|
return Config{}, validators.ValidationErrors(validators.GetErrors(err))
|
|
}
|
|
|
|
return config, nil
|
|
}
|