mirror of
https://github.com/prometheus/node_exporter.git
synced 2025-01-06 19:37:46 -08:00
33f99c4fc1
Uses godep to vendor dependencies. Godeps is not necessary during build, golang's new vendor support is used instead.
35 lines
1.1 KiB
Go
35 lines
1.1 KiB
Go
package logrus
|
|
|
|
// A hook to be fired when logging on the logging levels returned from
|
|
// `Levels()` on your implementation of the interface. Note that this is not
|
|
// fired in a goroutine or a channel with workers, you should handle such
|
|
// functionality yourself if your call is non-blocking and you don't wish for
|
|
// the logging calls for levels returned from `Levels()` to block.
|
|
type Hook interface {
|
|
Levels() []Level
|
|
Fire(*Entry) error
|
|
}
|
|
|
|
// Internal type for storing the hooks on a logger instance.
|
|
type LevelHooks map[Level][]Hook
|
|
|
|
// Add a hook to an instance of logger. This is called with
|
|
// `log.Hooks.Add(new(MyHook))` where `MyHook` implements the `Hook` interface.
|
|
func (hooks LevelHooks) Add(hook Hook) {
|
|
for _, level := range hook.Levels() {
|
|
hooks[level] = append(hooks[level], hook)
|
|
}
|
|
}
|
|
|
|
// Fire all the hooks for the passed level. Used by `entry.log` to fire
|
|
// appropriate hooks for a log entry.
|
|
func (hooks LevelHooks) Fire(level Level, entry *Entry) error {
|
|
for _, hook := range hooks[level] {
|
|
if err := hook.Fire(entry); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|