/
get_reviews_by_dd_id.go
70 lines (57 loc) · 2.32 KB
/
get_reviews_by_dd_id.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
//nolint:tagliatelle
package queries
import (
"context"
"database/sql"
"fmt"
"github.com/DIMO-Network/device-definitions-api/internal/core/common"
"github.com/volatiletech/sqlboiler/v4/queries/qm"
"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"
p_grpc "github.com/DIMO-Network/device-definitions-api/pkg/grpc"
"github.com/DIMO-Network/shared/db"
"github.com/pkg/errors"
)
type GetReviewsByDeviceDefinitionIDQuery struct {
DeviceDefinitionID string `json:"device_definition_id"`
}
func (*GetReviewsByDeviceDefinitionIDQuery) Key() string {
return "GetReviewsByDeviceDefinitionIDQuery"
}
type GetReviewsByDeviceDefinitionIDQueryHandler struct {
DBS func() *db.ReaderWriter
}
func NewGetReviewsByDeviceDefinitionIDQueryHandler(dbs func() *db.ReaderWriter) GetReviewsByDeviceDefinitionIDQueryHandler {
return GetReviewsByDeviceDefinitionIDQueryHandler{DBS: dbs}
}
func (qh GetReviewsByDeviceDefinitionIDQueryHandler) Handle(ctx context.Context, query mediator.Message) (interface{}, error) {
qry := query.(*GetReviewsByDeviceDefinitionIDQuery)
all, err := models.Reviews(models.ReviewWhere.DeviceDefinitionID.EQ(qry.DeviceDefinitionID),
qm.Load(models.ReviewRels.DeviceDefinition),
qm.Load(qm.Rels(models.ReviewRels.DeviceDefinition, models.DeviceDefinitionRels.DeviceMake))).
All(ctx, qh.DBS().Reader)
if err != nil {
if errors.Is(err, sql.ErrNoRows) {
return &p_grpc.GetReviewsResponse{}, nil
}
return nil, &exceptions.InternalError{
Err: fmt.Errorf("failed to get reviews"),
}
}
result := &p_grpc.GetReviewsResponse{}
for _, review := range all {
result.Reviews = append(result.Reviews, &p_grpc.DeviceReview{
Id: review.ID,
Url: review.URL,
ImageURL: review.ImageURL,
Channel: review.Channel.String,
DeviceDefinitionId: review.DeviceDefinitionID,
Comments: review.Comments,
Approved: review.Approved,
ApprovedBy: review.ApprovedBy,
Name: common.BuildDeviceDefinitionName(review.R.DeviceDefinition.Year, review.R.DeviceDefinition.R.DeviceMake.Name, review.R.DeviceDefinition.Model),
})
}
return result, nil
}