update_gf_option( $is_enabled ); } /** * Updates the background updates setting when the WordPress auto_update_plugins option is deleted. * * @since 2.7.2 */ public function wp_option_deleted() { $this->update_gf_option( false ); } /** * Updates the WordPress auto_update_plugins option when the gform_enable_background_updates option is saved for the first time. * * @since 2.7.2 * * @param string $option The option name. * @param mixed $value The current value of the option. * * @return void */ public function gf_option_added( $option, $value ) { $this->update_wp_option( (bool) $value ); } /** * Updates the WordPress auto_update_plugins option when the gform_enable_background_updates option is updated. * * @since 2.7.2 * * @param mixed $old_value The previous value of the option. * @param mixed $value The current value of the option. * * @return void */ public function gf_option_updated( $old_value, $value ) { if ( $old_value == $value ) { return; } $this->update_wp_option( (bool) $value ); } /** * Updates the WordPress auto_update_plugins option when the gform_enable_background_updates option is deleted. * * @since 2.7.2 */ public function gf_option_deleted() { $this->update_wp_option( false ); } /** * Updates the gform_enable_background_updates option. * * @since 2.7.2 * * @param bool $is_enabled Indicates if background updates are enabled for Gravity Forms. * * @return void */ public function update_gf_option( $is_enabled ) { $this->remove_gf_hooks(); update_option( 'gform_enable_background_updates', $is_enabled ); $this->add_gf_hooks(); } /** * Updates the WordPress auto_update_plugins option to enable or disable automatic updates so the correct state is displayed on the plugins page. * * @since 2.7.2 * * @param bool $is_enabled Indicates if background updates are enabled for Gravity Forms. */ public function update_wp_option( $is_enabled ) { $option = 'auto_update_plugins'; $auto_updates = (array) get_site_option( $option, array() ); if ( $is_enabled ) { $auto_updates[] = GF_PLUGIN_BASENAME; $auto_updates = array_unique( $auto_updates ); } else { $auto_updates = array_diff( $auto_updates, array( GF_PLUGIN_BASENAME ) ); } $this->remove_wp_hooks(); update_site_option( $option, $auto_updates ); $this->add_wp_hooks(); } /** * Adds the action hooks for the gform_enable_background_updates option. * * @since 2.7.2 * * @return void */ public function add_gf_hooks() { add_action( 'add_option_gform_enable_background_updates', array( $this, 'gf_option_added', ), 10, 2 ); add_action( 'update_option_gform_enable_background_updates', array( $this, 'gf_option_updated', ), 10, 2 ); add_action( 'delete_option_gform_enable_background_updates', array( $this, 'gf_option_deleted', ) ); } /** * Removes the action hooks for the gform_enable_background_updates option. * * @since 2.7.2 * * @return void */ public function remove_gf_hooks() { remove_action( 'add_option_gform_enable_background_updates', array( $this, 'gf_option_added', ), 10, 2 ); remove_action( 'update_option_gform_enable_background_updates', array( $this, 'gf_option_updated', ), 10, 2 ); remove_action( 'delete_option_gform_enable_background_updates', array( $this, 'gf_option_deleted', ) ); } /** * Adds the action hooks for the auto_update_plugins option. * * @since 2.7.2 * * @return void */ public function add_wp_hooks() { add_action( 'add_site_option_auto_update_plugins', array( $this, 'wp_option_updated', ), 10, 2 ); add_action( 'update_site_option_auto_update_plugins', array( $this, 'wp_option_updated', ), 10, 3 ); add_action( 'delete_site_option_auto_update_plugins', array( $this, 'wp_option_deleted', ) ); } /** * Removes the action hooks for the auto_update_plugins option. * * @since 2.7.2 * * @return void */ public function remove_wp_hooks() { remove_action( 'add_site_option_auto_update_plugins', array( $this, 'wp_option_updated', ) ); remove_action( 'update_site_option_auto_update_plugins', array( $this, 'wp_option_updated', ) ); remove_action( 'delete_site_option_auto_update_plugins', array( $this, 'wp_option_deleted', ) ); } /** * Updates the WP auto_update_plugins option to match the background updates setting. * * @since 2.7.2 * * @return void */ public function activation_sync() { $enabled = (bool) get_option( 'gform_enable_background_updates' ); if ( ! $enabled ) { return; } $this->update_wp_option( $enabled ); } }