add permission logic
This commit is contained in:
@ -3,18 +3,27 @@ package com.iconplus.smartproc.service.roles;
|
||||
import com.iconplus.smartproc.exception.BusinessException;
|
||||
import com.iconplus.smartproc.helper.service.BaseService;
|
||||
import com.iconplus.smartproc.model.entity.Roles;
|
||||
import com.iconplus.smartproc.model.projection.PermissionView;
|
||||
import com.iconplus.smartproc.model.request.RolesRequest;
|
||||
import com.iconplus.smartproc.model.response.PermissionResponse;
|
||||
import com.iconplus.smartproc.model.response.RolesResponse;
|
||||
import com.iconplus.smartproc.repository.PermissionRepository;
|
||||
import com.iconplus.smartproc.repository.RolesRepository;
|
||||
import com.iconplus.smartproc.util.Constants;
|
||||
import org.springframework.stereotype.Service;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
@Service
|
||||
public class GetRoleByIdService implements BaseService<RolesRequest, RolesResponse> {
|
||||
|
||||
private final RolesRepository rolesRepository;
|
||||
public GetRoleByIdService(RolesRepository rolesRepository) {
|
||||
private PermissionRepository permissionRepository;
|
||||
public GetRoleByIdService(RolesRepository rolesRepository,
|
||||
PermissionRepository permissionRepository) {
|
||||
this.rolesRepository = rolesRepository;
|
||||
this.permissionRepository = permissionRepository;
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -25,12 +34,28 @@ public class GetRoleByIdService implements BaseService<RolesRequest, RolesRespon
|
||||
Constants.ERR_TTL_10005,
|
||||
String.format(Constants.ERR_MSG_10005, input.getId())));
|
||||
|
||||
List<PermissionResponse> permissionResponses = new ArrayList<>();
|
||||
List<PermissionView> permissionViews = permissionRepository.getAllPermissionsByRoleId(role.getId());
|
||||
for (PermissionView permissionView : permissionViews) {
|
||||
permissionResponses.add(PermissionResponse.builder()
|
||||
.parentId(permissionView.getParentId())
|
||||
.menuId(permissionView.getMenuId())
|
||||
.menu(permissionView.getNama())
|
||||
.canView(permissionView.getCanView())
|
||||
.canCreate(permissionView.getCanCreate())
|
||||
.canRead(permissionView.getCanRead())
|
||||
.canUpdate(permissionView.getCanUpdate())
|
||||
.canDelete(permissionView.getCanDelete())
|
||||
.build());
|
||||
}
|
||||
|
||||
return RolesResponse.builder()
|
||||
.id(role.getId())
|
||||
.role(role.getRole())
|
||||
.keterangan(role.getKeterangan())
|
||||
.isActive(role.getIsActive())
|
||||
.isDelete(role.getIsDelete())
|
||||
.permission(permissionResponses)
|
||||
.build();
|
||||
}
|
||||
}
|
||||
|
@ -2,23 +2,37 @@ package com.iconplus.smartproc.service.roles;
|
||||
|
||||
import com.iconplus.smartproc.exception.BusinessException;
|
||||
import com.iconplus.smartproc.helper.service.BaseService;
|
||||
import com.iconplus.smartproc.model.entity.Menus;
|
||||
import com.iconplus.smartproc.model.entity.Permission;
|
||||
import com.iconplus.smartproc.model.entity.Roles;
|
||||
import com.iconplus.smartproc.model.request.RolesRequest;
|
||||
import com.iconplus.smartproc.model.response.RolesResponse;
|
||||
import com.iconplus.smartproc.repository.MenusRepository;
|
||||
import com.iconplus.smartproc.repository.PermissionRepository;
|
||||
import com.iconplus.smartproc.repository.RolesRepository;
|
||||
import com.iconplus.smartproc.util.Constants;
|
||||
import org.springframework.stereotype.Service;
|
||||
|
||||
import javax.transaction.Transactional;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.Optional;
|
||||
|
||||
@Service
|
||||
public class PostCreateRoleService implements BaseService<RolesRequest, RolesResponse> {
|
||||
|
||||
private final MenusRepository menusRepository;
|
||||
private final RolesRepository rolesRepository;
|
||||
public PostCreateRoleService(RolesRepository rolesRepository) {
|
||||
private final PermissionRepository permissionRepository;
|
||||
public PostCreateRoleService(RolesRepository rolesRepository,
|
||||
MenusRepository menusRepository,
|
||||
PermissionRepository permissionRepository) {
|
||||
this.rolesRepository = rolesRepository;
|
||||
this.menusRepository = menusRepository;
|
||||
this.permissionRepository = permissionRepository;
|
||||
}
|
||||
|
||||
@Transactional
|
||||
@Override
|
||||
public RolesResponse execute(RolesRequest input) {
|
||||
|
||||
@ -37,6 +51,25 @@ public class PostCreateRoleService implements BaseService<RolesRequest, RolesRes
|
||||
.build();
|
||||
var result = rolesRepository.save(roles);
|
||||
|
||||
List<Menus> menusList = menusRepository.findByIsDeleteFalse();
|
||||
|
||||
List<Permission> permissions = new ArrayList<>();
|
||||
for (Menus menus : menusList) {
|
||||
permissions.add(Permission.builder()
|
||||
.roleId(result.getId())
|
||||
.menuId(menus.getId())
|
||||
.canRead(false)
|
||||
.canCreate(false)
|
||||
.canView(false)
|
||||
.canUpdate(false)
|
||||
.canDelete(false)
|
||||
.canDelete(false)
|
||||
.isDelete(false)
|
||||
.build());
|
||||
}
|
||||
|
||||
permissionRepository.saveAll(permissions);
|
||||
|
||||
return RolesResponse.builder()
|
||||
.id(result.getId())
|
||||
.build();
|
||||
|
Reference in New Issue
Block a user