CVE-2024-10125 – missing JWT issuer and signer validation in aws-alb-identity-aspnetcore

Publication Date: 2024/10/21 4:00 PM PDT

Description:

The Amazon.ApplicationLoadBalancer.Identity.AspNetCore repo contains Middleware that can be used in conjunction with the Application Load Balancer (ALB) OpenId Connect integration and can be used in any ASP.NET Core deployment scenario, including AWS Fargate, Amazon Elastic Kubernetes Service (Amazon EKS), Amazon Elastic Container Service (Amazon ECS), Amazon Elastic Compute Cloud (Amazon EC2), and AWS Lambda. In the JWT handling code, it performs signature validation but fails to validate the JWT issuer and signer identity. The signer omission, if combined with a scenario where the infrastructure owner allows internet traffic to the ALB targets (not a recommended configuration), can allow for JWT signing by an untrusted entity and an actor may be able to mimic valid OIDC-federated sessions to the ALB targets.

Affected versions: all versions

Resolution

The repository/package has been deprecated, is End of Life, and is no longer actively supported.

Workarounds

As a security best practice, ensure that your ELB targets (e.g. EC2 Instances, Fargate Tasks etc.) do not have public IP addresses.

Ensure any forked or derivative code validate that the signer attribute in the JWT match the ARN of the Application Load Balancer that the service is configured to use.

References

We would like to thank Miggo Security for collaborating on this issue through the coordinated disclosure process.

Please email [email protected] with any security questions or concerns.

Go to Source