@kurly-growth/growthman 0.1.1 → 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/.next/BUILD_ID +1 -0
- package/.next/app-path-routes-manifest.json +12 -0
- package/.next/build/chunks/8e02f_b5d23412._.js +6758 -0
- package/.next/build/chunks/8e02f_b5d23412._.js.map +47 -0
- package/.next/build/chunks/[root-of-the-server]__310ad51a._.js +206 -0
- package/.next/build/chunks/[root-of-the-server]__310ad51a._.js.map +8 -0
- package/.next/build/chunks/[root-of-the-server]__8e2c0d87._.js +500 -0
- package/.next/build/chunks/[root-of-the-server]__8e2c0d87._.js.map +11 -0
- package/.next/build/chunks/[turbopack-node]_transforms_postcss_ts_5040861e._.js +13 -0
- package/.next/build/chunks/[turbopack-node]_transforms_postcss_ts_5040861e._.js.map +5 -0
- package/.next/build/chunks/[turbopack]_runtime.js +795 -0
- package/.next/build/chunks/[turbopack]_runtime.js.map +10 -0
- package/.next/build/package.json +1 -0
- package/.next/build/postcss.js +6 -0
- package/.next/build/postcss.js.map +5 -0
- package/.next/build-manifest.json +19 -0
- package/.next/diagnostics/build-diagnostics.json +6 -0
- package/.next/diagnostics/framework.json +1 -0
- package/.next/export-marker.json +6 -0
- package/.next/fallback-build-manifest.json +12 -0
- package/.next/images-manifest.json +66 -0
- package/.next/next-minimal-server.js.nft.json +1 -0
- package/.next/next-server.js.nft.json +1 -0
- package/.next/package.json +1 -0
- package/.next/prerender-manifest.json +114 -0
- package/.next/required-server-files.js +163 -0
- package/.next/required-server-files.json +163 -0
- package/.next/routes-manifest.json +109 -0
- package/.next/server/app/_global-error/page/app-paths-manifest.json +3 -0
- package/.next/server/app/_global-error/page/build-manifest.json +16 -0
- package/.next/server/app/_global-error/page/next-font-manifest.json +6 -0
- package/.next/server/app/_global-error/page/react-loadable-manifest.json +1 -0
- package/.next/server/app/_global-error/page/server-reference-manifest.json +4 -0
- package/.next/server/app/_global-error/page.js +11 -0
- package/.next/server/app/_global-error/page.js.map +5 -0
- package/.next/server/app/_global-error/page.js.nft.json +1 -0
- package/.next/server/app/_global-error/page_client-reference-manifest.js +2 -0
- package/.next/server/app/_global-error.html +2 -0
- package/.next/server/app/_global-error.meta +15 -0
- package/.next/server/app/_global-error.rsc +13 -0
- package/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +5 -0
- package/.next/server/app/_global-error.segments/_full.segment.rsc +13 -0
- package/.next/server/app/_global-error.segments/_head.segment.rsc +6 -0
- package/.next/server/app/_global-error.segments/_index.segment.rsc +4 -0
- package/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -0
- package/.next/server/app/_not-found/page/app-paths-manifest.json +3 -0
- package/.next/server/app/_not-found/page/build-manifest.json +16 -0
- package/.next/server/app/_not-found/page/next-font-manifest.json +11 -0
- package/.next/server/app/_not-found/page/react-loadable-manifest.json +1 -0
- package/.next/server/app/_not-found/page/server-reference-manifest.json +4 -0
- package/.next/server/app/_not-found/page.js +14 -0
- package/.next/server/app/_not-found/page.js.map +5 -0
- package/.next/server/app/_not-found/page.js.nft.json +1 -0
- package/.next/server/app/_not-found/page_client-reference-manifest.js +2 -0
- package/.next/server/app/_not-found.html +1 -0
- package/.next/server/app/_not-found.meta +16 -0
- package/.next/server/app/_not-found.rsc +15 -0
- package/.next/server/app/_not-found.segments/_full.segment.rsc +15 -0
- package/.next/server/app/_not-found.segments/_head.segment.rsc +6 -0
- package/.next/server/app/_not-found.segments/_index.segment.rsc +6 -0
- package/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +5 -0
- package/.next/server/app/_not-found.segments/_not-found.segment.rsc +4 -0
- package/.next/server/app/_not-found.segments/_tree.segment.rsc +2 -0
- package/.next/server/app/api/endpoints/[id]/route/app-paths-manifest.json +3 -0
- package/.next/server/app/api/endpoints/[id]/route/build-manifest.json +11 -0
- package/.next/server/app/api/endpoints/[id]/route/server-reference-manifest.json +4 -0
- package/.next/server/app/api/endpoints/[id]/route.js +6 -0
- package/.next/server/app/api/endpoints/[id]/route.js.map +5 -0
- package/.next/server/app/api/endpoints/[id]/route.js.nft.json +1 -0
- package/.next/server/app/api/endpoints/[id]/route_client-reference-manifest.js +2 -0
- package/.next/server/app/api/endpoints/bulk/route/app-paths-manifest.json +3 -0
- package/.next/server/app/api/endpoints/bulk/route/build-manifest.json +11 -0
- package/.next/server/app/api/endpoints/bulk/route/server-reference-manifest.json +4 -0
- package/.next/server/app/api/endpoints/bulk/route.js +6 -0
- package/.next/server/app/api/endpoints/bulk/route.js.map +5 -0
- package/.next/server/app/api/endpoints/bulk/route.js.nft.json +1 -0
- package/.next/server/app/api/endpoints/bulk/route_client-reference-manifest.js +2 -0
- package/.next/server/app/api/endpoints/import/route/app-paths-manifest.json +3 -0
- package/.next/server/app/api/endpoints/import/route/build-manifest.json +11 -0
- package/.next/server/app/api/endpoints/import/route/server-reference-manifest.json +4 -0
- package/.next/server/app/api/endpoints/import/route.js +6 -0
- package/.next/server/app/api/endpoints/import/route.js.map +5 -0
- package/.next/server/app/api/endpoints/import/route.js.nft.json +1 -0
- package/.next/server/app/api/endpoints/import/route_client-reference-manifest.js +2 -0
- package/.next/server/app/api/endpoints/route/app-paths-manifest.json +3 -0
- package/.next/server/app/api/endpoints/route/build-manifest.json +11 -0
- package/.next/server/app/api/endpoints/route/server-reference-manifest.json +4 -0
- package/.next/server/app/api/endpoints/route.js +6 -0
- package/.next/server/app/api/endpoints/route.js.map +5 -0
- package/.next/server/app/api/endpoints/route.js.nft.json +1 -0
- package/.next/server/app/api/endpoints/route_client-reference-manifest.js +2 -0
- package/.next/server/app/api/endpoints/sync/route/app-paths-manifest.json +3 -0
- package/.next/server/app/api/endpoints/sync/route/build-manifest.json +11 -0
- package/.next/server/app/api/endpoints/sync/route/server-reference-manifest.json +4 -0
- package/.next/server/app/api/endpoints/sync/route.js +6 -0
- package/.next/server/app/api/endpoints/sync/route.js.map +5 -0
- package/.next/server/app/api/endpoints/sync/route.js.nft.json +1 -0
- package/.next/server/app/api/endpoints/sync/route_client-reference-manifest.js +2 -0
- package/.next/server/app/api/mock/[...slug]/route/app-paths-manifest.json +3 -0
- package/.next/server/app/api/mock/[...slug]/route/build-manifest.json +11 -0
- package/.next/server/app/api/mock/[...slug]/route/server-reference-manifest.json +4 -0
- package/.next/server/app/api/mock/[...slug]/route.js +7 -0
- package/.next/server/app/api/mock/[...slug]/route.js.map +5 -0
- package/.next/server/app/api/mock/[...slug]/route.js.nft.json +1 -0
- package/.next/server/app/api/mock/[...slug]/route_client-reference-manifest.js +2 -0
- package/.next/server/app/favicon.ico/route/app-paths-manifest.json +3 -0
- package/.next/server/app/favicon.ico/route/build-manifest.json +11 -0
- package/.next/server/app/favicon.ico/route.js +7 -0
- package/.next/server/app/favicon.ico/route.js.map +5 -0
- package/.next/server/app/favicon.ico/route.js.nft.json +1 -0
- package/.next/server/app/favicon.ico.body +0 -0
- package/.next/server/app/favicon.ico.meta +1 -0
- package/.next/server/app/index.html +1 -0
- package/.next/server/app/index.meta +14 -0
- package/.next/server/app/index.rsc +21 -0
- package/.next/server/app/index.segments/__PAGE__.segment.rsc +9 -0
- package/.next/server/app/index.segments/_full.segment.rsc +21 -0
- package/.next/server/app/index.segments/_head.segment.rsc +6 -0
- package/.next/server/app/index.segments/_index.segment.rsc +6 -0
- package/.next/server/app/index.segments/_tree.segment.rsc +4 -0
- package/.next/server/app/page/app-paths-manifest.json +3 -0
- package/.next/server/app/page/build-manifest.json +16 -0
- package/.next/server/app/page/next-font-manifest.json +11 -0
- package/.next/server/app/page/react-loadable-manifest.json +8 -0
- package/.next/server/app/page/server-reference-manifest.json +4 -0
- package/.next/server/app/page.js +16 -0
- package/.next/server/app/page.js.map +5 -0
- package/.next/server/app/page.js.nft.json +1 -0
- package/.next/server/app/page_client-reference-manifest.js +2 -0
- package/.next/server/app-paths-manifest.json +12 -0
- package/.next/server/chunks/4c6d9__next-internal_server_app_api_endpoints_[id]_route_actions_9be426d4.js +3 -0
- package/.next/server/chunks/4c6d9__next-internal_server_app_api_endpoints_[id]_route_actions_9be426d4.js.map +1 -0
- package/.next/server/chunks/4c6d9__next-internal_server_app_api_endpoints_bulk_route_actions_e28c0cd3.js +3 -0
- package/.next/server/chunks/4c6d9__next-internal_server_app_api_endpoints_bulk_route_actions_e28c0cd3.js.map +1 -0
- package/.next/server/chunks/4c6d9__next-internal_server_app_api_endpoints_import_route_actions_89a982f4.js +3 -0
- package/.next/server/chunks/4c6d9__next-internal_server_app_api_endpoints_import_route_actions_89a982f4.js.map +1 -0
- package/.next/server/chunks/4c6d9__next-internal_server_app_api_endpoints_route_actions_0c151162.js +3 -0
- package/.next/server/chunks/4c6d9__next-internal_server_app_api_endpoints_route_actions_0c151162.js.map +1 -0
- package/.next/server/chunks/4c6d9__next-internal_server_app_api_endpoints_sync_route_actions_3051349a.js +3 -0
- package/.next/server/chunks/4c6d9__next-internal_server_app_api_endpoints_sync_route_actions_3051349a.js.map +1 -0
- package/.next/server/chunks/4c6d9__next-internal_server_app_api_mock_[___slug]_route_actions_521def8c.js +3 -0
- package/.next/server/chunks/4c6d9__next-internal_server_app_api_mock_[___slug]_route_actions_521def8c.js.map +1 -0
- package/.next/server/chunks/8e02f_529f6098._.js +3 -0
- package/.next/server/chunks/8e02f_529f6098._.js.map +1 -0
- package/.next/server/chunks/8e02f_next_dist_esm_build_templates_app-route_2d5d7dcf.js +3 -0
- package/.next/server/chunks/8e02f_next_dist_esm_build_templates_app-route_2d5d7dcf.js.map +1 -0
- package/.next/server/chunks/[externals]_next_dist_8dbe5856._.js +3 -0
- package/.next/server/chunks/[externals]_next_dist_8dbe5856._.js.map +1 -0
- package/.next/server/chunks/[root-of-the-server]__094b2f2b._.js +3 -0
- package/.next/server/chunks/[root-of-the-server]__094b2f2b._.js.map +1 -0
- package/.next/server/chunks/[root-of-the-server]__0ecd8530._.js +3 -0
- package/.next/server/chunks/[root-of-the-server]__0ecd8530._.js.map +1 -0
- package/.next/server/chunks/[root-of-the-server]__5b9c1ed8._.js +3 -0
- package/.next/server/chunks/[root-of-the-server]__5b9c1ed8._.js.map +1 -0
- package/.next/server/chunks/[root-of-the-server]__5d7c02da._.js +3 -0
- package/.next/server/chunks/[root-of-the-server]__5d7c02da._.js.map +1 -0
- package/.next/server/chunks/[root-of-the-server]__88f1e82c._.js +21 -0
- package/.next/server/chunks/[root-of-the-server]__88f1e82c._.js.map +1 -0
- package/.next/server/chunks/[root-of-the-server]__a413808a._.js +3 -0
- package/.next/server/chunks/[root-of-the-server]__a413808a._.js.map +1 -0
- package/.next/server/chunks/[root-of-the-server]__fbfc7922._.js +3 -0
- package/.next/server/chunks/[root-of-the-server]__fbfc7922._.js.map +1 -0
- package/.next/server/chunks/[turbopack]_runtime.js +795 -0
- package/.next/server/chunks/[turbopack]_runtime.js.map +10 -0
- package/.next/server/chunks/ced06_growth-mock-server__next-internal_server_app_favicon_ico_route_actions_b931e89c.js +3 -0
- package/.next/server/chunks/ced06_growth-mock-server__next-internal_server_app_favicon_ico_route_actions_b931e89c.js.map +1 -0
- package/.next/server/chunks/ssr/3d860_Project_Web_growth-mock-server__next-internal_server_app_page_actions_a455ccb7.js +3 -0
- package/.next/server/chunks/ssr/3d860_Project_Web_growth-mock-server__next-internal_server_app_page_actions_a455ccb7.js.map +1 -0
- package/.next/server/chunks/ssr/4c6d9__next-internal_server_app__global-error_page_actions_386af4fb.js +3 -0
- package/.next/server/chunks/ssr/4c6d9__next-internal_server_app__global-error_page_actions_386af4fb.js.map +1 -0
- package/.next/server/chunks/ssr/8e02f_lucide-react_dist_esm_createLucideIcon_92babc87.js +3 -0
- package/.next/server/chunks/ssr/8e02f_lucide-react_dist_esm_createLucideIcon_92babc87.js.map +1 -0
- package/.next/server/chunks/ssr/8e02f_next_dist_5f7af8e7._.js +3 -0
- package/.next/server/chunks/ssr/8e02f_next_dist_5f7af8e7._.js.map +1 -0
- package/.next/server/chunks/ssr/8e02f_next_dist_8b7d79d3._.js +6 -0
- package/.next/server/chunks/ssr/8e02f_next_dist_8b7d79d3._.js.map +1 -0
- package/.next/server/chunks/ssr/8e02f_next_dist_a79dfbb1._.js +4 -0
- package/.next/server/chunks/ssr/8e02f_next_dist_a79dfbb1._.js.map +1 -0
- package/.next/server/chunks/ssr/8e02f_next_dist_client_components_b780ac2a._.js +3 -0
- package/.next/server/chunks/ssr/8e02f_next_dist_client_components_b780ac2a._.js.map +1 -0
- package/.next/server/chunks/ssr/8e02f_next_dist_client_components_builtin_forbidden_8e6242aa.js +3 -0
- package/.next/server/chunks/ssr/8e02f_next_dist_client_components_builtin_forbidden_8e6242aa.js.map +1 -0
- package/.next/server/chunks/ssr/8e02f_next_dist_client_components_builtin_global-error_fef7daa4.js +3 -0
- package/.next/server/chunks/ssr/8e02f_next_dist_client_components_builtin_global-error_fef7daa4.js.map +1 -0
- package/.next/server/chunks/ssr/8e02f_next_dist_client_components_builtin_unauthorized_d6f465ad.js +3 -0
- package/.next/server/chunks/ssr/8e02f_next_dist_client_components_builtin_unauthorized_d6f465ad.js.map +1 -0
- package/.next/server/chunks/ssr/8e02f_next_dist_esm_build_templates_app-page_aefc7b05.js +4 -0
- package/.next/server/chunks/ssr/8e02f_next_dist_esm_build_templates_app-page_aefc7b05.js.map +1 -0
- package/.next/server/chunks/ssr/Desktop_Project_Web_growth-mock-server_192f26a7._.js +3 -0
- package/.next/server/chunks/ssr/Desktop_Project_Web_growth-mock-server_192f26a7._.js.map +1 -0
- package/.next/server/chunks/ssr/Desktop_Project_Web_growth-mock-server_4d3bfee7._.js +4 -0
- package/.next/server/chunks/ssr/Desktop_Project_Web_growth-mock-server_4d3bfee7._.js.map +1 -0
- package/.next/server/chunks/ssr/Desktop_Project_Web_growth-mock-server_app_734cd624._.js +3 -0
- package/.next/server/chunks/ssr/Desktop_Project_Web_growth-mock-server_app_734cd624._.js.map +1 -0
- package/.next/server/chunks/ssr/Desktop_Project_Web_growth-mock-server_e3bf5efe._.js +7 -0
- package/.next/server/chunks/ssr/Desktop_Project_Web_growth-mock-server_e3bf5efe._.js.map +1 -0
- package/.next/server/chunks/ssr/[externals]_next_dist_server_app-render_work-async-storage_external_1f8eeae7.js +3 -0
- package/.next/server/chunks/ssr/[externals]_next_dist_server_app-render_work-async-storage_external_1f8eeae7.js.map +1 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__0715ef20._.js +3 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__0715ef20._.js.map +1 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__0c263e23._.js +3 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__0c263e23._.js.map +1 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__2cf79de7._.js +10 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__2cf79de7._.js.map +1 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__5d3307e0._.js +3 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__5d3307e0._.js.map +1 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__6f5c427b._.js +4 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__6f5c427b._.js.map +1 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__7f083271._.js +3 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__7f083271._.js.map +1 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__88eba3a3._.js +3 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__88eba3a3._.js.map +1 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__c6e8de01._.js +3 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__c6e8de01._.js.map +1 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__c9e25af2._.js +3 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__c9e25af2._.js.map +1 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__caa92361._.js +3 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__caa92361._.js.map +1 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__e5032d8c._.js +3 -0
- package/.next/server/chunks/ssr/[root-of-the-server]__e5032d8c._.js.map +1 -0
- package/.next/server/chunks/ssr/[turbopack]_runtime.js +795 -0
- package/.next/server/chunks/ssr/[turbopack]_runtime.js.map +10 -0
- package/.next/server/chunks/ssr/ced06_growth-mock-server__next-internal_server_app__not-found_page_actions_41a9defd.js +3 -0
- package/.next/server/chunks/ssr/ced06_growth-mock-server__next-internal_server_app__not-found_page_actions_41a9defd.js.map +1 -0
- package/.next/server/functions-config-manifest.json +4 -0
- package/.next/server/interception-route-rewrite-manifest.js +1 -0
- package/.next/server/middleware-build-manifest.js +20 -0
- package/.next/server/middleware-manifest.json +6 -0
- package/.next/server/next-font-manifest.js +1 -0
- package/.next/server/next-font-manifest.json +15 -0
- package/.next/server/pages/404.html +1 -0
- package/.next/server/pages/500.html +2 -0
- package/.next/server/pages-manifest.json +4 -0
- package/.next/server/server-reference-manifest.js +1 -0
- package/.next/server/server-reference-manifest.json +5 -0
- package/.next/static/chunks/31523f3a41fdf0b5.js +1 -0
- package/.next/static/chunks/3a3338ff069e0977.js +5 -0
- package/.next/static/chunks/68c20af4dfeb36d0.js +1 -0
- package/.next/static/chunks/77942ffae83b12ce.js +1 -0
- package/.next/static/chunks/81faf4667437d774.js +1 -0
- package/.next/static/chunks/8c554104dfee37e0.js +5 -0
- package/.next/static/chunks/a6dad97d9634a72d.js +1 -0
- package/.next/static/chunks/a6dad97d9634a72d.js.map +1 -0
- package/.next/static/chunks/ab3bc4985a0e98d2.css +3 -0
- package/.next/static/chunks/d71bf6d63636cd19.js +1 -0
- package/.next/static/chunks/f32c6649a0ca2698.js +1 -0
- package/.next/static/chunks/turbopack-7ea3b444f61e390f.js +4 -0
- package/.next/static/media/4fa387ec64143e14-s.c1fdd6c2.woff2 +0 -0
- package/.next/static/media/7178b3e590c64307-s.b97b3418.woff2 +0 -0
- package/.next/static/media/797e433ab948586e-s.p.dbea232f.woff2 +0 -0
- package/.next/static/media/8a480f0b521d4e75-s.8e0177b5.woff2 +0 -0
- package/.next/static/media/bbc41e54d2fcbd21-s.799d8ef8.woff2 +0 -0
- package/.next/static/media/caa3a2e1cccd8315-s.p.853070df.woff2 +0 -0
- package/.next/static/media/favicon.de6b30f1.ico +0 -0
- package/.next/static/xP3uHv1GK0YyrTIpyEo8D/_buildManifest.js +11 -0
- package/.next/static/xP3uHv1GK0YyrTIpyEo8D/_clientMiddlewareManifest.json +1 -0
- package/.next/static/xP3uHv1GK0YyrTIpyEo8D/_ssgManifest.js +1 -0
- package/.next/trace +1 -0
- package/.next/trace-build +1 -0
- package/.next/turbopack +0 -0
- package/.next/types/routes.d.ts +78 -0
- package/next-env.d.ts +6 -0
- package/package.json +1 -1
- package/app/api/endpoints/[id]/route.ts +0 -63
- package/app/api/endpoints/bulk/route.ts +0 -23
- package/app/api/endpoints/import/route.ts +0 -52
- package/app/api/endpoints/route.ts +0 -39
- package/app/api/endpoints/sync/route.ts +0 -80
- package/app/api/mock/[...slug]/route.ts +0 -82
- package/eslint.config.mjs +0 -18
- package/lib/openapi-parser.ts +0 -270
- package/lib/prisma.ts +0 -9
- package/lib/utils.ts +0 -6
- package/lib/validation.ts +0 -19
- package/next.config.ts +0 -7
- package/prisma/seed.ts +0 -29
- package/tsconfig.json +0 -34
- package/types/endpoint.ts +0 -10
package/lib/openapi-parser.ts
DELETED
|
@@ -1,270 +0,0 @@
|
|
|
1
|
-
interface OpenAPISpec {
|
|
2
|
-
paths?: Record<string, Record<string, OpenAPIOperation>>
|
|
3
|
-
components?: {
|
|
4
|
-
schemas?: Record<string, OpenAPISchema>
|
|
5
|
-
}
|
|
6
|
-
}
|
|
7
|
-
|
|
8
|
-
interface OpenAPIOperation {
|
|
9
|
-
summary?: string
|
|
10
|
-
description?: string
|
|
11
|
-
responses?: Record<string, OpenAPIResponse>
|
|
12
|
-
requestBody?: {
|
|
13
|
-
content?: Record<string, { schema?: OpenAPISchema; example?: unknown }>
|
|
14
|
-
}
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
interface OpenAPIResponse {
|
|
18
|
-
description?: string
|
|
19
|
-
content?: Record<string, { schema?: OpenAPISchema; example?: unknown }>
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
interface OpenAPISchema {
|
|
23
|
-
type?: string
|
|
24
|
-
format?: string
|
|
25
|
-
properties?: Record<string, OpenAPISchema>
|
|
26
|
-
items?: OpenAPISchema
|
|
27
|
-
example?: unknown
|
|
28
|
-
default?: unknown
|
|
29
|
-
enum?: unknown[]
|
|
30
|
-
$ref?: string
|
|
31
|
-
allOf?: OpenAPISchema[]
|
|
32
|
-
oneOf?: OpenAPISchema[]
|
|
33
|
-
anyOf?: OpenAPISchema[]
|
|
34
|
-
nullable?: boolean
|
|
35
|
-
required?: string[]
|
|
36
|
-
additionalProperties?: boolean | OpenAPISchema
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
export interface ParsedEndpoint {
|
|
40
|
-
path: string
|
|
41
|
-
method: string
|
|
42
|
-
description: string | null
|
|
43
|
-
statusCode: number
|
|
44
|
-
responseBody: unknown
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
function resolveRef(ref: string, spec: OpenAPISpec): OpenAPISchema | null {
|
|
48
|
-
// $ref format: "#/components/schemas/SchemaName"
|
|
49
|
-
const parts = ref.split('/')
|
|
50
|
-
if (parts[0] !== '#' || parts[1] !== 'components' || parts[2] !== 'schemas') {
|
|
51
|
-
return null
|
|
52
|
-
}
|
|
53
|
-
const schemaName = parts[3]
|
|
54
|
-
return spec.components?.schemas?.[schemaName] || null
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
function generateMockValue(
|
|
58
|
-
schema: OpenAPISchema,
|
|
59
|
-
spec: OpenAPISpec,
|
|
60
|
-
visited: Set<string> = new Set()
|
|
61
|
-
): unknown {
|
|
62
|
-
// Handle $ref
|
|
63
|
-
if (schema.$ref) {
|
|
64
|
-
// Prevent circular references
|
|
65
|
-
if (visited.has(schema.$ref)) {
|
|
66
|
-
return {}
|
|
67
|
-
}
|
|
68
|
-
visited.add(schema.$ref)
|
|
69
|
-
const resolved = resolveRef(schema.$ref, spec)
|
|
70
|
-
if (resolved) {
|
|
71
|
-
return generateMockValue(resolved, spec, visited)
|
|
72
|
-
}
|
|
73
|
-
return {}
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
// Handle allOf (merge schemas)
|
|
77
|
-
if (schema.allOf && schema.allOf.length > 0) {
|
|
78
|
-
const merged: Record<string, unknown> = {}
|
|
79
|
-
for (const subSchema of schema.allOf) {
|
|
80
|
-
const value = generateMockValue(subSchema, spec, visited)
|
|
81
|
-
if (typeof value === 'object' && value !== null) {
|
|
82
|
-
Object.assign(merged, value)
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
return merged
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
// Handle oneOf/anyOf (use first option)
|
|
89
|
-
if (schema.oneOf && schema.oneOf.length > 0) {
|
|
90
|
-
return generateMockValue(schema.oneOf[0], spec, visited)
|
|
91
|
-
}
|
|
92
|
-
if (schema.anyOf && schema.anyOf.length > 0) {
|
|
93
|
-
return generateMockValue(schema.anyOf[0], spec, visited)
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
// Use example or default if available
|
|
97
|
-
if (schema.example !== undefined) return schema.example
|
|
98
|
-
if (schema.default !== undefined) return schema.default
|
|
99
|
-
if (schema.enum && schema.enum.length > 0) return schema.enum[0]
|
|
100
|
-
|
|
101
|
-
// Generate based on type and format
|
|
102
|
-
switch (schema.type) {
|
|
103
|
-
case 'string':
|
|
104
|
-
return generateStringValue(schema.format)
|
|
105
|
-
case 'number':
|
|
106
|
-
return generateNumberValue(schema.format)
|
|
107
|
-
case 'integer':
|
|
108
|
-
return generateIntegerValue(schema.format)
|
|
109
|
-
case 'boolean':
|
|
110
|
-
return true
|
|
111
|
-
case 'array':
|
|
112
|
-
if (schema.items) {
|
|
113
|
-
return [generateMockValue(schema.items, spec, visited)]
|
|
114
|
-
}
|
|
115
|
-
return []
|
|
116
|
-
case 'object':
|
|
117
|
-
return generateObjectValue(schema, spec, visited)
|
|
118
|
-
default:
|
|
119
|
-
// If no type but has properties, treat as object
|
|
120
|
-
if (schema.properties) {
|
|
121
|
-
return generateObjectValue(schema, spec, visited)
|
|
122
|
-
}
|
|
123
|
-
return null
|
|
124
|
-
}
|
|
125
|
-
}
|
|
126
|
-
|
|
127
|
-
function generateStringValue(format?: string): string {
|
|
128
|
-
switch (format) {
|
|
129
|
-
case 'date':
|
|
130
|
-
return '2024-01-15'
|
|
131
|
-
case 'date-time':
|
|
132
|
-
return '2024-01-15T09:30:00Z'
|
|
133
|
-
case 'time':
|
|
134
|
-
return '09:30:00'
|
|
135
|
-
case 'email':
|
|
136
|
-
return 'user@example.com'
|
|
137
|
-
case 'uri':
|
|
138
|
-
case 'url':
|
|
139
|
-
return 'https://example.com'
|
|
140
|
-
case 'uuid':
|
|
141
|
-
return '550e8400-e29b-41d4-a716-446655440000'
|
|
142
|
-
case 'hostname':
|
|
143
|
-
return 'example.com'
|
|
144
|
-
case 'ipv4':
|
|
145
|
-
return '192.168.1.1'
|
|
146
|
-
case 'ipv6':
|
|
147
|
-
return '2001:0db8:85a3:0000:0000:8a2e:0370:7334'
|
|
148
|
-
case 'byte':
|
|
149
|
-
return 'SGVsbG8gV29ybGQ='
|
|
150
|
-
case 'binary':
|
|
151
|
-
return '<binary>'
|
|
152
|
-
case 'password':
|
|
153
|
-
return '********'
|
|
154
|
-
case 'phone':
|
|
155
|
-
return '+1-555-555-5555'
|
|
156
|
-
default:
|
|
157
|
-
return 'string'
|
|
158
|
-
}
|
|
159
|
-
}
|
|
160
|
-
|
|
161
|
-
function generateNumberValue(format?: string): number {
|
|
162
|
-
switch (format) {
|
|
163
|
-
case 'float':
|
|
164
|
-
return 1.5
|
|
165
|
-
case 'double':
|
|
166
|
-
return 1.23456789
|
|
167
|
-
default:
|
|
168
|
-
return 0
|
|
169
|
-
}
|
|
170
|
-
}
|
|
171
|
-
|
|
172
|
-
function generateIntegerValue(format?: string): number {
|
|
173
|
-
switch (format) {
|
|
174
|
-
case 'int32':
|
|
175
|
-
return 123
|
|
176
|
-
case 'int64':
|
|
177
|
-
return 1234567890
|
|
178
|
-
default:
|
|
179
|
-
return 0
|
|
180
|
-
}
|
|
181
|
-
}
|
|
182
|
-
|
|
183
|
-
function generateObjectValue(
|
|
184
|
-
schema: OpenAPISchema,
|
|
185
|
-
spec: OpenAPISpec,
|
|
186
|
-
visited: Set<string>
|
|
187
|
-
): Record<string, unknown> {
|
|
188
|
-
const obj: Record<string, unknown> = {}
|
|
189
|
-
|
|
190
|
-
if (schema.properties) {
|
|
191
|
-
for (const [key, propSchema] of Object.entries(schema.properties)) {
|
|
192
|
-
obj[key] = generateMockValue(propSchema, spec, visited)
|
|
193
|
-
}
|
|
194
|
-
}
|
|
195
|
-
|
|
196
|
-
return obj
|
|
197
|
-
}
|
|
198
|
-
|
|
199
|
-
export function parseOpenAPISpec(spec: OpenAPISpec): ParsedEndpoint[] {
|
|
200
|
-
const endpoints: ParsedEndpoint[] = []
|
|
201
|
-
|
|
202
|
-
if (!spec.paths) return endpoints
|
|
203
|
-
|
|
204
|
-
for (const [path, methods] of Object.entries(spec.paths)) {
|
|
205
|
-
for (const [method, operation] of Object.entries(methods)) {
|
|
206
|
-
// Skip non-HTTP method properties like 'parameters'
|
|
207
|
-
if (
|
|
208
|
-
!['get', 'post', 'put', 'patch', 'delete', 'head', 'options'].includes(
|
|
209
|
-
method.toLowerCase()
|
|
210
|
-
)
|
|
211
|
-
) {
|
|
212
|
-
continue
|
|
213
|
-
}
|
|
214
|
-
|
|
215
|
-
const description = operation.summary || operation.description || null
|
|
216
|
-
|
|
217
|
-
// Find successful response (2xx)
|
|
218
|
-
let statusCode = 200
|
|
219
|
-
let responseBody: unknown = {}
|
|
220
|
-
|
|
221
|
-
if (operation.responses) {
|
|
222
|
-
// Sort response codes to prefer 200, then other 2xx
|
|
223
|
-
const responseCodes = Object.keys(operation.responses).sort((a, b) => {
|
|
224
|
-
if (a === '200') return -1
|
|
225
|
-
if (b === '200') return 1
|
|
226
|
-
return parseInt(a, 10) - parseInt(b, 10)
|
|
227
|
-
})
|
|
228
|
-
|
|
229
|
-
for (const code of responseCodes) {
|
|
230
|
-
const codeNum = parseInt(code, 10)
|
|
231
|
-
if (codeNum >= 200 && codeNum < 300) {
|
|
232
|
-
statusCode = codeNum
|
|
233
|
-
const response = operation.responses[code]
|
|
234
|
-
|
|
235
|
-
if (response.content) {
|
|
236
|
-
// Try application/json first, then any JSON-like content type
|
|
237
|
-
const jsonContent =
|
|
238
|
-
response.content['application/json'] ||
|
|
239
|
-
response.content['application/hal+json'] ||
|
|
240
|
-
response.content['application/vnd.api+json'] ||
|
|
241
|
-
Object.values(response.content).find((c) => c.schema)
|
|
242
|
-
|
|
243
|
-
if (jsonContent) {
|
|
244
|
-
if (jsonContent.example) {
|
|
245
|
-
responseBody = jsonContent.example
|
|
246
|
-
} else if (jsonContent.schema) {
|
|
247
|
-
responseBody = generateMockValue(jsonContent.schema, spec)
|
|
248
|
-
}
|
|
249
|
-
}
|
|
250
|
-
}
|
|
251
|
-
break
|
|
252
|
-
}
|
|
253
|
-
}
|
|
254
|
-
}
|
|
255
|
-
|
|
256
|
-
// Convert OpenAPI path params {id} to Express-style :id
|
|
257
|
-
const normalizedPath = path.replace(/\{(\w+)\}/g, ':$1')
|
|
258
|
-
|
|
259
|
-
endpoints.push({
|
|
260
|
-
path: normalizedPath,
|
|
261
|
-
method: method.toUpperCase(),
|
|
262
|
-
description,
|
|
263
|
-
statusCode,
|
|
264
|
-
responseBody,
|
|
265
|
-
})
|
|
266
|
-
}
|
|
267
|
-
}
|
|
268
|
-
|
|
269
|
-
return endpoints
|
|
270
|
-
}
|
package/lib/prisma.ts
DELETED
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import { PrismaClient } from '@prisma/client'
|
|
2
|
-
|
|
3
|
-
const globalForPrisma = globalThis as unknown as {
|
|
4
|
-
prisma: PrismaClient | undefined
|
|
5
|
-
}
|
|
6
|
-
|
|
7
|
-
export const prisma = globalForPrisma.prisma ?? new PrismaClient()
|
|
8
|
-
|
|
9
|
-
if (process.env.NODE_ENV !== 'production') globalForPrisma.prisma = prisma
|
package/lib/utils.ts
DELETED
package/lib/validation.ts
DELETED
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
const VALID_METHODS = ['GET', 'POST', 'PUT', 'PATCH', 'DELETE', 'HEAD', 'OPTIONS']
|
|
2
|
-
|
|
3
|
-
export function validatePath(path: unknown): path is string {
|
|
4
|
-
if (!path || typeof path !== 'string') return false
|
|
5
|
-
if (!path.startsWith('/')) return false
|
|
6
|
-
if (path.length > 1000) return false
|
|
7
|
-
return true
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
export function validateMethod(method: unknown): method is string {
|
|
11
|
-
if (typeof method !== 'string') return false
|
|
12
|
-
return VALID_METHODS.includes(method.toUpperCase())
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
export function validateStatusCode(statusCode: unknown): statusCode is number {
|
|
16
|
-
if (statusCode === undefined || statusCode === null) return true // optional
|
|
17
|
-
if (typeof statusCode !== 'number') return false
|
|
18
|
-
return statusCode >= 100 && statusCode < 600
|
|
19
|
-
}
|
package/next.config.ts
DELETED
package/prisma/seed.ts
DELETED
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
import { PrismaClient } from '@prisma/client'
|
|
2
|
-
|
|
3
|
-
const prisma = new PrismaClient()
|
|
4
|
-
|
|
5
|
-
async function main() {
|
|
6
|
-
// 기존 데이터 삭제
|
|
7
|
-
await prisma.mockEndpoint.deleteMany()
|
|
8
|
-
console.log('Cleared all mock endpoints')
|
|
9
|
-
|
|
10
|
-
// 샘플 데이터 추가 (선택사항)
|
|
11
|
-
// await prisma.mockEndpoint.create({
|
|
12
|
-
// data: {
|
|
13
|
-
// path: '/v1/health',
|
|
14
|
-
// method: 'GET',
|
|
15
|
-
// description: 'Health check',
|
|
16
|
-
// statusCode: 200,
|
|
17
|
-
// responseBody: { status: 'ok' },
|
|
18
|
-
// },
|
|
19
|
-
// })
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
main()
|
|
23
|
-
.catch((e) => {
|
|
24
|
-
console.error(e)
|
|
25
|
-
process.exit(1)
|
|
26
|
-
})
|
|
27
|
-
.finally(async () => {
|
|
28
|
-
await prisma.$disconnect()
|
|
29
|
-
})
|
package/tsconfig.json
DELETED
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"compilerOptions": {
|
|
3
|
-
"target": "ES2017",
|
|
4
|
-
"lib": ["dom", "dom.iterable", "esnext"],
|
|
5
|
-
"allowJs": true,
|
|
6
|
-
"skipLibCheck": true,
|
|
7
|
-
"strict": true,
|
|
8
|
-
"noEmit": true,
|
|
9
|
-
"esModuleInterop": true,
|
|
10
|
-
"module": "esnext",
|
|
11
|
-
"moduleResolution": "bundler",
|
|
12
|
-
"resolveJsonModule": true,
|
|
13
|
-
"isolatedModules": true,
|
|
14
|
-
"jsx": "react-jsx",
|
|
15
|
-
"incremental": true,
|
|
16
|
-
"plugins": [
|
|
17
|
-
{
|
|
18
|
-
"name": "next"
|
|
19
|
-
}
|
|
20
|
-
],
|
|
21
|
-
"paths": {
|
|
22
|
-
"@/*": ["./*"]
|
|
23
|
-
}
|
|
24
|
-
},
|
|
25
|
-
"include": [
|
|
26
|
-
"next-env.d.ts",
|
|
27
|
-
"**/*.ts",
|
|
28
|
-
"**/*.tsx",
|
|
29
|
-
".next/types/**/*.ts",
|
|
30
|
-
".next/dev/types/**/*.ts",
|
|
31
|
-
"**/*.mts"
|
|
32
|
-
],
|
|
33
|
-
"exclude": ["node_modules"]
|
|
34
|
-
}
|