Edit File by line
/home/zeestwma/richards.../wp-conte.../plugins/jetpack
File: class.jetpack.php
public static function activate_module( $module, $exit = true, $redirect = true ) {
[2500] Fix | Delete
return ( new Modules() )->activate( $module, $exit, $redirect );
[2501] Fix | Delete
}
[2502] Fix | Delete
[2503] Fix | Delete
/**
[2504] Fix | Delete
* Deactivate module.
[2505] Fix | Delete
*
[2506] Fix | Delete
* @param string $module Module slug.
[2507] Fix | Delete
*
[2508] Fix | Delete
* @return bool
[2509] Fix | Delete
*/
[2510] Fix | Delete
public static function deactivate_module( $module ) {
[2511] Fix | Delete
return ( new Modules() )->deactivate( $module );
[2512] Fix | Delete
}
[2513] Fix | Delete
[2514] Fix | Delete
/**
[2515] Fix | Delete
* Enable a configuable module.
[2516] Fix | Delete
*
[2517] Fix | Delete
* @param string $module Module slug.
[2518] Fix | Delete
*
[2519] Fix | Delete
* @return void
[2520] Fix | Delete
*/
[2521] Fix | Delete
public static function enable_module_configurable( $module ) {
[2522] Fix | Delete
$module = self::get_module_slug( $module );
[2523] Fix | Delete
add_filter( 'jetpack_module_configurable_' . $module, '__return_true' );
[2524] Fix | Delete
}
[2525] Fix | Delete
[2526] Fix | Delete
/**
[2527] Fix | Delete
* Composes a module configure URL. It uses Jetpack settings search as default value
[2528] Fix | Delete
* It is possible to redefine resulting URL by using "jetpack_module_configuration_url_$module" filter
[2529] Fix | Delete
*
[2530] Fix | Delete
* @param string $module Module slug.
[2531] Fix | Delete
* @return string $url module configuration URL.
[2532] Fix | Delete
*/
[2533] Fix | Delete
public static function module_configuration_url( $module ) {
[2534] Fix | Delete
$module = self::get_module_slug( $module );
[2535] Fix | Delete
$default_url = self::admin_url() . "#/settings?term=$module";
[2536] Fix | Delete
/**
[2537] Fix | Delete
* Allows to modify configure_url of specific module to be able to redirect to some custom location.
[2538] Fix | Delete
*
[2539] Fix | Delete
* @since 6.9.0
[2540] Fix | Delete
*
[2541] Fix | Delete
* @param string $default_url Default url, which redirects to jetpack settings page.
[2542] Fix | Delete
*/
[2543] Fix | Delete
$url = apply_filters( 'jetpack_module_configuration_url_' . $module, $default_url );
[2544] Fix | Delete
[2545] Fix | Delete
return $url;
[2546] Fix | Delete
}
[2547] Fix | Delete
[2548] Fix | Delete
/* Installation */
[2549] Fix | Delete
/**
[2550] Fix | Delete
* Bail on activation if there is an issue.
[2551] Fix | Delete
*
[2552] Fix | Delete
* @param string $message Error message.
[2553] Fix | Delete
* @param bool $deactivate Deactivate Jetpack or not.
[2554] Fix | Delete
*
[2555] Fix | Delete
* @return never
[2556] Fix | Delete
*/
[2557] Fix | Delete
public static function bail_on_activation( $message, $deactivate = true ) {
[2558] Fix | Delete
?>
[2559] Fix | Delete
<!doctype html>
[2560] Fix | Delete
<html>
[2561] Fix | Delete
<head>
[2562] Fix | Delete
<meta charset="<?php bloginfo( 'charset' ); ?>">
[2563] Fix | Delete
<style>
[2564] Fix | Delete
* {
[2565] Fix | Delete
text-align: center;
[2566] Fix | Delete
margin: 0;
[2567] Fix | Delete
padding: 0;
[2568] Fix | Delete
font-family: "Lucida Grande",Verdana,Arial,"Bitstream Vera Sans",sans-serif;
[2569] Fix | Delete
}
[2570] Fix | Delete
p {
[2571] Fix | Delete
margin-top: 1em;
[2572] Fix | Delete
font-size: 18px;
[2573] Fix | Delete
}
[2574] Fix | Delete
</style>
[2575] Fix | Delete
<body>
[2576] Fix | Delete
<p><?php echo esc_html( $message ); ?></p>
[2577] Fix | Delete
</body>
[2578] Fix | Delete
</html>
[2579] Fix | Delete
<?php
[2580] Fix | Delete
if ( $deactivate ) {
[2581] Fix | Delete
$plugins = get_option( 'active_plugins' );
[2582] Fix | Delete
$jetpack = plugin_basename( JETPACK__PLUGIN_DIR . 'jetpack.php' );
[2583] Fix | Delete
$update = false;
[2584] Fix | Delete
foreach ( $plugins as $i => $plugin ) {
[2585] Fix | Delete
if ( $plugin === $jetpack ) {
[2586] Fix | Delete
$plugins[ $i ] = false;
[2587] Fix | Delete
$update = true;
[2588] Fix | Delete
}
[2589] Fix | Delete
}
[2590] Fix | Delete
[2591] Fix | Delete
if ( $update ) {
[2592] Fix | Delete
update_option( 'active_plugins', array_filter( $plugins ) );
[2593] Fix | Delete
}
[2594] Fix | Delete
}
[2595] Fix | Delete
exit( 0 );
[2596] Fix | Delete
}
[2597] Fix | Delete
[2598] Fix | Delete
/**
[2599] Fix | Delete
* Attached to activate_{ plugin_basename( __FILES__ ) } by register_activation_hook()
[2600] Fix | Delete
*
[2601] Fix | Delete
* @param bool $network_wide Network-wide activation.
[2602] Fix | Delete
*/
[2603] Fix | Delete
public static function plugin_activation( $network_wide ) {
[2604] Fix | Delete
Jetpack_Options::update_option( 'activated', 1 );
[2605] Fix | Delete
[2606] Fix | Delete
if ( version_compare( $GLOBALS['wp_version'], JETPACK__MINIMUM_WP_VERSION, '<' ) ) {
[2607] Fix | Delete
/* translators: Jetpack version number. */
[2608] Fix | Delete
self::bail_on_activation( sprintf( __( 'Jetpack requires WordPress version %s or later.', 'jetpack' ), JETPACK__MINIMUM_WP_VERSION ) );
[2609] Fix | Delete
}
[2610] Fix | Delete
[2611] Fix | Delete
if ( $network_wide ) {
[2612] Fix | Delete
self::state( 'network_nag', true );
[2613] Fix | Delete
}
[2614] Fix | Delete
[2615] Fix | Delete
// For firing one-off events (notices) immediately after activation.
[2616] Fix | Delete
set_transient( 'activated_jetpack', true, 0.1 * MINUTE_IN_SECONDS );
[2617] Fix | Delete
[2618] Fix | Delete
update_option( 'jetpack_activation_source', self::get_activation_source( wp_get_referer() ) );
[2619] Fix | Delete
[2620] Fix | Delete
Health::on_jetpack_activated();
[2621] Fix | Delete
[2622] Fix | Delete
if ( self::is_connection_ready() && method_exists( 'Automattic\Jetpack\Sync\Actions', 'do_only_first_initial_sync' ) ) {
[2623] Fix | Delete
Sync_Actions::do_only_first_initial_sync();
[2624] Fix | Delete
}
[2625] Fix | Delete
[2626] Fix | Delete
if ( ! defined( 'WC_ANALYTICS' ) && class_exists( 'Automattic\Woocommerce_Analytics' ) ) {
[2627] Fix | Delete
Woocommerce_Analytics::maybe_add_proxy_speed_module();
[2628] Fix | Delete
}
[2629] Fix | Delete
[2630] Fix | Delete
self::plugin_initialize();
[2631] Fix | Delete
}
[2632] Fix | Delete
[2633] Fix | Delete
/**
[2634] Fix | Delete
* Returns the activation source.
[2635] Fix | Delete
*
[2636] Fix | Delete
* @param string $referer_url URL.
[2637] Fix | Delete
*
[2638] Fix | Delete
* @return array source_type, source_query.
[2639] Fix | Delete
*/
[2640] Fix | Delete
public static function get_activation_source( $referer_url ) {
[2641] Fix | Delete
if ( defined( 'WP_CLI' ) && WP_CLI ) {
[2642] Fix | Delete
return array( 'wp-cli', null );
[2643] Fix | Delete
}
[2644] Fix | Delete
[2645] Fix | Delete
$referer = wp_parse_url( $referer_url );
[2646] Fix | Delete
[2647] Fix | Delete
$source_type = 'unknown';
[2648] Fix | Delete
$source_query = null;
[2649] Fix | Delete
[2650] Fix | Delete
if ( ! is_array( $referer ) || ! isset( $referer['path'] ) ) {
[2651] Fix | Delete
return array( $source_type, $source_query );
[2652] Fix | Delete
}
[2653] Fix | Delete
[2654] Fix | Delete
$plugins_path = wp_parse_url( admin_url( 'plugins.php' ), PHP_URL_PATH );
[2655] Fix | Delete
$plugins_install_path = wp_parse_url( admin_url( 'plugin-install.php' ), PHP_URL_PATH );// /wp-admin/plugin-install.php
[2656] Fix | Delete
[2657] Fix | Delete
if ( isset( $referer['query'] ) ) {
[2658] Fix | Delete
parse_str( $referer['query'], $query_parts );
[2659] Fix | Delete
} else {
[2660] Fix | Delete
$query_parts = array();
[2661] Fix | Delete
}
[2662] Fix | Delete
[2663] Fix | Delete
if ( $plugins_path === $referer['path'] ) {
[2664] Fix | Delete
$source_type = 'list';
[2665] Fix | Delete
} elseif ( $plugins_install_path === $referer['path'] ) {
[2666] Fix | Delete
$tab = isset( $query_parts['tab'] ) ? $query_parts['tab'] : 'featured';
[2667] Fix | Delete
switch ( $tab ) {
[2668] Fix | Delete
case 'popular':
[2669] Fix | Delete
$source_type = 'popular';
[2670] Fix | Delete
break;
[2671] Fix | Delete
case 'recommended':
[2672] Fix | Delete
$source_type = 'recommended';
[2673] Fix | Delete
break;
[2674] Fix | Delete
case 'favorites':
[2675] Fix | Delete
$source_type = 'favorites';
[2676] Fix | Delete
break;
[2677] Fix | Delete
case 'search':
[2678] Fix | Delete
$source_type = 'search-' . ( isset( $query_parts['type'] ) ? $query_parts['type'] : 'term' );
[2679] Fix | Delete
$source_query = isset( $query_parts['s'] ) ? $query_parts['s'] : null;
[2680] Fix | Delete
break;
[2681] Fix | Delete
default:
[2682] Fix | Delete
$source_type = 'featured';
[2683] Fix | Delete
}
[2684] Fix | Delete
}
[2685] Fix | Delete
[2686] Fix | Delete
return array( $source_type, $source_query );
[2687] Fix | Delete
}
[2688] Fix | Delete
[2689] Fix | Delete
/**
[2690] Fix | Delete
* Runs before bumping version numbers up to a new version
[2691] Fix | Delete
*
[2692] Fix | Delete
* @param string $version Version:timestamp.
[2693] Fix | Delete
* @param string $old_version Old Version:timestamp or false if not set yet.
[2694] Fix | Delete
*/
[2695] Fix | Delete
public static function do_version_bump( $version, $old_version ) {
[2696] Fix | Delete
if ( $old_version ) { // For existing Jetpack installations.
[2697] Fix | Delete
add_action( 'admin_enqueue_scripts', __CLASS__ . '::enqueue_block_style' );
[2698] Fix | Delete
[2699] Fix | Delete
// If a front end page is visited after the update, the 'wp' action will fire.
[2700] Fix | Delete
add_action( 'wp', 'Jetpack::set_update_modal_display' );
[2701] Fix | Delete
[2702] Fix | Delete
// If an admin page is visited after the update, the 'current_screen' action will fire.
[2703] Fix | Delete
add_action( 'current_screen', 'Jetpack::set_update_modal_display' );
[2704] Fix | Delete
}
[2705] Fix | Delete
}
[2706] Fix | Delete
[2707] Fix | Delete
/**
[2708] Fix | Delete
* Sets the display_update_modal state.
[2709] Fix | Delete
*/
[2710] Fix | Delete
public static function set_update_modal_display() {
[2711] Fix | Delete
self::state( 'display_update_modal', true );
[2712] Fix | Delete
}
[2713] Fix | Delete
[2714] Fix | Delete
/**
[2715] Fix | Delete
* Enqueues the block library styles.
[2716] Fix | Delete
*
[2717] Fix | Delete
* @param string $hook The current admin page.
[2718] Fix | Delete
*/
[2719] Fix | Delete
public static function enqueue_block_style( $hook ) {
[2720] Fix | Delete
if ( 'toplevel_page_jetpack' === $hook ) {
[2721] Fix | Delete
wp_enqueue_style( 'wp-block-library' );
[2722] Fix | Delete
}
[2723] Fix | Delete
}
[2724] Fix | Delete
[2725] Fix | Delete
/**
[2726] Fix | Delete
* Sets the internal version number and activation state.
[2727] Fix | Delete
*
[2728] Fix | Delete
* @static
[2729] Fix | Delete
*/
[2730] Fix | Delete
public static function plugin_initialize() {
[2731] Fix | Delete
if ( ! Jetpack_Options::get_option( 'activated' ) ) {
[2732] Fix | Delete
Jetpack_Options::update_option( 'activated', 2 );
[2733] Fix | Delete
}
[2734] Fix | Delete
[2735] Fix | Delete
if ( ! Jetpack_Options::get_option( 'version' ) ) {
[2736] Fix | Delete
$old_version = JETPACK__VERSION . ':' . time();
[2737] Fix | Delete
$version = $old_version;
[2738] Fix | Delete
/** This action is documented in class.jetpack.php */
[2739] Fix | Delete
do_action( 'updating_jetpack_version', $version, false );
[2740] Fix | Delete
Jetpack_Options::update_options( compact( 'version', 'old_version' ) );
[2741] Fix | Delete
}
[2742] Fix | Delete
[2743] Fix | Delete
if ( self::is_connection_ready() ) {
[2744] Fix | Delete
self::handle_default_module_activation( true );
[2745] Fix | Delete
}
[2746] Fix | Delete
[2747] Fix | Delete
self::load_modules();
[2748] Fix | Delete
[2749] Fix | Delete
Jetpack_Options::delete_option( 'do_activate' );
[2750] Fix | Delete
}
[2751] Fix | Delete
[2752] Fix | Delete
/**
[2753] Fix | Delete
* Handles the activation of the default modules depending on the current state of the site:
[2754] Fix | Delete
* - If the site already has the jetpack_active_modules option, activate those.
[2755] Fix | Delete
* - If the site has a site-only connection, only activate the default modules that require only a site connection.
[2756] Fix | Delete
* - If the site has a user connection, activate the default modules that require a user connection.
[2757] Fix | Delete
*
[2758] Fix | Delete
* @param bool $should_activate_user_modules Whether the status of the user connection should be checked and the default modules that
[2759] Fix | Delete
* require a user connection activated.
[2760] Fix | Delete
*/
[2761] Fix | Delete
private static function handle_default_module_activation( $should_activate_user_modules ) {
[2762] Fix | Delete
$active_modules = Jetpack_Options::get_option( 'active_modules' );
[2763] Fix | Delete
if ( $active_modules ) {
[2764] Fix | Delete
self::delete_active_modules();
[2765] Fix | Delete
[2766] Fix | Delete
/**
[2767] Fix | Delete
* Previously active modules could mean two things. First, it could mean
[2768] Fix | Delete
* that Jetpack was previously active on the site. In this case we would like
[2769] Fix | Delete
* to only activate the modules that were set to active.
[2770] Fix | Delete
* Another case could be that the module option was set by a standalone
[2771] Fix | Delete
* plugin. In that case the `active_modules_initalized` option will not
[2772] Fix | Delete
* be set, so we need to enable default Jetpack modules as well.
[2773] Fix | Delete
*/
[2774] Fix | Delete
if ( ! Jetpack_Options::get_option( 'active_modules_initialized' ) ) {
[2775] Fix | Delete
$default_modules = self::get_default_modules();
[2776] Fix | Delete
$active_modules = array_merge( $active_modules, $default_modules );
[2777] Fix | Delete
Jetpack_Options::update_option( 'active_modules_initialized', true );
[2778] Fix | Delete
}
[2779] Fix | Delete
[2780] Fix | Delete
self::activate_default_modules(
[2781] Fix | Delete
999, // This version trick basically excludes every default module.
[2782] Fix | Delete
1,
[2783] Fix | Delete
$active_modules,
[2784] Fix | Delete
false
[2785] Fix | Delete
);
[2786] Fix | Delete
} elseif ( $should_activate_user_modules && ( new Connection_Manager() )->get_connection_owner_id() ) { // Check for a user connection.
[2787] Fix | Delete
self::activate_default_modules( false, false, array(), false, null, null, null );
[2788] Fix | Delete
Jetpack_Options::update_option( 'active_modules_initialized', true );
[2789] Fix | Delete
} else {
[2790] Fix | Delete
self::activate_default_modules( false, false, array(), false, null, null, false );
[2791] Fix | Delete
}
[2792] Fix | Delete
}
[2793] Fix | Delete
[2794] Fix | Delete
/**
[2795] Fix | Delete
* Removes all connection options
[2796] Fix | Delete
*
[2797] Fix | Delete
* @static
[2798] Fix | Delete
*/
[2799] Fix | Delete
public static function plugin_deactivation() {
[2800] Fix | Delete
require_once ABSPATH . '/wp-admin/includes/plugin.php';
[2801] Fix | Delete
$tracking = new Tracking();
[2802] Fix | Delete
$tracking->record_user_event( 'deactivate_plugin', array() );
[2803] Fix | Delete
if ( is_plugin_active_for_network( 'jetpack/jetpack.php' ) ) {
[2804] Fix | Delete
Jetpack_Network::init()->deactivate();
[2805] Fix | Delete
} else {
[2806] Fix | Delete
add_filter( 'jetpack_update_activated_state_on_disconnect', '__return_false' );
[2807] Fix | Delete
self::disconnect();
[2808] Fix | Delete
Jetpack_Options::delete_option( 'version' );
[2809] Fix | Delete
}
[2810] Fix | Delete
[2811] Fix | Delete
if ( ! defined( 'WC_ANALYTICS' ) && class_exists( 'Automattic\Woocommerce_Analytics' ) ) {
[2812] Fix | Delete
Woocommerce_Analytics::maybe_remove_proxy_speed_module();
[2813] Fix | Delete
}
[2814] Fix | Delete
}
[2815] Fix | Delete
[2816] Fix | Delete
/**
[2817] Fix | Delete
* Set activated option to 4 on jetpack_idc_disconnect action.
[2818] Fix | Delete
*/
[2819] Fix | Delete
public static function on_idc_disconnect() {
[2820] Fix | Delete
\Jetpack_Options::update_option( 'activated', 4 );
[2821] Fix | Delete
}
[2822] Fix | Delete
[2823] Fix | Delete
/**
[2824] Fix | Delete
* Disconnects from the Jetpack servers.
[2825] Fix | Delete
* Forgets all connection details and tells the Jetpack servers to do the same.
[2826] Fix | Delete
*
[2827] Fix | Delete
* Will not disconnect if there are other plugins using the connection.
[2828] Fix | Delete
*
[2829] Fix | Delete
* @since 11.0 Do not disconnect if other plugins are using the connection.
[2830] Fix | Delete
*
[2831] Fix | Delete
* @static
[2832] Fix | Delete
*/
[2833] Fix | Delete
public static function disconnect() {
[2834] Fix | Delete
[2835] Fix | Delete
$connection = self::connection();
[2836] Fix | Delete
[2837] Fix | Delete
// If the site is in an IDC because sync is not allowed,
[2838] Fix | Delete
// let's make sure to not disconnect the production site.
[2839] Fix | Delete
$connection->remove_connection( ! Identity_Crisis::validate_sync_error_idc_option() );
[2840] Fix | Delete
}
[2841] Fix | Delete
[2842] Fix | Delete
/**
[2843] Fix | Delete
* Happens after a successful disconnection.
[2844] Fix | Delete
*
[2845] Fix | Delete
* @static
[2846] Fix | Delete
*/
[2847] Fix | Delete
public static function jetpack_site_disconnected() {
[2848] Fix | Delete
Identity_Crisis::clear_all_idc_options();
[2849] Fix | Delete
[2850] Fix | Delete
// Delete all the sync related data. Since it could be taking up space.
[2851] Fix | Delete
Sender::get_instance()->uninstall();
[2852] Fix | Delete
[2853] Fix | Delete
/**
[2854] Fix | Delete
* Filters whether the Jetpack activated state should be updated after disconnecting.
[2855] Fix | Delete
*
[2856] Fix | Delete
* @since 10.0.0
[2857] Fix | Delete
*
[2858] Fix | Delete
* @param bool $update_activated_state Whether activated state should be updated after disconnecting, defaults to true.
[2859] Fix | Delete
*/
[2860] Fix | Delete
$update_activated_state = apply_filters( 'jetpack_update_activated_state_on_disconnect', true );
[2861] Fix | Delete
[2862] Fix | Delete
if ( $update_activated_state ) {
[2863] Fix | Delete
Jetpack_Options::update_option( 'activated', 4 );
[2864] Fix | Delete
}
[2865] Fix | Delete
}
[2866] Fix | Delete
[2867] Fix | Delete
/**
[2868] Fix | Delete
* Disconnects the user.
[2869] Fix | Delete
*
[2870] Fix | Delete
* @deprecated 13.4
[2871] Fix | Delete
* @see \Automattic\Jetpack\Connection\Manager::disconnect_user()
[2872] Fix | Delete
*
[2873] Fix | Delete
* @param int $user_id The user ID to disconnect.
[2874] Fix | Delete
*/
[2875] Fix | Delete
public function disconnect_user( $user_id ) {
[2876] Fix | Delete
$this->connection_manager->disconnect_user( $user_id );
[2877] Fix | Delete
}
[2878] Fix | Delete
[2879] Fix | Delete
/**
[2880] Fix | Delete
* Checking the domain names in beta versions.
[2881] Fix | Delete
* If this is a development version, before attempting to connect, let's make sure that the domains are viable.
[2882] Fix | Delete
*
[2883] Fix | Delete
* @param null|\WP_Error $error The domain validation error, or `null` if everything's fine.
[2884] Fix | Delete
*
[2885] Fix | Delete
* @return null|\WP_Error The domain validation error, or `null` if everything's fine.
[2886] Fix | Delete
*/
[2887] Fix | Delete
public static function registration_check_domains( $error ) {
[2888] Fix | Delete
if ( static::is_development_version() ) {
[2889] Fix | Delete
$domains_to_check = array_unique(
[2890] Fix | Delete
array(
[2891] Fix | Delete
'siteurl' => wp_parse_url( get_site_url(), PHP_URL_HOST ),
[2892] Fix | Delete
'homeurl' => wp_parse_url( get_home_url(), PHP_URL_HOST ),
[2893] Fix | Delete
)
[2894] Fix | Delete
);
[2895] Fix | Delete
foreach ( $domains_to_check as $domain ) {
[2896] Fix | Delete
$result = static::connection()->is_usable_domain( $domain );
[2897] Fix | Delete
if ( is_wp_error( $result ) ) {
[2898] Fix | Delete
return $result;
[2899] Fix | Delete
}
[2900] Fix | Delete
}
[2901] Fix | Delete
}
[2902] Fix | Delete
[2903] Fix | Delete
return $error;
[2904] Fix | Delete
}
[2905] Fix | Delete
[2906] Fix | Delete
/**
[2907] Fix | Delete
* Tracking an internal event log. Try not to put too much chaff in here.
[2908] Fix | Delete
*
[2909] Fix | Delete
* [Everyone Loves a Log!](https://www.youtube.com/watch?v=2C7mNr5WMjA)
[2910] Fix | Delete
*
[2911] Fix | Delete
* @param mixed $code Error code to log.
[2912] Fix | Delete
* @param mixed $data Data to log.
[2913] Fix | Delete
*/
[2914] Fix | Delete
public static function log( $code, $data = null ) {
[2915] Fix | Delete
[2916] Fix | Delete
$raw_log = Jetpack_Options::get_option( 'log', array() );
[2917] Fix | Delete
// This can be modified by the `jetpack_options` filter, so abort if we don't have an array.
[2918] Fix | Delete
if ( ! is_array( $raw_log ) ) {
[2919] Fix | Delete
return;
[2920] Fix | Delete
}
[2921] Fix | Delete
[2922] Fix | Delete
// only grab the latest 200 entries.
[2923] Fix | Delete
$log = array_slice( $raw_log, -199, 199 );
[2924] Fix | Delete
[2925] Fix | Delete
// Append our event to the log.
[2926] Fix | Delete
$log_entry = array(
[2927] Fix | Delete
'time' => time(),
[2928] Fix | Delete
'user_id' => get_current_user_id(),
[2929] Fix | Delete
'blog_id' => Jetpack_Options::get_option( 'id' ),
[2930] Fix | Delete
'code' => $code,
[2931] Fix | Delete
);
[2932] Fix | Delete
// Don't bother storing it unless we've got some.
[2933] Fix | Delete
if ( $data !== null ) {
[2934] Fix | Delete
$log_entry['data'] = $data;
[2935] Fix | Delete
}
[2936] Fix | Delete
$log[] = $log_entry;
[2937] Fix | Delete
[2938] Fix | Delete
// Try add_option first, to make sure it's not autoloaded.
[2939] Fix | Delete
// @todo: Add an add_option method to Jetpack_Options.
[2940] Fix | Delete
if ( ! add_option( 'jetpack_log', $log, '', 'no' ) ) {
[2941] Fix | Delete
Jetpack_Options::update_option( 'log', $log );
[2942] Fix | Delete
}
[2943] Fix | Delete
[2944] Fix | Delete
/**
[2945] Fix | Delete
* Fires when Jetpack logs an internal event.
[2946] Fix | Delete
*
[2947] Fix | Delete
* @since 3.0.0
[2948] Fix | Delete
*
[2949] Fix | Delete
* @param array $log_entry {
[2950] Fix | Delete
* Array of details about the log entry.
[2951] Fix | Delete
*
[2952] Fix | Delete
* @param string time Time of the event.
[2953] Fix | Delete
* @param int user_id ID of the user who trigerred the event.
[2954] Fix | Delete
* @param int blog_id Jetpack Blog ID.
[2955] Fix | Delete
* @param string code Unique name for the event.
[2956] Fix | Delete
* @param string data Data about the event.
[2957] Fix | Delete
* }
[2958] Fix | Delete
*/
[2959] Fix | Delete
do_action( 'jetpack_log_entry', $log_entry );
[2960] Fix | Delete
}
[2961] Fix | Delete
[2962] Fix | Delete
/**
[2963] Fix | Delete
* Get the internal event log.
[2964] Fix | Delete
*
[2965] Fix | Delete
* @param string $event only return the specific log events.
[2966] Fix | Delete
* @param int $num - get specific number of latest results, limited to 200.
[2967] Fix | Delete
*
[2968] Fix | Delete
* @return array of log events || WP_Error for invalid params
[2969] Fix | Delete
*/
[2970] Fix | Delete
public static function get_log( $event = false, $num = false ) {
[2971] Fix | Delete
if ( $event && ! is_string( $event ) ) {
[2972] Fix | Delete
return new WP_Error( __( 'First param must be string or empty', 'jetpack' ) );
[2973] Fix | Delete
}
[2974] Fix | Delete
[2975] Fix | Delete
if ( $num && ! is_numeric( $num ) ) {
[2976] Fix | Delete
return new WP_Error( __( 'Second param must be numeric or empty', 'jetpack' ) );
[2977] Fix | Delete
}
[2978] Fix | Delete
[2979] Fix | Delete
$entire_log = Jetpack_Options::get_option( 'log', array() );
[2980] Fix | Delete
[2981] Fix | Delete
// If nothing set - act as it did before, otherwise let's start customizing the output.
[2982] Fix | Delete
if ( ! $num && ! $event ) {
[2983] Fix | Delete
return $entire_log;
[2984] Fix | Delete
} else {
[2985] Fix | Delete
$entire_log = array_reverse( $entire_log );
[2986] Fix | Delete
}
[2987] Fix | Delete
[2988] Fix | Delete
$custom_log_output = array();
[2989] Fix | Delete
[2990] Fix | Delete
if ( $event ) {
[2991] Fix | Delete
foreach ( $entire_log as $log_event ) {
[2992] Fix | Delete
if ( $event === $log_event['code'] ) {
[2993] Fix | Delete
$custom_log_output[] = $log_event;
[2994] Fix | Delete
}
[2995] Fix | Delete
}
[2996] Fix | Delete
} else {
[2997] Fix | Delete
$custom_log_output = $entire_log;
[2998] Fix | Delete
}
[2999] Fix | Delete
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function