From 0f003ac422477ceaac1c69369d5b75ef76031d23 Mon Sep 17 00:00:00 2001 From: wenyu441069198 <14186472+wenyu441069198@user.noreply.gitee.com> Date: Sun, 2 Jun 2024 14:28:26 +0800 Subject: [PATCH] yh -2 --- pom.xml | 13 ++ .../teaching/TeachingBackendApplication.java | 2 + .../teaching/backend/common/BaseResponse.java | 34 +++++ .../teaching/backend/common/ErrorCode.java | 43 ++++++ .../teaching/backend/common/ResultUtils.java | 52 ++++++++ .../com/teaching/backend/common/test1.java | 9 -- .../backend/config/MyBatisPlusConfig.java | 29 +++++ .../backend/controller/UserController.java | 21 --- .../favour/SeCourseFavourController.java | 110 ++++++++++++++++ .../favour/SeKnowFavourController.java | 50 +++++++ .../favour/SeResourceFavourController.java | 51 ++++++++ .../thumb/SeCourseThumbController.java | 87 +++++++++++++ .../thumb/SeKnowThumbController.java | 49 +++++++ .../thumb/SeResourceThumbController.java | 49 +++++++ .../backend/exception/BusinessException.java | 37 ++++++ .../com/teaching/backend/exception/test1.java | 9 -- .../mapper/favour/SeCourseFavourMapper.java | 15 +++ .../mapper/favour/SeKnowFavourMapper.java | 16 +++ .../mapper/favour/SeResourceFavourMapper.java | 17 +++ .../com/teaching/backend/mapper/test1.java | 9 -- .../mapper/thumb/SeCourseThumbMapper.java | 15 +++ .../mapper/thumb/SeKnowThumbMapper.java | 16 +++ .../mapper/thumb/SeResourceThumbMapper.java | 17 +++ .../courseFavour/CourseFavourAddRequest.java | 24 ++++ .../courseFavour/CourseFavourAllRequest.java | 20 +++ .../courseFavour/CourseFavourListRequest.java | 20 +++ .../knowFavour/KnowFavourAddRequest.java | 29 +++++ .../ResourceFavourAddRequest.java | 29 +++++ .../com/teaching/backend/model/dto/test1.java | 9 -- .../coursethumb/CourseThumbAddRequest.java | 24 ++++ .../coursethumb/CourseThumbAllRequest.java | 20 +++ .../thumb/knowthumb/KnowThumbAddRequest.java | 29 +++++ .../ResourceThumbAddRequest.java | 29 +++++ .../model/entity/favour/SeCourseFavour.java | 35 +++++ .../model/entity/favour/SeKnowFavour.java | 40 ++++++ .../model/entity/favour/SeResourceFavour.java | 40 ++++++ .../teaching/backend/model/entity/test1.java | 9 -- .../model/entity/thumb/SeCourseThumb.java | 36 +++++ .../model/entity/thumb/SeKnowThumb.java | 40 ++++++ .../model/entity/thumb/SeResourceThumb.java | 40 ++++++ .../com/teaching/backend/model/test1.java | 9 -- .../service/favour/SeCourseFavourService.java | 51 ++++++++ .../service/favour/SeKnowFavourService.java | 22 ++++ .../favour/SeResourceFavourService.java | 22 ++++ .../favour/SeCourseFavourServiceImpl.java | 123 ++++++++++++++++++ .../impl/favour/SeKnowFavourServiceImpl.java | 64 +++++++++ .../favour/SeResourceFavourServiceImpl.java | 65 +++++++++ .../impl/thumb/SeCourseThumbServiceImpl.java | 105 +++++++++++++++ .../impl/thumb/SeKnowThumbServiceImpl.java | 63 +++++++++ .../thumb/SeResourceThumbServiceImpl.java | 63 +++++++++ .../com/teaching/backend/service/test1.java | 9 -- .../service/thumb/SeCourseThumbService.java | 40 ++++++ .../service/thumb/SeKnowThumbService.java | 22 ++++ .../service/thumb/SeResourceThumbService.java | 22 ++++ src/main/resources/application.yml | 18 ++- .../resources/mapper/SeCourseThumbMapper.xml | 18 +++ 56 files changed, 1854 insertions(+), 85 deletions(-) create mode 100644 src/main/java/com/teaching/backend/common/BaseResponse.java create mode 100644 src/main/java/com/teaching/backend/common/ErrorCode.java create mode 100644 src/main/java/com/teaching/backend/common/ResultUtils.java delete mode 100644 src/main/java/com/teaching/backend/common/test1.java create mode 100644 src/main/java/com/teaching/backend/config/MyBatisPlusConfig.java delete mode 100644 src/main/java/com/teaching/backend/controller/UserController.java create mode 100644 src/main/java/com/teaching/backend/controller/favour/SeCourseFavourController.java create mode 100644 src/main/java/com/teaching/backend/controller/favour/SeKnowFavourController.java create mode 100644 src/main/java/com/teaching/backend/controller/favour/SeResourceFavourController.java create mode 100644 src/main/java/com/teaching/backend/controller/thumb/SeCourseThumbController.java create mode 100644 src/main/java/com/teaching/backend/controller/thumb/SeKnowThumbController.java create mode 100644 src/main/java/com/teaching/backend/controller/thumb/SeResourceThumbController.java create mode 100644 src/main/java/com/teaching/backend/exception/BusinessException.java delete mode 100644 src/main/java/com/teaching/backend/exception/test1.java create mode 100644 src/main/java/com/teaching/backend/mapper/favour/SeCourseFavourMapper.java create mode 100644 src/main/java/com/teaching/backend/mapper/favour/SeKnowFavourMapper.java create mode 100644 src/main/java/com/teaching/backend/mapper/favour/SeResourceFavourMapper.java delete mode 100644 src/main/java/com/teaching/backend/mapper/test1.java create mode 100644 src/main/java/com/teaching/backend/mapper/thumb/SeCourseThumbMapper.java create mode 100644 src/main/java/com/teaching/backend/mapper/thumb/SeKnowThumbMapper.java create mode 100644 src/main/java/com/teaching/backend/mapper/thumb/SeResourceThumbMapper.java create mode 100644 src/main/java/com/teaching/backend/model/dto/favour/courseFavour/CourseFavourAddRequest.java create mode 100644 src/main/java/com/teaching/backend/model/dto/favour/courseFavour/CourseFavourAllRequest.java create mode 100644 src/main/java/com/teaching/backend/model/dto/favour/courseFavour/CourseFavourListRequest.java create mode 100644 src/main/java/com/teaching/backend/model/dto/favour/knowFavour/KnowFavourAddRequest.java create mode 100644 src/main/java/com/teaching/backend/model/dto/favour/resourceFavour/ResourceFavourAddRequest.java delete mode 100644 src/main/java/com/teaching/backend/model/dto/test1.java create mode 100644 src/main/java/com/teaching/backend/model/dto/thumb/coursethumb/CourseThumbAddRequest.java create mode 100644 src/main/java/com/teaching/backend/model/dto/thumb/coursethumb/CourseThumbAllRequest.java create mode 100644 src/main/java/com/teaching/backend/model/dto/thumb/knowthumb/KnowThumbAddRequest.java create mode 100644 src/main/java/com/teaching/backend/model/dto/thumb/resourcethumb/ResourceThumbAddRequest.java create mode 100644 src/main/java/com/teaching/backend/model/entity/favour/SeCourseFavour.java create mode 100644 src/main/java/com/teaching/backend/model/entity/favour/SeKnowFavour.java create mode 100644 src/main/java/com/teaching/backend/model/entity/favour/SeResourceFavour.java delete mode 100644 src/main/java/com/teaching/backend/model/entity/test1.java create mode 100644 src/main/java/com/teaching/backend/model/entity/thumb/SeCourseThumb.java create mode 100644 src/main/java/com/teaching/backend/model/entity/thumb/SeKnowThumb.java create mode 100644 src/main/java/com/teaching/backend/model/entity/thumb/SeResourceThumb.java delete mode 100644 src/main/java/com/teaching/backend/model/test1.java create mode 100644 src/main/java/com/teaching/backend/service/favour/SeCourseFavourService.java create mode 100644 src/main/java/com/teaching/backend/service/favour/SeKnowFavourService.java create mode 100644 src/main/java/com/teaching/backend/service/favour/SeResourceFavourService.java create mode 100644 src/main/java/com/teaching/backend/service/impl/favour/SeCourseFavourServiceImpl.java create mode 100644 src/main/java/com/teaching/backend/service/impl/favour/SeKnowFavourServiceImpl.java create mode 100644 src/main/java/com/teaching/backend/service/impl/favour/SeResourceFavourServiceImpl.java create mode 100644 src/main/java/com/teaching/backend/service/impl/thumb/SeCourseThumbServiceImpl.java create mode 100644 src/main/java/com/teaching/backend/service/impl/thumb/SeKnowThumbServiceImpl.java create mode 100644 src/main/java/com/teaching/backend/service/impl/thumb/SeResourceThumbServiceImpl.java delete mode 100644 src/main/java/com/teaching/backend/service/test1.java create mode 100644 src/main/java/com/teaching/backend/service/thumb/SeCourseThumbService.java create mode 100644 src/main/java/com/teaching/backend/service/thumb/SeKnowThumbService.java create mode 100644 src/main/java/com/teaching/backend/service/thumb/SeResourceThumbService.java create mode 100644 src/main/resources/mapper/SeCourseThumbMapper.xml diff --git a/pom.xml b/pom.xml index a0963d6..fdb7d41 100644 --- a/pom.xml +++ b/pom.xml @@ -41,6 +41,7 @@ mybatis-spring-boot-starter 2.2.2 + com.baomidou @@ -63,6 +64,18 @@ spring-boot-starter-test test + + + + com.github.xiaoymin + knife4j-openapi2-spring-boot-starter + 4.4.0 + + + + org.apache.commons + commons-lang3 + diff --git a/src/main/java/com/teaching/TeachingBackendApplication.java b/src/main/java/com/teaching/TeachingBackendApplication.java index 242c819..814a59c 100644 --- a/src/main/java/com/teaching/TeachingBackendApplication.java +++ b/src/main/java/com/teaching/TeachingBackendApplication.java @@ -1,9 +1,11 @@ package com.teaching; +import org.mybatis.spring.annotation.MapperScan; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication +@MapperScan("com.teaching.backend.mapper") public class TeachingBackendApplication { public static void main(String[] args) { diff --git a/src/main/java/com/teaching/backend/common/BaseResponse.java b/src/main/java/com/teaching/backend/common/BaseResponse.java new file mode 100644 index 0000000..e562b52 --- /dev/null +++ b/src/main/java/com/teaching/backend/common/BaseResponse.java @@ -0,0 +1,34 @@ +package com.teaching.backend.common; + +import lombok.Data; + +import java.io.Serializable; + +/** + * 通用返回类 + * + * @param + */ +@Data +public class BaseResponse implements Serializable { + + private int code; + + private T data; + + private String message; + + public BaseResponse(int code, T data, String message) { + this.code = code; + this.data = data; + this.message = message; + } + + public BaseResponse(int code, T data) { + this(code, data, ""); + } + + public BaseResponse(ErrorCode errorCode) { + this(errorCode.getCode(), null, errorCode.getMessage()); + } +} diff --git a/src/main/java/com/teaching/backend/common/ErrorCode.java b/src/main/java/com/teaching/backend/common/ErrorCode.java new file mode 100644 index 0000000..84ddc09 --- /dev/null +++ b/src/main/java/com/teaching/backend/common/ErrorCode.java @@ -0,0 +1,43 @@ +package com.teaching.backend.common; + +/** + * 自定义错误码 + * + * @author 程序员鱼皮 + * @from 编程导航知识星球 + */ +public enum ErrorCode { + + SUCCESS(0, "ok"), + PARAMS_ERROR(40000, "请求参数错误"), + NOT_LOGIN_ERROR(40100, "未登录"), + NO_AUTH_ERROR(40101, "无权限"), + NOT_FOUND_ERROR(40400, "请求数据不存在"), + FORBIDDEN_ERROR(40300, "禁止访问"), + SYSTEM_ERROR(50000, "系统内部异常"), + OPERATION_ERROR(50001, "操作失败"); + + /** + * 状态码 + */ + private final int code; + + /** + * 信息 + */ + private final String message; + + ErrorCode(int code, String message) { + this.code = code; + this.message = message; + } + + public int getCode() { + return code; + } + + public String getMessage() { + return message; + } + +} diff --git a/src/main/java/com/teaching/backend/common/ResultUtils.java b/src/main/java/com/teaching/backend/common/ResultUtils.java new file mode 100644 index 0000000..1cd695a --- /dev/null +++ b/src/main/java/com/teaching/backend/common/ResultUtils.java @@ -0,0 +1,52 @@ +package com.teaching.backend.common; + +/** + * 返回工具类 + * + * @author 程序员鱼皮 + * @from 编程导航知识星球 + */ +public class ResultUtils { + + /** + * 成功 + * + * @param data + * @param + * @return + */ + public static BaseResponse success(T data) { + return new BaseResponse<>(0, data, "ok"); + } + + /** + * 失败 + * + * @param errorCode + * @return + */ + public static BaseResponse error(ErrorCode errorCode) { + return new BaseResponse<>(errorCode); + } + + /** + * 失败 + * + * @param code + * @param message + * @return + */ + public static BaseResponse error(int code, String message) { + return new BaseResponse(code, null, message); + } + + /** + * 失败 + * + * @param errorCode + * @return + */ + public static BaseResponse error(ErrorCode errorCode, String message) { + return new BaseResponse(errorCode.getCode(), null, message); + } +} diff --git a/src/main/java/com/teaching/backend/common/test1.java b/src/main/java/com/teaching/backend/common/test1.java deleted file mode 100644 index 99ae8b7..0000000 --- a/src/main/java/com/teaching/backend/common/test1.java +++ /dev/null @@ -1,9 +0,0 @@ -package com.teaching.backend.common; - -/** - * @Author:youhang - * @Date:2024-05-30-18:20 - * @Description: - */ -public class test1 { -} diff --git a/src/main/java/com/teaching/backend/config/MyBatisPlusConfig.java b/src/main/java/com/teaching/backend/config/MyBatisPlusConfig.java new file mode 100644 index 0000000..8f10f71 --- /dev/null +++ b/src/main/java/com/teaching/backend/config/MyBatisPlusConfig.java @@ -0,0 +1,29 @@ +package com.teaching.backend.config; + +import com.baomidou.mybatisplus.annotation.DbType; +import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor; +import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor; +import org.mybatis.spring.annotation.MapperScan; +import org.springframework.context.annotation.Bean; +import org.springframework.context.annotation.Configuration; + +/** + * MyBatis Plus 配置 + */ +@Configuration +@MapperScan("com.teaching.backend.mapper") +public class MyBatisPlusConfig { + + /** + * 拦截器配置 + * + * @return + */ + @Bean + public MybatisPlusInterceptor mybatisPlusInterceptor() { + MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor(); + // 分页插件 + interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL)); + return interceptor; + } +} diff --git a/src/main/java/com/teaching/backend/controller/UserController.java b/src/main/java/com/teaching/backend/controller/UserController.java deleted file mode 100644 index ec1b0f8..0000000 --- a/src/main/java/com/teaching/backend/controller/UserController.java +++ /dev/null @@ -1,21 +0,0 @@ -package com.teaching.backend.controller; - -import org.springframework.stereotype.Controller; -import org.springframework.web.bind.annotation.RequestMapping; -import org.springframework.web.bind.annotation.RequestMethod; -import org.springframework.web.bind.annotation.ResponseBody; - -/** - * @Author:youhang - * @Date:2024-05-30-18:15 - * @Description: - */ -@Controller -public class UserController { - - @RequestMapping(value = "/1",method = RequestMethod.GET) - @ResponseBody - public String add(){ - return "yh"; - } -} diff --git a/src/main/java/com/teaching/backend/controller/favour/SeCourseFavourController.java b/src/main/java/com/teaching/backend/controller/favour/SeCourseFavourController.java new file mode 100644 index 0000000..da34af4 --- /dev/null +++ b/src/main/java/com/teaching/backend/controller/favour/SeCourseFavourController.java @@ -0,0 +1,110 @@ +package com.teaching.backend.controller.favour; + +import com.teaching.backend.common.BaseResponse; +import com.teaching.backend.common.ErrorCode; +import com.teaching.backend.common.ResultUtils; +import com.teaching.backend.exception.BusinessException; + + +import com.teaching.backend.model.dto.favour.courseFavour.CourseFavourAddRequest; +import com.teaching.backend.model.dto.favour.courseFavour.CourseFavourAllRequest; +import com.teaching.backend.model.dto.favour.courseFavour.CourseFavourListRequest; +import com.teaching.backend.service.favour.SeCourseFavourService; +import lombok.extern.slf4j.Slf4j; +import org.apache.commons.lang3.StringUtils; +import org.springframework.web.bind.annotation.PostMapping; +import org.springframework.web.bind.annotation.RequestBody; +import org.springframework.web.bind.annotation.RequestMapping; +import org.springframework.web.bind.annotation.RestController; + +import javax.annotation.Resource; +import java.util.List; + +/** + * @Author:youhang + * @Date:2024-05-30-20:22 + * @Description: + */ +@RestController +@RequestMapping("/course_favour") +@Slf4j +public class SeCourseFavourController { + + @Resource + private SeCourseFavourService seCourseFavourService; + + + /** + * 点赞 + * + * @param courseFavourAddRequest + * @return result 执行情况 + */ + @PostMapping("/add") + // todo 后期加上 HttpServletRequest request 在一个fitter里面进行鉴权操作 + public BaseResponse doFavour(@RequestBody CourseFavourAddRequest courseFavourAddRequest) { + System.out.println(courseFavourAddRequest); + if (StringUtils.isAnyBlank(courseFavourAddRequest.getCourseId(), courseFavourAddRequest.getUserId())) { + throw new BusinessException(ErrorCode.PARAMS_ERROR); + } + // todo 从数据库中校验是否存在courseid , userid + Boolean result = seCourseFavourService.doCourseFavour(courseFavourAddRequest.getCourseId(), courseFavourAddRequest.getUserId()); + return ResultUtils.success(result); + } + + + /** + * 课程点赞总数 + * + * @param courseFavourAddRequest + * @return result 课程点赞总数 + */ + @PostMapping("/count") + // todo 后期加上 HttpServletRequest request 在一个fitter里面进行鉴权操作 + public BaseResponse favourCount(@RequestBody CourseFavourAddRequest courseFavourAddRequest) { + if (StringUtils.isAnyBlank(courseFavourAddRequest.getCourseId())) { + throw new BusinessException(ErrorCode.PARAMS_ERROR, "请求参数不能为空"); + } + // todo 从数据库中校验是否存在courseid + + Long result = seCourseFavourService.favourCount(courseFavourAddRequest.getCourseId()); + return ResultUtils.success(result); + } + + /** + * 课程下资源和知识点点赞总数 + * + * @param courseFavourAllRequest + * @return result 课程下资源和知识点点赞总数 + */ + @PostMapping("/countAll") + // todo 后期加上 HttpServletRequest request 在一个fitter里面进行鉴权操作 + public BaseResponse courseCount(@RequestBody CourseFavourAllRequest courseFavourAllRequest) { + if (StringUtils.isAnyBlank(courseFavourAllRequest.getCourseId())) { + throw new BusinessException(ErrorCode.PARAMS_ERROR, "请求参数不能为空"); + } + // todo 从数据库中校验是否存在courseid + + Long result = seCourseFavourService.courseCount(courseFavourAllRequest.getCourseId()); + return ResultUtils.success(result); + } + + /** + * 某个用户课程列表 + * + * @param courseFavourListRequest + * @return result 某个用户课程列表 + */ + @PostMapping("/countList") + // todo 后期加上 HttpServletRequest request 在一个fitter里面进行鉴权操作 + public BaseResponse> courseList(@RequestBody CourseFavourListRequest courseFavourListRequest) { + if (StringUtils.isAnyBlank(courseFavourListRequest.getUserId())) { + throw new BusinessException(ErrorCode.PARAMS_ERROR, "请求参数-用户id不能为空"); + } + // todo 从数据库中校验是否存在userid + List result = seCourseFavourService.courseList(courseFavourListRequest.getUserId()); + return ResultUtils.success(result); + } + + +} diff --git a/src/main/java/com/teaching/backend/controller/favour/SeKnowFavourController.java b/src/main/java/com/teaching/backend/controller/favour/SeKnowFavourController.java new file mode 100644 index 0000000..755b4d6 --- /dev/null +++ b/src/main/java/com/teaching/backend/controller/favour/SeKnowFavourController.java @@ -0,0 +1,50 @@ +package com.teaching.backend.controller.favour; + +import com.teaching.backend.common.BaseResponse; +import com.teaching.backend.common.ErrorCode; +import com.teaching.backend.common.ResultUtils; +import com.teaching.backend.exception.BusinessException; + +import com.teaching.backend.model.dto.favour.knowFavour.KnowFavourAddRequest; +import com.teaching.backend.service.favour.SeKnowFavourService; +import lombok.extern.slf4j.Slf4j; +import org.apache.commons.lang3.StringUtils; +import org.springframework.web.bind.annotation.PostMapping; +import org.springframework.web.bind.annotation.RequestBody; +import org.springframework.web.bind.annotation.RequestMapping; +import org.springframework.web.bind.annotation.RestController; + +import javax.annotation.Resource; + +/** + * @Author:youhang + * @Date:2024-05-30-20:22 + * @Description: + */ +@RestController +@RequestMapping("/know_favour") +@Slf4j +public class SeKnowFavourController { + + @Resource + private SeKnowFavourService seKnowFavourService; + + + /** + * 点赞 + * + * @param knowFavourAddRequest + * @return result 执行情况 + */ + @PostMapping("/add") + // todo 后期加上 HttpServletRequest request 在一个fitter里面进行鉴权操作 + public BaseResponse doFavour(@RequestBody KnowFavourAddRequest knowFavourAddRequest) { + if (StringUtils.isAnyBlank(knowFavourAddRequest.getCourseId(), knowFavourAddRequest.getKnowId(), knowFavourAddRequest.getUserId())) { + throw new BusinessException(ErrorCode.PARAMS_ERROR); + } + // todo 从数据库中校验是否存在knowid , userid ,courseid + Boolean result = seKnowFavourService.doKnowFavour(knowFavourAddRequest.getCourseId(), knowFavourAddRequest.getKnowId(), knowFavourAddRequest.getUserId()); + return ResultUtils.success(result); + } + +} diff --git a/src/main/java/com/teaching/backend/controller/favour/SeResourceFavourController.java b/src/main/java/com/teaching/backend/controller/favour/SeResourceFavourController.java new file mode 100644 index 0000000..a9f0afa --- /dev/null +++ b/src/main/java/com/teaching/backend/controller/favour/SeResourceFavourController.java @@ -0,0 +1,51 @@ +package com.teaching.backend.controller.favour; + +import com.teaching.backend.common.BaseResponse; +import com.teaching.backend.common.ErrorCode; +import com.teaching.backend.common.ResultUtils; +import com.teaching.backend.exception.BusinessException; + +import com.teaching.backend.model.dto.favour.resourceFavour.ResourceFavourAddRequest; +import com.teaching.backend.service.favour.SeResourceFavourService; +import lombok.extern.slf4j.Slf4j; +import org.apache.commons.lang3.StringUtils; +import org.springframework.web.bind.annotation.PostMapping; +import org.springframework.web.bind.annotation.RequestBody; +import org.springframework.web.bind.annotation.RequestMapping; +import org.springframework.web.bind.annotation.RestController; + +import javax.annotation.Resource; + +/** + * @Author:youhang + * @Date:2024-05-30-20:22 + * @Description: + */ +@RestController +@RequestMapping("/resource_favour") +@Slf4j +public class SeResourceFavourController { + + @Resource + private SeResourceFavourService seResourceFavourService; + + + /** + * 收藏 + * + * @param resourceFavourAddRequest + * @return result 执行情况 + */ + @PostMapping("/add") + // todo 后期加上 HttpServletRequest request 在一个fitter里面进行鉴权操作 + public BaseResponse doFavour(@RequestBody ResourceFavourAddRequest resourceFavourAddRequest) { + if (StringUtils.isAnyBlank(resourceFavourAddRequest.getCourseId(), resourceFavourAddRequest.getResourceId(), resourceFavourAddRequest.getUserId())) { + throw new BusinessException(ErrorCode.PARAMS_ERROR); + } + // todo 从数据库中校验是否存在resourceid , userid ,courseid + Boolean result = seResourceFavourService.doResourceFavour(resourceFavourAddRequest.getCourseId(), resourceFavourAddRequest.getResourceId(), resourceFavourAddRequest.getUserId()); + return ResultUtils.success(result); + } + + +} diff --git a/src/main/java/com/teaching/backend/controller/thumb/SeCourseThumbController.java b/src/main/java/com/teaching/backend/controller/thumb/SeCourseThumbController.java new file mode 100644 index 0000000..14368f7 --- /dev/null +++ b/src/main/java/com/teaching/backend/controller/thumb/SeCourseThumbController.java @@ -0,0 +1,87 @@ +package com.teaching.backend.controller.thumb; + +import com.teaching.backend.common.BaseResponse; +import com.teaching.backend.common.ErrorCode; +import com.teaching.backend.common.ResultUtils; +import com.teaching.backend.exception.BusinessException; +import com.teaching.backend.model.dto.thumb.coursethumb.CourseThumbAddRequest; +import com.teaching.backend.model.dto.thumb.coursethumb.CourseThumbAllRequest; +import com.teaching.backend.service.thumb.SeCourseThumbService; +import lombok.extern.slf4j.Slf4j; +import org.apache.commons.lang3.StringUtils; +import org.springframework.web.bind.annotation.PostMapping; +import org.springframework.web.bind.annotation.RequestBody; +import org.springframework.web.bind.annotation.RequestMapping; +import org.springframework.web.bind.annotation.RestController; + +import javax.annotation.Resource; + +/** + * @Author:youhang + * @Date:2024-05-30-20:22 + * @Description: + */ +@RestController +@RequestMapping("/course_thumb") +@Slf4j +public class SeCourseThumbController { + + @Resource + private SeCourseThumbService seCourseThumbService; + + + /** + * 点赞/取消点赞 + * + * @param courseThumbAddRequest + * @return result 执行情况 + */ + @PostMapping("/") + // todo 后期加上 HttpServletRequest request 在一个fitter里面进行鉴权操作 + public BaseResponse doThumb(@RequestBody CourseThumbAddRequest courseThumbAddRequest) { + if (StringUtils.isAnyBlank(courseThumbAddRequest.getCourseId(), courseThumbAddRequest.getUserId())) { + throw new BusinessException(ErrorCode.PARAMS_ERROR); + } + // todo 从数据库中校验是否存在courseid , userid 从课程表和用户表查询 + Boolean result = seCourseThumbService.doCourseThumb(courseThumbAddRequest.getCourseId(), courseThumbAddRequest.getUserId()); + return ResultUtils.success(result); + } + + + /** + * 课程点赞总数 + * + * @param courseThumbAddRequest + * @return result 课程点赞总数 + */ + @PostMapping("/count") + // todo 后期加上 HttpServletRequest request 在一个fitter里面进行鉴权操作 + public BaseResponse thumbCount(@RequestBody CourseThumbAddRequest courseThumbAddRequest) { + if (StringUtils.isAnyBlank(courseThumbAddRequest.getCourseId())) { + throw new BusinessException(ErrorCode.PARAMS_ERROR, "请求参数不能为空"); + } + // todo 从数据库中校验是否存在courseid + + Long result = seCourseThumbService.thumbCount(courseThumbAddRequest.getCourseId()); + return ResultUtils.success(result); + } + + /** + * 课程下资源和知识点点赞总数 + * + * @param courseThumbAllRequest + * @return result 课程下资源和知识点点赞总数 + */ + @PostMapping("/countAll") + // todo 后期加上 HttpServletRequest request 在一个fitter里面进行鉴权操作 + public BaseResponse courseCount(@RequestBody CourseThumbAllRequest courseThumbAllRequest) { + if (StringUtils.isAnyBlank(courseThumbAllRequest.getCourseId())) { + throw new BusinessException(ErrorCode.PARAMS_ERROR, "请求参数不能为空"); + } + // todo 从数据库中校验是否存在courseid + + Long result = seCourseThumbService.courseCount(courseThumbAllRequest.getCourseId()); + return ResultUtils.success(result); + } + +} diff --git a/src/main/java/com/teaching/backend/controller/thumb/SeKnowThumbController.java b/src/main/java/com/teaching/backend/controller/thumb/SeKnowThumbController.java new file mode 100644 index 0000000..2814730 --- /dev/null +++ b/src/main/java/com/teaching/backend/controller/thumb/SeKnowThumbController.java @@ -0,0 +1,49 @@ +package com.teaching.backend.controller.thumb; + +import com.teaching.backend.common.BaseResponse; +import com.teaching.backend.common.ErrorCode; +import com.teaching.backend.common.ResultUtils; +import com.teaching.backend.exception.BusinessException; +import com.teaching.backend.model.dto.thumb.knowthumb.KnowThumbAddRequest; +import com.teaching.backend.service.thumb.SeKnowThumbService; +import lombok.extern.slf4j.Slf4j; +import org.apache.commons.lang3.StringUtils; +import org.springframework.web.bind.annotation.PostMapping; +import org.springframework.web.bind.annotation.RequestBody; +import org.springframework.web.bind.annotation.RequestMapping; +import org.springframework.web.bind.annotation.RestController; + +import javax.annotation.Resource; + +/** + * @Author:youhang + * @Date:2024-05-30-20:22 + * @Description: + */ +@RestController +@RequestMapping("/know_thumb") +@Slf4j +public class SeKnowThumbController { + + @Resource + private SeKnowThumbService seKnowThumbService; + + + /** + * 点赞 + * + * @param knowThumbAddRequest + * @return result 执行情况 + */ + @PostMapping("/add") + // todo 后期加上 HttpServletRequest request 在一个fitter里面进行鉴权操作 + public BaseResponse doThumb(@RequestBody KnowThumbAddRequest knowThumbAddRequest) { + if (StringUtils.isAnyBlank(knowThumbAddRequest.getCourseId(), knowThumbAddRequest.getKnowId(), knowThumbAddRequest.getUserId())) { + throw new BusinessException(ErrorCode.PARAMS_ERROR); + } + // todo 从数据库中校验是否存在knowid , userid ,courseid + Boolean result = seKnowThumbService.doKnowThumb(knowThumbAddRequest.getCourseId(), knowThumbAddRequest.getKnowId(), knowThumbAddRequest.getUserId()); + return ResultUtils.success(result); + } + +} diff --git a/src/main/java/com/teaching/backend/controller/thumb/SeResourceThumbController.java b/src/main/java/com/teaching/backend/controller/thumb/SeResourceThumbController.java new file mode 100644 index 0000000..706bc22 --- /dev/null +++ b/src/main/java/com/teaching/backend/controller/thumb/SeResourceThumbController.java @@ -0,0 +1,49 @@ +package com.teaching.backend.controller.thumb; + +import com.teaching.backend.common.BaseResponse; +import com.teaching.backend.common.ErrorCode; +import com.teaching.backend.common.ResultUtils; +import com.teaching.backend.exception.BusinessException; +import com.teaching.backend.model.dto.thumb.resourcethumb.ResourceThumbAddRequest; +import com.teaching.backend.service.thumb.SeResourceThumbService; +import lombok.extern.slf4j.Slf4j; +import org.apache.commons.lang3.StringUtils; +import org.springframework.web.bind.annotation.PostMapping; +import org.springframework.web.bind.annotation.RequestBody; +import org.springframework.web.bind.annotation.RequestMapping; +import org.springframework.web.bind.annotation.RestController; + +import javax.annotation.Resource; + +/** + * @Author:youhang + * @Date:2024-05-30-20:22 + * @Description: + */ +@RestController +@RequestMapping("/resource_thumb") +@Slf4j +public class SeResourceThumbController { + + @Resource + private SeResourceThumbService seResourceThumbService; + + + /** + * 点赞 + * + * @param resourceThumbAddRequest + * @return result 执行情况 + */ + @PostMapping("/add") + // todo 后期加上 HttpServletRequest request 在一个fitter里面进行鉴权操作 + public BaseResponse doThumb(@RequestBody ResourceThumbAddRequest resourceThumbAddRequest) { + if (StringUtils.isAnyBlank(resourceThumbAddRequest.getCourseId(), resourceThumbAddRequest.getResourceId(), resourceThumbAddRequest.getUserId())) { + throw new BusinessException(ErrorCode.PARAMS_ERROR); + } + // todo 从数据库中校验是否存在resourceid , userid ,courseid + Boolean result = seResourceThumbService.doResourceThumb(resourceThumbAddRequest.getCourseId(), resourceThumbAddRequest.getResourceId(), resourceThumbAddRequest.getUserId()); + return ResultUtils.success(result); + } + +} diff --git a/src/main/java/com/teaching/backend/exception/BusinessException.java b/src/main/java/com/teaching/backend/exception/BusinessException.java new file mode 100644 index 0000000..152ac4b --- /dev/null +++ b/src/main/java/com/teaching/backend/exception/BusinessException.java @@ -0,0 +1,37 @@ +package com.teaching.backend.exception; + + +import com.teaching.backend.common.ErrorCode; + +/** + * 自定义异常类 + * + * @author 程序员鱼皮 + * @from 编程导航知识星球 + */ +public class BusinessException extends RuntimeException { + + /** + * 错误码 + */ + private final int code; + + public BusinessException(int code, String message) { + super(message); + this.code = code; + } + + public BusinessException(ErrorCode errorCode) { + super(errorCode.getMessage()); + this.code = errorCode.getCode(); + } + + public BusinessException(ErrorCode errorCode, String message) { + super(message); + this.code = errorCode.getCode(); + } + + public int getCode() { + return code; + } +} diff --git a/src/main/java/com/teaching/backend/exception/test1.java b/src/main/java/com/teaching/backend/exception/test1.java deleted file mode 100644 index bb8ef3c..0000000 --- a/src/main/java/com/teaching/backend/exception/test1.java +++ /dev/null @@ -1,9 +0,0 @@ -package com.teaching.backend.exception; - -/** - * @Author:youhang - * @Date:2024-05-30-18:20 - * @Description: - */ -public class test1 { -} diff --git a/src/main/java/com/teaching/backend/mapper/favour/SeCourseFavourMapper.java b/src/main/java/com/teaching/backend/mapper/favour/SeCourseFavourMapper.java new file mode 100644 index 0000000..47ed89a --- /dev/null +++ b/src/main/java/com/teaching/backend/mapper/favour/SeCourseFavourMapper.java @@ -0,0 +1,15 @@ +package com.teaching.backend.mapper.favour; + +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.teaching.backend.model.entity.favour.SeCourseFavour; + +/** + * 课程点赞数据库操作 + */ +public interface SeCourseFavourMapper extends BaseMapper { + +} + + + + diff --git a/src/main/java/com/teaching/backend/mapper/favour/SeKnowFavourMapper.java b/src/main/java/com/teaching/backend/mapper/favour/SeKnowFavourMapper.java new file mode 100644 index 0000000..53d3a80 --- /dev/null +++ b/src/main/java/com/teaching/backend/mapper/favour/SeKnowFavourMapper.java @@ -0,0 +1,16 @@ +package com.teaching.backend.mapper.favour; + + +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.teaching.backend.model.entity.favour.SeKnowFavour; + +/** + * 知识点赞数据库操作 + */ +public interface SeKnowFavourMapper extends BaseMapper { + +} + + + + diff --git a/src/main/java/com/teaching/backend/mapper/favour/SeResourceFavourMapper.java b/src/main/java/com/teaching/backend/mapper/favour/SeResourceFavourMapper.java new file mode 100644 index 0000000..eeb63f1 --- /dev/null +++ b/src/main/java/com/teaching/backend/mapper/favour/SeResourceFavourMapper.java @@ -0,0 +1,17 @@ +package com.teaching.backend.mapper.favour; + + +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.teaching.backend.model.entity.favour.SeResourceFavour; + + +/** + * 课程资源点赞数据库操作 + */ +public interface SeResourceFavourMapper extends BaseMapper { + +} + + + + diff --git a/src/main/java/com/teaching/backend/mapper/test1.java b/src/main/java/com/teaching/backend/mapper/test1.java deleted file mode 100644 index 61714bc..0000000 --- a/src/main/java/com/teaching/backend/mapper/test1.java +++ /dev/null @@ -1,9 +0,0 @@ -package com.teaching.backend.mapper; - -/** - * @Author:youhang - * @Date:2024-05-30-18:20 - * @Description: - */ -public class test1 { -} diff --git a/src/main/java/com/teaching/backend/mapper/thumb/SeCourseThumbMapper.java b/src/main/java/com/teaching/backend/mapper/thumb/SeCourseThumbMapper.java new file mode 100644 index 0000000..6236a4a --- /dev/null +++ b/src/main/java/com/teaching/backend/mapper/thumb/SeCourseThumbMapper.java @@ -0,0 +1,15 @@ +package com.teaching.backend.mapper.thumb; + +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.teaching.backend.model.entity.thumb.SeCourseThumb; + +/** + * 课程点赞数据库操作 + */ +public interface SeCourseThumbMapper extends BaseMapper { + +} + + + + diff --git a/src/main/java/com/teaching/backend/mapper/thumb/SeKnowThumbMapper.java b/src/main/java/com/teaching/backend/mapper/thumb/SeKnowThumbMapper.java new file mode 100644 index 0000000..1aaf9b4 --- /dev/null +++ b/src/main/java/com/teaching/backend/mapper/thumb/SeKnowThumbMapper.java @@ -0,0 +1,16 @@ +package com.teaching.backend.mapper.thumb; + + +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.teaching.backend.model.entity.thumb.SeKnowThumb; + +/** + * 知识点赞数据库操作 + */ +public interface SeKnowThumbMapper extends BaseMapper { + +} + + + + diff --git a/src/main/java/com/teaching/backend/mapper/thumb/SeResourceThumbMapper.java b/src/main/java/com/teaching/backend/mapper/thumb/SeResourceThumbMapper.java new file mode 100644 index 0000000..dbb4136 --- /dev/null +++ b/src/main/java/com/teaching/backend/mapper/thumb/SeResourceThumbMapper.java @@ -0,0 +1,17 @@ +package com.teaching.backend.mapper.thumb; + + +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.teaching.backend.model.entity.thumb.SeResourceThumb; + + +/** + * 课程资源点赞数据库操作 + */ +public interface SeResourceThumbMapper extends BaseMapper { + +} + + + + diff --git a/src/main/java/com/teaching/backend/model/dto/favour/courseFavour/CourseFavourAddRequest.java b/src/main/java/com/teaching/backend/model/dto/favour/courseFavour/CourseFavourAddRequest.java new file mode 100644 index 0000000..7d377d8 --- /dev/null +++ b/src/main/java/com/teaching/backend/model/dto/favour/courseFavour/CourseFavourAddRequest.java @@ -0,0 +1,24 @@ +package com.teaching.backend.model.dto.favour.courseFavour; + +import lombok.Data; + +import java.io.Serializable; + +/** + * 课程点赞请求 + */ +@Data +public class CourseFavourAddRequest implements Serializable { + + /** + * 帖子 id + */ + private String courseId; + + /** + * user id + */ + private String userId; + + private static final long serialVersionUID = 1L; +} diff --git a/src/main/java/com/teaching/backend/model/dto/favour/courseFavour/CourseFavourAllRequest.java b/src/main/java/com/teaching/backend/model/dto/favour/courseFavour/CourseFavourAllRequest.java new file mode 100644 index 0000000..2f54718 --- /dev/null +++ b/src/main/java/com/teaching/backend/model/dto/favour/courseFavour/CourseFavourAllRequest.java @@ -0,0 +1,20 @@ +package com.teaching.backend.model.dto.favour.courseFavour; + +import lombok.Data; + +import java.io.Serializable; + +/** + * 课程点赞请求 + */ +@Data +public class CourseFavourAllRequest implements Serializable { + + /** + * 课程 id + */ + private String courseId; + + + private static final long serialVersionUID = 1L; +} diff --git a/src/main/java/com/teaching/backend/model/dto/favour/courseFavour/CourseFavourListRequest.java b/src/main/java/com/teaching/backend/model/dto/favour/courseFavour/CourseFavourListRequest.java new file mode 100644 index 0000000..92426b1 --- /dev/null +++ b/src/main/java/com/teaching/backend/model/dto/favour/courseFavour/CourseFavourListRequest.java @@ -0,0 +1,20 @@ +package com.teaching.backend.model.dto.favour.courseFavour; + +import lombok.Data; + +import java.io.Serializable; + +/** + * 课程点赞请求 + */ +@Data +public class CourseFavourListRequest implements Serializable { + + /** + * 用户 id + */ + private String userId; + + + private static final long serialVersionUID = 1L; +} diff --git a/src/main/java/com/teaching/backend/model/dto/favour/knowFavour/KnowFavourAddRequest.java b/src/main/java/com/teaching/backend/model/dto/favour/knowFavour/KnowFavourAddRequest.java new file mode 100644 index 0000000..c3ee0d6 --- /dev/null +++ b/src/main/java/com/teaching/backend/model/dto/favour/knowFavour/KnowFavourAddRequest.java @@ -0,0 +1,29 @@ +package com.teaching.backend.model.dto.favour.knowFavour; + +import lombok.Data; + +import java.io.Serializable; + +/** + * 知识点点赞请求 + */ +@Data +public class KnowFavourAddRequest implements Serializable { + + /** + * 课程 id + */ + private String courseId; + + /** + * 知识点 id + */ + private String knowId; + + /** + * user id + */ + private String userId; + + private static final long serialVersionUID = 1L; +} diff --git a/src/main/java/com/teaching/backend/model/dto/favour/resourceFavour/ResourceFavourAddRequest.java b/src/main/java/com/teaching/backend/model/dto/favour/resourceFavour/ResourceFavourAddRequest.java new file mode 100644 index 0000000..64c3277 --- /dev/null +++ b/src/main/java/com/teaching/backend/model/dto/favour/resourceFavour/ResourceFavourAddRequest.java @@ -0,0 +1,29 @@ +package com.teaching.backend.model.dto.favour.resourceFavour; + +import lombok.Data; + +import java.io.Serializable; + +/** + * 资源点赞请求 + */ +@Data +public class ResourceFavourAddRequest implements Serializable { + + /** + * 课程 id + */ + private String courseId; + + /** + * 知识点 id + */ + private String resourceId; + + /** + * user id + */ + private String userId; + + private static final long serialVersionUID = 1L; +} diff --git a/src/main/java/com/teaching/backend/model/dto/test1.java b/src/main/java/com/teaching/backend/model/dto/test1.java deleted file mode 100644 index 4a85daf..0000000 --- a/src/main/java/com/teaching/backend/model/dto/test1.java +++ /dev/null @@ -1,9 +0,0 @@ -package com.teaching.backend.model.dto; - -/** - * @Author:youhang - * @Date:2024-05-30-18:20 - * @Description: - */ -public class test1 { -} diff --git a/src/main/java/com/teaching/backend/model/dto/thumb/coursethumb/CourseThumbAddRequest.java b/src/main/java/com/teaching/backend/model/dto/thumb/coursethumb/CourseThumbAddRequest.java new file mode 100644 index 0000000..021c0fd --- /dev/null +++ b/src/main/java/com/teaching/backend/model/dto/thumb/coursethumb/CourseThumbAddRequest.java @@ -0,0 +1,24 @@ +package com.teaching.backend.model.dto.thumb.coursethumb; + +import lombok.Data; + +import java.io.Serializable; + +/** + * 课程点赞请求 + */ +@Data +public class CourseThumbAddRequest implements Serializable { + + /** + * 帖子 id + */ + private String courseId; + + /** + * user id + */ + private String userId; + + private static final long serialVersionUID = 1L; +} diff --git a/src/main/java/com/teaching/backend/model/dto/thumb/coursethumb/CourseThumbAllRequest.java b/src/main/java/com/teaching/backend/model/dto/thumb/coursethumb/CourseThumbAllRequest.java new file mode 100644 index 0000000..4d13ec0 --- /dev/null +++ b/src/main/java/com/teaching/backend/model/dto/thumb/coursethumb/CourseThumbAllRequest.java @@ -0,0 +1,20 @@ +package com.teaching.backend.model.dto.thumb.coursethumb; + +import lombok.Data; + +import java.io.Serializable; + +/** + * 课程点赞请求 + */ +@Data +public class CourseThumbAllRequest implements Serializable { + + /** + * 课程 id + */ + private String courseId; + + + private static final long serialVersionUID = 1L; +} diff --git a/src/main/java/com/teaching/backend/model/dto/thumb/knowthumb/KnowThumbAddRequest.java b/src/main/java/com/teaching/backend/model/dto/thumb/knowthumb/KnowThumbAddRequest.java new file mode 100644 index 0000000..d794050 --- /dev/null +++ b/src/main/java/com/teaching/backend/model/dto/thumb/knowthumb/KnowThumbAddRequest.java @@ -0,0 +1,29 @@ +package com.teaching.backend.model.dto.thumb.knowthumb; + +import lombok.Data; + +import java.io.Serializable; + +/** + * 知识点点赞请求 + */ +@Data +public class KnowThumbAddRequest implements Serializable { + + /** + * 课程 id + */ + private String courseId; + + /** + * 知识点 id + */ + private String knowId; + + /** + * user id + */ + private String userId; + + private static final long serialVersionUID = 1L; +} diff --git a/src/main/java/com/teaching/backend/model/dto/thumb/resourcethumb/ResourceThumbAddRequest.java b/src/main/java/com/teaching/backend/model/dto/thumb/resourcethumb/ResourceThumbAddRequest.java new file mode 100644 index 0000000..a3697aa --- /dev/null +++ b/src/main/java/com/teaching/backend/model/dto/thumb/resourcethumb/ResourceThumbAddRequest.java @@ -0,0 +1,29 @@ +package com.teaching.backend.model.dto.thumb.resourcethumb; + +import lombok.Data; + +import java.io.Serializable; + +/** + * 资源点赞请求 + */ +@Data +public class ResourceThumbAddRequest implements Serializable { + + /** + * 课程 id + */ + private String courseId; + + /** + * 知识点 id + */ + private String resourceId; + + /** + * user id + */ + private String userId; + + private static final long serialVersionUID = 1L; +} diff --git a/src/main/java/com/teaching/backend/model/entity/favour/SeCourseFavour.java b/src/main/java/com/teaching/backend/model/entity/favour/SeCourseFavour.java new file mode 100644 index 0000000..017291d --- /dev/null +++ b/src/main/java/com/teaching/backend/model/entity/favour/SeCourseFavour.java @@ -0,0 +1,35 @@ +package com.teaching.backend.model.entity.favour; + +import com.baomidou.mybatisplus.annotation.IdType; +import com.baomidou.mybatisplus.annotation.TableField; +import com.baomidou.mybatisplus.annotation.TableId; +import com.baomidou.mybatisplus.annotation.TableName; +import lombok.Data; + +import java.io.Serializable; + +/** + * 课程点赞 + */ +@TableName(value = "se_course_favour") +@Data +public class SeCourseFavour implements Serializable { + /** + * id + */ + @TableId(type = IdType.ASSIGN_ID) + private Long id; + + /** + * 课程 id + */ + private String courseId; + + /** + * 创建用户 id + */ + private String userId; + + @TableField(exist = false) + private static final long serialVersionUID = 1L; +} diff --git a/src/main/java/com/teaching/backend/model/entity/favour/SeKnowFavour.java b/src/main/java/com/teaching/backend/model/entity/favour/SeKnowFavour.java new file mode 100644 index 0000000..8e6d462 --- /dev/null +++ b/src/main/java/com/teaching/backend/model/entity/favour/SeKnowFavour.java @@ -0,0 +1,40 @@ +package com.teaching.backend.model.entity.favour; + +import com.baomidou.mybatisplus.annotation.IdType; +import com.baomidou.mybatisplus.annotation.TableField; +import com.baomidou.mybatisplus.annotation.TableId; +import com.baomidou.mybatisplus.annotation.TableName; +import lombok.Data; + +import java.io.Serializable; + +/** + * 知识点点赞 + */ +@TableName(value = "se_know_favour") +@Data +public class SeKnowFavour implements Serializable { + /** + * id + */ + @TableId(type = IdType.ASSIGN_ID) + private Long id; + + /** + * 课程 id + */ + private String courseId; + + /** + * 创建知识点 id + */ + private String knowId; + + /** + * 创建用户 id + */ + private String userId; + + @TableField(exist = false) + private static final long serialVersionUID = 1L; +} diff --git a/src/main/java/com/teaching/backend/model/entity/favour/SeResourceFavour.java b/src/main/java/com/teaching/backend/model/entity/favour/SeResourceFavour.java new file mode 100644 index 0000000..c58f88e --- /dev/null +++ b/src/main/java/com/teaching/backend/model/entity/favour/SeResourceFavour.java @@ -0,0 +1,40 @@ +package com.teaching.backend.model.entity.favour; + +import com.baomidou.mybatisplus.annotation.IdType; +import com.baomidou.mybatisplus.annotation.TableField; +import com.baomidou.mybatisplus.annotation.TableId; +import com.baomidou.mybatisplus.annotation.TableName; +import lombok.Data; + +import java.io.Serializable; + +/** + * 资源点赞 + */ +@TableName(value = "se_resource_favour") +@Data +public class SeResourceFavour implements Serializable { + /** + * id + */ + @TableId(type = IdType.ASSIGN_ID) + private Long id; + + /** + * 课程 id + */ + private String courseId; + + /** + * 创建知识点 id + */ + private String resourceId; + + /** + * 创建用户 id + */ + private String userId; + + @TableField(exist = false) + private static final long serialVersionUID = 1L; +} diff --git a/src/main/java/com/teaching/backend/model/entity/test1.java b/src/main/java/com/teaching/backend/model/entity/test1.java deleted file mode 100644 index fa16819..0000000 --- a/src/main/java/com/teaching/backend/model/entity/test1.java +++ /dev/null @@ -1,9 +0,0 @@ -package com.teaching.backend.model.entity; - -/** - * @Author:youhang - * @Date:2024-05-30-18:20 - * @Description: - */ -public class test1 { -} diff --git a/src/main/java/com/teaching/backend/model/entity/thumb/SeCourseThumb.java b/src/main/java/com/teaching/backend/model/entity/thumb/SeCourseThumb.java new file mode 100644 index 0000000..d71e68f --- /dev/null +++ b/src/main/java/com/teaching/backend/model/entity/thumb/SeCourseThumb.java @@ -0,0 +1,36 @@ +package com.teaching.backend.model.entity.thumb; + +import com.baomidou.mybatisplus.annotation.IdType; +import com.baomidou.mybatisplus.annotation.TableField; +import com.baomidou.mybatisplus.annotation.TableId; +import com.baomidou.mybatisplus.annotation.TableName; +import lombok.Data; + +import java.io.Serializable; +import java.util.Date; + +/** + * 课程点赞 + */ +@TableName(value = "se_course_thumb") +@Data +public class SeCourseThumb implements Serializable { + /** + * id + */ + @TableId(type = IdType.ASSIGN_ID) + private Long id; + + /** + * 课程 id + */ + private String courseId; + + /** + * 创建用户 id + */ + private String userId; + + @TableField(exist = false) + private static final long serialVersionUID = 1L; +} diff --git a/src/main/java/com/teaching/backend/model/entity/thumb/SeKnowThumb.java b/src/main/java/com/teaching/backend/model/entity/thumb/SeKnowThumb.java new file mode 100644 index 0000000..513c34c --- /dev/null +++ b/src/main/java/com/teaching/backend/model/entity/thumb/SeKnowThumb.java @@ -0,0 +1,40 @@ +package com.teaching.backend.model.entity.thumb; + +import com.baomidou.mybatisplus.annotation.IdType; +import com.baomidou.mybatisplus.annotation.TableField; +import com.baomidou.mybatisplus.annotation.TableId; +import com.baomidou.mybatisplus.annotation.TableName; +import lombok.Data; + +import java.io.Serializable; + +/** + * 知识点点赞 + */ +@TableName(value = "se_know_thumb") +@Data +public class SeKnowThumb implements Serializable { + /** + * id + */ + @TableId(type = IdType.ASSIGN_ID) + private Long id; + + /** + * 课程 id + */ + private String courseId; + + /** + * 创建知识点 id + */ + private String knowId; + + /** + * 创建用户 id + */ + private String userId; + + @TableField(exist = false) + private static final long serialVersionUID = 1L; +} diff --git a/src/main/java/com/teaching/backend/model/entity/thumb/SeResourceThumb.java b/src/main/java/com/teaching/backend/model/entity/thumb/SeResourceThumb.java new file mode 100644 index 0000000..749a5ee --- /dev/null +++ b/src/main/java/com/teaching/backend/model/entity/thumb/SeResourceThumb.java @@ -0,0 +1,40 @@ +package com.teaching.backend.model.entity.thumb; + +import com.baomidou.mybatisplus.annotation.IdType; +import com.baomidou.mybatisplus.annotation.TableField; +import com.baomidou.mybatisplus.annotation.TableId; +import com.baomidou.mybatisplus.annotation.TableName; +import lombok.Data; + +import java.io.Serializable; + +/** + * 资源点赞 + */ +@TableName(value = "se_resource_thumb") +@Data +public class SeResourceThumb implements Serializable { + /** + * id + */ + @TableId(type = IdType.ASSIGN_ID) + private Long id; + + /** + * 课程 id + */ + private String courseId; + + /** + * 创建知识点 id + */ + private String resourceId; + + /** + * 创建用户 id + */ + private String userId; + + @TableField(exist = false) + private static final long serialVersionUID = 1L; +} diff --git a/src/main/java/com/teaching/backend/model/test1.java b/src/main/java/com/teaching/backend/model/test1.java deleted file mode 100644 index 716b9fe..0000000 --- a/src/main/java/com/teaching/backend/model/test1.java +++ /dev/null @@ -1,9 +0,0 @@ -package com.teaching.backend.model; - -/** - * @Author:youhang - * @Date:2024-05-30-18:20 - * @Description: - */ -public class test1 { -} diff --git a/src/main/java/com/teaching/backend/service/favour/SeCourseFavourService.java b/src/main/java/com/teaching/backend/service/favour/SeCourseFavourService.java new file mode 100644 index 0000000..1fae7ce --- /dev/null +++ b/src/main/java/com/teaching/backend/service/favour/SeCourseFavourService.java @@ -0,0 +1,51 @@ +package com.teaching.backend.service.favour; + +import com.baomidou.mybatisplus.extension.service.IService; +import com.teaching.backend.model.entity.favour.SeCourseFavour; + +import java.util.List; + +/** + * @Author:youhang + * @Date:2024-05-30-20:22 + * @Description: + */ +public interface SeCourseFavourService extends IService { + + /** + * 收藏/取消收藏 + * + * @param courseId + * @param userId + * @return + */ + boolean doCourseFavour(String courseId, String userId); + + + /** + * 收藏总数 + * + * @param courseId + * @return + */ + long favourCount(String courseId); + + + /** + * 课程下资源和知识点的收藏总数 + * + * @param courseId + * @return + */ + long courseCount(String courseId); + + + /** + * 某个用户课程列表 + * + * @param userId + * @return + */ + List courseList(String userId); + +} diff --git a/src/main/java/com/teaching/backend/service/favour/SeKnowFavourService.java b/src/main/java/com/teaching/backend/service/favour/SeKnowFavourService.java new file mode 100644 index 0000000..22d7d6e --- /dev/null +++ b/src/main/java/com/teaching/backend/service/favour/SeKnowFavourService.java @@ -0,0 +1,22 @@ +package com.teaching.backend.service.favour; + +import com.baomidou.mybatisplus.extension.service.IService; +import com.teaching.backend.model.entity.favour.SeKnowFavour; + +/** + * @Author:youhang + * @Date:2024-05-30-20:22 + * @Description: + */ +public interface SeKnowFavourService extends IService { + + /** + * 收藏 + * + * @param courseId + * @param userId + * @return + */ + boolean doKnowFavour(String courseId, String resourceId, String userId); + +} diff --git a/src/main/java/com/teaching/backend/service/favour/SeResourceFavourService.java b/src/main/java/com/teaching/backend/service/favour/SeResourceFavourService.java new file mode 100644 index 0000000..2eab5a8 --- /dev/null +++ b/src/main/java/com/teaching/backend/service/favour/SeResourceFavourService.java @@ -0,0 +1,22 @@ +package com.teaching.backend.service.favour; + +import com.baomidou.mybatisplus.extension.service.IService; +import com.teaching.backend.model.entity.favour.SeResourceFavour; + +/** + * @Author:youhang + * @Date:2024-05-30-20:22 + * @Description: + */ +public interface SeResourceFavourService extends IService { + + /** + * 收藏 + * + * @param courseId + * @param userId + * @return + */ + boolean doResourceFavour(String courseId, String resourceId, String userId); + +} diff --git a/src/main/java/com/teaching/backend/service/impl/favour/SeCourseFavourServiceImpl.java b/src/main/java/com/teaching/backend/service/impl/favour/SeCourseFavourServiceImpl.java new file mode 100644 index 0000000..4d9db6e --- /dev/null +++ b/src/main/java/com/teaching/backend/service/impl/favour/SeCourseFavourServiceImpl.java @@ -0,0 +1,123 @@ +package com.teaching.backend.service.impl.favour; + +import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.teaching.backend.common.ErrorCode; +import com.teaching.backend.exception.BusinessException; +import com.teaching.backend.mapper.favour.SeCourseFavourMapper; +import com.teaching.backend.model.entity.favour.SeCourseFavour; +import com.teaching.backend.model.entity.favour.SeKnowFavour; +import com.teaching.backend.model.entity.favour.SeResourceFavour; + +import com.teaching.backend.service.favour.SeCourseFavourService; +import com.teaching.backend.service.favour.SeKnowFavourService; +import com.teaching.backend.service.favour.SeResourceFavourService; + +import org.springframework.stereotype.Service; + +import javax.annotation.Resource; +import java.util.List; +import java.util.concurrent.locks.Lock; +import java.util.concurrent.locks.ReentrantLock; +import java.util.stream.Collectors; + + +/** + * @Author:youhang + * @Date:2024-05-30-20:23 + * @Description: + */ +@Service +public class SeCourseFavourServiceImpl extends ServiceImpl implements SeCourseFavourService { + + + @Resource + private SeResourceFavourService seResourceFavourService; + + @Resource + SeKnowFavourService seKnowFavourService; + + + @Override + public boolean doCourseFavour(String courseId, String userId) { + System.out.println("进入点赞" + courseId + userId); + // todo 先查询数据库记录,该用户是否点赞 + SeCourseFavour seCourseFavour = new SeCourseFavour(); + seCourseFavour.setCourseId(courseId); + seCourseFavour.setUserId(userId); + QueryWrapper favourQueryWrapper = new QueryWrapper<>(seCourseFavour); + SeCourseFavour oldSeCourseFavour = this.getOne(favourQueryWrapper); + boolean result = false; + //已点赞 + if (oldSeCourseFavour != null) { + // 取消点赞 删除记录 + result = this.remove(favourQueryWrapper); + if (result) { + System.out.println("取消点赞成功"); + return result; + } else { + throw new BusinessException(ErrorCode.SYSTEM_ERROR); + } + } else { + // 每个用户串行点赞 + // 锁必须要包裹住事务方法 + Lock lock = new ReentrantLock(); + lock.lock(); + try { + result = this.save(seCourseFavour); + } catch (Exception e) { + throw new BusinessException(ErrorCode.OPERATION_ERROR); + } finally { + lock.unlock(); + System.out.println("点赞成功"); + return result; + } + } + } + + @Override + public long favourCount(String courseId) { + System.out.println("进入课程点赞统计" + courseId); + QueryWrapper favourQueryWrapper = new QueryWrapper<>(); + favourQueryWrapper.eq("course_id", courseId); + long result = this.count(favourQueryWrapper); + if (result == 0) { + throw new BusinessException(ErrorCode.SYSTEM_ERROR, "查询参数不存在"); + } else { + return result; + } + } + + @Override + public long courseCount(String courseId) { + System.out.println("进入课程下资源和知识点的点赞统计" + courseId); + QueryWrapper ResourceQueryWrapper = new QueryWrapper<>(); + ResourceQueryWrapper.eq("course_id", courseId); + long result1 = seResourceFavourService.count(ResourceQueryWrapper); + QueryWrapper KnowQueryWrapper = new QueryWrapper<>(); + KnowQueryWrapper.eq("course_id", courseId); + long result2 = seKnowFavourService.count(KnowQueryWrapper); + long result = result1 + result2; + if (result == 0) { + throw new BusinessException(ErrorCode.SYSTEM_ERROR, "查询参数不存在"); + } else { + return result; + } + } + + /** + * 某个用户课程列表 + * + * @param userId + * @return + */ + @Override + public List courseList(String userId) { + QueryWrapper courseQueryWrapper = new QueryWrapper<>(); + courseQueryWrapper.eq("user_id", userId); + List list = this.list(courseQueryWrapper).stream().map(SeCourseFavour::getCourseId).collect(Collectors.toList()); + return list; + } + + +} diff --git a/src/main/java/com/teaching/backend/service/impl/favour/SeKnowFavourServiceImpl.java b/src/main/java/com/teaching/backend/service/impl/favour/SeKnowFavourServiceImpl.java new file mode 100644 index 0000000..6ccb14a --- /dev/null +++ b/src/main/java/com/teaching/backend/service/impl/favour/SeKnowFavourServiceImpl.java @@ -0,0 +1,64 @@ +package com.teaching.backend.service.impl.favour; + +import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.teaching.backend.common.ErrorCode; +import com.teaching.backend.exception.BusinessException; +import com.teaching.backend.mapper.favour.SeKnowFavourMapper; +import com.teaching.backend.model.entity.favour.SeKnowFavour; + +import com.teaching.backend.service.favour.SeKnowFavourService; +import org.springframework.stereotype.Service; + +import java.util.concurrent.locks.Lock; +import java.util.concurrent.locks.ReentrantLock; + + +/** + * @Author:youhang + * @Date:2024-05-30-20:23 + * @Description: + */ +@Service +public class SeKnowFavourServiceImpl extends ServiceImpl implements SeKnowFavourService { + + @Override + public boolean doKnowFavour(String courseId, String knowId, String userId) { + System.out.println("进入知识点点赞" + knowId + userId); + // 先查询数据库记录,该用户是否点赞 + SeKnowFavour seKnowFavour = new SeKnowFavour(); + seKnowFavour.setKnowId(knowId); + seKnowFavour.setUserId(userId); + seKnowFavour.setCourseId(courseId); + QueryWrapper favourQueryWrapper = new QueryWrapper<>(seKnowFavour); + SeKnowFavour oldSeKnowFavour = this.getOne(favourQueryWrapper); + boolean result = false; + //已点赞 + if (oldSeKnowFavour != null) { + // 取消点赞 删除记录 + result = this.remove(favourQueryWrapper); + if (result) { + System.out.println("取消点赞成功"); + return result; + } else { + throw new BusinessException(ErrorCode.SYSTEM_ERROR); + } + } else { + // 每个用户串行点赞 + // 锁必须要包裹住事务方法 + Lock lock = new ReentrantLock(); + lock.lock(); + try { + result = this.save(seKnowFavour); + } catch (Exception e) { + throw new BusinessException(ErrorCode.OPERATION_ERROR); + } finally { + lock.unlock(); + System.out.println("点赞成功"); + return result; + } + } + } + + +} diff --git a/src/main/java/com/teaching/backend/service/impl/favour/SeResourceFavourServiceImpl.java b/src/main/java/com/teaching/backend/service/impl/favour/SeResourceFavourServiceImpl.java new file mode 100644 index 0000000..968d993 --- /dev/null +++ b/src/main/java/com/teaching/backend/service/impl/favour/SeResourceFavourServiceImpl.java @@ -0,0 +1,65 @@ +package com.teaching.backend.service.impl.favour; + +import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.teaching.backend.common.ErrorCode; +import com.teaching.backend.exception.BusinessException; + + +import com.teaching.backend.mapper.favour.SeResourceFavourMapper; +import com.teaching.backend.model.entity.favour.SeResourceFavour; +import com.teaching.backend.service.favour.SeResourceFavourService; +import org.springframework.stereotype.Service; + +import java.util.concurrent.locks.Lock; +import java.util.concurrent.locks.ReentrantLock; + + +/** + * @Author:youhang + * @Date:2024-05-30-20:23 + * @Description: + */ +@Service +public class SeResourceFavourServiceImpl extends ServiceImpl implements SeResourceFavourService { + + @Override + public boolean doResourceFavour(String courseId, String resourceId, String userId) { + System.out.println("进入知识点点赞" + resourceId + userId); + // 先查询数据库记录,该用户是否点赞 + SeResourceFavour seResourceFavour = new SeResourceFavour(); + seResourceFavour.setResourceId(resourceId); + seResourceFavour.setUserId(userId); + seResourceFavour.setCourseId(courseId); + QueryWrapper thumbQueryWrapper = new QueryWrapper<>(seResourceFavour); + SeResourceFavour oldSeResourceFavour = this.getOne(thumbQueryWrapper); + boolean result = false; + //已点赞 + if (oldSeResourceFavour != null) { + // 取消点赞 删除记录 + result = this.remove(thumbQueryWrapper); + if (result) { + System.out.println("取消点赞成功"); + return result; + } else { + throw new BusinessException(ErrorCode.SYSTEM_ERROR); + } + } else { + // 每个用户串行点赞 + // 锁必须要包裹住事务方法 + Lock lock = new ReentrantLock(); + lock.lock(); + try { + result = this.save(seResourceFavour); + } catch (Exception e) { + throw new BusinessException(ErrorCode.OPERATION_ERROR); + } finally { + lock.unlock(); + System.out.println("点赞成功"); + return result; + } + } + } + + +} diff --git a/src/main/java/com/teaching/backend/service/impl/thumb/SeCourseThumbServiceImpl.java b/src/main/java/com/teaching/backend/service/impl/thumb/SeCourseThumbServiceImpl.java new file mode 100644 index 0000000..3940f7d --- /dev/null +++ b/src/main/java/com/teaching/backend/service/impl/thumb/SeCourseThumbServiceImpl.java @@ -0,0 +1,105 @@ +package com.teaching.backend.service.impl.thumb; + +import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.teaching.backend.common.ErrorCode; +import com.teaching.backend.exception.BusinessException; +import com.teaching.backend.mapper.thumb.SeCourseThumbMapper; +import com.teaching.backend.model.entity.thumb.SeCourseThumb; +import com.teaching.backend.model.entity.thumb.SeKnowThumb; +import com.teaching.backend.model.entity.thumb.SeResourceThumb; +import com.teaching.backend.service.thumb.SeCourseThumbService; +import com.teaching.backend.service.thumb.SeKnowThumbService; +import com.teaching.backend.service.thumb.SeResourceThumbService; +import org.springframework.stereotype.Service; + +import javax.annotation.Resource; +import java.util.concurrent.locks.Lock; +import java.util.concurrent.locks.ReentrantLock; + + +/** + * @Author:youhang + * @Date:2024-05-30-20:23 + * @Description: + */ +@Service +public class SeCourseThumbServiceImpl extends ServiceImpl implements SeCourseThumbService { + + + @Resource + private SeResourceThumbService seResourceThumbService; + + @Resource + SeKnowThumbService seKnowThumbService; + + + @Override + public boolean doCourseThumb(String courseId, String userId) { + System.out.println("进入点赞" + courseId + userId); + // 先查询数据库记录,该用户是否点赞 + SeCourseThumb seCourseThumb = new SeCourseThumb(); + seCourseThumb.setCourseId(courseId); + seCourseThumb.setUserId(userId); + QueryWrapper thumbQueryWrapper = new QueryWrapper<>(seCourseThumb); + SeCourseThumb oldSeCourseThumb = this.getOne(thumbQueryWrapper); + boolean result = false; + //已点赞 + if (oldSeCourseThumb != null) { + // 取消点赞 删除记录 + result = this.remove(thumbQueryWrapper); + if (result) { + System.out.println("取消点赞成功"); + return result; + } else { + throw new BusinessException(ErrorCode.SYSTEM_ERROR); + } + } else { + // 每个用户串行点赞 + // 锁必须要包裹住事务方法 + Lock lock = new ReentrantLock(); + lock.lock(); + try { + result = this.save(seCourseThumb); + } catch (Exception e) { + throw new BusinessException(ErrorCode.OPERATION_ERROR); + } finally { + lock.unlock(); + System.out.println("点赞成功"); + return result; + } + } + } + + @Override + public long thumbCount(String courseId) { + System.out.println("进入课程点赞统计" + courseId); + QueryWrapper thumbQueryWrapper = new QueryWrapper<>(); + thumbQueryWrapper.eq("course_id", courseId); + long result = this.count(thumbQueryWrapper); + if (result == 0) { + throw new BusinessException(ErrorCode.SYSTEM_ERROR, "查询参数不存在"); + } else { + return result; + } + } + + @Override + public long courseCount(String courseId) { + System.out.println("进入课程下资源和知识点的点赞统计" + courseId); + QueryWrapper ResourceQueryWrapper = new QueryWrapper<>(); + ResourceQueryWrapper.eq("course_id", courseId); + long result1 = seResourceThumbService.count(ResourceQueryWrapper); + QueryWrapper KnowQueryWrapper = new QueryWrapper<>(); + KnowQueryWrapper.eq("course_id", courseId); + long result2 = seKnowThumbService.count(KnowQueryWrapper); + long result = result1 + result2; + if (result == 0) { + throw new BusinessException(ErrorCode.SYSTEM_ERROR, "查询参数不存在"); + } else { + return result; + } + } + + +} diff --git a/src/main/java/com/teaching/backend/service/impl/thumb/SeKnowThumbServiceImpl.java b/src/main/java/com/teaching/backend/service/impl/thumb/SeKnowThumbServiceImpl.java new file mode 100644 index 0000000..9b2232d --- /dev/null +++ b/src/main/java/com/teaching/backend/service/impl/thumb/SeKnowThumbServiceImpl.java @@ -0,0 +1,63 @@ +package com.teaching.backend.service.impl.thumb; + +import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.teaching.backend.common.ErrorCode; +import com.teaching.backend.exception.BusinessException; +import com.teaching.backend.mapper.thumb.SeKnowThumbMapper; +import com.teaching.backend.model.entity.thumb.SeKnowThumb; +import com.teaching.backend.service.thumb.SeKnowThumbService; +import org.springframework.stereotype.Service; + +import java.util.concurrent.locks.Lock; +import java.util.concurrent.locks.ReentrantLock; + + +/** + * @Author:youhang + * @Date:2024-05-30-20:23 + * @Description: + */ +@Service +public class SeKnowThumbServiceImpl extends ServiceImpl implements SeKnowThumbService { + + @Override + public boolean doKnowThumb(String courseId, String knowId, String userId) { + System.out.println("进入知识点点赞" + knowId + userId); + // 先查询数据库记录,该用户是否点赞 + SeKnowThumb seKnowThumb = new SeKnowThumb(); + seKnowThumb.setKnowId(knowId); + seKnowThumb.setUserId(userId); + seKnowThumb.setCourseId(courseId); + QueryWrapper thumbQueryWrapper = new QueryWrapper<>(seKnowThumb); + SeKnowThumb oldSeKnowThumb = this.getOne(thumbQueryWrapper); + boolean result = false; + //已点赞 + if (oldSeKnowThumb != null) { + // 取消点赞 删除记录 + result = this.remove(thumbQueryWrapper); + if (result) { + System.out.println("取消点赞成功"); + return result; + } else { + throw new BusinessException(ErrorCode.SYSTEM_ERROR); + } + } else { + // 每个用户串行点赞 + // 锁必须要包裹住事务方法 + Lock lock = new ReentrantLock(); + lock.lock(); + try { + result = this.save(seKnowThumb); + } catch (Exception e) { + throw new BusinessException(ErrorCode.OPERATION_ERROR); + } finally { + lock.unlock(); + System.out.println("点赞成功"); + return result; + } + } + } + + +} diff --git a/src/main/java/com/teaching/backend/service/impl/thumb/SeResourceThumbServiceImpl.java b/src/main/java/com/teaching/backend/service/impl/thumb/SeResourceThumbServiceImpl.java new file mode 100644 index 0000000..a44da42 --- /dev/null +++ b/src/main/java/com/teaching/backend/service/impl/thumb/SeResourceThumbServiceImpl.java @@ -0,0 +1,63 @@ +package com.teaching.backend.service.impl.thumb; + +import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.teaching.backend.common.ErrorCode; +import com.teaching.backend.exception.BusinessException; +import com.teaching.backend.mapper.thumb.SeResourceThumbMapper; +import com.teaching.backend.model.entity.thumb.SeResourceThumb; +import com.teaching.backend.service.thumb.SeResourceThumbService; +import org.springframework.stereotype.Service; + +import java.util.concurrent.locks.Lock; +import java.util.concurrent.locks.ReentrantLock; + + +/** + * @Author:youhang + * @Date:2024-05-30-20:23 + * @Description: + */ +@Service +public class SeResourceThumbServiceImpl extends ServiceImpl implements SeResourceThumbService { + + @Override + public boolean doResourceThumb(String courseId, String resourceId, String userId) { + System.out.println("进入知识点点赞" + resourceId + userId); + // 先查询数据库记录,该用户是否点赞 + SeResourceThumb seResourceThumb = new SeResourceThumb(); + seResourceThumb.setResourceId(resourceId); + seResourceThumb.setUserId(userId); + seResourceThumb.setCourseId(courseId); + QueryWrapper thumbQueryWrapper = new QueryWrapper<>(seResourceThumb); + SeResourceThumb oldSeResourceThumb = this.getOne(thumbQueryWrapper); + boolean result = false; + //已点赞 + if (oldSeResourceThumb != null) { + // 取消点赞 删除记录 + result = this.remove(thumbQueryWrapper); + if (result) { + System.out.println("取消点赞成功"); + return result; + } else { + throw new BusinessException(ErrorCode.SYSTEM_ERROR); + } + } else { + // 每个用户串行点赞 + // 锁必须要包裹住事务方法 + Lock lock = new ReentrantLock(); + lock.lock(); + try { + result = this.save(seResourceThumb); + } catch (Exception e) { + throw new BusinessException(ErrorCode.OPERATION_ERROR); + } finally { + lock.unlock(); + System.out.println("点赞成功"); + return result; + } + } + } + + +} diff --git a/src/main/java/com/teaching/backend/service/test1.java b/src/main/java/com/teaching/backend/service/test1.java deleted file mode 100644 index 1508af5..0000000 --- a/src/main/java/com/teaching/backend/service/test1.java +++ /dev/null @@ -1,9 +0,0 @@ -package com.teaching.backend.service; - -/** - * @Author:youhang - * @Date:2024-05-30-18:20 - * @Description: - */ -public class test1 { -} diff --git a/src/main/java/com/teaching/backend/service/thumb/SeCourseThumbService.java b/src/main/java/com/teaching/backend/service/thumb/SeCourseThumbService.java new file mode 100644 index 0000000..ea02850 --- /dev/null +++ b/src/main/java/com/teaching/backend/service/thumb/SeCourseThumbService.java @@ -0,0 +1,40 @@ +package com.teaching.backend.service.thumb; + +import com.baomidou.mybatisplus.extension.service.IService; +import com.teaching.backend.model.entity.thumb.SeCourseThumb; + +/** + * @Author:youhang + * @Date:2024-05-30-20:22 + * @Description: + */ +public interface SeCourseThumbService extends IService { + + /** + * 点赞 + * + * @param courseId + * @param userId + * @return + */ + boolean doCourseThumb(String courseId, String userId); + + + /** + * 点赞总数 + * + * @param courseId + * @return + */ + long thumbCount(String courseId); + + + /** + * 课程下资源和知识点的点赞总数 + * + * @param courseId + * @return + */ + long courseCount(String courseId); + +} diff --git a/src/main/java/com/teaching/backend/service/thumb/SeKnowThumbService.java b/src/main/java/com/teaching/backend/service/thumb/SeKnowThumbService.java new file mode 100644 index 0000000..c6536e3 --- /dev/null +++ b/src/main/java/com/teaching/backend/service/thumb/SeKnowThumbService.java @@ -0,0 +1,22 @@ +package com.teaching.backend.service.thumb; + +import com.baomidou.mybatisplus.extension.service.IService; +import com.teaching.backend.model.entity.thumb.SeKnowThumb; + +/** + * @Author:youhang + * @Date:2024-05-30-20:22 + * @Description: + */ +public interface SeKnowThumbService extends IService { + + /** + * 点赞 + * + * @param courseId + * @param userId + * @return + */ + boolean doKnowThumb(String courseId, String resourceId, String userId); + +} diff --git a/src/main/java/com/teaching/backend/service/thumb/SeResourceThumbService.java b/src/main/java/com/teaching/backend/service/thumb/SeResourceThumbService.java new file mode 100644 index 0000000..9382343 --- /dev/null +++ b/src/main/java/com/teaching/backend/service/thumb/SeResourceThumbService.java @@ -0,0 +1,22 @@ +package com.teaching.backend.service.thumb; + +import com.baomidou.mybatisplus.extension.service.IService; +import com.teaching.backend.model.entity.thumb.SeResourceThumb; + +/** + * @Author:youhang + * @Date:2024-05-30-20:22 + * @Description: + */ +public interface SeResourceThumbService extends IService { + + /** + * 点赞 + * + * @param courseId + * @param userId + * @return + */ + boolean doResourceThumb(String courseId, String resourceId, String userId); + +} diff --git a/src/main/resources/application.yml b/src/main/resources/application.yml index 7f1e8c0..51061c8 100644 --- a/src/main/resources/application.yml +++ b/src/main/resources/application.yml @@ -13,4 +13,20 @@ spring: password: root mybatis: configuration: - map-underscore-to-camel-case: true \ No newline at end of file + map-underscore-to-camel-case: true + mapper-locations: + - classpath:dao/*.xml + - classpath*:com/**/mapper/*.xml + + +# 接口文档配置 +knife4j: + enable: true + openapi: + title: "接口文档" + version: 1.0 + group: + default: + api-rule: package + api-rule-resources: + - com.teaching.backend.controller diff --git a/src/main/resources/mapper/SeCourseThumbMapper.xml b/src/main/resources/mapper/SeCourseThumbMapper.xml new file mode 100644 index 0000000..39ee736 --- /dev/null +++ b/src/main/resources/mapper/SeCourseThumbMapper.xml @@ -0,0 +1,18 @@ + + + + + + + + + + + + id + ,courseId, + userId + +