@lssm/bundle.contractspec-workspace 0.0.0-canary-20251217063201 → 0.0.0-canary-20251217072406
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/dist/_virtual/rolldown_runtime.js +22 -1
- package/dist/adapters/ai.js +82 -1
- package/dist/adapters/factory.js +36 -1
- package/dist/adapters/fs.js +118 -1
- package/dist/adapters/git.js +54 -1
- package/dist/adapters/index.js +7 -1
- package/dist/adapters/logger.js +80 -1
- package/dist/adapters/watcher.js +69 -1
- package/dist/adapters/workspace.js +190 -2
- package/dist/ai/agents/claude-code-agent.js +146 -9
- package/dist/ai/agents/cursor-agent.js +286 -17
- package/dist/ai/agents/index.js +5 -1
- package/dist/ai/agents/openai-codex-agent.js +140 -8
- package/dist/ai/agents/orchestrator.js +142 -1
- package/dist/ai/agents/simple-agent.js +80 -4
- package/dist/ai/client.js +162 -1
- package/dist/ai/index.js +27 -1
- package/dist/ai/prompts/code-generation.js +55 -13
- package/dist/ai/prompts/index.js +12 -1
- package/dist/ai/prompts/spec-creation.js +61 -20
- package/dist/ai/providers.js +40 -1
- package/dist/formatters/index.js +18 -1
- package/dist/formatters/json.js +71 -1
- package/dist/formatters/sarif.js +163 -1
- package/dist/formatters/text.js +208 -2
- package/dist/index.js +81 -1
- package/dist/libs/ai-providers/dist/factory.js +154 -1
- package/dist/libs/ai-providers/dist/index.js +4 -1
- package/dist/libs/ai-providers/dist/legacy.js +72 -1
- package/dist/libs/ai-providers/dist/models.js +287 -1
- package/dist/libs/ai-providers/dist/validation.js +1 -1
- package/dist/libs/contracts/dist/capabilities/openbanking.js +88 -1
- package/dist/libs/contracts/dist/client/index.js +5 -1
- package/dist/libs/contracts/dist/client/react/feature-render.js +2 -1
- package/dist/libs/contracts/dist/client/react/form-render.js +4 -1
- package/dist/libs/contracts/dist/client/react/index.js +4 -1
- package/dist/libs/contracts/dist/contract-registry/index.js +1 -1
- package/dist/libs/contracts/dist/contract-registry/schemas.js +60 -1
- package/dist/libs/contracts/dist/docs/PUBLISHING.docblock.js +16 -76
- package/dist/libs/contracts/dist/docs/accessibility_wcag_compliance_specs.docblock.js +16 -350
- package/dist/libs/contracts/dist/docs/index.js +29 -1
- package/dist/libs/contracts/dist/docs/presentations.js +71 -1
- package/dist/libs/contracts/dist/docs/registry.js +44 -1
- package/dist/libs/contracts/dist/docs/tech/PHASE_1_QUICKSTART.docblock.js +16 -383
- package/dist/libs/contracts/dist/docs/tech/PHASE_2_AI_NATIVE_OPERATIONS.docblock.js +16 -68
- package/dist/libs/contracts/dist/docs/tech/PHASE_3_AUTO_EVOLUTION.docblock.js +16 -140
- package/dist/libs/contracts/dist/docs/tech/PHASE_4_PERSONALIZATION_ENGINE.docblock.js +16 -86
- package/dist/libs/contracts/dist/docs/tech/PHASE_5_ZERO_TOUCH_OPERATIONS.docblock.js +16 -1
- package/dist/libs/contracts/dist/docs/tech/auth/better-auth-nextjs.docblock.js +24 -2
- package/dist/libs/contracts/dist/docs/tech/contracts/openapi-export.docblock.js +21 -2
- package/dist/libs/contracts/dist/docs/tech/lifecycle-stage-system.docblock.js +16 -213
- package/dist/libs/contracts/dist/docs/tech/llm/llm-integration.docblock.js +73 -5
- package/dist/libs/contracts/dist/docs/tech/mcp-endpoints.docblock.js +37 -1
- package/dist/libs/contracts/dist/docs/tech/presentation-runtime.docblock.js +16 -1
- package/dist/libs/contracts/dist/docs/tech/schema/README.docblock.js +20 -262
- package/dist/libs/contracts/dist/docs/tech/studio/learning-events.docblock.js +48 -1
- package/dist/libs/contracts/dist/docs/tech/studio/learning-journeys.docblock.js +24 -2
- package/dist/libs/contracts/dist/docs/tech/studio/platform-admin-panel.docblock.js +23 -2
- package/dist/libs/contracts/dist/docs/tech/studio/project-access-teams.docblock.js +25 -16
- package/dist/libs/contracts/dist/docs/tech/studio/project-routing.docblock.js +67 -1
- package/dist/libs/contracts/dist/docs/tech/studio/sandbox-unlogged.docblock.js +22 -2
- package/dist/libs/contracts/dist/docs/tech/studio/team-invitations.docblock.js +40 -36
- package/dist/libs/contracts/dist/docs/tech/studio/workspace-ops.docblock.js +47 -1
- package/dist/libs/contracts/dist/docs/tech/studio/workspaces.docblock.js +23 -2
- package/dist/libs/contracts/dist/docs/tech/telemetry-ingest.docblock.js +36 -3
- package/dist/libs/contracts/dist/docs/tech/templates/runtime.docblock.js +20 -1
- package/dist/libs/contracts/dist/docs/tech/vscode-extension.docblock.js +36 -3
- package/dist/libs/contracts/dist/docs/tech/workflows/overview.docblock.js +20 -1
- package/dist/libs/contracts/dist/events.js +8 -1
- package/dist/libs/contracts/dist/experiments/evaluator.js +1 -1
- package/dist/libs/contracts/dist/index.js +72 -1
- package/dist/libs/contracts/dist/install.js +2 -1
- package/dist/libs/contracts/dist/integrations/contracts.js +377 -1
- package/dist/libs/contracts/dist/integrations/index.js +18 -1
- package/dist/libs/contracts/dist/integrations/openbanking/contracts/accounts.js +228 -1
- package/dist/libs/contracts/dist/integrations/openbanking/contracts/balances.js +159 -1
- package/dist/libs/contracts/dist/integrations/openbanking/contracts/index.js +3 -1
- package/dist/libs/contracts/dist/integrations/openbanking/contracts/transactions.js +210 -1
- package/dist/libs/contracts/dist/integrations/openbanking/models.js +242 -1
- package/dist/libs/contracts/dist/integrations/openbanking/telemetry.js +13 -1
- package/dist/libs/contracts/dist/integrations/providers/elevenlabs.js +52 -1
- package/dist/libs/contracts/dist/integrations/providers/gcs-storage.js +75 -1
- package/dist/libs/contracts/dist/integrations/providers/gmail.js +87 -1
- package/dist/libs/contracts/dist/integrations/providers/google-calendar.js +66 -1
- package/dist/libs/contracts/dist/integrations/providers/index.js +11 -1
- package/dist/libs/contracts/dist/integrations/providers/mistral.js +68 -1
- package/dist/libs/contracts/dist/integrations/providers/postmark.js +68 -1
- package/dist/libs/contracts/dist/integrations/providers/powens.js +116 -1
- package/dist/libs/contracts/dist/integrations/providers/qdrant.js +73 -1
- package/dist/libs/contracts/dist/integrations/providers/registry.js +10 -1
- package/dist/libs/contracts/dist/integrations/providers/stripe.js +83 -1
- package/dist/libs/contracts/dist/integrations/providers/twilio-sms.js +61 -1
- package/dist/libs/contracts/dist/jsonschema.js +24 -1
- package/dist/libs/contracts/dist/knowledge/contracts.js +306 -1
- package/dist/libs/contracts/dist/knowledge/index.js +7 -1
- package/dist/libs/contracts/dist/knowledge/spaces/email-threads.js +34 -1
- package/dist/libs/contracts/dist/knowledge/spaces/financial-docs.js +34 -1
- package/dist/libs/contracts/dist/knowledge/spaces/financial-overview.js +38 -1
- package/dist/libs/contracts/dist/knowledge/spaces/index.js +6 -1
- package/dist/libs/contracts/dist/knowledge/spaces/product-canon.js +34 -1
- package/dist/libs/contracts/dist/knowledge/spaces/support-faq.js +37 -1
- package/dist/libs/contracts/dist/knowledge/spaces/uploaded-docs.js +34 -1
- package/dist/libs/contracts/dist/llm/exporters.js +352 -4
- package/dist/libs/contracts/dist/llm/index.js +2 -1
- package/dist/libs/contracts/dist/llm/prompts.js +143 -7
- package/dist/libs/contracts/dist/onboarding-base.js +196 -1
- package/dist/libs/contracts/dist/openapi.js +75 -1
- package/dist/libs/contracts/dist/ownership.js +21 -1
- package/dist/libs/contracts/dist/presentations.js +1 -1
- package/dist/libs/contracts/dist/presentations.v2.js +11 -1
- package/dist/libs/contracts/dist/prompt.js +1 -1
- package/dist/libs/contracts/dist/promptRegistry.js +1 -1
- package/dist/libs/contracts/dist/regenerator/index.js +2 -1
- package/dist/libs/contracts/dist/regenerator/service.js +92 -1
- package/dist/libs/contracts/dist/regenerator/utils.js +51 -1
- package/dist/libs/contracts/dist/registry.js +208 -1
- package/dist/libs/contracts/dist/resources.js +1 -1
- package/dist/libs/contracts/dist/schema/dist/EnumType.js +2 -1
- package/dist/libs/contracts/dist/schema/dist/FieldType.js +49 -1
- package/dist/libs/contracts/dist/schema/dist/ScalarTypeEnum.js +236 -1
- package/dist/libs/contracts/dist/schema/dist/SchemaModel.js +34 -1
- package/dist/libs/contracts/dist/schema/dist/entity/defineEntity.js +1 -1
- package/dist/libs/contracts/dist/schema/dist/entity/index.js +2 -1
- package/dist/libs/contracts/dist/schema/dist/entity/types.js +1 -1
- package/dist/libs/contracts/dist/schema/dist/index.js +6 -1
- package/dist/libs/contracts/dist/server/graphql-pothos.js +6 -1
- package/dist/libs/contracts/dist/server/index.js +8 -1
- package/dist/libs/contracts/dist/server/mcp/createMcpServer.js +4 -1
- package/dist/libs/contracts/dist/server/mcp/registerPresentations.js +2 -1
- package/dist/libs/contracts/dist/server/mcp/registerPrompts.js +1 -1
- package/dist/libs/contracts/dist/server/mcp/registerResources.js +2 -1
- package/dist/libs/contracts/dist/server/mcp/registerTools.js +1 -1
- package/dist/libs/contracts/dist/server/provider-mcp.js +1 -1
- package/dist/libs/contracts/dist/server/rest-elysia.js +1 -1
- package/dist/libs/contracts/dist/server/rest-express.js +1 -1
- package/dist/libs/contracts/dist/server/rest-generic.js +1 -1
- package/dist/libs/contracts/dist/server/rest-next-app.js +1 -1
- package/dist/libs/contracts/dist/server/rest-next-pages.js +1 -1
- package/dist/libs/contracts/dist/spec.js +35 -1
- package/dist/libs/contracts/dist/telemetry/index.js +1 -1
- package/dist/libs/contracts/dist/telemetry/tracker.js +1 -1
- package/dist/libs/contracts/dist/tests/index.js +1 -1
- package/dist/libs/contracts/dist/tests/runner.js +150 -1
- package/dist/libs/contracts/dist/workflow/index.js +1 -1
- package/dist/libs/contracts/dist/workflow/runner.js +1 -1
- package/dist/libs/contracts-transformers/dist/common/utils.js +47 -1
- package/dist/libs/contracts-transformers/dist/openapi/exporter.js +1 -1
- package/dist/libs/contracts-transformers/dist/openapi/importer.js +255 -2
- package/dist/libs/contracts-transformers/dist/openapi/index.js +4 -1
- package/dist/libs/contracts-transformers/dist/openapi/parser.js +231 -1
- package/dist/libs/contracts-transformers/dist/openapi/schema-converter.js +201 -4
- package/dist/modules/contractspec-workspace/dist/ai/code-generation.js +50 -13
- package/dist/modules/contractspec-workspace/dist/ai/spec-creation.js +50 -18
- package/dist/modules/contractspec-workspace/dist/analysis/deps/graph.js +84 -2
- package/dist/modules/contractspec-workspace/dist/analysis/deps/parse-imports.js +30 -1
- package/dist/modules/contractspec-workspace/dist/analysis/diff/semantic.js +96 -1
- package/dist/modules/contractspec-workspace/dist/analysis/feature-scan.js +151 -1
- package/dist/modules/contractspec-workspace/dist/analysis/spec-scan.js +344 -1
- package/dist/modules/contractspec-workspace/dist/analysis/validate/spec-structure.js +122 -1
- package/dist/modules/contractspec-workspace/dist/templates/app-config.js +100 -28
- package/dist/modules/contractspec-workspace/dist/templates/data-view.js +41 -27
- package/dist/modules/contractspec-workspace/dist/templates/event.js +28 -14
- package/dist/modules/contractspec-workspace/dist/templates/experiment.js +76 -51
- package/dist/modules/contractspec-workspace/dist/templates/handler.js +49 -17
- package/dist/modules/contractspec-workspace/dist/templates/integration-utils.js +97 -26
- package/dist/modules/contractspec-workspace/dist/templates/integration.js +46 -23
- package/dist/modules/contractspec-workspace/dist/templates/knowledge.js +59 -19
- package/dist/modules/contractspec-workspace/dist/templates/migration.js +49 -26
- package/dist/modules/contractspec-workspace/dist/templates/operation.js +40 -28
- package/dist/modules/contractspec-workspace/dist/templates/presentation.js +45 -20
- package/dist/modules/contractspec-workspace/dist/templates/telemetry.js +73 -53
- package/dist/modules/contractspec-workspace/dist/templates/utils.js +38 -1
- package/dist/modules/contractspec-workspace/dist/templates/workflow-runner.js +12 -6
- package/dist/modules/contractspec-workspace/dist/templates/workflow.js +50 -24
- package/dist/modules/contractspec-workspace/dist/types/generation-types.js +20 -1
- package/dist/services/agent-guide/adapters/claude-code.js +144 -3
- package/dist/services/agent-guide/adapters/cursor-cli.js +135 -3
- package/dist/services/agent-guide/adapters/generic-mcp.js +159 -3
- package/dist/services/agent-guide/adapters/index.js +30 -1
- package/dist/services/agent-guide/agent-guide-service.js +148 -1
- package/dist/services/agent-guide/index.js +5 -1
- package/dist/services/build.js +140 -1
- package/dist/services/ci-check/ci-check-service.js +393 -1
- package/dist/services/ci-check/index.js +2 -1
- package/dist/services/ci-check/types.js +28 -1
- package/dist/services/clean.js +71 -1
- package/dist/services/config.js +76 -1
- package/dist/services/deps.js +62 -1
- package/dist/services/diff.js +33 -1
- package/dist/services/doctor/checks/ai.js +118 -2
- package/dist/services/doctor/checks/cli.js +146 -1
- package/dist/services/doctor/checks/config.js +170 -1
- package/dist/services/doctor/checks/deps.js +180 -1
- package/dist/services/doctor/checks/index.js +6 -1
- package/dist/services/doctor/checks/mcp.js +144 -1
- package/dist/services/doctor/checks/workspace.js +243 -1
- package/dist/services/doctor/doctor-service.js +115 -2
- package/dist/services/doctor/index.js +2 -1
- package/dist/services/doctor/types.js +26 -1
- package/dist/services/implementation/discovery.js +143 -2
- package/dist/services/implementation/index.js +2 -1
- package/dist/services/implementation/resolver.js +223 -1
- package/dist/services/index.js +53 -1
- package/dist/services/integrity-diagram.js +274 -6
- package/dist/services/integrity.js +272 -1
- package/dist/services/list.js +35 -1
- package/dist/services/openapi/export-service.js +51 -2
- package/dist/services/openapi/import-service.js +75 -1
- package/dist/services/openapi/index.js +4 -1
- package/dist/services/openapi/sync-service.js +121 -1
- package/dist/services/openapi/validate-service.js +130 -1
- package/dist/services/regenerator.js +23 -1
- package/dist/services/registry.js +73 -1
- package/dist/services/setup/config-generators.js +113 -26
- package/dist/services/setup/file-merger.js +60 -2
- package/dist/services/setup/index.js +4 -1
- package/dist/services/setup/setup-service.js +95 -1
- package/dist/services/setup/targets/agents-md.js +46 -1
- package/dist/services/setup/targets/cli-config.js +59 -1
- package/dist/services/setup/targets/cursor-rules.js +47 -1
- package/dist/services/setup/targets/mcp-claude.js +59 -1
- package/dist/services/setup/targets/mcp-cursor.js +58 -1
- package/dist/services/setup/targets/vscode-settings.js +62 -1
- package/dist/services/setup/types.js +26 -1
- package/dist/services/sync.js +62 -1
- package/dist/services/test.js +30 -1
- package/dist/services/validate-implementation.js +69 -1
- package/dist/services/validate.js +47 -1
- package/dist/services/verification-cache/adapters/filesystem.js +121 -1
- package/dist/services/verification-cache/adapters/in-memory.js +45 -1
- package/dist/services/verification-cache/adapters/index.js +3 -1
- package/dist/services/verification-cache/adapters/workspace-state.js +90 -1
- package/dist/services/verification-cache/cache-service.js +255 -1
- package/dist/services/verification-cache/index.js +6 -1
- package/dist/services/verification-cache/types.js +15 -1
- package/dist/services/verify/ai-verifier.js +336 -9
- package/dist/services/verify/behavior-verifier.js +185 -1
- package/dist/services/verify/index.js +4 -1
- package/dist/services/verify/structure-verifier.js +195 -2
- package/dist/services/verify/verify-service.js +203 -3
- package/dist/services/watch.js +31 -1
- package/dist/services/workspace-info.js +102 -2
- package/dist/templates/app-config.template.js +101 -28
- package/dist/templates/data-view.template.js +42 -27
- package/dist/templates/event.template.js +29 -14
- package/dist/templates/experiment.template.js +77 -51
- package/dist/templates/handler.template.js +53 -17
- package/dist/templates/index.js +36 -1
- package/dist/templates/integration.template.js +134 -50
- package/dist/templates/knowledge.template.js +62 -21
- package/dist/templates/migration.template.js +50 -26
- package/dist/templates/operation.template.js +44 -28
- package/dist/templates/presentation.template.js +46 -20
- package/dist/templates/telemetry.template.js +74 -53
- package/dist/templates/workflow-runner.template.js +12 -6
- package/dist/templates/workflow.template.js +51 -24
- package/package.json +13 -9
package/dist/services/diff.js
CHANGED
|
@@ -1 +1,33 @@
|
|
|
1
|
-
import{
|
|
1
|
+
import { computeSemanticDiff } from "../modules/contractspec-workspace/dist/analysis/diff/semantic.js";
|
|
2
|
+
|
|
3
|
+
//#region src/services/diff.ts
|
|
4
|
+
/**
|
|
5
|
+
* Diff service.
|
|
6
|
+
*/
|
|
7
|
+
/**
|
|
8
|
+
* Compare two spec files semantically.
|
|
9
|
+
*/
|
|
10
|
+
async function compareSpecs(spec1Path, spec2Path, adapters, options = {}) {
|
|
11
|
+
const { fs, git } = adapters;
|
|
12
|
+
if (!await fs.exists(spec1Path)) throw new Error(`Spec file not found: ${spec1Path}`);
|
|
13
|
+
const spec1Code = await fs.readFile(spec1Path);
|
|
14
|
+
let spec2Code;
|
|
15
|
+
let spec2Label;
|
|
16
|
+
if (options.baseline) {
|
|
17
|
+
spec2Code = await git.showFile(options.baseline, spec1Path);
|
|
18
|
+
spec2Label = `${options.baseline}:${spec1Path}`;
|
|
19
|
+
} else {
|
|
20
|
+
if (!await fs.exists(spec2Path)) throw new Error(`Spec file not found: ${spec2Path}`);
|
|
21
|
+
spec2Code = await fs.readFile(spec2Path);
|
|
22
|
+
spec2Label = spec2Path;
|
|
23
|
+
}
|
|
24
|
+
const differences = computeSemanticDiff(spec1Code, spec1Path, spec2Code, spec2Label, { breakingOnly: options.breakingOnly });
|
|
25
|
+
return {
|
|
26
|
+
spec1: spec1Path,
|
|
27
|
+
spec2: spec2Label,
|
|
28
|
+
differences
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
//#endregion
|
|
33
|
+
export { compareSpecs };
|
|
@@ -1,2 +1,118 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
//#region src/services/doctor/checks/ai.ts
|
|
2
|
+
/**
|
|
3
|
+
* Run AI provider-related health checks.
|
|
4
|
+
*/
|
|
5
|
+
async function runAiChecks(fs, ctx, prompts) {
|
|
6
|
+
const results = [];
|
|
7
|
+
const providerResult = await checkAiProvider(fs, ctx);
|
|
8
|
+
results.push(providerResult);
|
|
9
|
+
if (providerResult.status === "pass") results.push(await checkApiKey(fs, ctx, prompts));
|
|
10
|
+
return results;
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* Check which AI provider is configured.
|
|
14
|
+
*/
|
|
15
|
+
async function checkAiProvider(fs, ctx) {
|
|
16
|
+
const configPath = fs.join(ctx.workspaceRoot, ".contractsrc.json");
|
|
17
|
+
try {
|
|
18
|
+
if (!await fs.exists(configPath)) return {
|
|
19
|
+
category: "ai",
|
|
20
|
+
name: "AI Provider",
|
|
21
|
+
status: "skip",
|
|
22
|
+
message: "No config file found"
|
|
23
|
+
};
|
|
24
|
+
const content = await fs.readFile(configPath);
|
|
25
|
+
const config = JSON.parse(content);
|
|
26
|
+
return {
|
|
27
|
+
category: "ai",
|
|
28
|
+
name: "AI Provider",
|
|
29
|
+
status: "pass",
|
|
30
|
+
message: `Provider: ${config.aiProvider ?? "claude"}, Model: ${config.aiModel ?? "default"}`
|
|
31
|
+
};
|
|
32
|
+
} catch {
|
|
33
|
+
return {
|
|
34
|
+
category: "ai",
|
|
35
|
+
name: "AI Provider",
|
|
36
|
+
status: "skip",
|
|
37
|
+
message: "Could not read AI config"
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* Check if API key is set for the configured provider.
|
|
43
|
+
*/
|
|
44
|
+
async function checkApiKey(fs, ctx, prompts) {
|
|
45
|
+
const configPath = fs.join(ctx.workspaceRoot, ".contractsrc.json");
|
|
46
|
+
try {
|
|
47
|
+
const content = await fs.readFile(configPath);
|
|
48
|
+
const provider = JSON.parse(content).aiProvider ?? "claude";
|
|
49
|
+
const envVar = {
|
|
50
|
+
claude: "ANTHROPIC_API_KEY",
|
|
51
|
+
openai: "OPENAI_API_KEY",
|
|
52
|
+
ollama: "",
|
|
53
|
+
custom: "CONTRACTSPEC_LLM_API_KEY"
|
|
54
|
+
}[provider];
|
|
55
|
+
if (!envVar) return {
|
|
56
|
+
category: "ai",
|
|
57
|
+
name: "API Key",
|
|
58
|
+
status: "pass",
|
|
59
|
+
message: `${provider} does not require an API key`
|
|
60
|
+
};
|
|
61
|
+
if (!!process.env[envVar]) return {
|
|
62
|
+
category: "ai",
|
|
63
|
+
name: "API Key",
|
|
64
|
+
status: "pass",
|
|
65
|
+
message: `${envVar} is set`
|
|
66
|
+
};
|
|
67
|
+
return {
|
|
68
|
+
category: "ai",
|
|
69
|
+
name: "API Key",
|
|
70
|
+
status: "warn",
|
|
71
|
+
message: `${envVar} not set`,
|
|
72
|
+
details: `Set ${envVar} in your environment to use AI features`,
|
|
73
|
+
fix: prompts ? {
|
|
74
|
+
description: `Set ${envVar} environment variable`,
|
|
75
|
+
apply: async () => {
|
|
76
|
+
const key = await prompts.input(`Enter your ${provider} API key:`, { password: true });
|
|
77
|
+
if (!key) return {
|
|
78
|
+
success: false,
|
|
79
|
+
message: "No API key provided"
|
|
80
|
+
};
|
|
81
|
+
const envPath = fs.join(ctx.workspaceRoot, ".env");
|
|
82
|
+
try {
|
|
83
|
+
let envContent = "";
|
|
84
|
+
if (await fs.exists(envPath)) {
|
|
85
|
+
envContent = await fs.readFile(envPath);
|
|
86
|
+
if (envContent.includes(`${envVar}=`)) return {
|
|
87
|
+
success: false,
|
|
88
|
+
message: `${envVar} already in .env, update manually`
|
|
89
|
+
};
|
|
90
|
+
envContent += "\n";
|
|
91
|
+
}
|
|
92
|
+
envContent += `${envVar}=${key}\n`;
|
|
93
|
+
await fs.writeFile(envPath, envContent);
|
|
94
|
+
return {
|
|
95
|
+
success: true,
|
|
96
|
+
message: `Added ${envVar} to .env (restart required)`
|
|
97
|
+
};
|
|
98
|
+
} catch (error) {
|
|
99
|
+
return {
|
|
100
|
+
success: false,
|
|
101
|
+
message: `Failed: ${error instanceof Error ? error.message : String(error)}`
|
|
102
|
+
};
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
} : void 0
|
|
106
|
+
};
|
|
107
|
+
} catch {
|
|
108
|
+
return {
|
|
109
|
+
category: "ai",
|
|
110
|
+
name: "API Key",
|
|
111
|
+
status: "skip",
|
|
112
|
+
message: "Could not check API key"
|
|
113
|
+
};
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
//#endregion
|
|
118
|
+
export { runAiChecks };
|
|
@@ -1 +1,146 @@
|
|
|
1
|
-
import{exec
|
|
1
|
+
import { exec } from "node:child_process";
|
|
2
|
+
import { promisify } from "node:util";
|
|
3
|
+
|
|
4
|
+
//#region src/services/doctor/checks/cli.ts
|
|
5
|
+
/**
|
|
6
|
+
* CLI installation health checks.
|
|
7
|
+
*/
|
|
8
|
+
const execAsync = promisify(exec);
|
|
9
|
+
/**
|
|
10
|
+
* Run CLI-related health checks.
|
|
11
|
+
*/
|
|
12
|
+
async function runCliChecks(fs, ctx) {
|
|
13
|
+
const results = [];
|
|
14
|
+
results.push(await checkCliAccessible(ctx));
|
|
15
|
+
results.push(await checkCliVersion(ctx));
|
|
16
|
+
results.push(await checkCliInstallLocation(fs, ctx));
|
|
17
|
+
return results;
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* Check if the CLI is accessible.
|
|
21
|
+
*/
|
|
22
|
+
async function checkCliAccessible(ctx) {
|
|
23
|
+
try {
|
|
24
|
+
await execAsync("npx contractspec --version", {
|
|
25
|
+
cwd: ctx.workspaceRoot,
|
|
26
|
+
timeout: 1e4
|
|
27
|
+
});
|
|
28
|
+
return {
|
|
29
|
+
category: "cli",
|
|
30
|
+
name: "CLI Accessible",
|
|
31
|
+
status: "pass",
|
|
32
|
+
message: "ContractSpec CLI is accessible"
|
|
33
|
+
};
|
|
34
|
+
} catch {
|
|
35
|
+
return {
|
|
36
|
+
category: "cli",
|
|
37
|
+
name: "CLI Accessible",
|
|
38
|
+
status: "fail",
|
|
39
|
+
message: "ContractSpec CLI is not accessible",
|
|
40
|
+
details: "Could not run \"npx contractspec --version\"",
|
|
41
|
+
fix: {
|
|
42
|
+
description: "Install ContractSpec CLI globally",
|
|
43
|
+
apply: async () => {
|
|
44
|
+
try {
|
|
45
|
+
await execAsync("npm install -g @lssm/app.cli-contracts", {
|
|
46
|
+
cwd: ctx.workspaceRoot,
|
|
47
|
+
timeout: 6e4
|
|
48
|
+
});
|
|
49
|
+
return {
|
|
50
|
+
success: true,
|
|
51
|
+
message: "CLI installed globally"
|
|
52
|
+
};
|
|
53
|
+
} catch (error) {
|
|
54
|
+
return {
|
|
55
|
+
success: false,
|
|
56
|
+
message: `Failed to install: ${error instanceof Error ? error.message : String(error)}`
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
};
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
/**
|
|
65
|
+
* Check CLI version.
|
|
66
|
+
*/
|
|
67
|
+
async function checkCliVersion(ctx) {
|
|
68
|
+
try {
|
|
69
|
+
const { stdout } = await execAsync("npx contractspec --version", {
|
|
70
|
+
cwd: ctx.workspaceRoot,
|
|
71
|
+
timeout: 1e4
|
|
72
|
+
});
|
|
73
|
+
return {
|
|
74
|
+
category: "cli",
|
|
75
|
+
name: "CLI Version",
|
|
76
|
+
status: "pass",
|
|
77
|
+
message: `CLI version: ${stdout.trim()}`
|
|
78
|
+
};
|
|
79
|
+
} catch {
|
|
80
|
+
return {
|
|
81
|
+
category: "cli",
|
|
82
|
+
name: "CLI Version",
|
|
83
|
+
status: "skip",
|
|
84
|
+
message: "Could not determine CLI version"
|
|
85
|
+
};
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
/**
|
|
89
|
+
* Check if CLI is installed locally in the project.
|
|
90
|
+
*/
|
|
91
|
+
async function checkCliInstallLocation(fs, ctx) {
|
|
92
|
+
const packageJsonPath = fs.join(ctx.workspaceRoot, "package.json");
|
|
93
|
+
try {
|
|
94
|
+
if (!await fs.exists(packageJsonPath)) return {
|
|
95
|
+
category: "cli",
|
|
96
|
+
name: "Local Installation",
|
|
97
|
+
status: "skip",
|
|
98
|
+
message: "No package.json found"
|
|
99
|
+
};
|
|
100
|
+
const content = await fs.readFile(packageJsonPath);
|
|
101
|
+
const pkg = JSON.parse(content);
|
|
102
|
+
if (pkg.dependencies?.["@lssm/app.cli-contracts"] !== void 0 || pkg.devDependencies?.["@lssm/app.cli-contracts"] !== void 0) return {
|
|
103
|
+
category: "cli",
|
|
104
|
+
name: "Local Installation",
|
|
105
|
+
status: "pass",
|
|
106
|
+
message: "CLI is installed as a project dependency"
|
|
107
|
+
};
|
|
108
|
+
return {
|
|
109
|
+
category: "cli",
|
|
110
|
+
name: "Local Installation",
|
|
111
|
+
status: "warn",
|
|
112
|
+
message: "CLI is not installed as a project dependency",
|
|
113
|
+
details: "Consider adding @lssm/app.cli-contracts to devDependencies",
|
|
114
|
+
fix: {
|
|
115
|
+
description: "Add CLI as a dev dependency",
|
|
116
|
+
apply: async () => {
|
|
117
|
+
try {
|
|
118
|
+
await execAsync("npm install -D @lssm/app.cli-contracts", {
|
|
119
|
+
cwd: ctx.workspaceRoot,
|
|
120
|
+
timeout: 6e4
|
|
121
|
+
});
|
|
122
|
+
return {
|
|
123
|
+
success: true,
|
|
124
|
+
message: "CLI added as dev dependency"
|
|
125
|
+
};
|
|
126
|
+
} catch (error) {
|
|
127
|
+
return {
|
|
128
|
+
success: false,
|
|
129
|
+
message: `Failed to install: ${error instanceof Error ? error.message : String(error)}`
|
|
130
|
+
};
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
};
|
|
135
|
+
} catch {
|
|
136
|
+
return {
|
|
137
|
+
category: "cli",
|
|
138
|
+
name: "Local Installation",
|
|
139
|
+
status: "skip",
|
|
140
|
+
message: "Could not check local installation"
|
|
141
|
+
};
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
//#endregion
|
|
146
|
+
export { runCliChecks };
|
|
@@ -1 +1,170 @@
|
|
|
1
|
-
import{generateContractsrcConfig
|
|
1
|
+
import { generateContractsrcConfig } from "../../setup/config-generators.js";
|
|
2
|
+
import { formatJson } from "../../setup/file-merger.js";
|
|
3
|
+
|
|
4
|
+
//#region src/services/doctor/checks/config.ts
|
|
5
|
+
/**
|
|
6
|
+
* Run configuration-related health checks.
|
|
7
|
+
*/
|
|
8
|
+
async function runConfigChecks(fs, ctx) {
|
|
9
|
+
const results = [];
|
|
10
|
+
results.push(await checkContractsrcExists(fs, ctx));
|
|
11
|
+
results.push(await checkContractsrcValid(fs, ctx));
|
|
12
|
+
results.push(await checkContractsrcFields(fs, ctx));
|
|
13
|
+
return results;
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* Check if .contractsrc.json exists.
|
|
17
|
+
*/
|
|
18
|
+
async function checkContractsrcExists(fs, ctx) {
|
|
19
|
+
const configPath = fs.join(ctx.workspaceRoot, ".contractsrc.json");
|
|
20
|
+
if (await fs.exists(configPath)) return {
|
|
21
|
+
category: "config",
|
|
22
|
+
name: "Config File Exists",
|
|
23
|
+
status: "pass",
|
|
24
|
+
message: ".contractsrc.json found"
|
|
25
|
+
};
|
|
26
|
+
return {
|
|
27
|
+
category: "config",
|
|
28
|
+
name: "Config File Exists",
|
|
29
|
+
status: "fail",
|
|
30
|
+
message: ".contractsrc.json not found",
|
|
31
|
+
fix: {
|
|
32
|
+
description: "Create .contractsrc.json with defaults",
|
|
33
|
+
apply: async () => {
|
|
34
|
+
try {
|
|
35
|
+
const defaults = generateContractsrcConfig({
|
|
36
|
+
workspaceRoot: ctx.workspaceRoot,
|
|
37
|
+
interactive: false,
|
|
38
|
+
targets: []
|
|
39
|
+
});
|
|
40
|
+
await fs.writeFile(configPath, formatJson(defaults));
|
|
41
|
+
return {
|
|
42
|
+
success: true,
|
|
43
|
+
message: "Created .contractsrc.json"
|
|
44
|
+
};
|
|
45
|
+
} catch (error) {
|
|
46
|
+
return {
|
|
47
|
+
success: false,
|
|
48
|
+
message: `Failed to create: ${error instanceof Error ? error.message : String(error)}`
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* Check if .contractsrc.json is valid JSON.
|
|
57
|
+
*/
|
|
58
|
+
async function checkContractsrcValid(fs, ctx) {
|
|
59
|
+
const configPath = fs.join(ctx.workspaceRoot, ".contractsrc.json");
|
|
60
|
+
if (!await fs.exists(configPath)) return {
|
|
61
|
+
category: "config",
|
|
62
|
+
name: "Config Valid JSON",
|
|
63
|
+
status: "skip",
|
|
64
|
+
message: "Config file does not exist"
|
|
65
|
+
};
|
|
66
|
+
try {
|
|
67
|
+
const content = await fs.readFile(configPath);
|
|
68
|
+
JSON.parse(content);
|
|
69
|
+
return {
|
|
70
|
+
category: "config",
|
|
71
|
+
name: "Config Valid JSON",
|
|
72
|
+
status: "pass",
|
|
73
|
+
message: ".contractsrc.json is valid JSON"
|
|
74
|
+
};
|
|
75
|
+
} catch (error) {
|
|
76
|
+
return {
|
|
77
|
+
category: "config",
|
|
78
|
+
name: "Config Valid JSON",
|
|
79
|
+
status: "fail",
|
|
80
|
+
message: ".contractsrc.json is not valid JSON",
|
|
81
|
+
details: error instanceof Error ? error.message : String(error),
|
|
82
|
+
fix: {
|
|
83
|
+
description: "Replace with valid default config",
|
|
84
|
+
apply: async () => {
|
|
85
|
+
try {
|
|
86
|
+
const defaults = generateContractsrcConfig({
|
|
87
|
+
workspaceRoot: ctx.workspaceRoot,
|
|
88
|
+
interactive: false,
|
|
89
|
+
targets: []
|
|
90
|
+
});
|
|
91
|
+
await fs.writeFile(configPath, formatJson(defaults));
|
|
92
|
+
return {
|
|
93
|
+
success: true,
|
|
94
|
+
message: "Replaced with valid config"
|
|
95
|
+
};
|
|
96
|
+
} catch (err) {
|
|
97
|
+
return {
|
|
98
|
+
success: false,
|
|
99
|
+
message: `Failed: ${err instanceof Error ? err.message : String(err)}`
|
|
100
|
+
};
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
};
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
/**
|
|
108
|
+
* Check required fields in .contractsrc.json.
|
|
109
|
+
*/
|
|
110
|
+
async function checkContractsrcFields(fs, ctx) {
|
|
111
|
+
const configPath = fs.join(ctx.workspaceRoot, ".contractsrc.json");
|
|
112
|
+
if (!await fs.exists(configPath)) return {
|
|
113
|
+
category: "config",
|
|
114
|
+
name: "Config Fields",
|
|
115
|
+
status: "skip",
|
|
116
|
+
message: "Config file does not exist"
|
|
117
|
+
};
|
|
118
|
+
try {
|
|
119
|
+
const content = await fs.readFile(configPath);
|
|
120
|
+
const config = JSON.parse(content);
|
|
121
|
+
const missingFields = [];
|
|
122
|
+
if (!config["outputDir"]) missingFields.push("outputDir");
|
|
123
|
+
if (!config["conventions"]) missingFields.push("conventions");
|
|
124
|
+
if (missingFields.length === 0) return {
|
|
125
|
+
category: "config",
|
|
126
|
+
name: "Config Fields",
|
|
127
|
+
status: "pass",
|
|
128
|
+
message: "All recommended fields present"
|
|
129
|
+
};
|
|
130
|
+
return {
|
|
131
|
+
category: "config",
|
|
132
|
+
name: "Config Fields",
|
|
133
|
+
status: "warn",
|
|
134
|
+
message: `Missing recommended fields: ${missingFields.join(", ")}`,
|
|
135
|
+
fix: {
|
|
136
|
+
description: "Add missing fields with defaults",
|
|
137
|
+
apply: async () => {
|
|
138
|
+
try {
|
|
139
|
+
const defaults = generateContractsrcConfig({
|
|
140
|
+
workspaceRoot: ctx.workspaceRoot,
|
|
141
|
+
interactive: false,
|
|
142
|
+
targets: []
|
|
143
|
+
});
|
|
144
|
+
for (const field of missingFields) if (defaults[field] !== void 0) config[field] = defaults[field];
|
|
145
|
+
await fs.writeFile(configPath, formatJson(config));
|
|
146
|
+
return {
|
|
147
|
+
success: true,
|
|
148
|
+
message: "Added missing fields"
|
|
149
|
+
};
|
|
150
|
+
} catch (err) {
|
|
151
|
+
return {
|
|
152
|
+
success: false,
|
|
153
|
+
message: `Failed: ${err instanceof Error ? err.message : String(err)}`
|
|
154
|
+
};
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
};
|
|
159
|
+
} catch {
|
|
160
|
+
return {
|
|
161
|
+
category: "config",
|
|
162
|
+
name: "Config Fields",
|
|
163
|
+
status: "skip",
|
|
164
|
+
message: "Could not parse config"
|
|
165
|
+
};
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
|
|
169
|
+
//#endregion
|
|
170
|
+
export { runConfigChecks };
|
|
@@ -1 +1,180 @@
|
|
|
1
|
-
import{exec
|
|
1
|
+
import { exec } from "node:child_process";
|
|
2
|
+
import { promisify } from "node:util";
|
|
3
|
+
|
|
4
|
+
//#region src/services/doctor/checks/deps.ts
|
|
5
|
+
/**
|
|
6
|
+
* Dependencies health checks.
|
|
7
|
+
*/
|
|
8
|
+
const execAsync = promisify(exec);
|
|
9
|
+
/**
|
|
10
|
+
* Run dependency-related health checks.
|
|
11
|
+
*/
|
|
12
|
+
async function runDepsChecks(fs, ctx) {
|
|
13
|
+
const results = [];
|
|
14
|
+
results.push(await checkNodeJs(ctx));
|
|
15
|
+
results.push(await checkBun(ctx));
|
|
16
|
+
results.push(await checkPackageManager(fs, ctx));
|
|
17
|
+
results.push(await checkNodeModules(fs, ctx));
|
|
18
|
+
return results;
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* Check if Node.js is available.
|
|
22
|
+
*/
|
|
23
|
+
async function checkNodeJs(ctx) {
|
|
24
|
+
try {
|
|
25
|
+
const { stdout } = await execAsync("node --version", {
|
|
26
|
+
cwd: ctx.workspaceRoot,
|
|
27
|
+
timeout: 5e3
|
|
28
|
+
});
|
|
29
|
+
return {
|
|
30
|
+
category: "deps",
|
|
31
|
+
name: "Node.js",
|
|
32
|
+
status: "pass",
|
|
33
|
+
message: `Node.js ${stdout.trim()} available`
|
|
34
|
+
};
|
|
35
|
+
} catch {
|
|
36
|
+
return {
|
|
37
|
+
category: "deps",
|
|
38
|
+
name: "Node.js",
|
|
39
|
+
status: "fail",
|
|
40
|
+
message: "Node.js not found",
|
|
41
|
+
details: "Install Node.js from https://nodejs.org"
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
/**
|
|
46
|
+
* Check if Bun is available.
|
|
47
|
+
*/
|
|
48
|
+
async function checkBun(ctx) {
|
|
49
|
+
try {
|
|
50
|
+
const { stdout } = await execAsync("bun --version", {
|
|
51
|
+
cwd: ctx.workspaceRoot,
|
|
52
|
+
timeout: 5e3
|
|
53
|
+
});
|
|
54
|
+
return {
|
|
55
|
+
category: "deps",
|
|
56
|
+
name: "Bun Runtime",
|
|
57
|
+
status: "pass",
|
|
58
|
+
message: `Bun ${stdout.trim()} available`
|
|
59
|
+
};
|
|
60
|
+
} catch {
|
|
61
|
+
return {
|
|
62
|
+
category: "deps",
|
|
63
|
+
name: "Bun Runtime",
|
|
64
|
+
status: "warn",
|
|
65
|
+
message: "Bun not found (optional but recommended)",
|
|
66
|
+
details: "Install Bun from https://bun.sh for faster execution"
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* Detect and check the package manager.
|
|
72
|
+
*/
|
|
73
|
+
async function checkPackageManager(fs, ctx) {
|
|
74
|
+
const lockFiles = [
|
|
75
|
+
{
|
|
76
|
+
file: "bun.lockb",
|
|
77
|
+
name: "bun"
|
|
78
|
+
},
|
|
79
|
+
{
|
|
80
|
+
file: "pnpm-lock.yaml",
|
|
81
|
+
name: "pnpm"
|
|
82
|
+
},
|
|
83
|
+
{
|
|
84
|
+
file: "yarn.lock",
|
|
85
|
+
name: "yarn"
|
|
86
|
+
},
|
|
87
|
+
{
|
|
88
|
+
file: "package-lock.json",
|
|
89
|
+
name: "npm"
|
|
90
|
+
}
|
|
91
|
+
];
|
|
92
|
+
let detectedManager = null;
|
|
93
|
+
for (const { file, name } of lockFiles) {
|
|
94
|
+
const lockPath = fs.join(ctx.workspaceRoot, file);
|
|
95
|
+
if (await fs.exists(lockPath)) {
|
|
96
|
+
detectedManager = name;
|
|
97
|
+
break;
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
if (!detectedManager) return {
|
|
101
|
+
category: "deps",
|
|
102
|
+
name: "Package Manager",
|
|
103
|
+
status: "warn",
|
|
104
|
+
message: "No lock file found",
|
|
105
|
+
details: "Run npm install, yarn, pnpm install, or bun install"
|
|
106
|
+
};
|
|
107
|
+
try {
|
|
108
|
+
await execAsync(`${detectedManager} --version`, {
|
|
109
|
+
cwd: ctx.workspaceRoot,
|
|
110
|
+
timeout: 5e3
|
|
111
|
+
});
|
|
112
|
+
return {
|
|
113
|
+
category: "deps",
|
|
114
|
+
name: "Package Manager",
|
|
115
|
+
status: "pass",
|
|
116
|
+
message: `Using ${detectedManager}`
|
|
117
|
+
};
|
|
118
|
+
} catch {
|
|
119
|
+
return {
|
|
120
|
+
category: "deps",
|
|
121
|
+
name: "Package Manager",
|
|
122
|
+
status: "fail",
|
|
123
|
+
message: `${detectedManager} detected but not available`,
|
|
124
|
+
details: `Install ${detectedManager} or use a different package manager`
|
|
125
|
+
};
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
/**
|
|
129
|
+
* Check if node_modules exists.
|
|
130
|
+
*/
|
|
131
|
+
async function checkNodeModules(fs, ctx) {
|
|
132
|
+
const nodeModulesPath = fs.join(ctx.workspaceRoot, "node_modules");
|
|
133
|
+
if (await fs.exists(nodeModulesPath)) return {
|
|
134
|
+
category: "deps",
|
|
135
|
+
name: "Dependencies Installed",
|
|
136
|
+
status: "pass",
|
|
137
|
+
message: "node_modules directory exists"
|
|
138
|
+
};
|
|
139
|
+
return {
|
|
140
|
+
category: "deps",
|
|
141
|
+
name: "Dependencies Installed",
|
|
142
|
+
status: "fail",
|
|
143
|
+
message: "node_modules not found",
|
|
144
|
+
details: "Run your package manager install command",
|
|
145
|
+
fix: {
|
|
146
|
+
description: "Install dependencies",
|
|
147
|
+
apply: async () => {
|
|
148
|
+
try {
|
|
149
|
+
try {
|
|
150
|
+
await execAsync("bun install", {
|
|
151
|
+
cwd: ctx.workspaceRoot,
|
|
152
|
+
timeout: 12e4
|
|
153
|
+
});
|
|
154
|
+
return {
|
|
155
|
+
success: true,
|
|
156
|
+
message: "Installed with bun"
|
|
157
|
+
};
|
|
158
|
+
} catch {
|
|
159
|
+
await execAsync("npm install", {
|
|
160
|
+
cwd: ctx.workspaceRoot,
|
|
161
|
+
timeout: 12e4
|
|
162
|
+
});
|
|
163
|
+
return {
|
|
164
|
+
success: true,
|
|
165
|
+
message: "Installed with npm"
|
|
166
|
+
};
|
|
167
|
+
}
|
|
168
|
+
} catch (error) {
|
|
169
|
+
return {
|
|
170
|
+
success: false,
|
|
171
|
+
message: `Failed: ${error instanceof Error ? error.message : String(error)}`
|
|
172
|
+
};
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
};
|
|
177
|
+
}
|
|
178
|
+
|
|
179
|
+
//#endregion
|
|
180
|
+
export { runDepsChecks };
|
|
@@ -1 +1,6 @@
|
|
|
1
|
-
import
|
|
1
|
+
import { runCliChecks } from "./cli.js";
|
|
2
|
+
import { runConfigChecks } from "./config.js";
|
|
3
|
+
import { runMcpChecks } from "./mcp.js";
|
|
4
|
+
import { runDepsChecks } from "./deps.js";
|
|
5
|
+
import { runWorkspaceChecks } from "./workspace.js";
|
|
6
|
+
import { runAiChecks } from "./ai.js";
|