mirror of
https://github.com/InvoiceShelf/InvoiceShelf.git
synced 2026-04-07 05:31:24 +00:00
* Convert string references to `::class` PHP 5.5.9 adds the new static `class` property which provides the fully qualified class name. This is preferred over using strings for class names since the `class` property references are checked by PHP. * Use Faker methods Accessing Faker properties was deprecated in Faker 1.14. * Convert route options to fluent methods Laravel 8 adopts the tuple syntax for controller actions. Since the old options array is incompatible with this syntax, Shift converted them to use modern, fluent methods. * Adopt class based routes * Remove default `app` files * Shift core files * Streamline config files * Set new `ENV` variables * Default new `bootstrap/app.php` * Re-register HTTP middleware * Consolidate service providers * Re-register service providers * Re-register routes * Re-register scheduled commands * Bump Composer dependencies * Use `<env>` tags for configuration `<env>` tags have a lower precedence than system environment variables making it easier to overwrite PHPUnit configuration values in additional environments, such a CI. Review this blog post for more details on configuration precedence when testing Laravel: https://jasonmccreary.me/articles/laravel-testing-configuration-precedence/ * Adopt anonymous migrations * Rename `password_resets` table * Convert `$casts` property to method * Adopt Laravel type hints * Mark base controller as `abstract` * Remove `CreatesApplication` testing trait * Shift cleanup * Fix shift first issues * Updating Rules for laravel 11, sanctum config and pint * Fix Carbon issue on dashboard * Temporary fix for tests while migration is issue fixed on laravel side * Carbon needs numerical values, not strings * Minimum php version * Fix domain installation step not fetching the correct company_id * Fix Role Policy wasn't properly registered ---------
195 lines
4.8 KiB
PHP
195 lines
4.8 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\V1\Admin\Settings;
|
|
|
|
use App\Http\Controllers\Controller;
|
|
use App\Http\Requests\DiskEnvironmentRequest;
|
|
use App\Http\Resources\FileDiskResource;
|
|
use App\Models\FileDisk;
|
|
use Illuminate\Http\JsonResponse;
|
|
use Illuminate\Http\Request;
|
|
|
|
class DiskController extends Controller
|
|
{
|
|
/**
|
|
* @return JsonResponse
|
|
*/
|
|
public function index(Request $request)
|
|
{
|
|
$this->authorize('manage file disk');
|
|
|
|
$limit = $request->has('limit') ? $request->limit : 5;
|
|
$disks = FileDisk::applyFilters($request->all())
|
|
->latest()
|
|
->paginateData($limit);
|
|
|
|
return FileDiskResource::collection($disks);
|
|
}
|
|
|
|
/**
|
|
* @return JsonResponse
|
|
*/
|
|
public function store(DiskEnvironmentRequest $request)
|
|
{
|
|
$this->authorize('manage file disk');
|
|
|
|
if (! FileDisk::validateCredentials($request->credentials, $request->driver)) {
|
|
return respondJson('invalid_credentials', 'Invalid Credentials.');
|
|
}
|
|
|
|
$disk = FileDisk::createDisk($request);
|
|
|
|
return new FileDiskResource($disk);
|
|
}
|
|
|
|
/**
|
|
* @param \App\Models\FileDisk $file_disk
|
|
* @return JsonResponse
|
|
*/
|
|
public function update(FileDisk $disk, Request $request)
|
|
{
|
|
$this->authorize('manage file disk');
|
|
|
|
$credentials = $request->credentials;
|
|
$driver = $request->driver;
|
|
|
|
if ($credentials && $driver && $disk->type !== 'SYSTEM') {
|
|
if (! FileDisk::validateCredentials($credentials, $driver)) {
|
|
return respondJson('invalid_credentials', 'Invalid Credentials.');
|
|
}
|
|
|
|
$disk->updateDisk($request);
|
|
} elseif ($request->set_as_default) {
|
|
$disk->setAsDefaultDisk();
|
|
}
|
|
|
|
return new FileDiskResource($disk);
|
|
}
|
|
|
|
/**
|
|
* @param Request $request
|
|
* @return JsonResponse
|
|
*/
|
|
public function show($disk)
|
|
{
|
|
$this->authorize('manage file disk');
|
|
|
|
$diskData = [];
|
|
switch ($disk) {
|
|
case 'local':
|
|
$diskData = [
|
|
'root' => config('filesystems.disks.local.root'),
|
|
];
|
|
|
|
break;
|
|
|
|
case 's3':
|
|
$diskData = [
|
|
'key' => '',
|
|
'secret' => '',
|
|
'region' => '',
|
|
'bucket' => '',
|
|
'root' => '',
|
|
];
|
|
|
|
break;
|
|
|
|
case 's3compat':
|
|
$diskData = [
|
|
'endpoint' => '',
|
|
'key' => '',
|
|
'secret' => '',
|
|
'region' => '',
|
|
'bucket' => '',
|
|
'root' => '',
|
|
];
|
|
|
|
case 'doSpaces':
|
|
$diskData = [
|
|
'key' => '',
|
|
'secret' => '',
|
|
'region' => '',
|
|
'bucket' => '',
|
|
'endpoint' => '',
|
|
'root' => '',
|
|
];
|
|
|
|
break;
|
|
|
|
case 'dropbox':
|
|
$diskData = [
|
|
'token' => '',
|
|
'key' => '',
|
|
'secret' => '',
|
|
'app' => '',
|
|
'root' => '',
|
|
];
|
|
|
|
break;
|
|
}
|
|
|
|
$data = array_merge($diskData);
|
|
|
|
return response()->json($data);
|
|
}
|
|
|
|
/**
|
|
* Remove the specified resource from storage.
|
|
*
|
|
* @param \App\Models\FileDisk $taxType
|
|
* @return \Illuminate\Http\Response
|
|
*/
|
|
public function destroy(FileDisk $disk)
|
|
{
|
|
$this->authorize('manage file disk');
|
|
|
|
if ($disk->setAsDefault() && $disk->type === 'SYSTEM') {
|
|
return respondJson('not_allowed', 'Not Allowed');
|
|
}
|
|
|
|
$disk->delete();
|
|
|
|
return response()->json([
|
|
'success' => true,
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* @return JsonResponse
|
|
*/
|
|
public function getDiskDrivers()
|
|
{
|
|
$this->authorize('manage file disk');
|
|
|
|
$drivers = [
|
|
[
|
|
'name' => 'Local',
|
|
'value' => 'local',
|
|
],
|
|
[
|
|
'name' => 'Amazon S3',
|
|
'value' => 's3',
|
|
],
|
|
[
|
|
'name' => 'S3 Compatible Storage',
|
|
'value' => 's3compat',
|
|
],
|
|
[
|
|
'name' => 'Digital Ocean Spaces',
|
|
'value' => 'doSpaces',
|
|
],
|
|
[
|
|
'name' => 'Dropbox',
|
|
'value' => 'dropbox',
|
|
],
|
|
];
|
|
|
|
$default = config('filesystems.default');
|
|
|
|
return response()->json([
|
|
'drivers' => $drivers,
|
|
'default' => $default,
|
|
]);
|
|
}
|
|
}
|