debut logique pour post sur la route

This commit is contained in:
2024-12-04 14:05:11 +01:00
parent 5a6990faa1
commit b78154c582
5 changed files with 86 additions and 12 deletions

View File

@ -33,15 +33,73 @@ class PageController extends Controller {
#[NoCSRFRequired]
#[NoAdminRequired]
#[FrontpageRoute(verb: 'POST', url: '/zipDeposit')]
public function post($archiveUrl, $token) {
$request = $this->request;
$parameters = array('archiveUrl' => $archiveUrl, 'token' => $token);
return new TemplateResponse(
#[OpenAPI(OpenAPI::SCOPE_IGNORE)]
#[FrontpageRoute(verb: 'POST', url: '/zipDrop')]
public function zipDrop() {
$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
}
$parameters = array('archiveUrl' => $subUrl);
// Créer une réponse basée sur un template
$response = new TemplateResponse(
Application::APP_ID,
'index',
$parameters
);
return $response;
}
#[NoCSRFRequired]
#[NoAdminRequired]
#[OpenAPI(OpenAPI::SCOPE_IGNORE)]
#[FrontpageRoute(verb: 'POST', 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
// Valider l'URL
if (!$zipUrl || filter_var($zipUrl, FILTER_VALIDATE_URL) === false) {
return new \OCP\AppFramework\Http\DataResponse(['error' => 'Invalid URL'], 400);
}
// 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 {
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $zipUrl);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
$response = curl_exec($ch);
if (curl_errno($ch)) {
return new JSONResponse(['feur' => curl_error($ch)], 200);
}
return new JSONResponse(['feur' => $response], 200);
} catch (Exception $e) {
return new JSONResponse(['feur' => $e->getMessage()], 500);
}
}
}