diff --git a/appinfo/routes.php b/appinfo/routes.php index 15f0a6f..222ad94 100644 --- a/appinfo/routes.php +++ b/appinfo/routes.php @@ -3,6 +3,6 @@ return [ 'routes' => [ ['name' => 'page#main', 'url' => '/', 'verb' => 'GET'], ['name' => 'page#zipDrop', 'url' => '/zipDrop', 'verb' => 'GET'], - ['name' => 'page#getZipFile', 'url' => '/getZipFile', 'verb' => 'POST'] + ['name' => 'page#getZipFile', 'url' => '/getZipFile', 'verb' => 'GET'] ] ]; diff --git a/lib/Controller/PageController.php b/lib/Controller/PageController.php index c194af0..bb1e9fb 100644 --- a/lib/Controller/PageController.php +++ b/lib/Controller/PageController.php @@ -34,72 +34,96 @@ class PageController extends Controller { #[NoCSRFRequired] #[NoAdminRequired] #[OpenAPI(OpenAPI::SCOPE_IGNORE)] - #[FrontpageRoute(verb: 'POST', url: '/zipDrop')] + #[FrontpageRoute(verb: 'GET', url: '/zipDrop')] public function zipDrop() { + // Récupérer le paramètre subUrl (compatible GET et POST) $subUrl = $this->request->getParam('subUrl'); + if (!$subUrl) { - return new JSONResponse(['error' => 'subUrl is required'], 400); // Retourner une réponse d'erreur 400 si le paramètre est manquant + return new \OCP\AppFramework\Http\DataResponse([ + 'error' => 'Le paramètre subUrl est manquant' + ], 400); + } + + // Optionnel : Validation de l'URL + if (filter_var($subUrl, FILTER_VALIDATE_URL) === false) { + return new \OCP\AppFramework\Http\DataResponse([ + 'error' => 'subUrl n\'est pas une URL valide' + ], 400); } $parameters = array('archiveUrl' => $subUrl); - // Créer une réponse basée sur un template - $response = new TemplateResponse( + // Réponse de succès + return new TemplateResponse( Application::APP_ID, 'index', $parameters ); - - return $response; } #[NoCSRFRequired] #[NoAdminRequired] #[OpenAPI(OpenAPI::SCOPE_IGNORE)] - #[FrontpageRoute(verb: 'POST', url: '/getZipFile')] + #[FrontpageRoute(verb: 'GET', url: '/getZipFile')] public function getZipFile() { - // Récupérer les données envoyées dans la requête POST - $requestData = $this->request->getParams(); // Accéder aux paramètres envoyés - $zipUrl = $requestData['subUrl'] ?? null; // Récupérer 'subUrl' ou null si absent + // Récupérer les données envoyées dans la requête + $zipUrl = $this->request->getParam('subUrl'); + + // Initialiser les paramètres de réponse + $parameters = [ + 'status' => 'error', // Par défaut, la réponse indique une erreur + 'message' => '', + 'data' => null + ]; // Valider l'URL if (!$zipUrl || filter_var($zipUrl, FILTER_VALIDATE_URL) === false) { - return new \OCP\AppFramework\Http\DataResponse(['error' => 'Invalid URL'], 400); + $parameters['message'] = 'Invalid URL'; + return new JsonResponse($parameters, 400); // 400 Bad Request } - // Utiliser cURL pour récupérer le fichier ZIP à l'URL fournie - /*$ch = curl_init($zipUrl); - curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); - $fileContent = curl_exec($ch); - $httpCode = curl_getinfo($ch, CURLINFO_HTTP_CODE); // Récupérer le code HTTP - curl_close($ch);*/ - - // Vérifier si le fichier est récupéré avec succès - /*if ($fileContent !== false && $httpCode === 200) { - $response = new \OCP\AppFramework\Http\DownloadResponse($fileContent); - $response->setContentDisposition('attachment', 'yourfile.zip'); - return $response; - } - - // Gérer les erreurs si le fichier ne peut pas être récupéré - return new \OCP\AppFramework\Http\DataResponse(['error' => 'File not found'], 404); - - new JSONResponse(['error' => 'subUrl is required'], 400); - */ try { + // Initialiser cURL $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, $zipUrl); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); + curl_setopt($ch, CURLOPT_TIMEOUT, 10); // Timeout de 10 secondes + curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true); // Suivre les redirections + // Récupérer le contenu $response = curl_exec($ch); + // Gérer les erreurs cURL if (curl_errno($ch)) { - return new JSONResponse(['feur' => curl_error($ch)], 200); + $parameters['message'] = 'cURL error: ' . curl_error($ch); + curl_close($ch); + return new JsonResponse(['parameters' => $parameters, 'status' => 500]); // 500 Internal Server Error } - - return new JSONResponse(['feur' => $response], 200); - } catch (Exception $e) { - return new JSONResponse(['feur' => $e->getMessage()], 500); + + // Vérifier le code HTTP + $httpCode = curl_getinfo($ch, CURLINFO_HTTP_CODE); + curl_close($ch); + + if ($httpCode !== 200) { + $parameters['message'] = "HTTP error: $httpCode"; + return new JsonResponse(['parameters' => $parameters, 'status' => $httpCode]); + } + + // Encodage explicite en UTF-8 si nécessaire + if (!mb_detect_encoding($response, 'UTF-8', true)) { + $response = utf8_encode($response); + } + + // Si tout est OK, construire la réponse + $parameters['status'] = 'success'; + $parameters['message'] = 'File retrieved successfully'; + $parameters['data'] = $response; // Encodage Base64 pour éviter les problèmes d'encodage JSON + + return new JsonResponse(['parameters' => $parameters, 'status' => 200]); // 200 OK + } catch (\Exception $e) { + $parameters['message'] = 'Exception: ' . $e->getMessage(); + return new JsonResponse(['parameters' => $parameters, 'status' => 500]); // 500 Internal Server Error } } -} +} \ No newline at end of file diff --git a/src/App.vue b/src/App.vue index 4871511..1d57de8 100644 --- a/src/App.vue +++ b/src/App.vue @@ -40,7 +40,7 @@ export default { data() { console.log('feur') let zipUrl = document.getElementById('archiveInfos').getAttribute('dataarchiveurl'); - console.log(zipUrl) + console.log(zipUrl); return { zipUrl, sharedFile: null, diff --git a/src/components/WebContentViewer.vue b/src/components/WebContentViewer.vue index 29235f7..44524af 100644 --- a/src/components/WebContentViewer.vue +++ b/src/components/WebContentViewer.vue @@ -167,20 +167,11 @@ export default { async loadZipContent() { try { var baseUrl = OC.generateUrl('/apps/webtransfer/getZipFile'); - var postData = { - subUrl: this.zipUrl - }; + let fullUrl = baseUrl + '?subUrl=' + this.zipUrl; - let response = await fetch(baseUrl, { - method: 'POST', - headers: { - 'Content-Type': 'application/json' // Type de contenu JSON - }, - body: JSON.stringify(postData) // Convertir les données en JSON - }) - - console.log('response: ', await response.json()) - const zipData = await response.blob(); + let response = await fetch(fullUrl); + let responseJson = await response.json(); + const zipData = responseJson.parameters.data; this.zipName = this.zipUrl.split('/').pop(); const zip = await JSZip.loadAsync(zipData); this.zipSize = zipData.size;