-
Notifications
You must be signed in to change notification settings - Fork 1
/
get_dd_images_by_ids.go
84 lines (72 loc) · 2.81 KB
/
get_dd_images_by_ids.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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
package queries
import (
"context"
"github.com/DIMO-Network/device-definitions-api/internal/core/mediator"
"github.com/DIMO-Network/device-definitions-api/internal/infrastructure/db/models"
"github.com/DIMO-Network/device-definitions-api/internal/infrastructure/exceptions"
"github.com/DIMO-Network/device-definitions-api/pkg/grpc"
"github.com/DIMO-Network/shared/db"
"github.com/pkg/errors"
"github.com/rs/zerolog"
"github.com/volatiletech/sqlboiler/v4/queries/qm"
)
type GetDeviceDefinitionImagesByIDsQuery struct {
DeviceDefinitionID []string `json:"deviceDefinitionId" validate:"required"`
}
func (*GetDeviceDefinitionImagesByIDsQuery) Key() string {
return "GetDeviceDefinitionImagesByIDsQuery"
}
type GetDeviceDefinitionImagesByIDsQueryHandler struct {
log *zerolog.Logger
dbs func() *db.ReaderWriter
}
func NewGetDeviceDefinitionImagesByIDsQueryHandler(dbs func() *db.ReaderWriter, log *zerolog.Logger) GetDeviceDefinitionImagesByIDsQueryHandler {
return GetDeviceDefinitionImagesByIDsQueryHandler{
log: log,
dbs: dbs,
}
}
func (ch GetDeviceDefinitionImagesByIDsQueryHandler) Handle(ctx context.Context, query mediator.Message) (interface{}, error) {
qry := query.(*GetDeviceDefinitionImagesByIDsQuery)
if len(qry.DeviceDefinitionID) == 0 {
return nil, &exceptions.ValidationError{
Err: errors.New("Device Definition Ids is required"),
}
}
response := &grpc.GetDeviceImagesResponse{Images: make([]*grpc.DeviceImage, 0)}
all, err := models.Images(models.ImageWhere.DeviceDefinitionID.IN(qry.DeviceDefinitionID), qm.OrderBy(models.ImageColumns.DeviceDefinitionID)).All(ctx, ch.dbs().Reader)
if err != nil {
return nil, err
}
// filter for one image in each width/height size in preffered color
for _, image := range all {
// see if response.Images already has this image width, if not, add it, if it does, then does this image have a color we prefere?
if ei := findImage(response.Images, image.Width.Int, image.DeviceDefinitionID); ei == nil {
response.Images = append(response.Images, &grpc.DeviceImage{
DeviceDefinitionId: image.DeviceDefinitionID,
ImageUrl: image.SourceURL,
Width: int32(image.Width.Int),
Height: int32(image.Height.Int),
Color: image.Color,
})
} else {
// ei is a pointer so i should be able to just modify values in it
if ei.Color == "Silver" || ei.Color == "White" || ei.Color == "Red" {
continue
}
if image.Color == "Silver" || image.Color == "White" || image.Color == "Red" {
ei.Color = image.Color
ei.ImageUrl = image.SourceURL
}
}
}
return response, nil
}
func findImage(images []*grpc.DeviceImage, width int, ddID string) *grpc.DeviceImage {
for _, image := range images {
if image.Width == int32(width) && image.DeviceDefinitionId == ddID {
return image
}
}
return nil
}