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);
 | 
			
		||||
	// }
 | 
			
		||||
}
 | 
			
		||||
		Reference in New Issue
	
	Block a user