/** * BladeX Commercial License Agreement * Copyright (c) 2018-2099, https://bladex.cn. All rights reserved. *

* Use of this software is governed by the Commercial License Agreement * obtained after purchasing a license from BladeX. *

* 1. This software is for development use only under a valid license * from BladeX. *

* 2. Redistribution of this software's source code to any third party * without a commercial license is strictly prohibited. *

* 3. Licensees may copyright their own code but cannot use segments * from this software for such purposes. Copyright of this software * remains with BladeX. *

* Using this software signifies agreement to this License, and the software * must not be used for illegal purposes. *

* THIS SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY. The author is * not liable for any claims arising from secondary or illegal development. *

* Author: Chill Zhuang (bladejava@qq.com) */ package org.springblade.develop.controller; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.generator.config.builder.ConfigBuilder; import com.baomidou.mybatisplus.generator.config.po.TableInfo; import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport; import io.swagger.v3.oas.annotations.Operation; import io.swagger.v3.oas.annotations.Parameter; import io.swagger.v3.oas.annotations.tags.Tag; import jakarta.validation.Valid; import lombok.AllArgsConstructor; import org.springblade.core.boot.ctrl.BladeController; import org.springblade.core.mp.support.Condition; import org.springblade.core.mp.support.Query; import org.springblade.core.secure.annotation.IsAdministrator; import org.springblade.core.tool.api.R; import org.springblade.core.tool.utils.Func; import org.springblade.core.tool.utils.StringPool; import org.springblade.core.tool.utils.StringUtil; import org.springblade.develop.pojo.entity.Datasource; import org.springblade.develop.pojo.entity.Model; import org.springblade.develop.pojo.entity.ModelPrototype; import org.springblade.develop.service.IDatasourceService; import org.springblade.develop.service.IModelPrototypeService; import org.springblade.develop.service.IModelService; import org.springframework.web.bind.annotation.*; import java.util.List; import java.util.stream.Collectors; /** * 数据模型表 控制器 * * @author Chill */ @RestController @AllArgsConstructor @IsAdministrator @RequestMapping("/model") @Tag(name = "数据模型表", description = "数据模型表接口") public class ModelController extends BladeController { private final IModelService modelService; private final IModelPrototypeService modelPrototypeService; private final IDatasourceService datasourceService; /** * 详情 */ @GetMapping("/detail") @ApiOperationSupport(order = 1) @Operation(summary = "详情", description = "传入model") public R detail(Model model) { Model detail = modelService.getOne(Condition.getQueryWrapper(model)); return R.data(detail); } /** * 分页 数据模型表 */ @GetMapping("/list") @ApiOperationSupport(order = 2) @Operation(summary = "分页", description = "传入model") public R> list(Model model, Query query) { IPage pages = modelService.page(Condition.getPage(query), Condition.getQueryWrapper(model)); return R.data(pages); } /** * 新增 数据模型表 */ @PostMapping("/save") @ApiOperationSupport(order = 3) @Operation(summary = "新增", description = "传入model") public R save(@Valid @RequestBody Model model) { return R.status(modelService.save(model)); } /** * 修改 数据模型表 */ @PostMapping("/update") @ApiOperationSupport(order = 4) @Operation(summary = "修改", description = "传入model") public R update(@Valid @RequestBody Model model) { return R.status(modelService.updateById(model)); } /** * 新增或修改 数据模型表 */ @PostMapping("/submit") @ApiOperationSupport(order = 5) @Operation(summary = "新增或修改", description = "传入model") public R submit(@Valid @RequestBody Model model) { boolean temp = modelService.saveOrUpdate(model); if (temp) { return R.data(model); } else { return R.status(Boolean.FALSE); } } /** * 删除 数据模型表 */ @PostMapping("/remove") @ApiOperationSupport(order = 6) @Operation(summary = "逻辑删除", description = "传入ids") public R remove(@Parameter(description = "主键集合", required = true) @RequestParam String ids) { return R.status(modelService.delete(Func.toLongList(ids))); } /** * 模型列表 */ @GetMapping("/select") @ApiOperationSupport(order = 7) @Operation(summary = "模型列表", description = "模型列表") public R> select() { List list = modelService.list(); list.forEach(model -> model.setModelName(model.getModelTable() + StringPool.COLON + StringPool.SPACE + model.getModelName())); return R.data(list); } /** * 获取物理表列表 */ @GetMapping("/table-list") @ApiOperationSupport(order = 8) @Operation(summary = "物理表列表", description = "传入datasourceId") public R> tableList(Long datasourceId) { Datasource datasource = datasourceService.getById(datasourceId); ConfigBuilder config = modelPrototypeService.getConfigBuilder(datasource); List tableInfoList = config.getTableInfoList().stream() .filter(tableInfo -> !StringUtil.startsWithIgnoreCase(tableInfo.getName(), "ACT_") && !StringUtil.startsWithIgnoreCase(tableInfo.getName(), "FLW_")) .map(tableInfo -> tableInfo.setComment(tableInfo.getName() + StringPool.COLON + tableInfo.getComment())) .collect(Collectors.toList()); return R.data(tableInfoList); } /** * 获取物理表信息 */ @GetMapping("/table-info") @ApiOperationSupport(order = 9) @Operation(summary = "物理表信息", description = "传入model信息") public R tableInfo(Long modelId, String tableName, Long datasourceId) { if (StringUtil.isBlank(tableName)) { Model model = modelService.getById(modelId); tableName = model.getModelTable(); } TableInfo tableInfo = modelPrototypeService.getTableInfo(tableName, datasourceId); return R.data(tableInfo); } /** * 获取字段信息 */ @GetMapping("/model-prototype") @ApiOperationSupport(order = 10) @Operation(summary = "物理表字段信息", description = "传入modelId与datasourceId") public R modelPrototype(Long modelId, Long datasourceId) { List modelPrototypeList = modelPrototypeService.list(Wrappers.query().lambda().eq(ModelPrototype::getModelId, modelId)); if (!modelPrototypeList.isEmpty()) { return R.data(modelPrototypeList); } Model model = modelService.getById(modelId); String tableName = model.getModelTable(); TableInfo tableInfo = modelPrototypeService.getTableInfo(tableName, datasourceId); if (tableInfo != null) { return R.data(tableInfo.getFields()); } else { return R.fail("未获得相关表信息"); } } }