/
images.go
69 lines (60 loc) · 2.04 KB
/
images.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
65
66
67
68
69
package resources
import (
"context"
"github.com/cloudquery/plugin-sdk/v4/schema"
"github.com/cloudquery/plugin-sdk/v4/transformers"
"github.com/dihedron/cq-plugin-utils/format"
"github.com/dihedron/cq-plugin-utils/transform"
"github.com/dihedron/cq-source-openstack/client"
"github.com/gophercloud/gophercloud/openstack/imageservice/v2/images"
)
func Images() *schema.Table {
return &schema.Table{
Name: "openstack_images",
Resolver: fetchImages,
Transform: transformers.TransformWithStruct(
&images.Image{},
//transformers.WithPrimaryKeys("ID"),
transformers.WithNameTransformer(transform.TagNameTransformer), // use cq-name tags to translate name
transformers.WithTypeTransformer(transform.TagTypeTransformer), // use cq-type tags to translate type
//transformers.WithSkipFields("Metadata", "Properties", "Tags"),
transformers.WithSkipFields("Links"),
),
Relations: []*schema.Table{
ImageMetadata(),
ImageProperties(),
ImageTags(),
},
}
}
func fetchImages(ctx context.Context, meta schema.ClientMeta, parent *schema.Resource, res chan<- interface{}) error {
api := meta.(*client.Client)
glance, err := api.GetServiceClient(client.ImageServiceV2)
if err != nil {
api.Logger().Error().Err(err).Msg("error retrieving client")
return err
}
opts := images.ListOpts{}
allPages, err := images.List(glance, opts).AllPages()
if err != nil {
api.Logger().Error().Err(err).Str("options", format.ToPrettyJSON(opts)).Msg("error listing images with options")
return err
}
allImages, err := images.ExtractImages(allPages)
if err != nil {
api.Logger().Error().Err(err).Msg("error extracting images")
return err
}
api.Logger().Debug().Int("count", len(allImages)).Msg("images retrieved")
for _, image := range allImages {
if ctx.Err() != nil {
api.Logger().Debug().Msg("context done, exit")
break
}
image := image
// api.Logger().Debug().Str("data", format.ToPrettyJSON(image)).Msg("streaming image")
api.Logger().Debug().Str("id", image.ID).Msg("streaming image")
res <- image
}
return nil
}