/
update_user.go
65 lines (51 loc) · 1.67 KB
/
update_user.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
package main
import (
"context"
"time"
"github.com/elojah/trax/internal/user"
"github.com/elojah/trax/internal/user/dto"
gerrors "github.com/elojah/trax/pkg/errors"
"github.com/elojah/trax/pkg/pbtypes"
"github.com/elojah/trax/pkg/transaction"
"github.com/rs/zerolog/log"
"google.golang.org/grpc/codes"
"google.golang.org/grpc/status"
)
func (h *handler) UpdateUser(ctx context.Context, req *dto.UpdateUserReq) (*user.U, error) {
logger := log.With().Str("method", "update_user").Logger()
if req == nil {
return &user.U{}, status.New(codes.Internal, gerrors.ErrNullRequest{}.Error()).Err()
}
// #MARK:Authenticate
claims, err := h.user.Auth(ctx, "access")
if err != nil {
return &user.U{}, status.New(codes.Unauthenticated, err.Error()).Err()
}
var u user.U
if err := h.user.Tx(ctx, transaction.Write, func(ctx context.Context) (transaction.Operation, error) {
now := time.Now().Unix()
us, err := h.user.Update(ctx, user.Filter{
ID: claims.UserID,
}, user.Patch{
FirstName: pbtypes.GetString(req.Firstname),
LastName: pbtypes.GetString(req.Lastname),
AvatarURL: pbtypes.GetString(req.AvatarURL),
UpdatedAt: &now,
})
if err != nil {
logger.Error().Err(err).Msg("failed to update user")
return transaction.Rollback, status.New(codes.Internal, err.Error()).Err()
}
if len(us) == 0 {
err := gerrors.ErrNotFound{Resource: "user", Index: claims.UserID.String()}
logger.Error().Err(err).Msg("failed to update user")
return transaction.Rollback, status.New(codes.NotFound, err.Error()).Err()
}
u = us[0]
return transaction.Commit, nil
}); err != nil {
return &user.U{}, err
}
logger.Info().Msg("success")
return &u, nil
}