|
20 | 20 |
|
21 | 21 | include('authenticate.php');
|
22 | 22 |
|
23 |
| -if ($_SERVER['REQUEST_METHOD'] !== 'POST') { |
24 |
| - $response = new Response(); |
25 |
| - $response->setHttpStatusCode(405); |
26 |
| - $response->setSuccess(false); |
27 |
| - $response->addMessage('Server request method not allowed.'); |
28 |
| - $response->send(); |
29 |
| - exit(); |
30 |
| -} |
| 23 | +try { |
31 | 24 |
|
32 |
| -if ($_SERVER['CONTENT_TYPE'] !== 'application/json') { |
33 |
| - $response = new Response(); |
34 |
| - $response->setHttpStatusCode(400); |
35 |
| - $response->setSuccess(false); |
36 |
| - $response->addMessage("Error: content type header not set to JSON."); |
37 |
| - $response->send(); |
38 |
| - exit(); |
39 |
| -} |
| 25 | + if ($_SERVER['REQUEST_METHOD'] === 'POST' && array_key_exists('l', $_GET)) { //ENTRY |
40 | 26 |
|
41 |
| -$raw_post_data = file_get_contents('php://input'); |
| 27 | + if ($_SERVER['CONTENT_TYPE'] !== 'application/json') { |
| 28 | + $response = new Response(); |
| 29 | + $response->setHttpStatusCode(400); |
| 30 | + $response->setSuccess(false); |
| 31 | + $response->addMessage("Error: content type header not set to JSON."); |
| 32 | + $response->send(); |
| 33 | + exit(); |
| 34 | + } |
42 | 35 |
|
43 |
| -if (!$json_data = json_decode($raw_post_data)) { |
44 |
| - $response = new Response(); |
45 |
| - $response->setHttpStatusCode(400); |
46 |
| - $response->setSuccess(false); |
47 |
| - $response->addMessage("Error: request body is not valid JSON."); |
48 |
| - $response->send(); |
49 |
| - exit(); |
50 |
| -} |
| 36 | + $raw_post_data = file_get_contents('php://input'); |
51 | 37 |
|
52 |
| -if (!isset($jsonData->name, $jsonData->phone)) { |
53 |
| - $response = new Response(); |
54 |
| - $response->setHttpStatusCode(400); |
55 |
| - $response->setSuccess(false); |
56 |
| - (!isset($jsonData->name) ? $response->addMessage("Error: request body does not contain a visitor name.") : false); |
57 |
| - (!isset($jsonData->phone) ? $response->addMessage("Error: request body does not contain a phone number.") : false); |
58 |
| - $response->send(); |
59 |
| - exit(); |
60 |
| -} |
| 38 | + if (!$json_data = json_decode($raw_post_data)) { |
| 39 | + $response = new Response(); |
| 40 | + $response->setHttpStatusCode(400); |
| 41 | + $response->setSuccess(false); |
| 42 | + $response->addMessage("Error: request body is not valid JSON."); |
| 43 | + $response->send(); |
| 44 | + exit(); |
| 45 | + } |
| 46 | + |
| 47 | + if (!isset($json_data->name, $json_data->phone)) { |
| 48 | + $response = new Response(); |
| 49 | + $response->setHttpStatusCode(400); |
| 50 | + $response->setSuccess(false); |
| 51 | + (!isset($json_data->name) ? $response->addMessage("Error: request body does not contain a visitor name.") : false); |
| 52 | + (!isset($json_data->phone) ? $response->addMessage("Error: request body does not contain a phone number.") : false); |
| 53 | + $response->send(); |
| 54 | + exit(); |
| 55 | + } |
61 | 56 |
|
62 |
| -try { |
| 57 | + $visitor = new Visitor(); |
| 58 | + $visitor->setName(trim($json_data->name)); |
| 59 | + $visitor->setPhoneNumber(trim($json_data->phone)); |
63 | 60 |
|
64 |
| - $visitor = new Visitor(); |
65 |
| - $visitor->setName(trim($json_data->name)); |
66 |
| - $visitor->setPhoneNumber(trim($json_data->phone)); |
| 61 | + $query_name = $visitor->getName(); |
| 62 | + $query_phone = $visitor->getPhoneNumber(); |
| 63 | + $query_account_id = intval($_GET['l']); |
| 64 | + $query = $writeDB->prepare("INSERT INTO `contacts`(`account_id`,`name`, `phone`) VALUES (:a, :n, :p)"); |
| 65 | + $query->bindParam(':a', $query_account_id, PDO::PARAM_INT); |
| 66 | + $query->bindParam(':n', $query_name, PDO::PARAM_STR); |
| 67 | + $query->bindParam(':p', $query_phone, PDO::PARAM_STR); |
| 68 | + $query->execute(); |
67 | 69 |
|
68 |
| - $query_name = $visitor->getName(); |
69 |
| - $query_phone = $visitor->getPhoneNumber(); |
70 |
| - $query_arr = new DateTime(); |
71 |
| - $query = $writeDB->prepare("INSERT INTO `contacts`(`name`, `phone`) VALUES (:n, :p)"); |
72 |
| - $query->bindParam(':n', $query_name, PDO::PARAM_STR); |
73 |
| - $query->bindParam(':p', $query_phone, PDO::PARAM_STR); |
74 |
| - $query->execute(); |
| 70 | + $row_count = $query->rowCount(); |
| 71 | + if ($rowCount === 0) { |
| 72 | + $response = new Response(); |
| 73 | + $response->setHttpStatusCode(409); |
| 74 | + $response->setSuccess(false); |
| 75 | + $response->addMessage("Error: New arrival not added."); |
| 76 | + $response->send(); |
| 77 | + exit(); |
| 78 | + } |
75 | 79 |
|
76 |
| - $row_count = $query->rowCount(); |
77 |
| - if ($rowCount === 0) { |
78 | 80 | $response = new Response();
|
79 |
| - $response->setHttpStatusCode(409); |
| 81 | + $response->setHttpStatusCode(201); |
| 82 | + $response->setSuccess(true); |
| 83 | + $response->addMessage("Visitor successfully checked in."); |
| 84 | + $response->send(); |
| 85 | + exit(); |
| 86 | + |
| 87 | + } elseif ($_SERVER['REQUEST_METHOD'] === 'PATCH' && array_key_exists('v', $_GET)) { //EXIT |
| 88 | + |
| 89 | + $query_id = intval($_GET['v']); |
| 90 | + $query = $writeDB->prepare("SELECT * FROM `contacts` WHERE id=:id"); |
| 91 | + $query->bindParam(':id', $query_id, PDO::PARAM_INT); |
| 92 | + $query->execute(); |
| 93 | + |
| 94 | + $row_count = $query->rowCount(); |
| 95 | + if ($rowCount === 0) { |
| 96 | + $response = new Response(); |
| 97 | + $response->setHttpStatusCode(409); |
| 98 | + $response->setSuccess(false); |
| 99 | + $response->addMessage("Error: Arrival entry not found."); |
| 100 | + $response->send(); |
| 101 | + exit(); |
| 102 | + } |
| 103 | + |
| 104 | + $query = $writeDB->prepare("UPDATE `contacts` SET `dep`=CURRENT_TIMESTAMP() WHERE id=:id"); |
| 105 | + $query->bindParam(':id', $query_id, PDO::PARAM_INT); |
| 106 | + $query->execute(); |
| 107 | + |
| 108 | + $row_count = $query->rowCount(); |
| 109 | + if ($rowCount === 0) { |
| 110 | + $response = new Response(); |
| 111 | + $response->setHttpStatusCode(409); |
| 112 | + $response->setSuccess(false); |
| 113 | + $response->addMessage("Error: New arrival not added."); |
| 114 | + $response->send(); |
| 115 | + exit(); |
| 116 | + } |
| 117 | + |
| 118 | + $response = new Response(); |
| 119 | + $response->setHttpStatusCode(201); |
| 120 | + $response->setSuccess(true); |
| 121 | + $response->addMessage("Visitor successfully checked out."); |
| 122 | + $response->send(); |
| 123 | + exit(); |
| 124 | + |
| 125 | + } else { |
| 126 | + $response = new Response(); |
| 127 | + $response->setHttpStatusCode(405); |
80 | 128 | $response->setSuccess(false);
|
81 |
| - $response->addMessage("Error: New arrival not added."); |
| 129 | + $response->addMessage('Server request method not allowed.'); |
82 | 130 | $response->send();
|
83 | 131 | exit();
|
84 | 132 | }
|
85 | 133 |
|
86 |
| - $response = new Response(); |
87 |
| - $response->setHttpStatusCode(201); |
88 |
| - $response->setSuccess(true); |
89 |
| - $response->addMessage("Visitor successfully checked in."); |
90 |
| - $response->send(); |
91 |
| - exit(); |
92 |
| - |
93 | 134 | } catch (PDOException $e) {
|
94 | 135 | error_log("Exception: " . $e->getMessage());
|
95 | 136 | $response = new Response();
|
|
0 commit comments