@botbotgo/kit-builtin 0.0.92
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/README.md +82 -0
- package/dist/agent-tool-extension-compat.d.ts +5 -0
- package/dist/agent-tool-extension-compat.d.ts.map +1 -0
- package/dist/agent-tool-extension-compat.js +8 -0
- package/dist/agent-tool-extension-compat.js.map +1 -0
- package/dist/config/tool.yaml +162 -0
- package/dist/core-tools-manifest.json +7081 -0
- package/dist/index.d.ts +11 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +11 -0
- package/dist/index.js.map +1 -0
- package/dist/src/analyze/analyzeLog.d.ts +30 -0
- package/dist/src/analyze/analyzeLog.d.ts.map +1 -0
- package/dist/src/analyze/analyzeLog.js +168 -0
- package/dist/src/analyze/analyzeLog.js.map +1 -0
- package/dist/src/analyze/analyzeProjectRepo.constants.d.ts +6 -0
- package/dist/src/analyze/analyzeProjectRepo.constants.d.ts.map +1 -0
- package/dist/src/analyze/analyzeProjectRepo.constants.js +53 -0
- package/dist/src/analyze/analyzeProjectRepo.constants.js.map +1 -0
- package/dist/src/analyze/analyzeProjectRepo.d.ts +35 -0
- package/dist/src/analyze/analyzeProjectRepo.d.ts.map +1 -0
- package/dist/src/analyze/analyzeProjectRepo.js +349 -0
- package/dist/src/analyze/analyzeProjectRepo.js.map +1 -0
- package/dist/src/analyze/askProjectRepo.d.ts +40 -0
- package/dist/src/analyze/askProjectRepo.d.ts.map +1 -0
- package/dist/src/analyze/askProjectRepo.helpers.d.ts +57 -0
- package/dist/src/analyze/askProjectRepo.helpers.d.ts.map +1 -0
- package/dist/src/analyze/askProjectRepo.helpers.js +233 -0
- package/dist/src/analyze/askProjectRepo.helpers.js.map +1 -0
- package/dist/src/analyze/askProjectRepo.js +287 -0
- package/dist/src/analyze/askProjectRepo.js.map +1 -0
- package/dist/src/analyze/defaults.d.ts +17 -0
- package/dist/src/analyze/defaults.d.ts.map +1 -0
- package/dist/src/analyze/defaults.js +17 -0
- package/dist/src/analyze/defaults.js.map +1 -0
- package/dist/src/analyze/embedText.d.ts +27 -0
- package/dist/src/analyze/embedText.d.ts.map +1 -0
- package/dist/src/analyze/embedText.js +132 -0
- package/dist/src/analyze/embedText.js.map +1 -0
- package/dist/src/calendar/calendarCreateEvent.d.ts +31 -0
- package/dist/src/calendar/calendarCreateEvent.d.ts.map +1 -0
- package/dist/src/calendar/calendarCreateEvent.js +67 -0
- package/dist/src/calendar/calendarCreateEvent.js.map +1 -0
- package/dist/src/calendar/calendarDeleteEvent.d.ts +22 -0
- package/dist/src/calendar/calendarDeleteEvent.d.ts.map +1 -0
- package/dist/src/calendar/calendarDeleteEvent.js +41 -0
- package/dist/src/calendar/calendarDeleteEvent.js.map +1 -0
- package/dist/src/calendar/calendarListEvents.d.ts +32 -0
- package/dist/src/calendar/calendarListEvents.d.ts.map +1 -0
- package/dist/src/calendar/calendarListEvents.js +95 -0
- package/dist/src/calendar/calendarListEvents.js.map +1 -0
- package/dist/src/calendar/calendarRescheduleEventByTitle.d.ts +30 -0
- package/dist/src/calendar/calendarRescheduleEventByTitle.d.ts.map +1 -0
- package/dist/src/calendar/calendarRescheduleEventByTitle.js +94 -0
- package/dist/src/calendar/calendarRescheduleEventByTitle.js.map +1 -0
- package/dist/src/calendar/calendarSearchEventsByTitle.d.ts +33 -0
- package/dist/src/calendar/calendarSearchEventsByTitle.d.ts.map +1 -0
- package/dist/src/calendar/calendarSearchEventsByTitle.js +95 -0
- package/dist/src/calendar/calendarSearchEventsByTitle.js.map +1 -0
- package/dist/src/calendar/calendarUpdateEvent.d.ts +27 -0
- package/dist/src/calendar/calendarUpdateEvent.d.ts.map +1 -0
- package/dist/src/calendar/calendarUpdateEvent.js +58 -0
- package/dist/src/calendar/calendarUpdateEvent.js.map +1 -0
- package/dist/src/cron/cronListEntries.d.ts +19 -0
- package/dist/src/cron/cronListEntries.d.ts.map +1 -0
- package/dist/src/cron/cronListEntries.js +33 -0
- package/dist/src/cron/cronListEntries.js.map +1 -0
- package/dist/src/cron/cronRemoveTaggedEntries.d.ts +21 -0
- package/dist/src/cron/cronRemoveTaggedEntries.d.ts.map +1 -0
- package/dist/src/cron/cronRemoveTaggedEntries.js +41 -0
- package/dist/src/cron/cronRemoveTaggedEntries.js.map +1 -0
- package/dist/src/cron/cronSetTaggedEntry.d.ts +24 -0
- package/dist/src/cron/cronSetTaggedEntry.d.ts.map +1 -0
- package/dist/src/cron/cronSetTaggedEntry.js +51 -0
- package/dist/src/cron/cronSetTaggedEntry.js.map +1 -0
- package/dist/src/exec/defaults.d.ts +8 -0
- package/dist/src/exec/defaults.d.ts.map +1 -0
- package/dist/src/exec/defaults.js +28 -0
- package/dist/src/exec/defaults.js.map +1 -0
- package/dist/src/exec/runCommand.d.ts +31 -0
- package/dist/src/exec/runCommand.d.ts.map +1 -0
- package/dist/src/exec/runCommand.js +158 -0
- package/dist/src/exec/runCommand.js.map +1 -0
- package/dist/src/fs/defaults.d.ts +16 -0
- package/dist/src/fs/defaults.d.ts.map +1 -0
- package/dist/src/fs/defaults.js +16 -0
- package/dist/src/fs/defaults.js.map +1 -0
- package/dist/src/fs/deletePath.d.ts +23 -0
- package/dist/src/fs/deletePath.d.ts.map +1 -0
- package/dist/src/fs/deletePath.js +70 -0
- package/dist/src/fs/deletePath.js.map +1 -0
- package/dist/src/fs/listDir.d.ts +35 -0
- package/dist/src/fs/listDir.d.ts.map +1 -0
- package/dist/src/fs/listDir.js +115 -0
- package/dist/src/fs/listDir.js.map +1 -0
- package/dist/src/fs/readText.d.ts +22 -0
- package/dist/src/fs/readText.d.ts.map +1 -0
- package/dist/src/fs/readText.js +47 -0
- package/dist/src/fs/readText.js.map +1 -0
- package/dist/src/fs/searchText.d.ts +40 -0
- package/dist/src/fs/searchText.d.ts.map +1 -0
- package/dist/src/fs/searchText.js +162 -0
- package/dist/src/fs/searchText.js.map +1 -0
- package/dist/src/fs/sha256.d.ts +21 -0
- package/dist/src/fs/sha256.d.ts.map +1 -0
- package/dist/src/fs/sha256.js +51 -0
- package/dist/src/fs/sha256.js.map +1 -0
- package/dist/src/fs/writeText.d.ts +28 -0
- package/dist/src/fs/writeText.d.ts.map +1 -0
- package/dist/src/fs/writeText.js +68 -0
- package/dist/src/fs/writeText.js.map +1 -0
- package/dist/src/git/common.d.ts +34 -0
- package/dist/src/git/common.d.ts.map +1 -0
- package/dist/src/git/common.js +120 -0
- package/dist/src/git/common.js.map +1 -0
- package/dist/src/git/defaults.d.ts +11 -0
- package/dist/src/git/defaults.d.ts.map +1 -0
- package/dist/src/git/defaults.js +54 -0
- package/dist/src/git/defaults.js.map +1 -0
- package/dist/src/git/ghRead.d.ts +29 -0
- package/dist/src/git/ghRead.d.ts.map +1 -0
- package/dist/src/git/ghRead.js +63 -0
- package/dist/src/git/ghRead.js.map +1 -0
- package/dist/src/git/gitAdd.d.ts +29 -0
- package/dist/src/git/gitAdd.d.ts.map +1 -0
- package/dist/src/git/gitAdd.js +57 -0
- package/dist/src/git/gitAdd.js.map +1 -0
- package/dist/src/git/gitCommit.d.ts +29 -0
- package/dist/src/git/gitCommit.d.ts.map +1 -0
- package/dist/src/git/gitCommit.js +56 -0
- package/dist/src/git/gitCommit.js.map +1 -0
- package/dist/src/git/gitDiff.d.ts +28 -0
- package/dist/src/git/gitDiff.d.ts.map +1 -0
- package/dist/src/git/gitDiff.js +54 -0
- package/dist/src/git/gitDiff.js.map +1 -0
- package/dist/src/git/gitLogHistory.d.ts +37 -0
- package/dist/src/git/gitLogHistory.d.ts.map +1 -0
- package/dist/src/git/gitLogHistory.js +85 -0
- package/dist/src/git/gitLogHistory.js.map +1 -0
- package/dist/src/git/gitPrView.d.ts +26 -0
- package/dist/src/git/gitPrView.d.ts.map +1 -0
- package/dist/src/git/gitPrView.js +66 -0
- package/dist/src/git/gitPrView.js.map +1 -0
- package/dist/src/git/gitPull.d.ts +31 -0
- package/dist/src/git/gitPull.d.ts.map +1 -0
- package/dist/src/git/gitPull.js +56 -0
- package/dist/src/git/gitPull.js.map +1 -0
- package/dist/src/git/gitRead.d.ts +28 -0
- package/dist/src/git/gitRead.d.ts.map +1 -0
- package/dist/src/git/gitRead.js +59 -0
- package/dist/src/git/gitRead.js.map +1 -0
- package/dist/src/git/gitStatus.d.ts +28 -0
- package/dist/src/git/gitStatus.d.ts.map +1 -0
- package/dist/src/git/gitStatus.js +55 -0
- package/dist/src/git/gitStatus.js.map +1 -0
- package/dist/src/git/gitSwitchBranch.d.ts +29 -0
- package/dist/src/git/gitSwitchBranch.d.ts.map +1 -0
- package/dist/src/git/gitSwitchBranch.js +57 -0
- package/dist/src/git/gitSwitchBranch.js.map +1 -0
- package/dist/src/git/gitTools.d.ts +11 -0
- package/dist/src/git/gitTools.d.ts.map +1 -0
- package/dist/src/git/gitTools.js +11 -0
- package/dist/src/git/gitTools.js.map +1 -0
- package/dist/src/http/defaults.d.ts +10 -0
- package/dist/src/http/defaults.d.ts.map +1 -0
- package/dist/src/http/defaults.js +19 -0
- package/dist/src/http/defaults.js.map +1 -0
- package/dist/src/http/downloadFile.d.ts +31 -0
- package/dist/src/http/downloadFile.d.ts.map +1 -0
- package/dist/src/http/downloadFile.js +188 -0
- package/dist/src/http/downloadFile.js.map +1 -0
- package/dist/src/http/duckduckgoSearch.d.ts +31 -0
- package/dist/src/http/duckduckgoSearch.d.ts.map +1 -0
- package/dist/src/http/duckduckgoSearch.js +190 -0
- package/dist/src/http/duckduckgoSearch.js.map +1 -0
- package/dist/src/http/fetchJson.d.ts +28 -0
- package/dist/src/http/fetchJson.d.ts.map +1 -0
- package/dist/src/http/fetchJson.js +139 -0
- package/dist/src/http/fetchJson.js.map +1 -0
- package/dist/src/http/fetchPageMainContent.d.ts +27 -0
- package/dist/src/http/fetchPageMainContent.d.ts.map +1 -0
- package/dist/src/http/fetchPageMainContent.js +164 -0
- package/dist/src/http/fetchPageMainContent.js.map +1 -0
- package/dist/src/http/fetchText.d.ts +29 -0
- package/dist/src/http/fetchText.d.ts.map +1 -0
- package/dist/src/http/fetchText.js +153 -0
- package/dist/src/http/fetchText.js.map +1 -0
- package/dist/src/http/head.d.ts +25 -0
- package/dist/src/http/head.d.ts.map +1 -0
- package/dist/src/http/head.js +80 -0
- package/dist/src/http/head.js.map +1 -0
- package/dist/src/http/yahooFinance.d.ts +39 -0
- package/dist/src/http/yahooFinance.d.ts.map +1 -0
- package/dist/src/http/yahooFinance.js +160 -0
- package/dist/src/http/yahooFinance.js.map +1 -0
- package/dist/src/iterm/common.d.ts +51 -0
- package/dist/src/iterm/common.d.ts.map +1 -0
- package/dist/src/iterm/common.js +214 -0
- package/dist/src/iterm/common.js.map +1 -0
- package/dist/src/iterm/itermCreateTab.d.ts +30 -0
- package/dist/src/iterm/itermCreateTab.d.ts.map +1 -0
- package/dist/src/iterm/itermCreateTab.js +73 -0
- package/dist/src/iterm/itermCreateTab.js.map +1 -0
- package/dist/src/iterm/itermCreateWindow.d.ts +30 -0
- package/dist/src/iterm/itermCreateWindow.d.ts.map +1 -0
- package/dist/src/iterm/itermCreateWindow.js +78 -0
- package/dist/src/iterm/itermCreateWindow.js.map +1 -0
- package/dist/src/iterm/itermGetSessionInfo.d.ts +30 -0
- package/dist/src/iterm/itermGetSessionInfo.d.ts.map +1 -0
- package/dist/src/iterm/itermGetSessionInfo.js +41 -0
- package/dist/src/iterm/itermGetSessionInfo.js.map +1 -0
- package/dist/src/iterm/itermListCurrentWindowSessions.d.ts +22 -0
- package/dist/src/iterm/itermListCurrentWindowSessions.d.ts.map +1 -0
- package/dist/src/iterm/itermListCurrentWindowSessions.js +67 -0
- package/dist/src/iterm/itermListCurrentWindowSessions.js.map +1 -0
- package/dist/src/iterm/itermListWindows.d.ts +31 -0
- package/dist/src/iterm/itermListWindows.d.ts.map +1 -0
- package/dist/src/iterm/itermListWindows.js +73 -0
- package/dist/src/iterm/itermListWindows.js.map +1 -0
- package/dist/src/iterm/itermRename.d.ts +30 -0
- package/dist/src/iterm/itermRename.d.ts.map +1 -0
- package/dist/src/iterm/itermRename.js +49 -0
- package/dist/src/iterm/itermRename.js.map +1 -0
- package/dist/src/iterm/itermResizeWindow.d.ts +29 -0
- package/dist/src/iterm/itermResizeWindow.d.ts.map +1 -0
- package/dist/src/iterm/itermResizeWindow.js +53 -0
- package/dist/src/iterm/itermResizeWindow.js.map +1 -0
- package/dist/src/iterm/itermRunCommandInSession.d.ts +37 -0
- package/dist/src/iterm/itermRunCommandInSession.d.ts.map +1 -0
- package/dist/src/iterm/itermRunCommandInSession.js +175 -0
- package/dist/src/iterm/itermRunCommandInSession.js.map +1 -0
- package/dist/src/iterm/itermSendText.d.ts +31 -0
- package/dist/src/iterm/itermSendText.d.ts.map +1 -0
- package/dist/src/iterm/itermSendText.js +70 -0
- package/dist/src/iterm/itermSendText.js.map +1 -0
- package/dist/src/iterm/itermSetBackgroundColor.d.ts +35 -0
- package/dist/src/iterm/itermSetBackgroundColor.d.ts.map +1 -0
- package/dist/src/iterm/itermSetBackgroundColor.js +41 -0
- package/dist/src/iterm/itermSetBackgroundColor.js.map +1 -0
- package/dist/src/iterm/itermSetSessionColors.d.ts +48 -0
- package/dist/src/iterm/itermSetSessionColors.d.ts.map +1 -0
- package/dist/src/iterm/itermSetSessionColors.js +71 -0
- package/dist/src/iterm/itermSetSessionColors.js.map +1 -0
- package/dist/src/iterm/itermSplitPane.d.ts +32 -0
- package/dist/src/iterm/itermSplitPane.d.ts.map +1 -0
- package/dist/src/iterm/itermSplitPane.js +76 -0
- package/dist/src/iterm/itermSplitPane.js.map +1 -0
- package/dist/src/iterm/itermTools.d.ts +13 -0
- package/dist/src/iterm/itermTools.d.ts.map +1 -0
- package/dist/src/iterm/itermTools.js +13 -0
- package/dist/src/iterm/itermTools.js.map +1 -0
- package/dist/src/messages/messagesFindChatsByParticipant.d.ts +27 -0
- package/dist/src/messages/messagesFindChatsByParticipant.d.ts.map +1 -0
- package/dist/src/messages/messagesFindChatsByParticipant.js +95 -0
- package/dist/src/messages/messagesFindChatsByParticipant.js.map +1 -0
- package/dist/src/messages/messagesListChats.d.ts +25 -0
- package/dist/src/messages/messagesListChats.d.ts.map +1 -0
- package/dist/src/messages/messagesListChats.js +69 -0
- package/dist/src/messages/messagesListChats.js.map +1 -0
- package/dist/src/messages/messagesReadChat.d.ts +28 -0
- package/dist/src/messages/messagesReadChat.d.ts.map +1 -0
- package/dist/src/messages/messagesReadChat.js +88 -0
- package/dist/src/messages/messagesReadChat.js.map +1 -0
- package/dist/src/messages/messagesSendByChatId.d.ts +22 -0
- package/dist/src/messages/messagesSendByChatId.d.ts.map +1 -0
- package/dist/src/messages/messagesSendByChatId.js +48 -0
- package/dist/src/messages/messagesSendByChatId.js.map +1 -0
- package/dist/src/messages/messagesSendByHandle.d.ts +26 -0
- package/dist/src/messages/messagesSendByHandle.d.ts.map +1 -0
- package/dist/src/messages/messagesSendByHandle.js +67 -0
- package/dist/src/messages/messagesSendByHandle.js.map +1 -0
- package/dist/src/messages/messagesSendByParticipantQuery.d.ts +26 -0
- package/dist/src/messages/messagesSendByParticipantQuery.d.ts.map +1 -0
- package/dist/src/messages/messagesSendByParticipantQuery.js +93 -0
- package/dist/src/messages/messagesSendByParticipantQuery.js.map +1 -0
- package/dist/src/notes/notesCreate.d.ts +23 -0
- package/dist/src/notes/notesCreate.d.ts.map +1 -0
- package/dist/src/notes/notesCreate.js +56 -0
- package/dist/src/notes/notesCreate.js.map +1 -0
- package/dist/src/notes/notesDelete.d.ts +20 -0
- package/dist/src/notes/notesDelete.d.ts.map +1 -0
- package/dist/src/notes/notesDelete.js +58 -0
- package/dist/src/notes/notesDelete.js.map +1 -0
- package/dist/src/notes/notesList.d.ts +26 -0
- package/dist/src/notes/notesList.d.ts.map +1 -0
- package/dist/src/notes/notesList.js +80 -0
- package/dist/src/notes/notesList.js.map +1 -0
- package/dist/src/notes/notesRead.d.ts +26 -0
- package/dist/src/notes/notesRead.d.ts.map +1 -0
- package/dist/src/notes/notesRead.js +82 -0
- package/dist/src/notes/notesRead.js.map +1 -0
- package/dist/src/notes/notesUpdate.d.ts +24 -0
- package/dist/src/notes/notesUpdate.d.ts.map +1 -0
- package/dist/src/notes/notesUpdate.js +75 -0
- package/dist/src/notes/notesUpdate.js.map +1 -0
- package/dist/src/osascript/common.d.ts +6 -0
- package/dist/src/osascript/common.d.ts.map +1 -0
- package/dist/src/osascript/common.js +52 -0
- package/dist/src/osascript/common.js.map +1 -0
- package/dist/src/platform/adapters/darwin.d.ts +3 -0
- package/dist/src/platform/adapters/darwin.d.ts.map +1 -0
- package/dist/src/platform/adapters/darwin.js +14 -0
- package/dist/src/platform/adapters/darwin.js.map +1 -0
- package/dist/src/platform/adapters/linux.d.ts +3 -0
- package/dist/src/platform/adapters/linux.d.ts.map +1 -0
- package/dist/src/platform/adapters/linux.js +8 -0
- package/dist/src/platform/adapters/linux.js.map +1 -0
- package/dist/src/platform/adapters/win32.d.ts +3 -0
- package/dist/src/platform/adapters/win32.d.ts.map +1 -0
- package/dist/src/platform/adapters/win32.js +8 -0
- package/dist/src/platform/adapters/win32.js.map +1 -0
- package/dist/src/platform/platformGetCapabilities.d.ts +23 -0
- package/dist/src/platform/platformGetCapabilities.d.ts.map +1 -0
- package/dist/src/platform/platformGetCapabilities.js +32 -0
- package/dist/src/platform/platformGetCapabilities.js.map +1 -0
- package/dist/src/platform/registry.d.ts +3 -0
- package/dist/src/platform/registry.d.ts.map +1 -0
- package/dist/src/platform/registry.js +16 -0
- package/dist/src/platform/registry.js.map +1 -0
- package/dist/src/platform/runtime.d.ts +15 -0
- package/dist/src/platform/runtime.d.ts.map +1 -0
- package/dist/src/platform/runtime.js +37 -0
- package/dist/src/platform/runtime.js.map +1 -0
- package/dist/src/platform/securityCompat.d.ts +8 -0
- package/dist/src/platform/securityCompat.d.ts.map +1 -0
- package/dist/src/platform/securityCompat.js +3 -0
- package/dist/src/platform/securityCompat.js.map +1 -0
- package/dist/src/platform/types.d.ts +10 -0
- package/dist/src/platform/types.d.ts.map +1 -0
- package/dist/src/platform/types.js +10 -0
- package/dist/src/platform/types.js.map +1 -0
- package/dist/src/reminders/remindersComplete.d.ts +22 -0
- package/dist/src/reminders/remindersComplete.d.ts.map +1 -0
- package/dist/src/reminders/remindersComplete.js +60 -0
- package/dist/src/reminders/remindersComplete.js.map +1 -0
- package/dist/src/reminders/remindersCreate.d.ts +24 -0
- package/dist/src/reminders/remindersCreate.d.ts.map +1 -0
- package/dist/src/reminders/remindersCreate.js +57 -0
- package/dist/src/reminders/remindersCreate.js.map +1 -0
- package/dist/src/reminders/remindersDelete.d.ts +22 -0
- package/dist/src/reminders/remindersDelete.d.ts.map +1 -0
- package/dist/src/reminders/remindersDelete.js +60 -0
- package/dist/src/reminders/remindersDelete.js.map +1 -0
- package/dist/src/reminders/remindersFind.d.ts +30 -0
- package/dist/src/reminders/remindersFind.d.ts.map +1 -0
- package/dist/src/reminders/remindersFind.js +85 -0
- package/dist/src/reminders/remindersFind.js.map +1 -0
- package/dist/src/reminders/remindersList.d.ts +28 -0
- package/dist/src/reminders/remindersList.d.ts.map +1 -0
- package/dist/src/reminders/remindersList.js +78 -0
- package/dist/src/reminders/remindersList.js.map +1 -0
- package/dist/src/safari/safariCloseTab.d.ts +22 -0
- package/dist/src/safari/safariCloseTab.d.ts.map +1 -0
- package/dist/src/safari/safariCloseTab.js +39 -0
- package/dist/src/safari/safariCloseTab.js.map +1 -0
- package/dist/src/safari/safariGetActiveTab.d.ts +18 -0
- package/dist/src/safari/safariGetActiveTab.d.ts.map +1 -0
- package/dist/src/safari/safariGetActiveTab.js +34 -0
- package/dist/src/safari/safariGetActiveTab.js.map +1 -0
- package/dist/src/safari/safariListTabs.d.ts +26 -0
- package/dist/src/safari/safariListTabs.d.ts.map +1 -0
- package/dist/src/safari/safariListTabs.js +71 -0
- package/dist/src/safari/safariListTabs.js.map +1 -0
- package/dist/src/safari/safariOpenWebUrl.d.ts +22 -0
- package/dist/src/safari/safariOpenWebUrl.d.ts.map +1 -0
- package/dist/src/safari/safariOpenWebUrl.js +49 -0
- package/dist/src/safari/safariOpenWebUrl.js.map +1 -0
- package/dist/src/safari/safariReadPageContent.d.ts +31 -0
- package/dist/src/safari/safariReadPageContent.d.ts.map +1 -0
- package/dist/src/safari/safariReadPageContent.js +69 -0
- package/dist/src/safari/safariReadPageContent.js.map +1 -0
- package/dist/src/safari/safariReadSelection.d.ts +26 -0
- package/dist/src/safari/safariReadSelection.d.ts.map +1 -0
- package/dist/src/safari/safariReadSelection.js +75 -0
- package/dist/src/safari/safariReadSelection.js.map +1 -0
- package/dist/src/util/hashText.d.ts +19 -0
- package/dist/src/util/hashText.d.ts.map +1 -0
- package/dist/src/util/hashText.js +24 -0
- package/dist/src/util/hashText.js.map +1 -0
- package/dist/src/util/jsonSelect.d.ts +22 -0
- package/dist/src/util/jsonSelect.d.ts.map +1 -0
- package/dist/src/util/jsonSelect.js +41 -0
- package/dist/src/util/jsonSelect.js.map +1 -0
- package/dist/src/util/now.d.ts +22 -0
- package/dist/src/util/now.d.ts.map +1 -0
- package/dist/src/util/now.js +51 -0
- package/dist/src/util/now.js.map +1 -0
- package/dist/src/util/overrideWithConfig.d.ts +2 -0
- package/dist/src/util/overrideWithConfig.d.ts.map +1 -0
- package/dist/src/util/overrideWithConfig.js +2 -0
- package/dist/src/util/overrideWithConfig.js.map +1 -0
- package/dist/src/util/templateRender.d.ts +20 -0
- package/dist/src/util/templateRender.d.ts.map +1 -0
- package/dist/src/util/templateRender.js +40 -0
- package/dist/src/util/templateRender.js.map +1 -0
- package/dist/src/util/truncate.d.ts +23 -0
- package/dist/src/util/truncate.d.ts.map +1 -0
- package/dist/src/util/truncate.js +44 -0
- package/dist/src/util/truncate.js.map +1 -0
- package/dist/vitest.config.d.ts +3 -0
- package/dist/vitest.config.d.ts.map +1 -0
- package/dist/vitest.config.js +8 -0
- package/dist/vitest.config.js.map +1 -0
- package/package.json +65 -0
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
import { createTaggedError } from "@botbotgo/kit/sdk";
|
|
2
|
+
import { parseSeparatedRows, quoteAppleScriptString, runOsaScript } from "../osascript/common.js";
|
|
3
|
+
/**
|
|
4
|
+
* Canonical name for searching calendar events by title.
|
|
5
|
+
* @tool
|
|
6
|
+
* @effect none
|
|
7
|
+
*/
|
|
8
|
+
export async function calendarSearchEventsByTitle(args) {
|
|
9
|
+
const titleQuery = args.titleQuery?.trim();
|
|
10
|
+
if (!titleQuery)
|
|
11
|
+
throw createTaggedError("CALENDAR_INVALID", "titleQuery is required", {});
|
|
12
|
+
const calendar = args.calendar?.trim() || "Home";
|
|
13
|
+
const fromDateText = args.fromDateText?.trim() || null;
|
|
14
|
+
const toDateText = args.toDateText?.trim() || null;
|
|
15
|
+
const hasRange = Boolean(fromDateText && toDateText);
|
|
16
|
+
const limit = Math.max(1, Math.min(500, Math.trunc(args.limit ?? 100)));
|
|
17
|
+
const lines = [
|
|
18
|
+
'tell application "Calendar"',
|
|
19
|
+
"activate",
|
|
20
|
+
"set rs to (ASCII character 30)",
|
|
21
|
+
"set fs to (ASCII character 31)",
|
|
22
|
+
`set calName to ${quoteAppleScriptString(calendar)}`,
|
|
23
|
+
...(hasRange
|
|
24
|
+
? [
|
|
25
|
+
`set fromText to ${quoteAppleScriptString(fromDateText)}`,
|
|
26
|
+
`set toText to ${quoteAppleScriptString(toDateText)}`,
|
|
27
|
+
"set fromDate to date fromText",
|
|
28
|
+
"set toDate to date toText",
|
|
29
|
+
]
|
|
30
|
+
: []),
|
|
31
|
+
"set targetCal to calendar calName",
|
|
32
|
+
"set rows to {}",
|
|
33
|
+
"set n to 0",
|
|
34
|
+
`set maxCount to ${limit}`,
|
|
35
|
+
...(hasRange
|
|
36
|
+
? ["set matchedEvents to (every event of targetCal whose start date >= fromDate and start date <= toDate)"]
|
|
37
|
+
: ["set matchedEvents to every event of targetCal"]),
|
|
38
|
+
"repeat with ev in matchedEvents",
|
|
39
|
+
"if n is greater than or equal to maxCount then exit repeat",
|
|
40
|
+
"set n to n + 1",
|
|
41
|
+
"set eid to \"\"",
|
|
42
|
+
"try",
|
|
43
|
+
"set eid to (uid of ev) as text",
|
|
44
|
+
"end try",
|
|
45
|
+
"set titleText to \"\"",
|
|
46
|
+
"try",
|
|
47
|
+
"set titleText to (summary of ev) as text",
|
|
48
|
+
"end try",
|
|
49
|
+
"set startText to \"\"",
|
|
50
|
+
"try",
|
|
51
|
+
"set startText to (start date of ev) as text",
|
|
52
|
+
"end try",
|
|
53
|
+
"set endText to \"\"",
|
|
54
|
+
"try",
|
|
55
|
+
"set endText to (end date of ev) as text",
|
|
56
|
+
"end try",
|
|
57
|
+
"set end of rows to eid & fs & titleText & fs & startText & fs & endText",
|
|
58
|
+
"end repeat",
|
|
59
|
+
"set AppleScript's text item delimiters to rs",
|
|
60
|
+
"set outText to rows as text",
|
|
61
|
+
"set AppleScript's text item delimiters to \"\"",
|
|
62
|
+
"return outText",
|
|
63
|
+
"end tell",
|
|
64
|
+
];
|
|
65
|
+
const output = await runOsaScript(lines, "CALENDAR");
|
|
66
|
+
const rows = parseSeparatedRows(output);
|
|
67
|
+
const q = titleQuery.toLowerCase();
|
|
68
|
+
const events = rows
|
|
69
|
+
.map((parts) => ({
|
|
70
|
+
id: parts[0] ?? "",
|
|
71
|
+
title: parts[1] ?? "",
|
|
72
|
+
startDateText: parts[2] ?? "",
|
|
73
|
+
endDateText: parts[3] ?? "",
|
|
74
|
+
}))
|
|
75
|
+
.filter((event) => event.title.toLowerCase().includes(q));
|
|
76
|
+
return {
|
|
77
|
+
result: {
|
|
78
|
+
titleQuery,
|
|
79
|
+
calendar,
|
|
80
|
+
fromDateText,
|
|
81
|
+
toDateText,
|
|
82
|
+
count: events.length,
|
|
83
|
+
events,
|
|
84
|
+
},
|
|
85
|
+
evidence: [
|
|
86
|
+
{
|
|
87
|
+
type: "tool",
|
|
88
|
+
ref: "calendarSearchEventsByTitle",
|
|
89
|
+
summary: `Found ${events.length} events matching \"${titleQuery}\"`,
|
|
90
|
+
createdAt: new Date().toISOString(),
|
|
91
|
+
},
|
|
92
|
+
],
|
|
93
|
+
};
|
|
94
|
+
}
|
|
95
|
+
//# sourceMappingURL=calendarSearchEventsByTitle.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"calendarSearchEventsByTitle.js","sourceRoot":"","sources":["../../../src/calendar/calendarSearchEventsByTitle.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Update calendar event by uid in specific calendar.
|
|
3
|
+
* @tool
|
|
4
|
+
* @effect local_write
|
|
5
|
+
*/
|
|
6
|
+
export declare function calendarUpdateEvent(args: {
|
|
7
|
+
id: string;
|
|
8
|
+
calendar?: string;
|
|
9
|
+
title?: string;
|
|
10
|
+
startDateText?: string;
|
|
11
|
+
endDateText?: string;
|
|
12
|
+
location?: string;
|
|
13
|
+
notes?: string;
|
|
14
|
+
}): Promise<{
|
|
15
|
+
result: {
|
|
16
|
+
id: string;
|
|
17
|
+
calendar: string;
|
|
18
|
+
status: string;
|
|
19
|
+
};
|
|
20
|
+
evidence: {
|
|
21
|
+
type: string;
|
|
22
|
+
ref: string;
|
|
23
|
+
summary: string;
|
|
24
|
+
createdAt: string;
|
|
25
|
+
}[];
|
|
26
|
+
}>;
|
|
27
|
+
//# sourceMappingURL=calendarUpdateEvent.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"calendarUpdateEvent.d.ts","sourceRoot":"","sources":["../../../src/calendar/calendarUpdateEvent.ts"],"names":[],"mappings":"AAGA;;;;GAIG;AACH,wBAAsB,mBAAmB,CAAC,IAAI,EAAE;IAC9C,EAAE,EAAE,MAAM,CAAC;IACX,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;;;;;;;;;;;;GAmDA"}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { createTaggedError } from "@botbotgo/kit/sdk";
|
|
2
|
+
import { quoteAppleScriptString, runOsaScript } from "../osascript/common.js";
|
|
3
|
+
/**
|
|
4
|
+
* Update calendar event by uid in specific calendar.
|
|
5
|
+
* @tool
|
|
6
|
+
* @effect local_write
|
|
7
|
+
*/
|
|
8
|
+
export async function calendarUpdateEvent(args) {
|
|
9
|
+
const id = args.id?.trim();
|
|
10
|
+
const calendar = args.calendar?.trim() || "Home";
|
|
11
|
+
if (!id)
|
|
12
|
+
throw createTaggedError("CALENDAR_INVALID", "id is required", {});
|
|
13
|
+
if (!args.title && !args.startDateText && !args.endDateText && !args.location && !args.notes) {
|
|
14
|
+
throw createTaggedError("CALENDAR_INVALID", "at least one field to update is required", {});
|
|
15
|
+
}
|
|
16
|
+
const lines = [
|
|
17
|
+
'tell application "Calendar"',
|
|
18
|
+
"activate",
|
|
19
|
+
`set calName to ${quoteAppleScriptString(calendar)}`,
|
|
20
|
+
`set wantedId to ${quoteAppleScriptString(id)}`,
|
|
21
|
+
"set targetCal to calendar calName",
|
|
22
|
+
"set targetEvent to first event of targetCal whose (uid as text) is wantedId",
|
|
23
|
+
...(args.title?.trim() ? [`set summary of targetEvent to ${quoteAppleScriptString(args.title.trim())}`] : []),
|
|
24
|
+
...(args.startDateText?.trim()
|
|
25
|
+
? [
|
|
26
|
+
`set stText to ${quoteAppleScriptString(args.startDateText.trim())}`,
|
|
27
|
+
"set start date of targetEvent to date stText",
|
|
28
|
+
]
|
|
29
|
+
: []),
|
|
30
|
+
...(args.endDateText?.trim()
|
|
31
|
+
? [
|
|
32
|
+
`set edText to ${quoteAppleScriptString(args.endDateText.trim())}`,
|
|
33
|
+
"set end date of targetEvent to date edText",
|
|
34
|
+
]
|
|
35
|
+
: []),
|
|
36
|
+
...(args.location?.trim() ? [`set location of targetEvent to ${quoteAppleScriptString(args.location.trim())}`] : []),
|
|
37
|
+
...(args.notes?.trim() ? [`set description of targetEvent to ${quoteAppleScriptString(args.notes.trim())}`] : []),
|
|
38
|
+
'return "updated"',
|
|
39
|
+
"end tell",
|
|
40
|
+
];
|
|
41
|
+
const output = await runOsaScript(lines, "CALENDAR");
|
|
42
|
+
return {
|
|
43
|
+
result: {
|
|
44
|
+
id,
|
|
45
|
+
calendar,
|
|
46
|
+
status: output || "updated",
|
|
47
|
+
},
|
|
48
|
+
evidence: [
|
|
49
|
+
{
|
|
50
|
+
type: "tool",
|
|
51
|
+
ref: "calendarUpdateEvent",
|
|
52
|
+
summary: `Updated calendar event ${id} in ${calendar}`,
|
|
53
|
+
createdAt: new Date().toISOString(),
|
|
54
|
+
},
|
|
55
|
+
],
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
//# sourceMappingURL=calendarUpdateEvent.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"calendarUpdateEvent.js","sourceRoot":"","sources":["../../../src/calendar/calendarUpdateEvent.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AACtD,OAAO,EAAE,sBAAsB,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AAE9E;;;;GAIG;AACH,MAAM,CAAC,KAAK,UAAU,mBAAmB,CAAC,IAQzC;IACC,MAAM,EAAE,GAAG,IAAI,CAAC,EAAE,EAAE,IAAI,EAAE,CAAC;IAC3B,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,EAAE,IAAI,EAAE,IAAI,MAAM,CAAC;IACjD,IAAI,CAAC,EAAE;QAAE,MAAM,iBAAiB,CAAC,kBAAkB,EAAE,gBAAgB,EAAE,EAAE,CAAC,CAAC;IAC3E,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;QAC7F,MAAM,iBAAiB,CAAC,kBAAkB,EAAE,0CAA0C,EAAE,EAAE,CAAC,CAAC;IAC9F,CAAC;IAED,MAAM,KAAK,GAAG;QACZ,6BAA6B;QAC7B,UAAU;QACV,kBAAkB,sBAAsB,CAAC,QAAQ,CAAC,EAAE;QACpD,mBAAmB,sBAAsB,CAAC,EAAE,CAAC,EAAE;QAC/C,mCAAmC;QACnC,6EAA6E;QAC7E,GAAG,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,iCAAiC,sBAAsB,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAC7G,GAAG,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,EAAE;YAC5B,CAAC,CAAC;gBACE,iBAAiB,sBAAsB,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC,EAAE;gBACpE,8CAA8C;aAC/C;YACH,CAAC,CAAC,EAAE,CAAC;QACP,GAAG,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,EAAE;YAC1B,CAAC,CAAC;gBACE,iBAAiB,sBAAsB,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC,EAAE;gBAClE,4CAA4C;aAC7C;YACH,CAAC,CAAC,EAAE,CAAC;QACP,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,kCAAkC,sBAAsB,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QACpH,GAAG,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,qCAAqC,sBAAsB,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QACjH,kBAAkB;QAClB,UAAU;KACX,CAAC;IAEF,MAAM,MAAM,GAAG,MAAM,YAAY,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC;IAErD,OAAO;QACL,MAAM,EAAE;YACN,EAAE;YACF,QAAQ;YACR,MAAM,EAAE,MAAM,IAAI,SAAS;SAC5B;QACD,QAAQ,EAAE;YACR;gBACE,IAAI,EAAE,MAAM;gBACZ,GAAG,EAAE,qBAAqB;gBAC1B,OAAO,EAAE,0BAA0B,EAAE,OAAO,QAAQ,EAAE;gBACtD,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;aACpC;SACF;KACF,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Canonical name for listing cron entries.
|
|
3
|
+
* @tool
|
|
4
|
+
* @effect none
|
|
5
|
+
*/
|
|
6
|
+
export declare function cronListEntries(_?: {}): Promise<{
|
|
7
|
+
result: {
|
|
8
|
+
count: number;
|
|
9
|
+
entries: string[];
|
|
10
|
+
raw: string;
|
|
11
|
+
};
|
|
12
|
+
evidence: {
|
|
13
|
+
type: string;
|
|
14
|
+
ref: string;
|
|
15
|
+
summary: string;
|
|
16
|
+
createdAt: string;
|
|
17
|
+
}[];
|
|
18
|
+
}>;
|
|
19
|
+
//# sourceMappingURL=cronListEntries.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cronListEntries.d.ts","sourceRoot":"","sources":["../../../src/cron/cronListEntries.ts"],"names":[],"mappings":"AAEA;;;;GAIG;AACH,wBAAsB,eAAe,CAAC,CAAC,GAAE,EAAO;;;;;;;;;;;;GA2B/C"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { runOsaScript } from "../osascript/common.js";
|
|
2
|
+
/**
|
|
3
|
+
* Canonical name for listing cron entries.
|
|
4
|
+
* @tool
|
|
5
|
+
* @effect none
|
|
6
|
+
*/
|
|
7
|
+
export async function cronListEntries(_ = {}) {
|
|
8
|
+
const lines = [
|
|
9
|
+
"set sh to \"crontab -l 2>/dev/null || true\"",
|
|
10
|
+
"return do shell script sh",
|
|
11
|
+
];
|
|
12
|
+
const output = await runOsaScript(lines, "CRON");
|
|
13
|
+
const linesOut = output
|
|
14
|
+
.split(/\r?\n/)
|
|
15
|
+
.map((line) => line.trim())
|
|
16
|
+
.filter((line) => line.length > 0);
|
|
17
|
+
return {
|
|
18
|
+
result: {
|
|
19
|
+
count: linesOut.length,
|
|
20
|
+
entries: linesOut,
|
|
21
|
+
raw: output,
|
|
22
|
+
},
|
|
23
|
+
evidence: [
|
|
24
|
+
{
|
|
25
|
+
type: "tool",
|
|
26
|
+
ref: "cronListEntries",
|
|
27
|
+
summary: `Listed ${linesOut.length} cron entries`,
|
|
28
|
+
createdAt: new Date().toISOString(),
|
|
29
|
+
},
|
|
30
|
+
],
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
//# sourceMappingURL=cronListEntries.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cronListEntries.js","sourceRoot":"","sources":["../../../src/cron/cronListEntries.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AAEtD;;;;GAIG;AACH,MAAM,CAAC,KAAK,UAAU,eAAe,CAAC,IAAQ,EAAE;IAC9C,MAAM,KAAK,GAAG;QACZ,8CAA8C;QAC9C,2BAA2B;KAC5B,CAAC;IAEF,MAAM,MAAM,GAAG,MAAM,YAAY,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;IACjD,MAAM,QAAQ,GAAG,MAAM;SACpB,KAAK,CAAC,OAAO,CAAC;SACd,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;SAC1B,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;IAErC,OAAO;QACL,MAAM,EAAE;YACN,KAAK,EAAE,QAAQ,CAAC,MAAM;YACtB,OAAO,EAAE,QAAQ;YACjB,GAAG,EAAE,MAAM;SACZ;QACD,QAAQ,EAAE;YACR;gBACE,IAAI,EAAE,MAAM;gBACZ,GAAG,EAAE,iBAAiB;gBACtB,OAAO,EAAE,UAAU,QAAQ,CAAC,MAAM,eAAe;gBACjD,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;aACpC;SACF;KACF,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Canonical name for removing tagged cron entries.
|
|
3
|
+
* @tool
|
|
4
|
+
* @effect local_write
|
|
5
|
+
*/
|
|
6
|
+
export declare function cronRemoveTaggedEntries(args: {
|
|
7
|
+
tag: string;
|
|
8
|
+
}): Promise<{
|
|
9
|
+
result: {
|
|
10
|
+
tag: string;
|
|
11
|
+
marker: string;
|
|
12
|
+
status: string;
|
|
13
|
+
};
|
|
14
|
+
evidence: {
|
|
15
|
+
type: string;
|
|
16
|
+
ref: string;
|
|
17
|
+
summary: string;
|
|
18
|
+
createdAt: string;
|
|
19
|
+
}[];
|
|
20
|
+
}>;
|
|
21
|
+
//# sourceMappingURL=cronRemoveTaggedEntries.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cronRemoveTaggedEntries.d.ts","sourceRoot":"","sources":["../../../src/cron/cronRemoveTaggedEntries.ts"],"names":[],"mappings":"AAOA;;;;GAIG;AACH,wBAAsB,uBAAuB,CAAC,IAAI,EAAE;IAAE,GAAG,EAAE,MAAM,CAAA;CAAE;;;;;;;;;;;;GA+BlE"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { createTaggedError } from "@botbotgo/kit/sdk";
|
|
2
|
+
import { quoteAppleScriptString, runOsaScript } from "../osascript/common.js";
|
|
3
|
+
function b64(input) {
|
|
4
|
+
return Buffer.from(input, "utf-8").toString("base64");
|
|
5
|
+
}
|
|
6
|
+
/**
|
|
7
|
+
* Canonical name for removing tagged cron entries.
|
|
8
|
+
* @tool
|
|
9
|
+
* @effect local_write
|
|
10
|
+
*/
|
|
11
|
+
export async function cronRemoveTaggedEntries(args) {
|
|
12
|
+
const tag = args.tag?.trim();
|
|
13
|
+
if (!tag)
|
|
14
|
+
throw createTaggedError("CRON_INVALID", "tag is required", {});
|
|
15
|
+
const marker = `# botbotgo:${tag}`;
|
|
16
|
+
const script = [
|
|
17
|
+
"set -e",
|
|
18
|
+
`marker=$(printf '%s' ${JSON.stringify(b64(marker))} | base64 -D)`,
|
|
19
|
+
"existing=$(crontab -l 2>/dev/null || true)",
|
|
20
|
+
"filtered=$(printf '%s\\n' \"$existing\" | grep -vF \"$marker\" || true)",
|
|
21
|
+
"printf '%s\\n' \"$filtered\" | sed '/^[[:space:]]*$/d' | crontab -",
|
|
22
|
+
"printf '%s' \"$marker\"",
|
|
23
|
+
].join("; ");
|
|
24
|
+
const output = await runOsaScript([`return do shell script ${quoteAppleScriptString(script)}`], "CRON");
|
|
25
|
+
return {
|
|
26
|
+
result: {
|
|
27
|
+
tag,
|
|
28
|
+
marker: output || marker,
|
|
29
|
+
status: "removed",
|
|
30
|
+
},
|
|
31
|
+
evidence: [
|
|
32
|
+
{
|
|
33
|
+
type: "tool",
|
|
34
|
+
ref: "cronRemoveTaggedEntries",
|
|
35
|
+
summary: `Removed cron entries with tag ${tag}`,
|
|
36
|
+
createdAt: new Date().toISOString(),
|
|
37
|
+
},
|
|
38
|
+
],
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=cronRemoveTaggedEntries.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cronRemoveTaggedEntries.js","sourceRoot":"","sources":["../../../src/cron/cronRemoveTaggedEntries.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AACtD,OAAO,EAAE,sBAAsB,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AAE9E,SAAS,GAAG,CAAC,KAAa;IACxB,OAAO,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;AACxD,CAAC;AAED;;;;GAIG;AACH,MAAM,CAAC,KAAK,UAAU,uBAAuB,CAAC,IAAqB;IACjE,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,IAAI,EAAE,CAAC;IAC7B,IAAI,CAAC,GAAG;QAAE,MAAM,iBAAiB,CAAC,cAAc,EAAE,iBAAiB,EAAE,EAAE,CAAC,CAAC;IAEzE,MAAM,MAAM,GAAG,cAAc,GAAG,EAAE,CAAC;IACnC,MAAM,MAAM,GAAG;QACb,QAAQ;QACR,wBAAwB,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,eAAe;QAClE,4CAA4C;QAC5C,yEAAyE;QACzE,oEAAoE;QACpE,yBAAyB;KAC1B,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAEb,MAAM,MAAM,GAAG,MAAM,YAAY,CAAC,CAAC,0BAA0B,sBAAsB,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC;IAExG,OAAO;QACL,MAAM,EAAE;YACN,GAAG;YACH,MAAM,EAAE,MAAM,IAAI,MAAM;YACxB,MAAM,EAAE,SAAS;SAClB;QACD,QAAQ,EAAE;YACR;gBACE,IAAI,EAAE,MAAM;gBACZ,GAAG,EAAE,yBAAyB;gBAC9B,OAAO,EAAE,iCAAiC,GAAG,EAAE;gBAC/C,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;aACpC;SACF;KACF,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Canonical name for creating/updating a tagged cron entry.
|
|
3
|
+
* @tool
|
|
4
|
+
* @effect local_write
|
|
5
|
+
*/
|
|
6
|
+
export declare function cronSetTaggedEntry(args: {
|
|
7
|
+
expression: string;
|
|
8
|
+
command: string;
|
|
9
|
+
tag: string;
|
|
10
|
+
}): Promise<{
|
|
11
|
+
result: {
|
|
12
|
+
tag: string;
|
|
13
|
+
marker: string;
|
|
14
|
+
line: string;
|
|
15
|
+
status: string;
|
|
16
|
+
};
|
|
17
|
+
evidence: {
|
|
18
|
+
type: string;
|
|
19
|
+
ref: string;
|
|
20
|
+
summary: string;
|
|
21
|
+
createdAt: string;
|
|
22
|
+
}[];
|
|
23
|
+
}>;
|
|
24
|
+
//# sourceMappingURL=cronSetTaggedEntry.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cronSetTaggedEntry.d.ts","sourceRoot":"","sources":["../../../src/cron/cronSetTaggedEntry.ts"],"names":[],"mappings":"AAOA;;;;GAIG;AACH,wBAAsB,kBAAkB,CAAC,IAAI,EAAE;IAC7C,UAAU,EAAE,MAAM,CAAC;IACnB,OAAO,EAAE,MAAM,CAAC;IAChB,GAAG,EAAE,MAAM,CAAC;CACb;;;;;;;;;;;;;GAyCA"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { createTaggedError } from "@botbotgo/kit/sdk";
|
|
2
|
+
import { quoteAppleScriptString, runOsaScript } from "../osascript/common.js";
|
|
3
|
+
function b64(input) {
|
|
4
|
+
return Buffer.from(input, "utf-8").toString("base64");
|
|
5
|
+
}
|
|
6
|
+
/**
|
|
7
|
+
* Canonical name for creating/updating a tagged cron entry.
|
|
8
|
+
* @tool
|
|
9
|
+
* @effect local_write
|
|
10
|
+
*/
|
|
11
|
+
export async function cronSetTaggedEntry(args) {
|
|
12
|
+
const expression = args.expression?.trim();
|
|
13
|
+
const command = args.command?.trim();
|
|
14
|
+
const tag = args.tag?.trim();
|
|
15
|
+
if (!expression)
|
|
16
|
+
throw createTaggedError("CRON_INVALID", "expression is required", {});
|
|
17
|
+
if (!command)
|
|
18
|
+
throw createTaggedError("CRON_INVALID", "command is required", {});
|
|
19
|
+
if (!tag)
|
|
20
|
+
throw createTaggedError("CRON_INVALID", "tag is required", {});
|
|
21
|
+
const marker = `# botbotgo:${tag}`;
|
|
22
|
+
const newLine = `${expression} ${command} ${marker}`;
|
|
23
|
+
const script = [
|
|
24
|
+
"set -e",
|
|
25
|
+
`marker=$(printf '%s' ${JSON.stringify(b64(marker))} | base64 -D)`,
|
|
26
|
+
`new_line=$(printf '%s' ${JSON.stringify(b64(newLine))} | base64 -D)`,
|
|
27
|
+
"existing=$(crontab -l 2>/dev/null || true)",
|
|
28
|
+
"filtered=$(printf '%s\\n' \"$existing\" | grep -vF \"$marker\" || true)",
|
|
29
|
+
"next=$(printf '%s\\n%s\\n' \"$filtered\" \"$new_line\" | sed '/^[[:space:]]*$/d')",
|
|
30
|
+
"printf '%s\\n' \"$next\" | crontab -",
|
|
31
|
+
"printf '%s' \"$new_line\"",
|
|
32
|
+
].join("; ");
|
|
33
|
+
const output = await runOsaScript([`return do shell script ${quoteAppleScriptString(script)}`], "CRON");
|
|
34
|
+
return {
|
|
35
|
+
result: {
|
|
36
|
+
tag,
|
|
37
|
+
marker,
|
|
38
|
+
line: output || newLine,
|
|
39
|
+
status: "upserted",
|
|
40
|
+
},
|
|
41
|
+
evidence: [
|
|
42
|
+
{
|
|
43
|
+
type: "tool",
|
|
44
|
+
ref: "cronSetTaggedEntry",
|
|
45
|
+
summary: `Upserted cron entry with tag ${tag}`,
|
|
46
|
+
createdAt: new Date().toISOString(),
|
|
47
|
+
},
|
|
48
|
+
],
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
//# sourceMappingURL=cronSetTaggedEntry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cronSetTaggedEntry.js","sourceRoot":"","sources":["../../../src/cron/cronSetTaggedEntry.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AACtD,OAAO,EAAE,sBAAsB,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AAE9E,SAAS,GAAG,CAAC,KAAa;IACxB,OAAO,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;AACxD,CAAC;AAED;;;;GAIG;AACH,MAAM,CAAC,KAAK,UAAU,kBAAkB,CAAC,IAIxC;IACC,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,EAAE,IAAI,EAAE,CAAC;IAC3C,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,EAAE,IAAI,EAAE,CAAC;IACrC,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,IAAI,EAAE,CAAC;IAE7B,IAAI,CAAC,UAAU;QAAE,MAAM,iBAAiB,CAAC,cAAc,EAAE,wBAAwB,EAAE,EAAE,CAAC,CAAC;IACvF,IAAI,CAAC,OAAO;QAAE,MAAM,iBAAiB,CAAC,cAAc,EAAE,qBAAqB,EAAE,EAAE,CAAC,CAAC;IACjF,IAAI,CAAC,GAAG;QAAE,MAAM,iBAAiB,CAAC,cAAc,EAAE,iBAAiB,EAAE,EAAE,CAAC,CAAC;IAEzE,MAAM,MAAM,GAAG,cAAc,GAAG,EAAE,CAAC;IACnC,MAAM,OAAO,GAAG,GAAG,UAAU,IAAI,OAAO,IAAI,MAAM,EAAE,CAAC;IAErD,MAAM,MAAM,GAAG;QACb,QAAQ;QACR,wBAAwB,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,eAAe;QAClE,0BAA0B,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,eAAe;QACrE,4CAA4C;QAC5C,yEAAyE;QACzE,mFAAmF;QACnF,sCAAsC;QACtC,2BAA2B;KAC5B,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAEb,MAAM,MAAM,GAAG,MAAM,YAAY,CAAC,CAAC,0BAA0B,sBAAsB,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC;IAExG,OAAO;QACL,MAAM,EAAE;YACN,GAAG;YACH,MAAM;YACN,IAAI,EAAE,MAAM,IAAI,OAAO;YACvB,MAAM,EAAE,UAAU;SACnB;QACD,QAAQ,EAAE;YACR;gBACE,IAAI,EAAE,MAAM;gBACZ,GAAG,EAAE,oBAAoB;gBACzB,OAAO,EAAE,gCAAgC,GAAG,EAAE;gBAC9C,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;aACpC;SACF;KACF,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Exec tool defaults (max output bytes, timeout).
|
|
3
|
+
* Config: these constants or user's tool config at invoke (e.g. allowedCommands).
|
|
4
|
+
*/
|
|
5
|
+
export declare const DEFAULT_ALLOWED_COMMANDS: string[];
|
|
6
|
+
export declare const DEFAULT_MAX_COMMAND_OUTPUT_BYTES: number;
|
|
7
|
+
export declare const DEFAULT_COMMAND_TIMEOUT_MS = 10000;
|
|
8
|
+
//# sourceMappingURL=defaults.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"defaults.d.ts","sourceRoot":"","sources":["../../../src/exec/defaults.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,eAAO,MAAM,wBAAwB,UAoBpC,CAAC;AAEF,eAAO,MAAM,gCAAgC,QAAc,CAAC;AAC5D,eAAO,MAAM,0BAA0B,QAAS,CAAC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Exec tool defaults (max output bytes, timeout).
|
|
3
|
+
* Config: these constants or user's tool config at invoke (e.g. allowedCommands).
|
|
4
|
+
*/
|
|
5
|
+
export const DEFAULT_ALLOWED_COMMANDS = [
|
|
6
|
+
"awk",
|
|
7
|
+
"cat",
|
|
8
|
+
"cut",
|
|
9
|
+
"echo",
|
|
10
|
+
"env",
|
|
11
|
+
"find",
|
|
12
|
+
"grep",
|
|
13
|
+
"head",
|
|
14
|
+
"ls",
|
|
15
|
+
"pwd",
|
|
16
|
+
"rg",
|
|
17
|
+
"sed",
|
|
18
|
+
"sort",
|
|
19
|
+
"tail",
|
|
20
|
+
"tr",
|
|
21
|
+
"uniq",
|
|
22
|
+
"wc",
|
|
23
|
+
"whoami",
|
|
24
|
+
"xargs",
|
|
25
|
+
];
|
|
26
|
+
export const DEFAULT_MAX_COMMAND_OUTPUT_BYTES = 1024 * 1024;
|
|
27
|
+
export const DEFAULT_COMMAND_TIMEOUT_MS = 10_000;
|
|
28
|
+
//# sourceMappingURL=defaults.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"defaults.js","sourceRoot":"","sources":["../../../src/exec/defaults.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,MAAM,CAAC,MAAM,wBAAwB,GAAG;IACtC,KAAK;IACL,KAAK;IACL,KAAK;IACL,MAAM;IACN,KAAK;IACL,MAAM;IACN,MAAM;IACN,MAAM;IACN,IAAI;IACJ,KAAK;IACL,IAAI;IACJ,KAAK;IACL,MAAM;IACN,MAAM;IACN,IAAI;IACJ,MAAM;IACN,IAAI;IACJ,QAAQ;IACR,OAAO;CACR,CAAC;AAEF,MAAM,CAAC,MAAM,gCAAgC,GAAG,IAAI,GAAG,IAAI,CAAC;AAC5D,MAAM,CAAC,MAAM,0BAA0B,GAAG,MAAM,CAAC"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
type RunCommandOutput = {
|
|
2
|
+
result: {
|
|
3
|
+
stdout: string;
|
|
4
|
+
stderr: string;
|
|
5
|
+
exitCode: number | null;
|
|
6
|
+
timedOut: boolean;
|
|
7
|
+
signal?: string;
|
|
8
|
+
};
|
|
9
|
+
evidence: Array<{
|
|
10
|
+
type: string;
|
|
11
|
+
ref?: string;
|
|
12
|
+
summary: string;
|
|
13
|
+
createdAt: string;
|
|
14
|
+
}>;
|
|
15
|
+
};
|
|
16
|
+
/**
|
|
17
|
+
* Run a whitelisted command with bounded output/timeout inside sandbox.
|
|
18
|
+
* @tool
|
|
19
|
+
* @effect local_write
|
|
20
|
+
*/
|
|
21
|
+
export declare function runCommand(args: {
|
|
22
|
+
command?: string;
|
|
23
|
+
cmd?: string;
|
|
24
|
+
cmdArray?: string[];
|
|
25
|
+
args?: string[];
|
|
26
|
+
arguments?: string[];
|
|
27
|
+
cwd?: string;
|
|
28
|
+
timeoutMs?: number;
|
|
29
|
+
}): Promise<RunCommandOutput>;
|
|
30
|
+
export {};
|
|
31
|
+
//# sourceMappingURL=runCommand.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runCommand.d.ts","sourceRoot":"","sources":["../../../src/exec/runCommand.ts"],"names":[],"mappings":"AAYA,KAAK,gBAAgB,GAAG;IACtB,MAAM,EAAE;QACN,MAAM,EAAE,MAAM,CAAC;QACf,MAAM,EAAE,MAAM,CAAC;QACf,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAC;QACxB,QAAQ,EAAE,OAAO,CAAC;QAClB,MAAM,CAAC,EAAE,MAAM,CAAC;KACjB,CAAC;IACF,QAAQ,EAAE,KAAK,CAAC;QACd,IAAI,EAAE,MAAM,CAAC;QACb,GAAG,CAAC,EAAE,MAAM,CAAC;QACb,OAAO,EAAE,MAAM,CAAC;QAChB,SAAS,EAAE,MAAM,CAAC;KACnB,CAAC,CAAC;CACJ,CAAC;AAmKF;;;;GAIG;AACH,wBAAsB,UAAU,CAAC,IAAI,EAAE;IACrC,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAC;IACpB,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;IAChB,SAAS,CAAC,EAAE,MAAM,EAAE,CAAC;IACrB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAc5B"}
|
|
@@ -0,0 +1,158 @@
|
|
|
1
|
+
import { spawn } from "node:child_process";
|
|
2
|
+
import { resolve as pathResolve } from "node:path";
|
|
3
|
+
import { getExtensionContext } from "../../index.js";
|
|
4
|
+
import { DEFAULT_ALLOWED_COMMANDS, DEFAULT_MAX_COMMAND_OUTPUT_BYTES, DEFAULT_COMMAND_TIMEOUT_MS, } from "./defaults.js";
|
|
5
|
+
import { createTaggedError } from "@botbotgo/kit/sdk";
|
|
6
|
+
import { resolveSandboxedPath } from "../platform/securityCompat.js";
|
|
7
|
+
import { overrideWithConfig } from "../util/overrideWithConfig.js";
|
|
8
|
+
function getCommandConfig() {
|
|
9
|
+
const defaults = {
|
|
10
|
+
allowedCommands: DEFAULT_ALLOWED_COMMANDS,
|
|
11
|
+
maxCommandOutputBytes: DEFAULT_MAX_COMMAND_OUTPUT_BYTES,
|
|
12
|
+
commandTimeoutMs: DEFAULT_COMMAND_TIMEOUT_MS,
|
|
13
|
+
sandboxRoot: "",
|
|
14
|
+
enableSandboxValidation: false,
|
|
15
|
+
};
|
|
16
|
+
const ctx = getExtensionContext();
|
|
17
|
+
const cfg = overrideWithConfig(defaults, ctx.config);
|
|
18
|
+
const timeoutMs = typeof ctx.config?.timeoutMs === "number"
|
|
19
|
+
? ctx.config.timeoutMs
|
|
20
|
+
: cfg.commandTimeoutMs;
|
|
21
|
+
return {
|
|
22
|
+
allowedCommands: cfg.allowedCommands,
|
|
23
|
+
maxCommandOutputBytes: cfg.maxCommandOutputBytes,
|
|
24
|
+
timeoutMs,
|
|
25
|
+
sandboxRoot: cfg.sandboxRoot ?? "",
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
function normalizeCommandInput(args) {
|
|
29
|
+
if (Array.isArray(args.cmdArray) && args.cmdArray.length > 0) {
|
|
30
|
+
return { rawCommand: String(args.cmdArray[0]).trim(), cmdArgs: args.cmdArray.slice(1).map(String) };
|
|
31
|
+
}
|
|
32
|
+
const rawCommand = (args.command ?? args.cmd)?.trim() ?? "";
|
|
33
|
+
if (!rawCommand) {
|
|
34
|
+
throw createTaggedError("EXEC_INVALID", "command is required (pass 'command', 'cmd', or 'cmdArray')", {});
|
|
35
|
+
}
|
|
36
|
+
const cmdArgs = Array.isArray(args.args)
|
|
37
|
+
? args.args
|
|
38
|
+
: Array.isArray(args.arguments)
|
|
39
|
+
? args.arguments
|
|
40
|
+
: [];
|
|
41
|
+
return { rawCommand, cmdArgs };
|
|
42
|
+
}
|
|
43
|
+
function validateAllowedCommand(rawCommand, allowedCommands) {
|
|
44
|
+
if (!allowedCommands.length) {
|
|
45
|
+
throw createTaggedError("EXEC_DISABLED", "Exec is disabled: allowedCommands is empty", {});
|
|
46
|
+
}
|
|
47
|
+
const baseName = rawCommand.replace(/^.*\//, "").trim();
|
|
48
|
+
if (baseName !== rawCommand || /[;&|$`\s]/.test(rawCommand)) {
|
|
49
|
+
throw createTaggedError("EXEC_INVALID", "command must be a single executable name (no path, no shell chars)", {
|
|
50
|
+
command: rawCommand,
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
if (!allowedCommands.includes(baseName)) {
|
|
54
|
+
throw createTaggedError("EXEC_NOT_ALLOWED", `Command "${baseName}" is not in allowedCommands`, {
|
|
55
|
+
command: baseName,
|
|
56
|
+
allowed: allowedCommands,
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
return baseName;
|
|
60
|
+
}
|
|
61
|
+
async function resolveCommandCwd(inputCwd, sandboxRoot) {
|
|
62
|
+
if (inputCwd != null && inputCwd !== "") {
|
|
63
|
+
return resolveSandboxedPath(inputCwd, sandboxRoot);
|
|
64
|
+
}
|
|
65
|
+
return pathResolve(sandboxRoot);
|
|
66
|
+
}
|
|
67
|
+
function runSpawnedCommand(args) {
|
|
68
|
+
return new Promise((resolvePromise, rejectPromise) => {
|
|
69
|
+
const proc = spawn(args.baseName, args.cmdArgs, {
|
|
70
|
+
cwd: args.cwd,
|
|
71
|
+
shell: false,
|
|
72
|
+
stdio: ["ignore", "pipe", "pipe"],
|
|
73
|
+
env: { ...process.env },
|
|
74
|
+
});
|
|
75
|
+
let stdout = "";
|
|
76
|
+
let stderr = "";
|
|
77
|
+
let totalBytes = 0;
|
|
78
|
+
let settled = false;
|
|
79
|
+
const rejectOnce = (error) => {
|
|
80
|
+
if (settled)
|
|
81
|
+
return;
|
|
82
|
+
settled = true;
|
|
83
|
+
rejectPromise(error);
|
|
84
|
+
};
|
|
85
|
+
const resolveOnce = (value) => {
|
|
86
|
+
if (settled)
|
|
87
|
+
return;
|
|
88
|
+
settled = true;
|
|
89
|
+
resolvePromise(value);
|
|
90
|
+
};
|
|
91
|
+
const append = (chunk, dest) => {
|
|
92
|
+
const len = Buffer.byteLength(chunk, "utf-8");
|
|
93
|
+
if (totalBytes + len > args.maxCommandOutputBytes) {
|
|
94
|
+
proc.kill("SIGKILL");
|
|
95
|
+
rejectOnce(createTaggedError("EXEC_OUTPUT_TOO_LARGE", `Command output exceeded ${args.maxCommandOutputBytes} bytes`, {
|
|
96
|
+
maxBytes: args.maxCommandOutputBytes,
|
|
97
|
+
}));
|
|
98
|
+
return;
|
|
99
|
+
}
|
|
100
|
+
totalBytes += len;
|
|
101
|
+
if (dest === "stdout")
|
|
102
|
+
stdout += chunk;
|
|
103
|
+
else
|
|
104
|
+
stderr += chunk;
|
|
105
|
+
};
|
|
106
|
+
proc.stdout?.setEncoding("utf-8");
|
|
107
|
+
proc.stderr?.setEncoding("utf-8");
|
|
108
|
+
proc.stdout?.on("data", (chunk) => append(chunk, "stdout"));
|
|
109
|
+
proc.stderr?.on("data", (chunk) => append(chunk, "stderr"));
|
|
110
|
+
const timeout = setTimeout(() => {
|
|
111
|
+
proc.kill("SIGKILL");
|
|
112
|
+
resolveOnce({
|
|
113
|
+
result: { stdout, stderr, exitCode: null, timedOut: true, signal: "SIGKILL" },
|
|
114
|
+
evidence: [{
|
|
115
|
+
type: "exec",
|
|
116
|
+
summary: `Command "${args.baseName}" timed out after ${args.timeoutMs}ms`,
|
|
117
|
+
createdAt: new Date().toISOString(),
|
|
118
|
+
}],
|
|
119
|
+
});
|
|
120
|
+
}, args.timeoutMs);
|
|
121
|
+
proc.on("error", (err) => {
|
|
122
|
+
clearTimeout(timeout);
|
|
123
|
+
rejectOnce(createTaggedError("EXEC_SPAWN_ERROR", err.message, { command: args.baseName }));
|
|
124
|
+
});
|
|
125
|
+
proc.on("close", (code, signal) => {
|
|
126
|
+
clearTimeout(timeout);
|
|
127
|
+
resolveOnce({
|
|
128
|
+
result: { stdout, stderr, exitCode: code, timedOut: false, signal: signal ?? undefined },
|
|
129
|
+
evidence: [{
|
|
130
|
+
type: "exec",
|
|
131
|
+
ref: args.baseName,
|
|
132
|
+
summary: `Ran ${args.baseName} (exit ${code ?? signal})`,
|
|
133
|
+
createdAt: new Date().toISOString(),
|
|
134
|
+
}],
|
|
135
|
+
});
|
|
136
|
+
});
|
|
137
|
+
});
|
|
138
|
+
}
|
|
139
|
+
/**
|
|
140
|
+
* Run a whitelisted command with bounded output/timeout inside sandbox.
|
|
141
|
+
* @tool
|
|
142
|
+
* @effect local_write
|
|
143
|
+
*/
|
|
144
|
+
export async function runCommand(args) {
|
|
145
|
+
const config = getCommandConfig();
|
|
146
|
+
const normalized = normalizeCommandInput(args);
|
|
147
|
+
const baseName = validateAllowedCommand(normalized.rawCommand, config.allowedCommands);
|
|
148
|
+
const cwd = await resolveCommandCwd(args.cwd, config.sandboxRoot);
|
|
149
|
+
const timeoutMs = args.timeoutMs ?? config.timeoutMs;
|
|
150
|
+
return runSpawnedCommand({
|
|
151
|
+
baseName,
|
|
152
|
+
cmdArgs: normalized.cmdArgs,
|
|
153
|
+
cwd,
|
|
154
|
+
timeoutMs,
|
|
155
|
+
maxCommandOutputBytes: config.maxCommandOutputBytes,
|
|
156
|
+
});
|
|
157
|
+
}
|
|
158
|
+
//# sourceMappingURL=runCommand.js.map
|