Sending cookies through server components
Answered
Siamese Crocodile posted this in #help-forum
data:image/s3,"s3://crabby-images/6d868/6d868490db02c60a2c8f935e1fc13af45c830f70" alt="Avatar"
Siamese CrocodileOP
Hi, I've an external backend that sets a cookie and It's set properly -> I can access it using nextjs cookies(). The problem is that when I want to fetch some user specific data using fetch with credentials include the cookies that I console log inside server component are not being sent to the external api.
const sessionId = (await cookies()).get('sessionId')?.value
console.log("sessionId") -> 'someuniqueid123'
fetch("my-external-api.com", { credentials: 'include'} ) // This session id above is not used for this request so we get 401
return <div>Server component</div>
Answered by B33fb0n3
you are right, cookies won't be directly forwarded. You need to place the cookies extra inside your fetch request
5 Replies
data:image/s3,"s3://crabby-images/6d868/6d868490db02c60a2c8f935e1fc13af45c830f70" alt="Avatar"
@Siamese Crocodile Hi, I've an external backend that sets a cookie and It's set properly -> I can access it using nextjs cookies(). The problem is that when I want to fetch some user specific data using fetch with credentials include the cookies that I console log inside server component are not being sent to the external api.
ts
const sessionId = (await cookies()).get('sessionId')?.value
console.log("sessionId") -> 'someuniqueid123'
fetch("my-external-api.com", { credentials: 'include'} ) // This session id above is not used for this request so we get 401
return <div>Server component</div>
data:image/s3,"s3://crabby-images/e9035/e9035780a5585406eb6421b82cd580e5dc8561fa" alt="Avatar"
you are right, cookies won't be directly forwarded. You need to place the cookies extra inside your fetch request
Answer
data:image/s3,"s3://crabby-images/6d868/6d868490db02c60a2c8f935e1fc13af45c830f70" alt="Avatar"
Siamese CrocodileOP
@B33fb0n3 that sucks - what if cookie has an expiration date and I will be pasing only the value.
Also the api would differ - when I do client side mutations I dont have to include credentials because cookies are sent automatically
When I am fetching some static data that doesnt require authentication I dont need to use cookies with fetch
But when I am fetching some user specific data i need to read cookies and set them manually in fetch
Is it the correct approach?
Also the api would differ - when I do client side mutations I dont have to include credentials because cookies are sent automatically
When I am fetching some static data that doesnt require authentication I dont need to use cookies with fetch
But when I am fetching some user specific data i need to read cookies and set them manually in fetch
Is it the correct approach?
data:image/s3,"s3://crabby-images/6d868/6d868490db02c60a2c8f935e1fc13af45c830f70" alt="Avatar"
@Siamese Crocodile <@301376057326567425> that sucks - what if cookie has an expiration date and I will be pasing only the value.
Also the api would differ - when I do client side mutations I dont have to include credentials because cookies are sent automatically
When I am fetching some static data that doesnt require authentication I dont need to use cookies with fetch
But when I am fetching some user specific data i need to read cookies and set them manually in fetch
Is it the correct approach?
data:image/s3,"s3://crabby-images/e9035/e9035780a5585406eb6421b82cd580e5dc8561fa" alt="Avatar"
what if cookie has an expiration date and I will be pasing only the valuenormally expiration dates are set directly to the cookie (as well) so you can't get an experied cookie.
Pass the cookies whenever you need them and when they are not passed automatically
data:image/s3,"s3://crabby-images/6d868/6d868490db02c60a2c8f935e1fc13af45c830f70" alt="Avatar"
Siamese CrocodileOP
Ty
data:image/s3,"s3://crabby-images/e9035/e9035780a5585406eb6421b82cd580e5dc8561fa" alt="Avatar"
happy to help