2016-05-29 19:21:11 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
class pluginAPI extends Plugin {
|
|
|
|
|
2017-06-25 22:54:59 +02:00
|
|
|
private $method;
|
|
|
|
|
2016-05-30 05:36:13 +02:00
|
|
|
public function init()
|
|
|
|
{
|
2017-06-22 00:21:08 +02:00
|
|
|
// Generate the API Token
|
|
|
|
$token = md5( uniqid().time().DOMAIN );
|
2016-06-05 03:31:07 +02:00
|
|
|
|
2016-05-30 05:36:13 +02:00
|
|
|
$this->dbFields = array(
|
2017-06-22 00:21:08 +02:00
|
|
|
'token'=>$token, // API Token
|
2018-08-06 21:46:58 +02:00
|
|
|
'numberOfItems'=>15 // Amount of items to return
|
2016-05-30 05:36:13 +02:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2019-02-25 16:32:47 +01:00
|
|
|
public function getToken()
|
|
|
|
{
|
|
|
|
return $this->getValue('token');
|
|
|
|
}
|
|
|
|
|
2016-05-30 05:36:13 +02:00
|
|
|
public function form()
|
|
|
|
{
|
2018-08-05 17:54:20 +02:00
|
|
|
global $L;
|
2017-06-25 22:54:59 +02:00
|
|
|
|
2018-07-01 14:17:24 +02:00
|
|
|
$html = '<div class="alert alert-primary" role="alert">';
|
|
|
|
$html .= $this->description();
|
|
|
|
$html .= '</div>';
|
|
|
|
|
2018-08-09 23:15:52 +02:00
|
|
|
$html .= '<div>';
|
|
|
|
$html .= '<label>'.$L->get('URL').'</label>';
|
2019-04-07 20:43:42 +02:00
|
|
|
$html .= '<p class="text-muted">'.DOMAIN_BASE.'api/{endpoint}</p>';
|
2018-08-09 23:15:52 +02:00
|
|
|
$html .= '</div>';
|
|
|
|
|
2018-07-01 14:17:24 +02:00
|
|
|
$html .= '<div>';
|
2018-08-05 17:54:20 +02:00
|
|
|
$html .= '<label>'.$L->get('API Token').'</label>';
|
2017-06-25 22:54:59 +02:00
|
|
|
$html .= '<input name="token" type="text" value="'.$this->getValue('token').'">';
|
2018-08-05 17:54:20 +02:00
|
|
|
$html .= '<span class="tip">'.$L->get('This token is for read only and is regenerated every time you install the plugin').'</span>';
|
2016-05-30 05:36:13 +02:00
|
|
|
$html .= '</div>';
|
|
|
|
|
2016-06-05 03:31:07 +02:00
|
|
|
$html .= '<div>';
|
2018-08-05 17:54:20 +02:00
|
|
|
$html .= '<label>'.$L->get('Amount of pages').'</label>';
|
2018-08-06 21:46:58 +02:00
|
|
|
$html .= '<input id="jsnumberOfItems" name="numberOfItems" type="text" value="'.$this->getValue('numberOfItems').'">';
|
2018-08-05 17:54:20 +02:00
|
|
|
$html .= '<span class="tip">'.$L->get('This is the maximum of pages to return when you call to').'</span>';
|
2016-06-05 03:31:07 +02:00
|
|
|
$html .= '</div>';
|
2016-06-03 03:37:52 +02:00
|
|
|
|
2016-05-30 05:36:13 +02:00
|
|
|
return $html;
|
|
|
|
}
|
|
|
|
|
2016-12-01 02:39:16 +01:00
|
|
|
|
|
|
|
// API HOOKS
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
2017-07-05 23:30:30 +02:00
|
|
|
public function beforeAll()
|
2016-09-25 20:38:15 +02:00
|
|
|
{
|
2018-07-17 19:13:01 +02:00
|
|
|
global $url;
|
2018-08-03 18:59:23 +02:00
|
|
|
global $pages;
|
|
|
|
global $users;
|
2016-09-25 20:38:15 +02:00
|
|
|
|
2017-06-22 00:21:08 +02:00
|
|
|
// CHECK URL
|
|
|
|
// ------------------------------------------------------------
|
2017-07-29 01:20:47 +02:00
|
|
|
$URI = $this->webhook('api', $returnsAfterURI=true, $fixed=false);
|
2017-07-19 22:50:08 +02:00
|
|
|
if ($URI===false) {
|
2016-12-01 02:39:16 +01:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2017-06-25 22:54:59 +02:00
|
|
|
// METHOD
|
|
|
|
// ------------------------------------------------------------
|
|
|
|
$method = $this->getMethod();
|
|
|
|
|
2017-07-19 22:50:08 +02:00
|
|
|
// METHOD INPUTS
|
2016-12-01 02:39:16 +01:00
|
|
|
// ------------------------------------------------------------
|
2017-07-19 22:50:08 +02:00
|
|
|
$inputs = $this->getMethodInputs();
|
2019-02-19 08:38:17 +01:00
|
|
|
if (empty($inputs)) {
|
2019-02-08 08:53:26 +01:00
|
|
|
$this->response(400, 'Bad Request', array('message'=>'Missing method inputs.'));
|
2017-07-07 23:38:01 +02:00
|
|
|
}
|
|
|
|
|
2017-07-19 22:50:08 +02:00
|
|
|
// ENDPOINT PARAMETERS
|
2016-12-01 02:39:16 +01:00
|
|
|
// ------------------------------------------------------------
|
2017-07-19 22:50:08 +02:00
|
|
|
$parameters = $this->getEndpointParameters($URI);
|
2019-02-19 08:38:17 +01:00
|
|
|
if (empty($parameters)) {
|
2019-02-08 08:53:26 +01:00
|
|
|
$this->response(400, 'Bad Request', array('message'=>'Missing endpoint parameters.'));
|
2017-07-07 23:38:01 +02:00
|
|
|
}
|
|
|
|
|
2021-01-23 22:19:47 +01:00
|
|
|
$parmA = isset($parameters[0])?$parameters[0]:'';
|
|
|
|
$parmB = isset($parameters[1])?$parameters[1]:'';
|
|
|
|
$parmC = isset($parameters[2])?$parameters[2]:'';
|
|
|
|
$parmD = isset($parameters[3])?$parameters[3]:'';
|
|
|
|
|
2017-06-22 00:21:08 +02:00
|
|
|
// API TOKEN
|
|
|
|
// ------------------------------------------------------------
|
2017-08-30 20:02:31 +02:00
|
|
|
// Token from the plugin, the user can change it on the settings of the plugin
|
2017-06-22 00:21:08 +02:00
|
|
|
$tokenAPI = $this->getValue('token');
|
2016-12-01 02:39:16 +01:00
|
|
|
|
2017-06-22 00:21:08 +02:00
|
|
|
// Check empty token
|
2017-09-22 23:11:08 +02:00
|
|
|
if (empty($inputs['token'])) {
|
2019-02-08 08:53:26 +01:00
|
|
|
$this->response(400, 'Bad Request', array('message'=>'Missing API token.'));
|
2016-12-01 02:39:16 +01:00
|
|
|
}
|
2017-06-22 00:21:08 +02:00
|
|
|
|
2017-08-30 20:02:31 +02:00
|
|
|
// Check if the token is valid
|
2017-07-19 22:50:08 +02:00
|
|
|
if ($inputs['token']!==$tokenAPI) {
|
|
|
|
$this->response(401, 'Unauthorized', array('message'=>'Invalid API token.'));
|
2016-12-01 02:39:16 +01:00
|
|
|
}
|
|
|
|
|
2017-06-22 00:21:08 +02:00
|
|
|
// AUTHENTICATION TOKEN
|
2016-12-01 02:39:16 +01:00
|
|
|
// ------------------------------------------------------------
|
2017-06-22 00:21:08 +02:00
|
|
|
$writePermissions = false;
|
2018-08-10 15:41:23 +02:00
|
|
|
if (!empty($inputs['authentication'])) {
|
2017-09-23 13:10:05 +02:00
|
|
|
|
|
|
|
// Get the user with the authentication token, FALSE if doesn't exit
|
2018-08-03 18:59:23 +02:00
|
|
|
$username = $users->getByAuthToken($inputs['authentication']);
|
2017-07-19 22:50:08 +02:00
|
|
|
if ($username!==false) {
|
2018-08-10 15:41:23 +02:00
|
|
|
try {
|
|
|
|
$user = new User($username);
|
|
|
|
if (($user->role()=='admin') && ($user->enabled())) {
|
|
|
|
// Loggin the user to create the session
|
|
|
|
$login = new Login();
|
|
|
|
$login->setLogin($username, 'admin');
|
|
|
|
// Enable write permissions
|
|
|
|
$writePermissions = true;
|
|
|
|
}
|
|
|
|
} catch (Exception $e) {
|
|
|
|
// Continue without permissions
|
2017-09-23 13:10:05 +02:00
|
|
|
}
|
2016-12-01 02:39:16 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-11-11 19:16:05 +01:00
|
|
|
// Clean inputs
|
|
|
|
// ------------------------------------------------------------
|
|
|
|
unset($inputs['token']);
|
|
|
|
unset($inputs['authentication']);
|
|
|
|
|
2017-07-19 22:50:08 +02:00
|
|
|
// ENDPOINTS
|
2017-06-22 23:50:12 +02:00
|
|
|
// ------------------------------------------------------------
|
2016-12-01 02:39:16 +01:00
|
|
|
|
2021-01-23 22:19:47 +01:00
|
|
|
// /api/pages
|
|
|
|
// /api/pages/files
|
|
|
|
// /api/pages/files/:key
|
|
|
|
// /api/pages/files/:parent/:key
|
|
|
|
// /api/pages/:key
|
|
|
|
// /api/pages/:parent/:key
|
|
|
|
|
2017-06-22 23:50:12 +02:00
|
|
|
// (GET) /api/pages
|
2021-01-23 22:19:47 +01:00
|
|
|
if ( ($method==='GET') && ($parmA==='pages') && empty($parmB) ) {
|
2019-02-19 08:38:17 +01:00
|
|
|
$data = $this->getPages($inputs);
|
2016-12-01 02:39:16 +01:00
|
|
|
}
|
2021-01-23 22:19:47 +01:00
|
|
|
// (POST) /api/pages
|
|
|
|
elseif ( ($method==='POST') && ($parmA==='pages') && empty($parmB) && $writePermissions ) {
|
|
|
|
$data = $this->createPage($inputs);
|
|
|
|
}
|
|
|
|
// (GET) /api/pages/files/:key
|
|
|
|
elseif ( ($method==='GET') && ($parmA==='pages') && ($parmB==='files') && !empty($parmC) ) {
|
|
|
|
$key = $parmC;
|
|
|
|
if (!empty($parmD)) {
|
|
|
|
$key = $parmC.'/'.$parmD;
|
2020-05-12 23:05:29 +02:00
|
|
|
}
|
2021-01-23 22:19:47 +01:00
|
|
|
$data = $this->getFiles($key);
|
2017-09-21 20:42:03 +02:00
|
|
|
}
|
2021-01-23 22:19:47 +01:00
|
|
|
// (POST) /api/pages/files/:key
|
|
|
|
elseif ( ($method==='POST') && ($parmA==='pages') && ($parmB==='files') && !empty($parmC) && $writePermissions ) {
|
|
|
|
$key = $parmC;
|
|
|
|
if (!empty($parmD)) {
|
|
|
|
$key = $parmC.'/'.$parmD;
|
|
|
|
}
|
|
|
|
$data = $this->uploadPageFile($key);
|
2017-09-21 20:42:03 +02:00
|
|
|
}
|
2021-01-23 22:19:47 +01:00
|
|
|
// (DELETE) /api/pages/files/:key
|
|
|
|
elseif ( ($method==='DELETE') && ($parmA==='pages') && ($parmB==='files') && !empty($parmC) && $writePermissions ) {
|
|
|
|
$key = $parmC;
|
|
|
|
if (!empty($parmD)) {
|
|
|
|
$key = $parmC.'/'.$parmD;
|
|
|
|
}
|
|
|
|
// Delete file function
|
2016-12-01 02:39:16 +01:00
|
|
|
}
|
2021-01-23 22:19:47 +01:00
|
|
|
// (GET) /api/pages/:key
|
|
|
|
elseif ( ($method==='GET') && ($parmA==='pages') && !empty($parmB) ) {
|
|
|
|
$key = $parmB;
|
|
|
|
if (!empty($parmC)) {
|
|
|
|
$key = $parmB.'/'.$parmC;
|
|
|
|
}
|
|
|
|
$data = $this->getPage($key);
|
|
|
|
}
|
|
|
|
// (PUT) /api/pages/:key
|
|
|
|
elseif ( ($method==='PUT') && ($parmA==='pages') && !empty($parmB) && $writePermissions ) {
|
|
|
|
$inputs['key'] = $parmB;
|
|
|
|
if (!empty($parmC)) {
|
|
|
|
$inputs['key'] = $parmB.'/'.$parmC;
|
|
|
|
}
|
|
|
|
$data = $this->editPage($inputs);
|
|
|
|
}
|
|
|
|
// (DELETE) /api/pages/:key
|
|
|
|
elseif ( ($method==='DELETE') && ($parmA==='pages') && !empty($parmB) && $writePermissions ) {
|
|
|
|
$key = $parmB;
|
|
|
|
if (!empty($parmC)) {
|
|
|
|
$key = $parmB.'/'.$parmC;
|
|
|
|
}
|
2021-01-26 22:31:12 +01:00
|
|
|
$data = $this->deletePage(array('key'=>$key));
|
2017-06-22 23:50:12 +02:00
|
|
|
}
|
2019-11-11 19:16:05 +01:00
|
|
|
// (GET) /api/settings
|
2021-01-23 22:19:47 +01:00
|
|
|
elseif ( ($method==='GET') && ($parmA==='settings') && empty($parmB) && $writePermissions ) {
|
2019-11-11 19:16:05 +01:00
|
|
|
$data = $this->getSettings();
|
|
|
|
}
|
2019-09-25 20:19:34 +02:00
|
|
|
// (PUT) /api/settings
|
2021-01-23 22:19:47 +01:00
|
|
|
elseif ( ($method==='PUT') && ($parmA==='settings') && empty($parmB) && $writePermissions ) {
|
2019-09-25 20:19:34 +02:00
|
|
|
$data = $this->editSettings($inputs);
|
|
|
|
}
|
2021-03-09 15:55:08 +01:00
|
|
|
// (POST) /api/settings/logo
|
|
|
|
elseif ( ($method==='POST') && ($parmA==='settings') && ($parmB==='logo') && $writePermissions ) {
|
|
|
|
$data = $this->uploadSiteLogo($inputs);
|
|
|
|
}
|
|
|
|
// (DELETE) /api/settings/logo
|
|
|
|
elseif ( ($method==='DELETE') && ($parmA==='settings') && ($parmB==='logo') && $writePermissions ) {
|
|
|
|
$data = $this->deleteSiteLogo();
|
|
|
|
}
|
2019-02-19 08:38:17 +01:00
|
|
|
// (GET) /api/tags
|
2021-01-23 22:19:47 +01:00
|
|
|
elseif ( ($method==='GET') && ($parmA==='tags') && empty($parmB) ) {
|
2019-02-19 08:38:17 +01:00
|
|
|
$data = $this->getTags();
|
|
|
|
}
|
2021-01-23 22:19:47 +01:00
|
|
|
// (GET) /api/tags/:key
|
|
|
|
elseif ( ($method==='GET') && ($parmA==='tags') && !empty($parmB) ) {
|
|
|
|
$key = $parmB;
|
|
|
|
$data = $this->getTag($key);
|
2019-02-19 08:38:17 +01:00
|
|
|
}
|
2019-05-12 12:32:12 +02:00
|
|
|
// (GET) /api/categories
|
2021-01-23 22:19:47 +01:00
|
|
|
elseif ( ($method==='GET') && ($parmA==='categories') && empty($parmB) ) {
|
2019-05-12 12:32:12 +02:00
|
|
|
$data = $this->getCategories();
|
|
|
|
}
|
2021-01-23 22:19:47 +01:00
|
|
|
// (GET) /api/categories/:key
|
|
|
|
elseif ( ($method==='GET') && ($parmA==='categories') && !empty($parmB) ) {
|
|
|
|
$key = $parmB;
|
|
|
|
$data = $this->getCategory($key);
|
2019-05-12 12:32:12 +02:00
|
|
|
}
|
2021-01-12 21:46:42 +01:00
|
|
|
// (POST) /api/categories
|
2021-01-23 22:19:47 +01:00
|
|
|
elseif ( ($method==='POST') && ($parmA==='categories') && empty($parmB) && $writePermissions ) {
|
2021-01-12 21:46:42 +01:00
|
|
|
$data = $this->createCategory($inputs);
|
|
|
|
}
|
2021-01-23 22:19:47 +01:00
|
|
|
// (PUT) /api/categories/:key
|
|
|
|
elseif ( ($method==='PUT') && ($parmA==='categories') && !empty($parmB) && $writePermissions ) {
|
|
|
|
$inputs['key'] = $parmB;
|
2021-01-16 13:03:16 +01:00
|
|
|
$data = $this->editCategory($inputs);
|
|
|
|
}
|
2021-01-23 22:19:47 +01:00
|
|
|
// (DELETE) /api/categories/:key
|
|
|
|
elseif ( ($method==='DELETE') && ($parmA==='categories') && !empty($parmB) && $writePermissions ) {
|
|
|
|
$inputs['key'] = $parmB;
|
2021-01-16 13:03:16 +01:00
|
|
|
$data = $this->deleteCategory($inputs);
|
|
|
|
}
|
2019-09-25 20:19:34 +02:00
|
|
|
// (GET) /api/users
|
2021-01-23 22:19:47 +01:00
|
|
|
elseif ( ($method==='GET') && ($parmA==='users') && empty($parmB) ) {
|
2019-09-25 20:19:34 +02:00
|
|
|
$data = $this->getUsers();
|
|
|
|
}
|
2021-01-23 22:19:47 +01:00
|
|
|
// (POST) /api/users
|
|
|
|
elseif ( ($method==='POST') && ($parmA==='users') && empty($parmB) && $writePermissions ) {
|
2021-01-12 21:46:42 +01:00
|
|
|
$data = $this->createUser($inputs);
|
|
|
|
}
|
2021-01-23 22:19:47 +01:00
|
|
|
// (POST) /api/users/picture/:username
|
|
|
|
elseif ( ($method==='POST') && ($parmA==='users') && ($parmB==='picture') && !empty($parmC) && $writePermissions ) {
|
|
|
|
$username = $parmC;
|
|
|
|
$data = $this->uploadProfilePicture($username);
|
2020-03-20 19:49:59 +01:00
|
|
|
}
|
2021-01-23 22:19:47 +01:00
|
|
|
// (DELETE) /api/users/picture/:username
|
|
|
|
elseif ( ($method==='DELETE') && ($parmA==='users') && ($parmB==='picture') && !empty($parmC) && $writePermissions ) {
|
|
|
|
$username = $parmC;
|
|
|
|
$data = $this->deleteProfilePicture($username);
|
2020-08-23 18:59:56 +02:00
|
|
|
}
|
2021-01-23 22:19:47 +01:00
|
|
|
// (GET) /api/users/:username
|
|
|
|
elseif ( ($method==='GET') && ($parmA==='users') && !empty($parmB) ) {
|
|
|
|
$username = $parmB;
|
|
|
|
$data = $this->getUser($username);
|
|
|
|
}
|
|
|
|
// (PUT) /api/users/:username
|
|
|
|
elseif ( ($method==='PUT') && ($parmA==='users') && !empty($parmB) ) {
|
|
|
|
$inputs['username'] = $parmB;
|
|
|
|
$data = $this->editUser($inputs);
|
|
|
|
}
|
2021-02-07 17:19:24 +01:00
|
|
|
// (POST) /api/plugins/:key
|
|
|
|
elseif ( ($method==='POST') && ($parmA==='plugins') && !empty($parmB) ) {
|
|
|
|
$pluginClassName = $parmB;
|
|
|
|
$data = $this->activatePlugin($pluginClassName);
|
|
|
|
}
|
2021-02-07 18:13:25 +01:00
|
|
|
// (DELETE) /api/plugins/:key
|
|
|
|
elseif ( ($method==='DELETE') && ($parmA==='plugins') && !empty($parmB) ) {
|
|
|
|
$pluginClassName = $parmB;
|
|
|
|
$data = $this->deactivatePlugin($pluginClassName);
|
|
|
|
}
|
2021-03-19 19:54:09 +01:00
|
|
|
// (PUT) /api/plugins/:key
|
|
|
|
elseif ( ($method==='PUT') && ($parmA==='plugins') && !empty($parmB) ) {
|
|
|
|
$inputs['className'] = $parmB;
|
|
|
|
$data = $this->configurePlugin($inputs);
|
|
|
|
}
|
2021-01-23 22:19:47 +01:00
|
|
|
// (GET) /api/helper/:name
|
|
|
|
elseif ( ($method==='GET') && ($parmA==='helper') && !empty($parmB) ) {
|
|
|
|
$name = $parmB;
|
|
|
|
if ($name=='friendly-url') {
|
2020-11-01 11:55:34 +01:00
|
|
|
$data = $this->getFriendlyURL($inputs);
|
|
|
|
}
|
|
|
|
}
|
2017-06-22 23:50:12 +02:00
|
|
|
else {
|
2017-07-19 22:50:08 +02:00
|
|
|
$this->response(401, 'Unauthorized', array('message'=>'Access denied or invalid endpoint.'));
|
2016-12-02 00:59:58 +01:00
|
|
|
}
|
2017-06-22 23:50:12 +02:00
|
|
|
|
2017-07-19 22:50:08 +02:00
|
|
|
$this->response(200, 'OK', $data);
|
2016-09-25 20:38:15 +02:00
|
|
|
}
|
|
|
|
|
2017-06-22 00:21:08 +02:00
|
|
|
// PRIVATE METHODS
|
2016-12-01 02:39:16 +01:00
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
2017-06-25 22:54:59 +02:00
|
|
|
private function getMethod()
|
|
|
|
{
|
|
|
|
// METHODS
|
|
|
|
// ------------------------------------------------------------
|
|
|
|
// GET
|
|
|
|
// POST
|
|
|
|
// PUT
|
|
|
|
// DELETE
|
|
|
|
|
|
|
|
$this->method = $_SERVER['REQUEST_METHOD'];
|
|
|
|
return $this->method;
|
|
|
|
}
|
|
|
|
|
2017-07-19 22:50:08 +02:00
|
|
|
private function getMethodInputs()
|
2017-06-22 00:21:08 +02:00
|
|
|
{
|
2017-06-25 22:54:59 +02:00
|
|
|
switch($this->method) {
|
2017-06-22 00:21:08 +02:00
|
|
|
case "POST":
|
|
|
|
$inputs = $_POST;
|
|
|
|
break;
|
|
|
|
case "GET":
|
|
|
|
case "DELETE":
|
|
|
|
$inputs = $_GET;
|
|
|
|
break;
|
|
|
|
case "PUT":
|
2017-10-20 20:34:22 +02:00
|
|
|
$inputs = '';
|
2017-06-22 00:21:08 +02:00
|
|
|
break;
|
|
|
|
default:
|
|
|
|
$inputs = json_encode(array());
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2017-10-20 20:34:22 +02:00
|
|
|
// Try to get raw/json data
|
2017-09-22 23:11:08 +02:00
|
|
|
if (empty($inputs)) {
|
|
|
|
$inputs = file_get_contents('php://input');
|
|
|
|
}
|
|
|
|
|
2017-07-07 23:38:01 +02:00
|
|
|
return $this->cleanInputs($inputs);
|
|
|
|
}
|
2017-06-22 00:21:08 +02:00
|
|
|
|
2019-02-19 08:38:17 +01:00
|
|
|
// Returns an array with key=>value with the inputs
|
2017-10-20 20:34:22 +02:00
|
|
|
// If the content is JSON is parsed to array
|
|
|
|
private function cleanInputs($inputs)
|
|
|
|
{
|
|
|
|
$tmp = array();
|
|
|
|
if (is_array($inputs)) {
|
|
|
|
foreach ($inputs as $key=>$value) {
|
|
|
|
$tmp[$key] = Sanitize::html($value);
|
|
|
|
}
|
|
|
|
} elseif (is_string($inputs)) {
|
|
|
|
$tmp = json_decode($inputs, true);
|
|
|
|
if (json_last_error()!==JSON_ERROR_NONE) {
|
|
|
|
$tmp = array();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $tmp;
|
|
|
|
}
|
|
|
|
|
2017-07-19 22:50:08 +02:00
|
|
|
private function getEndpointParameters($URI)
|
|
|
|
{
|
|
|
|
// ENDPOINT Parameters
|
|
|
|
// ------------------------------------------------------------
|
|
|
|
// /api/pages | GET | returns all pages
|
|
|
|
// /api/pages/{key} | GET | returns the page with the {key}
|
|
|
|
// /api/pages | POST | create a new page
|
|
|
|
|
2017-08-30 20:02:31 +02:00
|
|
|
$URI = ltrim($URI, '/');
|
2017-07-19 22:50:08 +02:00
|
|
|
$parameters = explode('/', $URI);
|
|
|
|
|
|
|
|
// Sanitize parameters
|
|
|
|
foreach ($parameters as $key=>$value) {
|
|
|
|
$parameters[$key] = Sanitize::html($value);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $parameters;
|
|
|
|
}
|
|
|
|
|
|
|
|
private function response($code=200, $message='OK', $data=array())
|
2016-12-01 19:09:29 +01:00
|
|
|
{
|
2017-07-19 22:50:08 +02:00
|
|
|
header('HTTP/1.1 '.$code.' '.$message);
|
2017-08-30 20:02:31 +02:00
|
|
|
header('Access-Control-Allow-Origin: *');
|
2016-12-01 19:09:29 +01:00
|
|
|
header('Content-Type: application/json');
|
2017-07-19 22:50:08 +02:00
|
|
|
$json = json_encode($data);
|
2016-12-01 19:09:29 +01:00
|
|
|
exit($json);
|
|
|
|
}
|
|
|
|
|
2019-02-19 08:38:17 +01:00
|
|
|
private function getTags()
|
2016-06-06 04:24:15 +02:00
|
|
|
{
|
2019-02-19 08:38:17 +01:00
|
|
|
global $tags;
|
|
|
|
$tmp = array(
|
|
|
|
'status'=>'0',
|
|
|
|
'message'=>'List of tags.',
|
|
|
|
'data'=>array()
|
|
|
|
);
|
|
|
|
foreach ($tags->keys() as $key) {
|
|
|
|
$tag = $tags->getMap($key);
|
|
|
|
array_push($tmp['data'], $tag);
|
|
|
|
}
|
|
|
|
return $tmp;
|
|
|
|
}
|
2017-06-22 23:50:12 +02:00
|
|
|
|
2019-02-19 08:38:17 +01:00
|
|
|
// Returns the tag information and the pages releated to the tag
|
|
|
|
// The array with the pages has the complete information of each page
|
|
|
|
private function getTag($key)
|
|
|
|
{
|
|
|
|
try {
|
|
|
|
$tag = new Tag($key);
|
|
|
|
} catch (Exception $e) {
|
|
|
|
return array(
|
|
|
|
'status'=>'1',
|
2019-05-12 12:32:12 +02:00
|
|
|
'message'=>'Tag not found by the key: '.$key
|
2019-02-19 08:38:17 +01:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
$list = array();
|
|
|
|
foreach ($tag->pages() as $pageKey) {
|
|
|
|
try {
|
|
|
|
$page = new Page($pageKey);
|
|
|
|
array_push($list, $page->json($returnsArray=true));
|
|
|
|
} catch (Exception $e){}
|
|
|
|
}
|
|
|
|
|
|
|
|
$data = $tag->json($returnsArray=true);
|
|
|
|
$data['pages'] = $list;
|
|
|
|
|
|
|
|
return array(
|
|
|
|
'status'=>'0',
|
2019-05-12 12:32:12 +02:00
|
|
|
'message'=>'Information about the tag and pages related.',
|
2019-02-19 08:38:17 +01:00
|
|
|
'data'=>$data
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
private function getPages($args)
|
|
|
|
{
|
|
|
|
global $pages;
|
2019-02-20 08:45:55 +01:00
|
|
|
|
|
|
|
// Parameters and the default values
|
2019-02-25 16:32:47 +01:00
|
|
|
$published = (isset($args['published'])?$args['published']=='true':true);
|
|
|
|
$static = (isset($args['static'])?$args['static']=='true':false);
|
|
|
|
$draft = (isset($args['draft'])?$args['draft']=='true':false);
|
|
|
|
$sticky = (isset($args['sticky'])?$args['sticky']=='true':false);
|
|
|
|
$scheduled = (isset($args['scheduled'])?$args['scheduled']=='true':false);
|
|
|
|
$untagged = (isset($args['untagged'])?$args['untagged']=='true':false);
|
2019-02-20 08:45:55 +01:00
|
|
|
|
2019-09-25 20:19:34 +02:00
|
|
|
$numberOfItems = (isset($args['numberOfItems'])?$args['numberOfItems']:10);
|
|
|
|
$pageNumber = (isset($args['pageNumber'])?$args['pageNumber']:1);
|
2019-02-19 08:38:17 +01:00
|
|
|
$list = $pages->getList($pageNumber, $numberOfItems, $published, $static, $sticky, $draft, $scheduled);
|
2016-06-06 04:24:15 +02:00
|
|
|
|
2016-12-01 19:09:29 +01:00
|
|
|
$tmp = array(
|
|
|
|
'status'=>'0',
|
2019-09-25 20:19:34 +02:00
|
|
|
'message'=>'List of pages',
|
|
|
|
'numberOfItems'=>$numberOfItems,
|
2016-12-02 00:59:58 +01:00
|
|
|
'data'=>array()
|
2016-12-01 19:09:29 +01:00
|
|
|
);
|
2016-06-06 04:24:15 +02:00
|
|
|
|
2017-12-26 17:45:02 +01:00
|
|
|
foreach ($list as $pageKey) {
|
2018-07-18 21:48:37 +02:00
|
|
|
try {
|
|
|
|
// Create the page object from the page key
|
2018-08-02 17:06:53 +02:00
|
|
|
$page = new Page($pageKey);
|
2019-02-20 08:45:55 +01:00
|
|
|
if ($untagged) {
|
|
|
|
if (empty($page->tags())) {
|
|
|
|
// Push the page to the data array for the response
|
|
|
|
array_push($tmp['data'], $page->json($returnsArray=true));
|
|
|
|
}
|
|
|
|
} else{
|
2019-02-19 08:38:17 +01:00
|
|
|
array_push($tmp['data'], $page->json($returnsArray=true));
|
|
|
|
}
|
2018-07-18 21:48:37 +02:00
|
|
|
} catch (Exception $e) {
|
|
|
|
// Continue
|
|
|
|
}
|
2016-06-06 04:24:15 +02:00
|
|
|
}
|
|
|
|
|
2016-12-01 19:09:29 +01:00
|
|
|
return $tmp;
|
2016-06-06 04:24:15 +02:00
|
|
|
}
|
|
|
|
|
2017-09-21 20:42:03 +02:00
|
|
|
private function getPage($key)
|
|
|
|
{
|
2018-07-18 21:48:37 +02:00
|
|
|
try {
|
2018-08-02 17:06:53 +02:00
|
|
|
$page = new Page($key);
|
2018-07-18 21:48:37 +02:00
|
|
|
return array(
|
|
|
|
'status'=>'0',
|
|
|
|
'message'=>'Page filtered by key: '.$key,
|
|
|
|
'data'=>$page->json( $returnsArray=true )
|
|
|
|
);
|
|
|
|
} catch (Exception $e) {
|
2017-09-21 20:42:03 +02:00
|
|
|
return array(
|
|
|
|
'status'=>'1',
|
|
|
|
'message'=>'Page not found.'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-07-07 23:38:01 +02:00
|
|
|
private function createPage($args)
|
2017-06-22 23:50:12 +02:00
|
|
|
{
|
2018-02-07 20:15:33 +01:00
|
|
|
// Unsanitize content because all values are sanitized
|
|
|
|
if (isset($args['content'])) {
|
2018-07-17 19:13:01 +02:00
|
|
|
$args['content'] = Sanitize::htmlDecode($args['content']);
|
2018-02-07 20:15:33 +01:00
|
|
|
}
|
|
|
|
|
2017-06-22 23:50:12 +02:00
|
|
|
// This function is defined on functions.php
|
2017-09-21 20:42:03 +02:00
|
|
|
$key = createPage($args);
|
|
|
|
if ($key===false) {
|
|
|
|
return array(
|
|
|
|
'status'=>'1',
|
|
|
|
'message'=>'Error trying to create the new page.'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return array(
|
|
|
|
'status'=>'0',
|
|
|
|
'message'=>'Page created.',
|
|
|
|
'data'=>array('key'=>$key)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2020-11-01 11:55:34 +01:00
|
|
|
private function editPage($args)
|
2017-09-21 20:42:03 +02:00
|
|
|
{
|
2018-02-07 20:15:33 +01:00
|
|
|
// Unsanitize content because all values are sanitized
|
|
|
|
if (isset($args['content'])) {
|
2018-08-10 15:41:23 +02:00
|
|
|
$args['content'] = Sanitize::htmlDecode($args['content']);
|
2018-02-07 20:15:33 +01:00
|
|
|
}
|
|
|
|
|
2017-09-21 20:42:03 +02:00
|
|
|
$newKey = editPage($args);
|
|
|
|
|
|
|
|
if ($newKey===false) {
|
|
|
|
return array(
|
|
|
|
'status'=>'1',
|
|
|
|
'message'=>'Error trying to edit the page.'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return array(
|
|
|
|
'status'=>'0',
|
|
|
|
'message'=>'Page edited.',
|
|
|
|
'data'=>array('key'=>$newKey)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2021-01-26 22:31:12 +01:00
|
|
|
private function deletePage($args)
|
2017-09-21 20:42:03 +02:00
|
|
|
{
|
2021-01-26 22:31:12 +01:00
|
|
|
if (deletePage($args)) {
|
2017-09-21 20:42:03 +02:00
|
|
|
return array(
|
|
|
|
'status'=>'0',
|
|
|
|
'message'=>'Page deleted.'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return array(
|
|
|
|
'status'=>'1',
|
|
|
|
'message'=>'Error trying to delete the page.'
|
|
|
|
);
|
2017-06-22 23:50:12 +02:00
|
|
|
}
|
|
|
|
|
2019-11-11 19:16:05 +01:00
|
|
|
/*
|
|
|
|
| Get the settings
|
|
|
|
|
|
|
|
|
| @args array
|
|
|
|
|
|
|
|
|
| @return array
|
|
|
|
*/
|
|
|
|
private function getSettings()
|
|
|
|
{
|
|
|
|
global $site;
|
|
|
|
return array(
|
|
|
|
'status'=>'0',
|
|
|
|
'message'=>'Settings.',
|
|
|
|
'data'=>$site->get()
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2019-05-12 11:50:08 +02:00
|
|
|
/*
|
|
|
|
| Edit the settings
|
|
|
|
| You can edit any field defined in the class site.class.php variable $dbFields
|
|
|
|
|
|
2019-05-12 12:32:12 +02:00
|
|
|
| @args array
|
2019-05-12 11:50:08 +02:00
|
|
|
|
|
2019-05-12 12:32:12 +02:00
|
|
|
| @return array
|
2019-05-12 11:50:08 +02:00
|
|
|
*/
|
|
|
|
private function editSettings($args)
|
|
|
|
{
|
|
|
|
if (editSettings($args)) {
|
|
|
|
return array(
|
|
|
|
'status'=>'0',
|
|
|
|
'message'=>'Settings edited.'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
return array(
|
|
|
|
'status'=>'1',
|
|
|
|
'message'=>'Error trying to edit the settings.'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2019-05-12 12:32:12 +02:00
|
|
|
/*
|
|
|
|
| Returns the categories in the system
|
|
|
|
| Included the category name, key, description and the list of pages
|
|
|
|
| The list of pages are the page's key
|
|
|
|
|
|
|
|
|
| @return array
|
|
|
|
*/
|
|
|
|
private function getCategories()
|
|
|
|
{
|
|
|
|
global $categories;
|
|
|
|
$tmp = array(
|
|
|
|
'status'=>'0',
|
|
|
|
'message'=>'List of categories.',
|
|
|
|
'data'=>array()
|
|
|
|
);
|
|
|
|
foreach ($categories->keys() as $key) {
|
|
|
|
$category = $categories->getMap($key);
|
|
|
|
array_push($tmp['data'], $category);
|
|
|
|
}
|
|
|
|
return $tmp;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
| Returns information about the category and pages related
|
|
|
|
| The pages are expanded which mean the title, content and more fields are returned in the query
|
|
|
|
| This can degrade the performance
|
|
|
|
|
|
|
|
|
| @key string Category key
|
|
|
|
|
|
|
|
|
| @return array
|
|
|
|
*/
|
|
|
|
private function getCategory($key)
|
|
|
|
{
|
|
|
|
try {
|
|
|
|
$category = new Category($key);
|
|
|
|
} catch (Exception $e) {
|
|
|
|
return array(
|
|
|
|
'status'=>'1',
|
|
|
|
'message'=>'Category not found by the key: '.$key
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
$list = array();
|
|
|
|
foreach ($category->pages() as $pageKey) {
|
|
|
|
try {
|
|
|
|
$page = new Page($pageKey);
|
|
|
|
array_push($list, $page->json($returnsArray=true));
|
|
|
|
} catch (Exception $e){}
|
|
|
|
}
|
|
|
|
|
|
|
|
$data = $category->json($returnsArray=true);
|
|
|
|
$data['pages'] = $list;
|
|
|
|
|
|
|
|
return array(
|
|
|
|
'status'=>'0',
|
|
|
|
'message'=>'Information about the category and pages related.',
|
|
|
|
'data'=>$data
|
|
|
|
);
|
|
|
|
}
|
2019-09-25 20:19:34 +02:00
|
|
|
|
2021-01-16 13:03:16 +01:00
|
|
|
/* Create a new category === Bludit v4
|
|
|
|
Referer to the function createCategory() from functions.php
|
|
|
|
*/
|
2021-01-12 21:46:42 +01:00
|
|
|
private function createCategory($args)
|
|
|
|
{
|
|
|
|
$key = createCategory($args);
|
|
|
|
if ($key===false) {
|
|
|
|
return array(
|
|
|
|
'status'=>'1',
|
|
|
|
'message'=>'An error occurred while trying to create the category.'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return array(
|
|
|
|
'status'=>'0',
|
|
|
|
'message'=>'Category created.',
|
|
|
|
'data'=>array('key'=>$key)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2021-01-16 13:03:16 +01:00
|
|
|
/* Edit a category === Bludit v4
|
|
|
|
Referer to the function editCategory() from functions.php
|
|
|
|
*/
|
|
|
|
private function editCategory($args)
|
|
|
|
{
|
|
|
|
$key = editCategory($args);
|
|
|
|
if ($key===false) {
|
|
|
|
return array(
|
|
|
|
'status'=>'1',
|
|
|
|
'message'=>'An error occurred while trying to edit the category.'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return array(
|
|
|
|
'status'=>'0',
|
|
|
|
'message'=>'Category edited.',
|
|
|
|
'data'=>array('key'=>$key)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Delete a category === Bludit v4
|
|
|
|
Referer to the function deleteCategory() from functions.php
|
|
|
|
*/
|
|
|
|
private function deleteCategory($args)
|
|
|
|
{
|
|
|
|
if (deleteCategory($args)) {
|
|
|
|
return array(
|
|
|
|
'status'=>'0',
|
|
|
|
'message'=>'Category deleted.',
|
|
|
|
'data'=>array('key'=>$args['key'])
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return array(
|
|
|
|
'status'=>'1',
|
|
|
|
'message'=>'An error occurred while trying to delete the category.'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2019-09-25 20:19:34 +02:00
|
|
|
/*
|
|
|
|
| Returns the user profile
|
|
|
|
|
|
|
|
|
| @username string Username
|
|
|
|
|
|
|
|
|
| @return array
|
|
|
|
*/
|
|
|
|
private function getUser($username)
|
|
|
|
{
|
|
|
|
try {
|
|
|
|
$user = new User($username);
|
|
|
|
} catch (Exception $e) {
|
|
|
|
return array(
|
|
|
|
'status'=>'1',
|
|
|
|
'message'=>'User not found by username: '.$username
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
$data = $user->json($returnsArray=true);
|
|
|
|
return array(
|
|
|
|
'status'=>'0',
|
|
|
|
'message'=>'User profile.',
|
|
|
|
'data'=>$data
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
| Returns all the users
|
|
|
|
|
|
|
|
|
| @return array
|
|
|
|
*/
|
|
|
|
private function getUsers()
|
|
|
|
{
|
|
|
|
global $users;
|
|
|
|
$data = array();
|
|
|
|
foreach ($users->db as $username=>$profile) {
|
|
|
|
try {
|
|
|
|
$user = new User($username);
|
|
|
|
$data[$username] = $user->json($returnsArray=true);
|
|
|
|
} catch (Exception $e) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return array(
|
|
|
|
'status'=>'0',
|
|
|
|
'message'=>'Users profiles.',
|
|
|
|
'data'=>$data
|
|
|
|
);
|
|
|
|
}
|
2020-03-20 19:49:59 +01:00
|
|
|
|
2021-01-23 22:19:47 +01:00
|
|
|
/* Create a new user === Bludit v4
|
|
|
|
Referer to the function createUser() from functions.php
|
|
|
|
*/
|
2021-01-12 21:46:42 +01:00
|
|
|
private function createUser($args)
|
|
|
|
{
|
|
|
|
$key = createUser($args);
|
|
|
|
if ($key===false) {
|
|
|
|
return array(
|
|
|
|
'status'=>'1',
|
|
|
|
'message'=>'An error occurred while trying to create the user.'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return array(
|
|
|
|
'status'=>'0',
|
|
|
|
'message'=>'User created.',
|
|
|
|
'data'=>array('key'=>$key)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2021-01-23 22:19:47 +01:00
|
|
|
/* Edit an user === Bludit v4
|
|
|
|
Referer to the function editUser() from functions.php
|
2020-08-23 18:59:56 +02:00
|
|
|
*/
|
2021-01-23 22:19:47 +01:00
|
|
|
private function editUser($args)
|
2020-08-23 18:59:56 +02:00
|
|
|
{
|
2021-01-23 22:19:47 +01:00
|
|
|
$key = editUser($args);
|
|
|
|
if ($key===false) {
|
2020-08-23 18:59:56 +02:00
|
|
|
return array(
|
|
|
|
'status'=>'1',
|
2021-01-23 22:19:47 +01:00
|
|
|
'message'=>'An error occurred while trying to edit the user.'
|
2020-08-23 18:59:56 +02:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2021-01-23 22:19:47 +01:00
|
|
|
return array(
|
|
|
|
'status'=>'0',
|
|
|
|
'message'=>'User edited.',
|
|
|
|
'data'=>array('key'=>$key)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Upload a profile picture === Bludit v4
|
|
|
|
Referer to the function uploadProfilePicture() from functions.php
|
|
|
|
*/
|
|
|
|
private function uploadProfilePicture($username)
|
|
|
|
{
|
|
|
|
$data = uploadProfilePicture($username);
|
|
|
|
if ($data===false) {
|
2020-08-23 18:59:56 +02:00
|
|
|
return array(
|
|
|
|
'status'=>'1',
|
2021-01-23 22:19:47 +01:00
|
|
|
'message'=>'An error occurred while trying to upload the profile picture.'
|
2020-08-23 18:59:56 +02:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2021-01-23 22:19:47 +01:00
|
|
|
return array(
|
|
|
|
'status'=>'0',
|
|
|
|
'message'=>'Profile picture uploaded.',
|
|
|
|
'data'=>$data
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Delete a profile picture === Bludit v4
|
|
|
|
Referer to the function deleteProfilePicture() from functions.php
|
|
|
|
*/
|
|
|
|
private function deleteProfilePicture($username)
|
|
|
|
{
|
|
|
|
if (deleteProfilePicture($username)) {
|
2020-08-23 18:59:56 +02:00
|
|
|
return array(
|
|
|
|
'status'=>'0',
|
2021-01-23 22:19:47 +01:00
|
|
|
'message'=>'Profile picture deleted.',
|
|
|
|
'data'=>array('username'=>$username)
|
2020-08-23 18:59:56 +02:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return array(
|
|
|
|
'status'=>'1',
|
2021-01-23 22:19:47 +01:00
|
|
|
'message'=>'An error occurred while trying to delete the profile picture.'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2021-03-09 15:55:08 +01:00
|
|
|
/* Upload the site logo === Bludit v4
|
|
|
|
Referer to the function uploadSiteLogo() from functions.php
|
|
|
|
*/
|
|
|
|
private function uploadSiteLogo($username)
|
|
|
|
{
|
|
|
|
$data = uploadSiteLogo($username);
|
|
|
|
if ($data===false) {
|
|
|
|
return array(
|
|
|
|
'status'=>'1',
|
|
|
|
'message'=>'An error occurred while trying to upload the site logo.'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return array(
|
|
|
|
'status'=>'0',
|
|
|
|
'message'=>'Site logo uploaded.',
|
|
|
|
'data'=>$data
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Delete the site logo === Bludit v4
|
|
|
|
Referer to the function deleteSiteLogo() from functions.php
|
|
|
|
*/
|
|
|
|
private function deleteSiteLogo()
|
|
|
|
{
|
|
|
|
if (deleteSiteLogo()) {
|
|
|
|
return array(
|
|
|
|
'status'=>'0',
|
|
|
|
'message'=>'Site logo deleted.'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return array(
|
|
|
|
'status'=>'1',
|
|
|
|
'message'=>'An error occurred while trying to delete the site logo.'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2021-01-23 22:19:47 +01:00
|
|
|
/* Upload a file to a particular page === Bludit v4
|
|
|
|
Referer to the function uploadPageFile() from functions.php
|
|
|
|
*/
|
|
|
|
private function uploadPageFile($pageKey)
|
|
|
|
{
|
|
|
|
$data = uploadPageFile($pageKey);
|
|
|
|
if ($data===false) {
|
|
|
|
return array(
|
|
|
|
'status'=>'1',
|
|
|
|
'message'=>'An error occurred while trying to upload the file.'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return array(
|
|
|
|
'status'=>'0',
|
|
|
|
'message'=>'File uploaded to the page.',
|
|
|
|
'data'=>$data
|
2020-08-23 18:59:56 +02:00
|
|
|
);
|
|
|
|
}
|
2020-11-01 11:55:34 +01:00
|
|
|
|
|
|
|
/*
|
|
|
|
Generates unique slug text for the a page
|
|
|
|
|
2020-12-29 14:39:47 +01:00
|
|
|
@args['text'] string
|
|
|
|
@args['parentKey'] string
|
|
|
|
@args['pageKey'] string
|
2020-11-01 11:55:34 +01:00
|
|
|
|
2021-01-23 22:19:47 +01:00
|
|
|
@return['data'] string The slug string
|
2020-11-01 11:55:34 +01:00
|
|
|
*/
|
|
|
|
private function getFriendlyURL($args)
|
|
|
|
{
|
|
|
|
global $pages;
|
|
|
|
$slug = $pages->generateKey($args['text'], $args['parentKey'], true, $args['pageKey']);
|
|
|
|
|
|
|
|
return array(
|
|
|
|
'status'=>'0',
|
|
|
|
'message'=>'Friendly URL generated.',
|
2021-01-23 22:19:47 +01:00
|
|
|
'data'=>array('slug'=>$slug)
|
2020-11-01 11:55:34 +01:00
|
|
|
);
|
|
|
|
}
|
2020-12-29 14:39:47 +01:00
|
|
|
|
|
|
|
/*
|
|
|
|
Returns all files uploaded for a specific page.
|
|
|
|
Includes all files types.
|
|
|
|
|
|
|
|
@pageKey string The page's key
|
|
|
|
|
2021-01-23 22:19:47 +01:00
|
|
|
@return['data'] array The list of files
|
2020-12-29 14:39:47 +01:00
|
|
|
*/
|
|
|
|
private function getFiles($pageKey)
|
|
|
|
{
|
|
|
|
$chunk = false;
|
|
|
|
$sortByDate = true;
|
|
|
|
$path = PATH_UPLOADS_PAGES.$pageKey.DS;
|
2021-01-12 21:46:42 +01:00
|
|
|
|
|
|
|
if (Sanitize::pathFile($path) === false) {
|
|
|
|
return array(
|
|
|
|
'status'=>'1',
|
|
|
|
'message'=>'Invalid path.'
|
|
|
|
);
|
|
|
|
}
|
2020-12-29 14:39:47 +01:00
|
|
|
|
|
|
|
$files = array();
|
2021-01-12 21:46:42 +01:00
|
|
|
$listFiles = Filesystem::listFiles($path, '*', '*', $sortByDate, $chunk);
|
2020-12-29 14:39:47 +01:00
|
|
|
foreach ($listFiles as $file) {
|
2021-01-12 21:46:42 +01:00
|
|
|
$filename = basename($file);
|
|
|
|
$absoluteURL = DOMAIN_UPLOADS_PAGES.$pageKey.DS.$filename;
|
|
|
|
$absolutePath = $file;
|
|
|
|
$data = array(
|
|
|
|
'filename'=>$filename,
|
|
|
|
'absolutePath'=>$absolutePath,
|
|
|
|
'absoluteURL'=>$absoluteURL,
|
|
|
|
'mime'=>Filesystem::mimeType($absolutePath),
|
|
|
|
'size'=>Filesystem::getSize($absolutePath),
|
|
|
|
'thumbnail'=>''
|
|
|
|
);
|
2020-12-29 14:39:47 +01:00
|
|
|
|
|
|
|
// Check if thumbnail exists for the file
|
2021-01-12 21:46:42 +01:00
|
|
|
$thumbnail = $path.'thumbnails'.DS.$filename;
|
2020-12-29 14:39:47 +01:00
|
|
|
if (Filesystem::fileExists($thumbnail)) {
|
2021-01-12 21:46:42 +01:00
|
|
|
$data['thumbnail'] = $thumbnail;
|
2020-12-29 14:39:47 +01:00
|
|
|
}
|
|
|
|
|
2021-01-12 21:46:42 +01:00
|
|
|
array_push($files, $data);
|
2020-12-29 14:39:47 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return array(
|
|
|
|
'status'=>'0',
|
|
|
|
'message'=>'Files for the page key: '.$pageKey,
|
|
|
|
'data'=>$files
|
|
|
|
);
|
|
|
|
}
|
2021-02-07 17:19:24 +01:00
|
|
|
|
|
|
|
/* Install and activate a plugin === Bludit v4
|
|
|
|
Referer to the function activatePlugin() from functions.php
|
|
|
|
*/
|
|
|
|
private function activatePlugin($pluginClassName)
|
|
|
|
{
|
|
|
|
if (activatePlugin($pluginClassName)) {
|
|
|
|
return array(
|
|
|
|
'status'=>'0',
|
|
|
|
'message'=>'Plugin installed and activated.',
|
|
|
|
'data'=>array('key'=>$pluginClassName)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return array(
|
|
|
|
'status'=>'1',
|
|
|
|
'message'=>'An error occurred while trying to install the plugin.'
|
|
|
|
);
|
|
|
|
}
|
2021-02-07 18:13:25 +01:00
|
|
|
|
|
|
|
/* Uninstall and deactivate a plugin === Bludit v4
|
|
|
|
Referer to the function deactivatePlugin() from functions.php
|
|
|
|
*/
|
|
|
|
private function deactivatePlugin($pluginClassName)
|
|
|
|
{
|
|
|
|
if (deactivatePlugin($pluginClassName)) {
|
|
|
|
return array(
|
|
|
|
'status'=>'0',
|
|
|
|
'message'=>'Plugin uninstalled and deactivated.',
|
|
|
|
'data'=>array('key'=>$pluginClassName)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return array(
|
|
|
|
'status'=>'1',
|
|
|
|
'message'=>'An error occurred while trying to uninstall the plugin.'
|
|
|
|
);
|
|
|
|
}
|
2021-03-19 19:54:09 +01:00
|
|
|
|
|
|
|
|
|
|
|
/* Configure a plugin === Bludit v4
|
|
|
|
Referer to the function configurePlugin() from functions.php
|
|
|
|
*/
|
|
|
|
private function configurePlugin($args)
|
|
|
|
{
|
|
|
|
if (configurePlugin($args)) {
|
|
|
|
return array(
|
|
|
|
'status'=>'0',
|
|
|
|
'message'=>'Plugin configured.',
|
|
|
|
'data'=>array('key'=>$args['className'])
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return array(
|
|
|
|
'status'=>'1',
|
|
|
|
'message'=>'An error occurred while trying to configure the plugin.'
|
|
|
|
);
|
|
|
|
}
|
2016-12-02 00:59:58 +01:00
|
|
|
}
|