Documentation ¶
Index ¶
- Constants
- type AttributeField
- type BodyField
- func (f BodyField) Child(key string) BodyField
- func (f BodyField) Delete(entry *Entry) (interface{}, bool)
- func (f BodyField) Get(entry *Entry) (interface{}, bool)
- func (f BodyField) MarshalJSON() ([]byte, error)
- func (f BodyField) MarshalYAML() (interface{}, error)
- func (f BodyField) Merge(entry *Entry, mapValues map[string]interface{})
- func (f BodyField) Parent() BodyField
- func (f BodyField) Set(entry *Entry, value interface{}) error
- func (f BodyField) String() string
- func (f *BodyField) UnmarshalJSON(raw []byte) error
- func (f *BodyField) UnmarshalYAML(unmarshal func(interface{}) error) error
- type Entry
- func (entry *Entry) AddAttribute(key, value string)
- func (entry *Entry) AddResourceKey(key, value string)
- func (entry *Entry) Copy() *Entry
- func (entry *Entry) Delete(field FieldInterface) (interface{}, bool)
- func (entry *Entry) Get(field FieldInterface) (interface{}, bool)
- func (entry *Entry) Read(field FieldInterface, dest interface{}) error
- func (entry *Entry) Set(field FieldInterface, val interface{}) error
- type Field
- type FieldInterface
- type NilField
- type ResourceField
- type Severity
Constants ¶
const ( AttributesPrefix = "$attributes" ResourcePrefix = "$resource" BodyPrefix = "$body" )
const ( // Begin is the beginning state of a field split Begin splitState = iota // InBracket is the state of a field split inside a bracket InBracket // InQuote is the state of a field split inside a quote InQuote // OutQuote is the state of a field split outside a quote OutQuote // OutBracket is the state of a field split outside a bracket OutBracket // InUnbracketedToken is the state field split on any token outside brackets InUnbracketedToken )
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type AttributeField ¶ added in v0.16.0
type AttributeField struct {
// contains filtered or unexported fields
}
AttributeField is the path to an entry attribute
func (AttributeField) Delete ¶ added in v0.16.0
func (l AttributeField) Delete(entry *Entry) (interface{}, bool)
Delete will delete a attribute from an entry
func (AttributeField) Get ¶ added in v0.16.0
func (l AttributeField) Get(entry *Entry) (interface{}, bool)
Get will return the attribute value and a boolean indicating if it exists
func (AttributeField) Set ¶ added in v0.16.0
func (l AttributeField) Set(entry *Entry, val interface{}) error
Set will set the attribute value on an entry
func (AttributeField) String ¶ added in v0.16.0
func (l AttributeField) String() string
type BodyField ¶ added in v0.17.0
type BodyField struct {
Keys []string
}
BodyField is a field found on an entry body.
func (BodyField) Child ¶ added in v0.17.0
Child returns a child of the current field using the given key.
func (BodyField) Delete ¶ added in v0.17.0
Delete removes a value from an entry's body using the field. It will return the deleted value and whether the field existed.
func (BodyField) Get ¶ added in v0.17.0
Get will retrieve a value from an entry's body using the field. It will return the value and whether the field existed.
func (BodyField) MarshalJSON ¶ added in v0.17.0
MarshalJSON will marshal the field for JSON.
func (BodyField) MarshalYAML ¶ added in v0.17.0
MarshalYAML will marshal the field for YAML.
func (BodyField) Merge ¶ added in v0.17.0
Merge will attempt to merge the contents of a map into an entry's body. It will overwrite any intermediate values as necessary.
func (BodyField) Parent ¶ added in v0.17.0
Parent returns the parent of the current field. In the case that the body field points to the root node, it is a no-op.
func (BodyField) Set ¶ added in v0.17.0
Set will set a value on an entry's body using the field. If a key already exists, it will be overwritten. If mergeMaps is set to true, map values will be merged together.
func (*BodyField) UnmarshalJSON ¶ added in v0.17.0
UnmarshalJSON will attempt to unmarshal the field from JSON.
func (*BodyField) UnmarshalYAML ¶ added in v0.17.0
UnmarshalYAML will attempt to unmarshal a field from YAML.
type Entry ¶
type Entry struct { Timestamp time.Time `json:"timestamp" yaml:"timestamp"` Body interface{} `json:"body" yaml:"body"` Attributes map[string]string `json:"attributes,omitempty" yaml:"attributes,omitempty"` Resource map[string]string `json:"resource,omitempty" yaml:"resource,omitempty"` SeverityText string `json:"severity_text,omitempty" yaml:"severity_text,omitempty"` SpanId []byte `json:"span_id,omitempty" yaml:"span_id,omitempty"` TraceId []byte `json:"trace_id,omitempty" yaml:"trace_id,omitempty"` TraceFlags []byte `json:"trace_flags,omitempty" yaml:"trace_flags,omitempty"` Severity Severity `json:"severity" yaml:"severity"` }
Entry is a flexible representation of log data associated with a timestamp.
func New ¶
func New() *Entry
New will create a new log entry with current timestamp and an empty body.
func (*Entry) AddAttribute ¶ added in v0.16.0
AddAttribute will add a key/value pair to the entry's attributes.
func (*Entry) AddResourceKey ¶
AddResourceKey wil add a key/value pair to the entry's resource.
func (*Entry) Delete ¶
func (entry *Entry) Delete(field FieldInterface) (interface{}, bool)
Delete will delete a field from the entry.
func (*Entry) Get ¶
func (entry *Entry) Get(field FieldInterface) (interface{}, bool)
Get will return the value of a field on the entry, including a boolean indicating if the field exists.
func (*Entry) Read ¶
func (entry *Entry) Read(field FieldInterface, dest interface{}) error
Read will read the value of a field into a designated interface.
func (*Entry) Set ¶
func (entry *Entry) Set(field FieldInterface, val interface{}) error
Set will set the value of a field on the entry.
type Field ¶
type Field struct {
FieldInterface
}
Field represents a potential field on an entry. It is used to get, set, and delete values at this field. It is deserialized from JSON dot notation.
func NewAttributeField ¶ added in v0.16.0
NewAttributeField will creat a new attribute field from a key
func NewBodyField ¶ added in v0.17.0
NewBodyField creates a new field from an ordered array of keys.
func NewResourceField ¶
NewResourceField will creat a new resource field from a key
func (Field) MarshalJSON ¶
MarshalJSON will marshal a field into JSON
func (Field) MarshalYAML ¶
MarshalYAML will marshal a field into YAML
func (*Field) UnmarshalJSON ¶
UnmarshalJSON will unmarshal a field from JSON
func (*Field) UnmarshalYAML ¶
UnmarshalYAML will unmarshal a field from YAML
type FieldInterface ¶
type FieldInterface interface { Get(*Entry) (interface{}, bool) Set(entry *Entry, value interface{}) error Delete(entry *Entry) (interface{}, bool) String() string }
FieldInterface is a field on an entry.
type NilField ¶
type NilField struct{}
NilField is a struct that implements Field, but does nothing for all its operations. It is useful as a default no-op field to avoid nil checks.
type ResourceField ¶
type ResourceField struct {
// contains filtered or unexported fields
}
ResourceField is the path to an entry's resource key
func (ResourceField) Delete ¶
func (r ResourceField) Delete(entry *Entry) (interface{}, bool)
Delete will delete a resource key from an entry
func (ResourceField) Get ¶
func (r ResourceField) Get(entry *Entry) (interface{}, bool)
Get will return the resource value and a boolean indicating if it exists
func (ResourceField) Set ¶
func (r ResourceField) Set(entry *Entry, val interface{}) error
Set will set the resource value on an entry
func (ResourceField) String ¶
func (r ResourceField) String() string
type Severity ¶
type Severity int
Severity indicates the seriousness of a log entry
const ( // Default indicates an unknown severity Default Severity = 0 // Trace indicates that the log may be useful for detailed debugging Trace Severity = 10 // Trace2 indicates that the log may be useful for detailed debugging Trace2 Severity = 12 // Trace3 indicates that the log may be useful for detailed debugging Trace3 Severity = 13 // Trace4 indicates that the log may be useful for detailed debugging Trace4 Severity = 14 // Debug indicates that the log may be useful for debugging purposes Debug Severity = 20 // Debug2 indicates that the log may be useful for debugging purposes Debug2 Severity = 22 // Debug3 indicates that the log may be useful for debugging purposes Debug3 Severity = 23 // Debug4 indicates that the log may be useful for debugging purposes Debug4 Severity = 24 // Info indicates that the log may be useful for understanding high level details about an application Info Severity = 30 // Info2 indicates that the log may be useful for understanding high level details about an application Info2 Severity = 32 // Info3 indicates that the log may be useful for understanding high level details about an application Info3 Severity = 33 // Info4 indicates that the log may be useful for understanding high level details about an application Info4 Severity = 34 // Notice indicates that the log should be noticed Notice Severity = 40 // Warning indicates that someone should look into an issue Warning Severity = 50 // Warning2 indicates that someone should look into an issue Warning2 Severity = 52 // Warning3 indicates that someone should look into an issue Warning3 Severity = 53 // Warning4 indicates that someone should look into an issue Warning4 Severity = 54 // Error indicates that something undesirable has actually happened Error Severity = 60 // Error2 indicates that something undesirable has actually happened Error2 Severity = 62 // Error3 indicates that something undesirable has actually happened Error3 Severity = 63 // Error4 indicates that something undesirable has actually happened Error4 Severity = 64 // Critical indicates that a problem requires attention immediately Critical Severity = 70 // Alert indicates that action must be taken immediately Alert Severity = 80 // Emergency indicates that the application is unusable Emergency Severity = 90 // Emergency2 indicates that the application is unusable Emergency2 Severity = 92 // Emergency3 indicates that the application is unusable Emergency3 Severity = 93 // Emergency4 indicates that the application is unusable Emergency4 Severity = 94 // Catastrophe indicates that it is already too late Catastrophe Severity = 100 )