2018-08-01 11:52:03 +00:00
|
|
|
// Copyright (c) 2017 Uber Technologies, Inc.
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
2018-01-10 16:48:04 +00:00
|
|
|
//
|
2018-08-01 11:52:03 +00:00
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
2018-01-10 16:48:04 +00:00
|
|
|
//
|
2018-08-01 11:52:03 +00:00
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
2018-01-10 16:48:04 +00:00
|
|
|
|
|
|
|
package spanlog
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/json"
|
|
|
|
"fmt"
|
|
|
|
|
|
|
|
"github.com/opentracing/opentracing-go/log"
|
|
|
|
)
|
|
|
|
|
|
|
|
type fieldsAsMap map[string]string
|
|
|
|
|
|
|
|
// MaterializeWithJSON converts log Fields into JSON string
|
|
|
|
// TODO refactor into pluggable materializer
|
|
|
|
func MaterializeWithJSON(logFields []log.Field) ([]byte, error) {
|
|
|
|
fields := fieldsAsMap(make(map[string]string, len(logFields)))
|
|
|
|
for _, field := range logFields {
|
|
|
|
field.Marshal(fields)
|
|
|
|
}
|
|
|
|
if event, ok := fields["event"]; ok && len(fields) == 1 {
|
|
|
|
return []byte(event), nil
|
|
|
|
}
|
|
|
|
return json.Marshal(fields)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (ml fieldsAsMap) EmitString(key, value string) {
|
|
|
|
ml[key] = value
|
|
|
|
}
|
|
|
|
|
|
|
|
func (ml fieldsAsMap) EmitBool(key string, value bool) {
|
|
|
|
ml[key] = fmt.Sprintf("%t", value)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (ml fieldsAsMap) EmitInt(key string, value int) {
|
|
|
|
ml[key] = fmt.Sprintf("%d", value)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (ml fieldsAsMap) EmitInt32(key string, value int32) {
|
|
|
|
ml[key] = fmt.Sprintf("%d", value)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (ml fieldsAsMap) EmitInt64(key string, value int64) {
|
|
|
|
ml[key] = fmt.Sprintf("%d", value)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (ml fieldsAsMap) EmitUint32(key string, value uint32) {
|
|
|
|
ml[key] = fmt.Sprintf("%d", value)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (ml fieldsAsMap) EmitUint64(key string, value uint64) {
|
|
|
|
ml[key] = fmt.Sprintf("%d", value)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (ml fieldsAsMap) EmitFloat32(key string, value float32) {
|
|
|
|
ml[key] = fmt.Sprintf("%f", value)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (ml fieldsAsMap) EmitFloat64(key string, value float64) {
|
|
|
|
ml[key] = fmt.Sprintf("%f", value)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (ml fieldsAsMap) EmitObject(key string, value interface{}) {
|
|
|
|
ml[key] = fmt.Sprintf("%+v", value)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (ml fieldsAsMap) EmitLazyLogger(value log.LazyLogger) {
|
|
|
|
value(ml)
|
|
|
|
}
|