Certificate pinning in Azure is a security feature that allows you to specify which certificates are trusted by your application. This helps prevent man-in-the-middle attacks where an attacker intercepts and alters your application's communication with a server.
By pinning certificates, you can ensure that only specific certificates are used for communication, reducing the risk of unauthorized access. This is especially important for applications that handle sensitive data.
Certificate pinning in Azure can be implemented using the Azure App Service feature, which allows you to specify a list of trusted certificates. This list can be updated as needed to reflect changes in your application's certificate requirements.
Implementing certificate pinning in Azure requires careful consideration of the certificate's public key, issuer, and subject fields.
What Changed?
Azure services will now chain up to one of the following Root CAs after the change.
Azure services will use the DigiCert Global Root G2, with a thumbprint of df3c24f9bfd666761b268073fe06d1cc8d4f82a4, as a trusted Root CA.
The DigiCert Global Root CA is also a trusted Root CA, with a thumbprint of a8985d3a65e5e5c4b2d7d66d40c6dd2fb19c5436.
Here's a list of the new trusted Root CAs:
Azure services will also use the Baltimore CyberTrust Root, with a thumbprint of d4de20d05e66fc53fe1a50882c78db2852cae474, as a trusted Root CA.
The D-TRUST Root Class 3 CA 2 2009 is another trusted Root CA, with a thumbprint of 58e8abb0361533fb80f79b1b6d29d3ff8d5f00f0.
Application Impact
If your application uses certificate pinning, it was likely impacted by the Azure Storage TLS changes. This means you'll need to update your source code to include the new CAs.
To detect if your application was impacted, search your source code for the thumbprint, Common Name, and other cert properties of any of the Microsoft IT TLS CAs in the Microsoft PKI repository. If there's a match, then your application will be impacted.
Industry regulations require CA certificates to be replaced within seven days of the change, so it's essential to be able to add or edit CAs on short notice.
If you're unsure if your application uses certificate pinning, check with the application vendor. They should be able to provide more information.
You may need to allow additional CRL and OCSP URLs in your environment's firewall rules to ensure proper certificate chain building with the new roots.
Here are some specific CRL and OCSP URLs you may need to allow:
- For a complete list of CRL and OCSP URLs used in Azure, see the Azure CA details article.
Security Configuration
Certificate pinning is a crucial aspect of network security configuration, and it's essential to understand its importance. Key pinning associates specific public keys with a particular service or domain, validating the authenticity of public keys presented by servers during the Transport Layer Security handshake process.
By enforcing the use of specific certificates, SSL pinning mitigates the risk of unauthorized access and data interception, bolstering the overall confidentiality and integrity of communication channels. This is especially important for HTTPS connections.
Incorporating cryptographic agility into certificate pinning implementations future-proofs security controls against emerging threats and regulatory requirements. This proactive approach enables organizations to maintain compliance with evolving security standards.
Key pinning brings about several benefits, including the validation of public keys presented by servers during the Transport Layer Security handshake process. This helps to prevent unauthorized access and data interception.
Certificate Pinning Benefits
Certificate pinning enhances the authentication process between clients and servers, reducing the risk of man-in-the-middle attacks and unauthorized access.
By pinning specific public keys, organizations can strengthen the trust model and mitigate the risk of certificate-based attacks.
Choosing the Right Approach
Certificate pinning in Azure can be achieved through two primary methods: using a trusted certificate authority (CA) or a self-signed certificate.
Using a trusted CA ensures that the certificate is verified and trusted by the Azure platform, but it may not be feasible for all scenarios, especially when working with internal or custom certificates.
A self-signed certificate, on the other hand, can be easily managed and updated, but it requires additional validation and verification steps to ensure its authenticity.
The choice between these two methods depends on the specific requirements and constraints of your Azure setup.
Choosing the Right Approach: Public Key
Key pinning is a more flexible approach than traditional certificate validation, as it allows for the association of specific public keys with a particular service or domain.
By focusing on public keys, key pinning can validate the authenticity of servers during the Transport Layer Security handshake process.
Key pinning brings several benefits, including the prevention of man-in-the-middle attacks and the ability to identify and block malicious servers.
It's a more granular approach than certificate validation, which can be limited by the trust chain of a certificate authority.
Key pinning can be used to validate the authenticity of public keys presented by servers during the TLS handshake process.
Choosing the Right Approach
The key to success lies in understanding the context and goals of the project. This involves considering the type of project, its scope, and the desired outcome.
A hybrid approach can be effective for projects with multiple stakeholders and complex requirements. This approach combines elements of Agile and Waterfall methodologies.
For projects with well-defined requirements and a fixed scope, a Waterfall approach can be efficient. This approach involves breaking down the project into distinct phases, with each phase building on the previous one.
Agile methodologies are ideal for projects with rapidly changing requirements and a focus on customer satisfaction. They involve breaking down the project into smaller, manageable chunks, with regular iterations and feedback.
Ultimately, the right approach depends on the specific needs and goals of the project. It's essential to assess the project's context and choose a methodology that aligns with its requirements.
Multiple Perspectives
Choosing the right approach for pinning certificates can be a complex task. It's essential to consider the complexity of the environment.
The choice between public key and certificate pinning depends on factors such as the complexity of the environment, the level of control desired, and the resources available for maintenance. This is a key consideration for organizations.
Organizations must weigh the trade-offs and select the approach that best aligns with their security requirements and operational capabilities. This might involve evaluating the pros and cons of each approach.
Application developers should think about pinning more than one or all certificates in the certificate chain. This is crucial for ensuring the security of the application.
Frequently Asked Questions
What is the purpose of certificate pinning?
Certificate pinning prevents apps from accepting fake certificates from imposter servers, ensuring secure communication with trusted servers only. This security measure protects against man-in-the-middle attacks and other certificate-based threats.
How to check Azure certificate pinning?
Certificate pinning in Azure is an internal application configuration and cannot be viewed directly. It typically involves a list of authorized certificates with specific details like Subject Distinguished Names and thumbprints.
How do I know if I use certificate pinning?
Check your source code for hardcoded SSL certificate thumbprints to determine if you're using certificate pinning. If you find any, it's likely a sign that you're implementing this security measure.
Sources
- https://learn.microsoft.com/en-us/azure/security/fundamentals/tls-certificate-changes
- https://learn.microsoft.com/en-us/azure/security/fundamentals/certificate-pinning
- https://live.paloaltonetworks.com/t5/next-generation-firewall/what-is-certificate-pinning-and-how-to-deal-with-ssl-decryption/td-p/571722
- https://www.securew2.com/blog/everything-you-need-to-know-about-certificate-pinning
- https://tyk.io/docs/security/certificate-pinning/
Featured Images: pexels.com