|
@ -11,7 +11,8 @@ import { |
|
|
Res, |
|
|
Res, |
|
|
StreamableFile, |
|
|
StreamableFile, |
|
|
BadRequestException, |
|
|
BadRequestException, |
|
|
Redirect |
|
|
Redirect, |
|
|
|
|
|
type NotFoundException |
|
|
} from '@nestjs/common' |
|
|
} from '@nestjs/common' |
|
|
|
|
|
|
|
|
import { FileInterceptor } from '@nestjs/platform-express' |
|
|
import { FileInterceptor } from '@nestjs/platform-express' |
|
@ -30,6 +31,7 @@ import { ApiBody, ApiConsumes } from '@nestjs/swagger' |
|
|
import { type Request, Response } from 'express' |
|
|
import { type Request, Response } from 'express' |
|
|
import { createReadStream } from 'fs' |
|
|
import { createReadStream } from 'fs' |
|
|
import { join } from 'path' |
|
|
import { join } from 'path' |
|
|
|
|
|
import type Result from 'src/pong/entity/result.entity' |
|
|
|
|
|
|
|
|
@Controller() |
|
|
@Controller() |
|
|
export class UsersController { |
|
|
export class UsersController { |
|
@ -50,39 +52,38 @@ export class UsersController { |
|
|
|
|
|
|
|
|
@Get('friends') |
|
|
@Get('friends') |
|
|
@UseGuards(AuthenticatedGuard) |
|
|
@UseGuards(AuthenticatedGuard) |
|
|
async getFriends(@FtUser() profile: Profile) { |
|
|
async getFriends (@FtUser() profile: Profile): Promise<User[]> { |
|
|
return await this.usersService.getFriends(profile.id) |
|
|
return await this.usersService.getFriends(profile.id) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
@Get('invits') |
|
|
@Get('invits') |
|
|
@UseGuards(AuthenticatedGuard) |
|
|
@UseGuards(AuthenticatedGuard) |
|
|
async getInvits(@FtUser() profile: Profile) { |
|
|
async getInvits (@FtUser() profile: Profile): Promise<User[]> { |
|
|
return await this.usersService.getInvits(profile.id) |
|
|
return await this.usersService.getInvits(profile.id) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@Get('leader') |
|
|
@Get('leader') |
|
|
@UseGuards(AuthenticatedGuard) |
|
|
@UseGuards(AuthenticatedGuard) |
|
|
async getLeader() { |
|
|
async getLeader (): Promise<User[]> { |
|
|
return await this.usersService.getLeader() |
|
|
return await this.usersService.getLeader() |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
@Get('leader/:id') |
|
|
@Get('leader/:id') |
|
|
@UseGuards(AuthenticatedGuard) |
|
|
@UseGuards(AuthenticatedGuard) |
|
|
async getRank(@Param('id', ParseIntPipe) id: number) { |
|
|
async getRank (@Param('id', ParseIntPipe) id: number): Promise<number> { |
|
|
return await this.usersService.getRank(id) |
|
|
return await this.usersService.getRank(id) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
@Get('history') |
|
|
@Get('history') |
|
|
@UseGuards(AuthenticatedGuard) |
|
|
@UseGuards(AuthenticatedGuard) |
|
|
async getHistory() { |
|
|
async getHistory (): Promise<Result[]> { |
|
|
return await this.pongService.getHistory() |
|
|
return await this.pongService.getHistory() |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
@Get('history/:id') |
|
|
@Get('history/:id') |
|
|
@UseGuards(AuthenticatedGuard) |
|
|
@UseGuards(AuthenticatedGuard) |
|
|
async getHistoryById(@Param('id', ParseIntPipe) id: number) { |
|
|
async getHistoryById (@Param('id', ParseIntPipe) id: number): Promise<Result[]> { |
|
|
return this.pongService.getHistoryById(id) |
|
|
return await this.pongService.getHistoryById(id) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
@Post('avatar') |
|
|
@Post('avatar') |
|
@ -110,7 +111,7 @@ export class UsersController { |
|
|
async addAvatar ( |
|
|
async addAvatar ( |
|
|
@FtUser() profile: Profile, |
|
|
@FtUser() profile: Profile, |
|
|
@UploadedFile() file: Express.Multer.File |
|
|
@UploadedFile() file: Express.Multer.File |
|
|
) { |
|
|
): Promise<void> { |
|
|
await this.usersService.addAvatar(profile.id, file.filename) |
|
|
await this.usersService.addAvatar(profile.id, file.filename) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -119,7 +120,7 @@ export class UsersController { |
|
|
async getAvatar ( |
|
|
async getAvatar ( |
|
|
@FtUser() profile: Profile, |
|
|
@FtUser() profile: Profile, |
|
|
@Res({ passthrough: true }) response: Response |
|
|
@Res({ passthrough: true }) response: Response |
|
|
) { |
|
|
): Promise<StreamableFile | null> { |
|
|
return await this.getAvatarById(profile.id, response) |
|
|
return await this.getAvatarById(profile.id, response) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -133,7 +134,7 @@ export class UsersController { |
|
|
async invitUser ( |
|
|
async invitUser ( |
|
|
@FtUser() profile: Profile, |
|
|
@FtUser() profile: Profile, |
|
|
@Param('id', ParseIntPipe) id: number |
|
|
@Param('id', ParseIntPipe) id: number |
|
|
) { |
|
|
): Promise<NotFoundException | null | undefined> { |
|
|
return await this.usersService.invit(profile.id, id) |
|
|
return await this.usersService.invit(profile.id, id) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -141,9 +142,9 @@ export class UsersController { |
|
|
async getAvatarById ( |
|
|
async getAvatarById ( |
|
|
@Param('id', ParseIntPipe) ftId: number, |
|
|
@Param('id', ParseIntPipe) ftId: number, |
|
|
@Res({ passthrough: true }) response: Response |
|
|
@Res({ passthrough: true }) response: Response |
|
|
) { |
|
|
): Promise<StreamableFile | null> { |
|
|
const user = await this.usersService.findUser(ftId) |
|
|
const user = await this.usersService.findUser(ftId) |
|
|
if (user == null) return |
|
|
if (user == null) return null |
|
|
const filename = user.avatar |
|
|
const filename = user.avatar |
|
|
const stream = createReadStream(join(process.cwd(), 'avatars/' + filename)) |
|
|
const stream = createReadStream(join(process.cwd(), 'avatars/' + filename)) |
|
|
response.set({ |
|
|
response.set({ |
|
@ -160,9 +161,9 @@ export class UsersController { |
|
|
return await this.usersService.findUser(ftId) |
|
|
return await this.usersService.findUser(ftId) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
@Post(":id") |
|
|
@Post(':id') |
|
|
@UseGuards(AuthenticatedGuard) |
|
|
@UseGuards(AuthenticatedGuard) |
|
|
async createById(@Body() payload: UserDto) { |
|
|
async createById (@Body() payload: UserDto): Promise<User | null> { |
|
|
const user = await this.usersService.findUser(payload.ftId) |
|
|
const user = await this.usersService.findUser(payload.ftId) |
|
|
if (user != null) { |
|
|
if (user != null) { |
|
|
return await this.usersService.update(user, payload) |
|
|
return await this.usersService.update(user, payload) |
|
@ -179,7 +180,7 @@ export class UsersController { |
|
|
|
|
|
|
|
|
@Post() |
|
|
@Post() |
|
|
@UseGuards(AuthenticatedGuard) |
|
|
@UseGuards(AuthenticatedGuard) |
|
|
async create(@Body() payload: UserDto, @FtUser() profile: Profile) { |
|
|
async create (@Body() payload: UserDto, @FtUser() profile: Profile): Promise<User | null> { |
|
|
const user = await this.usersService.findUser(profile.id) |
|
|
const user = await this.usersService.findUser(profile.id) |
|
|
if (user != null) { |
|
|
if (user != null) { |
|
|
return await this.usersService.update(user, payload) |
|
|
return await this.usersService.update(user, payload) |
|
@ -187,5 +188,4 @@ export class UsersController { |
|
|
return await this.usersService.create(payload) |
|
|
return await this.usersService.create(payload) |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
} |
|
|
} |
|
|