-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathlogout+api.ts
More file actions
37 lines (32 loc) · 877 Bytes
/
logout+api.ts
File metadata and controls
37 lines (32 loc) · 877 Bytes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
import { parse } from 'cookie';
import { deleteSession } from '../../../database/sessions';
import { ExpoApiResponse } from '../../../ExpoApiResponse';
import { deleteSerializedSessionTokenCookie } from '../../../util/cookies';
export type LogoutResponseBodyPost =
| {
success: true;
}
| {
error: string;
};
export async function POST(
request: Request,
): Promise<ExpoApiResponse<LogoutResponseBodyPost>> {
const cookies = parse(request.headers.get('cookie') || '');
const sessionToken = cookies.sessionToken;
if (!sessionToken) {
return ExpoApiResponse.json(
{ error: 'Authentication required' },
{ status: 401 },
);
}
await deleteSession(sessionToken);
return ExpoApiResponse.json(
{ success: true },
{
headers: {
'Set-Cookie': deleteSerializedSessionTokenCookie(),
},
},
);
}