2018-09-04 21:08:00 +00:00
|
|
|
package zap
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"io"
|
|
|
|
|
2020-04-03 17:39:20 +00:00
|
|
|
"github.com/influxdata/influxdb/v2/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 {
|
2019-12-04 23:10:23 +00:00
|
|
|
log *zap.Logger
|
2018-09-04 21:08:00 +00:00
|
|
|
}
|
|
|
|
|
2019-12-04 23:10:23 +00:00
|
|
|
// NewProxyQueryService creates a new proxy query service with a log.
|
2018-09-04 21:08:00 +00:00
|
|
|
// If the logger is nil, then it will use a noop logger.
|
2019-12-04 23:10:23 +00:00
|
|
|
func NewProxyQueryService(log *zap.Logger) *ProxyQueryService {
|
2018-09-04 21:08:00 +00:00
|
|
|
return &ProxyQueryService{
|
2019-12-04 23:10:23 +00:00
|
|
|
log: log,
|
2018-09-04 21:08:00 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// 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 {
|
2019-12-04 23:10:23 +00:00
|
|
|
s.log.Info("Query", zap.Any("request", req))
|
2018-09-04 21:08:00 +00:00
|
|
|
}
|
|
|
|
n, err := w.Write([]byte{})
|
|
|
|
return int64(n), err
|
|
|
|
}
|