This repository has been archived on 2024-04-10. You can view files and clone it, but you cannot make any changes to it's state, such as pushing and creating new issues, pull requests or comments.
elektron/logging/loggerConfig.go

84 lines
2.4 KiB
Go
Raw Normal View History

2019-12-09 20:05:28 -05:00
// Copyright (C) 2018 spdfg
//
// This file is part of Elektron.
//
// Elektron is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Elektron is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Elektron. If not, see <http://www.gnu.org/licenses/>.
//
2019-12-05 17:38:56 -05:00
package logging
2019-11-20 13:33:46 -05:00
2019-11-13 11:19:04 -05:00
import (
"github.com/pkg/errors"
log "github.com/sirupsen/logrus"
2019-11-20 13:33:46 -05:00
"gopkg.in/yaml.v2"
"io/ioutil"
2019-11-13 11:19:04 -05:00
)
2019-12-05 23:02:08 -05:00
type loggerConfig struct {
2019-11-13 11:19:04 -05:00
SchedTraceConfig struct {
2019-11-21 18:04:59 -05:00
Enabled bool `yaml:"enabled"`
FilenameExtension string `yaml:"filenameExtension"`
AllowOnConsole bool `yaml:"allowOnConsole"`
2019-11-13 11:19:04 -05:00
} `yaml:"schedTrace"`
PCPConfig struct {
2019-11-21 18:04:59 -05:00
Enabled bool `yaml:"enabled"`
FilenameExtension string `yaml:"filenameExtension"`
AllowOnConsole bool `yaml:"allowOnConsole"`
2019-11-13 11:19:04 -05:00
} `yaml:"pcp"`
ConsoleConfig struct {
2019-11-21 18:04:59 -05:00
Enabled bool `yaml:"enabled"`
FilenameExtension string `yaml:"filenameExtension"`
MinLogLevel string `yaml:"minLogLevel"`
AllowOnConsole bool `yaml:"allowOnConsole"`
2019-11-13 11:19:04 -05:00
} `yaml:"console"`
SPSConfig struct {
2019-11-21 18:04:59 -05:00
Enabled bool `yaml:"enabled"`
FilenameExtension string `yaml:"filenameExtension"`
AllowOnConsole bool `yaml:"allowOnConsole"`
2019-11-13 11:19:04 -05:00
} `yaml:"sps"`
2019-11-21 18:04:59 -05:00
TaskDistrConfig struct {
Enabled bool `yaml:"enabled"`
FilenameExtension string `yaml:"filenameExtension"`
AllowOnConsole bool `yaml:"allowOnConsole"`
} `yaml:"clsfnTaskDistrOverhead"`
2019-11-20 13:33:46 -05:00
2019-11-13 11:19:04 -05:00
SchedWindowConfig struct {
2019-11-21 18:04:59 -05:00
Enabled bool `yaml:"enabled"`
FilenameExtension string `yaml:"filenameExtension"`
AllowOnConsole bool `yaml:"allowOnConsole"`
2019-11-13 11:19:04 -05:00
} `yaml:"schedWindow"`
2019-11-20 13:33:46 -05:00
Format []string `yaml:"format"`
2019-11-13 11:19:04 -05:00
}
func getConfig(logConfigFilename string) (*loggerConfig, error) {
2019-11-13 11:19:04 -05:00
yamlFile, err := ioutil.ReadFile(logConfigFilename)
2019-11-20 13:33:46 -05:00
if err != nil {
return nil, errors.Wrap(err, "failed to read log config file")
2019-11-20 13:33:46 -05:00
}
2019-12-05 23:02:08 -05:00
c := &loggerConfig{}
2019-11-20 13:33:46 -05:00
err = yaml.Unmarshal(yamlFile, c)
if err != nil {
log.Fatalf("Error in unmarshalling yaml: %v", err)
2019-11-20 13:33:46 -05:00
}
2019-11-13 11:19:04 -05:00
return c, nil
2019-11-13 11:19:04 -05:00
}