traefik/pkg/server/middleware/plugins.go

61 lines
1.5 KiB
Go
Raw Normal View History

2020-04-20 18:36:34 +02:00
package middleware
import (
"context"
2020-04-20 18:36:34 +02:00
"errors"
"net/http"
2020-04-20 18:36:34 +02:00
2023-02-03 15:24:05 +01:00
"github.com/traefik/traefik/v3/pkg/config/dynamic"
"github.com/traefik/traefik/v3/pkg/plugins"
2024-01-08 10:10:06 +02:00
"go.opentelemetry.io/otel/trace"
2020-04-20 18:36:34 +02:00
)
2024-01-08 10:10:06 +02:00
const typeName = "Plugin"
2020-09-07 13:58:03 +02:00
// PluginsBuilder the plugin's builder interface.
type PluginsBuilder interface {
Build(pName string, config map[string]interface{}, middlewareName string) (plugins.Constructor, error)
}
2020-04-20 18:36:34 +02:00
func findPluginConfig(rawConfig map[string]dynamic.PluginConf) (string, map[string]interface{}, error) {
if len(rawConfig) != 1 {
return "", nil, errors.New("invalid configuration: no configuration or too many plugin definition")
2020-04-20 18:36:34 +02:00
}
var pluginType string
var rawPluginConfig map[string]interface{}
for pType, pConfig := range rawConfig {
pluginType = pType
rawPluginConfig = pConfig
}
if pluginType == "" {
return "", nil, errors.New("missing plugin type")
2020-04-20 18:36:34 +02:00
}
return pluginType, rawPluginConfig, nil
}
type traceablePlugin struct {
name string
h http.Handler
}
func newTraceablePlugin(ctx context.Context, name string, plug plugins.Constructor, next http.Handler) (*traceablePlugin, error) {
h, err := plug(ctx, next)
if err != nil {
return nil, err
}
return &traceablePlugin{name: name, h: h}, nil
}
func (s *traceablePlugin) ServeHTTP(rw http.ResponseWriter, req *http.Request) {
s.h.ServeHTTP(rw, req)
}
2024-01-08 10:10:06 +02:00
func (s *traceablePlugin) GetTracingInformation() (string, string, trace.SpanKind) {
return s.name, typeName, trace.SpanKindInternal
}