This repository has been archived by the owner on Sep 2, 2022. It is now read-only.
/
requestheader.go
45 lines (39 loc) · 1.63 KB
/
requestheader.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
package oauth
import (
"k8s.io/apimachinery/pkg/runtime/serializer/json"
configv1 "github.com/openshift/api/legacyconfig/v1"
)
type identityProviderRequestHeader struct {
identityProviderCommon `yaml:",inline"`
RequestHeader struct {
ChallengeURL string `yaml:"challengeURL"`
LoginURL string `yaml:"loginURL"`
CA struct {
Name string `yaml:"name"`
} `yaml:"ca"`
ClientCommonNames []string `yaml:"сlientCommonNames"`
Headers []string `yaml:"headers"`
EmailHeaders []string `yaml:"emailHeaders"`
NameHeaders []string `yaml:"nameHeaders"`
PreferredUsernameHeaders []string `yaml:"preferredUsernameHeaders"`
} `yaml:"requestHeader"`
}
func buildRequestHeaderIP(serializer *json.Serializer, p configv1.IdentityProvider) identityProviderRequestHeader {
var idP identityProviderRequestHeader
var requestHeader configv1.RequestHeaderIdentityProvider
_, _, _ = serializer.Decode(p.Provider.Raw, nil, &requestHeader)
idP.Type = "RequestHeader"
idP.Name = p.Name
idP.Challenge = p.UseAsChallenger
idP.Login = p.UseAsLogin
idP.MappingMethod = p.MappingMethod
idP.RequestHeader.ChallengeURL = requestHeader.ChallengeURL
idP.RequestHeader.LoginURL = requestHeader.LoginURL
idP.RequestHeader.CA.Name = requestHeader.ClientCA
idP.RequestHeader.ClientCommonNames = requestHeader.ClientCommonNames
idP.RequestHeader.Headers = requestHeader.Headers
idP.RequestHeader.EmailHeaders = requestHeader.EmailHeaders
idP.RequestHeader.NameHeaders = requestHeader.NameHeaders
idP.RequestHeader.PreferredUsernameHeaders = requestHeader.PreferredUsernameHeaders
return idP
}