veryfront 0.1.48 → 0.1.49
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/esm/cli/app/components/inline-input.d.ts +1 -4
- package/esm/cli/app/components/inline-input.d.ts.map +1 -1
- package/esm/cli/app/components/inline-input.js +1 -1
- package/esm/cli/app/components/list-select.d.ts +0 -8
- package/esm/cli/app/components/list-select.d.ts.map +1 -1
- package/esm/cli/app/components/list-select.js +0 -13
- package/esm/cli/app/operations/project-creation.d.ts +2 -14
- package/esm/cli/app/operations/project-creation.d.ts.map +1 -1
- package/esm/cli/app/operations/project-creation.js +3 -68
- package/esm/cli/app/shell.js +1 -1
- package/esm/cli/app/utils.d.ts +1 -2
- package/esm/cli/app/utils.d.ts.map +1 -1
- package/esm/cli/app/utils.js +1 -17
- package/esm/cli/app/views/dashboard.d.ts +0 -4
- package/esm/cli/app/views/dashboard.d.ts.map +1 -1
- package/esm/cli/app/views/dashboard.js +0 -15
- package/esm/cli/app/views/startup.d.ts +0 -4
- package/esm/cli/app/views/startup.d.ts.map +1 -1
- package/esm/cli/app/views/startup.js +0 -7
- package/esm/cli/auth/login.d.ts.map +1 -1
- package/esm/cli/auth/login.js +1 -2
- package/esm/cli/auth/token-store.js +1 -1
- package/esm/cli/auth/utils.d.ts +2 -1
- package/esm/cli/auth/utils.d.ts.map +1 -1
- package/esm/cli/commands/generate/integration-generator.js +1 -1
- package/esm/cli/commands/install/types.d.ts +2 -2
- package/esm/cli/help/formatters.d.ts +1 -1
- package/esm/cli/help/formatters.d.ts.map +1 -1
- package/esm/cli/help/formatters.js +8 -4
- package/esm/cli/help/main-help.d.ts.map +1 -1
- package/esm/cli/help/main-help.js +2 -2
- package/esm/cli/mcp/server.d.ts +0 -1
- package/esm/cli/mcp/server.d.ts.map +1 -1
- package/esm/cli/mcp/server.js +2 -5
- package/esm/cli/mcp/tools/dev-tools.d.ts +1 -1
- package/esm/cli/mcp/tools/dev-tools.d.ts.map +1 -1
- package/esm/cli/mcp/tools/dev-tools.js +1 -2
- package/esm/cli/mcp/tools/scaffold-tools.d.ts +2 -2
- package/esm/cli/mcp/tools.d.ts +1 -2
- package/esm/cli/mcp/tools.d.ts.map +1 -1
- package/esm/cli/mcp/tools.js +1 -2
- package/esm/cli/shared/reserve-slug.d.ts.map +1 -1
- package/esm/cli/shared/reserve-slug.js +1 -3
- package/esm/cli/sync/ignore.d.ts +1 -1
- package/esm/cli/sync/ignore.d.ts.map +1 -1
- package/esm/cli/sync/ignore.js +22 -18
- package/esm/cli/ui/colors.d.ts +0 -1
- package/esm/cli/ui/colors.d.ts.map +1 -1
- package/esm/cli/ui/colors.js +0 -10
- package/esm/cli/ui/dot-matrix.d.ts.map +1 -1
- package/esm/cli/ui/dot-matrix.js +2 -5
- package/esm/cli/ui/tui.js +2 -3
- package/esm/cli/utils/index.js +1 -2
- package/esm/cli/utils/package-manager.d.ts.map +1 -1
- package/esm/cli/utils/package-manager.js +3 -4
- package/esm/deno.d.ts +3 -0
- package/esm/deno.js +22 -19
- package/esm/src/agent/chat-handler.d.ts.map +1 -1
- package/esm/src/agent/chat-handler.js +8 -23
- package/esm/src/agent/factory.d.ts +0 -8
- package/esm/src/agent/factory.d.ts.map +1 -1
- package/esm/src/agent/factory.js +50 -1
- package/esm/src/agent/index.d.ts +16 -1
- package/esm/src/agent/index.d.ts.map +1 -1
- package/esm/src/agent/index.js +16 -1
- package/esm/src/agent/memory/memory.d.ts +2 -2
- package/esm/src/agent/memory/memory.d.ts.map +1 -1
- package/esm/src/agent/memory/memory.js +0 -1
- package/esm/src/agent/react/use-chat/types.d.ts +2 -0
- package/esm/src/agent/react/use-chat/types.d.ts.map +1 -1
- package/esm/src/agent/react/use-chat/use-chat.d.ts.map +1 -1
- package/esm/src/agent/react/use-chat/use-chat.js +15 -9
- package/esm/src/agent/runtime/index.d.ts +18 -0
- package/esm/src/agent/runtime/index.d.ts.map +1 -1
- package/esm/src/agent/runtime/index.js +167 -36
- package/esm/src/agent/runtime/tool-helpers.d.ts +6 -1
- package/esm/src/agent/runtime/tool-helpers.d.ts.map +1 -1
- package/esm/src/agent/runtime/tool-helpers.js +10 -1
- package/esm/src/agent/schemas/agent.schema.d.ts +4 -4
- package/esm/src/agent/types.d.ts +10 -0
- package/esm/src/agent/types.d.ts.map +1 -1
- package/esm/src/ai/registry-manager.d.ts.map +1 -1
- package/esm/src/ai/registry-manager.js +2 -1
- package/esm/src/build/bundler/code-splitter/manifest-builder.d.ts +0 -2
- package/esm/src/build/bundler/code-splitter/manifest-builder.d.ts.map +1 -1
- package/esm/src/build/bundler/code-splitter/manifest-builder.js +1 -1
- package/esm/src/build/compiler/mdx-compiler/validator.d.ts.map +1 -1
- package/esm/src/build/compiler/mdx-compiler/validator.js +2 -3
- package/esm/src/build/compiler/mdx-to-js.d.ts +0 -2
- package/esm/src/build/compiler/mdx-to-js.d.ts.map +1 -1
- package/esm/src/build/compiler/mdx-to-js.js +0 -81
- package/esm/src/build/index.d.ts +0 -6
- package/esm/src/build/index.d.ts.map +1 -1
- package/esm/src/build/index.js +0 -1
- package/esm/src/build/production-build/build/route-collector.d.ts.map +1 -1
- package/esm/src/build/production-build/build/route-collector.js +2 -3
- package/esm/src/build/production-build/templates.d.ts +5 -9
- package/esm/src/build/production-build/templates.d.ts.map +1 -1
- package/esm/src/build/production-build/templates.js +6 -18
- package/esm/src/build/vendor-cache.d.ts.map +1 -1
- package/esm/src/build/vendor-cache.js +0 -5
- package/esm/src/cache/tokenizing-gateway.d.ts +0 -2
- package/esm/src/cache/tokenizing-gateway.d.ts.map +1 -1
- package/esm/src/cache/tokenizing-gateway.js +1 -3
- package/esm/src/chat/index.d.ts +2 -2
- package/esm/src/chat/index.d.ts.map +1 -1
- package/esm/src/chat/index.js +1 -1
- package/esm/src/config/define-config.d.ts.map +1 -1
- package/esm/src/config/define-config.js +28 -25
- package/esm/src/config/loader.d.ts.map +1 -1
- package/esm/src/config/loader.js +10 -7
- package/esm/src/config/schemas/config.schema.d.ts +58 -12
- package/esm/src/config/schemas/config.schema.d.ts.map +1 -1
- package/esm/src/config/schemas/config.schema.js +12 -0
- package/esm/src/data/data-fetcher.d.ts +1 -2
- package/esm/src/data/data-fetcher.d.ts.map +1 -1
- package/esm/src/data/data-fetcher.js +14 -15
- package/esm/src/data/server-data-fetcher.d.ts +0 -3
- package/esm/src/data/server-data-fetcher.d.ts.map +1 -1
- package/esm/src/data/server-data-fetcher.js +1 -8
- package/esm/src/data/static-data-fetcher.d.ts +1 -3
- package/esm/src/data/static-data-fetcher.d.ts.map +1 -1
- package/esm/src/data/static-data-fetcher.js +1 -3
- package/esm/src/discovery/discovery-engine.d.ts.map +1 -1
- package/esm/src/discovery/discovery-engine.js +19 -1
- package/esm/src/discovery/discovery-utils.d.ts +0 -4
- package/esm/src/discovery/discovery-utils.d.ts.map +1 -1
- package/esm/src/discovery/discovery-utils.js +0 -6
- package/esm/src/discovery/file-discovery.d.ts +3 -1
- package/esm/src/discovery/file-discovery.d.ts.map +1 -1
- package/esm/src/discovery/file-discovery.js +3 -8
- package/esm/src/discovery/handlers/index.d.ts +1 -0
- package/esm/src/discovery/handlers/index.d.ts.map +1 -1
- package/esm/src/discovery/handlers/index.js +1 -0
- package/esm/src/discovery/handlers/skill-handler.d.ts +26 -0
- package/esm/src/discovery/handlers/skill-handler.d.ts.map +1 -0
- package/esm/src/discovery/handlers/skill-handler.js +87 -0
- package/esm/src/discovery/handlers/task-handler.d.ts.map +1 -1
- package/esm/src/discovery/handlers/task-handler.js +1 -5
- package/esm/src/discovery/transpiler.d.ts.map +1 -1
- package/esm/src/discovery/transpiler.js +7 -4
- package/esm/src/discovery/types.d.ts +3 -0
- package/esm/src/discovery/types.d.ts.map +1 -1
- package/esm/src/embedding/resolve.d.ts.map +1 -1
- package/esm/src/embedding/resolve.js +1 -3
- package/esm/src/embedding/upload-handler.d.ts.map +1 -1
- package/esm/src/embedding/upload-handler.js +4 -3
- package/esm/src/embedding/upload-store.js +4 -4
- package/esm/src/errors/error-registry.d.ts +2 -1
- package/esm/src/errors/error-registry.d.ts.map +1 -1
- package/esm/src/errors/http-error.d.ts +1 -2
- package/esm/src/errors/http-error.d.ts.map +1 -1
- package/esm/src/errors/http-error.js +2 -2
- package/esm/src/errors/middleware/cli-error-boundary.d.ts.map +1 -1
- package/esm/src/errors/middleware/cli-error-boundary.js +13 -2
- package/esm/src/errors/middleware/wrap-unknown.d.ts +0 -7
- package/esm/src/errors/middleware/wrap-unknown.d.ts.map +1 -1
- package/esm/src/errors/middleware/wrap-unknown.js +0 -9
- package/esm/src/errors/veryfront-error.d.ts +0 -3
- package/esm/src/errors/veryfront-error.d.ts.map +1 -1
- package/esm/src/errors/veryfront-error.js +0 -5
- package/esm/src/html/schemas/html.schema.d.ts +2 -2
- package/esm/src/html/styles-builder/css-hash-cache.d.ts.map +1 -1
- package/esm/src/html/styles-builder/css-hash-cache.js +1 -2
- package/esm/src/html/styles-builder/plugin-loader.d.ts.map +1 -1
- package/esm/src/html/styles-builder/plugin-loader.js +50 -21
- package/esm/src/html/styles-builder/tailwind-compiler-cache.d.ts.map +1 -1
- package/esm/src/html/styles-builder/tailwind-compiler-cache.js +12 -4
- package/esm/src/html/utils.d.ts +0 -7
- package/esm/src/html/utils.d.ts.map +1 -1
- package/esm/src/html/utils.js +0 -25
- package/esm/src/modules/component-registry/registry.d.ts +0 -3
- package/esm/src/modules/component-registry/registry.d.ts.map +1 -1
- package/esm/src/modules/component-registry/registry.js +0 -3
- package/esm/src/oauth/handlers/callback-handler.d.ts +2 -0
- package/esm/src/oauth/handlers/callback-handler.d.ts.map +1 -1
- package/esm/src/oauth/handlers/callback-handler.js +10 -4
- package/esm/src/oauth/providers/common.d.ts.map +1 -1
- package/esm/src/oauth/providers/common.js +0 -23
- package/esm/src/observability/auto-instrument/react-instrumentation.js +2 -1
- package/esm/src/observability/instruments/instruments-factory.d.ts +1 -1
- package/esm/src/observability/instruments/instruments-factory.d.ts.map +1 -1
- package/esm/src/observability/instruments/instruments-factory.js +5 -4
- package/esm/src/observability/metrics/config.js +5 -4
- package/esm/src/observability/metrics/manager.js +1 -1
- package/esm/src/observability/tracing/span-operations.d.ts.map +1 -1
- package/esm/src/observability/tracing/span-operations.js +14 -8
- package/esm/src/platform/compat/console/node.d.ts +0 -1
- package/esm/src/platform/compat/console/node.d.ts.map +1 -1
- package/esm/src/platform/compat/console/node.js +4 -11
- package/esm/src/platform/compat/fs.d.ts.map +1 -1
- package/esm/src/platform/compat/fs.js +4 -2
- package/esm/src/platform/compat/opaque-deps.d.ts +4 -2
- package/esm/src/platform/compat/opaque-deps.d.ts.map +1 -1
- package/esm/src/platform/compat/opaque-deps.js +1 -1
- package/esm/src/platform/compat/path/basic-operations.d.ts.map +1 -1
- package/esm/src/platform/compat/path/basic-operations.js +8 -7
- package/esm/src/platform/compat/path/resolution.d.ts.map +1 -1
- package/esm/src/platform/compat/path/resolution.js +15 -10
- package/esm/src/platform/compat/path/url-conversion.d.ts.map +1 -1
- package/esm/src/platform/compat/path/url-conversion.js +3 -2
- package/esm/src/platform/compat/process.d.ts +2 -14
- package/esm/src/platform/compat/process.d.ts.map +1 -1
- package/esm/src/platform/compat/process.js +92 -70
- package/esm/src/provider/index.d.ts +1 -1
- package/esm/src/provider/index.d.ts.map +1 -1
- package/esm/src/provider/index.js +1 -1
- package/esm/src/provider/local/ai-sdk-adapter.d.ts.map +1 -1
- package/esm/src/provider/local/ai-sdk-adapter.js +18 -18
- package/esm/src/provider/local/env.d.ts.map +1 -1
- package/esm/src/provider/local/env.js +2 -1
- package/esm/src/provider/model-registry.d.ts +10 -0
- package/esm/src/provider/model-registry.d.ts.map +1 -1
- package/esm/src/provider/model-registry.js +43 -0
- package/esm/src/proxy/retry.d.ts +3 -3
- package/esm/src/proxy/retry.d.ts.map +1 -1
- package/esm/src/proxy/retry.js +0 -7
- package/esm/src/proxy/tracing.d.ts +1 -5
- package/esm/src/proxy/tracing.d.ts.map +1 -1
- package/esm/src/proxy/tracing.js +1 -7
- package/esm/src/react/components/ai/chat/components/code-block.js +1 -1
- package/esm/src/react/components/ai/chat/components/skill-badge.d.ts +12 -0
- package/esm/src/react/components/ai/chat/components/skill-badge.d.ts.map +1 -0
- package/esm/src/react/components/ai/chat/components/skill-badge.js +34 -0
- package/esm/src/react/components/ai/chat/components/step-indicator.js +4 -4
- package/esm/src/react/components/ai/chat/composition/chat-message-list.d.ts.map +1 -1
- package/esm/src/react/components/ai/chat/composition/chat-message-list.js +8 -2
- package/esm/src/react/components/ai/chat/composition/message.d.ts.map +1 -1
- package/esm/src/react/components/ai/chat/composition/message.js +8 -2
- package/esm/src/react/components/ai/chat/index.d.ts +4 -1
- package/esm/src/react/components/ai/chat/index.d.ts.map +1 -1
- package/esm/src/react/components/ai/chat/index.js +4 -3
- package/esm/src/react/components/ai/chat/utils/message-parts.d.ts +2 -0
- package/esm/src/react/components/ai/chat/utils/message-parts.d.ts.map +1 -1
- package/esm/src/react/components/ai/chat/utils/message-parts.js +9 -0
- package/esm/src/react/components/ai/chat-with-sidebar.d.ts +1 -0
- package/esm/src/react/components/ai/chat-with-sidebar.d.ts.map +1 -1
- package/esm/src/react/components/ai/chat-with-sidebar.js +1 -0
- package/esm/src/react/components/ai/chat.d.ts +1 -1
- package/esm/src/react/components/ai/chat.d.ts.map +1 -1
- package/esm/src/react/components/ai/chat.js +1 -1
- package/esm/src/rendering/cache/index.d.ts +1 -5
- package/esm/src/rendering/cache/index.d.ts.map +1 -1
- package/esm/src/rendering/cache/index.js +1 -5
- package/esm/src/rendering/orchestrator/pipeline.d.ts +11 -2
- package/esm/src/rendering/orchestrator/pipeline.d.ts.map +1 -1
- package/esm/src/rendering/shared/context-aware-cache.d.ts.map +1 -1
- package/esm/src/rendering/shared/context-aware-cache.js +0 -4
- package/esm/src/repositories/schemas/index.d.ts +1 -1
- package/esm/src/repositories/schemas/index.d.ts.map +1 -1
- package/esm/src/repositories/schemas/index.js +1 -1
- package/esm/src/repositories/schemas/repository.schema.d.ts +0 -11
- package/esm/src/repositories/schemas/repository.schema.d.ts.map +1 -1
- package/esm/src/repositories/schemas/repository.schema.js +0 -13
- package/esm/src/repositories/types.d.ts +1 -1
- package/esm/src/repositories/types.d.ts.map +1 -1
- package/esm/src/routing/api/module-loader/loader.d.ts.map +1 -1
- package/esm/src/routing/api/module-loader/loader.js +63 -7
- package/esm/src/routing/api/openapi/path-utils.d.ts +0 -19
- package/esm/src/routing/api/openapi/path-utils.d.ts.map +1 -1
- package/esm/src/routing/api/openapi/path-utils.js +0 -34
- package/esm/src/routing/api/openapi/spec-generator.d.ts.map +1 -1
- package/esm/src/routing/api/openapi/spec-generator.js +1 -19
- package/esm/src/routing/api/openapi/types.d.ts +1 -0
- package/esm/src/routing/api/openapi/types.d.ts.map +1 -1
- package/esm/src/routing/api/openapi/types.js +18 -0
- package/esm/src/sandbox/sandbox.d.ts +1 -0
- package/esm/src/sandbox/sandbox.d.ts.map +1 -1
- package/esm/src/sandbox/sandbox.js +7 -8
- package/esm/src/security/http/cors/constants.d.ts +0 -2
- package/esm/src/security/http/cors/constants.d.ts.map +1 -1
- package/esm/src/security/http/cors/constants.js +0 -2
- package/esm/src/security/http/response/index.d.ts +3 -4
- package/esm/src/security/http/response/index.d.ts.map +1 -1
- package/esm/src/security/http/response/index.js +2 -3
- package/esm/src/server/context/enriched-context.d.ts +0 -8
- package/esm/src/server/context/enriched-context.d.ts.map +1 -1
- package/esm/src/server/context/enriched-context.js +1 -12
- package/esm/src/server/dev-server/server.d.ts.map +1 -1
- package/esm/src/server/dev-server/server.js +11 -4
- package/esm/src/server/dev-ui/manifest.d.ts +20 -20
- package/esm/src/server/dev-ui/manifest.js +20 -20
- package/esm/src/server/handlers/dev/framework-candidates.generated.d.ts.map +1 -1
- package/esm/src/server/handlers/dev/framework-candidates.generated.js +426 -179
- package/esm/src/server/runtime-handler/index.d.ts.map +1 -1
- package/esm/src/server/runtime-handler/index.js +14 -24
- package/esm/src/server/shared/renderer/memory/pressure.d.ts +0 -7
- package/esm/src/server/shared/renderer/memory/pressure.d.ts.map +1 -1
- package/esm/src/server/shared/renderer/memory/pressure.js +1 -13
- package/esm/src/server/utils/domain-lookup.d.ts +0 -4
- package/esm/src/server/utils/domain-lookup.d.ts.map +1 -1
- package/esm/src/server/utils/domain-lookup.js +0 -3
- package/esm/src/skill/allowed-tools.d.ts +54 -0
- package/esm/src/skill/allowed-tools.d.ts.map +1 -0
- package/esm/src/skill/allowed-tools.js +87 -0
- package/esm/src/skill/executor.d.ts +28 -0
- package/esm/src/skill/executor.d.ts.map +1 -0
- package/esm/src/skill/executor.js +187 -0
- package/esm/src/skill/index.d.ts +19 -0
- package/esm/src/skill/index.d.ts.map +1 -0
- package/esm/src/skill/index.js +24 -0
- package/esm/src/skill/parser.d.ts +30 -0
- package/esm/src/skill/parser.d.ts.map +1 -0
- package/esm/src/skill/parser.js +162 -0
- package/esm/src/skill/path-safety.d.ts +22 -0
- package/esm/src/skill/path-safety.d.ts.map +1 -0
- package/esm/src/skill/path-safety.js +156 -0
- package/esm/src/skill/prompt-augmentation.d.ts +19 -0
- package/esm/src/skill/prompt-augmentation.d.ts.map +1 -0
- package/esm/src/skill/prompt-augmentation.js +36 -0
- package/esm/src/skill/registry.d.ts +25 -0
- package/esm/src/skill/registry.d.ts.map +1 -0
- package/esm/src/skill/registry.js +42 -0
- package/esm/src/skill/tools.d.ts +27 -0
- package/esm/src/skill/tools.d.ts.map +1 -0
- package/esm/src/skill/tools.js +149 -0
- package/esm/src/skill/types.d.ts +85 -0
- package/esm/src/skill/types.d.ts.map +1 -0
- package/esm/src/skill/types.js +27 -0
- package/esm/src/studio/bridge/bridge-bundle.generated.d.ts +1 -1
- package/esm/src/studio/bridge/bridge-bundle.generated.d.ts.map +1 -1
- package/esm/src/studio/bridge/bridge-bundle.generated.js +1 -1
- package/esm/src/studio/element-selector-injector.d.ts +0 -2
- package/esm/src/studio/element-selector-injector.d.ts.map +1 -1
- package/esm/src/task/runner.d.ts +6 -0
- package/esm/src/task/runner.d.ts.map +1 -1
- package/esm/src/task/runner.js +8 -8
- package/esm/src/tool/factory.js +31 -39
- package/esm/src/transforms/esm/http-cache-helpers.d.ts +0 -8
- package/esm/src/transforms/esm/http-cache-helpers.d.ts.map +1 -1
- package/esm/src/transforms/esm/http-cache-helpers.js +0 -20
- package/esm/src/transforms/esm/path-resolver.d.ts +0 -14
- package/esm/src/transforms/esm/path-resolver.d.ts.map +1 -1
- package/esm/src/transforms/esm/path-resolver.js +1 -92
- package/esm/src/transforms/esm/source-url-embed.d.ts +0 -14
- package/esm/src/transforms/esm/source-url-embed.d.ts.map +1 -1
- package/esm/src/transforms/esm/source-url-embed.js +0 -47
- package/esm/src/transforms/esm/transform-cache.d.ts.map +1 -1
- package/esm/src/transforms/esm/transform-cache.js +2 -6
- package/esm/src/transforms/mdx/index.d.ts +0 -1
- package/esm/src/transforms/mdx/index.d.ts.map +1 -1
- package/esm/src/transforms/mdx/index.js +0 -4
- package/esm/src/transforms/pipeline/context.d.ts +0 -1
- package/esm/src/transforms/pipeline/context.d.ts.map +1 -1
- package/esm/src/transforms/pipeline/context.js +0 -1
- package/esm/src/transforms/pipeline/index.d.ts +1 -2
- package/esm/src/transforms/pipeline/index.d.ts.map +1 -1
- package/esm/src/transforms/pipeline/index.js +0 -3
- package/esm/src/transforms/pipeline/stages/ssr-http-cache.d.ts.map +1 -1
- package/esm/src/transforms/pipeline/stages/ssr-http-cache.js +0 -1
- package/esm/src/types/entities/getEntityInfo.js +1 -1
- package/esm/src/types/index.d.ts +2 -13
- package/esm/src/types/index.d.ts.map +1 -1
- package/esm/src/types/server.d.ts +2 -1
- package/esm/src/types/server.d.ts.map +1 -1
- package/esm/src/utils/cache-file-ops.d.ts +1 -1
- package/esm/src/utils/cache-file-ops.d.ts.map +1 -1
- package/esm/src/utils/cache-file-ops.js +5 -6
- package/esm/src/utils/lru-wrapper.d.ts.map +1 -1
- package/esm/src/utils/lru-wrapper.js +2 -4
- package/esm/src/workflow/claude-code/event-publisher.d.ts +0 -4
- package/esm/src/workflow/claude-code/event-publisher.d.ts.map +1 -1
- package/esm/src/workflow/claude-code/event-publisher.js +2 -6
- package/esm/src/workflow/executor/workflow-executor.d.ts.map +1 -1
- package/esm/src/workflow/executor/workflow-executor.js +6 -1
- package/esm/src/workflow/react/use-workflow-list.d.ts.map +1 -1
- package/esm/src/workflow/react/use-workflow-list.js +2 -1
- package/esm/src/workflow/schemas/workflow.schema.d.ts +8 -8
- package/package.json +1 -2
- package/src/cli/app/components/inline-input.ts +0 -5
- package/src/cli/app/components/list-select.ts +0 -21
- package/src/cli/app/operations/project-creation.ts +4 -109
- package/src/cli/app/shell.ts +1 -1
- package/src/cli/app/utils.ts +0 -22
- package/src/cli/app/views/dashboard.ts +0 -17
- package/src/cli/app/views/startup.ts +0 -13
- package/src/cli/auth/login.ts +1 -2
- package/src/cli/auth/token-store.ts +1 -1
- package/src/cli/auth/utils.ts +2 -1
- package/src/cli/commands/generate/integration-generator.ts +1 -1
- package/src/cli/help/formatters.ts +11 -4
- package/src/cli/help/main-help.ts +2 -3
- package/src/cli/mcp/server.ts +2 -5
- package/src/cli/mcp/tools/dev-tools.ts +1 -2
- package/src/cli/mcp/tools.ts +8 -2
- package/src/cli/shared/reserve-slug.ts +1 -4
- package/src/cli/sync/ignore.ts +26 -21
- package/src/cli/ui/colors.ts +0 -12
- package/src/cli/ui/dot-matrix.ts +3 -6
- package/src/cli/ui/tui.ts +3 -3
- package/src/cli/utils/index.ts +1 -1
- package/src/cli/utils/package-manager.ts +3 -4
- package/src/deno.js +22 -19
- package/src/src/agent/chat-handler.ts +8 -23
- package/src/src/agent/factory.ts +58 -9
- package/src/src/agent/index.ts +16 -1
- package/src/src/agent/memory/memory.ts +0 -9
- package/src/src/agent/react/use-chat/types.ts +2 -0
- package/src/src/agent/react/use-chat/use-chat.ts +15 -9
- package/src/src/agent/runtime/index.ts +213 -35
- package/src/src/agent/runtime/tool-helpers.ts +9 -0
- package/src/src/agent/types.ts +10 -0
- package/src/src/ai/registry-manager.ts +2 -1
- package/src/src/build/bundler/code-splitter/manifest-builder.ts +1 -1
- package/src/src/build/compiler/mdx-compiler/validator.ts +3 -7
- package/src/src/build/compiler/mdx-to-js.ts +0 -101
- package/src/src/build/index.ts +0 -8
- package/src/src/build/production-build/build/route-collector.ts +2 -4
- package/src/src/build/production-build/templates.ts +9 -18
- package/src/src/build/vendor-cache.ts +0 -6
- package/src/src/cache/tokenizing-gateway.ts +1 -9
- package/src/src/chat/index.ts +3 -0
- package/src/src/config/define-config.ts +30 -29
- package/src/src/config/loader.ts +10 -9
- package/src/src/config/schemas/config.schema.ts +12 -0
- package/src/src/data/data-fetcher.ts +15 -21
- package/src/src/data/server-data-fetcher.ts +1 -8
- package/src/src/data/static-data-fetcher.ts +1 -6
- package/src/src/discovery/discovery-engine.ts +27 -0
- package/src/src/discovery/discovery-utils.ts +0 -7
- package/src/src/discovery/file-discovery.ts +3 -9
- package/src/src/discovery/handlers/index.ts +1 -0
- package/src/src/discovery/handlers/skill-handler.ts +123 -0
- package/src/src/discovery/handlers/task-handler.ts +1 -5
- package/src/src/discovery/transpiler.ts +7 -4
- package/src/src/discovery/types.ts +3 -0
- package/src/src/embedding/resolve.ts +1 -3
- package/src/src/embedding/upload-handler.ts +7 -3
- package/src/src/embedding/upload-store.ts +4 -4
- package/src/src/errors/error-registry.ts +2 -2
- package/src/src/errors/http-error.ts +7 -3
- package/src/src/errors/middleware/cli-error-boundary.ts +28 -2
- package/src/src/errors/middleware/wrap-unknown.ts +0 -10
- package/src/src/errors/veryfront-error.ts +0 -9
- package/src/src/html/styles-builder/css-hash-cache.ts +5 -2
- package/src/src/html/styles-builder/plugin-loader.ts +58 -21
- package/src/src/html/styles-builder/tailwind-compiler-cache.ts +11 -4
- package/src/src/html/utils.ts +0 -33
- package/src/src/modules/component-registry/registry.ts +0 -3
- package/src/src/modules/server/websocket-handler.ts +1 -1
- package/src/src/oauth/handlers/callback-handler.ts +17 -5
- package/src/src/oauth/providers/base.ts +3 -3
- package/src/src/oauth/providers/common.ts +0 -23
- package/src/src/observability/auto-instrument/react-instrumentation.ts +2 -2
- package/src/src/observability/instruments/instruments-factory.ts +6 -6
- package/src/src/observability/metrics/config.ts +5 -5
- package/src/src/observability/metrics/manager.ts +1 -1
- package/src/src/observability/tracing/span-operations.ts +14 -9
- package/src/src/platform/compat/console/node.ts +4 -14
- package/src/src/platform/compat/fs.ts +14 -3
- package/src/src/platform/compat/opaque-deps.ts +10 -5
- package/src/src/platform/compat/path/basic-operations.ts +9 -7
- package/src/src/platform/compat/path/resolution.ts +15 -8
- package/src/src/platform/compat/path/url-conversion.ts +10 -6
- package/src/src/platform/compat/process.ts +133 -76
- package/src/src/provider/index.ts +1 -0
- package/src/src/provider/local/ai-sdk-adapter.ts +40 -37
- package/src/src/provider/local/env.ts +4 -1
- package/src/src/provider/model-registry.ts +47 -0
- package/src/src/proxy/retry.ts +0 -9
- package/src/src/proxy/tracing.ts +1 -9
- package/src/src/react/components/ai/chat/components/code-block.tsx +1 -1
- package/src/src/react/components/ai/chat/components/skill-badge.tsx +51 -0
- package/src/src/react/components/ai/chat/components/step-indicator.tsx +4 -4
- package/src/src/react/components/ai/chat/composition/chat-message-list.tsx +9 -2
- package/src/src/react/components/ai/chat/composition/message.tsx +9 -2
- package/src/src/react/components/ai/chat/index.tsx +6 -1
- package/src/src/react/components/ai/chat/utils/message-parts.ts +11 -0
- package/src/src/react/components/ai/chat-with-sidebar.tsx +2 -0
- package/src/src/react/components/ai/chat.tsx +3 -0
- package/src/src/rendering/cache/index.ts +12 -5
- package/src/src/rendering/orchestrator/pipeline.ts +12 -2
- package/src/src/rendering/renderer.ts +1 -1
- package/src/src/rendering/shared/context-aware-cache.ts +0 -5
- package/src/src/repositories/schemas/index.ts +0 -2
- package/src/src/repositories/schemas/repository.schema.ts +0 -15
- package/src/src/repositories/types.ts +1 -6
- package/src/src/routing/api/module-loader/loader.ts +88 -3
- package/src/src/routing/api/openapi/path-utils.ts +0 -39
- package/src/src/routing/api/openapi/spec-generator.ts +1 -20
- package/src/src/routing/api/openapi/types.ts +20 -0
- package/src/src/sandbox/sandbox.ts +8 -8
- package/src/src/security/http/cors/constants.ts +0 -4
- package/src/src/security/http/response/index.ts +3 -9
- package/src/src/server/context/enriched-context.ts +1 -19
- package/src/src/server/dev-server/server.ts +11 -4
- package/src/src/server/dev-ui/manifest.js +20 -20
- package/src/src/server/handlers/dev/framework-candidates.generated.ts +426 -179
- package/src/src/server/runtime-handler/index.ts +17 -28
- package/src/src/server/shared/renderer/memory/pressure.ts +2 -15
- package/src/src/server/utils/domain-lookup.ts +0 -4
- package/src/src/skill/allowed-tools.ts +107 -0
- package/src/src/skill/executor.ts +215 -0
- package/src/src/skill/index.ts +60 -0
- package/src/src/skill/parser.ts +214 -0
- package/src/src/skill/path-safety.ts +203 -0
- package/src/src/skill/prompt-augmentation.ts +48 -0
- package/src/src/skill/registry.ts +51 -0
- package/src/src/skill/tools.ts +197 -0
- package/src/src/skill/types.ts +107 -0
- package/src/src/studio/bridge/bridge-bundle.generated.ts +1 -1
- package/src/src/studio/element-selector-injector.ts +0 -2
- package/src/src/task/runner.ts +10 -8
- package/src/src/tool/factory.ts +54 -54
- package/src/src/transforms/esm/http-cache-helpers.ts +0 -20
- package/src/src/transforms/esm/path-resolver.ts +1 -140
- package/src/src/transforms/esm/source-url-embed.ts +0 -53
- package/src/src/transforms/esm/transform-cache.ts +3 -7
- package/src/src/transforms/mdx/index.ts +0 -5
- package/src/src/transforms/pipeline/context.ts +0 -2
- package/src/src/transforms/pipeline/index.ts +0 -4
- package/src/src/transforms/pipeline/stages/ssr-http-cache.ts +0 -1
- package/src/src/types/entities/getEntityInfo.ts +1 -1
- package/src/src/types/index.ts +1 -20
- package/src/src/types/server.ts +1 -1
- package/src/src/utils/cache-file-ops.ts +5 -5
- package/src/src/utils/lru-wrapper.ts +2 -8
- package/src/src/workflow/claude-code/event-publisher.ts +13 -4
- package/src/src/workflow/executor/workflow-executor.ts +7 -2
- package/src/src/workflow/react/use-workflow-list.ts +3 -2
- package/esm/src/transforms/mdx/parser.d.ts +0 -4
- package/esm/src/transforms/mdx/parser.d.ts.map +0 -1
- package/esm/src/transforms/mdx/parser.js +0 -49
- package/src/src/transforms/mdx/parser.ts +0 -65
|
@@ -324,10 +324,24 @@ export function createVeryfrontHandler(
|
|
|
324
324
|
// proceeding would cause cryptic 500s deep in the rendering pipeline.
|
|
325
325
|
if (isProxyMode && !isLightweightPath(url.pathname) && !isWebSocketPath(url.pathname)) {
|
|
326
326
|
const token = req.headers.get("x-token");
|
|
327
|
-
|
|
328
|
-
|
|
327
|
+
|
|
328
|
+
const missingHeader = !headers.projectSlug
|
|
329
|
+
? {
|
|
330
|
+
error: "Missing project context",
|
|
331
|
+
detail: "x-project-slug header is required in proxy mode",
|
|
332
|
+
}
|
|
333
|
+
: !token
|
|
334
|
+
? {
|
|
335
|
+
error: "Missing authentication context",
|
|
336
|
+
detail: "x-token header is required in proxy mode",
|
|
337
|
+
}
|
|
338
|
+
: null;
|
|
339
|
+
|
|
340
|
+
if (missingHeader) {
|
|
341
|
+
logger.error(missingHeader.detail, {
|
|
329
342
|
pathname: url.pathname,
|
|
330
343
|
domain,
|
|
344
|
+
projectSlug: headers.projectSlug,
|
|
331
345
|
host: req.headers.get("host"),
|
|
332
346
|
forwardedHost: req.headers.get("x-forwarded-host"),
|
|
333
347
|
});
|
|
@@ -340,32 +354,7 @@ export function createVeryfrontHandler(
|
|
|
340
354
|
completeIsolatedRequest(headers.projectSlug, lifecycle.shouldCheckIsolation, false);
|
|
341
355
|
endRequestTracing(spanInfo.span, 502);
|
|
342
356
|
return new dntShim.Response(
|
|
343
|
-
JSON.stringify(
|
|
344
|
-
error: "Missing project context",
|
|
345
|
-
detail: "x-project-slug header is required in proxy mode",
|
|
346
|
-
}),
|
|
347
|
-
{ status: 502, headers: { "Content-Type": "application/json" } },
|
|
348
|
-
);
|
|
349
|
-
}
|
|
350
|
-
if (!token) {
|
|
351
|
-
logger.error("Missing required x-token header in proxy mode", {
|
|
352
|
-
pathname: url.pathname,
|
|
353
|
-
domain,
|
|
354
|
-
projectSlug: headers.projectSlug,
|
|
355
|
-
});
|
|
356
|
-
endContentMetrics({
|
|
357
|
-
requestId: lifecycle.requestId,
|
|
358
|
-
pathname: url.pathname,
|
|
359
|
-
mode: "proxy",
|
|
360
|
-
});
|
|
361
|
-
completeRequestTracking(lifecycle.requestId, 502, false);
|
|
362
|
-
completeIsolatedRequest(headers.projectSlug, lifecycle.shouldCheckIsolation, false);
|
|
363
|
-
endRequestTracing(spanInfo.span, 502);
|
|
364
|
-
return new dntShim.Response(
|
|
365
|
-
JSON.stringify({
|
|
366
|
-
error: "Missing authentication context",
|
|
367
|
-
detail: "x-token header is required in proxy mode",
|
|
368
|
-
}),
|
|
357
|
+
JSON.stringify(missingHeader),
|
|
369
358
|
{ status: 502, headers: { "Content-Type": "application/json" } },
|
|
370
359
|
);
|
|
371
360
|
}
|
|
@@ -21,7 +21,7 @@ import { getEnvNumber, getEnvString } from "../../../../platform/compat/process.
|
|
|
21
21
|
const memoryPressureLog = rendererLogger.component("memory-pressure");
|
|
22
22
|
const rendererLog = rendererLogger.component("renderer");
|
|
23
23
|
|
|
24
|
-
|
|
24
|
+
type MemoryPressureLevel = "normal" | "warning" | "high" | "critical";
|
|
25
25
|
|
|
26
26
|
function parseEnvThreshold(name: string, fallback: number): number {
|
|
27
27
|
const value = getEnvString(name);
|
|
@@ -42,7 +42,7 @@ const THRESHOLDS = {
|
|
|
42
42
|
CRITICAL: parseEnvThreshold("MEMORY_CRITICAL_THRESHOLD", 80),
|
|
43
43
|
};
|
|
44
44
|
|
|
45
|
-
|
|
45
|
+
function getMemoryPressure(): { level: MemoryPressureLevel; heapUsedPercent: number } {
|
|
46
46
|
const { heapUsedPercent } = getHeapStats();
|
|
47
47
|
|
|
48
48
|
if (heapUsedPercent >= THRESHOLDS.CRITICAL) return { level: "critical", heapUsedPercent };
|
|
@@ -59,16 +59,3 @@ export function shouldRejectDueToMemory(): boolean {
|
|
|
59
59
|
rendererLog.warn("Rejecting request - memory critical", { heapUsedPercent });
|
|
60
60
|
return true;
|
|
61
61
|
}
|
|
62
|
-
|
|
63
|
-
export function getCacheTTLMultiplier(): number {
|
|
64
|
-
const { level } = getMemoryPressure();
|
|
65
|
-
|
|
66
|
-
if (level === "warning") return 0.5;
|
|
67
|
-
if (level === "high" || level === "critical") return 0.25;
|
|
68
|
-
return 1.0;
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
export function shouldEvictAggressively(): boolean {
|
|
72
|
-
const { level } = getMemoryPressure();
|
|
73
|
-
return level === "high" || level === "critical";
|
|
74
|
-
}
|
|
@@ -227,10 +227,6 @@ export function clearDomainCache(): void {
|
|
|
227
227
|
logger.debug("Cache cleared");
|
|
228
228
|
}
|
|
229
229
|
|
|
230
|
-
export function getDomainCacheStats(): { size: number; maxSize: number } {
|
|
231
|
-
return { size: domainCache.size, maxSize: DOMAIN_CACHE_MAX_ENTRIES };
|
|
232
|
-
}
|
|
233
|
-
|
|
234
230
|
/**
|
|
235
231
|
* Inject a CacheRepository for testing or distributed caching.
|
|
236
232
|
* Call with null to restore default Map-based caching.
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Allowed-Tools Enforcement
|
|
3
|
+
*
|
|
4
|
+
* Dual-layer enforcement for skill tool access restrictions.
|
|
5
|
+
* Layer 1: Filter tool definitions before sending to model (planning-time)
|
|
6
|
+
* Layer 2: Check individual tool calls at execution time
|
|
7
|
+
*
|
|
8
|
+
* @module
|
|
9
|
+
*/
|
|
10
|
+
|
|
11
|
+
import { SKILL_ALLOWED_TOOL_PATTERN_REGEX, SKILL_TOOL_IDS } from "./types.js";
|
|
12
|
+
import { createError, toError } from "../errors/veryfront-error.js";
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
* Check if a tool name matches a single allowed-tools pattern.
|
|
16
|
+
*
|
|
17
|
+
* Supports:
|
|
18
|
+
* - Exact match: "Read" matches "Read"
|
|
19
|
+
* - Prefix wildcard: "api:*" matches "api:list-users"
|
|
20
|
+
*/
|
|
21
|
+
export function matchesAllowedTool(toolName: string, pattern: string): boolean {
|
|
22
|
+
// Invalid patterns always fail (fail closed)
|
|
23
|
+
if (!SKILL_ALLOWED_TOOL_PATTERN_REGEX.test(pattern)) {
|
|
24
|
+
return false;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
// Prefix wildcard
|
|
28
|
+
if (pattern.endsWith(":*")) {
|
|
29
|
+
const prefix = pattern.slice(0, -1); // keep the colon: "api:"
|
|
30
|
+
return toolName.startsWith(prefix);
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
// Exact match
|
|
34
|
+
return toolName === pattern;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
/** Minimal tool definition shape for filtering */
|
|
38
|
+
export interface FilterableToolDefinition {
|
|
39
|
+
name: string;
|
|
40
|
+
description: string;
|
|
41
|
+
parameters: unknown;
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
/**
|
|
45
|
+
* Layer 1: Filter tool definitions before sending to model.
|
|
46
|
+
*
|
|
47
|
+
* Removes tools not in the allowed list. Always-allowed tools
|
|
48
|
+
* (skill system tools) pass through regardless.
|
|
49
|
+
*
|
|
50
|
+
* @param tools - Full list of tool definitions
|
|
51
|
+
* @param allowedTools - Allowed tool patterns, or undefined for no restrictions
|
|
52
|
+
* @returns Filtered tool definitions
|
|
53
|
+
*/
|
|
54
|
+
export function filterToolsForSkill<T extends FilterableToolDefinition>(
|
|
55
|
+
tools: T[],
|
|
56
|
+
allowedTools: string[] | undefined,
|
|
57
|
+
): T[] {
|
|
58
|
+
if (allowedTools === undefined) {
|
|
59
|
+
return tools;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
return tools.filter((tool) => {
|
|
63
|
+
if (SKILL_TOOL_IDS.has(tool.name)) return true;
|
|
64
|
+
return allowedTools.some((pattern) => matchesAllowedTool(tool.name, pattern));
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
/**
|
|
69
|
+
* Layer 2: Check if a specific tool call is allowed at execution time.
|
|
70
|
+
*
|
|
71
|
+
* @param toolName - Name of the tool being called
|
|
72
|
+
* @param allowedTools - Allowed tool patterns, or undefined for no restrictions
|
|
73
|
+
* @returns true if the tool call is allowed
|
|
74
|
+
*/
|
|
75
|
+
export function isToolAllowedBySkill(
|
|
76
|
+
toolName: string,
|
|
77
|
+
allowedTools: string[] | undefined,
|
|
78
|
+
): boolean {
|
|
79
|
+
if (allowedTools === undefined) return true;
|
|
80
|
+
if (SKILL_TOOL_IDS.has(toolName)) return true;
|
|
81
|
+
return allowedTools.some((pattern) => matchesAllowedTool(toolName, pattern));
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
/**
|
|
85
|
+
* Validate allowed-tool patterns at parse time.
|
|
86
|
+
*
|
|
87
|
+
* Ensures each pattern matches the expected format.
|
|
88
|
+
* Rejects unsupported patterns with a descriptive error (fail closed).
|
|
89
|
+
*
|
|
90
|
+
* @param patterns - Array of tool patterns to validate
|
|
91
|
+
* @returns Validated patterns (same array if all valid)
|
|
92
|
+
* @throws If any pattern is invalid
|
|
93
|
+
*/
|
|
94
|
+
export function validateAllowedToolPatterns(patterns: string[]): string[] {
|
|
95
|
+
for (const pattern of patterns) {
|
|
96
|
+
if (!SKILL_ALLOWED_TOOL_PATTERN_REGEX.test(pattern)) {
|
|
97
|
+
throw toError(
|
|
98
|
+
createError({
|
|
99
|
+
type: "agent",
|
|
100
|
+
message: `Invalid allowed-tools pattern "${pattern}". ` +
|
|
101
|
+
`Only exact tool IDs (e.g. "Read") and prefix wildcards (e.g. "api:*") are supported.`,
|
|
102
|
+
}),
|
|
103
|
+
);
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
return patterns;
|
|
107
|
+
}
|
|
@@ -0,0 +1,215 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Skill Script Executor
|
|
3
|
+
*
|
|
4
|
+
* Executes skill scripts using cross-runtime subprocess execution.
|
|
5
|
+
*
|
|
6
|
+
* @module
|
|
7
|
+
*/
|
|
8
|
+
import * as dntShim from "../../_dnt.shims.js";
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
import { getEnv, runCommand } from "../platform/compat/process.js";
|
|
12
|
+
import { isDeno } from "../platform/compat/runtime.js";
|
|
13
|
+
import { extname } from "../platform/compat/path/index.js";
|
|
14
|
+
import { readTextFile } from "../platform/compat/fs.js";
|
|
15
|
+
import { createError, toError } from "../errors/veryfront-error.js";
|
|
16
|
+
import type { SkillScriptExecutor, SkillScriptExecutorInput, SkillScriptResult } from "./types.js";
|
|
17
|
+
|
|
18
|
+
const DEFAULT_SCRIPT_TIMEOUT_MS = 60_000;
|
|
19
|
+
const MAX_SCRIPT_TIMEOUT_MS = 300_000;
|
|
20
|
+
const TIMEOUT_EXIT_CODE = 124;
|
|
21
|
+
const ENV_KEY_REGEX = /^[A-Za-z_][A-Za-z0-9_]*$/;
|
|
22
|
+
const TIMEOUT_SENTINEL = Symbol("skill-script-timeout");
|
|
23
|
+
|
|
24
|
+
function resolveTimeoutMs(timeoutMs?: number): number {
|
|
25
|
+
if (timeoutMs === undefined || !Number.isFinite(timeoutMs) || timeoutMs <= 0) {
|
|
26
|
+
return DEFAULT_SCRIPT_TIMEOUT_MS;
|
|
27
|
+
}
|
|
28
|
+
return Math.min(Math.floor(timeoutMs), MAX_SCRIPT_TIMEOUT_MS);
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
async function withTimeout<T>(
|
|
32
|
+
promise: Promise<T>,
|
|
33
|
+
timeoutMs: number,
|
|
34
|
+
): Promise<T | typeof TIMEOUT_SENTINEL> {
|
|
35
|
+
let timeoutId: ReturnType<typeof dntShim.setTimeout> | undefined;
|
|
36
|
+
const timeoutPromise = new Promise<typeof TIMEOUT_SENTINEL>((resolve) => {
|
|
37
|
+
timeoutId = dntShim.setTimeout(() => resolve(TIMEOUT_SENTINEL), timeoutMs);
|
|
38
|
+
});
|
|
39
|
+
|
|
40
|
+
try {
|
|
41
|
+
return await Promise.race([promise, timeoutPromise]);
|
|
42
|
+
} finally {
|
|
43
|
+
if (timeoutId) clearTimeout(timeoutId);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
function timeoutResult(timeoutMs: number): SkillScriptResult {
|
|
48
|
+
return {
|
|
49
|
+
stdout: "",
|
|
50
|
+
stderr: `Script execution timed out after ${timeoutMs}ms`,
|
|
51
|
+
exitCode: TIMEOUT_EXIT_CODE,
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
function shellEscapeArg(value: string): string {
|
|
56
|
+
return `'${value.replaceAll("'", "'\"'\"'")}'`;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
function buildShellCommand(parts: string[]): string {
|
|
60
|
+
return parts.map(shellEscapeArg).join(" ");
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
function formatEnvAssignments(env?: Record<string, string>): string[] {
|
|
64
|
+
if (!env) return [];
|
|
65
|
+
return Object.entries(env).map(([key, value]) => {
|
|
66
|
+
if (!ENV_KEY_REGEX.test(key)) {
|
|
67
|
+
throw toError(
|
|
68
|
+
createError({
|
|
69
|
+
type: "agent",
|
|
70
|
+
message: `Invalid environment variable name: "${key}"`,
|
|
71
|
+
}),
|
|
72
|
+
);
|
|
73
|
+
}
|
|
74
|
+
return `${key}=${value}`;
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
function createSandboxScriptPath(scriptPath: string): string {
|
|
79
|
+
const ext = extname(scriptPath) || ".sh";
|
|
80
|
+
const suffix = Math.random().toString(36).slice(2, 10);
|
|
81
|
+
return `/tmp/veryfront-skill-script-${Date.now()}-${suffix}${ext}`;
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
/**
|
|
85
|
+
* Detect the runtime command for a script based on file extension.
|
|
86
|
+
*/
|
|
87
|
+
export function detectRuntime(scriptPath: string): { command: string; args: string[] } {
|
|
88
|
+
const ext = extname(scriptPath).toLowerCase();
|
|
89
|
+
|
|
90
|
+
switch (ext) {
|
|
91
|
+
case ".py":
|
|
92
|
+
return { command: "python3", args: [scriptPath] };
|
|
93
|
+
case ".sh":
|
|
94
|
+
return { command: "bash", args: [scriptPath] };
|
|
95
|
+
case ".js":
|
|
96
|
+
return { command: "node", args: [scriptPath] };
|
|
97
|
+
case ".ts":
|
|
98
|
+
if (isDeno) {
|
|
99
|
+
return {
|
|
100
|
+
command: "deno",
|
|
101
|
+
args: ["run", "--allow-read", "--allow-env", "--allow-net", "--allow-write", scriptPath],
|
|
102
|
+
};
|
|
103
|
+
}
|
|
104
|
+
return { command: "npx", args: ["tsx", scriptPath] };
|
|
105
|
+
default:
|
|
106
|
+
return { command: scriptPath, args: [] };
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
/**
|
|
111
|
+
* Local script executor using runCommand() from the compat layer.
|
|
112
|
+
*/
|
|
113
|
+
export class LocalScriptExecutor implements SkillScriptExecutor {
|
|
114
|
+
async execute(input: SkillScriptExecutorInput): Promise<SkillScriptResult> {
|
|
115
|
+
const timeoutMs = resolveTimeoutMs(input.timeoutMs);
|
|
116
|
+
const { command, args: runtimeArgs } = detectRuntime(input.scriptPath);
|
|
117
|
+
const allArgs = [...runtimeArgs, ...(input.args ?? [])];
|
|
118
|
+
|
|
119
|
+
// Remove the script path from args if it's already the command
|
|
120
|
+
const finalArgs = command === input.scriptPath ? (input.args ?? []) : allArgs;
|
|
121
|
+
|
|
122
|
+
const result = await runCommand(command, {
|
|
123
|
+
args: finalArgs,
|
|
124
|
+
cwd: input.cwd,
|
|
125
|
+
env: input.env,
|
|
126
|
+
capture: true,
|
|
127
|
+
timeoutMs,
|
|
128
|
+
});
|
|
129
|
+
|
|
130
|
+
return {
|
|
131
|
+
stdout: result.stdout ?? "",
|
|
132
|
+
stderr: result.stderr ?? "",
|
|
133
|
+
exitCode: result.code,
|
|
134
|
+
};
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
/**
|
|
139
|
+
* Cloud script executor using sandbox.
|
|
140
|
+
* Requires SANDBOX_AUTH_TOKEN environment variable.
|
|
141
|
+
*/
|
|
142
|
+
export class CloudScriptExecutor implements SkillScriptExecutor {
|
|
143
|
+
async execute(input: SkillScriptExecutorInput): Promise<SkillScriptResult> {
|
|
144
|
+
const timeoutMs = resolveTimeoutMs(input.timeoutMs);
|
|
145
|
+
// NOTE: In SSR contexts, getEnv() reads through the project-env overlay
|
|
146
|
+
// (AsyncLocalStorage-backed). If the token is set at host level only,
|
|
147
|
+
// the overlay may not surface it. Ensure SANDBOX_AUTH_TOKEN is available
|
|
148
|
+
// in the request-scoped environment when running under SSR.
|
|
149
|
+
const authToken = getEnv("SANDBOX_AUTH_TOKEN");
|
|
150
|
+
if (!authToken) {
|
|
151
|
+
throw toError(
|
|
152
|
+
createError({
|
|
153
|
+
type: "agent",
|
|
154
|
+
message: "Cloud script execution requires SANDBOX_AUTH_TOKEN environment variable",
|
|
155
|
+
}),
|
|
156
|
+
);
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
// Lazy import to avoid bundling sandbox in non-cloud environments
|
|
160
|
+
const { Sandbox } = await import("../sandbox/index.js");
|
|
161
|
+
const sandbox = await Sandbox.create({ authToken });
|
|
162
|
+
try {
|
|
163
|
+
const sandboxScriptPath = createSandboxScriptPath(input.scriptPath);
|
|
164
|
+
const scriptContent = input.scriptContent ?? await readTextFile(input.scriptPath);
|
|
165
|
+
|
|
166
|
+
await sandbox.writeFiles([{ path: sandboxScriptPath, content: scriptContent }]);
|
|
167
|
+
await sandbox.executeCommand(buildShellCommand(["chmod", "+x", sandboxScriptPath]));
|
|
168
|
+
|
|
169
|
+
const { command, args: runtimeArgs } = detectRuntime(sandboxScriptPath);
|
|
170
|
+
const allArgs = [...runtimeArgs, ...(input.args ?? [])];
|
|
171
|
+
const finalArgs = command === sandboxScriptPath ? (input.args ?? []) : allArgs;
|
|
172
|
+
|
|
173
|
+
const envAssignments = formatEnvAssignments(input.env);
|
|
174
|
+
const commandParts = envAssignments.length > 0
|
|
175
|
+
? ["env", ...envAssignments, command, ...finalArgs]
|
|
176
|
+
: [command, ...finalArgs];
|
|
177
|
+
|
|
178
|
+
const cmdString = buildShellCommand(commandParts);
|
|
179
|
+
const commandPromise = sandbox.executeCommand(cmdString);
|
|
180
|
+
const result = await withTimeout(commandPromise, timeoutMs);
|
|
181
|
+
|
|
182
|
+
if (result === TIMEOUT_SENTINEL) {
|
|
183
|
+
// Kill any running processes before returning — withTimeout only
|
|
184
|
+
// races the timer, it doesn't terminate the sandbox command.
|
|
185
|
+
try {
|
|
186
|
+
await sandbox.executeCommand("kill -9 -1 2>/dev/null || true");
|
|
187
|
+
} catch {
|
|
188
|
+
// Best-effort kill; sandbox.close() in finally will clean up.
|
|
189
|
+
}
|
|
190
|
+
return timeoutResult(timeoutMs);
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
return {
|
|
194
|
+
stdout: result.stdout,
|
|
195
|
+
stderr: result.stderr,
|
|
196
|
+
exitCode: result.exitCode,
|
|
197
|
+
};
|
|
198
|
+
} finally {
|
|
199
|
+
try {
|
|
200
|
+
await sandbox.close();
|
|
201
|
+
} catch {
|
|
202
|
+
// Best-effort cleanup.
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
|
|
208
|
+
/**
|
|
209
|
+
* Get the appropriate script executor.
|
|
210
|
+
* Checks SANDBOX_AUTH_TOKEN on every call so request-scoped env overlays
|
|
211
|
+
* (e.g. project-env AsyncLocalStorage) are respected.
|
|
212
|
+
*/
|
|
213
|
+
export function getSkillScriptExecutor(): SkillScriptExecutor {
|
|
214
|
+
return getEnv("SANDBOX_AUTH_TOKEN") ? new CloudScriptExecutor() : new LocalScriptExecutor();
|
|
215
|
+
}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Agent Skills
|
|
3
|
+
*
|
|
4
|
+
* Public API for the agent skills system.
|
|
5
|
+
* Skills are project-level capabilities defined as SKILL.md files
|
|
6
|
+
* following the agentskills.io specification.
|
|
7
|
+
*
|
|
8
|
+
* @module
|
|
9
|
+
*/
|
|
10
|
+
|
|
11
|
+
// Types
|
|
12
|
+
export type {
|
|
13
|
+
ActiveSkillContext,
|
|
14
|
+
Skill,
|
|
15
|
+
SkillContent,
|
|
16
|
+
SkillMetadata,
|
|
17
|
+
SkillScriptExecutor,
|
|
18
|
+
SkillScriptExecutorInput,
|
|
19
|
+
SkillScriptResult,
|
|
20
|
+
} from "./types.js";
|
|
21
|
+
|
|
22
|
+
export {
|
|
23
|
+
SKILL_ALLOWED_TOOL_PATTERN_REGEX,
|
|
24
|
+
SKILL_ASSETS_DIR,
|
|
25
|
+
SKILL_DESCRIPTION_MAX_LENGTH,
|
|
26
|
+
SKILL_MD_FILENAME,
|
|
27
|
+
SKILL_NAME_REGEX,
|
|
28
|
+
SKILL_REFERENCES_DIR,
|
|
29
|
+
SKILL_SCRIPTS_DIR,
|
|
30
|
+
SKILL_TOOL_IDS,
|
|
31
|
+
} from "./types.js";
|
|
32
|
+
|
|
33
|
+
// Registry
|
|
34
|
+
export { getAllSkills, getSkill, registerSkill, skillRegistry } from "./registry.js";
|
|
35
|
+
|
|
36
|
+
// Parser
|
|
37
|
+
export { parseSkillFrontmatter, validateSkillMetadata } from "./parser.js";
|
|
38
|
+
|
|
39
|
+
// Path Safety
|
|
40
|
+
export { listSkillSubdir, validateSkillPath } from "./path-safety.js";
|
|
41
|
+
|
|
42
|
+
// Tools
|
|
43
|
+
export {
|
|
44
|
+
createExecuteSkillScriptTool,
|
|
45
|
+
createLoadSkillReferenceTool,
|
|
46
|
+
createLoadSkillTool,
|
|
47
|
+
} from "./tools.js";
|
|
48
|
+
|
|
49
|
+
// Executor
|
|
50
|
+
export { getSkillScriptExecutor } from "./executor.js";
|
|
51
|
+
|
|
52
|
+
// Prompt
|
|
53
|
+
export { buildSkillManifestPrompt } from "./prompt-augmentation.js";
|
|
54
|
+
|
|
55
|
+
// Allowed-Tools
|
|
56
|
+
export {
|
|
57
|
+
filterToolsForSkill,
|
|
58
|
+
isToolAllowedBySkill,
|
|
59
|
+
validateAllowedToolPatterns,
|
|
60
|
+
} from "./allowed-tools.js";
|
|
@@ -0,0 +1,214 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Skill frontmatter parser
|
|
3
|
+
*
|
|
4
|
+
* Parses SKILL.md files with YAML frontmatter.
|
|
5
|
+
* Primary parser: gray-matter shim (#std/front-matter/yaml.ts)
|
|
6
|
+
* Fallback: regex + line-by-line parser
|
|
7
|
+
*
|
|
8
|
+
* @module
|
|
9
|
+
*/
|
|
10
|
+
|
|
11
|
+
import { createError, toError } from "../errors/veryfront-error.js";
|
|
12
|
+
import {
|
|
13
|
+
SKILL_ALLOWED_TOOL_PATTERN_REGEX,
|
|
14
|
+
SKILL_DESCRIPTION_MAX_LENGTH,
|
|
15
|
+
SKILL_NAME_REGEX,
|
|
16
|
+
type SkillMetadata,
|
|
17
|
+
} from "./types.js";
|
|
18
|
+
|
|
19
|
+
/** Result of parsing a SKILL.md file */
|
|
20
|
+
export interface ParsedSkillContent {
|
|
21
|
+
frontmatter: Record<string, unknown>;
|
|
22
|
+
body: string;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
/**
|
|
26
|
+
* Parse SKILL.md content into frontmatter + body.
|
|
27
|
+
*
|
|
28
|
+
* Uses gray-matter shim as primary parser with a regex fallback
|
|
29
|
+
* for environments where gray-matter is not available.
|
|
30
|
+
*/
|
|
31
|
+
export async function parseSkillFrontmatter(content: string): Promise<ParsedSkillContent> {
|
|
32
|
+
// Try primary parser: gray-matter shim
|
|
33
|
+
try {
|
|
34
|
+
const { extract } = await import("../platform/compat/std/front-matter-yaml.js");
|
|
35
|
+
const result = extract<Record<string, unknown>>(content);
|
|
36
|
+
return { frontmatter: result.attrs, body: result.body };
|
|
37
|
+
} catch {
|
|
38
|
+
// Fall through to fallback
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
// Fallback: regex-based parser
|
|
42
|
+
return parseFrontmatterFallback(content);
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
/**
|
|
46
|
+
* Regex-based fallback parser for YAML frontmatter.
|
|
47
|
+
* Handles simple key: value pairs (no nested YAML).
|
|
48
|
+
*/
|
|
49
|
+
function parseFrontmatterFallback(content: string): ParsedSkillContent {
|
|
50
|
+
const match = content.match(/^---\r?\n([\s\S]*?)\r?\n---\r?\n?([\s\S]*)$/);
|
|
51
|
+
if (!match) {
|
|
52
|
+
return { frontmatter: {}, body: content };
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
const rawFrontmatter = match[1]!;
|
|
56
|
+
const body = match[2]!;
|
|
57
|
+
const frontmatter: Record<string, unknown> = {};
|
|
58
|
+
|
|
59
|
+
for (const line of rawFrontmatter.split("\n")) {
|
|
60
|
+
const trimmed = line.trim();
|
|
61
|
+
if (!trimmed || trimmed.startsWith("#")) continue;
|
|
62
|
+
|
|
63
|
+
const colonIndex = trimmed.indexOf(":");
|
|
64
|
+
if (colonIndex === -1) continue;
|
|
65
|
+
|
|
66
|
+
const key = trimmed.slice(0, colonIndex).trim();
|
|
67
|
+
const value = trimmed.slice(colonIndex + 1).trim();
|
|
68
|
+
frontmatter[key] = value;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
return { frontmatter, body };
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
/**
|
|
75
|
+
* Validate and normalize parsed frontmatter into SkillMetadata.
|
|
76
|
+
*
|
|
77
|
+
* @param frontmatter - Parsed frontmatter object
|
|
78
|
+
* @param directoryName - Directory name used as fallback for skill name
|
|
79
|
+
*/
|
|
80
|
+
export function validateSkillMetadata(
|
|
81
|
+
frontmatter: Record<string, unknown>,
|
|
82
|
+
directoryName: string,
|
|
83
|
+
): SkillMetadata {
|
|
84
|
+
// Name: from frontmatter or directory name
|
|
85
|
+
const rawName = typeof frontmatter.name === "string" ? frontmatter.name.trim() : directoryName;
|
|
86
|
+
|
|
87
|
+
if (!SKILL_NAME_REGEX.test(rawName)) {
|
|
88
|
+
throw toError(
|
|
89
|
+
createError({
|
|
90
|
+
type: "agent",
|
|
91
|
+
message:
|
|
92
|
+
`Invalid skill name "${rawName}": must be lowercase alphanumeric with hyphens, 1-64 characters`,
|
|
93
|
+
}),
|
|
94
|
+
);
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
// Description: required
|
|
98
|
+
const rawDescription = frontmatter.description;
|
|
99
|
+
if (!rawDescription || typeof rawDescription !== "string" || !rawDescription.trim()) {
|
|
100
|
+
throw toError(
|
|
101
|
+
createError({
|
|
102
|
+
type: "agent",
|
|
103
|
+
message: `Skill "${rawName}" is missing a required "description" field`,
|
|
104
|
+
}),
|
|
105
|
+
);
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
const description = rawDescription.trim().slice(0, SKILL_DESCRIPTION_MAX_LENGTH);
|
|
109
|
+
|
|
110
|
+
// Allowed-tools: parse from space-delimited string or array
|
|
111
|
+
const allowedTools = parseAllowedTools(frontmatter["allowed-tools"], rawName);
|
|
112
|
+
|
|
113
|
+
// License: optional string passthrough
|
|
114
|
+
const license = typeof frontmatter.license === "string" ? frontmatter.license.trim() : undefined;
|
|
115
|
+
|
|
116
|
+
// Compatibility: optional string passthrough
|
|
117
|
+
const compatibility = typeof frontmatter.compatibility === "string"
|
|
118
|
+
? frontmatter.compatibility.trim()
|
|
119
|
+
: undefined;
|
|
120
|
+
|
|
121
|
+
// Metadata: convert nested object values to strings
|
|
122
|
+
const metadata = parseMetadata(frontmatter.metadata);
|
|
123
|
+
|
|
124
|
+
return {
|
|
125
|
+
name: rawName,
|
|
126
|
+
description,
|
|
127
|
+
...(allowedTools && { allowedTools }),
|
|
128
|
+
...(license && { license }),
|
|
129
|
+
...(compatibility && { compatibility }),
|
|
130
|
+
...(metadata && { metadata }),
|
|
131
|
+
};
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
/**
|
|
135
|
+
* Parse `allowed-tools` from frontmatter.
|
|
136
|
+
* Accepts a space-delimited string or an array of strings.
|
|
137
|
+
* Validates each pattern against SKILL_ALLOWED_TOOL_PATTERN_REGEX.
|
|
138
|
+
*/
|
|
139
|
+
function parseAllowedTools(
|
|
140
|
+
value: unknown,
|
|
141
|
+
skillName: string,
|
|
142
|
+
): string[] | undefined {
|
|
143
|
+
if (value === undefined || value === null) return undefined;
|
|
144
|
+
|
|
145
|
+
let patterns: string[];
|
|
146
|
+
|
|
147
|
+
if (typeof value === "string") {
|
|
148
|
+
patterns = value.split(/\s+/).filter(Boolean);
|
|
149
|
+
} else if (Array.isArray(value)) {
|
|
150
|
+
patterns = [];
|
|
151
|
+
for (const rawPattern of value) {
|
|
152
|
+
if (typeof rawPattern !== "string") {
|
|
153
|
+
throw toError(
|
|
154
|
+
createError({
|
|
155
|
+
type: "agent",
|
|
156
|
+
message:
|
|
157
|
+
`Skill "${skillName}" has invalid allowed-tools value: expected all entries to be strings`,
|
|
158
|
+
}),
|
|
159
|
+
);
|
|
160
|
+
}
|
|
161
|
+
const pattern = rawPattern.trim();
|
|
162
|
+
if (!pattern) {
|
|
163
|
+
throw toError(
|
|
164
|
+
createError({
|
|
165
|
+
type: "agent",
|
|
166
|
+
message: `Skill "${skillName}" has invalid allowed-tools pattern: empty value`,
|
|
167
|
+
}),
|
|
168
|
+
);
|
|
169
|
+
}
|
|
170
|
+
patterns.push(pattern);
|
|
171
|
+
}
|
|
172
|
+
} else {
|
|
173
|
+
throw toError(
|
|
174
|
+
createError({
|
|
175
|
+
type: "agent",
|
|
176
|
+
message:
|
|
177
|
+
`Skill "${skillName}" has invalid allowed-tools value: expected a string or array of strings, got ${typeof value}`,
|
|
178
|
+
}),
|
|
179
|
+
);
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
if (patterns.length === 0) return undefined;
|
|
183
|
+
|
|
184
|
+
// Validate each pattern (fail closed)
|
|
185
|
+
for (const pattern of patterns) {
|
|
186
|
+
if (!SKILL_ALLOWED_TOOL_PATTERN_REGEX.test(pattern)) {
|
|
187
|
+
throw toError(
|
|
188
|
+
createError({
|
|
189
|
+
type: "agent",
|
|
190
|
+
message: `Skill "${skillName}" has invalid allowed-tools pattern "${pattern}". ` +
|
|
191
|
+
`Only exact tool IDs (e.g. "Read") and prefix wildcards (e.g. "api:*") are supported.`,
|
|
192
|
+
}),
|
|
193
|
+
);
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
|
|
197
|
+
return patterns;
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
/** Convert metadata object values to strings */
|
|
201
|
+
function parseMetadata(
|
|
202
|
+
value: unknown,
|
|
203
|
+
): Record<string, string> | undefined {
|
|
204
|
+
if (!value || typeof value !== "object" || Array.isArray(value)) return undefined;
|
|
205
|
+
|
|
206
|
+
const entries = Object.entries(value as Record<string, unknown>);
|
|
207
|
+
if (entries.length === 0) return undefined;
|
|
208
|
+
|
|
209
|
+
const result: Record<string, string> = {};
|
|
210
|
+
for (const [k, v] of entries) {
|
|
211
|
+
result[k] = String(v);
|
|
212
|
+
}
|
|
213
|
+
return result;
|
|
214
|
+
}
|