![]() Server : Apache/2 System : Linux server-15-235-50-60 5.15.0-164-generic #174-Ubuntu SMP Fri Nov 14 20:25:16 UTC 2025 x86_64 User : gositeme ( 1004) PHP Version : 8.2.29 Disable Function : exec,system,passthru,shell_exec,proc_close,proc_open,dl,popen,show_source,posix_kill,posix_mkfifo,posix_getpwuid,posix_setpgid,posix_setsid,posix_setuid,posix_setgid,posix_seteuid,posix_setegid,posix_uname Directory : /home/gositeme/.cursor-server/data/User/History/39433f7/ |
<?php
session_start();
header('Content-Type: application/json');
// Check if user is logged in
if (!isset($_SESSION['user_id'])) {
http_response_code(401);
echo json_encode(['error' => 'Not authenticated']);
exit;
}
require_once '../config/database.php';
// Check if file was uploaded
if (!isset($_FILES['profile_image']) || $_FILES['profile_image']['error'] !== UPLOAD_ERR_OK) {
http_response_code(400);
echo json_encode(['error' => 'No image uploaded or upload error']);
exit;
}
$file = $_FILES['profile_image'];
$user_id = $_SESSION['user_id'];
// Validate file type
$allowed_types = ['image/jpeg', 'image/jpg', 'image/png', 'image/gif'];
$file_info = finfo_open(FILEINFO_MIME_TYPE);
$mime_type = finfo_file($file_info, $file['tmp_name']);
finfo_close($file_info);
if (!in_array($mime_type, $allowed_types)) {
http_response_code(400);
echo json_encode(['error' => 'Invalid file type. Only JPG, PNG, and GIF are allowed.']);
exit;
}
// Validate file size (max 5MB)
if ($file['size'] > 5 * 1024 * 1024) {
http_response_code(400);
echo json_encode(['error' => 'File too large. Maximum size is 5MB.']);
exit;
}
// Create uploads directory if it doesn't exist
$upload_dir = '../uploads/profile_images/';
if (!is_dir($upload_dir)) {
mkdir($upload_dir, 0755, true);
}
// Generate unique filename
$file_extension = pathinfo($file['name'], PATHINFO_EXTENSION);
$filename = 'profile_' . $user_id . '_' . time() . '.' . $file_extension;
$filepath = $upload_dir . $filename;
// Move uploaded file
if (!move_uploaded_file($file['tmp_name'], $filepath)) {
http_response_code(500);
echo json_encode(['error' => 'Failed to save image']);
exit;
}
// Create different sizes for the image
$image_url = '/uploads/profile_images/' . $filename;
try {
$pdo = getDBConnection();
// Update user profile with new image
$stmt = $pdo->prepare("
INSERT INTO user_profiles (user_id, profile_image)
VALUES (?, ?)
ON DUPLICATE KEY UPDATE profile_image = ?
");
$stmt->execute([$user_id, $image_url, $image_url]);
echo json_encode([
'success' => true,
'message' => 'Profile image uploaded successfully',
'image_url' => $image_url
]);
} catch (Exception $e) {
error_log("Profile image upload error: " . $e->getMessage());
http_response_code(500);
echo json_encode(['error' => 'Database error occurred']);
// Clean up uploaded file if database update failed
if (file_exists($filepath)) {
unlink($filepath);
}
}
?>