-
Notifications
You must be signed in to change notification settings - Fork 1
/
wachtwoord-vergeten.php
64 lines (47 loc) · 1.87 KB
/
wachtwoord-vergeten.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
<?php
require_once("business/accountService.php");
require_once("business/encryptionService.php");
require_once("business/validationService.php");
require_once("business/mailService.php");
$mail = (filter_input(INPUT_POST, 'mail') !== null ? filter_input(INPUT_POST, 'mail') : '');
$errors = [];
$successMsg = '';
if ($_POST) {
// Validate the fields
$validation = new ValidationService();
$mailErrors = $validation->checkRequiredAndMaxLength($mail, 255);
if ($mailErrors === '') {
$mailErrors = $validation->checkEmail($mail);
}
if ($mailErrors === '') {
$accountSvc = new AccountService();
$account = $accountSvc->getByEmail($mail);
if ($account === null) {
$mailErrors = "Onbekend e-mailadres.";
}
}
if ($mailErrors !== '') {
$errors['mail'] = $mailErrors;
}
if (empty($errors)) {
// Get the encryption key
$encryptionSvc = new EncryptionService();
$code = $encryptionSvc->encryptString(
$mail,
$encryptionSvc::FORGOTTEN_PASSWORD_KEY
);
// Generate the message
$currentPath = $accountSvc->getCurrentPath();
$link = $currentPath . "wachtwoord-resetten.php?code=" . $code;
$msg = "<p>Beste, <br><br>
Klik op de onderstaande link om je wachtwoord te resetten:<br>
<a href=\"" . $link . "\">Reset je wachtwoord</a><br><br>
Met vriendelijke groeten,<br>
VDAB</p>";
// Send the mail
$mailSvc = new MailService();
$mailSvc->sendHtmlMail($mail, "Wachtwoord vergeten", $msg);
$successMsg = "We hebben je een mail gestuurd met een link om je wachtwoord te resetten.";
}
}
include("presentation/wachtwoord-vergeten.php");