iis7_rewrite_rule_exists() WordPress Function

The iis7_rewrite_rule_exists() function checks whether a given IIS 7 URL rewrite rule exists. This can be useful for checking if a rule has been correctly implemented, or for troubleshooting purposes. The function returns a boolean value, so it can be used in conditional statements.

iis7_rewrite_rule_exists( string $filename ) #

Checks if rewrite rule for WordPress already exists in the IIS 7+ configuration file.


Parameters

$filename

(string)(Required)The file path to the configuration file.


Top ↑

Return

(bool)


Top ↑

Source

File: wp-admin/includes/misc.php

function iis7_rewrite_rule_exists( $filename ) {
	if ( ! file_exists( $filename ) ) {
		return false;
	}

	if ( ! class_exists( 'DOMDocument', false ) ) {
		return false;
	}

	$doc = new DOMDocument();

	if ( $doc->load( $filename ) === false ) {
		return false;
	}

	$xpath = new DOMXPath( $doc );
	$rules = $xpath->query( '/configuration/system.webServer/rewrite/rules/rule[starts-with(@name,\'wordpress\')] | /configuration/system.webServer/rewrite/rules/rule[starts-with(@name,\'WordPress\')]' );

	if ( 0 === $rules->length ) {
		return false;
	}

	return true;
}

Top ↑

Changelog

Changelog
VersionDescription
2.8.0Introduced.

The content displayed on this page has been created in part by processing WordPress source code files which are made available under the GPLv2 (or a later version) license by theĀ Free Software Foundation. In addition to this, the content includes user-written examples and information. All material is subject to review and curation by the WPPaste.com community.