2016-10-17 12:20:55 +08:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Services;
|
|
|
|
|
2016-12-24 23:06:56 +08:00
|
|
|
use ArrayAccess;
|
2016-10-17 12:20:55 +08:00
|
|
|
use Illuminate\Support\Arr;
|
2016-10-24 22:32:07 +08:00
|
|
|
use Illuminate\Contracts\Support\Arrayable;
|
2016-10-17 12:20:55 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @property string $name
|
|
|
|
* @property string $description
|
2016-10-24 22:32:07 +08:00
|
|
|
* @property string $title
|
|
|
|
* @property array $author
|
2016-10-17 12:20:55 +08:00
|
|
|
*/
|
2016-12-24 23:06:56 +08:00
|
|
|
class Plugin implements Arrayable, ArrayAccess
|
2016-10-17 12:20:55 +08:00
|
|
|
{
|
|
|
|
/**
|
2016-12-31 16:07:12 +08:00
|
|
|
* The full directory of this plugin.
|
2016-10-17 12:20:55 +08:00
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $path;
|
|
|
|
|
2016-12-31 16:07:12 +08:00
|
|
|
/**
|
|
|
|
* The directory name where the plugin installed.
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $dirname;
|
|
|
|
|
2016-10-17 12:20:55 +08:00
|
|
|
/**
|
|
|
|
* package.json of the package.
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected $packageInfo;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether the plugin is installed.
|
|
|
|
*
|
|
|
|
* @var bool
|
|
|
|
*/
|
|
|
|
protected $installed = true;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The installed version of the plugin.
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $version;
|
|
|
|
|
2016-10-24 22:32:07 +08:00
|
|
|
/**
|
|
|
|
* The namespace used by the plugin.
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $namespace;
|
|
|
|
|
2016-10-17 12:20:55 +08:00
|
|
|
/**
|
|
|
|
* Whether the plugin is enabled.
|
|
|
|
*
|
|
|
|
* @var bool
|
|
|
|
*/
|
|
|
|
protected $enabled = false;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param $path
|
|
|
|
* @param array $packageInfo
|
|
|
|
*/
|
|
|
|
public function __construct($path, $packageInfo)
|
|
|
|
{
|
|
|
|
$this->path = $path;
|
|
|
|
$this->packageInfo = $packageInfo;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* {@inheritdoc}
|
|
|
|
*/
|
|
|
|
public function __get($name)
|
|
|
|
{
|
2017-01-18 22:57:15 +08:00
|
|
|
return $this->packageInfoAttribute(snake_case($name, '-'));
|
2016-10-17 12:20:55 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* {@inheritdoc}
|
|
|
|
*/
|
|
|
|
public function __isset($name)
|
|
|
|
{
|
2017-01-18 22:57:15 +08:00
|
|
|
return isset($this->{$name}) || $this->packageInfoAttribute(snake_case($name, '-'));
|
2016-10-17 12:20:55 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Dot notation getter for composer.json attributes.
|
|
|
|
*
|
|
|
|
* @see https://laravel.com/docs/5.1/helpers#arrays
|
|
|
|
*
|
|
|
|
* @param $name
|
|
|
|
* @return mixed
|
|
|
|
*/
|
|
|
|
public function packageInfoAttribute($name)
|
|
|
|
{
|
|
|
|
return Arr::get($this->packageInfo, $name);
|
|
|
|
}
|
|
|
|
|
2017-01-08 16:05:54 +08:00
|
|
|
public function assets($relativeUri)
|
|
|
|
{
|
|
|
|
return url("plugins/{$this->getDirname()}/$relativeUri");
|
|
|
|
}
|
|
|
|
|
2016-10-17 12:20:55 +08:00
|
|
|
/**
|
|
|
|
* @param bool $installed
|
|
|
|
* @return Plugin
|
|
|
|
*/
|
|
|
|
public function setInstalled($installed)
|
|
|
|
{
|
|
|
|
$this->installed = $installed;
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function isInstalled()
|
|
|
|
{
|
|
|
|
return $this->installed;
|
|
|
|
}
|
|
|
|
|
2016-12-31 16:07:12 +08:00
|
|
|
public function getDirname()
|
|
|
|
{
|
|
|
|
return $this->dirname;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function setDirname($dirname)
|
|
|
|
{
|
|
|
|
$this->dirname = $dirname;
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2016-10-24 22:32:07 +08:00
|
|
|
public function getNameSpace()
|
|
|
|
{
|
|
|
|
return $this->namespace;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function setNameSpace($namespace)
|
|
|
|
{
|
|
|
|
$this->namespace = $namespace;
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getViewPath($name)
|
|
|
|
{
|
2017-01-17 21:41:20 +08:00
|
|
|
return $this->getViewPathByFileName("$name.tpl");
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getViewPathByFileName($filename)
|
|
|
|
{
|
|
|
|
return $this->path."/views/$filename";
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getConfigView()
|
|
|
|
{
|
|
|
|
return $this->hasConfigView() ? view()->file($this->getViewPathByFileName(Arr::get($this->packageInfo, 'config'))) : null;
|
2016-10-17 17:51:51 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
public function hasConfigView()
|
|
|
|
{
|
2017-01-17 21:41:20 +08:00
|
|
|
$filename = Arr::get($this->packageInfo, 'config');
|
|
|
|
|
|
|
|
return $filename && file_exists($this->getViewPathByFileName($filename));
|
2016-10-17 17:51:51 +08:00
|
|
|
}
|
|
|
|
|
2016-10-17 12:20:55 +08:00
|
|
|
/**
|
|
|
|
* @param string $version
|
|
|
|
* @return Plugin
|
|
|
|
*/
|
|
|
|
public function setVersion($version)
|
|
|
|
{
|
|
|
|
$this->version = $version;
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getVersion()
|
|
|
|
{
|
|
|
|
return $this->version;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param bool $enabled
|
|
|
|
* @return Plugin
|
|
|
|
*/
|
|
|
|
public function setEnabled($enabled)
|
|
|
|
{
|
|
|
|
$this->enabled = $enabled;
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function isEnabled()
|
|
|
|
{
|
|
|
|
return $this->enabled;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getPath()
|
|
|
|
{
|
|
|
|
return $this->path;
|
|
|
|
}
|
|
|
|
|
2016-12-24 23:06:56 +08:00
|
|
|
/**
|
|
|
|
* Determine if the given option option exists.
|
|
|
|
*
|
|
|
|
* @param string $key
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function offsetExists($key)
|
|
|
|
{
|
|
|
|
return Arr::has($this->packageInfo, $key);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get a option option.
|
|
|
|
*
|
|
|
|
* @param string $key
|
|
|
|
* @return mixed
|
|
|
|
*/
|
|
|
|
public function offsetGet($key)
|
|
|
|
{
|
|
|
|
return $this->packageInfoAttribute($key);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set a option option.
|
|
|
|
*
|
|
|
|
* @param string $key
|
|
|
|
* @param mixed $value
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function offsetSet($key, $value)
|
|
|
|
{
|
|
|
|
return Arr::set($this->packageInfo, $key, $value);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Unset a option option.
|
|
|
|
*
|
|
|
|
* @param string $key
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function offsetUnset($key)
|
|
|
|
{
|
|
|
|
unset($this->packageInfo[$key]);
|
|
|
|
}
|
|
|
|
|
2016-10-17 12:20:55 +08:00
|
|
|
/**
|
|
|
|
* Generates an array result for the object.
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function toArray()
|
|
|
|
{
|
|
|
|
return (array) array_merge([
|
|
|
|
'name' => $this->name,
|
|
|
|
'version' => $this->getVersion(),
|
|
|
|
'path' => $this->path
|
|
|
|
], $this->packageInfo);
|
|
|
|
}
|
|
|
|
}
|