server: support get comment without login

This commit is contained in:
fantasticit 2022-06-03 15:40:49 +08:00
parent a7fb655f4c
commit b77a7d2ffe
3 changed files with 36 additions and 6 deletions

View File

@ -1,5 +1,6 @@
import { CommentDto, UpdateCommentDto } from '@dtos/comment.dto'; import { CommentDto, UpdateCommentDto } from '@dtos/comment.dto';
import { JwtGuard } from '@guard/jwt.guard'; import { JwtGuard } from '@guard/jwt.guard';
import { UserGuard } from '@guard/user.guard';
import { import {
Body, Body,
ClassSerializerInterceptor, ClassSerializerInterceptor,
@ -63,8 +64,9 @@ export class CommentController {
@UseInterceptors(ClassSerializerInterceptor) @UseInterceptors(ClassSerializerInterceptor)
@Get(CommentApiDefinition.documents.server) @Get(CommentApiDefinition.documents.server)
@HttpCode(HttpStatus.OK) @HttpCode(HttpStatus.OK)
@UseGuards(JwtGuard) @UseGuards(UserGuard)
async getArticleComments(@Param('documentId') documentId, @Query() qurey) { async getArticleComments(@Request() req, @Param('documentId') documentId, @Query() qurey) {
return this.commentService.getDocumentComments(documentId, qurey); const user = req.user;
return this.commentService.getDocumentComments(user, documentId, qurey);
} }
} }

View File

@ -0,0 +1,16 @@
import { CanActivate, ExecutionContext, Injectable } from '@nestjs/common';
import { JwtService } from '@nestjs/jwt';
import { IUser } from '@think/domains';
@Injectable()
export class UserGuard implements CanActivate {
constructor(private readonly jwtService: JwtService) {}
async canActivate(context: ExecutionContext): Promise<boolean> {
const request = context.switchToHttp().getRequest();
const token = request?.cookies['token'];
const user = this.jwtService.decode(token) as IUser;
request.user = user;
return true;
}
}

View File

@ -92,7 +92,9 @@ export class CommentService {
* @param documentId * @param documentId
* @param queryParams * @param queryParams
*/ */
async getDocumentComments(documentId, queryParams) { async getDocumentComments(user, documentId, queryParams) {
const hasLogin = user ? !!(await this.userService.validateUser(user)) : false;
const query = this.commentRepo const query = this.commentRepo
.createQueryBuilder('comment') .createQueryBuilder('comment')
.where('comment.documentId=:documentId') .where('comment.documentId=:documentId')
@ -116,9 +118,19 @@ export class CommentService {
const getCreateUser = async (comment) => { const getCreateUser = async (comment) => {
try { try {
const createUser = await this.userService.findById(comment.createUserId); if (hasLogin) {
comment.createUser = createUser; const createUser = await this.userService.findById(comment.createUserId);
comment.createUser = createUser;
} else {
comment.createUser = {
id: comment.createUserId,
name: `用户${comment.createUserId.split('-').shift()}`,
role: 'normal',
status: 'normal',
};
}
} catch (e) { } catch (e) {
console.log('error', e);
comment.createUser = null; comment.createUser = null;
} }
}; };