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 (
2019-12-05 21:32:37 -05:00
"github.com/pkg/errors"
2019-11-21 14:12:53 -05:00
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
}
2019-12-09 11:03:40 -05:00
func getConfig ( logConfigFilename string ) ( * loggerConfig , error ) {
2019-11-13 11:19:04 -05:00
2019-11-26 13:08:45 -05:00
yamlFile , err := ioutil . ReadFile ( logConfigFilename )
2019-11-20 13:33:46 -05:00
if err != nil {
2019-12-05 21:32:37 -05:00
return nil , errors . Wrap ( err , "failed to read log config file" )
2019-11-20 13:33:46 -05:00
}
2019-12-05 21:32:37 -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 {
2019-11-26 12:48:48 -05:00
log . Fatalf ( "Error in unmarshalling yaml: %v" , err )
2019-11-20 13:33:46 -05:00
}
2019-11-13 11:19:04 -05:00
2019-12-05 21:32:37 -05:00
return c , nil
2019-11-13 11:19:04 -05:00
}