WebTemplateDataSourceController.java 4.65 KB
package com.lhcredit.project.webbusiness.controller;

import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.stream.Collectors;

import com.lhcredit.LhCreditApplication;
import com.lhcredit.common.utils.StringUtils;
import com.lhcredit.common.utils.security.ShiroUtils;
import com.lhcredit.framework.aspectj.lang.enums.OperatorType;
import com.lhcredit.project.business.reportMake.reportTemp.WebTempConfig;
import io.swagger.annotations.ApiImplicitParam;
import io.swagger.annotations.ApiOperation;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
import com.lhcredit.framework.aspectj.lang.annotation.Log;
import com.lhcredit.framework.aspectj.lang.enums.BusinessType;
import com.lhcredit.project.business.templateDataSource.domain.TemplateDataSource;
import com.lhcredit.project.business.templateDataSource.service.ITemplateDataSourceService;
import com.lhcredit.framework.web.controller.BaseController;
import com.lhcredit.framework.web.domain.AjaxResult;


/**
 * 报告模版数据源信息对外接口
 *
 * @author lhcredit
 * @date 2025-04-03
 */
@RestController
@RequestMapping("/web/templateDataSource")
public class WebTemplateDataSourceController extends BaseController {
    @Autowired
    private ITemplateDataSourceService templateDataSourceService;


    /**
     * 查询报告模版数据源列表接口
     */
    @ApiOperation("查询报告模版数据源列表")
    @Log(title = "报告模版数据源", businessType = BusinessType.LIST, operatorType = OperatorType.WEB)
    @GetMapping
    public AjaxResult list(TemplateDataSource templateDataSource) {
        startPage();
        List<TemplateDataSource> list = templateDataSourceService.changeModel(templateDataSourceService.selectTemplateDataSourceList(templateDataSource));
        return toAjax(list);
    }

    /**
     * 查询报告模版数据源详情接口
     */
    @ApiOperation("查询报告模版数据源详情")
    @ApiImplicitParam(name = "id", value = "主键", required = true, dataType = "int", paramType = "path")
    @Log(title = "报告模版数据源", businessType = BusinessType.DETAIL, operatorType = OperatorType.WEB)
    @GetMapping("/{id}")
    public AjaxResult detail(@PathVariable Integer id) {
        TemplateDataSource templateDataSource =templateDataSourceService.changeModel(templateDataSourceService.selectTemplateDataSourceById(id));
        if (StringUtils.isNull(templateDataSource)) {
            return AjaxResult.error("该信息不存在");
        }
        return toAjax(templateDataSource);
    }

    /**
     * 新增保存报告模版数据源接口
     */
    @ApiOperation("新增报告模版数据源")
    @ApiImplicitParam(name = "templateDataSource", value = "报告模版数据源", dataType = "TemplateDataSource")
    @Log(title = "报告模版数据源", businessType = BusinessType.INSERT, operatorType = OperatorType.WEB)
    @PostMapping
    public AjaxResult addSave(TemplateDataSource templateDataSource) {
        templateDataSource.setCreateBy(ShiroUtils.getLoginName());
        templateDataSource.setCreateTime(new Date());
        templateDataSource.setUpdateBy(ShiroUtils.getLoginName());
        templateDataSource.setUpdateTime(new Date());
        return toAjax(templateDataSourceService.insertTemplateDataSource(templateDataSource));
    }

    /**
     * 修改保存报告模版数据源接口
     */
    @ApiOperation("修改报告模版数据源")
    @ApiImplicitParam(name = "templateDataSource", value = "报告模版数据源", dataType = "TemplateDataSource")
    @Log(title = "报告模版数据源", businessType = BusinessType.UPDATE, operatorType = OperatorType.WEB)
    @PutMapping
    public AjaxResult update(TemplateDataSource templateDataSource) {
        if (StringUtils.isNull(templateDataSource) || StringUtils.isNull(templateDataSource.getId())){
            return AjaxResult.error("主键id不能为空");
        }
        templateDataSource.setUpdateBy(ShiroUtils.getLoginName());
        templateDataSource.setUpdateTime(new Date());
        return toAjax(templateDataSourceService.updateTemplateDataSource(templateDataSource));
    }

    /**
     * 删除报告模版数据源接口
     */
    @ApiOperation("删除报告模版数据源")
    @ApiImplicitParam(name = "ids", value = "主键id,多条以英文逗号分隔", required = true, dataType = "String", paramType = "path")
    @Log(title = "报告模版数据源", businessType = BusinessType.DELETE, operatorType = OperatorType.WEB)
    @DeleteMapping("/{ids}")
    public AjaxResult delete(@PathVariable String ids) {
        return toAjax(templateDataSourceService.deleteTemplateDataSourceByIds(ids));
    }

}