jilo-web/app/pages/register.php

85 lines
2.7 KiB
PHP
Raw Normal View History

<?php
2024-11-27 14:34:16 +00:00
/**
* User registration
*
* This page ("register") handles user registration if the feature is enabled in the configuration.
* It accepts a POST request with a username and password, attempts to register the user,
* and redirects to the login page on success or displays an error message on failure.
*/
// registration is allowed, go on
if ($config['registration_enabled'] == true) {
try {
2024-08-10 18:42:44 +00:00
// connect to database
$dbWeb = connectDB($config);
2024-08-10 18:42:44 +00:00
if ( $_SERVER['REQUEST_METHOD'] == 'POST' ) {
2025-02-17 13:15:05 +00:00
// Apply rate limiting
require '../app/includes/rate_limit_middleware.php';
checkRateLimit($dbWeb, 'register');
2025-02-10 17:25:17 +00:00
require_once '../app/classes/validator.php';
2025-02-10 17:25:17 +00:00
$validator = new Validator($_POST);
$rules = [
'username' => [
'required' => true,
'min' => 3,
'max' => 20
],
'password' => [
'required' => true,
'min' => 8,
'max' => 100
],
'confirm_password' => [
'required' => true,
'matches' => 'password'
]
];
2024-09-13 10:49:17 +00:00
2025-02-10 17:25:17 +00:00
if ($validator->validate($rules)) {
$username = $_POST['username'];
$password = $_POST['password'];
// registering
$result = $userObject->register($username, $password);
// redirect to login
if ($result === true) {
2025-02-16 08:18:26 +00:00
Feedback::flash('NOTICE', 'DEFAULT', "Registration successful. You can log in now.");
2025-02-10 17:25:17 +00:00
header('Location: ' . htmlspecialchars($app_root));
exit();
// registration fail, redirect to login
} else {
2025-02-16 08:18:26 +00:00
Feedback::flash('ERROR', 'DEFAULT', "Registration failed. $result");
2025-02-10 17:25:17 +00:00
header('Location: ' . htmlspecialchars($app_root));
exit();
}
} else {
2025-02-16 08:18:26 +00:00
Feedback::flash('ERROR', 'DEFAULT', $validator->getFirstError());
2025-02-10 17:25:17 +00:00
header('Location: ' . htmlspecialchars($app_root . '?page=register'));
exit();
}
}
} catch (Exception $e) {
2025-02-16 08:18:26 +00:00
Feedback::flash('ERROR', 'DEFAULT', $e->getMessage());
}
2025-02-17 08:24:50 +00:00
// Get any new feedback messages
2025-02-17 14:50:57 +00:00
include '../app/helpers/feedback.php';
// Load the template
2024-08-12 11:12:24 +00:00
include '../app/templates/form-register.php';
// registration disabled
} else {
2025-02-16 08:18:26 +00:00
echo Feedback::render('NOTICE', 'DEFAULT', 'Registration is disabled', false);
}
?>