dn-react-router-toolkit 0.1.0 → 0.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/auth-kit/apple_auth.d.mts +24 -0
- package/dist/{esm/auth-kit → auth-kit}/apple_auth.d.ts +11 -2
- package/dist/auth-kit/apple_auth.js +75 -0
- package/dist/auth-kit/apple_auth.mjs +50 -0
- package/dist/auth-kit/auth_service.d.mts +73 -0
- package/dist/{esm/auth-kit → auth-kit}/auth_service.d.ts +17 -11
- package/dist/auth-kit/auth_service.js +257 -0
- package/dist/auth-kit/auth_service.mjs +218 -0
- package/dist/auth-kit/client/google_login_button.d.mts +9 -0
- package/dist/auth-kit/client/google_login_button.d.ts +9 -0
- package/dist/auth-kit/client/google_login_button.js +67 -0
- package/dist/auth-kit/client/google_login_button.mjs +32 -0
- package/dist/auth-kit/client/redirect_page.d.mts +5 -0
- package/dist/auth-kit/client/redirect_page.d.ts +5 -0
- package/dist/auth-kit/client/redirect_page.js +53 -0
- package/dist/auth-kit/client/redirect_page.mjs +18 -0
- package/dist/auth-kit/google_auth.d.mts +27 -0
- package/dist/{esm/auth-kit → auth-kit}/google_auth.d.ts +11 -2
- package/dist/auth-kit/google_auth.js +144 -0
- package/dist/auth-kit/google_auth.mjs +117 -0
- package/dist/auth-kit/jwt.d.mts +18 -0
- package/dist/{esm/auth-kit → auth-kit}/jwt.d.ts +5 -2
- package/dist/auth-kit/jwt.js +76 -0
- package/dist/auth-kit/jwt.mjs +51 -0
- package/dist/auth-kit/kakao_auth.d.mts +24 -0
- package/dist/{esm/auth-kit → auth-kit}/kakao_auth.d.ts +11 -2
- package/dist/auth-kit/kakao_auth.js +115 -0
- package/dist/auth-kit/kakao_auth.mjs +88 -0
- package/dist/auth-kit/repository.d.mts +42 -0
- package/dist/{esm/auth-kit → auth-kit}/repository.d.ts +3 -1
- package/dist/auth-kit/repository.js +18 -0
- package/dist/auth-kit/repository.mjs +0 -0
- package/dist/auth-kit/with_auth.d.mts +17 -0
- package/dist/auth-kit/with_auth.d.ts +17 -0
- package/dist/auth-kit/with_auth.js +108 -0
- package/dist/auth-kit/with_auth.mjs +71 -0
- package/dist/cn.d.mts +3 -0
- package/dist/cn.d.ts +3 -0
- package/dist/cn.js +32 -0
- package/dist/cn.mjs +7 -0
- package/dist/components/index.d.mts +5 -0
- package/dist/components/index.d.ts +5 -0
- package/dist/components/index.js +261 -0
- package/dist/components/index.mjs +219 -0
- package/dist/components/modal/fullscreen_container.d.mts +7 -0
- package/dist/components/modal/fullscreen_container.d.ts +7 -0
- package/dist/components/modal/fullscreen_container.js +102 -0
- package/dist/components/modal/fullscreen_container.mjs +68 -0
- package/dist/components/modal/hooks.d.mts +18 -0
- package/dist/components/modal/hooks.d.ts +18 -0
- package/dist/components/modal/hooks.js +236 -0
- package/dist/components/modal/hooks.mjs +204 -0
- package/dist/components/modal/index.d.mts +4 -0
- package/dist/components/modal/index.d.ts +4 -0
- package/dist/components/modal/index.js +238 -0
- package/dist/components/modal/index.mjs +203 -0
- package/dist/components/modal/modal.d.mts +13 -0
- package/dist/components/modal/modal.d.ts +13 -0
- package/dist/components/modal/modal.js +155 -0
- package/dist/components/modal/modal.mjs +130 -0
- package/dist/components/styles.d.mts +9 -0
- package/dist/components/styles.d.ts +9 -0
- package/dist/components/styles.js +48 -0
- package/dist/components/styles.mjs +17 -0
- package/dist/date.d.mts +3 -0
- package/dist/date.d.ts +3 -0
- package/dist/date.js +63 -0
- package/dist/date.mjs +28 -0
- package/dist/file-kit/cdn.d.mts +5 -0
- package/dist/file-kit/cdn.d.ts +5 -0
- package/dist/file-kit/cdn.js +34 -0
- package/dist/file-kit/cdn.mjs +9 -0
- package/dist/file-kit/client/drop_file_input.d.mts +33 -0
- package/dist/{esm/file-kit → file-kit}/client/drop_file_input.d.ts +9 -7
- package/dist/file-kit/client/drop_file_input.js +235 -0
- package/dist/file-kit/client/drop_file_input.mjs +205 -0
- package/dist/file-kit/client/file_uploader.d.mts +13 -0
- package/dist/{esm/file-kit → file-kit}/client/file_uploader.d.ts +4 -2
- package/dist/file-kit/client/file_uploader.js +115 -0
- package/dist/file-kit/client/file_uploader.mjs +90 -0
- package/dist/file-kit/file_service.d.mts +26 -0
- package/dist/{esm/file-kit → file-kit}/file_service.d.ts +7 -4
- package/dist/file-kit/file_service.js +60 -0
- package/dist/file-kit/file_service.mjs +35 -0
- package/dist/file-kit/object_storage.d.mts +17 -0
- package/dist/{esm/file-kit → file-kit}/object_storage.d.ts +6 -2
- package/dist/file-kit/object_storage.js +78 -0
- package/dist/file-kit/object_storage.mjs +57 -0
- package/dist/file-kit/repository.d.mts +16 -0
- package/dist/{esm/file-kit → file-kit}/repository.d.ts +3 -1
- package/dist/file-kit/repository.js +18 -0
- package/dist/file-kit/repository.mjs +0 -0
- package/dist/file-kit/responsive_image.d.mts +20 -0
- package/dist/file-kit/responsive_image.d.ts +20 -0
- package/dist/file-kit/responsive_image.js +123 -0
- package/dist/file-kit/responsive_image.mjs +87 -0
- package/dist/http-kit/index.d.mts +1 -0
- package/dist/http-kit/index.d.ts +1 -0
- package/dist/http-kit/index.js +111 -0
- package/dist/http-kit/index.mjs +68 -0
- package/dist/http-kit/response.d.mts +19 -0
- package/dist/http-kit/response.d.ts +19 -0
- package/dist/http-kit/response.js +109 -0
- package/dist/http-kit/response.mjs +68 -0
- package/dist/index.d.mts +4 -0
- package/dist/index.d.ts +4 -0
- package/dist/index.js +91 -0
- package/dist/index.mjs +51 -0
- package/dist/route/api/auth/login/[provider]/route.js +113 -0
- package/dist/route/api/auth/login/[provider]/route.mjs +86 -0
- package/dist/route/api/auth/login/_provider_/route.d.mts +20 -0
- package/dist/route/api/auth/login/_provider_/route.d.ts +20 -0
- package/dist/route/api/auth/login/route.d.mts +14 -0
- package/dist/route/api/auth/login/route.d.ts +14 -0
- package/dist/route/api/auth/login/route.js +107 -0
- package/dist/route/api/auth/login/route.mjs +80 -0
- package/dist/route/api/auth/logout/route.d.mts +14 -0
- package/dist/route/api/auth/logout/route.d.ts +14 -0
- package/dist/route/api/auth/logout/route.js +98 -0
- package/dist/route/api/auth/logout/route.mjs +71 -0
- package/dist/route/api/auth/refresh/route.d.mts +13 -0
- package/dist/route/api/auth/refresh/route.d.ts +13 -0
- package/dist/route/api/auth/refresh/route.js +92 -0
- package/dist/route/api/auth/refresh/route.mjs +65 -0
- package/dist/route/api/auth/route.d.mts +13 -0
- package/dist/route/api/auth/route.d.ts +13 -0
- package/dist/route/api/auth/route.js +82 -0
- package/dist/route/api/auth/route.mjs +55 -0
- package/dist/route/api/files/[fileId]/route.js +99 -0
- package/dist/route/api/files/[fileId]/route.mjs +72 -0
- package/dist/route/api/files/_fileId_/route.d.mts +17 -0
- package/dist/route/api/files/_fileId_/route.d.ts +17 -0
- package/dist/route/api/files/route.d.mts +16 -0
- package/dist/route/api/files/route.d.ts +16 -0
- package/dist/route/api/files/route.js +106 -0
- package/dist/route/api/files/route.mjs +79 -0
- package/dist/route/api.d.mts +29 -0
- package/dist/route/api.d.ts +29 -0
- package/dist/route/api.js +395 -0
- package/dist/route/api.mjs +368 -0
- package/dist/route/auth/callback/[provider]/route.js +120 -0
- package/dist/route/auth/callback/[provider]/route.mjs +93 -0
- package/dist/route/auth/callback/_provider_/route.d.mts +20 -0
- package/dist/route/auth/callback/_provider_/route.d.ts +20 -0
- package/dist/seo-kit/index.d.mts +6 -0
- package/dist/seo-kit/index.d.ts +6 -0
- package/dist/seo-kit/index.js +321 -0
- package/dist/seo-kit/index.mjs +282 -0
- package/dist/seo-kit/loader.d.mts +7 -0
- package/dist/seo-kit/loader.d.ts +7 -0
- package/dist/seo-kit/loader.js +43 -0
- package/dist/seo-kit/loader.mjs +18 -0
- package/dist/seo-kit/seo.d.mts +103 -0
- package/dist/{esm/seo-kit → seo-kit}/seo.d.ts +9 -6
- package/dist/seo-kit/seo.js +286 -0
- package/dist/seo-kit/seo.mjs +251 -0
- package/dist/seo-kit/seo_loader.d.mts +16 -0
- package/dist/seo-kit/seo_loader.d.ts +16 -0
- package/dist/seo-kit/seo_loader.js +68 -0
- package/dist/seo-kit/seo_loader.mjs +31 -0
- package/dist/singleton.d.mts +3 -0
- package/dist/singleton.d.ts +3 -0
- package/dist/singleton.js +37 -0
- package/dist/singleton.mjs +12 -0
- package/dist/slug.d.mts +3 -0
- package/dist/slug.d.ts +3 -0
- package/dist/slug.js +32 -0
- package/dist/slug.mjs +7 -0
- package/package.json +36 -34
- package/tsup.config.ts +9 -0
- package/dist/cjs/auth-kit/apple_auth.js +0 -60
- package/dist/cjs/auth-kit/auth_service.js +0 -204
- package/dist/cjs/auth-kit/client/google_login_button.js +0 -25
- package/dist/cjs/auth-kit/client/redirect_page.js +0 -21
- package/dist/cjs/auth-kit/google_auth.js +0 -65
- package/dist/cjs/auth-kit/jwt.js +0 -53
- package/dist/cjs/auth-kit/kakao_auth.js +0 -38
- package/dist/cjs/auth-kit/repository.js +0 -2
- package/dist/cjs/auth-kit/with_auth.js +0 -46
- package/dist/cjs/cn.js +0 -6
- package/dist/cjs/components/index.js +0 -18
- package/dist/cjs/components/modal/fullscreen_container.js +0 -64
- package/dist/cjs/components/modal/hooks.js +0 -78
- package/dist/cjs/components/modal/index.js +0 -19
- package/dist/cjs/components/modal/modal.js +0 -91
- package/dist/cjs/components/styles.js +0 -10
- package/dist/cjs/date.js +0 -31
- package/dist/cjs/file-kit/cdn.js +0 -9
- package/dist/cjs/file-kit/client/drop_file_input.js +0 -195
- package/dist/cjs/file-kit/client/file_uploader.js +0 -78
- package/dist/cjs/file-kit/file_service.js +0 -29
- package/dist/cjs/file-kit/object_storage.js +0 -50
- package/dist/cjs/file-kit/repository.js +0 -2
- package/dist/cjs/file-kit/responsive_image.js +0 -78
- package/dist/cjs/http-kit/index.js +0 -17
- package/dist/cjs/http-kit/response.js +0 -34
- package/dist/cjs/index.js +0 -20
- package/dist/cjs/route/api/auth/login/[provider]/route.js +0 -36
- package/dist/cjs/route/api/auth/login/route.js +0 -35
- package/dist/cjs/route/api/auth/logout/route.js +0 -22
- package/dist/cjs/route/api/auth/refresh/route.js +0 -23
- package/dist/cjs/route/api/auth/route.js +0 -12
- package/dist/cjs/route/api/files/[fileId]/route.js +0 -20
- package/dist/cjs/route/api/files/route.js +0 -34
- package/dist/cjs/route/auth/callback/[provider]/route.js +0 -35
- package/dist/cjs/route/index.js +0 -80
- package/dist/cjs/seo-kit/index.js +0 -19
- package/dist/cjs/seo-kit/loader.js +0 -17
- package/dist/cjs/seo-kit/seo.js +0 -286
- package/dist/cjs/seo-kit/seo_loader.js +0 -19
- package/dist/cjs/singleton.js +0 -12
- package/dist/cjs/slug.js +0 -10
- package/dist/esm/auth-kit/apple_auth.js +0 -56
- package/dist/esm/auth-kit/auth_service.js +0 -197
- package/dist/esm/auth-kit/client/google_login_button.d.ts +0 -6
- package/dist/esm/auth-kit/client/google_login_button.js +0 -19
- package/dist/esm/auth-kit/client/redirect_page.d.ts +0 -2
- package/dist/esm/auth-kit/client/redirect_page.js +0 -15
- package/dist/esm/auth-kit/google_auth.js +0 -61
- package/dist/esm/auth-kit/jwt.js +0 -49
- package/dist/esm/auth-kit/kakao_auth.js +0 -34
- package/dist/esm/auth-kit/repository.js +0 -1
- package/dist/esm/auth-kit/with_auth.d.ts +0 -12
- package/dist/esm/auth-kit/with_auth.js +0 -43
- package/dist/esm/cn.d.ts +0 -1
- package/dist/esm/cn.js +0 -3
- package/dist/esm/components/index.d.ts +0 -2
- package/dist/esm/components/index.js +0 -2
- package/dist/esm/components/modal/fullscreen_container.d.ts +0 -5
- package/dist/esm/components/modal/fullscreen_container.js +0 -57
- package/dist/esm/components/modal/hooks.d.ts +0 -15
- package/dist/esm/components/modal/hooks.js +0 -69
- package/dist/esm/components/modal/index.d.ts +0 -3
- package/dist/esm/components/modal/index.js +0 -3
- package/dist/esm/components/modal/modal.d.ts +0 -10
- package/dist/esm/components/modal/modal.js +0 -55
- package/dist/esm/components/styles.d.ts +0 -7
- package/dist/esm/components/styles.js +0 -7
- package/dist/esm/date.d.ts +0 -1
- package/dist/esm/date.js +0 -24
- package/dist/esm/file-kit/cdn.d.ts +0 -3
- package/dist/esm/file-kit/cdn.js +0 -5
- package/dist/esm/file-kit/client/drop_file_input.js +0 -158
- package/dist/esm/file-kit/client/file_uploader.js +0 -74
- package/dist/esm/file-kit/file_service.js +0 -25
- package/dist/esm/file-kit/object_storage.js +0 -46
- package/dist/esm/file-kit/repository.js +0 -1
- package/dist/esm/file-kit/responsive_image.d.ts +0 -17
- package/dist/esm/file-kit/responsive_image.js +0 -70
- package/dist/esm/http-kit/index.d.ts +0 -1
- package/dist/esm/http-kit/index.js +0 -1
- package/dist/esm/http-kit/response.d.ts +0 -17
- package/dist/esm/http-kit/response.js +0 -28
- package/dist/esm/index.d.ts +0 -4
- package/dist/esm/index.js +0 -4
- package/dist/esm/route/api/auth/login/[provider]/route.d.ts +0 -10
- package/dist/esm/route/api/auth/login/[provider]/route.js +0 -32
- package/dist/esm/route/api/auth/login/route.d.ts +0 -6
- package/dist/esm/route/api/auth/login/route.js +0 -31
- package/dist/esm/route/api/auth/logout/route.d.ts +0 -6
- package/dist/esm/route/api/auth/logout/route.js +0 -18
- package/dist/esm/route/api/auth/refresh/route.d.ts +0 -4
- package/dist/esm/route/api/auth/refresh/route.js +0 -19
- package/dist/esm/route/api/auth/route.d.ts +0 -4
- package/dist/esm/route/api/auth/route.js +0 -8
- package/dist/esm/route/api/files/[fileId]/route.d.ts +0 -8
- package/dist/esm/route/api/files/[fileId]/route.js +0 -16
- package/dist/esm/route/api/files/route.d.ts +0 -6
- package/dist/esm/route/api/files/route.js +0 -30
- package/dist/esm/route/auth/callback/[provider]/route.d.ts +0 -11
- package/dist/esm/route/auth/callback/[provider]/route.js +0 -31
- package/dist/esm/route/index.d.ts +0 -22
- package/dist/esm/route/index.js +0 -76
- package/dist/esm/seo-kit/index.d.ts +0 -3
- package/dist/esm/seo-kit/index.js +0 -3
- package/dist/esm/seo-kit/loader.d.ts +0 -5
- package/dist/esm/seo-kit/loader.js +0 -14
- package/dist/esm/seo-kit/seo.js +0 -280
- package/dist/esm/seo-kit/seo_loader.d.ts +0 -12
- package/dist/esm/seo-kit/seo_loader.js +0 -13
- package/dist/esm/singleton.d.ts +0 -1
- package/dist/esm/singleton.js +0 -9
- package/dist/esm/slug.d.ts +0 -1
- package/dist/esm/slug.js +0 -6
|
@@ -0,0 +1,368 @@
|
|
|
1
|
+
// src/http-kit/response.ts
|
|
2
|
+
var createJsonResponse = (status) => {
|
|
3
|
+
return (data = {}, init) => {
|
|
4
|
+
return Response.json(data, { status, ...init });
|
|
5
|
+
};
|
|
6
|
+
};
|
|
7
|
+
var OK = createJsonResponse(200);
|
|
8
|
+
var CREATED = createJsonResponse(201);
|
|
9
|
+
var ACCEPTED = createJsonResponse(202);
|
|
10
|
+
var NO_CONTENT = (init) => {
|
|
11
|
+
return new Response(null, {
|
|
12
|
+
...init,
|
|
13
|
+
status: 204
|
|
14
|
+
});
|
|
15
|
+
};
|
|
16
|
+
var createException = (status, defaultMessage = "\uC624\uB958\uAC00 \uBC1C\uC0DD\uD588\uC2B5\uB2C8\uB2E4.") => {
|
|
17
|
+
return (message = defaultMessage, init) => {
|
|
18
|
+
return createJsonResponse(status)({ message }, init);
|
|
19
|
+
};
|
|
20
|
+
};
|
|
21
|
+
var BAD_REQUEST = createException(400, "\uC694\uCCAD\uC774 \uC62C\uBC14\uB974\uC9C0 \uC54A\uC2B5\uB2C8\uB2E4.");
|
|
22
|
+
var UNAUTHORIZED = createException(401, "\uC778\uC99D\uC774 \uD544\uC694\uD569\uB2C8\uB2E4.");
|
|
23
|
+
var FORBIDDEN = createException(403, "\uAD8C\uD55C\uC774 \uC5C6\uC2B5\uB2C8\uB2E4.");
|
|
24
|
+
var NOT_FOUND = createException(
|
|
25
|
+
404,
|
|
26
|
+
"\uC694\uCCAD\uD55C \uB9AC\uC18C\uC2A4\uB97C \uCC3E\uC744 \uC218 \uC5C6\uC2B5\uB2C8\uB2E4."
|
|
27
|
+
);
|
|
28
|
+
var METHOD_NOT_ALLOWED = createException(
|
|
29
|
+
405,
|
|
30
|
+
"\uBA54\uC11C\uB4DC\uB97C \uC0AC\uC6A9\uD560 \uC218 \uC5C6\uC2B5\uB2C8\uB2E4."
|
|
31
|
+
);
|
|
32
|
+
var NOT_ACCEPTABLE = createException(
|
|
33
|
+
406,
|
|
34
|
+
"\uC694\uCCAD\uD55C \uD615\uC2DD\uC744 \uC0AC\uC6A9\uD560 \uC218 \uC5C6\uC2B5\uB2C8\uB2E4."
|
|
35
|
+
);
|
|
36
|
+
var REQUEST_TIMEOUT = createException(
|
|
37
|
+
408,
|
|
38
|
+
"\uC694\uCCAD \uC2DC\uAC04\uC774 \uCD08\uACFC\uB418\uC5C8\uC2B5\uB2C8\uB2E4."
|
|
39
|
+
);
|
|
40
|
+
var CONFLICT = createException(409, "\uC694\uCCAD\uC774 \uCDA9\uB3CC\uD588\uC2B5\uB2C8\uB2E4.");
|
|
41
|
+
var UNPROCESSABLE_ENTITY = createException(
|
|
42
|
+
422,
|
|
43
|
+
"\uCC98\uB9AC\uD560 \uC218 \uC5C6\uB294 \uC5D4\uD2F0\uD2F0\uC785\uB2C8\uB2E4."
|
|
44
|
+
);
|
|
45
|
+
var TOO_MANY_REQUESTS = createException(429, "\uC694\uCCAD\uC774 \uB108\uBB34 \uB9CE\uC2B5\uB2C8\uB2E4.");
|
|
46
|
+
var INTERNAL_SERVER_ERROR = createException(
|
|
47
|
+
500,
|
|
48
|
+
"\uC608\uAE30\uCE58 \uBABB\uD55C \uC624\uB958\uAC00 \uBC1C\uC0DD\uD588\uC2B5\uB2C8\uB2E4."
|
|
49
|
+
);
|
|
50
|
+
|
|
51
|
+
// src/route/auth/callback/[provider]/route.tsx
|
|
52
|
+
var thirdPartyAuthCallbackHandler = async (request, {
|
|
53
|
+
provider
|
|
54
|
+
}, {
|
|
55
|
+
AUTH,
|
|
56
|
+
GOOGLE_AUTH,
|
|
57
|
+
APPLE_AUTH,
|
|
58
|
+
SITE_ORIGIN
|
|
59
|
+
}) => {
|
|
60
|
+
const url = new URL(request.url);
|
|
61
|
+
const code = url.searchParams.get("code");
|
|
62
|
+
if (!code) {
|
|
63
|
+
throw BAD_REQUEST("\uCF54\uB4DC\uAC00 \uC5C6\uC2B5\uB2C8\uB2E4.");
|
|
64
|
+
}
|
|
65
|
+
const getThirdPartyAuth = (provider2) => {
|
|
66
|
+
switch (provider2) {
|
|
67
|
+
case "google":
|
|
68
|
+
return GOOGLE_AUTH;
|
|
69
|
+
case "apple":
|
|
70
|
+
return APPLE_AUTH;
|
|
71
|
+
default:
|
|
72
|
+
throw BAD_REQUEST("\uC9C0\uC6D0\uD558\uC9C0 \uC54A\uB294 \uC778\uC99D \uC81C\uACF5\uC790\uC785\uB2C8\uB2E4.");
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
const { accessToken, refreshToken } = await getThirdPartyAuth(
|
|
76
|
+
provider
|
|
77
|
+
).signIn(code);
|
|
78
|
+
const [accessTokenSetCookie, refreshTokenSetCookie] = await Promise.all([
|
|
79
|
+
AUTH.getAccessTokenSetCookie(accessToken),
|
|
80
|
+
AUTH.getRefreshTokenSetCookie(refreshToken)
|
|
81
|
+
]);
|
|
82
|
+
const headers = new Headers();
|
|
83
|
+
headers.append("Set-Cookie", accessTokenSetCookie);
|
|
84
|
+
headers.append("Set-Cookie", refreshTokenSetCookie);
|
|
85
|
+
const redirectUrl = url.searchParams.get("state") || SITE_ORIGIN;
|
|
86
|
+
return new Response("Temporary Redirect", {
|
|
87
|
+
status: 307,
|
|
88
|
+
headers: {
|
|
89
|
+
...headers,
|
|
90
|
+
Location: new URL(
|
|
91
|
+
`/r?redirectUrl=${encodeURIComponent(redirectUrl)}`,
|
|
92
|
+
request.url
|
|
93
|
+
).toString()
|
|
94
|
+
}
|
|
95
|
+
});
|
|
96
|
+
};
|
|
97
|
+
|
|
98
|
+
// src/route/api/files/route.ts
|
|
99
|
+
var fileUploadHandler = async (request, {
|
|
100
|
+
AUTH,
|
|
101
|
+
FILE_SERVICE
|
|
102
|
+
}) => {
|
|
103
|
+
const auth = await AUTH.verifyOrRefresh(request);
|
|
104
|
+
const { name, type, size, metadata } = await request.json();
|
|
105
|
+
const headers = {
|
|
106
|
+
"Access-Control-Allow-Origin": "*"
|
|
107
|
+
};
|
|
108
|
+
if (typeof name !== "string") {
|
|
109
|
+
return BAD_REQUEST("\uD30C\uC77C \uC774\uB984\uC774 \uD544\uC694\uD574\uC694.", { headers });
|
|
110
|
+
}
|
|
111
|
+
if (typeof type !== "string") {
|
|
112
|
+
return BAD_REQUEST("\uD30C\uC77C \uD0C0\uC785\uC774 \uD544\uC694\uD574\uC694.", { headers });
|
|
113
|
+
}
|
|
114
|
+
try {
|
|
115
|
+
const result = await FILE_SERVICE.generateSignedUrl({
|
|
116
|
+
userId: auth?.userId,
|
|
117
|
+
name,
|
|
118
|
+
type,
|
|
119
|
+
size,
|
|
120
|
+
metadata
|
|
121
|
+
});
|
|
122
|
+
return CREATED(result, { headers });
|
|
123
|
+
} catch (e) {
|
|
124
|
+
if (e instanceof Error) {
|
|
125
|
+
return INTERNAL_SERVER_ERROR(e.message, { headers });
|
|
126
|
+
}
|
|
127
|
+
return INTERNAL_SERVER_ERROR(e, { headers });
|
|
128
|
+
}
|
|
129
|
+
};
|
|
130
|
+
|
|
131
|
+
// src/route/api/files/[fileId]/route.ts
|
|
132
|
+
var fileDeleteHandler = async (request, { fileId }, {
|
|
133
|
+
AUTH,
|
|
134
|
+
repository
|
|
135
|
+
}) => {
|
|
136
|
+
const auth = await AUTH.verifyOrRefresh(request);
|
|
137
|
+
const file = await repository.findFileById(fileId);
|
|
138
|
+
const headers = {
|
|
139
|
+
"Access-Control-Allow-Origin": "*"
|
|
140
|
+
};
|
|
141
|
+
if (!file) {
|
|
142
|
+
return NOT_FOUND("\uD30C\uC77C\uC744 \uCC3E\uC744 \uC218 \uC5C6\uC2B5\uB2C8\uB2E4.", { headers });
|
|
143
|
+
}
|
|
144
|
+
if (!repository.hasPermission(file, auth?.userId)) {
|
|
145
|
+
return FORBIDDEN("\uD30C\uC77C\uC744 \uC0AD\uC81C\uD560 \uAD8C\uD55C\uC774 \uC5C6\uC2B5\uB2C8\uB2E4.", { headers });
|
|
146
|
+
}
|
|
147
|
+
await repository.deleteFile(fileId);
|
|
148
|
+
return NO_CONTENT({ headers });
|
|
149
|
+
};
|
|
150
|
+
|
|
151
|
+
// src/route/api/auth/route.ts
|
|
152
|
+
var getAuthHandler = async (request, { AUTH }) => {
|
|
153
|
+
const auth = await AUTH.verifyOrRefresh(request);
|
|
154
|
+
if (!auth) {
|
|
155
|
+
return UNAUTHORIZED();
|
|
156
|
+
}
|
|
157
|
+
return OK(auth);
|
|
158
|
+
};
|
|
159
|
+
|
|
160
|
+
// src/route/api/auth/login/[provider]/route.ts
|
|
161
|
+
var loginThirdPartyHandler = async (request, {
|
|
162
|
+
provider
|
|
163
|
+
}, {
|
|
164
|
+
GOOGLE_AUTH,
|
|
165
|
+
APPLE_AUTH,
|
|
166
|
+
KAKAO_AUTH
|
|
167
|
+
}) => {
|
|
168
|
+
const { code } = await request.json();
|
|
169
|
+
if (!code) {
|
|
170
|
+
return BAD_REQUEST("\uCF54\uB4DC\uAC00 \uC5C6\uC2B5\uB2C8\uB2E4.");
|
|
171
|
+
}
|
|
172
|
+
const getThirdPartyAuth = (provider2) => {
|
|
173
|
+
switch (provider2) {
|
|
174
|
+
case "google":
|
|
175
|
+
return GOOGLE_AUTH;
|
|
176
|
+
case "apple":
|
|
177
|
+
return APPLE_AUTH;
|
|
178
|
+
case "kakao":
|
|
179
|
+
return KAKAO_AUTH;
|
|
180
|
+
default:
|
|
181
|
+
throw BAD_REQUEST("\uC9C0\uC6D0\uD558\uC9C0 \uC54A\uB294 \uC778\uC99D \uC81C\uACF5\uC790\uC785\uB2C8\uB2E4.");
|
|
182
|
+
}
|
|
183
|
+
};
|
|
184
|
+
try {
|
|
185
|
+
const { accessToken, refreshToken } = await getThirdPartyAuth(
|
|
186
|
+
provider
|
|
187
|
+
).signIn(code);
|
|
188
|
+
return CREATED({
|
|
189
|
+
accessToken,
|
|
190
|
+
refreshToken
|
|
191
|
+
});
|
|
192
|
+
} catch (error) {
|
|
193
|
+
if (error instanceof Response) {
|
|
194
|
+
return error;
|
|
195
|
+
}
|
|
196
|
+
throw INTERNAL_SERVER_ERROR();
|
|
197
|
+
}
|
|
198
|
+
};
|
|
199
|
+
|
|
200
|
+
// src/route/api/auth/login/route.ts
|
|
201
|
+
var loginCredentialHandler = async (request, {
|
|
202
|
+
AUTH,
|
|
203
|
+
JWT_MANAGER
|
|
204
|
+
}) => {
|
|
205
|
+
const searchParams = new URL(request.url).searchParams;
|
|
206
|
+
const { id, password } = await request.json();
|
|
207
|
+
try {
|
|
208
|
+
const { accessToken, refreshToken } = await AUTH.signIn({
|
|
209
|
+
id,
|
|
210
|
+
password
|
|
211
|
+
});
|
|
212
|
+
if (searchParams.get("type") === "json") {
|
|
213
|
+
return CREATED({ accessToken, refreshToken });
|
|
214
|
+
}
|
|
215
|
+
const [accessTokenSetCookie, refreshTokenSetCookie] = await Promise.all([
|
|
216
|
+
AUTH.getAccessTokenSetCookie(accessToken),
|
|
217
|
+
AUTH.getRefreshTokenSetCookie(refreshToken)
|
|
218
|
+
]);
|
|
219
|
+
const payload = JWT_MANAGER.decode(accessToken);
|
|
220
|
+
const headers = new Headers();
|
|
221
|
+
headers.append("Set-Cookie", accessTokenSetCookie);
|
|
222
|
+
headers.append("Set-Cookie", refreshTokenSetCookie);
|
|
223
|
+
return CREATED(payload, {
|
|
224
|
+
headers
|
|
225
|
+
});
|
|
226
|
+
} catch (e) {
|
|
227
|
+
if (e instanceof Error) {
|
|
228
|
+
return UNAUTHORIZED(e.message);
|
|
229
|
+
}
|
|
230
|
+
throw e;
|
|
231
|
+
}
|
|
232
|
+
};
|
|
233
|
+
|
|
234
|
+
// src/route/api/auth/logout/route.ts
|
|
235
|
+
var logoutHandler = async (request, { AUTH, repository }) => {
|
|
236
|
+
const auth = await AUTH.verifyOrRefresh(request);
|
|
237
|
+
if (!auth) {
|
|
238
|
+
return UNAUTHORIZED();
|
|
239
|
+
}
|
|
240
|
+
await repository.updateUserRefreshToken(auth.userId, null);
|
|
241
|
+
const headers = new Headers();
|
|
242
|
+
const [accessTokenSetCookie, refreshTokenSetCookie] = await Promise.all([
|
|
243
|
+
AUTH.getAccessTokenSetCookie(null),
|
|
244
|
+
AUTH.getRefreshTokenSetCookie(null)
|
|
245
|
+
]);
|
|
246
|
+
headers.append("Set-Cookie", accessTokenSetCookie);
|
|
247
|
+
headers.append("Set-Cookie", refreshTokenSetCookie);
|
|
248
|
+
return NO_CONTENT({
|
|
249
|
+
headers
|
|
250
|
+
});
|
|
251
|
+
};
|
|
252
|
+
|
|
253
|
+
// src/route/api/auth/refresh/route.ts
|
|
254
|
+
var authRefreshHandler = async (request, {
|
|
255
|
+
AUTH
|
|
256
|
+
}) => {
|
|
257
|
+
const refreshToken = request?.headers.get("Authorization")?.replace("Bearer ", "") || await AUTH.getRefreshTokenFromCookies(request);
|
|
258
|
+
if (!refreshToken) {
|
|
259
|
+
return BAD_REQUEST();
|
|
260
|
+
}
|
|
261
|
+
try {
|
|
262
|
+
const accessToken = await AUTH.refreshAccessToken(refreshToken);
|
|
263
|
+
return CREATED({ accessToken });
|
|
264
|
+
} catch (e) {
|
|
265
|
+
if (e instanceof Error) {
|
|
266
|
+
return UNAUTHORIZED(e.message);
|
|
267
|
+
}
|
|
268
|
+
throw e;
|
|
269
|
+
}
|
|
270
|
+
};
|
|
271
|
+
|
|
272
|
+
// src/route/api.ts
|
|
273
|
+
var createAuthAPIHandler = ({
|
|
274
|
+
AUTH,
|
|
275
|
+
GOOGLE_AUTH,
|
|
276
|
+
APPLE_AUTH,
|
|
277
|
+
KAKAO_AUTH,
|
|
278
|
+
JWT_MANAGER,
|
|
279
|
+
FILE_SERVICE,
|
|
280
|
+
SITE_ORIGIN,
|
|
281
|
+
authRepository,
|
|
282
|
+
fileRepository
|
|
283
|
+
}) => {
|
|
284
|
+
const handler = async ({
|
|
285
|
+
request,
|
|
286
|
+
params
|
|
287
|
+
}) => {
|
|
288
|
+
const method = request.method.toUpperCase();
|
|
289
|
+
const slug = params["*"].split("/");
|
|
290
|
+
if (slug[0] === "auth") {
|
|
291
|
+
if (!slug[1]) {
|
|
292
|
+
if (method === "GET") {
|
|
293
|
+
return getAuthHandler(request, { AUTH });
|
|
294
|
+
}
|
|
295
|
+
}
|
|
296
|
+
if (slug[1] === "login") {
|
|
297
|
+
if (slug[2]) {
|
|
298
|
+
const provider = slug[2];
|
|
299
|
+
if (method === "POST") {
|
|
300
|
+
return loginThirdPartyHandler(
|
|
301
|
+
request,
|
|
302
|
+
{ provider },
|
|
303
|
+
{ GOOGLE_AUTH, KAKAO_AUTH, APPLE_AUTH }
|
|
304
|
+
);
|
|
305
|
+
}
|
|
306
|
+
}
|
|
307
|
+
if (method === "POST") {
|
|
308
|
+
return loginCredentialHandler(request, {
|
|
309
|
+
AUTH,
|
|
310
|
+
JWT_MANAGER
|
|
311
|
+
});
|
|
312
|
+
}
|
|
313
|
+
}
|
|
314
|
+
if (slug[1] === "logout") {
|
|
315
|
+
if (method === "POST") {
|
|
316
|
+
return logoutHandler(request, {
|
|
317
|
+
AUTH,
|
|
318
|
+
repository: authRepository
|
|
319
|
+
});
|
|
320
|
+
}
|
|
321
|
+
}
|
|
322
|
+
if (slug[1] === "refresh") {
|
|
323
|
+
if (method === "GET") {
|
|
324
|
+
return authRefreshHandler(request, { AUTH });
|
|
325
|
+
}
|
|
326
|
+
}
|
|
327
|
+
if (slug[1] === "callback") {
|
|
328
|
+
if (slug[2]) {
|
|
329
|
+
const provider = slug[2];
|
|
330
|
+
if (method === "GET") {
|
|
331
|
+
return thirdPartyAuthCallbackHandler(
|
|
332
|
+
request,
|
|
333
|
+
{ provider },
|
|
334
|
+
{
|
|
335
|
+
AUTH,
|
|
336
|
+
GOOGLE_AUTH,
|
|
337
|
+
APPLE_AUTH,
|
|
338
|
+
SITE_ORIGIN
|
|
339
|
+
}
|
|
340
|
+
);
|
|
341
|
+
}
|
|
342
|
+
}
|
|
343
|
+
}
|
|
344
|
+
}
|
|
345
|
+
if (slug[0] === "files") {
|
|
346
|
+
if (!slug[1]) {
|
|
347
|
+
if (method === "POST") {
|
|
348
|
+
return fileUploadHandler(request, { AUTH, FILE_SERVICE });
|
|
349
|
+
}
|
|
350
|
+
}
|
|
351
|
+
if (slug[1]) {
|
|
352
|
+
if (method === "DELETE") {
|
|
353
|
+
const fileId = slug[1];
|
|
354
|
+
return fileDeleteHandler(
|
|
355
|
+
request,
|
|
356
|
+
{ fileId },
|
|
357
|
+
{ AUTH, repository: fileRepository }
|
|
358
|
+
);
|
|
359
|
+
}
|
|
360
|
+
}
|
|
361
|
+
}
|
|
362
|
+
return new Response("Not Found", { status: 404 });
|
|
363
|
+
};
|
|
364
|
+
return handler;
|
|
365
|
+
};
|
|
366
|
+
export {
|
|
367
|
+
createAuthAPIHandler
|
|
368
|
+
};
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
|
|
20
|
+
// src/route/auth/callback/[provider]/route.tsx
|
|
21
|
+
var route_exports = {};
|
|
22
|
+
__export(route_exports, {
|
|
23
|
+
thirdPartyAuthCallbackHandler: () => thirdPartyAuthCallbackHandler
|
|
24
|
+
});
|
|
25
|
+
module.exports = __toCommonJS(route_exports);
|
|
26
|
+
|
|
27
|
+
// src/http-kit/response.ts
|
|
28
|
+
var createJsonResponse = (status) => {
|
|
29
|
+
return (data = {}, init) => {
|
|
30
|
+
return Response.json(data, { status, ...init });
|
|
31
|
+
};
|
|
32
|
+
};
|
|
33
|
+
var OK = createJsonResponse(200);
|
|
34
|
+
var CREATED = createJsonResponse(201);
|
|
35
|
+
var ACCEPTED = createJsonResponse(202);
|
|
36
|
+
var createException = (status, defaultMessage = "\uC624\uB958\uAC00 \uBC1C\uC0DD\uD588\uC2B5\uB2C8\uB2E4.") => {
|
|
37
|
+
return (message = defaultMessage, init) => {
|
|
38
|
+
return createJsonResponse(status)({ message }, init);
|
|
39
|
+
};
|
|
40
|
+
};
|
|
41
|
+
var BAD_REQUEST = createException(400, "\uC694\uCCAD\uC774 \uC62C\uBC14\uB974\uC9C0 \uC54A\uC2B5\uB2C8\uB2E4.");
|
|
42
|
+
var UNAUTHORIZED = createException(401, "\uC778\uC99D\uC774 \uD544\uC694\uD569\uB2C8\uB2E4.");
|
|
43
|
+
var FORBIDDEN = createException(403, "\uAD8C\uD55C\uC774 \uC5C6\uC2B5\uB2C8\uB2E4.");
|
|
44
|
+
var NOT_FOUND = createException(
|
|
45
|
+
404,
|
|
46
|
+
"\uC694\uCCAD\uD55C \uB9AC\uC18C\uC2A4\uB97C \uCC3E\uC744 \uC218 \uC5C6\uC2B5\uB2C8\uB2E4."
|
|
47
|
+
);
|
|
48
|
+
var METHOD_NOT_ALLOWED = createException(
|
|
49
|
+
405,
|
|
50
|
+
"\uBA54\uC11C\uB4DC\uB97C \uC0AC\uC6A9\uD560 \uC218 \uC5C6\uC2B5\uB2C8\uB2E4."
|
|
51
|
+
);
|
|
52
|
+
var NOT_ACCEPTABLE = createException(
|
|
53
|
+
406,
|
|
54
|
+
"\uC694\uCCAD\uD55C \uD615\uC2DD\uC744 \uC0AC\uC6A9\uD560 \uC218 \uC5C6\uC2B5\uB2C8\uB2E4."
|
|
55
|
+
);
|
|
56
|
+
var REQUEST_TIMEOUT = createException(
|
|
57
|
+
408,
|
|
58
|
+
"\uC694\uCCAD \uC2DC\uAC04\uC774 \uCD08\uACFC\uB418\uC5C8\uC2B5\uB2C8\uB2E4."
|
|
59
|
+
);
|
|
60
|
+
var CONFLICT = createException(409, "\uC694\uCCAD\uC774 \uCDA9\uB3CC\uD588\uC2B5\uB2C8\uB2E4.");
|
|
61
|
+
var UNPROCESSABLE_ENTITY = createException(
|
|
62
|
+
422,
|
|
63
|
+
"\uCC98\uB9AC\uD560 \uC218 \uC5C6\uB294 \uC5D4\uD2F0\uD2F0\uC785\uB2C8\uB2E4."
|
|
64
|
+
);
|
|
65
|
+
var TOO_MANY_REQUESTS = createException(429, "\uC694\uCCAD\uC774 \uB108\uBB34 \uB9CE\uC2B5\uB2C8\uB2E4.");
|
|
66
|
+
var INTERNAL_SERVER_ERROR = createException(
|
|
67
|
+
500,
|
|
68
|
+
"\uC608\uAE30\uCE58 \uBABB\uD55C \uC624\uB958\uAC00 \uBC1C\uC0DD\uD588\uC2B5\uB2C8\uB2E4."
|
|
69
|
+
);
|
|
70
|
+
|
|
71
|
+
// src/route/auth/callback/[provider]/route.tsx
|
|
72
|
+
var thirdPartyAuthCallbackHandler = async (request, {
|
|
73
|
+
provider
|
|
74
|
+
}, {
|
|
75
|
+
AUTH,
|
|
76
|
+
GOOGLE_AUTH,
|
|
77
|
+
APPLE_AUTH,
|
|
78
|
+
SITE_ORIGIN
|
|
79
|
+
}) => {
|
|
80
|
+
const url = new URL(request.url);
|
|
81
|
+
const code = url.searchParams.get("code");
|
|
82
|
+
if (!code) {
|
|
83
|
+
throw BAD_REQUEST("\uCF54\uB4DC\uAC00 \uC5C6\uC2B5\uB2C8\uB2E4.");
|
|
84
|
+
}
|
|
85
|
+
const getThirdPartyAuth = (provider2) => {
|
|
86
|
+
switch (provider2) {
|
|
87
|
+
case "google":
|
|
88
|
+
return GOOGLE_AUTH;
|
|
89
|
+
case "apple":
|
|
90
|
+
return APPLE_AUTH;
|
|
91
|
+
default:
|
|
92
|
+
throw BAD_REQUEST("\uC9C0\uC6D0\uD558\uC9C0 \uC54A\uB294 \uC778\uC99D \uC81C\uACF5\uC790\uC785\uB2C8\uB2E4.");
|
|
93
|
+
}
|
|
94
|
+
};
|
|
95
|
+
const { accessToken, refreshToken } = await getThirdPartyAuth(
|
|
96
|
+
provider
|
|
97
|
+
).signIn(code);
|
|
98
|
+
const [accessTokenSetCookie, refreshTokenSetCookie] = await Promise.all([
|
|
99
|
+
AUTH.getAccessTokenSetCookie(accessToken),
|
|
100
|
+
AUTH.getRefreshTokenSetCookie(refreshToken)
|
|
101
|
+
]);
|
|
102
|
+
const headers = new Headers();
|
|
103
|
+
headers.append("Set-Cookie", accessTokenSetCookie);
|
|
104
|
+
headers.append("Set-Cookie", refreshTokenSetCookie);
|
|
105
|
+
const redirectUrl = url.searchParams.get("state") || SITE_ORIGIN;
|
|
106
|
+
return new Response("Temporary Redirect", {
|
|
107
|
+
status: 307,
|
|
108
|
+
headers: {
|
|
109
|
+
...headers,
|
|
110
|
+
Location: new URL(
|
|
111
|
+
`/r?redirectUrl=${encodeURIComponent(redirectUrl)}`,
|
|
112
|
+
request.url
|
|
113
|
+
).toString()
|
|
114
|
+
}
|
|
115
|
+
});
|
|
116
|
+
};
|
|
117
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
118
|
+
0 && (module.exports = {
|
|
119
|
+
thirdPartyAuthCallbackHandler
|
|
120
|
+
});
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
// src/http-kit/response.ts
|
|
2
|
+
var createJsonResponse = (status) => {
|
|
3
|
+
return (data = {}, init) => {
|
|
4
|
+
return Response.json(data, { status, ...init });
|
|
5
|
+
};
|
|
6
|
+
};
|
|
7
|
+
var OK = createJsonResponse(200);
|
|
8
|
+
var CREATED = createJsonResponse(201);
|
|
9
|
+
var ACCEPTED = createJsonResponse(202);
|
|
10
|
+
var createException = (status, defaultMessage = "\uC624\uB958\uAC00 \uBC1C\uC0DD\uD588\uC2B5\uB2C8\uB2E4.") => {
|
|
11
|
+
return (message = defaultMessage, init) => {
|
|
12
|
+
return createJsonResponse(status)({ message }, init);
|
|
13
|
+
};
|
|
14
|
+
};
|
|
15
|
+
var BAD_REQUEST = createException(400, "\uC694\uCCAD\uC774 \uC62C\uBC14\uB974\uC9C0 \uC54A\uC2B5\uB2C8\uB2E4.");
|
|
16
|
+
var UNAUTHORIZED = createException(401, "\uC778\uC99D\uC774 \uD544\uC694\uD569\uB2C8\uB2E4.");
|
|
17
|
+
var FORBIDDEN = createException(403, "\uAD8C\uD55C\uC774 \uC5C6\uC2B5\uB2C8\uB2E4.");
|
|
18
|
+
var NOT_FOUND = createException(
|
|
19
|
+
404,
|
|
20
|
+
"\uC694\uCCAD\uD55C \uB9AC\uC18C\uC2A4\uB97C \uCC3E\uC744 \uC218 \uC5C6\uC2B5\uB2C8\uB2E4."
|
|
21
|
+
);
|
|
22
|
+
var METHOD_NOT_ALLOWED = createException(
|
|
23
|
+
405,
|
|
24
|
+
"\uBA54\uC11C\uB4DC\uB97C \uC0AC\uC6A9\uD560 \uC218 \uC5C6\uC2B5\uB2C8\uB2E4."
|
|
25
|
+
);
|
|
26
|
+
var NOT_ACCEPTABLE = createException(
|
|
27
|
+
406,
|
|
28
|
+
"\uC694\uCCAD\uD55C \uD615\uC2DD\uC744 \uC0AC\uC6A9\uD560 \uC218 \uC5C6\uC2B5\uB2C8\uB2E4."
|
|
29
|
+
);
|
|
30
|
+
var REQUEST_TIMEOUT = createException(
|
|
31
|
+
408,
|
|
32
|
+
"\uC694\uCCAD \uC2DC\uAC04\uC774 \uCD08\uACFC\uB418\uC5C8\uC2B5\uB2C8\uB2E4."
|
|
33
|
+
);
|
|
34
|
+
var CONFLICT = createException(409, "\uC694\uCCAD\uC774 \uCDA9\uB3CC\uD588\uC2B5\uB2C8\uB2E4.");
|
|
35
|
+
var UNPROCESSABLE_ENTITY = createException(
|
|
36
|
+
422,
|
|
37
|
+
"\uCC98\uB9AC\uD560 \uC218 \uC5C6\uB294 \uC5D4\uD2F0\uD2F0\uC785\uB2C8\uB2E4."
|
|
38
|
+
);
|
|
39
|
+
var TOO_MANY_REQUESTS = createException(429, "\uC694\uCCAD\uC774 \uB108\uBB34 \uB9CE\uC2B5\uB2C8\uB2E4.");
|
|
40
|
+
var INTERNAL_SERVER_ERROR = createException(
|
|
41
|
+
500,
|
|
42
|
+
"\uC608\uAE30\uCE58 \uBABB\uD55C \uC624\uB958\uAC00 \uBC1C\uC0DD\uD588\uC2B5\uB2C8\uB2E4."
|
|
43
|
+
);
|
|
44
|
+
|
|
45
|
+
// src/route/auth/callback/[provider]/route.tsx
|
|
46
|
+
var thirdPartyAuthCallbackHandler = async (request, {
|
|
47
|
+
provider
|
|
48
|
+
}, {
|
|
49
|
+
AUTH,
|
|
50
|
+
GOOGLE_AUTH,
|
|
51
|
+
APPLE_AUTH,
|
|
52
|
+
SITE_ORIGIN
|
|
53
|
+
}) => {
|
|
54
|
+
const url = new URL(request.url);
|
|
55
|
+
const code = url.searchParams.get("code");
|
|
56
|
+
if (!code) {
|
|
57
|
+
throw BAD_REQUEST("\uCF54\uB4DC\uAC00 \uC5C6\uC2B5\uB2C8\uB2E4.");
|
|
58
|
+
}
|
|
59
|
+
const getThirdPartyAuth = (provider2) => {
|
|
60
|
+
switch (provider2) {
|
|
61
|
+
case "google":
|
|
62
|
+
return GOOGLE_AUTH;
|
|
63
|
+
case "apple":
|
|
64
|
+
return APPLE_AUTH;
|
|
65
|
+
default:
|
|
66
|
+
throw BAD_REQUEST("\uC9C0\uC6D0\uD558\uC9C0 \uC54A\uB294 \uC778\uC99D \uC81C\uACF5\uC790\uC785\uB2C8\uB2E4.");
|
|
67
|
+
}
|
|
68
|
+
};
|
|
69
|
+
const { accessToken, refreshToken } = await getThirdPartyAuth(
|
|
70
|
+
provider
|
|
71
|
+
).signIn(code);
|
|
72
|
+
const [accessTokenSetCookie, refreshTokenSetCookie] = await Promise.all([
|
|
73
|
+
AUTH.getAccessTokenSetCookie(accessToken),
|
|
74
|
+
AUTH.getRefreshTokenSetCookie(refreshToken)
|
|
75
|
+
]);
|
|
76
|
+
const headers = new Headers();
|
|
77
|
+
headers.append("Set-Cookie", accessTokenSetCookie);
|
|
78
|
+
headers.append("Set-Cookie", refreshTokenSetCookie);
|
|
79
|
+
const redirectUrl = url.searchParams.get("state") || SITE_ORIGIN;
|
|
80
|
+
return new Response("Temporary Redirect", {
|
|
81
|
+
status: 307,
|
|
82
|
+
headers: {
|
|
83
|
+
...headers,
|
|
84
|
+
Location: new URL(
|
|
85
|
+
`/r?redirectUrl=${encodeURIComponent(redirectUrl)}`,
|
|
86
|
+
request.url
|
|
87
|
+
).toString()
|
|
88
|
+
}
|
|
89
|
+
});
|
|
90
|
+
};
|
|
91
|
+
export {
|
|
92
|
+
thirdPartyAuthCallbackHandler
|
|
93
|
+
};
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { AuthService } from '../../../../auth-kit/auth_service.mjs';
|
|
2
|
+
import { GoogleAuth } from '../../../../auth-kit/google_auth.mjs';
|
|
3
|
+
import { AppleAuth } from '../../../../auth-kit/apple_auth.mjs';
|
|
4
|
+
import 'jose';
|
|
5
|
+
import 'react-router';
|
|
6
|
+
import '../../../../auth-kit/jwt.mjs';
|
|
7
|
+
import '../../../../file-kit/object_storage.mjs';
|
|
8
|
+
import '@aws-sdk/client-s3';
|
|
9
|
+
import '../../../../auth-kit/repository.mjs';
|
|
10
|
+
|
|
11
|
+
declare const thirdPartyAuthCallbackHandler: (request: Request, { provider, }: {
|
|
12
|
+
provider: string;
|
|
13
|
+
}, { AUTH, GOOGLE_AUTH, APPLE_AUTH, SITE_ORIGIN, }: {
|
|
14
|
+
AUTH: AuthService;
|
|
15
|
+
GOOGLE_AUTH: GoogleAuth;
|
|
16
|
+
APPLE_AUTH: AppleAuth;
|
|
17
|
+
SITE_ORIGIN: string;
|
|
18
|
+
}) => Promise<Response>;
|
|
19
|
+
|
|
20
|
+
export { thirdPartyAuthCallbackHandler };
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { AuthService } from '../../../../auth-kit/auth_service.js';
|
|
2
|
+
import { GoogleAuth } from '../../../../auth-kit/google_auth.js';
|
|
3
|
+
import { AppleAuth } from '../../../../auth-kit/apple_auth.js';
|
|
4
|
+
import 'jose';
|
|
5
|
+
import 'react-router';
|
|
6
|
+
import '../../../../auth-kit/jwt.js';
|
|
7
|
+
import '../../../../file-kit/object_storage.js';
|
|
8
|
+
import '@aws-sdk/client-s3';
|
|
9
|
+
import '../../../../auth-kit/repository.js';
|
|
10
|
+
|
|
11
|
+
declare const thirdPartyAuthCallbackHandler: (request: Request, { provider, }: {
|
|
12
|
+
provider: string;
|
|
13
|
+
}, { AUTH, GOOGLE_AUTH, APPLE_AUTH, SITE_ORIGIN, }: {
|
|
14
|
+
AUTH: AuthService;
|
|
15
|
+
GOOGLE_AUTH: GoogleAuth;
|
|
16
|
+
APPLE_AUTH: AppleAuth;
|
|
17
|
+
SITE_ORIGIN: string;
|
|
18
|
+
}) => Promise<Response>;
|
|
19
|
+
|
|
20
|
+
export { thirdPartyAuthCallbackHandler };
|