diff --git a/.github/workflows/build-and-test.yml b/.github/workflows/build-and-test.yml
index 67af2f0a0..4187ed712 100644
--- a/.github/workflows/build-and-test.yml
+++ b/.github/workflows/build-and-test.yml
@@ -21,7 +21,7 @@ jobs:
steps:
- name: Checkout
- uses: actions/checkout@v3
+ uses: actions/checkout@v4
- name: Setup Node.js ${{ matrix.node-version }}
uses: actions/setup-node@v3
with:
diff --git a/.github/workflows/codeql-analysis.yml b/.github/workflows/codeql-analysis.yml
index c2e59e237..8931faebb 100644
--- a/.github/workflows/codeql-analysis.yml
+++ b/.github/workflows/codeql-analysis.yml
@@ -25,7 +25,7 @@ jobs:
steps:
- name: Checkout repository
- uses: actions/checkout@v3
+ uses: actions/checkout@v4
with:
# We must fetch at least the immediate parents so that if this is
# a pull request then we can checkout the head.
diff --git a/README.md b/README.md
index 2aa4d47ce..ff7fc5963 100644
--- a/README.md
+++ b/README.md
@@ -1,12 +1,12 @@
# DOMPurify
-[data:image/s3,"s3://crabby-images/8088c/8088cd7379cf8dd61e9142d4f3a32a2b2880cd14" alt="npm version"](http://badge.fury.io/js/dompurify) data:image/s3,"s3://crabby-images/1008f/1008fccce3f018970932e15653c88119a4e4c9dd" alt="Build and Test" [data:image/s3,"s3://crabby-images/e8ba9/e8ba97baa938e325e849af2401053d79fb38a436" alt="Downloads"](https://www.npmjs.com/package/dompurify) [data:image/s3,"s3://crabby-images/4559c/4559c58f76632a763a1eaa718d28e8861c96d5d0" alt="minified size"](https://cdn.jsdelivr.net/npm/dompurify/dist/purify.min.js) [data:image/s3,"s3://crabby-images/c42fc/c42fcdf4ded13d33bec2c5f94a19ec32ea41f9d6" alt="gzip size"](https://packagephobia.now.sh/result?p=dompurify) [data:image/s3,"s3://crabby-images/60630/60630f64368bdea68d7a4bc293c662ac1e8a1c3f" alt="dependents"](https://github.com/cure53/DOMPurify/network/dependents)
+[data:image/s3,"s3://crabby-images/8088c/8088cd7379cf8dd61e9142d4f3a32a2b2880cd14" alt="npm version"](http://badge.fury.io/js/dompurify) data:image/s3,"s3://crabby-images/1008f/1008fccce3f018970932e15653c88119a4e4c9dd" alt="Build and Test" [data:image/s3,"s3://crabby-images/e8ba9/e8ba97baa938e325e849af2401053d79fb38a436" alt="Downloads"](https://www.npmjs.com/package/dompurify) data:image/s3,"s3://crabby-images/c50b7/c50b7aabb1228b01eae502f5b03f7ab1c9df31b7" alt="npm package minimized gzipped size (select exports)" data:image/s3,"s3://crabby-images/5c34b/5c34b3ef44df7eb0211c0c61d05d7e3b68279a88" alt="GitHub code size in bytes" [data:image/s3,"s3://crabby-images/60630/60630f64368bdea68d7a4bc293c662ac1e8a1c3f" alt="dependents"](https://github.com/cure53/DOMPurify/network/dependents)
[data:image/s3,"s3://crabby-images/1ce70/1ce70c2f9223da56c1afa668b48fbb0d856d1ca1" alt="NPM"](https://nodei.co/npm/dompurify/)
DOMPurify is a DOM-only, super-fast, uber-tolerant XSS sanitizer for HTML, MathML and SVG.
-It's also very simple to use and get started with. DOMPurify was [started in February 2014](https://github.com/cure53/DOMPurify/commit/a630922616927373485e0e787ab19e73e3691b2b) and, meanwhile, has reached version **v3.0.5**.
+It's also very simple to use and get started with. DOMPurify was [started in February 2014](https://github.com/cure53/DOMPurify/commit/a630922616927373485e0e787ab19e73e3691b2b) and, meanwhile, has reached version **v3.0.6**.
DOMPurify is written in JavaScript and works in all modern browsers (Safari (10+), Opera (15+), Edge, Firefox and Chrome - as well as almost anything else using Blink, Gecko or WebKit). It doesn't break on MSIE or other legacy browsers. It simply does nothing.
@@ -39,7 +39,7 @@ It's easy. Just include DOMPurify on your website.
Afterwards you can sanitize strings by executing the following code:
```js
-let clean = DOMPurify.sanitize(dirty);
+const clean = DOMPurify.sanitize(dirty);
```
Or maybe this, if you love working with Angular or alike:
@@ -47,14 +47,14 @@ Or maybe this, if you love working with Angular or alike:
```js
import * as DOMPurify from 'dompurify';
-let clean = DOMPurify.sanitize('hello there');
+const clean = DOMPurify.sanitize('hello there');
```
The resulting HTML can be written into a DOM element using `innerHTML` or the DOM using `document.write()`. That is fully up to you.
Note that by default, we permit HTML, SVG **and** MathML. If you only need HTML, which might be a very common use-case, you can easily set that up as well:
```js
-let clean = DOMPurify.sanitize(dirty, { USE_PROFILES: { html: true } });
+const clean = DOMPurify.sanitize(dirty, { USE_PROFILES: { html: true } });
```
### Where are the TypeScript type definitions?
@@ -160,62 +160,58 @@ When `DOMPurify.sanitize` is used in an environment where the Trusted Types API
Yes. The included default configuration values are pretty good already - but you can of course override them. Check out the [`/demos`](https://github.com/cure53/DOMPurify/tree/main/demos) folder to see a bunch of examples on how you can [customize DOMPurify](https://github.com/cure53/DOMPurify/tree/main/demos#what-is-this).
+### General settings
```js
-/**
- * General settings
- */
-
// strip {{ ... }}, ${ ... } and <% ... %> to make output safe for template systems
// be careful please, this mode is not recommended for production usage.
// allowing template parsing in user-controlled HTML is not advised at all.
// only use this mode if there is really no alternative.
-var clean = DOMPurify.sanitize(dirty, {SAFE_FOR_TEMPLATES: true});
+const clean = DOMPurify.sanitize(dirty, {SAFE_FOR_TEMPLATES: true});
+```
-/**
- * Control our allow-lists and block-lists
- */
+### Control our allow-lists and block-lists
+```js
// allow only elements, very strict
-var clean = DOMPurify.sanitize(dirty, {ALLOWED_TAGS: ['b']});
+const clean = DOMPurify.sanitize(dirty, {ALLOWED_TAGS: ['b']});
// allow only and with style attributes
-var clean = DOMPurify.sanitize(dirty, {ALLOWED_TAGS: ['b', 'q'], ALLOWED_ATTR: ['style']});
+const clean = DOMPurify.sanitize(dirty, {ALLOWED_TAGS: ['b', 'q'], ALLOWED_ATTR: ['style']});
// allow all safe HTML elements but neither SVG nor MathML
// note that the USE_PROFILES setting will override the ALLOWED_TAGS setting
// so don't use them together
-var clean = DOMPurify.sanitize(dirty, {USE_PROFILES: {html: true}});
+const clean = DOMPurify.sanitize(dirty, {USE_PROFILES: {html: true}});
// allow all safe SVG elements and SVG Filters, no HTML or MathML
-var clean = DOMPurify.sanitize(dirty, {USE_PROFILES: {svg: true, svgFilters: true}});
+const clean = DOMPurify.sanitize(dirty, {USE_PROFILES: {svg: true, svgFilters: true}});
// allow all safe MathML elements and SVG, but no SVG Filters
-var clean = DOMPurify.sanitize(dirty, {USE_PROFILES: {mathMl: true, svg: true}});
+const clean = DOMPurify.sanitize(dirty, {USE_PROFILES: {mathMl: true, svg: true}});
// change the default namespace from HTML to something different
-var clean = DOMPurify.sanitize(dirty, {NAMESPACE: 'http://www.w3.org/2000/svg'});
+const clean = DOMPurify.sanitize(dirty, {NAMESPACE: 'http://www.w3.org/2000/svg'});
// leave all safe HTML as it is and add