An atproto PDS written in Go
at main 1.4 kB view raw
1package server 2 3import ( 4 "time" 5 6 "github.com/Azure/go-autorest/autorest/to" 7 "github.com/haileyok/cocoon/internal/helpers" 8 "github.com/haileyok/cocoon/models" 9 "github.com/labstack/echo/v4" 10) 11 12type ComAtprotoServerConfirmEmailRequest struct { 13 Email string `json:"email" validate:"required"` 14 Token string `json:"token" validate:"required"` 15} 16 17func (s *Server) handleServerConfirmEmail(e echo.Context) error { 18 urepo := e.Get("repo").(*models.RepoActor) 19 20 var req ComAtprotoServerConfirmEmailRequest 21 if err := e.Bind(&req); err != nil { 22 s.logger.Error("error binding", "error", err) 23 return helpers.ServerError(e, nil) 24 } 25 26 if err := e.Validate(req); err != nil { 27 return helpers.InputError(e, nil) 28 } 29 30 if urepo.EmailVerificationCode == nil || urepo.EmailVerificationCodeExpiresAt == nil { 31 return helpers.ExpiredTokenError(e) 32 } 33 34 if *urepo.EmailVerificationCode != req.Token { 35 return helpers.InputError(e, to.StringPtr("InvalidToken")) 36 } 37 38 if time.Now().UTC().After(*urepo.EmailVerificationCodeExpiresAt) { 39 return helpers.ExpiredTokenError(e) 40 } 41 42 now := time.Now().UTC() 43 44 if err := s.db.Exec("UPDATE repos SET email_verification_code = NULL, email_verification_code_expires_at = NULL, email_confirmed_at = ? WHERE did = ?", nil, now, urepo.Repo.Did).Error; err != nil { 45 s.logger.Error("error updating user", "error", err) 46 return helpers.ServerError(e, nil) 47 } 48 49 return e.NoContent(200) 50}