feat: agrega funcionalidad para subir y descargar APK de la aplicación móvil
This commit is contained in:
parent
fc897f5130
commit
2c5307fa5b
64
app/Http/Controllers/Repuve/AppController.php
Normal file
64
app/Http/Controllers/Repuve/AppController.php
Normal file
@ -0,0 +1,64 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Http\Controllers\Repuve;
|
||||||
|
|
||||||
|
use App\Http\Controllers\Controller;
|
||||||
|
use App\Http\Requests\Repuve\ApkStorageRequest;
|
||||||
|
use Illuminate\Support\Facades\Storage;
|
||||||
|
use Notsoweb\ApiResponse\Enums\ApiResponse;
|
||||||
|
use Symfony\Component\HttpFoundation\BinaryFileResponse;
|
||||||
|
|
||||||
|
class AppController extends Controller
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Middleware
|
||||||
|
*/
|
||||||
|
public static function middleware(): array
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
self::can('apk.upload', ['upload']),
|
||||||
|
self::can('apk.download', ['download']),
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Subir APK de la aplicación móvil
|
||||||
|
*/
|
||||||
|
public function upload(ApkStorageRequest $request)
|
||||||
|
{
|
||||||
|
$file = $request->file('apk');
|
||||||
|
|
||||||
|
// Eliminar APK anterior si existe
|
||||||
|
$existingFiles = Storage::disk('public')->files('apk');
|
||||||
|
foreach ($existingFiles as $existingFile) {
|
||||||
|
Storage::disk('public')->delete($existingFile);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Guardar el nuevo APK
|
||||||
|
$fileName = 'repuve-app-' . now()->format('Y-m-d') . '.apk';
|
||||||
|
$file->storeAs('apk', $fileName, 'public');
|
||||||
|
|
||||||
|
return ApiResponse::OK->response([
|
||||||
|
'message' => 'APK subido correctamente',
|
||||||
|
'file' => $fileName,
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Descargar APK de la aplicación móvil
|
||||||
|
*/
|
||||||
|
public function download(): BinaryFileResponse
|
||||||
|
{
|
||||||
|
$files = Storage::disk('public')->files('apk');
|
||||||
|
|
||||||
|
if (empty($files)) {
|
||||||
|
abort(404, 'No hay APK disponible para descargar.');
|
||||||
|
}
|
||||||
|
|
||||||
|
$latestFile = end($files);
|
||||||
|
$path = Storage::disk('public')->path($latestFile);
|
||||||
|
|
||||||
|
return response()->download($path);
|
||||||
|
}
|
||||||
|
}
|
||||||
29
app/Http/Requests/Repuve/ApkStorageRequest.php
Normal file
29
app/Http/Requests/Repuve/ApkStorageRequest.php
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Http\Requests\Repuve;
|
||||||
|
|
||||||
|
use Illuminate\Foundation\Http\FormRequest;
|
||||||
|
|
||||||
|
class ApkStorageRequest extends FormRequest
|
||||||
|
{
|
||||||
|
public function authorize()
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function rules()
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'apk' => 'required|file|max:102400',
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
public function messages()
|
||||||
|
{
|
||||||
|
return [
|
||||||
|
'apk.required' => 'El archivo APK es obligatorio',
|
||||||
|
'apk.file' => 'El archivo debe ser un archivo válido',
|
||||||
|
'apk.max' => 'El archivo no debe superar los 100MB',
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -50,6 +50,12 @@ public function run(): void
|
|||||||
|
|
||||||
$rolePermissions = $this->onPermission('roles.permissions', 'Permisos de roles', $roles, 'api');
|
$rolePermissions = $this->onPermission('roles.permissions', 'Permisos de roles', $roles, 'api');
|
||||||
|
|
||||||
|
// === APK ===
|
||||||
|
$apk = PermissionType::updateOrCreate(['name' => 'App Móvil']);
|
||||||
|
|
||||||
|
$apkUpload = $this->onPermission('apk.upload', 'Subir APK de la aplicación móvil', $apk, 'api');
|
||||||
|
$apkDownload = $this->onPermission('apk.download', 'Descargar APK de la aplicación móvil', $apk, 'api');
|
||||||
|
|
||||||
// === MÓDULOS ===
|
// === MÓDULOS ===
|
||||||
$modules = PermissionType::updateOrCreate(['name' => 'Módulos']);
|
$modules = PermissionType::updateOrCreate(['name' => 'Módulos']);
|
||||||
|
|
||||||
@ -183,6 +189,8 @@ public function run(): void
|
|||||||
$packageIndex, $packageCreate, $packageEdit, $packageDestroy, $packageBoxTags,
|
$packageIndex, $packageCreate, $packageEdit, $packageDestroy, $packageBoxTags,
|
||||||
// Constancias
|
// Constancias
|
||||||
$tagIndex, $tagCreate, $tagEdit, $tagDestroy,
|
$tagIndex, $tagCreate, $tagEdit, $tagDestroy,
|
||||||
|
//app
|
||||||
|
$apkUpload, $apkDownload,
|
||||||
);
|
);
|
||||||
|
|
||||||
// Encargado
|
// Encargado
|
||||||
@ -207,6 +215,8 @@ public function run(): void
|
|||||||
$packageIndex, $packageCreate, $packageEdit, $packageDestroy, $packageBoxTags,
|
$packageIndex, $packageCreate, $packageEdit, $packageDestroy, $packageBoxTags,
|
||||||
// Constancias
|
// Constancias
|
||||||
$tagIndex, $tagCreate, $tagEdit, $tagDestroy, $tagAssignToModule,
|
$tagIndex, $tagCreate, $tagEdit, $tagDestroy, $tagAssignToModule,
|
||||||
|
//app
|
||||||
|
$apkDownload,
|
||||||
);
|
);
|
||||||
|
|
||||||
// Perito
|
// Perito
|
||||||
|
|||||||
@ -14,6 +14,7 @@
|
|||||||
use App\Http\Controllers\Repuve\ExcelController;
|
use App\Http\Controllers\Repuve\ExcelController;
|
||||||
use App\Http\Controllers\Repuve\PackageController;
|
use App\Http\Controllers\Repuve\PackageController;
|
||||||
use App\Http\Controllers\Repuve\TagsController;
|
use App\Http\Controllers\Repuve\TagsController;
|
||||||
|
use App\Http\Controllers\Repuve\AppController;
|
||||||
use App\Http\Controllers\System\SettingsController;
|
use App\Http\Controllers\System\SettingsController;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -95,4 +96,9 @@
|
|||||||
});
|
});
|
||||||
|
|
||||||
/** Rutas públicas */
|
/** Rutas públicas */
|
||||||
// Tus rutas públicas
|
Route::get('app/download', [AppController::class, 'download']);
|
||||||
|
|
||||||
|
/** Rutas protegidas - App móvil */
|
||||||
|
Route::middleware('auth:api')->group(function() {
|
||||||
|
Route::post('app/upload', [AppController::class, 'upload']);
|
||||||
|
});
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user