aaa
doum
2026-06-08 3ac279c9df7181c9f21d35a689a321b990b87b22
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
package com.doumee.api.business;
 
import com.doumee.api.BaseController;
import com.doumee.core.annotation.pr.PreventRepeat;
import com.doumee.core.model.ApiResponse;
import com.doumee.core.model.PageData;
import com.doumee.core.model.PageWrap;
import com.doumee.dao.business.model.GoodsImportTask;
import com.doumee.service.business.GoodsImportTaskService;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiImplicitParam;
import io.swagger.annotations.ApiImplicitParams;
import io.swagger.annotations.ApiOperation;
import org.apache.shiro.authz.annotation.RequiresPermissions;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.multipart.MultipartFile;
 
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.File;
 
@Api(tags = "商品异步导入任务")
@RestController
@RequestMapping("/business/goodsImportTask")
public class GoodsImportTaskController extends BaseController {
 
    @Autowired
    private GoodsImportTaskService goodsImportTaskService;
 
    @ApiOperation("下载异步导入模板")
    @PostMapping("/exportTemplate")
    @RequiresPermissions("business:goods:exportExcel")
    public void exportTemplate(HttpServletRequest request, HttpServletResponse response) throws Exception {
        goodsImportTaskService.exportImportAsyncTemplate(request, response);
    }
 
    @PreventRepeat
    @ApiOperation("提交异步导入任务")
    @PostMapping("/importExcelAsync")
    @ApiImplicitParams({
            @ApiImplicitParam(name = "file", value = "file", required = true, paramType = "query", dataType = "file", dataTypeClass = File.class),
    })
    @RequiresPermissions("business:goodsImportTask:create")
    public ApiResponse<Integer> importExcelAsync(@RequestParam("file") MultipartFile file) {
        return ApiResponse.success(goodsImportTaskService.submitTask(file));
    }
 
    @ApiOperation("分页查询导入任务")
    @PostMapping("/page")
    @RequiresPermissions("business:goodsImportTask:query")
    public ApiResponse<PageData<GoodsImportTask>> page(@RequestBody PageWrap<GoodsImportTask> pageWrap) {
        return ApiResponse.success(goodsImportTaskService.findPage(pageWrap));
    }
 
    @ApiOperation("查询任务详情")
    @GetMapping("/{id}")
    @RequiresPermissions("business:goodsImportTask:query")
    public ApiResponse<GoodsImportTask> findById(@PathVariable Integer id) {
        return ApiResponse.success(goodsImportTaskService.findById(id));
    }
 
    @ApiOperation("是否存在未完成导入任务")
    @GetMapping("/hasUnfinished")
    @RequiresPermissions("business:goodsImportTask:query")
    public ApiResponse<Boolean> hasUnfinished() {
        return ApiResponse.success(goodsImportTaskService.hasUnfinishedTask(getLoginUser().getCompanyId()));
    }
 
    @ApiOperation("删除导入任务")
    @GetMapping("/delete/{id}")
    @RequiresPermissions("business:goodsImportTask:delete")
    public ApiResponse deleteById(@PathVariable Integer id) {
        goodsImportTaskService.deleteById(id);
        return ApiResponse.success(null);
    }
}