Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

fix(deps): update dependency path-to-regexp to v8 #73

Open
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

renovate[bot]
Copy link
Contributor

@renovate renovate bot commented Sep 1, 2024

This PR contains the following updates:

Package Change Age Adoption Passing Confidence
path-to-regexp ^6.2.0 -> ^8.0.0 age adoption passing confidence

Release Notes

pillarjs/path-to-regexp (path-to-regexp)

v8.2.0: 8.2.0

Compare Source

Fixed

  • Allowing path-to-regexp to run on older browsers by targeting ES2015
    • Target ES2015 5969033
      • Also saved 0.22kb (10%!) by removing the private class field down level
    • Remove s flag from regexp 51dbd45

v8.1.0

Compare Source

Added

  • Adds pathToRegexp method back for generating a regex
  • Adds stringify method for converting TokenData into a path string

v8.0.0: Simpler API

Compare Source

Heads up! This is a fairly large change (again) and I need to apologize in advance. If I foresaw what this version would have ended up being I would not have released version 7. A longer blog post and explanation will be incoming this week, but the pivot has been due to work on Express.js v5 and this will the finalized syntax used in Express moving forward.

Added

  • Adds key names to wildcards using *name syntax, aligns with : behavior but using an asterisk instead

Changed

  • Removes group suffixes of ?, +, and * - only optional exists moving forward (use wildcards for +, {*foo} for *)
  • Parameter names follow JS identifier rules and allow unicode characters

Added

  • Parameter names can now be quoted, e.g. :"foo-bar"

Removed

  • Removes loose mode
  • Removes regular expression overrides of parameters

v7.2.0: Support array inputs (again)

Compare Source

Added

  • Support array inputs for match and pathToRegexp 3fdd88f

v7.1.0: Strict mode

Compare Source

Added

  • Adds a strict option to detect potential ReDOS issues

Fixed

  • Fixes separator to default to suffix + prefix when not specified
  • Allows separator to be undefined in TokenData
    • This is only relevant if you are building TokenData manually, previously parse filled it in automatically

Comments

  • I highly recommend enabling strict: true and I'm probably releasing a V8 with it enabled by default ASAP as a necessary security mitigation

v7.0.0: Wildcard, unicode, and modifier changes

Compare Source

Hi all! There's a few major breaking changes in this release so read carefully.

Breaking changes:

  • The function returned by compile only accepts strings as values (i.e. no numbers, use String(value) before compiling a path)
    • For repeated values, when encode !== false, it must be an array of strings
  • Parameter names can contain all unicode identifier characters (defined as regex \p{XID_Continue}).
  • Modifiers (?, *, +) must be used after a param explicitly wrapped in {}
    • No more implied prefix of / or .
  • No support for arrays or regexes as inputs
  • The wildcard (standalone *) has been added back and matches Express.js expected behavior
  • Removed endsWith option
  • Renamed strict: true to trailing: false
  • Reserved ;, ,, !, and @ for future use-cases
  • Removed tokensToRegexp, tokensToFunction and regexpToFunction in favor of simplifying exports
  • Enable a "loose" mode by default, so / can be repeated multiple times in a matched path (i.e. /foo works like //foo, etc)
  • encode and decode no longer receive the token as the second parameter
  • Removed the ESM + CommonJS dual package in favor of only one CommonJS supported export
  • Minimum JS support for ES2020 (previous ES2015)
  • Encode defaults to encodeURIComponent and decode defaults to decodeURIComponent

Added:

  • Adds encodePath to fix an issue around encode being used for both path and parameters (the path and parameter should be encoded slightly differently)
  • Adds loose as an option to support arbitrarily matching the delimiter in paths, e.g. foo/bar and foo///bar should work the same
  • Allow encode and decode to be set to false which skips all processing of the parameters input/output
  • All remaining methods support TokenData (exported, returned by parse) as input
    • This should be useful if you are programmatically building paths to match or want to avoid parsing multiple times

Requests for feedback:

  • Requiring {} is an obvious drawback but I'm seeking feedback on whether it helps make path behavior clearer
    • Related: Removing / and . as implicit prefixes
  • Removing array and regex support is to reduce the overall package size for things many users don't need
  • Unicode IDs are added to align more closely with browser URLPattern behavior, which uses JS identifiers

Configuration

📅 Schedule: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).

🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.

Rebasing: Whenever PR is behind base branch, or you tick the rebase/retry checkbox.

🔕 Ignore: Close this PR and you won't be reminded about this update again.


  • If you want to rebase/retry this PR, check this box

This PR was generated by Mend Renovate. View the repository job log.

@renovate renovate bot force-pushed the renovate/path-to-regexp-8.x branch 5 times, most recently from 95235c1 to 08bc9c3 Compare September 6, 2024 04:10
@renovate renovate bot changed the title fix(deps): update dependency path-to-regexp to v8 fix(deps): update dependency path-to-regexp to v8 - autoclosed Sep 9, 2024
@renovate renovate bot closed this Sep 9, 2024
@renovate renovate bot deleted the renovate/path-to-regexp-8.x branch September 9, 2024 21:44
@renovate renovate bot changed the title fix(deps): update dependency path-to-regexp to v8 - autoclosed fix(deps): update dependency path-to-regexp to v8 Sep 11, 2024
@renovate renovate bot restored the renovate/path-to-regexp-8.x branch September 11, 2024 18:26
@renovate renovate bot reopened this Sep 11, 2024
@renovate renovate bot force-pushed the renovate/path-to-regexp-8.x branch from 08bc9c3 to 9620d3d Compare September 11, 2024 18:26
@renovate renovate bot changed the title fix(deps): update dependency path-to-regexp to v8 fix(deps): update dependency path-to-regexp to v8 - autoclosed Sep 11, 2024
@renovate renovate bot closed this Sep 11, 2024
@renovate renovate bot deleted the renovate/path-to-regexp-8.x branch September 11, 2024 21:13
@renovate renovate bot changed the title fix(deps): update dependency path-to-regexp to v8 - autoclosed fix(deps): update dependency path-to-regexp to v8 Sep 12, 2024
@renovate renovate bot reopened this Sep 12, 2024
@renovate renovate bot restored the renovate/path-to-regexp-8.x branch September 12, 2024 18:36
@renovate renovate bot changed the title fix(deps): update dependency path-to-regexp to v8 fix(deps): update dependency path-to-regexp to v8 - autoclosed Sep 12, 2024
@renovate renovate bot closed this Sep 12, 2024
@renovate renovate bot deleted the renovate/path-to-regexp-8.x branch September 12, 2024 23:18
@renovate renovate bot changed the title fix(deps): update dependency path-to-regexp to v8 - autoclosed fix(deps): update dependency path-to-regexp to v8 Sep 13, 2024
@renovate renovate bot reopened this Sep 13, 2024
@renovate renovate bot restored the renovate/path-to-regexp-8.x branch September 13, 2024 00:08
@renovate renovate bot force-pushed the renovate/path-to-regexp-8.x branch 5 times, most recently from e971f70 to 18bcf6e Compare September 16, 2024 18:33
@renovate renovate bot force-pushed the renovate/path-to-regexp-8.x branch 6 times, most recently from ce81930 to 132b5d0 Compare September 27, 2024 21:59
@renovate renovate bot force-pushed the renovate/path-to-regexp-8.x branch 3 times, most recently from 26a2df5 to ddaab79 Compare October 8, 2024 02:03
@renovate renovate bot force-pushed the renovate/path-to-regexp-8.x branch 3 times, most recently from 5cc23c8 to 16f7a05 Compare October 19, 2024 13:37
@renovate renovate bot force-pushed the renovate/path-to-regexp-8.x branch 4 times, most recently from 5c7ae6e to 5a9ab4d Compare October 30, 2024 19:43
@renovate renovate bot force-pushed the renovate/path-to-regexp-8.x branch 2 times, most recently from cdec1a1 to a4fc06b Compare November 7, 2024 00:29
@renovate renovate bot force-pushed the renovate/path-to-regexp-8.x branch 2 times, most recently from 9698512 to 6b3cfbc Compare November 17, 2024 22:52
@renovate renovate bot force-pushed the renovate/path-to-regexp-8.x branch 2 times, most recently from d1a7d4c to 5542448 Compare November 26, 2024 03:53
@renovate renovate bot force-pushed the renovate/path-to-regexp-8.x branch from 5542448 to 904d8ab Compare December 2, 2024 23:25
@renovate renovate bot force-pushed the renovate/path-to-regexp-8.x branch 3 times, most recently from b8c0bea to c8b30d6 Compare January 3, 2025 19:43
@renovate renovate bot force-pushed the renovate/path-to-regexp-8.x branch 2 times, most recently from 38985e3 to 4281d8e Compare January 15, 2025 02:18
@renovate renovate bot force-pushed the renovate/path-to-regexp-8.x branch from 4281d8e to a43e18f Compare January 16, 2025 08:33
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.

1 participant