forked from open-telemetry/opentelemetry-collector-contrib
-
Notifications
You must be signed in to change notification settings - Fork 0
/
func_replace_pattern.go
62 lines (53 loc) · 1.84 KB
/
func_replace_pattern.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
// Copyright The OpenTelemetry Authors
// SPDX-License-Identifier: Apache-2.0
package ottlfuncs // import "github.com/open-telemetry/opentelemetry-collector-contrib/pkg/ottl/ottlfuncs"
import (
"context"
"fmt"
"regexp"
"github.com/open-telemetry/opentelemetry-collector-contrib/pkg/ottl"
)
type ReplacePatternArguments[K any] struct {
Target ottl.GetSetter[K]
RegexPattern string
Replacement ottl.StringGetter[K]
}
func NewReplacePatternFactory[K any]() ottl.Factory[K] {
return ottl.NewFactory("replace_pattern", &ReplacePatternArguments[K]{}, createReplacePatternFunction[K])
}
func createReplacePatternFunction[K any](_ ottl.FunctionContext, oArgs ottl.Arguments) (ottl.ExprFunc[K], error) {
args, ok := oArgs.(*ReplacePatternArguments[K])
if !ok {
return nil, fmt.Errorf("ReplacePatternFactory args must be of type *ReplacePatternArguments[K]")
}
return replacePattern(args.Target, args.RegexPattern, args.Replacement)
}
func replacePattern[K any](target ottl.GetSetter[K], regexPattern string, replacement ottl.StringGetter[K]) (ottl.ExprFunc[K], error) {
compiledPattern, err := regexp.Compile(regexPattern)
if err != nil {
return nil, fmt.Errorf("the regex pattern supplied to replace_pattern is not a valid pattern: %w", err)
}
return func(ctx context.Context, tCtx K) (interface{}, error) {
originalVal, err := target.Get(ctx, tCtx)
if err != nil {
return nil, err
}
replacementVal, err := replacement.Get(ctx, tCtx)
if err != nil {
return nil, err
}
if originalVal == nil {
return nil, nil
}
if originalValStr, ok := originalVal.(string); ok {
if compiledPattern.MatchString(originalValStr) {
updatedStr := compiledPattern.ReplaceAllString(originalValStr, replacementVal)
err = target.Set(ctx, tCtx, updatedStr)
if err != nil {
return nil, err
}
}
}
return nil, nil
}, nil
}