@sanity/cli 5.9.0-next.8 → 6.0.0-alpha.11
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/LICENSE +1 -1
- package/README.md +3212 -2
- package/bin/run.cmd +3 -0
- package/bin/run.js +33 -0
- package/codemods/deskRename.js +115 -96
- package/codemods/partsTypeDirective.js +7 -7
- package/codemods/reactIconsV3.js +78 -51
- package/dist/SanityHelp.js +43 -0
- package/dist/SanityHelp.js.map +1 -0
- package/dist/actions/auth/authServer.js +153 -0
- package/dist/actions/auth/authServer.js.map +1 -0
- package/dist/actions/auth/getProviderName.js +15 -0
- package/dist/actions/auth/getProviderName.js.map +1 -0
- package/dist/actions/auth/login/getProvider.js +54 -0
- package/dist/actions/auth/login/getProvider.js.map +1 -0
- package/dist/actions/auth/login/getSSOProvider.js +30 -0
- package/dist/actions/auth/login/getSSOProvider.js.map +1 -0
- package/dist/actions/auth/login/login.js +101 -0
- package/dist/actions/auth/login/login.js.map +1 -0
- package/dist/actions/auth/login/promptProviders.js +23 -0
- package/dist/actions/auth/login/promptProviders.js.map +1 -0
- package/dist/actions/auth/login/samlProviderToLoginProvider.js +15 -0
- package/dist/actions/auth/login/samlProviderToLoginProvider.js.map +1 -0
- package/dist/actions/auth/types.js +7 -0
- package/dist/actions/auth/types.js.map +1 -0
- package/dist/actions/backup/archiveDir.js +43 -0
- package/dist/actions/backup/archiveDir.js.map +1 -0
- package/dist/actions/backup/assertDatasetExist.js +16 -0
- package/dist/actions/backup/assertDatasetExist.js.map +1 -0
- package/dist/actions/backup/backupDownloadDebug.js +4 -0
- package/dist/actions/backup/backupDownloadDebug.js.map +1 -0
- package/dist/actions/backup/cleanupTmpDir.js +19 -0
- package/dist/actions/backup/cleanupTmpDir.js.map +1 -0
- package/dist/actions/backup/constants.js +3 -0
- package/dist/actions/backup/constants.js.map +1 -0
- package/dist/actions/backup/downloadAsset.js +54 -0
- package/dist/actions/backup/downloadAsset.js.map +1 -0
- package/dist/actions/backup/downloadDocument.js +32 -0
- package/dist/actions/backup/downloadDocument.js.map +1 -0
- package/dist/actions/backup/fetchNextBackupPage.js +48 -0
- package/dist/actions/backup/fetchNextBackupPage.js.map +1 -0
- package/dist/actions/backup/progressSpinner.js +40 -0
- package/dist/actions/backup/progressSpinner.js.map +1 -0
- package/dist/actions/build/buildApp.js +159 -0
- package/dist/actions/build/buildApp.js.map +1 -0
- package/dist/actions/build/buildDebug.js +4 -0
- package/dist/actions/build/buildDebug.js.map +1 -0
- package/dist/actions/build/buildStaticFiles.js +82 -0
- package/dist/actions/build/buildStaticFiles.js.map +1 -0
- package/dist/actions/build/buildStudio.js +202 -0
- package/dist/actions/build/buildStudio.js.map +1 -0
- package/dist/actions/build/buildVendorDependencies.js +179 -0
- package/dist/actions/build/buildVendorDependencies.js.map +1 -0
- package/dist/actions/build/checkRequiredDependencies.js +122 -0
- package/dist/actions/build/checkRequiredDependencies.js.map +1 -0
- package/dist/actions/build/checkStudioDependencyVersions.js +154 -0
- package/dist/actions/build/checkStudioDependencyVersions.js.map +1 -0
- package/dist/actions/build/createExternalFromImportMap.js +11 -0
- package/dist/actions/build/createExternalFromImportMap.js.map +1 -0
- package/dist/actions/build/decorateIndexWithAutoGeneratedWarning.js +13 -0
- package/dist/actions/build/decorateIndexWithAutoGeneratedWarning.js.map +1 -0
- package/dist/actions/build/decorateIndexWithBridgeScript.js +17 -0
- package/dist/actions/build/decorateIndexWithBridgeScript.js.map +1 -0
- package/dist/actions/build/determineBasePath.js +20 -0
- package/dist/actions/build/determineBasePath.js.map +1 -0
- package/dist/actions/build/generateWebManifest.js +27 -0
- package/dist/actions/build/generateWebManifest.js.map +1 -0
- package/dist/actions/build/getAppEnvVars.js +9 -0
- package/dist/actions/build/getAppEnvVars.js.map +1 -0
- package/dist/actions/build/getAutoUpdatesImportMap.js +57 -0
- package/dist/actions/build/getAutoUpdatesImportMap.js.map +1 -0
- package/dist/actions/build/getEntryModule.js +46 -0
- package/dist/actions/build/getEntryModule.js.map +1 -0
- package/dist/actions/build/getPossibleDocumentComponentLocations.js +11 -0
- package/dist/actions/build/getPossibleDocumentComponentLocations.js.map +1 -0
- package/dist/actions/build/getStudioEnvVars.js +9 -0
- package/dist/actions/build/getStudioEnvVars.js.map +1 -0
- package/dist/actions/build/getStudioEnvironmentVariables.js +58 -0
- package/dist/actions/build/getStudioEnvironmentVariables.js.map +1 -0
- package/dist/actions/build/getViteConfig.js +180 -0
- package/dist/actions/build/getViteConfig.js.map +1 -0
- package/dist/actions/build/normalizeBasePath.js +9 -0
- package/dist/actions/build/normalizeBasePath.js.map +1 -0
- package/dist/actions/build/renderDocument.js +54 -0
- package/dist/actions/build/renderDocument.js.map +1 -0
- package/dist/actions/build/renderDocument.worker.js +9 -0
- package/dist/actions/build/renderDocument.worker.js.map +1 -0
- package/dist/actions/build/renderDocumentWorker/addTimestampImportMapScriptToHtml.js +59 -0
- package/dist/actions/build/renderDocumentWorker/addTimestampImportMapScriptToHtml.js.map +1 -0
- package/dist/actions/build/renderDocumentWorker/components/BasicDocument.js +61 -0
- package/dist/actions/build/renderDocumentWorker/components/BasicDocument.js.map +1 -0
- package/dist/actions/build/renderDocumentWorker/components/DefaultDocument.js +165 -0
- package/dist/actions/build/renderDocumentWorker/components/DefaultDocument.js.map +1 -0
- package/dist/actions/build/renderDocumentWorker/components/Favicons.js +28 -0
- package/dist/actions/build/renderDocumentWorker/components/Favicons.js.map +1 -0
- package/dist/actions/build/renderDocumentWorker/components/GlobalErrorHandler.js +177 -0
- package/dist/actions/build/renderDocumentWorker/components/GlobalErrorHandler.js.map +1 -0
- package/dist/actions/build/renderDocumentWorker/components/NoJavascript.js +51 -0
- package/dist/actions/build/renderDocumentWorker/components/NoJavascript.js.map +1 -0
- package/dist/actions/build/renderDocumentWorker/getDocumentComponent.js +41 -0
- package/dist/actions/build/renderDocumentWorker/getDocumentComponent.js.map +1 -0
- package/dist/actions/build/renderDocumentWorker/getDocumentHtml.js +55 -0
- package/dist/actions/build/renderDocumentWorker/getDocumentHtml.js.map +1 -0
- package/dist/actions/build/renderDocumentWorker/renderDocumentWorker.js +31 -0
- package/dist/actions/build/renderDocumentWorker/renderDocumentWorker.js.map +1 -0
- package/dist/actions/build/renderDocumentWorker/tryLoadDocumentComponent.js +30 -0
- package/dist/actions/build/renderDocumentWorker/tryLoadDocumentComponent.js.map +1 -0
- package/dist/actions/build/renderDocumentWorker/types.js +5 -0
- package/dist/actions/build/renderDocumentWorker/types.js.map +1 -0
- package/dist/actions/build/shouldAutoUpdate.js +35 -0
- package/dist/actions/build/shouldAutoUpdate.js.map +1 -0
- package/dist/actions/build/types.js +3 -0
- package/dist/actions/build/types.js.map +1 -0
- package/dist/actions/build/writeFavicons.js +26 -0
- package/dist/actions/build/writeFavicons.js.map +1 -0
- package/dist/actions/build/writeSanityRuntime.js +61 -0
- package/dist/actions/build/writeSanityRuntime.js.map +1 -0
- package/dist/actions/build/writeWebManifest.js +12 -0
- package/dist/actions/build/writeWebManifest.js.map +1 -0
- package/dist/actions/codemods/deskRename.js +18 -0
- package/dist/actions/codemods/deskRename.js.map +1 -0
- package/dist/actions/codemods/index.js +10 -0
- package/dist/actions/codemods/index.js.map +1 -0
- package/dist/actions/codemods/partsTypeDirective.js +27 -0
- package/dist/actions/codemods/partsTypeDirective.js.map +1 -0
- package/dist/actions/codemods/reactIconsV3.js +30 -0
- package/dist/actions/codemods/reactIconsV3.js.map +1 -0
- package/dist/actions/codemods/types.js +3 -0
- package/dist/actions/codemods/types.js.map +1 -0
- package/dist/actions/cors/filterAndValidateOrigin.js +38 -0
- package/dist/actions/cors/filterAndValidateOrigin.js.map +1 -0
- package/dist/actions/dataset/create.js +46 -0
- package/dist/actions/dataset/create.js.map +1 -0
- package/dist/actions/dataset/determineDatasetAclMode.js +36 -0
- package/dist/actions/dataset/determineDatasetAclMode.js.map +1 -0
- package/dist/actions/dataset/processAliasName.js +20 -0
- package/dist/actions/dataset/processAliasName.js.map +1 -0
- package/dist/actions/dataset/validateDatasetAliasName.js +28 -0
- package/dist/actions/dataset/validateDatasetAliasName.js.map +1 -0
- package/dist/actions/dataset/validateDatasetName.js +39 -0
- package/dist/actions/dataset/validateDatasetName.js.map +1 -0
- package/dist/actions/debug/gatherDebugInfo.js +104 -0
- package/dist/actions/debug/gatherDebugInfo.js.map +1 -0
- package/dist/actions/debug/getGlobalConfigLocation.js +7 -0
- package/dist/actions/debug/getGlobalConfigLocation.js.map +1 -0
- package/dist/actions/debug/types.js +3 -0
- package/dist/actions/debug/types.js.map +1 -0
- package/dist/actions/deploy/checkDir.js +31 -0
- package/dist/actions/deploy/checkDir.js.map +1 -0
- package/dist/actions/deploy/createStudioUserApplication.js +59 -0
- package/dist/actions/deploy/createStudioUserApplication.js.map +1 -0
- package/dist/actions/deploy/createUserApplicationForApp.js +56 -0
- package/dist/actions/deploy/createUserApplicationForApp.js.map +1 -0
- package/dist/actions/deploy/deployApp.js +162 -0
- package/dist/actions/deploy/deployApp.js.map +1 -0
- package/dist/actions/deploy/deployDebug.js +4 -0
- package/dist/actions/deploy/deployDebug.js.map +1 -0
- package/dist/actions/deploy/deployStudio.js +134 -0
- package/dist/actions/deploy/deployStudio.js.map +1 -0
- package/dist/actions/deploy/findUserApplicationForApp.js +110 -0
- package/dist/actions/deploy/findUserApplicationForApp.js.map +1 -0
- package/dist/actions/deploy/findUserApplicationForStudio.js +143 -0
- package/dist/actions/deploy/findUserApplicationForStudio.js.map +1 -0
- package/dist/actions/deploy/types.js +3 -0
- package/dist/actions/deploy/types.js.map +1 -0
- package/dist/actions/dev/devAction.js +7 -0
- package/dist/actions/dev/devAction.js.map +1 -0
- package/dist/actions/dev/devDebug.js +4 -0
- package/dist/actions/dev/devDebug.js.map +1 -0
- package/dist/actions/dev/getCoreAppUrl.js +10 -0
- package/dist/actions/dev/getCoreAppUrl.js.map +1 -0
- package/dist/actions/dev/getDevServerConfig.js +28 -0
- package/dist/actions/dev/getDevServerConfig.js.map +1 -0
- package/dist/actions/dev/startAppDevServer.js +57 -0
- package/dist/actions/dev/startAppDevServer.js.map +1 -0
- package/dist/actions/dev/startStudioDevServer.js +154 -0
- package/dist/actions/dev/startStudioDevServer.js.map +1 -0
- package/dist/actions/dev/types.js +3 -0
- package/dist/actions/dev/types.js.map +1 -0
- package/dist/actions/docs/normalizeDocsPath.js +15 -0
- package/dist/actions/docs/normalizeDocsPath.js.map +1 -0
- package/dist/actions/documents/constants.js +3 -0
- package/dist/actions/documents/constants.js.map +1 -0
- package/dist/actions/documents/editor.js +26 -0
- package/dist/actions/documents/editor.js.map +1 -0
- package/dist/actions/documents/types.js +3 -0
- package/dist/actions/documents/types.js.map +1 -0
- package/dist/actions/documents/validate.js +60 -0
- package/dist/actions/documents/validate.js.map +1 -0
- package/dist/actions/documents/validateDocuments.worker.js +251 -0
- package/dist/actions/documents/validateDocuments.worker.js.map +1 -0
- package/dist/actions/documents/validation/reporters/index.js +10 -0
- package/dist/actions/documents/validation/reporters/index.js.map +1 -0
- package/dist/actions/documents/validation/reporters/jsonReporter.js +25 -0
- package/dist/actions/documents/validation/reporters/jsonReporter.js.map +1 -0
- package/dist/actions/documents/validation/reporters/ndjsonReporter.js +18 -0
- package/dist/actions/documents/validation/reporters/ndjsonReporter.js.map +1 -0
- package/dist/actions/documents/validation/reporters/prettyReporter/formatDocumentValidation.js +62 -0
- package/dist/actions/documents/validation/reporters/prettyReporter/formatDocumentValidation.js.map +1 -0
- package/dist/actions/documents/validation/reporters/prettyReporter/index.js +3 -0
- package/dist/actions/documents/validation/reporters/prettyReporter/index.js.map +1 -0
- package/dist/actions/documents/validation/reporters/prettyReporter/prettyReporter.js +92 -0
- package/dist/actions/documents/validation/reporters/prettyReporter/prettyReporter.js.map +1 -0
- package/dist/actions/documents/validation/reporters/prettyReporter/util.js +45 -0
- package/dist/actions/documents/validation/reporters/prettyReporter/util.js.map +1 -0
- package/dist/actions/exec/configClient.worker.js +9 -0
- package/dist/actions/exec/configClient.worker.js.map +1 -0
- package/dist/actions/exec/execScript.js +77 -0
- package/dist/actions/exec/execScript.js.map +1 -0
- package/dist/actions/exec/registerBrowserEnv.worker.js +17 -0
- package/dist/actions/exec/registerBrowserEnv.worker.js.map +1 -0
- package/dist/actions/graphql/SchemaError.js +37 -0
- package/dist/actions/graphql/SchemaError.js.map +1 -0
- package/dist/actions/graphql/extractFromSanitySchema.js +659 -0
- package/dist/actions/graphql/extractFromSanitySchema.js.map +1 -0
- package/dist/actions/graphql/gen1/generateTypeFilters.js +226 -0
- package/dist/actions/graphql/gen1/generateTypeFilters.js.map +1 -0
- package/dist/actions/graphql/gen1/generateTypeQueries.js +85 -0
- package/dist/actions/graphql/gen1/generateTypeQueries.js.map +1 -0
- package/dist/actions/graphql/gen1/index.js +19 -0
- package/dist/actions/graphql/gen1/index.js.map +1 -0
- package/dist/actions/graphql/gen2/filters/booleanFilters.js +26 -0
- package/dist/actions/graphql/gen2/filters/booleanFilters.js.map +1 -0
- package/dist/actions/graphql/gen2/filters/dateFilters.js +46 -0
- package/dist/actions/graphql/gen2/filters/dateFilters.js.map +1 -0
- package/dist/actions/graphql/gen2/filters/dateTimeFilters.js +46 -0
- package/dist/actions/graphql/gen2/filters/dateTimeFilters.js.map +1 -0
- package/dist/actions/graphql/gen2/filters/documentFilters.js +21 -0
- package/dist/actions/graphql/gen2/filters/documentFilters.js.map +1 -0
- package/dist/actions/graphql/gen2/filters/floatFilters.js +46 -0
- package/dist/actions/graphql/gen2/filters/floatFilters.js.map +1 -0
- package/dist/actions/graphql/gen2/filters/idFilters.js +44 -0
- package/dist/actions/graphql/gen2/filters/idFilters.js.map +1 -0
- package/dist/actions/graphql/gen2/filters/integerFilters.js +46 -0
- package/dist/actions/graphql/gen2/filters/integerFilters.js.map +1 -0
- package/dist/actions/graphql/gen2/filters/stringFilters.js +49 -0
- package/dist/actions/graphql/gen2/filters/stringFilters.js.map +1 -0
- package/dist/actions/graphql/gen2/generateTypeFilters.js +85 -0
- package/dist/actions/graphql/gen2/generateTypeFilters.js.map +1 -0
- package/dist/actions/graphql/gen2/generateTypeQueries.js +107 -0
- package/dist/actions/graphql/gen2/generateTypeQueries.js.map +1 -0
- package/dist/actions/graphql/gen2/generateTypeSortings.js +70 -0
- package/dist/actions/graphql/gen2/generateTypeSortings.js.map +1 -0
- package/dist/actions/graphql/gen2/index.js +22 -0
- package/dist/actions/graphql/gen2/index.js.map +1 -0
- package/dist/actions/graphql/gen3/filters/documentFilters.js +21 -0
- package/dist/actions/graphql/gen3/filters/documentFilters.js.map +1 -0
- package/dist/actions/graphql/gen3/generateTypeFilters.js +101 -0
- package/dist/actions/graphql/gen3/generateTypeFilters.js.map +1 -0
- package/dist/actions/graphql/gen3/generateTypeQueries.js +104 -0
- package/dist/actions/graphql/gen3/generateTypeQueries.js.map +1 -0
- package/dist/actions/graphql/gen3/generateTypeSortings.js +70 -0
- package/dist/actions/graphql/gen3/generateTypeSortings.js.map +1 -0
- package/dist/actions/graphql/gen3/index.js +31 -0
- package/dist/actions/graphql/gen3/index.js.map +1 -0
- package/dist/actions/graphql/gen3/utils.js +12 -0
- package/dist/actions/graphql/gen3/utils.js.map +1 -0
- package/dist/actions/graphql/getGraphQLAPIs.js +65 -0
- package/dist/actions/graphql/getGraphQLAPIs.js.map +1 -0
- package/dist/actions/graphql/getGraphQLAPIs.worker.js +126 -0
- package/dist/actions/graphql/getGraphQLAPIs.worker.js.map +1 -0
- package/dist/actions/graphql/graphqlDebug.js +4 -0
- package/dist/actions/graphql/graphqlDebug.js.map +1 -0
- package/dist/actions/graphql/helpUrls.js +3 -0
- package/dist/actions/graphql/helpUrls.js.map +1 -0
- package/dist/actions/graphql/helpers.js +11 -0
- package/dist/actions/graphql/helpers.js.map +1 -0
- package/dist/actions/graphql/resolveApiGeneration.js +43 -0
- package/dist/actions/graphql/resolveApiGeneration.js.map +1 -0
- package/dist/actions/graphql/types.js +3 -0
- package/dist/actions/graphql/types.js.map +1 -0
- package/dist/actions/hook/constants.js +3 -0
- package/dist/actions/hook/constants.js.map +1 -0
- package/dist/actions/hook/formatFailure.js +29 -0
- package/dist/actions/hook/formatFailure.js.map +1 -0
- package/dist/actions/hook/types.js +3 -0
- package/dist/actions/hook/types.js.map +1 -0
- package/dist/actions/init/bootstrapLocalTemplate.js +137 -0
- package/dist/actions/init/bootstrapLocalTemplate.js.map +1 -0
- package/dist/actions/init/bootstrapRemoteTemplate.js +109 -0
- package/dist/actions/init/bootstrapRemoteTemplate.js.map +1 -0
- package/dist/actions/init/bootstrapTemplate.js +32 -0
- package/dist/actions/init/bootstrapTemplate.js.map +1 -0
- package/dist/actions/init/checkNextJsReactCompatibility.js +21 -0
- package/dist/actions/init/checkNextJsReactCompatibility.js.map +1 -0
- package/dist/actions/init/constants.js +3 -0
- package/dist/actions/init/constants.js.map +1 -0
- package/dist/actions/init/countNestedFolders.js +6 -0
- package/dist/actions/init/countNestedFolders.js.map +1 -0
- package/dist/actions/init/createAppCliConfig.js +19 -0
- package/dist/actions/init/createAppCliConfig.js.map +1 -0
- package/dist/actions/init/createCliConfig.js +27 -0
- package/dist/actions/init/createCliConfig.js.map +1 -0
- package/dist/actions/init/createPackageManifest.js +86 -0
- package/dist/actions/init/createPackageManifest.js.map +1 -0
- package/dist/actions/init/createStudioConfig.js +41 -0
- package/dist/actions/init/createStudioConfig.js.map +1 -0
- package/dist/actions/init/determineAppTemplate.js +16 -0
- package/dist/actions/init/determineAppTemplate.js.map +1 -0
- package/dist/actions/init/env/createOrAppendEnvVars.js +25 -0
- package/dist/actions/init/env/createOrAppendEnvVars.js.map +1 -0
- package/dist/actions/init/env/parseAndUpdateEnvVars.js +42 -0
- package/dist/actions/init/env/parseAndUpdateEnvVars.js.map +1 -0
- package/dist/actions/init/env/writeEnvVarsToFile.js +49 -0
- package/dist/actions/init/env/writeEnvVarsToFile.js.map +1 -0
- package/dist/actions/init/fetchPostInitPrompt.js +30 -0
- package/dist/actions/init/fetchPostInitPrompt.js.map +1 -0
- package/dist/actions/init/git.js +65 -0
- package/dist/actions/init/git.js.map +1 -0
- package/dist/actions/init/processTemplate.js +56 -0
- package/dist/actions/init/processTemplate.js.map +1 -0
- package/dist/actions/init/remoteTemplate.js +211 -0
- package/dist/actions/init/remoteTemplate.js.map +1 -0
- package/dist/actions/init/resolvePackageManager.js +20 -0
- package/dist/actions/init/resolvePackageManager.js.map +1 -0
- package/dist/actions/init/templates/appQuickstart.js +28 -0
- package/dist/actions/init/templates/appQuickstart.js.map +1 -0
- package/dist/actions/init/templates/appSanityUi.js +30 -0
- package/dist/actions/init/templates/appSanityUi.js.map +1 -0
- package/dist/actions/init/templates/blog.js +4 -0
- package/dist/actions/init/templates/blog.js.map +1 -0
- package/dist/actions/init/templates/clean.js +4 -0
- package/dist/actions/init/templates/clean.js.map +1 -0
- package/dist/actions/init/templates/getStarted.js +35 -0
- package/dist/actions/init/templates/getStarted.js.map +1 -0
- package/dist/actions/init/templates/index.js +23 -0
- package/dist/actions/init/templates/index.js.map +1 -0
- package/dist/actions/init/templates/moviedb.js +34 -0
- package/dist/actions/init/templates/moviedb.js.map +1 -0
- package/dist/actions/init/templates/nextjs/index.js +213 -0
- package/dist/actions/init/templates/nextjs/index.js.map +1 -0
- package/dist/actions/init/templates/nextjs/schemaTypes/blog.js +247 -0
- package/dist/actions/init/templates/nextjs/schemaTypes/blog.js.map +1 -0
- package/dist/actions/init/templates/quickstart.js +4 -0
- package/dist/actions/init/templates/quickstart.js.map +1 -0
- package/dist/actions/init/templates/shopify.js +77 -0
- package/dist/actions/init/templates/shopify.js.map +1 -0
- package/dist/actions/init/templates/shopifyOnline.js +49 -0
- package/dist/actions/init/templates/shopifyOnline.js.map +1 -0
- package/dist/actions/init/types.js +3 -0
- package/dist/actions/init/types.js.map +1 -0
- package/dist/actions/init/updateInitialTemplateMetadata.js +17 -0
- package/dist/actions/init/updateInitialTemplateMetadata.js.map +1 -0
- package/dist/actions/manifest/SchemaIcon.js +21 -0
- package/dist/actions/manifest/SchemaIcon.js.map +1 -0
- package/dist/actions/manifest/extractAppManifest.js +51 -0
- package/dist/actions/manifest/extractAppManifest.js.map +1 -0
- package/dist/actions/manifest/extractManifest.js +93 -0
- package/dist/actions/manifest/extractManifest.js.map +1 -0
- package/dist/actions/manifest/extractWorkspaceManifest.js +406 -0
- package/dist/actions/manifest/extractWorkspaceManifest.js.map +1 -0
- package/dist/actions/manifest/purifyConfig.js +307 -0
- package/dist/actions/manifest/purifyConfig.js.map +1 -0
- package/dist/actions/manifest/schemaTypeHelpers.js +110 -0
- package/dist/actions/manifest/schemaTypeHelpers.js.map +1 -0
- package/dist/actions/manifest/types.js +5 -0
- package/dist/actions/manifest/types.js.map +1 -0
- package/dist/actions/mcp/detectAvailableEditors.js +75 -0
- package/dist/actions/mcp/detectAvailableEditors.js.map +1 -0
- package/dist/actions/mcp/editorConfigs.js +147 -0
- package/dist/actions/mcp/editorConfigs.js.map +1 -0
- package/dist/actions/mcp/promptForMCPSetup.js +24 -0
- package/dist/actions/mcp/promptForMCPSetup.js.map +1 -0
- package/dist/actions/mcp/setupMCP.js +88 -0
- package/dist/actions/mcp/setupMCP.js.map +1 -0
- package/dist/actions/mcp/types.js +3 -0
- package/dist/actions/mcp/types.js.map +1 -0
- package/dist/actions/mcp/writeMCPConfig.js +41 -0
- package/dist/actions/mcp/writeMCPConfig.js.map +1 -0
- package/dist/actions/media/__tests__/createMockClient.js +32 -0
- package/dist/actions/media/__tests__/createMockClient.js.map +1 -0
- package/dist/actions/media/getMediaLibraryConfig.js +5 -0
- package/dist/actions/media/getMediaLibraryConfig.js.map +1 -0
- package/dist/actions/media/importAspects.js +112 -0
- package/dist/actions/media/importAspects.js.map +1 -0
- package/dist/actions/media/importMedia.js +213 -0
- package/dist/actions/media/importMedia.js.map +1 -0
- package/dist/actions/media/importMediaDebug.js +4 -0
- package/dist/actions/media/importMediaDebug.js.map +1 -0
- package/dist/actions/organizations/getOrganization.js +67 -0
- package/dist/actions/organizations/getOrganization.js.map +1 -0
- package/dist/actions/organizations/getOrganizationChoices.js +23 -0
- package/dist/actions/organizations/getOrganizationChoices.js.map +1 -0
- package/dist/actions/organizations/getOrganizationsWithAttachGrantInfo.js +9 -0
- package/dist/actions/organizations/getOrganizationsWithAttachGrantInfo.js.map +1 -0
- package/dist/actions/organizations/hasProjectAttachGrant.js +24 -0
- package/dist/actions/organizations/hasProjectAttachGrant.js.map +1 -0
- package/dist/actions/organizations/validateOrganizationName.js +10 -0
- package/dist/actions/organizations/validateOrganizationName.js.map +1 -0
- package/dist/actions/preview/getPreviewServerConfig.js +16 -0
- package/dist/actions/preview/getPreviewServerConfig.js.map +1 -0
- package/dist/actions/preview/previewAction.js +20 -0
- package/dist/actions/preview/previewAction.js.map +1 -0
- package/dist/actions/preview/types.js +3 -0
- package/dist/actions/preview/types.js.map +1 -0
- package/dist/actions/projects/getManageUrl.js +7 -0
- package/dist/actions/projects/getManageUrl.js.map +1 -0
- package/dist/actions/projects/validateProjectName.js +11 -0
- package/dist/actions/projects/validateProjectName.js.map +1 -0
- package/dist/actions/schema/deleteSchemaAction.js +101 -0
- package/dist/actions/schema/deleteSchemaAction.js.map +1 -0
- package/dist/actions/schema/deploySchemas.js +98 -0
- package/dist/actions/schema/deploySchemas.js.map +1 -0
- package/dist/actions/schema/extractSanitySchema.worker.js +38 -0
- package/dist/actions/schema/extractSanitySchema.worker.js.map +1 -0
- package/dist/actions/schema/extractSchema.js +77 -0
- package/dist/actions/schema/extractSchema.js.map +1 -0
- package/dist/actions/schema/formatSchemaValidation.js +74 -0
- package/dist/actions/schema/formatSchemaValidation.js.map +1 -0
- package/dist/actions/schema/listSchemas.js +119 -0
- package/dist/actions/schema/listSchemas.js.map +1 -0
- package/dist/actions/schema/metafile.js +51 -0
- package/dist/actions/schema/metafile.js.map +1 -0
- package/dist/actions/schema/schemaStoreTypes.js +19 -0
- package/dist/actions/schema/schemaStoreTypes.js.map +1 -0
- package/dist/actions/schema/types.js +9 -0
- package/dist/actions/schema/types.js.map +1 -0
- package/dist/actions/schema/utils/debug.js +6 -0
- package/dist/actions/schema/utils/debug.js.map +1 -0
- package/dist/actions/schema/utils/extractValidationFromSchemaError.js +12 -0
- package/dist/actions/schema/utils/extractValidationFromSchemaError.js.map +1 -0
- package/dist/actions/schema/utils/manifestExtractor.js +33 -0
- package/dist/actions/schema/utils/manifestExtractor.js.map +1 -0
- package/dist/actions/schema/utils/manifestReader.js +71 -0
- package/dist/actions/schema/utils/manifestReader.js.map +1 -0
- package/dist/actions/schema/utils/schemaStoreOutStrings.js +11 -0
- package/dist/actions/schema/utils/schemaStoreOutStrings.js.map +1 -0
- package/dist/actions/schema/utils/schemaStoreValidation.js +108 -0
- package/dist/actions/schema/utils/schemaStoreValidation.js.map +1 -0
- package/dist/actions/schema/utils/uniqByProjectIdDataset.js +9 -0
- package/dist/actions/schema/utils/uniqByProjectIdDataset.js.map +1 -0
- package/dist/actions/schema/utils/workspaceSchemaId.js +23 -0
- package/dist/actions/schema/utils/workspaceSchemaId.js.map +1 -0
- package/dist/actions/schema/validateAction.js +71 -0
- package/dist/actions/schema/validateAction.js.map +1 -0
- package/dist/actions/schema/validateSchema.worker.js +124 -0
- package/dist/actions/schema/validateSchema.worker.js.map +1 -0
- package/dist/actions/telemetry/getLearnMoreMessage.js +15 -0
- package/dist/actions/telemetry/getLearnMoreMessage.js.map +1 -0
- package/dist/actions/telemetry/getStatusDisplay.js +26 -0
- package/dist/actions/telemetry/getStatusDisplay.js.map +1 -0
- package/dist/actions/telemetry/getStatusMessage.js +36 -0
- package/dist/actions/telemetry/getStatusMessage.js.map +1 -0
- package/dist/actions/telemetry/resolveConsent.js +48 -0
- package/dist/actions/telemetry/resolveConsent.js.map +1 -0
- package/dist/actions/telemetry/setConsent.js +83 -0
- package/dist/actions/telemetry/setConsent.js.map +1 -0
- package/dist/actions/telemetry/telemetryDebug.js +4 -0
- package/dist/actions/telemetry/telemetryDebug.js.map +1 -0
- package/dist/actions/telemetry/telemetryDisclosure.js +33 -0
- package/dist/actions/telemetry/telemetryDisclosure.js.map +1 -0
- package/dist/actions/telemetry/telemetryLearnMoreMessage.js +15 -0
- package/dist/actions/telemetry/telemetryLearnMoreMessage.js.map +1 -0
- package/dist/actions/tokens/constants.js +5 -0
- package/dist/actions/tokens/constants.js.map +1 -0
- package/dist/actions/tokens/types.js +3 -0
- package/dist/actions/tokens/types.js.map +1 -0
- package/dist/actions/tokens/validateRole.js +23 -0
- package/dist/actions/tokens/validateRole.js.map +1 -0
- package/dist/actions/undeploy/getStudioOrAppUserApplication.js +36 -0
- package/dist/actions/undeploy/getStudioOrAppUserApplication.js.map +1 -0
- package/dist/actions/users/getMembersForProject.js +47 -0
- package/dist/actions/users/getMembersForProject.js.map +1 -0
- package/dist/actions/users/getPendingInvitations.js +15 -0
- package/dist/actions/users/getPendingInvitations.js.map +1 -0
- package/dist/actions/users/types.js +3 -0
- package/dist/actions/users/types.js.map +1 -0
- package/dist/actions/users/usersDebug.js +4 -0
- package/dist/actions/users/usersDebug.js.map +1 -0
- package/dist/actions/users/validateEmail.js +14 -0
- package/dist/actions/users/validateEmail.js.map +1 -0
- package/dist/actions/versions/buildPackageArray.js +44 -0
- package/dist/actions/versions/buildPackageArray.js.map +1 -0
- package/dist/actions/versions/filterSanityModules.js +20 -0
- package/dist/actions/versions/filterSanityModules.js.map +1 -0
- package/dist/actions/versions/findSanityModulesVersions.js +47 -0
- package/dist/actions/versions/findSanityModulesVersions.js.map +1 -0
- package/dist/actions/versions/getFormatters.js +30 -0
- package/dist/actions/versions/getFormatters.js.map +1 -0
- package/dist/actions/versions/tryFindLatestVersion.js +21 -0
- package/dist/actions/versions/tryFindLatestVersion.js.map +1 -0
- package/dist/actions/versions/types.js +5 -0
- package/dist/actions/versions/types.js.map +1 -0
- package/dist/actions/versions/versionsDebug.js +4 -0
- package/dist/actions/versions/versionsDebug.js.map +1 -0
- package/dist/commands/backup/disable.js +94 -0
- package/dist/commands/backup/disable.js.map +1 -0
- package/dist/commands/backup/download.js +291 -0
- package/dist/commands/backup/download.js.map +1 -0
- package/dist/commands/backup/enable.js +99 -0
- package/dist/commands/backup/enable.js.map +1 -0
- package/dist/commands/backup/list.js +187 -0
- package/dist/commands/backup/list.js.map +1 -0
- package/dist/commands/build.js +82 -0
- package/dist/commands/build.js.map +1 -0
- package/dist/commands/codemod.js +141 -0
- package/dist/commands/codemod.js.map +1 -0
- package/dist/commands/cors/add.js +154 -0
- package/dist/commands/cors/add.js.map +1 -0
- package/dist/commands/cors/delete.js +90 -0
- package/dist/commands/cors/delete.js.map +1 -0
- package/dist/commands/cors/list.js +40 -0
- package/dist/commands/cors/list.js.map +1 -0
- package/dist/commands/dataset/alias/create.js +118 -0
- package/dist/commands/dataset/alias/create.js.map +1 -0
- package/dist/commands/dataset/alias/delete.js +88 -0
- package/dist/commands/dataset/alias/delete.js.map +1 -0
- package/dist/commands/dataset/alias/link.js +137 -0
- package/dist/commands/dataset/alias/link.js.map +1 -0
- package/dist/commands/dataset/alias/unlink.js +98 -0
- package/dist/commands/dataset/alias/unlink.js.map +1 -0
- package/dist/commands/dataset/copy.js +369 -0
- package/dist/commands/dataset/copy.js.map +1 -0
- package/dist/commands/dataset/create.js +106 -0
- package/dist/commands/dataset/create.js.map +1 -0
- package/dist/commands/dataset/delete.js +104 -0
- package/dist/commands/dataset/delete.js.map +1 -0
- package/dist/commands/dataset/export.js +271 -0
- package/dist/commands/dataset/export.js.map +1 -0
- package/dist/commands/dataset/import.js +3 -0
- package/dist/commands/dataset/import.js.map +1 -0
- package/dist/commands/dataset/list.js +50 -0
- package/dist/commands/dataset/list.js.map +1 -0
- package/dist/commands/dataset/visibility/get.js +55 -0
- package/dist/commands/dataset/visibility/get.js.map +1 -0
- package/dist/commands/dataset/visibility/set.js +88 -0
- package/dist/commands/dataset/visibility/set.js.map +1 -0
- package/dist/commands/debug.js +93 -0
- package/dist/commands/debug.js.map +1 -0
- package/dist/commands/deploy.js +115 -0
- package/dist/commands/deploy.js.map +1 -0
- package/dist/commands/dev.js +65 -0
- package/dist/commands/dev.js.map +1 -0
- package/dist/commands/docs/browse.js +15 -0
- package/dist/commands/docs/browse.js.map +1 -0
- package/dist/commands/docs/read.js +81 -0
- package/dist/commands/docs/read.js.map +1 -0
- package/dist/commands/docs/search.js +111 -0
- package/dist/commands/docs/search.js.map +1 -0
- package/dist/commands/documents/create.js +338 -0
- package/dist/commands/documents/create.js.map +1 -0
- package/dist/commands/documents/delete.js +104 -0
- package/dist/commands/documents/delete.js.map +1 -0
- package/dist/commands/documents/get.js +85 -0
- package/dist/commands/documents/get.js.map +1 -0
- package/dist/commands/documents/query.js +105 -0
- package/dist/commands/documents/query.js.map +1 -0
- package/dist/commands/documents/validate.js +142 -0
- package/dist/commands/documents/validate.js.map +1 -0
- package/dist/commands/exec.js +54 -0
- package/dist/commands/exec.js.map +1 -0
- package/dist/commands/graphql/deploy.js +429 -0
- package/dist/commands/graphql/deploy.js.map +1 -0
- package/dist/commands/graphql/list.js +53 -0
- package/dist/commands/graphql/list.js.map +1 -0
- package/dist/commands/graphql/undeploy.js +143 -0
- package/dist/commands/graphql/undeploy.js.map +1 -0
- package/dist/commands/hook/attempt.js +66 -0
- package/dist/commands/hook/attempt.js.map +1 -0
- package/dist/commands/hook/create.js +46 -0
- package/dist/commands/hook/create.js.map +1 -0
- package/dist/commands/hook/delete.js +86 -0
- package/dist/commands/hook/delete.js.map +1 -0
- package/dist/commands/hook/list.js +46 -0
- package/dist/commands/hook/list.js.map +1 -0
- package/dist/commands/hook/logs.js +184 -0
- package/dist/commands/hook/logs.js.map +1 -0
- package/dist/commands/init.js +1389 -0
- package/dist/commands/init.js.map +1 -0
- package/dist/commands/install.js +43 -0
- package/dist/commands/install.js.map +1 -0
- package/dist/commands/learn.js +15 -0
- package/dist/commands/learn.js.map +1 -0
- package/dist/commands/login.js +50 -0
- package/dist/commands/login.js.map +1 -0
- package/dist/commands/logout.js +37 -0
- package/dist/commands/logout.js.map +1 -0
- package/dist/commands/manage.js +29 -0
- package/dist/commands/manage.js.map +1 -0
- package/dist/commands/manifest/extract.js +43 -0
- package/dist/commands/manifest/extract.js.map +1 -0
- package/dist/commands/mcp/configure.js +28 -0
- package/dist/commands/mcp/configure.js.map +1 -0
- package/dist/commands/media/create-aspect.js +88 -0
- package/dist/commands/media/create-aspect.js.map +1 -0
- package/dist/commands/media/delete-aspect.js +85 -0
- package/dist/commands/media/delete-aspect.js.map +1 -0
- package/dist/commands/media/deploy-aspect.js +151 -0
- package/dist/commands/media/deploy-aspect.js.map +1 -0
- package/dist/commands/media/export.js +210 -0
- package/dist/commands/media/export.js.map +1 -0
- package/dist/commands/media/import.js +160 -0
- package/dist/commands/media/import.js.map +1 -0
- package/dist/commands/openapi/get.js +83 -0
- package/dist/commands/openapi/get.js.map +1 -0
- package/dist/commands/openapi/list.js +80 -0
- package/dist/commands/openapi/list.js.map +1 -0
- package/dist/commands/preview.js +60 -0
- package/dist/commands/preview.js.map +1 -0
- package/dist/commands/projects/create.js +181 -0
- package/dist/commands/projects/create.js.map +1 -0
- package/dist/commands/projects/list.js +76 -0
- package/dist/commands/projects/list.js.map +1 -0
- package/dist/commands/schema/delete.js +91 -0
- package/dist/commands/schema/delete.js.map +1 -0
- package/dist/commands/schema/deploy.js +98 -0
- package/dist/commands/schema/deploy.js.map +1 -0
- package/dist/commands/schema/extract.js +46 -0
- package/dist/commands/schema/extract.js.map +1 -0
- package/dist/commands/schema/list.js +104 -0
- package/dist/commands/schema/list.js.map +1 -0
- package/dist/commands/schema/validate.js +73 -0
- package/dist/commands/schema/validate.js.map +1 -0
- package/dist/commands/telemetry/disable.js +33 -0
- package/dist/commands/telemetry/disable.js.map +1 -0
- package/dist/commands/telemetry/enable.js +33 -0
- package/dist/commands/telemetry/enable.js.map +1 -0
- package/dist/commands/telemetry/status.js +25 -0
- package/dist/commands/telemetry/status.js.map +1 -0
- package/dist/commands/tokens/add.js +135 -0
- package/dist/commands/tokens/add.js.map +1 -0
- package/dist/commands/tokens/delete.js +107 -0
- package/dist/commands/tokens/delete.js.map +1 -0
- package/dist/commands/tokens/list.js +92 -0
- package/dist/commands/tokens/list.js.map +1 -0
- package/dist/commands/undeploy.js +93 -0
- package/dist/commands/undeploy.js.map +1 -0
- package/dist/commands/users/invite.js +100 -0
- package/dist/commands/users/invite.js.map +1 -0
- package/dist/commands/users/list.js +101 -0
- package/dist/commands/users/list.js.map +1 -0
- package/dist/commands/versions.js +27 -0
- package/dist/commands/versions.js.map +1 -0
- package/dist/config/createCliConfig.js +9 -0
- package/dist/config/createCliConfig.js.map +1 -0
- package/dist/config/defineCliConfig.js +5 -0
- package/dist/config/defineCliConfig.js.map +1 -0
- package/dist/hooks/prerun/flushTelemetry.worker.js +22 -0
- package/dist/hooks/prerun/flushTelemetry.worker.js.map +1 -0
- package/dist/hooks/prerun/injectEnvVariables.js +31 -0
- package/dist/hooks/prerun/injectEnvVariables.js.map +1 -0
- package/dist/hooks/prerun/setupTelemetry.js +72 -0
- package/dist/hooks/prerun/setupTelemetry.js.map +1 -0
- package/dist/hooks/prerun/warnings.js +6 -0
- package/dist/hooks/prerun/warnings.js.map +1 -0
- package/dist/index.d.ts +2326 -0
- package/dist/index.js +6 -0
- package/dist/index.js.map +1 -0
- package/dist/prompts/init/nextjs.js +56 -0
- package/dist/prompts/init/nextjs.js.map +1 -0
- package/dist/prompts/init/promptForTypescript.js +9 -0
- package/dist/prompts/init/promptForTypescript.js.map +1 -0
- package/dist/prompts/promptForDataset.js +32 -0
- package/dist/prompts/promptForDataset.js.map +1 -0
- package/dist/prompts/promptForDatasetAclMode.js +27 -0
- package/dist/prompts/promptForDatasetAclMode.js.map +1 -0
- package/dist/prompts/promptForDatasetAliasName.js +17 -0
- package/dist/prompts/promptForDatasetAliasName.js.map +1 -0
- package/dist/prompts/promptForDatasetName.js +20 -0
- package/dist/prompts/promptForDatasetName.js.map +1 -0
- package/dist/prompts/promptForDefaultConfig.js +12 -0
- package/dist/prompts/promptForDefaultConfig.js.map +1 -0
- package/dist/prompts/promptForMediaLibrary.js +37 -0
- package/dist/prompts/promptForMediaLibrary.js.map +1 -0
- package/dist/prompts/promptForOrganizationName.js +11 -0
- package/dist/prompts/promptForOrganizationName.js.map +1 -0
- package/dist/prompts/promptForProjectName.js +11 -0
- package/dist/prompts/promptForProjectName.js.map +1 -0
- package/dist/prompts/selectDataset.js +12 -0
- package/dist/prompts/selectDataset.js.map +1 -0
- package/dist/prompts/selectMediaLibrary.js +34 -0
- package/dist/prompts/selectMediaLibrary.js.map +1 -0
- package/dist/server/devServer.js +53 -0
- package/dist/server/devServer.js.map +1 -0
- package/dist/server/gracefulServerDeath.js +12 -0
- package/dist/server/gracefulServerDeath.js.map +1 -0
- package/dist/server/previewServer.js +93 -0
- package/dist/server/previewServer.js.map +1 -0
- package/dist/server/serverDebug.js +4 -0
- package/dist/server/serverDebug.js.map +1 -0
- package/dist/server/vite/plugin-sanity-basepath-redirect.js +25 -0
- package/dist/server/vite/plugin-sanity-basepath-redirect.js.map +1 -0
- package/dist/server/vite/plugin-sanity-build-entries.js +65 -0
- package/dist/server/vite/plugin-sanity-build-entries.js.map +1 -0
- package/dist/server/vite/plugin-sanity-favicons.js +72 -0
- package/dist/server/vite/plugin-sanity-favicons.js.map +1 -0
- package/dist/server/vite/plugin-sanity-runtime-rewrite.js +18 -0
- package/dist/server/vite/plugin-sanity-runtime-rewrite.js.map +1 -0
- package/dist/services/auth.js +13 -0
- package/dist/services/auth.js.map +1 -0
- package/dist/services/backup.js +51 -0
- package/dist/services/backup.js.map +1 -0
- package/dist/services/cors.js +38 -0
- package/dist/services/cors.js.map +1 -0
- package/dist/services/datasetAliases.js +64 -0
- package/dist/services/datasetAliases.js.map +1 -0
- package/dist/services/datasets.js +153 -0
- package/dist/services/datasets.js.map +1 -0
- package/dist/services/docs.js +46 -0
- package/dist/services/docs.js.map +1 -0
- package/dist/services/documents.js +56 -0
- package/dist/services/documents.js.map +1 -0
- package/dist/services/getProjectFeatures.js +16 -0
- package/dist/services/getProjectFeatures.js.map +1 -0
- package/dist/services/getUrlHeaders.js +36 -0
- package/dist/services/getUrlHeaders.js.map +1 -0
- package/dist/services/graphql.js +96 -0
- package/dist/services/graphql.js.map +1 -0
- package/dist/services/hooks.js +59 -0
- package/dist/services/hooks.js.map +1 -0
- package/dist/services/mcp.js +50 -0
- package/dist/services/mcp.js.map +1 -0
- package/dist/services/mediaLibraries.js +74 -0
- package/dist/services/mediaLibraries.js.map +1 -0
- package/dist/services/organizations.js +42 -0
- package/dist/services/organizations.js.map +1 -0
- package/dist/services/plans.js +37 -0
- package/dist/services/plans.js.map +1 -0
- package/dist/services/projects.js +119 -0
- package/dist/services/projects.js.map +1 -0
- package/dist/services/schemas.js +40 -0
- package/dist/services/schemas.js.map +1 -0
- package/dist/services/telemetry.js +80 -0
- package/dist/services/telemetry.js.map +1 -0
- package/dist/services/tokens.js +72 -0
- package/dist/services/tokens.js.map +1 -0
- package/dist/services/user.js +35 -0
- package/dist/services/user.js.map +1 -0
- package/dist/services/userApplications.js +164 -0
- package/dist/services/userApplications.js.map +1 -0
- package/dist/studioDependencies.js +24 -0
- package/dist/studioDependencies.js.map +1 -0
- package/dist/telemetry/build.telemetry.js +13 -0
- package/dist/telemetry/build.telemetry.js.map +1 -0
- package/dist/telemetry/cli.telemetry.js +8 -0
- package/dist/telemetry/cli.telemetry.js.map +1 -0
- package/dist/telemetry/extractSchema.telemetry.js +8 -0
- package/dist/telemetry/extractSchema.telemetry.js.map +1 -0
- package/dist/telemetry/init.telemetry.js +8 -0
- package/dist/telemetry/init.telemetry.js.map +1 -0
- package/dist/telemetry/login.telemetry.js +8 -0
- package/dist/telemetry/login.telemetry.js.map +1 -0
- package/dist/telemetry/mcp.telemetry.js +8 -0
- package/dist/telemetry/mcp.telemetry.js.map +1 -0
- package/dist/types.js +5 -0
- package/dist/types.js.map +1 -0
- package/dist/typings/deepSortObject.d.js +2 -0
- package/dist/typings/deepSortObject.d.js.map +1 -0
- package/dist/util/absolutify.js +26 -0
- package/dist/util/absolutify.js.map +1 -0
- package/dist/util/appId.js +58 -0
- package/dist/util/appId.js.map +1 -0
- package/dist/util/canLaunchBrowser.js +14 -0
- package/dist/util/canLaunchBrowser.js.map +1 -0
- package/dist/util/cliClient.js +41 -0
- package/dist/util/cliClient.js.map +1 -0
- package/dist/util/compareDependencyVersions.js +73 -0
- package/dist/util/compareDependencyVersions.js.map +1 -0
- package/dist/util/copy.js +37 -0
- package/dist/util/copy.js.map +1 -0
- package/dist/util/copyDir.js +63 -0
- package/dist/util/copyDir.js.map +1 -0
- package/dist/util/detectRuntime.js +20 -0
- package/dist/util/detectRuntime.js.map +1 -0
- package/dist/util/determineIsApp.js +9 -0
- package/dist/util/determineIsApp.js.map +1 -0
- package/dist/util/dirIsEmptyOrNonExistent.js +18 -0
- package/dist/util/dirIsEmptyOrNonExistent.js.map +1 -0
- package/dist/util/ensureTrailingSlash.js +12 -0
- package/dist/util/ensureTrailingSlash.js.map +1 -0
- package/dist/util/errorMessages.js +6 -0
- package/dist/util/errorMessages.js.map +1 -0
- package/dist/util/extractDocumentsFromNdjsonOrTarball.js +88 -0
- package/dist/util/extractDocumentsFromNdjsonOrTarball.js.map +1 -0
- package/dist/util/findNdjsonEntry.js +21 -0
- package/dist/util/findNdjsonEntry.js.map +1 -0
- package/dist/util/formatSize.js +10 -0
- package/dist/util/formatSize.js.map +1 -0
- package/dist/util/frameworkPort.js +61 -0
- package/dist/util/frameworkPort.js.map +1 -0
- package/dist/util/fsUtils.js +34 -0
- package/dist/util/fsUtils.js.map +1 -0
- package/dist/util/getCliVersion.js +28 -0
- package/dist/util/getCliVersion.js.map +1 -0
- package/dist/util/getErrorMessage.js +19 -0
- package/dist/util/getErrorMessage.js.map +1 -0
- package/dist/util/getLocalPackageVersion.js +32 -0
- package/dist/util/getLocalPackageVersion.js.map +1 -0
- package/dist/util/getProjectDefaults.js +77 -0
- package/dist/util/getProjectDefaults.js.map +1 -0
- package/dist/util/getSanityEnv.js +3 -0
- package/dist/util/getSanityEnv.js.map +1 -0
- package/dist/util/getSharedServerConfig.js +31 -0
- package/dist/util/getSharedServerConfig.js.map +1 -0
- package/dist/util/getWorkspace.js +18 -0
- package/dist/util/getWorkspace.js.map +1 -0
- package/dist/util/humanFileSize.js +12 -0
- package/dist/util/humanFileSize.js.map +1 -0
- package/dist/util/importStudioConfig.js +40 -0
- package/dist/util/importStudioConfig.js.map +1 -0
- package/dist/util/isPathDirName.js +6 -0
- package/dist/util/isPathDirName.js.map +1 -0
- package/dist/util/isSanityDocumentish.js +20 -0
- package/dist/util/isSanityDocumentish.js.map +1 -0
- package/dist/util/loadEnv.js +3 -0
- package/dist/util/loadEnv.js.map +1 -0
- package/dist/util/moduleFormatUtils.js +18 -0
- package/dist/util/moduleFormatUtils.js.map +1 -0
- package/dist/util/packageManager/installPackages.js +87 -0
- package/dist/util/packageManager/installPackages.js.map +1 -0
- package/dist/util/packageManager/packageManagerChoice.js +181 -0
- package/dist/util/packageManager/packageManagerChoice.js.map +1 -0
- package/dist/util/packageManager/upgradePackages.js +69 -0
- package/dist/util/packageManager/upgradePackages.js.map +1 -0
- package/dist/util/parseArguments.js +42 -0
- package/dist/util/parseArguments.js.map +1 -0
- package/dist/util/pluralize.js +11 -0
- package/dist/util/pluralize.js.map +1 -0
- package/dist/util/readModuleVersion.js +15 -0
- package/dist/util/readModuleVersion.js.map +1 -0
- package/dist/util/readPackageJson.js +44 -0
- package/dist/util/readPackageJson.js.map +1 -0
- package/dist/util/readPackageManifest.js +46 -0
- package/dist/util/readPackageManifest.js.map +1 -0
- package/dist/util/readdirRecursive.js +24 -0
- package/dist/util/readdirRecursive.js.map +1 -0
- package/dist/util/resolveLatestVersions.js +21 -0
- package/dist/util/resolveLatestVersions.js.map +1 -0
- package/dist/util/toInt.js +9 -0
- package/dist/util/toInt.js.map +1 -0
- package/dist/util/trimHashFromVersion.js +8 -0
- package/dist/util/trimHashFromVersion.js.map +1 -0
- package/dist/util/uniqBy.js +14 -0
- package/dist/util/uniqBy.js.map +1 -0
- package/dist/util/validation/validateDocumentsUtils.js +33 -0
- package/dist/util/validation/validateDocumentsUtils.js.map +1 -0
- package/dist/util/warnAboutMissingAppId.js +15 -0
- package/dist/util/warnAboutMissingAppId.js.map +1 -0
- package/dist/util/warnOnNonProductionEnvironment.js +18 -0
- package/dist/util/warnOnNonProductionEnvironment.js.map +1 -0
- package/dist/util/workerChannels.js +172 -0
- package/dist/util/workerChannels.js.map +1 -0
- package/oclif.config.js +21 -0
- package/oclif.manifest.json +4154 -0
- package/package.json +138 -98
- package/templates/app-quickstart/src/App.css +3 -1
- package/templates/app-quickstart/src/App.tsx +1 -1
- package/templates/app-sanity-ui/src/App.tsx +2 -2
- package/templates/app-sanity-ui/src/ExampleComponent.tsx +2 -1
- package/templates/get-started/plugins/sanity-plugin-tutorial/GetStartedTutorial.tsx +3 -3
- package/templates/get-started/plugins/sanity-plugin-tutorial/index.ts +2 -2
- package/templates/shopify/components/hotspots/ProductTooltip.tsx +1 -1
- package/templates/shopify/components/icons/Shopify.tsx +0 -2
- package/templates/shopify/components/inputs/CollectionHidden.tsx +0 -1
- package/templates/shopify/components/media/ColorTheme.tsx +1 -1
- package/templates/shopify/constants.ts +4 -4
- package/templates/shopify/plugins/customDocumentActions/index.ts +2 -2
- package/templates/shopify/plugins/customDocumentActions/shopifyDelete.tsx +1 -1
- package/templates/shopify/schemaTypes/documents/collection.tsx +1 -2
- package/templates/shopify/schemaTypes/documents/page.ts +1 -1
- package/templates/shopify/schemaTypes/documents/product.tsx +1 -1
- package/templates/shopify/schemaTypes/documents/productVariant.tsx +2 -3
- package/templates/shopify/schemaTypes/objects/customProductOption/customProductOptionColorObjectType.tsx +0 -1
- package/templates/shopify/schemaTypes/objects/hotspot/productHotspotsType.tsx +1 -3
- package/templates/shopify/schemaTypes/objects/module/collectionReferenceType.tsx +0 -1
- package/templates/shopify/schemaTypes/objects/shopify/placeholderStringType.ts +2 -3
- package/templates/shopify/schemaTypes/objects/shopify/productWithVariantType.tsx +1 -1
- package/templates/shopify/schemaTypes/objects/shopify/shopifyCollectionType.ts +1 -2
- package/templates/shopify/schemaTypes/objects/shopify/shopifyProductType.ts +1 -2
- package/templates/shopify/schemaTypes/portableText/portableTextType.tsx +7 -7
- package/templates/shopify/schemaTypes/singletons/homeType.ts +8 -8
- package/templates/shopify/structure/collectionStructure.ts +4 -1
- package/templates/shopify/structure/colorThemeStructure.ts +1 -1
- package/templates/shopify/structure/homeStructure.ts +2 -2
- package/templates/shopify/structure/index.ts +1 -1
- package/templates/shopify/structure/pageStructure.ts +2 -2
- package/templates/shopify/structure/productStructure.ts +7 -7
- package/templates/shopify/structure/settingStructure.ts +1 -1
- package/templates/shopify/utils/defineStructure.ts +1 -1
- package/templates/shopify-online-storefront/plugins/shopifyDocumentActions/index.ts +1 -1
- package/templates/shopify-online-storefront/plugins/shopifyDocumentActions/shopifyDelete.tsx +1 -1
- package/templates/shopify-online-storefront/structure/collectionStructure.ts +4 -1
- package/templates/shopify-online-storefront/structure/productStructure.ts +4 -4
- package/templates/shopify-online-storefront/utils/defineStructure.ts +1 -1
- package/bin/dev.js +0 -30
- package/bin/sanity +0 -14
- package/lib/_chunks-cjs/cli.js +0 -70870
- package/lib/_chunks-cjs/cli.js.map +0 -1
- package/lib/_chunks-cjs/cliWorker.js +0 -19
- package/lib/_chunks-cjs/cliWorker.js.map +0 -1
- package/lib/_chunks-cjs/generateAction.js +0 -128
- package/lib/_chunks-cjs/generateAction.js.map +0 -1
- package/lib/_chunks-cjs/getCliConfig.js +0 -89
- package/lib/_chunks-cjs/getCliConfig.js.map +0 -1
- package/lib/_chunks-cjs/index.js +0 -31
- package/lib/_chunks-cjs/index.js.map +0 -1
- package/lib/_chunks-cjs/journeyConfig.js +0 -113
- package/lib/_chunks-cjs/journeyConfig.js.map +0 -1
- package/lib/_chunks-cjs/loadEnv.js +0 -347
- package/lib/_chunks-cjs/loadEnv.js.map +0 -1
- package/lib/_chunks-dts/types.d.ts +0 -432
- package/lib/cli.d.ts +0 -7
- package/lib/cli.js +0 -10
- package/lib/cli.js.map +0 -1
- package/lib/index.d.ts +0 -44
- package/lib/index.js +0 -46
- package/lib/index.js.map +0 -1
- package/lib/run.d.ts +0 -1
- package/lib/run.js +0 -8
- package/lib/run.js.map +0 -1
- package/lib/workers/getAndWriteJourneySchema.d.ts +0 -1
- package/lib/workers/getAndWriteJourneySchema.js +0 -4
- package/lib/workers/getAndWriteJourneySchema.js.map +0 -1
- package/lib/workers/getCliConfig.d.ts +0 -1
- package/lib/workers/getCliConfig.js +0 -10
- package/lib/workers/getCliConfig.js.map +0 -1
- package/lib/workers/typegenGenerate.d.ts +0 -18
- package/lib/workers/typegenGenerate.js +0 -47
- package/lib/workers/typegenGenerate.js.map +0 -1
|
@@ -0,0 +1,429 @@
|
|
|
1
|
+
import { Flags } from '@oclif/core';
|
|
2
|
+
import { isInteractive, SanityCommand } from '@sanity/cli-core';
|
|
3
|
+
import { confirm, spinner } from '@sanity/cli-core/ux';
|
|
4
|
+
import { get } from 'lodash-es';
|
|
5
|
+
import { extractFromSanitySchema } from '../../actions/graphql/extractFromSanitySchema.js';
|
|
6
|
+
import gen1 from '../../actions/graphql/gen1/index.js';
|
|
7
|
+
import gen2 from '../../actions/graphql/gen2/index.js';
|
|
8
|
+
import gen3 from '../../actions/graphql/gen3/index.js';
|
|
9
|
+
import { getGraphQLAPIs } from '../../actions/graphql/getGraphQLAPIs.js';
|
|
10
|
+
import { graphqlDebug } from '../../actions/graphql/graphqlDebug.js';
|
|
11
|
+
import { resolveApiGeneration } from '../../actions/graphql/resolveApiGeneration.js';
|
|
12
|
+
import { SchemaError } from '../../actions/graphql/SchemaError.js';
|
|
13
|
+
import { deployGraphQLAPI, getClientUrl, getCurrentSchemaProps, validateGraphQLAPI } from '../../services/graphql.js';
|
|
14
|
+
const apiIdRegex = /^[a-z0-9_-]+$/;
|
|
15
|
+
const generations = {
|
|
16
|
+
gen1,
|
|
17
|
+
gen2,
|
|
18
|
+
gen3
|
|
19
|
+
};
|
|
20
|
+
const ignoredBreaking = new Set([
|
|
21
|
+
'OPTIONAL_INPUT_FIELD_ADDED'
|
|
22
|
+
]);
|
|
23
|
+
// Reserved for future use to filter out specific dangerous change types
|
|
24
|
+
const ignoredWarnings = new Set();
|
|
25
|
+
const debug = graphqlDebug.extend('deploy');
|
|
26
|
+
export class GraphQLDeployCommand extends SanityCommand {
|
|
27
|
+
static description = 'Deploy a GraphQL API from the current Sanity schema';
|
|
28
|
+
static examples = [
|
|
29
|
+
{
|
|
30
|
+
command: '<%= config.bin %> <%= command.id %>',
|
|
31
|
+
description: 'Deploy all defined GraphQL APIs'
|
|
32
|
+
},
|
|
33
|
+
{
|
|
34
|
+
command: '<%= config.bin %> <%= command.id %> --dry-run',
|
|
35
|
+
description: 'Validate defined GraphQL APIs, check for breaking changes, skip deploy'
|
|
36
|
+
},
|
|
37
|
+
{
|
|
38
|
+
command: '<%= config.bin %> <%= command.id %> --api staging --api ios',
|
|
39
|
+
description: 'Deploy only the GraphQL APIs with the IDs "staging" and "ios"'
|
|
40
|
+
},
|
|
41
|
+
{
|
|
42
|
+
command: '<%= config.bin %> <%= command.id %> --playground',
|
|
43
|
+
description: 'Deploy all defined GraphQL APIs, overriding any playground setting'
|
|
44
|
+
}
|
|
45
|
+
];
|
|
46
|
+
static flags = {
|
|
47
|
+
api: Flags.string({
|
|
48
|
+
description: 'Only deploy API with this ID. Can be specified multiple times.',
|
|
49
|
+
multiple: true
|
|
50
|
+
}),
|
|
51
|
+
dataset: Flags.string({
|
|
52
|
+
description: 'Deploy API for the given dataset'
|
|
53
|
+
}),
|
|
54
|
+
'dry-run': Flags.boolean({
|
|
55
|
+
default: false,
|
|
56
|
+
description: 'Validate defined GraphQL APIs, check for breaking changes, skip deploy'
|
|
57
|
+
}),
|
|
58
|
+
force: Flags.boolean({
|
|
59
|
+
description: 'Deploy API without confirming breaking changes'
|
|
60
|
+
}),
|
|
61
|
+
generation: Flags.string({
|
|
62
|
+
description: 'API generation to deploy (defaults to "gen3")',
|
|
63
|
+
options: [
|
|
64
|
+
'gen1',
|
|
65
|
+
'gen2',
|
|
66
|
+
'gen3'
|
|
67
|
+
]
|
|
68
|
+
}),
|
|
69
|
+
'non-null-document-fields': Flags.boolean({
|
|
70
|
+
description: 'Use non-null document fields (_id, _type etc)'
|
|
71
|
+
}),
|
|
72
|
+
playground: Flags.boolean({
|
|
73
|
+
allowNo: true,
|
|
74
|
+
description: 'Enable GraphQL playground for easier debugging'
|
|
75
|
+
}),
|
|
76
|
+
tag: Flags.string({
|
|
77
|
+
description: 'Deploy API(s) to given tag (defaults to "default")'
|
|
78
|
+
}),
|
|
79
|
+
'with-union-cache': Flags.boolean({
|
|
80
|
+
description: 'Enable union cache that optimizes schema generation for schemas with many self referencing types'
|
|
81
|
+
})
|
|
82
|
+
};
|
|
83
|
+
async run() {
|
|
84
|
+
const { flags } = await this.parse(GraphQLDeployCommand);
|
|
85
|
+
const { api: onlyApis, dataset: datasetFlag, 'dry-run': dryRun, generation: generationFlag, 'non-null-document-fields': nonNullDocumentFieldsFlag, playground: playgroundFlag, tag: tagFlag, 'with-union-cache': withUnionCache } = flags;
|
|
86
|
+
const workDir = (await this.getProjectRoot()).directory;
|
|
87
|
+
let apiDefs = [];
|
|
88
|
+
let spin;
|
|
89
|
+
try {
|
|
90
|
+
apiDefs = await getGraphQLAPIs(workDir);
|
|
91
|
+
} catch (error) {
|
|
92
|
+
debug('Failed to get GraphQL APIs', error);
|
|
93
|
+
this.error('Failed to get GraphQL APIs', {
|
|
94
|
+
exit: 1
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
const hasMultipleApis = flags.api ? flags.api.length > 1 : apiDefs.length > 1;
|
|
98
|
+
const usedFlags = [
|
|
99
|
+
datasetFlag && '--dataset',
|
|
100
|
+
tagFlag && '--tag',
|
|
101
|
+
playgroundFlag !== undefined && '--playground',
|
|
102
|
+
generationFlag !== undefined && '--generation',
|
|
103
|
+
nonNullDocumentFieldsFlag !== undefined && '--non-null-document-fields'
|
|
104
|
+
].filter(Boolean);
|
|
105
|
+
if (hasMultipleApis && usedFlags.length > 0) {
|
|
106
|
+
this.warn(`More than one API defined, and ${usedFlags.join('/')} is specified`);
|
|
107
|
+
this.warn(`This will use the specified flag(s) for ALL APIs, overriding config!`);
|
|
108
|
+
if (flags.force) {
|
|
109
|
+
this.warn(`--force specified, continuing...`);
|
|
110
|
+
} else {
|
|
111
|
+
const confirmed = await confirm({
|
|
112
|
+
default: false,
|
|
113
|
+
message: 'Continue with flag overrides for all APIs?'
|
|
114
|
+
});
|
|
115
|
+
if (!confirmed) {
|
|
116
|
+
this.error('Operation cancelled', {
|
|
117
|
+
exit: 1
|
|
118
|
+
});
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
const deployTasks = [];
|
|
123
|
+
let hasErrors = false;
|
|
124
|
+
for (const apiId of onlyApis || []){
|
|
125
|
+
if (!apiDefs.some((apiDef)=>apiDef.id === apiId)) {
|
|
126
|
+
this.error(`GraphQL API with id "${apiId}" not found`, {
|
|
127
|
+
exit: 1
|
|
128
|
+
});
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
const apiNames = new Set();
|
|
132
|
+
const apiIds = new Set();
|
|
133
|
+
for (const apiDef of apiDefs){
|
|
134
|
+
if (onlyApis && (!apiDef.id || !onlyApis.includes(apiDef.id))) {
|
|
135
|
+
continue;
|
|
136
|
+
}
|
|
137
|
+
const { apiName } = this.getApiIdentifiers(apiDef, datasetFlag, tagFlag);
|
|
138
|
+
if (apiNames.has(apiName)) {
|
|
139
|
+
this.error(`Multiple GraphQL APIs with the same dataset and tag found (${apiName})`, {
|
|
140
|
+
exit: 1
|
|
141
|
+
});
|
|
142
|
+
}
|
|
143
|
+
if (apiDef.id) {
|
|
144
|
+
if (typeof apiDef.id !== 'string' || !apiIdRegex.test(apiDef.id)) {
|
|
145
|
+
this.error(`Invalid GraphQL API id "${apiDef.id}" - only a-z, 0-9, underscore and dashes are allowed`, {
|
|
146
|
+
exit: 1
|
|
147
|
+
});
|
|
148
|
+
}
|
|
149
|
+
if (apiIds.has(apiDef.id)) {
|
|
150
|
+
this.error(`Multiple GraphQL APIs with the same ID found (${apiDef.id})`, {
|
|
151
|
+
exit: 1
|
|
152
|
+
});
|
|
153
|
+
}
|
|
154
|
+
apiIds.add(apiDef.id);
|
|
155
|
+
}
|
|
156
|
+
apiNames.add(apiName);
|
|
157
|
+
}
|
|
158
|
+
if (onlyApis) {
|
|
159
|
+
this.warn(`Deploying only specified APIs: ${onlyApis.join(', ')}`);
|
|
160
|
+
}
|
|
161
|
+
let index = -1;
|
|
162
|
+
for (const apiDef of apiDefs){
|
|
163
|
+
if (onlyApis && (!apiDef.id || !onlyApis.includes(apiDef.id))) {
|
|
164
|
+
continue;
|
|
165
|
+
}
|
|
166
|
+
index++;
|
|
167
|
+
const { apiName, dataset, tag } = this.getApiIdentifiers(apiDef, datasetFlag, tagFlag);
|
|
168
|
+
const { nonNullDocumentFields, playground, projectId, schema } = apiDef;
|
|
169
|
+
spin = spinner(`Generating GraphQL API: ${apiName}`).start();
|
|
170
|
+
if (!dataset) {
|
|
171
|
+
spin.fail();
|
|
172
|
+
this.error(`No dataset specified for API at index ${index}`, {
|
|
173
|
+
exit: 1
|
|
174
|
+
});
|
|
175
|
+
}
|
|
176
|
+
let currentGeneration;
|
|
177
|
+
let playgroundEnabled;
|
|
178
|
+
try {
|
|
179
|
+
const schemaProps = await getCurrentSchemaProps(projectId, dataset, tag);
|
|
180
|
+
currentGeneration = schemaProps.currentGeneration;
|
|
181
|
+
playgroundEnabled = schemaProps.playgroundEnabled;
|
|
182
|
+
} catch (err) {
|
|
183
|
+
debug('Failed to get current GraphQL schema properties', err);
|
|
184
|
+
spin.fail();
|
|
185
|
+
this.error('Failed to get current GraphQL schema properties', {
|
|
186
|
+
exit: 1
|
|
187
|
+
});
|
|
188
|
+
}
|
|
189
|
+
// CLI flag takes precedence over configuration
|
|
190
|
+
const specifiedGeneration = generationFlag === undefined ? apiDef.generation : generationFlag;
|
|
191
|
+
const generation = await resolveApiGeneration({
|
|
192
|
+
currentGeneration,
|
|
193
|
+
force: flags.force,
|
|
194
|
+
index,
|
|
195
|
+
output: this.output,
|
|
196
|
+
specifiedGeneration
|
|
197
|
+
});
|
|
198
|
+
if (!generation) {
|
|
199
|
+
// User cancelled
|
|
200
|
+
spin.fail();
|
|
201
|
+
continue;
|
|
202
|
+
}
|
|
203
|
+
if (!this.isRecognizedApiGeneration(generation)) {
|
|
204
|
+
spin.fail();
|
|
205
|
+
this.error(`Unknown API generation "${generation}" for API at index ${index}`, {
|
|
206
|
+
exit: 1
|
|
207
|
+
});
|
|
208
|
+
}
|
|
209
|
+
const enablePlayground = await this.shouldEnablePlayground({
|
|
210
|
+
dryRun,
|
|
211
|
+
playgroundCliFlag: playgroundFlag,
|
|
212
|
+
playgroundConfiguration: playground,
|
|
213
|
+
playgroundCurrentlyEnabled: playgroundEnabled,
|
|
214
|
+
spin
|
|
215
|
+
});
|
|
216
|
+
let apiSpec;
|
|
217
|
+
try {
|
|
218
|
+
const generateSchema = generations[generation];
|
|
219
|
+
const extracted = extractFromSanitySchema(schema, {
|
|
220
|
+
// Allow CLI flag to override configured setting
|
|
221
|
+
nonNullDocumentFields: nonNullDocumentFieldsFlag === undefined ? nonNullDocumentFields : nonNullDocumentFieldsFlag,
|
|
222
|
+
withUnionCache
|
|
223
|
+
});
|
|
224
|
+
apiSpec = generateSchema(extracted, {
|
|
225
|
+
filterSuffix: apiDef.filterSuffix
|
|
226
|
+
});
|
|
227
|
+
} catch (err) {
|
|
228
|
+
debug('Failed to extract schema', err);
|
|
229
|
+
spin.fail();
|
|
230
|
+
if (err instanceof SchemaError) {
|
|
231
|
+
err.print(this.output);
|
|
232
|
+
this.error('Failed to extract schema', {
|
|
233
|
+
exit: 1
|
|
234
|
+
});
|
|
235
|
+
} else {
|
|
236
|
+
const message = err instanceof Error ? err.message : 'Unknown error';
|
|
237
|
+
this.error(`Failed to extract schema: ${message}`, {
|
|
238
|
+
exit: 1
|
|
239
|
+
});
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
let valid;
|
|
243
|
+
try {
|
|
244
|
+
valid = await validateGraphQLAPI({
|
|
245
|
+
dataset,
|
|
246
|
+
enablePlayground,
|
|
247
|
+
projectId,
|
|
248
|
+
schema: apiSpec,
|
|
249
|
+
tag
|
|
250
|
+
});
|
|
251
|
+
} catch (err) {
|
|
252
|
+
debug('validateGraphQLAPI error', err);
|
|
253
|
+
const validationError = get(err, 'response.body.validationError');
|
|
254
|
+
spin.fail();
|
|
255
|
+
this.error(validationError ?? 'Failed to validate GraphQL API', {
|
|
256
|
+
exit: 1
|
|
257
|
+
});
|
|
258
|
+
}
|
|
259
|
+
// when the result is not valid and there are breaking changes afoot!
|
|
260
|
+
if (!this.isResultValid(valid, {
|
|
261
|
+
force: flags.force,
|
|
262
|
+
spin
|
|
263
|
+
})) {
|
|
264
|
+
// not valid and a dry run? then it can exit with a error
|
|
265
|
+
if (dryRun) {
|
|
266
|
+
spin.fail();
|
|
267
|
+
this.renderBreakingChanges(valid);
|
|
268
|
+
hasErrors = true;
|
|
269
|
+
continue;
|
|
270
|
+
}
|
|
271
|
+
if (!isInteractive()) {
|
|
272
|
+
spin.fail();
|
|
273
|
+
this.renderBreakingChanges(valid);
|
|
274
|
+
this.error('Dangerous changes found - falling back. Re-run the command with the `--force` flag to force deployment.', {
|
|
275
|
+
exit: 1
|
|
276
|
+
});
|
|
277
|
+
}
|
|
278
|
+
spin.stop();
|
|
279
|
+
this.renderBreakingChanges(valid);
|
|
280
|
+
const shouldDeploy = await confirm({
|
|
281
|
+
default: false,
|
|
282
|
+
message: 'Do you want to deploy a new API despite the dangerous changes?'
|
|
283
|
+
});
|
|
284
|
+
if (!shouldDeploy) {
|
|
285
|
+
spin.fail();
|
|
286
|
+
continue;
|
|
287
|
+
}
|
|
288
|
+
spin.succeed();
|
|
289
|
+
} else if (dryRun) {
|
|
290
|
+
spin.succeed();
|
|
291
|
+
this.log('GraphQL API is valid and has no breaking changes');
|
|
292
|
+
continue;
|
|
293
|
+
}
|
|
294
|
+
deployTasks.push({
|
|
295
|
+
dataset,
|
|
296
|
+
enablePlayground,
|
|
297
|
+
projectId,
|
|
298
|
+
schema: apiSpec,
|
|
299
|
+
tag
|
|
300
|
+
});
|
|
301
|
+
}
|
|
302
|
+
// Give some space for deployment tasks
|
|
303
|
+
this.log('');
|
|
304
|
+
for (const task of deployTasks){
|
|
305
|
+
const { dataset, enablePlayground, projectId, schema, tag } = task;
|
|
306
|
+
this.log(`Project: ${projectId}`);
|
|
307
|
+
this.log(`Dataset: ${dataset}`);
|
|
308
|
+
this.log(`Tag: ${tag}`);
|
|
309
|
+
spin = spinner('Deploying GraphQL API').start();
|
|
310
|
+
try {
|
|
311
|
+
const response = await deployGraphQLAPI({
|
|
312
|
+
dataset,
|
|
313
|
+
enablePlayground,
|
|
314
|
+
projectId,
|
|
315
|
+
schema,
|
|
316
|
+
tag
|
|
317
|
+
});
|
|
318
|
+
spin.stop();
|
|
319
|
+
const apiUrl = await getClientUrl(projectId, response.location.replace(/^\/(v1|v\d{4}-\d{2}-\d{2})\//, '/'));
|
|
320
|
+
this.log(`URL: ${apiUrl}`);
|
|
321
|
+
spin.start('Deployed!').succeed();
|
|
322
|
+
this.log('');
|
|
323
|
+
} catch (error) {
|
|
324
|
+
spin.fail();
|
|
325
|
+
debug('Failed to deploy GraphQL API', error);
|
|
326
|
+
this.error('Failed to deploy GraphQL API', {
|
|
327
|
+
exit: 1
|
|
328
|
+
});
|
|
329
|
+
}
|
|
330
|
+
}
|
|
331
|
+
if (hasErrors) {
|
|
332
|
+
this.exit(1);
|
|
333
|
+
}
|
|
334
|
+
}
|
|
335
|
+
filterChanges(valid) {
|
|
336
|
+
const { breakingChanges: breaking, dangerousChanges: dangerous } = valid;
|
|
337
|
+
return {
|
|
338
|
+
breakingChanges: breaking.filter((change)=>!ignoredBreaking.has(change.type)),
|
|
339
|
+
dangerousChanges: dangerous.filter((change)=>!ignoredWarnings.has(change.type))
|
|
340
|
+
};
|
|
341
|
+
}
|
|
342
|
+
getApiIdentifiers(apiDef, datasetFlag, tagFlag) {
|
|
343
|
+
const dataset = datasetFlag || apiDef.dataset;
|
|
344
|
+
const tag = tagFlag || apiDef.tag || 'default';
|
|
345
|
+
const apiName = [
|
|
346
|
+
dataset,
|
|
347
|
+
tag
|
|
348
|
+
].join('/');
|
|
349
|
+
return {
|
|
350
|
+
apiName,
|
|
351
|
+
dataset,
|
|
352
|
+
tag
|
|
353
|
+
};
|
|
354
|
+
}
|
|
355
|
+
isRecognizedApiGeneration(generation) {
|
|
356
|
+
return [
|
|
357
|
+
'gen1',
|
|
358
|
+
'gen2',
|
|
359
|
+
'gen3'
|
|
360
|
+
].includes(generation);
|
|
361
|
+
}
|
|
362
|
+
isResultValid(valid, { force, spin }) {
|
|
363
|
+
const { validationError } = valid;
|
|
364
|
+
if (validationError) {
|
|
365
|
+
spin.fail();
|
|
366
|
+
this.error(`GraphQL schema is not valid:\n\n${validationError}`, {
|
|
367
|
+
exit: 1
|
|
368
|
+
});
|
|
369
|
+
}
|
|
370
|
+
const { breakingChanges, dangerousChanges } = this.filterChanges(valid);
|
|
371
|
+
const hasProblematicChanges = breakingChanges.length > 0 || dangerousChanges.length > 0;
|
|
372
|
+
if (!hasProblematicChanges) {
|
|
373
|
+
spin.succeed();
|
|
374
|
+
return true;
|
|
375
|
+
}
|
|
376
|
+
if (force) {
|
|
377
|
+
spin.text = 'Validating GraphQL API: Dangerous changes. Forced with `--force`.';
|
|
378
|
+
spin.warn();
|
|
379
|
+
return true;
|
|
380
|
+
}
|
|
381
|
+
spin.warn();
|
|
382
|
+
return false;
|
|
383
|
+
}
|
|
384
|
+
renderBreakingChanges(valid) {
|
|
385
|
+
const { breakingChanges, dangerousChanges } = this.filterChanges(valid);
|
|
386
|
+
if (dangerousChanges.length > 0) {
|
|
387
|
+
this.log('\nFound potentially dangerous changes from previous schema:');
|
|
388
|
+
for (const change of dangerousChanges)this.log(` - ${change.description}`);
|
|
389
|
+
}
|
|
390
|
+
if (breakingChanges.length > 0) {
|
|
391
|
+
this.log('\nFound BREAKING changes from previous schema:');
|
|
392
|
+
for (const change of breakingChanges)this.log(` - ${change.description}`);
|
|
393
|
+
}
|
|
394
|
+
this.output.log('');
|
|
395
|
+
}
|
|
396
|
+
async shouldEnablePlayground({ dryRun, playgroundCliFlag, playgroundConfiguration, playgroundCurrentlyEnabled, spin }) {
|
|
397
|
+
// On a dry run, it doesn't matter, return true 🤷♂️
|
|
398
|
+
if (dryRun) {
|
|
399
|
+
return true;
|
|
400
|
+
}
|
|
401
|
+
// Prioritize CLI flag if set
|
|
402
|
+
if (playgroundCliFlag !== undefined) {
|
|
403
|
+
return playgroundCliFlag;
|
|
404
|
+
}
|
|
405
|
+
// If explicitly set true/false in configuration, use that
|
|
406
|
+
if (playgroundConfiguration !== undefined) {
|
|
407
|
+
return playgroundConfiguration;
|
|
408
|
+
}
|
|
409
|
+
// If API is already deployed, use the current state
|
|
410
|
+
if (playgroundCurrentlyEnabled !== undefined) {
|
|
411
|
+
return playgroundCurrentlyEnabled;
|
|
412
|
+
}
|
|
413
|
+
// If no API is deployed, default to true if non-interactive
|
|
414
|
+
if (!isInteractive()) {
|
|
415
|
+
return true;
|
|
416
|
+
}
|
|
417
|
+
// Interactive environment, so prompt the user
|
|
418
|
+
const prevText = spin.text;
|
|
419
|
+
spin.warn();
|
|
420
|
+
const shouldDeploy = await confirm({
|
|
421
|
+
default: true,
|
|
422
|
+
message: 'Do you want to enable a GraphQL playground?'
|
|
423
|
+
});
|
|
424
|
+
spin.clear().start(prevText);
|
|
425
|
+
return shouldDeploy;
|
|
426
|
+
}
|
|
427
|
+
}
|
|
428
|
+
|
|
429
|
+
//# sourceMappingURL=deploy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/commands/graphql/deploy.ts"],"sourcesContent":["import {Flags} from '@oclif/core'\nimport {isInteractive, SanityCommand} from '@sanity/cli-core'\nimport {confirm, spinner} from '@sanity/cli-core/ux'\nimport {get} from 'lodash-es'\n\nimport {extractFromSanitySchema} from '../../actions/graphql/extractFromSanitySchema.js'\nimport gen1 from '../../actions/graphql/gen1/index.js'\nimport gen2 from '../../actions/graphql/gen2/index.js'\nimport gen3 from '../../actions/graphql/gen3/index.js'\nimport {getGraphQLAPIs} from '../../actions/graphql/getGraphQLAPIs.js'\nimport {graphqlDebug} from '../../actions/graphql/graphqlDebug.js'\nimport {resolveApiGeneration} from '../../actions/graphql/resolveApiGeneration.js'\nimport {SchemaError} from '../../actions/graphql/SchemaError.js'\nimport {\n type GeneratedApiSpecification,\n type ResolvedGraphQLAPI,\n type ValidationResponse,\n} from '../../actions/graphql/types.js'\nimport {\n deployGraphQLAPI,\n getClientUrl,\n getCurrentSchemaProps,\n validateGraphQLAPI,\n} from '../../services/graphql.js'\n\ninterface DeployTask {\n dataset: string\n enablePlayground: boolean\n projectId: string\n schema: GeneratedApiSpecification\n tag: string\n}\n\nconst apiIdRegex = /^[a-z0-9_-]+$/\nconst generations = {\n gen1,\n gen2,\n gen3,\n}\n\nconst ignoredBreaking = new Set<string>(['OPTIONAL_INPUT_FIELD_ADDED'])\n// Reserved for future use to filter out specific dangerous change types\nconst ignoredWarnings = new Set<string>()\n\nconst debug = graphqlDebug.extend('deploy')\n\nexport class GraphQLDeployCommand extends SanityCommand<typeof GraphQLDeployCommand> {\n static override description = 'Deploy a GraphQL API from the current Sanity schema'\n\n static override examples = [\n {\n command: '<%= config.bin %> <%= command.id %>',\n description: 'Deploy all defined GraphQL APIs',\n },\n {\n command: '<%= config.bin %> <%= command.id %> --dry-run',\n description: 'Validate defined GraphQL APIs, check for breaking changes, skip deploy',\n },\n {\n command: '<%= config.bin %> <%= command.id %> --api staging --api ios',\n description: 'Deploy only the GraphQL APIs with the IDs \"staging\" and \"ios\"',\n },\n {\n command: '<%= config.bin %> <%= command.id %> --playground',\n description: 'Deploy all defined GraphQL APIs, overriding any playground setting',\n },\n ]\n\n static override flags = {\n api: Flags.string({\n description: 'Only deploy API with this ID. Can be specified multiple times.',\n multiple: true,\n }),\n dataset: Flags.string({\n description: 'Deploy API for the given dataset',\n }),\n 'dry-run': Flags.boolean({\n default: false,\n description: 'Validate defined GraphQL APIs, check for breaking changes, skip deploy',\n }),\n force: Flags.boolean({\n description: 'Deploy API without confirming breaking changes',\n }),\n generation: Flags.string({\n description: 'API generation to deploy (defaults to \"gen3\")',\n options: ['gen1', 'gen2', 'gen3'],\n }),\n 'non-null-document-fields': Flags.boolean({\n description: 'Use non-null document fields (_id, _type etc)',\n }),\n playground: Flags.boolean({\n allowNo: true,\n description: 'Enable GraphQL playground for easier debugging',\n }),\n tag: Flags.string({\n description: 'Deploy API(s) to given tag (defaults to \"default\")',\n }),\n 'with-union-cache': Flags.boolean({\n description:\n 'Enable union cache that optimizes schema generation for schemas with many self referencing types',\n }),\n }\n\n public async run(): Promise<void> {\n const {flags} = await this.parse(GraphQLDeployCommand)\n const {\n api: onlyApis,\n dataset: datasetFlag,\n 'dry-run': dryRun,\n generation: generationFlag,\n 'non-null-document-fields': nonNullDocumentFieldsFlag,\n playground: playgroundFlag,\n tag: tagFlag,\n 'with-union-cache': withUnionCache,\n } = flags\n\n const workDir = (await this.getProjectRoot()).directory\n\n let apiDefs: ResolvedGraphQLAPI[] = []\n let spin: ReturnType<typeof spinner>\n\n try {\n apiDefs = await getGraphQLAPIs(workDir)\n } catch (error) {\n debug('Failed to get GraphQL APIs', error)\n this.error('Failed to get GraphQL APIs', {exit: 1})\n }\n\n const hasMultipleApis = flags.api ? flags.api.length > 1 : apiDefs.length > 1\n\n const usedFlags = [\n datasetFlag && '--dataset',\n tagFlag && '--tag',\n playgroundFlag !== undefined && '--playground',\n generationFlag !== undefined && '--generation',\n nonNullDocumentFieldsFlag !== undefined && '--non-null-document-fields',\n ].filter(Boolean)\n\n if (hasMultipleApis && usedFlags.length > 0) {\n this.warn(`More than one API defined, and ${usedFlags.join('/')} is specified`)\n this.warn(`This will use the specified flag(s) for ALL APIs, overriding config!`)\n\n if (flags.force) {\n this.warn(`--force specified, continuing...`)\n } else {\n const confirmed = await confirm({\n default: false,\n message: 'Continue with flag overrides for all APIs?',\n })\n if (!confirmed) {\n this.error('Operation cancelled', {exit: 1})\n }\n }\n }\n\n const deployTasks: DeployTask[] = []\n let hasErrors = false\n\n for (const apiId of onlyApis || []) {\n if (!apiDefs.some((apiDef) => apiDef.id === apiId)) {\n this.error(`GraphQL API with id \"${apiId}\" not found`, {exit: 1})\n }\n }\n\n const apiNames = new Set<string>()\n const apiIds = new Set<string>()\n\n for (const apiDef of apiDefs) {\n if (onlyApis && (!apiDef.id || !onlyApis.includes(apiDef.id))) {\n continue\n }\n\n const {apiName} = this.getApiIdentifiers(apiDef, datasetFlag, tagFlag)\n if (apiNames.has(apiName)) {\n this.error(`Multiple GraphQL APIs with the same dataset and tag found (${apiName})`, {\n exit: 1,\n })\n }\n\n if (apiDef.id) {\n if (typeof apiDef.id !== 'string' || !apiIdRegex.test(apiDef.id)) {\n this.error(\n `Invalid GraphQL API id \"${apiDef.id}\" - only a-z, 0-9, underscore and dashes are allowed`,\n {exit: 1},\n )\n }\n\n if (apiIds.has(apiDef.id)) {\n this.error(`Multiple GraphQL APIs with the same ID found (${apiDef.id})`, {exit: 1})\n }\n\n apiIds.add(apiDef.id)\n }\n\n apiNames.add(apiName)\n }\n\n if (onlyApis) {\n this.warn(`Deploying only specified APIs: ${onlyApis.join(', ')}`)\n }\n\n let index = -1\n for (const apiDef of apiDefs) {\n if (onlyApis && (!apiDef.id || !onlyApis.includes(apiDef.id))) {\n continue\n }\n\n index++\n\n const {apiName, dataset, tag} = this.getApiIdentifiers(apiDef, datasetFlag, tagFlag)\n const {nonNullDocumentFields, playground, projectId, schema} = apiDef\n spin = spinner(`Generating GraphQL API: ${apiName}`).start()\n\n if (!dataset) {\n spin.fail()\n this.error(`No dataset specified for API at index ${index}`, {exit: 1})\n }\n\n let currentGeneration: string | undefined\n let playgroundEnabled: boolean | undefined\n try {\n const schemaProps = await getCurrentSchemaProps(projectId, dataset, tag)\n currentGeneration = schemaProps.currentGeneration\n playgroundEnabled = schemaProps.playgroundEnabled\n } catch (err) {\n debug('Failed to get current GraphQL schema properties', err)\n spin.fail()\n this.error('Failed to get current GraphQL schema properties', {exit: 1})\n }\n\n // CLI flag takes precedence over configuration\n const specifiedGeneration = generationFlag === undefined ? apiDef.generation : generationFlag\n\n const generation = await resolveApiGeneration({\n currentGeneration,\n force: flags.force,\n index,\n output: this.output,\n specifiedGeneration,\n })\n\n if (!generation) {\n // User cancelled\n spin.fail()\n continue\n }\n\n if (!this.isRecognizedApiGeneration(generation)) {\n spin.fail()\n this.error(`Unknown API generation \"${generation}\" for API at index ${index}`, {exit: 1})\n }\n\n const enablePlayground = await this.shouldEnablePlayground({\n dryRun,\n playgroundCliFlag: playgroundFlag,\n playgroundConfiguration: playground,\n playgroundCurrentlyEnabled: playgroundEnabled,\n spin,\n })\n\n let apiSpec: GeneratedApiSpecification\n try {\n const generateSchema = generations[generation]\n const extracted = extractFromSanitySchema(schema, {\n // Allow CLI flag to override configured setting\n nonNullDocumentFields:\n nonNullDocumentFieldsFlag === undefined\n ? nonNullDocumentFields\n : nonNullDocumentFieldsFlag,\n withUnionCache,\n })\n\n apiSpec = generateSchema(extracted, {filterSuffix: apiDef.filterSuffix})\n } catch (err) {\n debug('Failed to extract schema', err)\n spin.fail()\n\n if (err instanceof SchemaError) {\n err.print(this.output)\n this.error('Failed to extract schema', {exit: 1})\n } else {\n const message = err instanceof Error ? err.message : 'Unknown error'\n this.error(`Failed to extract schema: ${message}`, {exit: 1})\n }\n }\n\n let valid: ValidationResponse | undefined\n try {\n valid = await validateGraphQLAPI({\n dataset,\n enablePlayground,\n projectId,\n schema: apiSpec,\n tag,\n })\n } catch (err) {\n debug('validateGraphQLAPI error', err)\n const validationError = get(err, 'response.body.validationError')\n spin.fail()\n this.error(validationError ?? 'Failed to validate GraphQL API', {exit: 1})\n }\n\n // when the result is not valid and there are breaking changes afoot!\n if (!this.isResultValid(valid, {force: flags.force, spin})) {\n // not valid and a dry run? then it can exit with a error\n if (dryRun) {\n spin.fail()\n this.renderBreakingChanges(valid)\n hasErrors = true\n continue\n }\n\n if (!isInteractive()) {\n spin.fail()\n this.renderBreakingChanges(valid)\n this.error(\n 'Dangerous changes found - falling back. Re-run the command with the `--force` flag to force deployment.',\n {exit: 1},\n )\n }\n\n spin.stop()\n this.renderBreakingChanges(valid)\n const shouldDeploy = await confirm({\n default: false,\n message: 'Do you want to deploy a new API despite the dangerous changes?',\n })\n\n if (!shouldDeploy) {\n spin.fail()\n continue\n }\n\n spin.succeed()\n } else if (dryRun) {\n spin.succeed()\n this.log('GraphQL API is valid and has no breaking changes')\n continue\n }\n\n deployTasks.push({\n dataset,\n enablePlayground,\n projectId,\n schema: apiSpec,\n tag,\n })\n }\n\n // Give some space for deployment tasks\n this.log('')\n\n for (const task of deployTasks) {\n const {dataset, enablePlayground, projectId, schema, tag} = task\n\n this.log(`Project: ${projectId}`)\n this.log(`Dataset: ${dataset}`)\n this.log(`Tag: ${tag}`)\n\n spin = spinner('Deploying GraphQL API').start()\n\n try {\n const response = await deployGraphQLAPI({\n dataset,\n enablePlayground,\n projectId,\n schema,\n tag,\n })\n\n spin.stop()\n const apiUrl = await getClientUrl(\n projectId,\n response.location.replace(/^\\/(v1|v\\d{4}-\\d{2}-\\d{2})\\//, '/'),\n )\n this.log(`URL: ${apiUrl}`)\n spin.start('Deployed!').succeed()\n this.log('')\n } catch (error) {\n spin.fail()\n debug('Failed to deploy GraphQL API', error)\n this.error('Failed to deploy GraphQL API', {exit: 1})\n }\n }\n\n if (hasErrors) {\n this.exit(1)\n }\n }\n\n private filterChanges(valid: ValidationResponse) {\n const {breakingChanges: breaking, dangerousChanges: dangerous} = valid\n return {\n breakingChanges: breaking.filter((change) => !ignoredBreaking.has(change.type)),\n dangerousChanges: dangerous.filter((change) => !ignoredWarnings.has(change.type)),\n }\n }\n\n private getApiIdentifiers(apiDef: ResolvedGraphQLAPI, datasetFlag?: string, tagFlag?: string) {\n const dataset = datasetFlag || apiDef.dataset\n const tag = tagFlag || apiDef.tag || 'default'\n const apiName = [dataset, tag].join('/')\n return {apiName, dataset, tag}\n }\n\n private isRecognizedApiGeneration(generation: string): generation is 'gen1' | 'gen2' | 'gen3' {\n return ['gen1', 'gen2', 'gen3'].includes(generation)\n }\n\n private isResultValid(\n valid: ValidationResponse,\n {force, spin}: {force?: boolean; spin: ReturnType<typeof spinner>},\n ) {\n const {validationError} = valid\n if (validationError) {\n spin.fail()\n this.error(`GraphQL schema is not valid:\\n\\n${validationError}`, {exit: 1})\n }\n\n const {breakingChanges, dangerousChanges} = this.filterChanges(valid)\n\n const hasProblematicChanges = breakingChanges.length > 0 || dangerousChanges.length > 0\n\n if (!hasProblematicChanges) {\n spin.succeed()\n return true\n }\n\n if (force) {\n spin.text = 'Validating GraphQL API: Dangerous changes. Forced with `--force`.'\n spin.warn()\n return true\n }\n\n spin.warn()\n return false\n }\n\n private renderBreakingChanges(valid: ValidationResponse) {\n const {breakingChanges, dangerousChanges} = this.filterChanges(valid)\n\n if (dangerousChanges.length > 0) {\n this.log('\\nFound potentially dangerous changes from previous schema:')\n for (const change of dangerousChanges) this.log(` - ${change.description}`)\n }\n\n if (breakingChanges.length > 0) {\n this.log('\\nFound BREAKING changes from previous schema:')\n for (const change of breakingChanges) this.log(` - ${change.description}`)\n }\n\n this.output.log('')\n }\n\n private async shouldEnablePlayground({\n dryRun,\n playgroundCliFlag,\n playgroundConfiguration,\n playgroundCurrentlyEnabled,\n spin,\n }: {\n dryRun: boolean\n playgroundCliFlag?: boolean\n playgroundConfiguration?: boolean\n playgroundCurrentlyEnabled?: boolean\n spin: ReturnType<typeof spinner>\n }): Promise<boolean> {\n // On a dry run, it doesn't matter, return true 🤷♂️\n if (dryRun) {\n return true\n }\n\n // Prioritize CLI flag if set\n if (playgroundCliFlag !== undefined) {\n return playgroundCliFlag\n }\n\n // If explicitly set true/false in configuration, use that\n if (playgroundConfiguration !== undefined) {\n return playgroundConfiguration\n }\n\n // If API is already deployed, use the current state\n if (playgroundCurrentlyEnabled !== undefined) {\n return playgroundCurrentlyEnabled\n }\n\n // If no API is deployed, default to true if non-interactive\n if (!isInteractive()) {\n return true\n }\n\n // Interactive environment, so prompt the user\n const prevText = spin.text\n spin.warn()\n const shouldDeploy = await confirm({\n default: true,\n message: 'Do you want to enable a GraphQL playground?',\n })\n spin.clear().start(prevText)\n\n return shouldDeploy\n }\n}\n"],"names":["Flags","isInteractive","SanityCommand","confirm","spinner","get","extractFromSanitySchema","gen1","gen2","gen3","getGraphQLAPIs","graphqlDebug","resolveApiGeneration","SchemaError","deployGraphQLAPI","getClientUrl","getCurrentSchemaProps","validateGraphQLAPI","apiIdRegex","generations","ignoredBreaking","Set","ignoredWarnings","debug","extend","GraphQLDeployCommand","description","examples","command","flags","api","string","multiple","dataset","boolean","default","force","generation","options","playground","allowNo","tag","run","parse","onlyApis","datasetFlag","dryRun","generationFlag","nonNullDocumentFieldsFlag","playgroundFlag","tagFlag","withUnionCache","workDir","getProjectRoot","directory","apiDefs","spin","error","exit","hasMultipleApis","length","usedFlags","undefined","filter","Boolean","warn","join","confirmed","message","deployTasks","hasErrors","apiId","some","apiDef","id","apiNames","apiIds","includes","apiName","getApiIdentifiers","has","test","add","index","nonNullDocumentFields","projectId","schema","start","fail","currentGeneration","playgroundEnabled","schemaProps","err","specifiedGeneration","output","isRecognizedApiGeneration","enablePlayground","shouldEnablePlayground","playgroundCliFlag","playgroundConfiguration","playgroundCurrentlyEnabled","apiSpec","generateSchema","extracted","filterSuffix","print","Error","valid","validationError","isResultValid","renderBreakingChanges","stop","shouldDeploy","succeed","log","push","task","response","apiUrl","location","replace","filterChanges","breakingChanges","breaking","dangerousChanges","dangerous","change","type","hasProblematicChanges","text","prevText","clear"],"mappings":"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"}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { styleText } from 'node:util';
|
|
2
|
+
import { getProjectCliClient, SanityCommand, subdebug } from '@sanity/cli-core';
|
|
3
|
+
import { GRAPHQL_API_VERSION, listGraphQLEndpoints } from '../../services/graphql.js';
|
|
4
|
+
import { NO_PROJECT_ID } from '../../util/errorMessages.js';
|
|
5
|
+
const listGraphQLDebug = subdebug('graphql:list');
|
|
6
|
+
export class List extends SanityCommand {
|
|
7
|
+
static description = 'List all GraphQL endpoints deployed for this project';
|
|
8
|
+
static examples = [
|
|
9
|
+
{
|
|
10
|
+
command: '<%= config.bin %> <%= command.id %>',
|
|
11
|
+
description: 'List GraphQL endpoints for the current project'
|
|
12
|
+
}
|
|
13
|
+
];
|
|
14
|
+
async run() {
|
|
15
|
+
await this.parse(List);
|
|
16
|
+
const projectId = await this.getProjectId();
|
|
17
|
+
if (!projectId) {
|
|
18
|
+
this.error(NO_PROJECT_ID, {
|
|
19
|
+
exit: 1
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
let endpoints;
|
|
23
|
+
try {
|
|
24
|
+
endpoints = await listGraphQLEndpoints(projectId);
|
|
25
|
+
} catch (error) {
|
|
26
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
27
|
+
listGraphQLDebug(`Error fetching GraphQL endpoints for project ${projectId}`, error);
|
|
28
|
+
this.error(`GraphQL endpoints list retrieval failed:\n${message}`, {
|
|
29
|
+
exit: 1
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
if (!endpoints || endpoints.length === 0) {
|
|
33
|
+
this.log("This project doesn't have any GraphQL endpoints deployed.");
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
const client = await getProjectCliClient({
|
|
37
|
+
apiVersion: GRAPHQL_API_VERSION,
|
|
38
|
+
projectId
|
|
39
|
+
});
|
|
40
|
+
this.log('Here are the GraphQL endpoints deployed for this project:');
|
|
41
|
+
for (const [index, endpoint] of endpoints.entries()){
|
|
42
|
+
const { dataset, tag } = endpoint;
|
|
43
|
+
const url = client.getUrl(`/graphql/${dataset}/${tag}`);
|
|
44
|
+
this.log(`${index + 1}. ${styleText('bold', 'Dataset:')} ${dataset}`);
|
|
45
|
+
this.log(` ${styleText('bold', 'Tag:')} ${tag}`);
|
|
46
|
+
this.log(` ${styleText('bold', 'Generation:')} ${endpoint.generation}`);
|
|
47
|
+
this.log(` ${styleText('bold', 'Playground:')} ${endpoint.playgroundEnabled}`);
|
|
48
|
+
this.log(` ${styleText('bold', 'URL:')} ${url}\n`);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
//# sourceMappingURL=list.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/commands/graphql/list.ts"],"sourcesContent":["import {styleText} from 'node:util'\n\nimport {getProjectCliClient, SanityCommand, subdebug} from '@sanity/cli-core'\n\nimport {\n GRAPHQL_API_VERSION,\n type GraphQLEndpoint,\n listGraphQLEndpoints,\n} from '../../services/graphql.js'\nimport {NO_PROJECT_ID} from '../../util/errorMessages.js'\n\nconst listGraphQLDebug = subdebug('graphql:list')\n\nexport class List extends SanityCommand<typeof List> {\n static override description = 'List all GraphQL endpoints deployed for this project'\n static override examples = [\n {\n command: '<%= config.bin %> <%= command.id %>',\n description: 'List GraphQL endpoints for the current project',\n },\n ]\n\n public async run(): Promise<void> {\n await this.parse(List)\n\n const projectId = await this.getProjectId()\n if (!projectId) {\n this.error(NO_PROJECT_ID, {exit: 1})\n }\n\n let endpoints: GraphQLEndpoint[] | undefined\n try {\n endpoints = await listGraphQLEndpoints(projectId)\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error)\n\n listGraphQLDebug(`Error fetching GraphQL endpoints for project ${projectId}`, error)\n this.error(`GraphQL endpoints list retrieval failed:\\n${message}`, {exit: 1})\n }\n\n if (!endpoints || endpoints.length === 0) {\n this.log(\"This project doesn't have any GraphQL endpoints deployed.\")\n return\n }\n\n const client = await getProjectCliClient({\n apiVersion: GRAPHQL_API_VERSION,\n projectId,\n })\n\n this.log('Here are the GraphQL endpoints deployed for this project:')\n for (const [index, endpoint] of endpoints.entries()) {\n const {dataset, tag} = endpoint\n const url = client.getUrl(`/graphql/${dataset}/${tag}`)\n\n this.log(`${index + 1}. ${styleText('bold', 'Dataset:')} ${dataset}`)\n this.log(` ${styleText('bold', 'Tag:')} ${tag}`)\n this.log(` ${styleText('bold', 'Generation:')} ${endpoint.generation}`)\n this.log(` ${styleText('bold', 'Playground:')} ${endpoint.playgroundEnabled}`)\n this.log(` ${styleText('bold', 'URL:')} ${url}\\n`)\n }\n }\n}\n"],"names":["styleText","getProjectCliClient","SanityCommand","subdebug","GRAPHQL_API_VERSION","listGraphQLEndpoints","NO_PROJECT_ID","listGraphQLDebug","List","description","examples","command","run","parse","projectId","getProjectId","error","exit","endpoints","message","Error","String","length","log","client","apiVersion","index","endpoint","entries","dataset","tag","url","getUrl","generation","playgroundEnabled"],"mappings":"AAAA,SAAQA,SAAS,QAAO,YAAW;AAEnC,SAAQC,mBAAmB,EAAEC,aAAa,EAAEC,QAAQ,QAAO,mBAAkB;AAE7E,SACEC,mBAAmB,EAEnBC,oBAAoB,QACf,4BAA2B;AAClC,SAAQC,aAAa,QAAO,8BAA6B;AAEzD,MAAMC,mBAAmBJ,SAAS;AAElC,OAAO,MAAMK,aAAaN;IACxB,OAAgBO,cAAc,uDAAsD;IACpF,OAAgBC,WAAW;QACzB;YACEC,SAAS;YACTF,aAAa;QACf;KACD,CAAA;IAED,MAAaG,MAAqB;QAChC,MAAM,IAAI,CAACC,KAAK,CAACL;QAEjB,MAAMM,YAAY,MAAM,IAAI,CAACC,YAAY;QACzC,IAAI,CAACD,WAAW;YACd,IAAI,CAACE,KAAK,CAACV,eAAe;gBAACW,MAAM;YAAC;QACpC;QAEA,IAAIC;QACJ,IAAI;YACFA,YAAY,MAAMb,qBAAqBS;QACzC,EAAE,OAAOE,OAAO;YACd,MAAMG,UAAUH,iBAAiBI,QAAQJ,MAAMG,OAAO,GAAGE,OAAOL;YAEhET,iBAAiB,CAAC,6CAA6C,EAAEO,WAAW,EAAEE;YAC9E,IAAI,CAACA,KAAK,CAAC,CAAC,0CAA0C,EAAEG,SAAS,EAAE;gBAACF,MAAM;YAAC;QAC7E;QAEA,IAAI,CAACC,aAAaA,UAAUI,MAAM,KAAK,GAAG;YACxC,IAAI,CAACC,GAAG,CAAC;YACT;QACF;QAEA,MAAMC,SAAS,MAAMvB,oBAAoB;YACvCwB,YAAYrB;YACZU;QACF;QAEA,IAAI,CAACS,GAAG,CAAC;QACT,KAAK,MAAM,CAACG,OAAOC,SAAS,IAAIT,UAAUU,OAAO,GAAI;YACnD,MAAM,EAACC,OAAO,EAAEC,GAAG,EAAC,GAAGH;YACvB,MAAMI,MAAMP,OAAOQ,MAAM,CAAC,CAAC,SAAS,EAAEH,QAAQ,CAAC,EAAEC,KAAK;YAEtD,IAAI,CAACP,GAAG,CAAC,GAAGG,QAAQ,EAAE,GAAG,EAAE1B,UAAU,QAAQ,YAAY,KAAK,EAAE6B,SAAS;YACzE,IAAI,CAACN,GAAG,CAAC,CAAC,IAAI,EAAEvB,UAAU,QAAQ,QAAQ,SAAS,EAAE8B,KAAK;YAC1D,IAAI,CAACP,GAAG,CAAC,CAAC,IAAI,EAAEvB,UAAU,QAAQ,eAAe,EAAE,EAAE2B,SAASM,UAAU,EAAE;YAC1E,IAAI,CAACV,GAAG,CAAC,CAAC,IAAI,EAAEvB,UAAU,QAAQ,eAAe,EAAE,EAAE2B,SAASO,iBAAiB,EAAE;YACjF,IAAI,CAACX,GAAG,CAAC,CAAC,IAAI,EAAEvB,UAAU,QAAQ,QAAQ,EAAE,EAAE+B,IAAI,EAAE,CAAC;QACvD;IACF;AACF"}
|