Replies: 1 comment
-
By the way, is API APP possible to switch to Hono ? |
Beta Was this translation helpful? Give feedback.
0 replies
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
-
Is your feature request related to a problem? Please describe.
More of a discussion (maybe we need a discussions tab). My understanding was that the API was to be used as a standalone API service rather then just a functions wrapper.
In most of our SaaS products the API is a seperate service. Currently
apps/api
there is no way to easily verify a user.The solution I went with
In the interest of keeping strong seperation of concern I have setup the API as follows.
https://api.mydomain.com
Middleware
In the middleware for the API I do a few things.
Server Component/Page Fetching
How do we attach the user to the api?
Clerk has a few different methods but the easiest way I found was just to include the Auth header. I created a fetch function similar to this that I can call from any server component in app or web or any other microservice we create.
This attached the session to the auth header as Clerk expects it.
Server Actions/Forms
The intent for Server Actions becomes really obvious in this now. We can use server actions to invoke the API. Here is a very simple one I use for submitting a form.
in apps/app/app/actions/nameAction.ts
Clerk In API
After this we can create the user session on the server.
If you use the JWT public key it will verify the session without sending a request to Clerks backend. I have created a function like so.
Then I just call this first in any API route that needs a user attached
Results
This makes the API a completely stand alone system that can still use the Clerk user for auth.
With how Next.js works it adds a strong seperation of concern. It also makes it extendable or replaceable. They push heavy that data fetching/mutations should happen server side. This has the benefit's of both and prevents any valuable info being leaked to the client.
Shortcomings
I am aware that calling a server action in itself is an api request. In early testing in other projects the impact with not really a concern. The benefits out weighed the negatives.
While this is definitely more code, I think its one of the core reasons why this repo is so popular. Everything is seperate, it makes it very easy to find things.
This extends on that fact. It felt a bit messy putting API routes in the app when we had a dedicated API service.
Describe alternatives you've considered
I would love some feedback on this. Maybe it can be improved.
Beta Was this translation helpful? Give feedback.
All reactions