$c->get_string( 'cdn.rackspace_cdn.user_name' ), 'api_key' => $c->get_string( 'cdn.rackspace_cdn.api_key' ), ); include W3TC_DIR . '/Cdn_RackSpaceCdn_Popup_View_Intro.php'; exit(); } public function w3tc_ajax_cdn_rackspace_intro_done() { $this->_render_cdn_rackspace_regions( array( 'user_name' => Util_Request::get_string( 'user_name' ), 'api_key' => Util_Request::get_string( 'api_key' ), ) ); } private function _render_cdn_rackspace_regions( $details ) { $user_name = $details['user_name']; $api_key = $details['api_key']; try { $r = Cdn_RackSpace_Api_Tokens::authenticate( $user_name, $api_key ); } catch ( \Exception $ex ) { $details = array( 'user_name' => $user_name, 'api_key' => $api_key, 'error_message' => 'Can\'t authenticate: ' . $ex->getMessage(), ); include W3TC_DIR . '/Cdn_RackSpaceCdn_Popup_View_Intro.php'; exit(); } $r['regions'] = Cdn_RackSpace_Api_Tokens::cdn_services_by_region( $r['services'] ); $details['access_token'] = $r['access_token']; $details['region_descriptors'] = $r['regions']; // avoid fights with quotes, magic_quotes may break randomly. $details['region_descriptors_serialized'] = strtr( wp_json_encode( $r['regions'] ), '"\\', '!^' ); include W3TC_DIR . '/Cdn_RackSpaceCdn_Popup_View_Regions.php'; exit(); } public function w3tc_ajax_cdn_rackspace_regions_done() { $user_name = Util_Request::get_string( 'user_name' ); $api_key = Util_Request::get_string( 'api_key' ); $access_token = Util_Request::get_string( 'access_token' ); $region = Util_Request::get_string( 'region' ); $region_descriptors = json_decode( strtr( Util_Request::get_string( 'region_descriptors' ), '!^', '"\\' ), true ); if ( ! isset( $region_descriptors[$region] ) ) { return $this->_render_cdn_rackspace_regions( array( 'user_name' => $user_name, 'api_key' => $api_key, 'error_message' => 'Please select region ' . $region, ) ); } $api = new Cdn_RackSpace_Api_Cdn( array( 'access_token' => $access_token, 'access_region_descriptor' => $region_descriptors[ $region ], 'new_access_required' => '', ) ); try { $services = $api->services(); } catch ( \Exception $ex ) { $details = array( 'user_name' => $user_name, 'api_key' => $api_key, 'error_message' => $ex->getMessage(), ); include W3TC_DIR . '/Cdn_RackSpaceCdn_Popup_View_Intro.php'; exit(); } $details = array( 'user_name' => $user_name, 'api_key' => $api_key, 'access_token' => $access_token, 'access_region_descriptor_serialized' => strtr( wp_json_encode( $region_descriptors[ $region ] ), '"\\', '!^' ), 'region' => $region, // avoid fights with quotes, magic_quotes may break randomly. 'services' => $services, ); include W3TC_DIR . '/Cdn_RackSpaceCdn_Popup_View_Services.php'; exit(); } public function w3tc_ajax_cdn_rackspace_services_done() { $user_name = Util_Request::get_string( 'user_name' ); $api_key = Util_Request::get_string( 'api_key' ); $access_token = Util_Request::get_string( 'access_token' ); $access_region_descriptor = json_decode( strtr( Util_Request::get_string( 'access_region_descriptor' ), '!^', '"\\' ), true ); $region = Util_Request::get_string( 'region' ); $service = Util_Request::get( 'service' ); if ( !empty( $service ) ) { $this->_render_service_actualize( array( 'user_name' => $user_name, 'api_key' => $api_key, 'access_token' => $access_token, 'access_region_descriptor_serialized' => strtr( json_encode( $access_region_descriptor ), '"\\', '!^' ), 'region' => $region, 'service_id' => $service, ) ); exit(); } $home_url = get_home_url(); $parsed = wp_parse_url( $home_url ); $is_https = ( 'https' === $parsed['scheme'] ); $details = array( 'user_name' => $user_name, 'api_key' => $api_key, 'access_token' => $access_token, 'access_region_descriptor_serialized' => strtr( wp_json_encode( $access_region_descriptor ), '"\\', '!^' ), 'region' => $region, 'name' => '', 'protocol' => ( $is_https ? 'https' : 'http' ), 'cname_http' => '', 'cname_http_style' => ( $is_https ? 'display: none' : '' ), 'cname_https_prefix' => '', 'cname_https_style' => ( $is_https ? '' : 'display: none' ), 'origin' => Util_Environment::home_url_host(), ); include W3TC_DIR . '/Cdn_RackSpaceCdn_Popup_View_Service_Create.php'; exit(); } public function w3tc_ajax_cdn_rackspace_service_create_done() { $user_name = Util_Request::get_string( 'user_name' ); $api_key = Util_Request::get_string( 'api_key' ); $access_token = Util_Request::get_string( 'access_token' ); $access_region_descriptor = json_decode( strtr( Util_Request::get_string( 'access_region_descriptor' ), '!^', '"\\' ), true ); $region = Util_Request::get_string( 'region' ); $name = Util_Request::get_string( 'name' ); $protocol = Util_Request::get_string( 'protocol' ); $cname_http = Util_Request::get_string( 'cname_http' ); $cname_https_prefix = Util_Request::get_string( 'cname_https_prefix' ); $is_https = ( 'https' === $protocol ); $cname = ( $is_https ? $cname_https_prefix : $cname_http ); $api = new Cdn_RackSpace_Api_Cdn( array( 'access_token' => $access_token, 'access_region_descriptor' => $access_region_descriptor, 'new_access_required' => '', ) ); $service_id = null; $access_url = null; try { $domain = array( 'domain' => $cname, 'protocol' => ( $is_https ? 'https' : 'http' ), ); if ( $is_https ) { $domain['certificate'] = 'shared'; } $service_id = $api->service_create( array( 'name' => $name, 'domains' => array( $domain ), 'origins' => array( array( 'origin' => Util_Environment::home_url_host(), 'port' => ( $is_https ? 443 : 80 ), 'ssl' => $is_https, 'hostheadertype' => 'origin', 'rules' => array(), ), ), 'caching' => array( array( 'name' => 'default', 'ttl' => 86400, ), ), ) ); } catch ( \Exception $ex ) { $details = array( 'user_name' => $user_name, 'api_key' => $api_key, 'access_token' => $access_token, 'access_region_descriptor_serialized' => strtr( wp_json_encode( $access_region_descriptor ), '"\\', '!^' ), 'region' => $region, 'name' => $name, 'protocol' => ( $is_https ? 'https' : 'http' ), 'cname_http' => $cname_http, 'cname_http_style' => ( $is_https ? 'display: none' : '' ), 'cname_https_prefix' => $cname_https_prefix, 'cname_https_style' => ( $is_https ? '' : 'display: none' ), 'origin' => Util_Environment::home_url_host(), 'error_message' => $ex->getMessage(), ); include W3TC_DIR . '/Cdn_RackSpaceCdn_Popup_View_Service_Create.php'; exit(); } $details = array( 'user_name' => $user_name, 'api_key' => $api_key, 'access_token' => $access_token, 'access_region_descriptor_serialized' => strtr( wp_json_encode( $access_region_descriptor ), '"\\', '!^' ), 'region' => $region, 'name' => $name, 'is_https' => $is_https, 'cname' => $cname, 'service_id' => $service_id, ); include W3TC_DIR . '/Cdn_RackSpaceCdn_Popup_View_Service_Created.php'; } /** * AJAX returning json for js-script about service state. */ public function w3tc_ajax_cdn_rackspace_service_get_state() { $access_token = Util_Request::get_string( 'access_token' ); $access_region_descriptor = json_decode( strtr( Util_Request::get_string( 'access_region_descriptor' ), '!^', '"\\' ), true ); $service_id = Util_Request::get_string( 'service_id' ); $api = new Cdn_RackSpace_Api_Cdn( array( 'access_token' => $access_token, 'access_region_descriptor' => $access_region_descriptor, 'new_access_required' => '', ) ); $service = $api->service_get( $service_id ); $response = array( 'status' => 'Unknown' ); if ( isset( $service['status'] ) ) { $response['status'] = $service['status']; } if ( isset( $service['links_by_rel']['access_url'] ) ) { $response['access_url'] = $service['links_by_rel']['access_url']['href']; } if ( isset( $service['domains'] ) ) { $response['cname'] = $service['domains'][0]['domain']; } // decode to friendly name. if ( 'create_in_progress' === $response['status'] ) { $response['status'] = 'Creation in progress...'; } echo esc_html( wp_json_encode( $response ) ); } public function w3tc_ajax_cdn_rackspace_service_created_done() { $this->_save_config(); } private function _render_service_actualize( $details ) { $access_region_descriptor = json_decode( strtr( $details['access_region_descriptor_serialized'], '!^', '"\\' ), true ); $api = new Cdn_RackSpace_Api_Cdn( array( 'access_token' => $details['access_token'], 'access_region_descriptor' => $access_region_descriptor, 'new_access_required' => '', ) ); $service = null; try { $service = $api->service_get( $details['service_id'] ); } catch ( \Exception $ex ) { $details['error_message'] = $ex->getMessage(); include W3TC_DIR . '/Cdn_RackSpaceCdn_Popup_View_Intro.php'; exit(); } $origin = ''; $protocol = 'http'; if ( isset( $service['origins'] ) && $service['origins'][0]['origin'] ) { $protocol = $service['origins'][0]['ssl'] ? 'https' : 'http'; $origin = $service['origins'][0]['origin']; } $details['name'] = $service['name']; $details['protocol'] = $protocol; $details['origin'] = array( 'current' => $origin, 'new' => Util_Environment::home_url_host(), ); include W3TC_DIR . '/Cdn_RackSpaceCdn_Popup_View_Service_Actualize.php'; exit(); } public function w3tc_ajax_cdn_rackspace_service_actualize_done() { $user_name = Util_Request::get_string( 'user_name' ); $api_key = Util_Request::get_string( 'api_key' ); $access_token = Util_Request::get_string( 'access_token' ); $access_region_descriptor = json_decode( strtr( Util_Request::get_string( 'access_region_descriptor' ), '!^', '"\\' ), true ); $region = Util_Request::get_string( 'region' ); $service_id = Util_Request::get_string( 'service_id' ); $api = new Cdn_RackSpace_Api_Cdn( array( 'access_token' => $access_token, 'access_region_descriptor' => $access_region_descriptor, 'new_access_required' => '', ) ); try { $service = $api->service_get( $service_id ); $is_https = false; $origin = ''; if ( isset( $service['origins'] ) && $service['origins'][0]['ssl'] ) { $is_https = $service['origins'][0]['ssl']; $origin = $service['origins'][0]['origin']; } $new_origin = Util_Environment::home_url_host(); if ( $origin !== $new_origin ) { $api->service_set( $service_id, array( array( 'op' => 'replace', 'path' => '/origins', 'value' => array( array( 'origin' => $new_origin, 'port' => ( $is_https ? 443 : 80 ), 'ssl' => $is_https, 'hostheadertype' => 'origin', 'rules' => array(), ), ), ), ) ); } } catch ( \Exception $ex ) { $details = array( 'user_name' => $user_name, 'api_key' => $api_key, 'error_message' => $ex->getMessage(), ); include W3TC_DIR . '/Cdn_RackSpaceCdn_Popup_View_Intro.php'; exit(); } $this->_save_config(); } private function _save_config() { $user_name = Util_Request::get_string( 'user_name' ); $api_key = Util_Request::get_string( 'api_key' ); $access_token = Util_Request::get_string( 'access_token' ); $access_region_descriptor = json_decode( strtr( Util_Request::get_string( 'access_region_descriptor' ), '!^', '"\\' ), true ); $region = Util_Request::get_string( 'region' ); $service_id = Util_Request::get_string( 'service_id' ); $api = new Cdn_RackSpace_Api_Cdn( array( 'access_token' => $access_token, 'access_region_descriptor' => $access_region_descriptor, 'new_access_required' => '', ) ); $service = $api->service_get( $service_id ); $access_url = $service['links_by_rel']['access_url']['href']; $protocol = 'http'; $domain = ''; if ( isset( $service['domains'] ) && $service['domains'][0]['protocol'] ) { $protocol = $service['domains'][0]['protocol']; $domain = $service['domains'][0]['domain']; } $c = Dispatcher::config(); $c->set( 'cdn.rackspace_cdn.user_name', $user_name ); $c->set( 'cdn.rackspace_cdn.api_key', $api_key ); $c->set( 'cdn.rackspace_cdn.region', $region ); $c->set( 'cdn.rackspace_cdn.service.name', $service['name'] ); $c->set( 'cdn.rackspace_cdn.service.id', $service_id ); $c->set( 'cdn.rackspace_cdn.service.access_url', $access_url ); $c->set( 'cdn.rackspace_cdn.service.protocol', $protocol ); if ( 'https' !== $protocol ) { $c->set( 'cdn.rackspace_cdn.domains', array( $domain ) ); } $c->save(); // reset calculated state. $state = Dispatcher::config_state(); $state->set( 'cdn.rackspace_cdn.access_state', '' ); $state->save(); $postfix = Util_Admin::custom_message_id( array(), array( 'cdn_configuration_saved' => 'CDN credentials are saved successfully' ) ); echo esc_url( 'Location admin.php?page=w3tc_cdn&' . $postfix ); exit(); } /** * CNAMEs popup */ public function w3tc_ajax_cdn_rackspace_configure_domains() { $this->render_configure_domains_form(); exit(); } public function w3tc_ajax_cdn_rackspace_configure_domains_done() { $details = array( 'cnames' => Util_Request::get_array( 'cdn_cnames' ), ); $core = Dispatcher::component( 'Cdn_Core' ); $cdn = $core->get_cdn(); try { // try to obtain CNAMEs. $cdn->service_domains_set( $details['cnames'] ); $c = Dispatcher::config(); $c->set( 'cdn.rackspace_cdn.domains', $details['cnames'] ); $c->save(); $postfix = Util_Admin::custom_message_id( array(), array( 'cdn_cnames_saved' => 'CNAMEs are saved successfully' ) ); echo esc_url( 'Location admin.php?page=w3tc_cdn&' . $postfix ); exit(); } catch ( \Exception $ex ) { $details['error_message'] = $ex->getMessage(); } $this->render_configure_domains_form( $details ); exit(); } private function render_configure_domains_form( $details = array() ) { if ( isset( $details['cnames'] ) ) { $cnames = $details['cnames']; } else { $core = Dispatcher::component( 'Cdn_Core' ); $cdn = $core->get_cdn(); try { // try to obtain CNAMEs. $cnames = $cdn->service_domains_get(); } catch ( \Exception $ex ) { $details['error_message'] = $ex->getMessage(); $cnames = array(); } } include W3TC_DIR . '/Cdn_RackSpaceCdn_Popup_View_ConfigureDomains.php'; } private function render_service_value_change( $details, $field ) { Util_Ui::hidden( '', $field, $details[ $field ]['new'] ); if ( ! isset( $details[ $field ]['current'] ) || $details[ $field ]['current'] === $details[ $field ]['new'] ) { echo esc_html( $details[ $field ]['new'] ); } else { echo wp_kses( sprintf( // translators: 1 opening HTML strong tag, 2 current setting value, 3 closing HTML strong tag followed by HTML line break, // translators: 4 opening HTML strong tag, 5 new setting value, 6 closing HTML strong tag followed by HTML line break. __( 'currently set to %1$s%2$s%3$s will be changed to %4$s%5$s%6$s', 'w3-total-cache' ), '', empty( $details[ $field ]['current'] ) ? '' : $details[ $field ]['current'], '
', '', $details[ $field ]['new'], '
' ), array( 'strong' => array(), 'empty' => array(), 'br' => array(), ) ); } } }