Skip to content

Commit

Permalink
Merge branch 'main' into v2-incident-patch
Browse files Browse the repository at this point in the history
  • Loading branch information
Aloento authored Jan 15, 2025
2 parents 75e174e + 513ef6d commit b466392
Show file tree
Hide file tree
Showing 3 changed files with 103 additions and 7 deletions.
3 changes: 2 additions & 1 deletion docs/readme.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,4 +2,5 @@

## Table of contents

- [Incident creation for API V1](./v1/v1_incident_creation.md)
- [Incident creation for API V1](./v1/v1_incident_creation.md)
- [Components availability V2](./v2/v2_components_availability.md)
101 changes: 101 additions & 0 deletions docs/v2/v2_components_availability.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,101 @@
# Components availability V2

## Overview

The `GetComponentsAvailabilityHandler` is an HTTP handler function
that returns a JSON response containing the availability data of
system components. It supports the following features:

## Handler Function: `GetComponentsAvailabilityHandler`

### Description

This handler performs the following operations:

- **Data Retrieval**: Fetches components along with their associated incidents from the database.
- **Availability Calculation**: Computes monthly availability percentages for each component.
- **Data Sorting**: Orders the availability data in descending order by year and month.
- **Response Delivery**: Returns a JSON response containing the compiled availability data.

## Request

- **Method**: `GET`
- **Endpoint**: `v2/availability`
- **Query Parameters**: None
- **Headers**:
- `Content-Type: application/json`

## Response

- **Status Code**: `200 OK`
- **Content-Type**: `application/json`
- **Body**:

## JSON Response Structure

The handler returns a JSON object with the following structure:

```json
{
"data": [
{
"id": 218,
"name": "Auto Scaling",
"region": "EU-DE",
"availability": [
{
"year": 2024,
"month": 5,
"percentage": 99.999666
}
]
}
]
}
```

## Function: `calculateAvailability`

### Description

Calculates the monthly availability of a component over the past year, expressed as a percentage.
Availability is defined as the proportion of time a component was operational within a given month.

### Workflow

1. **Input Validation**:
- Returns an error if the component is `nil`.
- Returns `nil` if the component has no incidents.

2. **Defining the Calculation Period**:
- Sets the end date to the current date.
- Sets the start date to 11 months prior, covering a 12-month period.

3. **Initializing Downtime Array**:
- Creates an array to record downtime for each month.

4. **Processing Incidents**:
- Filters incidents to include only those with an end date and a specific impact level.
- Adjusts incident periods to fit within the calculation timeframe.
- Allocates downtime across relevant months, accounting for month boundaries.

5. **Calculating Monthly Availability**:
- For each month:
- Determines total hours in the month.
- Calculates availability using the formula:

```markdown
Availability (%) = 100% - (Downtime Hours / Total Hours in Month) × 100%
```

- Rounds the result to five decimal places.

6. **Returning the Result**:
- Returns an array of `MonthlyAvailability` objects with year, month, and availability percentage.

### Handling Month Boundaries

The function accounts for incidents spanning multiple months by:

- **Adjusting Incident Periods**: Constrains incident times to the calculation period.
- **Distributing Downtime**: Calculates overlap with each month to allocate downtime accurately.
6 changes: 0 additions & 6 deletions internal/api/v2/v2.go
Original file line number Diff line number Diff line change
Expand Up @@ -630,12 +630,6 @@ func GetComponentsAvailabilityHandler(dbInst *db.DB, logger *zap.Logger) gin.Han
}

sortComponentAvailability(compAvailability)
// sort.Slice(compAvailability, func(i, j int) bool {
// if compAvailability[i].Year == compAvailability[j].Year {
// return compAvailability[i].Month > compAvailability[j].Month
// }
// return compAvailability[i].Year > compAvailability[j].Year
// })

availability[index] = &ComponentAvailability{
ComponentID: ComponentID{int(comp.ID)},
Expand Down

0 comments on commit b466392

Please sign in to comment.