- Исправлено выпадающее меню профиля (hover-баг с margin-top) - Исправлена авторизация: правильные пути к API (api/auth.php) - Исправлены ссылки на админку (admin/index.php вместо admin_panel.php) - Исправлены пути API корзины в catalog.php и checkout.php - Добавлена форма добавления/редактирования товаров в админке - Исправлены кнопки +/- в корзине (улучшена обработка AJAX) - Исправлена регистрация: правильные пути и обработка boolean в PostgreSQL - Добавлена миграция для назначения прав админа пользователю admin@mail.ru - Удален тестовый блок 'Быстрый вход' для неавторизованных пользователей - Улучшена обработка ошибок во всех API-эндпоинтах
31 lines
1001 B
PHP
31 lines
1001 B
PHP
<?php
|
|
session_start();
|
|
require_once __DIR__ . '/../config/database.php';
|
|
|
|
if (!isset($_SESSION['isLoggedIn']) || $_SESSION['isLoggedIn'] !== true) {
|
|
echo json_encode(['success' => false, 'message' => 'Требуется авторизация']);
|
|
exit();
|
|
}
|
|
|
|
if ($_SERVER['REQUEST_METHOD'] == 'POST' && isset($_POST['product_id'])) {
|
|
$product_id = intval($_POST['product_id']);
|
|
$quantity = intval($_POST['quantity'] ?? 1);
|
|
$user_id = $_SESSION['user_id'] ?? 0;
|
|
|
|
$db = Database::getInstance()->getConnection();
|
|
|
|
try {
|
|
$stmt = $db->prepare("
|
|
UPDATE cart
|
|
SET quantity = ?, updated_at = CURRENT_TIMESTAMP
|
|
WHERE user_id = ? AND product_id = ?
|
|
");
|
|
$stmt->execute([$quantity, $user_id, $product_id]);
|
|
|
|
echo json_encode(['success' => true]);
|
|
|
|
} catch (PDOException $e) {
|
|
echo json_encode(['success' => false, 'message' => 'Ошибка базы данных']);
|
|
}
|
|
}
|
|
?>
|