Git History → Data Gathering → AI Analysis → Webview / Report
Team X-Ray reads your repo's git history, structures the data through custom tools, passes it to an AI agent for analysis, and renders the results in a VS Code webview or standalone HTML export.
| File | Role |
|---|---|
extension.ts |
Entry point. Registers commands, initializes services, wires everything together. |
expertise-analyzer.ts |
Orchestrator. Runs the analysis pipeline and manages the AI provider fallback chain. |
copilot-service.ts |
Copilot SDK integration. Defines 5 custom tools with defineTool + Zod schemas. |
git-service.ts |
Git data gathering. Extracts commits, contributors, file ownership from repo history. |
git-worker.ts |
Worker thread entry point. Runs heavy git operations off the main thread. |
git-worker-client.ts |
Worker thread client. Spawns and communicates with the git worker. |
expertise-webview.ts |
VS Code webview panel + standalone HTML export generation. |
token-manager.ts |
SecretStorage wrapper. Manages API keys securely. |
expertise-tree-provider.ts |
TreeView data provider for the sidebar panel. |
report-generator.ts |
Structures analysis data into report format. |
The Copilot agent calls these 5 tools during analysis to pull data from your repo:
| Tool | What it returns |
|---|---|
get_contributors |
Contributor profiles — commit counts, first/last activity dates |
get_recent_commits |
Recent commit history with authors, messages, timestamps |
get_file_experts |
Contributors who touched a file, ranked by commit count |
get_repo_stats |
Repository-level stats — size, languages, age, total commits |
get_collaboration_patterns |
Cross-contributor collaboration and review patterns |
Each tool is defined with defineTool and validated with Zod schemas. The agent decides which tools to call and in what order based on the analysis prompt.
When you run an analysis, Team X-Ray uses this order:
Copilot SDK session (default or BYOK override) → GitHub Models API → Reduced local fallback
| Step | Condition to activate | What happens on failure |
|---|---|---|
| Copilot SDK session | CLI installed + authenticated; teamxray.aiProvider selects default Copilot or BYOK override |
Falls through to GitHub Models |
| GitHub Models | GitHub token with models: read |
Falls through to reduced local fallback |
| Reduced local fallback | Always available | Returns git-derived analysis when AI output cannot be produced |
BYOK is a Copilot session configuration, not a separate fallback tier. If the configured Copilot/BYOK session fails, Team X-Ray falls through to GitHub Models, then to the reduced local fallback.
The detectBot() helper identifies automated contributors (Dependabot, Renovate, GitHub Actions bots, Copilot) by matching name and email patterns against known bot signatures.
Detected bots get:
- Gray expertise bars (instead of colored)
- A 🤖 badge next to their name
- Separation from human contributors in management insights
Large repos (300K+ commits) freeze VS Code if git operations run on the main thread. The worker thread solves this:
git-worker.tsis a separate webpack entry point- It runs in a Node.js
Workerthread — novscodemodule imported (workers can't access the VS Code API) git-worker-client.tsspawns the worker and handles message passing- The main thread stays responsive while heavy git parsing runs in the background
