mirror of
https://codeberg.org/forgejo/forgejo
synced 2024-11-30 22:06:11 +01:00
49 lines
1.2 KiB
Go
49 lines
1.2 KiB
Go
|
// Copyright 2023 The Gitea Authors. All rights reserved.
|
||
|
// SPDX-License-Identifier: MIT
|
||
|
|
||
|
package log
|
||
|
|
||
|
import (
|
||
|
"code.gitea.io/gitea/modules/util/rotatingfilewriter"
|
||
|
)
|
||
|
|
||
|
type WriterFileOption struct {
|
||
|
FileName string
|
||
|
MaxSize int64
|
||
|
LogRotate bool
|
||
|
DailyRotate bool
|
||
|
MaxDays int
|
||
|
Compress bool
|
||
|
CompressionLevel int
|
||
|
}
|
||
|
|
||
|
type eventWriterFile struct {
|
||
|
*EventWriterBaseImpl
|
||
|
fileWriter *rotatingfilewriter.RotatingFileWriter
|
||
|
}
|
||
|
|
||
|
var _ EventWriter = (*eventWriterFile)(nil)
|
||
|
|
||
|
func NewEventWriterFile(name string, mode WriterMode) EventWriter {
|
||
|
w := &eventWriterFile{EventWriterBaseImpl: NewEventWriterBase(name, "file", mode)}
|
||
|
opt := mode.WriterOption.(WriterFileOption)
|
||
|
var err error
|
||
|
w.fileWriter, err = rotatingfilewriter.Open(opt.FileName, &rotatingfilewriter.Options{
|
||
|
Rotate: opt.LogRotate,
|
||
|
MaximumSize: opt.MaxSize,
|
||
|
RotateDaily: opt.DailyRotate,
|
||
|
KeepDays: opt.MaxDays,
|
||
|
Compress: opt.Compress,
|
||
|
CompressionLevel: opt.CompressionLevel,
|
||
|
})
|
||
|
if err != nil {
|
||
|
FallbackErrorf("unable to open log file %q: %v", opt.FileName, err)
|
||
|
}
|
||
|
w.OutputWriteCloser = w.fileWriter
|
||
|
return w
|
||
|
}
|
||
|
|
||
|
func init() {
|
||
|
RegisterEventWriter("file", NewEventWriterFile)
|
||
|
}
|