File: /www/wwwroot/njmuedu.com/wp-content/plugins/google-site-kit-cli/includes/Modules/Ads.php
<?php
/**
* Class Google\Site_Kit\Modules\Ads
*
* @package Google\Site_Kit
* @copyright 2024 Google LLC
* @license https://www.apache.org/licenses/LICENSE-2.0 Apache License 2.0
* @link https://sitekit.withgoogle.com
*/
namespace Google\Site_Kit\Modules;
use Google\Site_Kit\Core\Assets\Script;
use Google\Site_Kit\Core\Modules\Module;
use Google\Site_Kit\Core\Modules\Module_Settings;
use Google\Site_Kit\Core\Modules\Module_With_Assets;
use Google\Site_Kit\Core\Modules\Module_With_Assets_Trait;
use Google\Site_Kit\Core\Modules\Module_With_Debug_Fields;
use Google\Site_Kit\Core\Modules\Module_With_Deactivation;
use Google\Site_Kit\Core\Modules\Module_With_Settings;
use Google\Site_Kit\Core\Modules\Module_With_Settings_Trait;
use Google\Site_Kit\Core\Modules\Module_With_Tag;
use Google\Site_Kit\Core\Modules\Module_With_Tag_Trait;
use Google\Site_Kit\Core\Modules\Tags\Module_Tag_Matchers;
use Google\Site_Kit\Core\Site_Health\Debug_Data;
use Google\Site_Kit\Modules\Ads\Settings;
use Google\Site_Kit\Modules\Ads\Tag_Guard;
use Google\Site_Kit\Modules\Ads\Tag_Matchers;
use Google\Site_Kit\Modules\Ads\Web_Tag;
use Google\Site_Kit\Core\Tags\Guards\Tag_Environment_Type_Guard;
use Google\Site_Kit\Core\Tags\Guards\Tag_Verify_Guard;
/**
* Class representing the Ads module.
*
* @since 1.121.0
* @access private
* @ignore
*/
final class Ads extends Module implements Module_With_Assets, Module_With_Debug_Fields, Module_With_Settings, Module_With_Tag, Module_With_Deactivation {
use Module_With_Assets_Trait;
use Module_With_Settings_Trait;
use Module_With_Tag_Trait;
/**
* Module slug name.
*/
const MODULE_SLUG = 'ads';
/**
* Registers functionality through WordPress hooks.
*
* @since 1.121.0
*/
public function register() {
// Ads tag placement logic.
add_action( 'template_redirect', array( $this, 'register_tag' ) );
}
/**
* Sets up the module's assets to register.
*
* @since 1.122.0
*
* @return Asset[] List of Asset objects.
*/
protected function setup_assets() {
$base_url = $this->context->url( 'dist/assets/' );
return array(
new Script(
'googlesitekit-modules-ads',
array(
'src' => $base_url . 'js/googlesitekit-modules-ads.js',
'dependencies' => array(
'googlesitekit-vendor',
'googlesitekit-api',
'googlesitekit-data',
'googlesitekit-modules',
'googlesitekit-datastore-site',
'googlesitekit-datastore-user',
'googlesitekit-components',
),
)
),
);
}
/**
* Sets up information about the module.
*
* @since 1.121.0
*
* @return array Associative array of module info.
*/
protected function setup_info() {
return array(
'slug' => 'ads',
'name' => _x( 'Ads', 'Service name', 'google-site-kit' ),
'description' => __( 'Track conversions for your existing Google Ads campaigns', 'google-site-kit' ),
'order' => 1,
'homepage' => __( 'https://google.com/ads', 'google-site-kit' ),
);
}
/**
* Sets up the module's settings instance.
*
* @since 1.122.0
*
* @return Module_Settings
*/
protected function setup_settings() {
return new Settings( $this->options );
}
/**
* Checks whether the module is connected.
*
* A module being connected means that all steps required as part of its activation are completed.
*
* @since 1.122.0
*
* @return bool True if module is connected, false otherwise.
*/
public function is_connected() {
$options = $this->get_settings()->get();
return parent::is_connected() && ! empty( $options['adsConversionID'] );
}
/**
* Cleans up when the module is deactivated.
*
* @since 1.122.0
*/
public function on_deactivation() {
$this->get_settings()->delete();
}
/**
* Registers the Ads tag.
*
* @since 1.124.0
*/
public function register_tag() {
$ads_conversion_id = $this->get_settings()->get()['adsConversionID'];
$tag = new Web_Tag( $ads_conversion_id, self::MODULE_SLUG );
if ( $tag->is_tag_blocked() ) {
return;
}
$tag->use_guard( new Tag_Verify_Guard( $this->context->input() ) );
$tag->use_guard( new Tag_Guard( $this->get_settings() ) );
$tag->use_guard( new Tag_Environment_Type_Guard() );
if ( ! $tag->can_register() ) {
return;
}
$tag->register();
}
/**
* Gets an array of debug field definitions.
*
* @since 1.124.0
*
* @return array An array of all debug fields.
*/
public function get_debug_fields() {
$settings = $this->get_settings()->get();
return array(
'ads_conversion_tracking_id' => array(
'label' => __( 'Ads Conversion Tracking ID', 'google-site-kit' ),
'value' => $settings['adsConversionID'],
'debug' => Debug_Data::redact_debug_value( $settings['adsConversionID'] ),
),
);
}
/**
* Returns the Module_Tag_Matchers instance.
*
* @since 1.124.0
*
* @return Module_Tag_Matchers Module_Tag_Matchers instance.
*/
public function get_tag_matchers() {
return new Tag_Matchers();
}
}