mirror of
https://github.com/pelican-dev/panel.git
synced 2025-11-09 12:29:29 +01:00
use own composer process for better error messages
This commit is contained in:
parent
427c1187a2
commit
bfae4e7f30
@ -12,7 +12,6 @@ use Illuminate\Console\Application as ConsoleApplication;
|
|||||||
use Illuminate\Console\Command;
|
use Illuminate\Console\Command;
|
||||||
use Illuminate\Foundation\Application;
|
use Illuminate\Foundation\Application;
|
||||||
use Illuminate\Http\UploadedFile;
|
use Illuminate\Http\UploadedFile;
|
||||||
use Illuminate\Support\Composer;
|
|
||||||
use Illuminate\Support\Facades\Artisan;
|
use Illuminate\Support\Facades\Artisan;
|
||||||
use Illuminate\Support\Facades\File;
|
use Illuminate\Support\Facades\File;
|
||||||
use Illuminate\Support\Facades\Http;
|
use Illuminate\Support\Facades\Http;
|
||||||
@ -23,7 +22,7 @@ use ZipArchive;
|
|||||||
|
|
||||||
class PluginService
|
class PluginService
|
||||||
{
|
{
|
||||||
public function __construct(private Application $app, private Composer $composer) {}
|
public function __construct(private Application $app) {}
|
||||||
|
|
||||||
public function loadPlugins(): void
|
public function loadPlugins(): void
|
||||||
{
|
{
|
||||||
@ -160,10 +159,9 @@ class PluginService
|
|||||||
->unique()
|
->unique()
|
||||||
->toArray();
|
->toArray();
|
||||||
|
|
||||||
$success = $this->composer->setWorkingPath(base_path())->requirePackages($composerPackages);
|
$result = Process::path(base_path())->timeout(600)->run(['composer', 'require', ...$composerPackages]);
|
||||||
|
if ($result->failed()) {
|
||||||
if (!$success) {
|
throw new Exception('Could not require composer packages: ' . $result->errorOutput());
|
||||||
throw new Exception("Could not require composer packages for plugin '{$plugin->id}'");
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user