-
Notifications
You must be signed in to change notification settings - Fork 0
/
update_used_ingredient.go
74 lines (66 loc) · 2.68 KB
/
update_used_ingredient.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
package handlers
import (
usedIngredient "github.com/Digital-Voting-Team/warehouse-service/internal/pkg/used_ingredient"
"github.com/Digital-Voting-Team/warehouse-service/internal/service/helpers"
requests "github.com/Digital-Voting-Team/warehouse-service/internal/service/requests/used_ingredient"
"github.com/Digital-Voting-Team/warehouse-service/resources"
"net/http"
"gitlab.com/distributed_lab/ape"
"gitlab.com/distributed_lab/ape/problems"
)
func UpdateUsedIngredient(w http.ResponseWriter, r *http.Request) {
request, err := requests.NewUpdateUsedIngredientRequest(r)
if err != nil {
helpers.Log(r).WithError(err).Info("wrong request")
ape.RenderErr(w, problems.BadRequest(err)...)
return
}
currentUsedIngredient, err := helpers.UsedIngredientsQuery(r).FilterById(request.UsedIngredientID).Get()
if currentUsedIngredient == nil {
helpers.Log(r).WithError(err).Info("did not found usedIngredient to update")
ape.Render(w, problems.NotFound())
return
}
//userId := r.Context().Value("userId").(int64)
//accessLevel := r.Context().Value("accessLevel").(*resources.AccessLevel)
//_, _, usedIngredientId, err := helpers.GetIdsForGivenUser(r, userId)
//if err != nil {
// helpers.Log(r).WithError(err).Info("wrong relations")
// ape.RenderErr(w, problems.InternalError())
// return
//}
//if *accessLevel != resources.Admin && usedIngredientId != usedIngredient.ID {
// helpers.Log(r).Info("insufficient user permissions")
// ape.RenderErr(w, problems.Forbidden())
// return
//}
newUsedIngredient := usedIngredient.UsedIngredient{
Name: request.Data.Attributes.Name,
Quantity: request.Data.Attributes.Quantity,
Origin: request.Data.Attributes.Origin,
Price: request.Data.Attributes.Price,
DeletionDate: request.Data.Attributes.DeletionDate,
Reason: request.Data.Attributes.Reason,
}
var resultUsedIngredient usedIngredient.UsedIngredient
resultUsedIngredient, err = helpers.UsedIngredientsQuery(r).FilterById(currentUsedIngredient.Id).Update(newUsedIngredient)
if err != nil {
helpers.Log(r).WithError(err).Error("failed to update usedIngredient")
ape.RenderErr(w, problems.InternalError())
return
}
result := resources.UsedIngredientResponse{
Data: resources.UsedIngredient{
Key: resources.NewKeyInt64(resultUsedIngredient.Id, resources.USED_INGREDIENT),
Attributes: resources.UsedIngredientAttributes{
DeletionDate: resultUsedIngredient.DeletionDate,
Name: resultUsedIngredient.Name,
Origin: resultUsedIngredient.Origin,
Price: resultUsedIngredient.Price,
Quantity: resultUsedIngredient.Quantity,
Reason: resultUsedIngredient.Reason,
},
},
}
ape.Render(w, result)
}