zudoku 0.0.0-f865d81 → 0.0.0-fa903e7
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/app/demo.js +0 -2
- package/dist/app/demo.js.map +1 -1
- package/dist/app/entry.client.js +14 -0
- package/dist/app/entry.client.js.map +1 -1
- package/dist/app/entry.server.js +6 -6
- package/dist/app/entry.server.js.map +1 -1
- package/dist/app/main.d.ts +1 -1
- package/dist/app/main.js +2 -2
- package/dist/app/main.js.map +1 -1
- package/dist/app/standalone.js +0 -2
- package/dist/app/standalone.js.map +1 -1
- package/dist/cli/cli.js +1 -2
- package/dist/cli/cli.js.map +1 -1
- package/dist/cli/common/logger.js +9 -0
- package/dist/cli/common/logger.js.map +1 -1
- package/dist/codegen.d.ts +3 -0
- package/dist/codegen.js +45 -0
- package/dist/codegen.js.map +1 -0
- package/dist/config/validators/InputSidebarSchema.d.ts +10 -10
- package/dist/config/validators/validate.d.ts +148 -117
- package/dist/config/validators/validate.js +13 -6
- package/dist/config/validators/validate.js.map +1 -1
- package/dist/index.d.ts +2 -2
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/lib/authentication/AuthenticationPlugin.d.ts +4 -2
- package/dist/lib/authentication/AuthenticationPlugin.js +3 -0
- package/dist/lib/authentication/AuthenticationPlugin.js.map +1 -1
- package/dist/lib/authentication/authentication.d.ts +3 -3
- package/dist/lib/authentication/hook.d.ts +5 -4
- package/dist/lib/authentication/hook.js +1 -3
- package/dist/lib/authentication/hook.js.map +1 -1
- package/dist/lib/authentication/providers/auth0.js +12 -11
- package/dist/lib/authentication/providers/auth0.js.map +1 -1
- package/dist/lib/authentication/providers/openid.d.ts +0 -1
- package/dist/lib/authentication/providers/openid.js +11 -26
- package/dist/lib/authentication/providers/openid.js.map +1 -1
- package/dist/lib/authentication/state.d.ts +25 -4
- package/dist/lib/authentication/state.js +28 -3
- package/dist/lib/authentication/state.js.map +1 -1
- package/dist/lib/authentication/use-broadcast/shared.d.ts +48 -0
- package/dist/lib/authentication/use-broadcast/shared.js +243 -0
- package/dist/lib/authentication/use-broadcast/shared.js.map +1 -0
- package/dist/lib/authentication/use-broadcast/useBroadcast.d.ts +24 -0
- package/dist/lib/authentication/use-broadcast/useBroadcast.js +106 -0
- package/dist/lib/authentication/use-broadcast/useBroadcast.js.map +1 -0
- package/dist/lib/components/Bootstrap.d.ts +3 -1
- package/dist/lib/components/Bootstrap.js +10 -4
- package/dist/lib/components/Bootstrap.js.map +1 -1
- package/dist/lib/components/ClientOnly.d.ts +4 -2
- package/dist/lib/components/ClientOnly.js +1 -1
- package/dist/lib/components/ClientOnly.js.map +1 -1
- package/dist/lib/components/DeveloperHint.js +2 -1
- package/dist/lib/components/DeveloperHint.js.map +1 -1
- package/dist/lib/components/Header.js +16 -10
- package/dist/lib/components/Header.js.map +1 -1
- package/dist/lib/components/Heading.d.ts +1 -1
- package/dist/lib/components/Layout.js +12 -4
- package/dist/lib/components/Layout.js.map +1 -1
- package/dist/lib/components/MobileTopNavigation.js +6 -7
- package/dist/lib/components/MobileTopNavigation.js.map +1 -1
- package/dist/lib/components/SyntaxHighlight.js +16 -12
- package/dist/lib/components/SyntaxHighlight.js.map +1 -1
- package/dist/lib/components/ThemeSwitch.d.ts +1 -0
- package/dist/lib/components/ThemeSwitch.js +13 -0
- package/dist/lib/components/ThemeSwitch.js.map +1 -0
- package/dist/lib/components/TopNavigation.d.ts +2 -0
- package/dist/lib/components/TopNavigation.js +13 -7
- package/dist/lib/components/TopNavigation.js.map +1 -1
- package/dist/lib/components/{DevPortal.d.ts → Zudoku.d.ts} +3 -3
- package/dist/lib/components/{DevPortal.js → Zudoku.js} +13 -14
- package/dist/lib/components/Zudoku.js.map +1 -0
- package/dist/lib/components/context/ZudokuContext.d.ts +7 -7
- package/dist/lib/components/context/ZudokuContext.js +8 -13
- package/dist/lib/components/context/ZudokuContext.js.map +1 -1
- package/dist/lib/components/context/ZudokuProvider.d.ts +2 -2
- package/dist/lib/components/context/ZudokuProvider.js.map +1 -1
- package/dist/lib/components/index.d.ts +18 -10
- package/dist/lib/components/index.js +2 -3
- package/dist/lib/components/index.js.map +1 -1
- package/dist/lib/components/navigation/Sidebar.js +1 -1
- package/dist/lib/components/navigation/Sidebar.js.map +1 -1
- package/dist/lib/components/navigation/utils.js +2 -2
- package/dist/lib/components/navigation/utils.js.map +1 -1
- package/dist/lib/core/{DevPortalContext.d.ts → ZudokuContext.d.ts} +3 -7
- package/dist/lib/core/{DevPortalContext.js → ZudokuContext.js} +2 -7
- package/dist/lib/core/ZudokuContext.js.map +1 -0
- package/dist/lib/core/plugins.d.ts +18 -12
- package/dist/lib/core/plugins.js.map +1 -1
- package/dist/lib/errors/ErrorAlert.js +1 -1
- package/dist/lib/errors/ErrorAlert.js.map +1 -1
- package/dist/lib/oas/graphql/index.js +4 -4
- package/dist/lib/oas/graphql/index.js.map +1 -1
- package/dist/lib/oas/parser/upgrade/index.d.ts +2 -2
- package/dist/lib/oas/parser/upgrade/index.js +2 -17
- package/dist/lib/oas/parser/upgrade/index.js.map +1 -1
- package/dist/lib/plugins/api-keys/index.d.ts +9 -9
- package/dist/lib/plugins/api-keys/index.js +3 -0
- package/dist/lib/plugins/api-keys/index.js.map +1 -1
- package/dist/lib/plugins/custom-pages/index.d.ts +2 -2
- package/dist/lib/plugins/custom-pages/index.js.map +1 -1
- package/dist/lib/plugins/markdown/MdxPage.d.ts +9 -1
- package/dist/lib/plugins/markdown/MdxPage.js +14 -1
- package/dist/lib/plugins/markdown/MdxPage.js.map +1 -1
- package/dist/lib/plugins/markdown/index.d.ts +2 -2
- package/dist/lib/plugins/markdown/index.js +1 -1
- package/dist/lib/plugins/markdown/index.js.map +1 -1
- package/dist/lib/plugins/openapi/CollapsibleCode.d.ts +5 -0
- package/dist/lib/plugins/openapi/CollapsibleCode.js +24 -0
- package/dist/lib/plugins/openapi/CollapsibleCode.js.map +1 -0
- package/dist/lib/plugins/openapi/ColorizedParam.js +13 -9
- package/dist/lib/plugins/openapi/ColorizedParam.js.map +1 -1
- package/dist/lib/plugins/openapi/Endpoint.d.ts +1 -1
- package/dist/lib/plugins/openapi/Endpoint.js +5 -9
- package/dist/lib/plugins/openapi/Endpoint.js.map +1 -1
- package/dist/lib/plugins/openapi/OperationList.d.ts +2 -2
- package/dist/lib/plugins/openapi/OperationList.js +21 -22
- package/dist/lib/plugins/openapi/OperationList.js.map +1 -1
- package/dist/lib/plugins/openapi/ParameterListItem.js +6 -1
- package/dist/lib/plugins/openapi/ParameterListItem.js.map +1 -1
- package/dist/lib/plugins/openapi/RequestBodySidecarBox.js +7 -3
- package/dist/lib/plugins/openapi/RequestBodySidecarBox.js.map +1 -1
- package/dist/lib/plugins/openapi/ResponsesSidecarBox.js +9 -2
- package/dist/lib/plugins/openapi/ResponsesSidecarBox.js.map +1 -1
- package/dist/lib/plugins/openapi/Route.d.ts +4 -4
- package/dist/lib/plugins/openapi/Route.js +2 -4
- package/dist/lib/plugins/openapi/Route.js.map +1 -1
- package/dist/lib/plugins/openapi/Sidecar.d.ts +1 -1
- package/dist/lib/plugins/openapi/Sidecar.js +35 -33
- package/dist/lib/plugins/openapi/Sidecar.js.map +1 -1
- package/dist/lib/plugins/openapi/client/GraphQLClient.d.ts +8 -0
- package/dist/lib/plugins/openapi/client/GraphQLClient.js +114 -0
- package/dist/lib/plugins/openapi/client/GraphQLClient.js.map +1 -0
- package/dist/lib/plugins/openapi/client/GraphQLContext.d.ts +7 -0
- package/dist/lib/plugins/openapi/client/GraphQLContext.js +5 -0
- package/dist/lib/plugins/openapi/client/GraphQLContext.js.map +1 -0
- package/dist/lib/plugins/openapi/client/createServer.d.ts +1 -0
- package/dist/lib/plugins/openapi/client/useCreateQuery.d.ts +5 -0
- package/dist/lib/plugins/openapi/client/useCreateQuery.js +15 -0
- package/dist/lib/plugins/openapi/client/useCreateQuery.js.map +1 -0
- package/dist/lib/plugins/openapi/client/worker.d.ts +4 -1
- package/dist/lib/plugins/openapi/client/worker.js +23 -14
- package/dist/lib/plugins/openapi/client/worker.js.map +1 -1
- package/dist/lib/plugins/openapi/graphql/fragment-masking.d.ts +3 -3
- package/dist/lib/plugins/openapi/graphql/fragment-masking.js +3 -4
- package/dist/lib/plugins/openapi/graphql/fragment-masking.js.map +1 -1
- package/dist/lib/plugins/openapi/graphql/gql.d.ts +5 -51
- package/dist/lib/plugins/openapi/graphql/gql.js +4 -2
- package/dist/lib/plugins/openapi/graphql/gql.js.map +1 -1
- package/dist/lib/plugins/openapi/graphql/graphql.d.ts +32 -8
- package/dist/lib/plugins/openapi/graphql/graphql.js +194 -662
- package/dist/lib/plugins/openapi/graphql/graphql.js.map +1 -1
- package/dist/lib/plugins/openapi/index.d.ts +2 -2
- package/dist/lib/plugins/openapi/index.js +40 -53
- package/dist/lib/plugins/openapi/index.js.map +1 -1
- package/dist/lib/plugins/openapi/interfaces.d.ts +1 -1
- package/dist/lib/plugins/openapi/post-processors/removeExtensions.d.ts +6 -0
- package/dist/lib/plugins/openapi/post-processors/removeExtensions.js +14 -0
- package/dist/lib/plugins/openapi/post-processors/removeExtensions.js.map +1 -0
- package/dist/lib/plugins/openapi/post-processors/removeExtensions.test.d.ts +1 -0
- package/dist/lib/plugins/openapi/post-processors/removeExtensions.test.js +125 -0
- package/dist/lib/plugins/openapi/post-processors/removeExtensions.test.js.map +1 -0
- package/dist/lib/plugins/openapi/post-processors/removePaths.d.ts +11 -0
- package/dist/lib/plugins/openapi/post-processors/removePaths.js +33 -0
- package/dist/lib/plugins/openapi/post-processors/removePaths.js.map +1 -0
- package/dist/lib/plugins/openapi/post-processors/removePaths.test.d.ts +1 -0
- package/dist/lib/plugins/openapi/post-processors/removePaths.test.js +104 -0
- package/dist/lib/plugins/openapi/post-processors/removePaths.test.js.map +1 -0
- package/dist/lib/plugins/openapi/post-processors/traverse.d.ts +1 -0
- package/dist/lib/plugins/openapi/post-processors/traverse.js +2 -0
- package/dist/lib/plugins/openapi/post-processors/traverse.js.map +1 -0
- package/dist/lib/plugins/openapi/schema/SchemaView.js +2 -1
- package/dist/lib/plugins/openapi/schema/SchemaView.js.map +1 -1
- package/dist/lib/plugins/openapi/util/generateSchemaExample.d.ts +0 -1
- package/dist/lib/plugins/openapi/util/generateSchemaExample.js +25 -36
- package/dist/lib/plugins/openapi/util/generateSchemaExample.js.map +1 -1
- package/dist/lib/plugins/openapi-worker.d.ts +1 -1
- package/dist/lib/plugins/openapi-worker.js +7 -1
- package/dist/lib/plugins/openapi-worker.js.map +1 -1
- package/dist/lib/plugins/redirect/index.d.ts +4 -7
- package/dist/lib/plugins/redirect/index.js +1 -1
- package/dist/lib/plugins/redirect/index.js.map +1 -1
- package/dist/lib/plugins/search-inkeep/index.d.ts +2 -2
- package/dist/lib/plugins/search-inkeep/index.js.map +1 -1
- package/dist/lib/ui/ActionButton.d.ts +4 -0
- package/dist/lib/ui/ActionButton.js +10 -0
- package/dist/lib/ui/ActionButton.js.map +1 -0
- package/dist/lib/util/MdxComponents.d.ts +1 -1
- package/dist/lib/util/traverse.d.ts +2 -0
- package/dist/lib/util/traverse.js +18 -0
- package/dist/lib/util/traverse.js.map +1 -0
- package/dist/lib/util/useIsomorphicLayoutEffect.d.ts +3 -0
- package/dist/lib/util/useIsomorphicLayoutEffect.js +4 -0
- package/dist/lib/util/useIsomorphicLayoutEffect.js.map +1 -0
- package/dist/lib/util/useOnScreen.d.ts +4 -0
- package/dist/lib/util/useOnScreen.js +19 -0
- package/dist/lib/util/useOnScreen.js.map +1 -0
- package/dist/vite/build.js +5 -1
- package/dist/vite/build.js.map +1 -1
- package/dist/vite/config.d.ts +2 -8
- package/dist/vite/config.js +25 -54
- package/dist/vite/config.js.map +1 -1
- package/dist/vite/config.test.js +3 -4
- package/dist/vite/config.test.js.map +1 -1
- package/dist/vite/html.js +0 -2
- package/dist/vite/html.js.map +1 -1
- package/dist/vite/output.d.ts +101 -0
- package/dist/vite/output.js +53 -0
- package/dist/vite/output.js.map +1 -0
- package/dist/vite/plugin-api.js +23 -19
- package/dist/vite/plugin-api.js.map +1 -1
- package/dist/vite/plugin-component.js +14 -19
- package/dist/vite/plugin-component.js.map +1 -1
- package/dist/vite/plugin-config.d.ts +2 -3
- package/dist/vite/plugin-config.js +2 -3
- package/dist/vite/plugin-config.js.map +1 -1
- package/dist/vite/plugin-docs.test.js +15 -23
- package/dist/vite/plugin-docs.test.js.map +1 -1
- package/dist/vite/plugin-mdx.d.ts +0 -6
- package/dist/vite/plugin-mdx.js +13 -5
- package/dist/vite/plugin-mdx.js.map +1 -1
- package/dist/vite/plugin.js +1 -3
- package/dist/vite/plugin.js.map +1 -1
- package/dist/vite/prerender.js +3 -2
- package/dist/vite/prerender.js.map +1 -1
- package/dist/vite/remarkStaticGeneration.d.ts +3 -0
- package/dist/vite/remarkStaticGeneration.js +125 -0
- package/dist/vite/remarkStaticGeneration.js.map +1 -0
- package/dist/zuplo/with-zuplo.d.ts +3 -0
- package/dist/zuplo/with-zuplo.js +28 -0
- package/dist/zuplo/with-zuplo.js.map +1 -0
- package/lib/{AnchorLink-BbB2q-jx.js → AnchorLink-CDlhr8gL.js} +11 -10
- package/lib/{AnchorLink-BbB2q-jx.js.map → AnchorLink-CDlhr8gL.js.map} +1 -1
- package/lib/AuthenticationPlugin-D0Em0SwR.js +59 -0
- package/lib/{AuthenticationPlugin-C9BHGXlE.js.map → AuthenticationPlugin-D0Em0SwR.js.map} +1 -1
- package/lib/Button-jK0EsymC.js +48 -0
- package/lib/Button-jK0EsymC.js.map +1 -0
- package/lib/{ClientOnly-CVN6leDu.js → ClientOnly-E7hGysn1.js} +4 -4
- package/lib/ClientOnly-E7hGysn1.js.map +1 -0
- package/lib/Markdown-ievDDhFT.js +15192 -0
- package/lib/Markdown-ievDDhFT.js.map +1 -0
- package/lib/MdxPage-B2FpJ9KC.js +183 -0
- package/lib/MdxPage-B2FpJ9KC.js.map +1 -0
- package/lib/OperationList-BkNQEsNs.js +4693 -0
- package/lib/OperationList-BkNQEsNs.js.map +1 -0
- package/lib/Route-DlG_HTMu.js +11 -0
- package/lib/Route-DlG_HTMu.js.map +1 -0
- package/lib/{Select-Bagt3Bme.js → Select-O9ZM3ZgX.js} +7 -7
- package/lib/Select-O9ZM3ZgX.js.map +1 -0
- package/lib/{Spinner-C6zroowC.js → SidebarBadge-DxFJcJ6V.js} +28 -17
- package/lib/SidebarBadge-DxFJcJ6V.js.map +1 -0
- package/lib/SlotletProvider-DyomlzGx.js +252 -0
- package/lib/SlotletProvider-DyomlzGx.js.map +1 -0
- package/lib/Spinner-3cQDBVGr.js +7 -0
- package/lib/Spinner-3cQDBVGr.js.map +1 -0
- package/lib/SyntaxHighlight-DkLOsjHS.js +2983 -0
- package/lib/SyntaxHighlight-DkLOsjHS.js.map +1 -0
- package/lib/assets/{worker-Bf8vjASY.js → worker-BHClFO3A.js} +156 -156
- package/lib/assets/worker-BHClFO3A.js.map +1 -0
- package/lib/context-D1nXWxm7.js +22 -0
- package/lib/context-D1nXWxm7.js.map +1 -0
- package/lib/createServer-CpJlUPtn.js +15299 -0
- package/lib/createServer-CpJlUPtn.js.map +1 -0
- package/lib/{hook-sn0zMTkE.js → hook-hEqe7fPB.js} +12 -14
- package/lib/hook-hEqe7fPB.js.map +1 -0
- package/lib/index-C7SaIME0.js +1277 -0
- package/lib/index-C7SaIME0.js.map +1 -0
- package/lib/index-Czzd9rjU.js +899 -0
- package/lib/index-Czzd9rjU.js.map +1 -0
- package/lib/index-Yn8c3UWE.js +921 -0
- package/lib/index-Yn8c3UWE.js.map +1 -0
- package/lib/object_hash-CvlLgU-M.js +785 -0
- package/lib/object_hash-CvlLgU-M.js.map +1 -0
- package/lib/post-processors/removeExtensions.js +11 -0
- package/lib/post-processors/removeExtensions.js.map +1 -0
- package/lib/post-processors/removePaths.js +28 -0
- package/lib/post-processors/removePaths.js.map +1 -0
- package/lib/post-processors/traverse.js +12 -0
- package/lib/post-processors/traverse.js.map +1 -0
- package/lib/{router-BsfSoK2j.js → router-lfyopgBI.js} +23 -23
- package/lib/{router-BsfSoK2j.js.map → router-lfyopgBI.js.map} +1 -1
- package/lib/state-tsXBLONe.js +203 -0
- package/lib/{state-CsuHT8ZO.js.map → state-tsXBLONe.js.map} +1 -1
- package/lib/ui/ActionButton.js +25 -0
- package/lib/ui/ActionButton.js.map +1 -0
- package/lib/useExposedProps-CTPtylCV.js +10 -0
- package/lib/{useExposedProps-ChOIUaS4.js.map → useExposedProps-CTPtylCV.js.map} +1 -1
- package/lib/{ZudokuContext-BKXGJTmu.js → utils-DcpDOncX.js} +242 -246
- package/lib/utils-DcpDOncX.js.map +1 -0
- package/lib/zudoku.auth-auth0.js +24 -18
- package/lib/zudoku.auth-auth0.js.map +1 -1
- package/lib/zudoku.auth-clerk.js +2 -2
- package/lib/zudoku.auth-openid.js +124 -138
- package/lib/zudoku.auth-openid.js.map +1 -1
- package/lib/zudoku.components.js +1291 -1119
- package/lib/zudoku.components.js.map +1 -1
- package/lib/zudoku.openapi-worker.js +10 -16336
- package/lib/zudoku.openapi-worker.js.map +1 -1
- package/lib/zudoku.plugin-api-keys.js +41 -39
- package/lib/zudoku.plugin-api-keys.js.map +1 -1
- package/lib/zudoku.plugin-custom-pages.js +2 -2
- package/lib/zudoku.plugin-custom-pages.js.map +1 -1
- package/lib/zudoku.plugin-markdown.js +15 -14
- package/lib/zudoku.plugin-markdown.js.map +1 -1
- package/lib/zudoku.plugin-openapi.js +5 -9
- package/lib/zudoku.plugin-openapi.js.map +1 -1
- package/lib/zudoku.plugin-redirect.js +2 -2
- package/lib/zudoku.plugin-redirect.js.map +1 -1
- package/lib/zudoku.plugin-search-inkeep.js +1 -1
- package/lib/zudoku.plugin-search-inkeep.js.map +1 -1
- package/package.json +27 -7
- package/src/app/demo.tsx +0 -3
- package/src/app/entry.client.tsx +14 -0
- package/src/app/entry.server.tsx +59 -53
- package/src/app/main.css +1 -1
- package/src/app/main.tsx +4 -4
- package/src/app/standalone.tsx +0 -3
- package/src/lib/authentication/AuthenticationPlugin.tsx +4 -1
- package/src/lib/authentication/authentication.ts +3 -3
- package/src/lib/authentication/hook.ts +1 -3
- package/src/lib/authentication/providers/auth0.tsx +17 -11
- package/src/lib/authentication/providers/openid.tsx +12 -30
- package/src/lib/authentication/state.ts +50 -9
- package/{LICENSE.md → src/lib/authentication/use-broadcast/LICENSE.md} +2 -2
- package/src/lib/authentication/use-broadcast/shared.ts +372 -0
- package/src/lib/authentication/use-broadcast/useBroadcast.ts +146 -0
- package/src/lib/components/Bootstrap.tsx +36 -14
- package/src/lib/components/ClientOnly.tsx +6 -3
- package/src/lib/components/DeveloperHint.tsx +6 -1
- package/src/lib/components/Header.tsx +68 -40
- package/src/lib/components/Layout.tsx +49 -37
- package/src/lib/components/MobileTopNavigation.tsx +15 -18
- package/src/lib/components/SyntaxHighlight.tsx +81 -46
- package/src/lib/components/ThemeSwitch.tsx +26 -0
- package/src/lib/components/TopNavigation.tsx +27 -19
- package/src/lib/components/Zudoku.tsx +108 -0
- package/src/lib/components/context/ZudokuContext.ts +11 -16
- package/src/lib/components/context/ZudokuProvider.tsx +2 -2
- package/src/lib/components/index.ts +2 -3
- package/src/lib/components/navigation/Sidebar.tsx +3 -3
- package/src/lib/components/navigation/utils.ts +2 -2
- package/src/lib/core/{DevPortalContext.ts → ZudokuContext.ts} +3 -11
- package/src/lib/core/plugins.ts +20 -16
- package/src/lib/errors/ErrorAlert.tsx +2 -1
- package/src/lib/oas/graphql/index.ts +4 -4
- package/src/lib/oas/parser/upgrade/index.ts +3 -24
- package/src/lib/plugins/api-keys/index.tsx +12 -9
- package/src/lib/plugins/custom-pages/index.tsx +2 -2
- package/src/lib/plugins/markdown/MdxPage.tsx +25 -1
- package/src/lib/plugins/markdown/index.tsx +3 -2
- package/src/lib/plugins/openapi/CollapsibleCode.tsx +80 -0
- package/src/lib/plugins/openapi/ColorizedParam.tsx +23 -14
- package/src/lib/plugins/openapi/Endpoint.tsx +5 -10
- package/src/lib/plugins/openapi/OperationList.tsx +20 -40
- package/src/lib/plugins/openapi/ParameterListItem.tsx +37 -31
- package/src/lib/plugins/openapi/RequestBodySidecarBox.tsx +18 -13
- package/src/lib/plugins/openapi/ResponsesSidecarBox.tsx +17 -12
- package/src/lib/plugins/openapi/Route.tsx +11 -12
- package/src/lib/plugins/openapi/Sidecar.tsx +73 -59
- package/src/lib/plugins/openapi/client/GraphQLClient.tsx +157 -0
- package/src/lib/plugins/openapi/client/GraphQLContext.tsx +16 -0
- package/src/lib/plugins/openapi/client/createServer.ts +2 -0
- package/src/lib/plugins/openapi/client/useCreateQuery.ts +21 -0
- package/src/lib/plugins/openapi/client/worker.ts +38 -24
- package/src/lib/plugins/openapi/graphql/fragment-masking.ts +11 -18
- package/src/lib/plugins/openapi/graphql/gql.ts +10 -27
- package/src/lib/plugins/openapi/graphql/graphql.ts +233 -665
- package/src/lib/plugins/openapi/index.tsx +42 -67
- package/src/lib/plugins/openapi/interfaces.ts +1 -1
- package/src/lib/plugins/openapi/post-processors/removeExtensions.test.ts +144 -0
- package/src/lib/plugins/openapi/post-processors/removeExtensions.ts +24 -0
- package/src/lib/plugins/openapi/post-processors/removePaths.test.ts +126 -0
- package/src/lib/plugins/openapi/post-processors/removePaths.ts +55 -0
- package/src/lib/plugins/openapi/post-processors/traverse.ts +1 -0
- package/src/lib/plugins/openapi/schema/SchemaView.tsx +5 -2
- package/src/lib/plugins/openapi/util/generateSchemaExample.ts +28 -42
- package/src/lib/plugins/openapi-worker.ts +11 -1
- package/src/lib/plugins/redirect/index.tsx +5 -9
- package/src/lib/plugins/search-inkeep/index.tsx +2 -2
- package/src/lib/ui/ActionButton.tsx +28 -0
- package/src/lib/util/traverse.ts +25 -0
- package/src/lib/util/useIsomorphicLayoutEffect.ts +5 -0
- package/src/lib/util/useOnScreen.ts +32 -0
- package/dist/lib/components/DevPortal.js.map +0 -1
- package/dist/lib/components/context/ThemeContext.d.ts +0 -2
- package/dist/lib/components/context/ThemeContext.js +0 -7
- package/dist/lib/components/context/ThemeContext.js.map +0 -1
- package/dist/lib/components/context/ThemeProvider.d.ts +0 -4
- package/dist/lib/components/context/ThemeProvider.js +0 -23
- package/dist/lib/components/context/ThemeProvider.js.map +0 -1
- package/dist/lib/core/DevPortalContext.js.map +0 -1
- package/dist/lib/plugins/openapi/client/createMemoryClient.d.ts +0 -12
- package/dist/lib/plugins/openapi/client/createMemoryClient.js +0 -46
- package/dist/lib/plugins/openapi/client/createMemoryClient.js.map +0 -1
- package/dist/lib/plugins/openapi/client/createWorkerClient.d.ts +0 -10
- package/dist/lib/plugins/openapi/client/createWorkerClient.js +0 -61
- package/dist/lib/plugins/openapi/client/createWorkerClient.js.map +0 -1
- package/dist/lib/plugins/openapi/client/interfaces.d.ts +0 -4
- package/dist/lib/plugins/openapi/client/interfaces.js +0 -2
- package/dist/lib/plugins/openapi/client/interfaces.js.map +0 -1
- package/dist/lib/themeToggle.d.ts +0 -1
- package/dist/lib/themeToggle.js +0 -7
- package/dist/lib/themeToggle.js.map +0 -1
- package/dist/lib/util/createWaitForNotify.d.ts +0 -1
- package/dist/lib/util/createWaitForNotify.js +0 -15
- package/dist/lib/util/createWaitForNotify.js.map +0 -1
- package/dist/vite/plugin-html-transform.d.ts +0 -2
- package/dist/vite/plugin-html-transform.js +0 -15
- package/dist/vite/plugin-html-transform.js.map +0 -1
- package/lib/AuthenticationPlugin-C9BHGXlE.js +0 -55
- package/lib/ClientOnly-CVN6leDu.js.map +0 -1
- package/lib/DeveloperHint-DHdLXGHA.js +0 -16
- package/lib/DeveloperHint-DHdLXGHA.js.map +0 -1
- package/lib/Markdown-BDcCAWwm.js +0 -18059
- package/lib/Markdown-BDcCAWwm.js.map +0 -1
- package/lib/MdxPage-DKMH_t0f.js +0 -174
- package/lib/MdxPage-DKMH_t0f.js.map +0 -1
- package/lib/OperationList-Tj7ubW_t.js +0 -604
- package/lib/OperationList-Tj7ubW_t.js.map +0 -1
- package/lib/Route-C3DGB6OS.js +0 -13
- package/lib/Route-C3DGB6OS.js.map +0 -1
- package/lib/Select-Bagt3Bme.js.map +0 -1
- package/lib/SlotletProvider-Da7eFgd2.js +0 -241
- package/lib/SlotletProvider-Da7eFgd2.js.map +0 -1
- package/lib/Spinner-C6zroowC.js.map +0 -1
- package/lib/StaggeredRender-DDHSzQKE.js +0 -17
- package/lib/StaggeredRender-DDHSzQKE.js.map +0 -1
- package/lib/ZudokuContext-BKXGJTmu.js.map +0 -1
- package/lib/assets/worker-Bf8vjASY.js.map +0 -1
- package/lib/hook-sn0zMTkE.js.map +0 -1
- package/lib/index-AjWCJNGC.js +0 -5690
- package/lib/index-AjWCJNGC.js.map +0 -1
- package/lib/index-CRo94sKK.js +0 -1783
- package/lib/index-CRo94sKK.js.map +0 -1
- package/lib/state-CsuHT8ZO.js +0 -183
- package/lib/urql-core-KJnLL26g.js +0 -1455
- package/lib/urql-core-KJnLL26g.js.map +0 -1
- package/lib/useExposedProps-ChOIUaS4.js +0 -9
- package/src/lib/components/DevPortal.tsx +0 -111
- package/src/lib/components/context/ThemeContext.tsx +0 -8
- package/src/lib/components/context/ThemeProvider.tsx +0 -27
- package/src/lib/plugins/openapi/client/createMemoryClient.ts +0 -51
- package/src/lib/plugins/openapi/client/createWorkerClient.ts +0 -75
- package/src/lib/plugins/openapi/client/interfaces.ts +0 -5
- package/src/lib/themeToggle.ts +0 -7
- package/src/lib/util/createWaitForNotify.ts +0 -18
|
@@ -1,26 +1,23 @@
|
|
|
1
|
-
import { matchPath,
|
|
2
|
-
import {
|
|
3
|
-
import { type DevPortalPlugin } from "../../core/plugins.js";
|
|
1
|
+
import { matchPath, type RouteObject } from "react-router-dom";
|
|
2
|
+
import { type ZudokuPlugin } from "../../core/plugins.js";
|
|
4
3
|
import { graphql } from "./graphql/index.js";
|
|
5
4
|
|
|
6
5
|
import { useQuery } from "@tanstack/react-query";
|
|
7
6
|
import { CirclePlayIcon, LogInIcon } from "lucide-react";
|
|
8
|
-
import { createClient } from "zudoku/openapi-worker";
|
|
9
7
|
import type { SidebarItem } from "../../../config/validators/SidebarSchema.js";
|
|
10
8
|
import { useAuth } from "../../authentication/hook.js";
|
|
11
|
-
import { ErrorPage } from "../../components/ErrorPage.js";
|
|
12
9
|
import { ColorMap } from "../../components/navigation/SidebarBadge.js";
|
|
13
|
-
import { SyntaxHighlight } from "../../components/SyntaxHighlight.js";
|
|
14
10
|
import { Button } from "../../ui/Button.js";
|
|
15
11
|
import { joinPath } from "../../util/joinPath.js";
|
|
12
|
+
import { GraphQLClient } from "./client/GraphQLClient.js";
|
|
16
13
|
import { OasPluginConfig } from "./interfaces.js";
|
|
17
14
|
import type { PlaygroundContentProps } from "./playground/Playground.js";
|
|
18
15
|
import { PlaygroundDialog } from "./playground/PlaygroundDialog.js";
|
|
19
|
-
import { GetServerQuery } from "./Sidecar.js";
|
|
20
16
|
|
|
21
17
|
const GetCategoriesQuery = graphql(`
|
|
22
18
|
query GetCategories($input: JSON!, $type: SchemaType!) {
|
|
23
19
|
schema(input: $input, type: $type) {
|
|
20
|
+
url
|
|
24
21
|
tags {
|
|
25
22
|
__typename
|
|
26
23
|
name
|
|
@@ -38,20 +35,6 @@ const GetCategoriesQuery = graphql(`
|
|
|
38
35
|
}
|
|
39
36
|
`);
|
|
40
37
|
|
|
41
|
-
const OpenApiErrorPage = () => {
|
|
42
|
-
const error = useRouteError();
|
|
43
|
-
const message =
|
|
44
|
-
error instanceof Error ? (
|
|
45
|
-
<SyntaxHighlight code={error.message} />
|
|
46
|
-
) : (
|
|
47
|
-
"An unknown error occurred"
|
|
48
|
-
);
|
|
49
|
-
|
|
50
|
-
return (
|
|
51
|
-
<ErrorPage category="Error" title="An error occurred" message={message} />
|
|
52
|
-
);
|
|
53
|
-
};
|
|
54
|
-
|
|
55
38
|
type InternalOasPluginConfig = { inMemory?: boolean };
|
|
56
39
|
|
|
57
40
|
const MethodColorMap: Record<string, keyof typeof ColorMap> = {
|
|
@@ -66,17 +49,10 @@ const MethodColorMap: Record<string, keyof typeof ColorMap> = {
|
|
|
66
49
|
|
|
67
50
|
export type OpenApiPluginOptions = OasPluginConfig & InternalOasPluginConfig;
|
|
68
51
|
|
|
69
|
-
export const openApiPlugin = (
|
|
70
|
-
config: OpenApiPluginOptions,
|
|
71
|
-
): DevPortalPlugin => {
|
|
52
|
+
export const openApiPlugin = (config: OpenApiPluginOptions): ZudokuPlugin => {
|
|
72
53
|
const basePath = joinPath(config.navigationId ?? "/reference");
|
|
73
54
|
|
|
74
|
-
const client = config
|
|
75
|
-
? new UrqlClient({
|
|
76
|
-
url: config.server,
|
|
77
|
-
exchanges: [cacheExchange, fetchExchange],
|
|
78
|
-
})
|
|
79
|
-
: createClient({ useMemoryClient: config.inMemory ?? false });
|
|
55
|
+
const client = new GraphQLClient(config);
|
|
80
56
|
|
|
81
57
|
return {
|
|
82
58
|
getHead: () => {
|
|
@@ -104,15 +80,13 @@ export const openApiPlugin = (
|
|
|
104
80
|
...props
|
|
105
81
|
}: Partial<PlaygroundContentProps> & { requireAuth: boolean }) => {
|
|
106
82
|
const auth = useAuth();
|
|
83
|
+
// We don't have the GraphQL context here
|
|
107
84
|
const serverQuery = useQuery({
|
|
108
|
-
queryFn:
|
|
109
|
-
|
|
85
|
+
queryFn: () =>
|
|
86
|
+
client.fetch(GetCategoriesQuery, {
|
|
110
87
|
type: config.type,
|
|
111
88
|
input: config.input,
|
|
112
|
-
})
|
|
113
|
-
|
|
114
|
-
return result.data;
|
|
115
|
-
},
|
|
89
|
+
}),
|
|
116
90
|
enabled: !server,
|
|
117
91
|
queryKey: ["playground-server"],
|
|
118
92
|
});
|
|
@@ -150,38 +124,40 @@ export const openApiPlugin = (
|
|
|
150
124
|
return [];
|
|
151
125
|
}
|
|
152
126
|
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
if (!data) return [];
|
|
159
|
-
|
|
160
|
-
const categories = data.schema.tags
|
|
161
|
-
.filter((tag) => tag.operations.length > 0)
|
|
162
|
-
.map<SidebarItem>((tag) => ({
|
|
163
|
-
type: "category",
|
|
164
|
-
label: tag.name || "Other endpoints",
|
|
165
|
-
collapsible: true,
|
|
166
|
-
collapsed: false,
|
|
167
|
-
items: tag.operations.map((operation) => ({
|
|
168
|
-
type: "link",
|
|
169
|
-
label: operation.summary ?? operation.path,
|
|
170
|
-
href: `#${operation.slug}`,
|
|
171
|
-
badge: {
|
|
172
|
-
label: operation.method,
|
|
173
|
-
color: MethodColorMap[operation.method.toLowerCase()]!,
|
|
174
|
-
},
|
|
175
|
-
})),
|
|
176
|
-
}));
|
|
127
|
+
try {
|
|
128
|
+
const data = await client.fetch(GetCategoriesQuery, {
|
|
129
|
+
type: config.type,
|
|
130
|
+
input: config.input,
|
|
131
|
+
});
|
|
177
132
|
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
133
|
+
const categories = data.schema.tags
|
|
134
|
+
.filter((tag) => tag.operations.length > 0)
|
|
135
|
+
.map<SidebarItem>((tag) => ({
|
|
136
|
+
type: "category",
|
|
137
|
+
label: tag.name || "Other endpoints",
|
|
138
|
+
collapsible: true,
|
|
139
|
+
collapsed: false,
|
|
140
|
+
items: tag.operations.map((operation) => ({
|
|
141
|
+
type: "link",
|
|
142
|
+
label: operation.summary ?? operation.path,
|
|
143
|
+
href: `#${operation.slug}`,
|
|
144
|
+
badge: {
|
|
145
|
+
label: operation.method,
|
|
146
|
+
color: MethodColorMap[operation.method.toLowerCase()]!,
|
|
147
|
+
},
|
|
148
|
+
})),
|
|
149
|
+
}));
|
|
150
|
+
|
|
151
|
+
categories.unshift({
|
|
152
|
+
type: "link",
|
|
153
|
+
label: "Overview",
|
|
154
|
+
href: "#description",
|
|
155
|
+
});
|
|
183
156
|
|
|
184
|
-
|
|
157
|
+
return categories;
|
|
158
|
+
} catch {
|
|
159
|
+
return [];
|
|
160
|
+
}
|
|
185
161
|
},
|
|
186
162
|
getRoutes: () =>
|
|
187
163
|
[
|
|
@@ -192,7 +168,6 @@ export const openApiPlugin = (
|
|
|
192
168
|
element: <OpenApiRoute client={client} config={config} />,
|
|
193
169
|
};
|
|
194
170
|
},
|
|
195
|
-
errorElement: <OpenApiErrorPage />,
|
|
196
171
|
children: [
|
|
197
172
|
{
|
|
198
173
|
path: basePath,
|
|
@@ -0,0 +1,144 @@
|
|
|
1
|
+
import { describe, expect, it } from "vitest";
|
|
2
|
+
import { removeExtensions } from "./removeExtensions.js";
|
|
3
|
+
|
|
4
|
+
const baseDoc = {
|
|
5
|
+
openapi: "3.1.0",
|
|
6
|
+
"x-root-ext": "remove me",
|
|
7
|
+
info: {
|
|
8
|
+
title: "Test API",
|
|
9
|
+
version: "1.0.0",
|
|
10
|
+
"x-info-ext": "remove me",
|
|
11
|
+
},
|
|
12
|
+
paths: {
|
|
13
|
+
"/test": {
|
|
14
|
+
"x-path-ext": "remove me",
|
|
15
|
+
parameters: [
|
|
16
|
+
{
|
|
17
|
+
name: "param1",
|
|
18
|
+
in: "query",
|
|
19
|
+
schema: { type: "string" },
|
|
20
|
+
"x-param-ext": "remove me",
|
|
21
|
+
},
|
|
22
|
+
],
|
|
23
|
+
get: {
|
|
24
|
+
"x-operation-ext": "remove me",
|
|
25
|
+
responses: {
|
|
26
|
+
"200": {
|
|
27
|
+
description: "OK",
|
|
28
|
+
"x-response-ext": "remove me",
|
|
29
|
+
},
|
|
30
|
+
},
|
|
31
|
+
parameters: [
|
|
32
|
+
{
|
|
33
|
+
name: "opParam1",
|
|
34
|
+
in: "header",
|
|
35
|
+
schema: { type: "string" },
|
|
36
|
+
"x-op-param-ext": "remove me",
|
|
37
|
+
},
|
|
38
|
+
],
|
|
39
|
+
},
|
|
40
|
+
},
|
|
41
|
+
},
|
|
42
|
+
tags: [
|
|
43
|
+
{
|
|
44
|
+
name: "example",
|
|
45
|
+
"x-tag-ext": "remove me",
|
|
46
|
+
},
|
|
47
|
+
],
|
|
48
|
+
components: {
|
|
49
|
+
securitySchemes: {
|
|
50
|
+
ApiKeyAuth: {
|
|
51
|
+
type: "apiKey",
|
|
52
|
+
name: "api_key",
|
|
53
|
+
in: "header",
|
|
54
|
+
"x-security-ext": "remove me",
|
|
55
|
+
},
|
|
56
|
+
},
|
|
57
|
+
},
|
|
58
|
+
};
|
|
59
|
+
|
|
60
|
+
describe("removeExtensions", () => {
|
|
61
|
+
it("removes all x- extensions by default", () => {
|
|
62
|
+
const processed = removeExtensions()(baseDoc);
|
|
63
|
+
|
|
64
|
+
const removedExtensions = [
|
|
65
|
+
"x-root-ext",
|
|
66
|
+
"info.x-info-ext",
|
|
67
|
+
"paths./test.x-path-ext",
|
|
68
|
+
"paths./test.parameters[0].x-param-ext",
|
|
69
|
+
"paths./test.get.x-operation-ext",
|
|
70
|
+
"paths./test.get.responses.200.x-response-ext",
|
|
71
|
+
"paths./test.get.parameters[0].x-op-param-ext",
|
|
72
|
+
"tags[0].x-tag-ext",
|
|
73
|
+
"components.securitySchemes.ApiKeyAuth.x-security-ext",
|
|
74
|
+
];
|
|
75
|
+
|
|
76
|
+
removedExtensions.forEach((ext) => {
|
|
77
|
+
expect(processed).not.toHaveProperty(ext.split("."));
|
|
78
|
+
});
|
|
79
|
+
|
|
80
|
+
// Assert that non-x- fields remain unchanged
|
|
81
|
+
expect(processed.openapi).toBe("3.1.0");
|
|
82
|
+
expect(processed.info.title).toBe("Test API");
|
|
83
|
+
expect(processed).toHaveProperty(
|
|
84
|
+
["paths", "/test", "get", "responses", "200", "description"],
|
|
85
|
+
"OK",
|
|
86
|
+
);
|
|
87
|
+
expect(processed.tags[0].name).toBe("example");
|
|
88
|
+
});
|
|
89
|
+
|
|
90
|
+
it("removes only specified x- extensions when names are provided", () => {
|
|
91
|
+
const docWithExtraExtensions = {
|
|
92
|
+
...baseDoc,
|
|
93
|
+
info: { ...baseDoc.info, "x-other-ext": "keep me" },
|
|
94
|
+
};
|
|
95
|
+
|
|
96
|
+
const processed = removeExtensions({
|
|
97
|
+
keys: ["x-path-ext", "x-param-ext"],
|
|
98
|
+
})(docWithExtraExtensions);
|
|
99
|
+
|
|
100
|
+
// Assert specified extensions are removed
|
|
101
|
+
expect(processed.paths["/test"]["x-path-ext"]).toBeUndefined();
|
|
102
|
+
expect(
|
|
103
|
+
processed.paths["/test"].parameters[0]["x-param-ext"],
|
|
104
|
+
).toBeUndefined();
|
|
105
|
+
|
|
106
|
+
// Assert other x- fields remain
|
|
107
|
+
expect(processed["x-root-ext"]).toBe("remove me");
|
|
108
|
+
expect(processed.info["x-info-ext"]).toBe("remove me");
|
|
109
|
+
expect(processed.info["x-other-ext"]).toBe("keep me");
|
|
110
|
+
});
|
|
111
|
+
|
|
112
|
+
it("handles deeply nested extensions", () => {
|
|
113
|
+
const deeplyNested = {
|
|
114
|
+
a: {
|
|
115
|
+
b: {
|
|
116
|
+
c: {
|
|
117
|
+
"x-deep-ext": "remove me",
|
|
118
|
+
d: {
|
|
119
|
+
e: "value",
|
|
120
|
+
"x-another-ext": "remove me",
|
|
121
|
+
},
|
|
122
|
+
},
|
|
123
|
+
},
|
|
124
|
+
},
|
|
125
|
+
};
|
|
126
|
+
|
|
127
|
+
const processed = removeExtensions()(deeplyNested);
|
|
128
|
+
|
|
129
|
+
expect(processed.a.b.c["x-deep-ext"]).toBeUndefined();
|
|
130
|
+
expect(processed.a.b.c.d["x-another-ext"]).toBeUndefined();
|
|
131
|
+
expect(processed.a.b.c.d.e).toBe("value");
|
|
132
|
+
});
|
|
133
|
+
|
|
134
|
+
it("does nothing if no x- extensions are present", () => {
|
|
135
|
+
const docWithoutExtensions = {
|
|
136
|
+
openapi: "3.1.0",
|
|
137
|
+
info: { title: "API without extensions" },
|
|
138
|
+
};
|
|
139
|
+
|
|
140
|
+
const processed = removeExtensions()(docWithoutExtensions);
|
|
141
|
+
|
|
142
|
+
expect(processed).toEqual(docWithoutExtensions);
|
|
143
|
+
});
|
|
144
|
+
});
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { type RecordAny, traverse } from "./traverse.js";
|
|
2
|
+
|
|
3
|
+
interface RemoveExtensionsOptions {
|
|
4
|
+
keys?: string[];
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
// Remove all `x-` prefixed key/value pairs, or filter by names if provided
|
|
8
|
+
export const removeExtensions =
|
|
9
|
+
({ keys }: RemoveExtensionsOptions = {}) =>
|
|
10
|
+
(doc: RecordAny): RecordAny =>
|
|
11
|
+
traverse(doc, (spec) => {
|
|
12
|
+
const result: RecordAny = {};
|
|
13
|
+
|
|
14
|
+
for (const [key, value] of Object.entries(spec)) {
|
|
15
|
+
const isExtension = key.startsWith("x-");
|
|
16
|
+
const shouldRemove =
|
|
17
|
+
isExtension && (keys === undefined || keys.includes(key));
|
|
18
|
+
|
|
19
|
+
if (shouldRemove) continue;
|
|
20
|
+
|
|
21
|
+
result[key] = value;
|
|
22
|
+
}
|
|
23
|
+
return result;
|
|
24
|
+
});
|
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
import { describe, expect, it } from "vitest";
|
|
2
|
+
import { removePaths } from "./removePaths.js";
|
|
3
|
+
|
|
4
|
+
const baseDoc = {
|
|
5
|
+
openapi: "3.0.3",
|
|
6
|
+
paths: {
|
|
7
|
+
"/example": {
|
|
8
|
+
get: { summary: "Get example" },
|
|
9
|
+
post: { summary: "Post example" },
|
|
10
|
+
},
|
|
11
|
+
"/remove-me": {
|
|
12
|
+
delete: { summary: "Delete example" },
|
|
13
|
+
},
|
|
14
|
+
"/another": {
|
|
15
|
+
get: { summary: "Another example" },
|
|
16
|
+
},
|
|
17
|
+
},
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
describe("removePaths", () => {
|
|
21
|
+
it("removes paths specified in the paths option", () => {
|
|
22
|
+
const processed = removePaths({
|
|
23
|
+
paths: {
|
|
24
|
+
"/remove-me": true,
|
|
25
|
+
},
|
|
26
|
+
})(baseDoc);
|
|
27
|
+
|
|
28
|
+
expect(processed.paths["/remove-me"]).toBeUndefined();
|
|
29
|
+
expect(processed.paths["/example"]).toBeDefined();
|
|
30
|
+
expect(processed.paths["/another"]).toBeDefined();
|
|
31
|
+
});
|
|
32
|
+
|
|
33
|
+
it("removes specific methods in the paths option", () => {
|
|
34
|
+
const processed = removePaths({
|
|
35
|
+
paths: {
|
|
36
|
+
"/example": ["get"],
|
|
37
|
+
},
|
|
38
|
+
})(baseDoc);
|
|
39
|
+
|
|
40
|
+
expect(processed.paths["/example"].get).toBeUndefined();
|
|
41
|
+
expect(processed.paths["/example"].post).toBeDefined();
|
|
42
|
+
expect(processed.paths["/remove-me"]).toBeDefined();
|
|
43
|
+
});
|
|
44
|
+
|
|
45
|
+
it("removes paths and methods using paths and shouldRemove together", () => {
|
|
46
|
+
const processed = removePaths({
|
|
47
|
+
paths: {
|
|
48
|
+
"/example": ["post"],
|
|
49
|
+
},
|
|
50
|
+
shouldRemove: ({ path }) => path.startsWith("/remove"),
|
|
51
|
+
})(baseDoc);
|
|
52
|
+
|
|
53
|
+
expect(processed.paths["/remove-me"]).toBeUndefined();
|
|
54
|
+
expect(processed.paths["/example"].get).toBeDefined();
|
|
55
|
+
expect(processed.paths["/example"].post).toBeUndefined();
|
|
56
|
+
expect(processed.paths["/another"]).toBeDefined();
|
|
57
|
+
});
|
|
58
|
+
|
|
59
|
+
it("removes paths based on shouldRemove callback", () => {
|
|
60
|
+
const processed = removePaths({
|
|
61
|
+
shouldRemove: ({ path }) => path.startsWith("/remove"),
|
|
62
|
+
})(baseDoc);
|
|
63
|
+
|
|
64
|
+
expect(processed.paths["/remove-me"]).toBeUndefined();
|
|
65
|
+
expect(processed.paths["/example"]).toBeDefined();
|
|
66
|
+
expect(processed.paths["/another"]).toBeDefined();
|
|
67
|
+
});
|
|
68
|
+
|
|
69
|
+
it("removes methods based on shouldRemove callback", () => {
|
|
70
|
+
const processed = removePaths({
|
|
71
|
+
shouldRemove: ({ method }) => method === "post",
|
|
72
|
+
})(baseDoc);
|
|
73
|
+
|
|
74
|
+
expect(processed.paths["/example"].post).toBeUndefined();
|
|
75
|
+
expect(processed.paths["/example"].get).toBeDefined();
|
|
76
|
+
expect(processed.paths["/remove-me"]).toBeDefined();
|
|
77
|
+
});
|
|
78
|
+
|
|
79
|
+
it("removes both paths and methods based on shouldRemove callback", () => {
|
|
80
|
+
const processed = removePaths({
|
|
81
|
+
shouldRemove: ({ path, method }) =>
|
|
82
|
+
path.startsWith("/remove") || method === "post",
|
|
83
|
+
})(baseDoc);
|
|
84
|
+
|
|
85
|
+
expect(processed.paths["/remove-me"]).toBeUndefined();
|
|
86
|
+
expect(processed.paths["/example"].post).toBeUndefined();
|
|
87
|
+
expect(processed.paths["/example"].get).toBeDefined();
|
|
88
|
+
expect(processed.paths["/another"]).toBeDefined();
|
|
89
|
+
});
|
|
90
|
+
|
|
91
|
+
it("does nothing if shouldRemove always returns false", () => {
|
|
92
|
+
const processed = removePaths({
|
|
93
|
+
shouldRemove: () => false,
|
|
94
|
+
})(baseDoc);
|
|
95
|
+
|
|
96
|
+
expect(processed).toEqual(baseDoc);
|
|
97
|
+
});
|
|
98
|
+
|
|
99
|
+
it("removes everything if shouldRemove always returns true", () => {
|
|
100
|
+
const processed = removePaths({
|
|
101
|
+
shouldRemove: () => true,
|
|
102
|
+
})(baseDoc);
|
|
103
|
+
|
|
104
|
+
expect(processed.paths).toEqual({});
|
|
105
|
+
});
|
|
106
|
+
|
|
107
|
+
it("removes entire paths via shouldRemove callback", () => {
|
|
108
|
+
const processed = removePaths({
|
|
109
|
+
shouldRemove: ({ path, method }) =>
|
|
110
|
+
method === true && path === "/remove-me",
|
|
111
|
+
})(baseDoc);
|
|
112
|
+
|
|
113
|
+
expect(processed.paths["/remove-me"]).toBeUndefined();
|
|
114
|
+
expect(processed.paths["/example"]).toBeDefined();
|
|
115
|
+
expect(processed.paths["/another"]).toBeDefined();
|
|
116
|
+
});
|
|
117
|
+
|
|
118
|
+
it("removes specific methods while keeping paths", () => {
|
|
119
|
+
const processed = removePaths({
|
|
120
|
+
shouldRemove: ({ method }) => method === "delete",
|
|
121
|
+
})(baseDoc);
|
|
122
|
+
|
|
123
|
+
expect(processed.paths["/remove-me"]).toBeDefined();
|
|
124
|
+
expect(processed.paths["/remove-me"].delete).toBeUndefined();
|
|
125
|
+
});
|
|
126
|
+
});
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { type RecordAny, traverse } from "./traverse.js";
|
|
2
|
+
|
|
3
|
+
interface RemovePathsOptions {
|
|
4
|
+
// Path definitions, e.g., { '/path': true, '/path-2': ['get'] }
|
|
5
|
+
paths?: Record<string, true | string[]>;
|
|
6
|
+
shouldRemove?: (options: {
|
|
7
|
+
path: string;
|
|
8
|
+
method: true | string;
|
|
9
|
+
operation: RecordAny;
|
|
10
|
+
}) => boolean;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
export const removePaths =
|
|
14
|
+
({ paths = {}, shouldRemove }: RemovePathsOptions) =>
|
|
15
|
+
(doc: RecordAny): RecordAny =>
|
|
16
|
+
traverse(doc, (spec) => {
|
|
17
|
+
if (!spec.paths) return spec;
|
|
18
|
+
|
|
19
|
+
const updatedPaths: RecordAny = {};
|
|
20
|
+
|
|
21
|
+
for (const [path, methods] of Object.entries(spec.paths)) {
|
|
22
|
+
const operations = spec.paths[path];
|
|
23
|
+
|
|
24
|
+
// If the path is explicitly marked for removal in `paths`
|
|
25
|
+
if (paths[path] === true) continue;
|
|
26
|
+
|
|
27
|
+
// If the path should be removed via `shouldRemove`
|
|
28
|
+
if (shouldRemove?.({ path, method: true, operation: operations }))
|
|
29
|
+
continue;
|
|
30
|
+
|
|
31
|
+
if (typeof methods === "object" && methods !== null) {
|
|
32
|
+
const filteredPath = Object.fromEntries(
|
|
33
|
+
Object.entries(methods).filter(([method]) => {
|
|
34
|
+
const operations = spec.paths[path][method];
|
|
35
|
+
const isMethodToRemove =
|
|
36
|
+
Array.isArray(paths[path]) && paths[path].includes(method);
|
|
37
|
+
|
|
38
|
+
const isMethodFiltered = shouldRemove?.({
|
|
39
|
+
path,
|
|
40
|
+
method,
|
|
41
|
+
operation: operations,
|
|
42
|
+
});
|
|
43
|
+
|
|
44
|
+
return !isMethodToRemove && !isMethodFiltered;
|
|
45
|
+
}),
|
|
46
|
+
);
|
|
47
|
+
|
|
48
|
+
updatedPaths[path] = filteredPath;
|
|
49
|
+
} else {
|
|
50
|
+
updatedPaths[path] = methods;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
return { ...spec, paths: updatedPaths };
|
|
55
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { traverse, type RecordAny } from "../../../util/traverse.js";
|
|
@@ -67,10 +67,13 @@ export const SchemaView = ({
|
|
|
67
67
|
}
|
|
68
68
|
}
|
|
69
69
|
|
|
70
|
-
if (
|
|
70
|
+
if (
|
|
71
|
+
schema.type === "object" &&
|
|
72
|
+
(!schema.properties || Object.keys(schema.properties).length === 0)
|
|
73
|
+
) {
|
|
71
74
|
return (
|
|
72
75
|
<Card className="p-4 flex gap-2 items-center">
|
|
73
|
-
{"name" in schema && <>{schema.name}</>}
|
|
76
|
+
{"name" in schema && <>{schema.name as string}</>}
|
|
74
77
|
<span className="text-sm text-muted-foreground">object</span>
|
|
75
78
|
{schema.description && (
|
|
76
79
|
<Markdown
|
|
@@ -1,72 +1,58 @@
|
|
|
1
|
-
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
2
1
|
import { type SchemaObject } from "../../../oas/graphql/index.js";
|
|
3
2
|
|
|
4
|
-
export const isObject = (value: unknown): boolean =>
|
|
5
|
-
typeof value === "object" && value !== null && !Array.isArray(value);
|
|
6
|
-
|
|
7
3
|
export const generateSchemaExample = (
|
|
8
4
|
schema: SchemaObject,
|
|
9
5
|
name?: string,
|
|
6
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
10
7
|
): any => {
|
|
11
8
|
// Directly return the example or default if they exist
|
|
12
9
|
if (schema.example !== undefined) {
|
|
13
10
|
return schema.example;
|
|
11
|
+
} else if (schema.examples) {
|
|
12
|
+
return Object.values(schema.examples)[0];
|
|
14
13
|
} else if (schema.default !== undefined) {
|
|
15
14
|
return schema.default;
|
|
16
15
|
}
|
|
17
16
|
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
// Recursively process objects and arrays
|
|
24
|
-
return processComplexTypes(schema, name);
|
|
25
|
-
};
|
|
17
|
+
if (schema.properties || schema.type === "object") {
|
|
18
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
19
|
+
const example: any = {};
|
|
26
20
|
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
);
|
|
31
|
-
if (schema.type === "object" && properties.length > 0) {
|
|
32
|
-
const obj: { [key: string]: any } = {};
|
|
33
|
-
properties.forEach(([key, propSchema]) => {
|
|
34
|
-
const value = generateSchemaExample(propSchema, key);
|
|
35
|
-
if (value !== undefined) {
|
|
36
|
-
obj[key] = value;
|
|
21
|
+
if (schema.properties) {
|
|
22
|
+
for (const [key, propSchema] of Object.entries(schema.properties)) {
|
|
23
|
+
example[key] = generateSchemaExample(propSchema as SchemaObject, key);
|
|
37
24
|
}
|
|
38
|
-
}
|
|
39
|
-
return
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
25
|
+
}
|
|
26
|
+
return example;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
if (schema.type === "array") {
|
|
30
|
+
if (Array.isArray(schema.items)) {
|
|
31
|
+
return schema.items.map((itemSchema) =>
|
|
32
|
+
generateSchemaExample(itemSchema as SchemaObject),
|
|
33
|
+
);
|
|
34
|
+
} else if (schema.items) {
|
|
35
|
+
return [generateSchemaExample(schema.items as SchemaObject)];
|
|
44
36
|
}
|
|
45
37
|
return [];
|
|
46
38
|
}
|
|
47
|
-
// Fallback for missing or undefined types
|
|
48
|
-
return undefined; //getDefaultForType(schema.type);
|
|
49
|
-
}
|
|
50
39
|
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
return getDefaultForSingleType(type[0]);
|
|
40
|
+
if (schema.enum) {
|
|
41
|
+
return schema.enum[0];
|
|
54
42
|
}
|
|
55
|
-
return getDefaultForSingleType(type);
|
|
56
|
-
}
|
|
57
43
|
|
|
58
|
-
|
|
59
|
-
switch (type) {
|
|
44
|
+
switch (schema.type) {
|
|
60
45
|
case "string":
|
|
61
|
-
return "";
|
|
46
|
+
return name || "string";
|
|
62
47
|
case "number":
|
|
63
48
|
case "integer":
|
|
64
49
|
return 0;
|
|
65
50
|
case "boolean":
|
|
66
|
-
return
|
|
51
|
+
return true;
|
|
67
52
|
case "null":
|
|
68
53
|
return null;
|
|
54
|
+
case undefined:
|
|
69
55
|
default:
|
|
70
|
-
return
|
|
56
|
+
return {};
|
|
71
57
|
}
|
|
72
|
-
}
|
|
58
|
+
};
|
|
@@ -1 +1,11 @@
|
|
|
1
|
-
export
|
|
1
|
+
export const initializeWorker = () => {
|
|
2
|
+
const worker = new SharedWorker(
|
|
3
|
+
new URL("./openapi/client/worker.ts", import.meta.url),
|
|
4
|
+
{ type: "module" },
|
|
5
|
+
);
|
|
6
|
+
// eslint-disable-next-line no-console
|
|
7
|
+
worker.onerror = (e) => console.error(e);
|
|
8
|
+
worker.port.start();
|
|
9
|
+
|
|
10
|
+
return worker;
|
|
11
|
+
};
|