source: Admin Actions/AddAuthor.php

main
Last change on this file was 75f74d9, checked in by Vlado 222039 <vlado.popovski@…>, 6 weeks ago

Initial commit: Adding Book Tracker code

  • Property mode set to 100644
File size: 2.5 KB
Line 
1<?php
2error_reporting(E_ALL);
3ini_set('display_errors', 1);
4
5header('Content-Type: application/json');
6
7require '../connect.php';
8
9try {
10 // Start transaction
11 $conn->beginTransaction();
12
13 if ($_SERVER['REQUEST_METHOD'] !== 'POST') {
14 throw new Exception('Invalid request method');
15 }
16
17 $firstName = $_POST['firstName'] ?? '';
18 $lastName = $_POST['lastName'] ?? '';
19 $nationality = $_POST['nationality'] ?? '';
20 $dateOfBirth = $_POST['dateOfBirth'] ?? '';
21 $authorDescription = $_POST['authorDescription'] ?? '';
22
23 if (empty($firstName) || empty($lastName) || empty($nationality) || empty($dateOfBirth)) {
24 throw new Exception('Required fields cannot be empty');
25 }
26
27 // image upload
28 $imageName = null;
29 if (isset($_FILES['authorImage']) && $_FILES['authorImage']['error'] === UPLOAD_ERR_OK) {
30 $uploadDir = '../AuthorImages/';
31 /*
32 if (!file_exists($uploadDir)) {
33 mkdir($uploadDir, 0777, true);
34 }*/
35
36 $fileExtension = strtolower(pathinfo($_FILES['authorImage']['name'], PATHINFO_EXTENSION));
37 $imageName = uniqid() . '_author.' . $fileExtension;
38 $targetPath = $uploadDir . $imageName;
39
40 $allowedTypes = ['jpg', 'jpeg', 'png', 'gif'];
41 if (!in_array($fileExtension, $allowedTypes)) {
42 throw new Exception('Invalid file type. Only JPG, JPEG, PNG, and GIF are allowed.');
43 }
44
45 if (!move_uploaded_file($_FILES['authorImage']['tmp_name'], $targetPath)) {
46 throw new Exception('Failed to upload image');
47 }
48 }
49
50 $sql = "INSERT INTO author (firstname, lastname, nationality, dateofbirth, author_description, author_image)
51 VALUES (:firstname, :lastname, :nationality, :dateofbirth, :author_description, :author_image)";
52
53 $stmt = $conn->prepare($sql);
54 $stmt->execute([
55 ':firstname' => $firstName,
56 ':lastname' => $lastName,
57 ':nationality' => $nationality,
58 ':dateofbirth' => $dateOfBirth,
59 ':author_description' => $authorDescription,
60 ':author_image' => $imageName
61 ]);
62
63 $conn->commit();
64
65 echo json_encode(['success' => true, 'message' => 'Author added successfully']);
66
67} catch (Exception $e) {
68 // Rollback the transaction if it's active
69 if ($conn->inTransaction()) {
70 $conn->rollBack();
71 }
72
73 if (isset($imageName) && file_exists($uploadDir . $imageName)) {
74 unlink($uploadDir . $imageName);
75 }
76
77 echo json_encode(['success' => false, 'message' => $e->getMessage()]);
78}
79
80?>
Note: See TracBrowser for help on using the repository browser.