HEX
Server: Apache/2.4.65 (Debian)
System: Linux 88f31f35b0b8 6.1.0-38-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.1.147-1 (2025-08-02) x86_64
User: www-data (33)
PHP: 8.2.29
Disabled: NONE
Upload Files
File: /var/www/html/wp-content/plugins/advanced-ads/includes/functions-group.php
<?php
/**
 * Group CRUD Helpers
 *
 * @since 2.0.0
 * @package AdvancedAds
 * @author  Advanced Ads <info@wpadvancedads.com>
 *
 *  Content:
 *   1. Template
 *   2. Repositories functions
 *   3. CRUD functions
 *   4. Conditional functions
 *   5. Getter functions
 *   6. Finder functions
 */

use AdvancedAds\Abstracts\Group;
use AdvancedAds\Groups\Group_Types;
use AdvancedAds\Groups\Group_Factory;
use AdvancedAds\Interfaces\Group_Type;
use AdvancedAds\Groups\Group_Repository;

/** 1. Template --------------- */

/**
 * Get the group object.
 *
 * @param Group|WP_Term|int|bool $group_id Group instance, term instance or numeric.
 * @param string                 $new_type Change type of group.
 * @param array                  $args     Additional arguments.
 *
 * @return string|mixed The group output or whatever entity or string that is overriding the return value.
 */
function get_the_group( $group_id = 0, $new_type = '', $args = [] ) {
	if ( ! \Advanced_Ads::get_instance()->can_display_ads() ) {
		return '';
	}
	if ( defined( 'ADVANCED_ADS_DISABLE_CHANGE' ) && ADVANCED_ADS_DISABLE_CHANGE ) {
		$args = [];
	}

	// Early bail!!
	// TODO: remove later once we move to new hooks.
	if ( isset( $args['override'] ) ) {
		return $args['override'];
	}

	$group = is_a_group( $group_id ) ? $group_id : wp_advads_get_group( $group_id, $new_type );
	if ( ! $group || 0 === $group->get_id() ) {
		return '';
	}

	$args = wp_advads_default_entity_arguments( 'group', $group->get_id(), $args );
	wp_advads_set_additional_args( $group, $args );

	$override = apply_filters( 'advanced-ads-ad-select-override-by-group', false, $group, $group->get_ordered_ad_ids(), $args );

	if ( false !== $override ) {
		return $override;
	}

	return $group->output();
}

/**
 * Echo an ad from an ad group
 *
 * @since 1.0.0
 *
 * @param int   $id   ID of the ad group.
 * @param array $args Additional arguments.
 *
 * @return void
 */
function the_ad_group( $id = 0, $args = [] ): void {
	echo get_the_group( $id, '', $args ); // phpcs:ignore
}

/* 2. Repositories ------------------- */

/**
 * Get Group Factory
 *
 * @return Group_Factory
 */
function wp_advads_get_group_factory(): Group_Factory {
	return wp_advads()->groups->factory;
}

/**
 * Get Group Repository
 *
 * @return Group_Repository
 */
function wp_advads_get_group_repository(): Group_Repository {
	return wp_advads()->groups->repository;
}

/**
 * Get Group Types
 *
 * @return Group_Types
 */
function wp_advads_get_group_type_manager(): Group_Types {
	return wp_advads()->groups->types;
}

/* 3. CRUD ------------------- */

/**
 * Create an empty group object
 *
 * @param string $type Type of group to create.
 *
 * @return Group|bool Group object or false if the group type not found.
 */
function wp_advads_create_new_group( $type = 'default' ) {
	return wp_advads_get_group_factory()->create_group( $type );
}

/**
 * Delete an group from the database.
 *
 * @param int|Group $group Group object or Id.
 *
 * @return void
 */
function wp_advads_delete_group( &$group ): void {
	if ( ! $group instanceof Group ) {
		$group = wp_advads_get_group( $group );
	}

	$group->delete();
}

/**
 * Create missing group type.
 *
 * @param string $type Missing type.
 *
 * @return void
 */
function wp_advads_create_group_type( $type ): void {
	wp_advads_get_group_type_manager()->create_missing( $type );
}

/**
 * Register custom group type.
 *
 * @param string $classname Type class name.
 *
 * @return void
 */
function wp_advads_register_group_type( $classname ): void {
	wp_advads_get_group_type_manager()->register_type( $classname );
}

/* 4. Conditional ------------------- */

/**
 * Has group type.
 *
 * @param string $type Type to check.
 *
 * @return bool
 */
function wp_advads_has_group_type( $type ): bool {
	return wp_advads_get_group_type_manager()->has_type( $type );
}

/**
 * Checks whether the given variable is a group.
 *
 * @param mixed $thing The variable to check.
 *
 * @return bool
 */
function is_a_group( $thing ): bool {
	return $thing instanceof Group;
}

/* 5. Getter ------------------- */

/**
 * Get all groups object.
 *
 * @return Group[]
 */
function wp_advads_get_all_groups(): array {
	return wp_advads_get_group_repository()->get_all_groups();
}

/**
 * Get all group as dropdown.
 *
 * @return array
 */
function wp_advads_get_groups_dropdown() {
	return wp_advads_get_group_repository()->get_groups_dropdown();
}

/**
 * Get the registered group type.
 *
 * @param string $type Type to get.
 *
 * @return Group_Type|bool
 */
function wp_advads_get_group_type( $type ) {
	return wp_advads_get_group_type_manager()->get_type( $type );
}

/**
 * Get the registered group types.
 *
 * @return Group_Type[]
 */
function wp_advads_get_group_types() {
	return wp_advads_get_group_type_manager()->get_types();
}

/* 6. Finder ------------------- */

/**
 * Get the group object.
 *
 * @param Group|WP_Term|int|bool $group_id Group instance, term instance or numeric.
 * @param string                 $new_type Change type of group.
 *
 * @return Group|bool Group object or false if the group cannot be loaded.
 */
function wp_advads_get_group( $group_id = false, $new_type = '' ) {
	return wp_advads_get_group_factory()->get_group( $group_id, $new_type );
}