Description
@koa/cors npm provides Cross-Origin Resource Sharing (CORS) for koa, a web framework for Node.js. Prior to version 5.0.0, the middleware operates in a way that if an allowed origin is not provided, it will return an `Access-Control-Allow-Origin` header with the value of the origin from the request. This behavior completely disables one of the most crucial elements of browsers - the Same Origin Policy (SOP), this could cause a very serious security threat to the users of this middleware. If such behavior is expected, for instance, when middleware is used exclusively for prototypes and not for production applications, it should be heavily emphasized in the documentation along with an indication of the risks associated with such behavior, as many users may not be aware of it. Version 5.0.0 fixes this vulnerability.
Remediation
References
https://github.com/koajs/cors/security/advisories/GHSA-qxrj-hx23-xp82
https://github.com/koajs/cors/commit/f31dac99f5355c41e7d4dd3c4a80c5f154941a11
Related Vulnerabilities
CVE-2020-2187 Vulnerability in maven package org.jenkins-ci.plugins:ec2
CVE-2017-12611 Vulnerability in maven package org.apache.struts:struts2-core
CVE-2022-45921 Vulnerability in maven package io.fusionauth:fusionauth-java-client
CVE-2023-28670 Vulnerability in maven package com.paul8620.jenkins.plugins:pipeline-aggregator-view
CVE-2022-36922 Vulnerability in maven package org.jenkins-ci.plugins:lucene-search