Last active
January 11, 2021 11:50
-
-
Save milanarandjelovic/0f46ce5d52d60cd6e1c11de8fa3f4d52 to your computer and use it in GitHub Desktop.
WordPress - MultiSite Valet Drivers
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<?php | |
/* | |
Valet driver for Wordpress Multisite | |
Usage: Drop this file into your ~/.valet/Drivers/ directory | |
*/ | |
class WordPressMultisiteValetDriver extends WordPressValetDriver | |
{ | |
/** | |
* @var string The public web directory, if deeper under the root directory | |
*/ | |
protected $public_dir = ''; | |
/** | |
* @var bool true if site is detected to be multisite | |
*/ | |
protected $multisite = false; | |
/** | |
* Determine if the driver serves the request. | |
* | |
* @param string $sitePath | |
* @param string $siteName | |
* @param string $uri | |
* @return bool | |
*/ | |
public function serves($sitePath, $siteName, $uri) | |
{ | |
foreach (['', 'public'] as $public_directory) { | |
$this->public_dir = $public_directory; | |
$wp_config_path = $this->realSitePath($sitePath) . "/wp-config.php"; | |
if (file_exists($wp_config_path)) { | |
// Look for define('MULTISITE', true in wp-config | |
$env_path = $sitePath . "/.env"; | |
if (preg_match("/^define\(\s*('|\")MULTISITE\\1\s*,\s*true\s*\)/mi", | |
file_get_contents($wp_config_path)) | |
or (file_exists($env_path) and preg_match("/^WP_MULTISITE=true$/mi", | |
file_get_contents($env_path))) | |
) { | |
$this->multisite = true; | |
} | |
return true; | |
} | |
} | |
return false; | |
} | |
/** | |
* Determine if the incoming request is for a static file. | |
* | |
* @param string $sitePath | |
* @param string $siteName | |
* @param string $uri | |
* @return string|false | |
*/ | |
public function isStaticFile($sitePath, $siteName, $uri) | |
{ | |
$uri = $this->rewriteMultisite($sitePath, $uri); | |
$sitePath = $this->realSitePath($sitePath); | |
if ($this->isActualFile($staticFilePath = $sitePath . $uri)) { | |
return $staticFilePath; | |
} | |
return false; | |
} | |
/** | |
* Get the fully resolved path to the application's front controller. | |
* | |
* @param string $sitePath | |
* @param string $siteName | |
* @param string $uri | |
* @return string | |
*/ | |
public function frontControllerPath($sitePath, $siteName, $uri) | |
{ | |
$uri = $this->rewriteMultisite($sitePath, $uri); | |
$sitePath = $this->realSitePath($sitePath); | |
return parent::frontControllerPath($sitePath, $siteName, $uri); | |
} | |
/** | |
* Translate the site path to the actual public directory | |
* | |
* @param $sitePath | |
* @return string | |
*/ | |
protected function realSitePath($sitePath) | |
{ | |
if ($this->public_dir) { | |
$sitePath .= "/" . $this->public_dir; | |
} | |
return $sitePath; | |
} | |
/** | |
* Imitate the rewrite rules for a multisite .htaccess | |
* | |
* @param $sitePath | |
* @param $uri | |
* @return string | |
*/ | |
protected function rewriteMultisite($sitePath, $uri) | |
{ | |
if ($this->multisite) { | |
if (preg_match('/^(.*)?(\/wp-(content|admin|includes).*)/', $uri, $matches)) { | |
//RewriteRule ^([_0-9a-zA-Z-]+/)?(wp-(content|admin|includes).*) $2 [L] | |
$uri = $matches[2]; | |
} elseif (preg_match('/^(.*)?(\/.*\.php)$/', $uri, $matches)) { | |
//RewriteRule ^([_0-9a-zA-Z-]+/)?(.*\.php)$ $2 [L] | |
$uri = $matches[2]; | |
} | |
} | |
return $uri; | |
} | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment