Skip to content

Commit

Permalink
Merge pull request #1479 from Azanul/develop
Browse files Browse the repository at this point in the history
Add support for Redshift clusters
  • Loading branch information
Azanul authored Aug 4, 2024
2 parents 5655ca0 + cbb01cf commit c40e317
Show file tree
Hide file tree
Showing 2 changed files with 104 additions and 16 deletions.
90 changes: 90 additions & 0 deletions providers/aws/redshift/cluster.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,90 @@
package redshift

import (
"context"
"fmt"
"time"

log "github.com/sirupsen/logrus"

"github.com/aws/aws-sdk-go-v2/aws"
"github.com/aws/aws-sdk-go-v2/service/redshift"
"github.com/aws/aws-sdk-go-v2/service/sts"
"github.com/tailwarden/komiser/models"
"github.com/tailwarden/komiser/providers"
awsUtils "github.com/tailwarden/komiser/providers/aws/utils"
)

func Resources(ctx context.Context, client providers.ProviderClient) ([]models.Resource, error) {
resources := make([]models.Resource, 0)
var config redshift.DescribeClustersInput
redshiftClient := redshift.NewFromConfig(*client.AWSClient)

stsClient := sts.NewFromConfig(*client.AWSClient)
stsOutput, err := stsClient.GetCallerIdentity(ctx, &sts.GetCallerIdentityInput{})
if err != nil {
return resources, err
}

accountId := stsOutput.Account

serviceCost, err := awsUtils.GetCostAndUsage(ctx, client.AWSClient.Region, "Redshift")
if err != nil {
log.Warnln("Couldn't fetch Redshift cost and usage:", err)
}

for {
output, err := redshiftClient.DescribeClusters(ctx, &config)
if err != nil {
return resources, err
}

for _, cluster := range output.Clusters {
resourceArn := fmt.Sprintf("arn:aws:redshift:%s:%s:cluster/%s", client.AWSClient.Region, *accountId, *cluster.ClusterIdentifier)
outputTags := cluster.Tags

tags := make([]models.Tag, 0)

for _, tag := range outputTags {
tags = append(tags, models.Tag{
Key: *tag.Key,
Value: *tag.Value,
})
}

monthlyCost := float64(0)

resources = append(resources, models.Resource{
Provider: "AWS",
Account: client.Name,
Service: "Redshift Cluster",
ResourceId: resourceArn,
Region: client.AWSClient.Region,
Name: *cluster.ClusterIdentifier,
Cost: monthlyCost,
Metadata: map[string]string{
"serviceCost": fmt.Sprint(serviceCost),
},
Tags: tags,
FetchedAt: time.Now(),
Link: fmt.Sprintf("https://%s.console.aws.amaxon.com/redshift/home?region=%s/clusters/%s", client.AWSClient.Region, client.AWSClient.Region, *cluster.ClusterIdentifier),
})

}

if aws.ToString(output.Marker) == "" {
break
}
config.Marker = output.Marker
}

log.WithFields(log.Fields{
"provider": "AWS",
"account": client.Name,
"region": client.AWSClient.Region,
"service": "Redshift Cluster",
"resources": len(resources),
}).Info("Fetched resources")
return resources, nil

}
30 changes: 14 additions & 16 deletions providers/aws/redshift/eventsubscription.go
Original file line number Diff line number Diff line change
Expand Up @@ -10,13 +10,13 @@ import (
"github.com/aws/aws-sdk-go-v2/aws"
"github.com/aws/aws-sdk-go-v2/service/redshift"
"github.com/aws/aws-sdk-go-v2/service/sts"
. "github.com/tailwarden/komiser/models"
. "github.com/tailwarden/komiser/providers"
"github.com/tailwarden/komiser/models"
"github.com/tailwarden/komiser/providers"
awsUtils "github.com/tailwarden/komiser/providers/aws/utils"
)

func EventSubscriptions(ctx context.Context, client ProviderClient) ([]Resource, error) {
resources := make([]Resource, 0)
func EventSubscriptions(ctx context.Context, client providers.ProviderClient) ([]models.Resource, error) {
resources := make([]models.Resource, 0)
var config redshift.DescribeEventSubscriptionsInput
redshiftClient := redshift.NewFromConfig(*client.AWSClient)

Expand Down Expand Up @@ -45,20 +45,18 @@ func EventSubscriptions(ctx context.Context, client ProviderClient) ([]Resource,
resourceArn := fmt.Sprintf("arn:aws:redshift:%s:%s:eventsubscripion/%s", client.AWSClient.Region, *accountId, *eventSubscription.CustSubscriptionId)
outputTags := eventSubscription.Tags

tags := make([]Tag, 0)
tags := make([]models.Tag, 0)

if err == nil {
for _, tag := range outputTags {
tags = append(tags, Tag{
Key: *tag.Key,
Value: *tag.Value,
})
}
for _, tag := range outputTags {
tags = append(tags, models.Tag{
Key: *tag.Key,
Value: *tag.Value,
})
}

monthlyCost := float64(0)

resources = append(resources, Resource{
resources = append(resources, models.Resource{
Provider: "AWS",
Account: client.Name,
Service: "Redshift EventSubscription",
Expand All @@ -69,9 +67,9 @@ func EventSubscriptions(ctx context.Context, client ProviderClient) ([]Resource,
Metadata: map[string]string{
"serviceCost": fmt.Sprint(serviceCost),
},
Tags: tags,
FetchedAt: time.Now(),
Link: fmt.Sprintf("https://%s.console.aws.amaxon.com/redshift/home?region=%s/event-subscriptions/%s", client.AWSClient.Region, client.AWSClient.Region, *eventSubscription.CustSubscriptionId),
Tags: tags,
FetchedAt: time.Now(),
Link: fmt.Sprintf("https://%s.console.aws.amaxon.com/redshift/home?region=%s/event-subscriptions/%s", client.AWSClient.Region, client.AWSClient.Region, *eventSubscription.CustSubscriptionId),
})
}
}
Expand Down

0 comments on commit c40e317

Please sign in to comment.