123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247 |
- <?php
- if ( ! defined( 'ABSPATH' ) ) {
- exit; // Exit if accessed directly
- }
- if ( ! class_exists( 'ACF_Admin_Updates' ) ) :
- class ACF_Admin_Updates {
- /** @var array Data used in the view. */
- var $view = array();
- /**
- * __construct
- *
- * Sets up the class functionality.
- *
- * @date 23/06/12
- * @since 5.0.0
- *
- * @param void
- * @return void
- */
- function __construct() {
- // Add actions.
- add_action( 'admin_menu', array( $this, 'admin_menu' ), 20 );
- }
- /**
- * display_wp_error
- *
- * Adds an admin notice using the provided WP_Error.
- *
- * @date 14/1/19
- * @since 5.7.10
- *
- * @param WP_Error $wp_error The error to display.
- * @return void
- */
- function display_wp_error( $wp_error ) {
- // Only show one error on page.
- if ( acf_has_done( 'display_wp_error' ) ) {
- return;
- }
- // Create new notice.
- acf_new_admin_notice(
- array(
- 'text' => __( '<b>Error</b>. Could not connect to update server', 'acf' ) . ' <span class="description">(' . esc_html( $wp_error->get_error_message() ) . ').</span>',
- 'type' => 'error',
- )
- );
- }
- /**
- * get_changelog_changes
- *
- * Finds the specific changes for a given version from the provided changelog snippet.
- *
- * @date 14/1/19
- * @since 5.7.10
- *
- * @param string $changelog The changelog text.
- * @param string $version The version to find.
- * @return string
- */
- function get_changelog_changes( $changelog = '', $version = '' ) {
- // Explode changelog into sections.
- $bits = array_filter( explode( '<h4>', $changelog ) );
- // Loop over each version chunk.
- foreach ( $bits as $bit ) {
- // Find the version number for this chunk.
- $bit = explode( '</h4>', $bit );
- $bit_version = trim( $bit[0] );
- $bit_text = trim( $bit[1] );
- // Compare the chunk version number against param and return HTML.
- if ( acf_version_compare( $bit_version, '==', $version ) ) {
- return '<h4>' . esc_html( $bit_version ) . '</h4>' . acf_esc_html( $bit_text );
- }
- }
- // Return.
- return '';
- }
- /**
- * admin_menu
- *
- * Adds the admin menu subpage.
- *
- * @date 28/09/13
- * @since 5.0.0
- *
- * @param void
- * @return void
- */
- function admin_menu() {
- // Bail early if no show_admin.
- if ( ! acf_get_setting( 'show_admin' ) ) {
- return;
- }
- // Bail early if no show_updates.
- if ( ! acf_get_setting( 'show_updates' ) ) {
- return;
- }
- // Bail early if not a plugin (included in theme).
- if ( ! acf_is_plugin_active() ) {
- return;
- }
- // Add submenu.
- $page = add_submenu_page( 'edit.php?post_type=acf-field-group', __( 'Updates', 'acf' ), __( 'Updates', 'acf' ), acf_get_setting( 'capability' ), 'acf-settings-updates', array( $this, 'html' ) );
- // Add actions to page.
- add_action( "load-$page", array( $this, 'load' ) );
- }
- /**
- * load
- *
- * Runs when loading the submenu page.
- *
- * @date 7/01/2014
- * @since 5.0.0
- *
- * @param void
- * @return void
- */
- function load() {
- // Check activate.
- if ( acf_verify_nonce( 'activate_pro_license' ) ) {
- acf_pro_activate_license( sanitize_text_field( $_POST['acf_pro_license'] ) );
- // Check deactivate.
- } elseif ( acf_verify_nonce( 'deactivate_pro_license' ) ) {
- acf_pro_deactivate_license();
- }
- // vars
- $license = acf_pro_get_license_key();
- $this->view = array(
- 'license' => $license,
- 'active' => $license ? 1 : 0,
- 'current_version' => acf_get_setting( 'version' ),
- 'remote_version' => '',
- 'update_available' => false,
- 'changelog' => '',
- 'upgrade_notice' => '',
- 'is_defined_license' => defined( 'ACF_PRO_LICENSE' ) && ! empty( ACF_PRO_LICENSE ) && is_string( ACF_PRO_LICENSE ),
- 'license_error' => false,
- );
- // get plugin updates
- $force_check = ! empty( $_GET['force-check'] );
- $info = acf_updates()->get_plugin_info( 'pro', $force_check );
- // Display error.
- if ( is_wp_error( $info ) ) {
- return $this->display_wp_error( $info );
- }
- // add info to view
- $this->view['remote_version'] = $info['version'];
- // add changelog if the remote version is '>' than the current version
- $version = acf_get_setting( 'version' );
- // check if remote version is higher than current version
- if ( version_compare( $info['version'], $version, '>' ) ) {
- // update view
- $this->view['update_available'] = true;
- $this->view['changelog'] = $this->get_changelog_changes( $info['changelog'], $info['version'] );
- $this->view['upgrade_notice'] = $this->get_changelog_changes( $info['upgrade_notice'], $info['version'] );
- // perform update checks if license is active
- $basename = acf_get_setting( 'basename' );
- $update = acf_updates()->get_plugin_update( $basename );
- if ( $license ) {
- if ( isset( $update['license_valid'] ) && ! $update['license_valid'] ) {
- $this->view['license_error'] = true;
- acf_new_admin_notice(
- array(
- 'text' => __( '<b>Error</b>. Your license for this site has expired or been deactivated. Please reactivate your ACF PRO license.', 'acf' ),
- 'type' => 'error',
- )
- );
- } else {
- // display error if no package url
- // - possible if license key has been modified
- if ( $update && ! $update['package'] ) {
- $this->view['license_error'] = true;
- acf_new_admin_notice(
- array(
- 'text' => __( '<b>Error</b>. Could not authenticate update package. Please check again or deactivate and reactivate your ACF PRO license.', 'acf' ),
- 'type' => 'error',
- )
- );
- }
- }
- // refresh transient
- // - if no update exists in the transient
- // - or if the transient 'new_version' is stale
- if ( ! $update || $update['new_version'] !== $info['version'] ) {
- acf_updates()->refresh_plugins_transient();
- }
- }
- }
- }
- /**
- * html
- *
- * Displays the submenu page's HTML.
- *
- * @date 7/01/2014
- * @since 5.0.0
- *
- * @param void
- * @return void
- */
- function html() {
- acf_get_view( dirname( __FILE__ ) . '/views/html-settings-updates.php', $this->view );
- }
- }
- // Initialize.
- acf_new_instance( 'ACF_Admin_Updates' );
- endif; // class_exists check
|