/
lost_password.go
71 lines (62 loc) · 1.79 KB
/
lost_password.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
66
67
68
69
70
71
package mongo
import (
"context"
"errors"
"time"
"github.com/ic3network/mccs-alpha-api/internal/app/types"
"go.mongodb.org/mongo-driver/bson"
"go.mongodb.org/mongo-driver/mongo"
"go.mongodb.org/mongo-driver/mongo/options"
)
type lostPassword struct {
c *mongo.Collection
}
var LostPassword = &lostPassword{}
func (l *lostPassword) Register(db *mongo.Database) {
l.c = db.Collection("lostPassword")
}
// Create creates a lost password record in the table
func (l *lostPassword) Create(lostPassword *types.LostPassword) error {
filter := bson.M{"email": lostPassword.Email}
update := bson.M{"$set": bson.M{
"email": lostPassword.Email,
"token": lostPassword.Token,
"tokenUsed": false,
"createdAt": time.Now(),
}}
_, err := l.c.UpdateOne(
context.Background(),
filter,
update,
options.Update().SetUpsert(true),
)
return err
}
func (l *lostPassword) FindByToken(token string) (*types.LostPassword, error) {
if token == "" {
return nil, errors.New("Invalid token.")
}
lostPassword := types.LostPassword{}
err := l.c.FindOne(context.Background(), types.LostPassword{Token: token}).Decode(&lostPassword)
if err != nil {
return nil, errors.New("Invalid token.")
}
return &lostPassword, nil
}
func (l *lostPassword) FindByEmail(email string) (*types.LostPassword, error) {
if email == "" {
return nil, errors.New("Invalid token.")
}
lostPassword := types.LostPassword{}
err := l.c.FindOne(context.Background(), types.LostPassword{Email: email}).Decode(&lostPassword)
if err != nil {
return nil, errors.New("Invalid token.")
}
return &lostPassword, nil
}
func (l *lostPassword) SetTokenUsed(token string) error {
filter := bson.M{"token": token}
update := bson.M{"$set": bson.M{"tokenUsed": true}}
_, err := l.c.UpdateOne(context.Background(), filter, update)
return err
}