Better location handling (chocolate muffin remix)

This commit is contained in:
markseu 2014-03-16 19:32:52 +01:00
parent 0b02d4d4f3
commit d12adf5b4d
4 changed files with 192 additions and 154 deletions

View file

@ -2,24 +2,24 @@ Yellow
======
Yellow is a CMS **for people** who make websites.
[![Build Status](https://secure.travis-ci.org/markseu/yellowcms.png)](https://travis-ci.org/markseu/yellowcms)
How do I install this?
----------------------
1. [Download Yellow](https://github.com/markseu/yellowcms/archive/master.zip) and unzip it.
2. Copy all files to your web server hosting.
2. Copy all files to your web hosting.
3. Open your website in a browser.
Installation requirements are Apache, mod_rewrite, PHP 5.3 and multibyte support.
With Yellow you don't get a lot of extra stuff. There are [Yellow extensions](https://github.com/markseu/yellowcms-extensions/blob/master/README.md) for download.
Installation requirements are Apache, mod_rewrite and PHP 5.3.
With Yellow you don't get a lot of extra stuff. There are [Yellow extensions](https://github.com/markseu/yellowcms-extensions/blob/master/README.md).
How to make a website?
How do I get started?
----------------------
You already have everything you need, start by editing the default pages.
You already have everything you need, start by editing a page.
That's it. For more information see [Yellow documentation](https://github.com/markseu/yellowcms-extensions/blob/master/documentation/README.md).
License and a big thanks
------------------------
* Yellow and extensions by Mark Seuffert are licensed under [GPLv2](http://opensource.org/licenses/GPL-2.0)
License and thanks
------------------
* Yellow by Mark Seuffert and David Fehrmann is licensed under [GPLv2](http://opensource.org/licenses/GPL-2.0).
* [PHP Markdown Extra](https://github.com/michelf/php-markdown) by Michel Fortin is licensed under [BSD license](http://opensource.org/licenses/BSD-3-Clause)

View file

@ -25,6 +25,7 @@ imageDir = media/images/
contentDir = content/
contentHomeDir = home/
contentDefaultFile = page.txt
contentPagination = page
contentExtension = .txt
configExtension = .ini
errorPageFile = error(.*).txt

View file

@ -5,12 +5,12 @@
// Command line core plugin
class YellowCommandline
{
const Version = "0.2.4";
var $yellow; //access to API
var $content; //number of content pages
var $error; //number of build errors
var $locationsArgs; //build locations with arguments
var $locationsPage; //build locations with pagination
const Version = "0.2.5";
var $yellow; //access to API
var $content; //number of content pages
var $error; //number of build errors
var $locationsArguments; //build locations with arguments
var $locationsPagination; //build locations with pagination
// Initialise plugin
function onLoad($yellow)
@ -67,7 +67,7 @@ class YellowCommandline
list($dummy, $command, $path, $location) = $args;
if(!empty($path) && $path!="/" && (empty($location) || $location[0]=='/'))
{
if($this->yellow->config->isExisting("serverName"))
if($this->checkStaticConfig())
{
list($statusCode, $content, $media, $system, $error) = $this->buildStatic($location, $path);
} else {
@ -90,7 +90,7 @@ class YellowCommandline
{
$this->yellow->toolbox->timerStart($time);
$this->content = $this->error = $statusCodeMax = 0;
$this->locationsArgs = $this->locationsPage = array();
$this->locationsArguments = $this->locationsPagination = array();
if(empty($location))
{
$pages = $this->yellow->pages->index(true);
@ -109,11 +109,11 @@ class YellowCommandline
{
$statusCodeMax = max($statusCodeMax, $this->buildStaticLocation($page->location, $path, empty($location)));
}
foreach($this->locationsArgs as $location)
foreach($this->locationsArguments as $location)
{
$statusCodeMax = max($statusCodeMax, $this->buildStaticLocation($location, $path, true));
}
foreach($this->locationsPage as $location)
foreach($this->locationsPagination as $location)
{
for($pageNumber=2; $pageNumber<=999; ++$pageNumber)
{
@ -147,22 +147,12 @@ class YellowCommandline
$statusCode = $this->yellow->request();
if($statusCode != 404)
{
$fileOk = true;
$modified = strtotime($this->yellow->page->getHeader("Last-Modified"));
list($contentType, $contentEncoding) = explode(';', $this->yellow->page->getHeader("Content-Type"), 2);
$staticLocation = $this->getStaticLocation($location, $contentType);
if($location == $staticLocation)
{
$fileName = $this->getStaticFileName($location, $path);
$fileData = ob_get_contents();
if($statusCode>=301 && $statusCode<=303) $fileData = $this->getStaticRedirect($this->yellow->page->getHeader("Location"));
$fileOk = $this->yellow->toolbox->createFile($fileName, $fileData, true) &&
$this->yellow->toolbox->modifyFile($fileName, $modified);
} else {
$statusCode = 409;
$this->yellow->page->error($statusCode, "Type '$contentType' does not match file name!");
}
if(!$fileOk)
$fileName = $this->getStaticFileName($location, $path);
$fileData = ob_get_contents();
if($statusCode>=301 && $statusCode<=303) $fileData = $this->getStaticRedirect($this->yellow->page->getHeader("Location"));
if(!$this->yellow->toolbox->createFile($fileName, $fileData, true) ||
!$this->yellow->toolbox->modifyFile($fileName, $modified))
{
$statusCode = 500;
$this->yellow->page->error($statusCode, "Can't write file '$fileName'!");
@ -227,6 +217,7 @@ class YellowCommandline
{
$serverName = $this->yellow->config->get("serverName");
$serverBase = $this->yellow->config->get("serverBase");
$pagination = $this->yellow->config->get("contentPagination");
preg_match_all("/<a(.*?)href=\"([^\"]+)\"(.*?)>/i", $fileData, $matches);
foreach($matches[2] as $match)
{
@ -237,49 +228,32 @@ class YellowCommandline
}
if(!$this->yellow->toolbox->isLocationArgs($match)) continue;
if(substru($match, 0, strlenu($serverBase)) != $serverBase) continue;
$match = rawurldecode(substru($match, strlenu($serverBase)));
if(!preg_match("/^(.*\/page:)\d*$/", $match, $tokens))
$location = rawurldecode(substru($match, strlenu($serverBase)));
if(!$this->yellow->toolbox->isPaginationLocation($location, $pagination))
{
$match = rtrim($match, '/').'/';
if(is_null($this->locationsArgs[$match]))
$location = rtrim($location, '/').'/';
if(is_null($this->locationsArguments[$location]))
{
$this->locationsArgs[$match] = $match;
if(defined("DEBUG") && DEBUG>=2) echo "YellowCommandline::analyseStaticLocation type:args location:$match\n";
$this->locationsArguments[$location] = $location;
if(defined("DEBUG") && DEBUG>=2) echo "YellowCommandline::analyseStaticLocation type:arguments location:$location\n";
}
} else {
$match = $tokens[1];
if(is_null($this->locationsPage[$match]))
$location = rtrim($location, "0..9");
if(is_null($this->locationsPagination[$location]))
{
$this->locationsPage[$match] = $match;
if(defined("DEBUG") && DEBUG>=2) echo "YellowCommandline::analyseStaticLocation type:page location:$match\n";
$this->locationsPagination[$location] = $location;
if(defined("DEBUG") && DEBUG>=2) echo "YellowCommandline::analyseStaticLocation type:pagination location:$location\n";
}
}
}
}
// Return static location corresponding to content type
function getStaticLocation($location, $contentType)
// Check static configuration
function checkStaticConfig()
{
if(!empty($contentType))
{
$extension = ($pos = strrposu($location, '.')) ? substru($location, $pos) : "";
if($contentType == "text/html")
{
if($this->yellow->toolbox->isFileLocation($location))
{
if(!empty($extension) && !preg_match("/^\.(html|md)$/", $extension)) $location .= ".html";
}
} else {
if($this->yellow->toolbox->isFileLocation($location))
{
if(empty($extension)) $location .= ".invalid";
} else {
if(preg_match("/^(\w+)\/(\w+)/", $contentType, $matches)) $extension = ".$matches[2]";
$location .= "index$extension";
}
}
}
return $location;
$serverName = $this->yellow->config->get("serverName");
$serverBase = $this->yellow->config->get("serverBase");
return !empty($serverName) && $this->yellow->toolbox->isValidLocation($serverBase) && $serverBase!="/";
}
// Return static file name from location

View file

@ -5,7 +5,7 @@
// Yellow main class
class Yellow
{
const Version = "0.2.10";
const Version = "0.2.11";
var $page; //current page data
var $pages; //current page tree from file system
var $config; //configuration
@ -42,6 +42,7 @@ class Yellow
$this->config->setDefault("contentDir", "content/");
$this->config->setDefault("contentHomeDir", "home/");
$this->config->setDefault("contentDefaultFile", "page.txt");
$this->config->setDefault("contentPagination", "page");
$this->config->setDefault("contentExtension", ".txt");
$this->config->setDefault("configExtension", ".ini");
$this->config->setDefault("configFile", "config.ini");
@ -76,11 +77,7 @@ class Yellow
$statusCode = $this->processRequest($serverName, $serverBase, $location, $fileName, true, $statusCode);
}
if($statusCodeRequest > 200) $this->page->error($statusCodeRequest, "Request error");
if($this->isRequestError())
{
ob_clean();
$statusCode = $this->processRequestError();
}
if($this->isRequestError()) $statusCode = $this->processRequestError();
ob_end_flush();
$this->toolbox->timerStop($time);
if(defined("DEBUG") && DEBUG>=1) echo "Yellow::request status:$statusCode location:$location<br>\n";
@ -102,7 +99,7 @@ class Yellow
$fileName = $this->readPage($serverBase, $location, $fileName, $cacheable, $statusCode);
} else {
$statusCode = 303;
$locationArgs = $this->toolbox->getLocationArgsCleanUrl($location);
$locationArgs = $this->toolbox->getLocationArgsCleanUrl($location, $this->config->get("contentPagination"));
$this->sendStatus($statusCode, $this->toolbox->getHttpLocationHeader($serverName, $serverBase, $location.$locationArgs));
}
} else {
@ -119,19 +116,19 @@ class Yellow
$fileName = $this->readPage($serverBase, $location, $fileName, $cacheable, $statusCode);
}
if($this->page->statusCode != 0) $statusCode = $this->sendPage();
if(defined("DEBUG") && DEBUG>=1) echo "Yellow::processRequest handler:$handler base:$serverBase file:$fileName<br>\n";
if(defined("DEBUG") && DEBUG>=1) echo "Yellow::processRequest handler:$handler file:$fileName<br>\n";
return $statusCode;
}
// Process request with error
function processRequestError()
{
ob_clean();
$handler = $this->getRequestHandler();
$serverBase = $this->pages->serverBase;
$fileName = $this->readPage($serverBase, $this->page->location, $this->page->fileName, $this->page->cacheable,
$this->page->statusCode, $this->page->get("pageError"));
$fileName = $this->readPage($this->pages->serverBase, $this->page->location, $this->page->fileName,
$this->page->cacheable, $this->page->statusCode, $this->page->get("pageError"));
$statusCode = $this->sendPage();
if(defined("DEBUG") && DEBUG>=1) echo "Yellow::processRequestError handler:$handler base:$serverBase file:$fileName<br>\n";
if(defined("DEBUG") && DEBUG>=1) echo "Yellow::processRequestError handler:$handler file:$fileName<br>\n";
return $statusCode;
}
@ -165,7 +162,6 @@ class Yellow
function sendPage()
{
$this->template($this->page->get("template"));
$fileNameTemplate = $this->config->get("templateDir").$this->page->get("template").".php";
$fileNameStyle = $this->config->get("styleDir").$this->page->get("style").".css";
if(!is_file($fileNameStyle))
{
@ -175,6 +171,11 @@ class Yellow
{
$this->page->error(500, "Parser '".$this->page->get("parser")."' does not exist!");
}
list($contentType) = explode(';', $this->page->getHeader("Content-Type"));
if(!$this->toolbox->isValidContentType($contentType, $this->page->getLocation()))
{
$this->page->error(500, "Type '$contentType' does not match name!");
}
$statusCode = $this->page->statusCode;
if($statusCode==200 && $this->getRequestHandler()=="core" && $this->page->isExisting("redirect"))
{
@ -201,7 +202,9 @@ class Yellow
if(defined("DEBUG") && DEBUG>=1)
{
foreach($this->page->headerData as $key=>$value) echo "Yellow::sendPage $key: $value<br>\n";
echo "Yellow::sendPage template:$fileNameTemplate style:$fileNameStyle<br>\n";
$fileNameTemplate = $this->config->get("templateDir").$this->page->get("template").".php";
$parserName = $this->page->get("parser");
echo "Yellow::sendPage template:$fileNameTemplate style:$fileNameStyle parser:$parserName<br>\n";
}
return $statusCode;
}
@ -249,19 +252,13 @@ class Yellow
// Check if request error happened
function isRequestError()
{
$serverBase = $this->config->get("serverBase");
if(!empty($serverBase) && !$this->toolbox->isValidLocation($serverBase))
{
$this->page->error(500, "Server base '$serverBase' not supported!");
}
return $this->page->isExisting("pageError");
}
// Check if content directory exists
function isContentDirectory($location)
{
$path = $this->toolbox->findFileFromLocation($location,
$this->config->get("contentDir"), $this->config->get("contentHomeDir"), "", "");
$path = $this->toolbox->findFileFromLocation($location, $this->config->get("contentDir"), $this->config->get("contentHomeDir"), "", "");
return is_dir($path);
}
@ -749,7 +746,11 @@ class YellowPageCollection extends ArrayObject
if($reverse) $array = array_reverse($array);
$this->paginationPage = 1;
$this->paginationCount = ceil($this->count() / $limit);
if($limit < $this->count() && isset($_REQUEST["page"])) $this->paginationPage = max(1, $_REQUEST["page"]);
if($limit < $this->count())
{
$pagination = $this->yellow->config->get("contentPagination");
if(isset($_REQUEST[$pagination])) $this->paginationPage = max(1, $_REQUEST[$pagination]);
}
$this->exchangeArray(array_slice($array, ($this->paginationPage - 1) * $limit, $limit));
return $this;
}
@ -771,8 +772,10 @@ class YellowPageCollection extends ArrayObject
{
if($pageNumber>=1 && $pageNumber<=$this->paginationCount)
{
$pagination = $this->yellow->config->get("contentPagination");
$location = $this->yellow->page->getLocation();
$locationArgs = $this->yellow->toolbox->getLocationArgs($location, $pageNumber>1 ? "page:$pageNumber" : "page:");
$locationArgs = $this->yellow->toolbox->getLocationArgs($location, $pagination,
$pageNumber>1 ? "$pagination:$pageNumber" : "$pagination:");
}
return $location.$locationArgs;
}
@ -872,7 +875,7 @@ class YellowPages
return $pages;
}
// Return page collection with a specific page
// Return page collection with one specific page
function find($location, $absoluteLocation = false)
{
if($absoluteLocation) $location = substru($location, strlenu($this->serverBase));
@ -919,32 +922,9 @@ class YellowPages
{
if(defined("DEBUG") && DEBUG>=2) echo "YellowPages::scanChildren location:$location<br/>\n";
$this->pages[$location] = array();
$path = $this->yellow->config->get("contentDir");
if(!empty($location))
{
$path = $this->yellow->toolbox->findFileFromLocation($location,
$this->yellow->config->get("contentDir"), $this->yellow->config->get("contentHomeDir"), "", "");
}
$fileNames = array();
foreach($this->yellow->toolbox->getDirectoryEntries($path, "/.*/") as $entry)
{
$fileDefault = $this->yellow->config->get("contentDefaultFile");
if(!is_file($entry."/".$fileDefault))
{
$regex = "/^[\d\-\_\.]*".strreplaceu('-', '.', $fileDefault)."$/";
foreach($this->yellow->toolbox->getDirectoryEntries($entry, $regex, false, false, false) as $entry2)
{
if($this->yellow->toolbox->normaliseName($entry2) == $fileDefault) { $fileDefault = $entry2; break; }
}
}
array_push($fileNames, $entry."/".$fileDefault);
}
$fileDefault = $this->yellow->config->get("contentDefaultFile");
$regex = "/.*\\".$this->yellow->config->get("contentExtension")."/";
foreach($this->yellow->toolbox->getDirectoryEntries($path, $regex, true, false, false) as $entry)
{
if($this->yellow->toolbox->normaliseName($entry) != $fileDefault) array_push($fileNames, $path.$entry);
}
$fileNames = $this->yellow->toolbox->findChildrenFromLocation($location,
$this->yellow->config->get("contentDir"), $this->yellow->config->get("contentHomeDir"),
$this->yellow->config->get("contentDefaultFile"), $this->yellow->config->get("contentExtension"));
foreach($fileNames as $fileName)
{
$fileHandle = @fopen($fileName, "r");
@ -1259,7 +1239,7 @@ class YellowToolbox
}
// Return location arguments from current HTTP request
function getLocationArgs($location, $arg = "")
function getLocationArgs($location, $pagination, $arg = "")
{
preg_match("/^(.*?):(.*)$/", $arg, $args);
if(preg_match("/^(.*?\/)([^\/]+:.*)$/", $this->getLocation(), $matches))
@ -1283,13 +1263,14 @@ class YellowToolbox
if(!empty($locationArgs))
{
if($this->isFileLocation($location)) $locationArgs = '/'.$locationArgs;
$locationArgs = $this->normaliseLocationArgs($locationArgs, false);
if(!$this->isPaginationLocation($locationArgs, $pagination)) $locationArgs .= '/';
$locationArgs = $this->normaliseArgs($locationArgs, false, false);
}
return $locationArgs;
}
// Return location arguments from current HTTP request, convert form into clean URL
function getLocationArgsCleanUrl($location)
function getLocationArgsCleanUrl($location, $pagination)
{
foreach(array_merge($_GET, $_POST) as $key=>$value)
{
@ -1304,7 +1285,8 @@ class YellowToolbox
if(!empty($locationArgs))
{
if($this->isFileLocation($location)) $locationArgs = '/'.$locationArgs;
$locationArgs = $this->normaliseLocationArgs($locationArgs, false);
if(!$this->isPaginationLocation($locationArgs, $pagination)) $locationArgs .= '/';
$locationArgs = $this->normaliseArgs($locationArgs, false, false);
}
return $locationArgs;
}
@ -1314,17 +1296,45 @@ class YellowToolbox
{
return preg_match("/[^\/]+:.*$/", $location);
}
// Check if location contains pagination
function isPaginationLocation($location, $pagination)
{
return preg_match("/^(.*\/)?$pagination:\d*$/", $location);
}
// Check if location is specifying file or directory
function isFileLocation($location)
{
return substru($location, -1, 1) != "/";
}
// Check if file is unmodified since last HTTP request
function isFileNotModified($lastModified)
{
return isset($_SERVER["HTTP_IF_MODIFIED_SINCE"]) && $_SERVER["HTTP_IF_MODIFIED_SINCE"]==$lastModified;
}
// Check if location is specifying file or directory
function isFileLocation($location)
// Check if content type is valid for location
function isValidContentType($contentType, $location)
{
return substru($location, -1, 1) != "/";
$ok = false;
$extension = ($pos = strrposu($location, '.')) ? substru($location, $pos) : "";
if($contentType == "text/html")
{
if($this->isFileLocation($location))
{
if(empty($extension) || preg_match("/^\.(html|md)$/", $extension)) $ok = true;
} else {
$ok = true;
}
} else {
if($this->isFileLocation($location))
{
if(!empty($extension) && preg_match("/^.*$extension$/", $contentType)) $ok = true;
}
}
return $ok;
}
// Check if location is valid
@ -1360,8 +1370,25 @@ class YellowToolbox
}
return $visible;
}
// Find file path from location
// Return location from file path
function findLocationFromFile($fileName, $pathBase, $pathHome, $fileDefault, $fileExtension)
{
$location = "/";
if(substru($fileName, 0, strlenu($pathBase)) == $pathBase) $fileName = substru($fileName, strlenu($pathBase));
$tokens = explode('/', $fileName);
for($i=0; $i<count($tokens)-1; ++$i)
{
$token = $this->normaliseName($tokens[$i]).'/';
if($i || $token!=$pathHome) $location .= $token;
}
$token = $this->normaliseName($tokens[$i]);
$fileFolder = $this->normaliseName($tokens[$i-1]).$fileExtension;
if($token!=$fileDefault && $token!=$fileFolder) $location .= $this->normaliseName($tokens[$i], true);
return $location;
}
// Return file path from location
function findFileFromLocation($location, $pathBase, $pathHome, $fileDefault, $fileExtension)
{
$path = $pathBase;
@ -1382,7 +1409,7 @@ class YellowToolbox
}
} else {
$i = 1;
$token = rtrim($pathHome, '/');
$token = $tokens[0] = rtrim($pathHome, '/');
if($this->normaliseName($token) != $token) $invalid = true;
$regex = "/^[\d\-\_\.]*".strreplaceu('-', '.', $token)."$/";
foreach($this->getDirectoryEntries($path, $regex, false, true, false) as $entry)
@ -1391,40 +1418,69 @@ class YellowToolbox
}
$path .= "$token/";
}
$token = !empty($tokens[$i]) ? $tokens[$i].$fileExtension : $fileDefault;
if(!empty($tokens[$i]) && $tokens[$i].$fileExtension==$fileDefault) $invalid = true;
if($this->normaliseName($token) != $token) $invalid = true;
$regex = "/^[\d\-\_\.]*".strreplaceu('-', '.', $token)."$/";
foreach($this->getDirectoryEntries($path, $regex, false, false, false) as $entry)
if(!empty($fileDefault) && !empty($fileExtension))
{
if($this->normaliseName($entry) == $token) { $token = $entry; break; }
if(!empty($tokens[$i]))
{
$token = $tokens[$i].$fileExtension;
$fileFolder = $tokens[$i-1].$fileExtension;
if($token==$fileDefault || $token==$fileFolder) $invalid = true;
if($this->normaliseName($token) != $token) $invalid = true;
$regex = "/^[\d\-\_\.]*".strreplaceu('-', '.', $token)."$/";
foreach($this->getDirectoryEntries($path, $regex, false, false, false) as $entry)
{
if($this->normaliseName($entry) == $token) { $token = $entry; break; }
}
} else {
$token = $fileDefault;
if(!is_file($path."/".$fileDefault))
{
$fileFolder = $tokens[$i-1].$fileExtension;
$regex = "/^[\d\-\_\.]*($fileDefault|$fileFolder)$/";
foreach($this->getDirectoryEntries($path, $regex, true, false, false) as $entry)
{
if($this->normaliseName($entry) == $fileDefault) { $token = $entry; break; }
if($this->normaliseName($entry) == $fileFolder) { $token = $entry; break; }
}
}
}
$path .= $token;
}
$path .= $token;
return $invalid ? "" : $path;
}
// Find location from file path
function findLocationFromFile($fileName, $pathBase, $pathHome, $fileDefault, $fileExtension)
// Return file path of children from location
function findChildrenFromLocation($location, $pathBase, $pathHome, $fileDefault, $fileExtension)
{
$location = "/";
if(substru($fileName, 0, strlenu($pathBase)) == $pathBase) $fileName = substru($fileName, strlenu($pathBase));
$tokens = explode('/', $fileName);
for($i=0; $i<count($tokens)-1; ++$i)
$fileNames = array();
$path = empty($location) ? $pathBase : $this->findFileFromLocation($location, $pathBase, $pathHome, "", "");
foreach($this->getDirectoryEntries($path, "/.*/", true, true, false) as $entry)
{
$token = $this->normaliseName($tokens[$i]).'/';
if($i || $token!=$pathHome) $location .= $token;
$token = $fileDefault;
if(!is_file($path.$entry."/".$fileDefault))
{
$fileFolder = $this->normaliseName($entry).$fileExtension;
$regex = "/^[\d\-\_\.]*($fileDefault|$fileFolder)$/";
foreach($this->getDirectoryEntries($path.$entry, $regex, true, false, false) as $entry2)
{
if($this->normaliseName($entry2) == $fileDefault) { $token = $entry2; break; }
if($this->normaliseName($entry2) == $fileFolder) { $token = $entry2; break; }
}
}
array_push($fileNames, $path.$entry."/".$token);
}
$token = $this->normaliseName($tokens[$i]);
if($token != $fileDefault) $location .= $this->normaliseName($tokens[$i], true);
return $location;
}
// Normalise location arguments
function normaliseLocationArgs($text, $lowerCase = true)
{
if($lowerCase) $text = strreplaceu(' ', '-', strtoloweru($text));
if(!preg_match("/^(.*\/)?page:\d*$/", $text)) $text .= '/';
return strreplaceu(array('%3A','%2F'), array(':','/'), rawurlencode($text));
if(!empty($location))
{
$fileFolder = $this->normaliseName(basename($path)).$fileExtension;
$regex = "/.*\\".$fileExtension."/";
foreach($this->getDirectoryEntries($path, $regex, true, false, false) as $entry)
{
if($this->normaliseName($entry) == $fileDefault) continue;
if($this->normaliseName($entry) == $fileFolder) continue;
array_push($fileNames, $path.$entry);
}
}
return $fileNames;
}
// Normalise directory/file name
@ -1435,6 +1491,14 @@ class YellowToolbox
return preg_replace("/[^\pL\d\-\_\.]/u", "-", $text);
}
// Normalise location arguments
function normaliseArgs($text, $appendSlash = true, $lowerCase = true)
{
if($appendSlash) $text .= '/';
if($lowerCase) $text = strreplaceu(' ', '-', strtoloweru($text));
return strreplaceu(array('%3A','%2F'), array(':','/'), rawurlencode($text));
}
// Normalise text into UTF-8 NFC
function normaliseUnicode($text)
{
@ -1460,7 +1524,6 @@ class YellowToolbox
case 400: $text = "$_SERVER[SERVER_PROTOCOL] $statusCode Bad request"; break;
case 401: $text = "$_SERVER[SERVER_PROTOCOL] $statusCode Unauthorised"; break;
case 404: $text = "$_SERVER[SERVER_PROTOCOL] $statusCode Not found"; break;
case 409: $text = "$_SERVER[SERVER_PROTOCOL] $statusCode Conflict"; break;
case 424: $text = "$_SERVER[SERVER_PROTOCOL] $statusCode Does not exist"; break;
case 500: $text = "$_SERVER[SERVER_PROTOCOL] $statusCode Server error"; break;
default: $text = "$_SERVER[SERVER_PROTOCOL] $statusCode Unknown status";