PhotoAssetService.java 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157
  1. package com.izouma.nineth.service;
  2. import com.izouma.nineth.annotations.RedisLock;
  3. import com.izouma.nineth.config.GeneralProperties;
  4. import com.izouma.nineth.domain.Asset;
  5. import com.izouma.nineth.domain.PhotoAsset;
  6. import com.izouma.nineth.dto.PageQuery;
  7. import com.izouma.nineth.enums.CollectionStatus;
  8. import com.izouma.nineth.enums.OperationSource;
  9. import com.izouma.nineth.enums.*;
  10. import com.izouma.nineth.exception.BusinessException;
  11. import com.izouma.nineth.repo.AssetRepo;
  12. import com.izouma.nineth.repo.PhotoAssetRepo;
  13. import com.izouma.nineth.repo.UserRepo;
  14. import com.izouma.nineth.utils.JpaUtils;
  15. import lombok.AllArgsConstructor;
  16. import lombok.extern.slf4j.Slf4j;
  17. import org.springframework.core.env.Environment;
  18. import org.springframework.data.annotation.Transient;
  19. import org.springframework.data.domain.Page;
  20. import org.springframework.scheduling.annotation.Scheduled;
  21. import org.springframework.stereotype.Service;
  22. import java.math.BigDecimal;
  23. import java.util.Arrays;
  24. import java.util.List;
  25. import java.util.concurrent.TimeUnit;
  26. @Service
  27. @AllArgsConstructor
  28. @Slf4j
  29. public class PhotoAssetService {
  30. private PhotoAssetRepo photoAssetRepo;
  31. private AssetRepo assetRepo;
  32. private AssetService assetService;
  33. private UserRepo userRepo;
  34. private ContentAuditService contentAuditService;
  35. private GeneralProperties generalProperties;
  36. private Environment env;
  37. public Page<PhotoAsset> all(PageQuery pageQuery) {
  38. return photoAssetRepo
  39. .findAll(JpaUtils.toSpecification(pageQuery, PhotoAsset.class), JpaUtils.toPageRequest(pageQuery));
  40. }
  41. public PhotoAsset save(PhotoAsset record) {
  42. record.setStatus(CollectionStatus.PENDING);
  43. record.setOwnerId(record.getOwnerId());
  44. record.setGifted(false);
  45. if (record.isDestroyed()) {
  46. //将选取的藏品取消上架
  47. record.setOrderStatus(OrderStatus.NOT_PAID);
  48. // record.setPayMethod(PayMethod.DESTROY);
  49. Asset asset = assetService.cancelConsignmentAndStore(record.getDestroyAssetId());
  50. record.setUserAvatar(asset.getOwnerAvatar());
  51. record.setUserName(asset.getOwner());
  52. record.setDestroyAssetName(asset.getName());
  53. if (asset.getNumber() != null) {
  54. record.setDestroyAssetNumber(asset.getNumber().toString());
  55. }
  56. if (asset.getPic() != null) {
  57. record.setDestroyAssetPicture(asset.getPic().get(0));
  58. }
  59. } else {
  60. record.setOrderStatus(OrderStatus.NOT_PAID);
  61. }
  62. return photoAssetRepo.save(record);
  63. }
  64. public void pass(PhotoAsset photoAsset) {
  65. //销毁原来的藏品
  66. if (photoAsset.isDestroyed()) {
  67. assetService.destroyWithoutTradeCode(photoAsset.getDestroyAssetId(), photoAsset.getUserId(), OperationSource.RAEX);
  68. }
  69. //生成新的藏品
  70. if (photoAsset.getOrderStatus().equals(OrderStatus.FINISH)) {
  71. Long createId = assetService.createAsset(photoAsset, userRepo.findById(photoAsset.getUserId())
  72. .orElseThrow(new BusinessException("无用户记录")), null, BigDecimal.ZERO, "星图", null, false).getId();
  73. photoAsset.setStatus(CollectionStatus.SUCCESS);
  74. photoAsset.setCreateAssetId(createId);
  75. photoAsset.setOwnerId(photoAsset.getUserId());
  76. photoAssetRepo.save(photoAsset);
  77. }
  78. }
  79. public void deny(Long id) {
  80. PhotoAsset photoAsset = photoAssetRepo.findById(id).orElseThrow(new BusinessException("无记录"));
  81. photoAsset.setStatus(CollectionStatus.FAIL);
  82. // Asset asset = assetRepo.findById(photoAsset.getDestroyAssetId()).orElseThrow(new BusinessException("无藏品记录"));
  83. // asset.setStatus(AssetStatus.NORMAL);
  84. // assetRepo.saveAndFlush(asset);
  85. assetService.destroyWithoutTradeCode(photoAsset.getDestroyAssetId(), photoAsset.getUserId(), OperationSource.RAEX);;
  86. photoAssetRepo.save(photoAsset);
  87. }
  88. @Scheduled(fixedRate = 60000)
  89. @RedisLock(value = "autoPictureAudit", expire = 30, unit = TimeUnit.MINUTES)
  90. public void autoValidate() {
  91. if (generalProperties.isNotifyServer()) return;
  92. if (Arrays.asList(env.getActiveProfiles()).contains("dev")) {
  93. return;
  94. }
  95. try {
  96. List<PhotoAsset> list = photoAssetRepo
  97. .findAllByStatusAndOrderStatus(CollectionStatus.PENDING, OrderStatus.FINISH);
  98. list.parallelStream().forEach(this::imageAudit);
  99. } catch (Exception e) {
  100. log.error("批量图片审核出错", e);
  101. }
  102. }
  103. public void imageAudit(PhotoAsset photoAsset) {
  104. boolean result = contentAuditService.auditImage(photoAsset.getPic().getUrl());
  105. if (!result) {
  106. photoAsset.setAuditResult("涉及色情性感内容或暴恐,需要人工审核.");
  107. photoAssetRepo.save(photoAsset);
  108. } else {
  109. pass(photoAsset);
  110. }
  111. }
  112. @Transient
  113. public void notify(Long id, PayMethod payMethod, String transactionId) {
  114. PhotoAsset photoAsset = photoAssetRepo.findById(id).orElseThrow(new BusinessException("未找到星图"));
  115. if (!photoAsset.getOrderStatus().equals(OrderStatus.NOT_PAID)) {
  116. throw new BusinessException("订单已经处理");
  117. }
  118. photoAsset.setOrderStatus(OrderStatus.FINISH);
  119. photoAsset.setPayMethod(payMethod);
  120. photoAsset.setTransactionId(transactionId);
  121. photoAssetRepo.save(photoAsset);
  122. }
  123. // @Scheduled(fixedRate = 30000)
  124. // public void batchCancelPicOrder() {
  125. // List<PhotoAsset> orders = photoAssetRepo
  126. // .findAllByOrderStatus(OrderStatus.NOT_PAID);
  127. // orders.parallelStream().forEach(o -> {
  128. // try {
  129. // PhotoAsset order = photoAssetRepo.findById(o.getId()).orElseThrow(new BusinessException("订单不存在"));
  130. // if (order.getOrderStatus() == OrderStatus.NOT_PAID) {
  131. // cancel(order);
  132. // }
  133. // } catch (Exception e) {
  134. // log.error("取消拍卖订单错误 " + o.getId(), e);
  135. // }
  136. // });
  137. // }
  138. public void cancel(PhotoAsset photoAsset) {
  139. photoAsset.setOrderStatus(OrderStatus.CANCELLED);
  140. photoAsset.setStatus(CollectionStatus.FAIL);
  141. photoAssetRepo.save(photoAsset);
  142. }
  143. }