Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
182 commits
Select commit Hold shift + click to select a range
9976f02
Update dashboard data - 2025-06-10 12:09:41 UTC
hmcts-platform-operations Jun 10, 2025
081df80
Update dashboard data - 2025-06-10 12:09:52 UTC
hmcts-platform-operations Jun 10, 2025
c4fb1fb
Initial plan for issue
Copilot Jun 10, 2025
df105bd
Add support for additional resource types in cost calculation
Copilot Jun 10, 2025
313a521
Improve SKU detection and add comprehensive documentation
Copilot Jun 10, 2025
3098c81
Merge pull request #183 from hmcts/copilot/fix-182
JordanHoey96 Jun 10, 2025
cfcab63
Update dashboard data - 2025-06-10 12:35:45 UTC
hmcts-platform-operations Jun 10, 2025
33d03da
Update dashboard data - 2025-06-10 12:37:00 UTC
hmcts-platform-operations Jun 10, 2025
ebb53ae
Update dashboard data - 2025-06-10 12:37:15 UTC
hmcts-platform-operations Jun 10, 2025
9fd44b6
parseissue-184
hmcts-platform-operations Jun 10, 2025
29a6434
Update dashboard data - 2025-06-10 12:38:26 UTC
hmcts-platform-operations Jun 10, 2025
96bbd97
Update dashboard data - 2025-06-10 12:56:41 UTC
hmcts-platform-operations Jun 10, 2025
089c59d
Update dashboard data - 2025-06-10 12:56:56 UTC
hmcts-platform-operations Jun 10, 2025
80d9956
Initial plan for issue
Copilot Jun 10, 2025
feced38
Fix cost calculation issues: API URL syntax and Azure Graph query par…
Copilot Jun 10, 2025
1303c80
Fix bash syntax error in associative array check
Copilot Jun 10, 2025
e1b87de
Remove fallback pricing mechanism - use only API data
Copilot Jun 10, 2025
fd2b44f
Merge pull request #186 from hmcts/copilot/fix-185
JordanHoey96 Jun 10, 2025
827bf3c
Update dashboard data - 2025-06-10 13:32:32 UTC
hmcts-platform-operations Jun 10, 2025
5eea894
Update dashboard data - 2025-06-10 13:33:17 UTC
hmcts-platform-operations Jun 10, 2025
83077b5
parseissue-187
hmcts-platform-operations Jun 10, 2025
e31a166
Update dashboard data - 2025-06-10 13:34:20 UTC
hmcts-platform-operations Jun 10, 2025
2655af6
JSON Status files housekeeping
hmcts-platform-operations Jun 10, 2025
c241d87
Update dashboard data - 2025-06-11 06:06:33 UTC
hmcts-platform-operations Jun 11, 2025
243338a
housekeeping
hmcts-platform-operations Jun 11, 2025
cda4889
Update dashboard data - 2025-06-12 06:06:48 UTC
hmcts-platform-operations Jun 12, 2025
90e1bf0
Update dashboard data - 2025-06-13 06:06:34 UTC
hmcts-platform-operations Jun 13, 2025
81a40c2
adding torubleshooting file output
JordanHoey96 Jun 13, 2025
6a88563
Update dashboard data - 2025-06-13 09:46:01 UTC
hmcts-platform-operations Jun 13, 2025
86888e0
parseissue-188
hmcts-platform-operations Jun 13, 2025
eab19d5
Update dashboard data - 2025-06-13 09:47:12 UTC
hmcts-platform-operations Jun 13, 2025
36aff73
Update dashboard data - 2025-06-13 09:55:07 UTC
hmcts-platform-operations Jun 13, 2025
01784c0
Update dashboard data - 2025-06-13 09:55:19 UTC
hmcts-platform-operations Jun 13, 2025
948783a
Initial plan for issue
Copilot Jun 13, 2025
15c3934
Initial analysis of Azure Resource Graph query syntax errors
Copilot Jun 13, 2025
2e78608
Fix Azure Resource Graph KQL syntax errors in queries
Copilot Jun 13, 2025
b46e84b
Merge pull request #190 from hmcts/copilot/fix-189
JordanHoey96 Jun 13, 2025
c7dcbc4
Update dashboard data - 2025-06-13 11:06:43 UTC
hmcts-platform-operations Jun 13, 2025
79365a0
Update dashboard data - 2025-06-13 11:07:29 UTC
hmcts-platform-operations Jun 13, 2025
aee88c6
parseissue-191
hmcts-platform-operations Jun 13, 2025
ab7cbf7
Update dashboard data - 2025-06-13 11:08:19 UTC
hmcts-platform-operations Jun 13, 2025
a1d109a
Update dashboard data - 2025-06-14 06:05:39 UTC
hmcts-platform-operations Jun 14, 2025
2d69a67
Update dashboard data - 2025-06-15 06:05:57 UTC
hmcts-platform-operations Jun 15, 2025
80642da
Update dashboard data - 2025-06-16 06:06:59 UTC
hmcts-platform-operations Jun 16, 2025
377bf78
Update dashboard data - 2025-06-16 09:15:04 UTC
hmcts-platform-operations Jun 16, 2025
021b98b
Update dashboard data - 2025-06-17 06:06:25 UTC
hmcts-platform-operations Jun 17, 2025
3d33d6d
Update dashboard data - 2025-06-17 09:07:10 UTC
hmcts-platform-operations Jun 17, 2025
6cbd444
Update dashboard data - 2025-06-18 06:06:35 UTC
hmcts-platform-operations Jun 18, 2025
c2d55af
Update dashboard data - 2025-06-19 06:06:35 UTC
hmcts-platform-operations Jun 19, 2025
8271038
Update dashboard data - 2025-06-20 06:06:31 UTC
hmcts-platform-operations Jun 20, 2025
92fd1bf
Update dashboard data - 2025-06-21 06:05:32 UTC
hmcts-platform-operations Jun 21, 2025
351eaf2
Update dashboard data - 2025-06-22 06:05:48 UTC
hmcts-platform-operations Jun 22, 2025
c89470a
Update dashboard data - 2025-06-23 06:06:51 UTC
hmcts-platform-operations Jun 23, 2025
92ec96e
Update dashboard data - 2025-06-24 06:06:43 UTC
hmcts-platform-operations Jun 24, 2025
d06890d
Update dashboard data - 2025-06-25 06:06:46 UTC
hmcts-platform-operations Jun 25, 2025
5706578
Update dashboard data - 2025-06-25 09:18:13 UTC
hmcts-platform-operations Jun 25, 2025
bdcc3e3
Update dashboard data - 2025-06-25 09:18:23 UTC
hmcts-platform-operations Jun 25, 2025
4e3c71a
Update dashboard data - 2025-06-25 09:19:34 UTC
hmcts-platform-operations Jun 25, 2025
6b0e2f8
Update dashboard data - 2025-06-26 06:06:31 UTC
hmcts-platform-operations Jun 26, 2025
4e5a6e8
Update dashboard data - 2025-06-26 13:44:15 UTC
hmcts-platform-operations Jun 26, 2025
b55612f
Update dashboard data - 2025-06-26 13:44:33 UTC
hmcts-platform-operations Jun 26, 2025
b66a834
Update dashboard data - 2025-06-27 06:06:50 UTC
hmcts-platform-operations Jun 27, 2025
c17d0d9
Update dashboard data - 2025-06-28 06:05:37 UTC
hmcts-platform-operations Jun 28, 2025
00c0404
Update dashboard data - 2025-06-29 06:05:48 UTC
hmcts-platform-operations Jun 29, 2025
499edd5
Update dashboard data - 2025-06-30 06:06:52 UTC
hmcts-platform-operations Jun 30, 2025
d9beafd
Update dashboard data - 2025-07-01 06:07:04 UTC
hmcts-platform-operations Jul 1, 2025
75bf488
Update dashboard data - 2025-07-02 06:06:45 UTC
hmcts-platform-operations Jul 2, 2025
505532c
Update dashboard data - 2025-07-03 06:06:40 UTC
hmcts-platform-operations Jul 3, 2025
cf64011
Update dashboard data - 2025-07-04 06:06:29 UTC
hmcts-platform-operations Jul 4, 2025
71655f9
Update dashboard data - 2025-07-05 06:05:55 UTC
hmcts-platform-operations Jul 5, 2025
5520e26
Update dashboard data - 2025-07-06 06:06:09 UTC
hmcts-platform-operations Jul 6, 2025
cd26837
Update dashboard data - 2025-07-07 06:07:06 UTC
hmcts-platform-operations Jul 7, 2025
e018c31
Update dashboard data - 2025-07-08 06:06:33 UTC
hmcts-platform-operations Jul 8, 2025
d3bb4e1
Update dashboard data - 2025-07-09 06:06:40 UTC
hmcts-platform-operations Jul 9, 2025
20340b9
Update dashboard data - 2025-07-10 06:06:43 UTC
hmcts-platform-operations Jul 10, 2025
ea223b6
Update dashboard data - 2025-07-11 06:06:43 UTC
hmcts-platform-operations Jul 11, 2025
07228bf
Update dashboard data - 2025-07-12 06:06:04 UTC
hmcts-platform-operations Jul 12, 2025
f1ec2f2
Update dashboard data - 2025-07-13 06:06:00 UTC
hmcts-platform-operations Jul 13, 2025
05aa706
Update dashboard data - 2025-07-14 06:07:24 UTC
hmcts-platform-operations Jul 14, 2025
793f838
Update dashboard data - 2025-07-15 06:06:47 UTC
hmcts-platform-operations Jul 15, 2025
e69e9fc
Update dashboard data - 2025-07-16 06:06:52 UTC
hmcts-platform-operations Jul 16, 2025
e3e45c7
Update dashboard data - 2025-07-17 06:06:41 UTC
hmcts-platform-operations Jul 17, 2025
d8d290d
Update dashboard data - 2025-07-18 06:06:38 UTC
hmcts-platform-operations Jul 18, 2025
5566471
Update dashboard data - 2025-07-19 06:06:07 UTC
hmcts-platform-operations Jul 19, 2025
fcb5027
Update dashboard data - 2025-07-20 06:06:30 UTC
hmcts-platform-operations Jul 20, 2025
4cbea94
Update dashboard data - 2025-07-21 06:07:15 UTC
hmcts-platform-operations Jul 21, 2025
6df17d1
Update dashboard data - 2025-07-22 06:07:02 UTC
hmcts-platform-operations Jul 22, 2025
acd5dd9
Update dashboard data - 2025-07-23 06:07:04 UTC
hmcts-platform-operations Jul 23, 2025
2e4d39c
Update dashboard data - 2025-07-24 06:06:56 UTC
hmcts-platform-operations Jul 24, 2025
b74e655
Update dashboard data - 2025-07-25 06:06:50 UTC
hmcts-platform-operations Jul 25, 2025
96f2a6c
Update dashboard data - 2025-07-26 06:06:14 UTC
hmcts-platform-operations Jul 26, 2025
6779478
Update dashboard data - 2025-07-27 06:06:16 UTC
hmcts-platform-operations Jul 27, 2025
7d164a1
Update dashboard data - 2025-07-28 06:08:12 UTC
hmcts-platform-operations Jul 28, 2025
b16c69d
Update dashboard data - 2025-07-29 06:07:24 UTC
hmcts-platform-operations Jul 29, 2025
6ab0779
Update dashboard data - 2025-07-30 06:07:44 UTC
hmcts-platform-operations Jul 30, 2025
2ed6f43
Update dashboard data - 2025-07-31 06:07:10 UTC
hmcts-platform-operations Jul 31, 2025
87a405c
Update dashboard data - 2025-08-01 06:08:07 UTC
hmcts-platform-operations Aug 1, 2025
8dbf2ce
Update dashboard data - 2025-08-02 06:06:04 UTC
hmcts-platform-operations Aug 2, 2025
46c2aad
Update dashboard data - 2025-08-03 06:06:23 UTC
hmcts-platform-operations Aug 3, 2025
83fe11d
Update dashboard data - 2025-08-04 06:09:57 UTC
hmcts-platform-operations Aug 4, 2025
bde1aea
Update dashboard data - 2025-08-05 06:08:05 UTC
hmcts-platform-operations Aug 5, 2025
0425a5e
Update dashboard data - 2025-08-06 06:08:01 UTC
hmcts-platform-operations Aug 6, 2025
8a54266
Update dashboard data - 2025-08-07 06:07:45 UTC
hmcts-platform-operations Aug 7, 2025
6287179
Update dashboard data - 2025-08-08 06:07:36 UTC
hmcts-platform-operations Aug 8, 2025
ce570e2
Update dashboard data - 2025-08-09 06:06:12 UTC
hmcts-platform-operations Aug 9, 2025
a872e8c
Update dashboard data - 2025-08-10 06:06:25 UTC
hmcts-platform-operations Aug 10, 2025
e342a74
Update dashboard data - 2025-08-11 06:07:36 UTC
hmcts-platform-operations Aug 11, 2025
f0ed4d8
Update dashboard data - 2025-08-12 06:06:37 UTC
hmcts-platform-operations Aug 12, 2025
55b6e36
Update dashboard data - 2025-08-13 06:07:07 UTC
hmcts-platform-operations Aug 13, 2025
54a7852
Update dashboard data - 2025-08-14 06:06:43 UTC
hmcts-platform-operations Aug 14, 2025
cb761f5
Update dashboard data - 2025-08-15 06:07:02 UTC
hmcts-platform-operations Aug 15, 2025
1c59648
Update dashboard data - 2025-08-16 06:05:57 UTC
hmcts-platform-operations Aug 16, 2025
4abc893
Update dashboard data - 2025-08-17 06:06:04 UTC
hmcts-platform-operations Aug 17, 2025
eaa276d
Update dashboard data - 2025-08-18 06:07:19 UTC
hmcts-platform-operations Aug 18, 2025
1b898ee
Update dashboard data - 2025-08-19 06:06:44 UTC
hmcts-platform-operations Aug 19, 2025
6a294c8
Update dashboard data - 2025-08-20 06:06:57 UTC
hmcts-platform-operations Aug 20, 2025
900e4f1
Update dashboard data - 2025-08-21 06:06:59 UTC
hmcts-platform-operations Aug 21, 2025
e3653ec
Update dashboard data - 2025-08-22 06:06:42 UTC
hmcts-platform-operations Aug 22, 2025
a216498
Update dashboard data - 2025-08-23 06:05:44 UTC
hmcts-platform-operations Aug 23, 2025
231aa0a
Update dashboard data - 2025-08-24 06:05:55 UTC
hmcts-platform-operations Aug 24, 2025
1db265b
Update dashboard data - 2025-08-25 06:07:07 UTC
hmcts-platform-operations Aug 25, 2025
9a7a578
Update dashboard data - 2025-08-26 06:06:46 UTC
hmcts-platform-operations Aug 26, 2025
ec783f0
Update dashboard data - 2025-08-27 06:06:31 UTC
hmcts-platform-operations Aug 27, 2025
d90373b
Update dashboard data - 2025-08-28 06:06:41 UTC
hmcts-platform-operations Aug 28, 2025
b1926cf
Update dashboard data - 2025-08-29 06:06:32 UTC
hmcts-platform-operations Aug 29, 2025
eb7c78d
Update dashboard data - 2025-08-30 06:05:24 UTC
hmcts-platform-operations Aug 30, 2025
054835e
Update dashboard data - 2025-08-31 06:05:59 UTC
hmcts-platform-operations Aug 31, 2025
d811435
Update dashboard data - 2025-09-01 06:07:25 UTC
hmcts-platform-operations Sep 1, 2025
9e91fc8
Update dashboard data - 2025-09-02 06:06:53 UTC
hmcts-platform-operations Sep 2, 2025
284298f
Update dashboard data - 2025-09-03 06:06:40 UTC
hmcts-platform-operations Sep 3, 2025
eae365e
Update dashboard data - 2025-09-04 06:06:41 UTC
hmcts-platform-operations Sep 4, 2025
1f08751
Update dashboard data - 2025-09-05 06:06:44 UTC
hmcts-platform-operations Sep 5, 2025
a98304e
Update dashboard data - 2025-09-06 06:05:44 UTC
hmcts-platform-operations Sep 6, 2025
46763d4
Update dashboard data - 2025-09-07 06:05:44 UTC
hmcts-platform-operations Sep 7, 2025
0b258e4
Update dashboard data - 2025-09-08 06:07:11 UTC
hmcts-platform-operations Sep 8, 2025
bdec649
Update dashboard data - 2025-09-09 06:06:47 UTC
hmcts-platform-operations Sep 9, 2025
dc0fa91
Update dashboard data - 2025-09-10 06:06:40 UTC
hmcts-platform-operations Sep 10, 2025
2acef8a
Update dashboard data - 2025-09-11 06:06:54 UTC
hmcts-platform-operations Sep 11, 2025
0a23988
Update dashboard data - 2025-09-12 06:06:27 UTC
hmcts-platform-operations Sep 12, 2025
676bd13
Update dashboard data - 2025-09-13 06:06:04 UTC
hmcts-platform-operations Sep 13, 2025
43b81b5
Update dashboard data - 2025-09-14 06:06:10 UTC
hmcts-platform-operations Sep 14, 2025
16df9f0
Update dashboard data - 2025-09-15 06:07:04 UTC
hmcts-platform-operations Sep 15, 2025
d90001c
Update dashboard data - 2025-09-16 06:06:49 UTC
hmcts-platform-operations Sep 16, 2025
4b4bc88
Update dashboard data - 2025-09-17 06:06:54 UTC
hmcts-platform-operations Sep 17, 2025
2370580
Update dashboard data - 2025-09-18 06:06:35 UTC
hmcts-platform-operations Sep 18, 2025
f7ebd6d
Update dashboard data - 2025-09-19 06:06:47 UTC
hmcts-platform-operations Sep 19, 2025
92ebb90
Update dashboard data - 2025-09-20 06:06:17 UTC
hmcts-platform-operations Sep 20, 2025
4a479a6
Update dashboard data - 2025-09-21 06:06:14 UTC
hmcts-platform-operations Sep 21, 2025
955ca53
Update dashboard data - 2025-09-22 06:07:06 UTC
hmcts-platform-operations Sep 22, 2025
a79791a
Update dashboard data - 2025-09-23 06:06:51 UTC
hmcts-platform-operations Sep 23, 2025
0c3a4fe
Update dashboard data - 2025-09-24 06:06:47 UTC
hmcts-platform-operations Sep 24, 2025
18a284d
Update dashboard data - 2025-09-25 06:07:04 UTC
hmcts-platform-operations Sep 25, 2025
e04697a
Update dashboard data - 2025-09-26 06:06:34 UTC
hmcts-platform-operations Sep 26, 2025
321c401
Update dashboard data - 2025-09-27 06:06:00 UTC
hmcts-platform-operations Sep 27, 2025
6136539
Update dashboard data - 2025-09-28 06:07:18 UTC
hmcts-platform-operations Sep 28, 2025
9642ff5
Update dashboard data - 2025-09-29 06:07:05 UTC
hmcts-platform-operations Sep 29, 2025
335631d
Update dashboard data - 2025-09-29 09:56:07 UTC
hmcts-platform-operations Sep 29, 2025
c4da74a
Update dashboard data - 2025-09-30 06:06:53 UTC
hmcts-platform-operations Sep 30, 2025
c01998c
Update dashboard data - 2025-10-01 06:06:44 UTC
hmcts-platform-operations Oct 1, 2025
065e133
Update dashboard data - 2025-10-02 06:06:30 UTC
hmcts-platform-operations Oct 2, 2025
d6a4672
Update dashboard data - 2025-10-03 06:06:23 UTC
hmcts-platform-operations Oct 3, 2025
0bcf31b
Update dashboard data - 2025-10-04 06:06:07 UTC
hmcts-platform-operations Oct 4, 2025
02cf8dc
Update dashboard data - 2025-10-05 06:06:07 UTC
hmcts-platform-operations Oct 5, 2025
a7b3292
Update dashboard data - 2025-10-06 06:06:47 UTC
hmcts-platform-operations Oct 6, 2025
31bb3e2
Update dashboard data - 2025-10-07 06:06:41 UTC
hmcts-platform-operations Oct 7, 2025
0290c9b
Update dashboard data - 2025-10-08 06:06:47 UTC
hmcts-platform-operations Oct 8, 2025
a0f6cd0
Update dashboard data - 2025-10-09 06:06:49 UTC
hmcts-platform-operations Oct 9, 2025
9df9e9f
Update dashboard data - 2025-10-10 06:06:39 UTC
hmcts-platform-operations Oct 10, 2025
d9bfb56
Update dashboard data - 2025-10-11 06:06:09 UTC
hmcts-platform-operations Oct 11, 2025
a9d5f45
Update dashboard data - 2025-10-12 06:06:07 UTC
hmcts-platform-operations Oct 12, 2025
09fd9bd
Update dashboard data - 2025-10-13 06:07:08 UTC
hmcts-platform-operations Oct 13, 2025
80aa247
housekeeping
hmcts-platform-operations Oct 13, 2025
4356af7
Update dashboard data - 2025-10-14 06:07:09 UTC
hmcts-platform-operations Oct 14, 2025
fac772b
housekeeping
hmcts-platform-operations Oct 14, 2025
5fc9fad
Update dashboard data - 2025-10-15 06:06:59 UTC
hmcts-platform-operations Oct 15, 2025
65e9917
Update dashboard data - 2025-10-16 06:07:08 UTC
hmcts-platform-operations Oct 16, 2025
355c845
Update dashboard data - 2025-10-17 06:06:38 UTC
hmcts-platform-operations Oct 17, 2025
b60c409
Update dashboard data - 2025-10-18 06:06:05 UTC
hmcts-platform-operations Oct 18, 2025
cdc0762
Update dashboard data - 2025-10-19 06:06:30 UTC
hmcts-platform-operations Oct 19, 2025
db163b2
Update dashboard data - 2025-10-20 06:06:57 UTC
hmcts-platform-operations Oct 20, 2025
6b8432b
Update dashboard data - 2025-10-21 06:07:13 UTC
hmcts-platform-operations Oct 21, 2025
faae96e
Add ADR: test adr
backstage-hmcts[bot] Oct 21, 2025
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
22 changes: 21 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
@@ -1 +1,21 @@
.venv
.venv
__pycache__/
*.pyc
*.pyo
*.pyd
.Python
build/
develop-eggs/
dist/
downloads/
eggs/
.eggs/
lib/
lib64/
parts/
sdist/
var/
wheels/
*.egg-info/
.installed.cfg
*.egg
172 changes: 172 additions & 0 deletions COST_CALCULATION_IMPROVEMENTS.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,172 @@
# Cost Calculation Improvements

## Overview

This enhancement extends the existing cost calculation system to support additional Azure resource types beyond AKS clusters and VM Scale Sets. The system now supports:

- **Virtual Machines** - Individual VMs with accurate SKU detection
- **Application Gateways** - With tier and capacity-based pricing
- **PostgreSQL Flexible Servers** - With compute tier-based pricing
- **SQL Managed Instances** - With vCore-based pricing

## Key Features

### 1. Scalable Resource Type Support

The system uses a new data format that includes resource type information:
```
ResourceType,SKU,OS/Tier,Count
```

Examples:
```
VM,Standard_D2s_v3,Linux,2
ApplicationGateway,Standard_v2,Standard_v2,1
FlexibleServer,GP_Standard_D2ds_v4,PostgreSQL,1
SqlManagedInstance,GP_Gen5_4,GeneralPurpose,1
```

### 2. Backward Compatibility

The system maintains full backward compatibility with the existing format:
```
SKU,OS,Count
```

Legacy entries are automatically treated as VM resources.

### 3. Enhanced SKU Detection

- **Virtual Machines**: Extracts actual VM size and OS type from Azure properties
- **Application Gateways**: Detects tier, name, and capacity from Azure SKU properties
- **Flexible Servers**: Extracts compute tier and VM size from Azure SKU properties
- **SQL Managed Instances**: Detects service tier, generation, and vCore count

### 4. Robust Pricing API Integration

- Supports different Azure Pricing API product names for each resource type
- Includes fallback pricing when API is unavailable
- Maintains existing retry logic and error handling

### 5. Resource-Specific Cost Calculations

While most resources use the standard shutdown schedule calculation, the system is designed to support resource-specific cost models if needed in the future.

## Implementation Details

### New Functions in `resource-details.sh`

1. **`countResource()`** - Enhanced resource counting with type support
2. **`get_vm_costs()`** - Collects Virtual Machine cost information
3. **`get_appgateway_costs()`** - Collects Application Gateway cost information
4. **`get_flexible_server_costs()`** - Collects Flexible Server cost information
5. **`get_sqlmi_costs()`** - Collects SQL Managed Instance cost information

### Enhanced `cost-calculator.py`

1. **`get_fallback_pricing()`** - Provides fallback pricing when API is unavailable
2. **`azPriceAPI()`** - Enhanced to handle different resource types and product names
3. **Main processing loop** - Supports both new and legacy data formats

## Azure Graph Queries

The system uses enhanced Azure Resource Graph queries to extract pricing-relevant information:

### Virtual Machines
```kql
resources
| where type =~ 'Microsoft.Compute/virtualMachines'
| where tags.autoShutdown == 'true'
| project name, resourceGroup, subscriptionId, ['tags'],
properties.hardwareProfile.vmSize, properties.storageProfile.osDisk.osType
```

### Application Gateways
```kql
resources
| where type =~ 'microsoft.network/applicationgateways'
| where tags.autoShutdown == 'true'
| project name, resourceGroup, subscriptionId, ['tags'],
properties.sku.tier, properties.sku.name, properties.sku.capacity
```

### PostgreSQL Flexible Servers
```kql
resources
| where type =~ 'microsoft.dbforpostgresql/flexibleservers'
| where tags.autoShutdown == 'true'
| project name, resourceGroup, subscriptionId, ['tags'],
properties.sku.tier, properties.sku.name
```

### SQL Managed Instances
```kql
resources
| where type =~ 'microsoft.sql/managedinstances'
| where tags.autoShutdown == 'true'
| project name, resourceGroup, subscriptionId, ['tags'],
properties.sku.tier, properties.sku.family, properties.vCores
```

## Adding New Resource Types

To add support for additional resource types in the future:

1. **Create collection function** in `resource-details.sh`:
```bash
function get_newresource_costs() {
# Azure graph query to get resources with SKU info
# Process each resource and call countResource
}
```

2. **Add to main collection** in `resource-details.sh`:
```bash
get_newresource_costs
```

3. **Add pricing logic** in `cost-calculator.py`:
```python
elif resource_type == "NewResourceType":
productName = "'New Resource Product Name'"
```

4. **Add fallback pricing** in `cost-calculator.py`:
```python
"NewResourceType": {
"SKU_Name": hourly_rate
}
```

## Testing

The implementation includes comprehensive tests covering:

- Legacy format compatibility
- New format support
- Mixed format handling
- All resource types
- Stay-on-late functionality
- Error handling and fallback pricing

Run tests with:
```bash
# Basic functionality test
./test_cost_calculation.sh

# Comprehensive test suite
./final_test_suite.sh
```

## Cost Estimation Accuracy

The system maintains the existing 25% buffer for unmeasurable costs and uses realistic fallback pricing when the Azure Pricing API is unavailable. This ensures cost estimates remain useful even in degraded conditions.

## Future Enhancements

Potential future improvements:
- Resource-specific cost calculation models
- Regional pricing support
- Reserved instance pricing consideration
- More granular Application Gateway data processing costs
- Disk and storage cost calculations
35 changes: 35 additions & 0 deletions docs/adrs/0001-test-adr.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
---
Title: test adr
Date: 2025-10-21
Deciders: thomas thornton
Technical Story: dtspo-1234
---

## Status:
proposed

## Context:
hello

## Decision:
Winner

---

## Consequences:

### Pros:
no

### Cons / Risks:
test

---

## Alternatives Considered:
test

---

## Further Considerations:
test
Loading
Loading