mirror of
https://github.com/mattermost/mattermost.git
synced 2026-02-03 20:40:00 -05:00
It was a good decision in hindsight to keep the public module as 0.x because this would have been a breaking change again. https://mattermost.atlassian.net/browse/MM-53032 ```release-note Changed the Go module path from github.com/mattermost/mattermost-server/server/v8 to github.com/mattermost/mattermost/server/v8. For the public facing module, it's path is also changed from github.com/mattermost/mattermost-server/server/public to github.com/mattermost/mattermost/server/public ```
135 lines
2.9 KiB
Go
135 lines
2.9 KiB
Go
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See LICENSE.txt for license information.
|
|
|
|
package plugin
|
|
|
|
import (
|
|
"fmt"
|
|
"io"
|
|
"log"
|
|
"strings"
|
|
|
|
"github.com/hashicorp/go-hclog"
|
|
|
|
"github.com/mattermost/mattermost/server/public/shared/mlog"
|
|
)
|
|
|
|
type hclogAdapter struct {
|
|
wrappedLogger *mlog.Logger
|
|
extrasKey string
|
|
}
|
|
|
|
func (h *hclogAdapter) Log(level hclog.Level, msg string, args ...any) {
|
|
switch level {
|
|
case hclog.Trace:
|
|
h.Trace(msg, args...)
|
|
case hclog.Debug:
|
|
h.Debug(msg, args...)
|
|
case hclog.Info:
|
|
h.Info(msg, args...)
|
|
case hclog.Warn:
|
|
h.Warn(msg, args...)
|
|
case hclog.Error:
|
|
h.Error(msg, args...)
|
|
default:
|
|
// For unknown/unexpected log level, treat it as an error so we notice and fix the code.
|
|
h.Error(msg, args...)
|
|
}
|
|
}
|
|
|
|
func (h *hclogAdapter) Trace(msg string, args ...any) {
|
|
extras := strings.TrimSpace(fmt.Sprint(args...))
|
|
if extras != "" {
|
|
h.wrappedLogger.Debug(msg, mlog.String(h.extrasKey, extras))
|
|
} else {
|
|
h.wrappedLogger.Debug(msg)
|
|
}
|
|
}
|
|
|
|
func (h *hclogAdapter) Debug(msg string, args ...any) {
|
|
extras := strings.TrimSpace(fmt.Sprint(args...))
|
|
if extras != "" {
|
|
h.wrappedLogger.Debug(msg, mlog.String(h.extrasKey, extras))
|
|
} else {
|
|
h.wrappedLogger.Debug(msg)
|
|
}
|
|
}
|
|
|
|
func (h *hclogAdapter) Info(msg string, args ...any) {
|
|
extras := strings.TrimSpace(fmt.Sprint(args...))
|
|
if extras != "" {
|
|
h.wrappedLogger.Info(msg, mlog.String(h.extrasKey, extras))
|
|
} else {
|
|
h.wrappedLogger.Info(msg)
|
|
}
|
|
}
|
|
|
|
func (h *hclogAdapter) Warn(msg string, args ...any) {
|
|
extras := strings.TrimSpace(fmt.Sprint(args...))
|
|
if extras != "" {
|
|
h.wrappedLogger.Warn(msg, mlog.String(h.extrasKey, extras))
|
|
} else {
|
|
h.wrappedLogger.Warn(msg)
|
|
}
|
|
}
|
|
|
|
func (h *hclogAdapter) Error(msg string, args ...any) {
|
|
extras := strings.TrimSpace(fmt.Sprint(args...))
|
|
if extras != "" {
|
|
h.wrappedLogger.Error(msg, mlog.String(h.extrasKey, extras))
|
|
} else {
|
|
h.wrappedLogger.Error(msg)
|
|
}
|
|
}
|
|
|
|
func (h *hclogAdapter) IsTrace() bool {
|
|
return false
|
|
}
|
|
|
|
func (h *hclogAdapter) IsDebug() bool {
|
|
return true
|
|
}
|
|
|
|
func (h *hclogAdapter) IsInfo() bool {
|
|
return true
|
|
}
|
|
|
|
func (h *hclogAdapter) IsWarn() bool {
|
|
return true
|
|
}
|
|
|
|
func (h *hclogAdapter) IsError() bool {
|
|
return true
|
|
}
|
|
|
|
func (h *hclogAdapter) With(args ...any) hclog.Logger {
|
|
return h
|
|
}
|
|
|
|
func (h *hclogAdapter) Named(name string) hclog.Logger {
|
|
return h
|
|
}
|
|
|
|
func (h *hclogAdapter) ResetNamed(name string) hclog.Logger {
|
|
return h
|
|
}
|
|
|
|
func (h *hclogAdapter) StandardLogger(opts *hclog.StandardLoggerOptions) *log.Logger {
|
|
return h.wrappedLogger.StdLogger(mlog.LvlInfo)
|
|
}
|
|
|
|
func (h *hclogAdapter) StandardWriter(opts *hclog.StandardLoggerOptions) io.Writer {
|
|
return h.wrappedLogger.StdLogWriter()
|
|
}
|
|
|
|
func (h *hclogAdapter) SetLevel(hclog.Level) {}
|
|
|
|
func (h *hclogAdapter) GetLevel() hclog.Level { return hclog.NoLevel }
|
|
|
|
func (h *hclogAdapter) ImpliedArgs() []any {
|
|
return []any{}
|
|
}
|
|
|
|
func (h *hclogAdapter) Name() string {
|
|
return "MattermostPluginLogger"
|
|
}
|