From b3300c84a42276bd071a37addbd1ca6888ed9d7c Mon Sep 17 00:00:00 2001 From: Laura Beatris <48022589+LauraBeatris@users.noreply.github.com> Date: Wed, 18 Dec 2024 12:59:36 -0300 Subject: [PATCH 1/7] chore(backend): Introduce SAML connections per org (#4792) Co-authored-by: Izaak Lauer <8404559+izaaklauer@users.noreply.github.com> --- .changeset/kind-crews-hear.md | 7 +++++++ packages/backend/src/api/endpoints/SamlConnectionApi.ts | 2 ++ packages/backend/src/api/resources/JSON.ts | 1 + packages/backend/src/api/resources/SamlConnection.ts | 2 ++ 4 files changed, 12 insertions(+) create mode 100644 .changeset/kind-crews-hear.md diff --git a/.changeset/kind-crews-hear.md b/.changeset/kind-crews-hear.md new file mode 100644 index 0000000000..63bece9029 --- /dev/null +++ b/.changeset/kind-crews-hear.md @@ -0,0 +1,7 @@ +--- +'@clerk/backend': patch +--- + +Allow to create and update SAML connections with organization IDs. + +When users sign in or up using an organization's SAML connection, they're automatically added as members of that organization. For more information, refer to our docs: https://clerk.com/docs/organizations/manage-sso diff --git a/packages/backend/src/api/endpoints/SamlConnectionApi.ts b/packages/backend/src/api/endpoints/SamlConnectionApi.ts index 58671806c6..9ac17c2cf2 100644 --- a/packages/backend/src/api/endpoints/SamlConnectionApi.ts +++ b/packages/backend/src/api/endpoints/SamlConnectionApi.ts @@ -14,6 +14,7 @@ type CreateSamlConnectionParams = { name: string; provider: SamlIdpSlug; domain: string; + organizationId?: string; idpEntityId?: string; idpSsoUrl?: string; idpCertificate?: string; @@ -31,6 +32,7 @@ type UpdateSamlConnectionParams = { name?: string; provider?: SamlIdpSlug; domain?: string; + organizationId?: string; idpEntityId?: string; idpSsoUrl?: string; idpCertificate?: string; diff --git a/packages/backend/src/api/resources/JSON.ts b/packages/backend/src/api/resources/JSON.ts index 5ef4fb5d2a..0c5c544ba6 100644 --- a/packages/backend/src/api/resources/JSON.ts +++ b/packages/backend/src/api/resources/JSON.ts @@ -360,6 +360,7 @@ export interface PaginatedResponseJSON { export interface SamlConnectionJSON extends ClerkResourceJSON { name: string; domain: string; + organization_id: string | null; idp_entity_id: string; idp_sso_url: string; idp_certificate: string; diff --git a/packages/backend/src/api/resources/SamlConnection.ts b/packages/backend/src/api/resources/SamlConnection.ts index d32f0495f4..e42add44c4 100644 --- a/packages/backend/src/api/resources/SamlConnection.ts +++ b/packages/backend/src/api/resources/SamlConnection.ts @@ -5,6 +5,7 @@ export class SamlConnection { readonly id: string, readonly name: string, readonly domain: string, + readonly organizationId: string | null, readonly idpEntityId: string | null, readonly idpSsoUrl: string | null, readonly idpCertificate: string | null, @@ -28,6 +29,7 @@ export class SamlConnection { data.id, data.name, data.domain, + data.organization_id, data.idp_entity_id, data.idp_sso_url, data.idp_certificate, From 784b50e622f8d203d337f7bd90948a54d19d87cd Mon Sep 17 00:00:00 2001 From: Clerk Cookie <136073014+clerk-cookie@users.noreply.github.com> Date: Wed, 18 Dec 2024 11:23:15 -0500 Subject: [PATCH 2/7] ci(repo): Version packages (#4805) Co-authored-by: github-actions[bot] --- .changeset/kind-crews-hear.md | 7 ------- .changeset/old-dryers-approve.md | 12 ------------ .changeset/shiny-pandas-love.md | 5 ----- packages/astro/CHANGELOG.md | 9 +++++++++ packages/astro/package.json | 2 +- packages/backend/CHANGELOG.md | 12 ++++++++++++ packages/backend/package.json | 2 +- packages/chrome-extension/CHANGELOG.md | 9 +++++++++ packages/chrome-extension/package.json | 2 +- packages/clerk-js/CHANGELOG.md | 9 +++++++++ packages/clerk-js/package.json | 2 +- packages/elements/CHANGELOG.md | 9 +++++++++ packages/elements/package.json | 2 +- packages/expo-passkeys/CHANGELOG.md | 8 ++++++++ packages/expo-passkeys/package.json | 2 +- packages/expo/CHANGELOG.md | 10 ++++++++++ packages/expo/package.json | 2 +- packages/express/CHANGELOG.md | 9 +++++++++ packages/express/package.json | 2 +- packages/fastify/CHANGELOG.md | 9 +++++++++ packages/fastify/package.json | 2 +- packages/localizations/CHANGELOG.md | 7 +++++++ packages/localizations/package.json | 2 +- packages/nextjs/CHANGELOG.md | 10 ++++++++++ packages/nextjs/package.json | 2 +- packages/nuxt/CHANGELOG.md | 10 ++++++++++ packages/nuxt/package.json | 2 +- packages/react-router/CHANGELOG.md | 10 ++++++++++ packages/react-router/package.json | 2 +- packages/react/CHANGELOG.md | 8 ++++++++ packages/react/package.json | 2 +- packages/remix/CHANGELOG.md | 10 ++++++++++ packages/remix/package.json | 2 +- packages/sdk-node/CHANGELOG.md | 9 +++++++++ packages/sdk-node/package.json | 2 +- packages/shared/CHANGELOG.md | 7 +++++++ packages/shared/package.json | 2 +- packages/tanstack-start/CHANGELOG.md | 10 ++++++++++ packages/tanstack-start/package.json | 2 +- packages/testing/CHANGELOG.md | 9 +++++++++ packages/testing/package.json | 2 +- packages/themes/CHANGELOG.md | 7 +++++++ packages/themes/package.json | 2 +- packages/types/CHANGELOG.md | 13 +++++++++++++ packages/types/package.json | 2 +- packages/ui/CHANGELOG.md | 10 ++++++++++ packages/ui/package.json | 2 +- packages/vue/CHANGELOG.md | 10 ++++++++++ packages/vue/package.json | 2 +- 49 files changed, 237 insertions(+), 47 deletions(-) delete mode 100644 .changeset/kind-crews-hear.md delete mode 100644 .changeset/old-dryers-approve.md delete mode 100644 .changeset/shiny-pandas-love.md diff --git a/.changeset/kind-crews-hear.md b/.changeset/kind-crews-hear.md deleted file mode 100644 index 63bece9029..0000000000 --- a/.changeset/kind-crews-hear.md +++ /dev/null @@ -1,7 +0,0 @@ ---- -'@clerk/backend': patch ---- - -Allow to create and update SAML connections with organization IDs. - -When users sign in or up using an organization's SAML connection, they're automatically added as members of that organization. For more information, refer to our docs: https://clerk.com/docs/organizations/manage-sso diff --git a/.changeset/old-dryers-approve.md b/.changeset/old-dryers-approve.md deleted file mode 100644 index 1a6bb174e5..0000000000 --- a/.changeset/old-dryers-approve.md +++ /dev/null @@ -1,12 +0,0 @@ ---- -'@clerk/types': minor ---- - -Adds `oidcLoginHint` & `oidcPrompt` parameters to following types: - -- `ReauthorizeExternalAccountParams` -- `OAuthConfig` -- `SignInCreateParams` -- `PrepareVerificationParams` -- `SignUpCreateParams` -- `CreateExternalAccountParams` diff --git a/.changeset/shiny-pandas-love.md b/.changeset/shiny-pandas-love.md deleted file mode 100644 index 7ac5bf489d..0000000000 --- a/.changeset/shiny-pandas-love.md +++ /dev/null @@ -1,5 +0,0 @@ ---- -"@clerk/vue": patch ---- - -Add `initialValues` option to `` and `` components. diff --git a/packages/astro/CHANGELOG.md b/packages/astro/CHANGELOG.md index 93584a6b28..b5a577c602 100644 --- a/packages/astro/CHANGELOG.md +++ b/packages/astro/CHANGELOG.md @@ -1,5 +1,14 @@ # @clerk/astro +## 2.1.4 + +### Patch Changes + +- Updated dependencies [[`b3300c84a42276bd071a37addbd1ca6888ed9d7c`](https://github.com/clerk/javascript/commit/b3300c84a42276bd071a37addbd1ca6888ed9d7c), [`c9da04636ffe1ba804a1ce5e5b79027d3a2344d2`](https://github.com/clerk/javascript/commit/c9da04636ffe1ba804a1ce5e5b79027d3a2344d2)]: + - @clerk/backend@1.21.4 + - @clerk/types@4.40.0 + - @clerk/shared@2.20.4 + ## 2.1.3 ### Patch Changes diff --git a/packages/astro/package.json b/packages/astro/package.json index 5599e4c27f..d2717b0c2d 100644 --- a/packages/astro/package.json +++ b/packages/astro/package.json @@ -1,6 +1,6 @@ { "name": "@clerk/astro", - "version": "2.1.3", + "version": "2.1.4", "description": "Clerk SDK for Astro", "keywords": [ "auth", diff --git a/packages/backend/CHANGELOG.md b/packages/backend/CHANGELOG.md index 99ef93e94b..071f83fc04 100644 --- a/packages/backend/CHANGELOG.md +++ b/packages/backend/CHANGELOG.md @@ -1,5 +1,17 @@ # Change Log +## 1.21.4 + +### Patch Changes + +- Allow to create and update SAML connections with organization IDs. ([#4792](https://github.com/clerk/javascript/pull/4792)) by [@LauraBeatris](https://github.com/LauraBeatris) + + When users sign in or up using an organization's SAML connection, they're automatically added as members of that organization. For more information, refer to our docs: https://clerk.com/docs/organizations/manage-sso + +- Updated dependencies [[`c9da04636ffe1ba804a1ce5e5b79027d3a2344d2`](https://github.com/clerk/javascript/commit/c9da04636ffe1ba804a1ce5e5b79027d3a2344d2)]: + - @clerk/types@4.40.0 + - @clerk/shared@2.20.4 + ## 1.21.3 ### Patch Changes diff --git a/packages/backend/package.json b/packages/backend/package.json index a4703975ed..f6917d1ba9 100644 --- a/packages/backend/package.json +++ b/packages/backend/package.json @@ -1,6 +1,6 @@ { "name": "@clerk/backend", - "version": "1.21.3", + "version": "1.21.4", "description": "Clerk Backend SDK - REST Client for Backend API & JWT verification utilities", "homepage": "https://clerk.com/", "bugs": { diff --git a/packages/chrome-extension/CHANGELOG.md b/packages/chrome-extension/CHANGELOG.md index eacf9f01c6..e8b5cf2d67 100644 --- a/packages/chrome-extension/CHANGELOG.md +++ b/packages/chrome-extension/CHANGELOG.md @@ -1,5 +1,14 @@ # Change Log +## 2.1.6 + +### Patch Changes + +- Updated dependencies []: + - @clerk/clerk-js@5.43.3 + - @clerk/clerk-react@5.20.4 + - @clerk/shared@2.20.4 + ## 2.1.5 ### Patch Changes diff --git a/packages/chrome-extension/package.json b/packages/chrome-extension/package.json index 7c6fdb1f63..84cb43d456 100644 --- a/packages/chrome-extension/package.json +++ b/packages/chrome-extension/package.json @@ -1,6 +1,6 @@ { "name": "@clerk/chrome-extension", - "version": "2.1.5", + "version": "2.1.6", "description": "Clerk SDK for Chrome extensions", "keywords": [ "auth", diff --git a/packages/clerk-js/CHANGELOG.md b/packages/clerk-js/CHANGELOG.md index e4913b96c6..06857eaca2 100644 --- a/packages/clerk-js/CHANGELOG.md +++ b/packages/clerk-js/CHANGELOG.md @@ -1,5 +1,14 @@ # Change Log +## 5.43.3 + +### Patch Changes + +- Updated dependencies [[`c9da04636ffe1ba804a1ce5e5b79027d3a2344d2`](https://github.com/clerk/javascript/commit/c9da04636ffe1ba804a1ce5e5b79027d3a2344d2)]: + - @clerk/types@4.40.0 + - @clerk/localizations@3.9.4 + - @clerk/shared@2.20.4 + ## 5.43.2 ### Patch Changes diff --git a/packages/clerk-js/package.json b/packages/clerk-js/package.json index b44fdf6829..f870ff517c 100644 --- a/packages/clerk-js/package.json +++ b/packages/clerk-js/package.json @@ -1,6 +1,6 @@ { "name": "@clerk/clerk-js", - "version": "5.43.2", + "version": "5.43.3", "description": "Clerk JS library", "keywords": [ "clerk", diff --git a/packages/elements/CHANGELOG.md b/packages/elements/CHANGELOG.md index 666b3ddef0..26be42b0a5 100644 --- a/packages/elements/CHANGELOG.md +++ b/packages/elements/CHANGELOG.md @@ -1,5 +1,14 @@ # @clerk/elements +## 0.22.4 + +### Patch Changes + +- Updated dependencies [[`c9da04636ffe1ba804a1ce5e5b79027d3a2344d2`](https://github.com/clerk/javascript/commit/c9da04636ffe1ba804a1ce5e5b79027d3a2344d2)]: + - @clerk/types@4.40.0 + - @clerk/clerk-react@5.20.4 + - @clerk/shared@2.20.4 + ## 0.22.3 ### Patch Changes diff --git a/packages/elements/package.json b/packages/elements/package.json index 962279049c..00b7a5b823 100644 --- a/packages/elements/package.json +++ b/packages/elements/package.json @@ -1,6 +1,6 @@ { "name": "@clerk/elements", - "version": "0.22.3", + "version": "0.22.4", "description": "Clerk Elements", "keywords": [ "clerk", diff --git a/packages/expo-passkeys/CHANGELOG.md b/packages/expo-passkeys/CHANGELOG.md index 526295cad8..7d924d25fd 100644 --- a/packages/expo-passkeys/CHANGELOG.md +++ b/packages/expo-passkeys/CHANGELOG.md @@ -1,5 +1,13 @@ # @clerk/expo-passkeys +## 0.1.4 + +### Patch Changes + +- Updated dependencies [[`c9da04636ffe1ba804a1ce5e5b79027d3a2344d2`](https://github.com/clerk/javascript/commit/c9da04636ffe1ba804a1ce5e5b79027d3a2344d2)]: + - @clerk/types@4.40.0 + - @clerk/shared@2.20.4 + ## 0.1.3 ### Patch Changes diff --git a/packages/expo-passkeys/package.json b/packages/expo-passkeys/package.json index 58d3f0678c..6524ba61c5 100644 --- a/packages/expo-passkeys/package.json +++ b/packages/expo-passkeys/package.json @@ -1,6 +1,6 @@ { "name": "@clerk/expo-passkeys", - "version": "0.1.3", + "version": "0.1.4", "description": "Passkeys library to be used with Clerk for expo", "keywords": [ "react-native", diff --git a/packages/expo/CHANGELOG.md b/packages/expo/CHANGELOG.md index 9383307126..f3de5a1a87 100644 --- a/packages/expo/CHANGELOG.md +++ b/packages/expo/CHANGELOG.md @@ -1,5 +1,15 @@ # Change Log +## 2.6.5 + +### Patch Changes + +- Updated dependencies [[`c9da04636ffe1ba804a1ce5e5b79027d3a2344d2`](https://github.com/clerk/javascript/commit/c9da04636ffe1ba804a1ce5e5b79027d3a2344d2)]: + - @clerk/types@4.40.0 + - @clerk/clerk-js@5.43.3 + - @clerk/clerk-react@5.20.4 + - @clerk/shared@2.20.4 + ## 2.6.4 ### Patch Changes diff --git a/packages/expo/package.json b/packages/expo/package.json index 598b9e47a5..7bab782d6b 100644 --- a/packages/expo/package.json +++ b/packages/expo/package.json @@ -1,6 +1,6 @@ { "name": "@clerk/clerk-expo", - "version": "2.6.4", + "version": "2.6.5", "description": "Clerk React Native/Expo library", "keywords": [ "react", diff --git a/packages/express/CHANGELOG.md b/packages/express/CHANGELOG.md index f33eee9091..87fb4d3a05 100644 --- a/packages/express/CHANGELOG.md +++ b/packages/express/CHANGELOG.md @@ -1,5 +1,14 @@ # Change Log +## 1.3.31 + +### Patch Changes + +- Updated dependencies [[`b3300c84a42276bd071a37addbd1ca6888ed9d7c`](https://github.com/clerk/javascript/commit/b3300c84a42276bd071a37addbd1ca6888ed9d7c), [`c9da04636ffe1ba804a1ce5e5b79027d3a2344d2`](https://github.com/clerk/javascript/commit/c9da04636ffe1ba804a1ce5e5b79027d3a2344d2)]: + - @clerk/backend@1.21.4 + - @clerk/types@4.40.0 + - @clerk/shared@2.20.4 + ## 1.3.30 ### Patch Changes diff --git a/packages/express/package.json b/packages/express/package.json index c5d3e42e45..9839ec1fd0 100644 --- a/packages/express/package.json +++ b/packages/express/package.json @@ -1,6 +1,6 @@ { "name": "@clerk/express", - "version": "1.3.30", + "version": "1.3.31", "description": "Clerk server SDK for usage with Express", "keywords": [ "clerk", diff --git a/packages/fastify/CHANGELOG.md b/packages/fastify/CHANGELOG.md index 708671d0df..ee2540469d 100644 --- a/packages/fastify/CHANGELOG.md +++ b/packages/fastify/CHANGELOG.md @@ -1,5 +1,14 @@ # Change Log +## 2.1.4 + +### Patch Changes + +- Updated dependencies [[`b3300c84a42276bd071a37addbd1ca6888ed9d7c`](https://github.com/clerk/javascript/commit/b3300c84a42276bd071a37addbd1ca6888ed9d7c), [`c9da04636ffe1ba804a1ce5e5b79027d3a2344d2`](https://github.com/clerk/javascript/commit/c9da04636ffe1ba804a1ce5e5b79027d3a2344d2)]: + - @clerk/backend@1.21.4 + - @clerk/types@4.40.0 + - @clerk/shared@2.20.4 + ## 2.1.3 ### Patch Changes diff --git a/packages/fastify/package.json b/packages/fastify/package.json index 7fc1e5a87d..b5f024c13b 100644 --- a/packages/fastify/package.json +++ b/packages/fastify/package.json @@ -1,6 +1,6 @@ { "name": "@clerk/fastify", - "version": "2.1.3", + "version": "2.1.4", "description": "Clerk SDK for Fastify", "keywords": [ "auth", diff --git a/packages/localizations/CHANGELOG.md b/packages/localizations/CHANGELOG.md index 2d590c380a..d8e315d481 100644 --- a/packages/localizations/CHANGELOG.md +++ b/packages/localizations/CHANGELOG.md @@ -1,5 +1,12 @@ # Change Log +## 3.9.4 + +### Patch Changes + +- Updated dependencies [[`c9da04636ffe1ba804a1ce5e5b79027d3a2344d2`](https://github.com/clerk/javascript/commit/c9da04636ffe1ba804a1ce5e5b79027d3a2344d2)]: + - @clerk/types@4.40.0 + ## 3.9.3 ### Patch Changes diff --git a/packages/localizations/package.json b/packages/localizations/package.json index c94bdf6e83..756958409b 100644 --- a/packages/localizations/package.json +++ b/packages/localizations/package.json @@ -1,6 +1,6 @@ { "name": "@clerk/localizations", - "version": "3.9.3", + "version": "3.9.4", "description": "Localizations for the Clerk components", "keywords": [ "react", diff --git a/packages/nextjs/CHANGELOG.md b/packages/nextjs/CHANGELOG.md index f5d79b5d77..771ea54798 100644 --- a/packages/nextjs/CHANGELOG.md +++ b/packages/nextjs/CHANGELOG.md @@ -1,5 +1,15 @@ # Change Log +## 6.9.5 + +### Patch Changes + +- Updated dependencies [[`b3300c84a42276bd071a37addbd1ca6888ed9d7c`](https://github.com/clerk/javascript/commit/b3300c84a42276bd071a37addbd1ca6888ed9d7c), [`c9da04636ffe1ba804a1ce5e5b79027d3a2344d2`](https://github.com/clerk/javascript/commit/c9da04636ffe1ba804a1ce5e5b79027d3a2344d2)]: + - @clerk/backend@1.21.4 + - @clerk/types@4.40.0 + - @clerk/clerk-react@5.20.4 + - @clerk/shared@2.20.4 + ## 6.9.4 ### Patch Changes diff --git a/packages/nextjs/package.json b/packages/nextjs/package.json index 05789e758c..b8d2c2573c 100644 --- a/packages/nextjs/package.json +++ b/packages/nextjs/package.json @@ -1,6 +1,6 @@ { "name": "@clerk/nextjs", - "version": "6.9.4", + "version": "6.9.5", "description": "Clerk SDK for NextJS", "keywords": [ "clerk", diff --git a/packages/nuxt/CHANGELOG.md b/packages/nuxt/CHANGELOG.md index 8648f9d13e..5c202b3409 100644 --- a/packages/nuxt/CHANGELOG.md +++ b/packages/nuxt/CHANGELOG.md @@ -1,5 +1,15 @@ # @clerk/nuxt +## 0.1.5 + +### Patch Changes + +- Updated dependencies [[`b3300c84a42276bd071a37addbd1ca6888ed9d7c`](https://github.com/clerk/javascript/commit/b3300c84a42276bd071a37addbd1ca6888ed9d7c), [`c9da04636ffe1ba804a1ce5e5b79027d3a2344d2`](https://github.com/clerk/javascript/commit/c9da04636ffe1ba804a1ce5e5b79027d3a2344d2), [`aeb5855853e5e89a03a1d6ce3d421c3e9870c814`](https://github.com/clerk/javascript/commit/aeb5855853e5e89a03a1d6ce3d421c3e9870c814)]: + - @clerk/backend@1.21.4 + - @clerk/types@4.40.0 + - @clerk/vue@0.1.5 + - @clerk/shared@2.20.4 + ## 0.1.4 ### Patch Changes diff --git a/packages/nuxt/package.json b/packages/nuxt/package.json index 039e490073..b9b098761a 100644 --- a/packages/nuxt/package.json +++ b/packages/nuxt/package.json @@ -1,6 +1,6 @@ { "name": "@clerk/nuxt", - "version": "0.1.4", + "version": "0.1.5", "description": "Clerk SDK for Nuxt", "keywords": [ "clerk", diff --git a/packages/react-router/CHANGELOG.md b/packages/react-router/CHANGELOG.md index 84764dfca4..1efe86f6c4 100644 --- a/packages/react-router/CHANGELOG.md +++ b/packages/react-router/CHANGELOG.md @@ -1,5 +1,15 @@ # Change Log +## 0.1.4 + +### Patch Changes + +- Updated dependencies [[`b3300c84a42276bd071a37addbd1ca6888ed9d7c`](https://github.com/clerk/javascript/commit/b3300c84a42276bd071a37addbd1ca6888ed9d7c), [`c9da04636ffe1ba804a1ce5e5b79027d3a2344d2`](https://github.com/clerk/javascript/commit/c9da04636ffe1ba804a1ce5e5b79027d3a2344d2)]: + - @clerk/backend@1.21.4 + - @clerk/types@4.40.0 + - @clerk/clerk-react@5.20.4 + - @clerk/shared@2.20.4 + ## 0.1.3 ### Patch Changes diff --git a/packages/react-router/package.json b/packages/react-router/package.json index befb2075f5..2b06e010ba 100644 --- a/packages/react-router/package.json +++ b/packages/react-router/package.json @@ -1,6 +1,6 @@ { "name": "@clerk/react-router", - "version": "0.1.3", + "version": "0.1.4", "description": "Clerk SDK for React Router", "keywords": [ "clerk", diff --git a/packages/react/CHANGELOG.md b/packages/react/CHANGELOG.md index 3150367a3f..d43ad52689 100644 --- a/packages/react/CHANGELOG.md +++ b/packages/react/CHANGELOG.md @@ -1,5 +1,13 @@ # Change Log +## 5.20.4 + +### Patch Changes + +- Updated dependencies [[`c9da04636ffe1ba804a1ce5e5b79027d3a2344d2`](https://github.com/clerk/javascript/commit/c9da04636ffe1ba804a1ce5e5b79027d3a2344d2)]: + - @clerk/types@4.40.0 + - @clerk/shared@2.20.4 + ## 5.20.3 ### Patch Changes diff --git a/packages/react/package.json b/packages/react/package.json index d0d6b64ff1..29560d8ff0 100644 --- a/packages/react/package.json +++ b/packages/react/package.json @@ -1,6 +1,6 @@ { "name": "@clerk/clerk-react", - "version": "5.20.3", + "version": "5.20.4", "description": "Clerk React library", "keywords": [ "clerk", diff --git a/packages/remix/CHANGELOG.md b/packages/remix/CHANGELOG.md index 55d92066c4..c0578fbb5e 100644 --- a/packages/remix/CHANGELOG.md +++ b/packages/remix/CHANGELOG.md @@ -1,5 +1,15 @@ # Change Log +## 4.4.5 + +### Patch Changes + +- Updated dependencies [[`b3300c84a42276bd071a37addbd1ca6888ed9d7c`](https://github.com/clerk/javascript/commit/b3300c84a42276bd071a37addbd1ca6888ed9d7c), [`c9da04636ffe1ba804a1ce5e5b79027d3a2344d2`](https://github.com/clerk/javascript/commit/c9da04636ffe1ba804a1ce5e5b79027d3a2344d2)]: + - @clerk/backend@1.21.4 + - @clerk/types@4.40.0 + - @clerk/clerk-react@5.20.4 + - @clerk/shared@2.20.4 + ## 4.4.4 ### Patch Changes diff --git a/packages/remix/package.json b/packages/remix/package.json index baa00dd920..73220e6045 100644 --- a/packages/remix/package.json +++ b/packages/remix/package.json @@ -1,6 +1,6 @@ { "name": "@clerk/remix", - "version": "4.4.4", + "version": "4.4.5", "description": "Clerk SDK for Remix", "keywords": [ "clerk", diff --git a/packages/sdk-node/CHANGELOG.md b/packages/sdk-node/CHANGELOG.md index c580eac292..7bfb860119 100644 --- a/packages/sdk-node/CHANGELOG.md +++ b/packages/sdk-node/CHANGELOG.md @@ -1,5 +1,14 @@ # Change Log +## 5.1.4 + +### Patch Changes + +- Updated dependencies [[`b3300c84a42276bd071a37addbd1ca6888ed9d7c`](https://github.com/clerk/javascript/commit/b3300c84a42276bd071a37addbd1ca6888ed9d7c), [`c9da04636ffe1ba804a1ce5e5b79027d3a2344d2`](https://github.com/clerk/javascript/commit/c9da04636ffe1ba804a1ce5e5b79027d3a2344d2)]: + - @clerk/backend@1.21.4 + - @clerk/types@4.40.0 + - @clerk/shared@2.20.4 + ## 5.1.3 ### Patch Changes diff --git a/packages/sdk-node/package.json b/packages/sdk-node/package.json index 620ac49187..1e32c897d9 100644 --- a/packages/sdk-node/package.json +++ b/packages/sdk-node/package.json @@ -1,6 +1,6 @@ { "name": "@clerk/clerk-sdk-node", - "version": "5.1.3", + "version": "5.1.4", "description": "Clerk server SDK for usage with node", "keywords": [ "clerk", diff --git a/packages/shared/CHANGELOG.md b/packages/shared/CHANGELOG.md index 6b55cf5a8d..f5a4f4a08f 100644 --- a/packages/shared/CHANGELOG.md +++ b/packages/shared/CHANGELOG.md @@ -1,5 +1,12 @@ # Change Log +## 2.20.4 + +### Patch Changes + +- Updated dependencies [[`c9da04636ffe1ba804a1ce5e5b79027d3a2344d2`](https://github.com/clerk/javascript/commit/c9da04636ffe1ba804a1ce5e5b79027d3a2344d2)]: + - @clerk/types@4.40.0 + ## 2.20.3 ### Patch Changes diff --git a/packages/shared/package.json b/packages/shared/package.json index 1e43251a39..37aa9e2014 100644 --- a/packages/shared/package.json +++ b/packages/shared/package.json @@ -1,6 +1,6 @@ { "name": "@clerk/shared", - "version": "2.20.3", + "version": "2.20.4", "description": "Internal package utils used by the Clerk SDKs", "repository": { "type": "git", diff --git a/packages/tanstack-start/CHANGELOG.md b/packages/tanstack-start/CHANGELOG.md index 7605bc49d1..e1ee0bde5c 100644 --- a/packages/tanstack-start/CHANGELOG.md +++ b/packages/tanstack-start/CHANGELOG.md @@ -1,5 +1,15 @@ # @clerk/tanstack-start +## 0.8.4 + +### Patch Changes + +- Updated dependencies [[`b3300c84a42276bd071a37addbd1ca6888ed9d7c`](https://github.com/clerk/javascript/commit/b3300c84a42276bd071a37addbd1ca6888ed9d7c), [`c9da04636ffe1ba804a1ce5e5b79027d3a2344d2`](https://github.com/clerk/javascript/commit/c9da04636ffe1ba804a1ce5e5b79027d3a2344d2)]: + - @clerk/backend@1.21.4 + - @clerk/types@4.40.0 + - @clerk/clerk-react@5.20.4 + - @clerk/shared@2.20.4 + ## 0.8.3 ### Patch Changes diff --git a/packages/tanstack-start/package.json b/packages/tanstack-start/package.json index 81e706f86b..76c69a8687 100644 --- a/packages/tanstack-start/package.json +++ b/packages/tanstack-start/package.json @@ -1,6 +1,6 @@ { "name": "@clerk/tanstack-start", - "version": "0.8.3", + "version": "0.8.4", "description": "Clerk SDK for TanStack Start", "keywords": [ "clerk", diff --git a/packages/testing/CHANGELOG.md b/packages/testing/CHANGELOG.md index cdcba03206..80cbde183f 100644 --- a/packages/testing/CHANGELOG.md +++ b/packages/testing/CHANGELOG.md @@ -1,5 +1,14 @@ # @clerk/testing +## 1.4.4 + +### Patch Changes + +- Updated dependencies [[`b3300c84a42276bd071a37addbd1ca6888ed9d7c`](https://github.com/clerk/javascript/commit/b3300c84a42276bd071a37addbd1ca6888ed9d7c), [`c9da04636ffe1ba804a1ce5e5b79027d3a2344d2`](https://github.com/clerk/javascript/commit/c9da04636ffe1ba804a1ce5e5b79027d3a2344d2)]: + - @clerk/backend@1.21.4 + - @clerk/types@4.40.0 + - @clerk/shared@2.20.4 + ## 1.4.3 ### Patch Changes diff --git a/packages/testing/package.json b/packages/testing/package.json index 00064ef261..2bdda13bb9 100644 --- a/packages/testing/package.json +++ b/packages/testing/package.json @@ -1,6 +1,6 @@ { "name": "@clerk/testing", - "version": "1.4.3", + "version": "1.4.4", "description": "Utilities to help you create E2E test suites for apps using Clerk", "keywords": [ "auth", diff --git a/packages/themes/CHANGELOG.md b/packages/themes/CHANGELOG.md index 975e17b0ea..c27eb7db5a 100644 --- a/packages/themes/CHANGELOG.md +++ b/packages/themes/CHANGELOG.md @@ -1,5 +1,12 @@ # Change Log +## 2.2.3 + +### Patch Changes + +- Updated dependencies [[`c9da04636ffe1ba804a1ce5e5b79027d3a2344d2`](https://github.com/clerk/javascript/commit/c9da04636ffe1ba804a1ce5e5b79027d3a2344d2)]: + - @clerk/types@4.40.0 + ## 2.2.2 ### Patch Changes diff --git a/packages/themes/package.json b/packages/themes/package.json index 324fa18de6..d22b0a505c 100644 --- a/packages/themes/package.json +++ b/packages/themes/package.json @@ -1,6 +1,6 @@ { "name": "@clerk/themes", - "version": "2.2.2", + "version": "2.2.3", "description": "Themes for the Clerk auth components", "keywords": [ "react", diff --git a/packages/types/CHANGELOG.md b/packages/types/CHANGELOG.md index 6fa877a977..03ae85fa59 100644 --- a/packages/types/CHANGELOG.md +++ b/packages/types/CHANGELOG.md @@ -1,5 +1,18 @@ # Change Log +## 4.40.0 + +### Minor Changes + +- Adds `oidcLoginHint` & `oidcPrompt` parameters to following types: ([#4789](https://github.com/clerk/javascript/pull/4789)) by [@octoper](https://github.com/octoper) + + - `ReauthorizeExternalAccountParams` + - `OAuthConfig` + - `SignInCreateParams` + - `PrepareVerificationParams` + - `SignUpCreateParams` + - `CreateExternalAccountParams` + ## 4.39.4 ### Patch Changes diff --git a/packages/types/package.json b/packages/types/package.json index 1646e1ca6b..9ae7c6cdca 100644 --- a/packages/types/package.json +++ b/packages/types/package.json @@ -1,6 +1,6 @@ { "name": "@clerk/types", - "version": "4.39.4", + "version": "4.40.0", "description": "Typings for Clerk libraries.", "keywords": [ "clerk", diff --git a/packages/ui/CHANGELOG.md b/packages/ui/CHANGELOG.md index 3556fbb750..36757e949d 100644 --- a/packages/ui/CHANGELOG.md +++ b/packages/ui/CHANGELOG.md @@ -1,5 +1,15 @@ # @clerk/ui +## 0.3.5 + +### Patch Changes + +- Updated dependencies [[`c9da04636ffe1ba804a1ce5e5b79027d3a2344d2`](https://github.com/clerk/javascript/commit/c9da04636ffe1ba804a1ce5e5b79027d3a2344d2)]: + - @clerk/types@4.40.0 + - @clerk/elements@0.22.4 + - @clerk/localizations@3.9.4 + - @clerk/shared@2.20.4 + ## 0.3.4 ### Patch Changes diff --git a/packages/ui/package.json b/packages/ui/package.json index 6a97cc8d65..ac13ba67a6 100644 --- a/packages/ui/package.json +++ b/packages/ui/package.json @@ -1,6 +1,6 @@ { "name": "@clerk/ui", - "version": "0.3.4", + "version": "0.3.5", "repository": { "type": "git", "url": "git+https://github.com/clerk/javascript.git", diff --git a/packages/vue/CHANGELOG.md b/packages/vue/CHANGELOG.md index f919d6d955..7f434b7ea7 100644 --- a/packages/vue/CHANGELOG.md +++ b/packages/vue/CHANGELOG.md @@ -1,5 +1,15 @@ # @clerk/vue +## 0.1.5 + +### Patch Changes + +- Add `initialValues` option to `` and `` components. ([#4801](https://github.com/clerk/javascript/pull/4801)) by [@wobsoriano](https://github.com/wobsoriano) + +- Updated dependencies [[`c9da04636ffe1ba804a1ce5e5b79027d3a2344d2`](https://github.com/clerk/javascript/commit/c9da04636ffe1ba804a1ce5e5b79027d3a2344d2)]: + - @clerk/types@4.40.0 + - @clerk/shared@2.20.4 + ## 0.1.4 ### Patch Changes diff --git a/packages/vue/package.json b/packages/vue/package.json index e323b1ef38..7a6fac893f 100644 --- a/packages/vue/package.json +++ b/packages/vue/package.json @@ -1,6 +1,6 @@ { "name": "@clerk/vue", - "version": "0.1.4", + "version": "0.1.5", "description": "Clerk SDK for Vue", "keywords": [ "clerk", From a9234f28b53455c3be5517c9e1098fa525ee0dd4 Mon Sep 17 00:00:00 2001 From: Jacek Radko Date: Wed, 18 Dec 2024 10:49:33 -0600 Subject: [PATCH 3/7] fix(repo): Link local packages for e2e (#4800) --- .changeset/eleven-months-swim.md | 2 ++ integration/presets/astro.ts | 7 ++++--- integration/presets/elements.ts | 5 +++-- integration/presets/expo.ts | 3 ++- integration/presets/express.ts | 3 ++- integration/presets/next.ts | 7 ++++--- integration/presets/nuxt.ts | 3 ++- integration/presets/react-router.ts | 3 ++- integration/presets/react.ts | 5 +++-- integration/presets/remix.ts | 3 ++- integration/presets/tanstack.ts | 5 +++-- integration/presets/utils.ts | 8 ++++++++ integration/presets/vue.ts | 3 ++- 13 files changed, 39 insertions(+), 18 deletions(-) create mode 100644 .changeset/eleven-months-swim.md create mode 100644 integration/presets/utils.ts diff --git a/.changeset/eleven-months-swim.md b/.changeset/eleven-months-swim.md new file mode 100644 index 0000000000..a845151cc8 --- /dev/null +++ b/.changeset/eleven-months-swim.md @@ -0,0 +1,2 @@ +--- +--- diff --git a/integration/presets/astro.ts b/integration/presets/astro.ts index 0b7a208887..7995725b97 100644 --- a/integration/presets/astro.ts +++ b/integration/presets/astro.ts @@ -1,5 +1,6 @@ import { applicationConfig } from '../models/applicationConfig'; import { templates } from '../templates'; +import { linkPackage } from './utils'; const astroNode = applicationConfig() .setName('astro-node') @@ -9,9 +10,9 @@ const astroNode = applicationConfig() .addScript('dev', 'pnpm dev') .addScript('build', 'pnpm build') .addScript('serve', 'pnpm preview') - .addDependency('@clerk/astro', '*') - .addDependency('@clerk/types', '*') - .addDependency('@clerk/localizations', '*'); + .addDependency('@clerk/astro', linkPackage('astro')) + .addDependency('@clerk/types', linkPackage('types')) + .addDependency('@clerk/localizations', linkPackage('localizations')); const astroStatic = astroNode.clone().setName('astro-hybrid').useTemplate(templates['astro-hybrid']); diff --git a/integration/presets/elements.ts b/integration/presets/elements.ts index ae06dc5442..91bd21fbb0 100644 --- a/integration/presets/elements.ts +++ b/integration/presets/elements.ts @@ -1,6 +1,7 @@ import { constants } from '../constants'; import { applicationConfig } from '../models/applicationConfig.js'; import { templates } from '../templates/index.js'; +import { linkPackage } from './utils'; const nextAppRouter = applicationConfig() .setName('elements-next') @@ -13,8 +14,8 @@ const nextAppRouter = applicationConfig() .addDependency('next', constants.E2E_NEXTJS_VERSION) .addDependency('react', constants.E2E_REACT_VERSION) .addDependency('react-dom', constants.E2E_REACT_DOM_VERSION) - .addDependency('@clerk/nextjs', constants.E2E_CLERK_VERSION || '*') - .addDependency('@clerk/elements', constants.E2E_CLERK_VERSION || '*'); + .addDependency('@clerk/nextjs', constants.E2E_CLERK_VERSION || linkPackage('nextjs')) + .addDependency('@clerk/elements', constants.E2E_CLERK_VERSION || linkPackage('elements')); export const elements = { nextAppRouter, diff --git a/integration/presets/expo.ts b/integration/presets/expo.ts index 8380327fd3..bf9806fce2 100644 --- a/integration/presets/expo.ts +++ b/integration/presets/expo.ts @@ -1,5 +1,6 @@ import { applicationConfig } from '../models/applicationConfig'; import { templates } from '../templates'; +import { linkPackage } from './utils'; const expoWeb = applicationConfig() .setName('expo-web') @@ -9,7 +10,7 @@ const expoWeb = applicationConfig() .addScript('dev', 'pnpm dev') .addScript('build', 'pnpm build') .addScript('serve', 'pnpm start') - .addDependency('@clerk/clerk-expo', '*'); + .addDependency('@clerk/clerk-expo', linkPackage('expo')); export const expo = { expoWeb, diff --git a/integration/presets/express.ts b/integration/presets/express.ts index fdebf5a530..6470469a0b 100644 --- a/integration/presets/express.ts +++ b/integration/presets/express.ts @@ -1,6 +1,7 @@ import { constants } from '../constants'; import { applicationConfig } from '../models/applicationConfig'; import { templates } from '../templates'; +import { linkPackage } from './utils'; const vite = applicationConfig() .setName('express-vite') @@ -10,7 +11,7 @@ const vite = applicationConfig() .addScript('dev', 'pnpm dev') .addScript('build', 'pnpm build') .addScript('serve', 'pnpm start') - .addDependency('@clerk/clerk-sdk-node', constants.E2E_CLERK_VERSION || '*'); + .addDependency('@clerk/clerk-sdk-node', constants.E2E_CLERK_VERSION || linkPackage('sdk-node')); export const express = { vite, diff --git a/integration/presets/next.ts b/integration/presets/next.ts index a16a5a521e..6636af850c 100644 --- a/integration/presets/next.ts +++ b/integration/presets/next.ts @@ -1,6 +1,7 @@ import { constants } from '../constants'; import { applicationConfig } from '../models/applicationConfig.js'; import { templates } from '../templates/index.js'; +import { linkPackage } from './utils'; const appRouter = applicationConfig() .setName('next-app-router') @@ -13,9 +14,9 @@ const appRouter = applicationConfig() .addDependency('next', constants.E2E_NEXTJS_VERSION) .addDependency('react', constants.E2E_REACT_VERSION) .addDependency('react-dom', constants.E2E_REACT_DOM_VERSION) - .addDependency('@clerk/nextjs', constants.E2E_CLERK_VERSION || '*') - .addDependency('@clerk/shared', '*') - .addDependency('@clerk/types', '*'); + .addDependency('@clerk/nextjs', constants.E2E_CLERK_VERSION || linkPackage('nextjs')) + .addDependency('@clerk/shared', linkPackage('shared')) + .addDependency('@clerk/types', linkPackage('types')); const appRouterTurbo = appRouter.clone().setName('next-app-router-turbopack').addScript('dev', 'pnpm dev'); diff --git a/integration/presets/nuxt.ts b/integration/presets/nuxt.ts index 8a55270454..8fdc9716c6 100644 --- a/integration/presets/nuxt.ts +++ b/integration/presets/nuxt.ts @@ -1,5 +1,6 @@ import { applicationConfig } from '../models/applicationConfig'; import { templates } from '../templates'; +import { linkPackage } from './utils'; const nuxtNode = applicationConfig() .setName('nuxt-node') @@ -10,7 +11,7 @@ const nuxtNode = applicationConfig() .addScript('dev', 'pnpm dev') .addScript('build', 'pnpm build') .addScript('serve', 'pnpm preview') - .addDependency('@clerk/nuxt', '*'); + .addDependency('@clerk/nuxt', linkPackage('nuxt')); export const nuxt = { node: nuxtNode, diff --git a/integration/presets/react-router.ts b/integration/presets/react-router.ts index 1ff0470482..5ddb035f1b 100644 --- a/integration/presets/react-router.ts +++ b/integration/presets/react-router.ts @@ -1,6 +1,7 @@ import { constants } from '../constants'; import { applicationConfig } from '../models/applicationConfig.js'; import { templates } from '../templates/index.js'; +import { linkPackage } from './utils'; const reactRouterNode = applicationConfig() .setName('react-router-node') @@ -10,7 +11,7 @@ const reactRouterNode = applicationConfig() .addScript('dev', 'pnpm dev') .addScript('build', 'pnpm build') .addScript('serve', 'pnpm start') - .addDependency('@clerk/react-router', constants.E2E_CLERK_VERSION || '*'); + .addDependency('@clerk/react-router', constants.E2E_CLERK_VERSION || linkPackage('react-router')); export const reactRouter = { reactRouterNode, diff --git a/integration/presets/react.ts b/integration/presets/react.ts index 0dc674300f..06e1434282 100644 --- a/integration/presets/react.ts +++ b/integration/presets/react.ts @@ -1,6 +1,7 @@ import { constants } from '../constants'; import { applicationConfig } from '../models/applicationConfig'; import { templates } from '../templates'; +import { linkPackage } from './utils'; const cra = applicationConfig() .setName('react-cra') @@ -10,8 +11,8 @@ const cra = applicationConfig() .addScript('dev', 'pnpm start') .addScript('build', 'pnpm build') .addScript('serve', 'pnpm start') - .addDependency('@clerk/clerk-react', constants.E2E_CLERK_VERSION || '*') - .addDependency('@clerk/themes', constants.E2E_CLERK_VERSION || '*'); + .addDependency('@clerk/clerk-react', constants.E2E_CLERK_VERSION || linkPackage('react')) + .addDependency('@clerk/themes', constants.E2E_CLERK_VERSION || linkPackage('themes')); const vite = cra .clone() diff --git a/integration/presets/remix.ts b/integration/presets/remix.ts index 41decccff0..d8f6c619bf 100644 --- a/integration/presets/remix.ts +++ b/integration/presets/remix.ts @@ -1,6 +1,7 @@ import { constants } from '../constants'; import { applicationConfig } from '../models/applicationConfig.js'; import { templates } from '../templates/index.js'; +import { linkPackage } from './utils'; const remixNode = applicationConfig() .setName('remix-node') @@ -10,7 +11,7 @@ const remixNode = applicationConfig() .addScript('dev', 'pnpm dev') .addScript('build', 'pnpm build') .addScript('serve', 'pnpm start') - .addDependency('@clerk/remix', constants.E2E_CLERK_VERSION || '*'); + .addDependency('@clerk/remix', constants.E2E_CLERK_VERSION || linkPackage('remix')); export const remix = { remixNode, diff --git a/integration/presets/tanstack.ts b/integration/presets/tanstack.ts index 5b9399abe5..03ddd8d190 100644 --- a/integration/presets/tanstack.ts +++ b/integration/presets/tanstack.ts @@ -1,5 +1,6 @@ import { applicationConfig } from '../models/applicationConfig.js'; import { templates } from '../templates/index.js'; +import { linkPackage } from './utils'; const router = applicationConfig() .setName('tanstack-router') @@ -9,7 +10,7 @@ const router = applicationConfig() .addScript('dev', 'pnpm dev') .addScript('build', 'pnpm build') .addScript('serve', 'pnpm start') - .addDependency('@clerk/tanstack-start', '*'); + .addDependency('@clerk/tanstack-start', linkPackage('tanstack-start')); const start = applicationConfig() .setName('tanstack-start') @@ -19,7 +20,7 @@ const start = applicationConfig() .addScript('dev', 'pnpm dev') .addScript('build', 'pnpm build') .addScript('serve', 'pnpm start') - .addDependency('@clerk/tanstack-start', '*'); + .addDependency('@clerk/tanstack-start', linkPackage('tanstack-start')); export const tanstack = { start, diff --git a/integration/presets/utils.ts b/integration/presets/utils.ts new file mode 100644 index 0000000000..4c4f6db45d --- /dev/null +++ b/integration/presets/utils.ts @@ -0,0 +1,8 @@ +import path from 'node:path'; + +export function linkPackage(pkg: string) { + // eslint-disable-next-line turbo/no-undeclared-variables + if (process.env.CI === 'true') return '*'; + + return `link:${path.resolve(process.cwd(), `packages/${pkg}`)}`; +} diff --git a/integration/presets/vue.ts b/integration/presets/vue.ts index 3d9cc9e280..1003af19f5 100644 --- a/integration/presets/vue.ts +++ b/integration/presets/vue.ts @@ -1,5 +1,6 @@ import { applicationConfig } from '../models/applicationConfig'; import { templates } from '../templates'; +import { linkPackage } from './utils'; const vite = applicationConfig() .setName('vue-vite') @@ -9,7 +10,7 @@ const vite = applicationConfig() .addScript('dev', 'pnpm dev') .addScript('build', 'pnpm build') .addScript('serve', 'pnpm preview') - .addDependency('@clerk/vue', '*'); + .addDependency('@clerk/vue', linkPackage('vue')); export const vue = { vite, From 4fecdac34dd0f820a2b4e123e4f49a0202074937 Mon Sep 17 00:00:00 2001 From: Lennart Date: Thu, 19 Dec 2024 10:37:44 +0100 Subject: [PATCH 4/7] chore(react-router): Add library mode E2E test (#4808) Co-authored-by: Jacek --- integration/constants.ts | 4 - integration/presets/index.ts | 2 - integration/presets/longRunningApps.ts | 2 - integration/presets/react-router.ts | 11 ++ integration/presets/remix.ts | 18 --- integration/templates/index.ts | 2 +- .../templates/react-router-library/README.md | 50 +++++++ .../templates/react-router-library/index.html | 23 ++++ .../react-router-library/package.json | 25 ++++ .../react-router-library/public/vite.svg | 1 + .../react-router-library/src/App.css | 42 ++++++ .../react-router-library/src/App.tsx | 17 +++ .../react-router-library/src/assets/react.svg | 1 + .../react-router-library/src/index.css | 68 ++++++++++ .../react-router-library/src/main.tsx | 23 ++++ .../react-router-library/src/vite-env.d.ts | 1 + .../react-router-library/tsconfig.app.json | 26 ++++ .../react-router-library/tsconfig.json | 4 + .../react-router-library/tsconfig.node.json | 24 ++++ .../react-router-library/vite.config.ts | 7 + integration/templates/remix-node/.eslintrc.js | 4 - integration/templates/remix-node/.gitignore | 11 -- integration/templates/remix-node/README.md | 40 ------ .../templates/remix-node/app/entry.client.tsx | 18 --- .../templates/remix-node/app/entry.server.tsx | 125 ------------------ integration/templates/remix-node/app/root.tsx | 36 ----- .../remix-node/app/routes/_index.tsx | 16 --- .../remix-node/app/routes/protected.tsx | 19 --- .../remix-node/app/routes/sign-in.$.tsx | 14 -- .../remix-node/app/routes/sign-up.$.tsx | 14 -- integration/templates/remix-node/package.json | 33 ----- .../templates/remix-node/public/favicon.ico | Bin 16958 -> 0 bytes .../templates/remix-node/remix.config.js | 21 --- .../templates/remix-node/remix.env.d.ts | 2 - integration/templates/remix-node/server.ts | 7 - .../templates/remix-node/tsconfig.json | 22 --- .../tests/react-router/library-mode.test.ts | 59 +++++++++ package.json | 2 +- 38 files changed, 384 insertions(+), 410 deletions(-) delete mode 100644 integration/presets/remix.ts create mode 100644 integration/templates/react-router-library/README.md create mode 100644 integration/templates/react-router-library/index.html create mode 100644 integration/templates/react-router-library/package.json create mode 100644 integration/templates/react-router-library/public/vite.svg create mode 100644 integration/templates/react-router-library/src/App.css create mode 100644 integration/templates/react-router-library/src/App.tsx create mode 100644 integration/templates/react-router-library/src/assets/react.svg create mode 100644 integration/templates/react-router-library/src/index.css create mode 100644 integration/templates/react-router-library/src/main.tsx create mode 100644 integration/templates/react-router-library/src/vite-env.d.ts create mode 100644 integration/templates/react-router-library/tsconfig.app.json create mode 100644 integration/templates/react-router-library/tsconfig.json create mode 100644 integration/templates/react-router-library/tsconfig.node.json create mode 100644 integration/templates/react-router-library/vite.config.ts delete mode 100644 integration/templates/remix-node/.eslintrc.js delete mode 100644 integration/templates/remix-node/.gitignore delete mode 100644 integration/templates/remix-node/README.md delete mode 100644 integration/templates/remix-node/app/entry.client.tsx delete mode 100644 integration/templates/remix-node/app/entry.server.tsx delete mode 100644 integration/templates/remix-node/app/root.tsx delete mode 100644 integration/templates/remix-node/app/routes/_index.tsx delete mode 100644 integration/templates/remix-node/app/routes/protected.tsx delete mode 100644 integration/templates/remix-node/app/routes/sign-in.$.tsx delete mode 100644 integration/templates/remix-node/app/routes/sign-up.$.tsx delete mode 100644 integration/templates/remix-node/package.json delete mode 100644 integration/templates/remix-node/public/favicon.ico delete mode 100644 integration/templates/remix-node/remix.config.js delete mode 100644 integration/templates/remix-node/remix.env.d.ts delete mode 100644 integration/templates/remix-node/server.ts delete mode 100644 integration/templates/remix-node/tsconfig.json create mode 100644 integration/tests/react-router/library-mode.test.ts diff --git a/integration/constants.ts b/integration/constants.ts index d4b681f3b5..2369077fe8 100644 --- a/integration/constants.ts +++ b/integration/constants.ts @@ -56,10 +56,6 @@ export const constants = { * The version of the dependency to use, controlled programmatically. */ E2E_REACT_DOM_VERSION: process.env.E2E_REACT_DOM_VERSION, - /** - * The version of the dependency to use, controlled programmatically. - */ - E2E_REMIX_VERSION: process.env.E2E_REMIX_VERSION, /** * The version of the dependency to use, controlled programmatically. */ diff --git a/integration/presets/index.ts b/integration/presets/index.ts index 6f58b490f3..24fc2d58cd 100644 --- a/integration/presets/index.ts +++ b/integration/presets/index.ts @@ -8,7 +8,6 @@ import { next } from './next'; import { nuxt } from './nuxt'; import { react } from './react'; import { reactRouter } from './react-router'; -import { remix } from './remix'; import { tanstack } from './tanstack'; export const appConfigs = { @@ -17,7 +16,6 @@ export const appConfigs = { longRunningApps: createLongRunningApps(), next, react, - remix, elements, expo, astro, diff --git a/integration/presets/longRunningApps.ts b/integration/presets/longRunningApps.ts index 010251ab04..cd1f27cc19 100644 --- a/integration/presets/longRunningApps.ts +++ b/integration/presets/longRunningApps.ts @@ -9,7 +9,6 @@ import { next } from './next'; import { nuxt } from './nuxt'; import { react } from './react'; import { reactRouter } from './react-router'; -import { remix } from './remix'; import { tanstack } from './tanstack'; import { vue } from './vue'; @@ -24,7 +23,6 @@ export const createLongRunningApps = () => { { id: 'react.vite.withEmailCodes', config: react.vite, env: envs.withEmailCodes }, { id: 'react.vite.withEmailCodes_persist_client', config: react.vite, env: envs.withEmailCodes_destroy_client }, { id: 'react.vite.withEmailLinks', config: react.vite, env: envs.withEmailLinks }, - { id: 'remix.node.withEmailCodes', config: remix.remixNode, env: envs.withEmailCodes }, { id: 'next.appRouter.withEmailCodes', config: next.appRouter, env: envs.withEmailCodes }, { id: 'next.appRouter.withEmailCodes_persist_client', diff --git a/integration/presets/react-router.ts b/integration/presets/react-router.ts index 5ddb035f1b..4b43c7083b 100644 --- a/integration/presets/react-router.ts +++ b/integration/presets/react-router.ts @@ -13,6 +13,17 @@ const reactRouterNode = applicationConfig() .addScript('serve', 'pnpm start') .addDependency('@clerk/react-router', constants.E2E_CLERK_VERSION || linkPackage('react-router')); +const reactRouterLibrary = applicationConfig() + .setName('react-router-library') + .useTemplate(templates['react-router-library']) + .setEnvFormatter('public', key => `VITE_${key}`) + .addScript('setup', 'pnpm install') + .addScript('dev', 'pnpm dev') + .addScript('build', 'pnpm build') + .addScript('serve', 'pnpm preview') + .addDependency('@clerk/react-router', constants.E2E_CLERK_VERSION || linkPackage('react-router')); + export const reactRouter = { reactRouterNode, + reactRouterLibrary, } as const; diff --git a/integration/presets/remix.ts b/integration/presets/remix.ts deleted file mode 100644 index d8f6c619bf..0000000000 --- a/integration/presets/remix.ts +++ /dev/null @@ -1,18 +0,0 @@ -import { constants } from '../constants'; -import { applicationConfig } from '../models/applicationConfig.js'; -import { templates } from '../templates/index.js'; -import { linkPackage } from './utils'; - -const remixNode = applicationConfig() - .setName('remix-node') - .useTemplate(templates['remix-node']) - .setEnvFormatter('public', key => `${key}`) - .addScript('setup', 'pnpm install') - .addScript('dev', 'pnpm dev') - .addScript('build', 'pnpm build') - .addScript('serve', 'pnpm start') - .addDependency('@clerk/remix', constants.E2E_CLERK_VERSION || linkPackage('remix')); - -export const remix = { - remixNode, -} as const; diff --git a/integration/templates/index.ts b/integration/templates/index.ts index 4d745d1db5..26c115fe1b 100644 --- a/integration/templates/index.ts +++ b/integration/templates/index.ts @@ -9,7 +9,6 @@ export const templates = { 'react-cra': resolve(__dirname, './react-cra'), 'react-vite': resolve(__dirname, './react-vite'), 'express-vite': resolve(__dirname, './express-vite'), - 'remix-node': resolve(__dirname, './remix-node'), 'elements-next': resolve(__dirname, './elements-next'), 'astro-node': resolve(__dirname, './astro-node'), 'astro-hybrid': resolve(__dirname, './astro-hybrid'), @@ -19,6 +18,7 @@ export const templates = { 'vue-vite': resolve(__dirname, './vue-vite'), 'nuxt-node': resolve(__dirname, './nuxt-node'), 'react-router-node': resolve(__dirname, './react-router-node'), + 'react-router-library': resolve(__dirname, './react-router-library'), } as const; if (new Set([...Object.values(templates)]).size !== Object.values(templates).length) { diff --git a/integration/templates/react-router-library/README.md b/integration/templates/react-router-library/README.md new file mode 100644 index 0000000000..1e5a46b4e1 --- /dev/null +++ b/integration/templates/react-router-library/README.md @@ -0,0 +1,50 @@ +# React + TypeScript + Vite + +This template provides a minimal setup to get React working in Vite with HMR and some ESLint rules. + +Currently, two official plugins are available: + +- [@vitejs/plugin-react](https://github.com/vitejs/vite-plugin-react/blob/main/packages/plugin-react/README.md) uses [Babel](https://babeljs.io/) for Fast Refresh +- [@vitejs/plugin-react-swc](https://github.com/vitejs/vite-plugin-react-swc) uses [SWC](https://swc.rs/) for Fast Refresh + +## Expanding the ESLint configuration + +If you are developing a production application, we recommend updating the configuration to enable type aware lint rules: + +- Configure the top-level `parserOptions` property like this: + +```js +export default tseslint.config({ + languageOptions: { + // other options... + parserOptions: { + project: ['./tsconfig.node.json', './tsconfig.app.json'], + tsconfigRootDir: import.meta.dirname, + }, + }, +}); +``` + +- Replace `tseslint.configs.recommended` to `tseslint.configs.recommendedTypeChecked` or `tseslint.configs.strictTypeChecked` +- Optionally add `...tseslint.configs.stylisticTypeChecked` +- Install [eslint-plugin-react](https://github.com/jsx-eslint/eslint-plugin-react) and update the config: + +```js +// eslint.config.js +import react from 'eslint-plugin-react'; + +export default tseslint.config({ + // Set the react version + settings: { react: { version: '18.3' } }, + plugins: { + // Add the react plugin + react, + }, + rules: { + // other rules... + // Enable its recommended rules + ...react.configs.recommended.rules, + ...react.configs['jsx-runtime'].rules, + }, +}); +``` diff --git a/integration/templates/react-router-library/index.html b/integration/templates/react-router-library/index.html new file mode 100644 index 0000000000..e4c1f3de22 --- /dev/null +++ b/integration/templates/react-router-library/index.html @@ -0,0 +1,23 @@ + + + + + + + Vite + React + TS + + +
+ + + diff --git a/integration/templates/react-router-library/package.json b/integration/templates/react-router-library/package.json new file mode 100644 index 0000000000..28970a47e3 --- /dev/null +++ b/integration/templates/react-router-library/package.json @@ -0,0 +1,25 @@ +{ + "name": "react-router-library", + "version": "0.0.0", + "private": true, + "type": "module", + "scripts": { + "build": "tsc -b && vite build", + "dev": "vite --port $PORT", + "preview": "vite preview --port $PORT" + }, + "dependencies": { + "@clerk/react-router": "^0.1.2", + "react": "^18.3.1", + "react-dom": "^18.3.1", + "react-router": "^7.0.2" + }, + "devDependencies": { + "@types/react": "^18.3.12", + "@types/react-dom": "^18.3.1", + "@vitejs/plugin-react": "^4.3.4", + "globals": "^15.12.0", + "typescript": "~5.6.2", + "vite": "^6.0.1" + } +} diff --git a/integration/templates/react-router-library/public/vite.svg b/integration/templates/react-router-library/public/vite.svg new file mode 100644 index 0000000000..e7b8dfb1b2 --- /dev/null +++ b/integration/templates/react-router-library/public/vite.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/integration/templates/react-router-library/src/App.css b/integration/templates/react-router-library/src/App.css new file mode 100644 index 0000000000..b9d355df2a --- /dev/null +++ b/integration/templates/react-router-library/src/App.css @@ -0,0 +1,42 @@ +#root { + max-width: 1280px; + margin: 0 auto; + padding: 2rem; + text-align: center; +} + +.logo { + height: 6em; + padding: 1.5em; + will-change: filter; + transition: filter 300ms; +} +.logo:hover { + filter: drop-shadow(0 0 2em #646cffaa); +} +.logo.react:hover { + filter: drop-shadow(0 0 2em #61dafbaa); +} + +@keyframes logo-spin { + from { + transform: rotate(0deg); + } + to { + transform: rotate(360deg); + } +} + +@media (prefers-reduced-motion: no-preference) { + a:nth-of-type(2) .logo { + animation: logo-spin infinite 20s linear; + } +} + +.card { + padding: 2em; +} + +.read-the-docs { + color: #888; +} diff --git a/integration/templates/react-router-library/src/App.tsx b/integration/templates/react-router-library/src/App.tsx new file mode 100644 index 0000000000..93dfdf0438 --- /dev/null +++ b/integration/templates/react-router-library/src/App.tsx @@ -0,0 +1,17 @@ +import { SignInButton, SignedIn, SignedOut, UserButton } from '@clerk/react-router'; +import './App.css'; + +function App() { + return ( +
+ + + + + + +
+ ); +} + +export default App; diff --git a/integration/templates/react-router-library/src/assets/react.svg b/integration/templates/react-router-library/src/assets/react.svg new file mode 100644 index 0000000000..6c87de9bb3 --- /dev/null +++ b/integration/templates/react-router-library/src/assets/react.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/integration/templates/react-router-library/src/index.css b/integration/templates/react-router-library/src/index.css new file mode 100644 index 0000000000..6119ad9a8f --- /dev/null +++ b/integration/templates/react-router-library/src/index.css @@ -0,0 +1,68 @@ +:root { + font-family: Inter, system-ui, Avenir, Helvetica, Arial, sans-serif; + line-height: 1.5; + font-weight: 400; + + color-scheme: light dark; + color: rgba(255, 255, 255, 0.87); + background-color: #242424; + + font-synthesis: none; + text-rendering: optimizeLegibility; + -webkit-font-smoothing: antialiased; + -moz-osx-font-smoothing: grayscale; +} + +a { + font-weight: 500; + color: #646cff; + text-decoration: inherit; +} +a:hover { + color: #535bf2; +} + +body { + margin: 0; + display: flex; + place-items: center; + min-width: 320px; + min-height: 100vh; +} + +h1 { + font-size: 3.2em; + line-height: 1.1; +} + +button { + border-radius: 8px; + border: 1px solid transparent; + padding: 0.6em 1.2em; + font-size: 1em; + font-weight: 500; + font-family: inherit; + background-color: #1a1a1a; + cursor: pointer; + transition: border-color 0.25s; +} +button:hover { + border-color: #646cff; +} +button:focus, +button:focus-visible { + outline: 4px auto -webkit-focus-ring-color; +} + +@media (prefers-color-scheme: light) { + :root { + color: #213547; + background-color: #ffffff; + } + a:hover { + color: #747bff; + } + button { + background-color: #f9f9f9; + } +} diff --git a/integration/templates/react-router-library/src/main.tsx b/integration/templates/react-router-library/src/main.tsx new file mode 100644 index 0000000000..46ab36679f --- /dev/null +++ b/integration/templates/react-router-library/src/main.tsx @@ -0,0 +1,23 @@ +import { StrictMode } from 'react'; +import { createRoot } from 'react-dom/client'; +import { BrowserRouter, Routes, Route } from 'react-router'; +import { ClerkProvider } from '@clerk/react-router'; +import './index.css'; +import App from './App.tsx'; + +const PUBLISHABLE_KEY = import.meta.env.VITE_CLERK_PUBLISHABLE_KEY; + +createRoot(document.getElementById('root')!).render( + + + + + } + /> + + + + , +); diff --git a/integration/templates/react-router-library/src/vite-env.d.ts b/integration/templates/react-router-library/src/vite-env.d.ts new file mode 100644 index 0000000000..11f02fe2a0 --- /dev/null +++ b/integration/templates/react-router-library/src/vite-env.d.ts @@ -0,0 +1 @@ +/// diff --git a/integration/templates/react-router-library/tsconfig.app.json b/integration/templates/react-router-library/tsconfig.app.json new file mode 100644 index 0000000000..358ca9ba93 --- /dev/null +++ b/integration/templates/react-router-library/tsconfig.app.json @@ -0,0 +1,26 @@ +{ + "compilerOptions": { + "tsBuildInfoFile": "./node_modules/.tmp/tsconfig.app.tsbuildinfo", + "target": "ES2020", + "useDefineForClassFields": true, + "lib": ["ES2020", "DOM", "DOM.Iterable"], + "module": "ESNext", + "skipLibCheck": true, + + /* Bundler mode */ + "moduleResolution": "bundler", + "allowImportingTsExtensions": true, + "isolatedModules": true, + "moduleDetection": "force", + "noEmit": true, + "jsx": "react-jsx", + + /* Linting */ + "strict": true, + "noUnusedLocals": true, + "noUnusedParameters": true, + "noFallthroughCasesInSwitch": true, + "noUncheckedSideEffectImports": true + }, + "include": ["src"] +} diff --git a/integration/templates/react-router-library/tsconfig.json b/integration/templates/react-router-library/tsconfig.json new file mode 100644 index 0000000000..d32ff68200 --- /dev/null +++ b/integration/templates/react-router-library/tsconfig.json @@ -0,0 +1,4 @@ +{ + "files": [], + "references": [{ "path": "./tsconfig.app.json" }, { "path": "./tsconfig.node.json" }] +} diff --git a/integration/templates/react-router-library/tsconfig.node.json b/integration/templates/react-router-library/tsconfig.node.json new file mode 100644 index 0000000000..db0becc8b0 --- /dev/null +++ b/integration/templates/react-router-library/tsconfig.node.json @@ -0,0 +1,24 @@ +{ + "compilerOptions": { + "tsBuildInfoFile": "./node_modules/.tmp/tsconfig.node.tsbuildinfo", + "target": "ES2022", + "lib": ["ES2023"], + "module": "ESNext", + "skipLibCheck": true, + + /* Bundler mode */ + "moduleResolution": "bundler", + "allowImportingTsExtensions": true, + "isolatedModules": true, + "moduleDetection": "force", + "noEmit": true, + + /* Linting */ + "strict": true, + "noUnusedLocals": true, + "noUnusedParameters": true, + "noFallthroughCasesInSwitch": true, + "noUncheckedSideEffectImports": true + }, + "include": ["vite.config.ts"] +} diff --git a/integration/templates/react-router-library/vite.config.ts b/integration/templates/react-router-library/vite.config.ts new file mode 100644 index 0000000000..4a5def4c3d --- /dev/null +++ b/integration/templates/react-router-library/vite.config.ts @@ -0,0 +1,7 @@ +import { defineConfig } from 'vite'; +import react from '@vitejs/plugin-react'; + +// https://vite.dev/config/ +export default defineConfig({ + plugins: [react()], +}); diff --git a/integration/templates/remix-node/.eslintrc.js b/integration/templates/remix-node/.eslintrc.js deleted file mode 100644 index f2faf1470f..0000000000 --- a/integration/templates/remix-node/.eslintrc.js +++ /dev/null @@ -1,4 +0,0 @@ -/** @type {import('eslint').Linter.Config} */ -module.exports = { - extends: ['@remix-run/eslint-config', '@remix-run/eslint-config/node'], -}; diff --git a/integration/templates/remix-node/.gitignore b/integration/templates/remix-node/.gitignore deleted file mode 100644 index 5d6a175132..0000000000 --- a/integration/templates/remix-node/.gitignore +++ /dev/null @@ -1,11 +0,0 @@ -node_modules - -.cache -.env -.vercel -.output - -/build/ -/public/build -/api/index.js -/api/index.js.map diff --git a/integration/templates/remix-node/README.md b/integration/templates/remix-node/README.md deleted file mode 100644 index dc88d77a15..0000000000 --- a/integration/templates/remix-node/README.md +++ /dev/null @@ -1,40 +0,0 @@ -> **Warning** -> The `@remix-run/vercel` runtime adapter has been deprecated in favor of out of -> the box Vercel functionality and will be removed in Remix v2. -> This means you don't have to use the Vercel template & can just use the Remix -> template instead. - -# Welcome to Remix! - -- [Remix Docs](https://remix.run/docs) - -## Deployment - -After having run the `create-remix` command and selected "Vercel" as a deployment target, you only need to [import your Git repository](https://vercel.com/new) into Vercel, and it will be deployed. - -If you'd like to avoid using a Git repository, you can also deploy the directory by running [Vercel CLI](https://vercel.com/cli): - -```sh -npm i -g vercel -vercel -``` - -It is generally recommended to use a Git repository, because future commits will then automatically be deployed by Vercel, through its [Git Integration](https://vercel.com/docs/concepts/git). - -## Development - -To run your Remix app locally, make sure your project's local dependencies are installed: - -```sh -npm install -``` - -Afterwards, start the Remix development server like so: - -```sh -pnpm dev -``` - -Open up [http://localhost:3000](http://localhost:3000) and you should be ready to go! - -If you're used to using the `vercel dev` command provided by [Vercel CLI](https://vercel.com/cli) instead, you can also use that, but it's not needed. diff --git a/integration/templates/remix-node/app/entry.client.tsx b/integration/templates/remix-node/app/entry.client.tsx deleted file mode 100644 index 3f01ce18b1..0000000000 --- a/integration/templates/remix-node/app/entry.client.tsx +++ /dev/null @@ -1,18 +0,0 @@ -/** - * By default, Remix will handle hydrating your app on the client for you. - * You are free to delete this file if you'd like to, but if you ever want it revealed again, you can run `npx remix reveal` ✨ - * For more information, see https://remix.run/file-conventions/entry.client - */ - -import { RemixBrowser } from '@remix-run/react'; -import { startTransition, StrictMode } from 'react'; -import { hydrateRoot } from 'react-dom/client'; - -startTransition(() => { - hydrateRoot( - document, - - - , - ); -}); diff --git a/integration/templates/remix-node/app/entry.server.tsx b/integration/templates/remix-node/app/entry.server.tsx deleted file mode 100644 index 0791aea535..0000000000 --- a/integration/templates/remix-node/app/entry.server.tsx +++ /dev/null @@ -1,125 +0,0 @@ -/** - * By default, Remix will handle generating the HTTP Response for you. - * You are free to delete this file if you'd like to, but if you ever want it revealed again, you can run `npx remix reveal` ✨ - * For more information, see https://remix.run/file-conventions/entry.server - */ - -import { PassThrough } from 'node:stream'; - -import type { AppLoadContext, EntryContext } from '@remix-run/node'; -import { Response } from '@remix-run/node'; -import { RemixServer } from '@remix-run/react'; -import isbot from 'isbot'; -import { renderToPipeableStream } from 'react-dom/server'; - -const ABORT_DELAY = 5_000; - -export default function handleRequest( - request: Request, - responseStatusCode: number, - responseHeaders: Headers, - remixContext: EntryContext, - loadContext: AppLoadContext, -) { - return isbot(request.headers.get('user-agent')) - ? handleBotRequest(request, responseStatusCode, responseHeaders, remixContext) - : handleBrowserRequest(request, responseStatusCode, responseHeaders, remixContext); -} - -function handleBotRequest( - request: Request, - responseStatusCode: number, - responseHeaders: Headers, - remixContext: EntryContext, -) { - return new Promise((resolve, reject) => { - let shellRendered = false; - const { pipe, abort } = renderToPipeableStream( - , - { - onAllReady() { - shellRendered = true; - const body = new PassThrough(); - - responseHeaders.set('Content-Type', 'text/html'); - - resolve( - new Response(body, { - headers: responseHeaders, - status: responseStatusCode, - }), - ); - - pipe(body); - }, - onShellError(error: unknown) { - reject(error); - }, - onError(error: unknown) { - responseStatusCode = 500; - // Log streaming rendering errors from inside the shell. Don't log - // errors encountered during initial shell rendering since they'll - // reject and get logged in handleDocumentRequest. - if (shellRendered) { - console.error(error); - } - }, - }, - ); - - setTimeout(abort, ABORT_DELAY); - }); -} - -function handleBrowserRequest( - request: Request, - responseStatusCode: number, - responseHeaders: Headers, - remixContext: EntryContext, -) { - return new Promise((resolve, reject) => { - let shellRendered = false; - const { pipe, abort } = renderToPipeableStream( - , - { - onShellReady() { - shellRendered = true; - const body = new PassThrough(); - - responseHeaders.set('Content-Type', 'text/html'); - - resolve( - new Response(body, { - headers: responseHeaders, - status: responseStatusCode, - }), - ); - - pipe(body); - }, - onShellError(error: unknown) { - reject(error); - }, - onError(error: unknown) { - responseStatusCode = 500; - // Log streaming rendering errors from inside the shell. Don't log - // errors encountered during initial shell rendering since they'll - // reject and get logged in handleDocumentRequest. - if (shellRendered) { - console.error(error); - } - }, - }, - ); - - setTimeout(abort, ABORT_DELAY); - }); -} diff --git a/integration/templates/remix-node/app/root.tsx b/integration/templates/remix-node/app/root.tsx deleted file mode 100644 index 4546c7334b..0000000000 --- a/integration/templates/remix-node/app/root.tsx +++ /dev/null @@ -1,36 +0,0 @@ -import { cssBundleHref } from '@remix-run/css-bundle'; -import type { LinksFunction } from '@remix-run/node'; -import { LoaderFunction } from '@remix-run/node'; -import { Links, LiveReload, Meta, Outlet, Scripts, ScrollRestoration } from '@remix-run/react'; -import { rootAuthLoader } from '@clerk/remix/ssr.server'; -import { ClerkApp, ClerkCatchBoundary } from '@clerk/remix'; - -export const loader: LoaderFunction = args => rootAuthLoader(args); - -export const links: LinksFunction = () => [...(cssBundleHref ? [{ rel: 'stylesheet', href: cssBundleHref }] : [])]; - -function App() { - return ( - - - - - - - - - - - - - - - ); -} - -// TODO: Add clerkJsUrl -export default ClerkApp(App); -export const CatchBoundary = ClerkCatchBoundary(); diff --git a/integration/templates/remix-node/app/routes/_index.tsx b/integration/templates/remix-node/app/routes/_index.tsx deleted file mode 100644 index 2b40fdbdfa..0000000000 --- a/integration/templates/remix-node/app/routes/_index.tsx +++ /dev/null @@ -1,16 +0,0 @@ -import type { V2_MetaFunction } from '@remix-run/node'; -import { SignedIn, SignedOut, UserButton } from '@clerk/remix'; - -export const meta: V2_MetaFunction = () => { - return [{ title: 'New Remix App' }, { name: 'description', content: 'Welcome to Remix!' }]; -}; - -export default function Index() { - return ( -
- - SignedIn - SignedOut -
- ); -} diff --git a/integration/templates/remix-node/app/routes/protected.tsx b/integration/templates/remix-node/app/routes/protected.tsx deleted file mode 100644 index 2ec4e18cab..0000000000 --- a/integration/templates/remix-node/app/routes/protected.tsx +++ /dev/null @@ -1,19 +0,0 @@ -import { getAuth } from '@clerk/remix/ssr.server'; -import type { LoaderFunction } from '@remix-run/node'; -import { redirect } from '@remix-run/node'; - -export const loader: LoaderFunction = async args => { - const { userId } = await getAuth(args); - if (!userId) { - return redirect('/sign-in'); - } - return {}; -}; - -export default function Protected() { - return ( -
-

Protected

-
- ); -} diff --git a/integration/templates/remix-node/app/routes/sign-in.$.tsx b/integration/templates/remix-node/app/routes/sign-in.$.tsx deleted file mode 100644 index 62f80b0b75..0000000000 --- a/integration/templates/remix-node/app/routes/sign-in.$.tsx +++ /dev/null @@ -1,14 +0,0 @@ -import { SignIn } from '@clerk/remix'; - -export default function SignInPage() { - return ( -
-

Sign In route

- -
- ); -} diff --git a/integration/templates/remix-node/app/routes/sign-up.$.tsx b/integration/templates/remix-node/app/routes/sign-up.$.tsx deleted file mode 100644 index 1476b9f900..0000000000 --- a/integration/templates/remix-node/app/routes/sign-up.$.tsx +++ /dev/null @@ -1,14 +0,0 @@ -import { SignUp } from '@clerk/remix'; - -export default function SignUpPage() { - return ( -
-

Sign Up route

- -
- ); -} diff --git a/integration/templates/remix-node/package.json b/integration/templates/remix-node/package.json deleted file mode 100644 index ffe14860e2..0000000000 --- a/integration/templates/remix-node/package.json +++ /dev/null @@ -1,33 +0,0 @@ -{ - "private": true, - "sideEffects": false, - "scripts": { - "build": "remix build", - "dev": "remix dev", - "typecheck": "tsc" - }, - "dependencies": { - "@clerk/remix": "staging", - "@remix-run/css-bundle": "^1.18.1", - "@remix-run/node": "^1.18.1", - "@remix-run/react": "^1.18.1", - "@remix-run/vercel": "^1.18.1", - "@vercel/node": "^2.10.3", - "isbot": "^3.6.8", - "react": "^18.3.1", - "react-dom": "^18.3.1" - }, - "devDependencies": { - "@remix-run/dev": "^1.19.3", - "@remix-run/eslint-config": "^1.18.1", - "@remix-run/serve": "^1.18.1", - "@types/node": "^18.19.33", - "@types/react": "18.3.12", - "@types/react-dom": "18.3.1", - "eslint": "^8.38.0", - "typescript": "^5.6.3" - }, - "engines": { - "node": ">=18.17.0" - } -} diff --git a/integration/templates/remix-node/public/favicon.ico b/integration/templates/remix-node/public/favicon.ico deleted file mode 100644 index 8830cf6821b354114848e6354889b8ecf6d2bc61..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 16958 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 EKbET!0{{R3 diff --git a/integration/templates/remix-node/remix.config.js b/integration/templates/remix-node/remix.config.js deleted file mode 100644 index a67401bcd1..0000000000 --- a/integration/templates/remix-node/remix.config.js +++ /dev/null @@ -1,21 +0,0 @@ -/** @type {import('@remix-run/dev').AppConfig} */ -module.exports = { - ignoredRouteFiles: ['**/.*'], - // When running locally in development mode, we use the built-in remix - // server. This does not understand the vercel lambda module format, - // so we default back to the standard build output. - server: process.env.NODE_ENV === 'development' ? undefined : './server.ts', - serverBuildPath: 'api/index.js', - // appDirectory: "app", - // assetsBuildDirectory: "public/build", - // publicPath: "/build/", - serverModuleFormat: 'cjs', - future: { - v2_dev: false, - v2_errorBoundary: false, - v2_headers: true, - v2_meta: true, - v2_normalizeFormMethod: true, - v2_routeConvention: true, - }, -}; diff --git a/integration/templates/remix-node/remix.env.d.ts b/integration/templates/remix-node/remix.env.d.ts deleted file mode 100644 index dcf8c45e1d..0000000000 --- a/integration/templates/remix-node/remix.env.d.ts +++ /dev/null @@ -1,2 +0,0 @@ -/// -/// diff --git a/integration/templates/remix-node/server.ts b/integration/templates/remix-node/server.ts deleted file mode 100644 index 687d7293bc..0000000000 --- a/integration/templates/remix-node/server.ts +++ /dev/null @@ -1,7 +0,0 @@ -import * as build from '@remix-run/dev/server-build'; -import { installGlobals } from '@remix-run/node'; -import { createRequestHandler } from '@remix-run/vercel'; - -installGlobals(); - -export default createRequestHandler({ build, mode: process.env.NODE_ENV }); diff --git a/integration/templates/remix-node/tsconfig.json b/integration/templates/remix-node/tsconfig.json deleted file mode 100644 index 20f8a386a6..0000000000 --- a/integration/templates/remix-node/tsconfig.json +++ /dev/null @@ -1,22 +0,0 @@ -{ - "include": ["remix.env.d.ts", "**/*.ts", "**/*.tsx"], - "compilerOptions": { - "lib": ["DOM", "DOM.Iterable", "ES2019"], - "isolatedModules": true, - "esModuleInterop": true, - "jsx": "react-jsx", - "moduleResolution": "node", - "resolveJsonModule": true, - "target": "ES2019", - "strict": true, - "allowJs": true, - "forceConsistentCasingInFileNames": true, - "baseUrl": ".", - "paths": { - "~/*": ["./app/*"] - }, - - // Remix takes care of building everything in `remix build`. - "noEmit": true - } -} diff --git a/integration/tests/react-router/library-mode.test.ts b/integration/tests/react-router/library-mode.test.ts new file mode 100644 index 0000000000..6f5af6f63b --- /dev/null +++ b/integration/tests/react-router/library-mode.test.ts @@ -0,0 +1,59 @@ +import { test } from '@playwright/test'; + +import type { Application } from '../../models/application'; +import { appConfigs } from '../../presets'; +import type { FakeOrganization, FakeUser } from '../../testUtils'; +import { createTestUtils } from '../../testUtils'; + +test.describe('Library Mode basic tests for @react-router', () => { + test.describe.configure({ mode: 'parallel' }); + let app: Application; + let fakeUser: FakeUser; + let fakeOrganization: FakeOrganization; + + test.beforeAll(async () => { + app = await appConfigs.reactRouter.reactRouterLibrary.commit(); + + await app.setup(); + await app.withEnv(appConfigs.envs.withEmailCodes); + await app.dev(); + + const u = createTestUtils({ app }); + fakeUser = u.services.users.createFakeUser(); + const user = await u.services.users.createBapiUser(fakeUser); + fakeOrganization = await u.services.users.createFakeOrganization(user.id); + }); + + test.afterAll(async () => { + await fakeOrganization.delete(); + await fakeUser.deleteIfExists(); + + await app.teardown(); + }); + + test.afterEach(async ({ page, context }) => { + const u = createTestUtils({ app, page, context }); + await u.page.signOut(); + await u.page.context().clearCookies(); + }); + + test('should log in successfully', async ({ page, context }) => { + const u = createTestUtils({ app, page, context }); + + await u.page.goToAppHome(); + await u.po.expect.toBeSignedOut(); + await u.page.waitForClerkJsLoaded(); + + await u.page.getByRole('button', { name: /Sign in/i }).click(); + await u.po.signIn.waitForMounted(); + await u.po.signIn.signInWithEmailAndInstantPassword({ email: fakeUser.email, password: fakeUser.password }); + + await u.page.waitForAppUrl('/'); + await u.po.expect.toBeSignedIn(); + await u.po.userButton.waitForMounted(); + await u.po.userButton.toggleTrigger(); + await u.po.userButton.waitForPopover(); + + await u.po.userButton.toHaveVisibleMenuItems([/Manage account/i, /Sign out$/i]); + }); +}); diff --git a/package.json b/package.json index bf422c2522..3bfbe08b6d 100644 --- a/package.json +++ b/package.json @@ -38,7 +38,7 @@ "test:integration:nextjs": "E2E_APP_ID=next.appRouter.* pnpm test:integration:base --grep @nextjs", "test:integration:nuxt": "E2E_APP_ID=nuxt.node npm run test:integration:base -- --grep @nuxt", "test:integration:quickstart": "E2E_APP_ID=quickstart.* pnpm test:integration:base --grep @quickstart", - "test:integration:react-router": "E2E_APP_ID=react-router.node npm run test:integration:base -- --grep @react-router", + "test:integration:react-router": "E2E_APP_ID=react-router.* npm run test:integration:base -- --grep @react-router", "test:integration:sessions": "pnpm test:integration:base --grep @sessions", "test:integration:tanstack-router": "E2E_APP_ID=tanstack.router pnpm test:integration:base --grep @tanstack-router", "test:integration:tanstack-start": "E2E_APP_ID=tanstack.start pnpm test:integration:base --grep @tanstack-start", From 05c5de9201ac94ca889d4b65a9aab2946beb2474 Mon Sep 17 00:00:00 2001 From: Nikos Douvlis Date: Thu, 19 Dec 2024 17:48:32 +0200 Subject: [PATCH 5/7] fix(clerk-js): Rethrow errors if not requires_captcha during init (#4812) --- .changeset/ten-taxis-decide.md | 5 +++++ packages/clerk-js/src/core/clerk.ts | 2 ++ 2 files changed, 7 insertions(+) create mode 100644 .changeset/ten-taxis-decide.md diff --git a/.changeset/ten-taxis-decide.md b/.changeset/ten-taxis-decide.md new file mode 100644 index 0000000000..6adfd9b398 --- /dev/null +++ b/.changeset/ten-taxis-decide.md @@ -0,0 +1,5 @@ +--- +"@clerk/clerk-js": patch +--- + +fix(clerk-js): Rethrow errors if not requires_captcha during init diff --git a/packages/clerk-js/src/core/clerk.ts b/packages/clerk-js/src/core/clerk.ts index b1cfd5d586..eb91cc89b5 100644 --- a/packages/clerk-js/src/core/clerk.ts +++ b/packages/clerk-js/src/core/clerk.ts @@ -1898,6 +1898,8 @@ export class Clerk implements ClerkInterface { await initEnvironmentPromise; initComponents(); await initClient(); + } else { + throw e; } }); From 99f7536f191eb7b4f2ecff008f5523c500a02816 Mon Sep 17 00:00:00 2001 From: Laura Beatris <48022589+LauraBeatris@users.noreply.github.com> Date: Thu, 19 Dec 2024 13:46:26 -0300 Subject: [PATCH 6/7] fix(clerk-js): Fix broken enterprise connection icon for custom SAML provider (#4809) --- .changeset/friendly-trains-love.md | 5 +++++ .../UserProfile/EnterpriseAccountsSection.tsx | 11 ----------- 2 files changed, 5 insertions(+), 11 deletions(-) create mode 100644 .changeset/friendly-trains-love.md diff --git a/.changeset/friendly-trains-love.md b/.changeset/friendly-trains-love.md new file mode 100644 index 0000000000..cd11208d2c --- /dev/null +++ b/.changeset/friendly-trains-love.md @@ -0,0 +1,5 @@ +--- +'@clerk/clerk-js': patch +--- + +Fix broken enterprise connection icon for custom SAML provider diff --git a/packages/clerk-js/src/ui/components/UserProfile/EnterpriseAccountsSection.tsx b/packages/clerk-js/src/ui/components/UserProfile/EnterpriseAccountsSection.tsx index 674e402d60..b697f3aef2 100644 --- a/packages/clerk-js/src/ui/components/UserProfile/EnterpriseAccountsSection.tsx +++ b/packages/clerk-js/src/ui/components/UserProfile/EnterpriseAccountsSection.tsx @@ -1,4 +1,3 @@ -import { iconImageUrl } from '@clerk/shared/constants'; import { useUser } from '@clerk/shared/react'; import type { EnterpriseAccountResource, OAuthProvider } from '@clerk/types'; @@ -83,7 +82,6 @@ const EnterpriseAccount = ({ account }: { account: EnterpriseAccountResource }) const EnterpriseAccountProviderIcon = ({ account }: { account: EnterpriseAccountResource }) => { const { provider, enterpriseConnection } = account; - const isCustomOAuthProvider = provider.startsWith('oauth_custom_'); const providerWithoutPrefix = provider.replace(/(oauth_|saml_)/, '').trim() as OAuthProvider; const connectionName = enterpriseConnection?.name ?? providerWithoutPrefix; @@ -94,15 +92,6 @@ const EnterpriseAccountProviderIcon = ({ account }: { account: EnterpriseAccount elementId: descriptors.enterpriseButtonsProviderIcon.setId(account.provider), }; - if (!isCustomOAuthProvider) { - return ( - - ); - } - return enterpriseConnection?.logoPublicUrl ? ( Date: Thu, 19 Dec 2024 18:53:00 +0200 Subject: [PATCH 7/7] fix(clerk-expo): Re-export the `isClerkRuntimeError()` utility (#4815) --- .changeset/light-impalas-visit.md | 5 +++++ packages/expo/src/index.ts | 8 +++++++- 2 files changed, 12 insertions(+), 1 deletion(-) create mode 100644 .changeset/light-impalas-visit.md diff --git a/.changeset/light-impalas-visit.md b/.changeset/light-impalas-visit.md new file mode 100644 index 0000000000..5bc4534e1c --- /dev/null +++ b/.changeset/light-impalas-visit.md @@ -0,0 +1,5 @@ +--- +'@clerk/clerk-expo': patch +--- + +Re-export the `isClerkRuntimeError()` utility function from `@clerk/clerk-react`. diff --git a/packages/expo/src/index.ts b/packages/expo/src/index.ts index acb5c04139..57b60c6dac 100644 --- a/packages/expo/src/index.ts +++ b/packages/expo/src/index.ts @@ -1,6 +1,12 @@ import { setErrorThrowerOptions } from '@clerk/clerk-react/internal'; -export { isClerkAPIResponseError, isEmailLinkError, isKnownError, isMetamaskError } from '@clerk/clerk-react/errors'; +export { + isClerkAPIResponseError, + isEmailLinkError, + isKnownError, + isMetamaskError, + isClerkRuntimeError, +} from '@clerk/clerk-react/errors'; /** * @deprecated Use `getClerkInstance()` instead.