add permission logic
This commit is contained in:
parent
f8f489f565
commit
6bc02da741
@ -14,6 +14,7 @@ import javax.persistence.*;
|
|||||||
@Builder
|
@Builder
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
@NoArgsConstructor
|
@NoArgsConstructor
|
||||||
|
@Entity
|
||||||
@Table(name = "permission")
|
@Table(name = "permission")
|
||||||
public class Permission extends BaseEntity {
|
public class Permission extends BaseEntity {
|
||||||
|
|
||||||
@ -32,6 +33,10 @@ public class Permission extends BaseEntity {
|
|||||||
@Type(type = "org.hibernate.type.NumericBooleanType")
|
@Type(type = "org.hibernate.type.NumericBooleanType")
|
||||||
private Boolean canView;
|
private Boolean canView;
|
||||||
|
|
||||||
|
@Column(name = "can_create")
|
||||||
|
@Type(type = "org.hibernate.type.NumericBooleanType")
|
||||||
|
private Boolean canCreate;
|
||||||
|
|
||||||
@Column(name = "can_read")
|
@Column(name = "can_read")
|
||||||
@Type(type = "org.hibernate.type.NumericBooleanType")
|
@Type(type = "org.hibernate.type.NumericBooleanType")
|
||||||
private Boolean canRead;
|
private Boolean canRead;
|
||||||
|
@ -0,0 +1,29 @@
|
|||||||
|
package com.iconplus.smartproc.model.projection;
|
||||||
|
|
||||||
|
public interface PermissionView {
|
||||||
|
|
||||||
|
Long getParentId();
|
||||||
|
void setParentId(Long parentId);
|
||||||
|
|
||||||
|
Long getMenuId();
|
||||||
|
void setMenuId(Long menuId);
|
||||||
|
|
||||||
|
String getNama();
|
||||||
|
void setNama(String nama);
|
||||||
|
|
||||||
|
Boolean getCanView();
|
||||||
|
void setCanView(Boolean canView);
|
||||||
|
|
||||||
|
Boolean getCanRead();
|
||||||
|
void setCanRead(Boolean canRead);
|
||||||
|
|
||||||
|
Boolean getCanUpdate();
|
||||||
|
void setCanUpdate(Boolean canUpdate);
|
||||||
|
|
||||||
|
Boolean getCanDelete();
|
||||||
|
void setCanDelete(Boolean canDelete);
|
||||||
|
|
||||||
|
Boolean getCanCreate();
|
||||||
|
void setCanCreate(Boolean canCreate);
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,24 @@
|
|||||||
|
package com.iconplus.smartproc.model.response;
|
||||||
|
|
||||||
|
import com.iconplus.smartproc.helper.base.BaseResponse;
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import lombok.Builder;
|
||||||
|
import lombok.Data;
|
||||||
|
import lombok.NoArgsConstructor;
|
||||||
|
|
||||||
|
@Data
|
||||||
|
@Builder
|
||||||
|
@AllArgsConstructor
|
||||||
|
@NoArgsConstructor
|
||||||
|
public class PermissionResponse extends BaseResponse {
|
||||||
|
|
||||||
|
private Long id;
|
||||||
|
private Long parentId;
|
||||||
|
private Long menuId;
|
||||||
|
private String menu;
|
||||||
|
private Boolean canView;
|
||||||
|
private Boolean canCreate;
|
||||||
|
private Boolean canRead;
|
||||||
|
private Boolean canDelete;
|
||||||
|
private Boolean canUpdate;
|
||||||
|
}
|
@ -6,6 +6,8 @@ import lombok.Builder;
|
|||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import lombok.NoArgsConstructor;
|
import lombok.NoArgsConstructor;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
@Data
|
@Data
|
||||||
@Builder
|
@Builder
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
@ -17,5 +19,7 @@ public class RolesResponse extends BaseResponse {
|
|||||||
private String keterangan;
|
private String keterangan;
|
||||||
private Boolean isActive;
|
private Boolean isActive;
|
||||||
private Boolean isDelete;
|
private Boolean isDelete;
|
||||||
|
private List<PermissionResponse> permission;
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,13 @@
|
|||||||
|
package com.iconplus.smartproc.repository;
|
||||||
|
|
||||||
|
import com.iconplus.smartproc.model.entity.Menus;
|
||||||
|
import org.springframework.data.jpa.repository.JpaRepository;
|
||||||
|
import org.springframework.stereotype.Repository;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
@Repository
|
||||||
|
public interface MenusRepository extends JpaRepository<Menus, Long> {
|
||||||
|
|
||||||
|
List<Menus> findByIsDeleteFalse();
|
||||||
|
}
|
@ -0,0 +1,28 @@
|
|||||||
|
package com.iconplus.smartproc.repository;
|
||||||
|
|
||||||
|
import com.iconplus.smartproc.model.entity.Permission;
|
||||||
|
import com.iconplus.smartproc.model.projection.PermissionView;
|
||||||
|
import org.springframework.data.jpa.repository.JpaRepository;
|
||||||
|
import org.springframework.data.jpa.repository.Query;
|
||||||
|
import org.springframework.stereotype.Repository;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
@Repository
|
||||||
|
public interface PermissionRepository extends JpaRepository<Permission, Long> {
|
||||||
|
|
||||||
|
@Query(value = "SELECT m.parentId as parentId, " +
|
||||||
|
"p.menuId as menuId, " +
|
||||||
|
"m.nama as nama, " +
|
||||||
|
"p.canView as canView, " +
|
||||||
|
"p.canCreate as canCreate, " +
|
||||||
|
"p.canUpdate as canUpdate, " +
|
||||||
|
"p.canDelete as canDelete, " +
|
||||||
|
"p.canRead as canRead " +
|
||||||
|
"FROM Permission p " +
|
||||||
|
"JOIN Menus m ON m.id = p.menuId " +
|
||||||
|
"WHERE p.isDelete = false " +
|
||||||
|
"AND m.isDelete = false " +
|
||||||
|
"AND p.roleId = :roleId")
|
||||||
|
List<PermissionView> getAllPermissionsByRoleId(Long roleId);
|
||||||
|
}
|
@ -3,18 +3,27 @@ package com.iconplus.smartproc.service.roles;
|
|||||||
import com.iconplus.smartproc.exception.BusinessException;
|
import com.iconplus.smartproc.exception.BusinessException;
|
||||||
import com.iconplus.smartproc.helper.service.BaseService;
|
import com.iconplus.smartproc.helper.service.BaseService;
|
||||||
import com.iconplus.smartproc.model.entity.Roles;
|
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.request.RolesRequest;
|
||||||
|
import com.iconplus.smartproc.model.response.PermissionResponse;
|
||||||
import com.iconplus.smartproc.model.response.RolesResponse;
|
import com.iconplus.smartproc.model.response.RolesResponse;
|
||||||
|
import com.iconplus.smartproc.repository.PermissionRepository;
|
||||||
import com.iconplus.smartproc.repository.RolesRepository;
|
import com.iconplus.smartproc.repository.RolesRepository;
|
||||||
import com.iconplus.smartproc.util.Constants;
|
import com.iconplus.smartproc.util.Constants;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
@Service
|
@Service
|
||||||
public class GetRoleByIdService implements BaseService<RolesRequest, RolesResponse> {
|
public class GetRoleByIdService implements BaseService<RolesRequest, RolesResponse> {
|
||||||
|
|
||||||
private final RolesRepository rolesRepository;
|
private final RolesRepository rolesRepository;
|
||||||
public GetRoleByIdService(RolesRepository rolesRepository) {
|
private PermissionRepository permissionRepository;
|
||||||
|
public GetRoleByIdService(RolesRepository rolesRepository,
|
||||||
|
PermissionRepository permissionRepository) {
|
||||||
this.rolesRepository = rolesRepository;
|
this.rolesRepository = rolesRepository;
|
||||||
|
this.permissionRepository = permissionRepository;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -25,12 +34,28 @@ public class GetRoleByIdService implements BaseService<RolesRequest, RolesRespon
|
|||||||
Constants.ERR_TTL_10005,
|
Constants.ERR_TTL_10005,
|
||||||
String.format(Constants.ERR_MSG_10005, input.getId())));
|
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()
|
return RolesResponse.builder()
|
||||||
.id(role.getId())
|
.id(role.getId())
|
||||||
.role(role.getRole())
|
.role(role.getRole())
|
||||||
.keterangan(role.getKeterangan())
|
.keterangan(role.getKeterangan())
|
||||||
.isActive(role.getIsActive())
|
.isActive(role.getIsActive())
|
||||||
.isDelete(role.getIsDelete())
|
.isDelete(role.getIsDelete())
|
||||||
|
.permission(permissionResponses)
|
||||||
.build();
|
.build();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2,23 +2,37 @@ package com.iconplus.smartproc.service.roles;
|
|||||||
|
|
||||||
import com.iconplus.smartproc.exception.BusinessException;
|
import com.iconplus.smartproc.exception.BusinessException;
|
||||||
import com.iconplus.smartproc.helper.service.BaseService;
|
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.entity.Roles;
|
||||||
import com.iconplus.smartproc.model.request.RolesRequest;
|
import com.iconplus.smartproc.model.request.RolesRequest;
|
||||||
import com.iconplus.smartproc.model.response.RolesResponse;
|
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.repository.RolesRepository;
|
||||||
import com.iconplus.smartproc.util.Constants;
|
import com.iconplus.smartproc.util.Constants;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
|
import javax.transaction.Transactional;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
|
|
||||||
@Service
|
@Service
|
||||||
public class PostCreateRoleService implements BaseService<RolesRequest, RolesResponse> {
|
public class PostCreateRoleService implements BaseService<RolesRequest, RolesResponse> {
|
||||||
|
|
||||||
|
private final MenusRepository menusRepository;
|
||||||
private final RolesRepository rolesRepository;
|
private final RolesRepository rolesRepository;
|
||||||
public PostCreateRoleService(RolesRepository rolesRepository) {
|
private final PermissionRepository permissionRepository;
|
||||||
|
public PostCreateRoleService(RolesRepository rolesRepository,
|
||||||
|
MenusRepository menusRepository,
|
||||||
|
PermissionRepository permissionRepository) {
|
||||||
this.rolesRepository = rolesRepository;
|
this.rolesRepository = rolesRepository;
|
||||||
|
this.menusRepository = menusRepository;
|
||||||
|
this.permissionRepository = permissionRepository;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Transactional
|
||||||
@Override
|
@Override
|
||||||
public RolesResponse execute(RolesRequest input) {
|
public RolesResponse execute(RolesRequest input) {
|
||||||
|
|
||||||
@ -37,6 +51,25 @@ public class PostCreateRoleService implements BaseService<RolesRequest, RolesRes
|
|||||||
.build();
|
.build();
|
||||||
var result = rolesRepository.save(roles);
|
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()
|
return RolesResponse.builder()
|
||||||
.id(result.getId())
|
.id(result.getId())
|
||||||
.build();
|
.build();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user