mirror of
https://github.com/pmmp/PocketMine-MP.git
synced 2025-06-17 08:54:22 +00:00
Merge branch 'release/3.2' into release/3.3
This commit is contained in:
commit
b893645a81
@ -199,122 +199,140 @@ class PluginManager{
|
|||||||
* @return Plugin[]
|
* @return Plugin[]
|
||||||
*/
|
*/
|
||||||
public function loadPlugins(string $directory, array $newLoaders = null){
|
public function loadPlugins(string $directory, array $newLoaders = null){
|
||||||
|
if(!is_dir($directory)){
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
|
||||||
if(is_dir($directory)){
|
$plugins = [];
|
||||||
$plugins = [];
|
$loadedPlugins = [];
|
||||||
$loadedPlugins = [];
|
$dependencies = [];
|
||||||
$dependencies = [];
|
$softDependencies = [];
|
||||||
$softDependencies = [];
|
if(is_array($newLoaders)){
|
||||||
if(is_array($newLoaders)){
|
$loaders = [];
|
||||||
$loaders = [];
|
foreach($newLoaders as $key){
|
||||||
foreach($newLoaders as $key){
|
if(isset($this->fileAssociations[$key])){
|
||||||
if(isset($this->fileAssociations[$key])){
|
$loaders[$key] = $this->fileAssociations[$key];
|
||||||
$loaders[$key] = $this->fileAssociations[$key];
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}else{
|
|
||||||
$loaders = $this->fileAssociations;
|
|
||||||
}
|
}
|
||||||
foreach($loaders as $loader){
|
}else{
|
||||||
foreach(new \DirectoryIterator($directory) as $file){
|
$loaders = $this->fileAssociations;
|
||||||
if($file === "." or $file === ".."){
|
}
|
||||||
|
foreach($loaders as $loader){
|
||||||
|
foreach(new \DirectoryIterator($directory) as $file){
|
||||||
|
if($file === "." or $file === ".."){
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
$file = $directory . $file;
|
||||||
|
if(!$loader->canLoadPlugin($file)){
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
try{
|
||||||
|
$description = $loader->getPluginDescription($file);
|
||||||
|
if($description === null){
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
$file = $directory . $file;
|
|
||||||
if(!$loader->canLoadPlugin($file)){
|
$name = $description->getName();
|
||||||
|
if(stripos($name, "pocketmine") !== false or stripos($name, "minecraft") !== false or stripos($name, "mojang") !== false){
|
||||||
|
$this->server->getLogger()->error($this->server->getLanguage()->translateString("pocketmine.plugin.loadError", [$name, "%pocketmine.plugin.restrictedName"]));
|
||||||
|
continue;
|
||||||
|
}elseif(strpos($name, " ") !== false){
|
||||||
|
$this->server->getLogger()->warning($this->server->getLanguage()->translateString("pocketmine.plugin.spacesDiscouraged", [$name]));
|
||||||
|
}
|
||||||
|
|
||||||
|
if(isset($plugins[$name]) or $this->getPlugin($name) instanceof Plugin){
|
||||||
|
$this->server->getLogger()->error($this->server->getLanguage()->translateString("pocketmine.plugin.duplicateError", [$name]));
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
try{
|
|
||||||
$description = $loader->getPluginDescription($file);
|
|
||||||
if($description instanceof PluginDescription){
|
|
||||||
$name = $description->getName();
|
|
||||||
if(stripos($name, "pocketmine") !== false or stripos($name, "minecraft") !== false or stripos($name, "mojang") !== false){
|
|
||||||
$this->server->getLogger()->error($this->server->getLanguage()->translateString("pocketmine.plugin.loadError", [$name, "%pocketmine.plugin.restrictedName"]));
|
|
||||||
continue;
|
|
||||||
}elseif(strpos($name, " ") !== false){
|
|
||||||
$this->server->getLogger()->warning($this->server->getLanguage()->translateString("pocketmine.plugin.spacesDiscouraged", [$name]));
|
|
||||||
}
|
|
||||||
|
|
||||||
if(isset($plugins[$name]) or $this->getPlugin($name) instanceof Plugin){
|
if(!$this->isCompatibleApi(...$description->getCompatibleApis())){
|
||||||
$this->server->getLogger()->error($this->server->getLanguage()->translateString("pocketmine.plugin.duplicateError", [$name]));
|
$this->server->getLogger()->error($this->server->getLanguage()->translateString("pocketmine.plugin.loadError", [
|
||||||
continue;
|
$name,
|
||||||
}
|
$this->server->getLanguage()->translateString("%pocketmine.plugin.incompatibleAPI", [implode(", ", $description->getCompatibleApis())])
|
||||||
|
]));
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
if(!$this->isCompatibleApi(...$description->getCompatibleApis())){
|
if(count($pluginMcpeProtocols = $description->getCompatibleMcpeProtocols()) > 0){
|
||||||
$this->server->getLogger()->error($this->server->getLanguage()->translateString("pocketmine.plugin.loadError", [
|
$serverMcpeProtocols = [ProtocolInfo::CURRENT_PROTOCOL];
|
||||||
$name,
|
if(count(array_intersect($pluginMcpeProtocols, $serverMcpeProtocols)) === 0){
|
||||||
$this->server->getLanguage()->translateString("%pocketmine.plugin.incompatibleAPI", [implode(", ", $description->getCompatibleApis())])
|
$this->server->getLogger()->error($this->server->getLanguage()->translateString("pocketmine.plugin.loadError", [
|
||||||
]));
|
$name,
|
||||||
continue;
|
$this->server->getLanguage()->translateString("%pocketmine.plugin.incompatibleProtocol", [implode(", ", $pluginMcpeProtocols)])
|
||||||
}
|
]));
|
||||||
|
continue;
|
||||||
if(count($pluginMcpeProtocols = $description->getCompatibleMcpeProtocols()) > 0){
|
|
||||||
$serverMcpeProtocols = [ProtocolInfo::CURRENT_PROTOCOL];
|
|
||||||
if(count(array_intersect($pluginMcpeProtocols, $serverMcpeProtocols)) === 0){
|
|
||||||
$this->server->getLogger()->error($this->server->getLanguage()->translateString("pocketmine.plugin.loadError", [
|
|
||||||
$name,
|
|
||||||
$this->server->getLanguage()->translateString("%pocketmine.plugin.incompatibleProtocol", [implode(", ", $pluginMcpeProtocols)])
|
|
||||||
]));
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$plugins[$name] = $file;
|
|
||||||
|
|
||||||
$softDependencies[$name] = $description->getSoftDepend();
|
|
||||||
$dependencies[$name] = $description->getDepend();
|
|
||||||
|
|
||||||
foreach($description->getLoadBefore() as $before){
|
|
||||||
if(isset($softDependencies[$before])){
|
|
||||||
$softDependencies[$before][] = $name;
|
|
||||||
}else{
|
|
||||||
$softDependencies[$before] = [$name];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}catch(\Throwable $e){
|
}
|
||||||
$this->server->getLogger()->error($this->server->getLanguage()->translateString("pocketmine.plugin.fileError", [$file, $directory, $e->getMessage()]));
|
|
||||||
$this->server->getLogger()->logException($e);
|
$plugins[$name] = $file;
|
||||||
|
|
||||||
|
$softDependencies[$name] = $description->getSoftDepend();
|
||||||
|
$dependencies[$name] = $description->getDepend();
|
||||||
|
|
||||||
|
foreach($description->getLoadBefore() as $before){
|
||||||
|
if(isset($softDependencies[$before])){
|
||||||
|
$softDependencies[$before][] = $name;
|
||||||
|
}else{
|
||||||
|
$softDependencies[$before] = [$name];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}catch(\Throwable $e){
|
||||||
|
$this->server->getLogger()->error($this->server->getLanguage()->translateString("pocketmine.plugin.fileError", [$file, $directory, $e->getMessage()]));
|
||||||
|
$this->server->getLogger()->logException($e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
while(count($plugins) > 0){
|
||||||
|
$missingDependency = true;
|
||||||
|
foreach($plugins as $name => $file){
|
||||||
|
if(isset($dependencies[$name])){
|
||||||
|
foreach($dependencies[$name] as $key => $dependency){
|
||||||
|
if(isset($loadedPlugins[$dependency]) or $this->getPlugin($dependency) instanceof Plugin){
|
||||||
|
unset($dependencies[$name][$key]);
|
||||||
|
}elseif(!isset($plugins[$dependency])){
|
||||||
|
$this->server->getLogger()->critical($this->server->getLanguage()->translateString("pocketmine.plugin.loadError", [
|
||||||
|
$name,
|
||||||
|
$this->server->getLanguage()->translateString("%pocketmine.plugin.unknownDependency", [$dependency])
|
||||||
|
]));
|
||||||
|
unset($plugins[$name]);
|
||||||
|
continue 2;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(count($dependencies[$name]) === 0){
|
||||||
|
unset($dependencies[$name]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(isset($softDependencies[$name])){
|
||||||
|
foreach($softDependencies[$name] as $key => $dependency){
|
||||||
|
if(isset($loadedPlugins[$dependency]) or $this->getPlugin($dependency) instanceof Plugin){
|
||||||
|
unset($softDependencies[$name][$key]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(count($softDependencies[$name]) === 0){
|
||||||
|
unset($softDependencies[$name]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!isset($dependencies[$name]) and !isset($softDependencies[$name])){
|
||||||
|
unset($plugins[$name]);
|
||||||
|
$missingDependency = false;
|
||||||
|
if($plugin = $this->loadPlugin($file, $loaders) and $plugin instanceof Plugin){
|
||||||
|
$loadedPlugins[$name] = $plugin;
|
||||||
|
}else{
|
||||||
|
$this->server->getLogger()->critical($this->server->getLanguage()->translateString("pocketmine.plugin.genericLoadError", [$name]));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if($missingDependency){
|
||||||
while(count($plugins) > 0){
|
|
||||||
$missingDependency = true;
|
|
||||||
foreach($plugins as $name => $file){
|
foreach($plugins as $name => $file){
|
||||||
if(isset($dependencies[$name])){
|
if(!isset($dependencies[$name])){
|
||||||
foreach($dependencies[$name] as $key => $dependency){
|
unset($softDependencies[$name]);
|
||||||
if(isset($loadedPlugins[$dependency]) or $this->getPlugin($dependency) instanceof Plugin){
|
|
||||||
unset($dependencies[$name][$key]);
|
|
||||||
}elseif(!isset($plugins[$dependency])){
|
|
||||||
$this->server->getLogger()->critical($this->server->getLanguage()->translateString("pocketmine.plugin.loadError", [
|
|
||||||
$name,
|
|
||||||
$this->server->getLanguage()->translateString("%pocketmine.plugin.unknownDependency", [$dependency])
|
|
||||||
]));
|
|
||||||
unset($plugins[$name]);
|
|
||||||
continue 2;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if(count($dependencies[$name]) === 0){
|
|
||||||
unset($dependencies[$name]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if(isset($softDependencies[$name])){
|
|
||||||
foreach($softDependencies[$name] as $key => $dependency){
|
|
||||||
if(isset($loadedPlugins[$dependency]) or $this->getPlugin($dependency) instanceof Plugin){
|
|
||||||
unset($softDependencies[$name][$key]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if(count($softDependencies[$name]) === 0){
|
|
||||||
unset($softDependencies[$name]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if(!isset($dependencies[$name]) and !isset($softDependencies[$name])){
|
|
||||||
unset($plugins[$name]);
|
unset($plugins[$name]);
|
||||||
$missingDependency = false;
|
$missingDependency = false;
|
||||||
if($plugin = $this->loadPlugin($file, $loaders) and $plugin instanceof Plugin){
|
if($plugin = $this->loadPlugin($file, $loaders) and $plugin instanceof Plugin){
|
||||||
@ -325,34 +343,17 @@ class PluginManager{
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//No plugins loaded :(
|
||||||
if($missingDependency){
|
if($missingDependency){
|
||||||
foreach($plugins as $name => $file){
|
foreach($plugins as $name => $file){
|
||||||
if(!isset($dependencies[$name])){
|
$this->server->getLogger()->critical($this->server->getLanguage()->translateString("pocketmine.plugin.loadError", [$name, "%pocketmine.plugin.circularDependency"]));
|
||||||
unset($softDependencies[$name]);
|
|
||||||
unset($plugins[$name]);
|
|
||||||
$missingDependency = false;
|
|
||||||
if($plugin = $this->loadPlugin($file, $loaders) and $plugin instanceof Plugin){
|
|
||||||
$loadedPlugins[$name] = $plugin;
|
|
||||||
}else{
|
|
||||||
$this->server->getLogger()->critical($this->server->getLanguage()->translateString("pocketmine.plugin.genericLoadError", [$name]));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//No plugins loaded :(
|
|
||||||
if($missingDependency){
|
|
||||||
foreach($plugins as $name => $file){
|
|
||||||
$this->server->getLogger()->critical($this->server->getLanguage()->translateString("pocketmine.plugin.loadError", [$name, "%pocketmine.plugin.circularDependency"]));
|
|
||||||
}
|
|
||||||
$plugins = [];
|
|
||||||
}
|
}
|
||||||
|
$plugins = [];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return $loadedPlugins;
|
|
||||||
}else{
|
|
||||||
return [];
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return $loadedPlugins;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
x
Reference in New Issue
Block a user