правильный путь $filesToMove = [ 'crm2/CRM_Active_Files/Documents/394094/doc_394094_d583b5d6.pdf' => 'crm2/CRM_Active_Files/Documents/Project/Згурский_ООО_РЕНТСОФТ_394091/Договор_394094.pdf', 'crm2/CRM_Active_Files/Documents/394096/doc_394096_ce9e6bdc.pdf' => 'crm2/CRM_Active_Files/Documents/Project/Згурский_ООО_РЕНТСОФТ_394091/Подтверждение_оплаты_394096.pdf', 'crm2/CRM_Active_Files/Documents/394100/doc_394100_3f15e3c1.pdf' => 'crm2/CRM_Active_Files/Documents/Project/Згурский_ООО_РЕНТСОФТ_394091/Ответ_на_претензию_394100.pdf', 'crm2/CRM_Active_Files/Documents/394105/potrebitelya_Zgurskiy_1.pdf' => 'crm2/CRM_Active_Files/Documents/Project/Згурский_ООО_РЕНТСОФТ_394091/7_заявление_потребителя_394105.pdf', ]; echo "=== ПЕРЕМЕЩЕНИЕ ФАЙЛОВ ПРОЕКТА 394091 ===\n"; echo str_repeat("=", 80) . "\n\n"; $dryRun = isset($argv[1]) && $argv[1] === '--dry-run'; if ($dryRun) { echo "⚠️ РЕЖИМ ПРОВЕРКИ (dry-run)\n\n"; } try { $s3Client = new \Aws\S3\S3Client([ 'version' => 'latest', 'region' => $config['s3']['region'], 'endpoint' => $config['s3']['endpoint'], 'use_path_style_endpoint' => true, 'credentials' => [ 'key' => $config['s3']['key'], 'secret' => $config['s3']['secret'], ], 'suppress_php_deprecation_warning' => true ]); $stats = [ 'total' => count($filesToMove), 'moved' => 0, 'skipped' => 0, 'failed' => 0, ]; foreach ($filesToMove as $oldPath => $newPath) { $filename = basename($newPath); echo "Файл: {$filename}\n"; echo " От: {$oldPath}\n"; echo " К: {$newPath}\n"; // Проверяем существование старого файла if (!$s3Client->doesObjectExist($s3Bucket, $oldPath)) { echo " ⚠️ Старый файл не найден\n\n"; $stats['skipped']++; continue; } // Проверяем, не существует ли уже новый файл if ($s3Client->doesObjectExist($s3Bucket, $newPath)) { echo " ⚠️ Новый файл уже существует\n\n"; $stats['skipped']++; continue; } if (!$dryRun) { try { // Копируем файл $s3Client->copyObject([ 'Bucket' => $s3Bucket, 'Key' => $newPath, 'CopySource' => "{$s3Bucket}/{$oldPath}", ]); echo " ✅ Скопирован\n"; // Удаляем старый $s3Client->deleteObject([ 'Bucket' => $s3Bucket, 'Key' => $oldPath, ]); echo " ✅ Старый удален\n"; $stats['moved']++; sleep(1); } catch (Exception $e) { echo " ❌ Ошибка: " . $e->getMessage() . "\n"; $stats['failed']++; } } else { echo " ⏸️ Будет перемещен (dry-run)\n"; $stats['moved']++; } echo "\n"; } echo str_repeat("=", 80) . "\n"; echo "ИТОГИ:\n"; echo "Всего: {$stats['total']}\n"; if (!$dryRun) { echo "Перемещено: {$stats['moved']}\n"; echo "Пропущено: {$stats['skipped']}\n"; echo "Ошибок: {$stats['failed']}\n"; } else { echo "Будет перемещено: {$stats['moved']}\n"; } if (!$dryRun && $stats['moved'] > 0) { echo "\n⚠️ ВАЖНО: Обновите БД вручную:\n"; echo "UPDATE vtiger_notes SET s3_key = '...', filename = '...' WHERE notesid = ...;\n"; } echo "\n=== ГОТОВО ===\n"; } catch (Exception $e) { echo "❌ Ошибка: " . $e->getMessage() . "\n"; exit(1); }