|
@@ -171,35 +171,37 @@ func processHeaderOverride(info *common.RelayInfo, c *gin.Context) (map[string]s
|
|
|
|
|
|
|
|
passAll := false
|
|
passAll := false
|
|
|
var passthroughRegex []*regexp.Regexp
|
|
var passthroughRegex []*regexp.Regexp
|
|
|
- for k := range info.HeadersOverride {
|
|
|
|
|
- key := strings.TrimSpace(k)
|
|
|
|
|
- if key == "" {
|
|
|
|
|
- continue
|
|
|
|
|
- }
|
|
|
|
|
- if key == headerPassthroughAllKey {
|
|
|
|
|
- passAll = true
|
|
|
|
|
- continue
|
|
|
|
|
- }
|
|
|
|
|
|
|
+ if !info.IsChannelTest {
|
|
|
|
|
+ for k := range info.HeadersOverride {
|
|
|
|
|
+ key := strings.TrimSpace(k)
|
|
|
|
|
+ if key == "" {
|
|
|
|
|
+ continue
|
|
|
|
|
+ }
|
|
|
|
|
+ if key == headerPassthroughAllKey {
|
|
|
|
|
+ passAll = true
|
|
|
|
|
+ continue
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
- lower := strings.ToLower(key)
|
|
|
|
|
- var pattern string
|
|
|
|
|
- switch {
|
|
|
|
|
- case strings.HasPrefix(lower, headerPassthroughRegexPrefix):
|
|
|
|
|
- pattern = strings.TrimSpace(key[len(headerPassthroughRegexPrefix):])
|
|
|
|
|
- case strings.HasPrefix(lower, headerPassthroughRegexPrefixV2):
|
|
|
|
|
- pattern = strings.TrimSpace(key[len(headerPassthroughRegexPrefixV2):])
|
|
|
|
|
- default:
|
|
|
|
|
- continue
|
|
|
|
|
- }
|
|
|
|
|
|
|
+ lower := strings.ToLower(key)
|
|
|
|
|
+ var pattern string
|
|
|
|
|
+ switch {
|
|
|
|
|
+ case strings.HasPrefix(lower, headerPassthroughRegexPrefix):
|
|
|
|
|
+ pattern = strings.TrimSpace(key[len(headerPassthroughRegexPrefix):])
|
|
|
|
|
+ case strings.HasPrefix(lower, headerPassthroughRegexPrefixV2):
|
|
|
|
|
+ pattern = strings.TrimSpace(key[len(headerPassthroughRegexPrefixV2):])
|
|
|
|
|
+ default:
|
|
|
|
|
+ continue
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
- if pattern == "" {
|
|
|
|
|
- return nil, types.NewError(fmt.Errorf("header passthrough regex pattern is empty: %q", k), types.ErrorCodeChannelHeaderOverrideInvalid)
|
|
|
|
|
- }
|
|
|
|
|
- compiled, err := getHeaderPassthroughRegex(pattern)
|
|
|
|
|
- if err != nil {
|
|
|
|
|
- return nil, types.NewError(err, types.ErrorCodeChannelHeaderOverrideInvalid)
|
|
|
|
|
|
|
+ if pattern == "" {
|
|
|
|
|
+ return nil, types.NewError(fmt.Errorf("header passthrough regex pattern is empty: %q", k), types.ErrorCodeChannelHeaderOverrideInvalid)
|
|
|
|
|
+ }
|
|
|
|
|
+ compiled, err := getHeaderPassthroughRegex(pattern)
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ return nil, types.NewError(err, types.ErrorCodeChannelHeaderOverrideInvalid)
|
|
|
|
|
+ }
|
|
|
|
|
+ passthroughRegex = append(passthroughRegex, compiled)
|
|
|
}
|
|
}
|
|
|
- passthroughRegex = append(passthroughRegex, compiled)
|
|
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
if passAll || len(passthroughRegex) > 0 {
|
|
if passAll || len(passthroughRegex) > 0 {
|
|
@@ -243,6 +245,9 @@ func processHeaderOverride(info *common.RelayInfo, c *gin.Context) (map[string]s
|
|
|
if !ok {
|
|
if !ok {
|
|
|
return nil, types.NewError(nil, types.ErrorCodeChannelHeaderOverrideInvalid)
|
|
return nil, types.NewError(nil, types.ErrorCodeChannelHeaderOverrideInvalid)
|
|
|
}
|
|
}
|
|
|
|
|
+ if info.IsChannelTest && strings.HasPrefix(strings.TrimSpace(str), clientHeaderPlaceholderPrefix) {
|
|
|
|
|
+ continue
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
value, include, err := applyHeaderOverridePlaceholders(str, c, info.ApiKey)
|
|
value, include, err := applyHeaderOverridePlaceholders(str, c, info.ApiKey)
|
|
|
if err != nil {
|
|
if err != nil {
|