I am using go-saml library in our project to enable SSO in which the service provider will be Salesforce and Identity Provider will be the Golang code. Golang code will first verify the user then it will create a SAML response to allow the user to login to Salesforce. I am new to Golang and following Creating a SAML Response (if acting as an IdP) of this library. So, far I am able to create a SAML response using it but facing some challenges in customizing it as per the requirement.
- The first challenge I was facing is to add AudienceRestriction in the Conditions block as below:-
<saml:Conditions NotBefore="2020-03-15T16:33:16.23103491Z" NotOnOrAfter="2020-03-15T16:43:16.23104017Z">
<saml:AudienceRestriction>
<saml:Audience>https://saml.salesforce.com</saml:Audience>
</saml:AudienceRestriction>
</saml:Conditions>
I have tried to add it like below in the code, but it seems AudienceRestrictions is not defined in Conditions object.
authnResponse := saml.NewSignedResponse()
authnResponse.Conditions.AudienceRestrictions = "https://saml.salesforce.com"
I don't find any way to add the above block in the Conditions block which is mandatory for Salesforce. Please suggest me some way to do so.
- I also have to add AuthnStatement below the conditions block as below:-
<saml:AuthnStatement AuthnInstant="2020-03-01T11:28:31.396Z">
<saml:AuthnContext> <saml:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:unspecified</saml:AuthnContextClassRef>
</saml:AuthnContext>
</saml:AuthnStatement>
- Even after manually adding the above blocks in the SAML response, I am getting the below error while validating the SAML response using the Salesforce SAML validator
Validating the Signature... Is the response signed? true
Is the assertion signed? false
The reference in the response signature is valid
Is the correct certificate supplied in the keyinfo? trueSignature or certificate problems
The signature in the response is not valid
I have generated a Public key(self-signed .pem certificate) and a Private key. After that, I have uploaded the public key to the Salesforce and using private and public keys to inside the code for generating SAML response. I have no idea why I am getting Signature Invalid error. Please let me know if you have any suggestions for me.
In case you want to check my Golang code - https://play.golang.org/p/U9dXZblTHG1