parent
2151b8502d
commit
ee2433a5ae
101
src/controllers/ScanController.ts
Normal file
101
src/controllers/ScanController.ts
Normal file
@ -0,0 +1,101 @@
|
|||||||
|
import { Authorized, Get, JsonController } from 'routing-controllers';
|
||||||
|
import { OpenAPI, ResponseSchema } from 'routing-controllers-openapi';
|
||||||
|
import { getConnectionManager, Repository } from 'typeorm';
|
||||||
|
import { Scan } from '../models/entities/Scan';
|
||||||
|
import { ResponseDonor } from '../models/responses/ResponseDonor';
|
||||||
|
|
||||||
|
@JsonController('/donors')
|
||||||
|
@OpenAPI({ security: [{ "AuthToken": [] }, { "RefreshTokenCookie": [] }] })
|
||||||
|
export class ScanController {
|
||||||
|
private scanRepository: Repository<Scan>;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the repository of this controller's model/entity.
|
||||||
|
*/
|
||||||
|
constructor() {
|
||||||
|
this.scanRepository = getConnectionManager().get().getRepository(Scan);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Get()
|
||||||
|
@Authorized("SCAN:GET")
|
||||||
|
@ResponseSchema(ResponseDonor, { isArray: true })
|
||||||
|
@OpenAPI({ description: 'Lists all runners from all teams/orgs. <br> This includes the runner\'s group and distance ran.' })
|
||||||
|
async getAll() {
|
||||||
|
let responseScans: ResponseScan[] = new Array<ResponseScan>();
|
||||||
|
const scans = await this.scanRepository.find();
|
||||||
|
scans.forEach(scan => {
|
||||||
|
responseScans.push(new ResponseScan(scan));
|
||||||
|
});
|
||||||
|
return responseScans;
|
||||||
|
}
|
||||||
|
|
||||||
|
// @Get('/:id')
|
||||||
|
// @Authorized("DONOR:GET")
|
||||||
|
// @ResponseSchema(ResponseDonor)
|
||||||
|
// @ResponseSchema(DonorNotFoundError, { statusCode: 404 })
|
||||||
|
// @OnUndefined(DonorNotFoundError)
|
||||||
|
// @OpenAPI({ description: 'Lists all information about the runner whose id got provided.' })
|
||||||
|
// async getOne(@Param('id') id: number) {
|
||||||
|
// let donor = await this.donorRepository.findOne({ id: id })
|
||||||
|
// if (!donor) { throw new DonorNotFoundError(); }
|
||||||
|
// return new ResponseDonor(donor);
|
||||||
|
// }
|
||||||
|
|
||||||
|
// @Post()
|
||||||
|
// @Authorized("DONOR:CREATE")
|
||||||
|
// @ResponseSchema(ResponseDonor)
|
||||||
|
// @OpenAPI({ description: 'Create a new runner. <br> Please remeber to provide the runner\'s group\'s id.' })
|
||||||
|
// async post(@Body({ validate: true }) createRunner: CreateDonor) {
|
||||||
|
// let donor;
|
||||||
|
// try {
|
||||||
|
// donor = await createRunner.toDonor();
|
||||||
|
// } catch (error) {
|
||||||
|
// throw error;
|
||||||
|
// }
|
||||||
|
|
||||||
|
// donor = await this.donorRepository.save(donor)
|
||||||
|
// return new ResponseDonor(await this.donorRepository.findOne(donor));
|
||||||
|
// }
|
||||||
|
|
||||||
|
// @Put('/:id')
|
||||||
|
// @Authorized("DONOR:UPDATE")
|
||||||
|
// @ResponseSchema(ResponseDonor)
|
||||||
|
// @ResponseSchema(DonorNotFoundError, { statusCode: 404 })
|
||||||
|
// @ResponseSchema(DonorIdsNotMatchingError, { statusCode: 406 })
|
||||||
|
// @OpenAPI({ description: "Update the runner whose id you provided. <br> Please remember that ids can't be changed." })
|
||||||
|
// async put(@Param('id') id: number, @Body({ validate: true }) donor: UpdateDonor) {
|
||||||
|
// let oldDonor = await this.donorRepository.findOne({ id: id });
|
||||||
|
|
||||||
|
// if (!oldDonor) {
|
||||||
|
// throw new DonorNotFoundError();
|
||||||
|
// }
|
||||||
|
|
||||||
|
// if (oldDonor.id != donor.id) {
|
||||||
|
// throw new DonorIdsNotMatchingError();
|
||||||
|
// }
|
||||||
|
|
||||||
|
// await this.donorRepository.save(await donor.updateDonor(oldDonor));
|
||||||
|
// 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);
|
||||||
|
|
||||||
|
// 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);
|
||||||
|
// }
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user