Dastardly, from Burp Suite – scan checks

Date:

Share post:


HTML5 cross-origin resource sharing (CORS) is a browser mechanism that enables controlled access to resources located outside of a given domain. CORS is a powerful technology, which is easy to configure wrong – and high severity exploits are often relatively easy for an attacker to find.

CORS checks performed by Dastardly

CORS enabled

It’s easy to unintentionally enable CORS when building a web application. Some libraries turn CORS on by default, for instance. Or you might wish to have CORS enabled for an API, but accidentally enable it for your whole application.

Dastardly dynamically checks whether CORS is enabled in your application – and notifies you if it is. This serves as a reminder to check your CORS implementation, and to remove any unnecessary domains (e.g. test domains) from your CORS policy before deployment.

CORS: arbitrary origin trusted

If an application is set to trust arbitrary domains (as opposed to using an allow list / “whitelist”), then this effectively disables CORS – granting two-way interaction to any website that requests it. Unless the application’s response contains solely unprotected public content, such a policy is likely to constitute a security risk. Despite this, during development, applications are sometimes set to trust arbitrary origins – often for purposes of convenience.

It’s imperative to check that an application’s CORS implementation is only set to trust arbitrary origins when this is truly necessary. If your application uses CORS, Dastardly dynamically checks to see if it trusts arbitrary domains, and will warn you in your CI/CD pipeline if this configuration is detected.

CORS: all subdomains trusted

If an application’s CORS policy is set to allow two-way interaction with all subdomains, then this can significantly increase that application’s susceptibility to attack. For example, a cross-site scripting (XSS) vulnerability in any present or future subdomain could potentially compromise the application. This could pose a huge security risk.

Rather than trust all subdomains, it is generally better to include an allow list / “whitelist” of trusted subdomains in an application’s CORS implementation. If your application uses CORS, Dastardly dynamically checks to see if it trusts all subdomains, and will warn you in your CI/CD pipeline if this configuration is detected.

More information / further reading

Note that Dastardly does not check your application for a CORS implementation where unencrypted origins are trusted. Full versions of Burp Suite will dynamically check your application for this issue.



Source link

LEAVE A REPLY

Please enter your comment!
Please enter your name here

Related articles

New Zealand investing over $2 million a year in game development

New Zealand / Aotearoan game developers will soon benefit from a significant boost to industry funding over...

Playing In Online Casinos: A Beginners Guide

Going to a physical casino certainly has its appeal; you get to experience the hustle and bustle...

15 Biggest Email Service and Account Providers

In this article, we will discuss the 15 Biggest Email Service and Account Providers. You can skip...