lotus/node/modules/tracer/elasticsearch_transport.go

60 lines
1.3 KiB
Go
Raw Normal View History

2021-09-15 12:50:27 +00:00
package tracer
import (
"context"
"encoding/json"
"fmt"
"strings"
"github.com/elastic/go-elasticsearch/v7"
"github.com/elastic/go-elasticsearch/v7/esapi"
logging "github.com/ipfs/go-log/v2"
)
var rpclog = logging.Logger("elasticsearch")
2021-09-15 12:58:36 +00:00
func NewElasticSearchTransport() (TracerTransport, error) {
2021-09-15 12:50:27 +00:00
es, err := elasticsearch.NewDefaultClient()
if err != nil {
2021-09-15 12:58:36 +00:00
return nil, err
2021-09-15 12:50:27 +00:00
}
return &elasticSearchTransport{
cl: es,
2021-09-15 12:58:36 +00:00
}, nil
2021-09-15 12:50:27 +00:00
}
type elasticSearchTransport struct {
cl *elasticsearch.Client
}
func (est *elasticSearchTransport) Transport(jsonEvent []byte) error {
req := esapi.IndexRequest{
Index: "PeerScore",
DocumentID: "1", // todo
Body: strings.NewReader(string(jsonEvent)),
Refresh: "true",
}
// Perform the request with the client.
res, err := req.Do(context.Background(), est.cl)
if err != nil {
return err
}
defer res.Body.Close()
if res.IsError() {
return fmt.Errorf("[%s] Error indexing document ID=%s", res.Status(), req.DocumentID)
} else {
// Deserialize the response into a map.
var r map[string]interface{}
if err := json.NewDecoder(res.Body).Decode(&r); err != nil {
return err
} else {
rpclog.Infof("[%s] %s; version=%d", res.Status(), r["result"], int(r["_version"].(float64)))
}
}
return nil
}