fix : 권한관리 기능 추가 (각 기능 확인 필요)
- 메뉴관리 - 역할관리 - 부서관리 - 메뉴, 부서, 역할, 유저 - 권한 연동
This commit is contained in:
107
app/Http/Controllers/Api/V1/DepartmentController.php
Normal file
107
app/Http/Controllers/Api/V1/DepartmentController.php
Normal file
@@ -0,0 +1,107 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers\Api\V1;
|
||||
|
||||
use Illuminate\Http\Request;
|
||||
use App\Http\Controllers\Controller;
|
||||
use App\Services\DepartmentService;
|
||||
use App\Helpers\ApiResponse;
|
||||
|
||||
class DepartmentController extends Controller
|
||||
{
|
||||
// GET /v1/departments
|
||||
public function index(Request $request)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($request) {
|
||||
return DepartmentService::index($request->all());
|
||||
}, '부서 목록 조회');
|
||||
}
|
||||
|
||||
// POST /v1/departments
|
||||
public function store(Request $request)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($request) {
|
||||
return DepartmentService::store($request->all());
|
||||
}, '부서 생성');
|
||||
}
|
||||
|
||||
// GET /v1/departments/{id}
|
||||
public function show($id, Request $request)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($id, $request) {
|
||||
return DepartmentService::show((int)$id, $request->all());
|
||||
}, '부서 단건 조회');
|
||||
}
|
||||
|
||||
// PATCH /v1/departments/{id}
|
||||
public function update($id, Request $request)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($id, $request) {
|
||||
return DepartmentService::update((int)$id, $request->all());
|
||||
}, '부서 수정');
|
||||
}
|
||||
|
||||
// DELETE /v1/departments/{id}
|
||||
public function destroy($id, Request $request)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($id, $request) {
|
||||
return DepartmentService::destroy((int)$id, $request->all());
|
||||
}, '부서 삭제');
|
||||
}
|
||||
|
||||
// GET /v1/departments/{id}/users
|
||||
public function listUsers($id, Request $request)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($id, $request) {
|
||||
return DepartmentService::listUsers((int)$id, $request->all());
|
||||
}, '부서 사용자 목록');
|
||||
}
|
||||
|
||||
// POST /v1/departments/{id}/users
|
||||
public function attachUser($id, Request $request)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($id, $request) {
|
||||
return DepartmentService::attachUser((int)$id, $request->all());
|
||||
}, '부서 사용자 배정');
|
||||
}
|
||||
|
||||
// DELETE /v1/departments/{id}/users/{user}
|
||||
public function detachUser($id, $user, Request $request)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($id, $user, $request) {
|
||||
return DepartmentService::detachUser((int)$id, (int)$user, $request->all());
|
||||
}, '부서 사용자 제거');
|
||||
}
|
||||
|
||||
// PATCH /v1/departments/{id}/users/{user}/primary
|
||||
public function setPrimary($id, $user, Request $request)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($id, $user, $request) {
|
||||
return DepartmentService::setPrimary((int)$id, (int)$user, $request->all());
|
||||
}, '주 부서 설정/해제');
|
||||
}
|
||||
|
||||
// GET /v1/departments/{id}/permissions
|
||||
public function listPermissions($id, Request $request)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($id, $request) {
|
||||
return DepartmentService::listPermissions((int)$id, $request->all());
|
||||
}, '부서 권한 목록');
|
||||
}
|
||||
|
||||
// POST /v1/departments/{id}/permissions
|
||||
public function upsertPermission($id, Request $request)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($id, $request) {
|
||||
return DepartmentService::upsertPermission((int)$id, $request->all());
|
||||
}, '부서 권한 부여/차단');
|
||||
}
|
||||
|
||||
// DELETE /v1/departments/{id}/permissions/{permission}
|
||||
public function revokePermission($id, $permission, Request $request)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($id, $permission, $request) {
|
||||
return DepartmentService::revokePermission((int)$id, (int)$permission, $request->all());
|
||||
}, '부서 권한 제거');
|
||||
}
|
||||
}
|
||||
62
app/Http/Controllers/Api/V1/MenuController.php
Normal file
62
app/Http/Controllers/Api/V1/MenuController.php
Normal file
@@ -0,0 +1,62 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers\Api\V1;
|
||||
|
||||
use Illuminate\Http\Request;
|
||||
use App\Http\Controllers\Controller;
|
||||
use App\Services\MenuService;
|
||||
use App\Helpers\ApiResponse;
|
||||
|
||||
class MenuController extends Controller
|
||||
{
|
||||
public function index(Request $request)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($request) {
|
||||
return MenuService::index($request->all());
|
||||
}, '메뉴 목록 조회');
|
||||
}
|
||||
|
||||
public function show($id)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($id) {
|
||||
return MenuService::show(['id' => (int)$id]);
|
||||
}, '메뉴 단건 조회');
|
||||
}
|
||||
|
||||
public function store(Request $request)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($request) {
|
||||
return MenuService::store($request->all());
|
||||
}, '메뉴 등록');
|
||||
}
|
||||
|
||||
public function update(Request $request, $id)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($request, $id) {
|
||||
$params = $request->all(); $params['id'] = (int)$id;
|
||||
return MenuService::update($params);
|
||||
}, '메뉴 수정');
|
||||
}
|
||||
|
||||
public function destroy($id)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($id) {
|
||||
return MenuService::destroy(['id' => (int)$id]);
|
||||
}, '메뉴 삭제');
|
||||
}
|
||||
|
||||
public function reorder(Request $request)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($request) {
|
||||
return MenuService::reorder($request->all());
|
||||
}, '메뉴 정렬 변경');
|
||||
}
|
||||
|
||||
public function toggle(Request $request, $id)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($request, $id) {
|
||||
$params = $request->all(); $params['id'] = (int)$id;
|
||||
return MenuService::toggle($params);
|
||||
}, '메뉴 상태 토글');
|
||||
}
|
||||
}
|
||||
46
app/Http/Controllers/Api/V1/RoleController.php
Normal file
46
app/Http/Controllers/Api/V1/RoleController.php
Normal file
@@ -0,0 +1,46 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers\Api\V1;
|
||||
|
||||
use Illuminate\Http\Request;
|
||||
use App\Http\Controllers\Controller;
|
||||
use App\Services\Authz\RoleService;
|
||||
use App\Helpers\ApiResponse;
|
||||
|
||||
class RoleController extends Controller
|
||||
{
|
||||
public function index(Request $request)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($request) {
|
||||
return RoleService::index($request->all());
|
||||
}, '역할 목록 조회');
|
||||
}
|
||||
|
||||
public function store(Request $request)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($request) {
|
||||
return RoleService::store($request->all());
|
||||
}, '역할 생성');
|
||||
}
|
||||
|
||||
public function show($id)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($id) {
|
||||
return RoleService::show((int)$id);
|
||||
}, '역할 상세 조회');
|
||||
}
|
||||
|
||||
public function update(Request $request, $id)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($request, $id) {
|
||||
return RoleService::update((int)$id, $request->all());
|
||||
}, '역할 수정');
|
||||
}
|
||||
|
||||
public function destroy($id)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($id) {
|
||||
return RoleService::destroy((int)$id);
|
||||
}, '역할 삭제');
|
||||
}
|
||||
}
|
||||
39
app/Http/Controllers/Api/V1/RolePermissionController.php
Normal file
39
app/Http/Controllers/Api/V1/RolePermissionController.php
Normal file
@@ -0,0 +1,39 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers\Api\V1;
|
||||
|
||||
use Illuminate\Http\Request;
|
||||
use App\Http\Controllers\Controller;
|
||||
use App\Services\Authz\RolePermissionService;
|
||||
use App\Helpers\ApiResponse;
|
||||
|
||||
class RolePermissionController extends Controller
|
||||
{
|
||||
public function index($id, Request $request)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($id) {
|
||||
return RolePermissionService::list((int)$id);
|
||||
}, '역할 퍼미션 목록 조회');
|
||||
}
|
||||
|
||||
public function grant($id, Request $request)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($id, $request) {
|
||||
return RolePermissionService::grant((int)$id, $request->all());
|
||||
}, '역할 퍼미션 부여');
|
||||
}
|
||||
|
||||
public function revoke($id, Request $request)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($id, $request) {
|
||||
return RolePermissionService::revoke((int)$id, $request->all());
|
||||
}, '역할 퍼미션 회수');
|
||||
}
|
||||
|
||||
public function sync($id, Request $request)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($id, $request) {
|
||||
return RolePermissionService::sync((int)$id, $request->all());
|
||||
}, '역할 퍼미션 동기화');
|
||||
}
|
||||
}
|
||||
39
app/Http/Controllers/Api/V1/UserRoleController.php
Normal file
39
app/Http/Controllers/Api/V1/UserRoleController.php
Normal file
@@ -0,0 +1,39 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers\Api\V1;
|
||||
|
||||
use Illuminate\Http\Request;
|
||||
use App\Http\Controllers\Controller;
|
||||
use App\Services\Authz\UserRoleService;
|
||||
use App\Helpers\ApiResponse;
|
||||
|
||||
class UserRoleController extends Controller
|
||||
{
|
||||
public function index($id)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($id) {
|
||||
return UserRoleService::list((int)$id);
|
||||
}, '사용자의 역할 목록 조회');
|
||||
}
|
||||
|
||||
public function grant($id, Request $request)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($id, $request) {
|
||||
return UserRoleService::grant((int)$id, $request->all());
|
||||
}, '사용자에게 역할 부여');
|
||||
}
|
||||
|
||||
public function revoke($id, Request $request)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($id, $request) {
|
||||
return UserRoleService::revoke((int)$id, $request->all());
|
||||
}, '사용자의 역할 회수');
|
||||
}
|
||||
|
||||
public function sync($id, Request $request)
|
||||
{
|
||||
return ApiResponse::handle(function () use ($id, $request) {
|
||||
return UserRoleService::sync((int)$id, $request->all());
|
||||
}, '사용자의 역할 동기화');
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user