package user import ( "net/url" "nixcn-cms/data" "nixcn-cms/internal/cryptography" "nixcn-cms/utils" "unicode/utf8" "github.com/gin-gonic/gin" "github.com/google/uuid" ) func Update(c *gin.Context) { // New user model userIdOrig, ok := c.Get("user_id") if !ok { utils.HttpResponse(c, 403, "", "userid error") return } userId, err := uuid.Parse(userIdOrig.(string)) if err != nil { utils.HttpResponse(c, 500, "", "failed to parse uuid") return } var ReqInfo data.User err = c.ShouldBindJSON(&ReqInfo) if err != nil { utils.HttpResponse(c, 400, "", "invilad request") return } // Get user info userData, err := new(data.User).GetByUserId(userId) if err != nil { utils.HttpResponse(c, 500, "", "failed to find user") return } // if len(ReqInfo.Email) < 5 || len(ReqInfo.Email) >= 255 { // utils.HttpResponse(c, 400, "", "invilad email") // return // } // userData.Email = ReqInfo.Email // utils.HttpResponse(c, 400, "", "invilad user name") // return if ReqInfo.Username != "" { if len(ReqInfo.Username) < 5 || len(ReqInfo.Username) >= 255 { utils.HttpResponse(c, 400, "", "invalid request") return } userData.Username = ReqInfo.Username } if ReqInfo.Nickname != "" { if utf8.RuneCountInString(ReqInfo.Nickname) > 24 { utils.HttpResponse(c, 400, "", "invalid request") return } userData.Nickname = ReqInfo.Nickname } if ReqInfo.Subtitle != "" { if utf8.RuneCountInString(ReqInfo.Subtitle) > 32 { utils.HttpResponse(c, 400, "", "invalid request") return } userData.Subtitle = ReqInfo.Subtitle } if ReqInfo.Avatar != "" { _, err := url.ParseRequestURI(ReqInfo.Avatar) if err != nil { utils.HttpResponse(c, 400, "", "invalid request") return } userData.Avatar = ReqInfo.Avatar } if ReqInfo.Bio != "" { if !cryptography.IsBase64Std(ReqInfo.Bio) { utils.HttpResponse(c, 400, "", "invalid request") return } userData.Bio = ReqInfo.Bio } // Update user info userData.UpdateByUserID(userId) utils.HttpResponse(c, 200, "", "success") }