HEX
Server: Apache
System: Linux cpanelx.inxs.ro 4.18.0-477.27.2.lve.el8.x86_64 #1 SMP Wed Oct 11 12:32:56 UTC 2023 x86_64
User: crowdandsafety (1041)
PHP: 8.1.34
Disabled: exec,passthru,shell_exec,system
Upload Files
File: //proc/self/cwd/wp-content/plugins/cornerstone/includes/classes/Services/Updates.php
<?php

/**
* This is the update handler for Cornerstone Standalone
*
* Pro and X use the following file
* This file is very similar to that
* framework/legacy/functions/admin/class-validation-updates.php
*
*/

namespace Themeco\Cornerstone\Services;

use Themeco\Cornerstone\Util\AdminAjax;

class Updates implements Service {

  protected $plugin_file =  'cornerstone/cornerstone.php';
  protected $api;
  protected $ajaxUpdateCheck;
	protected $themeManagement;

	public function __construct(
		AdminAjax $ajaxUpdateCheck,
		ThemeManagement $themeManagement
	) {
		$this->ajaxUpdateCheck = $ajaxUpdateCheck;
		$this->themeManagement = $themeManagement;
  }

	public function setup() {

		add_action(
			'after_setup_theme',
			[$this, 'afterThemeSetup'],
			1001
		);

	}

	public function afterThemeSetup() {
		// This should only run on standalone mode
		if (!$this->themeManagement->isStandalone()) {
			return;
		}

		$this->ajaxUpdateCheck->setAction( 'update_check' )
			->setHandler( [ $this, 'ajaxUpdateCheckHandler'] )
			->start();

		if ( ! is_admin() ) return;

    add_filter( 'http_request_args', array( $this, 'http_request_args' ), 10, 2 );

		add_filter( 'themeco_update_api', array( $this, 'register' ), -100 );
    add_filter( 'themeco_update_cache', array( $this, 'cache_updates' ), 10, 2 );

		if ( isset( $_GET['force-check'] ) ) {
			delete_site_transient( 'update_plugins' );
		}

		add_action( 'plugins_api', array( $this, 'plugins_api' ), 100, 3 );
		add_filter( 'pre_set_site_transient_update_plugins', array( $this, 'pre_set_site_transient_update_plugins' ) );

		add_action( 'admin_enqueue_scripts', array( $this, 'add_script_data' ), -100 );

	}

	public function add_script_data() {
		cornerstone( 'Admin' )->add_script_data( 'cs-updates', array( $this, 'script_data' ) );
	}

  public function ajaxUpdateCheckHandler() {

  	if ( ! current_user_can( 'update_plugins' ) ) {
      return wp_send_json_error();
    }

    delete_site_transient( 'update_plugins' );
    tco_common()->updates()->refresh();
    $errors = tco_common()->updates()->get_errors();

    if ( empty( $errors ) ) {
      return wp_send_json_success( array(
        'latest' => esc_html( $this->get_latest_version() )
      ) );
    }

    return wp_send_json_error( array( 'errors' => $errors ) );

  }

  public function script_data() {
    return array(
      'complete'    => csi18n('admin.plugin-update-nothing'),
      'completeNew' => csi18n('admin.plugin-update-new'),
      'error'       => csi18n('admin.plugin-update-error'),
      'checking'    => csi18n('admin.plugin-update-checking'),
      'latest'      => esc_html( $this->get_latest_version() )
    );
  }

	public function get_plugin_data( $use_local_defaults = true ) {

		$data = tco_common()->updates()->get_update_cache();

		$cornerstone = ( isset( $data['plugins'] ) && isset( $data['plugins'][ $this->plugin_file ] ) ) ? $data['plugins'][ $this->plugin_file ] : array();
		$defaults = array();

		if ( $use_local_defaults ) {
			$defaults = array(
				'slug' => 'cornerstone',
				'name' => csi18n('common.title.cornerstone'),
				'new_version' => CS_VERSION,
				'author' => '<a href="https://theme.co/cornerstone/">Themeco</a>'
			);
		}

		return wp_parse_args( $cornerstone, $defaults );

	}

	public function get_latest_version() {

		$data = $this->get_plugin_data();
		return $data['new_version'];

  }

	public function plugins_api( $res, $action, $args ) {

		if ( ! isset( $args->slug ) || 'cornerstone' !== $args->slug ) {
			return $res;
		}

		$data = $this->get_plugin_data();

		$result = array(
			'slug'    => $data['slug'],
			'name'    => $data['name'],
			'author'  => $data['author'],
			'version' => $data['new_version'],
			'sections' => array(
				'changelog' => csi18n('admin.plugin-update-changelog')
			)
		);

		if ( 'query_plugins' === $action || 'plugin_information' === $action ) {
			$result = (object) $result;
		}

		return $result;

	}

	public function pre_set_site_transient_update_plugins( $data ) {

		tco_common()->updates()->refresh();
		$remote = $this->get_plugin_data();

		if ( empty( $remote ) ) {
			return $data;
		}

		include_once( ABSPATH . '/wp-admin/includes/plugin.php' );

		$installed_plugins = get_plugins();

		if ( ! isset( $installed_plugins[ $this->plugin_file ] ) ) {
			return $data;
		}

		$local = $installed_plugins[ $this->plugin_file ];

		// Version check
		if ( version_compare( $remote['new_version'], $local['Version'], '>' ) ) {

			if ( ! $remote['package'] ) {
				$remote['upgrade_notice'] = sprintf( csi18n('admin.plugin-update-notice'), admin_url( 'admin.php?page=cornerstone-home' ) );
			}

      // Add logo to WordPress format if found
      if (!empty($remote['logo_url'])) {
        $remote['icons'] = [
          '2x' => $remote['logo_url'],
        ];
      }

			$data->response[ $this->plugin_file ] = (object) $remote;

		}

		return $data;

	}

	public function register( $args ) {

		$args['api-key'] = esc_attr( get_option( 'cs_product_validation_key', '' ) );
		$args['cs-version'] = CS_VERSION;
		$args['php-version'] = PHP_VERSION;
		return $args;

  }

  public function cache_updates( $updates, $data ) {

		if ( !isset( $updates['plugins'] ) ) {
			$updates['plugins'] = array();
		}

    if ( isset( $data['error'] ) ) {
      delete_option( 'cs_product_validation_key' );
      delete_site_transient( 'update_plugins' );
    }

		$plugin_updates = array();

		if ( isset( $data['plugins'] ) && isset( $data['plugins']['cornerstone'] ) ) {
			$plugin = $data['plugins']['cornerstone'];
			$plugin_updates[$plugin['plugin']] = $plugin;
		}

		$updates['plugins'] = array_merge( $updates['plugins'], $plugin_updates );

		return $updates;

  }

	public function decode( $data ) {
		return $this->api->is_serial ? (array) unserialize( $data ) : json_decode( $data, true );
	}

	public function encode( $data ) {
		if ( $this->api->is_serial ) {
			return serialize( $this->api->is_plugin ? (object) $data : $data );
		}
		return json_encode( $data );
	}

	public function http_request_args( $request_args, $url ) {
		$this->api = $this->get_api( $url );
		if ( empty( $this->api ) ) {
			return $request_args;
		}
		$data = $this->decode( $request_args['body'][ $this->api->type ] );
		if ( $this->api->is_plugin ) {
			$data = $this->filter_plugins( $data );
		} elseif ( $this->api->is_theme ) {
			$data = $this->filter_themes( $data );
		}
		$request_args['body'][ $this->api->type ] = $this->encode( $data );
		return $request_args;
	}

	public function get_api( $url ) {
		static $regex = '#://api\.wordpress\.org/(?P<type>plugins|themes)/update-check/(?P<version>[0-9.]+)/#';
		$match = preg_match( $regex, $url, $api );
		if ( $match ) {
			$api['is_serial'] = ( 1.0 == (float) $api['version'] );
			$api['is_plugin'] = ( 'plugins' === $api['type'] );
			$api['is_theme']  = ( 'themes' === $api['type'] );
			return (object) $api;
		}
		return false;
	}

	public function filter_plugins( $data ) {
		foreach ( $data['plugins'] as $file => $plugin ) {
			$path = trailingslashit( WP_PLUGIN_DIR . '/' . dirname( $file ) );
      if ( in_array( $file, array($this->plugin_file), true ) ) {
				unset( $data['plugins'][ $file ] );
				unset( $data['active'][ array_search( $file, $data['active'] ) ] );
			}
		}
		return $data;
	}

	public function filter_themes( $data ) {
		foreach ( $data['themes'] as $slug => $theme ) {
			$path = trailingslashit( wp_get_theme( $slug )->get_stylesheet_directory() );
      if ( in_array( $slug, array('x', 'pro'), true ) ) {
				unset( $data['themes'][ $slug ] );
			}
		}
		return $data;
	}

}