完成博客添加时的权限指定

This commit is contained in:
2025-06-22 23:26:12 +08:00
parent f3193226e7
commit 857d73d2ba
4 changed files with 83 additions and 4 deletions

View File

@@ -1,4 +1,5 @@
import {
BadRequestException,
Body,
Controller,
Delete,
@@ -12,7 +13,9 @@ import {
import { AuthGuard } from '@nestjs/passport';
import { CreateBlogDto } from 'src/admin/dto/admin-web/create-blog.dto';
import { Role } from 'src/auth/role.enum';
import { BlogPermission } from 'src/blog/Blog.Permission.enum';
import { BlogService } from 'src/blog/blog.service';
import { Blog } from 'src/blog/entity/Blog.entity';
import { Roles } from 'src/common/decorators/role.decorator';
import { RolesGuard } from 'src/common/guard/roles.guard';
@@ -20,7 +23,7 @@ import { RolesGuard } from 'src/common/guard/roles.guard';
@UseGuards(AuthGuard('jwt'), RolesGuard)
@Roles(Role.Admin)
export class AdminWebBlogController {
constructor(private readonly adminWebBlogService: BlogService) {}
constructor(private readonly adminWebBlogService: BlogService) { }
@Get()
async list() {

View File

@@ -1,4 +1,5 @@
import { IsString } from 'class-validator';
import { IsEnum, IsString } from 'class-validator';
import { BlogPermission } from 'src/blog/Blog.Permission.enum';
export class CreateBlogDto {
@IsString()
@@ -9,4 +10,10 @@ export class CreateBlogDto {
@IsString()
contentUrl: string;
@IsEnum(BlogPermission, { each: true, message: '请求类型错误' })
permissions: BlogPermission[];
@IsString()
password: string;// 允许空串
}

View File

@@ -3,6 +3,8 @@ import { InjectRepository } from '@nestjs/typeorm';
import { Blog } from './entity/Blog.entity';
import { Repository } from 'typeorm';
import { BlogComment } from './entity/BlogComment.entity';
import { BlogPermission } from './Blog.Permission.enum';
import { createHash } from 'crypto';
@Injectable()
export class BlogService {
@@ -11,7 +13,7 @@ export class BlogService {
private readonly blogRepository: Repository<Blog>,
@InjectRepository(BlogComment)
private readonly blogCommentRepository: Repository<BlogComment>,
) {}
) { }
async list() {
return this.blogRepository.find({
@@ -22,7 +24,14 @@ export class BlogService {
});
}
async create(blog: Partial<Blog>) {
async create(dto: Partial<Blog> & { password: string }) {
const { password, ...blog } = dto;
if (blog.permissions.includes(BlogPermission.ByPassword)) {
if (password) {
blog.password_hash = createHash('sha256').update(`${password}`).digest('hex');
}
}
const newBlog = this.blogRepository.create(blog);
return this.blogRepository.save(newBlog);
}