go_goutils/logging/consts_windows.go

57 lines
1.4 KiB
Go
Raw Normal View History

package logging
import (
`os`
`path/filepath`
`regexp`
2022-01-06 04:16:44 -05:00
`r00t2.io/goutils/bitmask`
)
2022-01-05 05:15:38 -05:00
// Flags for logger configuration. These are used internally.
const (
2022-01-05 05:15:38 -05:00
// LogUndefined indicates an undefined Logger type.
2022-01-06 04:16:44 -05:00
LogUndefined bitmask.MaskBit = 1 << iota
2022-01-05 05:15:38 -05:00
// LogWinLogger indicates a WinLogger Logger type (Event Log).
LogWinLogger
2022-01-05 05:15:38 -05:00
// LogFile flags a FileLogger Logger type.
LogFile
2022-01-05 05:15:38 -05:00
// LogStdout flags a StdLogger Logger type.
LogStdout
)
var (
2022-01-05 05:15:38 -05:00
// defLogPaths indicates default log paths.
defLogPaths = []string{
filepath.Join(os.Getenv("ALLUSERSPROFILE"), "golang", "program.log"), // C:\ProgramData\log\golang\program.log
filepath.Join(os.Getenv("LOCALAPPDATA"), "log", "golang", "program.log"), // C:\Users\<username>\AppData\Local\log\golang\program.log
}
)
2022-01-05 05:15:38 -05:00
// ptrnSourceExists is a regex pattern to check for a registry entry (Event Log entry) already existing.
var ptrnSourceExists *regexp.Regexp = regexp.MustCompile(`registry\skey\salready\sexists$`)
2022-01-05 05:15:38 -05:00
// Default WinEventID, (can be) used in GetLogger and MultiLogger.AddWinLogger.
var DefaultEventID *WinEventID = &WinEventID{
Alert: EventAlert,
Crit: EventCrit,
Debug: EventDebug,
Emerg: EventEmerg,
Err: EventErr,
Info: EventInfo,
Notice: EventNotice,
Warning: EventWarning,
}
// Default Event IDs for WinEventID.
const (
EventAlert uint32 = 1 << iota
EventCrit
EventDebug
EventEmerg
EventErr
EventInfo
EventNotice
EventWarning
)