From f05d3392ed2bf609a5bc83eb6af82c858833d8d1 Mon Sep 17 00:00:00 2001 From: alex Date: Fri, 24 Feb 2023 08:42:58 +0100 Subject: [PATCH] added validation check for email and account name --- routers/api/v1/user/user.go | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) diff --git a/routers/api/v1/user/user.go b/routers/api/v1/user/user.go index f059691..a729c30 100644 --- a/routers/api/v1/user/user.go +++ b/routers/api/v1/user/user.go @@ -56,6 +56,27 @@ func UpdateUser(c *fiber.Ctx) error { return c.Status(fiber.StatusBadRequest).JSON(errValidation) } + foundUser := dbstructs.User{Id: params.UserId} + + if err := scylladb.Session.Query(gocnjhelper.DbMUsers.Get("email", "account_name_lc", "last_account_name_lc")).BindStruct(foundUser).GetRelease(&foundUser); err != nil { + gocnjhelper.LogErrorf("Failed to find user, err: %s", err.Error()) + return c.SendStatus(fiber.StatusInternalServerError) + } + + if foundUser.Email != body.Email { + if status, err := cnjvalidator.HandleEmailValidation(scylladb.Session, scylladb.Cluster.Keyspace, body.Email); err != nil { + return c.SendStatus(status) + } + } + + accountNameLc := strings.ToLower(body.AccountName) + + if foundUser.AccountNameLc != accountNameLc { + if status, err := cnjvalidator.HandleAccountNameValidation(scylladb.Session, scylladb.Cluster.Keyspace, body.AccountName); err != nil { + return c.SendStatus(status) + } + } + updatedUser := dbstructs.User{ Id: params.UserId, Username: body.Username,