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

Announcing the Beta Release of nextjs-auth0 SDK v4 🎉 #1808

Open
brth31 opened this issue Nov 18, 2024 · 39 comments
Open

Announcing the Beta Release of nextjs-auth0 SDK v4 🎉 #1808

brth31 opened this issue Nov 18, 2024 · 39 comments

Comments

@brth31
Copy link

brth31 commented Nov 18, 2024

Hello everyone,

We're thrilled to announce the beta release of nextjs-auth0 SDK v4! This new version brings significant improvements, new features, and fixes to enhance your development experience.

⚠️ Important Notice About v3

As we move forward, we will not be updating v3 of the SDK to support Next.js 15. This allows us to focus on v4, which offers a wealth of new features and improvements. This will also enable us to support future releases of Next.js faster and with more confidence. We understand this may pose challenges, and we're here to help.

v3 will continue to receive critical security updates for 6 months after the GA of v4.

📣 Highlights of v4 Beta

  • Middleware-Based Authentication: Improved compatibility and reduced maintenance by moving to middleware-based handlers.
  • Enhanced Security: Switched to encrypted cookies and removed outdated cookie logic.
  • Resolved State Mismatch Issues: Fixed long-standing issues reported by the community.
  • Improved Session Management: Implemented rolling sessions and eliminated cookie chunking.
  • Improved Hooks and Helpers: Introduced useUser(), getAccessToken(), and getSession() for easier data fetching and session handling.
  • Stateful Sessions with Custom Databases: Support for "Bring Your Own Database" (BYODB).
  • Compatibility with Next.js 15, Turbopack, and React 19
  • Simplified architecture, API, and configuration options

✍️ Try It Out and Provide Feedback

We invite you to explore the beta release and share your feedback to help us improve before the general availability release. We are currently targeting a general availability release by the end of December.

Beta Release: v4.0.0-beta.3

⛵ Need Help with Migration?

If you encounter challenges migrating to v4, please don't hesitate to open an issue and our team will assist you. We're committed to making the transition as smooth as possible.

Thank You for Your Support 🙌

We appreciate your understanding as we focus on making v4 the best it can be. Your feedback is invaluable, and we're here to support you every step of the way.

Happy coding! 🚀

— The Auth0 DX SDK Team

@arpit-jn arpit-jn pinned this issue Nov 18, 2024
@curry1337
Copy link

Thank you for the beta release! Do you have any migration documentation or best practices available?

@brth31
Copy link
Author

brth31 commented Nov 18, 2024

@curry1337 we do have a comprehensive documentation that you can refer to- https://github.com/auth0/nextjs-auth0/blob/v4/README.md. Hope this helps!

@johncarmack1984
Copy link

johncarmack1984 commented Nov 18, 2024

@brth31 The documentation is lacking a coherent migration strategy for those using earlier versions; so far advice from the only auth0 engineer in these threads has delivered application-breaking fixes that actually made our application less secure. I would disagree with the use of the word "comprehensive" in your previous comment, and I disagree with a product strategy that ignores what paying customers are telling you about this release's clear unreadiness for use in production environments.

@curry1337
Copy link

@brth31 Thanks, what about the Edge Runtime? Couldn't find anything about it in the Readme.
We now use @auth0/nextjs-auth0/edge in the middleware.

Is import { Auth0Client } from "@auth0/nextjs-auth0/server" replacing the old edge?

@johncarmack1984
Copy link

@curry1337 not representing auth0 or Vercel, but happy to help a fellow engineer: Vercel reverted all edge rendering back to Node.js seven months ago, so the distinction is currently moot from a practical standpoint (although the Edge API remains in the Next.js docs, so Edge rendering may return in time, so it makes sense you would want the auth0 adapter to ensure support for it). Hope this helps you and your team plan for the future!

@curry1337
Copy link

@johncarmack1984 Wow thanks so much for sharing, really appreciated!

@mitchheddles
Copy link

mitchheddles commented Nov 19, 2024

Is there, or will there be, a way to use this without middleware? Middleware only feels like more of a limitation, rather than a "feature".

Update: After some testing, it seems like we're able to use the export const GET = auth0Client.middleware; in a route handler, as long as the routes match, e.g. /src/app/auth/[auth0]/route.ts. It doesn't feel right, but it's good enough for now.

@portal7
Copy link

portal7 commented Nov 19, 2024

I have tried (albeit a bit “commending myself to god”) to implement from 0 in a totally clean project using the initial steps indicated in the “getting started” article of NextJS 15.

I followed the steps they mention in v4 beta, but not only is it not entirely clear, but it didn't work for me.
as you can see in the attached image.

Is there any place where you can give a “practical” example or a test repo, or a sandbox to see how you implement it?
Thanks

image

@uprizingFaze
Copy link

Hi @portal7, I have a project that will be deployed to NextJs 15, and the Auth0 SDK is delaying us. We're going to wait for version 1.0 of SDKv4. In the meantime, I created a basic example to see how it works. You can check it out to get an idea.
https://github.com/uprizingFaze/NextJs_15-Auth0_V4

@portal7
Copy link

portal7 commented Nov 19, 2024

Hi @portal7, I have a project that will be deployed to NextJs 15, and the Auth0 SDK is delaying us. We're going to wait for version 1.0 of SDKv4. In the meantime, I created a basic example to see how it works. You can check it out to get an idea. https://github.com/uprizingFaze/NextJs_15-Auth0_V4

Thanks!!! I really appreciate it, I'm going to try it out and then.... we'll see.

@portal7
Copy link

portal7 commented Nov 19, 2024

Well, I downloaded it and tried to run it, but I have not been able to get it to work.

(unfortunately, I don't have enough experience in JS development to be able to go deeper and investigate what would be the problem).
image

@uprizingFaze
Copy link

Oh, this is because of npm i, many packages need to specify the version of React 19 to avoid that issue.
Just use npm i --force when using Next.js 15 or any React 19 project (if you use pnpm, Bun, or Yarn, I think this isn't necessary). Here’s a brief explanation

@portal7
Copy link

portal7 commented Nov 20, 2024

@uprizingFaze , thanks for the clarification, I will read the explanation to improve my knoweldge.

After rename and fil the values inside the .env.local values was able to run it with any other console error.

But....
image

Same as my capture with a fresh-started project with the new package installed.

@uprizingFaze
Copy link

It is likely due to the Auth0 environment variables or the URLs in the Auth0 dashboard.

Check this

Dashboard of my example:
Captura de pantalla 2024-11-19 a la(s) 7 34 10 p m

@portal7
Copy link

portal7 commented Nov 20, 2024

Well, after configuring the variables again in auth0 with the indicated values (I registered a new app so as not to modify what I had) and it worked.

The strange thing was that when I clicked on logout, I got an error that the value of the logout URL that I had passed was not valid.
image

And this is my configuration on Auth0
image

this was fixed when I added http://localhost:3000 (what the Auth0 error page said) as an enabled value.
Note: I am using beta-3 version, I don't know if this is solved in version 7, but I will try it.

image

Thanks @uprizingFaze
I strongly appreciate your time and the help/guidance you have given me.

@ctcooper
Copy link

ctcooper commented Nov 20, 2024

@portal7 Did you make sure your app in Auth0 is set as a 'Regular Application'?

'Settings -> Application Properties -> Application Type -> Regular Web Application'
Screenshot 2024-11-20 at 9 06 15 AM

@portal7
Copy link

portal7 commented Nov 20, 2024

Hi @ctcooper ,
No, the value selected in Auth0 was Single Page (SPA)

@paradimes
Copy link

Hi @ctcooper , No, the value selected in Auth0 was Single Page (SPA)

for next, you should use Regular Web Application:
Screenshot 2024-11-20 at 3 59 15 PM

@jamiebytebender
Copy link

jamiebytebender commented Nov 21, 2024

Is there any example of the new v4 working with org invitations?
I have a solution similar to this #701 (comment) where I was calling handleLogin previously but on the latest version there is no handleLogin exported.

@willedanielsson
Copy link

@curry1337 we do have a comprehensive documentation that you can refer to- https://github.com/auth0/nextjs-auth0/blob/v4/README.md. Hope this helps!

Hey, any news on a migration guide?
Like
"Rename env variable XX to YY" etcetera so it's easy to migrate and that people can propose updates to?
As someone going from 3 to 4 due to requirement for Nextjs, it would be good with a migration guide and not an installation guide 🙌

@curry1337
Copy link

@brth31 Could you please provide an update on when we can expect the stable release of v4? Our team has decided to wait for the stable release and not rely on the beta version.

@brth31
Copy link
Author

brth31 commented Dec 2, 2024

@curry1337 we are tentatively aiming to go GA later this month. I will share more updates closer to the release date.

@curry1337
Copy link

@brth31 Great! Thank you for replying so quickly.

@neptaco
Copy link

neptaco commented Dec 9, 2024

When I retrieve the AccessToken, the Payload section is missing. Is this issue occurring for anyone else? This happens both when setting up from scratch with beta9 and accessing /auth/access-token, as well as in projects updated from v3.5.0. In both cases, the Payload section is missing.

@mcgaryes
Copy link

mcgaryes commented Dec 9, 2024

@neptaco - I was not seeing the payload until I overwrote the beforeSessionSaved property. I also changed my audience in authorizationParameters to get the accessToken back in a JWT format.

export const auth0 = new Auth0Client({
    async beforeSessionSaved(session) {
        return {
            ...session,
            user: {
                ...session.user,
            },
        }
    },
    authorizationParameters: {
        audience: "https://service.com", // service that I was needing a JWT for 
    },
});

@neptaco
Copy link

neptaco commented Dec 10, 2024

@mcgaryes
Thank you for the information!
I tried it, and in my case, I was able to retrieve the information just by setting the audience.

In v3.5.0, I used the environment variable AUTH0_AUDIENCE for the configuration, but in v4, it seems that this setting is no longer applied via environment variables.

I’m not sure whether this change is intentional in v4 or if it’s a bug where environment variables are not being loaded.

@chris-erickson
Copy link

chris-erickson commented Dec 13, 2024

@mcgaryes Thank you for the information! I tried it, and in my case, I was able to retrieve the information just by setting the audience.

In v3.5.0, I used the environment variable AUTH0_AUDIENCE for the configuration, but in v4, it seems that this setting is no longer applied via environment variables.

I’m not sure whether this change is intentional in v4 or if it’s a bug where environment variables are not being loaded.

Docs seem to indicate this is now configured with manually setting up the client. Would be good for the migration one to indicate this needs to be adjusted if so!

Wondering as well if it's contributing to this error (that we're also seeing, but slightly different, can open a new issue as needed): #1841 (comment)

TypeError: Failed to parse URL from /auth/access-token.

Update: This seems to be not influencing to aforementioned bug. #1843

@jdwitten
Copy link

I also stumbled on the audience issue. Needed to supply it in the auth0 client initialization like @mcgaryes mentioned to get a valid payload in the JWT access token. Would be good to document this in the migration guide if it is intended.

@isoroka-plana
Copy link

isoroka-plana commented Dec 15, 2024

We noticed that with v4 Auth0 uses /oidc/logout instead of /v2/logout which doesn't work for us for some reason and the error is not detailed at all. Logout just fails with error 400 and in Auth0 logs says something like "Failed to logout user".
Is this configurable somehow or the oidc logout is now the main? There is no mention of this change in the migration guide nor v4 readme.

EDIT: /oidc/logout works if we don't provide returnTo which is not registered as Allowed Logout URL, so that was a different issue, found a workaround for it.

@jonkwheeler
Copy link

Is there, or will there be, a way to use this without middleware?

Furthermore, right now you cannot use Middleware with OpenNext and Cloudflare.

@calvinbrewer
Copy link

calvinbrewer commented Dec 18, 2024

I haven't looked deeper at this issue yet and will follow up with more details but running into the following error:
image

Next.js version: 15.1.0
React version: 19.0.0
@auth0/nextjs-auth0: 4.0.0-beta.11

Update: The Auth0 application must have at least one connection. The actual error was highlighted in the OAuth exchange.

@jamiebytebender
Copy link

Any updates on how organization invites are used and implemented with v4?

@brandanmajeske
Copy link

brandanmajeske commented Dec 31, 2024

My kingdom for a migration guide. I've followed the Beta readme and am not succeeding. So many breaking changes, I think I need to see a bare bones example project from the authors.

@jonkwheeler
Copy link

I'm almost ready to give the node package a try...

https://github.com/auth0/node-auth0
https://auth0.github.io/node-auth0/index.html

In the time I've spent debugging auth0 for nextjs I might have been able to built my own auth provider. Some people found it easy. Others didn't.

@isoroka-plana
Copy link

Is there any new GA target date?

@JordanHoffman
Copy link

JordanHoffman commented Jan 7, 2025

Is there something I need to do to get useUser() to stop pinging /auth/profile when I'm logged out. It seems like every 10 seconds it pings it even though it's unauthorized (I don't know if this is a bug or I'm doing something wrong, I'm literally just calling useUser()):

image

Edit, I think this has to do with the way I log out. In order for logout to work, I enabled RP-Initiated Logout End Session Endpoint Discovery. I notice that this unwanted pinging only starts happening after I first log out via a logout anchor url.

But I still don't know whats being done wrong or how to fix it.

@jonschmidt
Copy link

jonschmidt commented Jan 8, 2025

I haven't looked deeper at this issue yet and will follow up with more details but running into the following error: image

Next.js version: 15.1.0 React version: 19.0.0 @auth0/nextjs-auth0: 4.0.0-beta.11

Update: The Auth0 application must have at least one connection. The actual error was highlighted in the OAuth exchange.

I am getting this error, but I am using an application that in fact has a connection, so this is not the problem I think. Could it be something else? Is it possible that a cookie from v3 is not compatible with a cookie from v4? I am currently logged in with a user that was logged in using v3 while testing the upgrade. It would obviously be very bad if everyone had to logout to accomplish this upgrade.

Edit: It turns out this was because the cookie shares the same name as the Clerk cookie, which is "__session". Deleting that session cookie fixed the problem. However it would be nice to be able to configure the cookie name!

@kylemorena
Copy link

kylemorena commented Jan 10, 2025

Hello, does the latest version support Preview URLs and Branch URLs on Vercel?

The issue is having different domains, causing the redirect URI to mismatch.

@EvanLovely
Copy link

Hello, does the latest version support Preview URLs and Branch URLs on Vercel?

The issue is having different domains, causing the redirect URI to mismatch.

Use a * in the domain to add the Vercel URLs to your Allowed ____ URLs. It'd be something like https://*-my-project.vercel.app. Probably smart to not do https://*.vercel.app as that'd let any Vercel account use your stuff.

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

No branches or pull requests