package ru.mcs.diary.auth;
import jakarta.persistence.*;
import lombok.*;
import java.time.LocalDateTime;
@Entity
@Table(name = "password_reset_tokens")
@Getter
@Setter
@NoArgsConstructor
@AllArgsConstructor
@Builder
public class PasswordResetToken {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
@Column(nullable = false, unique = true)
private String token;
@Column(name = "user_email", nullable = false)
private String userEmail;
@Column(name = "user_type", nullable = false, length = 20)
private String userType; // "TEACHER" or "PARENT"
@Column(name = "expires_at", nullable = false)
private LocalDateTime expiresAt;
@Builder.Default
private Boolean used = false;
@Column(name = "created_at", nullable = false, updatable = false)
@Builder.Default
private LocalDateTime createdAt = LocalDateTime.now();
public boolean isExpired() {
return LocalDateTime.now().isAfter(expiresAt);
}
}