parent
e46cfa0d77
commit
3df1db4ad8
@ -6,8 +6,8 @@ import { RunnerGroupNotFoundError } from '../errors/RunnerGroupErrors';
|
|||||||
import { CreateRunner } from '../models/actions/CreateRunner';
|
import { CreateRunner } from '../models/actions/CreateRunner';
|
||||||
import { UpdateRunner } from '../models/actions/UpdateRunner';
|
import { UpdateRunner } from '../models/actions/UpdateRunner';
|
||||||
import { Donor } from '../models/entities/Donor';
|
import { Donor } from '../models/entities/Donor';
|
||||||
|
import { ResponseDonor } from '../models/responses/ResponseDonor';
|
||||||
import { ResponseEmpty } from '../models/responses/ResponseEmpty';
|
import { ResponseEmpty } from '../models/responses/ResponseEmpty';
|
||||||
import { ResponseRunner } from '../models/responses/ResponseRunner';
|
|
||||||
|
|
||||||
@JsonController('/donors')
|
@JsonController('/donors')
|
||||||
@OpenAPI({ security: [{ "AuthToken": [] }, { "RefreshTokenCookie": [] }] })
|
@OpenAPI({ security: [{ "AuthToken": [] }, { "RefreshTokenCookie": [] }] })
|
||||||
@ -23,32 +23,32 @@ export class DonorController {
|
|||||||
|
|
||||||
@Get()
|
@Get()
|
||||||
@Authorized("DONOR:GET")
|
@Authorized("DONOR:GET")
|
||||||
@ResponseSchema(ResponseRunner, { isArray: true })
|
@ResponseSchema(ResponseDonor, { isArray: true })
|
||||||
@OpenAPI({ description: 'Lists all runners from all teams/orgs. <br> This includes the runner\'s group and distance ran.' })
|
@OpenAPI({ description: 'Lists all runners from all teams/orgs. <br> This includes the runner\'s group and distance ran.' })
|
||||||
async getAll() {
|
async getAll() {
|
||||||
let responseRunners: ResponseRunner[] = new Array<ResponseRunner>();
|
let responseDonors: ResponseDonor[] = new Array<ResponseDonor>();
|
||||||
const runners = await this.donorRepository.find({ relations: ['scans', 'group'] });
|
const donors = await this.donorRepository.find();
|
||||||
runners.forEach(runner => {
|
donors.forEach(donor => {
|
||||||
responseRunners.push(new ResponseRunner(runner));
|
responseDonors.push(new ResponseDonor(donor));
|
||||||
});
|
});
|
||||||
return responseRunners;
|
return responseDonors;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Get('/:id')
|
@Get('/:id')
|
||||||
@Authorized("DONOR:GET")
|
@Authorized("DONOR:GET")
|
||||||
@ResponseSchema(ResponseRunner)
|
@ResponseSchema(ResponseDonor)
|
||||||
@ResponseSchema(RunnerNotFoundError, { statusCode: 404 })
|
@ResponseSchema(RunnerNotFoundError, { statusCode: 404 })
|
||||||
@OnUndefined(RunnerNotFoundError)
|
@OnUndefined(RunnerNotFoundError)
|
||||||
@OpenAPI({ description: 'Lists all information about the runner whose id got provided.' })
|
@OpenAPI({ description: 'Lists all information about the runner whose id got provided.' })
|
||||||
async getOne(@Param('id') id: number) {
|
async getOne(@Param('id') id: number) {
|
||||||
let runner = await this.donorRepository.findOne({ id: id }, { relations: ['scans', 'group'] })
|
let donor = await this.donorRepository.findOne({ id: id })
|
||||||
if (!runner) { throw new RunnerNotFoundError(); }
|
if (!donor) { throw new RunnerNotFoundError(); }
|
||||||
return new ResponseRunner(runner);
|
return new ResponseDonor(donor);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Post()
|
@Post()
|
||||||
@Authorized("DONOR:CREATE")
|
@Authorized("DONOR:CREATE")
|
||||||
@ResponseSchema(ResponseRunner)
|
@ResponseSchema(ResponseDonor)
|
||||||
@ResponseSchema(RunnerGroupNeededError)
|
@ResponseSchema(RunnerGroupNeededError)
|
||||||
@ResponseSchema(RunnerGroupNotFoundError)
|
@ResponseSchema(RunnerGroupNotFoundError)
|
||||||
@OpenAPI({ description: 'Create a new runner. <br> Please remeber to provide the runner\'s group\'s id.' })
|
@OpenAPI({ description: 'Create a new runner. <br> Please remeber to provide the runner\'s group\'s id.' })
|
||||||
@ -61,12 +61,12 @@ export class DonorController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
runner = await this.donorRepository.save(runner)
|
runner = await this.donorRepository.save(runner)
|
||||||
return new ResponseRunner(await this.donorRepository.findOne(runner, { relations: ['scans', 'group'] }));
|
return new ResponseDonor(await this.donorRepository.findOne(runner, { relations: ['scans', 'group'] }));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Put('/:id')
|
@Put('/:id')
|
||||||
@Authorized("DONOR:UPDATE")
|
@Authorized("DONOR:UPDATE")
|
||||||
@ResponseSchema(ResponseRunner)
|
@ResponseSchema(ResponseDonor)
|
||||||
@ResponseSchema(RunnerNotFoundError, { statusCode: 404 })
|
@ResponseSchema(RunnerNotFoundError, { statusCode: 404 })
|
||||||
@ResponseSchema(RunnerIdsNotMatchingError, { statusCode: 406 })
|
@ResponseSchema(RunnerIdsNotMatchingError, { statusCode: 406 })
|
||||||
@OpenAPI({ description: "Update the runner whose id you provided. <br> Please remember that ids can't be changed." })
|
@OpenAPI({ description: "Update the runner whose id you provided. <br> Please remember that ids can't be changed." })
|
||||||
@ -82,12 +82,12 @@ export class DonorController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
await this.donorRepository.save(await runner.updateRunner(oldRunner));
|
await this.donorRepository.save(await runner.updateRunner(oldRunner));
|
||||||
return new ResponseRunner(await this.donorRepository.findOne({ id: id }, { relations: ['scans', 'group'] }));
|
return new ResponseDonor(await this.donorRepository.findOne({ id: id }, { relations: ['scans', 'group'] }));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Delete('/:id')
|
@Delete('/:id')
|
||||||
@Authorized("DONOR:DELETE")
|
@Authorized("DONOR:DELETE")
|
||||||
@ResponseSchema(ResponseRunner)
|
@ResponseSchema(ResponseDonor)
|
||||||
@ResponseSchema(ResponseEmpty, { statusCode: 204 })
|
@ResponseSchema(ResponseEmpty, { statusCode: 204 })
|
||||||
@OnUndefined(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).' })
|
@OpenAPI({ description: 'Delete the runner whose id you provided. <br> If no runner with this id exists it will just return 204(no content).' })
|
||||||
@ -101,6 +101,6 @@ export class DonorController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
await this.donorRepository.delete(runner);
|
await this.donorRepository.delete(runner);
|
||||||
return new ResponseRunner(responseRunner);
|
return new ResponseDonor(responseRunner);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user