-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathresetPassword.php
More file actions
67 lines (49 loc) · 1.49 KB
/
resetPassword.php
File metadata and controls
67 lines (49 loc) · 1.49 KB
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
65
66
<?php
/**
* Created by PhpStorm.
* User: hanbinpark
* Date: 6/15/18
* Time: 2:01 PM
*/
if(empty($_REQUEST["email"])){
$returnArray["status"] = "400";
$returnArray["message"] = "Missing required information";
echo json_encode($returnArray);
return;
}
$email = htmlentities($_REQUEST["email"]);
$file = parse_ini_file("../../Han.ini");
$host = trim($file["dbhost"]);
$user = trim($file["dbuser"]);
$pass = trim($file["dbpass"]);
$name = trim($file["dbname"]);
require ("secure/access.php");
$access = new access($host, $user, $pass, $name);
$access->connect();
$user = $access->selectUserViaEmail($email);
if(empty($user)){
$returnArray["status"] = "403";
$returnArray["message"] = "Email not found";
echo json_encode($returnArray);
return;
}
require ("secure/email.php");
$email = new email();
$token = $email->generateToken(20);
$access->saveToken("passwordTokens", $user["id"], $token);
$details = array();
$details["subject"] = "Password reset request on hAn";
$details["email"] = $email;
$details["to"] = $user["email"];
$details["fromName"] = "hAn Support";
$details["fromEmail"] = "han.help.contact@gmail.com";
$template = $email->resetPasswordTemplate();
$template = str_replace("{token}", $token, $template);
$details["body"] = $template;
$email->sendEmail($details);
$returnArray["status"] = "200";
$returnArray["email"] = $user["email"];
$returnArray["message"] = "We have sent you email to reset password";
echo json_encode($returnArray);
$access->disconnect();
?>