mirror of
https://github.com/vitodeploy/vito.git
synced 2025-07-07 00:42:34 +00:00
Merge (#127)
This commit is contained in:
50
app/Http/Controllers/Settings/StorageProviderController.php
Normal file
50
app/Http/Controllers/Settings/StorageProviderController.php
Normal file
@ -0,0 +1,50 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers\Settings;
|
||||
|
||||
use App\Actions\StorageProvider\CreateStorageProvider;
|
||||
use App\Actions\StorageProvider\DeleteStorageProvider;
|
||||
use App\Facades\Toast;
|
||||
use App\Helpers\HtmxResponse;
|
||||
use App\Http\Controllers\Controller;
|
||||
use App\Models\StorageProvider;
|
||||
use Illuminate\Contracts\View\View;
|
||||
use Illuminate\Http\RedirectResponse;
|
||||
use Illuminate\Http\Request;
|
||||
|
||||
class StorageProviderController extends Controller
|
||||
{
|
||||
public function index(): View
|
||||
{
|
||||
return view('settings.storage-providers.index', [
|
||||
'providers' => auth()->user()->storageProviders,
|
||||
]);
|
||||
}
|
||||
|
||||
public function connect(Request $request): HtmxResponse
|
||||
{
|
||||
app(CreateStorageProvider::class)->create(
|
||||
$request->user(),
|
||||
$request->input()
|
||||
);
|
||||
|
||||
Toast::success('Storage provider connected.');
|
||||
|
||||
return htmx()->redirect(route('storage-providers'));
|
||||
}
|
||||
|
||||
public function delete(StorageProvider $storageProvider): RedirectResponse
|
||||
{
|
||||
try {
|
||||
app(DeleteStorageProvider::class)->delete($storageProvider);
|
||||
} catch (\Exception $e) {
|
||||
Toast::error($e->getMessage());
|
||||
|
||||
return back();
|
||||
}
|
||||
|
||||
Toast::success('Storage provider deleted.');
|
||||
|
||||
return back();
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user