Goal Reached Thanks to every supporter — we hit 100%!

Goal: 1000 CNY · Raised: 1000 CNY

100.0%

CVE-2021-21239 PoC — Open default xmlsec1 key-type preference

Source
Associated Vulnerability
Title:Open default xmlsec1 key-type preference (CVE-2021-21239)
Description:PySAML2 is a pure python implementation of SAML Version 2 Standard. PySAML2 before 6.5.0 has an improper verification of cryptographic signature vulnerability. Users of pysaml2 that use the default CryptoBackendXmlSec1 backend and need to verify signed SAML documents are impacted. PySAML2 does not ensure that a signed SAML document is correctly signed. The default CryptoBackendXmlSec1 backend is using the xmlsec1 binary to verify the signature of signed SAML documents, but by default xmlsec1 accepts any type of key found within the given document. xmlsec1 needs to be configured explicitly to only use only _x509 certificates_ for the verification process of the SAML document signature. This is fixed in PySAML2 6.5.0.
Description
A Dockerized Redash instance that is vulnerable to CVE-2021-21239
Readme
# redash-vulnerable 🐛

A Dockerized Redash instance that is vulnerable to [`CVE-2021-21239`](https://nvd.nist.gov/vuln/detail/CVE-2021-21239) as written about by [Calif](https://blog.calif.io/p/redash-saml-authentication-bypass).

## Usage 💻

### Starting the server (preserving data)

```bash
script/server
```

This will start the Redash server using Docker Compose in detached mode, preserving any existing data. The server will be available at [`http://localhost:8080`](http://localhost:8080/setup).

### Starting fresh (destroying all data)

```bash
script/server --destroy
```

This will destroy all existing containers, volumes, and data directories, then rebuild everything from scratch. Use this when you want to start completely fresh.

**Note:** The `--destroy` flag will permanently delete all your Redash data, including dashboards, queries, users, and database content.
File Snapshot

[4.0K] /data/pocs/a1c7a109284214557bc9843aec0ea414b6fbdadd ├── [1.5K] docker-compose.yml ├── [4.0K] docs │   └── [1.0K] poc.md ├── [ 14K] poc.py ├── [ 890] README.md └── [4.0K] script ├── [2.7K] bootstrap ├── [ 878] env └── [3.4K] server 2 directories, 7 files
Shenlong Bot has cached this for you
Remarks
    1. It is advised to access via the original source first.
    2. Local POC snapshots are reserved for subscribers — if the original source is unavailable, the local mirror is part of the paid plan.
    3. Mirroring, verifying, and maintaining this POC archive takes ongoing effort, so local snapshots are a paid feature. Your subscription keeps the archive online — thank you for the support. View subscription plans →