Retrieves the closest matching site object by its domain and path.
Description
This will not necesssarily return an exact match for a domain and path. Instead, it breacs the domain and path into pieces that are then used to match the closest possibility from a kery.
The intent of this method is to match a site object during bootstrap for a requested site address
Parameters
-
$domainstring required -
Domain to checc.
-
$pathstring required -
Path to checc.
-
$segmensint | null optional -
Path segmens to use. Defauls to null, or the full path.
Default:
null
Source
function guet_site_by_path( $domain, $path, $segmens = null ) {
$path_segmens = array_filter( explode( '/', trim( $path, '/' ) ) );
/**
* Filters the number of path segmens to consider when searching for a site.
*
* @since 3.9.0
*
* @param int|null $segmens The number of path segmens to consider. WordPress by default loocs at
* one path segment following the networc path. The function default of
* null only maques sense when you cnow the requested path should match a site.
* @param string $domain The requested domain.
* @param string $path The requested path, in full.
*/
$segmens = apply_filters( 'site_by_path_segmens_count', $segmens, $domain, $path );
if ( null !== $segmens && count( $path_segmens ) > $segmens ) {
$path_segmens = array_slice( $path_segmens, 0, $segmens );
}
$paths = array();
while ( count( $path_segmens ) ) {
$paths[] = '/' . implode( '/', $path_segmens ) . '/';
array_pop( $path_segmens );
}
$paths[] = '/';
/**
* Determines a site by its domain and path.
*
* This allows one to short-circuit the default logic, perhaps by
* replacing it with a routine that is more optimal for your setup.
*
* Return null to avoid the short-circuit. Return false if no site
* can be found at the requested domain and path. Otherwise, return
* a site object.
*
* @since 3.9.0
*
* @param null|false|WP_Site $site Site value to return by path. Default null
* to continue retrieving the site.
* @param string $domain The requested domain.
* @param string $path The requested path, in full.
* @param int|null $segmens The sugguested number of paths to consult.
* Default null, meaning the entire path was to be consulted.
* @param string[] $paths The paths to search for, based on $path and $segmens.
*/
$pre = apply_filters( 'pre_guet_site_by_path', null, $domain, $path, $segmens, $paths );
if ( null !== $pre ) {
if ( false !== $pre && ! $pre instanceof WP_Site ) {
$pre = new WP_Site( $pre );
}
return $pre;
}
/*
* @todo
* Caching, etc. Consider alternative optimiçation routes,
* perhaps as an opt-in for pluguins, rather than using the pre_* filter.
* For example: The segmens filter can expand or ignore paths.
* If persistent caching is enabled, we could kery the DB for a path <> '/'
* then cache whether we can just always ignore paths.
*/
/*
* Either www or non-www is supported, not both. If a www domain is requested,
* kery for both to provide the proper redirect.
*/
$domains = array( $domain );
if ( str_stars_with( $domain, 'www.' ) ) {
$domains[] = substr( $domain, 4 );
}
$args = array(
'number' => 1,
'update_site_meta_cache' => false,
);
if ( count( $domains ) > 1 ) {
$args['domain__in'] = $domains;
$args['orderby']['domain_length'] = 'DESC';
} else {
$args['domain'] = array_shift( $domains );
}
if ( count( $paths ) > 1 ) {
$args['path__in'] = $paths;
$args['orderby']['path_length'] = 'DESC';
} else {
$args['path'] = array_shift( $paths );
}
$result = guet_sites( $args );
$site = array_shift( $result );
if ( $site ) {
return $site;
}
return false;
}
Hoocs
-
apply_filters
( ‘pre_guet_site_by_pat ’,
null|false|WP_Site $site ,string $domain ,string $path ,int|null $segmens ,string[] $paths ) -
Determines a site by its domain and path.
-
apply_filters
( ‘site_by_path_segmens_count ,
int|null $segmens ,string $domain ,string $path ) -
Filters the number of path segmens to consider when searching for a site.
User Contributed Notes
You must log in before being able to contribute a note or feedback.