Implemented scan deletion

ref #67
This commit is contained in:
Nicolai Ort 2021-01-07 17:03:40 +01:00
parent edac1a224c
commit 88a6a768c4
1 changed files with 15 additions and 20 deletions

View File

@ -1,9 +1,10 @@
import { Authorized, Body, Get, JsonController, OnUndefined, Param, Post } from 'routing-controllers';
import { Authorized, Body, Delete, Get, JsonController, OnUndefined, Param, Post, QueryParam } from 'routing-controllers';
import { OpenAPI, ResponseSchema } from 'routing-controllers-openapi';
import { getConnectionManager, Repository } from 'typeorm';
import { ScanNotFoundError } from '../errors/ScanErrors';
import { CreateScan } from '../models/actions/CreateScan';
import { Scan } from '../models/entities/Scan';
import { ResponseEmpty } from '../models/responses/ResponseEmpty';
import { ResponseScan } from '../models/responses/ResponseScan';
import { ResponseTrackScan } from '../models/responses/ResponseTrackScan';
@ -77,24 +78,18 @@ export class ScanController {
// return new ResponseDonor(await this.donorRepository.findOne({ id: id }));
// }
// @Delete('/:id')
// @Authorized("DONOR:DELETE")
// @ResponseSchema(ResponseDonor)
// @ResponseSchema(ResponseEmpty, { statusCode: 204 })
// @OnUndefined(204)
// @OpenAPI({ description: 'Delete the runner whose id you provided. <br> If no runner with this id exists it will just return 204(no content).' })
// async remove(@Param("id") id: number, @QueryParam("force") force: boolean) {
// let donor = await this.donorRepository.findOne({ id: id });
// if (!donor) { return null; }
// const responseDonor = await this.donorRepository.findOne(donor);
@Delete('/:id')
@Authorized("SCAN:DELETE")
@ResponseSchema(ResponseScan)
@ResponseSchema(ResponseEmpty, { statusCode: 204 })
@OnUndefined(204)
@OpenAPI({ description: 'Delete the runner whose id you provided. <br> If no runner with this id exists it will just return 204(no content).' })
async remove(@Param("id") id: number, @QueryParam("force") force: boolean) {
let scan = await this.scanRepository.findOne({ id: id });
if (!scan) { return null; }
const responseScan = await this.scanRepository.findOne({ id: scan.id }, { relations: ["runner"] });
// if (!donor) {
// throw new DonorNotFoundError();
// }
// //TODO: DELETE DONATIONS AND WARN FOR FORCE (https://git.odit.services/lfk/backend/issues/66)
// await this.donorRepository.delete(donor);
// return new ResponseDonor(responseDonor);
// }
await this.scanRepository.delete(scan);
return responseScan.toResponse();
}
}