forked from RobotsAndPencils/go-saml
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathsaml.go
72 lines (60 loc) · 1.81 KB
/
saml.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
63
64
65
66
67
68
69
70
71
72
package saml
import "github.com/diego-araujo/go-saml/util"
import stderrors "errors"
// ServiceProviderSettings provides settings to configure server acting as a SAML Service Provider.
// Expect only one IDP per SP in this configuration. If you need to configure multipe IDPs for an SP
// then configure multiple instances of this module
type ServiceProviderSettings struct {
PublicCertPath string
PrivateKeyPath string
IDPSSOURL string
IDPSSODescriptorURL string
DisplayName string
Description string
IDPPublicCertPath string
AssertionConsumerServiceURL string
Id string
SPSignRequest bool
IDPSignResponse bool
hasInit bool
publicCert string
privateKey string
iDPPublicCert string
}
var (
ErrPrivkey = stderrors.New("error load private key")
ErrSpPubCert = stderrors.New("error load SP publicCert")
ErrIdpPubCert = stderrors.New("error load IDP publicCert")
)
type IdentityProviderSettings struct {
}
func (s *ServiceProviderSettings) Init() (err error) {
if s.hasInit {
return nil
}
s.hasInit = true
if s.SPSignRequest {
s.publicCert, err = util.LoadCertificate(s.PublicCertPath)
if err != nil {
return ErrSpPubCert
}
s.privateKey, err = util.LoadCertificate(s.PrivateKeyPath)
if err != nil {
return ErrPrivkey
}
}
s.iDPPublicCert, err = util.LoadCertificate(s.IDPPublicCertPath)
if err != nil {
return ErrIdpPubCert
}
return nil
}
func (s *ServiceProviderSettings) PublicCert() string {
return s.publicCert
}
func (s *ServiceProviderSettings) PrivateKey() string {
return s.privateKey
}
func (s *ServiceProviderSettings) IDPPublicCert() string {
return s.iDPPublicCert
}