@brainfish-ai/devdoc 0.1.41 → 0.1.43
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/ai-agents/.claude/skills/bootstrap-docs/SKILL.md +710 -79
- package/ai-agents/.claude/skills/check-docs/SKILL.md +83 -8
- package/ai-agents/.claude/skills/create-doc/SKILL.md +267 -55
- package/ai-agents/.claude/skills/update-doc/SKILL.md +162 -63
- package/ai-agents/.cursor/rules/devdoc-bootstrap.mdc +145 -15
- package/ai-agents/.cursor/rules/devdoc-create.mdc +108 -57
- package/ai-agents/.cursor/rules/devdoc-update.mdc +93 -70
- package/ai-agents/.cursor/rules/devdoc.mdc +21 -0
- package/ai-agents/schemas/docs.schema.json +332 -0
- package/ai-agents/schemas/theme.schema.json +243 -0
- package/dist/cli/commands/create.js +4 -9
- package/dist/cli/commands/deploy.js +50 -25
- package/dist/cli/commands/dev.js +19 -10
- package/package.json +3 -2
- package/renderer/app/api/assets/[...path]/route.js +108 -0
- package/renderer/app/api/assets/route.js +114 -0
- package/renderer/app/api/assets/upload/route.js +163 -0
- package/renderer/app/api/auth-schemes/route.js +58 -0
- package/renderer/app/api/chat/route.js +759 -0
- package/renderer/app/api/codegen/route.js +52 -0
- package/renderer/app/api/collections/route.js +675 -0
- package/renderer/app/api/debug/route.js +47 -0
- package/renderer/app/api/deploy/route.js +199 -0
- package/renderer/app/api/device/route.js +36 -0
- package/renderer/app/api/docs/route.js +205 -0
- package/renderer/app/api/domains/add/route.js +121 -0
- package/renderer/app/api/domains/lookup/route.js +43 -0
- package/renderer/app/api/domains/remove/route.js +89 -0
- package/renderer/app/api/domains/status/route.js +140 -0
- package/renderer/app/api/domains/verify/route.js +168 -0
- package/renderer/app/api/keys/regenerate/route.js +71 -0
- package/renderer/app/api/local-assets/[...path]/route.js +108 -0
- package/renderer/app/api/openapi-spec/route.js +73 -0
- package/renderer/app/api/projects/[slug]/route.js +129 -0
- package/renderer/app/api/projects/[slug]/stats/route.js +80 -0
- package/renderer/app/api/projects/register/route.js +176 -0
- package/renderer/app/api/proxy/route.js +139 -0
- package/renderer/app/api/proxy-stream/route.js +156 -0
- package/renderer/app/api/redirects/route.js +35 -0
- package/renderer/app/api/schema/route.js +85 -0
- package/renderer/app/api/subdomains/check/route.js +158 -0
- package/renderer/app/api/suggestions/route.js +175 -0
- package/renderer/app/layout.js +47 -0
- package/renderer/app/llms-full.txt/route.js +257 -0
- package/renderer/app/llms.txt/route.js +219 -0
- package/renderer/app/page.js +12 -0
- package/renderer/app/robots.txt/route.js +66 -0
- package/renderer/app/sitemap.xml/route.js +145 -0
- package/renderer/components/docs/index.js +8 -0
- package/renderer/components/docs/mdx/accordion.js +113 -0
- package/renderer/components/docs/mdx/badge.js +72 -0
- package/renderer/components/docs/mdx/callouts.js +137 -0
- package/renderer/components/docs/mdx/cards.js +175 -0
- package/renderer/components/docs/mdx/changelog.js +100 -0
- package/renderer/components/docs/mdx/code-block.js +147 -0
- package/renderer/components/docs/mdx/code-group.js +287 -0
- package/renderer/components/docs/mdx/file-embeds.js +82 -0
- package/renderer/components/docs/mdx/frame.js +59 -0
- package/renderer/components/docs/mdx/highlight.js +90 -0
- package/renderer/components/docs/mdx/iframe.js +69 -0
- package/renderer/components/docs/mdx/image.js +135 -0
- package/renderer/components/docs/mdx/index.js +134 -0
- package/renderer/components/docs/mdx/landing.js +315 -0
- package/renderer/components/docs/mdx/mermaid.js +212 -0
- package/renderer/components/docs/mdx/param-field.js +112 -0
- package/renderer/components/docs/mdx/steps.js +74 -0
- package/renderer/components/docs/mdx/tabs.js +50 -0
- package/renderer/components/docs/mdx-renderer.js +77 -0
- package/renderer/components/docs/navigation/breadcrumbs.js +64 -0
- package/renderer/components/docs/navigation/index.js +6 -0
- package/renderer/components/docs/navigation/page-nav.js +57 -0
- package/renderer/components/docs/navigation/sidebar.js +375 -0
- package/renderer/components/docs/navigation/toc.js +89 -0
- package/renderer/components/docs/notice.js +77 -0
- package/renderer/components/docs-header.js +202 -0
- package/renderer/components/docs-viewer/agent/agent-chat.js +1930 -0
- package/renderer/components/docs-viewer/agent/cards/debug-context-card.js +107 -0
- package/renderer/components/docs-viewer/agent/cards/endpoint-context-card.js +57 -0
- package/renderer/components/docs-viewer/agent/cards/index.js +45 -0
- package/renderer/components/docs-viewer/agent/cards/response-options-card.js +154 -0
- package/renderer/components/docs-viewer/agent/cards/types.js +22 -0
- package/renderer/components/docs-viewer/agent/chat-message.js +2 -0
- package/renderer/components/docs-viewer/agent/index.js +4 -0
- package/renderer/components/docs-viewer/agent/messages/assistant-message.js +108 -0
- package/renderer/components/docs-viewer/agent/messages/chat-message.js +34 -0
- package/renderer/components/docs-viewer/agent/messages/index.js +6 -0
- package/renderer/components/docs-viewer/agent/messages/tool-call-display.js +1065 -0
- package/renderer/components/docs-viewer/agent/messages/types.js +2 -0
- package/renderer/components/docs-viewer/agent/messages/typing-indicator.js +26 -0
- package/renderer/components/docs-viewer/agent/messages/user-message.js +37 -0
- package/renderer/components/docs-viewer/code-editor/{index.tsx → index.js} +1 -1
- package/renderer/components/docs-viewer/code-editor/notes-mode.js +1338 -0
- package/renderer/components/docs-viewer/content/changelog-page.js +297 -0
- package/renderer/components/docs-viewer/content/doc-page.js +264 -0
- package/renderer/components/docs-viewer/content/documentation-viewer.js +14 -0
- package/renderer/components/docs-viewer/content/index.js +29 -0
- package/renderer/components/docs-viewer/content/not-found-page.js +300 -0
- package/renderer/components/docs-viewer/content/request-details.js +528 -0
- package/renderer/components/docs-viewer/content/sections/auth.js +108 -0
- package/renderer/components/docs-viewer/content/sections/body.js +80 -0
- package/renderer/components/docs-viewer/content/sections/headers.js +64 -0
- package/renderer/components/docs-viewer/content/sections/overview.js +56 -0
- package/renderer/components/docs-viewer/content/sections/parameters.js +64 -0
- package/renderer/components/docs-viewer/content/sections/responses.js +91 -0
- package/renderer/components/docs-viewer/global-auth-modal.js +427 -0
- package/renderer/components/docs-viewer/index.js +1552 -0
- package/renderer/components/docs-viewer/playground/auth-editor.js +418 -0
- package/renderer/components/docs-viewer/playground/body-editor.js +240 -0
- package/renderer/components/docs-viewer/playground/code-editor.js +135 -0
- package/renderer/components/docs-viewer/playground/code-snippet.js +393 -0
- package/renderer/components/docs-viewer/playground/graphql-playground.js +734 -0
- package/renderer/components/docs-viewer/playground/index.js +682 -0
- package/renderer/components/docs-viewer/playground/key-value-editor.js +317 -0
- package/renderer/components/docs-viewer/playground/method-selector.js +65 -0
- package/renderer/components/docs-viewer/playground/request-builder.js +181 -0
- package/renderer/components/docs-viewer/playground/request-tabs.js +240 -0
- package/renderer/components/docs-viewer/playground/response-cards/idle-card.js +42 -0
- package/renderer/components/docs-viewer/playground/response-cards/index.js +72 -0
- package/renderer/components/docs-viewer/playground/response-cards/loading-card.js +24 -0
- package/renderer/components/docs-viewer/playground/response-cards/network-error-card.js +28 -0
- package/renderer/components/docs-viewer/playground/response-cards/response-body-card.js +308 -0
- package/renderer/components/docs-viewer/playground/response-cards/types.js +9 -0
- package/renderer/components/docs-viewer/playground/response-viewer.js +18 -0
- package/renderer/components/docs-viewer/search/index.js +2 -0
- package/renderer/components/docs-viewer/search/search-dialog.js +367 -0
- package/renderer/components/docs-viewer/search/use-search.js +89 -0
- package/renderer/components/docs-viewer/shared/markdown-renderer.js +423 -0
- package/renderer/components/docs-viewer/shared/method-badge.js +23 -0
- package/renderer/components/docs-viewer/shared/schema-viewer.js +321 -0
- package/renderer/components/docs-viewer/sidebar/collection-tree.js +222 -0
- package/renderer/components/docs-viewer/sidebar/endpoint-options.js +512 -0
- package/renderer/components/docs-viewer/sidebar/index.js +196 -0
- package/renderer/components/docs-viewer/sidebar/right-sidebar.js +163 -0
- package/renderer/components/docs-viewer/sidebar/sidebar-group.js +87 -0
- package/renderer/components/docs-viewer/sidebar/sidebar-item.js +172 -0
- package/renderer/components/docs-viewer/sidebar/sidebar-section.js +31 -0
- package/renderer/components/theme-provider.js +10 -0
- package/renderer/components/theme-toggle.js +106 -0
- package/renderer/components/ui/badge.js +29 -0
- package/renderer/components/ui/button.js +40 -0
- package/renderer/components/ui/dialog.js +50 -0
- package/renderer/components/ui/dropdown-menu.js +143 -0
- package/renderer/components/ui/input.js +12 -0
- package/renderer/components/ui/label.js +13 -0
- package/renderer/components/ui/navigation-menu.js +83 -0
- package/renderer/components/ui/select.js +116 -0
- package/renderer/components/ui/spinner.js +92 -0
- package/renderer/components/ui/tabs.js +34 -0
- package/renderer/components/ui/tooltip.js +43 -0
- package/renderer/hooks/use-code-copy.js +76 -0
- package/renderer/hooks/use-openapi-title.js +33 -0
- package/renderer/lib/api-docs/agent/index.js +4 -0
- package/renderer/lib/api-docs/agent/indexer.js +254 -0
- package/renderer/lib/api-docs/agent/spec-summary.js +227 -0
- package/renderer/lib/api-docs/agent/types.js +5 -0
- package/renderer/lib/api-docs/auth/auth-context.js +157 -0
- package/renderer/lib/api-docs/auth/auth-storage.js +66 -0
- package/renderer/lib/api-docs/auth/crypto.js +64 -0
- package/renderer/lib/api-docs/auth/index.js +3 -0
- package/renderer/lib/api-docs/code-editor/db.js +145 -0
- package/renderer/lib/api-docs/code-editor/hooks.js +254 -0
- package/renderer/lib/api-docs/code-editor/{index.ts → index.js} +3 -4
- package/renderer/lib/api-docs/code-editor/mode-context.js +154 -0
- package/renderer/lib/api-docs/code-editor/types.js +53 -0
- package/renderer/lib/api-docs/codegen/definitions.js +258 -0
- package/renderer/lib/api-docs/codegen/har.js +171 -0
- package/renderer/lib/api-docs/codegen/index.js +118 -0
- package/renderer/lib/api-docs/factories.js +136 -0
- package/renderer/lib/api-docs/{index.ts → index.js} +5 -10
- package/renderer/lib/api-docs/mobile-context.js +79 -0
- package/renderer/lib/api-docs/navigation-context.js +62 -0
- package/renderer/lib/api-docs/parsers/graphql/index.js +50 -0
- package/renderer/lib/api-docs/parsers/graphql/parser.js +350 -0
- package/renderer/lib/api-docs/parsers/graphql/transformer.js +215 -0
- package/renderer/lib/api-docs/parsers/graphql/types.js +46 -0
- package/renderer/lib/api-docs/parsers/openapi/dereferencer.js +43 -0
- package/renderer/lib/api-docs/parsers/openapi/extractors/auth.js +486 -0
- package/renderer/lib/api-docs/parsers/openapi/extractors/body.js +295 -0
- package/renderer/lib/api-docs/parsers/openapi/extractors/index.js +132 -0
- package/renderer/lib/api-docs/parsers/openapi/index.js +127 -0
- package/renderer/lib/api-docs/parsers/openapi/transformer.js +192 -0
- package/renderer/lib/api-docs/parsers/openapi/validator.js +24 -0
- package/renderer/lib/api-docs/playground/context.js +65 -0
- package/renderer/lib/api-docs/playground/navigation-context.js +74 -0
- package/renderer/lib/api-docs/playground/request-builder.js +163 -0
- package/renderer/lib/api-docs/playground/request-runner.js +224 -0
- package/renderer/lib/api-docs/playground/types.js +5 -0
- package/renderer/lib/api-docs/types.js +23 -0
- package/renderer/lib/api-docs/utils.js +212 -0
- package/renderer/lib/cache.js +157 -0
- package/renderer/lib/docs/config/domain-schema.js +161 -0
- package/renderer/lib/docs/config/index.js +5 -0
- package/renderer/lib/docs/config/loader.js +113 -0
- package/renderer/lib/docs/config/schema.js +269 -0
- package/renderer/lib/docs/index.js +8 -0
- package/renderer/lib/docs/mdx/compiler.js +128 -0
- package/renderer/lib/docs/mdx/frontmatter.js +73 -0
- package/renderer/lib/docs/mdx/index.js +8 -0
- package/renderer/lib/docs/navigation/generator.js +269 -0
- package/renderer/lib/docs/navigation/index.js +4 -0
- package/renderer/lib/docs/navigation/types.js +9 -0
- package/renderer/lib/docs-navigation-context.js +40 -0
- package/renderer/lib/multi-tenant/context.js +80 -0
- package/renderer/lib/storage/blob.js +767 -0
- package/renderer/lib/utils/icons.js +30 -0
- package/renderer/lib/utils.js +5 -0
- package/renderer/next.config.js +62 -0
- package/renderer/tsconfig.json +23 -5
- package/renderer/app/api/assets/[...path]/route.ts +0 -123
- package/renderer/app/api/assets/route.ts +0 -124
- package/renderer/app/api/assets/upload/route.ts +0 -177
- package/renderer/app/api/auth-schemes/route.ts +0 -77
- package/renderer/app/api/chat/route.ts +0 -858
- package/renderer/app/api/codegen/route.ts +0 -72
- package/renderer/app/api/collections/route.ts +0 -1002
- package/renderer/app/api/debug/route.ts +0 -53
- package/renderer/app/api/deploy/route.ts +0 -234
- package/renderer/app/api/device/route.ts +0 -42
- package/renderer/app/api/docs/route.ts +0 -201
- package/renderer/app/api/domains/add/route.ts +0 -132
- package/renderer/app/api/domains/lookup/route.ts +0 -43
- package/renderer/app/api/domains/remove/route.ts +0 -100
- package/renderer/app/api/domains/status/route.ts +0 -158
- package/renderer/app/api/domains/verify/route.ts +0 -181
- package/renderer/app/api/keys/regenerate/route.ts +0 -80
- package/renderer/app/api/local-assets/[...path]/route.ts +0 -122
- package/renderer/app/api/openapi-spec/route.ts +0 -151
- package/renderer/app/api/projects/[slug]/route.ts +0 -153
- package/renderer/app/api/projects/[slug]/stats/route.ts +0 -96
- package/renderer/app/api/projects/register/route.ts +0 -152
- package/renderer/app/api/proxy/route.ts +0 -149
- package/renderer/app/api/proxy-stream/route.ts +0 -168
- package/renderer/app/api/redirects/route.ts +0 -47
- package/renderer/app/api/schema/route.ts +0 -73
- package/renderer/app/api/subdomains/check/route.ts +0 -172
- package/renderer/app/api/suggestions/route.ts +0 -144
- package/renderer/app/layout.tsx +0 -54
- package/renderer/app/llms-full.txt/route.ts +0 -346
- package/renderer/app/llms.txt/route.ts +0 -279
- package/renderer/app/page.tsx +0 -14
- package/renderer/app/robots.txt/route.ts +0 -84
- package/renderer/app/sitemap.xml/route.ts +0 -199
- package/renderer/components/docs/index.ts +0 -12
- package/renderer/components/docs/mdx/accordion.tsx +0 -169
- package/renderer/components/docs/mdx/badge.tsx +0 -132
- package/renderer/components/docs/mdx/callouts.tsx +0 -154
- package/renderer/components/docs/mdx/cards.tsx +0 -241
- package/renderer/components/docs/mdx/changelog.tsx +0 -120
- package/renderer/components/docs/mdx/code-block.tsx +0 -186
- package/renderer/components/docs/mdx/code-group.tsx +0 -421
- package/renderer/components/docs/mdx/file-embeds.tsx +0 -105
- package/renderer/components/docs/mdx/frame.tsx +0 -112
- package/renderer/components/docs/mdx/highlight.tsx +0 -151
- package/renderer/components/docs/mdx/iframe.tsx +0 -134
- package/renderer/components/docs/mdx/image.tsx +0 -235
- package/renderer/components/docs/mdx/index.ts +0 -237
- package/renderer/components/docs/mdx/landing.tsx +0 -684
- package/renderer/components/docs/mdx/mermaid.tsx +0 -240
- package/renderer/components/docs/mdx/param-field.tsx +0 -200
- package/renderer/components/docs/mdx/steps.tsx +0 -113
- package/renderer/components/docs/mdx/tabs.tsx +0 -86
- package/renderer/components/docs/mdx-renderer.tsx +0 -100
- package/renderer/components/docs/navigation/breadcrumbs.tsx +0 -76
- package/renderer/components/docs/navigation/index.ts +0 -8
- package/renderer/components/docs/navigation/page-nav.tsx +0 -64
- package/renderer/components/docs/navigation/sidebar.tsx +0 -515
- package/renderer/components/docs/navigation/toc.tsx +0 -113
- package/renderer/components/docs/notice.tsx +0 -105
- package/renderer/components/docs-header.tsx +0 -278
- package/renderer/components/docs-viewer/agent/agent-chat.tsx +0 -2076
- package/renderer/components/docs-viewer/agent/cards/debug-context-card.tsx +0 -90
- package/renderer/components/docs-viewer/agent/cards/endpoint-context-card.tsx +0 -49
- package/renderer/components/docs-viewer/agent/cards/index.tsx +0 -50
- package/renderer/components/docs-viewer/agent/cards/response-options-card.tsx +0 -212
- package/renderer/components/docs-viewer/agent/cards/types.ts +0 -84
- package/renderer/components/docs-viewer/agent/chat-message.tsx +0 -17
- package/renderer/components/docs-viewer/agent/index.tsx +0 -6
- package/renderer/components/docs-viewer/agent/messages/assistant-message.tsx +0 -119
- package/renderer/components/docs-viewer/agent/messages/chat-message.tsx +0 -46
- package/renderer/components/docs-viewer/agent/messages/index.ts +0 -17
- package/renderer/components/docs-viewer/agent/messages/tool-call-display.tsx +0 -721
- package/renderer/components/docs-viewer/agent/messages/types.ts +0 -61
- package/renderer/components/docs-viewer/agent/messages/typing-indicator.tsx +0 -24
- package/renderer/components/docs-viewer/agent/messages/user-message.tsx +0 -51
- package/renderer/components/docs-viewer/code-editor/notes-mode.tsx +0 -1283
- package/renderer/components/docs-viewer/content/changelog-page.tsx +0 -331
- package/renderer/components/docs-viewer/content/doc-page.tsx +0 -367
- package/renderer/components/docs-viewer/content/documentation-viewer.tsx +0 -17
- package/renderer/components/docs-viewer/content/index.tsx +0 -29
- package/renderer/components/docs-viewer/content/not-found-page.tsx +0 -330
- package/renderer/components/docs-viewer/content/request-details.tsx +0 -330
- package/renderer/components/docs-viewer/content/sections/auth.tsx +0 -69
- package/renderer/components/docs-viewer/content/sections/body.tsx +0 -66
- package/renderer/components/docs-viewer/content/sections/headers.tsx +0 -43
- package/renderer/components/docs-viewer/content/sections/overview.tsx +0 -40
- package/renderer/components/docs-viewer/content/sections/parameters.tsx +0 -43
- package/renderer/components/docs-viewer/content/sections/responses.tsx +0 -87
- package/renderer/components/docs-viewer/global-auth-modal.tsx +0 -352
- package/renderer/components/docs-viewer/index.tsx +0 -1662
- package/renderer/components/docs-viewer/playground/auth-editor.tsx +0 -280
- package/renderer/components/docs-viewer/playground/body-editor.tsx +0 -221
- package/renderer/components/docs-viewer/playground/code-editor.tsx +0 -224
- package/renderer/components/docs-viewer/playground/code-snippet.tsx +0 -387
- package/renderer/components/docs-viewer/playground/graphql-playground.tsx +0 -745
- package/renderer/components/docs-viewer/playground/index.tsx +0 -671
- package/renderer/components/docs-viewer/playground/key-value-editor.tsx +0 -261
- package/renderer/components/docs-viewer/playground/method-selector.tsx +0 -60
- package/renderer/components/docs-viewer/playground/request-builder.tsx +0 -179
- package/renderer/components/docs-viewer/playground/request-tabs.tsx +0 -237
- package/renderer/components/docs-viewer/playground/response-cards/idle-card.tsx +0 -21
- package/renderer/components/docs-viewer/playground/response-cards/index.tsx +0 -93
- package/renderer/components/docs-viewer/playground/response-cards/loading-card.tsx +0 -16
- package/renderer/components/docs-viewer/playground/response-cards/network-error-card.tsx +0 -23
- package/renderer/components/docs-viewer/playground/response-cards/response-body-card.tsx +0 -268
- package/renderer/components/docs-viewer/playground/response-cards/types.ts +0 -82
- package/renderer/components/docs-viewer/playground/response-viewer.tsx +0 -43
- package/renderer/components/docs-viewer/search/index.ts +0 -2
- package/renderer/components/docs-viewer/search/search-dialog.tsx +0 -331
- package/renderer/components/docs-viewer/search/use-search.ts +0 -117
- package/renderer/components/docs-viewer/shared/markdown-renderer.tsx +0 -431
- package/renderer/components/docs-viewer/shared/method-badge.tsx +0 -41
- package/renderer/components/docs-viewer/shared/schema-viewer.tsx +0 -349
- package/renderer/components/docs-viewer/sidebar/collection-tree.tsx +0 -259
- package/renderer/components/docs-viewer/sidebar/endpoint-options.tsx +0 -316
- package/renderer/components/docs-viewer/sidebar/index.tsx +0 -282
- package/renderer/components/docs-viewer/sidebar/right-sidebar.tsx +0 -202
- package/renderer/components/docs-viewer/sidebar/sidebar-group.tsx +0 -118
- package/renderer/components/docs-viewer/sidebar/sidebar-item.tsx +0 -212
- package/renderer/components/docs-viewer/sidebar/sidebar-section.tsx +0 -38
- package/renderer/components/theme-provider.tsx +0 -11
- package/renderer/components/theme-toggle.tsx +0 -76
- package/renderer/components/ui/badge.tsx +0 -46
- package/renderer/components/ui/button.tsx +0 -59
- package/renderer/components/ui/dialog.tsx +0 -118
- package/renderer/components/ui/dropdown-menu.tsx +0 -257
- package/renderer/components/ui/input.tsx +0 -21
- package/renderer/components/ui/label.tsx +0 -24
- package/renderer/components/ui/navigation-menu.tsx +0 -168
- package/renderer/components/ui/select.tsx +0 -190
- package/renderer/components/ui/spinner.tsx +0 -114
- package/renderer/components/ui/tabs.tsx +0 -66
- package/renderer/components/ui/tooltip.tsx +0 -61
- package/renderer/hooks/use-code-copy.ts +0 -88
- package/renderer/hooks/use-openapi-title.ts +0 -44
- package/renderer/lib/api-docs/agent/index.ts +0 -6
- package/renderer/lib/api-docs/agent/indexer.ts +0 -323
- package/renderer/lib/api-docs/agent/spec-summary.ts +0 -335
- package/renderer/lib/api-docs/agent/types.ts +0 -116
- package/renderer/lib/api-docs/auth/auth-context.tsx +0 -225
- package/renderer/lib/api-docs/auth/auth-storage.ts +0 -87
- package/renderer/lib/api-docs/auth/crypto.ts +0 -89
- package/renderer/lib/api-docs/auth/index.ts +0 -4
- package/renderer/lib/api-docs/code-editor/db.ts +0 -164
- package/renderer/lib/api-docs/code-editor/hooks.ts +0 -266
- package/renderer/lib/api-docs/code-editor/mode-context.tsx +0 -207
- package/renderer/lib/api-docs/code-editor/types.ts +0 -105
- package/renderer/lib/api-docs/codegen/definitions.ts +0 -297
- package/renderer/lib/api-docs/codegen/har.ts +0 -251
- package/renderer/lib/api-docs/codegen/index.ts +0 -159
- package/renderer/lib/api-docs/factories.ts +0 -170
- package/renderer/lib/api-docs/mobile-context.tsx +0 -112
- package/renderer/lib/api-docs/navigation-context.tsx +0 -88
- package/renderer/lib/api-docs/parsers/graphql/README.md +0 -129
- package/renderer/lib/api-docs/parsers/graphql/index.ts +0 -91
- package/renderer/lib/api-docs/parsers/graphql/parser.ts +0 -491
- package/renderer/lib/api-docs/parsers/graphql/transformer.ts +0 -246
- package/renderer/lib/api-docs/parsers/graphql/types.ts +0 -283
- package/renderer/lib/api-docs/parsers/openapi/README.md +0 -32
- package/renderer/lib/api-docs/parsers/openapi/dereferencer.ts +0 -60
- package/renderer/lib/api-docs/parsers/openapi/extractors/auth.ts +0 -574
- package/renderer/lib/api-docs/parsers/openapi/extractors/body.ts +0 -403
- package/renderer/lib/api-docs/parsers/openapi/extractors/index.ts +0 -232
- package/renderer/lib/api-docs/parsers/openapi/index.ts +0 -171
- package/renderer/lib/api-docs/parsers/openapi/transformer.ts +0 -278
- package/renderer/lib/api-docs/parsers/openapi/validator.ts +0 -31
- package/renderer/lib/api-docs/playground/context.tsx +0 -107
- package/renderer/lib/api-docs/playground/navigation-context.tsx +0 -124
- package/renderer/lib/api-docs/playground/request-builder.ts +0 -223
- package/renderer/lib/api-docs/playground/request-runner.ts +0 -282
- package/renderer/lib/api-docs/playground/types.ts +0 -35
- package/renderer/lib/api-docs/types.ts +0 -269
- package/renderer/lib/api-docs/utils.ts +0 -311
- package/renderer/lib/cache.ts +0 -193
- package/renderer/lib/docs/config/domain-schema.ts +0 -260
- package/renderer/lib/docs/config/index.ts +0 -43
- package/renderer/lib/docs/config/loader.ts +0 -142
- package/renderer/lib/docs/config/schema.ts +0 -308
- package/renderer/lib/docs/index.ts +0 -12
- package/renderer/lib/docs/mdx/compiler.ts +0 -176
- package/renderer/lib/docs/mdx/frontmatter.ts +0 -91
- package/renderer/lib/docs/mdx/index.ts +0 -26
- package/renderer/lib/docs/navigation/generator.ts +0 -348
- package/renderer/lib/docs/navigation/index.ts +0 -12
- package/renderer/lib/docs/navigation/types.ts +0 -123
- package/renderer/lib/docs-navigation-context.tsx +0 -80
- package/renderer/lib/multi-tenant/context.ts +0 -105
- package/renderer/lib/storage/blob.ts +0 -1083
- package/renderer/lib/utils/icons.ts +0 -48
- package/renderer/lib/utils.ts +0 -6
- package/renderer/next.config.ts +0 -76
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
import { NextResponse } from 'next/server';
|
|
2
|
+
import { head } from '@vercel/blob';
|
|
3
|
+
import path from 'path';
|
|
4
|
+
import fs from 'fs';
|
|
5
|
+
// Check if we're in local development mode
|
|
6
|
+
const IS_LOCAL_DEV = !process.env.BLOB_READ_WRITE_TOKEN;
|
|
7
|
+
const LOCAL_STORAGE_DIR = path.join(process.cwd(), '.devdoc-storage');
|
|
8
|
+
/**
|
|
9
|
+
* Asset proxy - serves uploaded assets for multi-tenant docs
|
|
10
|
+
*
|
|
11
|
+
* GET /api/assets/[slug]/[...path]
|
|
12
|
+
*
|
|
13
|
+
* This allows MDX files to reference assets as:
|
|
14
|
+
* 
|
|
15
|
+
*
|
|
16
|
+
* Or with the middleware rewrite, simply:
|
|
17
|
+
*  -> rewrites to /api/assets/[slug]/logo.png
|
|
18
|
+
*/ export async function GET(request, { params }) {
|
|
19
|
+
try {
|
|
20
|
+
const { path: pathSegments } = await params;
|
|
21
|
+
if (!pathSegments || pathSegments.length < 2) {
|
|
22
|
+
return NextResponse.json({
|
|
23
|
+
error: 'Invalid asset path'
|
|
24
|
+
}, {
|
|
25
|
+
status: 400
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
// First segment is the project slug, rest is the asset path
|
|
29
|
+
const [slug, ...assetPath] = pathSegments;
|
|
30
|
+
const fileName = assetPath.join('/');
|
|
31
|
+
if (!slug || !fileName) {
|
|
32
|
+
return NextResponse.json({
|
|
33
|
+
error: 'Missing slug or file path'
|
|
34
|
+
}, {
|
|
35
|
+
status: 400
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
// Build blob path
|
|
39
|
+
const blobPath = `projects/${slug}/assets/${fileName}`;
|
|
40
|
+
if (IS_LOCAL_DEV) {
|
|
41
|
+
// Local development - serve from filesystem
|
|
42
|
+
const filePath = path.join(LOCAL_STORAGE_DIR, 'projects', slug, 'assets', fileName);
|
|
43
|
+
if (!fs.existsSync(filePath)) {
|
|
44
|
+
return NextResponse.json({
|
|
45
|
+
error: 'Asset not found'
|
|
46
|
+
}, {
|
|
47
|
+
status: 404
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
const fileBuffer = fs.readFileSync(filePath);
|
|
51
|
+
const contentType = getContentType(fileName);
|
|
52
|
+
return new NextResponse(fileBuffer, {
|
|
53
|
+
status: 200,
|
|
54
|
+
headers: {
|
|
55
|
+
'Content-Type': contentType,
|
|
56
|
+
'Cache-Control': 'public, max-age=31536000, immutable'
|
|
57
|
+
}
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
// Production - fetch from Vercel Blob
|
|
61
|
+
const blobInfo = await head(blobPath).catch(()=>null);
|
|
62
|
+
if (!blobInfo) {
|
|
63
|
+
return NextResponse.json({
|
|
64
|
+
error: 'Asset not found'
|
|
65
|
+
}, {
|
|
66
|
+
status: 404
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
// Redirect to the blob URL (more efficient than proxying)
|
|
70
|
+
return NextResponse.redirect(blobInfo.url, {
|
|
71
|
+
status: 302,
|
|
72
|
+
headers: {
|
|
73
|
+
'Cache-Control': 'public, max-age=31536000, immutable'
|
|
74
|
+
}
|
|
75
|
+
});
|
|
76
|
+
} catch (error) {
|
|
77
|
+
console.error('[Asset Proxy] Error:', error);
|
|
78
|
+
return NextResponse.json({
|
|
79
|
+
error: 'Failed to serve asset'
|
|
80
|
+
}, {
|
|
81
|
+
status: 500
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
/**
|
|
86
|
+
* Get content type from file extension
|
|
87
|
+
*/ function getContentType(fileName) {
|
|
88
|
+
const ext = fileName.split('.').pop()?.toLowerCase();
|
|
89
|
+
const types = {
|
|
90
|
+
'jpg': 'image/jpeg',
|
|
91
|
+
'jpeg': 'image/jpeg',
|
|
92
|
+
'png': 'image/png',
|
|
93
|
+
'gif': 'image/gif',
|
|
94
|
+
'webp': 'image/webp',
|
|
95
|
+
'svg': 'image/svg+xml',
|
|
96
|
+
'ico': 'image/x-icon',
|
|
97
|
+
'pdf': 'application/pdf',
|
|
98
|
+
'mp4': 'video/mp4',
|
|
99
|
+
'webm': 'video/webm',
|
|
100
|
+
'mp3': 'audio/mpeg',
|
|
101
|
+
'wav': 'audio/wav',
|
|
102
|
+
'woff': 'font/woff',
|
|
103
|
+
'woff2': 'font/woff2',
|
|
104
|
+
'ttf': 'font/ttf',
|
|
105
|
+
'otf': 'font/otf'
|
|
106
|
+
};
|
|
107
|
+
return types[ext || ''] || 'application/octet-stream';
|
|
108
|
+
}
|
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
import { NextResponse } from 'next/server';
|
|
2
|
+
import { validateApiKey, listProjectAssets, deleteProjectAsset } from '@/lib/storage/blob';
|
|
3
|
+
/**
|
|
4
|
+
* List assets API
|
|
5
|
+
*
|
|
6
|
+
* GET /api/assets?slug=<project-slug>
|
|
7
|
+
* Headers:
|
|
8
|
+
* Authorization: Bearer <api_key>
|
|
9
|
+
*/ export async function GET(request) {
|
|
10
|
+
try {
|
|
11
|
+
const { searchParams } = new URL(request.url);
|
|
12
|
+
const slug = searchParams.get('slug');
|
|
13
|
+
if (!slug) {
|
|
14
|
+
return NextResponse.json({
|
|
15
|
+
error: 'Missing slug parameter'
|
|
16
|
+
}, {
|
|
17
|
+
status: 400
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
// Validate API key
|
|
21
|
+
const authHeader = request.headers.get('Authorization');
|
|
22
|
+
const apiKey = authHeader?.replace('Bearer ', '');
|
|
23
|
+
if (!apiKey) {
|
|
24
|
+
return NextResponse.json({
|
|
25
|
+
error: 'API key required'
|
|
26
|
+
}, {
|
|
27
|
+
status: 401
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
const validatedSlug = await validateApiKey(apiKey);
|
|
31
|
+
if (validatedSlug !== slug) {
|
|
32
|
+
return NextResponse.json({
|
|
33
|
+
error: 'Invalid API key for this project'
|
|
34
|
+
}, {
|
|
35
|
+
status: 403
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
const assets = await listProjectAssets(slug);
|
|
39
|
+
return NextResponse.json({
|
|
40
|
+
success: true,
|
|
41
|
+
slug,
|
|
42
|
+
assets,
|
|
43
|
+
count: assets.length
|
|
44
|
+
});
|
|
45
|
+
} catch (error) {
|
|
46
|
+
console.error('[Assets API] Error:', error);
|
|
47
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
48
|
+
return NextResponse.json({
|
|
49
|
+
error: 'Failed to list assets',
|
|
50
|
+
details: message
|
|
51
|
+
}, {
|
|
52
|
+
status: 500
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
/**
|
|
57
|
+
* Delete asset API
|
|
58
|
+
*
|
|
59
|
+
* DELETE /api/assets?slug=<project-slug>&fileName=<file-name>
|
|
60
|
+
* Headers:
|
|
61
|
+
* Authorization: Bearer <api_key>
|
|
62
|
+
*/ export async function DELETE(request) {
|
|
63
|
+
try {
|
|
64
|
+
const { searchParams } = new URL(request.url);
|
|
65
|
+
const slug = searchParams.get('slug');
|
|
66
|
+
const fileName = searchParams.get('fileName');
|
|
67
|
+
if (!slug || !fileName) {
|
|
68
|
+
return NextResponse.json({
|
|
69
|
+
error: 'Missing slug or fileName parameter'
|
|
70
|
+
}, {
|
|
71
|
+
status: 400
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
// Validate API key
|
|
75
|
+
const authHeader = request.headers.get('Authorization');
|
|
76
|
+
const apiKey = authHeader?.replace('Bearer ', '');
|
|
77
|
+
if (!apiKey) {
|
|
78
|
+
return NextResponse.json({
|
|
79
|
+
error: 'API key required'
|
|
80
|
+
}, {
|
|
81
|
+
status: 401
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
const validatedSlug = await validateApiKey(apiKey);
|
|
85
|
+
if (validatedSlug !== slug) {
|
|
86
|
+
return NextResponse.json({
|
|
87
|
+
error: 'Invalid API key for this project'
|
|
88
|
+
}, {
|
|
89
|
+
status: 403
|
|
90
|
+
});
|
|
91
|
+
}
|
|
92
|
+
const deleted = await deleteProjectAsset(slug, fileName);
|
|
93
|
+
if (!deleted) {
|
|
94
|
+
return NextResponse.json({
|
|
95
|
+
error: 'Asset not found'
|
|
96
|
+
}, {
|
|
97
|
+
status: 404
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
return NextResponse.json({
|
|
101
|
+
success: true,
|
|
102
|
+
message: `Asset ${fileName} deleted`
|
|
103
|
+
});
|
|
104
|
+
} catch (error) {
|
|
105
|
+
console.error('[Assets API] Error:', error);
|
|
106
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
107
|
+
return NextResponse.json({
|
|
108
|
+
error: 'Failed to delete asset',
|
|
109
|
+
details: message
|
|
110
|
+
}, {
|
|
111
|
+
status: 500
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
}
|
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
import { NextResponse } from 'next/server';
|
|
2
|
+
import { put } from '@vercel/blob';
|
|
3
|
+
import { validateApiKey } from '@/lib/storage/blob';
|
|
4
|
+
import path from 'path';
|
|
5
|
+
import fs from 'fs';
|
|
6
|
+
// Max file size: 25MB
|
|
7
|
+
const MAX_FILE_SIZE = 25 * 1024 * 1024;
|
|
8
|
+
// Allowed file types for assets
|
|
9
|
+
const ALLOWED_TYPES = [
|
|
10
|
+
'image/jpeg',
|
|
11
|
+
'image/png',
|
|
12
|
+
'image/gif',
|
|
13
|
+
'image/webp',
|
|
14
|
+
'image/svg+xml',
|
|
15
|
+
'image/x-icon',
|
|
16
|
+
'image/vnd.microsoft.icon',
|
|
17
|
+
'application/pdf',
|
|
18
|
+
'video/mp4',
|
|
19
|
+
'video/webm',
|
|
20
|
+
'audio/mpeg',
|
|
21
|
+
'audio/wav',
|
|
22
|
+
'font/woff',
|
|
23
|
+
'font/woff2',
|
|
24
|
+
'font/ttf',
|
|
25
|
+
'font/otf',
|
|
26
|
+
'application/font-woff',
|
|
27
|
+
'application/font-woff2'
|
|
28
|
+
];
|
|
29
|
+
// Check if we're in local development mode
|
|
30
|
+
const IS_LOCAL_DEV = !process.env.BLOB_READ_WRITE_TOKEN;
|
|
31
|
+
const LOCAL_STORAGE_DIR = path.join(process.cwd(), '.devdoc-storage');
|
|
32
|
+
/**
|
|
33
|
+
* Upload asset API - receives files from CLI and stores in Vercel Blob
|
|
34
|
+
*
|
|
35
|
+
* POST /api/assets/upload
|
|
36
|
+
* Headers:
|
|
37
|
+
* Authorization: Bearer <api_key>
|
|
38
|
+
* Content-Type: multipart/form-data
|
|
39
|
+
* Body: FormData with:
|
|
40
|
+
* - file: File to upload
|
|
41
|
+
* - slug: Project slug
|
|
42
|
+
* - path: Optional path/filename for the asset
|
|
43
|
+
*/ export async function POST(request) {
|
|
44
|
+
try {
|
|
45
|
+
// Validate API key
|
|
46
|
+
const authHeader = request.headers.get('Authorization');
|
|
47
|
+
const apiKey = authHeader?.replace('Bearer ', '');
|
|
48
|
+
if (!apiKey) {
|
|
49
|
+
return NextResponse.json({
|
|
50
|
+
error: 'API key required. Provide via Authorization header.'
|
|
51
|
+
}, {
|
|
52
|
+
status: 401
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
const validatedSlug = await validateApiKey(apiKey);
|
|
56
|
+
if (!validatedSlug) {
|
|
57
|
+
return NextResponse.json({
|
|
58
|
+
error: 'Invalid API key'
|
|
59
|
+
}, {
|
|
60
|
+
status: 403
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
// Parse multipart form data
|
|
64
|
+
const formData = await request.formData();
|
|
65
|
+
const file = formData.get('file');
|
|
66
|
+
const slug = formData.get('slug');
|
|
67
|
+
const assetPath = formData.get('path');
|
|
68
|
+
if (!file) {
|
|
69
|
+
return NextResponse.json({
|
|
70
|
+
error: 'No file provided'
|
|
71
|
+
}, {
|
|
72
|
+
status: 400
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
if (!slug) {
|
|
76
|
+
return NextResponse.json({
|
|
77
|
+
error: 'Project slug is required'
|
|
78
|
+
}, {
|
|
79
|
+
status: 400
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
// Verify the API key matches the project
|
|
83
|
+
if (validatedSlug !== slug) {
|
|
84
|
+
return NextResponse.json({
|
|
85
|
+
error: 'API key does not match project'
|
|
86
|
+
}, {
|
|
87
|
+
status: 403
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
// Validate file size
|
|
91
|
+
if (file.size > MAX_FILE_SIZE) {
|
|
92
|
+
return NextResponse.json({
|
|
93
|
+
error: `File size exceeds maximum allowed size of 25MB. Current size: ${(file.size / (1024 * 1024)).toFixed(2)}MB`
|
|
94
|
+
}, {
|
|
95
|
+
status: 400
|
|
96
|
+
});
|
|
97
|
+
}
|
|
98
|
+
// Validate file type
|
|
99
|
+
const contentType = file.type;
|
|
100
|
+
if (!ALLOWED_TYPES.includes(contentType) && !contentType.startsWith('image/')) {
|
|
101
|
+
return NextResponse.json({
|
|
102
|
+
error: `File type "${contentType}" is not allowed. Allowed types: images, PDFs, videos, audio, and fonts.`
|
|
103
|
+
}, {
|
|
104
|
+
status: 400
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
// Generate asset path
|
|
108
|
+
const fileName = assetPath || file.name;
|
|
109
|
+
const sanitizedFileName = fileName.replace(/[^a-zA-Z0-9._-]/g, '_');
|
|
110
|
+
const blobPath = `projects/${slug}/assets/${sanitizedFileName}`;
|
|
111
|
+
// Get file buffer
|
|
112
|
+
const buffer = Buffer.from(await file.arrayBuffer());
|
|
113
|
+
// Store in local filesystem or Vercel Blob
|
|
114
|
+
let url;
|
|
115
|
+
if (IS_LOCAL_DEV) {
|
|
116
|
+
// Local development - store in filesystem
|
|
117
|
+
const assetDir = path.join(LOCAL_STORAGE_DIR, 'projects', slug, 'assets');
|
|
118
|
+
fs.mkdirSync(assetDir, {
|
|
119
|
+
recursive: true
|
|
120
|
+
});
|
|
121
|
+
const filePath = path.join(assetDir, sanitizedFileName);
|
|
122
|
+
fs.writeFileSync(filePath, buffer);
|
|
123
|
+
url = `file://${filePath}`;
|
|
124
|
+
} else {
|
|
125
|
+
// Production - store in Vercel Blob
|
|
126
|
+
const blob = await put(blobPath, buffer, {
|
|
127
|
+
access: 'public',
|
|
128
|
+
contentType,
|
|
129
|
+
allowOverwrite: true
|
|
130
|
+
});
|
|
131
|
+
url = blob.url;
|
|
132
|
+
}
|
|
133
|
+
return NextResponse.json({
|
|
134
|
+
success: true,
|
|
135
|
+
url,
|
|
136
|
+
path: blobPath,
|
|
137
|
+
fileName: sanitizedFileName,
|
|
138
|
+
size: file.size,
|
|
139
|
+
contentType
|
|
140
|
+
});
|
|
141
|
+
} catch (error) {
|
|
142
|
+
console.error('[Asset Upload API] Error:', error);
|
|
143
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
144
|
+
return NextResponse.json({
|
|
145
|
+
error: 'Upload failed',
|
|
146
|
+
details: message
|
|
147
|
+
}, {
|
|
148
|
+
status: 500
|
|
149
|
+
});
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
/**
|
|
153
|
+
* OPTIONS for CORS preflight
|
|
154
|
+
*/ export async function OPTIONS() {
|
|
155
|
+
return new NextResponse(null, {
|
|
156
|
+
status: 200,
|
|
157
|
+
headers: {
|
|
158
|
+
'Access-Control-Allow-Origin': '*',
|
|
159
|
+
'Access-Control-Allow-Methods': 'POST, OPTIONS',
|
|
160
|
+
'Access-Control-Allow-Headers': 'Content-Type, Authorization'
|
|
161
|
+
}
|
|
162
|
+
});
|
|
163
|
+
}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Auth Schemes API Route
|
|
3
|
+
*
|
|
4
|
+
* Returns the security schemes defined in the OpenAPI spec
|
|
5
|
+
* so the frontend can suggest the correct auth type
|
|
6
|
+
*/ import { NextResponse } from 'next/server';
|
|
7
|
+
import { readFileSync, existsSync } from 'fs';
|
|
8
|
+
import { join, isAbsolute } from 'path';
|
|
9
|
+
import { extractSecuritySchemes, getDefaultAuth } from '@/lib/api-docs/parsers/openapi/extractors/auth';
|
|
10
|
+
const STARTER_PATH = process.env.STARTER_PATH || 'devdoc-docs';
|
|
11
|
+
const LOCAL_SPEC_PATH = process.env.LOCAL_SPEC_PATH || `${STARTER_PATH}/api-reference/openapi.json`;
|
|
12
|
+
// Helper to resolve paths
|
|
13
|
+
function resolvePath(...paths) {
|
|
14
|
+
if (isAbsolute(STARTER_PATH)) {
|
|
15
|
+
return join(STARTER_PATH, ...paths);
|
|
16
|
+
}
|
|
17
|
+
return join(process.cwd(), STARTER_PATH, ...paths);
|
|
18
|
+
}
|
|
19
|
+
// Load OpenAPI spec from local file
|
|
20
|
+
function loadLocalSpec() {
|
|
21
|
+
try {
|
|
22
|
+
const relativePath = LOCAL_SPEC_PATH;
|
|
23
|
+
const fullPath = relativePath.startsWith(STARTER_PATH) || isAbsolute(relativePath) ? isAbsolute(relativePath) ? relativePath : resolvePath(relativePath.replace(STARTER_PATH + '/', '')) : resolvePath(relativePath);
|
|
24
|
+
if (!existsSync(fullPath)) {
|
|
25
|
+
return null;
|
|
26
|
+
}
|
|
27
|
+
const content = readFileSync(fullPath, 'utf-8');
|
|
28
|
+
return JSON.parse(content);
|
|
29
|
+
} catch (error) {
|
|
30
|
+
console.error('[Auth Schemes] Error loading local spec:', error);
|
|
31
|
+
return null;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
export async function GET() {
|
|
35
|
+
try {
|
|
36
|
+
const spec = loadLocalSpec();
|
|
37
|
+
if (!spec) {
|
|
38
|
+
return NextResponse.json({
|
|
39
|
+
schemes: [],
|
|
40
|
+
defaultAuth: null
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
const schemes = extractSecuritySchemes(spec);
|
|
44
|
+
const defaultAuth = getDefaultAuth(spec);
|
|
45
|
+
return NextResponse.json({
|
|
46
|
+
schemes,
|
|
47
|
+
defaultAuth
|
|
48
|
+
});
|
|
49
|
+
} catch (error) {
|
|
50
|
+
return NextResponse.json({
|
|
51
|
+
schemes: [],
|
|
52
|
+
defaultAuth: null,
|
|
53
|
+
error: error instanceof Error ? error.message : 'Unknown error'
|
|
54
|
+
}, {
|
|
55
|
+
status: 500
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
}
|