Merge remote-tracking branch 'refs/remotes/origin/dev'

This commit is contained in:
landaiqing
2024-07-20 20:56:32 +08:00
8 changed files with 193 additions and 17 deletions

View File

@@ -2,10 +2,12 @@ package com.schisandra.share.application.controller;
import com.alibaba.fastjson.JSON;
import com.google.common.base.Preconditions;
import com.schisandra.share.application.convert.SchisandraShareDetailDTOConverter;
import com.schisandra.share.application.convert.SchisandraUserFavoritesDTOConverter;
import com.schisandra.share.application.dto.SchisandraUserFavoritesDTO;
import com.schisandra.share.common.entity.Result;
import com.schisandra.share.common.utils.CaffeineUtil;
import com.schisandra.share.domain.bo.SchisandraShareDetailBO;
import com.schisandra.share.domain.bo.SchisandraUserFavoritesBO;
import com.schisandra.share.domain.service.SchisandraUserFavoritesDomainService;
import lombok.extern.slf4j.Slf4j;
@@ -40,19 +42,19 @@ public class SchisandraUserFavoritesController {
* @return
*/
@GetMapping("myfavor")
public Result<SchisandraUserFavoritesDTO> myfavor(String userId) {
public Result myfavor(String userId) {
try{
if (log.isInfoEnabled()) {
log.info("SchisandraUserFavoritesController.myfavor.userId:{}", JSON.toJSONString(userId));
}
Preconditions.checkNotNull(userId, "userId不能为空");
List<SchisandraUserFavoritesBO> result= (List<SchisandraUserFavoritesBO>) caffeineUtil
List<SchisandraShareDetailBO> result= (List<SchisandraShareDetailBO>) caffeineUtil
.caffeineBuild().getIfPresent("myfavor"+userId);
if(result!=null){
return Result.ok(result);
return Result.ok(SchisandraShareDetailDTOConverter.INSTANCE.convertBOToDTOList(result));
}
result = schisandraUserFavoritesDomainService.returnMyFavor(userId);
return Result.ok(result);
return Result.ok(SchisandraShareDetailDTOConverter.INSTANCE.convertBOToDTOList(result));
} catch (Exception e) {
log.error("SchisandraUserFavoritesController.myfavor.error:{}", e.getMessage(), e);
return Result.fail("获取用户收藏表失败");

View File

@@ -1,5 +1,6 @@
package com.schisandra.share.domain.service;
import com.schisandra.share.domain.bo.SchisandraShareDetailBO;
import com.schisandra.share.domain.bo.SchisandraUserFavoritesBO;
import java.util.List;
@@ -27,6 +28,6 @@ public interface SchisandraUserFavoritesDomainService {
*/
Boolean delete(SchisandraUserFavoritesBO schisandraUserFavoritesBO);
List<SchisandraUserFavoritesBO> returnMyFavor(String userId);
List<SchisandraShareDetailBO> returnMyFavor(String userId);
}

View File

@@ -1,5 +1,7 @@
package com.schisandra.share.domain.service.impl;
import com.jd.platform.async.executor.Async;
import com.jd.platform.async.worker.WorkResult;
import com.jd.platform.async.wrapper.WorkerWrapper;
import com.schisandra.share.common.enums.IsDeletedFlagEnum;
import com.schisandra.share.domain.convert.SchisandraShareCommentReplyBOConverter;
@@ -18,6 +20,11 @@ import org.springframework.util.Assert;
import javax.annotation.Resource;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.LinkedBlockingQueue;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;
/**
* 评论回复表 领域service实现了
@@ -90,16 +97,48 @@ public class SchisandraShareCommentReplyDomainServiceImpl implements SchisandraS
public List<SchisandraShareCommentReplyBO> listComment(String detailId, String userId) {
List<SchisandraShareCommentReply> schisandraShareComments = schisandraShareCommentReplyService.listComment(detailId);
List<SchisandraShareCommentReplyBO> schisandraShareCommentBOS = SchisandraShareCommentReplyBOConverter.INSTANCE.convertEntityToBOList(schisandraShareComments);
List<WorkerWrapper> wrappers = new ArrayList<>();
schisandraShareCommentBOS.forEach(schisandraShareCommentReplyBO -> {
SchisandraUserLikesComment schisandraUserLikesComment =
schisandraUserLikesCommentService.queryByuserIdAndDetailId(schisandraShareCommentReplyBO.getId(), userId);
if(schisandraUserLikesComment!=null){
schisandraShareCommentReplyBO.setIsLike(true);
}
AuthUserInfoEntity userInfo = userRpc.getUserInfo(schisandraShareCommentReplyBO.getUserId());
schisandraShareCommentReplyBO.setNick(userInfo.getNickName());
schisandraShareCommentReplyBO.setAvatar(userInfo.getAvatar());
WorkerWrapper<SchisandraShareCommentReplyBO,String > workerWrapper = new WorkerWrapper.Builder<SchisandraShareCommentReplyBO,String >()
.worker((SchisandraShareCommentReplyBO object, Map<String, WorkerWrapper> allWrappers) -> {
SchisandraUserLikesComment schisandraUserLikesComment =
schisandraUserLikesCommentService.queryByuserIdAndDetailId(object.getId(), userId);
if(schisandraUserLikesComment!=null){
object.setIsLike(true);
}
AuthUserInfoEntity userInfo = userRpc.getUserInfo(object.getUserId());
object.setNick(userInfo.getNickName());
object.setAvatar(userInfo.getAvatar());
return "success";
})
.param(schisandraShareCommentReplyBO)
.id(schisandraShareCommentReplyBO.getId())
.callback((boolean success, SchisandraShareCommentReplyBO param, WorkResult<String> workResult) ->
System.out.println("该线程"+Thread.currentThread().getName()))
.build();
wrappers.add(workerWrapper);
//
// SchisandraUserLikesComment schisandraUserLikesComment =
// schisandraUserLikesCommentService.queryByuserIdAndDetailId(schisandraShareCommentReplyBO.getId(), userId);
// if(schisandraUserLikesComment!=null){
// schisandraShareCommentReplyBO.setIsLike(true);
// }
// AuthUserInfoEntity userInfo = userRpc.getUserInfo(schisandraShareCommentReplyBO.getUserId());
// schisandraShareCommentReplyBO.setNick(userInfo.getNickName());
// schisandraShareCommentReplyBO.setAvatar(userInfo.getAvatar());
});
try {
Async.beginWork(3500L,new ThreadPoolExecutor(10, 100, 5L,
TimeUnit.SECONDS, new LinkedBlockingQueue<Runnable>()), wrappers);
} catch (ExecutionException e) {
throw new RuntimeException(e);
} catch (InterruptedException e) {
throw new RuntimeException(e);
}
return schisandraShareCommentBOS;
}

View File

@@ -1,16 +1,21 @@
package com.schisandra.share.domain.service.impl;
import com.schisandra.share.common.enums.IsDeletedFlagEnum;
import com.schisandra.share.domain.bo.SchisandraShareDetailBO;
import com.schisandra.share.domain.convert.SchisandraShareDetailBOConverter;
import com.schisandra.share.domain.convert.SchisandraUserFavoritesBOConverter;
import com.schisandra.share.domain.bo.SchisandraUserFavoritesBO;
import com.schisandra.share.domain.service.SchisandraUserFavoritesDomainService;
import com.schisandra.share.infra.basic.entity.SchisandraShareDetail;
import com.schisandra.share.infra.basic.entity.SchisandraUserFavorites;
import com.schisandra.share.infra.basic.service.SchisandraShareDetailService;
import com.schisandra.share.infra.basic.service.SchisandraUserFavoritesService;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Service;
import javax.annotation.Resource;
import java.util.List;
import java.util.stream.Collectors;
/**
* 收藏表 领域service实现了
@@ -24,6 +29,8 @@ public class SchisandraUserFavoritesDomainServiceImpl implements SchisandraUserF
@Resource
private SchisandraUserFavoritesService schisandraUserFavoritesService;
@Resource
private SchisandraShareDetailService schisandraShareDetailService;
@Override
public Boolean add(SchisandraUserFavoritesBO schisandraUserFavoritesBO) {
@@ -47,9 +54,10 @@ public class SchisandraUserFavoritesDomainServiceImpl implements SchisandraUserF
}
@Override
public List<SchisandraUserFavoritesBO> returnMyFavor(String userId){
List<SchisandraUserFavoritesBO> schisandraUserFavoritesBOS = SchisandraUserFavoritesBOConverter.INSTANCE.convertEntityToBOList(schisandraUserFavoritesService.returnMyFavor(userId));
return schisandraUserFavoritesBOS;
public List<SchisandraShareDetailBO> returnMyFavor(String userId){
List<SchisandraUserFavoritesBO> schisandraUserFavoritesBOList = SchisandraUserFavoritesBOConverter.INSTANCE.convertEntityToBOList(schisandraUserFavoritesService.returnMyFavor(userId));
List<String> detailIds = schisandraUserFavoritesBOList.stream().map(SchisandraUserFavoritesBO::getDetailId).collect((Collectors.toList()));
List<SchisandraShareDetail> shareDetailList = schisandraShareDetailService.queryByIds(detailIds);
return SchisandraShareDetailBOConverter.INSTANCE.convertEntityToBOList(shareDetailList);
}
}

View File

@@ -71,4 +71,6 @@ public interface SchisandraShareDetailService {
List<SchisandraShareDetail> queryByCircleId(String circleId);
List<SchisandraShareDetail> queryByuserId(String userId);
List<SchisandraShareDetail> queryByIds(List<String> Ids);
}

View File

@@ -136,4 +136,9 @@ public class SchisandraShareDetailServiceImpl implements SchisandraShareDetailSe
public List<SchisandraShareDetail> queryByuserId(String userId) {
return this.schisandraShareDetailDao.selectListByCondition(SchisandraShareDetailTableDef.SCHISANDRA_SHARE_DETAIL.USER_ID.eq(userId));
}
@Override
public List<SchisandraShareDetail> queryByIds(List<String> ids) {
return this.schisandraShareDetailDao.selectListByIds(ids);
}
}

View File

@@ -0,0 +1,79 @@
package com.schisandra.share.infra.entity;
import java.io.Serializable;
import java.util.Date;
import lombok.Data;
@Data
public class AuthUserAddressEntity implements Serializable {
/**
*
*/
private String id;
/**
*
*/
private String userId;
/**
*
*/
private String ip;
/**
*
*/
private String location;
/**
*
*/
private String agent;
/**
*
*/
private String extJson;
/**
* 创建人
*/
private String createdBy;
/**
* 创建时间
*/
private Date createdTime;
/**
* 更新人
*/
private String updateBy;
/**
* 更新时间
*/
private Date updateTime;
/**
*
*/
private Integer isDeleted;
/**
*
*/
private String browser;
/**
*
*/
private String operatingSystem;
/**
*
*/
private String browserVersion;
}

View File

@@ -0,0 +1,40 @@
package com.schisandra.share.infra.rpc;;
import com.schisandra.auth.api.SchisandraAuthFeignService;
import com.schisandra.auth.entity.Result;
import com.schisandra.auth.entity.SchisandraAuthAddressDTO;
import com.schisandra.share.infra.entity.AuthUserAddressEntity;
import org.springframework.stereotype.Component;
import org.springframework.web.bind.annotation.RequestParam;
import javax.annotation.Resource;
/**
* @Classname UserRpc
* @BelongsProject: schisandra-cloud-storage
* @BelongsPackage: com.schisandra.share.infra.rpc
* @Author: landaiqing
* @CreateTime: 2024-07-15 09:48
* @Description: TODO
* @Version: 1.0
*/
@Component
public class AddressRpc {
@Resource
private SchisandraAuthFeignService schisandraAuthFeignService;
public AuthUserAddressEntity getUserAddress(@RequestParam("userId") String userId){
Result<SchisandraAuthAddressDTO> result = schisandraAuthFeignService.getUserAddress(userId);
AuthUserAddressEntity authUserAddressEntity = new AuthUserAddressEntity();
if (!result.getSuccess()) {
return authUserAddressEntity;
}
SchisandraAuthAddressDTO data = result.getData();
authUserAddressEntity.setId(data.getId());
authUserAddressEntity.setUserId(data.getUserId());
authUserAddressEntity.setLocation(data.getLocation());
authUserAddressEntity.setBrowser(data.getBrowser());
return authUserAddressEntity;
}
}