コード例 #1
0
ファイル: Backup.php プロジェクト: guysyml/software
 public function cron_run($args)
 {
     list($id, $uniqid, $method) = $args;
     $is_verbose = isset($args[3]) ? $args[3] : false;
     $options = get_site_option('my-wp-backup-options', Admin::$options);
     set_time_limit($options['time_limit']);
     $this->maintenance();
     $backup = self::get($id, $uniqid);
     $job = new JobModel($backup, true);
     $job->is_verbose = $is_verbose;
     $job->running($backup['uniqid']);
     $job->log(__('Restoring...', 'my-wp-backup'));
     if ('local' === $method && !$backup->has_archives()) {
         $job->log(__('No local copy of the backup is available.', 'my-wp-backup'));
     }
     try {
         $job->download($method);
         $archive = new Archive($job);
         // Joins the file if backup has been split into smaller files.
         // Uncompresses the file if compressed with bz2 or gz.
         $archive->pre_restore();
         $archive->restore();
         if ($job['volsize'] > 0) {
             unlink(reset($archive->get_archives()));
         }
         $job->log(__('Importing database file...', 'my-wp-backup'));
         $sql = new ExportFile($job);
         $sql->import();
         $sql->delete();
         $job->log(__('Ok.', 'my-wp-backup'));
         $job->finish();
         $job->log(__('Done restoring.', 'my-wp-backup'));
         $job->log(sprintf(__('Finished restoring backup in %.1f seconds.', 'my-wp-backup'), $job->end - $job->start));
     } catch (\Exception $e) {
         error_log($e);
         $job->log($e->getMessage(), 'error');
     }
     $this->maintenance('off');
 }