Update dependency swagger-ui to v4 [SECURITY] #5
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This PR contains the following updates:
^3.13.6
->^4.0.0
GitHub Vulnerability Alerts
GHSA-x9p2-fxq6-2m5f
Versions of
swagger-ui
prior to 3.18.0 are vulnerable to Reverse Tabnapping. The package usestarget='_blank'
in anchor tags, allowing attackers to accesswindow.opener
for the original page. This is commonly used for phishing attacks.Recommendation
Upgrade to version 3.18.0 or later.
CVE-2019-17495
A Cascading Style Sheets (CSS) injection vulnerability in Swagger UI before 3.23.11 allows attackers to use the Relative Path Overwrite (RPO) technique to perform CSS-based input field value exfiltration, such as exfiltration of a CSRF token value. In other words, this product intentionally allows the embedding of untrusted JSON data from remote servers, but it was not previously known that <style>@import within the JSON data was a functional attack method.
GHSA-4f9m-pxwh-68hg
Versions of
swagger-ui
prior to 3.20.9 are vulnerable to Cross-Site Scripting (XSS). The package fails to sanitize URLs used in the OAuth auth flow, which may allow attackers to execute arbitrary JavaScript.Recommendation
Upgrade to version 3.20.9 or later.
GHSA-qrmm-w75w-3wpx
SwaggerUI supports displaying remote OpenAPI definitions through the
?url
parameter. This enables robust demonstration capabilities on sites likepetstore.swagger.io
,editor.swagger.io
, and similar sites, where users often want to see what their OpenAPI definitions would look like rendered.However, this functionality may pose a risk for users who host their own SwaggerUI instances. In particular, including remote OpenAPI definitions opens a vector for phishing attacks by abusing the trusted names/domains of self-hosted instances.
An example scenario abusing this functionality could take the following form:
https://example.com/api-docs
hosts a version of SwaggerUI with?url=
query parameter enabled.https://example.com
and the contents of the OpenAPI definition.https://evildomain
.https://example.com/api-docs?url=https://evildomain/fakeapi.yaml
and enters sensitive data via the "Try-it-out" feature.We do want to stress that this attack vector is limited to scenarios that actively trick users into divulging sensitive information. The ease of this is highly contextual and, therefore, the threat model may be different for individual users and organizations. It is not possible to perform non-interactive attacks (e.g., cross-site scripting or code injection) through this mechanism.
Resolution
We've made the decision to disable query parameters (#4872) by default starting with SwaggerUI version
4.1.3
. Please update to this version when it becomes available (ETA: 2021 December). Users will still be able to be re-enable the options at their discretion. We'll continue to enable query parameters on the Swagger demo sites.Workaround
If you host a version of SwaggerUI and wish to mitigate this issue immediately, you are encouraged to add the following custom plugin code:
Future UX work
Through the exploration of this issue, it became apparent that users may not be aware to which web server the Try-it-out function will send requests. While this information is currently presented at the top of the page, understanding may improve by displaying it closer to the "Execute" button where requests are actually made. We'll be exploring these UX improvements over the coming months and welcome community input. Please create a Feature Request under the GitHub Issue tab to start a conversation with us and the community.
Reflected XSS attack
Warning in versions < 3.38.0, it is possible to combine the URL options (as mentioned above) with a vulnerability in DOMPurify (https://www.cvedetails.com/cve/CVE-2020-26870/) to create a reflected XSS vector. If your version of Swagger UI is older than 3.38.0, we suggest you upgrade or implement the workaround as mentioned above.
CVE-2018-25031
Swagger UI before 4.1.3 could allow a remote attacker to conduct spoofing attacks. By persuading a victim to open a crafted URL, an attacker could exploit this vulnerability to display remote OpenAPI definitions.
Release Notes
swagger-api/swagger-ui (swagger-ui)
v4.1.3
: Swagger UI v4.1.3 Released!Compare Source
Bug Fixes
v4.1.2
: Swagger UI v4.1.2 Released!Compare Source
Bug Fixes
v4.1.1
: Swagger UI v4.1.1 Released!Compare Source
Bug Fixes
v4.1.0
: Swagger UI v4.1.0 Released!Compare Source
Bug Fixes
Features
v4.0.1
: Swagger UI v4.0.1 Released!Compare Source
Bug Fixes
v4.0.0
: Swagger UI v4.0.0 Released!Compare Source
Breaking changes
Features
Bug Fixes
Other changes
More information in: https://github.com/swagger-api/swagger-ui/issues/7341
Release article: https://swagger.io/blog/news/what-s-new-in-swaggerui-v4-and-swaggereditor-v4/
v3.52.5
: Swagger UI v3.52.5 Released!Compare Source
Bug Fixes
v3.52.4
: Swagger UI v3.52.4 Released!Compare Source
Bug Fixes
<wbr>
(#7516) (f88334a), closes #7513v3.52.3
: Swagger UI v3.52.3 Released!Compare Source
Bug Fixes
v3.52.2
: Swagger UI v3.52.2 Released!Compare Source
Bug Fixes
v3.52.1
: Swagger UI v3.52.1 Released!Compare Source
Bug Fixes
v3.52.0
: Swagger UI v3.52.0 Released!Compare Source
Features
v3.51.2
: Swagger UI v3.51.2 Released!Compare Source
Bug Fixes
v3.51.1
: Swagger UI v3.51.1 Released!Compare Source
Bug Fixes
v3.51.0
: Swagger UI v3.51.0 Released!Compare Source
Features
Bug Fixes
name
(#7123) (3a0f72f)Deprecation Warning
Swagger UI now requires Node.js v12. Node.js v10 has reached its EOL on 30-04-2021. Documentation has been updated in this PR #7359
v3.50.0
: Swagger UI v3.50.0 Released!Compare Source
Features
chain
configuration option (#7236) (516e666)Bug Fixes
Deprecation warning
legacy
, with an opt-in setting forchain
. In a future version, this configuration option will toggle tochain
as default, as it is the intended fixed correct behavior. If your application expects and/or requires thelegacy
option, please update your application accordingly. If your application is agnostic towards the eitherchain
orlegacy
, no change is needed.v3.49.0
: Swagger UI v3.49.0 Released!Compare Source
Features
Bug Fixes
v3.48.0
: Swagger UI v3.48.0 Released!Compare Source
Bug Fixes
Features
v3.47.1
: Swagger UI v3.47.1 Released!Compare Source
[email protected] was a valid but incomplete release. This release should contain downstream release jobs.
v3.47.0
: Swagger UI v3.47.0 Released!Compare Source
Features
Bug Fixes
v3.46.0
: Swagger UI v3.46.0 Released!Compare Source
Features
Bug Fixes
Other
v3.45.1
: Swagger UI v3.45.1 Released!Compare Source
Bug Fixes
v3.45.0
: Swagger UI v3.45.0 Released!Compare Source
Features
Bug Fixes
v3.44.1
: Swagger UI v3.44.1 Released!Compare Source
Bug Fixes
v3.44.0
: Swagger UI v3.44.0 Released!Compare Source
Bug Fixes
script
tag inbody
in oauth2-redirect.html (#6958)Features
v3.43.0
: Swagger UI v3.43.0 Released!Compare Source
Features
Bug Fixes
Other
swagger-cllient: version bump to 3.13.1
v3.42.0
: Swagger UI v3.42.0 Released!Compare Source
Features
Bug Fixes
v3.41.1
: Swagger UI v3.41.1 Released!Compare Source
Bug Fixes
v3.41.0
: Swagger UI v3.41.0 Released!Compare Source
Features
Bug Fixes
v3.40.0
: Swagger UI v3.40.0 Released!Compare Source
Features
Bug Fixes
v3.39.0
: Swagger UI v3.39.0 Released!Compare Source
Features
Bug Fixes
v3.38.0
: Swagger UI v3.38.0 Released!Compare Source
Features
Bug Fixes
[email protected]
,[email protected]
, and[email protected]
v3.37.2
: Swagger UI v3.37.2 Released!Compare Source
d3fb9ab
)v3.37.1
: Swagger UI v3.37.1 Released!Compare Source
Warning
This is a failed release which is identical to v3.37.0. Please install v3.37.2 instead.
v3.37.0
: Swagger UI v3.37.0 Released!Compare Source
Features
Bug Fixes
v3.36.2
: Swagger UI v3.36.2 Released!Compare Source
Bug Fixes
v3.36.1
: Swagger UI v3.36.1 Released!Compare Source
nested allOf/oneOf schema resolution
in #5194, #5923, #4672Bug Fixes
v3.36.0
: Swagger UI v3.36.0 Released!Compare Source
Features
Bug Fixes
v3.35.2
: Swagger UI v3.35.2 Released!Compare Source
Bug Fixes
oas3: switching media types should update schema properties (#6518) (3905fad), closes #6201 #6250 #6476
requestBody: hide read only properties (#6490) (5065613)
missing commas in response header values #6183 (#6515) (99fda81)
add autofocus to auth fields (#6483) (65ea764)
style: preventing long strings from overflowing (#5934) (#6507) (4b2fddd)
jest: add stub for errActions to prevent unhandled promise rejections #6365 (#6495) (537ad6d)
jest: unknown prop initialValue on input tag (#6506) (1af8678)
v3.35.1
: Swagger UI v3.35.1 Released!Compare Source
Bug Fixes
parameter-row: rendering of default/example values of 0 (#6454) (797929f)
syntax-highlighter: configuration for Examples (#6455) (b5e8081), closes #5259
examples multipart array sample generation for items (#6461) (f4bdf2f)
filter: avoid filtering by the strings "true/false" when enabled (#6477) (aa53ec2)
style: inconsistent background colors in code sections (#6472) (1b11d5c)
deprecate from "new Buffer" to "Buffer.from" (#6489) (6c5e91d)
v3.35.0
: Swagger UI v3.35.0 Released!Compare Source
Bug Fixes
Features
v3.34.0
: Swagger UI v3.34.0 Released!Compare Source
Features
Refactor
v3.33.0
: Swagger UI v3.33.0 Released!Compare Source
Bug Fixes
$
(#6354) (89d57fc)entrySeq()
tobodyProperties.map()
(#6267) (0199b47)Configuration
📅 Schedule: Branch creation - "" (UTC), Automerge - At any time (no schedule defined).
🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.
♻ Rebasing: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.
🔕 Ignore: Close this PR and you won't be reminded about this update again.
Branch Conflicts?
♻ To rebase this PR, add the label
Run Renovate
to this PR