Next.js - blocking error upon login when creating new organisations
I've been creating new organisations, which was working as expected, but with the latest organisations, my support user is running into issues with the Kinde SDK after logging into such an organisation, even though I haven't made any changes compared to what was previously working.
While this is still working correctly for previous organisations, it's blocking me from onboarding new customers at the moment so quite severe for my side and I hope somebody can help me figure out what might be going wrong.
data:image/s3,"s3://crabby-images/e53e6/e53e640905cc4f05baa064a413c762410984ebed" alt="No description"
data:image/s3,"s3://crabby-images/a566c/a566cf13ee2ccf6f9d5e87067d44357f07cfe980" alt="No description"
22 Replies
This is the code in my middleware
Hi @Woet , what version of the SDK are you using (and have you upgraded recently?)
I'm currently on "@kinde-oss/kinde-auth-nextjs": "^2.4.6",
This might be an odd request but could you try downgrading to 2.4.5 and see if you continue to get the error?
The reason I ask is because I believe there may be a bug in version 2.4.6 of the SDK that could be causing this - I haven't been able to replicate your issue specifically, but I can replicate null ID tokens in middleware (which could lead to the error you're experiencing)
I'll take a look
Let me know how you go, I'll be around to help 🙂
Still getting the same error unfortunately:
data:image/s3,"s3://crabby-images/2f092/2f092c42a581d3edf1641e3e869083b026b176eb" alt="No description"
Okay, so that leaves us with 2 possibilities here - the ID token is null, or, somehow, the user has a null family name. Let’s try the easy one first - in the users profile on the Kinde admin dashboard, do they have a family name set? If not can we set it to something temporary?
That was idd my first idea; so I split the name in two
data:image/s3,"s3://crabby-images/0fae3/0fae30f48334a33d0af358b85e4bd1d28030e711" alt="No description"
But doesn't seem to quite solve the issue yet
Okay great! In the middleware, can we try doing:
Just to confirm the user is definitely authenticated?
If that returns true, I'd like to see if we're getting any ID token at all:
Logging things is a little bit of a hassle right now though, cause I only have the issue with my production environment
Haven't been able to reproduce it yet when working with my development environment on Kinde
I also have some auth checks in the layout of the project, could this be causing any conflicts:
´´´
So my auth in the middleware is a bit redundant?
I don't believe so - if this is your root layout though, your middleware may be a little redundant.
Understood RE: logging, build times suck - I have tried to replicate it on Vercel and locally to no avail unfortunately (though I'm not using your CSP headers, but I don't think that would be the cause of issue here) - unfortunately it's hard to move much further without logging to narrow down the cause. All I can get from the error returned right now is that the error appears to be happening on this line of the source, which means the
idTokenValue
defined on line 39 is for some reason in your case null.GitHub
kinde-auth-nextjs/src/authMiddleware/authMiddleware.ts at c65d26508...
Kinde NextJS SDK - authentication for server rendered apps - kinde-oss/kinde-auth-nextjs
On that note, these are also redundant in your middleware options:
public paths defaults to nothing by default, and isAuthorized will default to true, so if these aren't in use you can omit them 🙂 (unrelated to the bug, just thought I'd let you know)
I've removed the middleware and tried only authenticating from the root layout, but the issue persists. I've also tried linking another user to the organisation and this works as expected. Considering it also only crashes when the support user is added on specific organisations, it seems it's throwing an error on the missing last name for some orgs, but not for others.
data:image/s3,"s3://crabby-images/420ac/420ac52721d9b3128bb3b3201a42858d48e14ac7" alt="No description"
I used to not give the user a last name
I think that's still causing some issues somewhere
@Yoshify sorry, I had to deliver 3 new customer organisations for tomorrow, so worked around this issue for now with another account. I've setup my dev so I can already log the issues there and it does indeed seem that it already goes wrong with the isAuthenticated() check
data:image/s3,"s3://crabby-images/85015/850151eee1dc4eeb9e5a7191a700dea98b45214c" alt="No description"
@Woet Understood - and this only happens with this Finibase Support user you've created? No other user causes this problem?
@Yoshify yeah, I've also contacted Kinde support. Looks like the problem was due the organizations array option enabled in the ID token. It only with the support user because it had a lot of organizations linked (20+) and this scale apparently causes an issue with the ID token at the moment (I enabled it to develop a tenant switcher in my app). I've disabled this option and working as normal again now.
data:image/s3,"s3://crabby-images/4a23a/4a23a5fe3602b7fed6ba0a1d4a9ff6947690bfb7" alt="No description"
Thanks for sharing @Woet - I wasn’t aware of this limitation either (I might actually run into this same issue in my app soon…)
Hopefully it’s something the team can fix soon!
Hope so! 🤞
But thanks for the help @Yoshify, appreciate it!
Any time mate, it's what I'm here for! Happy building 👏