feature: verify tokens
This commit is contained in:
@@ -23,8 +23,8 @@ func (User) Fields() []ent.Field {
|
||||
field.Bool("email_verified").Default(false),
|
||||
field.String("phone").MaxLen(20).Optional(),
|
||||
field.Bool("phone_verified").Default(false),
|
||||
field.String("pwd_salt").MaxLen(250).NotEmpty(),
|
||||
field.String("pwd_hash").MaxLen(250).NotEmpty(),
|
||||
field.String("pwd_salt").MaxLen(100).NotEmpty(),
|
||||
field.String("pwd_hash").MaxLen(100).NotEmpty(),
|
||||
field.Uint8("login_failed_count").Optional().Default(0),
|
||||
field.Time("login_attempt_on").Optional().Nillable(),
|
||||
field.Time("login_locked_until").Optional().Nillable(),
|
||||
@@ -40,6 +40,7 @@ func (User) Edges() []ent.Edge {
|
||||
return []ent.Edge{
|
||||
edge.To("sessions", UserSession.Type).StorageKey(edge.Column("user_id")),
|
||||
edge.To("audit_logs", Audit.Type).StorageKey(edge.Column("user_id")),
|
||||
edge.To("verify_tokens", VerifyToken.Type).StorageKey(edge.Column("user_id")),
|
||||
}
|
||||
}
|
||||
|
||||
|
29
db/ent/schema/verifyToken.go
Normal file
29
db/ent/schema/verifyToken.go
Normal file
@@ -0,0 +1,29 @@
|
||||
package schema
|
||||
|
||||
import (
|
||||
"entgo.io/ent"
|
||||
"entgo.io/ent/schema/edge"
|
||||
"entgo.io/ent/schema/field"
|
||||
)
|
||||
|
||||
// Verify holds the schema definition for the Verify entity.
|
||||
type VerifyToken struct {
|
||||
ent.Schema
|
||||
}
|
||||
|
||||
// Fields of the Verify.
|
||||
func (VerifyToken) Fields() []ent.Field {
|
||||
return []ent.Field{
|
||||
fieldID,
|
||||
fieldCreated,
|
||||
field.Time("expires_at").Immutable(),
|
||||
field.String("token").MaxLen(50).Unique(),
|
||||
field.String("purpose").MaxLen(50).Optional(),
|
||||
}
|
||||
}
|
||||
|
||||
func (VerifyToken) Edges() []ent.Edge {
|
||||
return []ent.Edge{
|
||||
edge.From("user", User.Type).Ref("verify_tokens").Unique(),
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user