2016-05-12 06:24:41 +00:00
|
|
|
package internal
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2016-07-15 19:15:41 +00:00
|
|
|
"strings"
|
2016-05-12 06:24:41 +00:00
|
|
|
|
|
|
|
"github.com/v2ray/v2ray-core/common"
|
2016-05-24 20:09:22 +00:00
|
|
|
"github.com/v2ray/v2ray-core/common/serial"
|
2016-05-12 06:24:41 +00:00
|
|
|
)
|
|
|
|
|
2016-05-24 20:41:51 +00:00
|
|
|
func InterfaceToString(value interface{}) string {
|
|
|
|
if value == nil {
|
|
|
|
return " "
|
|
|
|
}
|
|
|
|
switch value := value.(type) {
|
|
|
|
case string:
|
|
|
|
return value
|
|
|
|
case *string:
|
|
|
|
return *value
|
|
|
|
case fmt.Stringer:
|
|
|
|
return value.String()
|
|
|
|
case error:
|
|
|
|
return value.Error()
|
|
|
|
case []byte:
|
|
|
|
return serial.BytesToHexString(value)
|
|
|
|
default:
|
|
|
|
return fmt.Sprint(value)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-05-12 06:24:41 +00:00
|
|
|
type LogEntry interface {
|
|
|
|
common.Releasable
|
2016-05-24 19:55:46 +00:00
|
|
|
fmt.Stringer
|
2016-05-12 06:24:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
type ErrorLog struct {
|
|
|
|
Prefix string
|
|
|
|
Values []interface{}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (this *ErrorLog) Release() {
|
|
|
|
for index := range this.Values {
|
|
|
|
this.Values[index] = nil
|
|
|
|
}
|
|
|
|
this.Values = nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (this *ErrorLog) String() string {
|
2016-07-15 19:15:41 +00:00
|
|
|
values := make([]string, len(this.Values)+1)
|
|
|
|
values[0] = this.Prefix
|
|
|
|
for i, value := range this.Values {
|
|
|
|
values[i+1] = InterfaceToString(value)
|
2016-05-12 06:24:41 +00:00
|
|
|
}
|
2016-07-15 19:15:41 +00:00
|
|
|
return strings.Join(values, "")
|
2016-05-12 06:24:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
type AccessLog struct {
|
2016-05-24 20:41:51 +00:00
|
|
|
From interface{}
|
|
|
|
To interface{}
|
2016-05-12 06:24:41 +00:00
|
|
|
Status string
|
2016-05-24 20:41:51 +00:00
|
|
|
Reason interface{}
|
2016-05-12 06:24:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (this *AccessLog) Release() {
|
|
|
|
this.From = nil
|
|
|
|
this.To = nil
|
|
|
|
this.Reason = nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (this *AccessLog) String() string {
|
2016-07-15 19:15:41 +00:00
|
|
|
return strings.Join([]string{InterfaceToString(this.From), this.Status, InterfaceToString(this.To), InterfaceToString(this.Reason)}, " ")
|
2016-05-12 06:24:41 +00:00
|
|
|
}
|