HEX
Server: Apache/2.4.52 (Ubuntu)
System: Linux aritmodecarnaval.es 5.15.0-79-generic #86-Ubuntu SMP Mon Jul 10 16:07:21 UTC 2023 x86_64
User: www-data (33)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /home/www/torresncgolf/wp-content/plugins/wp-migrate-db/class/Common/BackupExport.php
<?php

namespace DeliciousBrains\WPMDB\Common;

use DeliciousBrains\WPMDB\Common\Filesystem\Filesystem;
use DeliciousBrains\WPMDB\Common\FormData\FormData;
use DeliciousBrains\WPMDB\Common\Http\Http;
use DeliciousBrains\WPMDB\Common\MigrationPersistence\Persistence;
use DeliciousBrains\WPMDB\Common\MigrationState\MigrationStateManager;
use DeliciousBrains\WPMDB\Common\Properties\Properties;
use DeliciousBrains\WPMDB\Common\Settings\Settings;
use DeliciousBrains\WPMDB\Common\Sql\Table;
use DeliciousBrains\WPMDB\Common\Sql\TableHelper;

class BackupExport
{

    /**
     * @var Filesystem
     */
    private $filesystem;
    /**
     * @var TableHelper
     */
    private $table_helper;
    /**
     * @var Http
     */
    private $http;
    /**
     * @var Table
     */
    private $table;
    /**
     * @var FormData
     */
    private $form_data;
    /**
     * @var Properties
     */
    private $props;
    /**
     * @var Settings
     */
    private $settings;
    /**
     * @var MigrationStateManager
     */
    private $migration_state_manager;

    public function __construct(
        Settings $settings,
        Filesystem $filesystem,
        TableHelper $table_helper,
        Http $http,
        FormData $form_data,
        Table $table,
        Properties $properties,
        MigrationStateManager $migration_state_manager
    ) {
        $this->props                   = $properties;
        $this->settings                = $settings->get_settings();
        $this->filesystem              = $filesystem;
        $this->table_helper            = $table_helper;
        $this->http                    = $http;
        $this->form_data               = $form_data;
        $this->table                   = $table;
        $this->migration_state_manager = $migration_state_manager;
    }

    public function register()
    {
        add_filter('wpmdb_backup_header_included_tables', array($this, 'backup_header_included_tables'));
    }

    public function delete_export_file($filename, $is_backup)
    {
        $dump_file = $this->table_helper->format_dump_name($filename);

        if (true === $is_backup) {
            $dump_file = preg_replace('/.gz$/', '', $dump_file);
        }

            $dump_file = $this->filesystem->get_upload_info('path') . DIRECTORY_SEPARATOR . $dump_file;

        if (empty($dump_file) || false === $this->filesystem->file_exists($dump_file)) {
            return $this->http->end_ajax(new \WP_Error('wp-migrate-db-export-not-found', __('MySQL export file not found.', 'wp-migrate-db')));
        }

        if (false === $this->filesystem->unlink($dump_file)) {
            return $this->http->end_ajax(new \WP_Error('wp-migrate-db-export-not-found', __('Could not delete the MySQL export file.', 'wp-migrate-db')));
        }

        return null;
    }

    /**
     * Determine which tables to backup (if required).
     *
     * @param $profile
     * @param $prefixed_tables
     * @param $all_tables
     *
     * @return mixed|void
     */
    public function get_tables_to_backup($profile, $prefixed_tables, $all_tables)
    {
        $tables_to_backup = array();

        switch ($profile['backup_option']) {
            case 'backup_only_with_prefix':
                $tables_to_backup = $prefixed_tables;
                break;
            case 'backup_selected':
                $selected_tables = isset($profile['select_backup']) && !empty($profile['select_backup']) ? $profile['select_backup'] : $profile['select_tables'];

                /**
                 * When tables to migrate is tables with prefix, select_tables
                 * might be empty. Intersecting it with remote/local tables
                 * throws notice/warning and won't backup the file either.
                 */
                if ('migrate_only_with_prefix' === $profile['table_migrate_option'] || empty($selected_tables)) {
                    $tables_to_backup = $prefixed_tables;
                } else {
                    $selected_tables  = isset($profile['select_backup']) && !empty($profile['select_backup']) ? $profile['select_backup'] : $profile['select_tables'];
                    $tables_to_backup = array_intersect($selected_tables, $all_tables);
                }
                break;
            case 'backup_manual_select':
                $tables_to_backup = array_intersect($profile['select_backup'], $all_tables);
                break;
        }

        return apply_filters('wpmdb_tables_to_backup', $tables_to_backup, $profile);
    }

    /**
     * Updates the database backup header with the tables that were backed up.
     *
     * @param $included_tables
     *
     * @return mixed|void
     */
    public function backup_header_included_tables($included_tables)
    {
        $state_data = $this->migration_state_manager->set_post_data();
        $form_data  = $this->form_data->getFormData();

        if ('backup' === $state_data['stage']) {
            $included_tables = $this->get_tables_to_backup($form_data, $this->table->get_tables('prefix'), $this->table->get_tables());
        }

        return $included_tables;
    }

    public function setup_backups()
    {
        $dump_filename = wp_basename($this->table->get_sql_dump_info('backup', 'path'));
        $dump_filename = substr($dump_filename, 0, -4);

        return [
            $dump_filename,
            $this->table->get_sql_dump_info('backup', 'url'),
        ];
    }

}