daycare-cli 0.0.1
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 +21 -0
- package/README.md +80 -0
- package/bin/daycare.js +2 -0
- package/dist/auth/store.d.ts +25 -0
- package/dist/auth/store.d.ts.map +1 -0
- package/dist/auth/store.js +80 -0
- package/dist/auth/store.js.map +1 -0
- package/dist/commands/add.d.ts +5 -0
- package/dist/commands/add.d.ts.map +1 -0
- package/dist/commands/add.js +412 -0
- package/dist/commands/add.js.map +1 -0
- package/dist/commands/auth.d.ts +2 -0
- package/dist/commands/auth.d.ts.map +1 -0
- package/dist/commands/auth.js +13 -0
- package/dist/commands/auth.js.map +1 -0
- package/dist/commands/doctor.d.ts +5 -0
- package/dist/commands/doctor.d.ts.map +1 -0
- package/dist/commands/doctor.js +143 -0
- package/dist/commands/doctor.js.map +1 -0
- package/dist/commands/engineReloadRequest.d.ts +6 -0
- package/dist/commands/engineReloadRequest.d.ts.map +1 -0
- package/dist/commands/engineReloadRequest.js +17 -0
- package/dist/commands/engineReloadRequest.js.map +1 -0
- package/dist/commands/event.d.ts +2 -0
- package/dist/commands/event.d.ts.map +1 -0
- package/dist/commands/event.js +32 -0
- package/dist/commands/event.js.map +1 -0
- package/dist/commands/event.spec.d.ts +2 -0
- package/dist/commands/event.spec.d.ts.map +1 -0
- package/dist/commands/event.spec.js +36 -0
- package/dist/commands/event.spec.js.map +1 -0
- package/dist/commands/plugins.d.ts +3 -0
- package/dist/commands/plugins.d.ts.map +1 -0
- package/dist/commands/plugins.js +19 -0
- package/dist/commands/plugins.js.map +1 -0
- package/dist/commands/prompts.d.ts +23 -0
- package/dist/commands/prompts.d.ts.map +1 -0
- package/dist/commands/prompts.js +92 -0
- package/dist/commands/prompts.js.map +1 -0
- package/dist/commands/providers.d.ts +5 -0
- package/dist/commands/providers.d.ts.map +1 -0
- package/dist/commands/providers.js +149 -0
- package/dist/commands/providers.js.map +1 -0
- package/dist/commands/remove.d.ts +5 -0
- package/dist/commands/remove.d.ts.map +1 -0
- package/dist/commands/remove.js +103 -0
- package/dist/commands/remove.js.map +1 -0
- package/dist/commands/start.d.ts +7 -0
- package/dist/commands/start.d.ts.map +1 -0
- package/dist/commands/start.js +173 -0
- package/dist/commands/start.js.map +1 -0
- package/dist/commands/status.d.ts +2 -0
- package/dist/commands/status.d.ts.map +1 -0
- package/dist/commands/status.js +28 -0
- package/dist/commands/status.js.map +1 -0
- package/dist/config/configLoad.d.ts +7 -0
- package/dist/config/configLoad.d.ts.map +1 -0
- package/dist/config/configLoad.js +25 -0
- package/dist/config/configLoad.js.map +1 -0
- package/dist/config/configResolve.d.ts +8 -0
- package/dist/config/configResolve.d.ts.map +1 -0
- package/dist/config/configResolve.js +49 -0
- package/dist/config/configResolve.js.map +1 -0
- package/dist/config/configSettingsParse.d.ts +7 -0
- package/dist/config/configSettingsParse.d.ts.map +1 -0
- package/dist/config/configSettingsParse.js +61 -0
- package/dist/config/configSettingsParse.js.map +1 -0
- package/dist/config/configTypes.d.ts +19 -0
- package/dist/config/configTypes.d.ts.map +1 -0
- package/dist/config/configTypes.js +2 -0
- package/dist/config/configTypes.js.map +1 -0
- package/dist/engine/agents/agent.d.ts +72 -0
- package/dist/engine/agents/agent.d.ts.map +1 -0
- package/dist/engine/agents/agent.js +947 -0
- package/dist/engine/agents/agent.js.map +1 -0
- package/dist/engine/agents/agent.spec.d.ts +2 -0
- package/dist/engine/agents/agent.spec.d.ts.map +1 -0
- package/dist/engine/agents/agent.spec.js +410 -0
- package/dist/engine/agents/agent.spec.js.map +1 -0
- package/dist/engine/agents/agentSystem.d.ts +107 -0
- package/dist/engine/agents/agentSystem.d.ts.map +1 -0
- package/dist/engine/agents/agentSystem.js +554 -0
- package/dist/engine/agents/agentSystem.js.map +1 -0
- package/dist/engine/agents/ops/agentBackgroundList.d.ts +8 -0
- package/dist/engine/agents/ops/agentBackgroundList.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentBackgroundList.js +60 -0
- package/dist/engine/agents/ops/agentBackgroundList.js.map +1 -0
- package/dist/engine/agents/ops/agentDescriptorBuild.d.ts +7 -0
- package/dist/engine/agents/ops/agentDescriptorBuild.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentDescriptorBuild.js +16 -0
- package/dist/engine/agents/ops/agentDescriptorBuild.js.map +1 -0
- package/dist/engine/agents/ops/agentDescriptorIsCron.d.ts +9 -0
- package/dist/engine/agents/ops/agentDescriptorIsCron.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentDescriptorIsCron.js +8 -0
- package/dist/engine/agents/ops/agentDescriptorIsCron.js.map +1 -0
- package/dist/engine/agents/ops/agentDescriptorIsHeartbeat.d.ts +10 -0
- package/dist/engine/agents/ops/agentDescriptorIsHeartbeat.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentDescriptorIsHeartbeat.js +8 -0
- package/dist/engine/agents/ops/agentDescriptorIsHeartbeat.js.map +1 -0
- package/dist/engine/agents/ops/agentDescriptorIsHeartbeat.spec.d.ts +2 -0
- package/dist/engine/agents/ops/agentDescriptorIsHeartbeat.spec.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentDescriptorIsHeartbeat.spec.js +17 -0
- package/dist/engine/agents/ops/agentDescriptorIsHeartbeat.spec.js.map +1 -0
- package/dist/engine/agents/ops/agentDescriptorLabel.d.ts +7 -0
- package/dist/engine/agents/ops/agentDescriptorLabel.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentDescriptorLabel.js +17 -0
- package/dist/engine/agents/ops/agentDescriptorLabel.js.map +1 -0
- package/dist/engine/agents/ops/agentDescriptorLabel.spec.d.ts +2 -0
- package/dist/engine/agents/ops/agentDescriptorLabel.spec.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentDescriptorLabel.spec.js +41 -0
- package/dist/engine/agents/ops/agentDescriptorLabel.spec.js.map +1 -0
- package/dist/engine/agents/ops/agentDescriptorMatchesStrategy.d.ts +7 -0
- package/dist/engine/agents/ops/agentDescriptorMatchesStrategy.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentDescriptorMatchesStrategy.js +15 -0
- package/dist/engine/agents/ops/agentDescriptorMatchesStrategy.js.map +1 -0
- package/dist/engine/agents/ops/agentDescriptorRead.d.ts +8 -0
- package/dist/engine/agents/ops/agentDescriptorRead.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentDescriptorRead.js +66 -0
- package/dist/engine/agents/ops/agentDescriptorRead.js.map +1 -0
- package/dist/engine/agents/ops/agentDescriptorTargetResolve.d.ts +10 -0
- package/dist/engine/agents/ops/agentDescriptorTargetResolve.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentDescriptorTargetResolve.js +11 -0
- package/dist/engine/agents/ops/agentDescriptorTargetResolve.js.map +1 -0
- package/dist/engine/agents/ops/agentDescriptorTargetResolve.spec.d.ts +2 -0
- package/dist/engine/agents/ops/agentDescriptorTargetResolve.spec.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentDescriptorTargetResolve.spec.js +18 -0
- package/dist/engine/agents/ops/agentDescriptorTargetResolve.spec.js.map +1 -0
- package/dist/engine/agents/ops/agentDescriptorTypes.d.ts +27 -0
- package/dist/engine/agents/ops/agentDescriptorTypes.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentDescriptorTypes.js +2 -0
- package/dist/engine/agents/ops/agentDescriptorTypes.js.map +1 -0
- package/dist/engine/agents/ops/agentDescriptorWrite.d.ts +8 -0
- package/dist/engine/agents/ops/agentDescriptorWrite.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentDescriptorWrite.js +16 -0
- package/dist/engine/agents/ops/agentDescriptorWrite.js.map +1 -0
- package/dist/engine/agents/ops/agentHistoryAppend.d.ts +8 -0
- package/dist/engine/agents/ops/agentHistoryAppend.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentHistoryAppend.js +15 -0
- package/dist/engine/agents/ops/agentHistoryAppend.js.map +1 -0
- package/dist/engine/agents/ops/agentHistoryLoad.d.ts +8 -0
- package/dist/engine/agents/ops/agentHistoryLoad.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentHistoryLoad.js +144 -0
- package/dist/engine/agents/ops/agentHistoryLoad.js.map +1 -0
- package/dist/engine/agents/ops/agentHistoryLoad.spec.d.ts +2 -0
- package/dist/engine/agents/ops/agentHistoryLoad.spec.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentHistoryLoad.spec.js +29 -0
- package/dist/engine/agents/ops/agentHistoryLoad.spec.js.map +1 -0
- package/dist/engine/agents/ops/agentHistorySummaryBuild.d.ts +20 -0
- package/dist/engine/agents/ops/agentHistorySummaryBuild.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentHistorySummaryBuild.js +57 -0
- package/dist/engine/agents/ops/agentHistorySummaryBuild.js.map +1 -0
- package/dist/engine/agents/ops/agentHistorySummaryBuild.spec.d.ts +2 -0
- package/dist/engine/agents/ops/agentHistorySummaryBuild.spec.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentHistorySummaryBuild.spec.js +69 -0
- package/dist/engine/agents/ops/agentHistorySummaryBuild.spec.js.map +1 -0
- package/dist/engine/agents/ops/agentInbox.d.ts +20 -0
- package/dist/engine/agents/ops/agentInbox.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentInbox.js +128 -0
- package/dist/engine/agents/ops/agentInbox.js.map +1 -0
- package/dist/engine/agents/ops/agentInbox.spec.d.ts +2 -0
- package/dist/engine/agents/ops/agentInbox.spec.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentInbox.spec.js +74 -0
- package/dist/engine/agents/ops/agentInbox.spec.js.map +1 -0
- package/dist/engine/agents/ops/agentList.d.ts +14 -0
- package/dist/engine/agents/ops/agentList.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentList.js +41 -0
- package/dist/engine/agents/ops/agentList.js.map +1 -0
- package/dist/engine/agents/ops/agentLoopRun.d.ts +58 -0
- package/dist/engine/agents/ops/agentLoopRun.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentLoopRun.js +397 -0
- package/dist/engine/agents/ops/agentLoopRun.js.map +1 -0
- package/dist/engine/agents/ops/agentPathBuild.d.ts +7 -0
- package/dist/engine/agents/ops/agentPathBuild.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentPathBuild.js +9 -0
- package/dist/engine/agents/ops/agentPathBuild.js.map +1 -0
- package/dist/engine/agents/ops/agentPathForDescriptor.d.ts +7 -0
- package/dist/engine/agents/ops/agentPathForDescriptor.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentPathForDescriptor.js +17 -0
- package/dist/engine/agents/ops/agentPathForDescriptor.js.map +1 -0
- package/dist/engine/agents/ops/agentPermanentList.d.ts +8 -0
- package/dist/engine/agents/ops/agentPermanentList.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentPermanentList.js +51 -0
- package/dist/engine/agents/ops/agentPermanentList.js.map +1 -0
- package/dist/engine/agents/ops/agentPermanentPromptBuild.d.ts +7 -0
- package/dist/engine/agents/ops/agentPermanentPromptBuild.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentPermanentPromptBuild.js +42 -0
- package/dist/engine/agents/ops/agentPermanentPromptBuild.js.map +1 -0
- package/dist/engine/agents/ops/agentPermanentPromptBuild.spec.d.ts +2 -0
- package/dist/engine/agents/ops/agentPermanentPromptBuild.spec.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentPermanentPromptBuild.spec.js +47 -0
- package/dist/engine/agents/ops/agentPermanentPromptBuild.spec.js.map +1 -0
- package/dist/engine/agents/ops/agentPermanentTypes.d.ts +10 -0
- package/dist/engine/agents/ops/agentPermanentTypes.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentPermanentTypes.js +2 -0
- package/dist/engine/agents/ops/agentPermanentTypes.js.map +1 -0
- package/dist/engine/agents/ops/agentPromptBundledRead.d.ts +6 -0
- package/dist/engine/agents/ops/agentPromptBundledRead.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentPromptBundledRead.js +10 -0
- package/dist/engine/agents/ops/agentPromptBundledRead.js.map +1 -0
- package/dist/engine/agents/ops/agentPromptFilesEnsure.d.ts +6 -0
- package/dist/engine/agents/ops/agentPromptFilesEnsure.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentPromptFilesEnsure.js +31 -0
- package/dist/engine/agents/ops/agentPromptFilesEnsure.js.map +1 -0
- package/dist/engine/agents/ops/agentStateRead.d.ts +8 -0
- package/dist/engine/agents/ops/agentStateRead.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentStateRead.js +73 -0
- package/dist/engine/agents/ops/agentStateRead.js.map +1 -0
- package/dist/engine/agents/ops/agentStateWrite.d.ts +8 -0
- package/dist/engine/agents/ops/agentStateWrite.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentStateWrite.js +23 -0
- package/dist/engine/agents/ops/agentStateWrite.js.map +1 -0
- package/dist/engine/agents/ops/agentSystemPromptWrite.d.ts +7 -0
- package/dist/engine/agents/ops/agentSystemPromptWrite.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentSystemPromptWrite.js +22 -0
- package/dist/engine/agents/ops/agentSystemPromptWrite.js.map +1 -0
- package/dist/engine/agents/ops/agentSystemPromptWrite.spec.d.ts +2 -0
- package/dist/engine/agents/ops/agentSystemPromptWrite.spec.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentSystemPromptWrite.spec.js +33 -0
- package/dist/engine/agents/ops/agentSystemPromptWrite.spec.js.map +1 -0
- package/dist/engine/agents/ops/agentTimestampGet.d.ts +6 -0
- package/dist/engine/agents/ops/agentTimestampGet.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentTimestampGet.js +15 -0
- package/dist/engine/agents/ops/agentTimestampGet.js.map +1 -0
- package/dist/engine/agents/ops/agentTypes.d.ts +150 -0
- package/dist/engine/agents/ops/agentTypes.d.ts.map +1 -0
- package/dist/engine/agents/ops/agentTypes.js +2 -0
- package/dist/engine/agents/ops/agentTypes.js.map +1 -0
- package/dist/engine/agents/ops/contextCompact.d.ts +17 -0
- package/dist/engine/agents/ops/contextCompact.d.ts.map +1 -0
- package/dist/engine/agents/ops/contextCompact.js +58 -0
- package/dist/engine/agents/ops/contextCompact.js.map +1 -0
- package/dist/engine/agents/ops/contextCompactionStatusBuild.d.ts +19 -0
- package/dist/engine/agents/ops/contextCompactionStatusBuild.d.ts.map +1 -0
- package/dist/engine/agents/ops/contextCompactionStatusBuild.js +30 -0
- package/dist/engine/agents/ops/contextCompactionStatusBuild.js.map +1 -0
- package/dist/engine/agents/ops/contextCompactionStatusBuild.spec.d.ts +2 -0
- package/dist/engine/agents/ops/contextCompactionStatusBuild.spec.d.ts.map +1 -0
- package/dist/engine/agents/ops/contextCompactionStatusBuild.spec.js +34 -0
- package/dist/engine/agents/ops/contextCompactionStatusBuild.spec.js.map +1 -0
- package/dist/engine/agents/ops/contextEstimateTokens.d.ts +7 -0
- package/dist/engine/agents/ops/contextEstimateTokens.d.ts.map +1 -0
- package/dist/engine/agents/ops/contextEstimateTokens.js +114 -0
- package/dist/engine/agents/ops/contextEstimateTokens.js.map +1 -0
- package/dist/engine/agents/ops/contextEstimateTokens.spec.d.ts +2 -0
- package/dist/engine/agents/ops/contextEstimateTokens.spec.d.ts.map +1 -0
- package/dist/engine/agents/ops/contextEstimateTokens.spec.js +88 -0
- package/dist/engine/agents/ops/contextEstimateTokens.spec.js.map +1 -0
- package/dist/engine/agents/ops/contextNeedsEmergencyReset.d.ts +7 -0
- package/dist/engine/agents/ops/contextNeedsEmergencyReset.d.ts.map +1 -0
- package/dist/engine/agents/ops/contextNeedsEmergencyReset.js +10 -0
- package/dist/engine/agents/ops/contextNeedsEmergencyReset.js.map +1 -0
- package/dist/engine/agents/ops/contextNeedsEmergencyReset.spec.d.ts +2 -0
- package/dist/engine/agents/ops/contextNeedsEmergencyReset.spec.d.ts.map +1 -0
- package/dist/engine/agents/ops/contextNeedsEmergencyReset.spec.js +21 -0
- package/dist/engine/agents/ops/contextNeedsEmergencyReset.spec.js.map +1 -0
- package/dist/engine/agents/ops/tokensResolve.d.ts +18 -0
- package/dist/engine/agents/ops/tokensResolve.d.ts.map +1 -0
- package/dist/engine/agents/ops/tokensResolve.js +143 -0
- package/dist/engine/agents/ops/tokensResolve.js.map +1 -0
- package/dist/engine/agents/ops/tokensResolve.spec.d.ts +2 -0
- package/dist/engine/agents/ops/tokensResolve.spec.d.ts.map +1 -0
- package/dist/engine/agents/ops/tokensResolve.spec.js +83 -0
- package/dist/engine/agents/ops/tokensResolve.spec.js.map +1 -0
- package/dist/engine/agents/system/_systemAgents.d.ts +7 -0
- package/dist/engine/agents/system/_systemAgents.d.ts.map +1 -0
- package/dist/engine/agents/system/_systemAgents.js +17 -0
- package/dist/engine/agents/system/_systemAgents.js.map +1 -0
- package/dist/engine/agents/system/systemAgentPromptResolve.d.ts +7 -0
- package/dist/engine/agents/system/systemAgentPromptResolve.d.ts.map +1 -0
- package/dist/engine/agents/system/systemAgentPromptResolve.js +34 -0
- package/dist/engine/agents/system/systemAgentPromptResolve.js.map +1 -0
- package/dist/engine/agents/system/systemAgentPromptResolve.spec.d.ts +2 -0
- package/dist/engine/agents/system/systemAgentPromptResolve.spec.d.ts.map +1 -0
- package/dist/engine/agents/system/systemAgentPromptResolve.spec.js +20 -0
- package/dist/engine/agents/system/systemAgentPromptResolve.spec.js.map +1 -0
- package/dist/engine/agents/system/systemAgentTagIs.d.ts +6 -0
- package/dist/engine/agents/system/systemAgentTagIs.d.ts.map +1 -0
- package/dist/engine/agents/system/systemAgentTagIs.js +9 -0
- package/dist/engine/agents/system/systemAgentTagIs.js.map +1 -0
- package/dist/engine/agents/system/systemAgentTagIs.spec.d.ts +2 -0
- package/dist/engine/agents/system/systemAgentTagIs.spec.d.ts.map +1 -0
- package/dist/engine/agents/system/systemAgentTagIs.spec.js +14 -0
- package/dist/engine/agents/system/systemAgentTagIs.spec.js.map +1 -0
- package/dist/engine/agents/system/systemAgentTypes.d.ts +17 -0
- package/dist/engine/agents/system/systemAgentTypes.d.ts.map +1 -0
- package/dist/engine/agents/system/systemAgentTypes.js +2 -0
- package/dist/engine/agents/system/systemAgentTypes.js.map +1 -0
- package/dist/engine/config/configModule.d.ts +16 -0
- package/dist/engine/config/configModule.d.ts.map +1 -0
- package/dist/engine/config/configModule.js +26 -0
- package/dist/engine/config/configModule.js.map +1 -0
- package/dist/engine/config/configModule.spec.d.ts +2 -0
- package/dist/engine/config/configModule.spec.d.ts.map +1 -0
- package/dist/engine/config/configModule.spec.js +15 -0
- package/dist/engine/config/configModule.spec.js.map +1 -0
- package/dist/engine/cron/cronTypes.d.ts +81 -0
- package/dist/engine/cron/cronTypes.d.ts.map +1 -0
- package/dist/engine/cron/cronTypes.js +2 -0
- package/dist/engine/cron/cronTypes.js.map +1 -0
- package/dist/engine/cron/crons.d.ts +33 -0
- package/dist/engine/cron/crons.d.ts.map +1 -0
- package/dist/engine/cron/crons.js +124 -0
- package/dist/engine/cron/crons.js.map +1 -0
- package/dist/engine/cron/ops/cronExpressionParse.d.ts +9 -0
- package/dist/engine/cron/ops/cronExpressionParse.d.ts.map +1 -0
- package/dist/engine/cron/ops/cronExpressionParse.js +24 -0
- package/dist/engine/cron/ops/cronExpressionParse.js.map +1 -0
- package/dist/engine/cron/ops/cronExpressionParse.spec.d.ts +2 -0
- package/dist/engine/cron/ops/cronExpressionParse.spec.d.ts.map +1 -0
- package/dist/engine/cron/ops/cronExpressionParse.spec.js +73 -0
- package/dist/engine/cron/ops/cronExpressionParse.spec.js.map +1 -0
- package/dist/engine/cron/ops/cronFieldMatch.d.ts +9 -0
- package/dist/engine/cron/ops/cronFieldMatch.d.ts.map +1 -0
- package/dist/engine/cron/ops/cronFieldMatch.js +10 -0
- package/dist/engine/cron/ops/cronFieldMatch.js.map +1 -0
- package/dist/engine/cron/ops/cronFieldMatch.spec.d.ts +2 -0
- package/dist/engine/cron/ops/cronFieldMatch.spec.d.ts.map +1 -0
- package/dist/engine/cron/ops/cronFieldMatch.spec.js +29 -0
- package/dist/engine/cron/ops/cronFieldMatch.spec.js.map +1 -0
- package/dist/engine/cron/ops/cronFieldParse.d.ts +9 -0
- package/dist/engine/cron/ops/cronFieldParse.d.ts.map +1 -0
- package/dist/engine/cron/ops/cronFieldParse.js +48 -0
- package/dist/engine/cron/ops/cronFieldParse.js.map +1 -0
- package/dist/engine/cron/ops/cronFieldParse.spec.d.ts +2 -0
- package/dist/engine/cron/ops/cronFieldParse.spec.d.ts.map +1 -0
- package/dist/engine/cron/ops/cronFieldParse.spec.js +62 -0
- package/dist/engine/cron/ops/cronFieldParse.spec.js.map +1 -0
- package/dist/engine/cron/ops/cronFrontmatterParse.d.ts +9 -0
- package/dist/engine/cron/ops/cronFrontmatterParse.d.ts.map +1 -0
- package/dist/engine/cron/ops/cronFrontmatterParse.js +24 -0
- package/dist/engine/cron/ops/cronFrontmatterParse.js.map +1 -0
- package/dist/engine/cron/ops/cronFrontmatterParse.spec.d.ts +2 -0
- package/dist/engine/cron/ops/cronFrontmatterParse.spec.d.ts.map +1 -0
- package/dist/engine/cron/ops/cronFrontmatterParse.spec.js +82 -0
- package/dist/engine/cron/ops/cronFrontmatterParse.spec.js.map +1 -0
- package/dist/engine/cron/ops/cronFrontmatterSerialize.d.ts +9 -0
- package/dist/engine/cron/ops/cronFrontmatterSerialize.d.ts.map +1 -0
- package/dist/engine/cron/ops/cronFrontmatterSerialize.js +11 -0
- package/dist/engine/cron/ops/cronFrontmatterSerialize.js.map +1 -0
- package/dist/engine/cron/ops/cronFrontmatterSerialize.spec.d.ts +2 -0
- package/dist/engine/cron/ops/cronFrontmatterSerialize.spec.d.ts.map +1 -0
- package/dist/engine/cron/ops/cronFrontmatterSerialize.spec.js +54 -0
- package/dist/engine/cron/ops/cronFrontmatterSerialize.spec.js.map +1 -0
- package/dist/engine/cron/ops/cronScheduler.d.ts +55 -0
- package/dist/engine/cron/ops/cronScheduler.d.ts.map +1 -0
- package/dist/engine/cron/ops/cronScheduler.js +300 -0
- package/dist/engine/cron/ops/cronScheduler.js.map +1 -0
- package/dist/engine/cron/ops/cronScheduler.spec.d.ts +2 -0
- package/dist/engine/cron/ops/cronScheduler.spec.d.ts.map +1 -0
- package/dist/engine/cron/ops/cronScheduler.spec.js +239 -0
- package/dist/engine/cron/ops/cronScheduler.spec.js.map +1 -0
- package/dist/engine/cron/ops/cronStore.d.ts +33 -0
- package/dist/engine/cron/ops/cronStore.d.ts.map +1 -0
- package/dist/engine/cron/ops/cronStore.js +312 -0
- package/dist/engine/cron/ops/cronStore.js.map +1 -0
- package/dist/engine/cron/ops/cronStore.spec.d.ts +2 -0
- package/dist/engine/cron/ops/cronStore.spec.d.ts.map +1 -0
- package/dist/engine/cron/ops/cronStore.spec.js +162 -0
- package/dist/engine/cron/ops/cronStore.spec.js.map +1 -0
- package/dist/engine/cron/ops/cronTaskUidResolve.d.ts +9 -0
- package/dist/engine/cron/ops/cronTaskUidResolve.d.ts.map +1 -0
- package/dist/engine/cron/ops/cronTaskUidResolve.js +14 -0
- package/dist/engine/cron/ops/cronTaskUidResolve.js.map +1 -0
- package/dist/engine/cron/ops/cronTaskUidResolve.spec.d.ts +2 -0
- package/dist/engine/cron/ops/cronTaskUidResolve.spec.d.ts.map +1 -0
- package/dist/engine/cron/ops/cronTaskUidResolve.spec.js +29 -0
- package/dist/engine/cron/ops/cronTaskUidResolve.spec.js.map +1 -0
- package/dist/engine/cron/ops/cronTimeGetNext.d.ts +8 -0
- package/dist/engine/cron/ops/cronTimeGetNext.d.ts.map +1 -0
- package/dist/engine/cron/ops/cronTimeGetNext.js +40 -0
- package/dist/engine/cron/ops/cronTimeGetNext.js.map +1 -0
- package/dist/engine/cron/ops/cronTimeGetNext.spec.d.ts +2 -0
- package/dist/engine/cron/ops/cronTimeGetNext.spec.d.ts.map +1 -0
- package/dist/engine/cron/ops/cronTimeGetNext.spec.js +66 -0
- package/dist/engine/cron/ops/cronTimeGetNext.spec.js.map +1 -0
- package/dist/engine/engine.d.ts +80 -0
- package/dist/engine/engine.d.ts.map +1 -0
- package/dist/engine/engine.js +473 -0
- package/dist/engine/engine.js.map +1 -0
- package/dist/engine/engine.spec.d.ts +2 -0
- package/dist/engine/engine.spec.d.ts.map +1 -0
- package/dist/engine/engine.spec.js +147 -0
- package/dist/engine/engine.spec.js.map +1 -0
- package/dist/engine/heartbeat/heartbeatTypes.d.ts +48 -0
- package/dist/engine/heartbeat/heartbeatTypes.d.ts.map +1 -0
- package/dist/engine/heartbeat/heartbeatTypes.js +5 -0
- package/dist/engine/heartbeat/heartbeatTypes.js.map +1 -0
- package/dist/engine/heartbeat/heartbeats.d.ts +34 -0
- package/dist/engine/heartbeat/heartbeats.d.ts.map +1 -0
- package/dist/engine/heartbeat/heartbeats.js +107 -0
- package/dist/engine/heartbeat/heartbeats.js.map +1 -0
- package/dist/engine/heartbeat/ops/heartbeatParse.d.ts +11 -0
- package/dist/engine/heartbeat/ops/heartbeatParse.d.ts.map +1 -0
- package/dist/engine/heartbeat/ops/heartbeatParse.js +31 -0
- package/dist/engine/heartbeat/ops/heartbeatParse.js.map +1 -0
- package/dist/engine/heartbeat/ops/heartbeatParse.spec.d.ts +2 -0
- package/dist/engine/heartbeat/ops/heartbeatParse.spec.d.ts.map +1 -0
- package/dist/engine/heartbeat/ops/heartbeatParse.spec.js +46 -0
- package/dist/engine/heartbeat/ops/heartbeatParse.spec.js.map +1 -0
- package/dist/engine/heartbeat/ops/heartbeatPromptBuildBatch.d.ts +12 -0
- package/dist/engine/heartbeat/ops/heartbeatPromptBuildBatch.d.ts.map +1 -0
- package/dist/engine/heartbeat/ops/heartbeatPromptBuildBatch.js +34 -0
- package/dist/engine/heartbeat/ops/heartbeatPromptBuildBatch.js.map +1 -0
- package/dist/engine/heartbeat/ops/heartbeatPromptBuildBatch.spec.d.ts +2 -0
- package/dist/engine/heartbeat/ops/heartbeatPromptBuildBatch.spec.d.ts.map +1 -0
- package/dist/engine/heartbeat/ops/heartbeatPromptBuildBatch.spec.js +31 -0
- package/dist/engine/heartbeat/ops/heartbeatPromptBuildBatch.spec.js.map +1 -0
- package/dist/engine/heartbeat/ops/heartbeatScheduler.d.ts +39 -0
- package/dist/engine/heartbeat/ops/heartbeatScheduler.d.ts.map +1 -0
- package/dist/engine/heartbeat/ops/heartbeatScheduler.js +193 -0
- package/dist/engine/heartbeat/ops/heartbeatScheduler.js.map +1 -0
- package/dist/engine/heartbeat/ops/heartbeatScheduler.spec.d.ts +2 -0
- package/dist/engine/heartbeat/ops/heartbeatScheduler.spec.d.ts.map +1 -0
- package/dist/engine/heartbeat/ops/heartbeatScheduler.spec.js +140 -0
- package/dist/engine/heartbeat/ops/heartbeatScheduler.spec.js.map +1 -0
- package/dist/engine/heartbeat/ops/heartbeatStore.d.ts +25 -0
- package/dist/engine/heartbeat/ops/heartbeatStore.d.ts.map +1 -0
- package/dist/engine/heartbeat/ops/heartbeatStore.js +188 -0
- package/dist/engine/heartbeat/ops/heartbeatStore.js.map +1 -0
- package/dist/engine/heartbeat/ops/heartbeatStore.spec.d.ts +2 -0
- package/dist/engine/heartbeat/ops/heartbeatStore.spec.d.ts.map +1 -0
- package/dist/engine/heartbeat/ops/heartbeatStore.spec.js +30 -0
- package/dist/engine/heartbeat/ops/heartbeatStore.spec.js.map +1 -0
- package/dist/engine/ipc/client.d.ts +24 -0
- package/dist/engine/ipc/client.d.ts.map +1 -0
- package/dist/engine/ipc/client.js +92 -0
- package/dist/engine/ipc/client.js.map +1 -0
- package/dist/engine/ipc/events.d.ts +13 -0
- package/dist/engine/ipc/events.d.ts.map +1 -0
- package/dist/engine/ipc/events.js +17 -0
- package/dist/engine/ipc/events.js.map +1 -0
- package/dist/engine/ipc/server.d.ts +14 -0
- package/dist/engine/ipc/server.d.ts.map +1 -0
- package/dist/engine/ipc/server.js +411 -0
- package/dist/engine/ipc/server.js.map +1 -0
- package/dist/engine/ipc/socket.d.ts +4 -0
- package/dist/engine/ipc/socket.d.ts.map +1 -0
- package/dist/engine/ipc/socket.js +15 -0
- package/dist/engine/ipc/socket.js.map +1 -0
- package/dist/engine/messages/incomingMessages.d.ts +31 -0
- package/dist/engine/messages/incomingMessages.d.ts.map +1 -0
- package/dist/engine/messages/incomingMessages.js +130 -0
- package/dist/engine/messages/incomingMessages.js.map +1 -0
- package/dist/engine/messages/incomingMessages.spec.d.ts +2 -0
- package/dist/engine/messages/incomingMessages.spec.d.ts.map +1 -0
- package/dist/engine/messages/incomingMessages.spec.js +87 -0
- package/dist/engine/messages/incomingMessages.spec.js.map +1 -0
- package/dist/engine/messages/messageBuildSystemText.d.ts +2 -0
- package/dist/engine/messages/messageBuildSystemText.d.ts.map +1 -0
- package/dist/engine/messages/messageBuildSystemText.js +6 -0
- package/dist/engine/messages/messageBuildSystemText.js.map +1 -0
- package/dist/engine/messages/messageBuildSystemText.spec.d.ts +2 -0
- package/dist/engine/messages/messageBuildSystemText.spec.d.ts.map +1 -0
- package/dist/engine/messages/messageBuildSystemText.spec.js +11 -0
- package/dist/engine/messages/messageBuildSystemText.spec.js.map +1 -0
- package/dist/engine/messages/messageBuildUser.d.ts +4 -0
- package/dist/engine/messages/messageBuildUser.d.ts.map +1 -0
- package/dist/engine/messages/messageBuildUser.js +38 -0
- package/dist/engine/messages/messageBuildUser.js.map +1 -0
- package/dist/engine/messages/messageBuildUser.spec.d.ts +2 -0
- package/dist/engine/messages/messageBuildUser.spec.d.ts.map +1 -0
- package/dist/engine/messages/messageBuildUser.spec.js +54 -0
- package/dist/engine/messages/messageBuildUser.spec.js.map +1 -0
- package/dist/engine/messages/messageExtractText.d.ts +3 -0
- package/dist/engine/messages/messageExtractText.d.ts.map +1 -0
- package/dist/engine/messages/messageExtractText.js +11 -0
- package/dist/engine/messages/messageExtractText.js.map +1 -0
- package/dist/engine/messages/messageExtractText.spec.d.ts +2 -0
- package/dist/engine/messages/messageExtractText.spec.d.ts.map +1 -0
- package/dist/engine/messages/messageExtractText.spec.js +33 -0
- package/dist/engine/messages/messageExtractText.spec.js.map +1 -0
- package/dist/engine/messages/messageExtractToolCalls.d.ts +3 -0
- package/dist/engine/messages/messageExtractToolCalls.d.ts.map +1 -0
- package/dist/engine/messages/messageExtractToolCalls.js +7 -0
- package/dist/engine/messages/messageExtractToolCalls.js.map +1 -0
- package/dist/engine/messages/messageExtractToolCalls.spec.d.ts +2 -0
- package/dist/engine/messages/messageExtractToolCalls.spec.d.ts.map +1 -0
- package/dist/engine/messages/messageExtractToolCalls.spec.js +39 -0
- package/dist/engine/messages/messageExtractToolCalls.spec.js.map +1 -0
- package/dist/engine/messages/messageFormatIncoming.d.ts +3 -0
- package/dist/engine/messages/messageFormatIncoming.d.ts.map +1 -0
- package/dist/engine/messages/messageFormatIncoming.js +17 -0
- package/dist/engine/messages/messageFormatIncoming.js.map +1 -0
- package/dist/engine/messages/messageFormatIncoming.spec.d.ts +2 -0
- package/dist/engine/messages/messageFormatIncoming.spec.d.ts.map +1 -0
- package/dist/engine/messages/messageFormatIncoming.spec.js +20 -0
- package/dist/engine/messages/messageFormatIncoming.spec.js.map +1 -0
- package/dist/engine/messages/messageIsSystemText.d.ts +2 -0
- package/dist/engine/messages/messageIsSystemText.d.ts.map +1 -0
- package/dist/engine/messages/messageIsSystemText.js +5 -0
- package/dist/engine/messages/messageIsSystemText.js.map +1 -0
- package/dist/engine/messages/messageIsSystemText.spec.d.ts +2 -0
- package/dist/engine/messages/messageIsSystemText.spec.d.ts.map +1 -0
- package/dist/engine/messages/messageIsSystemText.spec.js +12 -0
- package/dist/engine/messages/messageIsSystemText.spec.js.map +1 -0
- package/dist/engine/messages/messageNoMessageIs.d.ts +6 -0
- package/dist/engine/messages/messageNoMessageIs.d.ts.map +1 -0
- package/dist/engine/messages/messageNoMessageIs.js +46 -0
- package/dist/engine/messages/messageNoMessageIs.js.map +1 -0
- package/dist/engine/messages/messageNoMessageIs.spec.d.ts +2 -0
- package/dist/engine/messages/messageNoMessageIs.spec.d.ts.map +1 -0
- package/dist/engine/messages/messageNoMessageIs.spec.js +22 -0
- package/dist/engine/messages/messageNoMessageIs.spec.js.map +1 -0
- package/dist/engine/modules/connectorRegistry.d.ts +40 -0
- package/dist/engine/modules/connectorRegistry.d.ts.map +1 -0
- package/dist/engine/modules/connectorRegistry.js +112 -0
- package/dist/engine/modules/connectorRegistry.js.map +1 -0
- package/dist/engine/modules/connectors/types.d.ts +74 -0
- package/dist/engine/modules/connectors/types.d.ts.map +1 -0
- package/dist/engine/modules/connectors/types.js +2 -0
- package/dist/engine/modules/connectors/types.js.map +1 -0
- package/dist/engine/modules/imageGenerationRegistry.d.ts +11 -0
- package/dist/engine/modules/imageGenerationRegistry.d.ts.map +1 -0
- package/dist/engine/modules/imageGenerationRegistry.js +32 -0
- package/dist/engine/modules/imageGenerationRegistry.js.map +1 -0
- package/dist/engine/modules/images/types.d.ts +25 -0
- package/dist/engine/modules/images/types.d.ts.map +1 -0
- package/dist/engine/modules/images/types.js +2 -0
- package/dist/engine/modules/images/types.js.map +1 -0
- package/dist/engine/modules/inference/router.d.ts +34 -0
- package/dist/engine/modules/inference/router.d.ts.map +1 -0
- package/dist/engine/modules/inference/router.js +81 -0
- package/dist/engine/modules/inference/router.js.map +1 -0
- package/dist/engine/modules/inference/types.d.ts +20 -0
- package/dist/engine/modules/inference/types.d.ts.map +1 -0
- package/dist/engine/modules/inference/types.js +2 -0
- package/dist/engine/modules/inference/types.js.map +1 -0
- package/dist/engine/modules/inferenceRegistry.d.ts +11 -0
- package/dist/engine/modules/inferenceRegistry.d.ts.map +1 -0
- package/dist/engine/modules/inferenceRegistry.js +34 -0
- package/dist/engine/modules/inferenceRegistry.js.map +1 -0
- package/dist/engine/modules/moduleRegistry.d.ts +14 -0
- package/dist/engine/modules/moduleRegistry.d.ts.map +1 -0
- package/dist/engine/modules/moduleRegistry.js +17 -0
- package/dist/engine/modules/moduleRegistry.js.map +1 -0
- package/dist/engine/modules/toolResolver.d.ts +11 -0
- package/dist/engine/modules/toolResolver.d.ts.map +1 -0
- package/dist/engine/modules/toolResolver.js +76 -0
- package/dist/engine/modules/toolResolver.js.map +1 -0
- package/dist/engine/modules/tools/agentListToolBuild.d.ts +7 -0
- package/dist/engine/modules/tools/agentListToolBuild.d.ts.map +1 -0
- package/dist/engine/modules/tools/agentListToolBuild.js +70 -0
- package/dist/engine/modules/tools/agentListToolBuild.js.map +1 -0
- package/dist/engine/modules/tools/agentListToolBuild.spec.d.ts +2 -0
- package/dist/engine/modules/tools/agentListToolBuild.spec.d.ts.map +1 -0
- package/dist/engine/modules/tools/agentListToolBuild.spec.js +94 -0
- package/dist/engine/modules/tools/agentListToolBuild.spec.js.map +1 -0
- package/dist/engine/modules/tools/background.d.ts +4 -0
- package/dist/engine/modules/tools/background.d.ts.map +1 -0
- package/dist/engine/modules/tools/background.js +93 -0
- package/dist/engine/modules/tools/background.js.map +1 -0
- package/dist/engine/modules/tools/background.spec.d.ts +2 -0
- package/dist/engine/modules/tools/background.spec.d.ts.map +1 -0
- package/dist/engine/modules/tools/background.spec.js +88 -0
- package/dist/engine/modules/tools/background.spec.js.map +1 -0
- package/dist/engine/modules/tools/cron.d.ts +8 -0
- package/dist/engine/modules/tools/cron.d.ts.map +1 -0
- package/dist/engine/modules/tools/cron.js +254 -0
- package/dist/engine/modules/tools/cron.js.map +1 -0
- package/dist/engine/modules/tools/heartbeat.d.ts +6 -0
- package/dist/engine/modules/tools/heartbeat.d.ts.map +1 -0
- package/dist/engine/modules/tools/heartbeat.js +172 -0
- package/dist/engine/modules/tools/heartbeat.js.map +1 -0
- package/dist/engine/modules/tools/image-generation.d.ts +4 -0
- package/dist/engine/modules/tools/image-generation.d.ts.map +1 -0
- package/dist/engine/modules/tools/image-generation.js +99 -0
- package/dist/engine/modules/tools/image-generation.js.map +1 -0
- package/dist/engine/modules/tools/mermaid-png.d.ts +14 -0
- package/dist/engine/modules/tools/mermaid-png.d.ts.map +1 -0
- package/dist/engine/modules/tools/mermaid-png.js +96 -0
- package/dist/engine/modules/tools/mermaid-png.js.map +1 -0
- package/dist/engine/modules/tools/mermaid-png.spec.d.ts +2 -0
- package/dist/engine/modules/tools/mermaid-png.spec.d.ts.map +1 -0
- package/dist/engine/modules/tools/mermaid-png.spec.js +81 -0
- package/dist/engine/modules/tools/mermaid-png.spec.js.map +1 -0
- package/dist/engine/modules/tools/permanentAgentToolBuild.d.ts +7 -0
- package/dist/engine/modules/tools/permanentAgentToolBuild.d.ts.map +1 -0
- package/dist/engine/modules/tools/permanentAgentToolBuild.js +163 -0
- package/dist/engine/modules/tools/permanentAgentToolBuild.js.map +1 -0
- package/dist/engine/modules/tools/permanentAgentToolBuild.spec.d.ts +2 -0
- package/dist/engine/modules/tools/permanentAgentToolBuild.spec.d.ts.map +1 -0
- package/dist/engine/modules/tools/permanentAgentToolBuild.spec.js +94 -0
- package/dist/engine/modules/tools/permanentAgentToolBuild.spec.js.map +1 -0
- package/dist/engine/modules/tools/permissions.d.ts +4 -0
- package/dist/engine/modules/tools/permissions.d.ts.map +1 -0
- package/dist/engine/modules/tools/permissions.js +187 -0
- package/dist/engine/modules/tools/permissions.js.map +1 -0
- package/dist/engine/modules/tools/reaction.d.ts +3 -0
- package/dist/engine/modules/tools/reaction.d.ts.map +1 -0
- package/dist/engine/modules/tools/reaction.js +49 -0
- package/dist/engine/modules/tools/reaction.js.map +1 -0
- package/dist/engine/modules/tools/send-file.d.ts +14 -0
- package/dist/engine/modules/tools/send-file.d.ts.map +1 -0
- package/dist/engine/modules/tools/send-file.js +147 -0
- package/dist/engine/modules/tools/send-file.js.map +1 -0
- package/dist/engine/modules/tools/sessionHistoryToolBuild.d.ts +7 -0
- package/dist/engine/modules/tools/sessionHistoryToolBuild.d.ts.map +1 -0
- package/dist/engine/modules/tools/sessionHistoryToolBuild.js +187 -0
- package/dist/engine/modules/tools/sessionHistoryToolBuild.js.map +1 -0
- package/dist/engine/modules/tools/sessionHistoryToolBuild.spec.d.ts +2 -0
- package/dist/engine/modules/tools/sessionHistoryToolBuild.spec.d.ts.map +1 -0
- package/dist/engine/modules/tools/sessionHistoryToolBuild.spec.js +193 -0
- package/dist/engine/modules/tools/sessionHistoryToolBuild.spec.js.map +1 -0
- package/dist/engine/modules/tools/signal.d.ts +4 -0
- package/dist/engine/modules/tools/signal.d.ts.map +1 -0
- package/dist/engine/modules/tools/signal.js +60 -0
- package/dist/engine/modules/tools/signal.js.map +1 -0
- package/dist/engine/modules/tools/signal.spec.d.ts +2 -0
- package/dist/engine/modules/tools/signal.spec.d.ts.map +1 -0
- package/dist/engine/modules/tools/signal.spec.js +58 -0
- package/dist/engine/modules/tools/signal.spec.js.map +1 -0
- package/dist/engine/modules/tools/signalSubscribeToolBuild.d.ts +4 -0
- package/dist/engine/modules/tools/signalSubscribeToolBuild.d.ts.map +1 -0
- package/dist/engine/modules/tools/signalSubscribeToolBuild.js +44 -0
- package/dist/engine/modules/tools/signalSubscribeToolBuild.js.map +1 -0
- package/dist/engine/modules/tools/signalSubscribeToolBuild.spec.d.ts +2 -0
- package/dist/engine/modules/tools/signalSubscribeToolBuild.spec.d.ts.map +1 -0
- package/dist/engine/modules/tools/signalSubscribeToolBuild.spec.js +62 -0
- package/dist/engine/modules/tools/signalSubscribeToolBuild.spec.js.map +1 -0
- package/dist/engine/modules/tools/signalUnsubscribeToolBuild.d.ts +4 -0
- package/dist/engine/modules/tools/signalUnsubscribeToolBuild.d.ts.map +1 -0
- package/dist/engine/modules/tools/signalUnsubscribeToolBuild.js +44 -0
- package/dist/engine/modules/tools/signalUnsubscribeToolBuild.js.map +1 -0
- package/dist/engine/modules/tools/signalUnsubscribeToolBuild.spec.d.ts +2 -0
- package/dist/engine/modules/tools/signalUnsubscribeToolBuild.spec.d.ts.map +1 -0
- package/dist/engine/modules/tools/signalUnsubscribeToolBuild.spec.js +74 -0
- package/dist/engine/modules/tools/signalUnsubscribeToolBuild.spec.js.map +1 -0
- package/dist/engine/modules/tools/toolArgsFormatVerbose.d.ts +6 -0
- package/dist/engine/modules/tools/toolArgsFormatVerbose.d.ts.map +1 -0
- package/dist/engine/modules/tools/toolArgsFormatVerbose.js +19 -0
- package/dist/engine/modules/tools/toolArgsFormatVerbose.js.map +1 -0
- package/dist/engine/modules/tools/toolArgsFormatVerbose.spec.d.ts +2 -0
- package/dist/engine/modules/tools/toolArgsFormatVerbose.spec.d.ts.map +1 -0
- package/dist/engine/modules/tools/toolArgsFormatVerbose.spec.js +14 -0
- package/dist/engine/modules/tools/toolArgsFormatVerbose.spec.js.map +1 -0
- package/dist/engine/modules/tools/toolListContextBuild.d.ts +18 -0
- package/dist/engine/modules/tools/toolListContextBuild.d.ts.map +1 -0
- package/dist/engine/modules/tools/toolListContextBuild.js +49 -0
- package/dist/engine/modules/tools/toolListContextBuild.js.map +1 -0
- package/dist/engine/modules/tools/toolListContextBuild.spec.d.ts +2 -0
- package/dist/engine/modules/tools/toolListContextBuild.spec.d.ts.map +1 -0
- package/dist/engine/modules/tools/toolListContextBuild.spec.js +78 -0
- package/dist/engine/modules/tools/toolListContextBuild.spec.js.map +1 -0
- package/dist/engine/modules/tools/toolResultFormatVerbose.d.ts +7 -0
- package/dist/engine/modules/tools/toolResultFormatVerbose.d.ts.map +1 -0
- package/dist/engine/modules/tools/toolResultFormatVerbose.js +24 -0
- package/dist/engine/modules/tools/toolResultFormatVerbose.js.map +1 -0
- package/dist/engine/modules/tools/toolResultFormatVerbose.spec.d.ts +2 -0
- package/dist/engine/modules/tools/toolResultFormatVerbose.spec.d.ts.map +1 -0
- package/dist/engine/modules/tools/toolResultFormatVerbose.spec.js +30 -0
- package/dist/engine/modules/tools/toolResultFormatVerbose.spec.js.map +1 -0
- package/dist/engine/modules/tools/toolResultTruncate.d.ts +7 -0
- package/dist/engine/modules/tools/toolResultTruncate.d.ts.map +1 -0
- package/dist/engine/modules/tools/toolResultTruncate.js +42 -0
- package/dist/engine/modules/tools/toolResultTruncate.js.map +1 -0
- package/dist/engine/modules/tools/toolResultTruncate.spec.d.ts +2 -0
- package/dist/engine/modules/tools/toolResultTruncate.spec.d.ts.map +1 -0
- package/dist/engine/modules/tools/toolResultTruncate.spec.js +39 -0
- package/dist/engine/modules/tools/toolResultTruncate.spec.js.map +1 -0
- package/dist/engine/modules/tools/types.d.ts +37 -0
- package/dist/engine/modules/tools/types.d.ts.map +1 -0
- package/dist/engine/modules/tools/types.js +2 -0
- package/dist/engine/modules/tools/types.js.map +1 -0
- package/dist/engine/permissions/pathResolveSecure.d.ts +38 -0
- package/dist/engine/permissions/pathResolveSecure.d.ts.map +1 -0
- package/dist/engine/permissions/pathResolveSecure.js +96 -0
- package/dist/engine/permissions/pathResolveSecure.js.map +1 -0
- package/dist/engine/permissions/pathResolveSecure.spec.d.ts +2 -0
- package/dist/engine/permissions/pathResolveSecure.spec.d.ts.map +1 -0
- package/dist/engine/permissions/pathResolveSecure.spec.js +115 -0
- package/dist/engine/permissions/pathResolveSecure.spec.js.map +1 -0
- package/dist/engine/permissions/pathSanitize.d.ts +16 -0
- package/dist/engine/permissions/pathSanitize.d.ts.map +1 -0
- package/dist/engine/permissions/pathSanitize.js +39 -0
- package/dist/engine/permissions/pathSanitize.js.map +1 -0
- package/dist/engine/permissions/pathSanitize.spec.d.ts +2 -0
- package/dist/engine/permissions/pathSanitize.spec.d.ts.map +1 -0
- package/dist/engine/permissions/pathSanitize.spec.js +43 -0
- package/dist/engine/permissions/pathSanitize.spec.js.map +1 -0
- package/dist/engine/permissions/permissionAccessAllows.d.ts +7 -0
- package/dist/engine/permissions/permissionAccessAllows.d.ts.map +1 -0
- package/dist/engine/permissions/permissionAccessAllows.js +35 -0
- package/dist/engine/permissions/permissionAccessAllows.js.map +1 -0
- package/dist/engine/permissions/permissionAccessAllows.spec.d.ts +2 -0
- package/dist/engine/permissions/permissionAccessAllows.spec.d.ts.map +1 -0
- package/dist/engine/permissions/permissionAccessAllows.spec.js +55 -0
- package/dist/engine/permissions/permissionAccessAllows.spec.js.map +1 -0
- package/dist/engine/permissions/permissionAccessApply.d.ts +7 -0
- package/dist/engine/permissions/permissionAccessApply.d.ts.map +1 -0
- package/dist/engine/permissions/permissionAccessApply.js +40 -0
- package/dist/engine/permissions/permissionAccessApply.js.map +1 -0
- package/dist/engine/permissions/permissionAccessApply.spec.d.ts +2 -0
- package/dist/engine/permissions/permissionAccessApply.spec.d.ts.map +1 -0
- package/dist/engine/permissions/permissionAccessApply.spec.js +34 -0
- package/dist/engine/permissions/permissionAccessApply.spec.js.map +1 -0
- package/dist/engine/permissions/permissionAccessParse.d.ts +7 -0
- package/dist/engine/permissions/permissionAccessParse.d.ts.map +1 -0
- package/dist/engine/permissions/permissionAccessParse.js +26 -0
- package/dist/engine/permissions/permissionAccessParse.js.map +1 -0
- package/dist/engine/permissions/permissionAccessParse.spec.d.ts +2 -0
- package/dist/engine/permissions/permissionAccessParse.spec.d.ts.map +1 -0
- package/dist/engine/permissions/permissionAccessParse.spec.js +15 -0
- package/dist/engine/permissions/permissionAccessParse.spec.js.map +1 -0
- package/dist/engine/permissions/permissionApply.d.ts +4 -0
- package/dist/engine/permissions/permissionApply.d.ts.map +1 -0
- package/dist/engine/permissions/permissionApply.js +8 -0
- package/dist/engine/permissions/permissionApply.js.map +1 -0
- package/dist/engine/permissions/permissionApply.spec.d.ts +2 -0
- package/dist/engine/permissions/permissionApply.spec.d.ts.map +1 -0
- package/dist/engine/permissions/permissionApply.spec.js +88 -0
- package/dist/engine/permissions/permissionApply.spec.js.map +1 -0
- package/dist/engine/permissions/permissionBuildCron.d.ts +3 -0
- package/dist/engine/permissions/permissionBuildCron.d.ts.map +1 -0
- package/dist/engine/permissions/permissionBuildCron.js +13 -0
- package/dist/engine/permissions/permissionBuildCron.js.map +1 -0
- package/dist/engine/permissions/permissionBuildCron.spec.d.ts +2 -0
- package/dist/engine/permissions/permissionBuildCron.spec.d.ts.map +1 -0
- package/dist/engine/permissions/permissionBuildCron.spec.js +19 -0
- package/dist/engine/permissions/permissionBuildCron.spec.js.map +1 -0
- package/dist/engine/permissions/permissionBuildDefault.d.ts +3 -0
- package/dist/engine/permissions/permissionBuildDefault.d.ts.map +1 -0
- package/dist/engine/permissions/permissionBuildDefault.js +27 -0
- package/dist/engine/permissions/permissionBuildDefault.js.map +1 -0
- package/dist/engine/permissions/permissionBuildDefault.spec.d.ts +2 -0
- package/dist/engine/permissions/permissionBuildDefault.spec.d.ts.map +1 -0
- package/dist/engine/permissions/permissionBuildDefault.spec.js +23 -0
- package/dist/engine/permissions/permissionBuildDefault.spec.js.map +1 -0
- package/dist/engine/permissions/permissionClone.d.ts +7 -0
- package/dist/engine/permissions/permissionClone.d.ts.map +1 -0
- package/dist/engine/permissions/permissionClone.js +12 -0
- package/dist/engine/permissions/permissionClone.js.map +1 -0
- package/dist/engine/permissions/permissionClone.spec.d.ts +2 -0
- package/dist/engine/permissions/permissionClone.spec.d.ts.map +1 -0
- package/dist/engine/permissions/permissionClone.spec.js +17 -0
- package/dist/engine/permissions/permissionClone.spec.js.map +1 -0
- package/dist/engine/permissions/permissionDescribeDecision.d.ts +3 -0
- package/dist/engine/permissions/permissionDescribeDecision.d.ts.map +1 -0
- package/dist/engine/permissions/permissionDescribeDecision.js +10 -0
- package/dist/engine/permissions/permissionDescribeDecision.js.map +1 -0
- package/dist/engine/permissions/permissionDescribeDecision.spec.d.ts +2 -0
- package/dist/engine/permissions/permissionDescribeDecision.spec.d.ts.map +1 -0
- package/dist/engine/permissions/permissionDescribeDecision.spec.js +11 -0
- package/dist/engine/permissions/permissionDescribeDecision.spec.js.map +1 -0
- package/dist/engine/permissions/permissionEnsureDefaultFile.d.ts +3 -0
- package/dist/engine/permissions/permissionEnsureDefaultFile.d.ts.map +1 -0
- package/dist/engine/permissions/permissionEnsureDefaultFile.js +7 -0
- package/dist/engine/permissions/permissionEnsureDefaultFile.js.map +1 -0
- package/dist/engine/permissions/permissionEnsureDefaultFile.spec.d.ts +2 -0
- package/dist/engine/permissions/permissionEnsureDefaultFile.spec.d.ts.map +1 -0
- package/dist/engine/permissions/permissionEnsureDefaultFile.spec.js +19 -0
- package/dist/engine/permissions/permissionEnsureDefaultFile.spec.js.map +1 -0
- package/dist/engine/permissions/permissionFormatTag.d.ts +3 -0
- package/dist/engine/permissions/permissionFormatTag.d.ts.map +1 -0
- package/dist/engine/permissions/permissionFormatTag.js +7 -0
- package/dist/engine/permissions/permissionFormatTag.js.map +1 -0
- package/dist/engine/permissions/permissionFormatTag.spec.d.ts +2 -0
- package/dist/engine/permissions/permissionFormatTag.spec.d.ts.map +1 -0
- package/dist/engine/permissions/permissionFormatTag.spec.js +11 -0
- package/dist/engine/permissions/permissionFormatTag.spec.js.map +1 -0
- package/dist/engine/permissions/permissionMergeDefault.d.ts +3 -0
- package/dist/engine/permissions/permissionMergeDefault.d.ts.map +1 -0
- package/dist/engine/permissions/permissionMergeDefault.js +12 -0
- package/dist/engine/permissions/permissionMergeDefault.js.map +1 -0
- package/dist/engine/permissions/permissionMergeDefault.spec.d.ts +2 -0
- package/dist/engine/permissions/permissionMergeDefault.spec.d.ts.map +1 -0
- package/dist/engine/permissions/permissionMergeDefault.spec.js +56 -0
- package/dist/engine/permissions/permissionMergeDefault.spec.js.map +1 -0
- package/dist/engine/permissions/permissionTagsApply.d.ts +7 -0
- package/dist/engine/permissions/permissionTagsApply.d.ts.map +1 -0
- package/dist/engine/permissions/permissionTagsApply.js +16 -0
- package/dist/engine/permissions/permissionTagsApply.js.map +1 -0
- package/dist/engine/permissions/permissionTagsApply.spec.d.ts +2 -0
- package/dist/engine/permissions/permissionTagsApply.spec.d.ts.map +1 -0
- package/dist/engine/permissions/permissionTagsApply.spec.js +18 -0
- package/dist/engine/permissions/permissionTagsApply.spec.js.map +1 -0
- package/dist/engine/permissions/permissionTagsNormalize.d.ts +6 -0
- package/dist/engine/permissions/permissionTagsNormalize.d.ts.map +1 -0
- package/dist/engine/permissions/permissionTagsNormalize.js +33 -0
- package/dist/engine/permissions/permissionTagsNormalize.js.map +1 -0
- package/dist/engine/permissions/permissionTagsNormalize.spec.d.ts +2 -0
- package/dist/engine/permissions/permissionTagsNormalize.spec.d.ts.map +1 -0
- package/dist/engine/permissions/permissionTagsNormalize.spec.js +17 -0
- package/dist/engine/permissions/permissionTagsNormalize.spec.js.map +1 -0
- package/dist/engine/permissions/permissionTagsValidate.d.ts +9 -0
- package/dist/engine/permissions/permissionTagsValidate.d.ts.map +1 -0
- package/dist/engine/permissions/permissionTagsValidate.js +18 -0
- package/dist/engine/permissions/permissionTagsValidate.js.map +1 -0
- package/dist/engine/permissions/permissionTagsValidate.spec.d.ts +2 -0
- package/dist/engine/permissions/permissionTagsValidate.spec.d.ts.map +1 -0
- package/dist/engine/permissions/permissionTagsValidate.spec.js +66 -0
- package/dist/engine/permissions/permissionTagsValidate.spec.js.map +1 -0
- package/dist/engine/permissions.d.ts +12 -0
- package/dist/engine/permissions.d.ts.map +1 -0
- package/dist/engine/permissions.js +67 -0
- package/dist/engine/permissions.js.map +1 -0
- package/dist/engine/plugins/builtins.spec.d.ts +2 -0
- package/dist/engine/plugins/builtins.spec.d.ts.map +1 -0
- package/dist/engine/plugins/builtins.spec.js +91 -0
- package/dist/engine/plugins/builtins.spec.js.map +1 -0
- package/dist/engine/plugins/catalog.d.ts +9 -0
- package/dist/engine/plugins/catalog.d.ts.map +1 -0
- package/dist/engine/plugins/catalog.js +37 -0
- package/dist/engine/plugins/catalog.js.map +1 -0
- package/dist/engine/plugins/descriptor.d.ts +22 -0
- package/dist/engine/plugins/descriptor.d.ts.map +1 -0
- package/dist/engine/plugins/descriptor.js +9 -0
- package/dist/engine/plugins/descriptor.js.map +1 -0
- package/dist/engine/plugins/events.d.ts +15 -0
- package/dist/engine/plugins/events.d.ts.map +1 -0
- package/dist/engine/plugins/events.js +2 -0
- package/dist/engine/plugins/events.js.map +1 -0
- package/dist/engine/plugins/exclusive.d.ts +9 -0
- package/dist/engine/plugins/exclusive.d.ts.map +1 -0
- package/dist/engine/plugins/exclusive.js +20 -0
- package/dist/engine/plugins/exclusive.js.map +1 -0
- package/dist/engine/plugins/inference.d.ts +31 -0
- package/dist/engine/plugins/inference.d.ts.map +1 -0
- package/dist/engine/plugins/inference.js +82 -0
- package/dist/engine/plugins/inference.js.map +1 -0
- package/dist/engine/plugins/loader.d.ts +12 -0
- package/dist/engine/plugins/loader.d.ts.map +1 -0
- package/dist/engine/plugins/loader.js +93 -0
- package/dist/engine/plugins/loader.js.map +1 -0
- package/dist/engine/plugins/loader.spec.d.ts +2 -0
- package/dist/engine/plugins/loader.spec.d.ts.map +1 -0
- package/dist/engine/plugins/loader.spec.js +66 -0
- package/dist/engine/plugins/loader.spec.js.map +1 -0
- package/dist/engine/plugins/manager.d.ts +57 -0
- package/dist/engine/plugins/manager.d.ts.map +1 -0
- package/dist/engine/plugins/manager.js +287 -0
- package/dist/engine/plugins/manager.js.map +1 -0
- package/dist/engine/plugins/manager.spec.d.ts +2 -0
- package/dist/engine/plugins/manager.spec.d.ts.map +1 -0
- package/dist/engine/plugins/manager.spec.js +341 -0
- package/dist/engine/plugins/manager.spec.js.map +1 -0
- package/dist/engine/plugins/registry.d.ts +36 -0
- package/dist/engine/plugins/registry.d.ts.map +1 -0
- package/dist/engine/plugins/registry.js +101 -0
- package/dist/engine/plugins/registry.js.map +1 -0
- package/dist/engine/plugins/types.d.ts +73 -0
- package/dist/engine/plugins/types.d.ts.map +1 -0
- package/dist/engine/plugins/types.js +4 -0
- package/dist/engine/plugins/types.js.map +1 -0
- package/dist/engine/processes/processBootTimeRead.d.ts +6 -0
- package/dist/engine/processes/processBootTimeRead.d.ts.map +1 -0
- package/dist/engine/processes/processBootTimeRead.js +56 -0
- package/dist/engine/processes/processBootTimeRead.js.map +1 -0
- package/dist/engine/processes/processes.d.ts +70 -0
- package/dist/engine/processes/processes.d.ts.map +1 -0
- package/dist/engine/processes/processes.js +632 -0
- package/dist/engine/processes/processes.js.map +1 -0
- package/dist/engine/processes/processes.spec.d.ts +2 -0
- package/dist/engine/processes/processes.spec.d.ts.map +1 -0
- package/dist/engine/processes/processes.spec.js +176 -0
- package/dist/engine/processes/processes.spec.js.map +1 -0
- package/dist/engine/scheduling/execGateCheck.d.ts +19 -0
- package/dist/engine/scheduling/execGateCheck.d.ts.map +1 -0
- package/dist/engine/scheduling/execGateCheck.js +136 -0
- package/dist/engine/scheduling/execGateCheck.js.map +1 -0
- package/dist/engine/scheduling/execGateNormalize.d.ts +7 -0
- package/dist/engine/scheduling/execGateNormalize.d.ts.map +1 -0
- package/dist/engine/scheduling/execGateNormalize.js +74 -0
- package/dist/engine/scheduling/execGateNormalize.js.map +1 -0
- package/dist/engine/scheduling/execGateNormalize.spec.d.ts +2 -0
- package/dist/engine/scheduling/execGateNormalize.spec.d.ts.map +1 -0
- package/dist/engine/scheduling/execGateNormalize.spec.js +41 -0
- package/dist/engine/scheduling/execGateNormalize.spec.js.map +1 -0
- package/dist/engine/scheduling/execGateOutputAppend.d.ts +7 -0
- package/dist/engine/scheduling/execGateOutputAppend.d.ts.map +1 -0
- package/dist/engine/scheduling/execGateOutputAppend.js +23 -0
- package/dist/engine/scheduling/execGateOutputAppend.js.map +1 -0
- package/dist/engine/scheduling/execGateOutputAppend.spec.d.ts +2 -0
- package/dist/engine/scheduling/execGateOutputAppend.spec.d.ts.map +1 -0
- package/dist/engine/scheduling/execGateOutputAppend.spec.js +24 -0
- package/dist/engine/scheduling/execGateOutputAppend.spec.js.map +1 -0
- package/dist/engine/scheduling/execGateTypes.d.ts +15 -0
- package/dist/engine/scheduling/execGateTypes.d.ts.map +1 -0
- package/dist/engine/scheduling/execGateTypes.js +2 -0
- package/dist/engine/scheduling/execGateTypes.js.map +1 -0
- package/dist/engine/scheduling/gatePermissionsCheck.d.ts +11 -0
- package/dist/engine/scheduling/gatePermissionsCheck.d.ts.map +1 -0
- package/dist/engine/scheduling/gatePermissionsCheck.js +52 -0
- package/dist/engine/scheduling/gatePermissionsCheck.js.map +1 -0
- package/dist/engine/scheduling/gatePermissionsCheck.spec.d.ts +2 -0
- package/dist/engine/scheduling/gatePermissionsCheck.spec.d.ts.map +1 -0
- package/dist/engine/scheduling/gatePermissionsCheck.spec.js +37 -0
- package/dist/engine/scheduling/gatePermissionsCheck.spec.js.map +1 -0
- package/dist/engine/signals/delayedSignals.d.ts +54 -0
- package/dist/engine/signals/delayedSignals.d.ts.map +1 -0
- package/dist/engine/signals/delayedSignals.js +368 -0
- package/dist/engine/signals/delayedSignals.js.map +1 -0
- package/dist/engine/signals/delayedSignals.spec.d.ts +2 -0
- package/dist/engine/signals/delayedSignals.spec.d.ts.map +1 -0
- package/dist/engine/signals/delayedSignals.spec.js +133 -0
- package/dist/engine/signals/delayedSignals.spec.js.map +1 -0
- package/dist/engine/signals/signalMessageBuild.d.ts +7 -0
- package/dist/engine/signals/signalMessageBuild.d.ts.map +1 -0
- package/dist/engine/signals/signalMessageBuild.js +20 -0
- package/dist/engine/signals/signalMessageBuild.js.map +1 -0
- package/dist/engine/signals/signalTypeMatchesPattern.d.ts +6 -0
- package/dist/engine/signals/signalTypeMatchesPattern.d.ts.map +1 -0
- package/dist/engine/signals/signalTypeMatchesPattern.js +28 -0
- package/dist/engine/signals/signalTypeMatchesPattern.js.map +1 -0
- package/dist/engine/signals/signalTypeMatchesPattern.spec.d.ts +2 -0
- package/dist/engine/signals/signalTypeMatchesPattern.spec.d.ts.map +1 -0
- package/dist/engine/signals/signalTypeMatchesPattern.spec.js +15 -0
- package/dist/engine/signals/signalTypeMatchesPattern.spec.js.map +1 -0
- package/dist/engine/signals/signalTypes.d.ts +62 -0
- package/dist/engine/signals/signalTypes.d.ts.map +1 -0
- package/dist/engine/signals/signalTypes.js +2 -0
- package/dist/engine/signals/signalTypes.js.map +1 -0
- package/dist/engine/signals/signals.d.ts +42 -0
- package/dist/engine/signals/signals.d.ts.map +1 -0
- package/dist/engine/signals/signals.js +215 -0
- package/dist/engine/signals/signals.js.map +1 -0
- package/dist/engine/signals/signals.spec.d.ts +2 -0
- package/dist/engine/signals/signals.spec.d.ts.map +1 -0
- package/dist/engine/signals/signals.spec.js +107 -0
- package/dist/engine/signals/signals.spec.js.map +1 -0
- package/dist/engine/skills/skillConstants.d.ts +5 -0
- package/dist/engine/skills/skillConstants.d.ts.map +1 -0
- package/dist/engine/skills/skillConstants.js +5 -0
- package/dist/engine/skills/skillConstants.js.map +1 -0
- package/dist/engine/skills/skillListConfig.d.ts +8 -0
- package/dist/engine/skills/skillListConfig.d.ts.map +1 -0
- package/dist/engine/skills/skillListConfig.js +10 -0
- package/dist/engine/skills/skillListConfig.js.map +1 -0
- package/dist/engine/skills/skillListCore.d.ts +8 -0
- package/dist/engine/skills/skillListCore.d.ts.map +1 -0
- package/dist/engine/skills/skillListCore.js +12 -0
- package/dist/engine/skills/skillListCore.js.map +1 -0
- package/dist/engine/skills/skillListFromRoot.d.ts +8 -0
- package/dist/engine/skills/skillListFromRoot.d.ts.map +1 -0
- package/dist/engine/skills/skillListFromRoot.js +57 -0
- package/dist/engine/skills/skillListFromRoot.js.map +1 -0
- package/dist/engine/skills/skillListFromRoot.spec.d.ts +2 -0
- package/dist/engine/skills/skillListFromRoot.spec.d.ts.map +1 -0
- package/dist/engine/skills/skillListFromRoot.spec.js +31 -0
- package/dist/engine/skills/skillListFromRoot.spec.js.map +1 -0
- package/dist/engine/skills/skillListRegistered.d.ts +8 -0
- package/dist/engine/skills/skillListRegistered.d.ts.map +1 -0
- package/dist/engine/skills/skillListRegistered.js +29 -0
- package/dist/engine/skills/skillListRegistered.js.map +1 -0
- package/dist/engine/skills/skillListRegistered.spec.d.ts +2 -0
- package/dist/engine/skills/skillListRegistered.spec.d.ts.map +1 -0
- package/dist/engine/skills/skillListRegistered.spec.js +30 -0
- package/dist/engine/skills/skillListRegistered.spec.js.map +1 -0
- package/dist/engine/skills/skillPromptFormat.d.ts +8 -0
- package/dist/engine/skills/skillPromptFormat.d.ts.map +1 -0
- package/dist/engine/skills/skillPromptFormat.js +49 -0
- package/dist/engine/skills/skillPromptFormat.js.map +1 -0
- package/dist/engine/skills/skillPromptFormat.spec.d.ts +2 -0
- package/dist/engine/skills/skillPromptFormat.spec.d.ts.map +1 -0
- package/dist/engine/skills/skillPromptFormat.spec.js +40 -0
- package/dist/engine/skills/skillPromptFormat.spec.js.map +1 -0
- package/dist/engine/skills/skillResolve.d.ts +8 -0
- package/dist/engine/skills/skillResolve.d.ts.map +1 -0
- package/dist/engine/skills/skillResolve.js +194 -0
- package/dist/engine/skills/skillResolve.js.map +1 -0
- package/dist/engine/skills/skillSort.d.ts +8 -0
- package/dist/engine/skills/skillSort.d.ts.map +1 -0
- package/dist/engine/skills/skillSort.js +15 -0
- package/dist/engine/skills/skillSort.js.map +1 -0
- package/dist/engine/skills/skillTypes.d.ts +32 -0
- package/dist/engine/skills/skillTypes.d.ts.map +1 -0
- package/dist/engine/skills/skillTypes.js +2 -0
- package/dist/engine/skills/skillTypes.js.map +1 -0
- package/dist/files/store.d.ts +24 -0
- package/dist/files/store.d.ts.map +1 -0
- package/dist/files/store.js +74 -0
- package/dist/files/store.js.map +1 -0
- package/dist/files/types.d.ts +17 -0
- package/dist/files/types.d.ts.map +1 -0
- package/dist/files/types.js +2 -0
- package/dist/files/types.js.map +1 -0
- package/dist/log.d.ts +15 -0
- package/dist/log.d.ts.map +1 -0
- package/dist/log.js +253 -0
- package/dist/log.js.map +1 -0
- package/dist/main.d.ts +2 -0
- package/dist/main.d.ts.map +1 -0
- package/dist/main.js +83 -0
- package/dist/main.js.map +1 -0
- package/dist/paths.d.ts +8 -0
- package/dist/paths.d.ts.map +1 -0
- package/dist/paths.js +19 -0
- package/dist/paths.js.map +1 -0
- package/dist/plugins/anthropic-fetch/plugin.d.ts +6 -0
- package/dist/plugins/anthropic-fetch/plugin.d.ts.map +1 -0
- package/dist/plugins/anthropic-fetch/plugin.js +209 -0
- package/dist/plugins/anthropic-fetch/plugin.js.map +1 -0
- package/dist/plugins/anthropic-search/plugin.d.ts +6 -0
- package/dist/plugins/anthropic-search/plugin.d.ts.map +1 -0
- package/dist/plugins/anthropic-search/plugin.js +204 -0
- package/dist/plugins/anthropic-search/plugin.js.map +1 -0
- package/dist/plugins/brave-search/plugin.d.ts +5 -0
- package/dist/plugins/brave-search/plugin.d.ts.map +1 -0
- package/dist/plugins/brave-search/plugin.js +130 -0
- package/dist/plugins/brave-search/plugin.js.map +1 -0
- package/dist/plugins/database/__tests__/plugin.spec.d.ts +2 -0
- package/dist/plugins/database/__tests__/plugin.spec.d.ts.map +1 -0
- package/dist/plugins/database/__tests__/plugin.spec.js +110 -0
- package/dist/plugins/database/__tests__/plugin.spec.js.map +1 -0
- package/dist/plugins/database/plugin.d.ts +3 -0
- package/dist/plugins/database/plugin.d.ts.map +1 -0
- package/dist/plugins/database/plugin.js +275 -0
- package/dist/plugins/database/plugin.js.map +1 -0
- package/dist/plugins/exa-ai/plugin.d.ts +5 -0
- package/dist/plugins/exa-ai/plugin.d.ts.map +1 -0
- package/dist/plugins/exa-ai/plugin.js +142 -0
- package/dist/plugins/exa-ai/plugin.js.map +1 -0
- package/dist/plugins/firecrawl/plugin.d.ts +5 -0
- package/dist/plugins/firecrawl/plugin.d.ts.map +1 -0
- package/dist/plugins/firecrawl/plugin.js +140 -0
- package/dist/plugins/firecrawl/plugin.js.map +1 -0
- package/dist/plugins/gemini-search/plugin.d.ts +6 -0
- package/dist/plugins/gemini-search/plugin.d.ts.map +1 -0
- package/dist/plugins/gemini-search/plugin.js +155 -0
- package/dist/plugins/gemini-search/plugin.js.map +1 -0
- package/dist/plugins/memory/plugin.d.ts +3 -0
- package/dist/plugins/memory/plugin.d.ts.map +1 -0
- package/dist/plugins/memory/plugin.js +30 -0
- package/dist/plugins/memory/plugin.js.map +1 -0
- package/dist/plugins/memory/store.d.ts +30 -0
- package/dist/plugins/memory/store.d.ts.map +1 -0
- package/dist/plugins/memory/store.js +266 -0
- package/dist/plugins/memory/store.js.map +1 -0
- package/dist/plugins/memory/tool.d.ts +6 -0
- package/dist/plugins/memory/tool.d.ts.map +1 -0
- package/dist/plugins/memory/tool.js +115 -0
- package/dist/plugins/memory/tool.js.map +1 -0
- package/dist/plugins/monty-python/plugin.d.ts +5 -0
- package/dist/plugins/monty-python/plugin.d.ts.map +1 -0
- package/dist/plugins/monty-python/plugin.js +23 -0
- package/dist/plugins/monty-python/plugin.js.map +1 -0
- package/dist/plugins/monty-python/tool.d.ts +3 -0
- package/dist/plugins/monty-python/tool.d.ts.map +1 -0
- package/dist/plugins/monty-python/tool.js +211 -0
- package/dist/plugins/monty-python/tool.js.map +1 -0
- package/dist/plugins/monty-python/tool.spec.d.ts +2 -0
- package/dist/plugins/monty-python/tool.spec.d.ts.map +1 -0
- package/dist/plugins/monty-python/tool.spec.js +89 -0
- package/dist/plugins/monty-python/tool.spec.js.map +1 -0
- package/dist/plugins/nano-banana-pro/__tests__/plugin.integration.spec.d.ts +2 -0
- package/dist/plugins/nano-banana-pro/__tests__/plugin.integration.spec.d.ts.map +1 -0
- package/dist/plugins/nano-banana-pro/__tests__/plugin.integration.spec.js +98 -0
- package/dist/plugins/nano-banana-pro/__tests__/plugin.integration.spec.js.map +1 -0
- package/dist/plugins/nano-banana-pro/plugin.d.ts +14 -0
- package/dist/plugins/nano-banana-pro/plugin.d.ts.map +1 -0
- package/dist/plugins/nano-banana-pro/plugin.js +240 -0
- package/dist/plugins/nano-banana-pro/plugin.js.map +1 -0
- package/dist/plugins/openai-search/plugin.d.ts +6 -0
- package/dist/plugins/openai-search/plugin.d.ts.map +1 -0
- package/dist/plugins/openai-search/plugin.js +194 -0
- package/dist/plugins/openai-search/plugin.js.map +1 -0
- package/dist/plugins/perplexity-search/plugin.d.ts +6 -0
- package/dist/plugins/perplexity-search/plugin.d.ts.map +1 -0
- package/dist/plugins/perplexity-search/plugin.js +126 -0
- package/dist/plugins/perplexity-search/plugin.js.map +1 -0
- package/dist/plugins/shell/plugin.d.ts +3 -0
- package/dist/plugins/shell/plugin.d.ts.map +1 -0
- package/dist/plugins/shell/plugin.js +36 -0
- package/dist/plugins/shell/plugin.js.map +1 -0
- package/dist/plugins/shell/processTools.d.ts +8 -0
- package/dist/plugins/shell/processTools.d.ts.map +1 -0
- package/dist/plugins/shell/processTools.js +213 -0
- package/dist/plugins/shell/processTools.js.map +1 -0
- package/dist/plugins/shell/processTools.spec.d.ts +2 -0
- package/dist/plugins/shell/processTools.spec.d.ts.map +1 -0
- package/dist/plugins/shell/processTools.spec.js +144 -0
- package/dist/plugins/shell/processTools.spec.js.map +1 -0
- package/dist/plugins/shell/tool.d.ts +6 -0
- package/dist/plugins/shell/tool.d.ts.map +1 -0
- package/dist/plugins/shell/tool.js +398 -0
- package/dist/plugins/shell/tool.js.map +1 -0
- package/dist/plugins/shell/tool.spec.d.ts +2 -0
- package/dist/plugins/shell/tool.spec.d.ts.map +1 -0
- package/dist/plugins/shell/tool.spec.js +234 -0
- package/dist/plugins/shell/tool.spec.js.map +1 -0
- package/dist/plugins/telegram/connector.d.ts +65 -0
- package/dist/plugins/telegram/connector.d.ts.map +1 -0
- package/dist/plugins/telegram/connector.js +760 -0
- package/dist/plugins/telegram/connector.js.map +1 -0
- package/dist/plugins/telegram/connector.spec.d.ts +2 -0
- package/dist/plugins/telegram/connector.spec.d.ts.map +1 -0
- package/dist/plugins/telegram/connector.spec.js +247 -0
- package/dist/plugins/telegram/connector.spec.js.map +1 -0
- package/dist/plugins/telegram/markdownToTelegramHtml.d.ts +11 -0
- package/dist/plugins/telegram/markdownToTelegramHtml.d.ts.map +1 -0
- package/dist/plugins/telegram/markdownToTelegramHtml.js +172 -0
- package/dist/plugins/telegram/markdownToTelegramHtml.js.map +1 -0
- package/dist/plugins/telegram/markdownToTelegramHtml.spec.d.ts +2 -0
- package/dist/plugins/telegram/markdownToTelegramHtml.spec.d.ts.map +1 -0
- package/dist/plugins/telegram/markdownToTelegramHtml.spec.js +97 -0
- package/dist/plugins/telegram/markdownToTelegramHtml.spec.js.map +1 -0
- package/dist/plugins/telegram/plugin.d.ts +8 -0
- package/dist/plugins/telegram/plugin.d.ts.map +1 -0
- package/dist/plugins/telegram/plugin.js +94 -0
- package/dist/plugins/telegram/plugin.js.map +1 -0
- package/dist/plugins/telegram/telegramMessageSplit.d.ts +6 -0
- package/dist/plugins/telegram/telegramMessageSplit.d.ts.map +1 -0
- package/dist/plugins/telegram/telegramMessageSplit.js +33 -0
- package/dist/plugins/telegram/telegramMessageSplit.js.map +1 -0
- package/dist/plugins/telegram/telegramMessageSplit.spec.d.ts +2 -0
- package/dist/plugins/telegram/telegramMessageSplit.spec.d.ts.map +1 -0
- package/dist/plugins/telegram/telegramMessageSplit.spec.js +16 -0
- package/dist/plugins/telegram/telegramMessageSplit.spec.js.map +1 -0
- package/dist/plugins/web-fetch/plugin.d.ts +5 -0
- package/dist/plugins/web-fetch/plugin.d.ts.map +1 -0
- package/dist/plugins/web-fetch/plugin.js +99 -0
- package/dist/plugins/web-fetch/plugin.js.map +1 -0
- package/dist/plugins/whatsapp/authState.d.ts +21 -0
- package/dist/plugins/whatsapp/authState.d.ts.map +1 -0
- package/dist/plugins/whatsapp/authState.js +92 -0
- package/dist/plugins/whatsapp/authState.js.map +1 -0
- package/dist/plugins/whatsapp/authenticate.d.ts +22 -0
- package/dist/plugins/whatsapp/authenticate.d.ts.map +1 -0
- package/dist/plugins/whatsapp/authenticate.js +82 -0
- package/dist/plugins/whatsapp/authenticate.js.map +1 -0
- package/dist/plugins/whatsapp/connector.d.ts +51 -0
- package/dist/plugins/whatsapp/connector.d.ts.map +1 -0
- package/dist/plugins/whatsapp/connector.js +481 -0
- package/dist/plugins/whatsapp/connector.js.map +1 -0
- package/dist/plugins/whatsapp/markdownToWhatsAppText.d.ts +11 -0
- package/dist/plugins/whatsapp/markdownToWhatsAppText.d.ts.map +1 -0
- package/dist/plugins/whatsapp/markdownToWhatsAppText.js +161 -0
- package/dist/plugins/whatsapp/markdownToWhatsAppText.js.map +1 -0
- package/dist/plugins/whatsapp/markdownToWhatsAppText.spec.d.ts +2 -0
- package/dist/plugins/whatsapp/markdownToWhatsAppText.spec.d.ts.map +1 -0
- package/dist/plugins/whatsapp/markdownToWhatsAppText.spec.js +80 -0
- package/dist/plugins/whatsapp/markdownToWhatsAppText.spec.js.map +1 -0
- package/dist/plugins/whatsapp/plugin.d.ts +6 -0
- package/dist/plugins/whatsapp/plugin.d.ts.map +1 -0
- package/dist/plugins/whatsapp/plugin.js +90 -0
- package/dist/plugins/whatsapp/plugin.js.map +1 -0
- package/dist/prompts/ACTORS.md +25 -0
- package/dist/prompts/AGENTIC.md +46 -0
- package/dist/prompts/ARCHITECT.md +36 -0
- package/dist/prompts/COMPACTION.md +20 -0
- package/dist/prompts/HEARTBEAT.md +12 -0
- package/dist/prompts/MEMORY.md +23 -0
- package/dist/prompts/PERMISSIONS.md +56 -0
- package/dist/prompts/SOUL.md +40 -0
- package/dist/prompts/SYSTEM.md +246 -0
- package/dist/prompts/TOOLS.md +13 -0
- package/dist/prompts/USER.md +12 -0
- package/dist/providers/__tests__/inference.integration.spec.d.ts +2 -0
- package/dist/providers/__tests__/inference.integration.spec.d.ts.map +1 -0
- package/dist/providers/__tests__/inference.integration.spec.js +203 -0
- package/dist/providers/__tests__/inference.integration.spec.js.map +1 -0
- package/dist/providers/__tests__/models.spec.d.ts +2 -0
- package/dist/providers/__tests__/models.spec.d.ts.map +1 -0
- package/dist/providers/__tests__/models.spec.js +19 -0
- package/dist/providers/__tests__/models.spec.js.map +1 -0
- package/dist/providers/catalog.d.ts +6 -0
- package/dist/providers/catalog.d.ts.map +1 -0
- package/dist/providers/catalog.js +128 -0
- package/dist/providers/catalog.js.map +1 -0
- package/dist/providers/manager.d.ts +33 -0
- package/dist/providers/manager.d.ts.map +1 -0
- package/dist/providers/manager.js +104 -0
- package/dist/providers/manager.js.map +1 -0
- package/dist/providers/manager.spec.d.ts +2 -0
- package/dist/providers/manager.spec.d.ts.map +1 -0
- package/dist/providers/manager.spec.js +149 -0
- package/dist/providers/manager.spec.js.map +1 -0
- package/dist/providers/models.d.ts +2926 -0
- package/dist/providers/models.d.ts.map +1 -0
- package/dist/providers/models.js +742 -0
- package/dist/providers/models.js.map +1 -0
- package/dist/providers/openai-compatible.d.ts +3 -0
- package/dist/providers/openai-compatible.d.ts.map +1 -0
- package/dist/providers/openai-compatible.js +111 -0
- package/dist/providers/openai-compatible.js.map +1 -0
- package/dist/providers/openai-image.d.ts +4 -0
- package/dist/providers/openai-image.d.ts.map +1 -0
- package/dist/providers/openai-image.js +64 -0
- package/dist/providers/openai-image.js.map +1 -0
- package/dist/providers/pi-ai.d.ts +13 -0
- package/dist/providers/pi-ai.d.ts.map +1 -0
- package/dist/providers/pi-ai.js +219 -0
- package/dist/providers/pi-ai.js.map +1 -0
- package/dist/providers/providerModelSelectBySize.d.ts +7 -0
- package/dist/providers/providerModelSelectBySize.d.ts.map +1 -0
- package/dist/providers/providerModelSelectBySize.js +27 -0
- package/dist/providers/providerModelSelectBySize.js.map +1 -0
- package/dist/providers/types.d.ts +72 -0
- package/dist/providers/types.d.ts.map +1 -0
- package/dist/providers/types.js +2 -0
- package/dist/providers/types.js.map +1 -0
- package/dist/recipe/_recipes.d.ts +13 -0
- package/dist/recipe/_recipes.d.ts.map +1 -0
- package/dist/recipe/_recipes.js +21 -0
- package/dist/recipe/_recipes.js.map +1 -0
- package/dist/recipe/recipePyrepl.d.ts +6 -0
- package/dist/recipe/recipePyrepl.d.ts.map +1 -0
- package/dist/recipe/recipePyrepl.js +208 -0
- package/dist/recipe/recipePyrepl.js.map +1 -0
- package/dist/recipe/recipeRlm.d.ts +6 -0
- package/dist/recipe/recipeRlm.d.ts.map +1 -0
- package/dist/recipe/recipeRlm.js +51 -0
- package/dist/recipe/recipeRlm.js.map +1 -0
- package/dist/recipe/recipeRun.d.ts +6 -0
- package/dist/recipe/recipeRun.d.ts.map +1 -0
- package/dist/recipe/recipeRun.js +31 -0
- package/dist/recipe/recipeRun.js.map +1 -0
- package/dist/recipe/utils/recipeAnthropicApiKeyResolve.d.ts +6 -0
- package/dist/recipe/utils/recipeAnthropicApiKeyResolve.d.ts.map +1 -0
- package/dist/recipe/utils/recipeAnthropicApiKeyResolve.js +25 -0
- package/dist/recipe/utils/recipeAnthropicApiKeyResolve.js.map +1 -0
- package/dist/recipe/utils/recipeAnthropicModelResolve.d.ts +7 -0
- package/dist/recipe/utils/recipeAnthropicModelResolve.d.ts.map +1 -0
- package/dist/recipe/utils/recipeAnthropicModelResolve.js +13 -0
- package/dist/recipe/utils/recipeAnthropicModelResolve.js.map +1 -0
- package/dist/recipe/utils/recipeAnthropicReplyGet.d.ts +17 -0
- package/dist/recipe/utils/recipeAnthropicReplyGet.d.ts.map +1 -0
- package/dist/recipe/utils/recipeAnthropicReplyGet.js +25 -0
- package/dist/recipe/utils/recipeAnthropicReplyGet.js.map +1 -0
- package/dist/recipe/utils/recipeAssistantTextExtract.d.ts +7 -0
- package/dist/recipe/utils/recipeAssistantTextExtract.d.ts.map +1 -0
- package/dist/recipe/utils/recipeAssistantTextExtract.js +14 -0
- package/dist/recipe/utils/recipeAssistantTextExtract.js.map +1 -0
- package/dist/recipe/utils/recipeAuthAnthropicEntryParse.d.ts +7 -0
- package/dist/recipe/utils/recipeAuthAnthropicEntryParse.d.ts.map +1 -0
- package/dist/recipe/utils/recipeAuthAnthropicEntryParse.js +16 -0
- package/dist/recipe/utils/recipeAuthAnthropicEntryParse.js.map +1 -0
- package/dist/recipe/utils/recipeAuthAnthropicEntryParse.spec.d.ts +2 -0
- package/dist/recipe/utils/recipeAuthAnthropicEntryParse.spec.d.ts.map +1 -0
- package/dist/recipe/utils/recipeAuthAnthropicEntryParse.spec.js +19 -0
- package/dist/recipe/utils/recipeAuthAnthropicEntryParse.spec.js.map +1 -0
- package/dist/recipe/utils/recipeAuthConfigRead.d.ts +6 -0
- package/dist/recipe/utils/recipeAuthConfigRead.d.ts.map +1 -0
- package/dist/recipe/utils/recipeAuthConfigRead.js +22 -0
- package/dist/recipe/utils/recipeAuthConfigRead.js.map +1 -0
- package/dist/recipe/utils/recipeAuthPathResolve.d.ts +6 -0
- package/dist/recipe/utils/recipeAuthPathResolve.d.ts.map +1 -0
- package/dist/recipe/utils/recipeAuthPathResolve.js +10 -0
- package/dist/recipe/utils/recipeAuthPathResolve.js.map +1 -0
- package/dist/recipe/utils/recipePythonReplCreate.d.ts +18 -0
- package/dist/recipe/utils/recipePythonReplCreate.d.ts.map +1 -0
- package/dist/recipe/utils/recipePythonReplCreate.js +265 -0
- package/dist/recipe/utils/recipePythonReplCreate.js.map +1 -0
- package/dist/recipe/utils/recipePythonSandboxPathResolve.d.ts +6 -0
- package/dist/recipe/utils/recipePythonSandboxPathResolve.d.ts.map +1 -0
- package/dist/recipe/utils/recipePythonSandboxPathResolve.js +9 -0
- package/dist/recipe/utils/recipePythonSandboxPathResolve.js.map +1 -0
- package/dist/recipe/utils/recipePythonSystemPromptBuild.d.ts +6 -0
- package/dist/recipe/utils/recipePythonSystemPromptBuild.d.ts.map +1 -0
- package/dist/recipe/utils/recipePythonSystemPromptBuild.js +23 -0
- package/dist/recipe/utils/recipePythonSystemPromptBuild.js.map +1 -0
- package/dist/sandbox/runtime.d.ts +16 -0
- package/dist/sandbox/runtime.d.ts.map +1 -0
- package/dist/sandbox/runtime.js +51 -0
- package/dist/sandbox/runtime.js.map +1 -0
- package/dist/sandbox/runtime.spec.d.ts +2 -0
- package/dist/sandbox/runtime.spec.d.ts.map +1 -0
- package/dist/sandbox/runtime.spec.js +84 -0
- package/dist/sandbox/runtime.spec.js.map +1 -0
- package/dist/sandbox/sandboxAllowedDomainsResolve.d.ts +7 -0
- package/dist/sandbox/sandboxAllowedDomainsResolve.d.ts.map +1 -0
- package/dist/sandbox/sandboxAllowedDomainsResolve.js +31 -0
- package/dist/sandbox/sandboxAllowedDomainsResolve.js.map +1 -0
- package/dist/sandbox/sandboxAllowedDomainsResolve.spec.d.ts +2 -0
- package/dist/sandbox/sandboxAllowedDomainsResolve.spec.d.ts.map +1 -0
- package/dist/sandbox/sandboxAllowedDomainsResolve.spec.js +42 -0
- package/dist/sandbox/sandboxAllowedDomainsResolve.spec.js.map +1 -0
- package/dist/sandbox/sandboxAllowedDomainsValidate.d.ts +6 -0
- package/dist/sandbox/sandboxAllowedDomainsValidate.d.ts.map +1 -0
- package/dist/sandbox/sandboxAllowedDomainsValidate.js +15 -0
- package/dist/sandbox/sandboxAllowedDomainsValidate.js.map +1 -0
- package/dist/sandbox/sandboxAllowedDomainsValidate.spec.d.ts +2 -0
- package/dist/sandbox/sandboxAllowedDomainsValidate.spec.d.ts.map +1 -0
- package/dist/sandbox/sandboxAllowedDomainsValidate.spec.js +16 -0
- package/dist/sandbox/sandboxAllowedDomainsValidate.spec.js.map +1 -0
- package/dist/sandbox/sandboxCanRead.d.ts +7 -0
- package/dist/sandbox/sandboxCanRead.d.ts.map +1 -0
- package/dist/sandbox/sandboxCanRead.js +13 -0
- package/dist/sandbox/sandboxCanRead.js.map +1 -0
- package/dist/sandbox/sandboxCanRead.spec.d.ts +2 -0
- package/dist/sandbox/sandboxCanRead.spec.d.ts.map +1 -0
- package/dist/sandbox/sandboxCanRead.spec.js +44 -0
- package/dist/sandbox/sandboxCanRead.spec.js.map +1 -0
- package/dist/sandbox/sandboxCanWrite.d.ts +7 -0
- package/dist/sandbox/sandboxCanWrite.d.ts.map +1 -0
- package/dist/sandbox/sandboxCanWrite.js +11 -0
- package/dist/sandbox/sandboxCanWrite.js.map +1 -0
- package/dist/sandbox/sandboxCanWrite.spec.d.ts +2 -0
- package/dist/sandbox/sandboxCanWrite.spec.d.ts.map +1 -0
- package/dist/sandbox/sandboxCanWrite.spec.js +52 -0
- package/dist/sandbox/sandboxCanWrite.spec.js.map +1 -0
- package/dist/sandbox/sandboxFilesystemPolicyBuild.d.ts +18 -0
- package/dist/sandbox/sandboxFilesystemPolicyBuild.d.ts.map +1 -0
- package/dist/sandbox/sandboxFilesystemPolicyBuild.js +79 -0
- package/dist/sandbox/sandboxFilesystemPolicyBuild.js.map +1 -0
- package/dist/sandbox/sandboxFilesystemPolicyBuild.spec.d.ts +2 -0
- package/dist/sandbox/sandboxFilesystemPolicyBuild.spec.d.ts.map +1 -0
- package/dist/sandbox/sandboxFilesystemPolicyBuild.spec.js +52 -0
- package/dist/sandbox/sandboxFilesystemPolicyBuild.spec.js.map +1 -0
- package/dist/sandbox/sandboxHomeRedefine.d.ts +15 -0
- package/dist/sandbox/sandboxHomeRedefine.d.ts.map +1 -0
- package/dist/sandbox/sandboxHomeRedefine.js +61 -0
- package/dist/sandbox/sandboxHomeRedefine.js.map +1 -0
- package/dist/sandbox/sandboxHomeRedefine.spec.d.ts +2 -0
- package/dist/sandbox/sandboxHomeRedefine.spec.d.ts.map +1 -0
- package/dist/sandbox/sandboxHomeRedefine.spec.js +41 -0
- package/dist/sandbox/sandboxHomeRedefine.spec.js.map +1 -0
- package/dist/sandbox/sandboxPackageManagers.d.ts +4 -0
- package/dist/sandbox/sandboxPackageManagers.d.ts.map +1 -0
- package/dist/sandbox/sandboxPackageManagers.js +39 -0
- package/dist/sandbox/sandboxPackageManagers.js.map +1 -0
- package/dist/settings.d.ts +75 -0
- package/dist/settings.d.ts.map +1 -0
- package/dist/settings.js +91 -0
- package/dist/settings.js.map +1 -0
- package/dist/skills/permanent-agent-creator/SKILL.md +73 -0
- package/dist/skills/scheduling/SKILL.md +131 -0
- package/dist/skills/skill-creator/SKILL.md +372 -0
- package/dist/skills/skill-creator/references/output-patterns.md +82 -0
- package/dist/skills/skill-creator/references/workflows.md +28 -0
- package/dist/skills/skill-creator/scripts/init_skill.py +303 -0
- package/dist/skills/skill-creator/scripts/package_skill.py +110 -0
- package/dist/skills/skill-creator/scripts/quick_validate.py +95 -0
- package/dist/skills/skills/permanent-agent-creator/SKILL.md +73 -0
- package/dist/skills/skills/scheduling/SKILL.md +131 -0
- package/dist/skills/skills/skill-creator/SKILL.md +372 -0
- package/dist/skills/skills/skill-creator/references/output-patterns.md +82 -0
- package/dist/skills/skills/skill-creator/references/workflows.md +28 -0
- package/dist/skills/skills/skill-creator/scripts/init_skill.py +303 -0
- package/dist/skills/skills/skill-creator/scripts/package_skill.py +110 -0
- package/dist/skills/skills/skill-creator/scripts/quick_validate.py +95 -0
- package/dist/types.d.ts +14 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +4 -0
- package/dist/types.js.map +1 -0
- package/dist/util/atomicWrite.d.ts +6 -0
- package/dist/util/atomicWrite.d.ts.map +1 -0
- package/dist/util/atomicWrite.js +11 -0
- package/dist/util/atomicWrite.js.map +1 -0
- package/dist/util/debounce.d.ts +13 -0
- package/dist/util/debounce.d.ts.map +1 -0
- package/dist/util/debounce.js +81 -0
- package/dist/util/debounce.js.map +1 -0
- package/dist/util/envNormalize.d.ts +7 -0
- package/dist/util/envNormalize.d.ts.map +1 -0
- package/dist/util/envNormalize.js +29 -0
- package/dist/util/envNormalize.js.map +1 -0
- package/dist/util/envNormalize.spec.d.ts +2 -0
- package/dist/util/envNormalize.spec.d.ts.map +1 -0
- package/dist/util/envNormalize.spec.js +26 -0
- package/dist/util/envNormalize.spec.js.map +1 -0
- package/dist/util/filename.d.ts +2 -0
- package/dist/util/filename.d.ts.map +1 -0
- package/dist/util/filename.js +7 -0
- package/dist/util/filename.js.map +1 -0
- package/dist/util/freezeDeep.d.ts +6 -0
- package/dist/util/freezeDeep.d.ts.map +1 -0
- package/dist/util/freezeDeep.js +18 -0
- package/dist/util/freezeDeep.js.map +1 -0
- package/dist/util/isoDate.d.ts +39 -0
- package/dist/util/isoDate.d.ts.map +1 -0
- package/dist/util/isoDate.js +124 -0
- package/dist/util/isoDate.js.map +1 -0
- package/dist/util/isoDate.spec.d.ts +2 -0
- package/dist/util/isoDate.spec.d.ts.map +1 -0
- package/dist/util/isoDate.spec.js +125 -0
- package/dist/util/isoDate.spec.js.map +1 -0
- package/dist/util/lock.d.ts +8 -0
- package/dist/util/lock.d.ts.map +1 -0
- package/dist/util/lock.js +36 -0
- package/dist/util/lock.js.map +1 -0
- package/dist/util/markdownParse.d.ts +34 -0
- package/dist/util/markdownParse.d.ts.map +1 -0
- package/dist/util/markdownParse.js +85 -0
- package/dist/util/markdownParse.js.map +1 -0
- package/dist/util/markdownParse.spec.d.ts +2 -0
- package/dist/util/markdownParse.spec.d.ts.map +1 -0
- package/dist/util/markdownParse.spec.js +76 -0
- package/dist/util/markdownParse.spec.js.map +1 -0
- package/dist/util/readWriteLock.d.ts +17 -0
- package/dist/util/readWriteLock.d.ts.map +1 -0
- package/dist/util/readWriteLock.js +82 -0
- package/dist/util/readWriteLock.js.map +1 -0
- package/dist/util/readWriteLock.spec.d.ts +2 -0
- package/dist/util/readWriteLock.spec.d.ts.map +1 -0
- package/dist/util/readWriteLock.spec.js +99 -0
- package/dist/util/readWriteLock.spec.js.map +1 -0
- package/dist/util/renderToPng.d.ts +10 -0
- package/dist/util/renderToPng.d.ts.map +1 -0
- package/dist/util/renderToPng.js +50 -0
- package/dist/util/renderToPng.js.map +1 -0
- package/dist/util/renderToPng.spec.d.ts +2 -0
- package/dist/util/renderToPng.spec.d.ts.map +1 -0
- package/dist/util/renderToPng.spec.js +61 -0
- package/dist/util/renderToPng.spec.js.map +1 -0
- package/dist/util/shutdown.d.ts +13 -0
- package/dist/util/shutdown.d.ts.map +1 -0
- package/dist/util/shutdown.js +116 -0
- package/dist/util/shutdown.js.map +1 -0
- package/dist/util/stringUtils.d.ts +3 -0
- package/dist/util/stringUtils.d.ts.map +1 -0
- package/dist/util/stringUtils.js +28 -0
- package/dist/util/stringUtils.js.map +1 -0
- package/dist/util/sync.d.ts +30 -0
- package/dist/util/sync.d.ts.map +1 -0
- package/dist/util/sync.js +145 -0
- package/dist/util/sync.js.map +1 -0
- package/dist/util/time.d.ts +11 -0
- package/dist/util/time.d.ts.map +1 -0
- package/dist/util/time.js +36 -0
- package/dist/util/time.js.map +1 -0
- package/dist/util/timeFormat.d.ts +18 -0
- package/dist/util/timeFormat.d.ts.map +1 -0
- package/dist/util/timeFormat.js +153 -0
- package/dist/util/timeFormat.js.map +1 -0
- package/dist/util/timeFormat.spec.d.ts +2 -0
- package/dist/util/timeFormat.spec.d.ts.map +1 -0
- package/dist/util/timeFormat.spec.js +82 -0
- package/dist/util/timeFormat.spec.js.map +1 -0
- package/dist/util/trimIdent.d.ts +2 -0
- package/dist/util/trimIdent.d.ts.map +1 -0
- package/dist/util/trimIdent.js +19 -0
- package/dist/util/trimIdent.js.map +1 -0
- package/dist/util/valueDeepEqual.d.ts +6 -0
- package/dist/util/valueDeepEqual.d.ts.map +1 -0
- package/dist/util/valueDeepEqual.js +51 -0
- package/dist/util/valueDeepEqual.js.map +1 -0
- package/dist/util/valueDeepEqual.spec.d.ts +2 -0
- package/dist/util/valueDeepEqual.spec.d.ts.map +1 -0
- package/dist/util/valueDeepEqual.spec.js +27 -0
- package/dist/util/valueDeepEqual.spec.js.map +1 -0
- package/dist/util/xmlEscape.d.ts +6 -0
- package/dist/util/xmlEscape.d.ts.map +1 -0
- package/dist/util/xmlEscape.js +13 -0
- package/dist/util/xmlEscape.js.map +1 -0
- package/dist/util/xmlEscape.spec.d.ts +2 -0
- package/dist/util/xmlEscape.spec.d.ts.map +1 -0
- package/dist/util/xmlEscape.spec.js +9 -0
- package/dist/util/xmlEscape.spec.js.map +1 -0
- package/dist/utils/cuid2Is.d.ts +2 -0
- package/dist/utils/cuid2Is.d.ts.map +1 -0
- package/dist/utils/cuid2Is.js +4 -0
- package/dist/utils/cuid2Is.js.map +1 -0
- package/dist/utils/cuid2Is.spec.d.ts +2 -0
- package/dist/utils/cuid2Is.spec.d.ts.map +1 -0
- package/dist/utils/cuid2Is.spec.js +15 -0
- package/dist/utils/cuid2Is.spec.js.map +1 -0
- package/dist/utils/stringSlugify.d.ts +9 -0
- package/dist/utils/stringSlugify.d.ts.map +1 -0
- package/dist/utils/stringSlugify.js +15 -0
- package/dist/utils/stringSlugify.js.map +1 -0
- package/dist/utils/stringSlugify.spec.d.ts +2 -0
- package/dist/utils/stringSlugify.spec.d.ts.map +1 -0
- package/dist/utils/stringSlugify.spec.js +24 -0
- package/dist/utils/stringSlugify.spec.js.map +1 -0
- package/dist/utils/stringTruncate.d.ts +2 -0
- package/dist/utils/stringTruncate.d.ts.map +1 -0
- package/dist/utils/stringTruncate.js +7 -0
- package/dist/utils/stringTruncate.js.map +1 -0
- package/dist/utils/stringTruncate.spec.d.ts +2 -0
- package/dist/utils/stringTruncate.spec.d.ts.map +1 -0
- package/dist/utils/stringTruncate.spec.js +12 -0
- package/dist/utils/stringTruncate.spec.js.map +1 -0
- package/dist/utils/taskIdIsSafe.d.ts +8 -0
- package/dist/utils/taskIdIsSafe.d.ts.map +1 -0
- package/dist/utils/taskIdIsSafe.js +10 -0
- package/dist/utils/taskIdIsSafe.js.map +1 -0
- package/dist/utils/taskIdIsSafe.spec.d.ts +2 -0
- package/dist/utils/taskIdIsSafe.spec.d.ts.map +1 -0
- package/dist/utils/taskIdIsSafe.spec.js +28 -0
- package/dist/utils/taskIdIsSafe.spec.js.map +1 -0
- package/package.json +78 -0
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
import { promises as fs } from "node:fs";
|
|
2
|
+
import path from "node:path";
|
|
3
|
+
import { pathSanitize } from "./pathSanitize.js";
|
|
4
|
+
/**
|
|
5
|
+
* Securely resolves a path, following symlinks and verifying containment.
|
|
6
|
+
*
|
|
7
|
+
* Addresses symlink following attacks by:
|
|
8
|
+
* 1. Resolving all symlinks using fs.realpath()
|
|
9
|
+
* 2. Checking containment against the real paths
|
|
10
|
+
*
|
|
11
|
+
* @param allowedDirs - Directories the path is allowed to be within
|
|
12
|
+
* @param target - The target path to resolve
|
|
13
|
+
* @returns The resolved real path and the base directory it's within
|
|
14
|
+
* @throws Error if path is outside allowed directories or doesn't exist
|
|
15
|
+
*/
|
|
16
|
+
export async function pathResolveSecure(allowedDirs, target) {
|
|
17
|
+
pathSanitize(target);
|
|
18
|
+
if (!path.isAbsolute(target)) {
|
|
19
|
+
throw new Error("Path must be absolute.");
|
|
20
|
+
}
|
|
21
|
+
// Resolve the target path following all symlinks
|
|
22
|
+
let realPath;
|
|
23
|
+
try {
|
|
24
|
+
realPath = await fs.realpath(target);
|
|
25
|
+
}
|
|
26
|
+
catch {
|
|
27
|
+
realPath = await resolveMissingPath(target);
|
|
28
|
+
}
|
|
29
|
+
// Check containment against each allowed directory (also resolve their real paths)
|
|
30
|
+
for (const dir of allowedDirs) {
|
|
31
|
+
let realDir;
|
|
32
|
+
try {
|
|
33
|
+
realDir = await fs.realpath(dir);
|
|
34
|
+
}
|
|
35
|
+
catch {
|
|
36
|
+
// If the allowed dir doesn't exist, use logical resolution
|
|
37
|
+
realDir = path.resolve(dir);
|
|
38
|
+
}
|
|
39
|
+
if (isWithinSecure(realDir, realPath)) {
|
|
40
|
+
return { realPath, allowedBase: realDir };
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
throw new Error("Path is outside the allowed directories.");
|
|
44
|
+
}
|
|
45
|
+
async function resolveMissingPath(target) {
|
|
46
|
+
const missing = [path.basename(target)];
|
|
47
|
+
let parent = path.dirname(target);
|
|
48
|
+
while (true) {
|
|
49
|
+
try {
|
|
50
|
+
const realParent = await fs.realpath(parent);
|
|
51
|
+
return path.join(realParent, ...missing);
|
|
52
|
+
}
|
|
53
|
+
catch {
|
|
54
|
+
const next = path.dirname(parent);
|
|
55
|
+
if (next === parent) {
|
|
56
|
+
return path.resolve(target);
|
|
57
|
+
}
|
|
58
|
+
missing.unshift(path.basename(parent));
|
|
59
|
+
parent = next;
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* Synchronous version that checks if a path would be within allowed dirs.
|
|
65
|
+
* Does NOT resolve symlinks - use only when you've already resolved.
|
|
66
|
+
*/
|
|
67
|
+
export function isWithinSecure(base, target) {
|
|
68
|
+
const relative = path.relative(base, target);
|
|
69
|
+
return relative === "" || (!relative.startsWith("..") && !path.isAbsolute(relative));
|
|
70
|
+
}
|
|
71
|
+
/**
|
|
72
|
+
* Opens a file handle securely with O_NOFOLLOW semantics.
|
|
73
|
+
* This prevents TOCTOU attacks by atomically opening without following symlinks.
|
|
74
|
+
*
|
|
75
|
+
* @param filePath - Path to open
|
|
76
|
+
* @param flags - File system flags (e.g., "r", "w", "a")
|
|
77
|
+
* @returns File handle
|
|
78
|
+
*/
|
|
79
|
+
export async function openSecure(filePath, flags) {
|
|
80
|
+
pathSanitize(filePath);
|
|
81
|
+
// Check if target is a symlink before opening
|
|
82
|
+
try {
|
|
83
|
+
const stats = await fs.lstat(filePath);
|
|
84
|
+
if (stats.isSymbolicLink()) {
|
|
85
|
+
throw new Error("Cannot open symbolic link directly.");
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
catch (error) {
|
|
89
|
+
// File doesn't exist - OK for write/create operations
|
|
90
|
+
if (error.code !== "ENOENT") {
|
|
91
|
+
throw error;
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
return fs.open(filePath, flags);
|
|
95
|
+
}
|
|
96
|
+
//# sourceMappingURL=pathResolveSecure.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pathResolveSecure.js","sourceRoot":"","sources":["../../../sources/engine/permissions/pathResolveSecure.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pathResolveSecure.spec.d.ts","sourceRoot":"","sources":["../../../sources/engine/permissions/pathResolveSecure.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
import { describe, it, expect, beforeEach, afterEach } from "vitest";
|
|
2
|
+
import { promises as fs } from "node:fs";
|
|
3
|
+
import path from "node:path";
|
|
4
|
+
import os from "node:os";
|
|
5
|
+
import { pathResolveSecure, isWithinSecure, openSecure } from "./pathResolveSecure.js";
|
|
6
|
+
describe("pathResolveSecure", () => {
|
|
7
|
+
let tempDir;
|
|
8
|
+
let realTempDir;
|
|
9
|
+
beforeEach(async () => {
|
|
10
|
+
tempDir = await fs.mkdtemp(path.join(os.tmpdir(), "path-resolve-test-"));
|
|
11
|
+
// On macOS, /var is a symlink to /private/var, so we need the real path
|
|
12
|
+
realTempDir = await fs.realpath(tempDir);
|
|
13
|
+
await fs.mkdir(path.join(tempDir, "allowed"));
|
|
14
|
+
await fs.mkdir(path.join(tempDir, "forbidden"));
|
|
15
|
+
await fs.writeFile(path.join(tempDir, "allowed", "file.txt"), "content");
|
|
16
|
+
await fs.writeFile(path.join(tempDir, "forbidden", "secret.txt"), "secret");
|
|
17
|
+
});
|
|
18
|
+
afterEach(async () => {
|
|
19
|
+
await fs.rm(tempDir, { recursive: true, force: true });
|
|
20
|
+
});
|
|
21
|
+
it("resolves paths within allowed directories", async () => {
|
|
22
|
+
const allowedDirs = [path.join(tempDir, "allowed")];
|
|
23
|
+
const result = await pathResolveSecure(allowedDirs, path.join(tempDir, "allowed", "file.txt"));
|
|
24
|
+
// fs.realpath resolves symlinks, so we compare against realTempDir
|
|
25
|
+
expect(result.realPath).toBe(path.join(realTempDir, "allowed", "file.txt"));
|
|
26
|
+
expect(result.allowedBase).toBe(path.join(realTempDir, "allowed"));
|
|
27
|
+
});
|
|
28
|
+
it("rejects paths outside allowed directories", async () => {
|
|
29
|
+
const allowedDirs = [path.join(tempDir, "allowed")];
|
|
30
|
+
await expect(pathResolveSecure(allowedDirs, path.join(tempDir, "forbidden", "secret.txt"))).rejects.toThrow("Path is outside the allowed directories.");
|
|
31
|
+
});
|
|
32
|
+
it("prevents symlink escape attack", async () => {
|
|
33
|
+
// Create symlink inside allowed dir pointing outside
|
|
34
|
+
const symlinkPath = path.join(tempDir, "allowed", "escape");
|
|
35
|
+
await fs.symlink(path.join(tempDir, "forbidden"), symlinkPath);
|
|
36
|
+
const allowedDirs = [path.join(tempDir, "allowed")];
|
|
37
|
+
// Attempting to access forbidden/secret.txt via symlink should fail
|
|
38
|
+
await expect(pathResolveSecure(allowedDirs, path.join(symlinkPath, "secret.txt"))).rejects.toThrow("Path is outside the allowed directories.");
|
|
39
|
+
});
|
|
40
|
+
it("allows symlinks that resolve within allowed dirs", async () => {
|
|
41
|
+
// Create symlink within allowed dir pointing to another file in allowed
|
|
42
|
+
await fs.mkdir(path.join(tempDir, "allowed", "subdir"));
|
|
43
|
+
await fs.writeFile(path.join(tempDir, "allowed", "subdir", "data.txt"), "data");
|
|
44
|
+
const symlinkPath = path.join(tempDir, "allowed", "link");
|
|
45
|
+
await fs.symlink(path.join(tempDir, "allowed", "subdir"), symlinkPath);
|
|
46
|
+
const allowedDirs = [path.join(tempDir, "allowed")];
|
|
47
|
+
const result = await pathResolveSecure(allowedDirs, path.join(symlinkPath, "data.txt"));
|
|
48
|
+
expect(result.realPath).toBe(path.join(realTempDir, "allowed", "subdir", "data.txt"));
|
|
49
|
+
});
|
|
50
|
+
it("handles non-existent files for write operations", async () => {
|
|
51
|
+
const allowedDirs = [path.join(tempDir, "allowed")];
|
|
52
|
+
const result = await pathResolveSecure(allowedDirs, path.join(tempDir, "allowed", "newfile.txt"));
|
|
53
|
+
expect(result.realPath).toBe(path.join(realTempDir, "allowed", "newfile.txt"));
|
|
54
|
+
});
|
|
55
|
+
it("handles nested non-existent files for write operations", async () => {
|
|
56
|
+
const allowedDirs = [path.join(tempDir, "allowed")];
|
|
57
|
+
const result = await pathResolveSecure(allowedDirs, path.join(tempDir, "allowed", "nested", "deep", "newfile.txt"));
|
|
58
|
+
expect(result.realPath).toBe(path.join(realTempDir, "allowed", "nested", "deep", "newfile.txt"));
|
|
59
|
+
});
|
|
60
|
+
it("rejects paths with null bytes", async () => {
|
|
61
|
+
const allowedDirs = [path.join(tempDir, "allowed")];
|
|
62
|
+
await expect(pathResolveSecure(allowedDirs, path.join(tempDir, "allowed\x00forbidden"))).rejects.toThrow("Path contains null byte.");
|
|
63
|
+
});
|
|
64
|
+
it("rejects relative paths", async () => {
|
|
65
|
+
const allowedDirs = [path.join(tempDir, "allowed")];
|
|
66
|
+
await expect(pathResolveSecure(allowedDirs, "relative/path")).rejects.toThrow("Path must be absolute.");
|
|
67
|
+
});
|
|
68
|
+
});
|
|
69
|
+
describe("isWithinSecure", () => {
|
|
70
|
+
it("returns true for paths within base", () => {
|
|
71
|
+
expect(isWithinSecure("/home/user", "/home/user/file.txt")).toBe(true);
|
|
72
|
+
expect(isWithinSecure("/home/user", "/home/user/sub/file.txt")).toBe(true);
|
|
73
|
+
expect(isWithinSecure("/home/user", "/home/user")).toBe(true);
|
|
74
|
+
});
|
|
75
|
+
it("returns false for paths outside base", () => {
|
|
76
|
+
expect(isWithinSecure("/home/user", "/home/other/file.txt")).toBe(false);
|
|
77
|
+
expect(isWithinSecure("/home/user", "/etc/passwd")).toBe(false);
|
|
78
|
+
expect(isWithinSecure("/home/user", "/home/user/../other")).toBe(false);
|
|
79
|
+
});
|
|
80
|
+
});
|
|
81
|
+
describe("openSecure", () => {
|
|
82
|
+
let tempDir;
|
|
83
|
+
beforeEach(async () => {
|
|
84
|
+
tempDir = await fs.mkdtemp(path.join(os.tmpdir(), "open-secure-test-"));
|
|
85
|
+
await fs.writeFile(path.join(tempDir, "regular.txt"), "content");
|
|
86
|
+
await fs.mkdir(path.join(tempDir, "target"));
|
|
87
|
+
await fs.writeFile(path.join(tempDir, "target", "secret.txt"), "secret");
|
|
88
|
+
});
|
|
89
|
+
afterEach(async () => {
|
|
90
|
+
await fs.rm(tempDir, { recursive: true, force: true });
|
|
91
|
+
});
|
|
92
|
+
it("opens regular files", async () => {
|
|
93
|
+
const handle = await openSecure(path.join(tempDir, "regular.txt"), "r");
|
|
94
|
+
const content = await handle.readFile("utf8");
|
|
95
|
+
await handle.close();
|
|
96
|
+
expect(content).toBe("content");
|
|
97
|
+
});
|
|
98
|
+
it("rejects symlinks", async () => {
|
|
99
|
+
const symlinkPath = path.join(tempDir, "link.txt");
|
|
100
|
+
await fs.symlink(path.join(tempDir, "regular.txt"), symlinkPath);
|
|
101
|
+
await expect(openSecure(symlinkPath, "r")).rejects.toThrow("Cannot open symbolic link directly.");
|
|
102
|
+
});
|
|
103
|
+
it("allows creating new files", async () => {
|
|
104
|
+
const newPath = path.join(tempDir, "new.txt");
|
|
105
|
+
const handle = await openSecure(newPath, "w");
|
|
106
|
+
await handle.writeFile("new content");
|
|
107
|
+
await handle.close();
|
|
108
|
+
const content = await fs.readFile(newPath, "utf8");
|
|
109
|
+
expect(content).toBe("new content");
|
|
110
|
+
});
|
|
111
|
+
it("rejects paths with null bytes", async () => {
|
|
112
|
+
await expect(openSecure(path.join(tempDir, "file\x00.txt"), "r")).rejects.toThrow("Path contains null byte.");
|
|
113
|
+
});
|
|
114
|
+
});
|
|
115
|
+
//# sourceMappingURL=pathResolveSecure.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pathResolveSecure.spec.js","sourceRoot":"","sources":["../../../sources/engine/permissions/pathResolveSecure.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Validates a path for dangerous characters and patterns.
|
|
3
|
+
* Throws an error if the path is invalid.
|
|
4
|
+
*
|
|
5
|
+
* Checks for:
|
|
6
|
+
* - Null bytes (can truncate strings in C libraries)
|
|
7
|
+
* - Control characters (ASCII 0-31 except tab/newline)
|
|
8
|
+
* - Excessively long paths (DoS potential)
|
|
9
|
+
*/
|
|
10
|
+
export declare function pathSanitize(target: string): void;
|
|
11
|
+
/**
|
|
12
|
+
* Sanitizes and resolves a path, ensuring it's absolute.
|
|
13
|
+
* Returns the resolved absolute path.
|
|
14
|
+
*/
|
|
15
|
+
export declare function pathSanitizeAndResolve(target: string): string;
|
|
16
|
+
//# sourceMappingURL=pathSanitize.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pathSanitize.d.ts","sourceRoot":"","sources":["../../../sources/engine/permissions/pathSanitize.ts"],"names":[],"mappings":"AAIA;;;;;;;;GAQG;AACH,wBAAgB,YAAY,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI,CAiBjD;AAED;;;GAGG;AACH,wBAAgB,sBAAsB,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAM7D"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import path from "node:path";
|
|
2
|
+
const MAX_PATH_LENGTH = 4096;
|
|
3
|
+
/**
|
|
4
|
+
* Validates a path for dangerous characters and patterns.
|
|
5
|
+
* Throws an error if the path is invalid.
|
|
6
|
+
*
|
|
7
|
+
* Checks for:
|
|
8
|
+
* - Null bytes (can truncate strings in C libraries)
|
|
9
|
+
* - Control characters (ASCII 0-31 except tab/newline)
|
|
10
|
+
* - Excessively long paths (DoS potential)
|
|
11
|
+
*/
|
|
12
|
+
export function pathSanitize(target) {
|
|
13
|
+
if (target.length > MAX_PATH_LENGTH) {
|
|
14
|
+
throw new Error(`Path exceeds maximum length of ${MAX_PATH_LENGTH} characters.`);
|
|
15
|
+
}
|
|
16
|
+
// Check for null bytes
|
|
17
|
+
if (target.includes("\x00")) {
|
|
18
|
+
throw new Error("Path contains null byte.");
|
|
19
|
+
}
|
|
20
|
+
// Check for control characters (ASCII 0-31, except 9=tab and 10=newline)
|
|
21
|
+
for (let i = 0; i < target.length; i++) {
|
|
22
|
+
const code = target.charCodeAt(i);
|
|
23
|
+
if (code < 32 && code !== 9 && code !== 10) {
|
|
24
|
+
throw new Error("Path contains invalid control character.");
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Sanitizes and resolves a path, ensuring it's absolute.
|
|
30
|
+
* Returns the resolved absolute path.
|
|
31
|
+
*/
|
|
32
|
+
export function pathSanitizeAndResolve(target) {
|
|
33
|
+
pathSanitize(target);
|
|
34
|
+
if (!path.isAbsolute(target)) {
|
|
35
|
+
throw new Error("Path must be absolute.");
|
|
36
|
+
}
|
|
37
|
+
return path.resolve(target);
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=pathSanitize.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pathSanitize.js","sourceRoot":"","sources":["../../../sources/engine/permissions/pathSanitize.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,WAAW,CAAC;AAE7B,MAAM,eAAe,GAAG,IAAI,CAAC;AAE7B;;;;;;;;GAQG;AACH,MAAM,UAAU,YAAY,CAAC,MAAc;IACzC,IAAI,MAAM,CAAC,MAAM,GAAG,eAAe,EAAE,CAAC;QACpC,MAAM,IAAI,KAAK,CAAC,kCAAkC,eAAe,cAAc,CAAC,CAAC;IACnF,CAAC;IAED,uBAAuB;IACvB,IAAI,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;QAC5B,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAC;IAC9C,CAAC;IAED,yEAAyE;IACzE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;QACvC,MAAM,IAAI,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;QAClC,IAAI,IAAI,GAAG,EAAE,IAAI,IAAI,KAAK,CAAC,IAAI,IAAI,KAAK,EAAE,EAAE,CAAC;YAC3C,MAAM,IAAI,KAAK,CAAC,0CAA0C,CAAC,CAAC;QAC9D,CAAC;IACH,CAAC;AACH,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,sBAAsB,CAAC,MAAc;IACnD,YAAY,CAAC,MAAM,CAAC,CAAC;IACrB,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC;QAC7B,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAC;IAC5C,CAAC;IACD,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;AAC9B,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pathSanitize.spec.d.ts","sourceRoot":"","sources":["../../../sources/engine/permissions/pathSanitize.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { describe, it, expect } from "vitest";
|
|
2
|
+
import { pathSanitize, pathSanitizeAndResolve } from "./pathSanitize.js";
|
|
3
|
+
describe("pathSanitize", () => {
|
|
4
|
+
it("accepts valid paths", () => {
|
|
5
|
+
expect(() => pathSanitize("/home/user/file.txt")).not.toThrow();
|
|
6
|
+
expect(() => pathSanitize("/path/with spaces/file.txt")).not.toThrow();
|
|
7
|
+
expect(() => pathSanitize("/unicode/日本語/文件.txt")).not.toThrow();
|
|
8
|
+
});
|
|
9
|
+
it("rejects paths with null bytes", () => {
|
|
10
|
+
expect(() => pathSanitize("/home/user\x00/malicious")).toThrow("Path contains null byte.");
|
|
11
|
+
expect(() => pathSanitize("/etc/passwd\x00.txt")).toThrow("Path contains null byte.");
|
|
12
|
+
});
|
|
13
|
+
it("rejects paths with control characters", () => {
|
|
14
|
+
expect(() => pathSanitize("/home/user\x01file")).toThrow("Path contains invalid control character.");
|
|
15
|
+
expect(() => pathSanitize("/home/user\x1Ffile")).toThrow("Path contains invalid control character.");
|
|
16
|
+
});
|
|
17
|
+
it("allows tabs and newlines", () => {
|
|
18
|
+
// Tabs and newlines are uncommon but not dangerous in the same way
|
|
19
|
+
expect(() => pathSanitize("/home/user\tfile")).not.toThrow();
|
|
20
|
+
expect(() => pathSanitize("/home/user\nfile")).not.toThrow();
|
|
21
|
+
});
|
|
22
|
+
it("rejects excessively long paths", () => {
|
|
23
|
+
const longPath = "/" + "a".repeat(5000);
|
|
24
|
+
expect(() => pathSanitize(longPath)).toThrow("Path exceeds maximum length of 4096 characters.");
|
|
25
|
+
});
|
|
26
|
+
it("accepts paths at the limit", () => {
|
|
27
|
+
const maxPath = "/" + "a".repeat(4095);
|
|
28
|
+
expect(() => pathSanitize(maxPath)).not.toThrow();
|
|
29
|
+
});
|
|
30
|
+
});
|
|
31
|
+
describe("pathSanitizeAndResolve", () => {
|
|
32
|
+
it("sanitizes and resolves valid absolute paths", () => {
|
|
33
|
+
const result = pathSanitizeAndResolve("/home/user/../user/file.txt");
|
|
34
|
+
expect(result).toBe("/home/user/file.txt");
|
|
35
|
+
});
|
|
36
|
+
it("rejects relative paths", () => {
|
|
37
|
+
expect(() => pathSanitizeAndResolve("relative/path")).toThrow("Path must be absolute.");
|
|
38
|
+
});
|
|
39
|
+
it("rejects paths with null bytes before checking absolute", () => {
|
|
40
|
+
expect(() => pathSanitizeAndResolve("/etc/passwd\x00")).toThrow("Path contains null byte.");
|
|
41
|
+
});
|
|
42
|
+
});
|
|
43
|
+
//# sourceMappingURL=pathSanitize.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pathSanitize.spec.js","sourceRoot":"","sources":["../../../sources/engine/permissions/pathSanitize.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,YAAY,EAAE,sBAAsB,EAAE,MAAM,mBAAmB,CAAC;AAEzE,QAAQ,CAAC,cAAc,EAAE,GAAG,EAAE;IAC5B,EAAE,CAAC,qBAAqB,EAAE,GAAG,EAAE;QAC7B,MAAM,CAAC,GAAG,EAAE,CAAC,YAAY,CAAC,qBAAqB,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;QAChE,MAAM,CAAC,GAAG,EAAE,CAAC,YAAY,CAAC,4BAA4B,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;QACvE,MAAM,CAAC,GAAG,EAAE,CAAC,YAAY,CAAC,qBAAqB,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;IAClE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+BAA+B,EAAE,GAAG,EAAE;QACvC,MAAM,CAAC,GAAG,EAAE,CAAC,YAAY,CAAC,0BAA0B,CAAC,CAAC,CAAC,OAAO,CAC5D,0BAA0B,CAC3B,CAAC;QACF,MAAM,CAAC,GAAG,EAAE,CAAC,YAAY,CAAC,qBAAqB,CAAC,CAAC,CAAC,OAAO,CACvD,0BAA0B,CAC3B,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,uCAAuC,EAAE,GAAG,EAAE;QAC/C,MAAM,CAAC,GAAG,EAAE,CAAC,YAAY,CAAC,oBAAoB,CAAC,CAAC,CAAC,OAAO,CACtD,0CAA0C,CAC3C,CAAC;QACF,MAAM,CAAC,GAAG,EAAE,CAAC,YAAY,CAAC,oBAAoB,CAAC,CAAC,CAAC,OAAO,CACtD,0CAA0C,CAC3C,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0BAA0B,EAAE,GAAG,EAAE;QAClC,mEAAmE;QACnE,MAAM,CAAC,GAAG,EAAE,CAAC,YAAY,CAAC,kBAAkB,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;QAC7D,MAAM,CAAC,GAAG,EAAE,CAAC,YAAY,CAAC,kBAAkB,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;IAC/D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE,GAAG,EAAE;QACxC,MAAM,QAAQ,GAAG,GAAG,GAAG,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACxC,MAAM,CAAC,GAAG,EAAE,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,CAC1C,iDAAiD,CAClD,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4BAA4B,EAAE,GAAG,EAAE;QACpC,MAAM,OAAO,GAAG,GAAG,GAAG,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACvC,MAAM,CAAC,GAAG,EAAE,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;IACpD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,wBAAwB,EAAE,GAAG,EAAE;IACtC,EAAE,CAAC,6CAA6C,EAAE,GAAG,EAAE;QACrD,MAAM,MAAM,GAAG,sBAAsB,CAAC,6BAA6B,CAAC,CAAC;QACrE,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wBAAwB,EAAE,GAAG,EAAE;QAChC,MAAM,CAAC,GAAG,EAAE,CAAC,sBAAsB,CAAC,eAAe,CAAC,CAAC,CAAC,OAAO,CAC3D,wBAAwB,CACzB,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wDAAwD,EAAE,GAAG,EAAE;QAChE,MAAM,CAAC,GAAG,EAAE,CAAC,sBAAsB,CAAC,iBAAiB,CAAC,CAAC,CAAC,OAAO,CAC7D,0BAA0B,CAC3B,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { PermissionAccess, SessionPermissions } from "@/types";
|
|
2
|
+
/**
|
|
3
|
+
* Checks whether a permission access is already allowed by current permissions.
|
|
4
|
+
* Expects: access.kind is network/read/write; paths must be absolute.
|
|
5
|
+
*/
|
|
6
|
+
export declare function permissionAccessAllows(permissions: SessionPermissions, access: PermissionAccess): Promise<boolean>;
|
|
7
|
+
//# sourceMappingURL=permissionAccessAllows.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"permissionAccessAllows.d.ts","sourceRoot":"","sources":["../../../sources/engine/permissions/permissionAccessAllows.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAIpE;;;GAGG;AACH,wBAAsB,sBAAsB,CAC1C,WAAW,EAAE,kBAAkB,EAC/B,MAAM,EAAE,gBAAgB,GACvB,OAAO,CAAC,OAAO,CAAC,CA4BlB"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import path from "node:path";
|
|
2
|
+
import { pathResolveSecure } from "./pathResolveSecure.js";
|
|
3
|
+
import { pathSanitizeAndResolve } from "./pathSanitize.js";
|
|
4
|
+
/**
|
|
5
|
+
* Checks whether a permission access is already allowed by current permissions.
|
|
6
|
+
* Expects: access.kind is network/read/write; paths must be absolute.
|
|
7
|
+
*/
|
|
8
|
+
export async function permissionAccessAllows(permissions, access) {
|
|
9
|
+
if (access.kind === "network") {
|
|
10
|
+
return permissions.network;
|
|
11
|
+
}
|
|
12
|
+
if (!path.isAbsolute(access.path)) {
|
|
13
|
+
return false;
|
|
14
|
+
}
|
|
15
|
+
let resolved;
|
|
16
|
+
try {
|
|
17
|
+
resolved = pathSanitizeAndResolve(access.path);
|
|
18
|
+
}
|
|
19
|
+
catch {
|
|
20
|
+
return false;
|
|
21
|
+
}
|
|
22
|
+
const allowedDirs = access.kind === "write"
|
|
23
|
+
? [...permissions.writeDirs]
|
|
24
|
+
: permissions.readDirs.length > 0
|
|
25
|
+
? [permissions.workingDir, ...permissions.readDirs, ...permissions.writeDirs]
|
|
26
|
+
: [path.parse(resolved).root];
|
|
27
|
+
try {
|
|
28
|
+
await pathResolveSecure(allowedDirs, resolved);
|
|
29
|
+
return true;
|
|
30
|
+
}
|
|
31
|
+
catch {
|
|
32
|
+
return false;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=permissionAccessAllows.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"permissionAccessAllows.js","sourceRoot":"","sources":["../../../sources/engine/permissions/permissionAccessAllows.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,WAAW,CAAC;AAG7B,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAC3D,OAAO,EAAE,sBAAsB,EAAE,MAAM,mBAAmB,CAAC;AAE3D;;;GAGG;AACH,MAAM,CAAC,KAAK,UAAU,sBAAsB,CAC1C,WAA+B,EAC/B,MAAwB;IAExB,IAAI,MAAM,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;QAC9B,OAAO,WAAW,CAAC,OAAO,CAAC;IAC7B,CAAC;IAED,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC;QAClC,OAAO,KAAK,CAAC;IACf,CAAC;IAED,IAAI,QAAgB,CAAC;IACrB,IAAI,CAAC;QACH,QAAQ,GAAG,sBAAsB,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IACjD,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,KAAK,CAAC;IACf,CAAC;IAED,MAAM,WAAW,GAAG,MAAM,CAAC,IAAI,KAAK,OAAO;QACzC,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC,SAAS,CAAC;QAC5B,CAAC,CAAC,WAAW,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC;YAC/B,CAAC,CAAC,CAAC,WAAW,CAAC,UAAU,EAAE,GAAG,WAAW,CAAC,QAAQ,EAAE,GAAG,WAAW,CAAC,SAAS,CAAC;YAC7E,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC;IAElC,IAAI,CAAC;QACH,MAAM,iBAAiB,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;QAC/C,OAAO,IAAI,CAAC;IACd,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,KAAK,CAAC;IACf,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"permissionAccessAllows.spec.d.ts","sourceRoot":"","sources":["../../../sources/engine/permissions/permissionAccessAllows.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { describe, it, expect, afterEach } from "vitest";
|
|
2
|
+
import { promises as fs } from "node:fs";
|
|
3
|
+
import os from "node:os";
|
|
4
|
+
import path from "node:path";
|
|
5
|
+
import { permissionAccessAllows } from "./permissionAccessAllows.js";
|
|
6
|
+
describe("permissionAccessAllows", () => {
|
|
7
|
+
const tempDirs = [];
|
|
8
|
+
afterEach(async () => {
|
|
9
|
+
await Promise.all(tempDirs.map((dir) => fs.rm(dir, { recursive: true, force: true })));
|
|
10
|
+
tempDirs.length = 0;
|
|
11
|
+
});
|
|
12
|
+
it("allows network access when enabled", async () => {
|
|
13
|
+
const allowed = await permissionAccessAllows({ workingDir: "/tmp", writeDirs: [], readDirs: [], network: true }, { kind: "network" });
|
|
14
|
+
expect(allowed).toBe(true);
|
|
15
|
+
});
|
|
16
|
+
it("allows read access within allowed directories", async () => {
|
|
17
|
+
const dir = await fs.mkdtemp(path.join(os.tmpdir(), "perm-allow-"));
|
|
18
|
+
tempDirs.push(dir);
|
|
19
|
+
const target = path.join(dir, "file.txt");
|
|
20
|
+
await fs.writeFile(target, "ok", "utf8");
|
|
21
|
+
const allowed = await permissionAccessAllows({ workingDir: dir, writeDirs: [], readDirs: [dir], network: false }, { kind: "read", path: target });
|
|
22
|
+
expect(allowed).toBe(true);
|
|
23
|
+
});
|
|
24
|
+
it("treats empty readDirs as unrestricted read access", async () => {
|
|
25
|
+
const workspaceDir = await fs.mkdtemp(path.join(os.tmpdir(), "perm-workspace-"));
|
|
26
|
+
const outsideDir = await fs.mkdtemp(path.join(os.tmpdir(), "perm-outside-"));
|
|
27
|
+
tempDirs.push(workspaceDir, outsideDir);
|
|
28
|
+
const outsideFile = path.join(outsideDir, "outside.txt");
|
|
29
|
+
await fs.writeFile(outsideFile, "ok", "utf8");
|
|
30
|
+
const allowed = await permissionAccessAllows({ workingDir: workspaceDir, writeDirs: [], readDirs: [], network: false }, { kind: "read", path: outsideFile });
|
|
31
|
+
expect(allowed).toBe(true);
|
|
32
|
+
});
|
|
33
|
+
it("denies write access outside allowed directories", async () => {
|
|
34
|
+
const dir = await fs.mkdtemp(path.join(os.tmpdir(), "perm-deny-"));
|
|
35
|
+
tempDirs.push(dir);
|
|
36
|
+
const target = path.join(dir, "elsewhere", "file.txt");
|
|
37
|
+
const allowed = await permissionAccessAllows({ workingDir: "/tmp", writeDirs: ["/tmp"], readDirs: [], network: false }, { kind: "write", path: target });
|
|
38
|
+
expect(allowed).toBe(false);
|
|
39
|
+
});
|
|
40
|
+
it("does not imply write access from workingDir", async () => {
|
|
41
|
+
const dir = await fs.mkdtemp(path.join(os.tmpdir(), "perm-working-dir-"));
|
|
42
|
+
tempDirs.push(dir);
|
|
43
|
+
const target = path.join(dir, "file.txt");
|
|
44
|
+
const allowed = await permissionAccessAllows({ workingDir: dir, writeDirs: [], readDirs: [], network: false }, { kind: "write", path: target });
|
|
45
|
+
expect(allowed).toBe(false);
|
|
46
|
+
});
|
|
47
|
+
it("allows write access when path is explicitly in writeDirs", async () => {
|
|
48
|
+
const dir = await fs.mkdtemp(path.join(os.tmpdir(), "perm-write-dir-"));
|
|
49
|
+
tempDirs.push(dir);
|
|
50
|
+
const target = path.join(dir, "file.txt");
|
|
51
|
+
const allowed = await permissionAccessAllows({ workingDir: "/tmp", writeDirs: [dir], readDirs: [], network: false }, { kind: "write", path: target });
|
|
52
|
+
expect(allowed).toBe(true);
|
|
53
|
+
});
|
|
54
|
+
});
|
|
55
|
+
//# sourceMappingURL=permissionAccessAllows.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"permissionAccessAllows.spec.js","sourceRoot":"","sources":["../../../sources/engine/permissions/permissionAccessAllows.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { PermissionAccess, SessionPermissions } from "@/types";
|
|
2
|
+
/**
|
|
3
|
+
* Applies a permission access to a permissions object in place.
|
|
4
|
+
* Returns true when applied; false when invalid or unsupported.
|
|
5
|
+
*/
|
|
6
|
+
export declare function permissionAccessApply(permissions: SessionPermissions, access: PermissionAccess): boolean;
|
|
7
|
+
//# sourceMappingURL=permissionAccessApply.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"permissionAccessApply.d.ts","sourceRoot":"","sources":["../../../sources/engine/permissions/permissionAccessApply.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAGpE;;;GAGG;AACH,wBAAgB,qBAAqB,CACnC,WAAW,EAAE,kBAAkB,EAC/B,MAAM,EAAE,gBAAgB,GACvB,OAAO,CAqCT"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import path from "node:path";
|
|
2
|
+
import { pathSanitizeAndResolve } from "./pathSanitize.js";
|
|
3
|
+
/**
|
|
4
|
+
* Applies a permission access to a permissions object in place.
|
|
5
|
+
* Returns true when applied; false when invalid or unsupported.
|
|
6
|
+
*/
|
|
7
|
+
export function permissionAccessApply(permissions, access) {
|
|
8
|
+
if (access.kind === "network") {
|
|
9
|
+
permissions.network = true;
|
|
10
|
+
return true;
|
|
11
|
+
}
|
|
12
|
+
if (!path.isAbsolute(access.path)) {
|
|
13
|
+
return false;
|
|
14
|
+
}
|
|
15
|
+
let resolved;
|
|
16
|
+
try {
|
|
17
|
+
resolved = pathSanitizeAndResolve(access.path);
|
|
18
|
+
}
|
|
19
|
+
catch {
|
|
20
|
+
return false;
|
|
21
|
+
}
|
|
22
|
+
if (access.kind === "write") {
|
|
23
|
+
const writeDirs = new Set(permissions.writeDirs);
|
|
24
|
+
writeDirs.add(resolved);
|
|
25
|
+
permissions.writeDirs = Array.from(writeDirs.values());
|
|
26
|
+
// Write access requires read access to the same path.
|
|
27
|
+
const readDirs = new Set(permissions.readDirs);
|
|
28
|
+
readDirs.add(resolved);
|
|
29
|
+
permissions.readDirs = Array.from(readDirs.values());
|
|
30
|
+
return true;
|
|
31
|
+
}
|
|
32
|
+
if (access.kind === "read") {
|
|
33
|
+
const next = new Set(permissions.readDirs);
|
|
34
|
+
next.add(resolved);
|
|
35
|
+
permissions.readDirs = Array.from(next.values());
|
|
36
|
+
return true;
|
|
37
|
+
}
|
|
38
|
+
return false;
|
|
39
|
+
}
|
|
40
|
+
//# sourceMappingURL=permissionAccessApply.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"permissionAccessApply.js","sourceRoot":"","sources":["../../../sources/engine/permissions/permissionAccessApply.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,WAAW,CAAC;AAG7B,OAAO,EAAE,sBAAsB,EAAE,MAAM,mBAAmB,CAAC;AAE3D;;;GAGG;AACH,MAAM,UAAU,qBAAqB,CACnC,WAA+B,EAC/B,MAAwB;IAExB,IAAI,MAAM,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;QAC9B,WAAW,CAAC,OAAO,GAAG,IAAI,CAAC;QAC3B,OAAO,IAAI,CAAC;IACd,CAAC;IAED,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC;QAClC,OAAO,KAAK,CAAC;IACf,CAAC;IAED,IAAI,QAAgB,CAAC;IACrB,IAAI,CAAC;QACH,QAAQ,GAAG,sBAAsB,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IACjD,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,KAAK,CAAC;IACf,CAAC;IAED,IAAI,MAAM,CAAC,IAAI,KAAK,OAAO,EAAE,CAAC;QAC5B,MAAM,SAAS,GAAG,IAAI,GAAG,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;QACjD,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QACxB,WAAW,CAAC,SAAS,GAAG,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,CAAC;QAEvD,sDAAsD;QACtD,MAAM,QAAQ,GAAG,IAAI,GAAG,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;QAC/C,QAAQ,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QACvB,WAAW,CAAC,QAAQ,GAAG,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC,CAAC;QACrD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,IAAI,MAAM,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;QAC3B,MAAM,IAAI,GAAG,IAAI,GAAG,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;QAC3C,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QACnB,WAAW,CAAC,QAAQ,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;QACjD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,OAAO,KAAK,CAAC;AACf,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"permissionAccessApply.spec.d.ts","sourceRoot":"","sources":["../../../sources/engine/permissions/permissionAccessApply.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { describe, it, expect } from "vitest";
|
|
2
|
+
import path from "node:path";
|
|
3
|
+
import { permissionAccessApply } from "./permissionAccessApply.js";
|
|
4
|
+
describe("permissionAccessApply", () => {
|
|
5
|
+
const basePermissions = () => ({
|
|
6
|
+
workingDir: "/tmp",
|
|
7
|
+
writeDirs: [],
|
|
8
|
+
readDirs: [],
|
|
9
|
+
network: false
|
|
10
|
+
});
|
|
11
|
+
it("applies network access", () => {
|
|
12
|
+
const permissions = basePermissions();
|
|
13
|
+
const applied = permissionAccessApply(permissions, { kind: "network" });
|
|
14
|
+
expect(applied).toBe(true);
|
|
15
|
+
expect(permissions.network).toBe(true);
|
|
16
|
+
});
|
|
17
|
+
it("applies read/write paths", () => {
|
|
18
|
+
const permissions = basePermissions();
|
|
19
|
+
const readPath = path.resolve("/tmp/read");
|
|
20
|
+
const writePath = path.resolve("/tmp/write");
|
|
21
|
+
expect(permissionAccessApply(permissions, { kind: "read", path: readPath })).toBe(true);
|
|
22
|
+
expect(permissionAccessApply(permissions, { kind: "write", path: writePath })).toBe(true);
|
|
23
|
+
expect(permissions.readDirs).toContain(readPath);
|
|
24
|
+
expect(permissions.readDirs).toContain(writePath);
|
|
25
|
+
expect(permissions.writeDirs).toContain(writePath);
|
|
26
|
+
});
|
|
27
|
+
it("rejects non-absolute paths", () => {
|
|
28
|
+
const permissions = basePermissions();
|
|
29
|
+
const applied = permissionAccessApply(permissions, { kind: "read", path: "relative" });
|
|
30
|
+
expect(applied).toBe(false);
|
|
31
|
+
expect(permissions.readDirs).toHaveLength(0);
|
|
32
|
+
});
|
|
33
|
+
});
|
|
34
|
+
//# sourceMappingURL=permissionAccessApply.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"permissionAccessApply.spec.js","sourceRoot":"","sources":["../../../sources/engine/permissions/permissionAccessApply.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,IAAI,MAAM,WAAW,CAAC;AAE7B,OAAO,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAC;AAEnE,QAAQ,CAAC,uBAAuB,EAAE,GAAG,EAAE;IACrC,MAAM,eAAe,GAAG,GAAG,EAAE,CAAC,CAAC;QAC7B,UAAU,EAAE,MAAM;QAClB,SAAS,EAAE,EAAc;QACzB,QAAQ,EAAE,EAAc;QACxB,OAAO,EAAE,KAAK;KACf,CAAC,CAAC;IAEH,EAAE,CAAC,wBAAwB,EAAE,GAAG,EAAE;QAChC,MAAM,WAAW,GAAG,eAAe,EAAE,CAAC;QACtC,MAAM,OAAO,GAAG,qBAAqB,CAAC,WAAW,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,CAAC;QACxE,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC3B,MAAM,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACzC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0BAA0B,EAAE,GAAG,EAAE;QAClC,MAAM,WAAW,GAAG,eAAe,EAAE,CAAC;QACtC,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QAC3C,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;QAC7C,MAAM,CAAC,qBAAqB,CAAC,WAAW,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACxF,MAAM,CAAC,qBAAqB,CAAC,WAAW,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC1F,MAAM,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;QACjD,MAAM,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QAClD,MAAM,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;IACrD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4BAA4B,EAAE,GAAG,EAAE;QACpC,MAAM,WAAW,GAAG,eAAe,EAAE,CAAC;QACtC,MAAM,OAAO,GAAG,qBAAqB,CAAC,WAAW,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC;QACvF,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC5B,MAAM,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IAC/C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { PermissionAccess } from "@/types";
|
|
2
|
+
/**
|
|
3
|
+
* Parses a permission tag string into a PermissionAccess union.
|
|
4
|
+
* Expects: value is @network, @read:<path>, or @write:<path>.
|
|
5
|
+
*/
|
|
6
|
+
export declare function permissionAccessParse(value: string): PermissionAccess;
|
|
7
|
+
//# sourceMappingURL=permissionAccessParse.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"permissionAccessParse.d.ts","sourceRoot":"","sources":["../../../sources/engine/permissions/permissionAccessParse.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAEhD;;;GAGG;AACH,wBAAgB,qBAAqB,CAAC,KAAK,EAAE,MAAM,GAAG,gBAAgB,CAoBrE"}
|