PageRenderTime 22ms CodeModel.GetById 14ms RepoModel.GetById 0ms app.codeStats 0ms

/wp-content/plugins/jetpack/class.jetpack-client-server.php

https://gitlab.com/thisishayat/itv-2016
PHP | 266 lines | 189 code | 56 blank | 21 comment | 42 complexity | 8079e64672c9aec51a48f4cc2d9ca43c MD5 | raw file
  1. <?php
  2. /**
  3. * Client = Plugin
  4. * Client Server = API Methods the Plugin must respond to
  5. */
  6. class Jetpack_Client_Server {
  7. function authorize() {
  8. $data = stripslashes_deep( $_GET );
  9. $redirect = isset( $data['redirect'] ) ? esc_url_raw( (string) $data['redirect'] ) : '';
  10. $jetpack_unique_connection = Jetpack_Options::get_option( 'unique_connection' );
  11. // Checking if site has been active/connected previously before recording unique connection
  12. if ( ! $jetpack_unique_connection ) {
  13. // jetpack_unique_connection option has never been set
  14. $jetpack_unique_connection = array(
  15. 'connected' => 0,
  16. 'disconnected' => 0,
  17. 'version' => '3.6.1'
  18. );
  19. update_option( 'jetpack_unique_connection', $jetpack_unique_connection );
  20. //track unique connection
  21. $jetpack = Jetpack::init();
  22. $jetpack->stat( 'connections', 'unique-connection' );
  23. $jetpack->do_stats( 'server_side' );
  24. }
  25. // increment number of times connected
  26. $jetpack_unique_connection['connected'] += 1;
  27. Jetpack_Options::update_option( 'unique_connection', $jetpack_unique_connection );
  28. do {
  29. $jetpack = $this->get_jetpack();
  30. $role = $jetpack->translate_current_user_to_role();
  31. if ( !$role ) {
  32. Jetpack::state( 'error', 'no_role' );
  33. break;
  34. }
  35. $cap = $jetpack->translate_role_to_cap( $role );
  36. if ( !$cap ) {
  37. Jetpack::state( 'error', 'no_cap' );
  38. break;
  39. }
  40. $this->check_admin_referer( "jetpack-authorize_{$role}_{$redirect}" );
  41. if ( !empty( $data['error'] ) ) {
  42. Jetpack::state( 'error', $data['error'] );
  43. break;
  44. }
  45. if ( empty( $data['state'] ) ) {
  46. Jetpack::state( 'error', 'no_state' );
  47. break;
  48. }
  49. if ( !ctype_digit( $data['state'] ) ) {
  50. Jetpack::state( 'error', 'invalid_state' );
  51. break;
  52. }
  53. $current_user_id = get_current_user_id();
  54. if ( $current_user_id != $data['state'] ) {
  55. Jetpack::state( 'error', 'wrong_state' );
  56. break;
  57. }
  58. if ( empty( $data['code'] ) ) {
  59. Jetpack::state( 'error', 'no_code' );
  60. break;
  61. }
  62. $token = $this->get_token( $data );
  63. if ( is_wp_error( $token ) ) {
  64. if ( $error = $token->get_error_code() )
  65. Jetpack::state( 'error', $error );
  66. else
  67. Jetpack::state( 'error', 'invalid_token' );
  68. Jetpack::state( 'error_description', $token->get_error_message() );
  69. break;
  70. }
  71. if ( !$token ) {
  72. Jetpack::state( 'error', 'no_token' );
  73. break;
  74. }
  75. $is_master_user = ! Jetpack::is_active();
  76. Jetpack::update_user_token( $current_user_id, sprintf( '%s.%d', $token, $current_user_id ), $is_master_user );
  77. if ( $is_master_user ) {
  78. Jetpack::state( 'message', 'authorized' );
  79. } else {
  80. Jetpack::state( 'message', 'linked' );
  81. // Don't activate anything since we are just connecting a user.
  82. break;
  83. }
  84. if ( $active_modules = Jetpack_Options::get_option( 'active_modules' ) ) {
  85. Jetpack_Options::delete_option( 'active_modules' );
  86. Jetpack::activate_default_modules( 999, 1, $active_modules );
  87. } else {
  88. Jetpack::activate_default_modules();
  89. }
  90. // Sync all registers options and constants
  91. /** This action is documented in class.jetpack.php */
  92. do_action( 'jetpack_sync_all_registered_options' );
  93. // Start nonce cleaner
  94. wp_clear_scheduled_hook( 'jetpack_clean_nonces' );
  95. wp_schedule_event( time(), 'hourly', 'jetpack_clean_nonces' );
  96. } while ( false );
  97. if ( wp_validate_redirect( $redirect ) ) {
  98. $this->wp_safe_redirect( $redirect );
  99. } else {
  100. $this->wp_safe_redirect( Jetpack::admin_url() );
  101. }
  102. $this->do_exit();
  103. }
  104. public static function deactivate_plugin( $probable_file, $probable_title ) {
  105. include_once( ABSPATH . 'wp-admin/includes/plugin.php' );
  106. if ( is_plugin_active( $probable_file ) ) {
  107. deactivate_plugins( $probable_file );
  108. return 1;
  109. } else {
  110. // If the plugin is not in the usual place, try looking through all active plugins.
  111. $active_plugins = Jetpack::get_active_plugins();
  112. foreach ( $active_plugins as $plugin ) {
  113. $data = get_plugin_data( WP_PLUGIN_DIR . '/' . $plugin );
  114. if ( $data['Name'] == $probable_title ) {
  115. deactivate_plugins( $plugin );
  116. return 1;
  117. }
  118. }
  119. }
  120. return 0;
  121. }
  122. /**
  123. * @return object|WP_Error
  124. */
  125. function get_token( $data ) {
  126. $jetpack = $this->get_jetpack();
  127. $role = $jetpack->translate_current_user_to_role();
  128. if ( !$role ) {
  129. return new Jetpack_Error( 'role', __( 'An administrator for this blog must set up the Jetpack connection.', 'jetpack' ) );
  130. }
  131. $client_secret = Jetpack_Data::get_access_token();
  132. if ( !$client_secret ) {
  133. return new Jetpack_Error( 'client_secret', __( 'You need to register your Jetpack before connecting it.', 'jetpack' ) );
  134. }
  135. $redirect = isset( $data['redirect'] ) ? esc_url_raw( (string) $data['redirect'] ) : '';
  136. $body = array(
  137. 'client_id' => Jetpack_Options::get_option( 'id' ),
  138. 'client_secret' => $client_secret->secret,
  139. 'grant_type' => 'authorization_code',
  140. 'code' => $data['code'],
  141. 'redirect_uri' => add_query_arg( array(
  142. 'action' => 'authorize',
  143. '_wpnonce' => wp_create_nonce( "jetpack-authorize_{$role}_{$redirect}" ),
  144. 'redirect' => $redirect ? urlencode( $redirect ) : false,
  145. ), menu_page_url( 'jetpack', false ) ),
  146. );
  147. $args = array(
  148. 'method' => 'POST',
  149. 'body' => $body,
  150. 'headers' => array(
  151. 'Accept' => 'application/json',
  152. ),
  153. );
  154. $response = Jetpack_Client::_wp_remote_request( Jetpack::fix_url_for_bad_hosts( Jetpack::api_url( 'token' ) ), $args );
  155. if ( is_wp_error( $response ) ) {
  156. return new Jetpack_Error( 'token_http_request_failed', $response->get_error_message() );
  157. }
  158. $code = wp_remote_retrieve_response_code( $response );
  159. $entity = wp_remote_retrieve_body( $response );
  160. if ( $entity )
  161. $json = json_decode( $entity );
  162. else
  163. $json = false;
  164. if ( 200 != $code || !empty( $json->error ) ) {
  165. if ( empty( $json->error ) )
  166. return new Jetpack_Error( 'unknown', '', $code );
  167. $error_description = isset( $json->error_description ) ? sprintf( __( 'Error Details: %s', 'jetpack' ), (string) $json->error_description ) : '';
  168. return new Jetpack_Error( (string) $json->error, $error_description, $code );
  169. }
  170. if ( empty( $json->access_token ) || !is_scalar( $json->access_token ) ) {
  171. return new Jetpack_Error( 'access_token', '', $code );
  172. }
  173. if ( empty( $json->token_type ) || 'X_JETPACK' != strtoupper( $json->token_type ) ) {
  174. return new Jetpack_Error( 'token_type', '', $code );
  175. }
  176. if ( empty( $json->scope ) ) {
  177. return new Jetpack_Error( 'scope', 'No Scope', $code );
  178. }
  179. @list( $role, $hmac ) = explode( ':', $json->scope );
  180. if ( empty( $role ) || empty( $hmac ) ) {
  181. return new Jetpack_Error( 'scope', 'Malformed Scope', $code );
  182. }
  183. if ( $jetpack->sign_role( $role ) !== $json->scope ) {
  184. return new Jetpack_Error( 'scope', 'Invalid Scope', $code );
  185. }
  186. if ( !$cap = $jetpack->translate_role_to_cap( $role ) )
  187. return new Jetpack_Error( 'scope', 'No Cap', $code );
  188. if ( ! current_user_can( $cap ) )
  189. return new Jetpack_Error( 'scope', 'current_user_cannot', $code );
  190. /**
  191. * Fires after user has successfully received an auth token.
  192. *
  193. * @since 3.9.0
  194. */
  195. do_action( 'jetpack_user_authorized' );
  196. return (string) $json->access_token;
  197. }
  198. public function get_jetpack() {
  199. return Jetpack::init();
  200. }
  201. public function check_admin_referer( $action ) {
  202. return check_admin_referer( $action );
  203. }
  204. public function wp_safe_redirect( $redirect ) {
  205. return wp_safe_redirect( $redirect );
  206. }
  207. public function do_exit() {
  208. exit;
  209. }
  210. }