303 lines
6.3 KiB
PHP
303 lines
6.3 KiB
PHP
<?php defined('BLUDIT') or die('Bludit CMS.');
|
|
|
|
class Plugin {
|
|
|
|
// (string) directory name, just the name
|
|
// Ex: sitemap
|
|
public $directoryName;
|
|
|
|
// (string) Absoulute database filename and path
|
|
// Ex: /www/bludit/bl-content/plugins/sitemap/db.php
|
|
public $filenameDb;
|
|
|
|
// (string) Absoulute metadata filename and path
|
|
// Ex: /www/bludit/bl-plugins/sitemap/metadata.json
|
|
public $filenameMetadata;
|
|
|
|
// (array) Plugin metadata
|
|
// Ex: array('author'=>'',...., 'notes'=>'')
|
|
public $metadata;
|
|
|
|
// (string) Class name
|
|
// Ex: pluginSitemap
|
|
public $className;
|
|
|
|
// (array) Database unserialized
|
|
public $db;
|
|
|
|
// (array) Database fields, only for initialize
|
|
public $dbFields;
|
|
|
|
// (boolean) Enable or disable default Save and Cancel button on plugin settings
|
|
public $formButtons;
|
|
|
|
function __construct()
|
|
{
|
|
$this->dbFields = array();
|
|
|
|
$reflector = new ReflectionClass(get_class($this));
|
|
|
|
// Directory name
|
|
$this->directoryName = basename(dirname($reflector->getFileName()));
|
|
|
|
// Class Name
|
|
$this->className = $reflector->getName();
|
|
|
|
$this->formButtons = true;
|
|
|
|
// Call the method init() from the children
|
|
$this->init();
|
|
|
|
// Init empty database with default values
|
|
$this->db = $this->dbFields;
|
|
|
|
$this->filenameDb = PATH_PLUGINS_DATABASES.$this->directoryName.DS.'db.php';
|
|
|
|
// --- Metadata ---
|
|
$this->filenameMetadata = PATH_PLUGINS.$this->directoryName().DS.'metadata.json';
|
|
$metadataString = file_get_contents($this->filenameMetadata);
|
|
$this->metadata = json_decode($metadataString, true);
|
|
|
|
// If the plugin is installed then get the database
|
|
if($this->installed()) {
|
|
$Tmp = new dbJSON($this->filenameDb);
|
|
$this->db = $Tmp->db;
|
|
}
|
|
}
|
|
|
|
// DEPRECATED
|
|
// 2017-06-19
|
|
public function setDb($args)
|
|
{
|
|
foreach($this->dbFields as $key=>$value) {
|
|
if( isset($args[$key]) ) {
|
|
$value = Sanitize::html( $args[$key] );
|
|
if($value==='false') { $value = false; }
|
|
elseif($value==='true') { $value = true; }
|
|
settype($value, gettype($this->dbFields[$key]));
|
|
$this->db[$key] = $value;
|
|
}
|
|
}
|
|
|
|
$this->save();
|
|
}
|
|
|
|
public function save()
|
|
{
|
|
$tmp = new dbJSON($this->filenameDb);
|
|
$tmp->db = $this->db;
|
|
$tmp->save();
|
|
}
|
|
|
|
public function htmlPath()
|
|
{
|
|
return HTML_PATH_PLUGINS.$this->directoryName.'/';
|
|
}
|
|
|
|
public function phpPath()
|
|
{
|
|
return PATH_PLUGINS.$this->directoryName.DS;
|
|
}
|
|
|
|
public function phpPathDB()
|
|
{
|
|
return PATH_PLUGINS_DATABASES.$this->directoryName.DS;
|
|
}
|
|
|
|
// Returns the value of the key from the metadata of the plugin, FALSE if the key doen't exit
|
|
public function getMetadata($key)
|
|
{
|
|
if(isset($this->metadata[$key])) {
|
|
return $this->metadata[$key];
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
// Set a key / value on the metadata of the plugin
|
|
public function setMetadata($key, $value)
|
|
{
|
|
$this->metadata[$key] = $value;
|
|
return true;
|
|
}
|
|
|
|
// Returns the value of the field from the database
|
|
// (string) $field
|
|
// (boolean) $html, TRUE returns the value sanitized, FALSE unsanitized
|
|
public function getValue($field, $html=true)
|
|
{
|
|
if( isset($this->db[$field]) ) {
|
|
if($html) {
|
|
return $this->db[$field];
|
|
}
|
|
else {
|
|
return Sanitize::htmlDecode($this->db[$field]);
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
|
|
// DEPRECATED
|
|
// 2017-06-16
|
|
public function getDbField($key, $html=true)
|
|
{
|
|
if(isset($this->db[$key])) {
|
|
|
|
if($html) {
|
|
// All fields from DBField are sanitized.
|
|
return $this->db[$key];
|
|
}
|
|
else {
|
|
// Decode HTML tags, this action unsanitized the variable.
|
|
return Sanitize::htmlDecode($this->db[$key]);
|
|
}
|
|
}
|
|
|
|
return '';
|
|
}
|
|
|
|
public function name()
|
|
{
|
|
return $this->getMetadata('name');
|
|
}
|
|
|
|
public function description()
|
|
{
|
|
return $this->getMetadata('description');
|
|
}
|
|
|
|
public function author()
|
|
{
|
|
return $this->getMetadata('author');
|
|
}
|
|
|
|
public function email()
|
|
{
|
|
return $this->getMetadata('email');
|
|
}
|
|
|
|
public function website()
|
|
{
|
|
return $this->getMetadata('website');
|
|
}
|
|
|
|
public function version()
|
|
{
|
|
return $this->getMetadata('version');
|
|
}
|
|
|
|
public function releaseDate()
|
|
{
|
|
return $this->getMetadata('releaseDate');
|
|
}
|
|
|
|
public function className()
|
|
{
|
|
return $this->className;
|
|
}
|
|
|
|
public function formButtons()
|
|
{
|
|
return $this->formButtons;
|
|
}
|
|
|
|
public function isCompatible()
|
|
{
|
|
$bluditRoot = explode('.', BLUDIT_VERSION);
|
|
$compatible = explode(',', $this->getMetadata('compatible'));
|
|
foreach( $compatible as $version ) {
|
|
$root = explode('.', $version);
|
|
if( $root[0]==$bluditRoot[0] && $root[1]==$bluditRoot[1] ) {
|
|
return true;
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
|
|
public function directoryName()
|
|
{
|
|
return $this->directoryName;
|
|
}
|
|
|
|
// Return TRUE if the installation success, otherwise FALSE.
|
|
public function install($position=0)
|
|
{
|
|
if($this->installed()) {
|
|
return false;
|
|
}
|
|
|
|
// Create plugin directory for databases and other files
|
|
mkdir(PATH_PLUGINS_DATABASES.$this->directoryName, 0755, true);
|
|
|
|
// Create database
|
|
$this->dbFields['position'] = $position;
|
|
$this->setDb($this->dbFields);
|
|
|
|
return true;
|
|
}
|
|
|
|
public function uninstall()
|
|
{
|
|
$path = PATH_PLUGINS_DATABASES.$this->directoryName;
|
|
return Filesystem::deleteRecursive($path);
|
|
}
|
|
|
|
public function installed()
|
|
{
|
|
return file_exists($this->filenameDb);
|
|
}
|
|
|
|
public function workspace()
|
|
{
|
|
return PATH_PLUGINS_DATABASES.$this->directoryName.DS;
|
|
}
|
|
|
|
public function init()
|
|
{
|
|
// This method is used on childre classes.
|
|
// The user can define his own field of the database
|
|
}
|
|
|
|
public function post()
|
|
{
|
|
$args = $_POST;
|
|
foreach($this->dbFields as $key=>$value) {
|
|
if( isset($args[$key]) ) {
|
|
$value = Sanitize::html( $args[$key] );
|
|
if($value==='false') { $value = false; }
|
|
elseif($value==='true') { $value = true; }
|
|
settype($value, gettype($this->dbFields[$key]));
|
|
$this->db[$key] = $value;
|
|
}
|
|
}
|
|
|
|
return $this->save();
|
|
}
|
|
|
|
// Returns the parameters after the URI, FALSE if the URI doesn't match with the webhook
|
|
// Example: https://www.mybludit.com/api/foo/bar
|
|
public function webhook($URI=false, $returnsAfterURI=false)
|
|
{
|
|
global $Url;
|
|
|
|
if(empty($URI)) {
|
|
return false;
|
|
}
|
|
|
|
// Check URI start with the webhook
|
|
$startString = HTML_PATH_ROOT.$URI;
|
|
$URI = $Url->uri();
|
|
$length = mb_strlen($startString, CHARSET);
|
|
if( mb_substr($URI, 0, $length)!=$startString ) {
|
|
return false;
|
|
}
|
|
|
|
if($returnsAfterURI) {
|
|
return mb_substr($URI, $length);
|
|
}
|
|
|
|
Log::set(__METHOD__.LOG_SEP.'Webhook requested.');
|
|
return true;
|
|
}
|
|
|
|
} |