/** * Main function of the plugin : duplicates a site * @since 0.2.0 * @param array $data parameters from form * @return $form_message result messages of the process */ public static function duplicate_site($data) { global $wpdb; $form_message = array(); $wpdb->hide_errors(); self::init_log($data); $email = $data['email']; $domain = $data['domain']; $newdomain = $data['newdomain']; $path = $data['path']; $title = $data['title']; $from_site_id = $data['from_site_id']; $keep_users = $data['keep_users']; $copy_file = $data['copy_files']; $public = $data['public']; $network_id = $data['network_id']; MUCD_Duplicate::write_log('Start site duplication : from site ' . $from_site_id); MUCD_Duplicate::write_log('Admin email : ' . $email); MUCD_Duplicate::write_log('Domain : ' . $newdomain); MUCD_Duplicate::write_log('Path : ' . $path); MUCD_Duplicate::write_log('Site title : ' . $title); $user_id = MUCD_Duplicate::create_admin($email, $domain); if (is_wp_error($user_id)) { wp_cache_flush(); $form_message['error'] = $user_id->get_error_message(); return $form_message; } // Create new site $to_site_id = wpmu_create_blog($newdomain, $path, $title, $user_id, array('public' => $public), $network_id); $wpdb->show_errors(); if (is_wp_error($to_site_id)) { wp_cache_flush(); $form_message['error'] = $to_site_id->get_error_message(); return $form_message; } // User rights adjustments if (!is_super_admin($user_id) && !get_user_option('primary_blog', $user_id)) { update_user_option($user_id, 'primary_blog', $to_site_id, true); } MUCD_Duplicate::bypass_server_limit(); // Copy Site - File if ($copy_file == 'yes') { do_action('mucd_before_copy_files', $from_site_id, $to_site_id); $result = MUCD_Files::copy_files($from_site_id, $to_site_id); do_action('mucd_after_copy_files', $from_site_id, $to_site_id); } // Copy Site - Data do_action('mucd_before_copy_data', $from_site_id, $to_site_id); $result = MUCD_Data::copy_data($from_site_id, $to_site_id); do_action('mucd_after_copy_data', $from_site_id, $to_site_id); // Copy Site - Users if ($keep_users == 'yes') { do_action('mucd_before_copy_users', $from_site_id, $to_site_id); $result = MUCD_Duplicate::copy_users($from_site_id, $to_site_id); do_action('mucd_after_copy_users', $from_site_id, $to_site_id); } update_blog_option($to_site_id, 'mucd_duplicable', "no"); $form_message['msg'] = MUCD_NETWORK_PAGE_DUPLICATE_NOTICE_CREATED; $form_message['site_id'] = $to_site_id; MUCD_Duplicate::write_log('End site duplication : new site ID = ' . $to_site_id); wp_cache_flush(); return $form_message; }
/** * Stop process on SQL Error, print and log error, removes the new blog * @since 0.2.0 * @param string $sql_query the query * @param string $sql_error the error */ public static function sql_error($sql_query, $sql_error) { $error_1 = 'ERROR SQL ON : ' . $sql_query; MUCD_Duplicate::write_log($error_1); $error_2 = 'WPDB ERROR : ' . $sql_error; MUCD_Duplicate::write_log($error_2); MUCD_Duplicate::write_log('Duplication interrupted on SQL ERROR'); echo '<br />Duplication failed :<br /><br />' . $error_1 . '<br /><br />' . $error_2 . '<br /><br />'; if ($log_url = MUCD_Duplicate::log_url()) { echo '<a href="' . $log_url . '">' . MUCD_NETWORK_PAGE_DUPLICATE_VIEW_LOG . '</a>'; } MUCD_Functions::remove_blog(self::$to_site_id); wp_die(); }
/** * Stop process on Creating dir Error, print and log error, removes the new blog * @since 0.2.0 * @param string $dir_path the path */ public static function mkdir_error($dir_path) { $error_1 = 'ERROR DURING FILE COPY : CANNOT CREATE ' . $dir_path; MUCD_Duplicate::write_log($error_1); $error_2 = sprintf(MUCD_NETWORK_PAGE_DUPLICATE_COPY_FILE_ERROR, MUCD_Functions::get_primary_upload_dir()); MUCD_Duplicate::write_log($error_2); MUCD_Duplicate::write_log('Duplication interrupted on FILE COPY ERROR'); echo '<br />Duplication failed :<br /><br />' . $error_1 . '<br /><br />' . $error_2 . '<br /><br />'; if ($log_url = MUCD_Duplicate::log_url()) { echo '<a href="' . $log_url . '">' . MUCD_NETWORK_PAGE_DUPLICATE_VIEW_LOG . '</a>'; } MUCD_Functions::remove_blog(self::$to_site_id); wp_die(); }