HEX
Server: Apache/2.4.58 (Ubuntu)
System: Linux ubuntu-8gb-hel1-1 6.8.0-55-generic #57-Ubuntu SMP PREEMPT_DYNAMIC Wed Feb 12 23:42:21 UTC 2025 x86_64
User: www-data (33)
PHP: 8.1.32
Disabled: NONE
Upload Files
File: /var/www/agighana.org_backup/String_Filter.php
<?php
/**
 * Class Google\Site_Kit\Modules\Analytics_4\Report\String_Filter
 *
 * @package   Google\Site_Kit\Modules\Analytics_4\Report\Filters
 * @copyright 2023 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\Analytics_4\Report\Filters;

use Google\Site_Kit_Dependencies\Google\Service\AnalyticsData\Filter as Google_Service_AnalyticsData_Filter;
use Google\Site_Kit_Dependencies\Google\Service\AnalyticsData\FilterExpression as Google_Service_AnalyticsData_FilterExpression;
use Google\Site_Kit_Dependencies\Google\Service\AnalyticsData\FilterExpressionList as Google_Service_AnalyticsData_FilterExpressionList;
use Google\Site_Kit_Dependencies\Google\Service\AnalyticsData\StringFilter as Google_Service_AnalyticsData_StringFilter;

/**
 * Class for parsing the string filter.
 *
 * @since 1.106.0
 * @since 1.147.0 Moved from `Analytics_4\Report\Dimension_Filters` to `Analytics_4\Report\Filters` for use with both dimensions and metrics.
 * @access private
 * @ignore
 */
class String_Filter implements Filter {

	/**
	 * Converts the filter into the GA4 compatible filter expression.
	 *
	 * @since 1.106.0
	 *
	 * @param string $name The filter field name.
	 * @param mixed  $value The filter value.
	 * @return Google_Service_AnalyticsData_FilterExpression The filter expression instance.
	 */
	public function parse_filter_expression( $name, $value ) {
		$match_type = isset( $value['matchType'] )
			? $value['matchType']
			: 'EXACT';

		$filter_value = isset( $value['value'] )
			? $value['value']
			: $value;

		// If there are many values for this filter, then it means that we want to find
		// rows where values are included in the list of provided values. In this case,
		// we need to create a nested filter expression that contains separate string filters
		// for each item in the list and combined into the "OR" group.
		if ( is_array( $filter_value ) ) {
			$expressions = array();
			foreach ( $filter_value as $value ) {
				$expressions[] = $this->compose_individual_filter_expression(
					$name,
					$match_type,
					$value
				);
			}

			$expression_list = new Google_Service_AnalyticsData_FilterExpressionList();
			$expression_list->setExpressions( $expressions );

			$filter_expression = new Google_Service_AnalyticsData_FilterExpression();
			$filter_expression->setOrGroup( $expression_list );

			return $filter_expression;
		}

		// If we have a single value for the filter, then we should use just a single
		// string filter expression and there is no need to create a nested one.
		return $this->compose_individual_filter_expression(
			$name,
			$match_type,
			$filter_value
		);
	}

	/**
	 * Composes individual filter expression and returns it.
	 *
	 * @since 1.106.0
	 *
	 * @param string $name Filter name.
	 * @param string $match_type Filter match type.
	 * @param mixed  $value Filter value.
	 * @return Google_Service_AnalyticsData_FilterExpression The filter expression instance.
	 */
	protected function compose_individual_filter_expression( $name, $match_type, $value ) {
		$string_filter = new Google_Service_AnalyticsData_StringFilter();
		$string_filter->setMatchType( $match_type );
		$string_filter->setValue( $value );

		$filter = new Google_Service_AnalyticsData_Filter();
		$filter->setFieldName( $name );
		$filter->setStringFilter( $string_filter );

		$filter_expression = new Google_Service_AnalyticsData_FilterExpression();
		$filter_expression->setFilter( $filter );

		return $filter_expression;
	}
}