| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859 |
- package log
- import (
- "github.com/v2ray/v2ray-core/common/alloc"
- "github.com/v2ray/v2ray-core/common/serial"
- )
- // AccessStatus is the status of an access request from clients.
- type AccessStatus string
- const (
- AccessAccepted = AccessStatus("accepted")
- AccessRejected = AccessStatus("rejected")
- )
- var (
- accessLoggerInstance logWriter = &noOpLogWriter{}
- )
- type accessLog struct {
- From serial.String
- To serial.String
- Status AccessStatus
- Reason serial.String
- }
- func (this *accessLog) Release() {
- this.From = nil
- this.To = nil
- this.Reason = nil
- }
- func (this *accessLog) String() string {
- b := alloc.NewSmallBuffer().Clear()
- defer b.Release()
- return b.AppendString(this.From.String()).AppendString(" ").AppendString(string(this.Status)).AppendString(" ").AppendString(this.To.String()).AppendString(" ").AppendString(this.Reason.String()).String()
- }
- // InitAccessLogger initializes the access logger to write into the give file.
- func InitAccessLogger(file string) error {
- logger, err := newFileLogWriter(file)
- if err != nil {
- Error("Failed to create access logger on file (", file, "): ", file, err)
- return err
- }
- accessLoggerInstance = logger
- return nil
- }
- // Access writes an access log.
- func Access(from, to serial.String, status AccessStatus, reason serial.String) {
- accessLoggerInstance.Log(&accessLog{
- From: from,
- To: to,
- Status: status,
- Reason: reason,
- })
- }
|