You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							67 lines
						
					
					
						
							1.7 KiB
						
					
					
				
			
		
		
	
	
							67 lines
						
					
					
						
							1.7 KiB
						
					
					
				| <?php | |
| 
 | |
| declare(strict_types=1); | |
| 
 | |
| namespace PhpMyAdmin\Controllers\Database\Structure; | |
| 
 | |
| use PhpMyAdmin\Controllers\Database\AbstractController; | |
| use PhpMyAdmin\Controllers\Database\StructureController; | |
| use PhpMyAdmin\Message; | |
| use PhpMyAdmin\ResponseRenderer; | |
| use PhpMyAdmin\Table; | |
| use PhpMyAdmin\Template; | |
| 
 | |
| use function count; | |
| use function mb_strlen; | |
| use function mb_substr; | |
| 
 | |
| final class CopyTableWithPrefixController extends AbstractController | |
| { | |
|     /** @var StructureController */ | |
|     private $structureController; | |
| 
 | |
|     public function __construct( | |
|         ResponseRenderer $response, | |
|         Template $template, | |
|         string $db, | |
|         StructureController $structureController | |
|     ) { | |
|         parent::__construct($response, $template, $db); | |
|         $this->structureController = $structureController; | |
|     } | |
| 
 | |
|     public function __invoke(): void | |
|     { | |
|         global $db, $message; | |
| 
 | |
|         $selected = $_POST['selected'] ?? []; | |
|         $fromPrefix = $_POST['from_prefix'] ?? null; | |
|         $toPrefix = $_POST['to_prefix'] ?? null; | |
| 
 | |
|         $selectedCount = count($selected); | |
| 
 | |
|         for ($i = 0; $i < $selectedCount; $i++) { | |
|             $current = $selected[$i]; | |
|             $newTableName = $toPrefix . mb_substr($current, mb_strlen((string) $fromPrefix)); | |
| 
 | |
|             Table::moveCopy( | |
|                 $db, | |
|                 $current, | |
|                 $db, | |
|                 $newTableName, | |
|                 'data', | |
|                 false, | |
|                 'one_table', | |
|                 isset($_POST['drop_if_exists']) && $_POST['drop_if_exists'] === 'true' | |
|             ); | |
|         } | |
| 
 | |
|         $message = Message::success(); | |
| 
 | |
|         if (empty($_POST['message'])) { | |
|             $_POST['message'] = $message; | |
|         } | |
| 
 | |
|         ($this->structureController)(); | |
|     } | |
| }
 | |
| 
 |