1. Navigate to your SimpleSAMLphp installation folder on the IIS server and open the config folder.
data:image/s3,"s3://crabby-images/91467/9146766a3f383ead943a26453afb0e255f23e04b" alt="Image4"
2. Open authsources.php in your favourite text editor.
data:image/s3,"s3://crabby-images/2911c/2911cd7d9821ee079aa79ddc2e1ad417629f07f1" alt="Image4"
3. I’m not going to repeat much of what I wrote in the post preceding this one where I added a Service Provider for Azure AD. Here, we will create a service provider configuration that uses our ADFS server. There are some differences in the configuration between Azure AD and ADFS 2012R2. The name of your SP is your choice, mine is called transishun-sp.
```php
// An authentication source which can authenticate against both SAML 2.0
// and Shibboleth 1.3 IdPs. If you make any configuration changes, you will need
// to update the RPT at the IdP.
'transishun-sp'=>array(
'saml:SP',
// The entity ID of this SP.
// Can be NULL/unset, in which case an entity ID is generated based on the metadata URL.
'entityID'=>null,
// The entity ID of the IdP this should SP should contact.
// Can be NULL/unset, in which case the user will be shown a list of available IdPs.
4. Here is how the code looks inside my authsources.php file.
data:image/s3,"s3://crabby-images/c077e/c077e29d78fd74fe720a57587acf4c962c096863" alt="Image4"
5. You will notice that the SP code defines that we must sign.logout, redirect.sign and assertion.encryption. All of these declarations mean we need a certificate and key to sign and encrypt these communications. We’ll create the certificate and key in the next section.
6. The final declaration enforces the use of SHA-256 which is best practice.
Creating a certificate and key file for signing and encryption
I mentioned in the requirements that you would need a Linux machine. Again, if you need one, just spin one up on Azure, I did.
data:image/s3,"s3://crabby-images/248d2/248d2baa17fe5e75299d2d4279cc9a5f111a3722" alt="Image4"
1. Log on to your Linux machine. Use Putty to log on via SSH.
data:image/s3,"s3://crabby-images/7893f/7893fe2cb8cf203267bb574e935b838463ee28e6" alt="Image4"
2. Create a directory called cert and change in to it.
data:image/s3,"s3://crabby-images/f4dcf/f4dcf53ef52bab5f07e38ae542d71df8bb608bb4" alt="Image4"
3. If you recall from the SP definition code at the end of previous section, I provided an example command for generating a two year certificate and key:
I extrapolated this from the documentation on the SimpleSAMLphp website in section 1.1. If you’re using this in a production environment, generate a key and cert that will last. The SimpleSAMLphp documentation suggests 10 years.
4. Run the command to create the key and certificate. You will be asked a number of questions, answer these however you like, this cert and key is only used for signing and encrypting on the SP. My run through is shown below.
data:image/s3,"s3://crabby-images/2e676/2e676d6357243a6bc3752bd290e23571e6fd652b" alt="Image4"
5. Now you need to download the my.key and my.pem files. There’s a number of ways but since they’re just text, I usually just cat them to screen and copy/paste from the Putty console in to a file on my local machine.
data:image/s3,"s3://crabby-images/9e0fc/9e0fc1564c646d7250b551bc052b6bc515f15434" alt="Image4"
6. NB: Don’t get too excited, this is an example key, I don’t use this one myself.
Navigate to the SimpleSAMLphp installation folder and create a folder called cert.
data:image/s3,"s3://crabby-images/8fbf4/8fbf40c984ccb7ade551f176fc9adc2e691e029c" alt="Image4"
7. Copy the my.key and my.pem files in to the cert folder. These are the two files that we declared when we created the Service Provider configuration in authsources.php. The cert folder is the default location for certs and keys in SimpleSAMLphp as mentioned in the documentation.
data:image/s3,"s3://crabby-images/463e5/463e51774d2f2aecfe5a198b9780aa655119845c" alt="Image4"