AssetRepo.java 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. package com.izouma.nineth.repo;
  2. import com.izouma.nineth.domain.Asset;
  3. import com.izouma.nineth.enums.AssetStatus;
  4. import org.springframework.data.jpa.repository.JpaRepository;
  5. import org.springframework.data.jpa.repository.JpaSpecificationExecutor;
  6. import org.springframework.data.jpa.repository.Modifying;
  7. import org.springframework.data.jpa.repository.Query;
  8. import javax.transaction.Transactional;
  9. import java.time.LocalDateTime;
  10. import java.util.Collection;
  11. import java.util.List;
  12. import java.util.Optional;
  13. import java.util.Set;
  14. public interface AssetRepo extends JpaRepository<Asset, Long>, JpaSpecificationExecutor<Asset> {
  15. @Query("update Asset t set t.del = true where t.id = ?1")
  16. @Modifying
  17. @Transactional
  18. void softDelete(Long id);
  19. long countByIpfsUrlAndStatusNot(String ipfsUrl, AssetStatus status);
  20. List<Asset> findByCollectionId(Long collectionId);
  21. List<Asset> findByCollectionIdAndStatusIn(Long collectionId, Iterable<AssetStatus> statuses);
  22. List<Asset> findAllByCollectionIdInAndStatusIn(List<Long> collectionId, Iterable<AssetStatus> statuses);
  23. List<Asset> findByCreatedAtBefore(LocalDateTime localDateTime);
  24. List<Asset> findByConsignmentTrue();
  25. List<Asset> findByTokenIdIn(Iterable<String> tokenId);
  26. List<Asset> findByTokenIdOrderByCreatedAt(String tokenId);
  27. List<Asset> findByOrderId(Long orderId);
  28. @Query("select a from Asset a join Order o on o.assetId = a.id join Asset aa on aa.orderId = o.id where a.id = ?1")
  29. Optional<Asset> findChild(Long id);
  30. @Query("select a from Asset a join User u on a.userId = u.id where a.consignment = true and u.settleAccountId is null")
  31. List<Asset> findNoAccount();
  32. Set<Asset> findAllByUserIdInAndCollectionId(List<Long> ids, Long collectionId);
  33. List<Asset> findByTxHash(String hash);
  34. List<Asset> findByIdIn(Iterable<Long> ids);
  35. @Query("select a from Asset a left join TokenHistory t on a.tokenId = t.tokenId where t.id is null")
  36. List<Asset> findByNoHistory();
  37. List<Asset> findByTokenIdAndCreatedAtBetween(String tokenId, LocalDateTime start, LocalDateTime end);
  38. Asset findFirstByTokenId(String tokenId);
  39. Asset findFirstByTxHashIsNullAndTokenIdNotNullAndStatusOrderByCreatedAt(AssetStatus status);
  40. @Query("select a from Asset a where a.txHash is null and a.tokenId is not null " +
  41. "and a.status = com.izouma.nineth.enums.AssetStatus.NORMAL and a.createdAt < ?1 " +
  42. "order by a.createdAt desc")
  43. List<Asset> toMint(LocalDateTime time);
  44. List<Asset> findAllByIdInAndUserId(Collection<Long> id, Long userId);
  45. @Query(value = "select c.id, c.pic, c.model3d, c.minter_avatar, c.owner_avatar, c.detail from asset c", nativeQuery = true)
  46. List<List<String>> selectResource();
  47. @Modifying
  48. @Transactional
  49. @Query(value = "update asset c set c.pic = ?2, c.model3d = ?3, c.minter_avatar = ?4, " +
  50. "c.owner_avatar = ?5, c.detail = ?6 where c.id = ?1", nativeQuery = true)
  51. int updateCDN(Long id, String pic, String model3d, String minterAvatar,
  52. String ownerAvatar, String detail);
  53. }