Guide used:
https://stellarlab.net/azure-automation-with-exchange-online-part-1
App Registration
The exchange runbooks in azure use the "ExO PowerShell CBA" app registration with certificate based authentication to connect to exchange management shell.
data:image/s3,"s3://crabby-images/09676/09676970891237b0875dd3a3675da804a8024a5b" alt=""
Certificate
ExO Powershell CBA has the certificate stored on it's object:
data:image/s3,"s3://crabby-images/a1abd/a1abdefbaff0e3ec49be91f77f93ea0b6b1d78b2" alt=""
To create/"renew" certificate
New-SelfSignedCertificate -Subject "CN=$Name" -KeyLength 2048 -KeyUsageProperty All -KeyAlgorithm 'RSA' -HashAlgorithm 'SHA256' -Provider "Microsoft Enhanced RSA and AES Cryptographic Provider" -NotAfter (Get-Date).AddYears(100)
Create certificate on any machine, export including the private key, additionally export without the private key:
data:image/s3,"s3://crabby-images/3eb6b/3eb6b31bddc5c25c1a01f360a679782d94b653b6" alt=""
Make note of the private key in password manager and store in CRST IT Support - Documents\01_Central Store\2_Documentation\0_Central & 365 Network Stuff\Automation Certificate
Upload the .cer to the App Registration mentioned above.
Upload the .pfx to the Automation account
data:image/s3,"s3://crabby-images/8b562/8b5620f9e4a205f6f186265f3d010195a1ecbac3" alt=""
Finally, update the cert name in the automation script:
data:image/s3,"s3://crabby-images/2d490/2d4907d420e621a44d4f6525ac2eb6737b22e2cb" alt=""