Newer
Older
Benaka Moorthi
a validé
<?php
/**
* Piwik - free/libre analytics platform
Benaka Moorthi
a validé
*
* @link http://piwik.org
* @license http://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
*
*/
namespace Piwik\Plugin;
use Exception;
use Piwik\Piwik;
use Piwik\Version;
Thomas Steur
a validé
use Piwik\Plugin;
Benaka Moorthi
a validé
/**
* @see core/Version.php
*/
require_once PIWIK_INCLUDE_PATH . '/core/Version.php';
Benaka Moorthi
a validé
/**
* Loads plugin metadata found in the following files:
Benaka Moorthi
a validé
*/
class MetadataLoader
Benaka Moorthi
a validé
{
const PLUGIN_JSON_FILENAME = 'plugin.json';
Benaka Moorthi
a validé
/**
* The name of the plugin whose metadata will be loaded.
*
Benaka Moorthi
a validé
* @var string
*/
private $pluginName;
Benaka Moorthi
a validé
/**
* Constructor.
*
Benaka Moorthi
a validé
* @param string $pluginName Name of the plugin to load metadata.
*/
public function __construct($pluginName)
{
$this->pluginName = $pluginName;
}
/**
* Loads plugin metadata. @see Plugin::getInformation.
*
Benaka Moorthi
a validé
* @return array
*/
public function load()
{
$defaults = $this->getDefaultPluginInformation();
$plugin = $this->loadPluginInfoJson();
// use translated plugin description if available
if ($defaults['description'] != Piwik::translate($defaults['description'])) {
unset($plugin['description']);
}
// look for a license file
$licenseFile = $this->getPathToLicenseFile();
if(!empty($licenseFile)) {
$plugin['license_file'] = $licenseFile;
}
Benaka Moorthi
a validé
return array_merge(
$defaults,
$plugin
Benaka Moorthi
a validé
);
}
Thomas Steur
a validé
public function hasPluginJson()
{
$hasJson = $this->loadPluginInfoJson();
return !empty($hasJson);
}
Benaka Moorthi
a validé
private function getDefaultPluginInformation()
{
$descriptionKey = $this->pluginName . '_PluginDescription';
return array(
'description' => $descriptionKey,
Benaka Moorthi
a validé
'homepage' => 'http://piwik.org/',
'authors' => array(array('name' => 'Piwik', 'homepage' => 'http://piwik.org/')),
'license' => 'GPL v3+',
'version' => Version::VERSION,
Benaka Moorthi
a validé
'theme' => false,
'require' => array()
Benaka Moorthi
a validé
);
}
Thomas Steur
a validé
/**
* It is important that this method works without using anything from DI
* @return array|mixed
*/
public function loadPluginInfoJson()
Benaka Moorthi
a validé
{
Thomas Steur
a validé
$path = $this->getPathToPluginJson();
Benaka Moorthi
a validé
return $this->loadJsonMetadata($path);
}
Thomas Steur
a validé
public function getPathToPluginJson()
{
$path = $this->getPathToPluginFolder() . '/' . self::PLUGIN_JSON_FILENAME;
return $path;
}
Benaka Moorthi
a validé
private function loadJsonMetadata($path)
{
if (!file_exists($path)) {
return array();
}
Benaka Moorthi
a validé
$json = file_get_contents($path);
if (!$json) {
return array();
}
$info = json_decode($json, $assoc = true);
Benaka Moorthi
a validé
if (!is_array($info)
|| empty($info)
) {
throw new Exception("Invalid JSON file: $path");
}
Thomas Steur
a validé
Benaka Moorthi
a validé
return $info;
}
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
/**
* @return string
*/
private function getPathToPluginFolder()
{
return \Piwik\Plugin\Manager::getPluginsDirectory() . $this->pluginName;
}
/**
* @return null|string
*/
public function getPathToLicenseFile()
{
$prefixPath = $this->getPathToPluginFolder() . '/';
$licenseFiles = array(
'LICENSE',
'LICENSE.md',
'LICENSE.txt'
);
foreach ($licenseFiles as $licenseFile) {
$pathToLicense = $prefixPath . $licenseFile;
if (is_file($pathToLicense) && is_readable($pathToLicense)) {
return $pathToLicense;
}
}
return null;
}