@erode-app/core 0.6.0-beta.0
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/adapters/adapter-factory.d.ts +3 -0
- package/dist/adapters/adapter-factory.d.ts.map +1 -0
- package/dist/adapters/adapter-factory.js +19 -0
- package/dist/adapters/adapter-factory.js.map +1 -0
- package/dist/adapters/adapter-metadata.d.ts +12 -0
- package/dist/adapters/adapter-metadata.d.ts.map +1 -0
- package/dist/adapters/adapter-metadata.js +2 -0
- package/dist/adapters/adapter-metadata.js.map +1 -0
- package/dist/adapters/architecture-adapter.d.ts +42 -0
- package/dist/adapters/architecture-adapter.d.ts.map +1 -0
- package/dist/adapters/architecture-adapter.js +2 -0
- package/dist/adapters/architecture-adapter.js.map +1 -0
- package/dist/adapters/architecture-types.d.ts +32 -0
- package/dist/adapters/architecture-types.d.ts.map +1 -0
- package/dist/adapters/architecture-types.js +2 -0
- package/dist/adapters/architecture-types.js.map +1 -0
- package/dist/adapters/base-patcher.d.ts +38 -0
- package/dist/adapters/base-patcher.d.ts.map +1 -0
- package/dist/adapters/base-patcher.js +266 -0
- package/dist/adapters/base-patcher.js.map +1 -0
- package/dist/adapters/dsl-validation.d.ts +2 -0
- package/dist/adapters/dsl-validation.d.ts.map +1 -0
- package/dist/adapters/dsl-validation.js +24 -0
- package/dist/adapters/dsl-validation.js.map +1 -0
- package/dist/adapters/likec4/adapter.d.ts +37 -0
- package/dist/adapters/likec4/adapter.d.ts.map +1 -0
- package/dist/adapters/likec4/adapter.js +302 -0
- package/dist/adapters/likec4/adapter.js.map +1 -0
- package/dist/adapters/likec4/dsl-validator.d.ts +3 -0
- package/dist/adapters/likec4/dsl-validator.d.ts.map +1 -0
- package/dist/adapters/likec4/dsl-validator.js +22 -0
- package/dist/adapters/likec4/dsl-validator.js.map +1 -0
- package/dist/adapters/likec4/index.d.ts +2 -0
- package/dist/adapters/likec4/index.d.ts.map +1 -0
- package/dist/adapters/likec4/index.js +2 -0
- package/dist/adapters/likec4/index.js.map +1 -0
- package/dist/adapters/likec4/likec4-types.d.ts +7 -0
- package/dist/adapters/likec4/likec4-types.d.ts.map +1 -0
- package/dist/adapters/likec4/likec4-types.js +2 -0
- package/dist/adapters/likec4/likec4-types.js.map +1 -0
- package/dist/adapters/likec4/metadata.d.ts +3 -0
- package/dist/adapters/likec4/metadata.d.ts.map +1 -0
- package/dist/adapters/likec4/metadata.js +30 -0
- package/dist/adapters/likec4/metadata.js.map +1 -0
- package/dist/adapters/likec4/patcher.d.ts +15 -0
- package/dist/adapters/likec4/patcher.d.ts.map +1 -0
- package/dist/adapters/likec4/patcher.js +69 -0
- package/dist/adapters/likec4/patcher.js.map +1 -0
- package/dist/adapters/likec4/version-check.d.ts +11 -0
- package/dist/adapters/likec4/version-check.d.ts.map +1 -0
- package/dist/adapters/likec4/version-check.js +75 -0
- package/dist/adapters/likec4/version-check.js.map +1 -0
- package/dist/adapters/model-patcher.d.ts +49 -0
- package/dist/adapters/model-patcher.d.ts.map +1 -0
- package/dist/adapters/model-patcher.js +15 -0
- package/dist/adapters/model-patcher.js.map +1 -0
- package/dist/adapters/structurizr/adapter.d.ts +39 -0
- package/dist/adapters/structurizr/adapter.d.ts.map +1 -0
- package/dist/adapters/structurizr/adapter.js +372 -0
- package/dist/adapters/structurizr/adapter.js.map +1 -0
- package/dist/adapters/structurizr/dsl-validator.d.ts +3 -0
- package/dist/adapters/structurizr/dsl-validator.d.ts.map +1 -0
- package/dist/adapters/structurizr/dsl-validator.js +26 -0
- package/dist/adapters/structurizr/dsl-validator.js.map +1 -0
- package/dist/adapters/structurizr/index.d.ts +2 -0
- package/dist/adapters/structurizr/index.d.ts.map +1 -0
- package/dist/adapters/structurizr/index.js +2 -0
- package/dist/adapters/structurizr/index.js.map +1 -0
- package/dist/adapters/structurizr/metadata.d.ts +3 -0
- package/dist/adapters/structurizr/metadata.d.ts.map +1 -0
- package/dist/adapters/structurizr/metadata.js +35 -0
- package/dist/adapters/structurizr/metadata.js.map +1 -0
- package/dist/adapters/structurizr/patcher.d.ts +15 -0
- package/dist/adapters/structurizr/patcher.d.ts.map +1 -0
- package/dist/adapters/structurizr/patcher.js +53 -0
- package/dist/adapters/structurizr/patcher.js.map +1 -0
- package/dist/adapters/structurizr/structurizr-cli.d.ts +2 -0
- package/dist/adapters/structurizr/structurizr-cli.d.ts.map +1 -0
- package/dist/adapters/structurizr/structurizr-cli.js +91 -0
- package/dist/adapters/structurizr/structurizr-cli.js.map +1 -0
- package/dist/adapters/structurizr/structurizr-types.d.ts +3 -0
- package/dist/adapters/structurizr/structurizr-types.d.ts.map +1 -0
- package/dist/adapters/structurizr/structurizr-types.js +2 -0
- package/dist/adapters/structurizr/structurizr-types.js.map +1 -0
- package/dist/adapters/url-utils.d.ts +3 -0
- package/dist/adapters/url-utils.d.ts.map +1 -0
- package/dist/adapters/url-utils.js +53 -0
- package/dist/adapters/url-utils.js.map +1 -0
- package/dist/analysis/analysis-types.d.ts +152 -0
- package/dist/analysis/analysis-types.d.ts.map +1 -0
- package/dist/analysis/analysis-types.js +2 -0
- package/dist/analysis/analysis-types.js.map +1 -0
- package/dist/analysis/prompt-builder.d.ts +27 -0
- package/dist/analysis/prompt-builder.d.ts.map +1 -0
- package/dist/analysis/prompt-builder.js +159 -0
- package/dist/analysis/prompt-builder.js.map +1 -0
- package/dist/analysis/prompt-variables.d.ts +72 -0
- package/dist/analysis/prompt-variables.d.ts.map +1 -0
- package/dist/analysis/prompt-variables.js +2 -0
- package/dist/analysis/prompt-variables.js.map +1 -0
- package/dist/analysis/prompts/component-selection.md +50 -0
- package/dist/analysis/prompts/dependency-extraction.md +219 -0
- package/dist/analysis/prompts/drift-analysis.md +154 -0
- package/dist/analysis/prompts/model-patch.md +29 -0
- package/dist/analysis/section-formatters.d.ts +54 -0
- package/dist/analysis/section-formatters.d.ts.map +1 -0
- package/dist/analysis/section-formatters.js +95 -0
- package/dist/analysis/section-formatters.js.map +1 -0
- package/dist/analysis/template-engine.d.ts +11 -0
- package/dist/analysis/template-engine.d.ts.map +1 -0
- package/dist/analysis/template-engine.js +64 -0
- package/dist/analysis/template-engine.js.map +1 -0
- package/dist/ci-entry.d.ts +3 -0
- package/dist/ci-entry.d.ts.map +1 -0
- package/dist/ci-entry.js +67 -0
- package/dist/ci-entry.js.map +1 -0
- package/dist/errors.d.ts +60 -0
- package/dist/errors.d.ts.map +1 -0
- package/dist/errors.js +134 -0
- package/dist/errors.js.map +1 -0
- package/dist/index.d.ts +45 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +38 -0
- package/dist/index.js.map +1 -0
- package/dist/output/ci-output.d.ts +13 -0
- package/dist/output/ci-output.d.ts.map +1 -0
- package/dist/output/ci-output.js +106 -0
- package/dist/output/ci-output.js.map +1 -0
- package/dist/output/structured-output.d.ts +89 -0
- package/dist/output/structured-output.d.ts.map +1 -0
- package/dist/output/structured-output.js +2 -0
- package/dist/output/structured-output.js.map +1 -0
- package/dist/output.d.ts +73 -0
- package/dist/output.d.ts.map +1 -0
- package/dist/output.js +304 -0
- package/dist/output.js.map +1 -0
- package/dist/pipelines/analyze.d.ts +35 -0
- package/dist/pipelines/analyze.d.ts.map +1 -0
- package/dist/pipelines/analyze.js +316 -0
- package/dist/pipelines/analyze.js.map +1 -0
- package/dist/pipelines/check.d.ts +48 -0
- package/dist/pipelines/check.d.ts.map +1 -0
- package/dist/pipelines/check.js +218 -0
- package/dist/pipelines/check.js.map +1 -0
- package/dist/pipelines/components.d.ts +8 -0
- package/dist/pipelines/components.d.ts.map +1 -0
- package/dist/pipelines/components.js +14 -0
- package/dist/pipelines/components.js.map +1 -0
- package/dist/pipelines/connections.d.ts +34 -0
- package/dist/pipelines/connections.d.ts.map +1 -0
- package/dist/pipelines/connections.js +53 -0
- package/dist/pipelines/connections.js.map +1 -0
- package/dist/pipelines/pr-creation.d.ts +30 -0
- package/dist/pipelines/pr-creation.d.ts.map +1 -0
- package/dist/pipelines/pr-creation.js +26 -0
- package/dist/pipelines/pr-creation.js.map +1 -0
- package/dist/pipelines/progress.d.ts +23 -0
- package/dist/pipelines/progress.d.ts.map +1 -0
- package/dist/pipelines/progress.js +22 -0
- package/dist/pipelines/progress.js.map +1 -0
- package/dist/pipelines/publish.d.ts +39 -0
- package/dist/pipelines/publish.d.ts.map +1 -0
- package/dist/pipelines/publish.js +125 -0
- package/dist/pipelines/publish.js.map +1 -0
- package/dist/pipelines/validate.d.ts +24 -0
- package/dist/pipelines/validate.d.ts.map +1 -0
- package/dist/pipelines/validate.js +79 -0
- package/dist/pipelines/validate.js.map +1 -0
- package/dist/platforms/bitbucket/api-client.d.ts +21 -0
- package/dist/platforms/bitbucket/api-client.d.ts.map +1 -0
- package/dist/platforms/bitbucket/api-client.js +98 -0
- package/dist/platforms/bitbucket/api-client.js.map +1 -0
- package/dist/platforms/bitbucket/index.d.ts +3 -0
- package/dist/platforms/bitbucket/index.d.ts.map +1 -0
- package/dist/platforms/bitbucket/index.js +3 -0
- package/dist/platforms/bitbucket/index.js.map +1 -0
- package/dist/platforms/bitbucket/reader.d.ts +9 -0
- package/dist/platforms/bitbucket/reader.d.ts.map +1 -0
- package/dist/platforms/bitbucket/reader.js +119 -0
- package/dist/platforms/bitbucket/reader.js.map +1 -0
- package/dist/platforms/bitbucket/writer.d.ts +15 -0
- package/dist/platforms/bitbucket/writer.d.ts.map +1 -0
- package/dist/platforms/bitbucket/writer.js +172 -0
- package/dist/platforms/bitbucket/writer.js.map +1 -0
- package/dist/platforms/github/index.d.ts +3 -0
- package/dist/platforms/github/index.d.ts.map +1 -0
- package/dist/platforms/github/index.js +3 -0
- package/dist/platforms/github/index.js.map +1 -0
- package/dist/platforms/github/reader.d.ts +9 -0
- package/dist/platforms/github/reader.d.ts.map +1 -0
- package/dist/platforms/github/reader.js +141 -0
- package/dist/platforms/github/reader.js.map +1 -0
- package/dist/platforms/github/writer.d.ts +15 -0
- package/dist/platforms/github/writer.d.ts.map +1 -0
- package/dist/platforms/github/writer.js +225 -0
- package/dist/platforms/github/writer.js.map +1 -0
- package/dist/platforms/gitlab/index.d.ts +3 -0
- package/dist/platforms/gitlab/index.d.ts.map +1 -0
- package/dist/platforms/gitlab/index.js +3 -0
- package/dist/platforms/gitlab/index.js.map +1 -0
- package/dist/platforms/gitlab/reader.d.ts +9 -0
- package/dist/platforms/gitlab/reader.d.ts.map +1 -0
- package/dist/platforms/gitlab/reader.js +136 -0
- package/dist/platforms/gitlab/reader.js.map +1 -0
- package/dist/platforms/gitlab/writer.d.ts +14 -0
- package/dist/platforms/gitlab/writer.d.ts.map +1 -0
- package/dist/platforms/gitlab/writer.js +130 -0
- package/dist/platforms/gitlab/writer.js.map +1 -0
- package/dist/platforms/platform-factory.d.ts +7 -0
- package/dist/platforms/platform-factory.d.ts.map +1 -0
- package/dist/platforms/platform-factory.js +53 -0
- package/dist/platforms/platform-factory.js.map +1 -0
- package/dist/platforms/platform-utils.d.ts +12 -0
- package/dist/platforms/platform-utils.d.ts.map +1 -0
- package/dist/platforms/platform-utils.js +48 -0
- package/dist/platforms/platform-utils.js.map +1 -0
- package/dist/platforms/source-platform.d.ts +117 -0
- package/dist/platforms/source-platform.d.ts.map +1 -0
- package/dist/platforms/source-platform.js +2 -0
- package/dist/platforms/source-platform.js.map +1 -0
- package/dist/providers/ai-provider.d.ts +23 -0
- package/dist/providers/ai-provider.d.ts.map +1 -0
- package/dist/providers/ai-provider.js +2 -0
- package/dist/providers/ai-provider.js.map +1 -0
- package/dist/providers/analysis-phase.d.ts +13 -0
- package/dist/providers/analysis-phase.d.ts.map +1 -0
- package/dist/providers/analysis-phase.js +14 -0
- package/dist/providers/analysis-phase.js.map +1 -0
- package/dist/providers/anthropic/models.d.ts +5 -0
- package/dist/providers/anthropic/models.d.ts.map +1 -0
- package/dist/providers/anthropic/models.js +5 -0
- package/dist/providers/anthropic/models.js.map +1 -0
- package/dist/providers/anthropic/provider.d.ts +12 -0
- package/dist/providers/anthropic/provider.d.ts.map +1 -0
- package/dist/providers/anthropic/provider.js +47 -0
- package/dist/providers/anthropic/provider.js.map +1 -0
- package/dist/providers/base-provider.d.ts +34 -0
- package/dist/providers/base-provider.d.ts.map +1 -0
- package/dist/providers/base-provider.js +100 -0
- package/dist/providers/base-provider.js.map +1 -0
- package/dist/providers/gemini/models.d.ts +5 -0
- package/dist/providers/gemini/models.d.ts.map +1 -0
- package/dist/providers/gemini/models.js +5 -0
- package/dist/providers/gemini/models.js.map +1 -0
- package/dist/providers/gemini/provider.d.ts +12 -0
- package/dist/providers/gemini/provider.d.ts.map +1 -0
- package/dist/providers/gemini/provider.js +42 -0
- package/dist/providers/gemini/provider.js.map +1 -0
- package/dist/providers/openai/models.d.ts +5 -0
- package/dist/providers/openai/models.d.ts.map +1 -0
- package/dist/providers/openai/models.js +5 -0
- package/dist/providers/openai/models.js.map +1 -0
- package/dist/providers/openai/provider.d.ts +12 -0
- package/dist/providers/openai/provider.d.ts.map +1 -0
- package/dist/providers/openai/provider.js +49 -0
- package/dist/providers/openai/provider.js.map +1 -0
- package/dist/providers/provider-factory.d.ts +3 -0
- package/dist/providers/provider-factory.d.ts.map +1 -0
- package/dist/providers/provider-factory.js +45 -0
- package/dist/providers/provider-factory.js.map +1 -0
- package/dist/schemas/bitbucket-api.schema.d.ts +52 -0
- package/dist/schemas/bitbucket-api.schema.d.ts.map +1 -0
- package/dist/schemas/bitbucket-api.schema.js +50 -0
- package/dist/schemas/bitbucket-api.schema.js.map +1 -0
- package/dist/schemas/common.schema.d.ts +46 -0
- package/dist/schemas/common.schema.d.ts.map +1 -0
- package/dist/schemas/common.schema.js +67 -0
- package/dist/schemas/common.schema.js.map +1 -0
- package/dist/schemas/dependency-extraction.schema.d.ts +17 -0
- package/dist/schemas/dependency-extraction.schema.d.ts.map +1 -0
- package/dist/schemas/dependency-extraction.schema.js +13 -0
- package/dist/schemas/dependency-extraction.schema.js.map +1 -0
- package/dist/schemas/drift-analysis.schema.d.ts +40 -0
- package/dist/schemas/drift-analysis.schema.d.ts.map +1 -0
- package/dist/schemas/drift-analysis.schema.js +15 -0
- package/dist/schemas/drift-analysis.schema.js.map +1 -0
- package/dist/schemas/gitlab-api.schema.d.ts +33 -0
- package/dist/schemas/gitlab-api.schema.d.ts.map +1 -0
- package/dist/schemas/gitlab-api.schema.js +33 -0
- package/dist/schemas/gitlab-api.schema.js.map +1 -0
- package/dist/schemas/likec4.schema.d.ts +26 -0
- package/dist/schemas/likec4.schema.d.ts.map +1 -0
- package/dist/schemas/likec4.schema.js +23 -0
- package/dist/schemas/likec4.schema.js.map +1 -0
- package/dist/schemas/package.schema.d.ts +5 -0
- package/dist/schemas/package.schema.d.ts.map +1 -0
- package/dist/schemas/package.schema.js +5 -0
- package/dist/schemas/package.schema.js.map +1 -0
- package/dist/schemas/source-platform.schema.d.ts +56 -0
- package/dist/schemas/source-platform.schema.d.ts.map +1 -0
- package/dist/schemas/source-platform.schema.js +49 -0
- package/dist/schemas/source-platform.schema.js.map +1 -0
- package/dist/schemas/structurizr.schema.d.ts +234 -0
- package/dist/schemas/structurizr.schema.d.ts.map +1 -0
- package/dist/schemas/structurizr.schema.js +54 -0
- package/dist/schemas/structurizr.schema.js.map +1 -0
- package/dist/skip-patterns +62 -0
- package/dist/utils/config.d.ts +156 -0
- package/dist/utils/config.d.ts.map +1 -0
- package/dist/utils/config.js +267 -0
- package/dist/utils/config.js.map +1 -0
- package/dist/utils/error-utils.d.ts +2 -0
- package/dist/utils/error-utils.d.ts.map +1 -0
- package/dist/utils/error-utils.js +6 -0
- package/dist/utils/error-utils.js.map +1 -0
- package/dist/utils/git-diff.d.ts +35 -0
- package/dist/utils/git-diff.d.ts.map +1 -0
- package/dist/utils/git-diff.js +114 -0
- package/dist/utils/git-diff.js.map +1 -0
- package/dist/utils/model-source.d.ts +30 -0
- package/dist/utils/model-source.d.ts.map +1 -0
- package/dist/utils/model-source.js +167 -0
- package/dist/utils/model-source.js.map +1 -0
- package/dist/utils/retry.d.ts +9 -0
- package/dist/utils/retry.d.ts.map +1 -0
- package/dist/utils/retry.js +51 -0
- package/dist/utils/retry.js.map +1 -0
- package/dist/utils/skip-patterns.d.ts +7 -0
- package/dist/utils/skip-patterns.d.ts.map +1 -0
- package/dist/utils/skip-patterns.js +35 -0
- package/dist/utils/skip-patterns.js.map +1 -0
- package/dist/utils/validation.d.ts +4 -0
- package/dist/utils/validation.d.ts.map +1 -0
- package/dist/utils/validation.js +37 -0
- package/dist/utils/validation.js.map +1 -0
- package/package.json +78 -0
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { SilentProgress } from './progress.js';
|
|
2
|
+
import { createAdapter } from '../adapters/adapter-factory.js';
|
|
3
|
+
import { validatePath } from '../utils/validation.js';
|
|
4
|
+
export async function runComponents(options, progress) {
|
|
5
|
+
const p = progress ?? new SilentProgress();
|
|
6
|
+
const adapter = createAdapter(options.modelFormat);
|
|
7
|
+
p.section(`Loading ${adapter.metadata.displayName} Architecture Model`);
|
|
8
|
+
validatePath(options.modelPath, 'directory');
|
|
9
|
+
p.start('Loading architecture model');
|
|
10
|
+
const components = await adapter.loadAndListComponents(options.modelPath);
|
|
11
|
+
p.succeed(`Loaded ${String(components.length)} components`);
|
|
12
|
+
return components;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=components.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"components.js","sourceRoot":"","sources":["../../src/pipelines/components.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAC/C,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAC/D,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AAQtD,MAAM,CAAC,KAAK,UAAU,aAAa,CACjC,OAA0B,EAC1B,QAA2B;IAE3B,MAAM,CAAC,GAAG,QAAQ,IAAI,IAAI,cAAc,EAAE,CAAC;IAC3C,MAAM,OAAO,GAAG,aAAa,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;IAEnD,CAAC,CAAC,OAAO,CAAC,WAAW,OAAO,CAAC,QAAQ,CAAC,WAAW,qBAAqB,CAAC,CAAC;IACxE,YAAY,CAAC,OAAO,CAAC,SAAS,EAAE,WAAW,CAAC,CAAC;IAC7C,CAAC,CAAC,KAAK,CAAC,4BAA4B,CAAC,CAAC;IAEtC,MAAM,UAAU,GAAG,MAAM,OAAO,CAAC,qBAAqB,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;IAC1E,CAAC,CAAC,OAAO,CAAC,UAAU,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;IAE5D,OAAO,UAAU,CAAC;AACpB,CAAC"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import type { ProgressReporter } from './progress.js';
|
|
2
|
+
export interface ConnectionsOptions {
|
|
3
|
+
modelPath: string;
|
|
4
|
+
modelFormat?: string;
|
|
5
|
+
repo: string;
|
|
6
|
+
}
|
|
7
|
+
export interface ComponentConnections {
|
|
8
|
+
component: {
|
|
9
|
+
id: string;
|
|
10
|
+
name: string;
|
|
11
|
+
type: string;
|
|
12
|
+
repository?: string;
|
|
13
|
+
};
|
|
14
|
+
dependencies: {
|
|
15
|
+
id: string;
|
|
16
|
+
name: string;
|
|
17
|
+
type: string;
|
|
18
|
+
repository?: string;
|
|
19
|
+
}[];
|
|
20
|
+
dependents: {
|
|
21
|
+
id: string;
|
|
22
|
+
name: string;
|
|
23
|
+
type: string;
|
|
24
|
+
repository?: string;
|
|
25
|
+
}[];
|
|
26
|
+
relationships: {
|
|
27
|
+
targetId: string;
|
|
28
|
+
targetName: string;
|
|
29
|
+
kind?: string;
|
|
30
|
+
title?: string;
|
|
31
|
+
}[];
|
|
32
|
+
}
|
|
33
|
+
export declare function runConnections(options: ConnectionsOptions, progress?: ProgressReporter): Promise<ComponentConnections[]>;
|
|
34
|
+
//# sourceMappingURL=connections.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"connections.d.ts","sourceRoot":"","sources":["../../src/pipelines/connections.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAKtD,MAAM,WAAW,kBAAkB;IACjC,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,IAAI,EAAE,MAAM,CAAC;CACd;AAED,MAAM,WAAW,oBAAoB;IACnC,SAAS,EAAE;QACT,EAAE,EAAE,MAAM,CAAC;QACX,IAAI,EAAE,MAAM,CAAC;QACb,IAAI,EAAE,MAAM,CAAC;QACb,UAAU,CAAC,EAAE,MAAM,CAAC;KACrB,CAAC;IACF,YAAY,EAAE;QACZ,EAAE,EAAE,MAAM,CAAC;QACX,IAAI,EAAE,MAAM,CAAC;QACb,IAAI,EAAE,MAAM,CAAC;QACb,UAAU,CAAC,EAAE,MAAM,CAAC;KACrB,EAAE,CAAC;IACJ,UAAU,EAAE;QACV,EAAE,EAAE,MAAM,CAAC;QACX,IAAI,EAAE,MAAM,CAAC;QACb,IAAI,EAAE,MAAM,CAAC;QACb,UAAU,CAAC,EAAE,MAAM,CAAC;KACrB,EAAE,CAAC;IACJ,aAAa,EAAE;QACb,QAAQ,EAAE,MAAM,CAAC;QACjB,UAAU,EAAE,MAAM,CAAC;QACnB,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,KAAK,CAAC,EAAE,MAAM,CAAC;KAChB,EAAE,CAAC;CACL;AAED,wBAAsB,cAAc,CAClC,OAAO,EAAE,kBAAkB,EAC3B,QAAQ,CAAC,EAAE,gBAAgB,GAC1B,OAAO,CAAC,oBAAoB,EAAE,CAAC,CAqDjC"}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { SilentProgress } from './progress.js';
|
|
2
|
+
import { createAdapter } from '../adapters/adapter-factory.js';
|
|
3
|
+
import { validatePath } from '../utils/validation.js';
|
|
4
|
+
export async function runConnections(options, progress) {
|
|
5
|
+
const p = progress ?? new SilentProgress();
|
|
6
|
+
const adapter = createAdapter(options.modelFormat);
|
|
7
|
+
p.section(`Loading ${adapter.metadata.displayName} Architecture Model`);
|
|
8
|
+
validatePath(options.modelPath, 'directory');
|
|
9
|
+
p.start('Loading architecture model');
|
|
10
|
+
await adapter.loadFromPath(options.modelPath);
|
|
11
|
+
p.succeed('Architecture model loaded');
|
|
12
|
+
p.start(`Finding components for ${options.repo}`);
|
|
13
|
+
const components = adapter.findAllComponentsByRepository(options.repo);
|
|
14
|
+
if (components.length === 0) {
|
|
15
|
+
p.warn(`No components found for repository: ${options.repo}`);
|
|
16
|
+
p.info('Run "erode validate [model-path]" to check which components have repository links.');
|
|
17
|
+
return [];
|
|
18
|
+
}
|
|
19
|
+
p.succeed(`Found ${String(components.length)} component(s)`);
|
|
20
|
+
const results = components.map((component) => {
|
|
21
|
+
const dependencies = adapter.getComponentDependencies(component.id);
|
|
22
|
+
const dependents = adapter.getComponentDependents(component.id);
|
|
23
|
+
const relationships = adapter.getComponentRelationships(component.id);
|
|
24
|
+
return {
|
|
25
|
+
component: {
|
|
26
|
+
id: component.id,
|
|
27
|
+
name: component.name,
|
|
28
|
+
type: component.type,
|
|
29
|
+
repository: component.repository,
|
|
30
|
+
},
|
|
31
|
+
dependencies: dependencies.map((d) => ({
|
|
32
|
+
id: d.id,
|
|
33
|
+
name: d.name,
|
|
34
|
+
type: d.type,
|
|
35
|
+
repository: d.repository,
|
|
36
|
+
})),
|
|
37
|
+
dependents: dependents.map((d) => ({
|
|
38
|
+
id: d.id,
|
|
39
|
+
name: d.name,
|
|
40
|
+
type: d.type,
|
|
41
|
+
repository: d.repository,
|
|
42
|
+
})),
|
|
43
|
+
relationships: relationships.map((r) => ({
|
|
44
|
+
targetId: r.target.id,
|
|
45
|
+
targetName: r.target.name,
|
|
46
|
+
kind: r.kind,
|
|
47
|
+
title: r.title,
|
|
48
|
+
})),
|
|
49
|
+
};
|
|
50
|
+
});
|
|
51
|
+
return results;
|
|
52
|
+
}
|
|
53
|
+
//# sourceMappingURL=connections.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"connections.js","sourceRoot":"","sources":["../../src/pipelines/connections.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import type { ChangeRequestFileWrite } from '../platforms/source-platform.js';
|
|
2
|
+
import type { AdapterMetadata } from '../adapters/adapter-metadata.js';
|
|
3
|
+
export declare function modelPrBranchName(sourceRepo: string, prNumber: number): string;
|
|
4
|
+
export interface CreateModelPrOptions {
|
|
5
|
+
repositoryUrl: string;
|
|
6
|
+
owner: string;
|
|
7
|
+
repo: string;
|
|
8
|
+
prNumber: number;
|
|
9
|
+
prTitle: string;
|
|
10
|
+
sourceRepo: string;
|
|
11
|
+
adapterMetadata: AdapterMetadata;
|
|
12
|
+
fileChanges: ChangeRequestFileWrite[];
|
|
13
|
+
body: string;
|
|
14
|
+
draft?: boolean;
|
|
15
|
+
}
|
|
16
|
+
export interface CreateModelPrResult {
|
|
17
|
+
url: string;
|
|
18
|
+
number: number;
|
|
19
|
+
action: 'created' | 'updated';
|
|
20
|
+
branch: string;
|
|
21
|
+
}
|
|
22
|
+
export declare function createModelPr(options: CreateModelPrOptions): Promise<CreateModelPrResult>;
|
|
23
|
+
export declare function closeModelPr(options: {
|
|
24
|
+
repositoryUrl: string;
|
|
25
|
+
owner: string;
|
|
26
|
+
repo: string;
|
|
27
|
+
sourceRepo: string;
|
|
28
|
+
prNumber: number;
|
|
29
|
+
}): Promise<void>;
|
|
30
|
+
//# sourceMappingURL=pr-creation.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pr-creation.d.ts","sourceRoot":"","sources":["../../src/pipelines/pr-creation.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,iCAAiC,CAAC;AAC9E,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;AAEvE,wBAAgB,iBAAiB,CAAC,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,MAAM,CAG9E;AAED,MAAM,WAAW,oBAAoB;IACnC,aAAa,EAAE,MAAM,CAAC;IACtB,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,UAAU,EAAE,MAAM,CAAC;IACnB,eAAe,EAAE,eAAe,CAAC;IACjC,WAAW,EAAE,sBAAsB,EAAE,CAAC;IACtC,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,CAAC,EAAE,OAAO,CAAC;CACjB;AAED,MAAM,WAAW,mBAAmB;IAClC,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,SAAS,GAAG,SAAS,CAAC;IAC9B,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,wBAAsB,aAAa,CAAC,OAAO,EAAE,oBAAoB,GAAG,OAAO,CAAC,mBAAmB,CAAC,CAe/F;AAED,wBAAsB,YAAY,CAAC,OAAO,EAAE;IAC1C,aAAa,EAAE,MAAM,CAAC;IACtB,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;CAClB,GAAG,OAAO,CAAC,IAAI,CAAC,CAGhB"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { createPlatformWriter } from '../platforms/platform-factory.js';
|
|
2
|
+
export function modelPrBranchName(sourceRepo, prNumber) {
|
|
3
|
+
const slug = sourceRepo.replace(/\//g, '-').replace(/[^a-zA-Z0-9._-]/g, '');
|
|
4
|
+
return `erode/${slug}/pr-${String(prNumber)}`;
|
|
5
|
+
}
|
|
6
|
+
export async function createModelPr(options) {
|
|
7
|
+
const writer = createPlatformWriter(options.repositoryUrl, options.owner, options.repo);
|
|
8
|
+
const branchName = modelPrBranchName(options.sourceRepo, options.prNumber);
|
|
9
|
+
const prTitle = options.adapterMetadata.prTitleTemplate
|
|
10
|
+
.replace('{{prNumber}}', String(options.prNumber))
|
|
11
|
+
.replace('{{prTitle}}', options.prTitle)
|
|
12
|
+
.replace('{{sourceRepo}}', options.sourceRepo);
|
|
13
|
+
const prResult = await writer.createOrUpdateChangeRequest({
|
|
14
|
+
branchName,
|
|
15
|
+
title: prTitle,
|
|
16
|
+
body: options.body,
|
|
17
|
+
fileChanges: options.fileChanges,
|
|
18
|
+
draft: options.draft,
|
|
19
|
+
});
|
|
20
|
+
return { ...prResult, branch: branchName };
|
|
21
|
+
}
|
|
22
|
+
export async function closeModelPr(options) {
|
|
23
|
+
const writer = createPlatformWriter(options.repositoryUrl, options.owner, options.repo);
|
|
24
|
+
await writer.closeChangeRequest(modelPrBranchName(options.sourceRepo, options.prNumber));
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=pr-creation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pr-creation.js","sourceRoot":"","sources":["../../src/pipelines/pr-creation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,kCAAkC,CAAC;AAIxE,MAAM,UAAU,iBAAiB,CAAC,UAAkB,EAAE,QAAgB;IACpE,MAAM,IAAI,GAAG,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,OAAO,CAAC,kBAAkB,EAAE,EAAE,CAAC,CAAC;IAC5E,OAAO,SAAS,IAAI,OAAO,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC;AAChD,CAAC;AAsBD,MAAM,CAAC,KAAK,UAAU,aAAa,CAAC,OAA6B;IAC/D,MAAM,MAAM,GAAG,oBAAoB,CAAC,OAAO,CAAC,aAAa,EAAE,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;IACxF,MAAM,UAAU,GAAG,iBAAiB,CAAC,OAAO,CAAC,UAAU,EAAE,OAAO,CAAC,QAAQ,CAAC,CAAC;IAC3E,MAAM,OAAO,GAAG,OAAO,CAAC,eAAe,CAAC,eAAe;SACpD,OAAO,CAAC,cAAc,EAAE,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;SACjD,OAAO,CAAC,aAAa,EAAE,OAAO,CAAC,OAAO,CAAC;SACvC,OAAO,CAAC,gBAAgB,EAAE,OAAO,CAAC,UAAU,CAAC,CAAC;IACjD,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,2BAA2B,CAAC;QACxD,UAAU;QACV,KAAK,EAAE,OAAO;QACd,IAAI,EAAE,OAAO,CAAC,IAAI;QAClB,WAAW,EAAE,OAAO,CAAC,WAAW;QAChC,KAAK,EAAE,OAAO,CAAC,KAAK;KACrB,CAAC,CAAC;IACH,OAAO,EAAE,GAAG,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC;AAC7C,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,YAAY,CAAC,OAMlC;IACC,MAAM,MAAM,GAAG,oBAAoB,CAAC,OAAO,CAAC,aAAa,EAAE,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;IACxF,MAAM,MAAM,CAAC,kBAAkB,CAAC,iBAAiB,CAAC,OAAO,CAAC,UAAU,EAAE,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC;AAC3F,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Progress reporting abstraction for pipeline functions.
|
|
3
|
+
*
|
|
4
|
+
* CI callers pass SilentProgress; CLI callers pass a ConsoleProgress reporter.
|
|
5
|
+
*/
|
|
6
|
+
export interface ProgressReporter {
|
|
7
|
+
section(title: string): void;
|
|
8
|
+
start(message: string): void;
|
|
9
|
+
succeed(message: string): void;
|
|
10
|
+
fail(message: string): void;
|
|
11
|
+
warn(message: string): void;
|
|
12
|
+
info(message: string): void;
|
|
13
|
+
}
|
|
14
|
+
/** No-op progress reporter — swallows every call silently. */
|
|
15
|
+
export declare class SilentProgress implements ProgressReporter {
|
|
16
|
+
section(_title: string): void;
|
|
17
|
+
start(_message: string): void;
|
|
18
|
+
succeed(_message: string): void;
|
|
19
|
+
fail(_message: string): void;
|
|
20
|
+
warn(_message: string): void;
|
|
21
|
+
info(_message: string): void;
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=progress.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"progress.d.ts","sourceRoot":"","sources":["../../src/pipelines/progress.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AACH,MAAM,WAAW,gBAAgB;IAC/B,OAAO,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IAC7B,KAAK,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IAC7B,OAAO,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IAC/B,IAAI,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,IAAI,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,IAAI,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;CAC7B;AAED,8DAA8D;AAC9D,qBAAa,cAAe,YAAW,gBAAgB;IACrD,OAAO,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI;IAG7B,KAAK,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAG7B,OAAO,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAG/B,IAAI,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAG5B,IAAI,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAG5B,IAAI,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;CAG7B"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
/** No-op progress reporter — swallows every call silently. */
|
|
2
|
+
export class SilentProgress {
|
|
3
|
+
section(_title) {
|
|
4
|
+
/* noop */
|
|
5
|
+
}
|
|
6
|
+
start(_message) {
|
|
7
|
+
/* noop */
|
|
8
|
+
}
|
|
9
|
+
succeed(_message) {
|
|
10
|
+
/* noop */
|
|
11
|
+
}
|
|
12
|
+
fail(_message) {
|
|
13
|
+
/* noop */
|
|
14
|
+
}
|
|
15
|
+
warn(_message) {
|
|
16
|
+
/* noop */
|
|
17
|
+
}
|
|
18
|
+
info(_message) {
|
|
19
|
+
/* noop */
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=progress.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"progress.js","sourceRoot":"","sources":["../../src/pipelines/progress.ts"],"names":[],"mappings":"AAcA,8DAA8D;AAC9D,MAAM,OAAO,cAAc;IACzB,OAAO,CAAC,MAAc;QACpB,UAAU;IACZ,CAAC;IACD,KAAK,CAAC,QAAgB;QACpB,UAAU;IACZ,CAAC;IACD,OAAO,CAAC,QAAgB;QACtB,UAAU;IACZ,CAAC;IACD,IAAI,CAAC,QAAgB;QACnB,UAAU;IACZ,CAAC;IACD,IAAI,CAAC,QAAgB;QACnB,UAAU;IACZ,CAAC;IACD,IAAI,CAAC,QAAgB;QACnB,UAAU;IACZ,CAAC;CACF"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import type { ProgressReporter } from './progress.js';
|
|
2
|
+
import type { ChangeRequestRef } from '../platforms/source-platform.js';
|
|
3
|
+
import type { AdapterMetadata } from '../adapters/adapter-metadata.js';
|
|
4
|
+
import type { DriftAnalysisResult } from '../analysis/analysis-types.js';
|
|
5
|
+
import type { PatchResult } from '../adapters/model-patcher.js';
|
|
6
|
+
import type { StructuredAnalysisOutput } from '../output/structured-output.js';
|
|
7
|
+
export interface PublishOptions {
|
|
8
|
+
ref: ChangeRequestRef;
|
|
9
|
+
analysisResult: DriftAnalysisResult;
|
|
10
|
+
patchResult: PatchResult | null;
|
|
11
|
+
structured: StructuredAnalysisOutput | undefined;
|
|
12
|
+
adapterMetadata: AdapterMetadata;
|
|
13
|
+
options: {
|
|
14
|
+
openPr?: boolean;
|
|
15
|
+
dryRun?: boolean;
|
|
16
|
+
draft?: boolean;
|
|
17
|
+
modelRepo?: string;
|
|
18
|
+
comment?: boolean;
|
|
19
|
+
githubActions?: boolean;
|
|
20
|
+
};
|
|
21
|
+
context: {
|
|
22
|
+
selectedComponentId?: string;
|
|
23
|
+
candidateComponents?: {
|
|
24
|
+
id: string;
|
|
25
|
+
name: string;
|
|
26
|
+
type: string;
|
|
27
|
+
}[];
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
export interface PublishResult {
|
|
31
|
+
generatedChangeRequest?: {
|
|
32
|
+
url: string;
|
|
33
|
+
number: number;
|
|
34
|
+
action: 'created' | 'updated';
|
|
35
|
+
branch: string;
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
export declare function publishResults(publish: PublishOptions, p: ProgressReporter): Promise<PublishResult>;
|
|
39
|
+
//# sourceMappingURL=publish.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"publish.d.ts","sourceRoot":"","sources":["../../src/pipelines/publish.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACtD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;AACxE,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;AACvE,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,+BAA+B,CAAC;AACzE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,8BAA8B,CAAC;AAChE,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,gCAAgC,CAAC;AAoB/E,MAAM,WAAW,cAAc;IAC7B,GAAG,EAAE,gBAAgB,CAAC;IACtB,cAAc,EAAE,mBAAmB,CAAC;IACpC,WAAW,EAAE,WAAW,GAAG,IAAI,CAAC;IAChC,UAAU,EAAE,wBAAwB,GAAG,SAAS,CAAC;IACjD,eAAe,EAAE,eAAe,CAAC;IACjC,OAAO,EAAE;QACP,MAAM,CAAC,EAAE,OAAO,CAAC;QACjB,MAAM,CAAC,EAAE,OAAO,CAAC;QACjB,KAAK,CAAC,EAAE,OAAO,CAAC;QAChB,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,OAAO,CAAC,EAAE,OAAO,CAAC;QAClB,aAAa,CAAC,EAAE,OAAO,CAAC;KACzB,CAAC;IACF,OAAO,EAAE;QACP,mBAAmB,CAAC,EAAE,MAAM,CAAC;QAC7B,mBAAmB,CAAC,EAAE;YAAE,EAAE,EAAE,MAAM,CAAC;YAAC,IAAI,EAAE,MAAM,CAAC;YAAC,IAAI,EAAE,MAAM,CAAA;SAAE,EAAE,CAAC;KACpE,CAAC;CACH;AAED,MAAM,WAAW,aAAa;IAC5B,sBAAsB,CAAC,EAAE;QACvB,GAAG,EAAE,MAAM,CAAC;QACZ,MAAM,EAAE,MAAM,CAAC;QACf,MAAM,EAAE,SAAS,GAAG,SAAS,CAAC;QAC9B,MAAM,EAAE,MAAM,CAAC;KAChB,CAAC;CACH;AAED,wBAAsB,cAAc,CAClC,OAAO,EAAE,cAAc,EACvB,CAAC,EAAE,gBAAgB,GAClB,OAAO,CAAC,aAAa,CAAC,CA0HxB"}
|
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
import { createModelPr, closeModelPr } from './pr-creation.js';
|
|
2
|
+
import { createPlatformWriter } from '../platforms/platform-factory.js';
|
|
3
|
+
import { formatAnalysisAsComment, formatPatchPrBody, analysisHasFindings, COMMENT_MARKER, } from '../output.js';
|
|
4
|
+
import { writeGitHubActionsOutputs, writeGitHubStepSummary } from '../output/ci-output.js';
|
|
5
|
+
import { CONFIG } from '../utils/config.js';
|
|
6
|
+
function parseOwnerRepo(modelRepo) {
|
|
7
|
+
const i = modelRepo.lastIndexOf('/');
|
|
8
|
+
return {
|
|
9
|
+
owner: modelRepo.substring(0, i),
|
|
10
|
+
repo: modelRepo.substring(i + 1),
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
export async function publishResults(publish, p) {
|
|
14
|
+
const { ref, analysisResult, patchResult, structured, adapterMetadata, options, context } = publish;
|
|
15
|
+
// ── Resolve model repo target ────────────────────────────────────────
|
|
16
|
+
const modelTarget = options.modelRepo ? parseOwnerRepo(options.modelRepo) : ref.platformId;
|
|
17
|
+
// ── PR creation ──────────────────────────────────────────────────────
|
|
18
|
+
let generatedChangeRequest;
|
|
19
|
+
if (options.openPr && !options.dryRun) {
|
|
20
|
+
if (patchResult) {
|
|
21
|
+
p.start('Opening PR with patched model');
|
|
22
|
+
const prNumber = analysisResult.metadata.number;
|
|
23
|
+
const prTitle = analysisResult.metadata.title;
|
|
24
|
+
const body = formatPatchPrBody({
|
|
25
|
+
prNumber,
|
|
26
|
+
prTitle,
|
|
27
|
+
prUrl: ref.url,
|
|
28
|
+
summary: analysisResult.summary,
|
|
29
|
+
insertedLines: patchResult.insertedLines,
|
|
30
|
+
relationshipLines: patchResult.relationshipLines,
|
|
31
|
+
skipped: patchResult.skipped,
|
|
32
|
+
removals: analysisResult.modelUpdates?.remove,
|
|
33
|
+
newComponents: patchResult.newComponents,
|
|
34
|
+
});
|
|
35
|
+
const result = await createModelPr({
|
|
36
|
+
repositoryUrl: ref.repositoryUrl,
|
|
37
|
+
owner: modelTarget.owner,
|
|
38
|
+
repo: modelTarget.repo,
|
|
39
|
+
prNumber,
|
|
40
|
+
prTitle,
|
|
41
|
+
sourceRepo: `${ref.platformId.owner}/${ref.platformId.repo}`,
|
|
42
|
+
adapterMetadata,
|
|
43
|
+
fileChanges: [{ path: patchResult.filePath, content: patchResult.content }],
|
|
44
|
+
body,
|
|
45
|
+
draft: options.draft,
|
|
46
|
+
});
|
|
47
|
+
generatedChangeRequest = result;
|
|
48
|
+
if (structured)
|
|
49
|
+
structured.generatedChangeRequest = generatedChangeRequest;
|
|
50
|
+
p.succeed(`PR ${result.action} successfully: ${result.url}`);
|
|
51
|
+
}
|
|
52
|
+
else {
|
|
53
|
+
p.warn('--open-pr requires structured relationships from analysis. Skipping PR creation.');
|
|
54
|
+
}
|
|
55
|
+
// Auto-close stale model PR when re-analysis finds no violations
|
|
56
|
+
if (!analysisResult.hasViolations && !generatedChangeRequest) {
|
|
57
|
+
try {
|
|
58
|
+
await closeModelPr({
|
|
59
|
+
repositoryUrl: ref.repositoryUrl,
|
|
60
|
+
owner: modelTarget.owner,
|
|
61
|
+
repo: modelTarget.repo,
|
|
62
|
+
sourceRepo: `${ref.platformId.owner}/${ref.platformId.repo}`,
|
|
63
|
+
prNumber: analysisResult.metadata.number,
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
catch (error) {
|
|
67
|
+
p.warn(`Could not close stale model PR: ${error instanceof Error ? error.message : String(error)}`);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
else if (options.openPr && options.dryRun) {
|
|
72
|
+
p.info('Dry run: skipped PR creation');
|
|
73
|
+
}
|
|
74
|
+
// ── PR commenting ────────────────────────────────────────────────────
|
|
75
|
+
if (options.comment) {
|
|
76
|
+
try {
|
|
77
|
+
p.section('Publishing PR Comment');
|
|
78
|
+
const commentWriter = createPlatformWriter(ref.repositoryUrl, ref.platformId.owner, ref.platformId.repo);
|
|
79
|
+
if (analysisHasFindings(analysisResult)) {
|
|
80
|
+
p.start('Publishing analysis comment on PR');
|
|
81
|
+
const providerName = CONFIG.ai.provider;
|
|
82
|
+
const providerConfig = CONFIG[providerName];
|
|
83
|
+
const commentBody = formatAnalysisAsComment(analysisResult, {
|
|
84
|
+
selectedComponentId: context.selectedComponentId,
|
|
85
|
+
candidateComponents: context.candidateComponents,
|
|
86
|
+
generatedChangeRequest,
|
|
87
|
+
githubActions: options.githubActions,
|
|
88
|
+
modelInfo: {
|
|
89
|
+
provider: providerName,
|
|
90
|
+
fastModel: providerConfig.fastModel,
|
|
91
|
+
advancedModel: providerConfig.advancedModel,
|
|
92
|
+
},
|
|
93
|
+
});
|
|
94
|
+
await commentWriter.commentOnChangeRequest(ref, commentBody, {
|
|
95
|
+
upsertMarker: COMMENT_MARKER,
|
|
96
|
+
});
|
|
97
|
+
p.succeed('Analysis comment published on PR');
|
|
98
|
+
}
|
|
99
|
+
else {
|
|
100
|
+
p.start('Removing stale comment (no findings)');
|
|
101
|
+
await commentWriter.deleteComment(ref, COMMENT_MARKER);
|
|
102
|
+
p.succeed('No findings — old comment cleared (if any)');
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
catch (error) {
|
|
106
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
107
|
+
p.warn(`Could not publish PR comment: ${message}`);
|
|
108
|
+
if (options.githubActions) {
|
|
109
|
+
console.warn(`::warning::Could not publish PR comment: ${message}`);
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
// ── GitHub Actions outputs ───────────────────────────────────────────
|
|
114
|
+
if (options.githubActions && structured) {
|
|
115
|
+
try {
|
|
116
|
+
writeGitHubActionsOutputs(structured);
|
|
117
|
+
writeGitHubStepSummary(structured);
|
|
118
|
+
}
|
|
119
|
+
catch (error) {
|
|
120
|
+
p.warn(`Could not write GitHub Actions outputs: ${error instanceof Error ? error.message : String(error)}`);
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
return { generatedChangeRequest };
|
|
124
|
+
}
|
|
125
|
+
//# sourceMappingURL=publish.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"publish.js","sourceRoot":"","sources":["../../src/pipelines/publish.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import type { ProgressReporter } from './progress.js';
|
|
2
|
+
export interface ValidateOptions {
|
|
3
|
+
modelPath: string;
|
|
4
|
+
modelFormat?: string;
|
|
5
|
+
}
|
|
6
|
+
export interface ValidateResult {
|
|
7
|
+
components: {
|
|
8
|
+
id: string;
|
|
9
|
+
title: string;
|
|
10
|
+
kind: string;
|
|
11
|
+
repository: string;
|
|
12
|
+
}[];
|
|
13
|
+
total: number;
|
|
14
|
+
linked: number;
|
|
15
|
+
unlinked: number;
|
|
16
|
+
versionCheck: {
|
|
17
|
+
detected: string | null;
|
|
18
|
+
minimum: string;
|
|
19
|
+
compatible: boolean | null;
|
|
20
|
+
} | null;
|
|
21
|
+
hasIssues: boolean;
|
|
22
|
+
}
|
|
23
|
+
export declare function runValidate(options: ValidateOptions, progress?: ProgressReporter): Promise<ValidateResult>;
|
|
24
|
+
//# sourceMappingURL=validate.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validate.d.ts","sourceRoot":"","sources":["../../src/pipelines/validate.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAKtD,MAAM,WAAW,eAAe;IAC9B,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,MAAM,WAAW,cAAc;IAC7B,UAAU,EAAE;QACV,EAAE,EAAE,MAAM,CAAC;QACX,KAAK,EAAE,MAAM,CAAC;QACd,IAAI,EAAE,MAAM,CAAC;QACb,UAAU,EAAE,MAAM,CAAC;KACpB,EAAE,CAAC;IACJ,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;IACjB,YAAY,EAAE;QACZ,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAC;QACxB,OAAO,EAAE,MAAM,CAAC;QAChB,UAAU,EAAE,OAAO,GAAG,IAAI,CAAC;KAC5B,GAAG,IAAI,CAAC;IACT,SAAS,EAAE,OAAO,CAAC;CACpB;AAuBD,wBAAsB,WAAW,CAC/B,OAAO,EAAE,eAAe,EACxB,QAAQ,CAAC,EAAE,gBAAgB,GAC1B,OAAO,CAAC,cAAc,CAAC,CAmEzB"}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import { SilentProgress } from './progress.js';
|
|
2
|
+
import { createAdapter } from '../adapters/adapter-factory.js';
|
|
3
|
+
import { validatePath } from '../utils/validation.js';
|
|
4
|
+
function isRepositoryUrl(url) {
|
|
5
|
+
try {
|
|
6
|
+
const parsed = new URL(url);
|
|
7
|
+
if (parsed.protocol !== 'https:' && parsed.protocol !== 'http:')
|
|
8
|
+
return false;
|
|
9
|
+
return [
|
|
10
|
+
'github.com',
|
|
11
|
+
'www.github.com',
|
|
12
|
+
'gitlab.com',
|
|
13
|
+
'www.gitlab.com',
|
|
14
|
+
'bitbucket.org',
|
|
15
|
+
'www.bitbucket.org',
|
|
16
|
+
].includes(parsed.hostname);
|
|
17
|
+
}
|
|
18
|
+
catch {
|
|
19
|
+
return false;
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
function findRepositoryLink(links) {
|
|
23
|
+
return links.find(isRepositoryUrl);
|
|
24
|
+
}
|
|
25
|
+
export async function runValidate(options, progress) {
|
|
26
|
+
const p = progress ?? new SilentProgress();
|
|
27
|
+
const adapter = createAdapter(options.modelFormat);
|
|
28
|
+
// Version check
|
|
29
|
+
let versionCheck = null;
|
|
30
|
+
if (adapter.checkVersion) {
|
|
31
|
+
p.start(`Checking ${adapter.metadata.displayName} version compatibility`);
|
|
32
|
+
const versionResult = adapter.checkVersion(options.modelPath);
|
|
33
|
+
if (versionResult.found && versionResult.compatible) {
|
|
34
|
+
p.succeed(`${adapter.metadata.displayName} version ${versionResult.version ?? 'unknown'} is compatible (minimum: ${versionResult.minimum})`);
|
|
35
|
+
}
|
|
36
|
+
else if (versionResult.found && !versionResult.compatible) {
|
|
37
|
+
p.warn(`${adapter.metadata.displayName} version ${versionResult.version ?? 'unknown'} is below minimum ${versionResult.minimum}. Update the ${adapter.metadata.id} dependency in the source repo.`);
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
p.warn(`Could not detect ${adapter.metadata.displayName} version — skipping compatibility check`);
|
|
41
|
+
}
|
|
42
|
+
versionCheck = {
|
|
43
|
+
detected: versionResult.version ?? null,
|
|
44
|
+
minimum: versionResult.minimum,
|
|
45
|
+
compatible: versionResult.compatible ?? null,
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
validatePath(options.modelPath, 'directory');
|
|
49
|
+
p.start('Loading architecture model');
|
|
50
|
+
const components = await adapter.loadAndListComponents(options.modelPath);
|
|
51
|
+
p.succeed(`Loaded ${String(components.length)} components`);
|
|
52
|
+
const mapped = components.map((c) => ({
|
|
53
|
+
id: c.id,
|
|
54
|
+
title: c.title ?? c.id,
|
|
55
|
+
kind: c.kind,
|
|
56
|
+
repository: findRepositoryLink(c.links) ?? 'MISSING',
|
|
57
|
+
}));
|
|
58
|
+
const linked = mapped.filter((c) => c.repository !== 'MISSING');
|
|
59
|
+
const unlinked = mapped.filter((c) => c.repository === 'MISSING');
|
|
60
|
+
if (unlinked.length > 0) {
|
|
61
|
+
p.warn(`${String(unlinked.length)} of ${String(mapped.length)} component(s) are missing repository links`);
|
|
62
|
+
for (const line of adapter.metadata.missingLinksHelpLines) {
|
|
63
|
+
p.info(line);
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
else if (mapped.length > 0) {
|
|
67
|
+
p.succeed('All components have repository links');
|
|
68
|
+
}
|
|
69
|
+
const hasIssues = unlinked.length > 0 || (versionCheck !== null && versionCheck.compatible === false);
|
|
70
|
+
return {
|
|
71
|
+
components: mapped,
|
|
72
|
+
total: mapped.length,
|
|
73
|
+
linked: linked.length,
|
|
74
|
+
unlinked: unlinked.length,
|
|
75
|
+
versionCheck,
|
|
76
|
+
hasIssues,
|
|
77
|
+
};
|
|
78
|
+
}
|
|
79
|
+
//# sourceMappingURL=validate.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validate.js","sourceRoot":"","sources":["../../src/pipelines/validate.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
interface BitbucketRequestOptions {
|
|
3
|
+
method?: string;
|
|
4
|
+
headers?: Record<string, string>;
|
|
5
|
+
body?: RequestInit['body'];
|
|
6
|
+
}
|
|
7
|
+
export declare class BitbucketApiClient {
|
|
8
|
+
private readonly baseUrl;
|
|
9
|
+
private readonly token;
|
|
10
|
+
constructor(token?: string);
|
|
11
|
+
private buildHeaders;
|
|
12
|
+
/** App passwords use Basic auth (username:password), OAuth/PATs use Bearer. */
|
|
13
|
+
private buildAuthHeader;
|
|
14
|
+
request<T>(path: string, schema: z.ZodType<T>, options?: BitbucketRequestOptions): Promise<T>;
|
|
15
|
+
requestText(path: string, options?: BitbucketRequestOptions): Promise<string>;
|
|
16
|
+
requestVoid(path: string, options?: BitbucketRequestOptions): Promise<void>;
|
|
17
|
+
/** Fetch all pages of a paginated Bitbucket API response. */
|
|
18
|
+
paginate<T>(path: string, itemSchema: z.ZodType<T>): Promise<T[]>;
|
|
19
|
+
}
|
|
20
|
+
export {};
|
|
21
|
+
//# sourceMappingURL=api-client.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"api-client.d.ts","sourceRoot":"","sources":["../../../src/platforms/bitbucket/api-client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAKxB,UAAU,uBAAuB;IAC/B,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACjC,IAAI,CAAC,EAAE,WAAW,CAAC,MAAM,CAAC,CAAC;CAC5B;AAED,qBAAa,kBAAkB;IAC7B,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAS;IACjC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAqB;gBAE/B,KAAK,CAAC,EAAE,MAAM;IAK1B,OAAO,CAAC,YAAY;IAQpB,+EAA+E;IAC/E,OAAO,CAAC,eAAe;IAOjB,OAAO,CAAC,CAAC,EACb,IAAI,EAAE,MAAM,EACZ,MAAM,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EACpB,OAAO,GAAE,uBAA4B,GACpC,OAAO,CAAC,CAAC,CAAC;IAmBP,WAAW,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,GAAE,uBAA4B,GAAG,OAAO,CAAC,MAAM,CAAC;IAkBjF,WAAW,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,GAAE,uBAA4B,GAAG,OAAO,CAAC,IAAI,CAAC;IAiBrF,6DAA6D;IACvD,QAAQ,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,EAAE,CAAC;CA0CxE"}
|