2024-11-18 15:23:13 +00:00
|
|
|
// Copyright 2024 Patial Tech. All rights reserved.
|
|
|
|
// Use of this source code is governed by a BSD-style
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
2024-11-17 16:58:29 +00:00
|
|
|
package user
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"errors"
|
|
|
|
"log/slog"
|
|
|
|
|
|
|
|
"gitserver.in/patialtech/rano/db"
|
|
|
|
"gitserver.in/patialtech/rano/db/ent"
|
|
|
|
"gitserver.in/patialtech/rano/db/ent/verifytoken"
|
|
|
|
"gitserver.in/patialtech/rano/util/logger"
|
|
|
|
)
|
|
|
|
|
|
|
|
// VerifyEmailAddress by a token
|
|
|
|
func VerifyEmailAddress(ctx context.Context, token string) error {
|
|
|
|
// decode token
|
|
|
|
uid, err := tokenToVerifyEmail(token)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
client := db.Client()
|
|
|
|
|
|
|
|
// get token from DB
|
|
|
|
vt, err := client.VerifyToken.Query().Where(verifytoken.TokenEQ(token)).Only(ctx)
|
|
|
|
if err != nil {
|
|
|
|
if ent.IsNotFound(err) {
|
|
|
|
return ErrInvalidToken
|
|
|
|
}
|
|
|
|
|
|
|
|
logger.Error(err, slog.String("ref", "pkg/user/verify.VerifyEmail"))
|
|
|
|
return ErrInvalidToken
|
|
|
|
}
|
|
|
|
|
|
|
|
// all good, lets do the following
|
|
|
|
// 1. Update user email verify status
|
|
|
|
// 2. Remvoe token from DB
|
|
|
|
// do it in a transaction
|
|
|
|
|
|
|
|
tx, err := client.BeginTx(ctx, nil)
|
|
|
|
if err != nil {
|
|
|
|
logger.Error(err)
|
|
|
|
return errors.New("unexpected error")
|
|
|
|
}
|
|
|
|
|
|
|
|
// update user email verify status
|
|
|
|
if err = tx.User.UpdateOneID(uid).SetEmailVerified(true).Exec(ctx); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// remove token from DB
|
|
|
|
if err = tx.VerifyToken.DeleteOneID(vt.ID).Exec(ctx); err != nil {
|
|
|
|
_ = tx.Rollback()
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// we are all done now,
|
|
|
|
// let's commit
|
|
|
|
return tx.Commit()
|
|
|
|
}
|