| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149 |
- package com.izouma.nineth.web;
- import com.izouma.nineth.TokenHistory;
- import com.izouma.nineth.domain.Asset;
- import com.izouma.nineth.domain.GiftOrder;
- import com.izouma.nineth.dto.PageQuery;
- import com.izouma.nineth.dto.UserHistory;
- import com.izouma.nineth.exception.BusinessException;
- import com.izouma.nineth.repo.AssetRepo;
- import com.izouma.nineth.repo.OrderRepo;
- import com.izouma.nineth.service.AssetService;
- import com.izouma.nineth.service.GiftOrderService;
- import com.izouma.nineth.utils.SecurityUtils;
- import com.izouma.nineth.utils.excel.ExcelUtils;
- import io.swagger.annotations.ApiOperation;
- import lombok.AllArgsConstructor;
- import org.springframework.data.domain.Page;
- import org.springframework.security.access.prepost.PreAuthorize;
- import org.springframework.web.bind.annotation.*;
- import javax.servlet.http.HttpServletResponse;
- import java.io.IOException;
- import java.math.BigDecimal;
- import java.time.LocalDateTime;
- import java.util.List;
- import java.util.Map;
- import java.util.concurrent.ExecutionException;
- @RestController
- @RequestMapping("/asset")
- @AllArgsConstructor
- public class AssetController extends BaseController {
- private AssetService assetService;
- private AssetRepo assetRepo;
- private GiftOrderService giftOrderService;
- private OrderRepo orderRepo;
- //@PreAuthorize("hasRole('ADMIN')")
- // @PostMapping("/save")
- // public Asset save(@RequestBody Asset record) {
- // if (record.getId() != null) {
- // Asset orig = assetRepo.findById(record.getId()).orElseThrow(new BusinessException("无记录"));
- // ObjUtils.merge(orig, record);
- // return assetRepo.save(orig);
- // }
- // return assetRepo.save(record);
- // }
- //@PreAuthorize("hasRole('ADMIN')")
- @PostMapping("/all")
- public Page<Asset> all(@RequestBody PageQuery pageQuery) {
- return assetService.all(pageQuery);
- }
- @GetMapping("/get/{id}")
- public Asset get(@PathVariable Long id) {
- Asset asset = assetRepo.findById(id).orElseThrow(new BusinessException("无记录"));
- orderRepo.findByIdAndDelFalse(asset.getOrderId()).ifPresent(order -> asset.setOpened(order.isOpened()));
- return asset;
- }
- // @PostMapping("/del/{id}")
- // public void del(@PathVariable Long id) {
- // assetRepo.softDelete(id);
- // }
- @GetMapping("/excel")
- @ResponseBody
- public void excel(HttpServletResponse response, PageQuery pageQuery) throws IOException {
- List<Asset> data = all(pageQuery).getContent();
- ExcelUtils.export(response, data);
- }
- @PostMapping("/publicShow")
- @ApiOperation("公开展示")
- public void publicShow(@RequestParam Long id) {
- assetService.publicShow(id);
- }
- @PostMapping("/cancelPublic")
- @ApiOperation("取消展示")
- public void cancelPublic(@RequestParam Long id) {
- assetService.cancelPublic(id);
- }
- @PostMapping("/usePrivilege")
- @ApiOperation("使用特权")
- public void usePrivilege(@RequestParam Long assetId, @RequestParam Long privilegeId) {
- assetService.usePrivilege(assetId, privilegeId);
- }
- @PostMapping("/consignment")
- @ApiOperation("寄售")
- public void consignment(@RequestParam Long id, @RequestParam BigDecimal price) {
- assetService.consignment(id, price);
- }
- @PostMapping("/cancelConsignment")
- @ApiOperation("取消寄售")
- public void cancelConsignment(@RequestParam Long id) {
- assetService.cancelConsignment(id);
- }
- @PostMapping("/gift")
- @ApiOperation("转赠")
- public GiftOrder gift(@RequestParam Long assetId, @RequestParam Long toUserId) {
- // return giftOrderService.gift(SecurityUtils.getAuthenticatedUser().getId(), assetId, toUserId);
- return null;
- }
- @GetMapping("/tokenHistory")
- @ApiOperation("交易历史")
- public List<TokenHistory> tokenHistory(@RequestParam(required = false) String tokenId, @RequestParam(required = false) Long assetId) {
- return assetService.tokenHistory(tokenId, assetId);
- }
- @GetMapping("/userHistory")
- @ApiOperation("交易历史")
- public Page<UserHistory> userHistory(PageQuery pageQuery) {
- return assetService.userHistory(SecurityUtils.getAuthenticatedUser().getId(), pageQuery);
- }
- @GetMapping("/mint")
- public String mint(@RequestParam(required = false) LocalDateTime time) {
- return assetService.mint(time);
- }
- @GetMapping("/breakdown")
- @ApiOperation("收支总计")
- public Map<String, BigDecimal> breakdown() {
- return assetService.breakdown(SecurityUtils.getAuthenticatedUser().getId());
- }
- @PostMapping("/cdn")
- @PreAuthorize("hasRole('ADMIN')")
- public String cdn() throws ExecutionException, InterruptedException {
- new Thread(() -> {
- try {
- assetService.transferCDN();
- } catch (ExecutionException | InterruptedException e) {
- e.printStackTrace();
- }
- }).start();
- return "ok";
- }
- }
|