2013-04-14 22:41:04 +00:00
|
|
|
<?php
|
2017-01-03 13:11:44 +00:00
|
|
|
// Copyright (c) 2013-2017 Datenstrom, http://datenstrom.se
|
2013-04-14 22:41:04 +00:00
|
|
|
// This file may be used and distributed under the terms of the public license.
|
|
|
|
|
2015-10-06 12:19:11 +00:00
|
|
|
// Web interface plugin
|
2013-12-01 11:59:07 +00:00
|
|
|
class YellowWebinterface
|
2013-04-14 22:41:04 +00:00
|
|
|
{
|
2017-01-23 10:27:02 +00:00
|
|
|
const VERSION = "0.6.19";
|
2016-08-13 15:48:18 +00:00
|
|
|
var $yellow; //access to API
|
|
|
|
var $response; //web interface response
|
|
|
|
var $users; //web interface users
|
|
|
|
var $merge; //web interface merge
|
2013-04-14 22:41:04 +00:00
|
|
|
|
2015-04-29 07:26:48 +00:00
|
|
|
// Handle initialisation
|
2013-12-01 11:59:07 +00:00
|
|
|
function onLoad($yellow)
|
2013-04-14 22:41:04 +00:00
|
|
|
{
|
|
|
|
$this->yellow = $yellow;
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->response = new YellowResponse($yellow);
|
2015-10-06 12:19:11 +00:00
|
|
|
$this->users = new YellowUsers($yellow);
|
|
|
|
$this->merge = new YellowMerge($yellow);
|
2015-12-13 09:02:43 +00:00
|
|
|
$this->yellow->config->setDefault("webinterfaceServerScheme", $this->yellow->config->get("serverScheme"));
|
2014-05-15 11:53:54 +00:00
|
|
|
$this->yellow->config->setDefault("webinterfaceServerName", $this->yellow->config->get("serverName"));
|
2016-02-20 17:34:06 +00:00
|
|
|
$this->yellow->config->setDefault("webinterfaceLocation", "/edit/");
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->yellow->config->setDefault("webinterfaceNewFile", "page-new-(.*).txt");
|
|
|
|
$this->yellow->config->setDefault("webinterfaceMetaFilePrefix", "published");
|
|
|
|
$this->yellow->config->setDefault("webinterfaceUserFile", "user.ini");
|
2016-04-12 13:58:56 +00:00
|
|
|
$this->yellow->config->setDefault("webinterfaceUserPasswordMinLength", "4");
|
2014-06-13 22:14:09 +00:00
|
|
|
$this->yellow->config->setDefault("webinterfaceUserHashAlgorithm", "bcrypt");
|
|
|
|
$this->yellow->config->setDefault("webinterfaceUserHashCost", "10");
|
2016-04-12 13:58:56 +00:00
|
|
|
$this->yellow->config->setDefault("webinterfaceUserStatus", "active");
|
2015-09-06 15:59:14 +00:00
|
|
|
$this->yellow->config->setDefault("webinterfaceUserHome", "/");
|
2013-04-14 22:41:04 +00:00
|
|
|
$this->users->load($this->yellow->config->get("configDir").$this->yellow->config->get("webinterfaceUserFile"));
|
|
|
|
}
|
|
|
|
|
2016-08-18 19:57:07 +00:00
|
|
|
// Handle update
|
|
|
|
function onUpdate($name)
|
|
|
|
{
|
2017-01-03 13:11:44 +00:00
|
|
|
if($name=="webinterface") $this->cleanCommand(array("clean", "all"));
|
2016-08-18 19:57:07 +00:00
|
|
|
}
|
|
|
|
|
2014-05-29 21:33:01 +00:00
|
|
|
// Handle request
|
2014-05-15 11:53:54 +00:00
|
|
|
function onRequest($serverScheme, $serverName, $base, $location, $fileName)
|
2013-04-14 22:41:04 +00:00
|
|
|
{
|
|
|
|
$statusCode = 0;
|
2016-06-27 13:28:10 +00:00
|
|
|
if($this->checkRequest($location))
|
2013-04-14 22:41:04 +00:00
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
$serverScheme = $this->yellow->config->get("webinterfaceServerScheme");
|
|
|
|
$serverName = $this->yellow->config->get("webinterfaceServerName");
|
|
|
|
$base = rtrim($this->yellow->config->get("serverBase").$this->yellow->config->get("webinterfaceLocation"), '/');
|
|
|
|
list($serverScheme, $serverName, $base, $location, $fileName) = $this->yellow->getRequestInformation($serverScheme, $serverName, $base);
|
|
|
|
$this->yellow->page->setRequestInformation($serverScheme, $serverName, $base, $location, $fileName);
|
2014-07-25 10:46:58 +00:00
|
|
|
$statusCode = $this->processRequest($serverScheme, $serverName, $base, $location, $fileName);
|
2013-04-14 22:41:04 +00:00
|
|
|
}
|
|
|
|
return $statusCode;
|
|
|
|
}
|
|
|
|
|
2014-01-27 11:30:39 +00:00
|
|
|
// Handle page meta data parsing
|
2015-04-29 07:26:48 +00:00
|
|
|
function onParseMeta($page)
|
2014-01-27 11:30:39 +00:00
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
if($page==$this->yellow->page && $this->response->isActive())
|
2014-01-27 11:30:39 +00:00
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
if($this->response->isUser())
|
2014-01-27 11:30:39 +00:00
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
if(empty($this->response->rawDataSource)) $this->response->rawDataSource = $page->rawData;
|
|
|
|
if(empty($this->response->rawDataEdit)) $this->response->rawDataEdit = $page->rawData;
|
|
|
|
if($page->statusCode==424) $this->response->rawDataEdit = $this->response->getRawDataNew($page->location);
|
2014-01-27 11:30:39 +00:00
|
|
|
}
|
2016-08-13 15:48:18 +00:00
|
|
|
if(empty($this->response->language)) $this->response->language = $page->get("language");
|
|
|
|
if(empty($this->response->action)) $this->response->action = $this->response->isUser() ? "none" : "login";
|
|
|
|
if(empty($this->response->status)) $this->response->status = "none";
|
|
|
|
if($this->response->status=="error") $this->response->action = "error";
|
2014-01-27 11:30:39 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-05-26 08:27:28 +00:00
|
|
|
// Handle page content parsing of custom block
|
2015-06-10 15:13:17 +00:00
|
|
|
function onParseContentBlock($page, $name, $text, $shortcut)
|
2015-05-26 08:27:28 +00:00
|
|
|
{
|
2016-07-19 22:12:05 +00:00
|
|
|
$output = null;
|
2015-06-10 15:13:17 +00:00
|
|
|
if($name=="edit" && $shortcut)
|
2015-05-26 08:27:28 +00:00
|
|
|
{
|
|
|
|
$editText = "$name $text";
|
|
|
|
if(substru($text, 0, 2)=="- ") $editText = trim(substru($text, 2));
|
|
|
|
$output = "<a href=\"".$page->get("pageEdit")."\">".htmlspecialchars($editText)."</a>";
|
|
|
|
}
|
|
|
|
return $output;
|
|
|
|
}
|
|
|
|
|
2015-04-29 07:26:48 +00:00
|
|
|
// Handle page extra HTML data
|
2015-05-04 11:11:33 +00:00
|
|
|
function onExtra($name)
|
2013-04-14 22:41:04 +00:00
|
|
|
{
|
2016-07-19 22:12:05 +00:00
|
|
|
$output = null;
|
2016-08-13 15:48:18 +00:00
|
|
|
if($name=="header" && $this->response->isActive())
|
2013-04-14 22:41:04 +00:00
|
|
|
{
|
2016-04-12 13:58:56 +00:00
|
|
|
$location = $this->yellow->config->get("serverBase").$this->yellow->config->get("pluginLocation")."webinterface";
|
|
|
|
$output = "<link rel=\"stylesheet\" type=\"text/css\" media=\"all\" href=\"".htmlspecialchars($location).".css\" />\n";
|
|
|
|
$output .= "<script type=\"text/javascript\" src=\"".htmlspecialchars($location).".js\"></script>\n";
|
|
|
|
$output .= "<script type=\"text/javascript\">\n";
|
|
|
|
$output .= "// <![CDATA[\n";
|
2016-08-13 15:48:18 +00:00
|
|
|
$output .= "yellow.page = ".json_encode($this->response->getPageData()).";\n";
|
|
|
|
$output .= "yellow.config = ".json_encode($this->response->getConfigData()).";\n";
|
|
|
|
$output .= "yellow.text = ".json_encode($this->response->getTextData()).";\n";
|
2016-04-12 13:58:56 +00:00
|
|
|
$output .= "// ]]>\n";
|
|
|
|
$output .= "</script>\n";
|
2013-04-14 22:41:04 +00:00
|
|
|
}
|
2015-04-29 07:26:48 +00:00
|
|
|
return $output;
|
2013-12-21 13:10:15 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Handle command
|
|
|
|
function onCommand($args)
|
|
|
|
{
|
2016-06-27 13:28:10 +00:00
|
|
|
list($command) = $args;
|
2013-12-21 13:10:15 +00:00
|
|
|
switch($command)
|
|
|
|
{
|
2016-06-02 15:31:42 +00:00
|
|
|
case "clean": $statusCode = $this->cleanCommand($args); break;
|
2013-12-21 13:10:15 +00:00
|
|
|
case "user": $statusCode = $this->userCommand($args); break;
|
|
|
|
default: $statusCode = 0;
|
|
|
|
}
|
|
|
|
return $statusCode;
|
|
|
|
}
|
|
|
|
|
2015-04-29 07:26:48 +00:00
|
|
|
// Handle command help
|
|
|
|
function onCommandHelp()
|
|
|
|
{
|
2016-07-03 21:13:24 +00:00
|
|
|
return "user [EMAIL PASSWORD NAME LANGUAGE]\n";
|
2015-04-29 07:26:48 +00:00
|
|
|
}
|
2016-06-02 15:31:42 +00:00
|
|
|
|
|
|
|
// Clean user accounts
|
|
|
|
function cleanCommand($args)
|
|
|
|
{
|
2016-06-27 13:28:10 +00:00
|
|
|
$statusCode = 0;
|
2016-07-15 16:35:11 +00:00
|
|
|
list($command, $path) = $args;
|
2016-07-19 22:12:05 +00:00
|
|
|
if($path=="all")
|
2016-07-15 16:35:11 +00:00
|
|
|
{
|
|
|
|
$fileNameUser = $this->yellow->config->get("configDir").$this->yellow->config->get("webinterfaceUserFile");
|
|
|
|
if(!$this->users->clean($fileNameUser)) $statusCode = 500;
|
2016-07-19 22:12:05 +00:00
|
|
|
if($statusCode==500) echo "ERROR cleaning configuration: Can't write file '$fileNameUser'!\n";
|
2016-07-15 16:35:11 +00:00
|
|
|
}
|
2016-07-03 21:13:24 +00:00
|
|
|
return $statusCode;
|
2016-06-02 15:31:42 +00:00
|
|
|
}
|
2015-04-29 07:26:48 +00:00
|
|
|
|
2015-08-09 20:17:17 +00:00
|
|
|
// Update user account
|
2013-12-21 13:10:15 +00:00
|
|
|
function userCommand($args)
|
|
|
|
{
|
|
|
|
$statusCode = 0;
|
2016-07-03 21:13:24 +00:00
|
|
|
list($command, $email, $password, $name, $language) = $args;
|
2015-10-06 12:19:11 +00:00
|
|
|
if(!empty($email) && !empty($password))
|
|
|
|
{
|
2016-04-12 13:58:56 +00:00
|
|
|
$userExisting = $this->users->isExisting($email);
|
|
|
|
$status = $this->getUserAccount($email, $password, $command);
|
|
|
|
switch($status)
|
2014-05-04 12:57:52 +00:00
|
|
|
{
|
2016-04-12 13:58:56 +00:00
|
|
|
case "invalid": echo "ERROR updating configuration: Please enter a valid email!\n"; break;
|
|
|
|
case "weak": echo "ERROR updating configuration: Please enter a different password!\n"; break;
|
2014-05-04 12:57:52 +00:00
|
|
|
}
|
2016-07-19 22:12:05 +00:00
|
|
|
if($status=="ok")
|
2016-04-12 13:58:56 +00:00
|
|
|
{
|
|
|
|
$fileNameUser = $this->yellow->config->get("configDir").$this->yellow->config->get("webinterfaceUserFile");
|
2016-07-03 21:13:24 +00:00
|
|
|
$status = $this->users->update($fileNameUser, $email, $password, $name, $language, "active") ? "ok" : "error";
|
2016-07-19 22:12:05 +00:00
|
|
|
if($status=="error") echo "ERROR updating configuration: Can't write file '$fileNameUser'!\n";
|
2016-04-12 13:58:56 +00:00
|
|
|
}
|
2016-07-19 22:12:05 +00:00
|
|
|
if($status=="ok")
|
2016-04-12 13:58:56 +00:00
|
|
|
{
|
|
|
|
$algorithm = $this->yellow->config->get("webinterfaceUserHashAlgorithm");
|
|
|
|
$status = substru($this->users->getHash($email), 0, 5)!="error-hash" ? "ok" : "error";
|
2016-07-19 22:12:05 +00:00
|
|
|
if($status=="error") echo "ERROR updating configuration: Hash algorithm '$algorithm' not supported!\n";
|
2016-04-12 13:58:56 +00:00
|
|
|
}
|
|
|
|
$statusCode = $status=="ok" ? 200 : 500;
|
2015-10-06 12:19:11 +00:00
|
|
|
echo "Yellow $command: User account ".($statusCode!=200 ? "not " : "");
|
2016-04-12 13:58:56 +00:00
|
|
|
echo ($userExisting ? "updated" : "created")."\n";
|
2013-12-21 13:10:15 +00:00
|
|
|
} else {
|
2015-10-06 12:19:11 +00:00
|
|
|
$statusCode = 200;
|
2016-08-13 15:48:18 +00:00
|
|
|
foreach($this->users->getData() as $line) echo "$line\n";
|
2015-10-06 12:19:11 +00:00
|
|
|
if(!$this->users->getNumber()) echo "Yellow $command: No user accounts\n";
|
2013-12-21 13:10:15 +00:00
|
|
|
}
|
|
|
|
return $statusCode;
|
|
|
|
}
|
|
|
|
|
2014-07-25 10:46:58 +00:00
|
|
|
// Process request
|
|
|
|
function processRequest($serverScheme, $serverName, $base, $location, $fileName)
|
|
|
|
{
|
|
|
|
$statusCode = 0;
|
2017-01-05 09:39:42 +00:00
|
|
|
if($this->checkUser($serverScheme, $serverName, $base, $location, $fileName))
|
2014-07-25 10:46:58 +00:00
|
|
|
{
|
2016-04-12 13:58:56 +00:00
|
|
|
switch($_REQUEST["action"])
|
|
|
|
{
|
|
|
|
case "": $statusCode = $this->processRequestShow($serverScheme, $serverName, $base, $location, $fileName); break;
|
|
|
|
case "login": $statusCode = $this->processRequestLogin($serverScheme, $serverName, $base, $location, $fileName); break;
|
|
|
|
case "logout": $statusCode = $this->processRequestLogout($serverScheme, $serverName, $base, $location, $fileName); break;
|
|
|
|
case "signup": $statusCode = $this->processRequestSignup($serverScheme, $serverName, $base, $location, $fileName); break;
|
|
|
|
case "confirm": $statusCode = $this->processRequestConfirm($serverScheme, $serverName, $base, $location, $fileName); break;
|
|
|
|
case "approve": $statusCode = $this->processRequestApprove($serverScheme, $serverName, $base, $location, $fileName); break;
|
|
|
|
case "recover": $statusCode = $this->processRequestRecover($serverScheme, $serverName, $base, $location, $fileName); break;
|
2016-05-15 16:35:10 +00:00
|
|
|
case "settings": $statusCode = $this->processRequestSettings($serverScheme, $serverName, $base, $location, $fileName); break;
|
2016-08-13 15:48:18 +00:00
|
|
|
case "reconfirm": $statusCode = $this->processRequestReconfirm($serverScheme, $serverName, $base, $location, $fileName); break;
|
|
|
|
case "change": $statusCode = $this->processRequestChange($serverScheme, $serverName, $base, $location, $fileName); break;
|
2016-08-16 08:16:13 +00:00
|
|
|
case "version": $statusCode = $this->processRequestVersion($serverScheme, $serverName, $base, $location, $fileName); break;
|
|
|
|
case "update": $statusCode = $this->processRequestUpdate($serverScheme, $serverName, $base, $location, $fileName); break;
|
2016-04-12 13:58:56 +00:00
|
|
|
case "create": $statusCode = $this->processRequestCreate($serverScheme, $serverName, $base, $location, $fileName); break;
|
|
|
|
case "edit": $statusCode = $this->processRequestEdit($serverScheme, $serverName, $base, $location, $fileName); break;
|
|
|
|
case "delete": $statusCode = $this->processRequestDelete($serverScheme, $serverName, $base, $location, $fileName); break;
|
|
|
|
}
|
|
|
|
} else {
|
2017-01-05 09:39:42 +00:00
|
|
|
$this->yellow->pages->requestHandler = "core";
|
2016-04-12 13:58:56 +00:00
|
|
|
switch($_REQUEST["action"])
|
2014-07-25 10:46:58 +00:00
|
|
|
{
|
2017-01-05 09:39:42 +00:00
|
|
|
case "": $statusCode = $this->processRequestShow($serverScheme, $serverName, $base, $location, $fileName); break;
|
2016-04-12 13:58:56 +00:00
|
|
|
case "signup": $statusCode = $this->processRequestSignup($serverScheme, $serverName, $base, $location, $fileName); break;
|
|
|
|
case "confirm": $statusCode = $this->processRequestConfirm($serverScheme, $serverName, $base, $location, $fileName); break;
|
|
|
|
case "approve": $statusCode = $this->processRequestApprove($serverScheme, $serverName, $base, $location, $fileName); break;
|
|
|
|
case "recover": $statusCode = $this->processRequestRecover($serverScheme, $serverName, $base, $location, $fileName); break;
|
2016-08-13 15:48:18 +00:00
|
|
|
case "reconfirm": $statusCode = $this->processRequestReconfirm($serverScheme, $serverName, $base, $location, $fileName); break;
|
|
|
|
case "change": $statusCode = $this->processRequestChange($serverScheme, $serverName, $base, $location, $fileName); break;
|
2014-07-25 10:46:58 +00:00
|
|
|
}
|
2016-08-13 15:48:18 +00:00
|
|
|
if($this->response->action=="fail") $this->yellow->page->error(500, "Login failed, [please log in](javascript:yellow.action('login');)!");
|
2014-07-25 10:46:58 +00:00
|
|
|
}
|
|
|
|
return $statusCode;
|
|
|
|
}
|
|
|
|
|
2017-01-05 09:39:42 +00:00
|
|
|
// Process request to show file
|
2014-07-25 10:46:58 +00:00
|
|
|
function processRequestShow($serverScheme, $serverName, $base, $location, $fileName)
|
|
|
|
{
|
|
|
|
$statusCode = 0;
|
|
|
|
if(is_readable($fileName))
|
|
|
|
{
|
2015-01-19 19:05:51 +00:00
|
|
|
$statusCode = $this->yellow->processRequest($serverScheme, $serverName, $base, $location, $fileName, false);
|
2014-07-25 10:46:58 +00:00
|
|
|
} else {
|
2017-01-03 13:11:44 +00:00
|
|
|
if($this->yellow->lookup->isRedirectLocation($location))
|
2014-07-25 10:46:58 +00:00
|
|
|
{
|
|
|
|
$statusCode = 301;
|
2017-01-03 13:11:44 +00:00
|
|
|
$location = $this->yellow->lookup->isFileLocation($location) ? "$location/" : "/".$this->yellow->getRequestLanguage()."/";
|
2015-04-29 07:26:48 +00:00
|
|
|
$location = $this->yellow->lookup->normaliseUrl($serverScheme, $serverName, $base, $location);
|
|
|
|
$this->yellow->sendStatus($statusCode, $location);
|
2014-07-25 10:46:58 +00:00
|
|
|
} else {
|
2016-08-13 15:48:18 +00:00
|
|
|
$statusCode = $this->response->isUserRestrictions() ? 404 : 424;
|
2015-01-19 19:05:51 +00:00
|
|
|
$this->yellow->processRequest($serverScheme, $serverName, $base, $location, $fileName, false);
|
|
|
|
$this->yellow->page->error($statusCode);
|
2014-07-25 10:46:58 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return $statusCode;
|
|
|
|
}
|
|
|
|
|
2016-04-12 13:58:56 +00:00
|
|
|
// Process request for user login
|
|
|
|
function processRequestLogin($serverScheme, $serverName, $base, $location, $fileName)
|
|
|
|
{
|
|
|
|
$statusCode = 0;
|
2016-08-13 15:48:18 +00:00
|
|
|
$home = $this->users->getHome($this->response->userEmail);
|
2016-07-19 22:12:05 +00:00
|
|
|
if(substru($location, 0, strlenu($home))==$home)
|
2016-04-12 13:58:56 +00:00
|
|
|
{
|
|
|
|
$statusCode = 303;
|
|
|
|
$location = $this->yellow->lookup->normaliseUrl($serverScheme, $serverName, $base, $location);
|
|
|
|
$this->yellow->sendStatus($statusCode, $location);
|
|
|
|
} else {
|
|
|
|
$statusCode = 302;
|
|
|
|
$location = $this->yellow->lookup->normaliseUrl($serverScheme, $serverName, $base, $home);
|
|
|
|
$this->yellow->sendStatus($statusCode, $location);
|
|
|
|
}
|
|
|
|
return $statusCode;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Process request for user logout
|
|
|
|
function processRequestLogout($serverScheme, $serverName, $base, $location, $fileName)
|
|
|
|
{
|
|
|
|
$statusCode = 302;
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->response->userEmail = "";
|
2017-01-05 09:39:42 +00:00
|
|
|
$this->response->destroyCookie($serverScheme, $serverName, $base);
|
2016-04-12 13:58:56 +00:00
|
|
|
$location = $this->yellow->lookup->normaliseUrl(
|
|
|
|
$this->yellow->config->get("serverScheme"),
|
|
|
|
$this->yellow->config->get("serverName"),
|
|
|
|
$this->yellow->config->get("serverBase"), $location);
|
|
|
|
$this->yellow->sendStatus($statusCode, $location);
|
|
|
|
return $statusCode;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Process request for user signup
|
|
|
|
function processRequestSignup($serverScheme, $serverName, $base, $location, $fileName)
|
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->response->action = "signup";
|
|
|
|
$this->response->status = "ok";
|
2016-04-12 13:58:56 +00:00
|
|
|
$name = trim(preg_replace("/[^\pL\d\-\. ]/u", "-", $_REQUEST["name"]));
|
|
|
|
$email = trim($_REQUEST["email"]);
|
|
|
|
$password = trim($_REQUEST["password"]);
|
2016-08-13 15:48:18 +00:00
|
|
|
if(empty($name) || empty($email) || empty($password)) $this->response->status = "incomplete";
|
|
|
|
if($this->response->status=="ok") $this->response->status = $this->getUserAccount($email, $password, $this->response->action);
|
|
|
|
if($this->response->status=="ok" && $this->response->isLoginRestrictions()) $this->response->status = "next";
|
2016-08-16 08:16:13 +00:00
|
|
|
if($this->response->status=="ok" && $this->users->isTaken($email)) $this->response->status = "next";
|
2016-08-13 15:48:18 +00:00
|
|
|
if($this->response->status=="ok")
|
2016-04-12 13:58:56 +00:00
|
|
|
{
|
|
|
|
$fileNameUser = $this->yellow->config->get("configDir").$this->yellow->config->get("webinterfaceUserFile");
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->response->status = $this->users->update($fileNameUser, $email, $password, $name, "", "unconfirmed") ? "ok" : "error";
|
|
|
|
if($this->response->status=="error") $this->yellow->page->error(500, "Can't write file '$fileNameUser'!");
|
2016-04-12 13:58:56 +00:00
|
|
|
}
|
2016-08-13 15:48:18 +00:00
|
|
|
if($this->response->status=="ok")
|
2016-04-12 13:58:56 +00:00
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->response->status = $this->response->sendMail($serverScheme, $serverName, $base, $email, "confirm") ? "next" : "error";
|
|
|
|
if($this->response->status=="error") $this->yellow->page->error(500, "Can't send email on this server!");
|
2016-04-12 13:58:56 +00:00
|
|
|
}
|
|
|
|
$statusCode = $this->yellow->processRequest($serverScheme, $serverName, $base, $location, $fileName, false);
|
|
|
|
return $statusCode;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Process request to confirm user signup
|
|
|
|
function processRequestConfirm($serverScheme, $serverName, $base, $location, $fileName)
|
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->response->action = "confirm";
|
|
|
|
$this->response->status = "ok";
|
2016-04-12 13:58:56 +00:00
|
|
|
$email = $_REQUEST["email"];
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->response->status = $this->users->getResponseStatus($email, $_REQUEST["action"], $_REQUEST["expire"], $_REQUEST["id"]);
|
|
|
|
if($this->response->status=="ok")
|
2016-04-12 13:58:56 +00:00
|
|
|
{
|
|
|
|
$fileNameUser = $this->yellow->config->get("configDir").$this->yellow->config->get("webinterfaceUserFile");
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->response->status = $this->users->update($fileNameUser, $email, "", "", "", "unapproved") ? "ok" : "error";
|
|
|
|
if($this->response->status=="error") $this->yellow->page->error(500, "Can't write file '$fileNameUser'!");
|
2016-04-12 13:58:56 +00:00
|
|
|
}
|
2016-08-13 15:48:18 +00:00
|
|
|
if($this->response->status=="ok")
|
2016-04-12 13:58:56 +00:00
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->response->status = $this->response->sendMail($serverScheme, $serverName, $base, $email, "approve") ? "done" : "error";
|
|
|
|
if($this->response->status=="error") $this->yellow->page->error(500, "Can't send email on this server!");
|
2016-04-12 13:58:56 +00:00
|
|
|
}
|
|
|
|
$statusCode = $this->yellow->processRequest($serverScheme, $serverName, $base, $location, $fileName, false);
|
|
|
|
return $statusCode;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Process request to approve user signup
|
|
|
|
function processRequestApprove($serverScheme, $serverName, $base, $location, $fileName)
|
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->response->action = "approve";
|
|
|
|
$this->response->status = "ok";
|
2016-04-12 13:58:56 +00:00
|
|
|
$email = $_REQUEST["email"];
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->response->status = $this->users->getResponseStatus($email, $_REQUEST["action"], $_REQUEST["expire"], $_REQUEST["id"]);
|
|
|
|
if($this->response->status=="ok")
|
2016-04-12 13:58:56 +00:00
|
|
|
{
|
|
|
|
$fileNameUser = $this->yellow->config->get("configDir").$this->yellow->config->get("webinterfaceUserFile");
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->response->status = $this->users->update($fileNameUser, $email, "", "", "", "active") ? "ok" : "error";
|
|
|
|
if($this->response->status=="error") $this->yellow->page->error(500, "Can't write file '$fileNameUser'!");
|
2016-04-12 13:58:56 +00:00
|
|
|
}
|
2016-08-13 15:48:18 +00:00
|
|
|
if($this->response->status=="ok")
|
2016-04-12 13:58:56 +00:00
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->response->status = $this->response->sendMail($serverScheme, $serverName, $base, $email, "welcome") ? "done" : "error";
|
|
|
|
if($this->response->status=="error") $this->yellow->page->error(500, "Can't send email on this server!");
|
2016-04-12 13:58:56 +00:00
|
|
|
}
|
|
|
|
$statusCode = $this->yellow->processRequest($serverScheme, $serverName, $base, $location, $fileName, false);
|
|
|
|
return $statusCode;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Process request to recover password
|
|
|
|
function processRequestRecover($serverScheme, $serverName, $base, $location, $fileName)
|
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->response->action = "recover";
|
|
|
|
$this->response->status = "ok";
|
2016-04-12 13:58:56 +00:00
|
|
|
$email = trim($_REQUEST["email"]);
|
|
|
|
$password = trim($_REQUEST["password"]);
|
|
|
|
if(empty($_REQUEST["id"]))
|
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
if(!filter_var($email, FILTER_VALIDATE_EMAIL)) $this->response->status = "invalid";
|
|
|
|
if($this->response->status=="ok" && $this->response->isLoginRestrictions()) $this->response->status = "next";
|
|
|
|
if($this->response->status=="ok" && !$this->users->isExisting($email)) $this->response->status = "next";
|
|
|
|
if($this->response->status=="ok")
|
2016-04-12 13:58:56 +00:00
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->response->status = $this->response->sendMail($serverScheme, $serverName, $base, $email, "recover") ? "next" : "error";
|
|
|
|
if($this->response->status=="error") $this->yellow->page->error(500, "Can't send email on this server!");
|
2016-04-12 13:58:56 +00:00
|
|
|
}
|
|
|
|
} else {
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->response->status = $this->users->getResponseStatus($email, $_REQUEST["action"], $_REQUEST["expire"], $_REQUEST["id"]);
|
|
|
|
if($this->response->status=="ok")
|
2016-04-12 13:58:56 +00:00
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
if(empty($password)) $this->response->status = "password";
|
|
|
|
if($this->response->status=="ok") $this->response->status = $this->getUserAccount($email, $password, $this->response->action);
|
|
|
|
if($this->response->status=="ok")
|
2016-04-12 13:58:56 +00:00
|
|
|
{
|
|
|
|
$fileNameUser = $this->yellow->config->get("configDir").$this->yellow->config->get("webinterfaceUserFile");
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->response->status = $this->users->update($fileNameUser, $email, $password) ? "ok" : "error";
|
|
|
|
if($this->response->status=="error") $this->yellow->page->error(500, "Can't write file '$fileNameUser'!");
|
2016-04-12 13:58:56 +00:00
|
|
|
}
|
2016-08-13 15:48:18 +00:00
|
|
|
if($this->response->status=="ok")
|
2016-04-12 13:58:56 +00:00
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->response->userEmail = "";
|
2017-01-05 09:39:42 +00:00
|
|
|
$this->response->destroyCookie($serverScheme, $serverName, $base);
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->response->status = $this->response->sendMail($serverScheme, $serverName, $base, $email, "information") ? "done" : "error";
|
|
|
|
if($this->response->status=="error") $this->yellow->page->error(500, "Can't send email on this server!");
|
2016-04-12 13:58:56 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$statusCode = $this->yellow->processRequest($serverScheme, $serverName, $base, $location, $fileName, false);
|
|
|
|
return $statusCode;
|
|
|
|
}
|
2016-08-13 15:48:18 +00:00
|
|
|
|
2016-05-15 16:35:10 +00:00
|
|
|
// Process request to change settings
|
|
|
|
function processRequestSettings($serverScheme, $serverName, $base, $location, $fileName)
|
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->response->action = "settings";
|
|
|
|
$this->response->status = "ok";
|
|
|
|
$email = trim($_REQUEST["email"]);
|
|
|
|
$emailSource = $this->response->userEmail;
|
|
|
|
$password = trim($_REQUEST["password"]);
|
|
|
|
$name = trim(preg_replace("/[^\pL\d\-\. ]/u", "-", $_REQUEST["name"]));
|
|
|
|
$language = trim($_REQUEST["language"]);
|
|
|
|
if($email!=$emailSource || !empty($password))
|
2016-05-15 16:35:10 +00:00
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
if(empty($email)) $this->response->status = "invalid";
|
|
|
|
if($this->response->status=="ok") $this->response->status = $this->getUserAccount($email, $password, $this->response->action);
|
2016-08-16 08:16:13 +00:00
|
|
|
if($this->response->status=="ok" && $email!=$emailSource && $this->users->isTaken($email)) $this->response->status = "taken";
|
2016-08-13 15:48:18 +00:00
|
|
|
if($this->response->status=="ok" && $email!=$emailSource)
|
|
|
|
{
|
|
|
|
$pending = $emailSource;
|
|
|
|
$fileNameUser = $this->yellow->config->get("configDir").$this->yellow->config->get("webinterfaceUserFile");
|
2016-08-16 08:16:13 +00:00
|
|
|
$this->response->status = $this->users->update($fileNameUser, $email, "no", $name, $language, "unconfirmed", "", $pending) ? "ok" : "error";
|
2016-08-13 15:48:18 +00:00
|
|
|
if($this->response->status=="error") $this->yellow->page->error(500, "Can't write file '$fileNameUser'!");
|
|
|
|
}
|
|
|
|
if($this->response->status=="ok")
|
|
|
|
{
|
|
|
|
$pending = $email.':'.(empty($password) ? $this->users->getHash($emailSource) : $this->users->createHash($password));
|
|
|
|
$fileNameUser = $this->yellow->config->get("configDir").$this->yellow->config->get("webinterfaceUserFile");
|
2016-08-16 08:16:13 +00:00
|
|
|
$this->response->status = $this->users->update($fileNameUser, $emailSource, "", $name, $language, "", "", $pending) ? "ok" : "error";
|
2016-08-13 15:48:18 +00:00
|
|
|
if($this->response->status=="error") $this->yellow->page->error(500, "Can't write file '$fileNameUser'!");
|
|
|
|
}
|
|
|
|
if($this->response->status=="ok")
|
|
|
|
{
|
|
|
|
$action = $email!=$emailSource ? "reconfirm" : "change";
|
|
|
|
$this->response->status = $this->response->sendMail($serverScheme, $serverName, $base, $email, $action) ? "next" : "error";
|
|
|
|
if($this->response->status=="error") $this->yellow->page->error(500, "Can't send email on this server!");
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if($this->response->status=="ok")
|
|
|
|
{
|
|
|
|
$fileNameUser = $this->yellow->config->get("configDir").$this->yellow->config->get("webinterfaceUserFile");
|
|
|
|
$this->response->status = $this->users->update($fileNameUser, $email, "", $name, $language) ? "done" : "error";
|
|
|
|
if($this->response->status=="error") $this->yellow->page->error(500, "Can't write file '$fileNameUser'!");
|
|
|
|
}
|
2016-06-02 15:31:42 +00:00
|
|
|
}
|
2016-08-13 15:48:18 +00:00
|
|
|
if($this->response->status=="done")
|
2016-06-02 15:31:42 +00:00
|
|
|
{
|
|
|
|
$statusCode = 303;
|
|
|
|
$location = $this->yellow->lookup->normaliseUrl($serverScheme, $serverName, $base, $location);
|
|
|
|
$this->yellow->sendStatus($statusCode, $location);
|
|
|
|
} else {
|
|
|
|
$statusCode = $this->yellow->processRequest($serverScheme, $serverName, $base, $location, $fileName, false);
|
2016-05-15 16:35:10 +00:00
|
|
|
}
|
|
|
|
return $statusCode;
|
|
|
|
}
|
2016-08-13 15:48:18 +00:00
|
|
|
|
|
|
|
// Process request to reconfirm email
|
|
|
|
function processRequestReconfirm($serverScheme, $serverName, $base, $location, $fileName)
|
|
|
|
{
|
|
|
|
$this->response->action = "reconfirm";
|
|
|
|
$this->response->status = "ok";
|
|
|
|
$email = $emailSource = $_REQUEST["email"];
|
|
|
|
$this->response->status = $this->users->getResponseStatus($email, $_REQUEST["action"], $_REQUEST["expire"], $_REQUEST["id"]);
|
|
|
|
if($this->response->status=="ok")
|
|
|
|
{
|
|
|
|
$emailSource = $this->users->getPending($email);
|
2016-08-16 08:16:13 +00:00
|
|
|
if($this->users->getStatus($emailSource)!="active") $this->response->status = "done";
|
2016-08-13 15:48:18 +00:00
|
|
|
}
|
|
|
|
if($this->response->status=="ok")
|
|
|
|
{
|
|
|
|
$fileNameUser = $this->yellow->config->get("configDir").$this->yellow->config->get("webinterfaceUserFile");
|
|
|
|
$this->response->status = $this->users->update($fileNameUser, $email, "", "", "", "unchanged") ? "ok" : "error";
|
|
|
|
if($this->response->status=="error") $this->yellow->page->error(500, "Can't write file '$fileNameUser'!");
|
|
|
|
}
|
|
|
|
if($this->response->status=="ok")
|
|
|
|
{
|
|
|
|
$this->response->status = $this->response->sendMail($serverScheme, $serverName, $base, $emailSource, "change") ? "done" : "error";
|
|
|
|
if($this->response->status=="error") $this->yellow->page->error(500, "Can't send email on this server!");
|
|
|
|
}
|
|
|
|
$statusCode = $this->yellow->processRequest($serverScheme, $serverName, $base, $location, $fileName, false);
|
|
|
|
return $statusCode;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Process request to change settings
|
|
|
|
function processRequestChange($serverScheme, $serverName, $base, $location, $fileName)
|
|
|
|
{
|
|
|
|
$this->response->action = "change";
|
|
|
|
$this->response->status = "ok";
|
|
|
|
$email = $emailSource = trim($_REQUEST["email"]);
|
|
|
|
$this->response->status = $this->users->getResponseStatus($email, $_REQUEST["action"], $_REQUEST["expire"], $_REQUEST["id"]);
|
|
|
|
if($this->response->status=="ok")
|
|
|
|
{
|
|
|
|
list($email, $hash) = explode(':', $this->users->getPending($email), 2);
|
|
|
|
if(!$this->users->isExisting($email) || empty($hash)) $this->response->status = "done";
|
|
|
|
}
|
|
|
|
if($this->response->status=="ok" && $email!=$emailSource)
|
|
|
|
{
|
|
|
|
$fileNameUser = $this->yellow->config->get("configDir").$this->yellow->config->get("webinterfaceUserFile");
|
2017-01-03 13:11:44 +00:00
|
|
|
$this->users->users[$emailSource]["pending"] = "none";
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->response->status = $this->users->update($fileNameUser, $emailSource, "", "", "", "inactive") ? "ok" : "error";
|
|
|
|
if($this->response->status=="error") $this->yellow->page->error(500, "Can't write file '$fileNameUser'!");
|
|
|
|
}
|
|
|
|
if($this->response->status=="ok")
|
|
|
|
{
|
|
|
|
$this->users->users[$email]["hash"] = $hash;
|
2017-01-03 13:11:44 +00:00
|
|
|
$this->users->users[$email]["pending"] = "none";
|
2016-08-13 15:48:18 +00:00
|
|
|
$fileNameUser = $this->yellow->config->get("configDir").$this->yellow->config->get("webinterfaceUserFile");
|
|
|
|
$this->response->status = $this->users->update($fileNameUser, $email, "", "", "", "active") ? "ok" : "error";
|
|
|
|
if($this->response->status=="error") $this->yellow->page->error(500, "Can't write file '$fileNameUser'!");
|
|
|
|
}
|
|
|
|
if($this->response->status=="ok")
|
|
|
|
{
|
|
|
|
$this->response->userEmail = "";
|
2017-01-05 09:39:42 +00:00
|
|
|
$this->response->destroyCookie($serverScheme, $serverName, $base);
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->response->status = $this->response->sendMail($serverScheme, $serverName, $base, $email, "information") ? "done" : "error";
|
|
|
|
if($this->response->status=="error") $this->yellow->page->error(500, "Can't send email on this server!");
|
|
|
|
}
|
|
|
|
$statusCode = $this->yellow->processRequest($serverScheme, $serverName, $base, $location, $fileName, false);
|
|
|
|
return $statusCode;
|
|
|
|
}
|
2016-04-12 13:58:56 +00:00
|
|
|
|
2016-08-18 19:57:07 +00:00
|
|
|
// Process request to show software version
|
2016-08-16 08:16:13 +00:00
|
|
|
function processRequestVersion($serverScheme, $serverName, $base, $location, $fileName)
|
|
|
|
{
|
|
|
|
$this->response->action = "version";
|
|
|
|
$this->response->status = "ok";
|
|
|
|
if($this->yellow->plugins->isExisting("update"))
|
|
|
|
{
|
|
|
|
list($statusCode, $dataCurrent) = $this->yellow->plugins->get("update")->getSoftwareVersion();
|
|
|
|
list($statusCode, $dataLatest) = $this->yellow->plugins->get("update")->getSoftwareVersion(true);
|
|
|
|
foreach($dataCurrent as $key=>$value)
|
|
|
|
{
|
|
|
|
if(strnatcasecmp($dataCurrent[$key], $dataLatest[$key])<0)
|
|
|
|
{
|
|
|
|
if(!empty($this->response->rawDataOutput)) $this->response->rawDataOutput .= "<br />\n";
|
|
|
|
$this->response->rawDataOutput .= "$key $dataLatest[$key]";
|
|
|
|
++$updates;
|
|
|
|
++$count; if($count>=4) { $this->response->rawDataOutput .= "…"; break; }
|
|
|
|
}
|
|
|
|
}
|
2017-01-03 13:11:44 +00:00
|
|
|
$this->response->status = $updates ? "updates" : "done";
|
|
|
|
if($statusCode!=200) $this->response->status = "error";
|
2016-08-16 08:16:13 +00:00
|
|
|
}
|
|
|
|
$statusCode = $this->yellow->processRequest($serverScheme, $serverName, $base, $location, $fileName, false);
|
|
|
|
return $statusCode;
|
|
|
|
}
|
|
|
|
|
2016-08-18 19:57:07 +00:00
|
|
|
// Process request to update website
|
2016-08-16 08:16:13 +00:00
|
|
|
function processRequestUpdate($serverScheme, $serverName, $base, $location, $fileName)
|
|
|
|
{
|
|
|
|
$statusCode = 0;
|
2017-01-03 13:11:44 +00:00
|
|
|
if($this->yellow->plugins->isExisting("update") && $this->response->isUserWebmaster())
|
2016-08-16 08:16:13 +00:00
|
|
|
{
|
|
|
|
$statusCode = $this->yellow->command("update");
|
|
|
|
if($statusCode==200)
|
|
|
|
{
|
|
|
|
$statusCode = 303;
|
|
|
|
$location = $this->yellow->lookup->normaliseUrl($serverScheme, $serverName, $base, $location);
|
|
|
|
$this->yellow->sendStatus($statusCode, $location);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $statusCode;
|
|
|
|
}
|
|
|
|
|
2014-07-25 10:46:58 +00:00
|
|
|
// Process request to create page
|
|
|
|
function processRequestCreate($serverScheme, $serverName, $base, $location, $fileName)
|
|
|
|
{
|
|
|
|
$statusCode = 0;
|
2016-08-13 15:48:18 +00:00
|
|
|
if(!$this->response->isUserRestrictions() && !empty($_POST["rawdataedit"]))
|
2014-07-25 10:46:58 +00:00
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->response->rawDataSource = $this->response->rawDataEdit = rawurldecode($_POST["rawdatasource"]);
|
|
|
|
$rawData = $this->response->normaliseText(rawurldecode($_POST["rawdataedit"]));
|
|
|
|
$page = $this->response->getPageNew($serverScheme, $serverName, $base, $location, $fileName, $rawData);
|
2014-08-13 14:36:13 +00:00
|
|
|
if(!$page->isError())
|
2014-07-25 10:46:58 +00:00
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
if($this->yellow->toolbox->createFile($page->fileName, $page->rawData, true))
|
2014-08-13 14:36:13 +00:00
|
|
|
{
|
|
|
|
$statusCode = 303;
|
2015-04-29 07:26:48 +00:00
|
|
|
$location = $this->yellow->lookup->normaliseUrl($serverScheme, $serverName, $base, $page->location);
|
|
|
|
$this->yellow->sendStatus($statusCode, $location);
|
2014-08-13 14:36:13 +00:00
|
|
|
} else {
|
|
|
|
$statusCode = 500;
|
2015-01-19 19:05:51 +00:00
|
|
|
$this->yellow->processRequest($serverScheme, $serverName, $base, $location, $fileName, false);
|
2014-08-13 14:36:13 +00:00
|
|
|
$this->yellow->page->error($statusCode, "Can't write file '$page->fileName'!");
|
|
|
|
}
|
2014-07-25 10:46:58 +00:00
|
|
|
} else {
|
|
|
|
$statusCode = 500;
|
2016-04-12 13:58:56 +00:00
|
|
|
$this->yellow->processRequest($serverScheme, $serverName, $base, $location, $fileName, false);
|
2014-08-13 14:36:13 +00:00
|
|
|
$this->yellow->page->error($statusCode, $page->get("pageError"));
|
2014-07-25 10:46:58 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return $statusCode;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Process request to edit page
|
|
|
|
function processRequestEdit($serverScheme, $serverName, $base, $location, $fileName)
|
|
|
|
{
|
|
|
|
$statusCode = 0;
|
2016-08-13 15:48:18 +00:00
|
|
|
if(!$this->response->isUserRestrictions() && !empty($_POST["rawdataedit"]))
|
2014-07-25 10:46:58 +00:00
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->response->rawDataSource = rawurldecode($_POST["rawdatasource"]);
|
|
|
|
$this->response->rawDataEdit = $this->response->normaliseText(rawurldecode($_POST["rawdataedit"]));
|
|
|
|
$page = $this->response->getPageUpdate($serverScheme, $serverName, $base, $location, $fileName,
|
|
|
|
$this->response->rawDataSource, $this->response->rawDataEdit, $this->yellow->toolbox->readFile($fileName));
|
2014-08-13 14:36:13 +00:00
|
|
|
if(!$page->isError())
|
2014-07-25 10:46:58 +00:00
|
|
|
{
|
2014-08-13 14:36:13 +00:00
|
|
|
if($this->yellow->toolbox->renameFile($fileName, $page->fileName) &&
|
|
|
|
$this->yellow->toolbox->createFile($page->fileName, $page->rawData))
|
2014-07-25 10:46:58 +00:00
|
|
|
{
|
|
|
|
$statusCode = 303;
|
2015-04-29 07:26:48 +00:00
|
|
|
$location = $this->yellow->lookup->normaliseUrl($serverScheme, $serverName, $base, $page->location);
|
|
|
|
$this->yellow->sendStatus($statusCode, $location);
|
2014-07-25 10:46:58 +00:00
|
|
|
} else {
|
|
|
|
$statusCode = 500;
|
2015-01-19 19:05:51 +00:00
|
|
|
$this->yellow->processRequest($serverScheme, $serverName, $base, $location, $fileName, false);
|
2014-08-13 14:36:13 +00:00
|
|
|
$this->yellow->page->error($statusCode, "Can't write file '$page->fileName'!");
|
2014-07-25 10:46:58 +00:00
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$statusCode = 500;
|
2015-01-19 19:05:51 +00:00
|
|
|
$this->yellow->processRequest($serverScheme, $serverName, $base, $location, $fileName, false);
|
2014-08-13 14:36:13 +00:00
|
|
|
$this->yellow->page->error($statusCode, $page->get("pageError"));
|
2014-07-25 10:46:58 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return $statusCode;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Process request to delete page
|
|
|
|
function processRequestDelete($serverScheme, $serverName, $base, $location, $fileName)
|
2013-04-14 22:41:04 +00:00
|
|
|
{
|
|
|
|
$statusCode = 0;
|
2016-08-13 15:48:18 +00:00
|
|
|
if(!$this->response->isUserRestrictions() && is_file($fileName))
|
2013-04-14 22:41:04 +00:00
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->response->rawDataSource = $this->response->rawDataEdit = rawurldecode($_POST["rawdatasource"]);
|
|
|
|
if($this->yellow->lookup->isFileLocation($location))
|
2014-07-25 10:46:58 +00:00
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
if($this->yellow->toolbox->deleteFile($fileName, $this->yellow->config->get("trashDir")))
|
|
|
|
{
|
|
|
|
$statusCode = 303;
|
|
|
|
$location = $this->yellow->lookup->normaliseUrl($serverScheme, $serverName, $base, $location);
|
|
|
|
$this->yellow->sendStatus($statusCode, $location);
|
|
|
|
} else {
|
|
|
|
$statusCode = 500;
|
|
|
|
$this->yellow->processRequest($serverScheme, $serverName, $base, $location, $fileName, false);
|
|
|
|
$this->yellow->page->error($statusCode, "Can't delete file '$fileName'!");
|
|
|
|
}
|
2014-07-25 10:46:58 +00:00
|
|
|
} else {
|
2016-08-13 15:48:18 +00:00
|
|
|
if($this->yellow->toolbox->deleteDirectory(dirname($fileName), $this->yellow->config->get("trashDir")))
|
|
|
|
{
|
|
|
|
$statusCode = 303;
|
|
|
|
$location = $this->yellow->lookup->normaliseUrl($serverScheme, $serverName, $base, $location);
|
|
|
|
$this->yellow->sendStatus($statusCode, $location);
|
|
|
|
} else {
|
|
|
|
$statusCode = 500;
|
|
|
|
$this->yellow->processRequest($serverScheme, $serverName, $base, $location, $fileName, false);
|
|
|
|
$this->yellow->page->error($statusCode, "Can't delete file '$fileName'!");
|
|
|
|
}
|
2014-07-25 10:46:58 +00:00
|
|
|
}
|
2013-04-14 22:41:04 +00:00
|
|
|
}
|
|
|
|
return $statusCode;
|
|
|
|
}
|
2014-07-25 10:46:58 +00:00
|
|
|
|
2014-05-15 11:53:54 +00:00
|
|
|
// Check web interface request
|
2016-06-02 15:31:42 +00:00
|
|
|
function checkRequest($location)
|
2013-04-14 22:41:04 +00:00
|
|
|
{
|
2016-05-15 16:35:10 +00:00
|
|
|
if($this->yellow->toolbox->getServerScheme()==$this->yellow->config->get("webinterfaceServerScheme") &&
|
|
|
|
$this->yellow->toolbox->getServerName()==$this->yellow->config->get("webinterfaceServerName"))
|
|
|
|
{
|
|
|
|
$locationLength = strlenu($this->yellow->config->get("webinterfaceLocation"));
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->response->active = substru($location, 0, $locationLength)==$this->yellow->config->get("webinterfaceLocation");
|
2016-05-15 16:35:10 +00:00
|
|
|
}
|
2016-08-13 15:48:18 +00:00
|
|
|
return $this->response->isActive();
|
2013-04-14 22:41:04 +00:00
|
|
|
}
|
|
|
|
|
2014-04-07 15:14:31 +00:00
|
|
|
// Check web interface user
|
2017-01-05 09:39:42 +00:00
|
|
|
function checkUser($serverScheme, $serverName, $base, $location, $fileName)
|
2013-04-14 22:41:04 +00:00
|
|
|
{
|
2016-07-19 22:12:05 +00:00
|
|
|
if($_POST["action"]=="login")
|
2013-04-14 22:41:04 +00:00
|
|
|
{
|
2013-12-05 22:30:45 +00:00
|
|
|
$email = $_POST["email"];
|
2013-04-14 22:41:04 +00:00
|
|
|
$password = $_POST["password"];
|
|
|
|
if($this->users->checkUser($email, $password))
|
|
|
|
{
|
2017-01-05 09:39:42 +00:00
|
|
|
$this->response->createCookie($serverScheme, $serverName, $base, $email);
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->response->userEmail = $email;
|
|
|
|
$this->response->userRestrictions = $this->getUserRestrictions($email, $location, $fileName);
|
|
|
|
$this->response->language = $this->response->getLanguage($email);
|
2013-04-14 22:41:04 +00:00
|
|
|
} else {
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->response->action = "fail";
|
2013-04-14 22:41:04 +00:00
|
|
|
}
|
|
|
|
} else if(isset($_COOKIE["login"])) {
|
2016-04-12 13:58:56 +00:00
|
|
|
list($email, $session) = explode(',', $_COOKIE["login"], 2);
|
2014-05-04 12:57:52 +00:00
|
|
|
if($this->users->checkCookie($email, $session))
|
2013-04-14 22:41:04 +00:00
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->response->userEmail = $email;
|
|
|
|
$this->response->userRestrictions = $this->getUserRestrictions($email, $location, $fileName);
|
|
|
|
$this->response->language = $this->response->getLanguage($email);
|
2013-04-14 22:41:04 +00:00
|
|
|
} else {
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->response->action = "fail";
|
2013-04-14 22:41:04 +00:00
|
|
|
}
|
|
|
|
}
|
2016-08-13 15:48:18 +00:00
|
|
|
return $this->response->isUser();
|
2016-04-12 13:58:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Return user account changes
|
|
|
|
function getUserAccount($email, $password, $action)
|
|
|
|
{
|
2016-07-19 22:12:05 +00:00
|
|
|
$status = null;
|
2014-04-07 15:14:31 +00:00
|
|
|
foreach($this->yellow->plugins->plugins as $key=>$value)
|
|
|
|
{
|
2016-04-12 13:58:56 +00:00
|
|
|
if(method_exists($value["obj"], "onUserAccount"))
|
2014-04-07 15:14:31 +00:00
|
|
|
{
|
2016-05-15 16:35:10 +00:00
|
|
|
$status = $value["obj"]->onUserAccount($email, $password, $action, $status, $this->users);
|
|
|
|
if(!is_null($status)) break;
|
2014-04-07 15:14:31 +00:00
|
|
|
}
|
|
|
|
}
|
2016-05-15 16:35:10 +00:00
|
|
|
if(is_null($status))
|
2015-09-06 15:59:14 +00:00
|
|
|
{
|
2016-05-15 16:35:10 +00:00
|
|
|
$status = "ok";
|
|
|
|
if(!empty($password) && strlenu($password)<$this->yellow->config->get("webinterfaceUserPasswordMinLength")) $status = "weak";
|
|
|
|
if(!empty($email) && !filter_var($email, FILTER_VALIDATE_EMAIL)) $status = "invalid";
|
2015-09-06 15:59:14 +00:00
|
|
|
}
|
2016-05-15 16:35:10 +00:00
|
|
|
return $status;
|
2013-04-14 22:41:04 +00:00
|
|
|
}
|
|
|
|
|
2016-04-12 13:58:56 +00:00
|
|
|
// Return user restrictions to change page
|
|
|
|
function getUserRestrictions($email, $location, $fileName)
|
2015-08-09 20:17:17 +00:00
|
|
|
{
|
2016-07-19 22:12:05 +00:00
|
|
|
$userRestrictions = null;
|
2016-04-12 13:58:56 +00:00
|
|
|
foreach($this->yellow->plugins->plugins as $key=>$value)
|
2015-10-06 12:19:11 +00:00
|
|
|
{
|
2016-04-12 13:58:56 +00:00
|
|
|
if(method_exists($value["obj"], "onUserRestrictions"))
|
|
|
|
{
|
|
|
|
$userRestrictions = $value["obj"]->onUserRestrictions($email, $location, $fileName, $this->users);
|
|
|
|
if(!is_null($userRestrictions)) break;
|
|
|
|
}
|
2015-10-06 12:19:11 +00:00
|
|
|
}
|
2016-04-12 13:58:56 +00:00
|
|
|
if(is_null($userRestrictions))
|
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
$userRestrictions = substru($location, 0, strlenu($this->users->getHome($email)))!=$this->users->getHome($email);
|
|
|
|
$userRestrictions |= empty($fileName) || strlenu(dirname($fileName))>128 || strlenu(basename($fileName))>128;
|
2016-04-12 13:58:56 +00:00
|
|
|
}
|
|
|
|
return $userRestrictions;
|
2015-08-09 20:17:17 +00:00
|
|
|
}
|
2016-08-13 15:48:18 +00:00
|
|
|
}
|
2015-08-09 20:17:17 +00:00
|
|
|
|
2016-08-13 15:48:18 +00:00
|
|
|
// Yellow response
|
|
|
|
class YellowResponse
|
|
|
|
{
|
|
|
|
var $yellow; //access to API
|
|
|
|
var $webinterface; //access to web interface
|
|
|
|
var $userEmail; //user email
|
|
|
|
var $userRestrictions; //user can change page? (boolean)
|
|
|
|
var $active; //web interface is active? (boolean)
|
|
|
|
var $rawDataSource; //raw data of page for comparison
|
|
|
|
var $rawDataEdit; //raw data of page for editing
|
2016-08-16 08:16:13 +00:00
|
|
|
var $rawDataOutput; //raw data of dynamic output
|
2016-08-13 15:48:18 +00:00
|
|
|
var $language; //response language
|
|
|
|
var $action; //response action
|
|
|
|
var $status; //response status
|
2014-07-25 10:46:58 +00:00
|
|
|
|
2016-08-13 15:48:18 +00:00
|
|
|
function __construct($yellow)
|
2015-05-24 15:31:17 +00:00
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
$this->yellow = $yellow;
|
|
|
|
$this->webinterface = $yellow->plugins->get("webinterface");
|
2015-05-24 15:31:17 +00:00
|
|
|
}
|
|
|
|
|
2014-07-25 10:46:58 +00:00
|
|
|
// Return new page
|
|
|
|
function getPageNew($serverScheme, $serverName, $base, $location, $fileName, $rawData)
|
|
|
|
{
|
2015-01-19 19:05:51 +00:00
|
|
|
$page = new YellowPage($this->yellow);
|
|
|
|
$page->setRequestInformation($serverScheme, $serverName, $base, $location, $fileName);
|
2015-04-29 07:26:48 +00:00
|
|
|
$page->parseData($rawData, false, 0);
|
2015-10-21 12:28:56 +00:00
|
|
|
if($this->yellow->lookup->isFileLocation($location) || is_file($fileName))
|
2014-07-25 10:46:58 +00:00
|
|
|
{
|
2015-10-21 12:28:56 +00:00
|
|
|
$page->fileName = $this->yellow->lookup->findFileFromTitle(
|
|
|
|
$page->get($this->yellow->config->get("webinterfaceMetaFilePrefix")), $page->get("title"), $fileName,
|
|
|
|
$this->yellow->config->get("contentDefaultFile"), $this->yellow->config->get("contentExtension"));
|
|
|
|
$page->location = $this->yellow->lookup->findLocationFromFile($page->fileName);
|
|
|
|
if($this->yellow->pages->find($page->location))
|
2014-07-25 10:46:58 +00:00
|
|
|
{
|
2015-10-21 12:28:56 +00:00
|
|
|
preg_match("/^(.*?)(\d*)$/", $page->get("title"), $matches);
|
|
|
|
$titleText = $matches[1];
|
|
|
|
$titleNumber = $matches[2];
|
|
|
|
if(strempty($titleNumber)) { $titleNumber = 2; $titleText = $titleText.' '; }
|
|
|
|
for(; $titleNumber<=999; ++$titleNumber)
|
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
$page->rawData = $this->updateTextTitle($rawData, $titleText.$titleNumber);
|
2015-10-21 12:28:56 +00:00
|
|
|
$page->fileName = $this->yellow->lookup->findFileFromTitle(
|
|
|
|
$page->get($this->yellow->config->get("webinterfaceMetaFilePrefix")), $titleText.$titleNumber, $fileName,
|
|
|
|
$this->yellow->config->get("contentDefaultFile"), $this->yellow->config->get("contentExtension"));
|
|
|
|
$page->location = $this->yellow->lookup->findLocationFromFile($page->fileName);
|
|
|
|
if(!$this->yellow->pages->find($page->location)) { $ok = true; break; }
|
|
|
|
}
|
|
|
|
if(!$ok) $page->error(500, "Page '".$page->get("title")."' can not be created!");
|
2014-07-25 10:46:58 +00:00
|
|
|
}
|
2014-08-13 14:36:13 +00:00
|
|
|
}
|
2016-08-13 15:48:18 +00:00
|
|
|
if(!is_dir(dirname($page->fileName)))
|
|
|
|
{
|
|
|
|
preg_match("/^([\d\-\_\.]*)(.*)$/", $page->get("title"), $matches);
|
|
|
|
if(preg_match("/\d$/", $matches[1])) $matches[1] .= '-';
|
|
|
|
$page->fileName = $this->yellow->lookup->findFilePageNew($fileName, $matches[1]);
|
2016-08-16 08:16:13 +00:00
|
|
|
$page->location = $this->yellow->lookup->findLocationFromFile($page->fileName);
|
2016-08-13 15:48:18 +00:00
|
|
|
}
|
|
|
|
if($this->webinterface->getUserRestrictions($this->userEmail, $page->location, $page->fileName))
|
2016-04-12 13:58:56 +00:00
|
|
|
{
|
|
|
|
$page->error(500, "Page '".$page->get("title")."' is not allowed!");
|
|
|
|
}
|
2014-08-13 14:36:13 +00:00
|
|
|
return $page;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Return modified page
|
2014-11-13 13:49:21 +00:00
|
|
|
function getPageUpdate($serverScheme, $serverName, $base, $location, $fileName, $rawDataSource, $rawDataEdit, $rawDataFile)
|
2014-08-13 14:36:13 +00:00
|
|
|
{
|
2015-01-19 19:05:51 +00:00
|
|
|
$page = new YellowPage($this->yellow);
|
|
|
|
$page->setRequestInformation($serverScheme, $serverName, $base, $location, $fileName);
|
2016-08-13 15:48:18 +00:00
|
|
|
$page->parseData($this->webinterface->merge->merge($rawDataSource, $rawDataEdit, $rawDataFile), false, 0);
|
2014-08-13 14:36:13 +00:00
|
|
|
if(empty($page->rawData)) $page->error(500, "Page has been modified by someone else!");
|
2015-04-29 07:26:48 +00:00
|
|
|
if($this->yellow->lookup->isFileLocation($location) && !$page->isError())
|
2014-08-13 14:36:13 +00:00
|
|
|
{
|
2015-01-19 19:05:51 +00:00
|
|
|
$pageSource = new YellowPage($this->yellow);
|
|
|
|
$pageSource->setRequestInformation($serverScheme, $serverName, $base, $location, $fileName);
|
2015-04-29 07:26:48 +00:00
|
|
|
$pageSource->parseData($rawDataSource, false, 0);
|
|
|
|
$prefix = $this->yellow->config->get("webinterfaceMetaFilePrefix");
|
2014-08-13 14:36:13 +00:00
|
|
|
if($pageSource->get($prefix)!=$page->get($prefix) || $pageSource->get("title")!=$page->get("title"))
|
2014-07-25 10:46:58 +00:00
|
|
|
{
|
2015-04-29 07:26:48 +00:00
|
|
|
$page->fileName = $this->yellow->lookup->findFileFromTitle(
|
2014-08-13 14:36:13 +00:00
|
|
|
$page->get($prefix), $page->get("title"), $fileName,
|
2014-07-25 10:46:58 +00:00
|
|
|
$this->yellow->config->get("contentDefaultFile"), $this->yellow->config->get("contentExtension"));
|
2015-04-29 07:26:48 +00:00
|
|
|
$page->location = $this->yellow->lookup->findLocationFromFile($page->fileName);
|
2016-07-19 22:12:05 +00:00
|
|
|
if($pageSource->location!=$page->location)
|
2014-08-13 14:36:13 +00:00
|
|
|
{
|
2015-10-21 12:28:56 +00:00
|
|
|
if(!$this->yellow->lookup->isFileLocation($page->location))
|
|
|
|
{
|
|
|
|
$page->error(500, "Page '".$page->get("title")."' is not allowed!");
|
|
|
|
} else if($this->yellow->pages->find($page->location)) {
|
|
|
|
$page->error(500, "Page '".$page->get("title")."' already exists!");
|
|
|
|
}
|
2014-08-13 14:36:13 +00:00
|
|
|
}
|
2014-07-25 10:46:58 +00:00
|
|
|
}
|
|
|
|
}
|
2016-08-13 15:48:18 +00:00
|
|
|
if($this->webinterface->getUserRestrictions($this->userEmail, $page->location, $page->fileName))
|
2016-04-12 13:58:56 +00:00
|
|
|
{
|
|
|
|
$page->error(500, "Page '".$page->get("title")."' is not allowed!");
|
|
|
|
}
|
2014-07-25 10:46:58 +00:00
|
|
|
return $page;
|
|
|
|
}
|
|
|
|
|
2016-04-12 13:58:56 +00:00
|
|
|
// Return page data including login information
|
2016-02-20 17:34:06 +00:00
|
|
|
function getPageData()
|
|
|
|
{
|
|
|
|
$data = array();
|
|
|
|
if($this->isUser())
|
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
$data["title"] = $this->getPageTitle($this->rawDataEdit);
|
2016-02-20 17:34:06 +00:00
|
|
|
$data["rawDataSource"] = $this->rawDataSource;
|
|
|
|
$data["rawDataEdit"] = $this->rawDataEdit;
|
|
|
|
$data["rawDataNew"] = $this->getRawDataNew();
|
2016-08-16 08:16:13 +00:00
|
|
|
$data["rawDataOutput"] = strval($this->rawDataOutput);
|
2016-02-20 17:34:06 +00:00
|
|
|
$data["pageFile"] = $this->yellow->page->get("pageFile");
|
|
|
|
$data["parserSafeMode"] = $this->yellow->page->parserSafeMode;
|
|
|
|
}
|
2016-07-19 22:12:05 +00:00
|
|
|
if($this->action!="none") $data = array_merge($data, $this->getRequestData());
|
2016-05-15 16:35:10 +00:00
|
|
|
$data["action"] = $this->action;
|
|
|
|
$data["status"] = $this->status;
|
|
|
|
$data["statusCode"] = $this->yellow->page->statusCode;
|
2016-02-20 17:34:06 +00:00
|
|
|
return $data;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Return configuration data including user information
|
|
|
|
function getConfigData()
|
2013-04-14 22:41:04 +00:00
|
|
|
{
|
2014-08-19 21:44:22 +00:00
|
|
|
$data = $this->yellow->config->getData("", "Location");
|
|
|
|
if($this->isUser())
|
|
|
|
{
|
2016-05-15 16:35:10 +00:00
|
|
|
$data["userEmail"] = $this->userEmail;
|
2016-08-13 15:48:18 +00:00
|
|
|
$data["userName"] = $this->webinterface->users->getName($this->userEmail);
|
|
|
|
$data["userLanguage"] = $this->webinterface->users->getLanguage($this->userEmail);
|
|
|
|
$data["userStatus"] = $this->webinterface->users->getStatus($this->userEmail);
|
|
|
|
$data["userHome"] = $this->webinterface->users->getHome($this->userEmail);
|
|
|
|
$data["userRestrictions"] = intval($this->isUserRestrictions());
|
|
|
|
$data["userWebmaster"] = intval($this->isUserWebmaster());
|
2017-01-03 13:11:44 +00:00
|
|
|
$data["pluginUpdate"] = intval($this->yellow->plugins->isExisting("update"));
|
2014-08-19 21:44:22 +00:00
|
|
|
$data["serverScheme"] = $this->yellow->config->get("serverScheme");
|
|
|
|
$data["serverName"] = $this->yellow->config->get("serverName");
|
|
|
|
$data["serverBase"] = $this->yellow->config->get("serverBase");
|
2016-02-20 17:34:06 +00:00
|
|
|
$data["serverTime"] = $this->yellow->config->get("serverTime");
|
2016-05-15 16:35:10 +00:00
|
|
|
$data["serverLanguages"] = array();
|
|
|
|
foreach($this->yellow->text->getLanguages() as $language)
|
|
|
|
{
|
|
|
|
$data["serverLanguages"][$language] = $this->yellow->text->getTextHtml("languageDescription", $language);
|
|
|
|
}
|
2016-07-19 22:12:05 +00:00
|
|
|
$data["serverVersion"] = "Yellow ".YellowCore::VERSION;
|
2014-08-19 21:44:22 +00:00
|
|
|
} else {
|
2014-10-19 19:22:47 +00:00
|
|
|
$data["loginEmail"] = $this->yellow->config->get("loginEmail");
|
|
|
|
$data["loginPassword"] = $this->yellow->config->get("loginPassword");
|
2016-08-13 15:48:18 +00:00
|
|
|
$data["loginRestrictions"] = intval($this->isLoginRestrictions());
|
2016-04-12 13:58:56 +00:00
|
|
|
}
|
2016-05-15 16:35:10 +00:00
|
|
|
if(defined("DEBUG") && DEBUG>=1) $data["debug"] = DEBUG;
|
2016-04-12 13:58:56 +00:00
|
|
|
return $data;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Return request strings
|
|
|
|
function getRequestData()
|
|
|
|
{
|
|
|
|
$data = array();
|
|
|
|
foreach($_REQUEST as $key=>$value)
|
|
|
|
{
|
2016-05-15 16:35:10 +00:00
|
|
|
if($key=="login" || $key=="password") continue;
|
2016-04-12 13:58:56 +00:00
|
|
|
$data["request".ucfirst($key)] = trim($value);
|
2014-08-19 21:44:22 +00:00
|
|
|
}
|
|
|
|
return $data;
|
2013-04-14 22:41:04 +00:00
|
|
|
}
|
2014-05-15 11:53:54 +00:00
|
|
|
|
2016-08-13 15:48:18 +00:00
|
|
|
// Return text strings
|
|
|
|
function getTextData()
|
2016-04-12 13:58:56 +00:00
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
$textLanguage = array_merge($this->yellow->text->getData("language", $this->language));
|
|
|
|
$textWebinterface = array_merge($this->yellow->text->getData("webinterface", $this->language));
|
|
|
|
$textYellow = array_merge($this->yellow->text->getData("yellow", $this->language));
|
|
|
|
return array_merge($textLanguage, $textWebinterface, $textYellow);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Return raw data for new page
|
|
|
|
function getRawDataNew($location = "")
|
|
|
|
{
|
|
|
|
$fileName = $this->yellow->lookup->findFileFromLocation($this->yellow->page->location);
|
|
|
|
$fileName = $this->yellow->lookup->findFileFromConfig($fileName,
|
|
|
|
$this->yellow->config->get("webinterfaceNewFile"), $this->yellow->config->get("template"));
|
|
|
|
$rawData = $this->yellow->toolbox->readFile($fileName);
|
|
|
|
$rawData = preg_replace("/@datetime/i", date("Y-m-d H:i:s"), $rawData);
|
|
|
|
$rawData = preg_replace("/@date/i", date("Y-m-d"), $rawData);
|
|
|
|
$rawData = preg_replace("/@usershort/i", strtok($this->webinterface->users->getName($this->userEmail), " "), $rawData);
|
|
|
|
$rawData = preg_replace("/@username/i", $this->webinterface->users->getName($this->userEmail), $rawData);
|
|
|
|
$rawData = preg_replace("/@userlanguage/i", $this->webinterface->users->getLanguage($this->userEmail), $rawData);
|
|
|
|
if(!empty($location))
|
2016-04-12 13:58:56 +00:00
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
$title = $this->yellow->toolbox->createTextTitle($location);
|
|
|
|
$rawData = $this->updateTextTitle($rawData, $title);
|
2016-04-12 13:58:56 +00:00
|
|
|
}
|
2016-08-13 15:48:18 +00:00
|
|
|
return $rawData;
|
2016-04-12 13:58:56 +00:00
|
|
|
}
|
|
|
|
|
2016-08-13 15:48:18 +00:00
|
|
|
// Return page title
|
|
|
|
function getPageTitle($rawData)
|
2016-02-20 17:34:06 +00:00
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
$title = $this->yellow->page->get("title");
|
|
|
|
if(preg_match("/^(\xEF\xBB\xBF)?\-\-\-[\r\n]+(.+?)[\r\n]+\-\-\-[\r\n]+/s", $rawData))
|
|
|
|
{
|
|
|
|
foreach($this->yellow->toolbox->getTextLines($rawData) as $line)
|
|
|
|
{
|
|
|
|
if(preg_match("/^(\s*Title\s*:\s*)(.*?)(\s*)$/i", $line, $matches)) { $title = $matches[2]; break; }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $title;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Return language for user
|
|
|
|
function getLanguage($email)
|
|
|
|
{
|
|
|
|
$language = $this->webinterface->users->getLanguage($email);
|
|
|
|
if(!$this->yellow->text->isLanguage($language)) $language = $this->yellow->config->get("language");
|
|
|
|
return $language;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Update text title
|
|
|
|
function updateTextTitle($rawData, $title)
|
|
|
|
{
|
|
|
|
foreach($this->yellow->toolbox->getTextLines($rawData) as $line)
|
|
|
|
{
|
|
|
|
if(preg_match("/^(\s*Title\s*:\s*)(.*?)(\s*)$/i", $line, $matches)) $line = $matches[1].$title.$matches[3];
|
|
|
|
$rawDataNew .= $line;
|
|
|
|
}
|
|
|
|
return $rawDataNew;
|
2016-02-20 17:34:06 +00:00
|
|
|
}
|
|
|
|
|
2016-04-12 13:58:56 +00:00
|
|
|
// Normlise text with special characters
|
|
|
|
function normaliseText($text)
|
|
|
|
{
|
|
|
|
if($this->yellow->plugins->isExisting("emojiawesome"))
|
|
|
|
{
|
|
|
|
$text = $this->yellow->plugins->get("emojiawesome")->normaliseText($text, true, false);
|
|
|
|
}
|
|
|
|
return $text;
|
|
|
|
}
|
2017-01-05 09:39:42 +00:00
|
|
|
|
|
|
|
// Create browser cookie
|
|
|
|
function createCookie($serverScheme, $serverName, $base, $email)
|
|
|
|
{
|
|
|
|
$session = $this->webinterface->users->createSession($email);
|
|
|
|
setcookie("login", "$email,$session", time()+60*60*24*365, "$base/", "", $serverScheme=="https");
|
|
|
|
}
|
|
|
|
|
|
|
|
// Destroy browser cookie
|
|
|
|
function destroyCookie($serverScheme, $serverName, $base)
|
|
|
|
{
|
|
|
|
setcookie("login", "", time()-60*60, "$base/", "", $serverScheme=="https");
|
|
|
|
}
|
2016-04-12 13:58:56 +00:00
|
|
|
|
2016-08-13 15:48:18 +00:00
|
|
|
// Send mail to user
|
|
|
|
function sendMail($serverScheme, $serverName, $base, $email, $action)
|
|
|
|
{
|
|
|
|
if($action=="welcome" || $action=="information")
|
|
|
|
{
|
|
|
|
$url = "$serverScheme://$serverName$base/";
|
|
|
|
} else {
|
|
|
|
$expire = time()+60*60*24;
|
|
|
|
$id = $this->webinterface->users->createRequestId($email, $action, $expire);
|
|
|
|
$url = "$serverScheme://$serverName$base"."/action:$action/email:$email/expire:$expire/id:$id/";
|
|
|
|
}
|
|
|
|
if($action=="approve")
|
|
|
|
{
|
|
|
|
$account = $email;
|
|
|
|
$name = $this->yellow->config->get("author");
|
|
|
|
$email = $this->yellow->config->get("email");
|
|
|
|
} else {
|
|
|
|
$account = $email;
|
|
|
|
$name = $this->webinterface->users->getName($email);
|
|
|
|
}
|
|
|
|
$language = $this->webinterface->users->getLanguage($email);
|
|
|
|
if(!$this->yellow->text->isLanguage($language)) $language = $this->yellow->config->get("language");
|
|
|
|
$sitename = $this->yellow->config->get("sitename");
|
|
|
|
$prefix = "webinterface".ucfirst($action);
|
|
|
|
$message = $this->yellow->text->getText("{$prefix}Message", $language);
|
|
|
|
$message = preg_replace("/@useraccount/i", $account, $message);
|
|
|
|
$message = preg_replace("/@usershort/i", strtok($name, " "), $message);
|
|
|
|
$message = preg_replace("/@username/i", $name, $message);
|
|
|
|
$message = preg_replace("/@userlanguage/i", $language, $message);
|
2017-01-23 10:27:02 +00:00
|
|
|
$mailTo = mb_encode_mimeheader("$name")." <$email>";
|
2016-08-13 15:48:18 +00:00
|
|
|
$mailSubject = mb_encode_mimeheader($this->yellow->text->getText("{$prefix}Subject", $language));
|
2017-01-23 10:27:02 +00:00
|
|
|
$mailHeaders = mb_encode_mimeheader("From: $sitename")." <noreply>\r\n";
|
2016-08-13 15:48:18 +00:00
|
|
|
$mailHeaders .= mb_encode_mimeheader("X-Request-Url: $serverScheme://$serverName$base")."\r\n";
|
|
|
|
$mailHeaders .= mb_encode_mimeheader("X-Remote-Addr: $_SERVER[REMOTE_ADDR]")."\r\n";
|
|
|
|
$mailHeaders .= "Mime-Version: 1.0\r\n";
|
|
|
|
$mailHeaders .= "Content-Type: text/plain; charset=utf-8\r\n";
|
|
|
|
$mailMessage = "$message\r\n\r\n$url\r\n-- \r\n$sitename";
|
|
|
|
return mail($mailTo, $mailSubject, $mailMessage, $mailHeaders);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Check if web interface active
|
|
|
|
function isActive()
|
|
|
|
{
|
|
|
|
return $this->active;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Check if web interface has login restrictions
|
|
|
|
function isLoginRestrictions()
|
|
|
|
{
|
|
|
|
return substru($this->yellow->config->get("email"), 0, 7)=="noreply";
|
|
|
|
}
|
|
|
|
|
2016-05-15 16:35:10 +00:00
|
|
|
// Check if user is logged in
|
|
|
|
function isUser()
|
2016-04-12 13:58:56 +00:00
|
|
|
{
|
2016-05-15 16:35:10 +00:00
|
|
|
return !empty($this->userEmail);
|
2016-04-12 13:58:56 +00:00
|
|
|
}
|
2016-08-13 15:48:18 +00:00
|
|
|
|
|
|
|
// Check if user has restrictions
|
|
|
|
function isUserRestrictions()
|
|
|
|
{
|
|
|
|
return empty($this->userEmail) || $this->userRestrictions;
|
|
|
|
}
|
2014-05-15 11:53:54 +00:00
|
|
|
|
2016-08-13 15:48:18 +00:00
|
|
|
// Check if user is webmaster
|
|
|
|
function isUserWebmaster()
|
2014-05-15 11:53:54 +00:00
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
return !empty($this->userEmail) && $this->userEmail==$this->yellow->config->get("email");
|
2014-05-15 11:53:54 +00:00
|
|
|
}
|
2013-04-14 22:41:04 +00:00
|
|
|
}
|
|
|
|
|
2015-10-06 12:19:11 +00:00
|
|
|
// Yellow users
|
|
|
|
class YellowUsers
|
2013-04-14 22:41:04 +00:00
|
|
|
{
|
2013-12-21 13:10:15 +00:00
|
|
|
var $yellow; //access to API
|
2013-04-14 22:41:04 +00:00
|
|
|
var $users; //registered users
|
|
|
|
|
2013-12-21 13:10:15 +00:00
|
|
|
function __construct($yellow)
|
2013-04-14 22:41:04 +00:00
|
|
|
{
|
2013-12-21 13:10:15 +00:00
|
|
|
$this->yellow = $yellow;
|
2013-04-14 22:41:04 +00:00
|
|
|
$this->users = array();
|
|
|
|
}
|
|
|
|
|
|
|
|
// Load users from file
|
2016-02-20 17:34:06 +00:00
|
|
|
function load($fileName)
|
2013-04-14 22:41:04 +00:00
|
|
|
{
|
2016-02-20 17:34:06 +00:00
|
|
|
if(defined("DEBUG") && DEBUG>=2) echo "YellowUsers::load file:$fileName<br/>\n";
|
|
|
|
$fileData = $this->yellow->toolbox->readFile($fileName);
|
|
|
|
foreach($this->yellow->toolbox->getTextLines($fileData) as $line)
|
2013-04-14 22:41:04 +00:00
|
|
|
{
|
2016-02-20 17:34:06 +00:00
|
|
|
if(preg_match("/^\#/", $line)) continue;
|
2016-06-27 13:28:10 +00:00
|
|
|
preg_match("/^\s*(.*?)\s*:\s*(.*?)\s*$/", $line, $matches);
|
|
|
|
if(!empty($matches[1]) && !empty($matches[2]))
|
2013-04-14 22:41:04 +00:00
|
|
|
{
|
2016-08-16 08:16:13 +00:00
|
|
|
list($hash, $name, $language, $status, $modified, $pending, $home) = explode(',', $matches[2]);
|
|
|
|
$this->set($matches[1], $hash, $name, $language, $status, $modified, $pending, $home);
|
2016-02-20 17:34:06 +00:00
|
|
|
if(defined("DEBUG") && DEBUG>=3) echo "YellowUsers::load email:$matches[1]<br/>\n";
|
2013-04-14 22:41:04 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2013-12-21 13:10:15 +00:00
|
|
|
|
2016-06-02 15:31:42 +00:00
|
|
|
// Clean users in file
|
|
|
|
function clean($fileName)
|
|
|
|
{
|
|
|
|
$fileData = $this->yellow->toolbox->readFile($fileName);
|
|
|
|
foreach($this->yellow->toolbox->getTextLines($fileData) as $line)
|
|
|
|
{
|
2016-06-27 13:28:10 +00:00
|
|
|
preg_match("/^\s*(.*?)\s*:\s*(.*?)\s*$/", $line, $matches);
|
|
|
|
if(!empty($matches[1]) && !empty($matches[2]))
|
2016-06-02 15:31:42 +00:00
|
|
|
{
|
2016-08-16 08:16:13 +00:00
|
|
|
list($hash, $name, $language, $status, $modified, $pending, $home) = explode(',', $matches[2]);
|
2016-06-27 13:28:10 +00:00
|
|
|
if($status=="active" || $status=="inactive")
|
|
|
|
{
|
2017-01-03 13:11:44 +00:00
|
|
|
$pending = "none";
|
2016-08-16 08:16:13 +00:00
|
|
|
$fileDataNew .= "$matches[1]: $hash,$name,$language,$status,$modified,$pending,$home\n";
|
2016-06-27 13:28:10 +00:00
|
|
|
}
|
|
|
|
} else {
|
2016-06-02 15:31:42 +00:00
|
|
|
$fileDataNew .= $line;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $this->yellow->toolbox->createFile($fileName, $fileDataNew);
|
|
|
|
}
|
|
|
|
|
2016-04-12 13:58:56 +00:00
|
|
|
// Update users in file
|
2016-08-16 08:16:13 +00:00
|
|
|
function update($fileName, $email, $password = "", $name = "", $language = "", $status = "", $modified = "", $pending = "", $home = "")
|
2016-04-12 13:58:56 +00:00
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
if(!empty($password)) $hash = $this->createHash($password);
|
2016-04-12 13:58:56 +00:00
|
|
|
if($this->isExisting($email))
|
|
|
|
{
|
|
|
|
$email = strreplaceu(',', '-', $email);
|
|
|
|
$hash = strreplaceu(',', '-', empty($hash) ? $this->users[$email]["hash"] : $hash);
|
|
|
|
$name = strreplaceu(',', '-', empty($name) ? $this->users[$email]["name"] : $name);
|
|
|
|
$language = strreplaceu(',', '-', empty($language) ? $this->users[$email]["language"] : $language);
|
|
|
|
$status = strreplaceu(',', '-', empty($status) ? $this->users[$email]["status"] : $status);
|
2016-08-16 08:16:13 +00:00
|
|
|
$modified = strreplaceu(',', '-', empty($modified) ? time() : $modified);
|
2016-06-27 13:28:10 +00:00
|
|
|
$pending = strreplaceu(',', '-', empty($pending) ? $this->users[$email]["pending"] : $pending);
|
2016-04-12 13:58:56 +00:00
|
|
|
$home = strreplaceu(',', '-', empty($home) ? $this->users[$email]["home"] : $home);
|
|
|
|
} else {
|
|
|
|
$email = strreplaceu(',', '-', empty($email) ? "none" : $email);
|
|
|
|
$hash = strreplaceu(',', '-', empty($hash) ? "none" : $hash);
|
|
|
|
$name = strreplaceu(',', '-', empty($name) ? $this->yellow->config->get("sitename") : $name);
|
|
|
|
$language = strreplaceu(',', '-', empty($language) ? $this->yellow->config->get("language") : $language);
|
|
|
|
$status = strreplaceu(',', '-', empty($status) ? $this->yellow->config->get("webinterfaceUserStatus") : $status);
|
2016-08-16 08:16:13 +00:00
|
|
|
$modified = strreplaceu(',', '-', empty($modified) ? time() : $modified);
|
2017-01-03 13:11:44 +00:00
|
|
|
$pending = strreplaceu(',', '-', empty($pending) ? "none" : $pending);
|
2016-04-12 13:58:56 +00:00
|
|
|
$home = strreplaceu(',', '-', empty($home) ? $this->yellow->config->get("webinterfaceUserHome") : $home);
|
|
|
|
}
|
2016-08-16 08:16:13 +00:00
|
|
|
$this->set($email, $hash, $name, $language, $status, $modified, $pending, $home);
|
2016-04-12 13:58:56 +00:00
|
|
|
$fileData = $this->yellow->toolbox->readFile($fileName);
|
|
|
|
foreach($this->yellow->toolbox->getTextLines($fileData) as $line)
|
|
|
|
{
|
2016-06-27 13:28:10 +00:00
|
|
|
preg_match("/^\s*(.*?)\s*:\s*(.*?)\s*$/", $line, $matches);
|
2016-04-12 13:58:56 +00:00
|
|
|
if(!empty($matches[1]) && $matches[1]==$email)
|
|
|
|
{
|
2016-08-16 08:16:13 +00:00
|
|
|
$fileDataNew .= "$email: $hash,$name,$language,$status,$modified,$pending,$home\n";
|
2016-04-12 13:58:56 +00:00
|
|
|
$found = true;
|
|
|
|
} else {
|
|
|
|
$fileDataNew .= $line;
|
|
|
|
}
|
|
|
|
}
|
2016-08-16 08:16:13 +00:00
|
|
|
if(!$found) $fileDataNew .= "$email: $hash,$name,$language,$status,$modified,$pending,$home\n";
|
2016-04-12 13:58:56 +00:00
|
|
|
return $this->yellow->toolbox->createFile($fileName, $fileDataNew);
|
|
|
|
}
|
|
|
|
|
2014-04-07 15:14:31 +00:00
|
|
|
// Set user data
|
2016-08-16 08:16:13 +00:00
|
|
|
function set($email, $hash, $name, $language, $status, $modified, $pending, $home)
|
2014-04-07 15:14:31 +00:00
|
|
|
{
|
|
|
|
$this->users[$email] = array();
|
|
|
|
$this->users[$email]["email"] = $email;
|
2014-05-04 12:57:52 +00:00
|
|
|
$this->users[$email]["hash"] = $hash;
|
2014-04-07 15:14:31 +00:00
|
|
|
$this->users[$email]["name"] = $name;
|
|
|
|
$this->users[$email]["language"] = $language;
|
2015-10-06 12:19:11 +00:00
|
|
|
$this->users[$email]["status"] = $status;
|
2016-08-16 08:16:13 +00:00
|
|
|
$this->users[$email]["modified"] = $modified;
|
2016-06-27 13:28:10 +00:00
|
|
|
$this->users[$email]["pending"] = $pending;
|
2014-04-07 15:14:31 +00:00
|
|
|
$this->users[$email]["home"] = $home;
|
|
|
|
}
|
|
|
|
|
2017-01-05 09:39:42 +00:00
|
|
|
// Check user login from email and password
|
2013-04-14 22:41:04 +00:00
|
|
|
function checkUser($email, $password)
|
|
|
|
{
|
2014-05-04 12:57:52 +00:00
|
|
|
$algorithm = $this->yellow->config->get("webinterfaceUserHashAlgorithm");
|
2015-10-06 12:19:11 +00:00
|
|
|
return $this->isExisting($email) && $this->users[$email]["status"]=="active" &&
|
|
|
|
$this->yellow->toolbox->verifyHash($password, $algorithm, $this->users[$email]["hash"]);
|
2013-04-14 22:41:04 +00:00
|
|
|
}
|
|
|
|
|
2017-01-05 09:39:42 +00:00
|
|
|
// Check user login from email and session
|
2016-04-12 13:58:56 +00:00
|
|
|
function checkCookie($email, $session)
|
|
|
|
{
|
|
|
|
return $this->isExisting($email) && $this->users[$email]["status"]=="active" &&
|
|
|
|
$this->yellow->toolbox->verifyHash($this->users[$email]["hash"], "sha256", $session);
|
|
|
|
}
|
|
|
|
|
2017-01-05 09:39:42 +00:00
|
|
|
// Create session
|
|
|
|
function createSession($email)
|
2013-04-14 22:41:04 +00:00
|
|
|
{
|
|
|
|
if($this->isExisting($email))
|
|
|
|
{
|
2014-05-04 12:57:52 +00:00
|
|
|
$session = $this->yellow->toolbox->createHash($this->users[$email]["hash"], "sha256");
|
|
|
|
if(empty($session)) $session = "error-hash-algorithm-sha256";
|
2013-04-14 22:41:04 +00:00
|
|
|
}
|
2017-01-05 09:39:42 +00:00
|
|
|
return $session;
|
2013-04-14 22:41:04 +00:00
|
|
|
}
|
|
|
|
|
2016-08-13 15:48:18 +00:00
|
|
|
// Create password hash
|
|
|
|
function createHash($password)
|
2013-04-14 22:41:04 +00:00
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
$algorithm = $this->yellow->config->get("webinterfaceUserHashAlgorithm");
|
|
|
|
$cost = $this->yellow->config->get("webinterfaceUserHashCost");
|
|
|
|
$hash = $this->yellow->toolbox->createHash($password, $algorithm, $cost);
|
|
|
|
if(empty($hash)) $hash = "error-hash-algorithm-$algorithm";
|
|
|
|
return $hash;
|
2013-04-14 22:41:04 +00:00
|
|
|
}
|
|
|
|
|
2016-08-13 15:48:18 +00:00
|
|
|
// Create request ID for action
|
|
|
|
function createRequestId($email, $action, $expire)
|
2013-04-14 22:41:04 +00:00
|
|
|
{
|
2016-04-12 13:58:56 +00:00
|
|
|
return $this->yellow->toolbox->createHash($this->users[$email]["hash"].$action.$expire, "sha256");
|
2013-04-14 22:41:04 +00:00
|
|
|
}
|
|
|
|
|
2016-08-13 15:48:18 +00:00
|
|
|
// Return response status for action
|
|
|
|
function getResponseStatus($email, $action, $expire, $id)
|
|
|
|
{
|
|
|
|
$status = "done";
|
|
|
|
switch($action)
|
|
|
|
{
|
|
|
|
case "confirm": $statusExpected = "unconfirmed"; break;
|
|
|
|
case "reconfirm": $statusExpected = "unconfirmed"; break;
|
|
|
|
case "approve": $statusExpected = "unapproved"; break;
|
|
|
|
default: $statusExpected = "active"; break;
|
|
|
|
}
|
|
|
|
if($this->isExisting($email) && $this->users[$email]["status"]==$statusExpected &&
|
|
|
|
$this->yellow->toolbox->verifyHash($this->users[$email]["hash"].$action.$expire, "sha256", $id))
|
|
|
|
{
|
|
|
|
$status = "ok";
|
|
|
|
}
|
|
|
|
if($expire<=time()) $status = "expired";
|
|
|
|
return $status;
|
|
|
|
}
|
|
|
|
|
2016-04-12 13:58:56 +00:00
|
|
|
// Return user hash
|
|
|
|
function getHash($email = "")
|
|
|
|
{
|
|
|
|
return $this->isExisting($email) ? $this->users[$email]["hash"] : "";
|
|
|
|
}
|
|
|
|
|
2013-04-14 22:41:04 +00:00
|
|
|
// Return user name
|
2014-04-07 15:14:31 +00:00
|
|
|
function getName($email = "")
|
2013-04-14 22:41:04 +00:00
|
|
|
{
|
|
|
|
return $this->isExisting($email) ? $this->users[$email]["name"] : "";
|
|
|
|
}
|
|
|
|
|
|
|
|
// Return user language
|
2014-04-07 15:14:31 +00:00
|
|
|
function getLanguage($email = "")
|
2013-04-14 22:41:04 +00:00
|
|
|
{
|
|
|
|
return $this->isExisting($email) ? $this->users[$email]["language"] : "";
|
|
|
|
}
|
2015-10-06 12:19:11 +00:00
|
|
|
|
|
|
|
// Return user status
|
|
|
|
function getStatus($email = "")
|
|
|
|
{
|
|
|
|
return $this->isExisting($email) ? $this->users[$email]["status"] : "";
|
|
|
|
}
|
|
|
|
|
2016-08-16 08:16:13 +00:00
|
|
|
// Return user modified
|
|
|
|
function getModified($email = "")
|
|
|
|
{
|
|
|
|
return $this->isExisting($email) ? $this->users[$email]["modified"] : "";
|
|
|
|
}
|
|
|
|
|
2016-06-27 13:28:10 +00:00
|
|
|
// Return user pending
|
|
|
|
function getPending($email = "")
|
|
|
|
{
|
|
|
|
return $this->isExisting($email) ? $this->users[$email]["pending"] : "";
|
|
|
|
}
|
|
|
|
|
2014-04-07 15:14:31 +00:00
|
|
|
// Return user home
|
|
|
|
function getHome($email = "")
|
|
|
|
{
|
|
|
|
return $this->isExisting($email) ? $this->users[$email]["home"] : "";
|
|
|
|
}
|
2013-04-14 22:41:04 +00:00
|
|
|
|
2015-05-05 16:11:43 +00:00
|
|
|
// Return number of users
|
|
|
|
function getNumber()
|
|
|
|
{
|
|
|
|
return count($this->users);
|
|
|
|
}
|
2016-05-15 16:35:10 +00:00
|
|
|
|
2016-08-13 15:48:18 +00:00
|
|
|
// Return user data
|
|
|
|
function getData()
|
2016-05-15 16:35:10 +00:00
|
|
|
{
|
2016-08-13 15:48:18 +00:00
|
|
|
$data = array();
|
|
|
|
foreach($this->users as $key=>$value)
|
|
|
|
{
|
|
|
|
$data[$key] = "$value[email] password $value[name] $value[language] $value[status]";
|
|
|
|
if($value["home"]!="/") $data[$key] .= " restrictions";
|
|
|
|
}
|
|
|
|
usort($data, strnatcasecmp);
|
|
|
|
return $data;
|
2016-05-15 16:35:10 +00:00
|
|
|
}
|
2016-08-16 08:16:13 +00:00
|
|
|
|
|
|
|
// Check if user is taken
|
|
|
|
function isTaken($email)
|
|
|
|
{
|
|
|
|
$taken = false;
|
|
|
|
if($this->isExisting($email))
|
|
|
|
{
|
|
|
|
$status = $this->users[$email]["status"];
|
|
|
|
$reserved = $this->users[$email]["modified"] + 60*60*24;
|
|
|
|
if($status=="active" || $status=="inactive" || $reserved>time()) $taken = true;
|
|
|
|
}
|
|
|
|
return $taken;
|
|
|
|
}
|
|
|
|
|
2013-04-14 22:41:04 +00:00
|
|
|
// Check if user exists
|
|
|
|
function isExisting($email)
|
|
|
|
{
|
|
|
|
return !is_null($this->users[$email]);
|
|
|
|
}
|
|
|
|
}
|
2014-11-13 13:49:21 +00:00
|
|
|
|
2015-10-06 12:19:11 +00:00
|
|
|
// Yellow merge
|
|
|
|
class YellowMerge
|
2014-11-13 13:49:21 +00:00
|
|
|
{
|
|
|
|
var $yellow; //access to API
|
2016-07-19 22:12:05 +00:00
|
|
|
const ADD = '+'; //merge types
|
|
|
|
const MODIFY = '*';
|
|
|
|
const REMOVE = '-';
|
|
|
|
const SAME = ' ';
|
2014-11-13 13:49:21 +00:00
|
|
|
|
|
|
|
function __construct($yellow)
|
|
|
|
{
|
|
|
|
$this->yellow = $yellow;
|
|
|
|
}
|
|
|
|
|
2016-07-19 22:12:05 +00:00
|
|
|
// Merge text, null if not possible
|
2014-11-13 13:49:21 +00:00
|
|
|
function merge($textSource, $textMine, $textYours, $showDiff = false)
|
|
|
|
{
|
2016-07-19 22:12:05 +00:00
|
|
|
if($textMine!=$textYours)
|
2014-11-13 13:49:21 +00:00
|
|
|
{
|
|
|
|
$diffMine = $this->buildDiff($textSource, $textMine);
|
|
|
|
$diffYours = $this->buildDiff($textSource, $textYours);
|
|
|
|
$diff = $this->mergeDiff($diffMine, $diffYours);
|
|
|
|
$output = $this->getOutput($diff, $showDiff);
|
|
|
|
} else {
|
|
|
|
$output = $textMine;
|
|
|
|
}
|
|
|
|
return $output;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Build differences to common source
|
|
|
|
function buildDiff($textSource, $textOther)
|
|
|
|
{
|
|
|
|
$diff = array();
|
|
|
|
$lastRemove = -1;
|
|
|
|
$textStart = 0;
|
|
|
|
$textSource = $this->yellow->toolbox->getTextLines($textSource);
|
|
|
|
$textOther = $this->yellow->toolbox->getTextLines($textOther);
|
|
|
|
$sourceEnd = $sourceSize = count($textSource);
|
|
|
|
$otherEnd = $otherSize = count($textOther);
|
|
|
|
while($textStart<$sourceEnd && $textStart<$otherEnd && $textSource[$textStart]==$textOther[$textStart]) ++$textStart;
|
|
|
|
while($textStart<$sourceEnd && $textStart<$otherEnd && $textSource[$sourceEnd-1]==$textOther[$otherEnd-1])
|
|
|
|
{
|
|
|
|
--$sourceEnd; --$otherEnd;
|
|
|
|
}
|
2016-07-19 22:12:05 +00:00
|
|
|
for($pos=0; $pos<$textStart; ++$pos) array_push($diff, array(YellowMerge::SAME, $textSource[$pos], false));
|
2014-11-13 13:49:21 +00:00
|
|
|
$lcs = $this->buildDiffLCS($textSource, $textOther, $textStart, $sourceEnd-$textStart, $otherEnd-$textStart);
|
|
|
|
for($x=0,$y=0,$xEnd=$otherEnd-$textStart,$yEnd=$sourceEnd-$textStart; $x<$xEnd || $y<$yEnd;)
|
|
|
|
{
|
|
|
|
$max = $lcs[$y][$x];
|
|
|
|
if($y<$yEnd && $lcs[$y+1][$x]==$max)
|
|
|
|
{
|
2016-07-19 22:12:05 +00:00
|
|
|
array_push($diff, array(YellowMerge::REMOVE, $textSource[$textStart+$y], false));
|
|
|
|
if($lastRemove==-1) $lastRemove = count($diff)-1;
|
2014-11-13 13:49:21 +00:00
|
|
|
++$y;
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if($x<$xEnd && $lcs[$y][$x+1]==$max)
|
|
|
|
{
|
2016-07-19 22:12:05 +00:00
|
|
|
if($lastRemove==-1 || $diff[$lastRemove][0]!=YellowMerge::REMOVE)
|
2014-11-13 13:49:21 +00:00
|
|
|
{
|
2016-07-19 22:12:05 +00:00
|
|
|
array_push($diff, array(YellowMerge::ADD, $textOther[$textStart+$x], false));
|
2014-11-13 13:49:21 +00:00
|
|
|
$lastRemove = -1;
|
|
|
|
} else {
|
2016-07-19 22:12:05 +00:00
|
|
|
$diff[$lastRemove] = array(YellowMerge::MODIFY, $textOther[$textStart+$x], false);
|
2014-11-13 13:49:21 +00:00
|
|
|
++$lastRemove; if(count($diff)==$lastRemove) $lastRemove = -1;
|
|
|
|
}
|
|
|
|
++$x;
|
|
|
|
continue;
|
|
|
|
}
|
2016-07-19 22:12:05 +00:00
|
|
|
array_push($diff, array(YellowMerge::SAME, $textSource[$textStart+$y], false));
|
2014-11-13 13:49:21 +00:00
|
|
|
$lastRemove = -1;
|
|
|
|
++$x;
|
|
|
|
++$y;
|
|
|
|
}
|
2016-07-19 22:12:05 +00:00
|
|
|
for($pos=$sourceEnd;$pos<$sourceSize; ++$pos) array_push($diff, array(YellowMerge::SAME, $textSource[$pos], false));
|
2014-11-13 13:49:21 +00:00
|
|
|
return $diff;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Build longest common subsequence
|
|
|
|
function buildDiffLCS($textSource, $textOther, $textStart, $yEnd, $xEnd)
|
|
|
|
{
|
|
|
|
$lcs = array_fill(0, $yEnd+1, array_fill(0, $xEnd+1, 0));
|
|
|
|
for($y=$yEnd-1; $y>=0; --$y)
|
|
|
|
{
|
|
|
|
for($x=$xEnd-1; $x>=0; --$x)
|
|
|
|
{
|
2016-07-19 22:12:05 +00:00
|
|
|
if($textSource[$textStart+$y]==$textOther[$textStart+$x])
|
2014-11-13 13:49:21 +00:00
|
|
|
{
|
|
|
|
$lcs[$y][$x] = $lcs[$y+1][$x+1]+1;
|
|
|
|
} else {
|
|
|
|
$lcs[$y][$x] = max($lcs[$y][$x+1], $lcs[$y+1][$x]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $lcs;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Merge differences
|
|
|
|
function mergeDiff($diffMine, $diffYours)
|
|
|
|
{
|
|
|
|
$diff = array();
|
|
|
|
$posMine = $posYours = 0;
|
|
|
|
while($posMine<count($diffMine) && $posYours<count($diffYours))
|
|
|
|
{
|
|
|
|
$typeMine = $diffMine[$posMine][0];
|
|
|
|
$typeYours = $diffYours[$posYours][0];
|
2016-07-19 22:12:05 +00:00
|
|
|
if($typeMine==YellowMerge::SAME)
|
2014-11-13 13:49:21 +00:00
|
|
|
{
|
|
|
|
array_push($diff, $diffYours[$posYours]);
|
2016-07-19 22:12:05 +00:00
|
|
|
} else if($typeYours==YellowMerge::SAME) {
|
2014-11-13 13:49:21 +00:00
|
|
|
array_push($diff, $diffMine[$posMine]);
|
2016-07-19 22:12:05 +00:00
|
|
|
} else if($typeMine==YellowMerge::ADD && $typeYours==YellowMerge::ADD) {
|
2014-11-13 13:49:21 +00:00
|
|
|
$this->mergeConflict($diff, $diffMine[$posMine], $diffYours[$posYours], false);
|
2016-07-19 22:12:05 +00:00
|
|
|
} else if($typeMine==YellowMerge::MODIFY && $typeYours==YellowMerge::MODIFY) {
|
2014-11-13 13:49:21 +00:00
|
|
|
$this->mergeConflict($diff, $diffMine[$posMine], $diffYours[$posYours], false);
|
2016-07-19 22:12:05 +00:00
|
|
|
} else if($typeMine==YellowMerge::REMOVE && $typeYours==YellowMerge::REMOVE) {
|
2014-11-13 13:49:21 +00:00
|
|
|
array_push($diff, $diffMine[$posMine]);
|
2016-07-19 22:12:05 +00:00
|
|
|
} else if($typeMine==YellowMerge::ADD) {
|
2014-11-13 13:49:21 +00:00
|
|
|
array_push($diff, $diffMine[$posMine]);
|
2016-07-19 22:12:05 +00:00
|
|
|
} else if($typeYours==YellowMerge::ADD) {
|
2014-11-13 13:49:21 +00:00
|
|
|
array_push($diff, $diffYours[$posYours]);
|
|
|
|
} else {
|
|
|
|
$this->mergeConflict($diff, $diffMine[$posMine], $diffYours[$posYours], true);
|
|
|
|
}
|
2015-10-06 12:19:11 +00:00
|
|
|
if(defined("DEBUG") && DEBUG>=2) echo "YellowMerge::mergeDiff $typeMine $typeYours pos:$posMine\t$posYours<br/>\n";
|
2016-07-19 22:12:05 +00:00
|
|
|
if($typeMine==YellowMerge::ADD || $typeYours==YellowMerge::ADD)
|
2014-11-13 13:49:21 +00:00
|
|
|
{
|
2016-07-19 22:12:05 +00:00
|
|
|
if($typeMine==YellowMerge::ADD) ++$posMine;
|
|
|
|
if($typeYours==YellowMerge::ADD) ++$posYours;
|
2014-11-13 13:49:21 +00:00
|
|
|
} else {
|
|
|
|
++$posMine;
|
|
|
|
++$posYours;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
for(;$posMine<count($diffMine); ++$posMine)
|
|
|
|
{
|
|
|
|
array_push($diff, $diffMine[$posMine]);
|
|
|
|
$typeMine = $diffMine[$posMine][0]; $typeYours = ' ';
|
2015-10-06 12:19:11 +00:00
|
|
|
if(defined("DEBUG") && DEBUG>=2) echo "YellowMerge::mergeDiff $typeMine $typeYours pos:$posMine\t$posYours<br/>\n";
|
2014-11-13 13:49:21 +00:00
|
|
|
}
|
|
|
|
for(;$posYours<count($diffYours); ++$posYours)
|
|
|
|
{
|
|
|
|
array_push($diff, $diffYours[$posYours]);
|
|
|
|
$typeYours = $diffYours[$posYours][0]; $typeMine = ' ';
|
2015-10-06 12:19:11 +00:00
|
|
|
if(defined("DEBUG") && DEBUG>=2) echo "YellowMerge::mergeDiff $typeMine $typeYours pos:$posMine\t$posYours<br/>\n";
|
2014-11-13 13:49:21 +00:00
|
|
|
}
|
|
|
|
return $diff;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Merge potential conflict
|
|
|
|
function mergeConflict(&$diff, $diffMine, $diffYours, $conflict)
|
|
|
|
{
|
|
|
|
if(!$conflict && $diffMine[1]==$diffYours[1])
|
|
|
|
{
|
|
|
|
array_push($diff, $diffMine);
|
|
|
|
} else {
|
|
|
|
array_push($diff, array($diffMine[0], $diffMine[1], true));
|
|
|
|
array_push($diff, array($diffYours[0], $diffYours[1], true));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-07-19 22:12:05 +00:00
|
|
|
// Return merged text, null if not possible
|
2014-11-13 13:49:21 +00:00
|
|
|
function getOutput($diff, $showDiff = false)
|
|
|
|
{
|
|
|
|
$output = "";
|
|
|
|
if(!$showDiff)
|
|
|
|
{
|
|
|
|
for($i=0; $i<count($diff); ++$i)
|
|
|
|
{
|
2016-07-19 22:12:05 +00:00
|
|
|
if($diff[$i][0]!=YellowMerge::REMOVE) $output .= $diff[$i][1];
|
2014-11-13 13:49:21 +00:00
|
|
|
$conflict |= $diff[$i][2];
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
for($i=0; $i<count($diff); ++$i)
|
|
|
|
{
|
|
|
|
$output .= $diff[$i][2] ? "! " : $diff[$i][0].' ';
|
|
|
|
$output .= $diff[$i][1];
|
|
|
|
}
|
|
|
|
}
|
2016-07-19 22:12:05 +00:00
|
|
|
return !$conflict ? $output : null;
|
2014-11-13 13:49:21 +00:00
|
|
|
}
|
|
|
|
}
|
2013-04-14 22:41:04 +00:00
|
|
|
|
2016-07-19 22:12:05 +00:00
|
|
|
$yellow->plugins->register("webinterface", "YellowWebinterface", YellowWebinterface::VERSION);
|
2013-04-14 22:41:04 +00:00
|
|
|
?>
|