(lookups string, limit uint)
| 76 | } |
| 77 | |
| 78 | func createExtractors(lookups string, limit uint) ([]ValuesExtractor, error) { |
| 79 | if lookups == "" { |
| 80 | return nil, nil |
| 81 | } |
| 82 | if limit == 0 { |
| 83 | limit = 1 |
| 84 | } else if limit > extractorLimit { |
| 85 | limit = extractorLimit |
| 86 | } |
| 87 | |
| 88 | sources := strings.SplitSeq(lookups, ",") |
| 89 | var extractors = make([]ValuesExtractor, 0) |
| 90 | for source := range sources { |
| 91 | parts := strings.Split(source, ":") |
| 92 | if len(parts) < 2 { |
| 93 | return nil, fmt.Errorf("extractor source for lookup could not be split into needed parts: %v", source) |
| 94 | } |
| 95 | |
| 96 | switch parts[0] { |
| 97 | case "query": |
| 98 | extractors = append(extractors, valuesFromQuery(parts[1], limit)) |
| 99 | case "param": |
| 100 | extractors = append(extractors, valuesFromParam(parts[1], limit)) |
| 101 | case "cookie": |
| 102 | extractors = append(extractors, valuesFromCookie(parts[1], limit)) |
| 103 | case "form": |
| 104 | extractors = append(extractors, valuesFromForm(parts[1], limit)) |
| 105 | case "header": |
| 106 | prefix := "" |
| 107 | if len(parts) > 2 { |
| 108 | prefix = parts[2] |
| 109 | } |
| 110 | extractors = append(extractors, valuesFromHeader(parts[1], prefix, limit)) |
| 111 | } |
| 112 | } |
| 113 | return extractors, nil |
| 114 | } |
| 115 | |
| 116 | // valuesFromHeader returns a functions that extracts values from the request header. |
| 117 | // valuePrefix is parameter to remove first part (prefix) of the extracted value. This is useful if header value has static |
no test coverage detected
searching dependent graphs…