plugin-agent-orchestrator 1.0.13 → 1.0.14
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +16 -291
- package/dist/client/AIEmployeesContext.d.ts +7 -0
- package/dist/client/OrchestratorSettings.d.ts +2 -1
- package/dist/client/index.js +1 -1
- package/dist/client/plugin.d.ts +1 -0
- package/dist/client/skill-hub/components/ExecutionHistory.d.ts +2 -0
- package/dist/client/skill-hub/components/ExecutionProgress.d.ts +20 -0
- package/dist/client/skill-hub/components/GitSkillImport.d.ts +7 -0
- package/dist/client/skill-hub/components/SkillEditor.d.ts +7 -0
- package/dist/client/skill-hub/components/SkillManager.d.ts +2 -0
- package/dist/client/skill-hub/components/SkillMetrics.d.ts +2 -0
- package/dist/client/skill-hub/components/SkillTestPanel.d.ts +7 -0
- package/dist/client/skill-hub/index.d.ts +10 -0
- package/dist/client/skill-hub/locale.d.ts +3 -0
- package/dist/client/skill-hub/tools/InteractionSchemasProvider.d.ts +19 -0
- package/dist/client/skill-hub/tools/SkillHubCard.d.ts +3 -0
- package/dist/client/skill-hub/utils/jsonFields.d.ts +3 -0
- package/dist/externalVersion.js +6 -6
- package/dist/node_modules/adm-zip/LICENSE +21 -0
- package/dist/node_modules/adm-zip/adm-zip.js +1 -0
- package/dist/node_modules/adm-zip/headers/entryHeader.js +377 -0
- package/dist/node_modules/adm-zip/headers/index.js +2 -0
- package/dist/node_modules/adm-zip/headers/mainHeader.js +130 -0
- package/dist/node_modules/adm-zip/methods/deflater.js +33 -0
- package/dist/node_modules/adm-zip/methods/index.js +3 -0
- package/dist/node_modules/adm-zip/methods/inflater.js +34 -0
- package/dist/node_modules/adm-zip/methods/zipcrypto.js +175 -0
- package/dist/node_modules/adm-zip/package.json +1 -0
- package/dist/node_modules/adm-zip/util/constants.js +142 -0
- package/dist/node_modules/adm-zip/util/decoder.js +5 -0
- package/dist/node_modules/adm-zip/util/errors.js +63 -0
- package/dist/node_modules/adm-zip/util/fattr.js +76 -0
- package/dist/node_modules/adm-zip/util/index.js +5 -0
- package/dist/node_modules/adm-zip/util/utils.js +339 -0
- package/dist/node_modules/adm-zip/zipEntry.js +405 -0
- package/dist/node_modules/adm-zip/zipFile.js +446 -0
- package/dist/node_modules/simple-git/dist/cjs/index.js +7399 -0
- package/dist/node_modules/simple-git/dist/esm/index.js +4745 -0
- package/dist/node_modules/simple-git/dist/esm/package.json +3 -0
- package/dist/node_modules/simple-git/dist/src/lib/api.d.ts +13 -0
- package/dist/node_modules/simple-git/dist/src/lib/args/log-format.d.ts +9 -0
- package/dist/node_modules/simple-git/dist/src/lib/errors/git-construct-error.d.ts +15 -0
- package/dist/node_modules/simple-git/dist/src/lib/errors/git-error.d.ts +30 -0
- package/dist/node_modules/simple-git/dist/src/lib/errors/git-plugin-error.d.ts +7 -0
- package/dist/node_modules/simple-git/dist/src/lib/errors/git-response-error.d.ts +32 -0
- package/dist/node_modules/simple-git/dist/src/lib/errors/task-configuration-error.d.ts +12 -0
- package/dist/node_modules/simple-git/dist/src/lib/git-factory.d.ts +15 -0
- package/dist/node_modules/simple-git/dist/src/lib/git-logger.d.ts +21 -0
- package/dist/node_modules/simple-git/dist/src/lib/parsers/parse-branch-delete.d.ts +5 -0
- package/dist/node_modules/simple-git/dist/src/lib/parsers/parse-branch.d.ts +2 -0
- package/dist/node_modules/simple-git/dist/src/lib/parsers/parse-commit.d.ts +2 -0
- package/dist/node_modules/simple-git/dist/src/lib/parsers/parse-diff-summary.d.ts +3 -0
- package/dist/node_modules/simple-git/dist/src/lib/parsers/parse-fetch.d.ts +2 -0
- package/dist/node_modules/simple-git/dist/src/lib/parsers/parse-list-log-summary.d.ts +6 -0
- package/dist/node_modules/simple-git/dist/src/lib/parsers/parse-merge.d.ts +11 -0
- package/dist/node_modules/simple-git/dist/src/lib/parsers/parse-move.d.ts +2 -0
- package/dist/node_modules/simple-git/dist/src/lib/parsers/parse-pull.d.ts +6 -0
- package/dist/node_modules/simple-git/dist/src/lib/parsers/parse-push.d.ts +4 -0
- package/dist/node_modules/simple-git/dist/src/lib/parsers/parse-remote-messages.d.ts +5 -0
- package/dist/node_modules/simple-git/dist/src/lib/parsers/parse-remote-objects.d.ts +3 -0
- package/dist/node_modules/simple-git/dist/src/lib/plugins/abort-plugin.d.ts +3 -0
- package/dist/node_modules/simple-git/dist/src/lib/plugins/block-unsafe-operations-plugin.d.ts +3 -0
- package/dist/node_modules/simple-git/dist/src/lib/plugins/command-config-prefixing-plugin.d.ts +2 -0
- package/dist/node_modules/simple-git/dist/src/lib/plugins/completion-detection.plugin.d.ts +3 -0
- package/dist/node_modules/simple-git/dist/src/lib/plugins/custom-binary.plugin.d.ts +3 -0
- package/dist/node_modules/simple-git/dist/src/lib/plugins/error-detection.plugin.d.ts +7 -0
- package/dist/node_modules/simple-git/dist/src/lib/plugins/index.d.ts +11 -0
- package/dist/node_modules/simple-git/dist/src/lib/plugins/plugin-store.d.ts +11 -0
- package/dist/node_modules/simple-git/dist/src/lib/plugins/progress-monitor-plugin.d.ts +3 -0
- package/dist/node_modules/simple-git/dist/src/lib/plugins/simple-git-plugin.d.ts +48 -0
- package/dist/node_modules/simple-git/dist/src/lib/plugins/spawn-options-plugin.d.ts +3 -0
- package/dist/node_modules/simple-git/dist/src/lib/plugins/suffix-paths.plugin.d.ts +2 -0
- package/dist/node_modules/simple-git/dist/src/lib/plugins/timout-plugin.d.ts +3 -0
- package/dist/node_modules/simple-git/dist/src/lib/responses/BranchDeleteSummary.d.ts +12 -0
- package/dist/node_modules/simple-git/dist/src/lib/responses/BranchSummary.d.ts +14 -0
- package/dist/node_modules/simple-git/dist/src/lib/responses/CheckIgnore.d.ts +4 -0
- package/dist/node_modules/simple-git/dist/src/lib/responses/CleanSummary.d.ts +9 -0
- package/dist/node_modules/simple-git/dist/src/lib/responses/ConfigList.d.ts +13 -0
- package/dist/node_modules/simple-git/dist/src/lib/responses/DiffSummary.d.ts +10 -0
- package/dist/node_modules/simple-git/dist/src/lib/responses/FileStatusSummary.d.ts +9 -0
- package/dist/node_modules/simple-git/dist/src/lib/responses/GetRemoteSummary.d.ts +11 -0
- package/dist/node_modules/simple-git/dist/src/lib/responses/InitSummary.d.ts +9 -0
- package/dist/node_modules/simple-git/dist/src/lib/responses/MergeSummary.d.ts +16 -0
- package/dist/node_modules/simple-git/dist/src/lib/responses/PullSummary.d.ts +25 -0
- package/dist/node_modules/simple-git/dist/src/lib/responses/StatusSummary.d.ts +19 -0
- package/dist/node_modules/simple-git/dist/src/lib/responses/TagList.d.ts +7 -0
- package/dist/node_modules/simple-git/dist/src/lib/runners/git-executor-chain.d.ts +25 -0
- package/dist/node_modules/simple-git/dist/src/lib/runners/git-executor.d.ts +14 -0
- package/dist/node_modules/simple-git/dist/src/lib/runners/promise-wrapped.d.ts +2 -0
- package/dist/node_modules/simple-git/dist/src/lib/runners/scheduler.d.ts +11 -0
- package/dist/node_modules/simple-git/dist/src/lib/runners/tasks-pending-queue.d.ts +23 -0
- package/dist/node_modules/simple-git/dist/src/lib/simple-git-api.d.ts +20 -0
- package/dist/node_modules/simple-git/dist/src/lib/task-callback.d.ts +2 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/apply-patch.d.ts +3 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/branch.d.ts +7 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/change-working-directory.d.ts +2 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/check-ignore.d.ts +2 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/check-is-repo.d.ts +9 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/checkout.d.ts +2 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/clean.d.ts +25 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/clone.d.ts +9 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/commit.d.ts +4 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/config.d.ts +8 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/count-objects.d.ts +12 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/diff-name-status.d.ts +12 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/diff.d.ts +5 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/fetch.d.ts +4 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/first-commit.d.ts +2 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/grep.d.ts +12 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/hash-object.d.ts +5 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/init.d.ts +3 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/log.d.ts +32 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/merge.d.ts +4 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/move.d.ts +3 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/pull.d.ts +3 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/push.d.ts +9 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/remote.d.ts +8 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/reset.d.ts +11 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/show.d.ts +2 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/stash-list.d.ts +4 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/status.d.ts +3 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/sub-module.d.ts +5 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/tag.d.ts +18 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/task.d.ts +14 -0
- package/dist/node_modules/simple-git/dist/src/lib/tasks/version.d.ts +9 -0
- package/dist/node_modules/simple-git/dist/src/lib/types/handlers.d.ts +21 -0
- package/dist/node_modules/simple-git/dist/src/lib/types/index.d.ts +136 -0
- package/dist/node_modules/simple-git/dist/src/lib/types/tasks.d.ts +19 -0
- package/dist/node_modules/simple-git/dist/src/lib/utils/argument-filters.d.ts +14 -0
- package/dist/node_modules/simple-git/dist/src/lib/utils/exit-codes.d.ts +10 -0
- package/dist/node_modules/simple-git/dist/src/lib/utils/git-output-streams.d.ts +7 -0
- package/dist/node_modules/simple-git/dist/src/lib/utils/index.d.ts +8 -0
- package/dist/node_modules/simple-git/dist/src/lib/utils/line-parser.d.ts +15 -0
- package/dist/node_modules/simple-git/dist/src/lib/utils/simple-git-options.d.ts +2 -0
- package/dist/node_modules/simple-git/dist/src/lib/utils/task-options.d.ts +13 -0
- package/dist/node_modules/simple-git/dist/src/lib/utils/task-parser.d.ts +5 -0
- package/dist/node_modules/simple-git/dist/src/lib/utils/util.d.ts +47 -0
- package/dist/node_modules/simple-git/dist/typings/errors.d.ts +5 -0
- package/dist/node_modules/simple-git/dist/typings/index.d.ts +14 -0
- package/dist/node_modules/simple-git/dist/typings/response.d.ts +556 -0
- package/dist/node_modules/simple-git/dist/typings/simple-git.d.ts +1033 -0
- package/dist/node_modules/simple-git/dist/typings/types.d.ts +22 -0
- package/dist/node_modules/simple-git/node_modules/debug/package.json +64 -0
- package/dist/node_modules/simple-git/node_modules/debug/src/browser.js +272 -0
- package/dist/node_modules/simple-git/node_modules/debug/src/common.js +292 -0
- package/dist/node_modules/simple-git/node_modules/debug/src/index.js +10 -0
- package/dist/node_modules/simple-git/node_modules/debug/src/node.js +263 -0
- package/dist/node_modules/simple-git/package.json +1 -0
- package/dist/node_modules/simple-git/promise.js +17 -0
- package/dist/server/collections/agent-execution-spans.d.ts +9 -0
- package/dist/server/collections/agent-execution-spans.js +152 -0
- package/dist/server/collections/orchestrator-config.js +6 -0
- package/dist/server/collections/skill-definitions.d.ts +3 -0
- package/dist/server/collections/skill-definitions.js +158 -0
- package/dist/server/collections/skill-executions.d.ts +3 -0
- package/dist/server/collections/skill-executions.js +123 -0
- package/dist/server/collections/skill-worker-configs.d.ts +3 -0
- package/dist/server/collections/skill-worker-configs.js +115 -0
- package/dist/server/migrations/20260423000000-add-progress-fields.d.ts +4 -0
- package/dist/server/migrations/20260423000000-add-progress-fields.js +69 -0
- package/dist/server/migrations/20260425000000-add-interaction-schema.d.ts +4 -0
- package/dist/server/migrations/20260425000000-add-interaction-schema.js +61 -0
- package/dist/server/migrations/20260427000000-change-packages-to-text.d.ts +4 -0
- package/dist/server/migrations/20260427000000-change-packages-to-text.js +70 -0
- package/dist/server/migrations/20260427000001-change-other-json-to-text.d.ts +4 -0
- package/dist/server/migrations/20260427000001-change-other-json-to-text.js +80 -0
- package/dist/server/migrations/20260429000000-add-llm-fields.js +8 -0
- package/dist/server/migrations/20260429000000-fix-inputargs-json-to-text.d.ts +16 -0
- package/dist/server/migrations/20260429000000-fix-inputargs-json-to-text.js +51 -0
- package/dist/server/migrations/20260503000000-add-orchestrator-trace-fields.d.ts +7 -0
- package/dist/server/migrations/20260503000000-add-orchestrator-trace-fields.js +57 -0
- package/dist/server/plugin.d.ts +3 -0
- package/dist/server/plugin.js +37 -1
- package/dist/server/resources/tracing.js +154 -11
- package/dist/server/services/CodeValidator.d.ts +32 -0
- package/dist/server/services/CodeValidator.js +205 -0
- package/dist/server/services/ExecutionSpanService.d.ts +44 -0
- package/dist/server/services/ExecutionSpanService.js +104 -0
- package/dist/server/services/FileManager.d.ts +28 -0
- package/dist/server/services/FileManager.js +151 -0
- package/dist/server/services/SandboxRunner.d.ts +41 -0
- package/dist/server/services/SandboxRunner.js +167 -0
- package/dist/server/services/SkillManager.d.ts +6 -0
- package/dist/server/services/SkillManager.js +640 -0
- package/dist/server/services/SkillRepositoryService.d.ts +22 -0
- package/dist/server/services/SkillRepositoryService.js +157 -0
- package/dist/server/services/WorkerEnvManager.d.ts +26 -0
- package/dist/server/services/WorkerEnvManager.js +120 -0
- package/dist/server/skill-hub/actions/git-import.d.ts +21 -0
- package/dist/server/skill-hub/actions/git-import.js +413 -0
- package/dist/server/skill-hub/mcp/McpController.d.ts +15 -0
- package/dist/server/skill-hub/mcp/McpController.js +111 -0
- package/dist/server/skill-hub/plugin.d.ts +58 -0
- package/dist/server/skill-hub/plugin.js +694 -0
- package/dist/server/skill-hub/sandbox-config.json +6 -0
- package/dist/server/skill-hub/tasks/SkillExecutionTask.d.ts +14 -0
- package/dist/server/skill-hub/tasks/SkillExecutionTask.js +267 -0
- package/dist/server/skill-hub/utils/json-fields.d.ts +7 -0
- package/dist/server/skill-hub/utils/json-fields.js +88 -0
- package/dist/server/tools/delegate-task.d.ts +4 -0
- package/dist/server/tools/delegate-task.js +606 -104
- package/dist/server/tools/skill-execute.d.ts +36 -0
- package/dist/server/tools/skill-execute.js +167 -0
- package/package.json +3 -1
- package/src/client/AIEmployeeSelect.tsx +1 -3
- package/src/client/AIEmployeesContext.tsx +28 -13
- package/src/client/OrchestratorSettings.tsx +43 -5
- package/src/client/RulesTab.tsx +253 -32
- package/src/client/TracingTab.tsx +277 -213
- package/src/client/plugin.tsx +39 -0
- package/src/client/skill-hub/components/ExecutionHistory.tsx +201 -0
- package/src/client/skill-hub/components/ExecutionProgress.tsx +55 -0
- package/src/client/skill-hub/components/GitSkillImport.tsx +555 -0
- package/src/client/skill-hub/components/SkillEditor.tsx +456 -0
- package/src/client/skill-hub/components/SkillManager.tsx +181 -0
- package/src/client/skill-hub/components/SkillMetrics.tsx +124 -0
- package/src/client/skill-hub/components/SkillTestPanel.tsx +144 -0
- package/src/client/skill-hub/index.tsx +75 -0
- package/src/client/skill-hub/locale.ts +16 -0
- package/src/client/skill-hub/tools/InteractionSchemasProvider.tsx +59 -0
- package/src/client/skill-hub/tools/SkillHubCard.tsx +78 -0
- package/src/client/skill-hub/utils/jsonFields.ts +37 -0
- package/src/server/collections/agent-execution-spans.ts +129 -0
- package/src/server/collections/orchestrator-config.ts +7 -0
- package/src/server/collections/skill-definitions.ts +128 -0
- package/src/server/collections/skill-executions.ts +94 -0
- package/src/server/collections/skill-worker-configs.ts +86 -0
- package/src/server/migrations/20260423000000-add-progress-fields.ts +50 -0
- package/src/server/migrations/20260425000000-add-interaction-schema.ts +35 -0
- package/src/server/migrations/20260427000000-change-packages-to-text.ts +47 -0
- package/src/server/migrations/20260427000001-change-other-json-to-text.ts +57 -0
- package/src/server/migrations/20260429000000-add-llm-fields.ts +9 -0
- package/src/server/migrations/20260429000000-fix-inputargs-json-to-text.ts +38 -0
- package/src/server/migrations/20260503000000-add-orchestrator-trace-fields.ts +32 -0
- package/src/server/plugin.ts +51 -3
- package/src/server/resources/tracing.ts +182 -15
- package/src/server/services/CodeValidator.ts +159 -0
- package/src/server/services/ExecutionSpanService.ts +106 -0
- package/src/server/services/FileManager.ts +144 -0
- package/src/server/services/SandboxRunner.ts +205 -0
- package/src/server/services/SkillManager.ts +623 -0
- package/src/server/services/SkillRepositoryService.ts +142 -0
- package/src/server/services/WorkerEnvManager.ts +113 -0
- package/src/server/skill-hub/actions/git-import.ts +486 -0
- package/src/server/skill-hub/mcp/McpController.ts +86 -0
- package/src/server/skill-hub/plugin.ts +771 -0
- package/src/server/skill-hub/sandbox-config.json +6 -0
- package/src/server/skill-hub/tasks/SkillExecutionTask.ts +297 -0
- package/src/server/skill-hub/utils/json-fields.ts +57 -0
- package/src/server/tools/delegate-task.ts +803 -127
- package/src/server/tools/skill-execute.ts +157 -0
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
import { cpSync, existsSync, mkdirSync, readFileSync, readdirSync, rmSync, statSync } from 'fs';
|
|
2
|
+
import { resolve, relative } from 'path';
|
|
3
|
+
import AdmZip from 'adm-zip';
|
|
4
|
+
import { parseSkillMarkdown } from '../skill-hub/utils/json-fields';
|
|
5
|
+
export interface SkillPackageMetadata {
|
|
6
|
+
path: string;
|
|
7
|
+
metadata: Record<string, any>;
|
|
8
|
+
instructions: string;
|
|
9
|
+
code: string | null;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
export class SkillRepositoryService {
|
|
13
|
+
private baseDir: string;
|
|
14
|
+
|
|
15
|
+
constructor(storagePath: string) {
|
|
16
|
+
this.baseDir = resolve(storagePath, 'skills');
|
|
17
|
+
if (!existsSync(this.baseDir)) {
|
|
18
|
+
mkdirSync(this.baseDir, { recursive: true });
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
/**
|
|
23
|
+
* Extract a zip file to the repository.
|
|
24
|
+
* Returns parsed metadata from SKILL.md / skill.yaml
|
|
25
|
+
*/
|
|
26
|
+
async extractSkillPackage(skillName: string, zipFilePath: string) {
|
|
27
|
+
const targetDir = resolve(this.baseDir, skillName);
|
|
28
|
+
|
|
29
|
+
// Clean target dir if exists
|
|
30
|
+
if (existsSync(targetDir)) {
|
|
31
|
+
rmSync(targetDir, { recursive: true, force: true });
|
|
32
|
+
}
|
|
33
|
+
mkdirSync(targetDir, { recursive: true });
|
|
34
|
+
|
|
35
|
+
// Extract
|
|
36
|
+
const zip = new AdmZip(zipFilePath);
|
|
37
|
+
zip.extractAllTo(targetDir, true);
|
|
38
|
+
|
|
39
|
+
return this.readSkillPackage(targetDir);
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
getSkillPath(skillName: string) {
|
|
43
|
+
return resolve(this.baseDir, skillName);
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
getSkillCode(skillName: string): string | null {
|
|
47
|
+
const dir = this.getSkillPath(skillName);
|
|
48
|
+
if (!existsSync(dir)) return null;
|
|
49
|
+
|
|
50
|
+
return this.getSkillCodeFromDir(dir);
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
copySkillPackageTo(skillName: string, destDir: string) {
|
|
54
|
+
const srcDir = this.getSkillPath(skillName);
|
|
55
|
+
this.copyDirectoryTo(srcDir, destDir);
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
readSkillPackage(packageDir: string): SkillPackageMetadata {
|
|
59
|
+
const rootDir = resolve(packageDir);
|
|
60
|
+
if (!existsSync(rootDir)) {
|
|
61
|
+
return {
|
|
62
|
+
path: rootDir,
|
|
63
|
+
metadata: {},
|
|
64
|
+
instructions: '',
|
|
65
|
+
code: null,
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
let metadata: Record<string, any> = {};
|
|
70
|
+
let instructions = '';
|
|
71
|
+
const skillMdPath = resolve(rootDir, 'SKILL.md');
|
|
72
|
+
|
|
73
|
+
if (existsSync(skillMdPath)) {
|
|
74
|
+
const content = readFileSync(skillMdPath, 'utf8');
|
|
75
|
+
const parsed = parseSkillMarkdown(content);
|
|
76
|
+
metadata = parsed.metadata;
|
|
77
|
+
instructions = parsed.body;
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
instructions += this.aggregateOtherMarkdownFiles(rootDir);
|
|
81
|
+
|
|
82
|
+
return {
|
|
83
|
+
path: rootDir,
|
|
84
|
+
metadata,
|
|
85
|
+
instructions: instructions.trim(),
|
|
86
|
+
code: this.getSkillCodeFromDir(rootDir),
|
|
87
|
+
};
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
copyDirectoryTo(srcDir: string, destDir: string) {
|
|
91
|
+
if (!existsSync(srcDir)) return;
|
|
92
|
+
|
|
93
|
+
cpSync(srcDir, destDir, {
|
|
94
|
+
recursive: true,
|
|
95
|
+
force: true,
|
|
96
|
+
filter: (src) => {
|
|
97
|
+
const name = src.split(/[\\/]/).pop();
|
|
98
|
+
return !['node_modules', '.git', '__pycache__'].includes(name || '') && !src.endsWith('.pyc');
|
|
99
|
+
},
|
|
100
|
+
});
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
|
|
104
|
+
|
|
105
|
+
private getSkillCodeFromDir(dir: string): string | null {
|
|
106
|
+
if (existsSync(resolve(dir, 'index.py'))) {
|
|
107
|
+
return readFileSync(resolve(dir, 'index.py'), 'utf8');
|
|
108
|
+
}
|
|
109
|
+
if (existsSync(resolve(dir, 'index.js'))) {
|
|
110
|
+
return readFileSync(resolve(dir, 'index.js'), 'utf8');
|
|
111
|
+
}
|
|
112
|
+
if (existsSync(resolve(dir, 'main.py'))) {
|
|
113
|
+
return readFileSync(resolve(dir, 'main.py'), 'utf8');
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
return null;
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
private aggregateOtherMarkdownFiles(dir: string, baseDir = dir): string {
|
|
120
|
+
let combined = '';
|
|
121
|
+
|
|
122
|
+
if (!existsSync(dir)) return combined;
|
|
123
|
+
|
|
124
|
+
const items = readdirSync(dir);
|
|
125
|
+
for (const item of items) {
|
|
126
|
+
const fullPath = resolve(dir, item);
|
|
127
|
+
const stat = statSync(fullPath);
|
|
128
|
+
|
|
129
|
+
if (stat.isDirectory()) {
|
|
130
|
+
if (item !== 'node_modules' && item !== '.git') {
|
|
131
|
+
combined += this.aggregateOtherMarkdownFiles(fullPath, baseDir);
|
|
132
|
+
}
|
|
133
|
+
} else if (stat.isFile() && item.toLowerCase().endsWith('.md') && item.toUpperCase() !== 'SKILL.md') {
|
|
134
|
+
const relPath = relative(baseDir, fullPath);
|
|
135
|
+
const content = readFileSync(fullPath, 'utf8');
|
|
136
|
+
combined += `\n\n--- Content from ${relPath} ---\n\n${content}`;
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
return combined;
|
|
141
|
+
}
|
|
142
|
+
}
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
import Application from '@nocobase/server';
|
|
2
|
+
import { Database } from '@nocobase/database';
|
|
3
|
+
import { parseJsonText, stringifyJsonText } from '../skill-hub/utils/json-fields';
|
|
4
|
+
|
|
5
|
+
type WorkerEnvConfig = {
|
|
6
|
+
npmRegistryUrl?: string;
|
|
7
|
+
npmAuthToken?: string;
|
|
8
|
+
pypiIndexUrl?: string;
|
|
9
|
+
pypiTrustedHost?: string;
|
|
10
|
+
aptMirrorUrl?: string;
|
|
11
|
+
aptGpgKeyUrl?: string;
|
|
12
|
+
customPackages?: {
|
|
13
|
+
python?: string[];
|
|
14
|
+
node?: string[];
|
|
15
|
+
apt?: string[];
|
|
16
|
+
};
|
|
17
|
+
};
|
|
18
|
+
|
|
19
|
+
const DEFAULT_WHITELIST: Record<'python' | 'node' | 'apt', string[]> = {
|
|
20
|
+
python: [
|
|
21
|
+
'python-docx',
|
|
22
|
+
'openpyxl',
|
|
23
|
+
'pandas',
|
|
24
|
+
'matplotlib',
|
|
25
|
+
'Pillow',
|
|
26
|
+
'reportlab',
|
|
27
|
+
'jinja2',
|
|
28
|
+
'pyyaml',
|
|
29
|
+
'tabulate',
|
|
30
|
+
'xlsxwriter',
|
|
31
|
+
'python-pptx',
|
|
32
|
+
],
|
|
33
|
+
node: ['xlsx', 'docx', 'pdfkit', 'csv-parse', 'archiver', 'sharp', 'lodash', 'dayjs'],
|
|
34
|
+
apt: ['python3', 'python3-pip', 'python3-venv'],
|
|
35
|
+
};
|
|
36
|
+
|
|
37
|
+
export class WorkerEnvManager {
|
|
38
|
+
constructor(
|
|
39
|
+
private readonly app: Application,
|
|
40
|
+
private readonly db: Database,
|
|
41
|
+
private readonly storagePath: string,
|
|
42
|
+
) {}
|
|
43
|
+
|
|
44
|
+
async getOrCreateConfig() {
|
|
45
|
+
const repo = this.db.getRepository('skillWorkerConfigs');
|
|
46
|
+
let config = await repo.findOne();
|
|
47
|
+
if (config) return config;
|
|
48
|
+
|
|
49
|
+
config = await repo.create({
|
|
50
|
+
values: {
|
|
51
|
+
retentionHours: 24,
|
|
52
|
+
initStatus: 'idle',
|
|
53
|
+
initProgressPercent: 0,
|
|
54
|
+
packageWhitelist: stringifyJsonText(DEFAULT_WHITELIST, DEFAULT_WHITELIST),
|
|
55
|
+
customPackages: stringifyJsonText({ python: [], node: [], apt: [] }, { python: [], node: [], apt: [] }),
|
|
56
|
+
},
|
|
57
|
+
});
|
|
58
|
+
return config;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
async initEnvironment(config: WorkerEnvConfig) {
|
|
62
|
+
const current = await this.getOrCreateConfig();
|
|
63
|
+
await current.update({
|
|
64
|
+
initStatus: 'running',
|
|
65
|
+
initProgressPercent: 0,
|
|
66
|
+
initProgressLog: 'Queued sandbox environment refresh',
|
|
67
|
+
lastInitLog: '',
|
|
68
|
+
customPackages: stringifyJsonText(config.customPackages || { python: [], node: [], apt: [] }, {
|
|
69
|
+
python: [],
|
|
70
|
+
node: [],
|
|
71
|
+
apt: [],
|
|
72
|
+
}),
|
|
73
|
+
});
|
|
74
|
+
|
|
75
|
+
await this.app.pubSubManager.publish('skill-hub.init-env', {
|
|
76
|
+
...config,
|
|
77
|
+
storagePath: this.storagePath,
|
|
78
|
+
queuedAt: new Date().toISOString(),
|
|
79
|
+
});
|
|
80
|
+
|
|
81
|
+
return 'Sandbox environment refresh queued on available workers.';
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
async executeInit(payload: WorkerEnvConfig) {
|
|
85
|
+
const customPackages = payload.customPackages || { python: [], node: [], apt: [] };
|
|
86
|
+
const whitelist = {
|
|
87
|
+
python: Array.from(new Set([...(DEFAULT_WHITELIST.python || []), ...(customPackages.python || [])])),
|
|
88
|
+
node: Array.from(new Set([...(DEFAULT_WHITELIST.node || []), ...(customPackages.node || [])])),
|
|
89
|
+
apt: Array.from(new Set([...(DEFAULT_WHITELIST.apt || []), ...(customPackages.apt || [])])),
|
|
90
|
+
};
|
|
91
|
+
|
|
92
|
+
await this.app.pubSubManager.publish('skill-hub.init-env.progress', {
|
|
93
|
+
percent: 25,
|
|
94
|
+
log: 'Resolved sandbox package whitelist',
|
|
95
|
+
});
|
|
96
|
+
|
|
97
|
+
await this.app.pubSubManager.publish('skill-hub.init-env.progress', {
|
|
98
|
+
percent: 75,
|
|
99
|
+
log: 'Sandbox runtime uses the local worker environment',
|
|
100
|
+
});
|
|
101
|
+
|
|
102
|
+
await this.app.pubSubManager.publish('skill-hub.init-env.done', {
|
|
103
|
+
status: 'succeeded',
|
|
104
|
+
log:
|
|
105
|
+
'Sandbox environment is ready on this worker. Package installation is managed by the worker image/runtime; whitelist was refreshed.',
|
|
106
|
+
whitelist,
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
parsePackageWhitelist(config: any) {
|
|
111
|
+
return parseJsonText(config?.get?.('packageWhitelist') ?? config?.packageWhitelist, DEFAULT_WHITELIST);
|
|
112
|
+
}
|
|
113
|
+
}
|