/
table_gcp_sql_database_instance_metric_connections_daily.go
49 lines (41 loc) · 1.6 KB
/
table_gcp_sql_database_instance_metric_connections_daily.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
package gcp
import (
"context"
"github.com/turbot/steampipe-plugin-sdk/v5/grpc/proto"
"github.com/turbot/steampipe-plugin-sdk/v5/plugin"
"github.com/turbot/steampipe-plugin-sdk/v5/plugin/transform"
sqladmin "google.golang.org/api/sqladmin/v1beta4"
)
//// TABLE DEFINITION
func tableGcpSQLDatabaseInstanceMetricConnectionsDaily(_ context.Context) *plugin.Table {
return &plugin.Table{
Name: "gcp_sql_database_instance_metric_connections_daily",
Description: "GCP SQL Database Instance Metrics - Connections (Daily)",
List: &plugin.ListConfig{
ParentHydrate: listSQLDatabaseInstances,
Hydrate: listSQLDatabaseInstanceMetricConnectionsDaily,
},
Columns: monitoringMetricColumns([]*plugin.Column{
{
Name: "instance_id",
Description: "The ID of the instance.",
Type: proto.ColumnType_STRING,
Transform: transform.FromField("DimensionValue"),
},
}),
}
}
//// LIST FUNCTION
func listSQLDatabaseInstanceMetricConnectionsDaily(ctx context.Context, d *plugin.QueryData, h *plugin.HydrateData) (interface{}, error) {
instanceInfo := h.Item.(*sqladmin.DatabaseInstance)
// Get project details
getProjectCached := plugin.HydrateFunc(getProject).WithCache()
projectId, err := getProjectCached(ctx, d, h)
if err != nil {
return nil, err
}
project := projectId.(string)
location := instanceInfo.Region
dimensionValue := "\"" + project + ":" + instanceInfo.Name + "\""
return listMonitorMetricStatistics(ctx, d, h, "DAILY", "\"cloudsql.googleapis.com/database/network/connections\"", "resource.label.database_id = ", dimensionValue, instanceInfo.Name, location)
}