2018-09-04 21:08:00 +00:00
|
|
|
package zap
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"io"
|
|
|
|
|
2019-01-08 00:37:16 +00:00
|
|
|
"github.com/influxdata/influxdb/query"
|
2018-09-04 21:08:00 +00:00
|
|
|
"go.uber.org/zap"
|
|
|
|
)
|
|
|
|
|
|
|
|
// ProxyQueryService logs the request but does not write to the writer.
|
|
|
|
type ProxyQueryService struct {
|
|
|
|
Logger *zap.Logger
|
|
|
|
}
|
|
|
|
|
|
|
|
// NewProxyQueryService creates a new proxy query service with a logger.
|
|
|
|
// If the logger is nil, then it will use a noop logger.
|
|
|
|
func NewProxyQueryService(l *zap.Logger) *ProxyQueryService {
|
|
|
|
if l == nil {
|
|
|
|
l = zap.NewNop()
|
|
|
|
}
|
|
|
|
return &ProxyQueryService{
|
|
|
|
Logger: l,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Query logs the query request.
|
2018-09-11 22:56:51 +00:00
|
|
|
func (s *ProxyQueryService) Query(ctx context.Context, w io.Writer, req *query.ProxyRequest) (int64, error) {
|
2018-09-04 21:08:00 +00:00
|
|
|
if req != nil {
|
|
|
|
s.Logger.Info("query", zap.Any("request", req))
|
|
|
|
}
|
|
|
|
n, err := w.Write([]byte{})
|
|
|
|
return int64(n), err
|
|
|
|
}
|