@@ -1,8 +1,10 @@
 | 
			
		||||
import { Authorized, Body, Delete, Get, JsonController, OnUndefined, Param, Post, QueryParam } from 'routing-controllers';
 | 
			
		||||
import { Authorized, Body, Delete, Get, JsonController, OnUndefined, Param, Post, Put, QueryParam } from 'routing-controllers';
 | 
			
		||||
import { OpenAPI, ResponseSchema } from 'routing-controllers-openapi';
 | 
			
		||||
import { getConnectionManager, Repository } from 'typeorm';
 | 
			
		||||
import { ScanNotFoundError } from '../errors/ScanErrors';
 | 
			
		||||
import { RunnerNotFoundError } from '../errors/RunnerErrors';
 | 
			
		||||
import { ScanIdsNotMatchingError, ScanNotFoundError } from '../errors/ScanErrors';
 | 
			
		||||
import { CreateScan } from '../models/actions/CreateScan';
 | 
			
		||||
import { UpdateScan } from '../models/actions/UpdateScan';
 | 
			
		||||
import { Scan } from '../models/entities/Scan';
 | 
			
		||||
import { ResponseEmpty } from '../models/responses/ResponseEmpty';
 | 
			
		||||
import { ResponseScan } from '../models/responses/ResponseScan';
 | 
			
		||||
@@ -57,26 +59,27 @@ export class ScanController {
 | 
			
		||||
		return (await this.scanRepository.findOne({ id: scan.id }, { relations: ['runner'] })).toResponse();
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// @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 });
 | 
			
		||||
	@Put('/:id')
 | 
			
		||||
	@Authorized("SCAN:UPDATE")
 | 
			
		||||
	@ResponseSchema(ResponseScan)
 | 
			
		||||
	@ResponseSchema(ScanNotFoundError, { statusCode: 404 })
 | 
			
		||||
	@ResponseSchema(RunnerNotFoundError, { statusCode: 404 })
 | 
			
		||||
	@ResponseSchema(ScanIdsNotMatchingError, { 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 }) scan: UpdateScan) {
 | 
			
		||||
		let oldScan = await this.scanRepository.findOne({ id: id });
 | 
			
		||||
 | 
			
		||||
	// 	if (!oldDonor) {
 | 
			
		||||
	// 		throw new DonorNotFoundError();
 | 
			
		||||
	// 	}
 | 
			
		||||
		if (!oldScan) {
 | 
			
		||||
			throw new ScanNotFoundError();
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
	// 	if (oldDonor.id != donor.id) {
 | 
			
		||||
	// 		throw new DonorIdsNotMatchingError();
 | 
			
		||||
	// 	}
 | 
			
		||||
		if (oldScan.id != scan.id) {
 | 
			
		||||
			throw new ScanIdsNotMatchingError();
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
	// 	await this.donorRepository.save(await donor.updateDonor(oldDonor));
 | 
			
		||||
	// 	return new ResponseDonor(await this.donorRepository.findOne({ id: id }));
 | 
			
		||||
	// }
 | 
			
		||||
		await this.scanRepository.save(await scan.updateScan(oldScan));
 | 
			
		||||
		return (await this.scanRepository.findOne({ id: id }, { relations: ['runner'] })).toResponse();
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	@Delete('/:id')
 | 
			
		||||
	@Authorized("SCAN:DELETE")
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user