OWL ITS + 탐지시스템(인터넷 진흥원)
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
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
package kr.wisestone.owl.service.impl;
 
 
import kr.wisestone.owl.constant.MsgConstants;
import kr.wisestone.owl.domain.*;
import kr.wisestone.owl.exception.OwlRuntimeException;
import kr.wisestone.owl.repository.ProjectRoleRepository;
import kr.wisestone.owl.service.*;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import java.util.List;
 
@Service
public class ProjectRoleServiceImpl extends AbstractServiceImpl<ProjectRole, Long, JpaRepository<ProjectRole, Long>> implements ProjectRoleService {
 
    private static final Logger log = LoggerFactory.getLogger(ProjectRoleServiceImpl.class);
 
    @Autowired
    private ProjectRoleRepository projectRoleRepository;
 
    @Autowired
    private ProjectRoleUserService projectRoleUserService;
 
    @Autowired
    private ProjectRoleDepartmentService projectRoleDepartmentService;
 
    @Autowired
    private ProjectRolePermissionService projectRolePermissionService;
 
    @Override
    protected JpaRepository<ProjectRole, Long> getRepository() {
        return this.projectRoleRepository;
    }
 
    //  기본, 관리자 프로젝트 역할을 생성한다.
    @Override
    @Transactional
    public void addDefaultProjectRoleUser(Project project, List<User> managers, List<User> users) {
        ProjectRole projectRole = this.addProjectRole(project, "기본 프로젝트 역할", ProjectRole.TYPE_DEFAULT, Permission.ROLE_TYPE_PROJECT_JOIN);
        ProjectRole managerProjectRole = this.addProjectRole(project, "프로젝트 관리자 역할", ProjectRole.TYPE_MANAGER, Permission.ROLE_TYPE_PROJECT_MANAGER);
        //  프로젝트 관리자 저장
        this.projectRoleAssociatedUser(managers, managerProjectRole);
        //  프로젝트 일반 사용자 저장
        this.projectRoleAssociatedUser(users, projectRole);
 
        this.projectRoleRepository.flush();
    }
 
    //  프로젝트 역할 생성(관리자, 담당부서)
    @Override
    @Transactional
    public void addDefaultProjectRoleDepartment(Project project, List<User> managers, List<Department> departments) {
        ProjectRole projectRole = this.addProjectRole(project, "기본 프로젝트 역할", ProjectRole.TYPE_DEFAULT, Permission.ROLE_TYPE_PROJECT_JOIN);
        ProjectRole managerProjectRole = this.addProjectRole(project, "프로젝트 관리자 역할", ProjectRole.TYPE_MANAGER, Permission.ROLE_TYPE_PROJECT_MANAGER);
        //  프로젝트 관리자 저장
        this.projectRoleAssociatedUser(managers, managerProjectRole);
        //  프로젝트 일반 사용자 저장
        //this.projectRoleAssociatedUser(users, projectRole);
        //  프로젝트 담당 부서 저장
        this.projectRoleAssociatedDepartment(departments, projectRole);
 
        this.projectRoleRepository.flush();
    }
 
    //  프로젝트 역할가 사용자 연결
    private void projectRoleAssociatedUser(List<User> users, ProjectRole projectRole) {
        for (User user : users) {
            this.addDefaultProjectRoleAssociatedUser(projectRole, user);
        }
    }
 
    //  해당 역할과 사용자를 연결시킨다.
    private void addDefaultProjectRoleAssociatedUser(ProjectRole projectRole, User user) {
        ProjectRoleUser projectRoleUser = this.projectRoleUserService.findByProjectRoleIdAndUserId(projectRole.getId(), user.getId());
 
        if (projectRoleUser == null) {
            //  프로젝트 관리자 - 기본 프로젝트 역할에 추가.
            user.addProjectRole(projectRole);
        }
    }
 
    // 프로젝트 역할과 부서 연결
    private void projectRoleAssociatedDepartment(List<Department> departments, ProjectRole projectRole) {
        for (Department department : departments) {
            this.addDefaultProjectRoleAssociatedDepartment(projectRole, department);
        }
    }
 
    //  해당 역할과 부서를 연결시킨다.
    private void addDefaultProjectRoleAssociatedDepartment(ProjectRole projectRole, Department department) {
        ProjectRoleDepartment projectRoleDepartment = this.projectRoleDepartmentService.findByProjectRoleIdAndDepartmentId(projectRole.getId(), department.getId());
 
        if (projectRoleDepartment == null) {
            //  프로젝트 관리자 - 기본 프로젝트 역할에 추가.
            department.addProjectRole(projectRole);
        }
    }
 
    //  프로젝트 역할을 생성한다.
    private ProjectRole addProjectRole(Project project, String projectRoleName, String projectRoleType, String permissionType) {
        ProjectRole projectRole = new ProjectRole(project, projectRoleName, projectRoleType);
        this.projectRoleRepository.saveAndFlush(projectRole);
        this.projectRolePermissionService.addDefaultProjectRoleAssociatedPermissions(projectRole, permissionType);
        return projectRole;
    }
 
    //  해당 프로젝트 역할을 조회한다.
    @Override
    @Transactional(readOnly = true)
    public ProjectRole findByProjectIdAndRoleType(Long projectId, String roleType) {
        ProjectRole projectRole = this.projectRoleRepository.findByProjectIdAndRoleType(projectId, roleType);
 
        if (projectRole == null) {
            throw new OwlRuntimeException(this.messageAccessor.getMessage(MsgConstants.PROJECT_ROLE_NOT_EXIST));
        }
 
        return projectRole;
    }
}