Skip to content

Conversation

nejidevelops
Copy link
Owner

snyk-top-banner

Snyk has created this PR to upgrade react-scripts from 4.0.1 to 4.0.3.

ℹ️ Keep your dependencies up-to-date. This makes it easier to fix existing vulnerabilities and to more quickly identify and fix newly disclosed vulnerabilities when they affect your project.


  • The recommended version is 2 versions ahead of your current version.

  • The recommended version was released 5 years ago.

Issues fixed by the recommended upgrade:

Issue Score Exploit Maturity
high severity Improper Handling of Extra Parameters
SNYK-JS-FOLLOWREDIRECTS-6141137
230 Proof of Concept
high severity Prototype Pollution
SNYK-JS-IMMER-1019369
230 Proof of Concept
high severity Server-side Request Forgery (SSRF)
SNYK-JS-IP-6240864
230 Proof of Concept
high severity Improper Input Validation
SNYK-JS-URLPARSE-2407770
230 Proof of Concept
high severity Prototype Pollution
SNYK-JS-ASYNC-2441827
230 Proof of Concept
high severity Asymmetric Resource Consumption (Amplification)
SNYK-JS-BODYPARSER-7926860
230 No Known Exploit
high severity Remote Memory Exposure
SNYK-JS-DNSPACKET-1293563
230 No Known Exploit
medium severity Improper Handling of Unexpected Data Type
SNYK-JS-ONHEADERS-10773729
230 No Known Exploit
medium severity Regular Expression Denial of Service (ReDoS)
SNYK-JS-PATHTOREGEXP-7925106
230 Proof of Concept
medium severity Regular Expression Denial of Service (ReDoS)
SNYK-JS-PATHTOREGEXP-8482416
230 Proof of Concept
medium severity Information Exposure
SNYK-JS-EVENTSOURCE-2823375
230 Proof of Concept
medium severity Open Redirect
SNYK-JS-EXPRESS-6474509
230 No Known Exploit
medium severity Cross-site Scripting
SNYK-JS-EXPRESS-7926867
230 No Known Exploit
medium severity Information Exposure
SNYK-JS-FOLLOWREDIRECTS-2332181
230 Proof of Concept
medium severity Information Exposure
SNYK-JS-FOLLOWREDIRECTS-6444610
230 Proof of Concept
medium severity Improper Input Validation
SNYK-JS-URLPARSE-1078283
230 No Known Exploit
medium severity Open Redirect
SNYK-JS-URLPARSE-1533425
230 Proof of Concept
medium severity Access Restriction Bypass
SNYK-JS-URLPARSE-2401205
230 Proof of Concept
medium severity Authorization Bypass
SNYK-JS-URLPARSE-2407759
230 Proof of Concept
medium severity Authorization Bypass Through User-Controlled Key
SNYK-JS-URLPARSE-2412697
230 Proof of Concept
medium severity Command Injection
SNYK-JS-REACTDEVUTILS-1083268
230 Proof of Concept
medium severity Cross-site Scripting (XSS)
SNYK-JS-COOKIE-8163060
230 No Known Exploit
low severity Information Exposure
SNYK-JS-FOLLOWREDIRECTS-2396346
230 No Known Exploit
low severity Cross-site Scripting
SNYK-JS-SEND-7926862
230 No Known Exploit
low severity Cross-site Scripting
SNYK-JS-SERVESTATIC-7926865
230 No Known Exploit
critical severity Incomplete List of Disallowed Inputs
SNYK-JS-BABELTRAVERSE-5962462
230 Proof of Concept
Release notes
Package name: react-scripts
  • 4.0.3 - 2021-02-22
  • 4.0.2 - 2021-02-03
  • 4.0.1 - 2020-11-23
from react-scripts GitHub release notes

Important

  • Check the changes in this PR to ensure they won't cause issues with your project.
  • This PR was automatically created by Snyk using the credentials of a real user.
  • Max score is 1000. Note that the real score may have changed since the PR was raised.

Note: You are seeing this because you or someone else with access to this repository has authorized Snyk to open upgrade PRs.

For more information:

Snyk has created this PR to upgrade react-scripts from 4.0.1 to 4.0.3.

See this package in npm:
react-scripts

See this project in Snyk:
https://app.snyk.io/org/newtonombese1/project/d8f549f8-a2b9-4731-b64b-a65d1dfc20bb?utm_source=github&utm_medium=referral&page=upgrade-pr
Copy link

@gemini-code-assist gemini-code-assist bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Summary of Changes

Hello @nejidevelops, I'm Gemini Code Assist1! I'm currently reviewing this pull request and will post my feedback shortly. In the meantime, here's a summary to help you and other reviewers quickly get up to speed!

This pull request focuses on improving the project's security posture by updating a key development dependency. The upgrade is essential for patching identified vulnerabilities and maintaining the application's resilience against potential security threats.

Highlights

  • Dependency Upgrade: Upgraded the react-scripts package from version 4.0.1 to 4.0.3.
  • Security Vulnerability Resolution: This upgrade addresses a total of 26 security vulnerabilities across various severity levels, including critical, high, medium, and low. These fixes mitigate risks such as Prototype Pollution, Server-side Request Forgery (SSRF), Cross-site Scripting (XSS), and Regular Expression Denial of Service (ReDoS).
Using Gemini Code Assist

The full guide for Gemini Code Assist can be found on our documentation page, here are some quick tips.

Invoking Gemini

You can request assistance from Gemini at any point in your pull request via creating an issue comment (i.e. comment on the pull request page) using either /gemini <command> or @gemini-code-assist <command>. Below is a summary of the supported commands.

Feature Command Description
Code Review /gemini review Performs a code review for the current pull request in its current state.
Pull Request Summary /gemini summary Provides a summary of the current pull request in its current state.
Comment @gemini-code-assist Responds in comments when explicitly tagged, both in issue comments and review comments.
Help /gemini help Displays a list of available commands.

Customization

To customize Gemini Code Assist for GitHub experience, repository maintainers can create a configuration file and/or provide a custom code review style guide (such as PEP-8 for Python) by creating and adding files to a .gemini/ folder in the base of the repository. Detailed instructions can be found here.

Limitations & Feedback

Gemini Code Assist may make mistakes. Please leave feedback on any instances where its feedback is incorrect or counter productive. You can react with 👍 and 👎 on @gemini-code-assist comments. If you're interested in giving your feedback about your experience with Gemini Code Assist for Github and other Google products, sign up here.

You can also get AI-powered code generation, chat, as well as code reviews directly in the IDE at no cost with the Gemini Code Assist IDE Extension.

Footnotes

  1. Review the Privacy Notices, Generative AI Prohibited Use Policy, Terms of Service, and learn how to configure Gemini Code Assist in GitHub here. Gemini can make mistakes, so double check it and use code with caution.

Copy link

@gemini-code-assist gemini-code-assist bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Code Review

This pull request, generated by Snyk, upgrades react-scripts from 4.0.1 to 4.0.3 to address several security vulnerabilities. This is a positive and necessary change. My review includes two main points for further improvement. First, I've raised a high-severity concern about the age of react-scripts v4 and strongly recommend planning an upgrade to the latest major version (v5) for better security and maintainability. Second, I've suggested using a caret range for the react-scripts version in package.json to automatically receive future security patches within the v4 branch.

"react": "^17.0.1",
"react-dom": "^17.0.1",
"react-scripts": "4.0.1"
"react-scripts": "4.0.3"

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

high

While upgrading react-scripts to 4.0.3 is a good step to patch the listed vulnerabilities, this version is still very old (released in 2021), and the entire [email protected] major version is outdated. The latest stable version is 5.x.x.

Staying on an old major version poses a significant maintenance and security risk, as you might be missing out on:

  • Critical security patches for vulnerabilities discovered after this version was released.
  • Major dependency upgrades like Webpack 5, Jest 27, and ESLint 8, which bring performance improvements and bug fixes.
  • Support for modern JavaScript features.

I strongly recommend creating a follow-up task to upgrade to the latest major version of react-scripts. This is a breaking change and will require careful testing, but it is crucial for the long-term health of the application. You can find more information in the Create React App documentation on updating to new releases.

"react": "^17.0.1",
"react-dom": "^17.0.1",
"react-scripts": "4.0.1"
"react-scripts": "4.0.3"

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

medium

You are pinning the exact version of react-scripts. While this ensures deterministic builds, it also prevents you from automatically receiving important patch updates, like this security fix. Consider using a caret (^) to allow for non-breaking patch and minor updates. This would help you get future security patches within the v4.x range automatically and aligns with how other dependencies like react and react-dom are configured in this file.

Suggested change
"react-scripts": "4.0.3"
"react-scripts": "^4.0.3"

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants