parent
5f1ab4a2f3
commit
0df26cbd54
@ -1,12 +1,15 @@
|
|||||||
import { JsonController } from 'routing-controllers';
|
import { Authorized, Get, JsonController, OnUndefined, Param } from 'routing-controllers';
|
||||||
import { OpenAPI } from 'routing-controllers-openapi';
|
import { OpenAPI, ResponseSchema } from 'routing-controllers-openapi';
|
||||||
import { getConnectionManager, Repository } from 'typeorm';
|
import { getConnectionManager, Repository } from 'typeorm';
|
||||||
|
import { DonationNotFoundError } from '../errors/DonationErrors';
|
||||||
import { DistanceDonation } from '../models/entities/DistanceDonation';
|
import { DistanceDonation } from '../models/entities/DistanceDonation';
|
||||||
import { Donation } from '../models/entities/Donation';
|
import { Donation } from '../models/entities/Donation';
|
||||||
|
import { ResponseDistanceDonation } from '../models/responses/ResponseDistanceDonation';
|
||||||
|
import { ResponseDonation } from '../models/responses/ResponseDonation';
|
||||||
|
|
||||||
@JsonController('/scans')
|
@JsonController('/donations')
|
||||||
@OpenAPI({ security: [{ "AuthToken": [] }, { "RefreshTokenCookie": [] }] })
|
@OpenAPI({ security: [{ "AuthToken": [] }, { "RefreshTokenCookie": [] }] })
|
||||||
export class ScanController {
|
export class DonationController {
|
||||||
private donationRepository: Repository<Donation>;
|
private donationRepository: Repository<Donation>;
|
||||||
private distanceDonationRepository: Repository<DistanceDonation>;
|
private distanceDonationRepository: Repository<DistanceDonation>;
|
||||||
|
|
||||||
@ -18,32 +21,32 @@ export class ScanController {
|
|||||||
this.distanceDonationRepository = getConnectionManager().get().getRepository(DistanceDonation);
|
this.distanceDonationRepository = getConnectionManager().get().getRepository(DistanceDonation);
|
||||||
}
|
}
|
||||||
|
|
||||||
// @Get()
|
@Get()
|
||||||
// @Authorized("SCAN:GET")
|
@Authorized("DONATION:GET")
|
||||||
// @ResponseSchema(ResponseScan, { isArray: true })
|
@ResponseSchema(ResponseDonation, { isArray: true })
|
||||||
// @ResponseSchema(ResponseTrackScan, { isArray: true })
|
@ResponseSchema(ResponseDistanceDonation, { isArray: true })
|
||||||
// @OpenAPI({ description: 'Lists all scans (normal or track) from all runners. <br> This includes the scan\'s runner\'s distance ran.' })
|
@OpenAPI({ description: 'Lists all donations (fixed or distance based) from all donors. <br> This includes the donations\'s runner\'s distance ran(if distance donation).' })
|
||||||
// async getAll() {
|
async getAll() {
|
||||||
// let responseScans: ResponseScan[] = new Array<ResponseScan>();
|
let responseDonations: ResponseDonation[] = new Array<ResponseDonation>();
|
||||||
// const scans = await this.scanRepository.find({ relations: ['runner', 'track', 'runner.scans', 'runner.scans.track', 'card', 'station'] });
|
const donations = await this.donationRepository.find({ relations: ['runner', 'donor', 'runner.scans', 'runner.scans.track'] });
|
||||||
// scans.forEach(scan => {
|
donations.forEach(donation => {
|
||||||
// responseScans.push(scan.toResponse());
|
responseDonations.push(donation.toResponse());
|
||||||
// });
|
});
|
||||||
// return responseScans;
|
return responseDonations;
|
||||||
// }
|
}
|
||||||
|
|
||||||
// @Get('/:id')
|
@Get('/:id')
|
||||||
// @Authorized("SCAN:GET")
|
@Authorized("DONATION:GET")
|
||||||
// @ResponseSchema(ResponseScan)
|
@ResponseSchema(ResponseDonation)
|
||||||
// @ResponseSchema(ResponseTrackScan)
|
@ResponseSchema(ResponseDistanceDonation)
|
||||||
// @ResponseSchema(ScanNotFoundError, { statusCode: 404 })
|
@ResponseSchema(DonationNotFoundError, { statusCode: 404 })
|
||||||
// @OnUndefined(ScanNotFoundError)
|
@OnUndefined(DonationNotFoundError)
|
||||||
// @OpenAPI({ description: 'Lists all information about the scan whose id got provided. This includes the scan\'s runner\'s distance ran.' })
|
@OpenAPI({ description: 'Lists all information about the donation whose id got provided. This includes the donation\'s runner\'s distance ran (if distance donation).' })
|
||||||
// async getOne(@Param('id') id: number) {
|
async getOne(@Param('id') id: number) {
|
||||||
// let scan = await this.scanRepository.findOne({ id: id }, { relations: ['runner', 'track', 'runner.scans', 'runner.scans.track', 'card', 'station'] })
|
let donation = await this.donationRepository.findOne({ id: id }, { relations: ['runner', 'donor', 'runner.scans', 'runner.scans.track'] })
|
||||||
// if (!scan) { throw new ScanNotFoundError(); }
|
if (!donation) { throw new DonationNotFoundError(); }
|
||||||
// return scan.toResponse();
|
return donation.toResponse();
|
||||||
// }
|
}
|
||||||
|
|
||||||
// @Post()
|
// @Post()
|
||||||
// @UseBefore(ScanAuth)
|
// @UseBefore(ScanAuth)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user