@ryuenn3123/agentic-senior-core 2.5.22 → 3.0.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/.agent-context/prompts/init-project.md +5 -5
- package/.agent-context/prompts/refactor.md +2 -1
- package/.agent-context/prompts/review-code.md +3 -2
- package/.agent-context/review-checklists/pr-checklist.md +8 -1
- package/.agent-context/rules/architecture.md +11 -0
- package/.agent-context/rules/frontend-architecture.md +2 -2
- package/.agent-context/state/architecture-map.md +1 -1
- package/.agent-context/state/memory-continuity-benchmark.json +1 -1
- package/.agents/workflows/init-project.md +3 -3
- package/.agents/workflows/refactor.md +1 -1
- package/.agents/workflows/review-code.md +4 -5
- package/.cursorrules +27 -71
- package/.gemini/instructions.md +6 -7
- package/.github/copilot-instructions.md +5 -6
- package/.windsurfrules +27 -71
- package/AGENTS.md +7 -9
- package/CONTRIBUTING.md +18 -31
- package/README.md +21 -4
- package/bin/agentic-senior-core.js +0 -6
- package/lib/cli/commands/init.mjs +113 -650
- package/lib/cli/commands/launch.mjs +1 -23
- package/lib/cli/commands/rollback.mjs +1 -1
- package/lib/cli/commands/upgrade.mjs +1 -23
- package/lib/cli/compiler.mjs +77 -72
- package/lib/cli/constants.mjs +84 -26
- package/lib/cli/init-architecture-flow.mjs +231 -0
- package/lib/cli/init-detection-flow.mjs +123 -0
- package/lib/cli/init-options.mjs +344 -0
- package/lib/cli/init-selection.mjs +100 -0
- package/lib/cli/preflight.mjs +1 -1
- package/lib/cli/profile-packs.mjs +15 -1
- package/lib/cli/project-scaffolder.mjs +18 -154
- package/lib/cli/utils.mjs +16 -12
- package/mcp.json +19 -19
- package/package.json +5 -2
- package/scripts/context-triggered-audit.mjs +18 -18
- package/scripts/documentation-boundary-audit.mjs +92 -5
- package/scripts/forbidden-content-check.mjs +1 -1
- package/scripts/frontend-usability-audit.mjs +21 -28
- package/scripts/governance-weekly-report.mjs +29 -15
- package/scripts/llm-judge.mjs +2 -5
- package/scripts/mcp-server.mjs +389 -5
- package/scripts/release-gate.mjs +121 -145
- package/scripts/sync-thin-adapters.mjs +161 -0
- package/scripts/v3-purge-audit.mjs +231 -0
- package/scripts/validate-evidence-bundle.mjs +1 -1
- package/scripts/validate.mjs +224 -272
- package/.agent-context/blueprints/api-nextjs.md +0 -184
- package/.agent-context/blueprints/aspnet-api.md +0 -247
- package/.agent-context/blueprints/ci-github-actions.md +0 -226
- package/.agent-context/blueprints/ci-gitlab.md +0 -200
- package/.agent-context/blueprints/fastapi-service.md +0 -210
- package/.agent-context/blueprints/go-service.md +0 -217
- package/.agent-context/blueprints/graphql-grpc-api.md +0 -51
- package/.agent-context/blueprints/infrastructure-as-code.md +0 -62
- package/.agent-context/blueprints/kubernetes-manifests.md +0 -76
- package/.agent-context/blueprints/laravel-api.md +0 -233
- package/.agent-context/blueprints/mobile-app.md +0 -91
- package/.agent-context/blueprints/nestjs-logic.md +0 -247
- package/.agent-context/blueprints/observability.md +0 -227
- package/.agent-context/blueprints/spring-boot-api.md +0 -218
- package/.agent-context/profiles/platform.md +0 -13
- package/.agent-context/profiles/regulated.md +0 -13
- package/.agent-context/profiles/startup.md +0 -13
- package/.agent-context/review-checklists/frontend-excellence-rubric.md +0 -73
- package/.agent-context/review-checklists/frontend-skill-parity.md +0 -29
- package/.agent-context/review-checklists/frontend-usability.md +0 -35
- package/.agent-context/review-checklists/marketplace-acceptance.md +0 -60
- package/.agent-context/review-checklists/performance-audit.md +0 -71
- package/.agent-context/review-checklists/release-operations.md +0 -33
- package/.agent-context/review-checklists/security-audit.md +0 -119
- package/.agent-context/skills/README.md +0 -63
- package/.agent-context/skills/backend/README.md +0 -68
- package/.agent-context/skills/backend/architecture.md +0 -361
- package/.agent-context/skills/backend/compatibility-manifest.json +0 -8
- package/.agent-context/skills/backend/data-access.md +0 -231
- package/.agent-context/skills/backend/errors.md +0 -138
- package/.agent-context/skills/backend/validation.md +0 -117
- package/.agent-context/skills/backend.md +0 -29
- package/.agent-context/skills/cli/.evidence/compatibility-manifest.json +0 -5
- package/.agent-context/skills/cli/.evidence/sbom-excerpt.json +0 -10
- package/.agent-context/skills/cli/.evidence/test-report.json +0 -8
- package/.agent-context/skills/cli/CHANGELOG.md +0 -6
- package/.agent-context/skills/cli/README.md +0 -56
- package/.agent-context/skills/cli/compatibility-manifest.json +0 -8
- package/.agent-context/skills/cli/init.md +0 -38
- package/.agent-context/skills/cli/output.md +0 -36
- package/.agent-context/skills/cli/package.json +0 -5
- package/.agent-context/skills/cli/safety-telemetry.md +0 -39
- package/.agent-context/skills/cli/tests/.gitkeep +0 -1
- package/.agent-context/skills/cli/upgrade.md +0 -38
- package/.agent-context/skills/cli.md +0 -32
- package/.agent-context/skills/distribution/.evidence/compatibility-manifest.json +0 -9
- package/.agent-context/skills/distribution/.evidence/sbom-excerpt.json +0 -6
- package/.agent-context/skills/distribution/.evidence/test-report.json +0 -8
- package/.agent-context/skills/distribution/CHANGELOG.md +0 -7
- package/.agent-context/skills/distribution/README.md +0 -27
- package/.agent-context/skills/distribution/compatibility-manifest.json +0 -8
- package/.agent-context/skills/distribution/compatibility.md +0 -32
- package/.agent-context/skills/distribution/package.json +0 -5
- package/.agent-context/skills/distribution/provenance-attestation.md +0 -47
- package/.agent-context/skills/distribution/publish.md +0 -37
- package/.agent-context/skills/distribution/rollback.md +0 -32
- package/.agent-context/skills/distribution/tests/.gitkeep +0 -1
- package/.agent-context/skills/distribution.md +0 -32
- package/.agent-context/skills/frontend/.evidence/compatibility-manifest.json +0 -9
- package/.agent-context/skills/frontend/.evidence/sbom-excerpt.json +0 -6
- package/.agent-context/skills/frontend/.evidence/test-report.json +0 -8
- package/.agent-context/skills/frontend/CHANGELOG.md +0 -7
- package/.agent-context/skills/frontend/README.md +0 -50
- package/.agent-context/skills/frontend/accessibility.md +0 -107
- package/.agent-context/skills/frontend/compatibility-manifest.json +0 -8
- package/.agent-context/skills/frontend/conversion-clarity.md +0 -51
- package/.agent-context/skills/frontend/motion.md +0 -67
- package/.agent-context/skills/frontend/package.json +0 -5
- package/.agent-context/skills/frontend/performance.md +0 -63
- package/.agent-context/skills/frontend/responsive-delivery.md +0 -41
- package/.agent-context/skills/frontend/tests/.gitkeep +0 -1
- package/.agent-context/skills/frontend/ui-architecture.md +0 -128
- package/.agent-context/skills/frontend.md +0 -40
- package/.agent-context/skills/fullstack/.evidence/compatibility-manifest.json +0 -9
- package/.agent-context/skills/fullstack/.evidence/sbom-excerpt.json +0 -6
- package/.agent-context/skills/fullstack/.evidence/test-report.json +0 -8
- package/.agent-context/skills/fullstack/CHANGELOG.md +0 -7
- package/.agent-context/skills/fullstack/README.md +0 -27
- package/.agent-context/skills/fullstack/compatibility-manifest.json +0 -8
- package/.agent-context/skills/fullstack/contracts.md +0 -53
- package/.agent-context/skills/fullstack/end-to-end.md +0 -42
- package/.agent-context/skills/fullstack/feature-slicing.md +0 -65
- package/.agent-context/skills/fullstack/package.json +0 -5
- package/.agent-context/skills/fullstack/release-coordination.md +0 -51
- package/.agent-context/skills/fullstack/tests/.gitkeep +0 -1
- package/.agent-context/skills/fullstack.md +0 -30
- package/.agent-context/skills/index.json +0 -107
- package/.agent-context/skills/review-quality/.evidence/compatibility-manifest.json +0 -9
- package/.agent-context/skills/review-quality/.evidence/sbom-excerpt.json +0 -6
- package/.agent-context/skills/review-quality/.evidence/test-report.json +0 -8
- package/.agent-context/skills/review-quality/CHANGELOG.md +0 -7
- package/.agent-context/skills/review-quality/README.md +0 -27
- package/.agent-context/skills/review-quality/benchmark.md +0 -30
- package/.agent-context/skills/review-quality/compatibility-manifest.json +0 -8
- package/.agent-context/skills/review-quality/package.json +0 -5
- package/.agent-context/skills/review-quality/planning.md +0 -38
- package/.agent-context/skills/review-quality/release-decision.md +0 -49
- package/.agent-context/skills/review-quality/security.md +0 -34
- package/.agent-context/skills/review-quality/tests/.gitkeep +0 -1
- package/.agent-context/skills/review-quality.md +0 -34
- package/.agent-context/stacks/csharp.md +0 -149
- package/.agent-context/stacks/flutter.md +0 -16
- package/.agent-context/stacks/go.md +0 -181
- package/.agent-context/stacks/java.md +0 -135
- package/.agent-context/stacks/php.md +0 -192
- package/.agent-context/stacks/python.md +0 -153
- package/.agent-context/stacks/react-native.md +0 -16
- package/.agent-context/stacks/ruby.md +0 -80
- package/.agent-context/stacks/rust.md +0 -86
- package/.agent-context/stacks/typescript.md +0 -317
- package/.agent-context/state/skill-platform.json +0 -38
- package/lib/cli/skill-selector.mjs +0 -232
- package/lib/cli/templates/api-contract.md.id.tmpl +0 -143
- package/lib/cli/templates/api-contract.md.tmpl +0 -143
- package/lib/cli/templates/architecture-decision-record.md.id.tmpl +0 -106
- package/lib/cli/templates/architecture-decision-record.md.tmpl +0 -145
- package/lib/cli/templates/database-schema.md.id.tmpl +0 -74
- package/lib/cli/templates/database-schema.md.tmpl +0 -74
- package/lib/cli/templates/flow-overview.md.id.tmpl +0 -118
- package/lib/cli/templates/flow-overview.md.tmpl +0 -131
- package/lib/cli/templates/project-brief.md.id.tmpl +0 -55
- package/lib/cli/templates/project-brief.md.tmpl +0 -79
- package/scripts/init-project.ps1 +0 -105
- package/scripts/init-project.sh +0 -131
- package/scripts/skill-tier-policy.mjs +0 -76
- package/scripts/trust-scorer.mjs +0 -119
package/scripts/trust-scorer.mjs
DELETED
|
@@ -1,119 +0,0 @@
|
|
|
1
|
-
import fs from 'node:fs/promises';
|
|
2
|
-
import path from 'node:path';
|
|
3
|
-
import { fileURLToPath } from 'node:url';
|
|
4
|
-
import { validateEvidenceBundle } from './validate-evidence-bundle.mjs';
|
|
5
|
-
|
|
6
|
-
const __filename = fileURLToPath(import.meta.url);
|
|
7
|
-
const __dirname = path.dirname(__filename);
|
|
8
|
-
const REPO_ROOT = path.resolve(__dirname, '..');
|
|
9
|
-
const TRUST_TIER_SCHEMA_PATH = path.join(REPO_ROOT, '.agent-context', 'marketplace', 'trust-tiers.json');
|
|
10
|
-
|
|
11
|
-
/**
|
|
12
|
-
* Calculates a 0-100 trust score for a given marketplace artifact directory
|
|
13
|
-
* based on the 4 dimensions defined in trust-tiers.json.
|
|
14
|
-
*/
|
|
15
|
-
export async function calculateTrustScore(artifactDir) {
|
|
16
|
-
let schemaData;
|
|
17
|
-
try {
|
|
18
|
-
schemaData = JSON.parse(await fs.readFile(TRUST_TIER_SCHEMA_PATH, 'utf8'));
|
|
19
|
-
} catch (err) {
|
|
20
|
-
throw new Error(`Failed to read trust-tiers.json: ${err.message}`);
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
const scorecard = schemaData.scorecard;
|
|
24
|
-
const dimensions = {
|
|
25
|
-
documentation: { max: scorecard.dimensions.documentation.weight, score: 0, details: [] },
|
|
26
|
-
tests: { max: scorecard.dimensions.tests.weight, score: 0, details: [] },
|
|
27
|
-
evidence: { max: scorecard.dimensions.evidence.weight, score: 0, details: [] },
|
|
28
|
-
maintenance: { max: scorecard.dimensions.maintenance.weight, score: 0, details: [] }
|
|
29
|
-
};
|
|
30
|
-
|
|
31
|
-
// 1. Documentation
|
|
32
|
-
try {
|
|
33
|
-
const readmeContent = await fs.readFile(path.join(artifactDir, 'README.md'), 'utf8');
|
|
34
|
-
const readmeLines = readmeContent.split('\n');
|
|
35
|
-
if (readmeLines.length >= 10) dimensions.documentation.score += 10; else dimensions.documentation.details.push('README too short');
|
|
36
|
-
if (readmeContent.toLowerCase().includes('example') || readmeContent.toLowerCase().includes('usage')) dimensions.documentation.score += 15; else dimensions.documentation.details.push('No examples found');
|
|
37
|
-
} catch (err) {
|
|
38
|
-
dimensions.documentation.details.push('Missing README.md');
|
|
39
|
-
}
|
|
40
|
-
// Cap doc score
|
|
41
|
-
dimensions.documentation.score = Math.min(dimensions.documentation.score, dimensions.documentation.max);
|
|
42
|
-
|
|
43
|
-
// 2. Tests
|
|
44
|
-
let hasTestDir = false;
|
|
45
|
-
try {
|
|
46
|
-
const stats = await fs.stat(path.join(artifactDir, 'tests'));
|
|
47
|
-
if (stats.isDirectory()) { hasTestDir = true; dimensions.tests.score += 10; }
|
|
48
|
-
} catch (err) {}
|
|
49
|
-
|
|
50
|
-
if (!hasTestDir) {
|
|
51
|
-
dimensions.tests.details.push('No tests/ directory');
|
|
52
|
-
} else {
|
|
53
|
-
dimensions.tests.score += 15; // Placeholder for test execution/coverage in a real CI system
|
|
54
|
-
}
|
|
55
|
-
dimensions.tests.score = Math.min(dimensions.tests.score, dimensions.tests.max);
|
|
56
|
-
|
|
57
|
-
// 3. Evidence
|
|
58
|
-
const evidenceCheck = await validateEvidenceBundle(artifactDir);
|
|
59
|
-
if (evidenceCheck.passed) {
|
|
60
|
-
dimensions.evidence.score = dimensions.evidence.max;
|
|
61
|
-
} else {
|
|
62
|
-
dimensions.evidence.details.push(evidenceCheck.error);
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
// 4. Maintenance
|
|
66
|
-
try {
|
|
67
|
-
await fs.stat(path.join(artifactDir, 'CHANGELOG.md'));
|
|
68
|
-
dimensions.maintenance.score += 15;
|
|
69
|
-
} catch (err) {
|
|
70
|
-
dimensions.maintenance.details.push('Missing CHANGELOG.md');
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
try {
|
|
74
|
-
const pkgData = JSON.parse(await fs.readFile(path.join(artifactDir, 'package.json'), 'utf8'));
|
|
75
|
-
if (pkgData.version && pkgData.author) dimensions.maintenance.score += 10;
|
|
76
|
-
} catch (err) {
|
|
77
|
-
// If package.json is missing, it might not be a Node package, so we don't penalize completely,
|
|
78
|
-
// but we deduct slightly.
|
|
79
|
-
}
|
|
80
|
-
dimensions.maintenance.score = Math.min(dimensions.maintenance.score, dimensions.maintenance.max);
|
|
81
|
-
|
|
82
|
-
const totalScore = dimensions.documentation.score +
|
|
83
|
-
dimensions.tests.score +
|
|
84
|
-
dimensions.evidence.score +
|
|
85
|
-
dimensions.maintenance.score;
|
|
86
|
-
|
|
87
|
-
// Determine tier
|
|
88
|
-
let assignedTier = 'experimental';
|
|
89
|
-
for (const [tierName, def] of Object.entries(schemaData.tiers)) {
|
|
90
|
-
if (tierName !== 'experimental' && totalScore >= def.minimumScore) {
|
|
91
|
-
// verified and community. Verified wins if >= 85
|
|
92
|
-
if (assignedTier === 'community' && tierName === 'verified') assignedTier = 'verified';
|
|
93
|
-
if (assignedTier === 'experimental') assignedTier = tierName;
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
return {
|
|
98
|
-
tier: assignedTier,
|
|
99
|
-
score: totalScore,
|
|
100
|
-
dimensions
|
|
101
|
-
};
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
if (process.argv[1] && process.argv[1] === new URL(import.meta.url).pathname || process.argv[1] === import.meta.filename) {
|
|
105
|
-
const targetDir = process.argv[2];
|
|
106
|
-
if (!targetDir) {
|
|
107
|
-
console.error('Usage: node trust-scorer.mjs <target-directory>');
|
|
108
|
-
process.exit(1);
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
calculateTrustScore(path.resolve(targetDir))
|
|
112
|
-
.then(result => {
|
|
113
|
-
console.log(JSON.stringify(result, null, 2));
|
|
114
|
-
})
|
|
115
|
-
.catch(err => {
|
|
116
|
-
console.error(JSON.stringify({ error: err.message }, null, 2));
|
|
117
|
-
process.exit(1);
|
|
118
|
-
});
|
|
119
|
-
}
|