ascvh@#%(^-^)V ?host,ip,port,protocol,title,domain,country,city,link,org ???à JFIF  x x ?? C         ?? C   ?à   " ??     ?? μ  } !1AQa "q2?‘?#B±áR?e$3br? %&'()*456789:CDEFGHIJSTUVWXYZcdefghijstuvwxyz??…???‰?’“”?–—???¢£¤¥|§¨?a23′μ?·?1o??????èéêòó???×?ùúáa?????èéê?òó???÷?ùú??     ?? μ   w !1AQ aq"2?B‘?±á #3Rebr?{ gilour
<?php /** * Rule processor for sending when the provided plugins are activated. */ namespace Automattic\WooCommerce\Admin\RemoteInboxNotifications; defined( 'ABSPATH' ) || exit; use Automattic\WooCommerce\Admin\PluginsProvider\PluginsProvider; /** * Rule processor for sending when the provided plugins are activated. */ class PluginsActivatedRuleProcessor implements RuleProcessorInterface { /** * The plugins provider. * * @var PluginsProviderInterface */ protected $plugins_provider; /** * Constructor. * * @param PluginsProviderInterface $plugins_provider The plugins provider. */ public function __construct( $plugins_provider = null ) { $this->plugins_provider = null === $plugins_provider ? new PluginsProvider() : $plugins_provider; } /** * Process the rule. * * @param object $rule The specific rule being processed by this rule processor. * @param object $stored_state Stored state. * * @return bool Whether the rule passes or not. */ public function process( $rule, $stored_state ) { if ( 0 === count( $rule->plugins ) ) { return false; } $active_plugin_slugs = $this->plugins_provider->get_active_plugin_slugs(); foreach ( $rule->plugins as $plugin_slug ) { if ( ! in_array( $plugin_slug, $active_plugin_slugs, true ) ) { return false; } } return true; } /** * Validates the rule. * * @param object $rule The rule to validate. * * @return bool Pass/fail. */ public function validate( $rule ) { if ( ! isset( $rule->plugins ) || ! is_array( $rule->plugins ) ) { return false; } return true; } }