From 43a8e9281c71f21b0e683e63def386d1ec0209bd Mon Sep 17 00:00:00 2001 From: wyu <kknd09321@nate.com> Date: 일, 05 12월 2021 17:44:21 +0900 Subject: [PATCH] Merge branch 'master' of http://192.168.0.25:9001/r/owl-kisa --- src/main/java/kr/wisestone/owl/service/impl/IssueServiceImpl.java | 297 +++++++++++++++++++------- src/main/java/kr/wisestone/owl/vo/IssueVo.java | 17 + src/main/java/kr/wisestone/owl/service/impl/WidgetServiceImpl.java | 12 src/main/java/kr/wisestone/owl/service/impl/CustomFieldApiOverlapServiceImpl.java | 3 src/main/java/kr/wisestone/owl/data/CheckIssueData.java | 93 ++++++++ src/main/java/kr/wisestone/owl/service/IssueHistoryService.java | 6 src/main/java/kr/wisestone/owl/service/ProjectRoleUserService.java | 2 src/main/webapp/scripts/app/issue/issueDetail.controller.js | 3 src/main/java/kr/wisestone/owl/service/impl/IssueCustomFieldValueServiceImpl.java | 9 src/main/java/kr/wisestone/owl/service/impl/UserWorkspaceServiceImpl.java | 7 src/main/java/kr/wisestone/owl/service/impl/ProjectServiceImpl.java | 40 ++- src/main/resources/system_prod.properties | 4 src/main/java/kr/wisestone/owl/service/UserWorkspaceService.java | 2 src/main/java/kr/wisestone/owl/service/IssueService.java | 6 src/main/java/kr/wisestone/owl/domain/IssueUser.java | 2 src/main/java/kr/wisestone/owl/service/impl/ProjectRoleUserServiceImpl.java | 4 src/main/java/kr/wisestone/owl/web/form/IssueApiForm.java | 9 src/main/java/kr/wisestone/owl/web/form/IssueForm.java | 6 src/main/java/kr/wisestone/owl/vo/IssueDownVo.java | 93 ++++++++ src/main/java/kr/wisestone/owl/service/impl/IssueHistoryServiceImpl.java | 18 + 20 files changed, 509 insertions(+), 124 deletions(-) diff --git a/src/main/java/kr/wisestone/owl/data/CheckIssueData.java b/src/main/java/kr/wisestone/owl/data/CheckIssueData.java new file mode 100644 index 0000000..8933cf0 --- /dev/null +++ b/src/main/java/kr/wisestone/owl/data/CheckIssueData.java @@ -0,0 +1,93 @@ +package kr.wisestone.owl.data; + +import kr.wisestone.owl.config.CommonConfiguration; +import kr.wisestone.owl.domain.*; +import kr.wisestone.owl.service.*; +import kr.wisestone.owl.util.ConvertUtil; +import kr.wisestone.owl.web.form.IssueForm; +import org.springframework.beans.factory.annotation.Autowired; + + +// issue �쑀�슚�꽦 泥댄겕�슜 �겢�옒�뒪 +public class CheckIssueData { + Issue issue; + IssueStatus oldIssueStatus; + IssueStatus newIssueStatus; + Project project; + IssueType issueType; + Priority priority; + Severity severity; + + public CheckIssueData() {} + + public Issue getIssue() { + return issue; + } + + public void setIssue(Issue issue) { + this.issue = issue; + } + + public IssueStatus getOldIssueStatus() { + return oldIssueStatus; + } + + public void setOldIssueStatus(IssueStatus oldIssueStatus) { + this.oldIssueStatus = oldIssueStatus; + } + + public IssueStatus getNewIssueStatus() { + return newIssueStatus; + } + + public void setNewIssueStatus(IssueStatus newIssueStatus) { + this.newIssueStatus = newIssueStatus; + } + + public Project getProject() { + return project; + } + + public void setProject(Project project) { + this.project = project; + } + + public IssueType getIssueType() { + return issueType; + } + + public void setIssueType(IssueType issueType) { + this.issueType = issueType; + } + + public Priority getPriority() { + return priority; + } + + public void setPriority(Priority priority) { + this.priority = priority; + } + + public Severity getSeverity() { + return severity; + } + + public void setSeverity(Severity severity) { + this.severity = severity; + } + + // 蹂�寃쎈맂 媛� �꽕�젙 + public Issue SetIssue(IssueForm issueForm) { + Issue issue = this.getIssue(); + ConvertUtil.copyProperties(issueForm, issue, "id"); + issue.setProject(getProject()); + issue.setIssueStatus(getNewIssueStatus()); + issue.setIssueType(getIssueType()); + issue.setPriority(getPriority()); + issue.setSeverity(getSeverity()); + issue.setStartDate(issueForm.getStartDate()); + issue.setCompleteDate(issueForm.getCompleteDate()); + + return issue; + } +} diff --git a/src/main/java/kr/wisestone/owl/domain/IssueUser.java b/src/main/java/kr/wisestone/owl/domain/IssueUser.java index 3815310..3a8bcdf 100644 --- a/src/main/java/kr/wisestone/owl/domain/IssueUser.java +++ b/src/main/java/kr/wisestone/owl/domain/IssueUser.java @@ -15,7 +15,7 @@ @JoinColumn(name = "user_id") private User user; - @ManyToOne(fetch = FetchType.LAZY) + @ManyToOne(fetch = FetchType.EAGER) @JoinColumn(name = "issue_id") private Issue issue; diff --git a/src/main/java/kr/wisestone/owl/service/IssueHistoryService.java b/src/main/java/kr/wisestone/owl/service/IssueHistoryService.java index 8f1e445..5813844 100644 --- a/src/main/java/kr/wisestone/owl/service/IssueHistoryService.java +++ b/src/main/java/kr/wisestone/owl/service/IssueHistoryService.java @@ -1,5 +1,6 @@ package kr.wisestone.owl.service; +import kr.wisestone.owl.data.CheckIssueData; import kr.wisestone.owl.domain.*; import kr.wisestone.owl.domain.enumType.IssueHistoryType; import kr.wisestone.owl.service.impl.IssueHistoryServiceImpl; @@ -28,7 +29,8 @@ List<IssueHistoryVo> findIssueHistory(Long issueId); - StringBuilder detectIssueChange(Issue issue, IssueForm issueForm, Project project, IssueStatus issueStatus, IssueType issueType, Priority priority, Severity severity, List<MultipartFile> files); + StringBuilder detectIssueChange(Issue issue, IssueForm issueForm, Project project, IssueStatus oldIssueStatus, IssueStatus issueStatus, IssueType issueType, Priority priority, Severity severity, List<MultipartFile> files); + StringBuilder detectIssueChange(IssueForm issueForm, CheckIssueData data, List<MultipartFile> files); void detectProject(Issue issue, IssueForm issueForm, StringBuilder description, Project project); @@ -36,7 +38,7 @@ void detectIssuePriority(Issue issue, IssueForm issueForm, StringBuilder description, Priority priority); - void detectIssueStatus(Issue issue, IssueForm issueForm, StringBuilder description, IssueStatus issueStatus); + void detectIssueStatus(Issue issue, IssueForm issueForm, StringBuilder description, IssueStatus oldIssueStatus, IssueStatus issueStatus); void detectReservationIssueStatus(Issue issue, StringBuilder description, IssueStatus issueStatus); diff --git a/src/main/java/kr/wisestone/owl/service/IssueService.java b/src/main/java/kr/wisestone/owl/service/IssueService.java index ab36a30..c6f4e66 100644 --- a/src/main/java/kr/wisestone/owl/service/IssueService.java +++ b/src/main/java/kr/wisestone/owl/service/IssueService.java @@ -28,7 +28,9 @@ Issue addIssue(User user, IssueForm issueForm, List<MultipartFile> multipartFiles); Issue addApiIssue(IssueApiForm issueApiForm); - Issue modifyIssue(IssueApiForm issueApiForm, List<MultipartFile> files); + List<Issue> modifyIssue(IssueApiForm issueApiForm, List<MultipartFile> files); + + List<IssueVo> findIssue(IssueApiForm issueApiform); List<IssueVo> findIssue(Map<String, Object> resJsonData, IssueCondition condition, Pageable pageable); @@ -47,7 +49,7 @@ void removeIssues(IssueForm issueForm); - void modifyIssueStatus(IssueForm issueForm); + void modifyIssueStatus(IssueForm issueForm, User user); Issue getIssue(Long taskId); diff --git a/src/main/java/kr/wisestone/owl/service/ProjectRoleUserService.java b/src/main/java/kr/wisestone/owl/service/ProjectRoleUserService.java index 8a31799..314344c 100644 --- a/src/main/java/kr/wisestone/owl/service/ProjectRoleUserService.java +++ b/src/main/java/kr/wisestone/owl/service/ProjectRoleUserService.java @@ -20,5 +20,5 @@ Map<String, Object> findProjectManager(Long userId); - boolean checkProjectManager(Project project); + boolean checkProjectManager(Project project, User user); } diff --git a/src/main/java/kr/wisestone/owl/service/UserWorkspaceService.java b/src/main/java/kr/wisestone/owl/service/UserWorkspaceService.java index dbe05f2..ce9d3c7 100644 --- a/src/main/java/kr/wisestone/owl/service/UserWorkspaceService.java +++ b/src/main/java/kr/wisestone/owl/service/UserWorkspaceService.java @@ -35,7 +35,7 @@ UserWorkspace getUserWorkspace(Long id); - boolean checkWorkspaceManager(); + boolean checkWorkspaceManager(User user); List<UserWorkspace> findByWorkspaceId(Long workspaceId); diff --git a/src/main/java/kr/wisestone/owl/service/impl/CustomFieldApiOverlapServiceImpl.java b/src/main/java/kr/wisestone/owl/service/impl/CustomFieldApiOverlapServiceImpl.java index 84bce83..4a483e6 100644 --- a/src/main/java/kr/wisestone/owl/service/impl/CustomFieldApiOverlapServiceImpl.java +++ b/src/main/java/kr/wisestone/owl/service/impl/CustomFieldApiOverlapServiceImpl.java @@ -48,7 +48,8 @@ @Override @Transactional public void find(Map<String, Object> resJsonData, CustomFieldApiOverlapForm form) { - List<CustomFieldApiOverlap> customFieldApiOverlaps = this.find(form.getUserId(), form.getIssueTypeId()); + Long userId = this.webAppUtil.getLoginId(); + List<CustomFieldApiOverlap> customFieldApiOverlaps = this.find(userId, form.getIssueTypeId()); if (customFieldApiOverlaps != null && customFieldApiOverlaps.size() > 0) { List<CustomFieldApiOverlapVo> customFieldApiOverlapVos = Lists.newArrayList(); diff --git a/src/main/java/kr/wisestone/owl/service/impl/IssueCustomFieldValueServiceImpl.java b/src/main/java/kr/wisestone/owl/service/impl/IssueCustomFieldValueServiceImpl.java index f8e1f52..6f556c6 100644 --- a/src/main/java/kr/wisestone/owl/service/impl/IssueCustomFieldValueServiceImpl.java +++ b/src/main/java/kr/wisestone/owl/service/impl/IssueCustomFieldValueServiceImpl.java @@ -1,9 +1,11 @@ package kr.wisestone.owl.service.impl; import com.google.common.collect.Lists; +import kr.wisestone.owl.constant.MsgConstants; import kr.wisestone.owl.domain.*; import kr.wisestone.owl.domain.enumType.CustomFieldType; import kr.wisestone.owl.domain.enumType.IssueHistoryType; +import kr.wisestone.owl.exception.OwlRuntimeException; import kr.wisestone.owl.mapper.IssueCustomFieldValueMapper; import kr.wisestone.owl.repository.IssueCustomFieldValueRepository; import kr.wisestone.owl.service.*; @@ -76,7 +78,12 @@ } if (issueCustomFieldValues.size() > 0) { - this.issueCustomFieldValueRepository.saveAll(issueCustomFieldValues); + try { + this.issueCustomFieldValueRepository.saveAll(issueCustomFieldValues); + } catch (Exception ex) { + throw new OwlRuntimeException( + this.messageAccessor.getMessage(MsgConstants.CUSTOM_FIELD_NOT_EXIST)); + } } } diff --git a/src/main/java/kr/wisestone/owl/service/impl/IssueHistoryServiceImpl.java b/src/main/java/kr/wisestone/owl/service/impl/IssueHistoryServiceImpl.java index b6b4725..ecf6b95 100644 --- a/src/main/java/kr/wisestone/owl/service/impl/IssueHistoryServiceImpl.java +++ b/src/main/java/kr/wisestone/owl/service/impl/IssueHistoryServiceImpl.java @@ -4,6 +4,7 @@ import kr.wisestone.owl.constant.Constants; import kr.wisestone.owl.constant.ElasticSearchConstants; import kr.wisestone.owl.constant.MsgConstants; +import kr.wisestone.owl.data.CheckIssueData; import kr.wisestone.owl.domain.*; import kr.wisestone.owl.domain.enumType.CustomFieldType; import kr.wisestone.owl.domain.enumType.IssueHistoryType; @@ -316,7 +317,13 @@ // �씠�뒋 蹂�寃� �궡�뿭�쓣 異붿텧�븳�떎. @Override - public StringBuilder detectIssueChange(Issue issue, IssueForm issueForm, Project project, IssueStatus issueStatus, IssueType issueType, Priority priority, Severity severity, List<MultipartFile> files) { + public StringBuilder detectIssueChange(IssueForm issueForm, CheckIssueData data, List<MultipartFile> files) { + return this.detectIssueChange(data.getIssue(), issueForm, data.getProject(), data.getOldIssueStatus(), data.getNewIssueStatus(), data.getIssueType(), data.getPriority(), data.getSeverity(), files); + } + + // �씠�뒋 蹂�寃� �궡�뿭�쓣 異붿텧�븳�떎. + @Override + public StringBuilder detectIssueChange(Issue issue, IssueForm issueForm, Project project, IssueStatus oldIssueStatus, IssueStatus issueStatus, IssueType issueType, Priority priority, Severity severity, List<MultipartFile> files) { StringBuilder description = new StringBuilder(); // �씠�뒋 �봽濡쒖젥�듃 蹂�寃� �젙蹂대�� 湲곕줉�븳�떎. @@ -326,7 +333,7 @@ // �씠�뒋 �슦�꽑�닚�쐞 蹂�寃� �젙蹂대�� 湲곕줉�븳�떎. this.detectIssuePriority(issue, issueForm, description, priority); // �씠�뒋 �긽�깭 蹂�寃� �젙蹂대�� 湲곕줉�븳�떎. - this.detectIssueStatus(issue, issueForm, description, issueStatus); + this.detectIssueStatus(issue, issueForm, description, oldIssueStatus, issueStatus); // �씠�뒋 ���엯 蹂�寃� �젙蹂대�� 湲곕줉�븳�떎. this.detectIssueType(issue, issueForm, description, issueType); // �씠�뒋�뿉 泥⑤��맂 �뙆�씪�뿉 ���빐 蹂�寃� �젙蹂대�� 湲곕줉�븳�떎. @@ -407,11 +414,12 @@ // �씠�뒋 �긽�깭 蹂�寃� �젙蹂대�� 湲곕줉�븳�떎. @Override - public void detectIssueStatus(Issue issue, IssueForm issueForm, StringBuilder description, IssueStatus issueStatus) { - if (!issue.getIssueStatus().getId().equals(issueForm.getIssueStatusId())) { + @Transactional + public void detectIssueStatus(Issue issue, IssueForm issueForm, StringBuilder description, IssueStatus oldIssueStatus, IssueStatus issueStatus) { + if (!oldIssueStatus.getId().equals(issueForm.getIssueStatusId())) { String title = "<span translate=\"common.updateHasStatus\">�긽�깭媛� 蹂�寃쎈릺�뿀�뒿�땲�떎.</span>"; // �씠�젰 �젙蹂대�� html �깭洹몃줈 留뚮뱾�뼱 以��떎. - this.makeIssueHistoryHtml(description, title, issue.getIssueStatus().getName(), issueStatus.getName()); + this.makeIssueHistoryHtml(description, title, oldIssueStatus.getName(), issueStatus.getName()); // �씠�뒋 �쐞�뿕 愿�由ъ뿉 �긽�깭 蹂�寃� �젙蹂대�� �뾽�뜲�씠�듃�븳�떎. - �떞�떦�옄 蹂�寃� this.issueRiskService.modifyIssueRisk(issue, true, false, issueForm.getIssueStatusId()); diff --git a/src/main/java/kr/wisestone/owl/service/impl/IssueServiceImpl.java b/src/main/java/kr/wisestone/owl/service/impl/IssueServiceImpl.java index f3aeac1..eb5524e 100644 --- a/src/main/java/kr/wisestone/owl/service/impl/IssueServiceImpl.java +++ b/src/main/java/kr/wisestone/owl/service/impl/IssueServiceImpl.java @@ -7,6 +7,7 @@ import kr.wisestone.owl.constant.ElasticSearchConstants; import kr.wisestone.owl.constant.MsgConstants; import kr.wisestone.owl.constant.UsePartner; +import kr.wisestone.owl.data.CheckIssueData; import kr.wisestone.owl.domain.*; import kr.wisestone.owl.domain.enumType.CustomFieldType; import kr.wisestone.owl.domain.enumType.EmailType; @@ -52,9 +53,6 @@ private IssueRepository issueRepository; @Autowired - private IssueTableConfigService issueTableConfigService; - - @Autowired private ProjectService projectService; @Autowired @@ -77,15 +75,6 @@ @Autowired private ApiTokenService apiTokenService; - - @Autowired - private CompanyFieldService companyFieldService; - - @Autowired - private IspFieldService ispFieldService; - - @Autowired - private HostingFieldService hostingFieldService; @Autowired private CommonConfiguration configuration; @@ -157,6 +146,9 @@ private UserWorkspaceService userWorkspaceService; @Autowired + private WorkflowDepartmentService workflowDepartmentService; + + @Autowired private IssueRelationService issueRelationService; @Autowired @@ -199,6 +191,28 @@ if (issueType == null){ throw new OwlRuntimeException(this.messageAccessor.getMessage(MsgConstants.API_PARAMETER_ISSUE_TYPE_ERROR)); } + + Workflow workflow = issueType.getWorkflow(); + + // �씠�뒋 �긽�깭媛� 吏��젙�릺�뼱 �엳吏� �븡�쓣 寃쎌슦 珥덇린媛믪쑝濡� 吏��젙 + if (issueApiForm.getIssueStatusId() == null) { + List<IssueStatusVo> issueStatusVos = issueStatusService.findByWorkflowId(workflow.getId()); + IssueStatusVo issueStatusVo = issueStatusVos.get(0); + issueApiForm.setIssueStatusId(issueStatusVo.getId()); + } + + // �썙�겕�뵆濡쒖슦 �긽�깭�뿉 �뵲瑜� �떞�떦遺��꽌 媛��졇�삤湲� + if (issueApiForm.getIssueStatusId() != null) { + WorkflowDepartmentCondition workflowDepartmentCondition = new WorkflowDepartmentCondition(); + workflowDepartmentCondition.setIssueStatusId(issueApiForm.getIssueStatusId()); + workflowDepartmentCondition.setWorkflowId(workflow.getId()); + List<WorkflowDepartmentVo> workflowDepartmentVos = this.workflowDepartmentService.find(workflowDepartmentCondition); + + for (WorkflowDepartmentVo workflowDepartmentVo : workflowDepartmentVos) { + issueForm.addDepartmentId(workflowDepartmentVo.getDepartmentVo().getId()); + } + } + // �봽濡쒖젥�듃 �엯�젰 Project project = issueType.getProject(); @@ -341,7 +355,7 @@ // �떞�떦�옄 吏��젙 //this.issueUserService.modifyIssueUser(issue, project.getWorkspace(), issueForm.getUserIds()); // �떞�떦遺��꽌 吏��젙 - this.issueDepartmentService.modifyIssueDepartment(issue, project.getWorkspace(), issueForm.getDepartmentIds()); + this.issueDepartmentService.modifyIssueDepartment(issue, user, project.getWorkspace(), issueForm.getDepartmentIds()); // �뾽泥� �젙蹂� ���옣 this.issueCompanyService.modifyIssueCompanyField(issue, issueForm.getIssueCompanyFields()); // ISP �젙蹂� ���옣 @@ -568,7 +582,8 @@ // �씠�뒋 �븘�씠�뵒 珥덇린�솕 issueCondition.setIssueIds(Lists.newArrayList()); // Map �뿉 �엳�뒗 �뜲�씠�꽣瑜� IssueVo �뜲�씠�꽣濡� 蹂��솚�븳�떎. - this.setMapToIssueVo(results, issueVos, issueCondition); + User user = this.webAppUtil.getLoginUserObject(); + this.setMapToIssueVo(results, issueVos, issueCondition, user); this.setCountDownIssues(results, issueVos); @@ -582,10 +597,10 @@ } private void setCountDownIssues(List<Map<String, Object>> results, List<IssueVo> issueVos) { - int downIssueCount = 0; for (Map<String, Object> result : results){ List<Issue> downIssues = this.issueRepository.findByParentIssueId((Long) result.get("id")); //�븯�쐞�씠�뒋 媛��졇�삤湲� if(downIssues != null && downIssues.size() > 0){ //�긽�쐞�씠�뒋 媛�吏�怨� �엳�뒗 �븷�뱾�씠 �엳�쑝硫� + int downIssueCount = 0; for(Issue downIssue : downIssues){ downIssueCount ++; Long parentIssueId = downIssue.getParentIssue().getId(); @@ -707,7 +722,9 @@ IssueCondition issueCondition = new IssueCondition(); // 寃��깋 議곌굔�쓣 留뚮뱺�떎 - if (!this.makeIssueSearchCondition(issueCondition, projectCondition, pageable)) { + + User user = this.webAppUtil.getLoginUserObject(); + if (!this.makeIssueSearchCondition(user, issueCondition, projectCondition, pageable)) { // �씠�뒋 紐⑸줉�쓣 李얠� 紐삵븷 寃쎌슦 湲곕낯 �젙蹂대줈 由ы꽩�븳�떎. this.notFoundIssueList(resJsonData, pageable); return Lists.newArrayList(); @@ -751,7 +768,7 @@ } // Map �뿉 �엳�뒗 �뜲�씠�꽣瑜� IssueVo �뜲�씠�꽣濡� 蹂��솚�븳�떎. - private void setMapToIssueVo(List<Map<String, Object>> results, List<IssueVo> issueVos, IssueCondition issueCondition) { + private void setMapToIssueVo(List<Map<String, Object>> results, List<IssueVo> issueVos, IssueCondition issueCondition, User user) { for (Map<String, Object> result : results) { IssueVo issueVo = ConvertUtil.convertMapToClass(result, IssueVo.class); issueVos.add(issueVo); @@ -760,7 +777,7 @@ // �씠�뒋 �궗�슜�옄 �젙蹂� 異붽� //this.setIssueUserList(issueVos, issueCondition); - this.setIssueDepartmentList(issueVos, issueCondition); + this.setIssueDepartmentList(issueVos, issueCondition, user); // �벑濡앹옄 �젙蹂� 異붽� this.setRegister(issueVos); // �떞�떦�옄 �젙蹂� �뀑�똿 @@ -807,7 +824,7 @@ } // 寃��깋 議곌굔�쓣 留뚮뱺�떎 - private boolean makeIssueSearchCondition(IssueCondition condition, ProjectCondition projectCondition, Pageable pageable) { + private boolean makeIssueSearchCondition(User user, IssueCondition condition, ProjectCondition projectCondition, Pageable pageable) { if (pageable != null) { condition.setPage(pageable.getPageNumber() * pageable.getPageSize()); condition.setPageSize(pageable.getPageSize()); @@ -825,7 +842,7 @@ // �봽濡쒖젥�듃瑜� �꽑�깮�븯吏� �븡�븯�쑝硫� �빐�떦 �뾽臾� 怨듦컙�뿉�꽌 李몄뿬�븯怨� �엳�뒗 �봽濡쒖젥�듃瑜� 李얜뒗�떎. if (condition.getProjectIds().size() < 1) { List<Map<String, Object>> projects = null; - if (this.userWorkspaceService.checkWorkspaceManager()) { + if (this.userWorkspaceService.checkWorkspaceManager(user)) { projects = this.projectMapper.findByWorkspaceManagerAll(projectCondition); } else { projects = this.projectService.findByWorkspaceIdAndIncludeProjectAll(projectCondition); @@ -903,7 +920,7 @@ } // �씠�뒋 �떞�떦�옄 �젙蹂대�� �뀑�똿�븳�떎. - private void setIssueUserList(List<IssueVo> issueVos, IssueCondition issueCondition) { + private void setIssueUserList(List<IssueVo> issueVos, IssueCondition issueCondition, User user) { if (issueVos.size() < 1) { return; } @@ -934,14 +951,14 @@ } // �씠�뒋 �닔�젙 沅뚰븳�쓣 媛뽮퀬 �엳�뒗吏� �솗�씤 - if (this.checkHasPermission(issueVo, issueVo.getUserVos())) { + if (this.checkHasPermission(issueVo, issueVo.getUserVos(), user)) { issueVo.setModifyPermissionCheck(Boolean.TRUE); } } } // �씠�뒋 �떞�떦遺��꽌 �젙蹂대�� �뀑�똿�븳�떎. - private void setIssueDepartmentList(List<IssueVo> issueVos, IssueCondition issueCondition) { + private void setIssueDepartmentList(List<IssueVo> issueVos, IssueCondition issueCondition, User user) { if (issueVos.size() < 1) { return; } @@ -971,7 +988,7 @@ } // �씠�뒋 �닔�젙 沅뚰븳�쓣 媛뽮퀬 �엳�뒗吏� �솗�씤 - if (this.checkHasPermission(issueVo, issueVo.getUserVos())) { + if (this.checkHasPermission(issueVo, issueVo.getUserVos(), user)) { issueVo.setModifyPermissionCheck(Boolean.TRUE); } } @@ -1021,9 +1038,25 @@ // �븯�쐞 �씠�뒋 �젙蹂대�� �뀑�똿�븳�떎 private void setDownIssues(Issue issue, IssueVo issueVo) { List<Issue> downIssues = this.issueRepository.findByParentIssueId(issue.getId()); + /*if(issueVo != null && downIssues.size()>0){ + for(Issue downIssue : downIssues){ + IssueVo downIssueVo = ConvertUtil.copyProperties(downIssue, IssueVo.class); + IssueDownVo issueDownVo = ConvertUtil.copyProperties(downIssueVo, IssueDownVo.class); + issueDownVo.setIssueDown(downIssueVo); + issueDownVo.setTitle(downIssue.getTitle()); + issueDownVo.setIssueTypeVo(ConvertUtil.copyProperties(downIssue.getIssueType(), IssueTypeVo.class)); + issueDownVo.setPriorityVo(ConvertUtil.copyProperties(downIssue.getPriority(), PriorityVo.class)); + issueDownVo.setSeverityVo(ConvertUtil.copyProperties(downIssue.getSeverity(), SeverityVo.class)); + this.setRegister(downIssue, downIssueVo); // �벑濡앹옄 + this.setIssueDepartment(downIssue, downIssueVo); // �떞�떦遺��꽌 �젙蹂� �뀑�똿 + this.setIssueCustomFields(downIssue, downIssueVo); // �궗�슜�옄�젙�쓽�븘�뱶 �젙蹂� �꽭�똿 + issueVo.addIssueDownVo(issueDownVo); + } + }*/ + List<IssueVo> downIssueVos = ConvertUtil.convertObjectsToClasses(downIssues, IssueVo.class); List<IssueVo> resultList = new ArrayList<>(); - if(downIssues != null && downIssueVos.size()>0){ + if(downIssueVos != null && downIssueVos.size()>0){ for(IssueVo downIssueVo : downIssueVos){ for(Issue downIssue : downIssues){ downIssueVo.setIssueTypeVo(ConvertUtil.copyProperties(downIssue.getIssueType(), IssueTypeVo.class)); @@ -1035,9 +1068,7 @@ } resultList.add(downIssueVo); } - issueVo.setIssueDownVos(resultList); //�봽濡좏듃�뿉�꽌 List�삎�깭濡� 諛쏆븘以섏꽌 由ъ뒪�듃 �삎�떇�쑝濡� 蹂대궡以� - }else{ - issueVo.setIssueDownVos(null); + issueVo.setIssueDownVos(resultList); } } @@ -1225,13 +1256,42 @@ issueVo.setIssueHistoryVos(this.issueHistoryService.findIssueHistory(issue.getId())); } - // �씠�뒋瑜� �닔�젙�븳�떎 + // �궗�슜�옄 �젙�쓽 �븘�뱶 媛믪씠 媛숈� �씠�뒋 李얘린 @Override - public Issue modifyIssue(IssueApiForm issueApiForm, List<MultipartFile> files) { + @Transactional + public List<IssueVo> findIssue(IssueApiForm issueApiform) { + List<IssueCustomFieldValueForm> issueCustomFieldValueForms = issueApiform.getIssueCustomFieldValues(); + IssueCustomFieldValueCondition issueCustomFieldValueCondition = new IssueCustomFieldValueCondition(); + if (issueCustomFieldValueForms != null && issueCustomFieldValueForms.size() > 0) { + for (IssueCustomFieldValueForm issueCustomFieldValueForm : issueCustomFieldValueForms) { + issueCustomFieldValueCondition.addUseValues(issueCustomFieldValueForm.getUseValue()); + } + } + List<Map<String, Object>> results = this.issueMapper.findByCustomFieldValue(issueCustomFieldValueCondition); + List<IssueVo> issueVos = Lists.newArrayList(); + if (results != null && results.size() > 0) { + issueVos.add(ConvertUtil.convertMapToClass(results.get(0), IssueVo.class)); + } + + return issueVos; + } + + + // �씠�뒋瑜� �닔�젙�븳�떎(api�슜) + @Override + @Transactional + public List<Issue> modifyIssue(IssueApiForm issueApiForm, List<MultipartFile> files) { User user = this.convertToUser(issueApiForm.getToken()); IssueForm issueForm = this.convertToIssueForm(issueApiForm, user); - return this.modifyIssue(user, issueForm, files); + List<IssueVo> issueVos = this.findIssue(issueApiForm); + List<Issue> issue = Lists.newArrayList(); + for (IssueVo issueVo : issueVos) { + issueForm.setId(issueVo.getId()); + issue.add(this.modifyIssueForApi(user, issueForm, files)); + } + + return issue; } // �씠�뒋瑜� �닔�젙�븳�떎. @@ -1242,14 +1302,16 @@ return modifyIssue(user, issueForm, multipartFiles); } - // �씠�뒋瑜� �닔�젙�븳�떎. - @Override - @Transactional - public Issue modifyIssue(User user, IssueForm issueForm, List<MultipartFile> multipartFiles) { + // �닔�젙 �뜲�씠�꽣媛� �쑀�슚�븳吏� �솗�씤 + private CheckIssueData checkIssue(User user, IssueForm issueForm) { + // �궗�슜�븯怨� �엳�뒗 �뾽臾� 怨듦컙�씠 �솢�꽦 �긽�깭�씤吏� �솗�씤�븳�떎. �궗�슜 怨듦컙�뿉�꽌 濡쒓렇�씤�븳 �궗�슜�옄媛� 鍮꾪솢�꽦�씤吏� �솗�씤�븳�떎. this.workspaceService.checkUseWorkspace(user, user.getLastWorkspaceId()); + + Issue issue = this.getIssue(issueForm.getId()); + IssueStatus oldIssueStatus = issue.getIssueStatus(); // �씠�뒋 �닔�젙 沅뚰븳 泥댄겕 - this.verifyIssueModifyPermission(issueForm.getId()); + this.verifyIssueModifyPermission(issue, user); // �봽濡쒖젥�듃 �쑀�슚�꽦 泥댄겕 Project project = this.projectService.getProject(issueForm.getProjectId()); // �씠�뒋 �긽�깭 �쑀�슚�꽦 泥댄겕 @@ -1270,10 +1332,83 @@ // �떞�떦遺��꽌 �쑀�슚�꽦 泥댄겕 this.verifyIssueDepartment(project, issueForm); - Issue issue = this.getIssue(issueForm.getId()); + CheckIssueData checkIssueData = new CheckIssueData(); + checkIssueData.setIssue(issue); + checkIssueData.setProject(project); + checkIssueData.setOldIssueStatus(oldIssueStatus); + checkIssueData.setNewIssueStatus(issueStatus); + checkIssueData.setIssueType(issueType); + checkIssueData.setPriority(priority); + checkIssueData.setSeverity(severity); + + return checkIssueData; + } + + // �씠�뒋 �닔�젙(API�슜) + private Issue modifyIssueForApi(User user, IssueForm issueForm, List<MultipartFile> multipartFiles) { + CheckIssueData checkIssueData = this.checkIssue(user, issueForm); + + Issue issue = checkIssueData.getIssue(); + Project project = checkIssueData.getProject(); + IssueType issueType = checkIssueData.getIssueType(); + IssueStatus oldIssueStatus = checkIssueData.getOldIssueStatus(); + IssueStatus issueStatus = checkIssueData.getNewIssueStatus(); // 蹂�寃� �씠�젰 �젙蹂� 異붿텧 - StringBuilder detectIssueChange = this.issueHistoryService.detectIssueChange(issue, issueForm, project, issueStatus, issueType, priority, severity, multipartFiles); + StringBuilder detectIssueChange = this.issueHistoryService.detectIssueChange(issueForm, checkIssueData, multipartFiles); + + // �봽濡쒖젥�듃媛� 蹂�寃쎈릺硫� �씠�뒋 �꽆踰꾨�� �깉濡� �뵲�빞 �븳�떎. + this.checkChangeProject(checkIssueData.getProject(), issue); + + // �씠�뒋 �쑀�삎�씠 蹂�寃쎈릺�뿀�뒗吏� �솗�씤�븯怨� 蹂�寃쎈릺�뿀�떎硫� �씠�뒋 �긽�깭 �냽�꽦�씠 '��湲�' �씤 �씠�뒋 �긽�깭濡� 援먯껜�븳�떎. + if (this.checkChangeIssueType(issueType, issueStatus, issue)) { + issueStatus = this.issueStatusService.findByIssueStatusTypeIsReady(issueType.getWorkflow()); + // �씠�뒋 �긽�깭 蹂�寃� �씠�젰 �궓湲곌린 - �씠�젰�쓣 �궓湲곌린 �쐞�빐 issueForm �뿉 issueStatus Id 媛믪쓣 ���옣. + issueForm.setIssueStatusId(issueStatus.getId()); + this.issueHistoryService.detectIssueStatus(issue, issueForm, detectIssueChange, oldIssueStatus, issueStatus); + } + + issue = this.saveIssue(issueForm, checkIssueData); + + // �씠�뒋 �씠�젰 �벑濡� + if (!StringUtils.isEmpty(detectIssueChange.toString())) { + this.issueHistoryService.addIssueHistory(issue, user, IssueHistoryType.MODIFY, detectIssueChange.toString()); + } + // �궗�슜�옄 �떆�뒪�뀥 湲곕뒫 �궗�슜 �젙蹂� �닔吏� + UserVo userVo = ConvertUtil.copyProperties(user, UserVo.class); + log.info(ElasticSearchUtil.makeUserActiveHistoryMessage(userVo, ElasticSearchConstants.ISSUE_MODIFY)); + + return issue; + } + + private Issue saveIssue(IssueForm issueForm, CheckIssueData checkIssueData) { + Issue issue = checkIssueData.getIssue(); + ConvertUtil.copyProperties(issueForm, issue, "id"); + issue.setProject(checkIssueData.getProject()); + issue.setIssueStatus(checkIssueData.getNewIssueStatus()); + issue.setIssueType(checkIssueData.getIssueType()); + issue.setPriority(checkIssueData.getPriority()); + issue.setSeverity(checkIssueData.getSeverity()); + issue.setStartDate(issueForm.getStartDate()); + issue.setCompleteDate(issueForm.getCompleteDate()); + + return this.issueRepository.saveAndFlush(issue); + } + + // �씠�뒋瑜� �닔�젙�븳�떎. + @Override + @Transactional + public Issue modifyIssue(User user, IssueForm issueForm, List<MultipartFile> multipartFiles) { + CheckIssueData checkIssueData = this.checkIssue(user, issueForm); + + Issue issue = checkIssueData.getIssue(); + IssueStatus oldIssueStatus = checkIssueData.getOldIssueStatus(); + Project project = checkIssueData.getProject(); + IssueStatus issueStatus = checkIssueData.getNewIssueStatus(); + IssueType issueType = checkIssueData.getIssueType(); + + // 蹂�寃� �씠�젰 �젙蹂� 異붿텧 + StringBuilder detectIssueChange = this.issueHistoryService.detectIssueChange(issueForm, checkIssueData, multipartFiles); // �봽濡쒖젥�듃媛� 蹂�寃쎈릺硫� �씠�뒋 �꽆踰꾨�� �깉濡� �뵲�빞 �븳�떎. this.checkChangeProject(project, issue); @@ -1283,19 +1418,10 @@ issueStatus = this.issueStatusService.findByIssueStatusTypeIsReady(issueType.getWorkflow()); // �씠�뒋 �긽�깭 蹂�寃� �씠�젰 �궓湲곌린 - �씠�젰�쓣 �궓湲곌린 �쐞�빐 issueForm �뿉 issueStatus Id 媛믪쓣 ���옣. issueForm.setIssueStatusId(issueStatus.getId()); - this.issueHistoryService.detectIssueStatus(issue, issueForm, detectIssueChange, issueStatus); + this.issueHistoryService.detectIssueStatus(issue, issueForm, detectIssueChange, oldIssueStatus, issueStatus); } - ConvertUtil.copyProperties(issueForm, issue, "id"); - issue.setProject(project); - issue.setIssueStatus(issueStatus); - issue.setIssueType(issueType); - issue.setPriority(priority); - issue.setSeverity(severity); - issue.setStartDate(issueForm.getStartDate()); - issue.setCompleteDate(issueForm.getCompleteDate()); - - this.issueRepository.saveAndFlush(issue); + issue = this.saveIssue(issueForm, checkIssueData); //this.issueUserService.modifyIssueUser(issue, project.getWorkspace(), issueForm.getUserIds()); // �떞�떦遺��꽌 吏��젙 if(issueForm.getDepartmentIds().size()>0){ @@ -1318,7 +1444,8 @@ this.issueHistoryService.addIssueHistory(issue, user, IssueHistoryType.MODIFY, detectIssueChange.toString()); } // �궗�슜�옄 �떆�뒪�뀥 湲곕뒫 �궗�슜 �젙蹂� �닔吏� - log.info(ElasticSearchUtil.makeUserActiveHistoryMessage(this.webAppUtil.getLoginUser(), ElasticSearchConstants.ISSUE_MODIFY)); + UserVo userVo = ConvertUtil.copyProperties(user, UserVo.class); + log.info(ElasticSearchUtil.makeUserActiveHistoryMessage(userVo, ElasticSearchConstants.ISSUE_MODIFY)); // �뾽泥� �젙蹂� ���옣 this.issueCompanyService.modifyIssueCompanyField(issue, issueForm.getIssueCompanyFields()); @@ -1440,11 +1567,9 @@ } // �씠�뒋 �닔�젙 沅뚰븳 泥댄겕 - private void verifyIssueModifyPermission(Long issueId) { - Issue issue = this.getIssue(issueId); - + private void verifyIssueModifyPermission(Issue issue, User user) { // �씠�뒋 �닔�젙 沅뚰븳�쓣 媛뽮퀬 �엳�뒗吏� �솗�씤 - if (!this.checkHasPermission(ConvertUtil.copyProperties(issue, IssueVo.class), this.getIssueUserVos(issue))) { + if (!this.checkHasPermission(ConvertUtil.copyProperties(issue, IssueVo.class), this.getIssueUserVos(issue), user)) { throw new OwlRuntimeException( this.messageAccessor.getMessage(MsgConstants.ISSUE_NOT_MODIFY_PERMISSION)); } @@ -1454,24 +1579,31 @@ private List<UserVo> getIssueUserVos(Issue issue) { List<UserVo> userVos = Lists.newArrayList(); - for (IssueUser issueUser : issue.getIssueUsers()) { - UserVo userVo = ConvertUtil.copyProperties(issueUser.getUser(), UserVo.class, "password"); - userVos.add(userVo); + Set<IssueUser> issueUsers = issue.getIssueUsers(); + + try { + for (IssueUser issueUser : issueUsers) { + User user = issueUser.getUser(); + UserVo userVo = ConvertUtil.copyProperties(user, UserVo.class, "password"); + userVos.add(userVo); + } + } catch (Exception ex) { + } return userVos; } // �씠�뒋 �닔�젙 沅뚰븳�쓣 媛뽮퀬 �엳�뒗吏� �솗�씤 - private boolean checkHasPermission(IssueVo issueVo, List<UserVo> issueUserVos) { + private boolean checkHasPermission(IssueVo issueVo, List<UserVo> issueUserVos, User user) { boolean hasPermission = false; // �뾽臾� 怨듦컙 愿�由ъ옄�씪 寃쎌슦 �닔�젙 沅뚰븳�쓣 媛뽯뒗�떎. - hasPermission = this.checkIssueModifyPermission(hasPermission, Issue.WORKSPACE_MANAGER, issueVo, null, null); + hasPermission = this.checkIssueModifyPermission(hasPermission, Issue.WORKSPACE_MANAGER, issueVo, null, null, user); // �봽濡쒖젥�듃 愿�由ъ옄�씪 寃쎌슦 �빐�떦 �봽濡쒖젥�듃�뿉 �벑濡앸맂 �씠�뒋�뒗 �닔�젙 沅뚰븳�쓣 媛뽯뒗�떎. - hasPermission = this.checkIssueModifyPermission(hasPermission, Issue.PROJECT_MANAGER, issueVo, null, null); + hasPermission = this.checkIssueModifyPermission(hasPermission, Issue.PROJECT_MANAGER, issueVo, null, null, user); // �씠�뒋 �벑濡앹옄�씪 寃쎌슦 �닔�젙 沅뚰븳�쓣 媛뽯뒗�떎. - hasPermission = this.checkIssueModifyPermission(hasPermission, Issue.REGISTER, issueVo, null, null); + hasPermission = this.checkIssueModifyPermission(hasPermission, Issue.REGISTER, issueVo, null, null, user); // �씠�뒋 �떞�떦�옄�씪 寃쎌슦 �닔�젙 沅뚰븳�쓣 媛뽯뒗�떎. => �떞�떦遺��꽌濡� �닔�젙 - 泥댄겕 //hasPermission = this.checkIssueModifyPermission(hasPermission, Issue.ASSIGNEE, issueVo, issueUserVos); // �떞�떦�옄媛� �뾾�쑝硫� 紐⑤뱺 �궗�슜�옄媛� �닔�젙 沅뚰븳�쓣 媛뽯뒗�떎. @@ -1480,22 +1612,22 @@ } // �씠�뒋 �닔�젙 沅뚰븳�쓣 �솗�씤�븳�떎. - private boolean checkIssueModifyPermission(Boolean hasPermission, String checkType, IssueVo issueVo, List<UserVo> issueUserVos, List<DepartmentVo> issueDepartmentVos) { + private boolean checkIssueModifyPermission(Boolean hasPermission, String checkType, IssueVo issueVo, List<UserVo> issueUserVos, List<DepartmentVo> issueDepartmentVos, User user) { if (!hasPermission) { switch (checkType) { case Issue.WORKSPACE_MANAGER: // �뾽臾� 怨듦컙 愿�由ъ옄 // �뾽臾� 怨듦컙 愿�由ъ옄�씪 寃쎌슦 �닔�젙 沅뚰븳�쓣 媛뽯뒗�떎. - hasPermission = this.userWorkspaceService.checkWorkspaceManager(); + hasPermission = this.userWorkspaceService.checkWorkspaceManager(user); break; case Issue.PROJECT_MANAGER: // �봽濡쒖젥�듃 愿�由ъ옄 Issue issue = this.getIssue(issueVo.getId()); // �봽濡쒖젥�듃 愿�由ъ옄�씪 寃쎌슦 �빐�떦 �봽濡쒖젥�듃�뿉 �벑濡앸맂 �씠�뒋�뒗 �닔�젙 沅뚰븳�쓣 媛뽯뒗�떎. - hasPermission = this.projectRoleUserService.checkProjectManager(issue.getProject()); + hasPermission = this.projectRoleUserService.checkProjectManager(issue.getProject(), user); break; case Issue.REGISTER: // �씠�뒋 �벑濡앹옄 - hasPermission = issueVo.getRegisterId().equals(this.webAppUtil.getLoginId()); + hasPermission = issueVo.getRegisterId().equals(user.getId()); break; case Issue.ASSIGNEE: @@ -1506,7 +1638,7 @@ } // �씠�뒋 �떞�떦�옄 �뿬遺� �솗�씤 for (UserVo issueUserVo : issueUserVos) { - if (issueUserVo.getId().equals(this.webAppUtil.getLoginId())) { + if (issueUserVo.getId().equals(user.getId())) { hasPermission = true; break; } @@ -1536,20 +1668,22 @@ // �씠�뒋 �긽�깭 蹂�寃� @Override @Transactional - public void modifyIssueStatus(IssueForm issueForm) { + public void modifyIssueStatus(IssueForm issueForm, User user) { // �궗�슜�븯怨� �엳�뒗 �뾽臾� 怨듦컙�씠 �솢�꽦 �긽�깭�씤吏� �솗�씤�븳�떎. �궗�슜 怨듦컙�뿉�꽌 濡쒓렇�씤�븳 �궗�슜�옄媛� 鍮꾪솢�꽦�씤吏� �솗�씤�븳�떎. this.workspaceService.checkUseWorkspace(); // 蹂�寃� �씠�젰 �젙蹂� 異붿텧 StringBuilder detectIssueChange = new StringBuilder(); // �씠�뒋 �닔�젙 沅뚰븳 泥댄겕 - this.verifyIssueModifyPermission(issueForm.getId()); Issue issue = this.getIssue(issueForm.getId()); + IssueStatus oldIssueStatus = issue.getIssueStatus(); + + this.verifyIssueModifyPermission(issue, user); IssueStatus issueStatus = this.issueStatusService.getIssueStatus(issueForm.getIssueStatusId()); // �씠�뒋 �긽�깭瑜� 蹂�寃쏀븷 �븣 �꽑�깮�븳 �씠�뒋 �긽�깭濡� 蹂�寃쏀븷 �닔 �엳�뒗吏� �솗�씤�븳�떎. this.issueStatusService.checkNextIssueStatus(issue, issueStatus); // 蹂�寃� �씠�젰 �젙蹂� 異붿텧 - this.issueHistoryService.detectIssueStatus(issue, issueForm, detectIssueChange, issueStatus); + this.issueHistoryService.detectIssueStatus(issue, issueForm, detectIssueChange, oldIssueStatus, issueStatus); issue.setIssueStatus(issueStatus); this.issueRepository.saveAndFlush(issue); @@ -1583,13 +1717,15 @@ @Override @Transactional public void modifyIssueUser(IssueForm issueForm) { + User user = this.webAppUtil.getLoginUserObject(); + // �궗�슜�븯怨� �엳�뒗 �뾽臾� 怨듦컙�씠 �솢�꽦 �긽�깭�씤吏� �솗�씤�븳�떎. �궗�슜 怨듦컙�뿉�꽌 濡쒓렇�씤�븳 �궗�슜�옄媛� 鍮꾪솢�꽦�씤吏� �솗�씤�븳�떎. this.workspaceService.checkUseWorkspace(); // 蹂�寃� �씠�젰 �젙蹂� 異붿텧 StringBuilder detectIssueChange = new StringBuilder(); // �씠�뒋 �닔�젙 沅뚰븳 泥댄겕 - this.verifyIssueModifyPermission(issueForm.getId()); Issue issue = this.getIssue(issueForm.getId()); + this.verifyIssueModifyPermission(issue, user); issue.setProject(this.projectService.getProject(issueForm.getProjectId())); // 蹂�寃� �씠�젰 �젙蹂� 異붿텧 @@ -1618,13 +1754,14 @@ @Override @Transactional public void modifyIssueDepartment(IssueForm issueForm) { + User user = this.webAppUtil.getLoginUserObject(); // �궗�슜�븯怨� �엳�뒗 �뾽臾� 怨듦컙�씠 �솢�꽦 �긽�깭�씤吏� �솗�씤�븳�떎. �궗�슜 怨듦컙�뿉�꽌 濡쒓렇�씤�븳 �궗�슜�옄媛� 鍮꾪솢�꽦�씤吏� �솗�씤�븳�떎. this.workspaceService.checkUseWorkspace(); // 蹂�寃� �씠�젰 �젙蹂� 異붿텧 StringBuilder detectIssueChange = new StringBuilder(); // �씠�뒋 �닔�젙 沅뚰븳 泥댄겕 - this.verifyIssueModifyPermission(issueForm.getId()); Issue issue = this.getIssue(issueForm.getId()); + this.verifyIssueModifyPermission(issue, user); issue.setProject(this.projectService.getProject(issueForm.getProjectId())); // 蹂�寃� �씠�젰 �젙蹂� 異붿텧 @@ -1656,6 +1793,7 @@ @Transactional public void removeIssues(IssueForm issueForm) { // �궗�슜�븯怨� �엳�뒗 �뾽臾� 怨듦컙�씠 �솢�꽦 �긽�깭�씤吏� �솗�씤�븳�떎. �궗�슜 怨듦컙�뿉�꽌 濡쒓렇�씤�븳 �궗�슜�옄媛� 鍮꾪솢�꽦�씤吏� �솗�씤�븳�떎. + User user = this.webAppUtil.getLoginUserObject(); this.workspaceService.checkUseWorkspace(); if (issueForm.getRemoveIds().size() < 1) { @@ -1666,7 +1804,7 @@ List<Issue> removeIssues = Lists.newArrayList(); for (Long issueId : issueForm.getRemoveIds()) { - Issue issue = this.issueRemoves(issueId); + Issue issue = this.issueRemoves(issueId, user); removeIssues.add(issue); } @@ -1678,10 +1816,10 @@ log.info(ElasticSearchUtil.makeUserActiveHistoryMessage(this.webAppUtil.getLoginUser(), ElasticSearchConstants.ISSUE_REMOVE)); } - private Issue issueRemoves(Long issueId) { + private Issue issueRemoves(Long issueId, User user) { Issue issue = this.getIssue(issueId); // �씠�뒋 �닔�젙 沅뚰븳�쓣 媛뽮퀬 �엳�뒗吏� �솗�씤 - this.verifyIssueModifyPermission(issueId); + this.verifyIssueModifyPermission(issue, user); // �씠�뒋 泥⑤� �뙆�씪�쓣 �궘�젣�븳�떎. if (issue.getAttachedFiles().size() > 0) { @@ -1845,7 +1983,8 @@ issueCondition.setIssueIds(Lists.newArrayList()); // Map �뿉 �엳�뒗 �뜲�씠�꽣瑜� IssueVo �뜲�씠�꽣濡� 蹂��솚�븳�떎. - this.setMapToIssueVo(results, issueVos, issueCondition); + User user = this.webAppUtil.getLoginUserObject(); + this.setMapToIssueVo(results, issueVos, issueCondition, user); // IssueVos �뜲�씠�꽣瑜� �뿊���뿉�꽌 �몴�떆�븷 �닔 �엳�뒗 �뜲�씠�꽣濡� 蹂�寃쏀븳�떎. List<Map<String, String>> convertExcelViewToIssueMaps = this.convertExcelViewToIssueVos(issueVos); @@ -2013,10 +2152,12 @@ // �궗�슜�븯怨� �엳�뒗 �뾽臾� 怨듦컙�씠 �솢�꽦 �긽�깭�씤吏� �솗�씤�븳�떎. �궗�슜 怨듦컙�뿉�꽌 濡쒓렇�씤�븳 �궗�슜�옄媛� 鍮꾪솢�꽦�씤吏� �솗�씤�븳�떎. this.workspaceService.checkUseWorkspace(); + User user = this.webAppUtil.getLoginUserObject(); + for (Long issueId : issueForm.getIds()) { issueForm.setId(issueId); // �씠�뒋 �긽�깭 蹂�寃� - this.modifyIssueStatus(issueForm); + this.modifyIssueStatus(issueForm, user); } // �떞�떦 遺��꽌 �닔�젙 @@ -2942,7 +3083,7 @@ StringBuilder sb = new StringBuilder(); Issue parentIssue = issue.getParentIssue(); //蹂�寃� �쟾 �븯�쐞�씠�뒋�쓽 �긽�쐞�씠�뒋 - if(parentIssue != null){ //蹂�寃� �쟾 �븯�쐞�씠�뒋�쓽 �긽�쐞�씠�뒋媛� 議댁옱 �븷 寃쎌슦 + if(parentIssue != null && parentIssue.getId().equals(newParentIssueId)){ //蹂�寃� �쟾 �븯�쐞�씠�뒋�쓽 �긽�쐞�씠�뒋媛� 議댁옱 �븷 寃쎌슦 this.issueHistoryService.detectDownIssues(IssueHistoryType.DELETE, issue, sb); this.issueHistoryService.addIssueHistory(parentIssue, IssueHistoryType.MODIFY, sb.toString()); } @@ -2951,7 +3092,7 @@ parentIssue = this.getIssue(newParentIssueId); //�긽�쐞�씠�뒋(myIssue) issue.setParentIssue(parentIssue); //myIssue瑜� �븯�쐞�씠�뒋�쓽 �긽�쐞�씠�뒋濡� set this.issueHistoryService.detectDownIssues(IssueHistoryType.ADD, issue, sb); //issue = �븯�쐞�씠�뒋 - } else { + } else{ // �궘�젣 �븷 寃쎌슦 this.issueHistoryService.detectDownIssues(IssueHistoryType.DELETE, issue, sb); issue.setParentIssue(null); diff --git a/src/main/java/kr/wisestone/owl/service/impl/ProjectRoleUserServiceImpl.java b/src/main/java/kr/wisestone/owl/service/impl/ProjectRoleUserServiceImpl.java index 963602f..02533b3 100644 --- a/src/main/java/kr/wisestone/owl/service/impl/ProjectRoleUserServiceImpl.java +++ b/src/main/java/kr/wisestone/owl/service/impl/ProjectRoleUserServiceImpl.java @@ -137,10 +137,10 @@ // �봽濡쒖젥�듃 愿�由ъ옄 �뿬遺�瑜� �솗�씤�븳�떎. @Override @Transactional(readOnly = true) - public boolean checkProjectManager(Project project) { + public boolean checkProjectManager(Project project, User user) { ProjectRole projectManagerRole = this.projectRoleService.findByProjectIdAndRoleType(project.getId(), ProjectRole.TYPE_MANAGER); // �빐�떦 �궗�슜�옄媛� �듅�젙 �뿭�븷�뿉 �냼�냽�릺�뼱 �엳�뒗吏� �솗�씤�븳�떎. - ProjectRoleUser projectRoleUser = this.findByProjectRoleIdAndUserId(projectManagerRole.getId(), this.webAppUtil.getLoginId()); + ProjectRoleUser projectRoleUser = this.findByProjectRoleIdAndUserId(projectManagerRole.getId(), user.getId()); return projectRoleUser != null; } diff --git a/src/main/java/kr/wisestone/owl/service/impl/ProjectServiceImpl.java b/src/main/java/kr/wisestone/owl/service/impl/ProjectServiceImpl.java index 255db28..303dc8a 100644 --- a/src/main/java/kr/wisestone/owl/service/impl/ProjectServiceImpl.java +++ b/src/main/java/kr/wisestone/owl/service/impl/ProjectServiceImpl.java @@ -342,10 +342,12 @@ List<Map<String, Object>> results; Long totalCount; + User user = this.webAppUtil.getLoginUserObject(); + if (condition.getWorkspaceManager()) { // �뾽臾닿났媛� 愿�由ъ옄�씪 寃쎌슦 紐⑤뱺 �봽濡쒖젥�듃媛� �몴�떆�릺�뼱�빞 �븳�떎. // 愿�由ъ옄�씪 �븣 - if (this.userWorkspaceService.checkWorkspaceManager()) { + if (this.userWorkspaceService.checkWorkspaceManager(user)) { results = this.projectMapper.findByWorkspaceManager(condition); totalCount = this.projectMapper.countByWorkspaceManager(condition); } @@ -361,8 +363,8 @@ int totalPage = (int) Math.ceil((totalCount - 1) / pageable.getPageSize()) + 1; // �봽濡쒖젥�듃 議고쉶 寃곌낵瑜� ProjectVos 濡� 蹂��솚�븳�떎. - 愿�由ъ옄, �씪諛� �궗�슜�옄 �젙蹂� 異붽� - List<ProjectVo> projectVos = this.makeProjectVos(results); - this.setChildrenProject(projectVos); + List<ProjectVo> projectVos = this.makeProjectVos(results, user); + this.setChildrenProject(projectVos, user); resJsonData.put(Constants.RES_KEY_CONTENTS, projectVos); resJsonData.put(Constants.REQ_KEY_PAGE_VO, new ResPage(pageable.getPageNumber(), pageable.getPageSize(), @@ -371,16 +373,16 @@ return projectVos; } - void setChildrenProject(List<ProjectVo> projectVos) { + void setChildrenProject(List<ProjectVo> projectVos, User user) { int projectCount = projectVos.size(); for (int i=0; i< projectCount; i++) { ProjectVo projectVo = projectVos.get(i); List<Map<String, Object>> children = this.projectMapper.findChildrenProject(projectVo.getId()); if (children != null && children.size() > 0) { - List<ProjectVo> childrenVo = this.makeProjectVos(children); + List<ProjectVo> childrenVo = this.makeProjectVos(children, user); projectVo.setChildProjects(childrenVo); - setChildrenProject(childrenVo); + setChildrenProject(childrenVo, user); } } } @@ -400,7 +402,7 @@ // �봽濡쒖젥�듃 議고쉶 寃곌낵瑜� ProjectVos 濡� 蹂��솚�븳�떎. - 愿�由ъ옄, �씪諛� �궗�슜�옄 �젙蹂� 異붽� - private List<ProjectVo> makeProjectVos(List<Map<String, Object>> results) { + private List<ProjectVo> makeProjectVos(List<Map<String, Object>> results, User user) { List<ProjectVo> projectVos = Lists.newArrayList(); for (Map<String, Object> result : results) { @@ -413,7 +415,7 @@ this.setProjectDepartment(projectVo); // �뾽臾닿났媛� �떞�떦�옄�뒗 紐⑤뱺 �봽濡쒖젥�듃瑜� �닔�젙/�궘�젣�븷 �닔 �엳�뼱�빞 �븳�떎. - if (this.userWorkspaceService.checkWorkspaceManager()) { + if (this.userWorkspaceService.checkWorkspaceManager(user)) { projectVo.setModifyPermissionCheck(true); } projectVos.add(projectVo); @@ -532,10 +534,12 @@ // �봽濡쒖젥�듃 李몄뿬 遺��꽌 List<Long> existDepartmentIds = this.getIncludeProjectDepartment(project); + User user = this.webAppUtil.getLoginUserObject(); + // �썙�겕�뒪�럹�씠�뒪�뿉�꽌 湲곕낯�쑝濡� �젣怨듬릺�뒗 �봽濡쒖젥�듃�뿉 ���븳 泥댄겕 this.checkDefaultProject(project, projectForm); // �닔�젙 沅뚰븳 泥댄겕 - this.checkModifyPermission(project.getId()); + this.checkModifyPermission(project.getId(), user); // 愿�由ъ옄 蹂�寃� Map<String, Object> changeProjectManagerNotifications = this.modifyProjectManagers(project, projectForm, ProjectRole.TYPE_MANAGER); // �씪諛� �궗�슜�옄 蹂�寃� @@ -659,11 +663,11 @@ } // 濡쒓렇�씤�븳 �궗�슜�옄媛� 愿�由ъ옄 �뿭�븷�뿉 �냼�냽�릺�뼱 �엳�뒗吏� �솗�씤�븳�떎. - private void checkModifyPermission(Long projectId) { + private void checkModifyPermission(Long projectId, User user) { Boolean hasPermission = Boolean.FALSE; // �빐�떦 �뾽臾� 怨듦컙�쓽 愿�由ъ옄�씪 寃쎌슦 沅뚰븳 泥댄겕瑜� �븯吏� �븡�뒗�떎. - if (this.userWorkspaceService.checkWorkspaceManager()) { + if (this.userWorkspaceService.checkWorkspaceManager(user)) { return; } @@ -1000,7 +1004,7 @@ } // 濡쒓렇�씤�븳 �궗�슜�옄媛� 愿�由ъ옄 �뿭�븷�뿉 �냼�냽�릺�뼱 �엳�뒗吏� �솗�씤�븳�떎. - this.checkModifyPermission(project.getId()); + this.checkModifyPermission(project.getId(), this.webAppUtil.getLoginUserObject()); List<String> sendEmails = Lists.newArrayList(); Map<String, Object> params = new HashMap<>(); @@ -1094,21 +1098,23 @@ @Override @Transactional(readOnly = true) public List<ProjectVo> findByIncludeProject(List<String> statuses, String projectType) { + User user = this.webAppUtil.getLoginUserObject(); + ProjectCondition projectCondition = new ProjectCondition(); - projectCondition.setLoginUserId(this.webAppUtil.getLoginId()); - projectCondition.setWorkspaceId(this.userService.getUser(this.webAppUtil.getLoginId()).getLastWorkspaceId()); + projectCondition.setLoginUserId(user.getId()); + projectCondition.setWorkspaceId(user.getLastWorkspaceId()); projectCondition.setProjectType(projectType); projectCondition.setStatuses(statuses); List<Map<String, Object>> results; - if (this.userWorkspaceService.checkWorkspaceManager()) { + if (this.userWorkspaceService.checkWorkspaceManager(user)) { results = this.projectMapper.findByWorkspaceManager(projectCondition); } else { results = this.projectMapper.findByWorkspaceIdAndIncludeProject(projectCondition); } List<ProjectVo> projectVos = this.makeProjectByVos(results); - this.setChildrenProject(projectVos); + this.setChildrenProject(projectVos, user); return projectVos; } @@ -1135,7 +1141,7 @@ projectCondition.setWorkspaceId(this.userService.getUser(this.webAppUtil.getLoginId()).getLastWorkspaceId()); List<Map<String, Object>> results = this.projectMapper.find(projectCondition); // �봽濡쒖젥�듃 議고쉶 寃곌낵瑜� ProjectVos 濡� 蹂��솚�븳�떎. - 愿�由ъ옄, �씪諛� �궗�슜�옄 �젙蹂� 異붽� - List<ProjectVo> projectVos = this.makeProjectVos(results); + List<ProjectVo> projectVos = this.makeProjectVos(results, this.webAppUtil.getLoginUserObject()); ExportExcelVo excelInfo = new ExportExcelVo(); excelInfo.setFileName(this.messageAccessor.message("common.projectList")); // �봽濡쒖젥�듃 紐⑸줉 excelInfo.addAttrInfos(new ExportExcelAttrVo("statusName", this.messageAccessor.message("common.status"), 6, ExportExcelAttrVo.ALIGN_CENTER)); // �긽�깭 diff --git a/src/main/java/kr/wisestone/owl/service/impl/UserWorkspaceServiceImpl.java b/src/main/java/kr/wisestone/owl/service/impl/UserWorkspaceServiceImpl.java index 04a5e39..f8657be 100644 --- a/src/main/java/kr/wisestone/owl/service/impl/UserWorkspaceServiceImpl.java +++ b/src/main/java/kr/wisestone/owl/service/impl/UserWorkspaceServiceImpl.java @@ -238,15 +238,14 @@ // �뾽臾� 怨듦컙 �떞�떦�옄 �뿬遺�瑜� �솗�씤�븳�떎. @Override @Transactional(readOnly = true) - public boolean checkWorkspaceManager() { + public boolean checkWorkspaceManager(User user) { boolean bIsManager = false; - User loginUser = this.userService.getUser(this.webAppUtil.getLoginId()); try { - Workspace workspace = this.workspaceService.getWorkspace(loginUser.getLastWorkspaceId()); // �쁽�옱 �젒�냽�븳 �뾽臾� 怨듦컙 + Workspace workspace = this.workspaceService.getWorkspace(user.getLastWorkspaceId()); // �쁽�옱 �젒�냽�븳 �뾽臾� 怨듦컙 // 濡쒓렇�씤�븳 �궗�슜�옄媛� 愿�由ы븯�뒗 �뾽臾� 怨듦컙�쓣 李얜뒗�떎. - UserWorkspace userWorkspace = this.findMyWorkspace(this.webAppUtil.getLoginId()); + UserWorkspace userWorkspace = this.findMyWorkspace(user.getId()); bIsManager = workspace.getId().equals(userWorkspace.getWorkspace().getId()); } diff --git a/src/main/java/kr/wisestone/owl/service/impl/WidgetServiceImpl.java b/src/main/java/kr/wisestone/owl/service/impl/WidgetServiceImpl.java index df9aac1..418273c 100644 --- a/src/main/java/kr/wisestone/owl/service/impl/WidgetServiceImpl.java +++ b/src/main/java/kr/wisestone/owl/service/impl/WidgetServiceImpl.java @@ -5,10 +5,7 @@ import kr.wisestone.owl.common.MessageAccessor; import kr.wisestone.owl.constant.Constants; import kr.wisestone.owl.constant.MsgConstants; -import kr.wisestone.owl.domain.IssueStatus; -import kr.wisestone.owl.domain.Project; -import kr.wisestone.owl.domain.ProjectClosure; -import kr.wisestone.owl.domain.UserDepartment; +import kr.wisestone.owl.domain.*; import kr.wisestone.owl.domain.enumType.ProjectType; import kr.wisestone.owl.exception.OwlRuntimeException; import kr.wisestone.owl.mapper.IssueMapper; @@ -166,9 +163,10 @@ @Override @Transactional(readOnly = true) public WidgetCondition makeWidgetCondition() { + User user = this.webAppUtil.getLoginUserObject(); // �빐�떦 �썙�겕�뒪�럹�씠�뒪�뿉�꽌 李몄뿬�븯怨� �엳�뒗 �봽濡쒖젥�듃 以� �긽�깭媛� �삤�뵂�씤 �봽濡쒖젥�듃 List<Map<String, Object>> projects = null; - if (this.userWorkspaceService.checkWorkspaceManager()) { + if (this.userWorkspaceService.checkWorkspaceManager(user)) { projects = this.projectService.findByWorkspaceManagerAll(); } else { projects = this.projectService.findByWorkspaceIdAndIncludeProjectAll(Lists.newArrayList("02"), ProjectType.BTS_PROJECT.toString()); @@ -277,9 +275,11 @@ public void findProjectProgress(Map<String, Object> resJsonData, WidgetCondition widgetCondition) { List<Map<String, Object>> progressingProjectDetails = Lists.newArrayList(); + User user = this.webAppUtil.getLoginUserObject(); + if (widgetCondition.getProjectIds().size() > 0) { SetMeAndDownProjectIds(widgetCondition.getProjectIds(), widgetCondition); - if (this.userWorkspaceService.checkWorkspaceManager()) { + if (this.userWorkspaceService.checkWorkspaceManager(user)) { progressingProjectDetails = this.widgetMapper.findProjectProgressAll(widgetCondition); } else { progressingProjectDetails = this.widgetMapper.findProjectProgress(widgetCondition); diff --git a/src/main/java/kr/wisestone/owl/vo/IssueDownVo.java b/src/main/java/kr/wisestone/owl/vo/IssueDownVo.java new file mode 100644 index 0000000..68de22d --- /dev/null +++ b/src/main/java/kr/wisestone/owl/vo/IssueDownVo.java @@ -0,0 +1,93 @@ +package kr.wisestone.owl.vo; + +import com.google.common.collect.Lists; + +import java.util.List; + +public class IssueDownVo extends BaseVo { + private Long id; + private IssueVo issue; + private IssueVo issueDown; + private String title; + + private IssueTypeVo issueTypeVo; // �씠�뒋 �긽�꽭�뿉�꽌 �궗�슜 + private PriorityVo priorityVo; // �씠�뒋 �긽�꽭�뿉�꽌 �궗�슜 + private SeverityVo severityVo; // �씠�뒋 �긽�꽭�뿉�꽌 �궗�슜 + private UserVo registerVo; // �씠�뒋 �긽�꽭�뿉�꽌 �궗�슜 + private List<DepartmentVo> departmentVos = Lists.newArrayList(); //�떞�떦遺��꽌 + private Boolean modifyPermissionCheck = Boolean.FALSE; + + public IssueDownVo() {} + + public Long getId() { + return id; + } + + public void setId(Long id) { + this.id = id; + } + + public IssueVo getIssue() { return issue; } + + public void setIssue(IssueVo issue) { this.issue = issue; } + + public IssueVo getIssueDown() { + return issueDown; + } + + public void setIssueDown(IssueVo issueDown) { + this.issueDown = issueDown; + } + + public String getTitle() { return this.title; } + + public void setTitle(String title) { this.title = title; } + + public IssueTypeVo getIssueTypeVo() { + return issueTypeVo; + } + + public void setIssueTypeVo(IssueTypeVo issueTypeVo) { + this.issueTypeVo = issueTypeVo; + } + + public PriorityVo getPriorityVo() { + return priorityVo; + } + + public void setPriorityVo(PriorityVo priorityVo) { + this.priorityVo = priorityVo; + } + + public SeverityVo getSeverityVo() { + return severityVo; + } + + public void setSeverityVo(SeverityVo severityVo) { + this.severityVo = severityVo; + } + + public UserVo getRegisterVo() { + return registerVo; + } + + public void setRegisterVo(UserVo registerVo) { + this.registerVo = registerVo; + } + + public List<DepartmentVo> getDepartmentVos() { + return departmentVos; + } + + public void setDepartmentVos(List<DepartmentVo> departmentVos) { + this.departmentVos = departmentVos; + } + + public Boolean getModifyPermissionCheck() { + return modifyPermissionCheck; + } + + public void setModifyPermissionCheck(Boolean modifyPermissionCheck) { + this.modifyPermissionCheck = modifyPermissionCheck; + } +} diff --git a/src/main/java/kr/wisestone/owl/vo/IssueVo.java b/src/main/java/kr/wisestone/owl/vo/IssueVo.java index 7d84a23..83daa76 100644 --- a/src/main/java/kr/wisestone/owl/vo/IssueVo.java +++ b/src/main/java/kr/wisestone/owl/vo/IssueVo.java @@ -45,6 +45,7 @@ private List<IssueTypeCustomFieldVo> issueTypeCustomFieldVos = Lists.newArrayList(); private List<IssueCustomFieldValueVo> issueCustomFieldValueVos = Lists.newArrayList(); private List<IssueRelationVo> issueRelations = Lists.newArrayList(); + //private List<IssueDownVo> issueDownVos = Lists.newArrayList(); private List<IssueVo> issueDownVos = Lists.newArrayList(); private List<IssueVo> issueRelationVos = Lists.newArrayList(); private Long attachedFileCount; @@ -402,6 +403,14 @@ this.issueRelations.add(issueRelationVo); } + /*public void addIssueDownVo(IssueDownVo issueDownVo) { + if (this.issueDownVos == null){ + this.issueDownVos = new ArrayList<>(); + } + + this.issueDownVos.add(issueDownVo); + }*/ + public List<IssueVo> getIssueRelationIssueVos() { return this.issueRelationVos; } public void setIssueRelationIssueVos(List<IssueVo> issueRelationVos) { this.issueRelationVos = issueRelationVos; } @@ -414,6 +423,14 @@ this.departmentVos = departmentVos; } + /*public List<IssueDownVo> getIssueDownVos() { + return issueDownVos; + } + + public void setIssueDownVos(List<IssueDownVo> issueDownVos) { + this.issueDownVos = issueDownVos; + }*/ + public List<IssueVo> getIssueDownVos() { return issueDownVos; } diff --git a/src/main/java/kr/wisestone/owl/web/form/IssueApiForm.java b/src/main/java/kr/wisestone/owl/web/form/IssueApiForm.java index 8c1e7a8..93d7e48 100644 --- a/src/main/java/kr/wisestone/owl/web/form/IssueApiForm.java +++ b/src/main/java/kr/wisestone/owl/web/form/IssueApiForm.java @@ -23,6 +23,7 @@ private String projectKey; private String description; private Long issueTypeId; + private Long issueStatusId; private Long priorityId; private Long severityId; private Date startDate; @@ -217,4 +218,12 @@ public void setMultipartFiles(List<MultipartFile> multipartFiles) { this.multipartFiles = multipartFiles; } + + public Long getIssueStatusId() { + return issueStatusId; + } + + public void setIssueStatusId(Long issueStatusId) { + this.issueStatusId = issueStatusId; + } } diff --git a/src/main/java/kr/wisestone/owl/web/form/IssueForm.java b/src/main/java/kr/wisestone/owl/web/form/IssueForm.java index 863a569..482f023 100644 --- a/src/main/java/kr/wisestone/owl/web/form/IssueForm.java +++ b/src/main/java/kr/wisestone/owl/web/form/IssueForm.java @@ -229,6 +229,12 @@ this.departmentIds = departmentIds; } + public void addDepartmentId(Long departmentId) { + if (this.departmentIds != null) { + this.departmentIds.add(departmentId); + } + } + public List<Long> getRemoveFiles() { return removeFiles; } diff --git a/src/main/resources/system_prod.properties b/src/main/resources/system_prod.properties index 951aeed..4f46fd6 100644 --- a/src/main/resources/system_prod.properties +++ b/src/main/resources/system_prod.properties @@ -40,8 +40,8 @@ # email \uC124\uC815 email.host=mail.g2works.kr email.port=587 -email.userName=wyu@maprex.co.kr -email.password=1234 +email.userName=supportowl@wisestone.kr +email.password=Stone0620** email.transport.protocol=smtp email.smtp.auth=true email.smtp.starttle.enable=true diff --git a/src/main/webapp/scripts/app/issue/issueDetail.controller.js b/src/main/webapp/scripts/app/issue/issueDetail.controller.js index 7dd4755..645ff08 100644 --- a/src/main/webapp/scripts/app/issue/issueDetail.controller.js +++ b/src/main/webapp/scripts/app/issue/issueDetail.controller.js @@ -870,7 +870,8 @@ // �븯�쐞 �씠�뒋 諛섎ぉ臾� if (result.data.data.issueDownVos !== null){ angular.forEach(result.data.data.issueDownVos, function (issueDownVo){ - $scope.vm.form.issuesDown.push(issueDownVo.issue); + //$scope.vm.form.issuesDown.push(issueDownVo.issueDown); + $scope.vm.form.issuesDown.push(issueDownVo); }); } $scope.vm.viewer.issueRelationVos = result.data.data.issueRelationVos; -- Gitblit v1.8.0