FIX permit reindexing on a Windows machine

It appears that when executing in a Microsoft Windows environment the
default shell used in the immediate reindex handler is CMD, which has
some severely different syntax support from that of a POSIX machine (e.g.
GNU bash). This leads to errors to do with double escaping certain
parameters passed in via the CLI - culminating in an Injector error about
an non-extant class e.g. 'SilverStripe\\CMS\\Model\\SiteTree' - two
slashes a namespace separator does not make!
This commit is contained in:
Dylan Wagstaff 2018-02-23 16:46:44 +13:00
parent 10344580c9
commit 367343c481

View File

@ -60,19 +60,21 @@ class SolrReindexImmediateHandler extends SolrReindexBase
$group, $group,
$taskName $taskName
) { ) {
// Build state $indexClass = get_class($indexInstance);
// Build script parameters
$indexClassEscaped = $indexClass;
$statevar = json_encode($state); $statevar = json_encode($state);
if (strpos(PHP_OS, "WIN") !== false) { if (strpos(PHP_OS, "WIN") !== false) {
$statevar = '"'.str_replace('"', '\\"', $statevar).'"'; $statevar = '"'.str_replace('"', '\\"', $statevar).'"';
} else { } else {
$statevar = "'".$statevar."'"; $statevar = "'".$statevar."'";
$class = addslashes($class);
$indexClassEscaped = addslashes($indexClass);
} }
// Build script // Build script line
$indexName = $indexInstance->getIndexName();
$indexClass = get_class($indexInstance);
$indexClassEscaped = addslashes($indexClass);
$class = addslashes($class);
$frameworkPath = ModuleLoader::getModule('silverstripe/framework')->getPath(); $frameworkPath = ModuleLoader::getModule('silverstripe/framework')->getPath();
$scriptPath = sprintf("%s%scli-script.php", $frameworkPath, DIRECTORY_SEPARATOR); $scriptPath = sprintf("%s%scli-script.php", $frameworkPath, DIRECTORY_SEPARATOR);
$scriptTask = "php {$scriptPath} dev/tasks/{$taskName}"; $scriptTask = "php {$scriptPath} dev/tasks/{$taskName}";