-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcinder.go
65 lines (56 loc) · 1.67 KB
/
cinder.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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
package main
import (
"context"
"github.com/gophercloud/gophercloud/pagination"
"github.com/gophercloud/gophercloud/openstack/blockstorage/v3/volumes"
"github.com/osquery/osquery-go/plugin/table"
)
func createCinderVolumesTable() *table.Plugin {
columns := []table.ColumnDefinition{
table.TextColumn("id"),
table.TextColumn("name"),
table.TextColumn("size"),
table.TextColumn("status"),
table.TextColumn("created_at"),
table.TextColumn("project_id"),
table.TextColumn("cloud_name"),
}
return table.NewPlugin("cinder_volumes", columns, generateCinderVolumes)
}
func generateCinderVolumes(ctx context.Context, queryContext table.QueryContext) ([]map[string]string, error) {
clients, err := getClientsFromCloudsYAML()
if err != nil {
return nil, err
}
var results []map[string]string
for _, client := range clients {
blockStorageClient, err := createBlockStorageClient(client.Client, client.ProjectID)
if err != nil {
return nil, err
}
pager := volumes.List(blockStorageClient, volumes.ListOpts{})
err = pager.EachPage(func(page pagination.Page) (bool, error) {
allVolumes, err := volumes.ExtractVolumes(page)
if err != nil {
return false, err
}
for _, volume := range allVolumes {
results = append(results, map[string]string{
"id": volume.ID,
"name": volume.Name,
"status": volume.Status,
"size": fmt.Sprintf("%d", volume.Size),
"volume_type": volume.VolumeType,
"created_at": volume.CreatedAt,
"project_id": client.ProjectID,
"cloud_name": client.CloudName,
})
}
return true, nil
})
if err != nil {
return nil, err
}
}
return results, nil
}