payload
Version:
Node, React, Headless CMS and Application Framework built on Next.js
38 lines (37 loc) • 1.25 kB
JavaScript
// @ts-strict-ignore
import { status as httpStatus } from 'http-status';
import { getRequestCollection } from '../../utilities/getRequestEntity.js';
import { headersWithCors } from '../../utilities/headersWithCors.js';
import { generatePayloadCookie } from '../cookies.js';
import { refreshOperation } from '../operations/refresh.js';
export const refreshHandler = async (req)=>{
const collection = getRequestCollection(req);
const { t } = req;
const headers = headersWithCors({
headers: new Headers(),
req
});
const result = await refreshOperation({
collection,
req
});
if (result.setCookie) {
const cookie = generatePayloadCookie({
collectionAuthConfig: collection.config.auth,
cookiePrefix: req.payload.config.cookiePrefix,
token: result.refreshedToken
});
if (collection.config.auth.removeTokenFromResponses) {
delete result.refreshedToken;
}
headers.set('Set-Cookie', cookie);
}
return Response.json({
message: t('authentication:tokenRefreshSuccessful'),
...result
}, {
headers,
status: httpStatus.OK
});
};
//# sourceMappingURL=refresh.js.map