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(backend): Preserve url protocol when joining paths #2745

Merged
merged 1 commit into from
Feb 7, 2024

Conversation

panteliselef
Copy link
Member

@panteliselef panteliselef commented Feb 7, 2024

Description

Internally when joinPaths was used to join strings that included a url protocol like https:// the utility function would remove the duplicate / from the protocol resulting in a string with this form 'https:/api.lclclerk.com/v1/organizations/org_2YRy2Bcrc05EMTY0nMY3qHTjbwj'

When this string was passed in a URL constructor like new URL(...) the URL would either be fixed automatically or throw an "Invalid URL" error.

I believe it came down to node version and different implementations of the URL class under the hood. In any case this PR ensures that absolute url string that is generated from joinPaths will keep the protocol intact.

Fixes #2706

Checklist

  • npm test runs as expected.
  • npm run build runs as expected.
  • (If applicable) JSDoc comments have been added or updated for any package exports
  • (If applicable) Documentation has been updated

Type of change

  • 🐛 Bug fix
  • 🌟 New feature
  • 🔨 Breaking change
  • 📖 Refactoring / dependency upgrade / documentation
  • other:

Packages affected

  • @clerk/backend
  • @clerk/chrome-extension
  • @clerk/clerk-js
  • @clerk/clerk-expo
  • @clerk/fastify
  • gatsby-plugin-clerk
  • @clerk/localizations
  • @clerk/nextjs
  • @clerk/clerk-react
  • @clerk/remix
  • @clerk/clerk-sdk-node
  • @clerk/shared
  • @clerk/themes
  • @clerk/types
  • build/tooling/chore

Copy link

changeset-bot bot commented Feb 7, 2024

🦋 Changeset detected

Latest commit: f0e076d

The changes in this PR will be included in the next version bump.

This PR includes changesets to release 6 packages
Name Type
@clerk/backend Patch
@clerk/fastify Patch
gatsby-plugin-clerk Patch
@clerk/nextjs Patch
@clerk/remix Patch
@clerk/clerk-sdk-node Patch

Not sure what this means? Click here to learn what changesets are.

Click here if you're a maintainer who wants to add another changeset to this PR

@panteliselef
Copy link
Member Author

Solves #2706

Copy link
Contributor

@dimkl dimkl left a comment

Choose a reason for hiding this comment

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

🤔 Even though we should apply the change in this PR since it fixes the URL, It seems that we haven't done any change in this part of the code for a lot of time and the current code works for node@v16, node@v18, node@v20.

❯ nvm exec 16 node -e 'console.log(new URL("https:/api.clerk.com/v1/organizations/org_xxxxxxxxxxxxxxxxx/"))'
Running node v16.19.0 (npm v9.2.0)
URL {
  href: 'https://api.clerk.com/v1/organizations/org_xxxxxxxxxxxxxxxxx/',
  origin: 'https://api.clerk.com/',
  protocol: 'https:',
  username: '',
  password: '',
  host: 'api.clerk.com',
  hostname: 'api.clerk.com',
  port: '',
  pathname: '/v1/organizations/org_xxxxxxxxxxxxxxxxx/',
  search: '',
  searchParams: URLSearchParams {},
  hash: ''
}
❯ nvm exec 18 node -e 'console.log(new URL("https:/api.clerk.com/v1/organizations/org_xxxxxxxxxxxxxxxxx/"))'
Running node v18.18.2 (npm v9.8.1)
URL {
  href: 'https://api.clerk.com/v1/organizations/org_xxxxxxxxxxxxxxxxx/',
  origin: 'https://api.clerk.com/',
  protocol: 'https:',
  username: '',
  password: '',
  host: 'api.clerk.com',
  hostname: 'api.clerk.com',
  port: '',
  pathname: '/v1/organizations/org_xxxxxxxxxxxxxxxxx/',
  search: '',
  searchParams: URLSearchParams {},
  hash: ''
}
❯ nvm exec 20 node -e 'console.log(new URL("https:/api.clerk.com/v1/organizations/org_xxxxxxxxxxxxxxxxx/"))'
Running node v20.9.0 (npm v10.1.0)
URL {
  href: 'https://api.clerk.com/v1/organizations/org_xxxxxxxxxxxxxxxxx/',
  origin: 'https://api.clerk.com/',
  protocol: 'https:',
  username: '',
  password: '',
  host: 'api.clerk.com',
  hostname: 'api.clerk.com',
  port: '',
  pathname: '/v1/organizations/org_xxxxxxxxxxxxxxxxx/',
  search: '',
  searchParams: URLSearchParams {},
  hash: ''
}

@panteliselef
Copy link
Member Author

Yes, this maybe have to do with edge vs node runtime. I'm still investigating. The fix is valid but I will merge after I've successfully reproduced.

@panteliselef
Copy link
Member Author

!snapshot

1 similar comment
@octoper
Copy link
Member

octoper commented Feb 7, 2024

!snapshot

@octoper octoper force-pushed the elef/SDK-1274-fix-join-paths branch from f98c9ae to f0e076d Compare February 7, 2024 16:06
@octoper
Copy link
Member

octoper commented Feb 7, 2024

!snapshot

@clerk-cookie
Copy link
Collaborator

Hey @octoper - the snapshot version command generated the following package versions:

Package Version
@clerk/backend 1.0.1-snapshot.vf0e076d
@clerk/chrome-extension 1.0.1-snapshot.vf0e076d
@clerk/clerk-js 5.0.1-snapshot.vf0e076d
@clerk/clerk-expo 1.0.1-snapshot.vf0e076d
@clerk/fastify 1.0.1-snapshot.vf0e076d
gatsby-plugin-clerk 5.0.1-snapshot.vf0e076d
@clerk/localizations 2.0.1-snapshot.vf0e076d
@clerk/nextjs 5.0.1-snapshot.vf0e076d
@clerk/clerk-react 5.0.1-snapshot.vf0e076d
@clerk/remix 4.0.1-snapshot.vf0e076d
@clerk/clerk-sdk-node 5.0.1-snapshot.vf0e076d
@clerk/shared 2.0.1-snapshot.vf0e076d
@clerk/themes 2.0.1-snapshot.vf0e076d
@clerk/types 4.0.1-snapshot.vf0e076d

Tip: Use the snippet copy button below to quickly install the required packages.
@clerk/backend

npm i @clerk/[email protected] --save-exact

@clerk/chrome-extension

npm i @clerk/[email protected] --save-exact

@clerk/clerk-js

npm i @clerk/[email protected] --save-exact

@clerk/clerk-expo

npm i @clerk/[email protected] --save-exact

@clerk/fastify

npm i @clerk/[email protected] --save-exact

gatsby-plugin-clerk

npm i [email protected] --save-exact

@clerk/localizations

npm i @clerk/[email protected] --save-exact

@clerk/nextjs

npm i @clerk/[email protected] --save-exact

@clerk/clerk-react

npm i @clerk/[email protected] --save-exact

@clerk/remix

npm i @clerk/[email protected] --save-exact

@clerk/clerk-sdk-node

npm i @clerk/[email protected] --save-exact

@clerk/shared

npm i @clerk/[email protected] --save-exact

@clerk/themes

npm i @clerk/[email protected] --save-exact

@clerk/types

npm i @clerk/[email protected] --save-exact

@panteliselef
Copy link
Member Author

We manage to replicate this in CF workers. It seems like the implementation of the URL constructor does not auto fixe the url as node or browser runtimes do. Thanks @octoper for replicating.

@panteliselef panteliselef added this pull request to the merge queue Feb 7, 2024
Merged via the queue into main with commit c2b9827 Feb 7, 2024
7 checks passed
@panteliselef panteliselef deleted the elef/SDK-1274-fix-join-paths branch February 7, 2024 17:05
panteliselef added a commit that referenced this pull request Feb 7, 2024
github-merge-queue bot pushed a commit that referenced this pull request Feb 7, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

@clerk/backend throws: Invalid URL string
5 participants