2023-04-22 12:39:27 +00:00
|
|
|
|
package common
|
|
|
|
|
|
|
|
|
|
import (
|
2023-09-17 07:39:46 +00:00
|
|
|
|
"context"
|
2023-04-22 12:39:27 +00:00
|
|
|
|
"fmt"
|
|
|
|
|
"github.com/gin-gonic/gin"
|
|
|
|
|
"io"
|
|
|
|
|
"log"
|
|
|
|
|
"os"
|
|
|
|
|
"path/filepath"
|
2023-09-17 08:35:30 +00:00
|
|
|
|
"sync"
|
2023-04-22 12:39:27 +00:00
|
|
|
|
"time"
|
|
|
|
|
)
|
|
|
|
|
|
2023-09-17 07:39:46 +00:00
|
|
|
|
const (
|
|
|
|
|
loggerINFO = "INFO"
|
|
|
|
|
loggerWarn = "WARN"
|
|
|
|
|
loggerError = "ERR"
|
|
|
|
|
)
|
|
|
|
|
|
2023-09-17 08:35:30 +00:00
|
|
|
|
const maxLogCount = 1000000
|
|
|
|
|
|
|
|
|
|
var logCount int
|
|
|
|
|
var setupLogLock sync.Mutex
|
|
|
|
|
var setupLogWorking bool
|
|
|
|
|
|
|
|
|
|
func SetupLogger() {
|
2023-04-22 12:39:27 +00:00
|
|
|
|
if *LogDir != "" {
|
2023-09-17 08:35:30 +00:00
|
|
|
|
ok := setupLogLock.TryLock()
|
|
|
|
|
if !ok {
|
|
|
|
|
log.Println("setup log is already working")
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
defer func() {
|
|
|
|
|
setupLogLock.Unlock()
|
|
|
|
|
setupLogWorking = false
|
|
|
|
|
}()
|
|
|
|
|
logPath := filepath.Join(*LogDir, fmt.Sprintf("oneapi-%s.log", time.Now().Format("20060102")))
|
2023-09-17 07:39:46 +00:00
|
|
|
|
fd, err := os.OpenFile(logPath, os.O_APPEND|os.O_CREATE|os.O_WRONLY, 0644)
|
2023-04-22 12:39:27 +00:00
|
|
|
|
if err != nil {
|
|
|
|
|
log.Fatal("failed to open log file")
|
|
|
|
|
}
|
2023-09-17 07:39:46 +00:00
|
|
|
|
gin.DefaultWriter = io.MultiWriter(os.Stdout, fd)
|
|
|
|
|
gin.DefaultErrorWriter = io.MultiWriter(os.Stderr, fd)
|
2023-04-22 12:39:27 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func SysLog(s string) {
|
|
|
|
|
t := time.Now()
|
|
|
|
|
_, _ = fmt.Fprintf(gin.DefaultWriter, "[SYS] %v | %s \n", t.Format("2006/01/02 - 15:04:05"), s)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func SysError(s string) {
|
|
|
|
|
t := time.Now()
|
|
|
|
|
_, _ = fmt.Fprintf(gin.DefaultErrorWriter, "[SYS] %v | %s \n", t.Format("2006/01/02 - 15:04:05"), s)
|
|
|
|
|
}
|
|
|
|
|
|
2023-09-17 07:39:46 +00:00
|
|
|
|
func LogInfo(ctx context.Context, msg string) {
|
|
|
|
|
logHelper(ctx, loggerINFO, msg)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func LogWarn(ctx context.Context, msg string) {
|
|
|
|
|
logHelper(ctx, loggerWarn, msg)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func LogError(ctx context.Context, msg string) {
|
|
|
|
|
logHelper(ctx, loggerError, msg)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func logHelper(ctx context.Context, level string, msg string) {
|
|
|
|
|
writer := gin.DefaultErrorWriter
|
|
|
|
|
if level == loggerINFO {
|
|
|
|
|
writer = gin.DefaultWriter
|
|
|
|
|
}
|
|
|
|
|
id := ctx.Value(RequestIdKey)
|
|
|
|
|
now := time.Now()
|
|
|
|
|
_, _ = fmt.Fprintf(writer, "[%s] %v | %s | %s \n", level, now.Format("2006/01/02 - 15:04:05"), id, msg)
|
2023-09-17 08:35:30 +00:00
|
|
|
|
logCount++ // we don't need accurate count, so no lock here
|
|
|
|
|
if logCount > maxLogCount && !setupLogWorking {
|
|
|
|
|
logCount = 0
|
|
|
|
|
setupLogWorking = true
|
|
|
|
|
go func() {
|
|
|
|
|
SetupLogger()
|
|
|
|
|
}()
|
|
|
|
|
}
|
2023-09-17 07:39:46 +00:00
|
|
|
|
}
|
|
|
|
|
|
2023-04-22 12:39:27 +00:00
|
|
|
|
func FatalLog(v ...any) {
|
|
|
|
|
t := time.Now()
|
|
|
|
|
_, _ = fmt.Fprintf(gin.DefaultErrorWriter, "[FATAL] %v | %v \n", t.Format("2006/01/02 - 15:04:05"), v)
|
|
|
|
|
os.Exit(1)
|
|
|
|
|
}
|
2023-06-20 12:09:17 +00:00
|
|
|
|
|
|
|
|
|
func LogQuota(quota int) string {
|
|
|
|
|
if DisplayInCurrencyEnabled {
|
|
|
|
|
return fmt.Sprintf("$%.6f 额度", float64(quota)/QuotaPerUnit)
|
|
|
|
|
} else {
|
|
|
|
|
return fmt.Sprintf("%d 点额度", quota)
|
|
|
|
|
}
|
|
|
|
|
}
|