Lucene search
K

Linux Distros Unpatched Vulnerability : CVE-2021-32618

🗓️ 10 Sep 2025 00:00:00Reported by TenableType 
nessus
 nessus
🔗 www.tenable.com👁 1 Views

Unpatched Linux hosts with Flask-Security-Too allow redirects via the next parameter; fix by enforcing absolute Location headers.

Related
Refs
Code
ReporterTitlePublishedViews
Family
Circl
CVE-2021-32618
27 Apr 202309:58
circl
CNNVD
flask-security 输入验证错误漏洞
17 May 202100:00
cnnvd
CVE
CVE-2021-32618
17 May 202118:05
cve
Cvelist
CVE-2021-32618 Open Redirect Vulnerability
17 May 202118:05
cvelist
Github Security Blog
Open Redirect in Flask-Security-Too
17 May 202120:51
github
Github Security Blog
Open Redirect in Flask-Security-Too
14 Dec 202118:14
github
GitLab Advisory Database
Open Redirect in Flask-Security-Too
17 May 202100:00
gitlab
Nuclei
Python Flask-Security - Open Redirect
3 Jun 202606:04
nuclei
NVD
CVE-2021-32618
17 May 202118:15
nvd
OSV
GHSA-6QMF-FJ6M-686C Open Redirect in Flask-Security-Too
17 May 202120:51
osv
Rows per page
#%NASL_MIN_LEVEL 80900
##
# (C) Tenable, Inc.
##

include('compat.inc');

if (description)
{
  script_id(262753);
  script_version("1.1");
  script_set_attribute(attribute:"plugin_modification_date", value:"2025/09/10");

  script_cve_id("CVE-2021-32618");

  script_name(english:"Linux Distros Unpatched Vulnerability : CVE-2021-32618");

  script_set_attribute(attribute:"synopsis", value:
"The Linux/Unix host has one or more packages installed with a vulnerability that the vendor indicates will not be
patched.");
  script_set_attribute(attribute:"description", value:
"The Linux/Unix host has one or more packages installed that are impacted by a vulnerability without a vendor supplied
patch available.

  - The Python Flask-Security-Too package is used for adding security features to your Flask application. It
    is an is an independently maintained version of Flask-Security based on the 3.0.0 version of Flask-
    Security. All versions of Flask-Security-Too allow redirects after many successful views (e.g. /login) by
    honoring the ?next query param. There is code in FS to validate that the url specified in the next
    parameter is either relative OR has the same netloc (network location) as the requesting URL. This check
    utilizes Pythons urlsplit library. However many browsers are very lenient on the kind of URL they accept
    and 'fill in the blanks' when presented with a possibly incomplete URL. As a concrete example - setting
    http://login?next=\\\github.com will pass FS's relative URL check however many browsers will gladly
    convert this to http://github.com. Thus an attacker could send such a link to an unwitting user, using a
    legitimate site and have it redirect to whatever site they want. This is considered a low severity due to
    the fact that if Werkzeug is used (which is very common with Flask applications) as the WSGI layer, it by
    default ALWAYS ensures that the Location header is absolute - thus making this attack vector mute. It is
    possible for application writers to modify this default behavior by setting the
    'autocorrect_location_header=False`. (CVE-2021-32618)

Note that Nessus relies on the presence of the package as reported by the vendor.");
  script_set_attribute(attribute:"see_also", value:"https://ubuntu.com/security/CVE-2021-32618");
  script_set_attribute(attribute:"solution", value:
"There is no known solution at this time.");
  script_set_attribute(attribute:"agent", value:"unix");
  script_set_cvss_base_vector("CVSS2#AV:N/AC:M/Au:N/C:P/I:P/A:N");
  script_set_cvss_temporal_vector("CVSS2#E:U/RL:OF/RC:C");
  script_set_cvss3_base_vector("CVSS:3.0/AV:N/AC:L/PR:N/UI:R/S:C/C:L/I:L/A:N");
  script_set_cvss3_temporal_vector("CVSS:3.0/E:U/RL:O/RC:C");
  script_set_attribute(attribute:"cvss_score_source", value:"CVE-2021-32618");

  script_set_attribute(attribute:"exploitability_ease", value:"No known exploits are available");
  script_set_attribute(attribute:"exploit_available", value:"false");
  script_set_attribute(attribute:"vendor_unpatched", value:"true");

  script_set_attribute(attribute:"vuln_publication_date", value:"2021/05/17");
  script_set_attribute(attribute:"plugin_publication_date", value:"2025/09/10");

  script_set_attribute(attribute:"plugin_type", value:"local");
  script_set_attribute(attribute:"cpe", value:"cpe:/o:canonical:ubuntu_linux:18.04:-:lts");
  script_set_attribute(attribute:"cpe", value:"cpe:/o:canonical:ubuntu_linux:20.04:-:lts");
  script_set_attribute(attribute:"cpe", value:"cpe:/o:canonical:ubuntu_linux:22.04:-:lts");
  script_set_attribute(attribute:"cpe", value:"cpe:/o:canonical:ubuntu_linux:24.04:-:lts");
  script_set_attribute(attribute:"cpe", value:"p-cpe:/a:canonical:ubuntu_linux:flask-security");
  script_set_attribute(attribute:"generated_plugin", value:"current");
  script_end_attributes();

  script_category(ACT_GATHER_INFO);
  script_family(english:"Misc.");

  script_copyright(english:"This script is Copyright (C) 2025 and is owned by Tenable, Inc. or an Affiliate thereof.");

  script_dependencies("ssh_get_info2.nasl", "set_linux_os_id.nasl");
  script_require_keys("Host/cpu", "Host/local_checks_enabled", "global_settings/vendor_unpatched", "Host/OS/identifier");
  script_require_ports("Host/OS/Ubuntu Linux-18.04", "Host/OS/Ubuntu Linux-20.04", "Host/OS/Ubuntu Linux-22.04", "Host/OS/Ubuntu Linux-24.04");

  exit(0);
}

if (!get_kb_item("global_settings/vendor_unpatched")) exit(0, "Unpatched Vulnerabilities Detection not active.");
if (!get_kb_item("Host/local_checks_enabled")) audit(AUDIT_LOCAL_CHECKS_NOT_ENABLED);
if (empty_or_null(get_one_kb_item("Host/Debian/dpkg-l"))) audit(AUDIT_PACKAGE_LIST_MISSING);

include('linux_unpatched.inc');

var distro_constraints_array = {
  "Ubuntu Linux-22.04": {
    "package_manager": "dpkg-l",
    "constraints": [
      {
        "release": "22.04",
        "pkgs": [
          {"reference": "flask-security"}
        ]
      }
    ]
  },
  "Ubuntu Linux-18.04": {
    "package_manager": "dpkg-l",
    "constraints": [
      {
        "release": "18.04",
        "pkgs": [
          {"reference": "flask-security"}
        ]
      }
    ]
  },
  "Ubuntu Linux-20.04": {
    "package_manager": "dpkg-l",
    "constraints": [
      {
        "release": "20.04",
        "pkgs": [
          {"reference": "flask-security"}
        ]
      }
    ]
  },
  "Ubuntu Linux-24.04": {
    "package_manager": "dpkg-l",
    "constraints": [
      {
        "release": "24.04",
        "pkgs": [
          {"reference": "flask-security"}
        ]
      }
    ]
  }
};

var distro_constraints_values = linux_unpatched::get_distro_constraints(distro_constraints_arr:distro_constraints_array);
if (empty_or_null(distro_constraints_values)) audit(AUDIT_HOST_NOT, 'affected');
var report = linux_unpatched::check_unpatched_constraints(distro_constraints_values:distro_constraints_values);

if (!empty_or_null(report))
{
  security_report_v4(
      port       : 0,
      severity   : SECURITY_WARNING,
      extra      : report
  );
  exit(0);
}
else
{
  audit(AUDIT_HOST_NOT, 'affected');
}

Data

Build on a solid foundation with Vulners data

We provide the essential building blocks for cybersecurity solutions with comprehensive, structured, and constantly updated vulnerability and exploits data

Api

Power your application with Vulners API

The Vulners REST API offers reliable, high-performance access to vulnerability intelligence, with 99.9% SLA uptime and CDN-backed data delivery for seamless global access

App

Assess and manage vulnerabilities with Vulners tools

Built on top of Vulners' database and SDK, end-user solutions give security professionals and developers lightweight and powerful tools for vulnerability remediation

10 Sep 2025 00:00Current
6.6Medium risk
Vulners AI Score6.6
CVSS 25.8
CVSS 3.13.1 - 6.1
EPSS0.17067
1