分组相关接口

This commit is contained in:
even 2025-07-15 17:39:10 +08:00
parent e07de3d7ad
commit 355673e532
15 changed files with 226 additions and 140 deletions

View File

@ -1,17 +1,16 @@
package cd.casic.ci.api;
import cd.casic.ci.process.dto.req.group.GroupQueryReq;
import cd.casic.ci.process.dto.req.group.GroupReq;
import cd.casic.ci.process.dto.resp.group.GroupResp;
import cd.casic.ci.process.dto.req.group.GroupAddReq;
import cd.casic.ci.process.dto.req.group.GroupListReq;
import cd.casic.ci.process.dto.req.group.GroupUpdateReq;
import cd.casic.ci.process.dto.resp.group.GroupListResp;
import cd.casic.ci.process.process.dataObject.pipgroup.PipGroup;
import cd.casic.ci.process.process.service.group.GroupService;
import cd.casic.framework.commons.pojo.CommonResult;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import jakarta.validation.Valid;
import org.jetbrains.annotations.NotNull;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import jakarta.annotation.Resource;
import org.springframework.web.bind.annotation.*;
import java.util.ArrayList;
import java.util.List;
@ -26,61 +25,25 @@ import java.util.List;
@RestController
@RequestMapping("/group")
public class GroupController {
@PostMapping(path="/createGroup")
public CommonResult<String> createGroup(@RequestBody @NotNull @Valid GroupReq groupReq){
// String pipelineAuthHostId = groupService.createGroup(group);
String envId = "1";
return CommonResult.success(envId);
}
@PostMapping(path="/deleteGroup")
public CommonResult<Void> deleteGroup(@NotNull String groupId){
// groupService.deleteGroup(groupId);
@Resource
private GroupService groupService;
@PostMapping("/addGroup")
public CommonResult<Void> addGroup(@RequestBody GroupAddReq req){
groupService.addGroup(req);
return CommonResult.success();
}
@PostMapping(path="/findGroupList")
public CommonResult<List<GroupResp>> findGroupList(@NotNull GroupQueryReq query){
// List<Group> groupList = groupService.findGroupList(groupQuery);
List<GroupResp> groupRespList = new ArrayList<>(0);
GroupResp groupResp = new GroupResp();
groupResp.setId("1");
groupResp.setGroupName("test数据交互测试");
groupRespList.add(groupResp);
return CommonResult.success(groupRespList);
}
@PostMapping(path="/updateGroup")
public CommonResult<Void> updateGroup(@RequestBody @NotNull @Valid GroupReq groupReq){
// this.groupService.updateGroup(group);
@PostMapping("/editGroup")
public CommonResult<Void> editGroup(@RequestBody GroupUpdateReq req){
groupService.editGroup(req);
return CommonResult.success();
}
@PostMapping(path="/findGroupPage")
public CommonResult<Page<GroupResp>> findGroupPage(@RequestBody @NotNull @Valid GroupQueryReq query){
// Pagination<Group> groupPage = groupService.findGroupPage(groupQuery);
Page<GroupResp> groupRespPage = new Page<>();
List<GroupResp> groupRespList = new ArrayList<>(0);
GroupResp groupResp = new GroupResp();
groupResp.setId("1");
groupResp.setGroupName("test数据交互测试");
groupRespList.add(groupResp);
groupRespPage.setRecords(groupRespList);
return CommonResult.success(groupRespPage);
@PostMapping("/listGroup")
public CommonResult<List<GroupListResp>> listGroup(@RequestBody GroupListReq req){
return CommonResult.success(groupService.listGroup(req));
}
@DeleteMapping("/deleteGroup/{id}")
public CommonResult<Void> deleteGroup(@PathVariable String id){
groupService.deleteGroup(id);
return CommonResult.success();
}
}

View File

@ -0,0 +1,6 @@
package cd.casic.ci.process.constant;
public class PipGroupConstant {
public static final String GROUP_TYPE_PROJECT="PROJECT";
public static final String GROUP_TYPE_PERSON="PERSON";
}

View File

@ -0,0 +1,12 @@
package cd.casic.ci.process.dto.req.group;
import lombok.Data;
@Data
public class GroupAddReq {
private String groupName;
/**
* PERSON-个人可见PROJECT-项目可见
* */
private String type;
}

View File

@ -0,0 +1,8 @@
package cd.casic.ci.process.dto.req.group;
import lombok.Data;
@Data
public class GroupListReq {
private String groupName;
}

View File

@ -1,22 +0,0 @@
package cd.casic.ci.process.dto.req.group;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import lombok.Data;
/**
* @ClassName GroupQueryReq
* @Author hopeli
* @Date 2025/5/10 11:50
* @Version 1.0
*/
@Data
public class GroupQueryReq {
// 环境名称
private String groupName;
// 用户ID
private String userId;
//@ApiProperty(name ="pageParam",desc = "分页参数")
private Page pageParam= new Page();
}

View File

@ -1,28 +0,0 @@
package cd.casic.ci.process.dto.req.group;
import cd.casic.framework.commons.dataobject.User;
import lombok.Data;
/**
* @ClassName GroupReq
* @Author hopeli
* @Date 2025/5/10 11:47
* @Version 1.0
*/
@Data
public class GroupReq {
// id
private String id;
// 环境名称
private String groupName;
// 创建时间
private String createTime;
private User user;
// 说明
private String detail;
}

View File

@ -0,0 +1,13 @@
package cd.casic.ci.process.dto.req.group;
import lombok.Data;
@Data
public class GroupUpdateReq {
private String id;
private String groupName;
/**
* PERSON-个人可见PROJECT-项目可见
* */
private String type;
}

View File

@ -0,0 +1,14 @@
package cd.casic.ci.process.dto.resp.group;
import lombok.Data;
@Data
public class GroupListResp {
private String id;
private String groupName;
/**
* PERSON-个人可见PROJECT-项目可见
* */
private String type;
private Integer count;
}

View File

@ -1,28 +0,0 @@
package cd.casic.ci.process.dto.resp.group;
import cd.casic.framework.commons.dataobject.User;
import lombok.Data;
/**
* @ClassName GroupResp
* @Author hopeli
* @Date 2025/5/10 11:47
* @Version 1.0
*/
@Data
public class GroupResp {
// id
private String id;
// 环境名称
private String groupName;
// 创建时间
private String createTime;
private User user;
// 说明
private String detail;
}

View File

@ -0,0 +1,29 @@
package cd.casic.ci.process.process.converter;
import cd.casic.ci.process.dto.req.group.GroupAddReq;
import cd.casic.ci.process.dto.req.group.GroupUpdateReq;
import cd.casic.ci.process.dto.req.pipeline.PipelineCreateReq;
import cd.casic.ci.process.dto.req.pipeline.PipelineUpdateReq;
import cd.casic.ci.process.dto.resp.group.GroupListResp;
import cd.casic.ci.process.dto.resp.pipeline.PipelineFindResp;
import cd.casic.ci.process.process.dataObject.pipeline.PipPipeline;
import cd.casic.ci.process.process.dataObject.pipgroup.PipGroup;
import org.mapstruct.Mapper;
import org.mapstruct.factory.Mappers;
import java.util.List;
/**
* @author HopeLi
* @version v1.0
* @ClassName PipelineConverter
* @Date: 2025/5/13 14:39
* @Description:
*/
@Mapper(componentModel = "spring")
public interface GroupConverter {
GroupConverter INSTANCE = Mappers.getMapper(GroupConverter.class);
public PipGroup reqToDto(GroupAddReq req);
public PipGroup reqToDto(GroupUpdateReq req);
List<GroupListResp> dtoListToResp(List<PipGroup> groupList);
}

View File

@ -0,0 +1,12 @@
package cd.casic.ci.process.process.dao.pipeline;
import cd.casic.ci.process.dto.resp.group.GroupListResp;
import cd.casic.ci.process.process.dataObject.pipgroup.PipGroup;
import cd.casic.framework.mybatis.core.mapper.BaseMapperX;
import org.apache.ibatis.annotations.Param;
import java.util.List;
public interface PipGroupDao extends BaseMapperX<PipGroup> {
List<GroupListResp> getList(@Param("groupName") String groupName, @Param("userId")String userId);
}

View File

@ -0,0 +1,16 @@
package cd.casic.ci.process.process.dataObject.pipgroup;
import cd.casic.framework.commons.dataobject.BaseDO;
import lombok.Data;
import lombok.EqualsAndHashCode;
@EqualsAndHashCode(callSuper = true)
@Data
public class PipGroup extends BaseDO {
private String id;
private String groupName;
/**
* PERSON-个人可见PROJECT-项目可见
* */
private String type;
}

View File

@ -0,0 +1,20 @@
package cd.casic.ci.process.process.service.group;
import cd.casic.ci.process.dto.req.group.GroupAddReq;
import cd.casic.ci.process.dto.req.group.GroupListReq;
import cd.casic.ci.process.dto.req.group.GroupUpdateReq;
import cd.casic.ci.process.dto.resp.group.GroupListResp;
import cd.casic.ci.process.process.dataObject.pipgroup.PipGroup;
import com.baomidou.mybatisplus.extension.service.IService;
import java.util.List;
/**
* 流水线分组服务
* */
public interface GroupService extends IService<PipGroup> {
void addGroup(GroupAddReq req);
void editGroup(GroupUpdateReq req);
List<GroupListResp> listGroup(GroupListReq req);
void deleteGroup(String id);
}

View File

@ -0,0 +1,45 @@
package cd.casic.ci.process.process.service.group.impl;
import cd.casic.ci.process.dto.req.group.GroupAddReq;
import cd.casic.ci.process.dto.req.group.GroupListReq;
import cd.casic.ci.process.dto.req.group.GroupUpdateReq;
import cd.casic.ci.process.dto.resp.group.GroupListResp;
import cd.casic.ci.process.process.converter.GroupConverter;
import cd.casic.ci.process.process.dao.pipeline.PipGroupDao;
import cd.casic.ci.process.process.dataObject.pipgroup.PipGroup;
import cd.casic.ci.process.process.service.group.GroupService;
import cd.casic.ci.process.util.WebFrameworkUtils;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import jakarta.annotation.Resource;
import org.springframework.stereotype.Service;
import java.util.List;
@Service
public class GroupServiceImpl extends ServiceImpl<PipGroupDao, PipGroup> implements GroupService {
@Resource
private GroupConverter converter;
@Resource
private PipGroupDao groupDao;
@Override
public void addGroup(GroupAddReq req) {
PipGroup pipGroup = converter.reqToDto(req);
save(pipGroup);
}
@Override
public void EditGroup(GroupUpdateReq req) {
PipGroup pipGroup = converter.reqToDto(req);
updateById(pipGroup);
}
@Override
public List<GroupListResp> listGroup(GroupListReq req) {
// 查询数量
return groupDao.getList(req.getGroupName(), WebFrameworkUtils.getLoginUserIdStr());
}
@Override
public void deleteGroup(String id) {
removeById(id);
}
}

View File

@ -0,0 +1,26 @@
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="cd.casic.ci.process.process.dao.pipeline.PipGroupDao">
<!-- 这里暂时没有任何SQL方法 -->
<select id="getList" resultType="cd.casic.ci.process.dto.resp.group.GroupListResp">
SELECT * FROM
(SELECT * FROM pip_group
UNION ALL
(SELECT null AS id,
"未分组" AS group_name,
"PROJECT" AS type ,
"" AS creator,
NOW() AS create_time,
NOW() AS update_time,
"" AS updater)
) pg
LEFT JOIN
(SELECT group_id,COUNT(*) count FROM pip_pipeline GROUP BY group_id) pl
ON ((pg.id = pl.group_id ) OR (ISNULL(pl.group_id) AND ISNULL(pl.group_id)))
WHERE pg.`name` LIKE #{groupName} AND ((pg.creator = #{userId} AND pg.type = 'PERSON') OR (pg.type = 'PROJECT'))
</select>
</mapper>