go-ethereum/ethutil/config.go

134 lines
2.2 KiB
Go
Raw Normal View History

2014-02-14 22:56:09 +00:00
package ethutil
import (
"log"
"os"
"os/user"
"path"
)
type LogType byte
const (
LogTypeStdIn = 1
LogTypeFile = 2
)
// Config struct isn't exposed
type config struct {
Db Database
Log Logger
ExecPath string
Debug bool
Ver string
Pubkey []byte
Seed bool
}
var Config *config
// Read config doesn't read anything yet.
func ReadConfig(base string) *config {
if Config == nil {
usr, _ := user.Current()
path := path.Join(usr.HomeDir, base)
2014-02-19 10:35:17 +00:00
if len(base) > 0 {
//Check if the logging directory already exists, create it if not
_, err := os.Stat(path)
if err != nil {
if os.IsNotExist(err) {
log.Printf("Debug logging directory %s doesn't exist, creating it\n", path)
2014-02-19 10:35:17 +00:00
os.Mkdir(path, 0777)
}
2014-02-14 22:56:09 +00:00
}
}
2014-02-18 11:10:21 +00:00
Config = &config{ExecPath: path, Debug: true, Ver: "0.2.3"}
2014-02-19 15:27:22 +00:00
Config.Log = NewLogger(LogFile|LogStd, LogLevelDebug)
2014-02-14 22:56:09 +00:00
}
return Config
}
type LoggerType byte
const (
LogFile = 0x1
LogStd = 0x2
)
type Logger struct {
logSys []*log.Logger
logLevel int
}
func NewLogger(flag LoggerType, level int) Logger {
var loggers []*log.Logger
2014-02-19 15:27:22 +00:00
flags := log.LstdFlags
2014-02-14 22:56:09 +00:00
if flag&LogFile > 0 {
file, err := os.OpenFile(path.Join(Config.ExecPath, "debug.log"), os.O_RDWR|os.O_CREATE|os.O_APPEND, os.ModePerm)
if err != nil {
log.Panic("unable to create file logger", err)
}
2014-02-19 15:27:22 +00:00
log := log.New(file, "", flags)
2014-02-14 22:56:09 +00:00
loggers = append(loggers, log)
}
if flag&LogStd > 0 {
2014-02-19 15:27:22 +00:00
log := log.New(os.Stdout, "", flags)
2014-02-14 22:56:09 +00:00
loggers = append(loggers, log)
}
return Logger{logSys: loggers, logLevel: level}
}
2014-02-19 15:27:22 +00:00
const (
LogLevelDebug = iota
LogLevelInfo
)
2014-02-14 22:56:09 +00:00
func (log Logger) Debugln(v ...interface{}) {
2014-02-19 15:27:22 +00:00
if log.logLevel != LogLevelDebug {
2014-02-14 22:56:09 +00:00
return
}
for _, logger := range log.logSys {
logger.Println(v...)
}
}
func (log Logger) Debugf(format string, v ...interface{}) {
2014-02-19 15:27:22 +00:00
if log.logLevel != LogLevelDebug {
return
}
for _, logger := range log.logSys {
logger.Printf(format, v...)
}
}
func (log Logger) Infoln(v ...interface{}) {
if log.logLevel > LogLevelInfo {
return
}
for _, logger := range log.logSys {
logger.Println(v...)
}
}
func (log Logger) Infof(format string, v ...interface{}) {
if log.logLevel > LogLevelInfo {
2014-02-14 22:56:09 +00:00
return
}
for _, logger := range log.logSys {
logger.Printf(format, v...)
}
}