![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/gg.corals.io/wp-content/plugins/custom-facebook-feed/inc/Admin/ |
<?php /** * Upgrade to the Pro version * * @since 4.0 */ namespace CustomFacebookFeed\Admin; use CustomFacebookFeed\Custom_Facebook_Feed; class CFF_Upgrader { /** * URL where licensing is done */ const STORE_URL = 'https://smashballoon.com/'; /** * URL to connect to Smash Balloon App and upgrade to Pro */ const UPGRADE_URL = 'https://connect.smashballoon.com/activate/index.php'; /** * Check the license key URL */ const CHECK_URL = 'https://connect.smashballoon.com/activate/check.php'; const NAME = 'facebook'; const SLUG = 'custom-facebook-feed-pro/custom-facebook-feed.php'; const REDIRECT = 'cff-settings'; const INSTALL_INSTRUCTIONS = 'https://smashballoon.com/doc/installing-and-configuring-the-custom-facebook-feed-wordpress-plugin/'; /** * AJAX hooks for creating the redirect * * @since 4.0 */ public static function hooks() { add_action( 'wp_ajax_nopriv_cff_run_one_click_upgrade', array( 'CustomFacebookFeed\Admin\CFF_Upgrader', 'install_upgrade' ) ); add_action( 'wp_ajax_cff_maybe_upgrade_redirect', array( 'CustomFacebookFeed\Admin\CFF_Upgrader', 'maybe_upgrade_redirect' ) ); } /** * Connect to licensing API to get download URL for Pro version * * @param $license_data * * @return bool|mixed|null * * @since 4.0 */ public static function get_version_info( $license_data ) { $api_params = array( 'edd_action' => 'get_version', 'license' => $license_data['key'], 'item_name' => isset( $license_data['item_name'] ) ? $license_data['item_name'] : false, 'item_id' => isset( $license_data['item_id'] ) ? $license_data['item_id'] : false, 'version' => '0', 'slug' => self::SLUG, 'author' => 'SmashBalloon', 'url' => home_url(), 'beta' => false, ); $api_url = trailingslashit( self::STORE_URL ); $request = wp_remote_post( $api_url, array( 'timeout' => 15, 'sslverify' => true, 'body' => $api_params ) ); if ( ! is_wp_error( $request ) ) { $version_info = json_decode( wp_remote_retrieve_body( $request ) ); return $version_info; } return false; } /** * Ajax handler for grabbing the upgrade url. * * @since 4.0 */ public static function maybe_upgrade_redirect() { $home_url = home_url(); check_ajax_referer( 'cff_admin_nonce' , 'nonce'); $cap = current_user_can( 'manage_custom_facebook_feed_options' ) ? 'manage_custom_facebook_feed_options' : 'manage_options'; $cap = apply_filters( 'cff_settings_pages_capability', $cap ); if ( ! current_user_can( $cap ) ) { wp_send_json_error(); // This auto-dies. } // Check for permissions. if ( ! current_user_can( 'install_plugins' ) ) { wp_send_json_error( array( 'message' => esc_html__( 'You are not allowed to install plugins.', 'custom-facebook-feed' ) ) ); } if ( CFF_Upgrader::is_dev_url( home_url() ) ) { wp_send_json_success( array( 'url' => self::INSTALL_INSTRUCTIONS, ) ); } // Check license key. $license = ! empty( $_POST['license_key'] ) ? sanitize_text_field( $_POST['license_key'] ) : ''; if ( empty( $license ) ) { wp_send_json_error( array( 'message' => esc_html__( 'You are not licensed.', 'custom-facebook-feed' ) ) ); } $args = array( 'plugin_name' => self::NAME, 'plugin_slug' => 'pro', 'plugin_path' => plugin_basename( __FILE__ ), 'plugin_url' => trailingslashit( WP_PLUGIN_URL ) . 'pro', 'home_url' => $home_url, 'version' => '1.0', 'key' => $license, ); $url = add_query_arg( $args, self::CHECK_URL ); $remote_request_args = array( 'timeout' => '20', ); $response = wp_remote_get( $url, $remote_request_args ); if ( ! is_wp_error( $response ) ) { $body = wp_remote_retrieve_body( $response ); $check_key_response = json_decode( $body, true ); if ( empty( $check_key_response['license_data'] ) ) { wp_send_json_error( array( 'message' => esc_html( CFF_Upgrader::get_error_message( $check_key_response ) ), ) ); } if ( ! empty( $check_key_response['license_data']['error'] ) ) { wp_send_json_error( array( 'message' => CFF_Upgrader::get_error_message( $check_key_response ), ) ); } if ( ! empty( $check_key_response['license_data']['error'] ) ) { wp_send_json_error( array( 'message' => CFF_Upgrader::get_error_message( $check_key_response ), ) ); } if ( $check_key_response['license_data']['license'] !== 'valid' ) { wp_send_json_error( array( 'message' => CFF_Upgrader::get_error_message( $check_key_response ), ) ); } $license_data = $check_key_response['license_data']; update_option( 'cff_license_key', $license ); update_option( 'cff_license_data', $license_data ); update_option( 'cff_license_status', $license_data['license'] ); // Redirect. $oth = hash( 'sha512', wp_rand() ); $hashed_oth = hash_hmac( 'sha512', $oth, wp_salt() ); update_option( 'cff_one_click_upgrade', $oth ); $version = '1.0'; $version_info = CFF_Upgrader::get_version_info( $license_data ); $file = ''; if ( isset( $version_info->package ) ) { $file = $version_info->package; } $siteurl = admin_url(); $endpoint = admin_url( 'admin-ajax.php' ); $redirect = admin_url( 'admin.php?page=' . self::REDIRECT ); $url = add_query_arg( array( 'key' => $license, 'oth' => $hashed_oth, 'endpoint' => $endpoint, 'version' => $version, 'siteurl' => $siteurl, 'homeurl' => $home_url, 'redirect' => rawurldecode( base64_encode( $redirect ) ), 'file' => rawurldecode( base64_encode( $file ) ), 'plugin_name' => self::NAME, ), self::UPGRADE_URL ); wp_send_json_success( array( 'url' => $url, ) ); } wp_send_json_error( array( 'message' => esc_html__( 'Could not connect.', 'custom-facebook-feed' ) ) ); } /** * Endpoint for one-click upgrade. * * @since 4.0 */ public static function install_upgrade() { $error = esc_html__( 'Could not install upgrade. Please download from smashballoon.com and install manually.', 'custom-facebook-feed' ); // verify params present (oth & download link). $post_oth = ! empty( $_REQUEST['oth'] ) ? sanitize_text_field( $_REQUEST['oth'] ) : ''; $post_url = ! empty( $_REQUEST['file'] ) ? $_REQUEST['file'] : ''; if ( empty( $post_oth ) || empty( $post_url ) ) { wp_send_json_error( $error ); } // Verify oth. $oth = get_option( 'cff_one_click_upgrade' ); if ( empty( $oth ) ) { wp_send_json_error( $error ); } if ( hash_hmac( 'sha512', $oth, wp_salt() ) !== $post_oth ) { wp_send_json_error( $error ); } // Delete so cannot replay. delete_option( 'cff_one_click_upgrade' ); // Set the current screen to avoid undefined notices. set_current_screen( self::REDIRECT ); // Prepare variables. $url = esc_url_raw( add_query_arg( array( 'page' => self::REDIRECT, ), admin_url( 'admin.php' ) ) ); // Verify pro not installed. $active = activate_plugin( self::SLUG, $url, false, true ); if ( ! is_wp_error( $active ) ) { deactivate_plugins( plugin_basename( CFF_PLUGIN_DIR ) ); wp_send_json_success( esc_html__( 'Plugin installed & activated.', 'custom-facebook-feed' ) ); } $creds = request_filesystem_credentials( $url, '', false, false, null ); // Check for file system permissions. if ( false === $creds ) { wp_send_json_error( $error ); } if ( ! WP_Filesystem( $creds ) ) { wp_send_json_error( $error ); } // We do not need any extra credentials if we have gotten this far, so let's install the plugin. $license = get_option( 'cff_license_key' ); if ( empty( $license ) ) { wp_send_json_error( new WP_Error( '403', esc_html__( 'You are not licensed.', 'custom-facebook-feed' ) ) ); } // Do not allow WordPress to search/download translations, as this will break JS output. remove_action( 'upgrader_process_complete', array( 'Language_Pack_Upgrader', 'async_upgrade' ), 20 ); // Create the plugin upgrader with our custom skin. $installer = new \CustomFacebookFeed\Helpers\PluginSilentUpgrader( new CFF_Install_Skin() ); // Error check. if ( ! method_exists( $installer, 'install' ) || empty( $post_url ) ) { wp_send_json_error( $error ); } $license_data = get_option( 'cff_license_data' ); if ( ! empty ( $license_data ) ) { $version_info = CFF_Upgrader::get_version_info( $license_data ); $file = ''; if ( isset( $version_info->package ) ) { $file = $version_info->package; } } else { wp_send_json_error( new WP_Error( '403', esc_html__( 'You are not licensed.', 'custom-facebook-feed' ) ) ); } if ( ! empty( $file ) ) { $installer->install( $file ); // phpcs:ignore // Check license key. // Flush the cache and return the newly installed plugin basename. wp_cache_flush(); $plugin_basename = $installer->plugin_info(); if ( $plugin_basename ) { deactivate_plugins( plugin_basename( CFF_PLUGIN_BASE ), true ); // Activate the plugin silently. $activated = activate_plugin( $plugin_basename ); if ( ! is_wp_error( $activated ) ) { wp_send_json_success( esc_html__( 'Plugin installed & activated.', 'custom-facebook-feed' ) ); } else { // Reactivate the lite plugin if pro activation failed. $activated = activate_plugin( plugin_basename( CFF_PLUGIN_BASE ), '', false, true ); wp_send_json_error( esc_html__( 'Pro version installed but needs to be activated from the Plugins page inside your WordPress admin.', 'custom-facebook-feed' ) ); } } } wp_send_json_error( $error ); } /** * Whether or not it's likely to be a reachable URL for upgrade * * @param string $url * * @return bool * * @since 4.0 */ public static function is_dev_url( $url = '' ) { $is_local_url = false; // Trim it up $url = strtolower( trim( $url ) ); // Need to get the host...so let's add the scheme so we can use parse_url if ( false === strpos( $url, 'http://' ) && false === strpos( $url, 'https://' ) ) { $url = 'https://' . $url; } $url_parts = parse_url( $url ); $host = ! empty( $url_parts['host'] ) ? $url_parts['host'] : false; if ( ! empty( $url ) && ! empty( $host ) ) { if ( false !== ip2long( $host ) ) { if ( ! filter_var( $host, FILTER_VALIDATE_IP, FILTER_FLAG_NO_PRIV_RANGE | FILTER_FLAG_NO_RES_RANGE ) ) { $is_local_url = true; } } else if ( 'localhost' === $host ) { $is_local_url = true; } $tlds_to_check = array( '.local', ':8888', ':8080', ':8081', '.invalid', '.example', '.test' ); foreach ( $tlds_to_check as $tld ) { if ( false !== strpos( $host, $tld ) ) { $is_local_url = true; break; } } if ( substr_count( $host, '.' ) > 1 ) { // $subdomains_to_check = array( 'dev.', '*.staging.', 'beta.', 'test.' ); allowing these for live test sites for now $subdomains_to_check = []; foreach ( $subdomains_to_check as $subdomain ) { $subdomain = str_replace( '.', '(.)', $subdomain ); $subdomain = str_replace( array( '*', '(.)' ), '(.*)', $subdomain ); if ( preg_match( '/^(' . $subdomain . ')/', $host ) ) { $is_local_url = true; break; } } } } return $is_local_url; } /** * Handle API Response and check for an error. * * @param array $response * * @return string * * @since 4.0 */ public static function get_error_message( $response ) { $message = ''; if ( isset( $response['error'] ) ) { $error = sanitize_text_field( $response['error'] ); switch ( $error ) { case 'expired': $message = __( 'This license is expired.', 'custom-facebook-feed' ); break; default : $message = __( 'We encountered a problem unlocking the PRO features. Please install the PRO version manually.', 'custom-facebook-feed' ); } } elseif ( isset( $response['license_data'] ) ) { $error = CFF_Global_Settings::get_license_error_message( $response['license_data'] ); $message = $error['errorMsg']; } return $message; } }