In most cases, trust boundaries are violated when a secret is exposed in a source code repository or an uncontrolled deployment environment.
Unintended people who don’t need to know the secret might get access to it. They might then be able to use it to gain unwanted access to associated
services or resources.
The trust issue can be more or less severe depending on the people’s role and entitlement.
What is the potential impact?
Access keys are used to authenticate to Azure Event Grid resources and can be employed for event publication to the resource.
Shared Access Secrets (SAS) are generated from access keys and used to authenticate specific resources with particular permissions within a defined
time frame.
Using Shared Access Signatures is always better than using access keys, because they reduce risk thanks to their scope and time
limitation. However, hardcoding secret tokens is always a bad practice, and still exposes the resources to attacks.
This is a risk unless the
whole resource is free of sensitive data.
Note that the Microsoft docs can use different terminologies for these two tokens:
- Access Keys are also called SAS keys
- Shared Access Secrets are also called SAS tokens
Below are some real-world scenarios that illustrate some impacts of an attacker exploiting these types of secrets.
Breach of trust in non-repudiation and disruption of the audit trail
When such a secret is compromised, malicious actors might have the possibility to send malicious event objects, causing discrepancies in the audit
trail. This can make it difficult to trace and verify the sequence of events, impacting the ability to investigate and identify unauthorized or
fraudulent activity.
All in all, this can lead to problems in proving the validity of transactions or actions performed, potentially leading to disputes and legal
complications.
Compromise of sensitive data
If the affected service is used to store or process personally identifiable information or other sensitive data, attackers knowing an
authentication secret could be able to access it. Depending on the type of data that is compromised, it could lead to privacy violations, identity
theft, financial loss, or other negative outcomes.
In most cases, a company suffering a sensitive data compromise will face a reputational loss when the security issue is publicly disclosed.
Financial loss
Financial losses can occur when a secret is used to access a paid third-party-provided service and is disclosed as part of the source code of
client applications. Having the secret, each user of the application will be able to use it without limit to use the third party service to their own
need, including in a way that was not expected.
This additional use of the secret will lead to added costs with the service provider.
Moreover, when rate or volume limiting is set up on the provider side, this additional use can prevent the regular operation of the affected
application. This might result in a partial denial of service for all the application’s users.