Move global admin controllers from Admin to SuperAdmin namespace

Backup, Update, Modules, and global Settings controllers (mail config,
PDF config, disk management, global settings) are application-wide features
not scoped to a company. Move them from Admin/ to SuperAdmin/ to match the
v3.0 UI structure where these live under Administration.

Company-scoped settings controllers remain in Admin/Settings/.
This commit is contained in:
Darko Gjorgjijoski
2026-04-03 16:52:18 +02:00
parent de06c335ac
commit bbf46577dc
27 changed files with 50 additions and 50 deletions

View File

@@ -0,0 +1,35 @@
<?php
namespace App\Http\Controllers\V1\SuperAdmin\Update;
use App\Http\Controllers\Controller;
use App\Services\Update\Updater;
use Illuminate\Http\JsonResponse;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\File;
class CheckVersionController extends Controller
{
/**
* Handle the incoming request.
*
* @return JsonResponse
*/
public function __invoke(Request $request)
{
if ((! $request->user()) || (! $request->user()->isOwner())) {
return response()->json([
'success' => false,
'message' => 'You are not allowed to update this app.',
], 401);
}
set_time_limit(600); // 10 minutes
$channel = $request->get('channel', 'stable');
$version = preg_replace('~[\r\n]+~', '', File::get(base_path('version.md')));
$response = Updater::checkForUpdate($version, $channel);
return response()->json($response);
}
}

View File

@@ -0,0 +1,37 @@
<?php
namespace App\Http\Controllers\V1\SuperAdmin\Update;
use App\Http\Controllers\Controller;
use App\Services\Update\Updater;
use Illuminate\Http\Request;
use Illuminate\Http\Response;
class CopyFilesController extends Controller
{
/**
* Handle the incoming request.
*
* @return Response
*/
public function __invoke(Request $request)
{
if ((! $request->user()) || (! $request->user()->isOwner())) {
return response()->json([
'success' => false,
'message' => 'You are not allowed to update this app.',
], 401);
}
$request->validate([
'path' => 'required',
]);
$path = Updater::copyFiles($request->path);
return response()->json([
'success' => true,
'path' => $path,
]);
}
}

View File

@@ -0,0 +1,34 @@
<?php
namespace App\Http\Controllers\V1\SuperAdmin\Update;
use App\Http\Controllers\Controller;
use App\Services\Update\Updater;
use Illuminate\Http\Request;
use Illuminate\Http\Response;
class DeleteFilesController extends Controller
{
/**
* Handle the incoming request.
*
* @return Response
*/
public function __invoke(Request $request)
{
if ((! $request->user()) || (! $request->user()->isOwner())) {
return response()->json([
'success' => false,
'message' => 'You are not allowed to update this app.',
], 401);
}
if (isset($request->deleted_files) && ! empty($request->deleted_files)) {
Updater::deleteFiles($request->deleted_files);
}
return response()->json([
'success' => true,
]);
}
}

View File

@@ -0,0 +1,37 @@
<?php
namespace App\Http\Controllers\V1\SuperAdmin\Update;
use App\Http\Controllers\Controller;
use App\Services\Update\Updater;
use Illuminate\Http\Request;
use Illuminate\Http\Response;
class DownloadUpdateController extends Controller
{
/**
* Handle the incoming request.
*
* @return Response
*/
public function __invoke(Request $request)
{
if ((! $request->user()) || (! $request->user()->isOwner())) {
return response()->json([
'success' => false,
'message' => 'You are not allowed to update this app.',
], 401);
}
$request->validate([
'version' => 'required',
]);
$path = Updater::download($request->version);
return response()->json([
'success' => true,
'path' => $path,
]);
}
}

View File

@@ -0,0 +1,35 @@
<?php
namespace App\Http\Controllers\V1\SuperAdmin\Update;
use App\Http\Controllers\Controller;
use App\Services\Update\Updater;
use Illuminate\Http\Request;
use Illuminate\Http\Response;
class FinishUpdateController extends Controller
{
/**
* Handle the incoming request.
*
* @return Response
*/
public function __invoke(Request $request)
{
if ((! $request->user()) || (! $request->user()->isOwner())) {
return response()->json([
'success' => false,
'message' => 'You are not allowed to update this app.',
], 401);
}
$request->validate([
'installed' => 'required',
'version' => 'required',
]);
$json = Updater::finishUpdate($request->installed, $request->version);
return response()->json($json);
}
}

View File

@@ -0,0 +1,32 @@
<?php
namespace App\Http\Controllers\V1\SuperAdmin\Update;
use App\Http\Controllers\Controller;
use App\Services\Update\Updater;
use Illuminate\Http\Request;
use Illuminate\Http\Response;
class MigrateUpdateController extends Controller
{
/**
* Handle the incoming request.
*
* @return Response
*/
public function __invoke(Request $request)
{
if ((! $request->user()) || (! $request->user()->isOwner())) {
return response()->json([
'success' => false,
'message' => 'You are not allowed to update this app.',
], 401);
}
Updater::migrateUpdate();
return response()->json([
'success' => true,
]);
}
}

View File

@@ -0,0 +1,44 @@
<?php
namespace App\Http\Controllers\V1\SuperAdmin\Update;
use App\Http\Controllers\Controller;
use App\Services\Update\Updater;
use Illuminate\Http\Request;
use Illuminate\Http\Response;
class UnzipUpdateController extends Controller
{
/**
* Handle the incoming request.
*
* @return Response
*/
public function __invoke(Request $request)
{
if ((! $request->user()) || (! $request->user()->isOwner())) {
return response()->json([
'success' => false,
'message' => 'You are not allowed to update this app.',
], 401);
}
$request->validate([
'path' => 'required',
]);
try {
$path = Updater::unzip($request->path);
return response()->json([
'success' => true,
'path' => $path,
]);
} catch (\Exception $e) {
return response()->json([
'success' => false,
'error' => $e->getMessage(),
], 500);
}
}
}

View File

@@ -0,0 +1,102 @@
<?php
namespace App\Http\Controllers\V1\SuperAdmin\Update;
use App\Http\Controllers\Controller;
use App\Models\Setting;
use App\Services\Update\Updater;
use Illuminate\Http\Request;
class UpdateController extends Controller
{
public function download(Request $request)
{
$this->authorize('manage update app');
$request->validate([
'version' => 'required',
]);
$path = Updater::download($request->version);
return response()->json([
'success' => true,
'path' => $path,
]);
}
public function unzip(Request $request)
{
$this->authorize('manage update app');
$request->validate([
'path' => 'required',
]);
try {
$path = Updater::unzip($request->path);
return response()->json([
'success' => true,
'path' => $path,
]);
} catch (\Exception $e) {
return response()->json([
'success' => false,
'error' => $e->getMessage(),
], 500);
}
}
public function copyFiles(Request $request)
{
$this->authorize('manage update app');
$request->validate([
'path' => 'required',
]);
$path = Updater::copyFiles($request->path);
return response()->json([
'success' => true,
'path' => $path,
]);
}
public function migrate(Request $request)
{
$this->authorize('manage update app');
Updater::migrateUpdate();
return response()->json([
'success' => true,
]);
}
public function finishUpdate(Request $request)
{
$this->authorize('manage update app');
$request->validate([
'installed' => 'required',
'version' => 'required',
]);
$json = Updater::finishUpdate($request->installed, $request->version);
return response()->json($json);
}
public function checkLatestVersion(Request $request)
{
$this->authorize('manage update app');
set_time_limit(600); // 10 minutes
$json = Updater::checkForUpdate(Setting::getSetting('version'));
return response()->json($json);
}
}