skywriter 1.0.0
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 +16 -0
- package/README.md +852 -0
- package/dist/cli/commands/host.d.ts +6 -0
- package/dist/cli/commands/host.d.ts.map +1 -0
- package/dist/cli/commands/host.js +52 -0
- package/dist/cli/commands/host.js.map +1 -0
- package/dist/cli/commands/init.d.ts +15 -0
- package/dist/cli/commands/init.d.ts.map +1 -0
- package/dist/cli/commands/init.js +207 -0
- package/dist/cli/commands/init.js.map +1 -0
- package/dist/cli/commands/login.d.ts +18 -0
- package/dist/cli/commands/login.d.ts.map +1 -0
- package/dist/cli/commands/login.js +152 -0
- package/dist/cli/commands/login.js.map +1 -0
- package/dist/cli/commands/logout.d.ts +15 -0
- package/dist/cli/commands/logout.d.ts.map +1 -0
- package/dist/cli/commands/logout.js +62 -0
- package/dist/cli/commands/logout.js.map +1 -0
- package/dist/cli/commands/pull.d.ts +19 -0
- package/dist/cli/commands/pull.d.ts.map +1 -0
- package/dist/cli/commands/pull.js +44 -0
- package/dist/cli/commands/pull.js.map +1 -0
- package/dist/cli/commands/push.d.ts +9 -0
- package/dist/cli/commands/push.d.ts.map +1 -0
- package/dist/cli/commands/push.js +49 -0
- package/dist/cli/commands/push.js.map +1 -0
- package/dist/cli/commands/removeServer.d.ts +9 -0
- package/dist/cli/commands/removeServer.d.ts.map +1 -0
- package/dist/cli/commands/removeServer.js +55 -0
- package/dist/cli/commands/removeServer.js.map +1 -0
- package/dist/cli/commands/render.d.ts +6 -0
- package/dist/cli/commands/render.d.ts.map +1 -0
- package/dist/cli/commands/render.js +11 -0
- package/dist/cli/commands/render.js.map +1 -0
- package/dist/cli/commands/serve.d.ts +7 -0
- package/dist/cli/commands/serve.d.ts.map +1 -0
- package/dist/cli/commands/serve.js +55 -0
- package/dist/cli/commands/serve.js.map +1 -0
- package/dist/cli/commands/sessions.d.ts +6 -0
- package/dist/cli/commands/sessions.d.ts.map +1 -0
- package/dist/cli/commands/sessions.js +24 -0
- package/dist/cli/commands/sessions.js.map +1 -0
- package/dist/cli/commands/settings.d.ts +10 -0
- package/dist/cli/commands/settings.d.ts.map +1 -0
- package/dist/cli/commands/settings.js +69 -0
- package/dist/cli/commands/settings.js.map +1 -0
- package/dist/cli/commands/switchServer.d.ts +9 -0
- package/dist/cli/commands/switchServer.d.ts.map +1 -0
- package/dist/cli/commands/switchServer.js +52 -0
- package/dist/cli/commands/switchServer.js.map +1 -0
- package/dist/cli/commands/vscodeInit.d.ts +13 -0
- package/dist/cli/commands/vscodeInit.d.ts.map +1 -0
- package/dist/cli/commands/vscodeInit.js +152 -0
- package/dist/cli/commands/vscodeInit.js.map +1 -0
- package/dist/cli/commands/whoami.d.ts +6 -0
- package/dist/cli/commands/whoami.d.ts.map +1 -0
- package/dist/cli/commands/whoami.js +67 -0
- package/dist/cli/commands/whoami.js.map +1 -0
- package/dist/cli/index.d.ts +3 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +5 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/middleware/checkDuplicatePath.d.ts +19 -0
- package/dist/cli/middleware/checkDuplicatePath.d.ts.map +1 -0
- package/dist/cli/middleware/checkDuplicatePath.js +45 -0
- package/dist/cli/middleware/checkDuplicatePath.js.map +1 -0
- package/dist/cli/middleware/redirectRoot.d.ts +18 -0
- package/dist/cli/middleware/redirectRoot.d.ts.map +1 -0
- package/dist/cli/middleware/redirectRoot.js +44 -0
- package/dist/cli/middleware/redirectRoot.js.map +1 -0
- package/dist/cli/middleware/serveDocument.d.ts +10 -0
- package/dist/cli/middleware/serveDocument.d.ts.map +1 -0
- package/dist/cli/middleware/serveDocument.js +104 -0
- package/dist/cli/middleware/serveDocument.js.map +1 -0
- package/dist/cli/middleware/serveUploads.d.ts +20 -0
- package/dist/cli/middleware/serveUploads.d.ts.map +1 -0
- package/dist/cli/middleware/serveUploads.js +93 -0
- package/dist/cli/middleware/serveUploads.js.map +1 -0
- package/dist/cli/middleware/types.d.ts +43 -0
- package/dist/cli/middleware/types.d.ts.map +1 -0
- package/dist/cli/middleware/types.js +2 -0
- package/dist/cli/middleware/types.js.map +1 -0
- package/dist/cli/pathOperations/deletePathUploads.d.ts +6 -0
- package/dist/cli/pathOperations/deletePathUploads.d.ts.map +1 -0
- package/dist/cli/pathOperations/deletePathUploads.js +68 -0
- package/dist/cli/pathOperations/deletePathUploads.js.map +1 -0
- package/dist/cli/pathOperations/downloadPathUploads.d.ts +6 -0
- package/dist/cli/pathOperations/downloadPathUploads.d.ts.map +1 -0
- package/dist/cli/pathOperations/downloadPathUploads.js +156 -0
- package/dist/cli/pathOperations/downloadPathUploads.js.map +1 -0
- package/dist/cli/pathOperations/pullPathViaGit.d.ts +9 -0
- package/dist/cli/pathOperations/pullPathViaGit.d.ts.map +1 -0
- package/dist/cli/pathOperations/pullPathViaGit.js +86 -0
- package/dist/cli/pathOperations/pullPathViaGit.js.map +1 -0
- package/dist/cli/pathOperations/pullPathViaTar.d.ts +14 -0
- package/dist/cli/pathOperations/pullPathViaTar.d.ts.map +1 -0
- package/dist/cli/pathOperations/pullPathViaTar.js +252 -0
- package/dist/cli/pathOperations/pullPathViaTar.js.map +1 -0
- package/dist/cli/pathOperations/pushPathViaGit.d.ts +9 -0
- package/dist/cli/pathOperations/pushPathViaGit.d.ts.map +1 -0
- package/dist/cli/pathOperations/pushPathViaGit.js +49 -0
- package/dist/cli/pathOperations/pushPathViaGit.js.map +1 -0
- package/dist/cli/pathOperations/pushPathViaTar.d.ts +6 -0
- package/dist/cli/pathOperations/pushPathViaTar.d.ts.map +1 -0
- package/dist/cli/pathOperations/pushPathViaTar.js +63 -0
- package/dist/cli/pathOperations/pushPathViaTar.js.map +1 -0
- package/dist/cli/pathOperations/uploadPathUploads.d.ts +6 -0
- package/dist/cli/pathOperations/uploadPathUploads.d.ts.map +1 -0
- package/dist/cli/pathOperations/uploadPathUploads.js +114 -0
- package/dist/cli/pathOperations/uploadPathUploads.js.map +1 -0
- package/dist/cli/pathOperations/validatePathSettings.d.ts +14 -0
- package/dist/cli/pathOperations/validatePathSettings.d.ts.map +1 -0
- package/dist/cli/pathOperations/validatePathSettings.js +191 -0
- package/dist/cli/pathOperations/validatePathSettings.js.map +1 -0
- package/dist/cli/utils/assemble.d.ts +22 -0
- package/dist/cli/utils/assemble.d.ts.map +1 -0
- package/dist/cli/utils/assemble.js +219 -0
- package/dist/cli/utils/assemble.js.map +1 -0
- package/dist/cli/utils/cliName.d.ts +3 -0
- package/dist/cli/utils/cliName.d.ts.map +1 -0
- package/dist/cli/utils/cliName.js +17 -0
- package/dist/cli/utils/cliName.js.map +1 -0
- package/dist/cli/utils/codeWorkspace.d.ts +13 -0
- package/dist/cli/utils/codeWorkspace.d.ts.map +1 -0
- package/dist/cli/utils/codeWorkspace.js +20 -0
- package/dist/cli/utils/codeWorkspace.js.map +1 -0
- package/dist/cli/utils/colors.d.ts +14 -0
- package/dist/cli/utils/colors.d.ts.map +1 -0
- package/dist/cli/utils/colors.js +22 -0
- package/dist/cli/utils/colors.js.map +1 -0
- package/dist/cli/utils/config.d.ts +35 -0
- package/dist/cli/utils/config.d.ts.map +1 -0
- package/dist/cli/utils/config.js +95 -0
- package/dist/cli/utils/config.js.map +1 -0
- package/dist/cli/utils/copilotInstructions.d.ts +5 -0
- package/dist/cli/utils/copilotInstructions.d.ts.map +1 -0
- package/dist/cli/utils/copilotInstructions.js +101 -0
- package/dist/cli/utils/copilotInstructions.js.map +1 -0
- package/dist/cli/utils/createLoggedFs.d.ts +17 -0
- package/dist/cli/utils/createLoggedFs.d.ts.map +1 -0
- package/dist/cli/utils/createLoggedFs.js +106 -0
- package/dist/cli/utils/createLoggedFs.js.map +1 -0
- package/dist/cli/utils/credentials.d.ts +38 -0
- package/dist/cli/utils/credentials.d.ts.map +1 -0
- package/dist/cli/utils/credentials.js +400 -0
- package/dist/cli/utils/credentials.js.map +1 -0
- package/dist/cli/utils/discover.d.ts +26 -0
- package/dist/cli/utils/discover.d.ts.map +1 -0
- package/dist/cli/utils/discover.js +209 -0
- package/dist/cli/utils/discover.js.map +1 -0
- package/dist/cli/utils/formatPlan.d.ts +40 -0
- package/dist/cli/utils/formatPlan.d.ts.map +1 -0
- package/dist/cli/utils/formatPlan.js +148 -0
- package/dist/cli/utils/formatPlan.js.map +1 -0
- package/dist/cli/utils/git.d.ts +17 -0
- package/dist/cli/utils/git.d.ts.map +1 -0
- package/dist/cli/utils/git.js +57 -0
- package/dist/cli/utils/git.js.map +1 -0
- package/dist/cli/utils/gitUrl.d.ts +7 -0
- package/dist/cli/utils/gitUrl.d.ts.map +1 -0
- package/dist/cli/utils/gitUrl.js +23 -0
- package/dist/cli/utils/gitUrl.js.map +1 -0
- package/dist/cli/utils/log.d.ts +22 -0
- package/dist/cli/utils/log.d.ts.map +1 -0
- package/dist/cli/utils/log.js +31 -0
- package/dist/cli/utils/log.js.map +1 -0
- package/dist/cli/utils/logData.d.ts +5 -0
- package/dist/cli/utils/logData.d.ts.map +1 -0
- package/dist/cli/utils/logData.js +65 -0
- package/dist/cli/utils/logData.js.map +1 -0
- package/dist/cli/utils/loggedFetch.d.ts +4 -0
- package/dist/cli/utils/loggedFetch.d.ts.map +1 -0
- package/dist/cli/utils/loggedFetch.js +15 -0
- package/dist/cli/utils/loggedFetch.js.map +1 -0
- package/dist/cli/utils/pageContext.d.ts +50 -0
- package/dist/cli/utils/pageContext.d.ts.map +1 -0
- package/dist/cli/utils/pageContext.js +86 -0
- package/dist/cli/utils/pageContext.js.map +1 -0
- package/dist/cli/utils/parseDocumentPath.d.ts +13 -0
- package/dist/cli/utils/parseDocumentPath.d.ts.map +1 -0
- package/dist/cli/utils/parseDocumentPath.js +35 -0
- package/dist/cli/utils/parseDocumentPath.js.map +1 -0
- package/dist/cli/utils/populateCache.d.ts +12 -0
- package/dist/cli/utils/populateCache.d.ts.map +1 -0
- package/dist/cli/utils/populateCache.js +21 -0
- package/dist/cli/utils/populateCache.js.map +1 -0
- package/dist/cli/utils/prefixLog.d.ts +21 -0
- package/dist/cli/utils/prefixLog.d.ts.map +1 -0
- package/dist/cli/utils/prefixLog.js +73 -0
- package/dist/cli/utils/prefixLog.js.map +1 -0
- package/dist/cli/utils/program.d.ts +7 -0
- package/dist/cli/utils/program.d.ts.map +1 -0
- package/dist/cli/utils/program.js +266 -0
- package/dist/cli/utils/program.js.map +1 -0
- package/dist/cli/utils/promptExec.d.ts +27 -0
- package/dist/cli/utils/promptExec.d.ts.map +1 -0
- package/dist/cli/utils/promptExec.js +47 -0
- package/dist/cli/utils/promptExec.js.map +1 -0
- package/dist/cli/utils/pullHarness.d.ts +15 -0
- package/dist/cli/utils/pullHarness.d.ts.map +1 -0
- package/dist/cli/utils/pullHarness.js +101 -0
- package/dist/cli/utils/pullHarness.js.map +1 -0
- package/dist/cli/utils/pullViaGit.d.ts +6 -0
- package/dist/cli/utils/pullViaGit.d.ts.map +1 -0
- package/dist/cli/utils/pullViaGit.js +13 -0
- package/dist/cli/utils/pullViaGit.js.map +1 -0
- package/dist/cli/utils/pullViaTar.d.ts +10 -0
- package/dist/cli/utils/pullViaTar.d.ts.map +1 -0
- package/dist/cli/utils/pullViaTar.js +15 -0
- package/dist/cli/utils/pullViaTar.js.map +1 -0
- package/dist/cli/utils/pushHarness.d.ts +24 -0
- package/dist/cli/utils/pushHarness.d.ts.map +1 -0
- package/dist/cli/utils/pushHarness.js +82 -0
- package/dist/cli/utils/pushHarness.js.map +1 -0
- package/dist/cli/utils/pushViaGit.d.ts +6 -0
- package/dist/cli/utils/pushViaGit.d.ts.map +1 -0
- package/dist/cli/utils/pushViaGit.js +16 -0
- package/dist/cli/utils/pushViaGit.js.map +1 -0
- package/dist/cli/utils/pushViaTar.d.ts +6 -0
- package/dist/cli/utils/pushViaTar.d.ts.map +1 -0
- package/dist/cli/utils/pushViaTar.js +9 -0
- package/dist/cli/utils/pushViaTar.js.map +1 -0
- package/dist/cli/utils/resolveTarget.d.ts +23 -0
- package/dist/cli/utils/resolveTarget.d.ts.map +1 -0
- package/dist/cli/utils/resolveTarget.js +43 -0
- package/dist/cli/utils/resolveTarget.js.map +1 -0
- package/dist/cli/utils/settingsValidation.d.ts +23 -0
- package/dist/cli/utils/settingsValidation.d.ts.map +1 -0
- package/dist/cli/utils/settingsValidation.js +176 -0
- package/dist/cli/utils/settingsValidation.js.map +1 -0
- package/dist/cli/utils/types.d.ts +33 -0
- package/dist/cli/utils/types.d.ts.map +1 -0
- package/dist/cli/utils/types.js +2 -0
- package/dist/cli/utils/types.js.map +1 -0
- package/dist/cli/utils/validateAndGetFilesFromDir.d.ts +10 -0
- package/dist/cli/utils/validateAndGetFilesFromDir.d.ts.map +1 -0
- package/dist/cli/utils/validateAndGetFilesFromDir.js +74 -0
- package/dist/cli/utils/validateAndGetFilesFromDir.js.map +1 -0
- package/dist/cli/utils/watchForChanges.d.ts +7 -0
- package/dist/cli/utils/watchForChanges.d.ts.map +1 -0
- package/dist/cli/utils/watchForChanges.js +44 -0
- package/dist/cli/utils/watchForChanges.js.map +1 -0
- package/dist/db/index.d.ts +5 -0
- package/dist/db/index.d.ts.map +1 -0
- package/dist/db/index.js +23 -0
- package/dist/db/index.js.map +1 -0
- package/dist/editor.bundle.dev.js +30823 -0
- package/dist/editor.bundle.dev.js.map +7 -0
- package/dist/editor.bundle.js +30347 -0
- package/dist/editor.bundle.js.map +7 -0
- package/dist/editor.bundle.prod.js +1373 -0
- package/dist/index.d.ts +5 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +4 -0
- package/dist/index.js.map +1 -0
- package/dist/operations/addRedirect.d.ts +20 -0
- package/dist/operations/addRedirect.d.ts.map +1 -0
- package/dist/operations/addRedirect.js +46 -0
- package/dist/operations/addRedirect.js.map +1 -0
- package/dist/operations/addUpload.d.ts +29 -0
- package/dist/operations/addUpload.d.ts.map +1 -0
- package/dist/operations/addUpload.js +96 -0
- package/dist/operations/addUpload.js.map +1 -0
- package/dist/operations/addUploadsFromContent.d.ts +27 -0
- package/dist/operations/addUploadsFromContent.d.ts.map +1 -0
- package/dist/operations/addUploadsFromContent.js +311 -0
- package/dist/operations/addUploadsFromContent.js.map +1 -0
- package/dist/operations/clearDraft.d.ts +17 -0
- package/dist/operations/clearDraft.d.ts.map +1 -0
- package/dist/operations/clearDraft.js +56 -0
- package/dist/operations/clearDraft.js.map +1 -0
- package/dist/operations/createDocumentRecord.d.ts +11 -0
- package/dist/operations/createDocumentRecord.d.ts.map +1 -0
- package/dist/operations/createDocumentRecord.js +100 -0
- package/dist/operations/createDocumentRecord.js.map +1 -0
- package/dist/operations/createRoute.d.ts +6 -0
- package/dist/operations/createRoute.d.ts.map +1 -0
- package/dist/operations/createRoute.js +10 -0
- package/dist/operations/createRoute.js.map +1 -0
- package/dist/operations/createSession.d.ts +21 -0
- package/dist/operations/createSession.d.ts.map +1 -0
- package/dist/operations/createSession.js +27 -0
- package/dist/operations/createSession.js.map +1 -0
- package/dist/operations/deleteSession.d.ts +13 -0
- package/dist/operations/deleteSession.d.ts.map +1 -0
- package/dist/operations/deleteSession.js +15 -0
- package/dist/operations/deleteSession.js.map +1 -0
- package/dist/operations/findDocument.d.ts +18 -0
- package/dist/operations/findDocument.d.ts.map +1 -0
- package/dist/operations/findDocument.js +53 -0
- package/dist/operations/findDocument.js.map +1 -0
- package/dist/operations/getAllUploadsForDocument.d.ts +11 -0
- package/dist/operations/getAllUploadsForDocument.d.ts.map +1 -0
- package/dist/operations/getAllUploadsForDocument.js +15 -0
- package/dist/operations/getAllUploadsForDocument.js.map +1 -0
- package/dist/operations/getDocumentClientState.d.ts +30 -0
- package/dist/operations/getDocumentClientState.d.ts.map +1 -0
- package/dist/operations/getDocumentClientState.js +246 -0
- package/dist/operations/getDocumentClientState.js.map +1 -0
- package/dist/operations/getDocumentInstance.d.ts +7 -0
- package/dist/operations/getDocumentInstance.d.ts.map +1 -0
- package/dist/operations/getDocumentInstance.js +32 -0
- package/dist/operations/getDocumentInstance.js.map +1 -0
- package/dist/operations/getDocumentRecord.d.ts +6 -0
- package/dist/operations/getDocumentRecord.d.ts.map +1 -0
- package/dist/operations/getDocumentRecord.js +8 -0
- package/dist/operations/getDocumentRecord.js.map +1 -0
- package/dist/operations/getDualDocument.d.ts +28 -0
- package/dist/operations/getDualDocument.d.ts.map +1 -0
- package/dist/operations/getDualDocument.js +81 -0
- package/dist/operations/getDualDocument.js.map +1 -0
- package/dist/operations/getDualDocuments.d.ts +26 -0
- package/dist/operations/getDualDocuments.d.ts.map +1 -0
- package/dist/operations/getDualDocuments.js +130 -0
- package/dist/operations/getDualDocuments.js.map +1 -0
- package/dist/operations/getOptimisticDocument.d.ts +6 -0
- package/dist/operations/getOptimisticDocument.d.ts.map +1 -0
- package/dist/operations/getOptimisticDocument.js +30 -0
- package/dist/operations/getOptimisticDocument.js.map +1 -0
- package/dist/operations/getPage.d.ts +18 -0
- package/dist/operations/getPage.d.ts.map +1 -0
- package/dist/operations/getPage.js +31 -0
- package/dist/operations/getPage.js.map +1 -0
- package/dist/operations/getPages.d.ts +18 -0
- package/dist/operations/getPages.d.ts.map +1 -0
- package/dist/operations/getPages.js +30 -0
- package/dist/operations/getPages.js.map +1 -0
- package/dist/operations/getRedirects.d.ts +13 -0
- package/dist/operations/getRedirects.d.ts.map +1 -0
- package/dist/operations/getRedirects.js +30 -0
- package/dist/operations/getRedirects.js.map +1 -0
- package/dist/operations/getRenderDocument.d.ts +18 -0
- package/dist/operations/getRenderDocument.d.ts.map +1 -0
- package/dist/operations/getRenderDocument.js +27 -0
- package/dist/operations/getRenderDocument.js.map +1 -0
- package/dist/operations/getRenderDocumentWithAssociations.d.ts +15 -0
- package/dist/operations/getRenderDocumentWithAssociations.d.ts.map +1 -0
- package/dist/operations/getRenderDocumentWithAssociations.js +64 -0
- package/dist/operations/getRenderDocumentWithAssociations.js.map +1 -0
- package/dist/operations/getRenderDocuments.d.ts +16 -0
- package/dist/operations/getRenderDocuments.d.ts.map +1 -0
- package/dist/operations/getRenderDocuments.js +25 -0
- package/dist/operations/getRenderDocuments.js.map +1 -0
- package/dist/operations/getUpload.d.ts +25 -0
- package/dist/operations/getUpload.d.ts.map +1 -0
- package/dist/operations/getUpload.js +37 -0
- package/dist/operations/getUpload.js.map +1 -0
- package/dist/operations/getUploads.d.ts +25 -0
- package/dist/operations/getUploads.d.ts.map +1 -0
- package/dist/operations/getUploads.js +76 -0
- package/dist/operations/getUploads.js.map +1 -0
- package/dist/operations/getUsersCount.d.ts +12 -0
- package/dist/operations/getUsersCount.d.ts.map +1 -0
- package/dist/operations/getUsersCount.js +12 -0
- package/dist/operations/getUsersCount.js.map +1 -0
- package/dist/operations/login.d.ts +20 -0
- package/dist/operations/login.d.ts.map +1 -0
- package/dist/operations/login.js +38 -0
- package/dist/operations/login.js.map +1 -0
- package/dist/operations/removeDocument.d.ts +19 -0
- package/dist/operations/removeDocument.d.ts.map +1 -0
- package/dist/operations/removeDocument.js +54 -0
- package/dist/operations/removeDocument.js.map +1 -0
- package/dist/operations/removeRedirect.d.ts +15 -0
- package/dist/operations/removeRedirect.d.ts.map +1 -0
- package/dist/operations/removeRedirect.js +71 -0
- package/dist/operations/removeRedirect.js.map +1 -0
- package/dist/operations/removeUpload.d.ts +21 -0
- package/dist/operations/removeUpload.d.ts.map +1 -0
- package/dist/operations/removeUpload.js +49 -0
- package/dist/operations/removeUpload.js.map +1 -0
- package/dist/operations/search.d.ts +19 -0
- package/dist/operations/search.d.ts.map +1 -0
- package/dist/operations/search.js +109 -0
- package/dist/operations/search.js.map +1 -0
- package/dist/operations/seedIfEmpty.d.ts +7 -0
- package/dist/operations/seedIfEmpty.d.ts.map +1 -0
- package/dist/operations/seedIfEmpty.js +100 -0
- package/dist/operations/seedIfEmpty.js.map +1 -0
- package/dist/operations/signup.d.ts +21 -0
- package/dist/operations/signup.d.ts.map +1 -0
- package/dist/operations/signup.js +45 -0
- package/dist/operations/signup.js.map +1 -0
- package/dist/operations/types.d.ts +223 -0
- package/dist/operations/types.d.ts.map +1 -0
- package/dist/operations/types.js +2 -0
- package/dist/operations/types.js.map +1 -0
- package/dist/operations/updateUpload.d.ts +27 -0
- package/dist/operations/updateUpload.d.ts.map +1 -0
- package/dist/operations/updateUpload.js +78 -0
- package/dist/operations/updateUpload.js.map +1 -0
- package/dist/operations/updateViaArchive.d.ts +23 -0
- package/dist/operations/updateViaArchive.d.ts.map +1 -0
- package/dist/operations/updateViaArchive.js +229 -0
- package/dist/operations/updateViaArchive.js.map +1 -0
- package/dist/operations/upsert.d.ts +26 -0
- package/dist/operations/upsert.d.ts.map +1 -0
- package/dist/operations/upsert.js +257 -0
- package/dist/operations/upsert.js.map +1 -0
- package/dist/operations/utils/common.d.ts +2 -0
- package/dist/operations/utils/common.d.ts.map +1 -0
- package/dist/operations/utils/common.js +2 -0
- package/dist/operations/utils/common.js.map +1 -0
- package/dist/operations/utils/contentType.d.ts +2 -0
- package/dist/operations/utils/contentType.d.ts.map +1 -0
- package/dist/operations/utils/contentType.js +66 -0
- package/dist/operations/utils/contentType.js.map +1 -0
- package/dist/operations/utils/dataType.d.ts +7 -0
- package/dist/operations/utils/dataType.d.ts.map +1 -0
- package/dist/operations/utils/dataType.js +35 -0
- package/dist/operations/utils/dataType.js.map +1 -0
- package/dist/operations/utils/generateUniqueFilename.d.ts +7 -0
- package/dist/operations/utils/generateUniqueFilename.d.ts.map +1 -0
- package/dist/operations/utils/generateUniqueFilename.js +38 -0
- package/dist/operations/utils/generateUniqueFilename.js.map +1 -0
- package/dist/operations/utils/hasEtaTemplates.d.ts +2 -0
- package/dist/operations/utils/hasEtaTemplates.d.ts.map +1 -0
- package/dist/operations/utils/hasEtaTemplates.js +10 -0
- package/dist/operations/utils/hasEtaTemplates.js.map +1 -0
- package/dist/operations/utils/normalizeDocumentQuery.d.ts +12 -0
- package/dist/operations/utils/normalizeDocumentQuery.d.ts.map +1 -0
- package/dist/operations/utils/normalizeDocumentQuery.js +45 -0
- package/dist/operations/utils/normalizeDocumentQuery.js.map +1 -0
- package/dist/operations/utils/utils.d.ts +4 -0
- package/dist/operations/utils/utils.d.ts.map +1 -0
- package/dist/operations/utils/utils.js +4 -0
- package/dist/operations/utils/utils.js.map +1 -0
- package/dist/operations/validateSession.d.ts +17 -0
- package/dist/operations/validateSession.d.ts.map +1 -0
- package/dist/operations/validateSession.js +27 -0
- package/dist/operations/validateSession.js.map +1 -0
- package/dist/render/index.d.ts +9 -0
- package/dist/render/index.d.ts.map +1 -0
- package/dist/render/index.js +347 -0
- package/dist/render/index.js.map +1 -0
- package/dist/render/utils/base.d.ts +74 -0
- package/dist/render/utils/base.d.ts.map +1 -0
- package/dist/render/utils/base.js +290 -0
- package/dist/render/utils/base.js.map +1 -0
- package/dist/render/utils/extractRawBlocks.d.ts +10 -0
- package/dist/render/utils/extractRawBlocks.d.ts.map +1 -0
- package/dist/render/utils/extractRawBlocks.js +28 -0
- package/dist/render/utils/extractRawBlocks.js.map +1 -0
- package/dist/render/utils/rawBlocks.d.ts +10 -0
- package/dist/render/utils/rawBlocks.d.ts.map +1 -0
- package/dist/render/utils/rawBlocks.js +28 -0
- package/dist/render/utils/rawBlocks.js.map +1 -0
- package/dist/render/utils/usageTracker.d.ts +10 -0
- package/dist/render/utils/usageTracker.d.ts.map +1 -0
- package/dist/render/utils/usageTracker.js +87 -0
- package/dist/render/utils/usageTracker.js.map +1 -0
- package/dist/responder/index.d.ts +34 -0
- package/dist/responder/index.d.ts.map +1 -0
- package/dist/responder/index.js +546 -0
- package/dist/responder/index.js.map +1 -0
- package/dist/server/index.d.ts +7 -0
- package/dist/server/index.d.ts.map +1 -0
- package/dist/server/index.js +54 -0
- package/dist/server/index.js.map +1 -0
- package/dist/server/middleware/authorize.d.ts +3 -0
- package/dist/server/middleware/authorize.d.ts.map +1 -0
- package/dist/server/middleware/authorize.js +15 -0
- package/dist/server/middleware/authorize.js.map +1 -0
- package/dist/server/middleware/establishAuth.d.ts +3 -0
- package/dist/server/middleware/establishAuth.d.ts.map +1 -0
- package/dist/server/middleware/establishAuth.js +45 -0
- package/dist/server/middleware/establishAuth.js.map +1 -0
- package/dist/server/middleware/log.d.ts +3 -0
- package/dist/server/middleware/log.d.ts.map +1 -0
- package/dist/server/middleware/log.js +12 -0
- package/dist/server/middleware/log.js.map +1 -0
- package/dist/server/middleware/requirePathMatch.d.ts +3 -0
- package/dist/server/middleware/requirePathMatch.d.ts.map +1 -0
- package/dist/server/middleware/requirePathMatch.js +25 -0
- package/dist/server/middleware/requirePathMatch.js.map +1 -0
- package/dist/server/middleware/requireQuery.d.ts +3 -0
- package/dist/server/middleware/requireQuery.d.ts.map +1 -0
- package/dist/server/middleware/requireQuery.js +24 -0
- package/dist/server/middleware/requireQuery.js.map +1 -0
- package/dist/server/middleware/withDb.d.ts +4 -0
- package/dist/server/middleware/withDb.d.ts.map +1 -0
- package/dist/server/middleware/withDb.js +7 -0
- package/dist/server/middleware/withDb.js.map +1 -0
- package/dist/server/routes/assets.d.ts +4 -0
- package/dist/server/routes/assets.d.ts.map +1 -0
- package/dist/server/routes/assets.js +178 -0
- package/dist/server/routes/assets.js.map +1 -0
- package/dist/server/routes/documents.d.ts +4 -0
- package/dist/server/routes/documents.d.ts.map +1 -0
- package/dist/server/routes/documents.js +40 -0
- package/dist/server/routes/documents.js.map +1 -0
- package/dist/server/routes/edit.d.ts +22 -0
- package/dist/server/routes/edit.d.ts.map +1 -0
- package/dist/server/routes/edit.js +494 -0
- package/dist/server/routes/edit.js.map +1 -0
- package/dist/server/routes/git.d.ts +4 -0
- package/dist/server/routes/git.d.ts.map +1 -0
- package/dist/server/routes/git.js +612 -0
- package/dist/server/routes/git.js.map +1 -0
- package/dist/server/routes/readUpload.d.ts +4 -0
- package/dist/server/routes/readUpload.d.ts.map +1 -0
- package/dist/server/routes/readUpload.js +57 -0
- package/dist/server/routes/readUpload.js.map +1 -0
- package/dist/server/utils/NotFoundError.d.ts +9 -0
- package/dist/server/utils/NotFoundError.d.ts.map +1 -0
- package/dist/server/utils/NotFoundError.js +16 -0
- package/dist/server/utils/NotFoundError.js.map +1 -0
- package/dist/server/utils/editor.css +1535 -0
- package/dist/server/utils/htmlEditorPage.d.ts +6 -0
- package/dist/server/utils/htmlEditorPage.d.ts.map +1 -0
- package/dist/server/utils/htmlEditorPage.js +518 -0
- package/dist/server/utils/htmlEditorPage.js.map +1 -0
- package/dist/server/utils/htmlLoginPage.d.ts +6 -0
- package/dist/server/utils/htmlLoginPage.d.ts.map +1 -0
- package/dist/server/utils/htmlLoginPage.js +134 -0
- package/dist/server/utils/htmlLoginPage.js.map +1 -0
- package/dist/server/utils/layout.css +153 -0
- package/dist/server/utils/types.d.ts +18 -0
- package/dist/server/utils/types.d.ts.map +1 -0
- package/dist/server/utils/types.js +2 -0
- package/dist/server/utils/types.js.map +1 -0
- package/dist/server-bin/index.d.ts +2 -0
- package/dist/server-bin/index.d.ts.map +1 -0
- package/dist/server-bin/index.js +26 -0
- package/dist/server-bin/index.js.map +1 -0
- package/dist/utils/functionContext.d.ts +12 -0
- package/dist/utils/functionContext.d.ts.map +1 -0
- package/dist/utils/functionContext.js +19 -0
- package/dist/utils/functionContext.js.map +1 -0
- package/dist/utils/functionContextClient.d.ts +23 -0
- package/dist/utils/functionContextClient.d.ts.map +1 -0
- package/dist/utils/functionContextClient.js +93 -0
- package/dist/utils/functionContextClient.js.map +1 -0
- package/dist/utils/stringifyData.d.ts +2 -0
- package/dist/utils/stringifyData.d.ts.map +1 -0
- package/dist/utils/stringifyData.js +23 -0
- package/dist/utils/stringifyData.js.map +1 -0
- package/dist/utils/stripImageExif.d.ts +14 -0
- package/dist/utils/stripImageExif.d.ts.map +1 -0
- package/dist/utils/stripImageExif.js +112 -0
- package/dist/utils/stripImageExif.js.map +1 -0
- package/dist/utils/types.d.ts +81 -0
- package/dist/utils/types.d.ts.map +1 -0
- package/dist/utils/types.js +2 -0
- package/dist/utils/types.js.map +1 -0
- package/migrations/1770796673000_initial-schema.js +178 -0
- package/package.json +97 -0
- package/pages/skywriter/.github/copilot-instructions.md +94 -0
- package/pages/skywriter/content.md +862 -0
- package/pages/skywriter/data.json +1 -0
- package/pages/skywriter/doc.code-workspace +15 -0
- package/pages/skywriter/script.js +1 -0
- package/pages/skywriter/server.js +1 -0
- package/pages/skywriter/settings.json +11 -0
- package/pages/skywriter/style.css +167 -0
- package/pages/skywriter/template/content.eta +55 -0
- package/pages/skywriter/template/data.json +1 -0
- package/pages/skywriter/template/script.js +512 -0
- package/pages/skywriter/template/server.js +27 -0
- package/pages/skywriter/template/settings.json +11 -0
- package/pages/skywriter/template/style.css +447 -0
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { pullViaGit } from "../utils/pullViaGit.js";
|
|
2
|
+
import { pullViaTar } from "../utils/pullViaTar.js";
|
|
3
|
+
import { hasRemote } from "../utils/git.js";
|
|
4
|
+
import { resolveTarget } from "../utils/resolveTarget.js";
|
|
5
|
+
import { createPrefixLog } from "../utils/prefixLog.js";
|
|
6
|
+
import { resolve } from 'node:path';
|
|
7
|
+
import { access } from 'node:fs/promises';
|
|
8
|
+
/**
|
|
9
|
+
* Pull command - clone or update a document from server
|
|
10
|
+
*
|
|
11
|
+
* Clone:
|
|
12
|
+
* skywriter pull /meow → clone into ./meow using default server
|
|
13
|
+
* skywriter pull http://host/meow → clone into ./meow using that server
|
|
14
|
+
* skywriter pull meow → clone into ./meow using default server
|
|
15
|
+
* skywriter pull /meow my-folder → clone into ./my-folder
|
|
16
|
+
*
|
|
17
|
+
* Update (inside existing repo):
|
|
18
|
+
* skywriter pull → pull updates using settings.json
|
|
19
|
+
* skywriter pull /meow → pull if settings.json#path matches
|
|
20
|
+
*/
|
|
21
|
+
export const pull = async (ctx, source, destination, options) => {
|
|
22
|
+
if (options?.via) {
|
|
23
|
+
if (options.via !== 'git' && options.via !== 'tar') {
|
|
24
|
+
throw new Error(`Invalid --via value: "${options.via}". Must be "git" or "tar".`);
|
|
25
|
+
}
|
|
26
|
+
if (options.via === 'tar') {
|
|
27
|
+
await pullViaTar(ctx, source, destination, { git: options.git });
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
// When no --via is specified, check if the target is a git repo with a remote
|
|
32
|
+
if (!options?.via) {
|
|
33
|
+
const cmdLog = createPrefixLog(ctx.cliName, 'pull');
|
|
34
|
+
const { dest } = await resolveTarget(ctx, cmdLog, source, destination);
|
|
35
|
+
const targetDir = resolve(dest);
|
|
36
|
+
const isGitDir = await access(`${targetDir}/.git`).then(() => true, () => false);
|
|
37
|
+
if (isGitDir && !(await hasRemote(targetDir))) {
|
|
38
|
+
await pullViaTar(ctx, source, destination, { git: options?.git });
|
|
39
|
+
return;
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
await pullViaGit(ctx, source, destination);
|
|
43
|
+
};
|
|
44
|
+
//# sourceMappingURL=pull.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pull.js","sourceRoot":"","sources":["../../../src/cli/commands/pull.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,UAAU,EAAC,MAAM,wBAAwB,CAAA;AACjD,OAAO,EAAC,UAAU,EAAC,MAAM,wBAAwB,CAAA;AACjD,OAAO,EAAC,SAAS,EAAC,MAAM,iBAAiB,CAAA;AACzC,OAAO,EAAC,aAAa,EAAC,MAAM,2BAA2B,CAAA;AACvD,OAAO,EAAC,eAAe,EAAC,MAAM,uBAAuB,CAAA;AACrD,OAAO,EAAC,OAAO,EAAC,MAAM,WAAW,CAAA;AACjC,OAAO,EAAC,MAAM,EAAC,MAAM,kBAAkB,CAAA;AAGvC;;;;;;;;;;;;GAYG;AACH,MAAM,CAAC,MAAM,IAAI,GAAmE,KAAK,EACvF,GAAG,EACH,MAAM,EACN,WAAW,EACX,OAAO,EACP,EAAE;IACF,IAAI,OAAO,EAAE,GAAG,EAAE,CAAC;QACjB,IAAI,OAAO,CAAC,GAAG,KAAK,KAAK,IAAI,OAAO,CAAC,GAAG,KAAK,KAAK,EAAE,CAAC;YACnD,MAAM,IAAI,KAAK,CAAC,yBAAyB,OAAO,CAAC,GAAG,4BAA4B,CAAC,CAAA;QACnF,CAAC;QACD,IAAI,OAAO,CAAC,GAAG,KAAK,KAAK,EAAE,CAAC;YAC1B,MAAM,UAAU,CAAC,GAAG,EAAE,MAAM,EAAE,WAAW,EAAE,EAAC,GAAG,EAAE,OAAO,CAAC,GAAG,EAAC,CAAC,CAAA;YAC9D,OAAM;QACR,CAAC;IACH,CAAC;IAED,8EAA8E;IAC9E,IAAI,CAAC,OAAO,EAAE,GAAG,EAAE,CAAC;QAClB,MAAM,MAAM,GAAG,eAAe,CAAC,GAAG,CAAC,OAAO,EAAE,MAAM,CAAC,CAAA;QACnD,MAAM,EAAC,IAAI,EAAC,GAAG,MAAM,aAAa,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,WAAW,CAAC,CAAA;QACpE,MAAM,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;QAC/B,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,SAAS,OAAO,CAAC,CAAC,IAAI,CACrD,GAAG,EAAE,CAAC,IAAI,EACV,GAAG,EAAE,CAAC,KAAK,CACZ,CAAA;QACD,IAAI,QAAQ,IAAI,CAAC,CAAC,MAAM,SAAS,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC;YAC9C,MAAM,UAAU,CAAC,GAAG,EAAE,MAAM,EAAE,WAAW,EAAE,EAAC,GAAG,EAAE,OAAO,EAAE,GAAG,EAAC,CAAC,CAAA;YAC/D,OAAM;QACR,CAAC;IACH,CAAC;IAED,MAAM,UAAU,CAAC,GAAG,EAAE,MAAM,EAAE,WAAW,CAAC,CAAA;AAC5C,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"push.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/push.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAC,UAAU,EAAC,MAAM,mBAAmB,CAAA;AAmBjD;;GAEG;AACH,eAAO,MAAM,IAAI,EAAE,UAAU,CAAC,CAAC,MAAM,CAAC,EAAE;IAAC,GAAG,CAAC,EAAE,MAAM,CAAC;IAAC,GAAG,CAAC,EAAE,OAAO,CAAA;CAAC,CAAC,CAAC,CA6BtE,CAAA"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { isDirectoryEmpty, isGitRepo, hasRemote } from "../utils/git.js";
|
|
2
|
+
import { pushViaGit } from "../utils/pushViaGit.js";
|
|
3
|
+
import { pushViaTar } from "../utils/pushViaTar.js";
|
|
4
|
+
/**
|
|
5
|
+
* Auto-detect transport based on directory state:
|
|
6
|
+
* - Empty directory → git (default)
|
|
7
|
+
* - Has .git with remote → git
|
|
8
|
+
* - Has .git without remote → tar
|
|
9
|
+
* - No .git → tar
|
|
10
|
+
*/
|
|
11
|
+
async function detectVia() {
|
|
12
|
+
if (await isDirectoryEmpty())
|
|
13
|
+
return 'git';
|
|
14
|
+
if (await isGitRepo()) {
|
|
15
|
+
return (await hasRemote('.')) ? 'git' : 'tar';
|
|
16
|
+
}
|
|
17
|
+
return 'tar';
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* Push command - unified push with --via transport selection
|
|
21
|
+
*/
|
|
22
|
+
export const push = async (ctx, pathArg, options) => {
|
|
23
|
+
let via;
|
|
24
|
+
const noGit = options?.git === false;
|
|
25
|
+
if (options?.via) {
|
|
26
|
+
if (options.via !== 'git' && options.via !== 'tar') {
|
|
27
|
+
throw new Error(`Invalid --via value: "${options.via}". Must be "git" or "tar".`);
|
|
28
|
+
}
|
|
29
|
+
via = options.via;
|
|
30
|
+
}
|
|
31
|
+
// --no-git implies --via=tar and errors if --via=git was explicit
|
|
32
|
+
if (noGit) {
|
|
33
|
+
if (via === 'git') {
|
|
34
|
+
throw new Error('Cannot use --no-git with --via=git.');
|
|
35
|
+
}
|
|
36
|
+
via = 'tar';
|
|
37
|
+
}
|
|
38
|
+
// Auto-detect if not specified
|
|
39
|
+
if (!via) {
|
|
40
|
+
via = await detectVia();
|
|
41
|
+
}
|
|
42
|
+
if (via === 'git') {
|
|
43
|
+
await pushViaGit(ctx, pathArg);
|
|
44
|
+
}
|
|
45
|
+
else {
|
|
46
|
+
await pushViaTar(ctx, pathArg);
|
|
47
|
+
}
|
|
48
|
+
};
|
|
49
|
+
//# sourceMappingURL=push.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"push.js","sourceRoot":"","sources":["../../../src/cli/commands/push.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,gBAAgB,EAAE,SAAS,EAAE,SAAS,EAAC,MAAM,iBAAiB,CAAA;AACtE,OAAO,EAAC,UAAU,EAAC,MAAM,wBAAwB,CAAA;AACjD,OAAO,EAAC,UAAU,EAAC,MAAM,wBAAwB,CAAA;AAKjD;;;;;;GAMG;AACH,KAAK,UAAU,SAAS;IACtB,IAAI,MAAM,gBAAgB,EAAE;QAAE,OAAO,KAAK,CAAA;IAC1C,IAAI,MAAM,SAAS,EAAE,EAAE,CAAC;QACtB,OAAO,CAAC,MAAM,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAA;IAC/C,CAAC;IACD,OAAO,KAAK,CAAA;AACd,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,MAAM,IAAI,GAA0D,KAAK,EAAE,GAAG,EAAE,OAAO,EAAE,OAAO,EAAE,EAAE;IACzG,IAAI,GAAoB,CAAA;IACxB,MAAM,KAAK,GAAG,OAAO,EAAE,GAAG,KAAK,KAAK,CAAA;IAEpC,IAAI,OAAO,EAAE,GAAG,EAAE,CAAC;QACjB,IAAI,OAAO,CAAC,GAAG,KAAK,KAAK,IAAI,OAAO,CAAC,GAAG,KAAK,KAAK,EAAE,CAAC;YACnD,MAAM,IAAI,KAAK,CAAC,yBAAyB,OAAO,CAAC,GAAG,4BAA4B,CAAC,CAAA;QACnF,CAAC;QACD,GAAG,GAAG,OAAO,CAAC,GAAG,CAAA;IACnB,CAAC;IAED,kEAAkE;IAClE,IAAI,KAAK,EAAE,CAAC;QACV,IAAI,GAAG,KAAK,KAAK,EAAE,CAAC;YAClB,MAAM,IAAI,KAAK,CAAC,qCAAqC,CAAC,CAAA;QACxD,CAAC;QACD,GAAG,GAAG,KAAK,CAAA;IACb,CAAC;IAED,+BAA+B;IAC/B,IAAI,CAAC,GAAG,EAAE,CAAC;QACT,GAAG,GAAG,MAAM,SAAS,EAAE,CAAA;IACzB,CAAC;IAED,IAAI,GAAG,KAAK,KAAK,EAAE,CAAC;QAClB,MAAM,UAAU,CAAC,GAAG,EAAE,OAAO,CAAC,CAAA;IAChC,CAAC;SAAM,CAAC;QACN,MAAM,UAAU,CAAC,GAAG,EAAE,OAAO,CAAC,CAAA;IAChC,CAAC;AACH,CAAC,CAAA"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { CliCommand } from '../utils/types.ts';
|
|
2
|
+
/**
|
|
3
|
+
* Remove a remote server connection
|
|
4
|
+
* Supports: skywriter remote remove [url]
|
|
5
|
+
* - skywriter remote remove (interactive select)
|
|
6
|
+
* - skywriter remote remove http://user@host.com (direct removal with confirmation)
|
|
7
|
+
*/
|
|
8
|
+
export declare const removeServer: CliCommand<[string?]>;
|
|
9
|
+
//# sourceMappingURL=removeServer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"removeServer.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/removeServer.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAC,UAAU,EAAa,MAAM,mBAAmB,CAAA;AAG7D;;;;;GAKG;AACH,eAAO,MAAM,YAAY,EAAE,UAAU,CAAC,CAAC,MAAM,CAAC,CAAC,CAoD9C,CAAA"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { select, confirm } from '@inquirer/prompts';
|
|
2
|
+
import { listServers, deleteCredentials } from "../utils/credentials.js";
|
|
3
|
+
import { createPrefixLog } from "../utils/prefixLog.js";
|
|
4
|
+
/**
|
|
5
|
+
* Remove a remote server connection
|
|
6
|
+
* Supports: skywriter remote remove [url]
|
|
7
|
+
* - skywriter remote remove (interactive select)
|
|
8
|
+
* - skywriter remote remove http://user@host.com (direct removal with confirmation)
|
|
9
|
+
*/
|
|
10
|
+
export const removeServer = async (ctx, url) => {
|
|
11
|
+
const log = createPrefixLog(ctx.cliName, 'remote remove');
|
|
12
|
+
const servers = await listServers(ctx, log);
|
|
13
|
+
if (servers.length === 0) {
|
|
14
|
+
throw new Error(`No servers configured. Run "${ctx.cliName} login" to add one.`);
|
|
15
|
+
}
|
|
16
|
+
const removeFn = async (server) => {
|
|
17
|
+
const confirmed = await confirm({
|
|
18
|
+
message: `Remove ${server.serverUrl} (${server.username})?`,
|
|
19
|
+
default: false,
|
|
20
|
+
});
|
|
21
|
+
if (confirmed) {
|
|
22
|
+
await deleteCredentials(ctx, log, server.serverUrl, server.username);
|
|
23
|
+
log.info(`removed server: ${server.serverUrl} (${server.username})`);
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
if (url) {
|
|
27
|
+
const parsed = new URL(url);
|
|
28
|
+
if (!parsed.username) {
|
|
29
|
+
throw new Error('URL must include a username (e.g. http://user@host.com)');
|
|
30
|
+
}
|
|
31
|
+
const username = parsed.username;
|
|
32
|
+
const serverUrl = parsed.origin;
|
|
33
|
+
const server = servers.find(s => s.serverUrl === serverUrl && s.username === username);
|
|
34
|
+
if (!server) {
|
|
35
|
+
throw new Error(`No server found for ${username}@${parsed.host}`);
|
|
36
|
+
}
|
|
37
|
+
await removeFn(server);
|
|
38
|
+
return;
|
|
39
|
+
}
|
|
40
|
+
if (servers.length === 1) {
|
|
41
|
+
const server = servers[0];
|
|
42
|
+
await removeFn(server);
|
|
43
|
+
return;
|
|
44
|
+
}
|
|
45
|
+
const choices = servers.map(server => ({
|
|
46
|
+
name: `${server.serverUrl} (${server.username})${server.active ? ' (current default)' : ''}`,
|
|
47
|
+
value: server,
|
|
48
|
+
}));
|
|
49
|
+
const selected = await select({
|
|
50
|
+
message: 'Select server to remove:',
|
|
51
|
+
choices,
|
|
52
|
+
});
|
|
53
|
+
await removeFn(selected);
|
|
54
|
+
};
|
|
55
|
+
//# sourceMappingURL=removeServer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"removeServer.js","sourceRoot":"","sources":["../../../src/cli/commands/removeServer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,MAAM,EAAE,OAAO,EAAC,MAAM,mBAAmB,CAAA;AACjD,OAAO,EAAC,WAAW,EAAE,iBAAiB,EAAC,MAAM,yBAAyB,CAAA;AAEtE,OAAO,EAAC,eAAe,EAAC,MAAM,uBAAuB,CAAA;AAErD;;;;;GAKG;AACH,MAAM,CAAC,MAAM,YAAY,GAA0B,KAAK,EAAE,GAAG,EAAE,GAAI,EAAE,EAAE;IACrE,MAAM,GAAG,GAAG,eAAe,CAAC,GAAG,CAAC,OAAO,EAAE,eAAe,CAAC,CAAA;IACzD,MAAM,OAAO,GAAG,MAAM,WAAW,CAAC,GAAG,EAAE,GAAG,CAAC,CAAA;IAE3C,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACzB,MAAM,IAAI,KAAK,CAAC,+BAA+B,GAAG,CAAC,OAAO,qBAAqB,CAAC,CAAA;IAClF,CAAC;IAED,MAAM,QAAQ,GAAG,KAAK,EAAE,MAAkB,EAAE,EAAE;QAC5C,MAAM,SAAS,GAAG,MAAM,OAAO,CAAC;YAC9B,OAAO,EAAE,UAAU,MAAM,CAAC,SAAS,KAAK,MAAM,CAAC,QAAQ,IAAI;YAC3D,OAAO,EAAE,KAAK;SACf,CAAC,CAAA;QAEF,IAAI,SAAS,EAAE,CAAC;YACd,MAAM,iBAAiB,CAAC,GAAG,EAAE,GAAG,EAAE,MAAM,CAAC,SAAS,EAAE,MAAM,CAAC,QAAQ,CAAC,CAAA;YACpE,GAAG,CAAC,IAAI,CAAC,mBAAmB,MAAM,CAAC,SAAS,KAAK,MAAM,CAAC,QAAQ,GAAG,CAAC,CAAA;QACtE,CAAC;IACH,CAAC,CAAA;IAED,IAAI,GAAG,EAAE,CAAC;QACR,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,CAAA;QAC3B,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;YACrB,MAAM,IAAI,KAAK,CAAC,yDAAyD,CAAC,CAAA;QAC5E,CAAC;QACD,MAAM,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAA;QAChC,MAAM,SAAS,GAAG,MAAM,CAAC,MAAM,CAAA;QAC/B,MAAM,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,KAAK,SAAS,IAAI,CAAC,CAAC,QAAQ,KAAK,QAAQ,CAAC,CAAA;QACtF,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,MAAM,IAAI,KAAK,CAAC,uBAAuB,QAAQ,IAAI,MAAM,CAAC,IAAI,EAAE,CAAC,CAAA;QACnE,CAAC;QACD,MAAM,QAAQ,CAAC,MAAM,CAAC,CAAA;QACtB,OAAM;IACR,CAAC;IAED,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACzB,MAAM,MAAM,GAAG,OAAO,CAAC,CAAC,CAAC,CAAA;QACzB,MAAM,QAAQ,CAAC,MAAM,CAAC,CAAA;QACtB,OAAM;IACR,CAAC;IAED,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QACrC,IAAI,EAAE,GAAG,MAAM,CAAC,SAAS,KAAK,MAAM,CAAC,QAAQ,IAAI,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,EAAE,EAAE;QAC5F,KAAK,EAAE,MAAM;KACd,CAAC,CAAC,CAAA;IAEH,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC;QAC5B,OAAO,EAAE,0BAA0B;QACnC,OAAO;KACR,CAAC,CAAA;IAEF,MAAM,QAAQ,CAAC,QAAQ,CAAC,CAAA;AAC1B,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"render.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/render.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAC,UAAU,EAAC,MAAM,mBAAmB,CAAA;AAEjD;;GAEG;AACH,eAAO,MAAM,MAAM,EAAE,UAKpB,CAAA"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { assemble } from "../utils/assemble.js";
|
|
2
|
+
import { render as renderDocument } from "../../render/index.js";
|
|
3
|
+
/**
|
|
4
|
+
* Render the current working directory document and output as JSON
|
|
5
|
+
*/
|
|
6
|
+
export const render = async (_ctx) => {
|
|
7
|
+
const document = await assemble();
|
|
8
|
+
const rendered = await renderDocument(document);
|
|
9
|
+
process.stdout.write(JSON.stringify(rendered) + '\n');
|
|
10
|
+
};
|
|
11
|
+
//# sourceMappingURL=render.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"render.js","sourceRoot":"","sources":["../../../src/cli/commands/render.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,QAAQ,EAAC,MAAM,sBAAsB,CAAA;AAC7C,OAAO,EAAC,MAAM,IAAI,cAAc,EAAC,MAAM,uBAAuB,CAAA;AAG9D;;GAEG;AACH,MAAM,CAAC,MAAM,MAAM,GAAe,KAAK,EAAC,IAAI,EAAC,EAAE;IAC7C,MAAM,QAAQ,GAAG,MAAM,QAAQ,EAAE,CAAA;IACjC,MAAM,QAAQ,GAAG,MAAM,cAAc,CAAC,QAAQ,CAAC,CAAA;IAE/C,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC,CAAA;AACvD,CAAC,CAAA"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { CliCommand } from '../utils/types.ts';
|
|
2
|
+
/**
|
|
3
|
+
* Serve multiple documents from the current working directory
|
|
4
|
+
* Discovers all settings.json files and routes to appropriate documents on-demand
|
|
5
|
+
*/
|
|
6
|
+
export declare const serve: CliCommand<[number, boolean?, boolean?]>;
|
|
7
|
+
//# sourceMappingURL=serve.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"serve.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/serve.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAC,UAAU,EAAC,MAAM,mBAAmB,CAAA;AAOjD;;;GAGG;AACH,eAAO,MAAM,KAAK,EAAE,UAAU,CAAC,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,OAAO,CAAC,CAAC,CAwD1D,CAAA"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { Hono } from 'hono';
|
|
2
|
+
import { serve as honoServe } from '@hono/node-server';
|
|
3
|
+
import { clearCache } from "../../utils/functionContextClient.js";
|
|
4
|
+
import { discoverDocuments } from "../utils/discover.js";
|
|
5
|
+
import { watchForChanges } from "../utils/watchForChanges.js";
|
|
6
|
+
import { checkDuplicatePath } from "../middleware/checkDuplicatePath.js";
|
|
7
|
+
import { redirectRoot } from "../middleware/redirectRoot.js";
|
|
8
|
+
import { serveUploads } from "../middleware/serveUploads.js";
|
|
9
|
+
import { serveDocument } from "../middleware/serveDocument.js";
|
|
10
|
+
import log from "../utils/log.js";
|
|
11
|
+
/**
|
|
12
|
+
* Serve multiple documents from the current working directory
|
|
13
|
+
* Discovers all settings.json files and routes to appropriate documents on-demand
|
|
14
|
+
*/
|
|
15
|
+
export const serve = async (ctx, port, watchFiles = true, clearCacheFlag = false) => {
|
|
16
|
+
// Clear cache if requested
|
|
17
|
+
if (clearCacheFlag) {
|
|
18
|
+
await clearCache();
|
|
19
|
+
}
|
|
20
|
+
// Discover all documents in the directory tree
|
|
21
|
+
let discovery = await discoverDocuments(process.cwd(), { throwOnEmpty: true });
|
|
22
|
+
// Getter function for middleware (allows for mutable discovery)
|
|
23
|
+
const getDiscovery = () => discovery;
|
|
24
|
+
const app = new Hono();
|
|
25
|
+
// Apply middleware in order:
|
|
26
|
+
// 1. Check for duplicate paths (returns 500 if path is duplicated)
|
|
27
|
+
// 2. Redirect root to first document if no root document exists
|
|
28
|
+
// 3. Serve uploads from document directories
|
|
29
|
+
// 4. Serve documents
|
|
30
|
+
app.get('/*', checkDuplicatePath(getDiscovery), redirectRoot(getDiscovery), serveUploads(getDiscovery), serveDocument(getDiscovery, ctx));
|
|
31
|
+
log.info(`\n🚀 Serving at http://localhost:${port}/`);
|
|
32
|
+
if (watchFiles) {
|
|
33
|
+
log.info(`👀 Watching for file changes...`);
|
|
34
|
+
watchForChanges(newDiscovery => {
|
|
35
|
+
discovery = newDiscovery;
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
const server = honoServe({
|
|
39
|
+
fetch: app.fetch,
|
|
40
|
+
port,
|
|
41
|
+
});
|
|
42
|
+
// Ensure the HTTP server keeps the process alive even if the underlying
|
|
43
|
+
// implementation uses `unref()`.
|
|
44
|
+
if (typeof server.ref === 'function') {
|
|
45
|
+
;
|
|
46
|
+
server.ref();
|
|
47
|
+
}
|
|
48
|
+
// Keep the command running until the server closes.
|
|
49
|
+
await new Promise((resolve, reject) => {
|
|
50
|
+
;
|
|
51
|
+
server.once('close', () => resolve());
|
|
52
|
+
server.once('error', err => reject(err));
|
|
53
|
+
});
|
|
54
|
+
};
|
|
55
|
+
//# sourceMappingURL=serve.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"serve.js","sourceRoot":"","sources":["../../../src/cli/commands/serve.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,IAAI,EAAC,MAAM,MAAM,CAAA;AACzB,OAAO,EAAC,KAAK,IAAI,SAAS,EAAC,MAAM,mBAAmB,CAAA;AACpD,OAAO,EAAC,UAAU,EAAC,MAAM,sCAAsC,CAAA;AAE/D,OAAO,EAAC,iBAAiB,EAAC,MAAM,sBAAsB,CAAA;AACtD,OAAO,EAAC,eAAe,EAAC,MAAM,6BAA6B,CAAA;AAE3D,OAAO,EAAC,kBAAkB,EAAC,MAAM,qCAAqC,CAAA;AACtE,OAAO,EAAC,YAAY,EAAC,MAAM,+BAA+B,CAAA;AAC1D,OAAO,EAAC,YAAY,EAAC,MAAM,+BAA+B,CAAA;AAC1D,OAAO,EAAC,aAAa,EAAC,MAAM,gCAAgC,CAAA;AAC5D,OAAO,GAAG,MAAM,iBAAiB,CAAA;AAEjC;;;GAGG;AACH,MAAM,CAAC,MAAM,KAAK,GAA6C,KAAK,EAClE,GAAG,EACH,IAAI,EACJ,UAAU,GAAG,IAAI,EACjB,cAAc,GAAG,KAAK,EACtB,EAAE;IACF,2BAA2B;IAC3B,IAAI,cAAc,EAAE,CAAC;QACnB,MAAM,UAAU,EAAE,CAAA;IACpB,CAAC;IAED,+CAA+C;IAC/C,IAAI,SAAS,GAAG,MAAM,iBAAiB,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,EAAC,YAAY,EAAE,IAAI,EAAC,CAAC,CAAA;IAE5E,gEAAgE;IAChE,MAAM,YAAY,GAAG,GAAG,EAAE,CAAC,SAAS,CAAA;IAEpC,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAA;IAEtB,6BAA6B;IAC7B,mEAAmE;IACnE,gEAAgE;IAChE,6CAA6C;IAC7C,qBAAqB;IACrB,GAAG,CAAC,GAAG,CACL,IAAI,EACJ,kBAAkB,CAAC,YAAY,CAAC,EAChC,YAAY,CAAC,YAAY,CAAC,EAC1B,YAAY,CAAC,YAAY,CAAC,EAC1B,aAAa,CAAC,YAAY,EAAE,GAAG,CAAC,CACjC,CAAA;IAED,GAAG,CAAC,IAAI,CAAC,oCAAoC,IAAI,GAAG,CAAC,CAAA;IACrD,IAAI,UAAU,EAAE,CAAC;QACf,GAAG,CAAC,IAAI,CAAC,iCAAiC,CAAC,CAAA;QAC3C,eAAe,CAAC,YAAY,CAAC,EAAE;YAC7B,SAAS,GAAG,YAAY,CAAA;QAC1B,CAAC,CAAC,CAAA;IACJ,CAAC;IAED,MAAM,MAAM,GAAG,SAAS,CAAC;QACvB,KAAK,EAAE,GAAG,CAAC,KAAK;QAChB,IAAI;KACL,CAAC,CAAA;IAEF,wEAAwE;IACxE,iCAAiC;IACjC,IAAI,OAAQ,MAA4B,CAAC,GAAG,KAAK,UAAU,EAAE,CAAC;QAC5D,CAAC;QAAC,MAA4B,CAAC,GAAG,EAAE,CAAA;IACtC,CAAC;IAED,oDAAoD;IACpD,MAAM,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QAC1C,CAAC;QAAC,MAA4B,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,EAAE,CAAC,OAAO,EAAE,CAAC,CAC5D;QAAC,MAA4B,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,CAAC,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAA;IAClE,CAAC,CAAC,CAAA;AACJ,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sessions.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/sessions.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAC,UAAU,EAAC,MAAM,mBAAmB,CAAA;AAIjD;;GAEG;AACH,eAAO,MAAM,QAAQ,EAAE,UAkBtB,CAAA"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { listServers } from "../utils/credentials.js";
|
|
2
|
+
import { createPrefixLog } from "../utils/prefixLog.js";
|
|
3
|
+
import { logData } from "../utils/logData.js";
|
|
4
|
+
/**
|
|
5
|
+
* List all configured sessions
|
|
6
|
+
*/
|
|
7
|
+
export const sessions = async (ctx) => {
|
|
8
|
+
const json = ctx.json;
|
|
9
|
+
const cmdLog = createPrefixLog(ctx.cliName, 'remote list');
|
|
10
|
+
const servers = await listServers(ctx, cmdLog);
|
|
11
|
+
if (servers.length === 0) {
|
|
12
|
+
const message = `No remotes configured. Run "${ctx.cliName} login" to add one.`;
|
|
13
|
+
if (json) {
|
|
14
|
+
logData({ error: 'no_servers', message }, true);
|
|
15
|
+
process.exitCode = 1;
|
|
16
|
+
return;
|
|
17
|
+
}
|
|
18
|
+
throw new Error(message);
|
|
19
|
+
}
|
|
20
|
+
const sorted = servers.sort((a, b) => (a.active === b.active ? 0 : a.active ? -1 : 1));
|
|
21
|
+
const data = sorted.map(s => ({ serverUrl: s.serverUrl, username: s.username, active: s.active }));
|
|
22
|
+
logData(data, json);
|
|
23
|
+
};
|
|
24
|
+
//# sourceMappingURL=sessions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sessions.js","sourceRoot":"","sources":["../../../src/cli/commands/sessions.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,WAAW,EAAC,MAAM,yBAAyB,CAAA;AAEnD,OAAO,EAAC,eAAe,EAAC,MAAM,uBAAuB,CAAA;AACrD,OAAO,EAAC,OAAO,EAAC,MAAM,qBAAqB,CAAA;AAE3C;;GAEG;AACH,MAAM,CAAC,MAAM,QAAQ,GAAe,KAAK,EAAC,GAAG,EAAC,EAAE;IAC9C,MAAM,IAAI,GAAG,GAAG,CAAC,IAAI,CAAA;IACrB,MAAM,MAAM,GAAG,eAAe,CAAC,GAAG,CAAC,OAAO,EAAE,aAAa,CAAC,CAAA;IAC1D,MAAM,OAAO,GAAG,MAAM,WAAW,CAAC,GAAG,EAAE,MAAM,CAAC,CAAA;IAE9C,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACzB,MAAM,OAAO,GAAG,+BAA+B,GAAG,CAAC,OAAO,qBAAqB,CAAA;QAC/E,IAAI,IAAI,EAAE,CAAC;YACT,OAAO,CAAC,EAAC,KAAK,EAAE,YAAY,EAAE,OAAO,EAAC,EAAE,IAAI,CAAC,CAAA;YAC7C,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAA;YACpB,OAAM;QACR,CAAC;QACD,MAAM,IAAI,KAAK,CAAC,OAAO,CAAC,CAAA;IAC1B,CAAC;IAED,MAAM,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;IACtF,MAAM,IAAI,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAC,SAAS,EAAE,CAAC,CAAC,SAAS,EAAE,QAAQ,EAAE,CAAC,CAAC,QAAQ,EAAE,MAAM,EAAE,CAAC,CAAC,MAAM,EAAC,CAAC,CAAC,CAAA;IAChG,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,CAAA;AACrB,CAAC,CAAA"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { CliCommand } from '../utils/types.ts';
|
|
2
|
+
interface SettingsOptions {
|
|
3
|
+
fix?: boolean;
|
|
4
|
+
}
|
|
5
|
+
/**
|
|
6
|
+
* Display local settings.json and validation issues.
|
|
7
|
+
*/
|
|
8
|
+
export declare const settings: CliCommand<[SettingsOptions?]>;
|
|
9
|
+
export {};
|
|
10
|
+
//# sourceMappingURL=settings.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"settings.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/settings.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAC,UAAU,EAAC,MAAM,mBAAmB,CAAA;AAIjD,UAAU,eAAe;IACvB,GAAG,CAAC,EAAE,OAAO,CAAA;CACd;AAED;;GAEG;AACH,eAAO,MAAM,QAAQ,EAAE,UAAU,CAAC,CAAC,eAAe,CAAC,CAAC,CA8DnD,CAAA"}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import { resolve } from 'node:path';
|
|
2
|
+
import { readSettings, normalizePath } from "../utils/pageContext.js";
|
|
3
|
+
import { validatePathSettings } from "../pathOperations/validatePathSettings.js";
|
|
4
|
+
import { logData } from "../utils/logData.js";
|
|
5
|
+
import { createPrefixLog } from "../utils/prefixLog.js";
|
|
6
|
+
import { createLoggedFs } from "../utils/createLoggedFs.js";
|
|
7
|
+
/**
|
|
8
|
+
* Display local settings.json and validation issues.
|
|
9
|
+
*/
|
|
10
|
+
export const settings = async (ctx, options) => {
|
|
11
|
+
const json = ctx.json;
|
|
12
|
+
const fix = options?.fix ?? false;
|
|
13
|
+
const cmdLog = createPrefixLog(ctx.cliName, 'settings');
|
|
14
|
+
const fs = createLoggedFs(cmdLog, ctx.cwd);
|
|
15
|
+
const data = await readSettings('.', fs);
|
|
16
|
+
if (!data) {
|
|
17
|
+
const message = 'No settings.json found in the current directory';
|
|
18
|
+
if (json) {
|
|
19
|
+
logData({ error: 'not_found', message }, true);
|
|
20
|
+
process.exitCode = 1;
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
throw new Error(message);
|
|
24
|
+
}
|
|
25
|
+
const rootCtx = {
|
|
26
|
+
reference: 'main',
|
|
27
|
+
path: data.path,
|
|
28
|
+
normalizedPath: normalizePath(data.path),
|
|
29
|
+
serverUrl: '',
|
|
30
|
+
auth: '',
|
|
31
|
+
settings: data,
|
|
32
|
+
dir: '.',
|
|
33
|
+
absoluteDir: resolve(ctx.cwd),
|
|
34
|
+
log: cmdLog,
|
|
35
|
+
prompt: ctx.prompt,
|
|
36
|
+
forbiddenPaths: [],
|
|
37
|
+
};
|
|
38
|
+
const violations = await validatePathSettings(rootCtx);
|
|
39
|
+
if (violations.length === 0) {
|
|
40
|
+
logData({ valid: true }, json);
|
|
41
|
+
return;
|
|
42
|
+
}
|
|
43
|
+
if (fix) {
|
|
44
|
+
let fixedCount = 0;
|
|
45
|
+
const unfixed = [];
|
|
46
|
+
for (const v of violations) {
|
|
47
|
+
if (v.apply) {
|
|
48
|
+
await v.apply();
|
|
49
|
+
fixedCount++;
|
|
50
|
+
}
|
|
51
|
+
else {
|
|
52
|
+
unfixed.push(v);
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
logData({ fixed: `${fixedCount}/${violations.length}`, valid: unfixed.length === 0, violations: unfixed }, json);
|
|
56
|
+
if (unfixed.length > 0) {
|
|
57
|
+
process.exitCode = 1;
|
|
58
|
+
}
|
|
59
|
+
return;
|
|
60
|
+
}
|
|
61
|
+
if (json) {
|
|
62
|
+
logData({ valid: false, violations }, true);
|
|
63
|
+
}
|
|
64
|
+
else {
|
|
65
|
+
logData({ violations });
|
|
66
|
+
}
|
|
67
|
+
process.exitCode = 1;
|
|
68
|
+
};
|
|
69
|
+
//# sourceMappingURL=settings.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"settings.js","sourceRoot":"","sources":["../../../src/cli/commands/settings.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,OAAO,EAAC,MAAM,WAAW,CAAA;AACjC,OAAO,EAAC,YAAY,EAAE,aAAa,EAAC,MAAM,yBAAyB,CAAA;AAEnE,OAAO,EAAC,oBAAoB,EAAC,MAAM,2CAA2C,CAAA;AAC9E,OAAO,EAAC,OAAO,EAAC,MAAM,qBAAqB,CAAA;AAE3C,OAAO,EAAC,eAAe,EAAC,MAAM,uBAAuB,CAAA;AACrD,OAAO,EAAC,cAAc,EAAC,MAAM,4BAA4B,CAAA;AAMzD;;GAEG;AACH,MAAM,CAAC,MAAM,QAAQ,GAAmC,KAAK,EAAE,GAAG,EAAE,OAAO,EAAE,EAAE;IAC7E,MAAM,IAAI,GAAG,GAAG,CAAC,IAAI,CAAA;IACrB,MAAM,GAAG,GAAG,OAAO,EAAE,GAAG,IAAI,KAAK,CAAA;IACjC,MAAM,MAAM,GAAG,eAAe,CAAC,GAAG,CAAC,OAAO,EAAE,UAAU,CAAC,CAAA;IACvD,MAAM,EAAE,GAAG,cAAc,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,CAAC,CAAA;IAC1C,MAAM,IAAI,GAAG,MAAM,YAAY,CAAC,GAAG,EAAE,EAAE,CAAC,CAAA;IAExC,IAAI,CAAC,IAAI,EAAE,CAAC;QACV,MAAM,OAAO,GAAG,iDAAiD,CAAA;QACjE,IAAI,IAAI,EAAE,CAAC;YACT,OAAO,CAAC,EAAC,KAAK,EAAE,WAAW,EAAE,OAAO,EAAC,EAAE,IAAI,CAAC,CAAA;YAC5C,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAA;YACpB,OAAM;QACR,CAAC;QACD,MAAM,IAAI,KAAK,CAAC,OAAO,CAAC,CAAA;IAC1B,CAAC;IAED,MAAM,OAAO,GAAgB;QAC3B,SAAS,EAAE,MAAM;QACjB,IAAI,EAAE,IAAI,CAAC,IAAI;QACf,cAAc,EAAE,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC;QACxC,SAAS,EAAE,EAAE;QACb,IAAI,EAAE,EAAE;QACR,QAAQ,EAAE,IAAI;QACd,GAAG,EAAE,GAAG;QACR,WAAW,EAAE,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC;QAC7B,GAAG,EAAE,MAAM;QACX,MAAM,EAAE,GAAG,CAAC,MAAM;QAClB,cAAc,EAAE,EAAE;KACnB,CAAA;IAED,MAAM,UAAU,GAAG,MAAM,oBAAoB,CAAC,OAAO,CAAC,CAAA;IAEtD,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC5B,OAAO,CAAC,EAAC,KAAK,EAAE,IAAI,EAAC,EAAE,IAAI,CAAC,CAAA;QAC5B,OAAM;IACR,CAAC;IAED,IAAI,GAAG,EAAE,CAAC;QACR,IAAI,UAAU,GAAG,CAAC,CAAA;QAClB,MAAM,OAAO,GAAsB,EAAE,CAAA;QACrC,KAAK,MAAM,CAAC,IAAI,UAAU,EAAE,CAAC;YAC3B,IAAI,CAAC,CAAC,KAAK,EAAE,CAAC;gBACZ,MAAM,CAAC,CAAC,KAAK,EAAE,CAAA;gBACf,UAAU,EAAE,CAAA;YACd,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;YACjB,CAAC;QACH,CAAC;QACD,OAAO,CAAC,EAAC,KAAK,EAAE,GAAG,UAAU,IAAI,UAAU,CAAC,MAAM,EAAE,EAAE,KAAK,EAAE,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,UAAU,EAAE,OAAO,EAAC,EAAE,IAAI,CAAC,CAAA;QAC9G,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACvB,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAA;QACtB,CAAC;QACD,OAAM;IACR,CAAC;IAED,IAAI,IAAI,EAAE,CAAC;QACT,OAAO,CAAC,EAAC,KAAK,EAAE,KAAK,EAAE,UAAU,EAAC,EAAE,IAAI,CAAC,CAAA;IAC3C,CAAC;SAAM,CAAC;QACN,OAAO,CAAC,EAAC,UAAU,EAAC,CAAC,CAAA;IACvB,CAAC;IACD,OAAO,CAAC,QAAQ,GAAG,CAAC,CAAA;AACtB,CAAC,CAAA"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { CliCommand } from '../utils/types.ts';
|
|
2
|
+
/**
|
|
3
|
+
* Switch the default server
|
|
4
|
+
* Supports: skywriter remote switch [url]
|
|
5
|
+
* - skywriter remote switch (interactive select)
|
|
6
|
+
* - skywriter remote switch http://user@host.com (direct switch)
|
|
7
|
+
*/
|
|
8
|
+
export declare const switchServer: CliCommand<[string?]>;
|
|
9
|
+
//# sourceMappingURL=switchServer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"switchServer.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/switchServer.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAC,UAAU,EAAC,MAAM,mBAAmB,CAAA;AAGjD;;;;;GAKG;AACH,eAAO,MAAM,YAAY,EAAE,UAAU,CAAC,CAAC,MAAM,CAAC,CAAC,CAgD9C,CAAA"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import { select } from '@inquirer/prompts';
|
|
2
|
+
import { listServers, setDefaultServer } from "../utils/credentials.js";
|
|
3
|
+
import { createPrefixLog } from "../utils/prefixLog.js";
|
|
4
|
+
/**
|
|
5
|
+
* Switch the default server
|
|
6
|
+
* Supports: skywriter remote switch [url]
|
|
7
|
+
* - skywriter remote switch (interactive select)
|
|
8
|
+
* - skywriter remote switch http://user@host.com (direct switch)
|
|
9
|
+
*/
|
|
10
|
+
export const switchServer = async (ctx, url) => {
|
|
11
|
+
const cmdLog = createPrefixLog(ctx.cliName, 'remote switch');
|
|
12
|
+
const servers = await listServers(ctx, cmdLog);
|
|
13
|
+
if (servers.length === 0) {
|
|
14
|
+
throw new Error(`No servers configured. Run "${ctx.cliName} login" to add one.`);
|
|
15
|
+
}
|
|
16
|
+
if (url) {
|
|
17
|
+
const parsed = new URL(url);
|
|
18
|
+
if (!parsed.username) {
|
|
19
|
+
throw new Error('URL must include a username (e.g. http://user@host.com)');
|
|
20
|
+
}
|
|
21
|
+
const username = parsed.username;
|
|
22
|
+
const serverUrl = parsed.origin;
|
|
23
|
+
const server = servers.find(s => s.serverUrl === serverUrl && s.username === username);
|
|
24
|
+
if (!server) {
|
|
25
|
+
throw new Error(`No server found for ${username}@${parsed.host}`);
|
|
26
|
+
}
|
|
27
|
+
if (server.active) {
|
|
28
|
+
cmdLog.info(`${username}@${parsed.host} is already the active server.`);
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
await setDefaultServer(ctx, cmdLog, server.serverUrl, server.username);
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
if (servers.length === 1) {
|
|
35
|
+
cmdLog.info('Only one server is configured.');
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
const choices = servers.map(server => ({
|
|
39
|
+
name: `${server.serverUrl} (${server.username})${server.active ? ' (current default)' : ''}`,
|
|
40
|
+
value: server,
|
|
41
|
+
}));
|
|
42
|
+
const selected = await select({
|
|
43
|
+
message: 'Select default server:',
|
|
44
|
+
choices,
|
|
45
|
+
});
|
|
46
|
+
if (selected.active) {
|
|
47
|
+
cmdLog.info(`${selected.username}@${new URL(selected.serverUrl).host} is already the active server.`);
|
|
48
|
+
return;
|
|
49
|
+
}
|
|
50
|
+
await setDefaultServer(ctx, cmdLog, selected.serverUrl, selected.username);
|
|
51
|
+
};
|
|
52
|
+
//# sourceMappingURL=switchServer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"switchServer.js","sourceRoot":"","sources":["../../../src/cli/commands/switchServer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,MAAM,EAAC,MAAM,mBAAmB,CAAA;AACxC,OAAO,EAAC,WAAW,EAAE,gBAAgB,EAAC,MAAM,yBAAyB,CAAA;AAErE,OAAO,EAAC,eAAe,EAAC,MAAM,uBAAuB,CAAA;AAErD;;;;;GAKG;AACH,MAAM,CAAC,MAAM,YAAY,GAA0B,KAAK,EAAE,GAAG,EAAE,GAAI,EAAE,EAAE;IACrE,MAAM,MAAM,GAAG,eAAe,CAAC,GAAG,CAAC,OAAO,EAAE,eAAe,CAAC,CAAA;IAC5D,MAAM,OAAO,GAAG,MAAM,WAAW,CAAC,GAAG,EAAE,MAAM,CAAC,CAAA;IAE9C,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACzB,MAAM,IAAI,KAAK,CAAC,+BAA+B,GAAG,CAAC,OAAO,qBAAqB,CAAC,CAAA;IAClF,CAAC;IAED,IAAI,GAAG,EAAE,CAAC;QACR,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,CAAA;QAC3B,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;YACrB,MAAM,IAAI,KAAK,CAAC,yDAAyD,CAAC,CAAA;QAC5E,CAAC;QACD,MAAM,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAA;QAChC,MAAM,SAAS,GAAG,MAAM,CAAC,MAAM,CAAA;QAC/B,MAAM,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,KAAK,SAAS,IAAI,CAAC,CAAC,QAAQ,KAAK,QAAQ,CAAC,CAAA;QACtF,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,MAAM,IAAI,KAAK,CAAC,uBAAuB,QAAQ,IAAI,MAAM,CAAC,IAAI,EAAE,CAAC,CAAA;QACnE,CAAC;QACD,IAAI,MAAM,CAAC,MAAM,EAAE,CAAC;YAClB,MAAM,CAAC,IAAI,CAAC,GAAG,QAAQ,IAAI,MAAM,CAAC,IAAI,gCAAgC,CAAC,CAAA;YACvE,OAAM;QACR,CAAC;QACD,MAAM,gBAAgB,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,CAAC,SAAS,EAAE,MAAM,CAAC,QAAQ,CAAC,CAAA;QACtE,OAAM;IACR,CAAC;IAED,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACzB,MAAM,CAAC,IAAI,CAAC,gCAAgC,CAAC,CAAA;QAC7C,OAAM;IACR,CAAC;IAED,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QACrC,IAAI,EAAE,GAAG,MAAM,CAAC,SAAS,KAAK,MAAM,CAAC,QAAQ,IAAI,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,EAAE,EAAE;QAC5F,KAAK,EAAE,MAAM;KACd,CAAC,CAAC,CAAA;IAEH,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC;QAC5B,OAAO,EAAE,wBAAwB;QACjC,OAAO;KACR,CAAC,CAAA;IAEF,IAAI,QAAQ,CAAC,MAAM,EAAE,CAAC;QACpB,MAAM,CAAC,IAAI,CAAC,GAAG,QAAQ,CAAC,QAAQ,IAAI,IAAI,GAAG,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,IAAI,gCAAgC,CAAC,CAAA;QACrG,OAAM;IACR,CAAC;IAED,MAAM,gBAAgB,CAAC,GAAG,EAAE,MAAM,EAAE,QAAQ,CAAC,SAAS,EAAE,QAAQ,CAAC,QAAQ,CAAC,CAAA;AAC5E,CAAC,CAAA"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { CliCommand } from '../utils/types.ts';
|
|
2
|
+
interface VscodeOptions {
|
|
3
|
+
init?: boolean;
|
|
4
|
+
open?: boolean;
|
|
5
|
+
}
|
|
6
|
+
/**
|
|
7
|
+
* VS Code workspace management
|
|
8
|
+
* --init: Initialize workspace files (copilot instructions, .code-workspace)
|
|
9
|
+
* --open: Open workspace in VS Code
|
|
10
|
+
*/
|
|
11
|
+
export declare const vscodeInit: CliCommand<[VscodeOptions?]>;
|
|
12
|
+
export {};
|
|
13
|
+
//# sourceMappingURL=vscodeInit.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vscodeInit.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/vscodeInit.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAa,UAAU,EAAC,MAAM,mBAAmB,CAAA;AA2I7D,UAAU,aAAa;IACrB,IAAI,CAAC,EAAE,OAAO,CAAA;IACd,IAAI,CAAC,EAAE,OAAO,CAAA;CACf;AAED;;;;GAIG;AACH,eAAO,MAAM,UAAU,EAAE,UAAU,CAAC,CAAC,aAAa,CAAC,CAAC,CA8CnD,CAAA"}
|