2018-09-11 22:56:51 +00:00
|
|
|
package query
|
|
|
|
|
|
|
|
import (
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/influxdata/flux"
|
2019-01-08 00:37:16 +00:00
|
|
|
platform "github.com/influxdata/influxdb"
|
2018-09-11 22:56:51 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// Logger persists metadata about executed queries.
|
|
|
|
type Logger interface {
|
|
|
|
Log(Log) error
|
|
|
|
}
|
|
|
|
|
|
|
|
// Log captures a query and any relevant metadata for the query execution.
|
|
|
|
type Log struct {
|
|
|
|
// Time is the time the query was completed
|
|
|
|
Time time.Time
|
|
|
|
// OrganizationID is the ID of the organization that requested the query
|
|
|
|
OrganizationID platform.ID
|
|
|
|
// Error is any error encountered by the query
|
|
|
|
Error error
|
|
|
|
|
|
|
|
// ProxyRequest is the query request
|
|
|
|
ProxyRequest *ProxyRequest
|
|
|
|
// ResponseSize is the size in bytes of the query response
|
|
|
|
ResponseSize int64
|
|
|
|
// Statistics is a set of statistics about the query execution
|
|
|
|
Statistics flux.Statistics
|
|
|
|
}
|
|
|
|
|
|
|
|
// Redact removes any sensitive information before logging
|
|
|
|
func (q *Log) Redact() {
|
2018-11-20 23:20:51 +00:00
|
|
|
if q.ProxyRequest != nil && q.ProxyRequest.Request.Authorization != nil {
|
2018-09-11 22:56:51 +00:00
|
|
|
// Make shallow copy of request
|
|
|
|
request := new(ProxyRequest)
|
|
|
|
*request = *q.ProxyRequest
|
|
|
|
|
2018-11-20 23:20:51 +00:00
|
|
|
// Make shallow copy of authorization
|
|
|
|
auth := new(platform.Authorization)
|
|
|
|
*auth = *q.ProxyRequest.Request.Authorization
|
|
|
|
// Redact authorization token
|
|
|
|
auth.Token = ""
|
|
|
|
|
|
|
|
// Apply redacted authorization
|
|
|
|
request.Request.Authorization = auth
|
2018-09-11 22:56:51 +00:00
|
|
|
|
|
|
|
// Apply redacted request
|
|
|
|
q.ProxyRequest = request
|
|
|
|
}
|
|
|
|
}
|