@brainfish-ai/devdoc 0.1.42 → 0.1.44
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/cli/commands/create.js +2 -2
- 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 +706 -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 +195 -0
- package/renderer/app/globals.css +69 -0
- package/renderer/app/layout.js +47 -0
- package/renderer/app/llms-full.txt/route.js +266 -0
- package/renderer/app/llms.txt/route.js +228 -0
- package/renderer/app/page.js +12 -0
- package/renderer/app/robots.txt/route.js +66 -0
- package/renderer/app/sitemap.xml/route.js +155 -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 +317 -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 +1831 -0
- package/renderer/components/docs-viewer/agent/agent-popup-button.js +99 -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 +7 -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/content-router.js +182 -0
- package/renderer/components/docs-viewer/content/doc-page.js +290 -0
- package/renderer/components/docs-viewer/content/documentation-viewer.js +14 -0
- package/renderer/components/docs-viewer/content/index.js +31 -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 +1448 -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 +936 -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 +159 -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 +86 -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/hooks/use-route-state.js +159 -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/agent/use-suggestions.js +97 -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 +126 -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 +116 -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/environment.js +38 -0
- package/renderer/lib/docs/config/index.js +6 -0
- package/renderer/lib/docs/config/loader.js +113 -0
- package/renderer/lib/docs/config/schema.js +281 -0
- package/renderer/lib/docs/index.js +8 -0
- package/renderer/lib/docs/mdx/compiler.js +131 -0
- package/renderer/lib/docs/mdx/frontmatter.js +73 -0
- package/renderer/lib/docs/mdx/index.js +10 -0
- package/renderer/lib/docs/mdx/remark-mermaid.js +63 -0
- package/renderer/lib/docs/navigation/generator.js +269 -0
- package/renderer/lib/docs/navigation/index.js +3 -0
- package/renderer/lib/docs/navigation/types.js +11 -0
- package/renderer/lib/docs-navigation-context.js +40 -0
- package/renderer/lib/docs-navigation.js +140 -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/package.json +1 -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 -1670
- 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,350 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* GraphQL Schema Parser
|
|
3
|
+
*
|
|
4
|
+
* Parses GraphQL SDL (Schema Definition Language) files into our internal types.
|
|
5
|
+
* Uses the graphql-js library for parsing.
|
|
6
|
+
*/ import { buildSchema, isObjectType, isInputObjectType, isEnumType, isInterfaceType, isUnionType, isScalarType, isNonNullType, isListType, isNamedType, getNamedType } from 'graphql';
|
|
7
|
+
// ============================================================================
|
|
8
|
+
// Type Conversion Helpers
|
|
9
|
+
// ============================================================================
|
|
10
|
+
/**
|
|
11
|
+
* Convert a GraphQL type to our type reference format
|
|
12
|
+
*/ function convertTypeToRef(type) {
|
|
13
|
+
if (isNonNullType(type)) {
|
|
14
|
+
return {
|
|
15
|
+
kind: 'NON_NULL',
|
|
16
|
+
name: null,
|
|
17
|
+
ofType: convertTypeToRef(type.ofType)
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
if (isListType(type)) {
|
|
21
|
+
return {
|
|
22
|
+
kind: 'LIST',
|
|
23
|
+
name: null,
|
|
24
|
+
ofType: convertTypeToRef(type.ofType)
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
if (isNamedType(type)) {
|
|
28
|
+
const namedType = getNamedType(type);
|
|
29
|
+
let kind = 'SCALAR';
|
|
30
|
+
if (isObjectType(namedType)) kind = 'OBJECT';
|
|
31
|
+
else if (isInputObjectType(namedType)) kind = 'INPUT_OBJECT';
|
|
32
|
+
else if (isEnumType(namedType)) kind = 'ENUM';
|
|
33
|
+
else if (isInterfaceType(namedType)) kind = 'INTERFACE';
|
|
34
|
+
else if (isUnionType(namedType)) kind = 'UNION';
|
|
35
|
+
else if (isScalarType(namedType)) kind = 'SCALAR';
|
|
36
|
+
return {
|
|
37
|
+
kind,
|
|
38
|
+
name: namedType.name,
|
|
39
|
+
ofType: null
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
return {
|
|
43
|
+
kind: 'SCALAR',
|
|
44
|
+
name: 'Unknown',
|
|
45
|
+
ofType: null
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
/**
|
|
49
|
+
* Convert GraphQL argument to our format
|
|
50
|
+
*/ function convertArgument(arg) {
|
|
51
|
+
return {
|
|
52
|
+
name: arg.name,
|
|
53
|
+
description: arg.description || null,
|
|
54
|
+
type: convertTypeToRef(arg.type),
|
|
55
|
+
defaultValue: arg.defaultValue !== undefined ? JSON.stringify(arg.defaultValue) : null,
|
|
56
|
+
isRequired: isNonNullType(arg.type)
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
/**
|
|
60
|
+
* Convert GraphQL input field to our format
|
|
61
|
+
*/ function convertInputField(field) {
|
|
62
|
+
return {
|
|
63
|
+
name: field.name,
|
|
64
|
+
description: field.description || null,
|
|
65
|
+
type: convertTypeToRef(field.type),
|
|
66
|
+
defaultValue: field.defaultValue !== undefined ? JSON.stringify(field.defaultValue) : null,
|
|
67
|
+
isRequired: isNonNullType(field.type)
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* Convert GraphQL field to our format
|
|
72
|
+
*/ function convertField(field) {
|
|
73
|
+
return {
|
|
74
|
+
name: field.name,
|
|
75
|
+
description: field.description || null,
|
|
76
|
+
args: field.args.map(convertArgument),
|
|
77
|
+
type: convertTypeToRef(field.type),
|
|
78
|
+
isDeprecated: field.deprecationReason != null,
|
|
79
|
+
deprecationReason: field.deprecationReason || null
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
|
+
// ============================================================================
|
|
83
|
+
// Type Definition Converters
|
|
84
|
+
// ============================================================================
|
|
85
|
+
/**
|
|
86
|
+
* Convert an object type to our format
|
|
87
|
+
*/ function convertObjectType(type) {
|
|
88
|
+
const fields = type.getFields();
|
|
89
|
+
return {
|
|
90
|
+
kind: 'OBJECT',
|
|
91
|
+
name: type.name,
|
|
92
|
+
description: type.description || null,
|
|
93
|
+
fields: Object.values(fields).map(convertField),
|
|
94
|
+
interfaces: type.getInterfaces().map((i)=>i.name)
|
|
95
|
+
};
|
|
96
|
+
}
|
|
97
|
+
/**
|
|
98
|
+
* Convert an input object type to our format
|
|
99
|
+
*/ function convertInputObjectType(type) {
|
|
100
|
+
const fields = type.getFields();
|
|
101
|
+
return {
|
|
102
|
+
kind: 'INPUT_OBJECT',
|
|
103
|
+
name: type.name,
|
|
104
|
+
description: type.description || null,
|
|
105
|
+
inputFields: Object.values(fields).map(convertInputField)
|
|
106
|
+
};
|
|
107
|
+
}
|
|
108
|
+
/**
|
|
109
|
+
* Convert an enum type to our format
|
|
110
|
+
*/ function convertEnumType(type) {
|
|
111
|
+
return {
|
|
112
|
+
kind: 'ENUM',
|
|
113
|
+
name: type.name,
|
|
114
|
+
description: type.description || null,
|
|
115
|
+
enumValues: type.getValues().map((v)=>({
|
|
116
|
+
name: v.name,
|
|
117
|
+
description: v.description || null,
|
|
118
|
+
isDeprecated: v.deprecationReason != null,
|
|
119
|
+
deprecationReason: v.deprecationReason || null
|
|
120
|
+
}))
|
|
121
|
+
};
|
|
122
|
+
}
|
|
123
|
+
/**
|
|
124
|
+
* Convert an interface type to our format
|
|
125
|
+
*/ function convertInterfaceType(type, schema) {
|
|
126
|
+
const fields = type.getFields();
|
|
127
|
+
const implementations = schema.getPossibleTypes(type);
|
|
128
|
+
return {
|
|
129
|
+
kind: 'INTERFACE',
|
|
130
|
+
name: type.name,
|
|
131
|
+
description: type.description || null,
|
|
132
|
+
fields: Object.values(fields).map(convertField),
|
|
133
|
+
possibleTypes: implementations.map((t)=>t.name)
|
|
134
|
+
};
|
|
135
|
+
}
|
|
136
|
+
/**
|
|
137
|
+
* Convert a union type to our format
|
|
138
|
+
*/ function convertUnionType(type) {
|
|
139
|
+
return {
|
|
140
|
+
kind: 'UNION',
|
|
141
|
+
name: type.name,
|
|
142
|
+
description: type.description || null,
|
|
143
|
+
possibleTypes: type.getTypes().map((t)=>t.name)
|
|
144
|
+
};
|
|
145
|
+
}
|
|
146
|
+
/**
|
|
147
|
+
* Convert a scalar type to our format
|
|
148
|
+
*/ function convertScalarType(type) {
|
|
149
|
+
return {
|
|
150
|
+
kind: 'SCALAR',
|
|
151
|
+
name: type.name,
|
|
152
|
+
description: type.description || null
|
|
153
|
+
};
|
|
154
|
+
}
|
|
155
|
+
// ============================================================================
|
|
156
|
+
// Operation Extractors
|
|
157
|
+
// ============================================================================
|
|
158
|
+
/**
|
|
159
|
+
* Extract operations from a root type (Query, Mutation, Subscription)
|
|
160
|
+
*/ function extractOperations(rootType, operationType) {
|
|
161
|
+
if (!rootType) return [];
|
|
162
|
+
const fields = rootType.getFields();
|
|
163
|
+
return Object.values(fields).map((field)=>({
|
|
164
|
+
id: `${operationType}-${field.name}`.toLowerCase(),
|
|
165
|
+
name: field.name,
|
|
166
|
+
description: field.description || null,
|
|
167
|
+
operationType,
|
|
168
|
+
args: field.args.map(convertArgument),
|
|
169
|
+
returnType: convertTypeToRef(field.type),
|
|
170
|
+
isDeprecated: field.deprecationReason != null,
|
|
171
|
+
deprecationReason: field.deprecationReason || null
|
|
172
|
+
}));
|
|
173
|
+
}
|
|
174
|
+
/**
|
|
175
|
+
* Extract directives from schema
|
|
176
|
+
*/ function extractDirectives(schema) {
|
|
177
|
+
return schema.getDirectives().map((directive)=>({
|
|
178
|
+
name: directive.name,
|
|
179
|
+
description: directive.description || null,
|
|
180
|
+
locations: directive.locations,
|
|
181
|
+
args: directive.args.map(convertArgument)
|
|
182
|
+
}));
|
|
183
|
+
}
|
|
184
|
+
// ============================================================================
|
|
185
|
+
// Main Parser Functions
|
|
186
|
+
// ============================================================================
|
|
187
|
+
/**
|
|
188
|
+
* Parse a GraphQL SDL string into our schema format
|
|
189
|
+
*/ export function parseGraphQLSchema(sdl) {
|
|
190
|
+
// Build the schema from SDL
|
|
191
|
+
const schema = buildSchema(sdl);
|
|
192
|
+
return convertGraphQLSchema(schema);
|
|
193
|
+
}
|
|
194
|
+
/**
|
|
195
|
+
* Convert a graphql-js schema object to our format
|
|
196
|
+
*/ export function convertGraphQLSchema(schema) {
|
|
197
|
+
const typeMap = schema.getTypeMap();
|
|
198
|
+
const types = {};
|
|
199
|
+
// Convert all types (excluding built-in types that start with __)
|
|
200
|
+
for (const [name, type] of Object.entries(typeMap)){
|
|
201
|
+
if (name.startsWith('__')) continue; // Skip introspection types
|
|
202
|
+
if (isObjectType(type)) {
|
|
203
|
+
types[name] = convertObjectType(type);
|
|
204
|
+
} else if (isInputObjectType(type)) {
|
|
205
|
+
types[name] = convertInputObjectType(type);
|
|
206
|
+
} else if (isEnumType(type)) {
|
|
207
|
+
types[name] = convertEnumType(type);
|
|
208
|
+
} else if (isInterfaceType(type)) {
|
|
209
|
+
types[name] = convertInterfaceType(type, schema);
|
|
210
|
+
} else if (isUnionType(type)) {
|
|
211
|
+
types[name] = convertUnionType(type);
|
|
212
|
+
} else if (isScalarType(type)) {
|
|
213
|
+
types[name] = convertScalarType(type);
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
// Get root types
|
|
217
|
+
const queryType = schema.getQueryType();
|
|
218
|
+
const mutationType = schema.getMutationType();
|
|
219
|
+
const subscriptionType = schema.getSubscriptionType();
|
|
220
|
+
// Schema info
|
|
221
|
+
const info = {
|
|
222
|
+
description: schema.description || null,
|
|
223
|
+
queryType: queryType?.name || null,
|
|
224
|
+
mutationType: mutationType?.name || null,
|
|
225
|
+
subscriptionType: subscriptionType?.name || null
|
|
226
|
+
};
|
|
227
|
+
return {
|
|
228
|
+
info,
|
|
229
|
+
types,
|
|
230
|
+
directives: extractDirectives(schema),
|
|
231
|
+
queries: extractOperations(queryType, 'query'),
|
|
232
|
+
mutations: extractOperations(mutationType, 'mutation'),
|
|
233
|
+
subscriptions: extractOperations(subscriptionType, 'subscription')
|
|
234
|
+
};
|
|
235
|
+
}
|
|
236
|
+
/**
|
|
237
|
+
* Parse GraphQL SDL from a file content (handles both .graphql and .gql)
|
|
238
|
+
*/ export async function parseGraphQLFile(content) {
|
|
239
|
+
return parseGraphQLSchema(content);
|
|
240
|
+
}
|
|
241
|
+
/**
|
|
242
|
+
* Validate that content is valid GraphQL SDL
|
|
243
|
+
*/ export function validateGraphQLSchema(sdl) {
|
|
244
|
+
try {
|
|
245
|
+
buildSchema(sdl);
|
|
246
|
+
return {
|
|
247
|
+
valid: true
|
|
248
|
+
};
|
|
249
|
+
} catch (error) {
|
|
250
|
+
return {
|
|
251
|
+
valid: false,
|
|
252
|
+
error: error instanceof Error ? error.message : 'Invalid GraphQL schema'
|
|
253
|
+
};
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
/**
|
|
257
|
+
* Parse introspection query result to our schema format
|
|
258
|
+
*/ export function parseIntrospectionResult(introspectionResult) {
|
|
259
|
+
// The introspection result contains __schema with types, directives, etc.
|
|
260
|
+
// We need to convert this to our format
|
|
261
|
+
// For now, this is a placeholder - full implementation would parse the introspection JSON
|
|
262
|
+
const result = introspectionResult;
|
|
263
|
+
if (!result.__schema) {
|
|
264
|
+
throw new Error('Invalid introspection result: missing __schema');
|
|
265
|
+
}
|
|
266
|
+
// This is a simplified implementation
|
|
267
|
+
// A full implementation would parse all the introspection data
|
|
268
|
+
const schema = {
|
|
269
|
+
info: {
|
|
270
|
+
description: null,
|
|
271
|
+
queryType: result.__schema.queryType?.name || null,
|
|
272
|
+
mutationType: result.__schema.mutationType?.name || null,
|
|
273
|
+
subscriptionType: result.__schema.subscriptionType?.name || null
|
|
274
|
+
},
|
|
275
|
+
types: {},
|
|
276
|
+
directives: [],
|
|
277
|
+
queries: [],
|
|
278
|
+
mutations: [],
|
|
279
|
+
subscriptions: []
|
|
280
|
+
};
|
|
281
|
+
return schema;
|
|
282
|
+
}
|
|
283
|
+
// ============================================================================
|
|
284
|
+
// Query Generation Helpers
|
|
285
|
+
// ============================================================================
|
|
286
|
+
/**
|
|
287
|
+
* Generate a sample query string for an operation
|
|
288
|
+
*/ export function generateOperationQuery(operation) {
|
|
289
|
+
const operationKeyword = operation.operationType;
|
|
290
|
+
const args = operation.args.map((arg)=>`$${arg.name}: ${formatTypeRefForQuery(arg.type)}`).join(', ');
|
|
291
|
+
const fieldArgs = operation.args.map((arg)=>`${arg.name}: $${arg.name}`).join(', ');
|
|
292
|
+
const argsStr = args ? `(${args})` : '';
|
|
293
|
+
const fieldArgsStr = fieldArgs ? `(${fieldArgs})` : '';
|
|
294
|
+
return `${operationKeyword} ${operation.name}${argsStr} {
|
|
295
|
+
${operation.name}${fieldArgsStr} {
|
|
296
|
+
# Add fields here
|
|
297
|
+
}
|
|
298
|
+
}`;
|
|
299
|
+
}
|
|
300
|
+
/**
|
|
301
|
+
* Format type ref for query variables
|
|
302
|
+
*/ function formatTypeRefForQuery(typeRef) {
|
|
303
|
+
if (typeRef.kind === 'NON_NULL' && typeRef.ofType) {
|
|
304
|
+
return `${formatTypeRefForQuery(typeRef.ofType)}!`;
|
|
305
|
+
}
|
|
306
|
+
if (typeRef.kind === 'LIST' && typeRef.ofType) {
|
|
307
|
+
return `[${formatTypeRefForQuery(typeRef.ofType)}]`;
|
|
308
|
+
}
|
|
309
|
+
return typeRef.name || 'Unknown';
|
|
310
|
+
}
|
|
311
|
+
/**
|
|
312
|
+
* Generate example variables for an operation
|
|
313
|
+
*/ export function generateExampleVariables(operation) {
|
|
314
|
+
const variables = {};
|
|
315
|
+
for (const arg of operation.args){
|
|
316
|
+
variables[arg.name] = generateExampleValue(arg.type);
|
|
317
|
+
}
|
|
318
|
+
return variables;
|
|
319
|
+
}
|
|
320
|
+
/**
|
|
321
|
+
* Generate example value for a type
|
|
322
|
+
*/ function generateExampleValue(typeRef) {
|
|
323
|
+
// Unwrap non-null
|
|
324
|
+
if (typeRef.kind === 'NON_NULL' && typeRef.ofType) {
|
|
325
|
+
return generateExampleValue(typeRef.ofType);
|
|
326
|
+
}
|
|
327
|
+
// Handle list
|
|
328
|
+
if (typeRef.kind === 'LIST' && typeRef.ofType) {
|
|
329
|
+
return [
|
|
330
|
+
generateExampleValue(typeRef.ofType)
|
|
331
|
+
];
|
|
332
|
+
}
|
|
333
|
+
// Handle named types
|
|
334
|
+
const typeName = typeRef.name;
|
|
335
|
+
switch(typeName){
|
|
336
|
+
case 'String':
|
|
337
|
+
return 'example';
|
|
338
|
+
case 'Int':
|
|
339
|
+
return 42;
|
|
340
|
+
case 'Float':
|
|
341
|
+
return 3.14;
|
|
342
|
+
case 'Boolean':
|
|
343
|
+
return true;
|
|
344
|
+
case 'ID':
|
|
345
|
+
return 'abc123';
|
|
346
|
+
default:
|
|
347
|
+
// For custom types, return an empty object as placeholder
|
|
348
|
+
return {};
|
|
349
|
+
}
|
|
350
|
+
}
|
|
@@ -0,0 +1,215 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* GraphQL Transformer
|
|
3
|
+
*
|
|
4
|
+
* Converts parsed GraphQL schema to BrainfishCollection format
|
|
5
|
+
* for integration with the existing documentation system.
|
|
6
|
+
*/ import { makeBrainfishCollection } from '../../factories';
|
|
7
|
+
import { formatTypeRef } from './types';
|
|
8
|
+
import { generateExampleVariables, generateOperationQuery } from './parser';
|
|
9
|
+
// ============================================================================
|
|
10
|
+
// GraphQL to REST-like Request Conversion
|
|
11
|
+
// ============================================================================
|
|
12
|
+
/**
|
|
13
|
+
* Convert a GraphQL operation to a REST-like request for the playground
|
|
14
|
+
* This allows us to reuse the existing API client UI
|
|
15
|
+
*/ function convertOperationToRESTRequest(operation, endpoint) {
|
|
16
|
+
// Generate the query string
|
|
17
|
+
const query = generateOperationQuery(operation);
|
|
18
|
+
// Generate example variables
|
|
19
|
+
const variables = generateExampleVariables(operation);
|
|
20
|
+
// GraphQL always uses POST with JSON body
|
|
21
|
+
const body = JSON.stringify({
|
|
22
|
+
query,
|
|
23
|
+
variables,
|
|
24
|
+
operationName: operation.name
|
|
25
|
+
}, null, 2);
|
|
26
|
+
return {
|
|
27
|
+
id: operation.id,
|
|
28
|
+
name: operation.name,
|
|
29
|
+
description: operation.description || formatOperationDescription(operation),
|
|
30
|
+
method: 'POST',
|
|
31
|
+
endpoint,
|
|
32
|
+
params: [],
|
|
33
|
+
headers: [
|
|
34
|
+
{
|
|
35
|
+
key: 'Content-Type',
|
|
36
|
+
value: 'application/json',
|
|
37
|
+
active: true,
|
|
38
|
+
description: 'GraphQL requests use JSON'
|
|
39
|
+
}
|
|
40
|
+
],
|
|
41
|
+
auth: {
|
|
42
|
+
authType: 'inherit',
|
|
43
|
+
authActive: true
|
|
44
|
+
},
|
|
45
|
+
body: {
|
|
46
|
+
contentType: 'application/json',
|
|
47
|
+
body
|
|
48
|
+
},
|
|
49
|
+
requestVariables: operation.args.map((arg)=>({
|
|
50
|
+
key: arg.name,
|
|
51
|
+
value: JSON.stringify(generateExampleVariables({
|
|
52
|
+
...operation,
|
|
53
|
+
args: [
|
|
54
|
+
arg
|
|
55
|
+
]
|
|
56
|
+
})[arg.name]),
|
|
57
|
+
active: true
|
|
58
|
+
})),
|
|
59
|
+
responses: {},
|
|
60
|
+
tags: [
|
|
61
|
+
operation.operationType
|
|
62
|
+
]
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* Format a description for an operation based on its signature
|
|
67
|
+
*/ function formatOperationDescription(operation) {
|
|
68
|
+
const args = operation.args.map((arg)=>`${arg.name}: ${formatTypeRef(arg.type)}`).join(', ');
|
|
69
|
+
const returnType = formatTypeRef(operation.returnType);
|
|
70
|
+
return `${operation.operationType} ${operation.name}(${args}): ${returnType}`;
|
|
71
|
+
}
|
|
72
|
+
// ============================================================================
|
|
73
|
+
// Main Transformer Functions
|
|
74
|
+
// ============================================================================
|
|
75
|
+
/**
|
|
76
|
+
* Convert GraphQL schema to a BrainfishGraphQLCollection
|
|
77
|
+
*/ export function convertGraphQLToCollection(schema, name, endpoint, description) {
|
|
78
|
+
// Convert operations to our request format
|
|
79
|
+
const queries = schema.queries.map((op)=>({
|
|
80
|
+
id: op.id,
|
|
81
|
+
name: op.name,
|
|
82
|
+
description: op.description,
|
|
83
|
+
operationType: 'query',
|
|
84
|
+
query: generateOperationQuery(op),
|
|
85
|
+
variables: op.args,
|
|
86
|
+
returnType: op.returnType,
|
|
87
|
+
tags: [
|
|
88
|
+
'Query'
|
|
89
|
+
],
|
|
90
|
+
exampleVariables: generateExampleVariables(op)
|
|
91
|
+
}));
|
|
92
|
+
const mutations = schema.mutations.map((op)=>({
|
|
93
|
+
id: op.id,
|
|
94
|
+
name: op.name,
|
|
95
|
+
description: op.description,
|
|
96
|
+
operationType: 'mutation',
|
|
97
|
+
query: generateOperationQuery(op),
|
|
98
|
+
variables: op.args,
|
|
99
|
+
returnType: op.returnType,
|
|
100
|
+
tags: [
|
|
101
|
+
'Mutation'
|
|
102
|
+
],
|
|
103
|
+
exampleVariables: generateExampleVariables(op)
|
|
104
|
+
}));
|
|
105
|
+
const subscriptions = schema.subscriptions.map((op)=>({
|
|
106
|
+
id: op.id,
|
|
107
|
+
name: op.name,
|
|
108
|
+
description: op.description,
|
|
109
|
+
operationType: 'subscription',
|
|
110
|
+
query: generateOperationQuery(op),
|
|
111
|
+
variables: op.args,
|
|
112
|
+
returnType: op.returnType,
|
|
113
|
+
tags: [
|
|
114
|
+
'Subscription'
|
|
115
|
+
],
|
|
116
|
+
exampleVariables: generateExampleVariables(op)
|
|
117
|
+
}));
|
|
118
|
+
// Extract custom types (exclude built-in scalars)
|
|
119
|
+
const customTypes = Object.values(schema.types).filter((type)=>![
|
|
120
|
+
'String',
|
|
121
|
+
'Int',
|
|
122
|
+
'Float',
|
|
123
|
+
'Boolean',
|
|
124
|
+
'ID'
|
|
125
|
+
].includes(type.name));
|
|
126
|
+
return {
|
|
127
|
+
id: `graphql-${name.toLowerCase().replace(/\s+/g, '-')}`,
|
|
128
|
+
name,
|
|
129
|
+
description: description || schema.info.description,
|
|
130
|
+
endpoint,
|
|
131
|
+
schema,
|
|
132
|
+
queries,
|
|
133
|
+
mutations,
|
|
134
|
+
subscriptions,
|
|
135
|
+
types: customTypes
|
|
136
|
+
};
|
|
137
|
+
}
|
|
138
|
+
/**
|
|
139
|
+
* Convert GraphQL schema to BrainfishCollection format
|
|
140
|
+
* This allows integration with the existing REST-based UI
|
|
141
|
+
*/ export function convertGraphQLToBrainfishCollection(schema, name, endpoint, description) {
|
|
142
|
+
// Create folders for each operation type
|
|
143
|
+
const queryFolder = makeBrainfishCollection({
|
|
144
|
+
name: 'Queries',
|
|
145
|
+
description: 'GraphQL Query operations',
|
|
146
|
+
requests: schema.queries.map((op)=>convertOperationToRESTRequest(op, endpoint)),
|
|
147
|
+
folders: [],
|
|
148
|
+
variables: [],
|
|
149
|
+
auth: {
|
|
150
|
+
authType: 'none',
|
|
151
|
+
authActive: false
|
|
152
|
+
},
|
|
153
|
+
headers: []
|
|
154
|
+
});
|
|
155
|
+
const mutationFolder = makeBrainfishCollection({
|
|
156
|
+
name: 'Mutations',
|
|
157
|
+
description: 'GraphQL Mutation operations',
|
|
158
|
+
requests: schema.mutations.map((op)=>convertOperationToRESTRequest(op, endpoint)),
|
|
159
|
+
folders: [],
|
|
160
|
+
variables: [],
|
|
161
|
+
auth: {
|
|
162
|
+
authType: 'none',
|
|
163
|
+
authActive: false
|
|
164
|
+
},
|
|
165
|
+
headers: []
|
|
166
|
+
});
|
|
167
|
+
const subscriptionFolder = makeBrainfishCollection({
|
|
168
|
+
name: 'Subscriptions',
|
|
169
|
+
description: 'GraphQL Subscription operations',
|
|
170
|
+
requests: schema.subscriptions.map((op)=>convertOperationToRESTRequest(op, endpoint)),
|
|
171
|
+
folders: [],
|
|
172
|
+
variables: [],
|
|
173
|
+
auth: {
|
|
174
|
+
authType: 'none',
|
|
175
|
+
authActive: false
|
|
176
|
+
},
|
|
177
|
+
headers: []
|
|
178
|
+
});
|
|
179
|
+
// Only include folders that have operations
|
|
180
|
+
const folders = [];
|
|
181
|
+
if (schema.queries.length > 0) folders.push(queryFolder);
|
|
182
|
+
if (schema.mutations.length > 0) folders.push(mutationFolder);
|
|
183
|
+
if (schema.subscriptions.length > 0) folders.push(subscriptionFolder);
|
|
184
|
+
return makeBrainfishCollection({
|
|
185
|
+
name,
|
|
186
|
+
description: description || schema.info.description || 'GraphQL API',
|
|
187
|
+
folders,
|
|
188
|
+
requests: [],
|
|
189
|
+
variables: [],
|
|
190
|
+
auth: {
|
|
191
|
+
authType: 'none',
|
|
192
|
+
authActive: false
|
|
193
|
+
},
|
|
194
|
+
headers: [
|
|
195
|
+
{
|
|
196
|
+
key: 'Content-Type',
|
|
197
|
+
value: 'application/json',
|
|
198
|
+
active: true,
|
|
199
|
+
description: 'GraphQL requests use JSON'
|
|
200
|
+
}
|
|
201
|
+
]
|
|
202
|
+
});
|
|
203
|
+
}
|
|
204
|
+
/**
|
|
205
|
+
* Merge GraphQL collection with existing REST collection
|
|
206
|
+
*/ export function mergeWithRESTCollection(restCollection, graphqlSchema, graphqlEndpoint) {
|
|
207
|
+
const graphqlCollection = convertGraphQLToBrainfishCollection(graphqlSchema, 'GraphQL', graphqlEndpoint);
|
|
208
|
+
return {
|
|
209
|
+
...restCollection,
|
|
210
|
+
folders: [
|
|
211
|
+
...restCollection.folders,
|
|
212
|
+
graphqlCollection
|
|
213
|
+
]
|
|
214
|
+
};
|
|
215
|
+
}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* GraphQL Types for Brainfish API Documentation
|
|
3
|
+
*
|
|
4
|
+
* Types for parsing and representing GraphQL schemas in the documentation system.
|
|
5
|
+
*/ // ============================================================================
|
|
6
|
+
// GraphQL Scalar Types
|
|
7
|
+
// ============================================================================
|
|
8
|
+
// ============================================================================
|
|
9
|
+
// Helper Functions
|
|
10
|
+
// ============================================================================
|
|
11
|
+
/**
|
|
12
|
+
* Format a GraphQL type reference as a string
|
|
13
|
+
* e.g., [String!]! -> "[String!]!"
|
|
14
|
+
*/ export function formatTypeRef(typeRef) {
|
|
15
|
+
if (typeRef.kind === 'NON_NULL' && typeRef.ofType) {
|
|
16
|
+
return `${formatTypeRef(typeRef.ofType)}!`;
|
|
17
|
+
}
|
|
18
|
+
if (typeRef.kind === 'LIST' && typeRef.ofType) {
|
|
19
|
+
return `[${formatTypeRef(typeRef.ofType)}]`;
|
|
20
|
+
}
|
|
21
|
+
return typeRef.name || 'Unknown';
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Check if a type is required (non-null at the top level)
|
|
25
|
+
*/ export function isTypeRequired(typeRef) {
|
|
26
|
+
return typeRef.kind === 'NON_NULL';
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Get the base type name from a type reference
|
|
30
|
+
*/ export function getBaseTypeName(typeRef) {
|
|
31
|
+
if (typeRef.ofType) {
|
|
32
|
+
return getBaseTypeName(typeRef.ofType);
|
|
33
|
+
}
|
|
34
|
+
return typeRef.name || 'Unknown';
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Check if a type is a scalar type
|
|
38
|
+
*/ export function isScalarType(typeName) {
|
|
39
|
+
return [
|
|
40
|
+
'String',
|
|
41
|
+
'Int',
|
|
42
|
+
'Float',
|
|
43
|
+
'Boolean',
|
|
44
|
+
'ID'
|
|
45
|
+
].includes(typeName);
|
|
46
|
+
}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* OpenAPI Dereferencer
|
|
3
|
+
*
|
|
4
|
+
* Ported from Hoppscotch's openapi-import-worker.ts
|
|
5
|
+
* Converts Web Worker pattern to direct function calls for Next.js
|
|
6
|
+
*/ import SwaggerParser from '@apidevtools/swagger-parser';
|
|
7
|
+
/**
|
|
8
|
+
* Dereferences all $ref references in an OpenAPI document
|
|
9
|
+
*
|
|
10
|
+
* @param docs - The OpenAPI document to dereference
|
|
11
|
+
* @returns Promise resolving to dereferenced OpenAPI document
|
|
12
|
+
* @throws Error if dereferencing fails
|
|
13
|
+
*/ export async function dereferenceOpenAPISpec(docs) {
|
|
14
|
+
try {
|
|
15
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
16
|
+
const dereferenced = await SwaggerParser.dereference(docs);
|
|
17
|
+
return dereferenced;
|
|
18
|
+
} catch {
|
|
19
|
+
throw new Error('COULD_NOT_DEREFERENCE');
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Checks if a document has unresolved $ref references
|
|
24
|
+
*
|
|
25
|
+
* @param obj - The object to check
|
|
26
|
+
* @param visited - Set of visited objects to detect circular references
|
|
27
|
+
* @returns true if unresolved references are found
|
|
28
|
+
*/ export function hasUnresolvedRefs(obj, visited = new WeakSet()) {
|
|
29
|
+
// Handle non-objects or null
|
|
30
|
+
if (!obj || typeof obj !== 'object') return false;
|
|
31
|
+
// Check for circular references
|
|
32
|
+
if (visited.has(obj)) return false;
|
|
33
|
+
// Add current object to visited set
|
|
34
|
+
visited.add(obj);
|
|
35
|
+
// Check if current object has $ref property
|
|
36
|
+
if ('$ref' in obj && typeof obj.$ref === 'string') return true;
|
|
37
|
+
// Check arrays
|
|
38
|
+
if (Array.isArray(obj)) {
|
|
39
|
+
return obj.some((item)=>hasUnresolvedRefs(item, visited));
|
|
40
|
+
}
|
|
41
|
+
// Check object properties
|
|
42
|
+
return Object.values(obj).some((value)=>hasUnresolvedRefs(value, visited));
|
|
43
|
+
}
|