2019-11-13 11:19:04 -05:00
package elektronLogging
2019-11-20 13:33:46 -05:00
2019-11-13 11:19:04 -05:00
import (
2019-11-21 14:12:53 -05:00
log "github.com/sirupsen/logrus"
2019-11-20 13:33:46 -05:00
elekEnv "github.com/spdfg/elektron/environment"
"gopkg.in/yaml.v2"
"io/ioutil"
2019-11-13 11:19:04 -05:00
)
type LoggerConfig struct {
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 ( c * LoggerConfig ) GetConfig ( ) * LoggerConfig {
2019-11-20 13:33:46 -05:00
yamlFile , err := ioutil . ReadFile ( elekEnv . LogConfigYaml )
if err != nil {
2019-11-21 18:04:59 -05:00
log . Printf ( "Error in reading yaml file #%v " , err )
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-11-20 13:33:46 -05:00
return c
2019-11-13 11:19:04 -05:00
}