register.php 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249
  1. <?php
  2. require_once __DIR__ . '/../config/database.php';
  3. require_once __DIR__ . '/../lib/auth.php';
  4. require_once __DIR__ . '/../lib/csrf.php';
  5. require_once __DIR__ . '/../lib/validation.php';
  6. require_once __DIR__ . '/../vendor/autoload.php';
  7. require_once __DIR__ . '/../lib/mailer.php';
  8. if (isLoggedIn()) {
  9. header('Location: /dashboard/dashboard.php');
  10. exit;
  11. }
  12. $errors = [];
  13. $old = []; // repopulate form fields on error
  14. if ($_SERVER['REQUEST_METHOD'] === 'POST') {
  15. if (!verifyCsrfToken($_POST['csrf_token'] ?? '')) {
  16. $errors['general'] = 'Invalid request. Please try again.';
  17. } else {
  18. $old = $_POST;
  19. // --- Validation ---
  20. $fullname = sanitizeString($_POST['fullname'] ?? '', 255);
  21. $email = sanitizeString($_POST['email'] ?? '', 255);
  22. $company = sanitizeString($_POST['company'] ?? '', 255);
  23. $mobilephone = sanitizeString($_POST['mobilephone'] ?? '', 50);
  24. $industry = $_POST['industry'] ?? '';
  25. $role = $_POST['role'] ?? '';
  26. $city = sanitizeString($_POST['city'] ?? '', 100);
  27. $state = $_POST['state'] ?? '';
  28. $postcode = sanitizeString($_POST['postcode'] ?? '', 20);
  29. $country = $_POST['country'] ?? 'Australia';
  30. $password = $_POST['password'] ?? '';
  31. $password2 = $_POST['password_confirm'] ?? '';
  32. if ($fullname === '') $errors['fullname'] = 'Full name is required.';
  33. if ($email === '') $errors['email'] = 'Email is required.';
  34. elseif (!filter_var($email, FILTER_VALIDATE_EMAIL)) $errors['email'] = 'Please enter a valid email.';
  35. if ($mobilephone === '') $errors['mobilephone'] = 'Mobile phone is required.';
  36. if ($password === '') $errors['password'] = 'Password is required.';
  37. elseif (strlen($password) < 8) $errors['password'] = 'Password must be at least 8 characters.';
  38. if ($password !== $password2) $errors['password_confirm'] = 'Passwords do not match.';
  39. $allowedIndustries = ['Broadacre','Viticulture','Horticulture','Permaculture','Dairy'];
  40. $allowedRoles = ['Manager','Viticulturist','Horticulturist','Permaculturist','Irrigation Manager'];
  41. $allowedStates = ['New South Wales','Victoria','Queensland','Western Australia','South Australia','Tasmania','Australian Capital Territory','Northern Territory','Other'];
  42. $allowedCountries = ['Australia','New Zealand'];
  43. if (!in_array($industry, $allowedIndustries, true)) $errors['industry'] = 'Please select an industry.';
  44. if (!in_array($role, $allowedRoles, true)) $errors['role'] = 'Please select a role.';
  45. if (!in_array($state, $allowedStates, true)) $errors['state'] = 'Please select a state.';
  46. if (!in_array($country, $allowedCountries, true)) $country = 'Australia';
  47. if (empty($errors)) {
  48. $result = registerUser([
  49. 'fullname' => $fullname,
  50. 'email' => $email,
  51. 'company' => $company,
  52. 'mobilephone' => $mobilephone,
  53. 'industry' => $industry,
  54. 'role' => $role,
  55. 'city' => $city,
  56. 'state' => $state,
  57. 'postcode' => $postcode,
  58. 'country' => $country,
  59. 'password' => $password,
  60. ]);
  61. if ($result['success']) {
  62. sendWelcomeEmail($email, $fullname);
  63. // Auto-login after registration
  64. loginUser($email, $password);
  65. header('Location: /dashboard/dashboard.php?registered=1');
  66. exit;
  67. } else {
  68. $errors['email'] = $result['error'];
  69. }
  70. }
  71. }
  72. }
  73. $pageTitle = 'Create an Account';
  74. include __DIR__ . '/_head.php';
  75. // Helper: old value for text inputs
  76. $v = fn(string $key) => htmlspecialchars($old[$key] ?? '', ENT_QUOTES, 'UTF-8');
  77. // Helper: re-select dropdown option
  78. $sel = fn(string $key, string $val) => (($old[$key] ?? '') === $val) ? 'selected' : '';
  79. ?>
  80. <div class="container">
  81. <div class="card o-hidden border-0 shadow-lg my-5">
  82. <div class="card-body p-0">
  83. <div class="row">
  84. <div class="col-lg-5 d-none d-lg-block bg-register-image"></div>
  85. <div class="col-lg-7">
  86. <div class="p-5">
  87. <div class="text-center mb-4">
  88. <h1 class="h4 text-gray-900">Create an Account</h1>
  89. </div>
  90. <?php if (!empty($errors['general'])): ?>
  91. <div class="alert alert-danger"><?= htmlspecialchars($errors['general'], ENT_QUOTES, 'UTF-8') ?></div>
  92. <?php endif; ?>
  93. <form method="POST" action="/login/register.php" novalidate>
  94. <input type="hidden" name="csrf_token" value="<?= generateCsrfToken() ?>">
  95. <!-- Name + Company -->
  96. <div class="row mb-3">
  97. <div class="col-md-6 mb-2 mb-md-0">
  98. <input type="text" name="fullname" class="form-control form-control-user <?= isset($errors['fullname']) ? 'is-invalid' : '' ?>"
  99. placeholder="Full Name *" value="<?= $v('fullname') ?>" required>
  100. <?php if (isset($errors['fullname'])): ?>
  101. <span class="error"><?= htmlspecialchars($errors['fullname'], ENT_QUOTES, 'UTF-8') ?></span>
  102. <?php endif; ?>
  103. </div>
  104. <div class="col-md-6">
  105. <input type="text" name="company" class="form-control form-control-user"
  106. placeholder="Company Name" value="<?= $v('company') ?>">
  107. </div>
  108. </div>
  109. <!-- Email -->
  110. <div class="mb-3">
  111. <input type="email" name="email" class="form-control form-control-user <?= isset($errors['email']) ? 'is-invalid' : '' ?>"
  112. placeholder="Email Address *" value="<?= $v('email') ?>" required>
  113. <?php if (isset($errors['email'])): ?>
  114. <span class="error"><?= htmlspecialchars($errors['email'], ENT_QUOTES, 'UTF-8') ?></span>
  115. <?php endif; ?>
  116. </div>
  117. <!-- Mobile -->
  118. <div class="mb-3">
  119. <input type="tel" name="mobilephone" class="form-control form-control-user <?= isset($errors['mobilephone']) ? 'is-invalid' : '' ?>"
  120. placeholder="Mobile Phone *" value="<?= $v('mobilephone') ?>">
  121. <?php if (isset($errors['mobilephone'])): ?>
  122. <span class="error"><?= htmlspecialchars($errors['mobilephone'], ENT_QUOTES, 'UTF-8') ?></span>
  123. <?php endif; ?>
  124. </div>
  125. <!-- Industry + Role -->
  126. <div class="row mb-3">
  127. <div class="col-md-6 mb-2 mb-md-0">
  128. <select name="industry" class="form-control form-control-user <?= isset($errors['industry']) ? 'is-invalid' : '' ?>">
  129. <option value="">Choose your industry *</option>
  130. <option value="Broadacre" <?= $sel('industry','Broadacre') ?>>Broadacre</option>
  131. <option value="Viticulture" <?= $sel('industry','Viticulture') ?>>Viticulture</option>
  132. <option value="Horticulture" <?= $sel('industry','Horticulture') ?>>Horticulture</option>
  133. <option value="Permaculture" <?= $sel('industry','Permaculture') ?>>Permaculture</option>
  134. <option value="Dairy" <?= $sel('industry','Dairy') ?>>Dairy</option>
  135. </select>
  136. <?php if (isset($errors['industry'])): ?>
  137. <span class="error"><?= htmlspecialchars($errors['industry'], ENT_QUOTES, 'UTF-8') ?></span>
  138. <?php endif; ?>
  139. </div>
  140. <div class="col-md-6">
  141. <select name="role" class="form-control form-control-user <?= isset($errors['role']) ? 'is-invalid' : '' ?>">
  142. <option value="">Choose your role *</option>
  143. <option value="Manager" <?= $sel('role','Manager') ?>>Manager</option>
  144. <option value="Viticulturist" <?= $sel('role','Viticulturist') ?>>Viticulturist</option>
  145. <option value="Horticulturist" <?= $sel('role','Horticulturist') ?>>Horticulturist</option>
  146. <option value="Permaculturist" <?= $sel('role','Permaculturist') ?>>Permaculturist</option>
  147. <option value="Irrigation Manager" <?= $sel('role','Irrigation Manager') ?>>Irrigation Manager</option>
  148. </select>
  149. <?php if (isset($errors['role'])): ?>
  150. <span class="error"><?= htmlspecialchars($errors['role'], ENT_QUOTES, 'UTF-8') ?></span>
  151. <?php endif; ?>
  152. </div>
  153. </div>
  154. <!-- City + State -->
  155. <div class="row mb-3">
  156. <div class="col-md-6 mb-2 mb-md-0">
  157. <input type="text" name="city" class="form-control form-control-user"
  158. placeholder="City" value="<?= $v('city') ?>">
  159. </div>
  160. <div class="col-md-6">
  161. <select name="state" class="form-control form-control-user <?= isset($errors['state']) ? 'is-invalid' : '' ?>">
  162. <option value="">State *</option>
  163. <option value="New South Wales" <?= $sel('state','New South Wales') ?>>New South Wales</option>
  164. <option value="Victoria" <?= $sel('state','Victoria') ?>>Victoria</option>
  165. <option value="Queensland" <?= $sel('state','Queensland') ?>>Queensland</option>
  166. <option value="Western Australia" <?= $sel('state','Western Australia') ?>>Western Australia</option>
  167. <option value="South Australia" <?= $sel('state','South Australia') ?>>South Australia</option>
  168. <option value="Tasmania" <?= $sel('state','Tasmania') ?>>Tasmania</option>
  169. <option value="Australian Capital Territory" <?= $sel('state','Australian Capital Territory') ?>>ACT</option>
  170. <option value="Northern Territory" <?= $sel('state','Northern Territory') ?>>Northern Territory</option>
  171. <option value="Other" <?= $sel('state','Other') ?>>Other</option>
  172. </select>
  173. <?php if (isset($errors['state'])): ?>
  174. <span class="error"><?= htmlspecialchars($errors['state'], ENT_QUOTES, 'UTF-8') ?></span>
  175. <?php endif; ?>
  176. </div>
  177. </div>
  178. <!-- Postcode + Country -->
  179. <div class="row mb-3">
  180. <div class="col-md-6 mb-2 mb-md-0">
  181. <input type="text" name="postcode" class="form-control form-control-user"
  182. placeholder="Post Code" value="<?= $v('postcode') ?>">
  183. </div>
  184. <div class="col-md-6">
  185. <select name="country" class="form-control form-control-user">
  186. <option value="Australia" <?= $sel('country','Australia') ?>>Australia</option>
  187. <option value="New Zealand" <?= $sel('country','New Zealand') ?>>New Zealand</option>
  188. </select>
  189. </div>
  190. </div>
  191. <!-- Password -->
  192. <div class="row mb-3">
  193. <div class="col-md-6 mb-2 mb-md-0">
  194. <input type="password" name="password" class="form-control form-control-user <?= isset($errors['password']) ? 'is-invalid' : '' ?>"
  195. placeholder="Password * (min 8 chars)" required>
  196. <?php if (isset($errors['password'])): ?>
  197. <span class="error"><?= htmlspecialchars($errors['password'], ENT_QUOTES, 'UTF-8') ?></span>
  198. <?php endif; ?>
  199. </div>
  200. <div class="col-md-6">
  201. <input type="password" name="password_confirm" class="form-control form-control-user <?= isset($errors['password_confirm']) ? 'is-invalid' : '' ?>"
  202. placeholder="Repeat Password *" required>
  203. <?php if (isset($errors['password_confirm'])): ?>
  204. <span class="error"><?= htmlspecialchars($errors['password_confirm'], ENT_QUOTES, 'UTF-8') ?></span>
  205. <?php endif; ?>
  206. </div>
  207. </div>
  208. <button type="submit" class="btn btn-success btn-user w-100 mb-3">
  209. Register Account
  210. </button>
  211. </form>
  212. <hr>
  213. <div class="text-center">
  214. <a class="small" href="/login/forgot-password.php">Forgot Password?</a>
  215. </div>
  216. <div class="text-center">
  217. <a class="small" href="/login/login.php">Already have an account? Login!</a>
  218. </div>
  219. </div>
  220. </div>
  221. </div>
  222. </div>
  223. </div>
  224. </div>
  225. <?php include __DIR__ . '/_foot.php'; ?>