- Added reset_token and reset_token_expiry fields to User model - Implemented generate_reset_token(), verify_reset_token(), and clear_reset_token() methods - Created password reset request form (/password-reset-request) - Created password reset form (/password-reset/<token>) - Added "Forgot password?" link to login page - Reset tokens expire after 1 hour for security - Created migration script to add new database columns - Reset links are logged (would be emailed in production) 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
42 lines
1.5 KiB
HTML
42 lines
1.5 KiB
HTML
{% extends "base.html" %}
|
|
|
|
{% block title %}Reset Password - BalanceBoard{% endblock %}
|
|
|
|
{% block content %}
|
|
<div class="auth-container">
|
|
<div class="auth-card">
|
|
<div class="auth-logo">
|
|
<img src="{{ url_for('serve_logo') }}" alt="BalanceBoard Logo">
|
|
<h1><span class="balance">balance</span>Board</h1>
|
|
<p style="color: var(--text-secondary); margin-top: 8px;">Reset your password</p>
|
|
</div>
|
|
|
|
{% with messages = get_flashed_messages(with_categories=true) %}
|
|
{% if messages %}
|
|
<div class="flash-messages">
|
|
{% for category, message in messages %}
|
|
<div class="flash-message {{ category }}">{{ message }}</div>
|
|
{% endfor %}
|
|
</div>
|
|
{% endif %}
|
|
{% endwith %}
|
|
|
|
<form method="POST" class="auth-form">
|
|
<div class="form-group">
|
|
<label for="email">Email Address</label>
|
|
<input type="email" id="email" name="email" required autofocus>
|
|
<small style="color: var(--text-secondary); display: block; margin-top: 4px;">
|
|
Enter the email address associated with your account and we'll send you a password reset link.
|
|
</small>
|
|
</div>
|
|
|
|
<button type="submit">Send Reset Link</button>
|
|
</form>
|
|
|
|
<div class="auth-footer">
|
|
<p>Remember your password? <a href="{{ url_for('login') }}">Log in</a></p>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{% endblock %}
|