-
Notifications
You must be signed in to change notification settings - Fork 460
Expand file tree
/
Copy pathnext-machine.test.ts
More file actions
124 lines (105 loc) · 3.49 KB
/
Copy pathnext-machine.test.ts
File metadata and controls
124 lines (105 loc) · 3.49 KB
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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
import { test } from '@playwright/test';
import { appConfigs } from '../presets';
import type { MachineAuthTestAdapter } from '../testUtils/machineAuthHelpers';
import {
registerApiKeyAuthTests,
registerM2MAuthTests,
registerOAuthAuthTests,
registerRateLimitTests,
} from '../testUtils/machineAuthHelpers';
const adapter: MachineAuthTestAdapter = {
baseConfig: appConfigs.next.appRouter,
apiKey: {
path: '/api/me',
addRoutes: config =>
config.addFile(
'src/app/api/me/route.ts',
() => `
import { auth } from '@clerk/nextjs/server';
export async function GET() {
const { userId, tokenType } = await auth({ acceptsToken: 'api_key' });
if (!userId) {
return Response.json({ error: 'Unauthorized' }, { status: 401 });
}
return Response.json({ userId, tokenType });
}
export async function POST() {
const authObject = await auth({ acceptsToken: ['api_key', 'session_token'] });
if (!authObject.isAuthenticated) {
return Response.json({ error: 'Unauthorized' }, { status: 401 });
}
return Response.json({ userId: authObject.userId, tokenType: authObject.tokenType });
}
`,
),
},
m2m: {
path: '/api/protected',
addRoutes: config =>
config.addFile(
'src/app/api/protected/route.ts',
() => `
import { auth } from '@clerk/nextjs/server';
export async function GET() {
const { subject, tokenType, isAuthenticated } = await auth({ acceptsToken: 'm2m_token' });
if (!isAuthenticated) {
return Response.json({ error: 'Unauthorized' }, { status: 401 });
}
return Response.json({ subject, tokenType });
}
`,
),
},
oauth: {
verifyPath: '/api/protected',
callbackPath: '/oauth/callback',
addRoutes: config =>
config
.addFile(
'src/app/api/protected/route.ts',
() => `
import { auth } from '@clerk/nextjs/server';
export async function GET() {
const { userId, tokenType } = await auth({ acceptsToken: 'oauth_token' });
if (!userId) {
return Response.json({ error: 'Unauthorized' }, { status: 401 });
}
return Response.json({ userId, tokenType });
}
`,
)
.addFile(
'src/app/oauth/callback/route.ts',
() => `
import { NextResponse } from 'next/server';
export async function GET() {
return NextResponse.json({ message: 'OAuth callback received' });
}
`,
),
},
rateLimit: {
path: '/api/rate-limit-test',
addRoutes: config =>
config.addFile(
'src/app/api/rate-limit-test/route.ts',
() => `
import { auth } from '@clerk/nextjs/server';
export async function GET(request: Request) {
const { userId, tokenType } = await auth({ acceptsToken: 'api_key' });
if (!userId) {
const reason = request.headers.get('x-clerk-auth-reason');
return Response.json({ error: 'Unauthorized', reason }, { status: 401 });
}
return Response.json({ userId, tokenType });
}
`,
),
},
};
test.describe('Next.js machine authentication @machine', () => {
registerApiKeyAuthTests(adapter);
registerM2MAuthTests(adapter);
registerOAuthAuthTests(adapter);
registerRateLimitTests(adapter);
});