Help us improve
Share bugs, ideas, or general feedback.
From marketplace-pro
Scans project directories to fingerprint tech stacks, languages, frameworks, infrastructure, and patterns; mines gaps with Apriori; ranks plugin recommendations by cosine similarity.
npx claudepluginhub markus41/claude --plugin marketplace-proHow this skill is triggered — by the user, by Claude, or both
Slash command
/marketplace-pro:intelligenceThe summary Claude sees in its skill listing — used to decide when to auto-load this skill
Analyze a project's technology stack and recommend plugins using machine learning techniques: $ARGUMENTS
Audits enabled Claude Code plugins against detected project tech stack from files like package.json, Cargo.toml, pyproject.toml; recommends additions/removals.
Analyzes codebases to identify project structure, technology stack, dependencies, development tools, CI/CD configs, and recommends MCP integrations like database and cloud tools.
Profiles codebases by detecting tech stack, frameworks, infrastructure, architecture patterns, quality signals, and scale metrics for targeted recommendations.
Share bugs, ideas, or general feedback.
Analyze a project's technology stack and recommend plugins using machine learning techniques: $ARGUMENTS
The intelligence module provides three core capabilities:
ProjectFingerprinter
|
|-- detectFrameworks() -> package.json, pyproject.toml, go.mod, Cargo.toml
|-- detectLanguages() -> file extension distribution (recursive walk)
|-- detectInfrastructure() -> config files (Dockerfile, Chart.yaml, .github/workflows, etc.)
|-- detectPatterns() -> monorepo, event-driven, api-gateway, microservices, serverless
|-- findGaps() -> uses AprioriMiner rules to identify missing capabilities
|
v
ProjectFingerprint { frameworks, languages, infrastructure, patterns, missing }
|
v
RecommendationEngine
|-- buildVocabulary() -> union of all feature terms
|-- toBinaryVector() -> project/plugin features -> [0,1,0,1,...] vectors
|-- cosineSimilarity() -> dot(A,B) / (||A|| * ||B||)
|-- computeGapCoverage() -> weighted gap fill score
|-- recommend() -> ranked PluginRecommendation[]
|
v
RecommendationReport { projectSummary, recommendations, gaps, scanDate }
The Apriori algorithm mines association rules from a dataset of project profiles. It works in two phases:
Phase 1: Find Frequent Itemsets
L1 = { items appearing in >= minSupport fraction of transactions }
k = 2
while L(k-1) is non-empty:
Candidates = apriori-gen(L(k-1)) // join + prune
Count each candidate's support across all transactions
L(k) = candidates with support >= minSupport
k++
The Apriori principle (anti-monotone property) states: if {A,B} is infrequent, no superset {A,B,C,...} can be frequent. This allows aggressive pruning of the candidate space.
Phase 2: Generate Rules
For each frequent itemset S where |S| >= 2:
For each item B in S:
A = S \ {B}
confidence = support(S) / support(A)
lift = confidence / support({B})
if confidence >= minConfidence: emit rule A => {B}
Projects and plugins are both represented as binary vectors over a shared vocabulary of feature terms:
vocabulary = sorted union of all terms
project_vector[i] = 1 if vocabulary[i] in project_features else 0
plugin_vector[i] = 1 if vocabulary[i] in plugin_capabilities else 0
similarity = dot(project, plugin) / (norm(project) * norm(plugin))
relevance = 0.6 * cosine_similarity + 0.4 * gap_coverage
gap_coverage = sum(confidence[gap] for filled gaps) / sum(confidence[gap] for all gaps)
plugins/marketplace-pro/
src/intelligence/
types.ts — All TypeScript interfaces
fingerprint.ts — ProjectFingerprinter, AprioriMiner, RecommendationEngine
config/
project-profiles.json — Training dataset (~22 project profiles)
commands/
recommend.md — /mp:recommend slash command
skills/intelligence/
SKILL.md — This file
import { ProjectFingerprinter } from './src/intelligence/fingerprint.js';
const fp = new ProjectFingerprinter('/path/to/project');
const fingerprint = await fp.scan();
console.log('Frameworks:', fingerprint.frameworks);
console.log('Languages:', fingerprint.languages);
console.log('Infrastructure:', fingerprint.infrastructure);
console.log('Patterns:', fingerprint.patterns);
console.log('Missing capabilities:', fingerprint.missing);
import { AprioriMiner } from './src/intelligence/fingerprint.js';
const profiles = [
{ features: ['typescript', 'react', 'nextjs', 'eslint', 'jest', 'ci-cd'] },
{ features: ['typescript', 'nodejs', 'express', 'docker', 'kubernetes', 'helm', 'ci-cd'] },
{ features: ['python', 'fastapi', 'docker', 'terraform', 'aws', 'monitoring'] },
// ...more profiles
];
const miner = new AprioriMiner(profiles, 0.3, 0.6);
const rules = miner.mineRules();
for (const rule of rules) {
console.log(
`{${rule.antecedent.join(', ')}} => {${rule.consequent.join(', ')}}`,
`support=${rule.support} confidence=${rule.confidence} lift=${rule.lift}`
);
}
// Example output:
// {kubernetes, helm} => {ci-cd} support=0.318 confidence=0.875 lift=1.05
// {docker, kubernetes} => {monitoring} support=0.364 confidence=0.8 lift=1.12
import { RecommendationEngine } from './src/intelligence/fingerprint.js';
import type { PluginCapability } from './src/intelligence/types.js';
const plugins: PluginCapability[] = [
{
name: 'ci-pipeline-pro',
description: 'CI/CD pipeline generator',
capabilities: ['ci-cd', 'testing', 'deployment'],
targetInfrastructure: ['docker', 'kubernetes'],
},
{
name: 'monitoring-stack',
description: 'Observability setup with Prometheus + Grafana',
capabilities: ['monitoring', 'alerting', 'dashboards'],
targetInfrastructure: ['kubernetes', 'docker'],
},
];
const engine = new RecommendationEngine();
const report = engine.recommend(fingerprint, plugins);
for (const rec of report.recommendations) {
console.log(`${rec.pluginName}: relevance=${rec.relevance}`);
console.log(` Reason: ${rec.reason}`);
console.log(` Gaps filled: ${rec.gapsFilled.join(', ')}`);
}
import { analyzeProject } from './src/intelligence/fingerprint.js';
const report = await analyzeProject('/path/to/project', availablePlugins);
console.log(JSON.stringify(report, null, 2));
The AprioriMiner accepts two thresholds:
| Parameter | Default | Description |
|---|---|---|
minSupport | 0.3 | Minimum fraction of profiles containing an itemset to be "frequent" |
minConfidence | 0.6 | Minimum conditional probability for a rule to be emitted |
Lower support finds more rules but may include noise. Higher confidence produces more reliable gap predictions.
Only gaps with confidence >= 0.6 are surfaced to users. This threshold is hardcoded in ProjectFingerprinter.findGaps() to avoid noisy suggestions.
The Apriori miner learns from config/project-profiles.json. Add new profiles to improve rule quality:
{
"label": "my-custom-stack",
"features": ["typescript", "react", "nextjs", "docker", "ci-cd", "monitoring"]
}
More diverse profiles = better association rules = more accurate gap detection.