HEX
Server: LiteSpeed
System: Linux mail.aatilis.ir 6.8.0-101-generic #101-Ubuntu SMP PREEMPT_DYNAMIC Mon Feb 9 10:15:05 UTC 2026 x86_64
User: www (1000)
PHP: 8.3.30
Disabled: passthru,exec,system,putenv,chroot,chgrp,chown,shell_exec,popen,proc_open,pcntl_exec,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,imap_open,apache_setenv
Upload Files
File: /www/wwwroot/soqatland.com/wp-content/plugins/woocommerce/src/Internal/Customers/SearchService.php
<?php

declare( strict_types = 1 );

namespace Automattic\WooCommerce\Internal\Customers;

use Automattic\WooCommerce\Internal\DataStores\Orders\OrdersTableDataStore;
use Automattic\WooCommerce\Utilities\OrderUtil;

/**
 * Internal API for searching users/customers: no backward compatibility obligation.
 */
final class SearchService {
	/**
	 * Searches users having the billing email (when applicable lookup orders as well) as specified and returns their id.
	 *
	 * @param string[] $emails Emails to search for.
	 *
	 * @return int[]
	 */
	public function find_user_ids_by_billing_email_for_coupons_usage_lookup( array $emails ): array {
		$emails = array_unique( array_map( 'strtolower', array_map( 'sanitize_email', $emails ) ) );

		$include_user_ids = array();
		if ( OrderUtil::custom_orders_table_usage_is_enabled() ) {
			global $wpdb;

			// phpcs:disable WordPress.DB.PreparedSQLPlaceholders.ReplacementsWrongNumber, WordPress.DB.PreparedSQL.InterpolatedNotPrepared
			$placeholders     = implode( ', ', array_fill( 0, count( $emails ), '%s' ) );
			$include_user_ids = $wpdb->get_col(
				$wpdb->prepare(
					"SELECT DISTINCT customer_id FROM %i WHERE billing_email IN ($placeholders)",
					OrdersTableDataStore::get_orders_table_name(),
					...$emails
				)
			);
			// phpcs:enable

			if ( array() === $include_user_ids ) {
				return array();
			}
		}

		$users_query = new \WP_User_Query(
			array(
				'fields'     => 'ID',
				'include'    => $include_user_ids,
				'meta_query' => array( // phpcs:ignore WordPress.DB.SlowDBQuery.slow_db_query_meta_query
					array(
						'key'     => 'billing_email',
						'value'   => $emails,
						'compare' => 'IN',
					),
				),
			)
		);
		return array_map( 'intval', array_unique( $users_query->get_results() ) );
	}
}