247 lines
4.8 KiB
PHP
247 lines
4.8 KiB
PHP
<?php defined('BLUDIT') or die('Bludit CMS.');
|
|
|
|
class Plugin {
|
|
|
|
// (string) Plugin's directory name
|
|
public $directoryName;
|
|
|
|
// (string) Database path and filename
|
|
public $filenameDb;
|
|
|
|
public $filenameMetadata;
|
|
|
|
// (array) Database unserialized
|
|
public $db;
|
|
|
|
// (array) Database fields, only for initialize.
|
|
public $dbFields;
|
|
|
|
// (string) Plugin's class name.
|
|
public $className;
|
|
|
|
// (array) Plugin's information.
|
|
public $metadata;
|
|
|
|
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();
|
|
|
|
// Initialize dbFields from the children.
|
|
$this->init();
|
|
|
|
// Init empty database
|
|
$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;
|
|
}
|
|
}
|
|
|
|
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 item from plugin-data.
|
|
public function getMetadata($key)
|
|
{
|
|
if(isset($this->metadata[$key])) {
|
|
return $this->metadata[$key];
|
|
}
|
|
|
|
return '';
|
|
}
|
|
|
|
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;
|
|
}
|
|
|
|
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 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;
|
|
}
|
|
|
|
public function workspace()
|
|
{
|
|
return PATH_PLUGINS_DATABASES.$this->directoryName.DS;
|
|
}
|
|
|
|
// 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()
|
|
{
|
|
// Delete all files.
|
|
$files = Filesystem::listFiles( $this->phpPathDB() );
|
|
foreach($files as $file) {
|
|
unlink($file);
|
|
}
|
|
|
|
// Delete the directory.
|
|
rmdir(PATH_PLUGINS_DATABASES.$this->directoryName);
|
|
}
|
|
|
|
public function installed()
|
|
{
|
|
return file_exists($this->filenameDb);
|
|
}
|
|
|
|
public function init()
|
|
{
|
|
// This method is used on childre classes.
|
|
// The user can define your own dbFields.
|
|
}
|
|
|
|
} |