plugins/segmentio-kafka/instrument.go (49 lines of code) (raw):
// Licensed to Apache Software Foundation (ASF) under one or more contributor
// license agreements. See the NOTICE file distributed with
// this work for additional information regarding copyright
// ownership. Apache Software Foundation (ASF) licenses this file to you under
// the Apache License, Version 2.0 (the "License"); you may
// not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing,
// software distributed under the License is distributed on an
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
// KIND, either express or implied. See the License for the
// specific language governing permissions and limitations
// under the License.
package segmentiokafka
import (
"embed"
"github.com/apache/skywalking-go/plugins/core/instrument"
)
//go:embed *
var fs embed.FS
//skywalking:nocopy
type Instrument struct {
}
func NewInstrument() *Instrument {
return &Instrument{}
}
func (i *Instrument) Name() string {
return "segmentio_kafka"
}
func (i *Instrument) BasePackage() string {
return "github.com/segmentio/kafka-go"
}
func (i *Instrument) VersionChecker(version string) bool {
return true
}
func (i *Instrument) Points() []*instrument.Point {
return []*instrument.Point{
{
PackageName: "kafka",
At: instrument.NewMethodEnhance("*Writer", "WriteMessages",
instrument.WithArgsCount(2),
instrument.WithArgType(0, "context.Context"),
instrument.WithArgType(1, "...Message"),
instrument.WithResultCount(1),
instrument.WithResultType(0, "error"),
),
Interceptor: "WriterInterceptor",
},
{
PackageName: "kafka",
At: instrument.NewMethodEnhance("*Reader", "ReadMessage",
instrument.WithArgsCount(1),
instrument.WithArgType(0, "context.Context"),
instrument.WithResultCount(2),
instrument.WithResultType(0, "Message"),
instrument.WithResultType(1, "error"),
),
Interceptor: "ReaderInterceptor",
},
}
}
func (i *Instrument) FS() *embed.FS {
return &fs
}