Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
32 commits
Select commit Hold shift + click to select a range
728db88
Add AI tools: agents, skills, commands, and output style for FinOps T…
Feb 9, 2026
7664a38
Update plugin settings, paths, and command extensions
Feb 11, 2026
d1887fa
Move AI tools from src/ai-tools to src/claude-plugin
Feb 18, 2026
e1ee1a5
Symlink CLAUDE.md and AGENTS.md to .github/copilot-instructions.md
Feb 18, 2026
b834fe9
Add reservations and commitment discount decision references
Feb 18, 2026
a33f72f
Merge branch 'dev' into features/agentskills
Feb 18, 2026
8a822a6
Add storage cost analysis reference and update savings plans
Feb 18, 2026
aaa39f5
Update azure-cost-management skill definition
Feb 18, 2026
f0fdaf7
Fix skill reference errors found during TDD evaluation sprint
Feb 18, 2026
38952ed
Move plugin to src/templates/, add docs-mslearn links to SKILL.md
Feb 18, 2026
631a62a
Add cost optimization references and command from Azure Copilot gap a…
Feb 20, 2026
5799afd
Update src/templates/claude-plugin/commands/ftk-mom-report.md
MSBrett Feb 23, 2026
9b15fac
chore: Update ms.date to fix CI workflow
Feb 23, 2026
735887f
Consolidate agent instructions into CLAUDE.md as single source of truth
Feb 25, 2026
6455064
Remove query catalog and coding standards from ftk-database-query agent
Feb 25, 2026
3a44819
Rename CLAUDE.md to AGENTS.md and update symlinks
Feb 26, 2026
63ae144
Address all PR #2013 review feedback
Feb 26, 2026
0ef609e
Fix copyright header casing in Get-BenefitRecommendations.ps1
Feb 26, 2026
ce3eb50
Remove all azcapman references from finops-toolkit
Feb 26, 2026
fe89930
Refine Claude Code plugin: improve skills, commands, versioning, and …
Mar 4, 2026
96ae42a
Merge dev into features/agentskills
Mar 4, 2026
64e3f94
chore: Update ms.date in changelog
Mar 4, 2026
e4299af
feat(agent-skills): consolidate skills into agent-skills/ with symlin…
Mar 28, 2026
a05e729
fix(agent-skills): tighten finops toolkit references
Mar 28, 2026
17ef5e4
fix: address PR #2043 review comments
Mar 30, 2026
2a945a6
Merge origin/dev into features/agentskills
Mar 30, 2026
8b98588
fix: resolve test failures from symlink paths on CI
Mar 30, 2026
da19749
fix: resolve remaining CI test failures
Mar 30, 2026
26e5363
fix: remove brittle Foundation reference content-policing test
Mar 30, 2026
b28ef1c
fix: remove brittle ClaudePlugin content-policing tests
Mar 30, 2026
5929844
chore: update ms.date in changed docs-mslearn files
Mar 30, 2026
a3b2445
refactor: remove mode:subagent and add subagent team to finops-practi…
Apr 21, 2026
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
28 changes: 28 additions & 0 deletions .claude-plugin/marketplace.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
{
"$schema": "https://anthropic.com/claude-code/marketplace.schema.json",
"name": "finops-toolkit",
"description": "Microsoft FinOps Toolkit plugins for AI-powered cloud financial management.",
"owner": {
"name": "Microsoft"
},
"plugins": [
{
"name": "microsoft-finops-toolkit",
"version": "13.0.0",
"source": "./src/templates/claude-plugin",
"description": "AI-powered cloud financial management for Azure. Analyze costs with KQL queries against FinOps hubs, get CFO-level reporting, and access Azure Cost Management insights.",
"category": "finops",
"homepage": "https://learn.microsoft.com/en-us/cloud-computing/finops/toolkit/finops-toolkit-overview"
},
{
"name": "microsoft-learn",
"source": {
"source": "url",
"url": "https://github.com/microsoftdocs/mcp.git"
},
"description": "Access official Microsoft documentation, API references, and code samples for Azure, .NET, Windows, and more.",
"category": "documentation",
"homepage": "https://learn.microsoft.com"
}
]
}
154 changes: 0 additions & 154 deletions .github/copilot-instructions.md

This file was deleted.

1 change: 1 addition & 0 deletions .github/copilot-instructions.md
6 changes: 6 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -370,3 +370,9 @@ env/

# AI
.claude/settings.local.json

# Internal planning docs
TODO.md
Copy link
Copy Markdown
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

These are very generic filenames. As written, they'll be ignored anywhere in the repo tree — if someone legitimately adds a TODO.md in a subdirectory, it would be silently excluded.

Consider scoping to the repo root:

/TODO.md
/PRD.md
/RTM.md
/RETROSPECTIVES.md

PRD.md
RTM.md
RETROSPECTIVES.md
182 changes: 182 additions & 0 deletions AGENTS.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,182 @@
# Agent Instructions

This file provides guidance to AI Agents when working with code in this repository.

## Repository Overview

The FinOps Toolkit is an open-source collection of tools for adopting and implementing FinOps capabilities in the Microsoft Cloud. It contains templates, PowerShell modules, workbooks, optimization engines, and supporting documentation organized in a modular architecture.

## Common Commands

### Building and Development

```bash
# Build entire toolkit
npm run build
# or
pwsh -Command ./src/scripts/Build-Toolkit

# Build FinOps hubs
pwsh -Command ./src/scripts/Build-Toolkit finops-hub

# Build specific components
npm run build-ps # PowerShell module only
pwsh -Command ./src/scripts/Build-Bicep # Bicep templates
pwsh -Command ./src/scripts/Build-Workbook # Azure Monitor workbooks
pwsh -Command ./src/scripts/Build-OpenData # Open data files

# Deploy for testing
npm run deploy-test
# or
pwsh -Command ./src/scripts/Deploy-Toolkit -Build -Test

# Package for release
npm run package
# or
pwsh -Command ./src/scripts/Package-Toolkit -Build
```

### Testing

```bash
# Run PowerShell unit tests
npm run pester
# or
pwsh -Command Invoke-Pester -Output Detailed -Path ./src/powershell/Tests/Unit/*

# Run integration tests
pwsh -Command ./src/scripts/Test-PowerShell -Integration

# Run specific test categories
pwsh -Command ./src/scripts/Test-PowerShell -Hubs -Exports

# Lint PowerShell code
pwsh -Command ./src/scripts/Test-PowerShell -Lint
```

### Bicep Development

```bash
# Validate Bicep templates
bicep build path/to/template.bicep --stdout

# Test template deployment
az deployment group what-if --resource-group myRG --template-file template.bicep
```

## Architecture and Code Organization

### High-Level Structure

- **`/src/templates/`** - ARM/Bicep infrastructure templates with modular namespace organization
- **`/src/powershell/`** - PowerShell module with public/private functions and comprehensive tests
- **`/src/optimization-engine/`** - Azure Optimization Engine for cost recommendations
- **`/src/workbooks/`** - Azure Monitor workbooks for governance and optimization
- **`/src/open-data/`** - Reference data (pricing, regions, services) with utilities
- **`/src/scripts/`** - Build automation and development tools
- **`/docs/`** - Jekyll documentation website
- **`/docs-mslearn/`** - Microsoft Learn documentation website
- **`/docs-wiki/`** - GitHub wiki documentation

### Current Architectural Reorganization

The FinOps hubs solution is actively migrating to a namespace-based modular structure:

- **`Microsoft.FinOpsHubs/`** - Core FinOps Hub infrastructure modules
- **`Microsoft.CostManagement/`** - Cost management exports and schemas
- **`fx/`** - Shared foundation components (hub-types, scripts, utilities)

### Template Architecture

Templates use a multi-target build system that generates:

- Azure Quickstart Templates (ARM JSON)
- Bicep Registry modules
- Standalone deployments
- Azure portal UI definitions

Key patterns:

- **`.build.config`** files control build behavior per template
- **`settings.json`** contains component-specific configuration
- **`ftkver.txt`** files maintain version synchronization
- **Conditional resource deployment** based on parameters

### PowerShell Module Structure

- **`Public/`** - User-facing cmdlets (Get-_, Set-_, New-\*, etc.)
- **`Private/`** - Internal utilities and helpers
- **`Tests/Unit/`** - Pester unit tests with mocking
- **`Tests/Integration/`** - End-to-end Azure integration tests
- **Module manifest** defines exports and dependencies

### Data Flow and Integration

- **Open data** provides reference information consumed by templates and PowerShell
- **Build scripts** orchestrate compilation across all components
- **Version management** is centralized through `Update-Version.ps1`
- **Templates reference** shared schemas and types from `fx/` namespace

## Key Development Patterns

### Template Development

- Use `newApp()` and `newHub()` functions from `fx/hub-types.bicep` for consistent resource naming
- Follow the conditional deployment pattern: `resource foo 'type' = if (condition) { ... }`
- Implement proper parameter validation with `@allowed`, `@minValue`, `@maxValue`
- Include telemetry tracking via `defaultTelemetry` parameter

### PowerShell Development

- All public functions must have comment-based help
- Use approved verbs from `Get-Verb`
- Implement comprehensive parameter validation
- Support `-WhatIf` and `-Confirm` for destructive operations
- Include Pester tests for all functions

### Testing Strategy

- **Lint tests** validate syntax and coding standards
- **Unit tests** test isolated function behavior with mocks
- **Integration tests** perform end-to-end validation against Azure
- **Template validation** uses `bicep build` and ARM what-if deployments

### Build System Integration

The PowerShell-based build system:

- Compiles templates to multiple target formats
- Validates all code before packaging
- Maintains version consistency across components
- Generates release artifacts automatically

### Version Management

- Central version in `package.json` (currently 12.0.0)
- Synchronized across all components via build scripts
- Individual `ftkver.txt` files distributed to modules
- Git tags correspond to release versions

## Repository Conventions

### Branch Strategy

- **`dev`** - Main integration branch
- Feature branches merge into `dev`
- Releases are tagged from `dev`

### File Organization

- Templates follow namespace/module/component structure
- PowerShell follows standard module layout
- Documentation uses Jekyll conventions
- Build artifacts are generated, not checked in

### Coding Standards

- Always follow the content and coding standards defined in `docs-wiki/Coding-guidelines.md`
- Content (text strings): Follow the Microsoft style guide and always use sentence casing except for proper nouns
- Bicep: Follow Azure Bicep style guide
- PowerShell: Use PowerShell best practices and approved verbs
- Documentation: Use markdown with consistent formatting
- Commit messages: Use conventional commit format
Loading
Loading