feat(menu-permissions): 메뉴 API 연동으로 사이드바 권한 정비

- .env.development.example과 lib/core/config/environment.dart, lib/core/permissions/permission_manager.dart에서 PERMISSION__ 폴백을 view 전용으로 좁히고 기본 정책을 명시적으로 거부하도록 재정비했다

- lib/core/navigation/*, lib/core/routing/app_router.dart, lib/widgets/app_shell.dart, lib/main.dart에서 메뉴 매니페스트·카탈로그를 도입해 /menus 응답을 캐싱하고 라우터·사이드바·Breadcrumb가 동일 menu_code/route_path를 쓰도록 리팩터링했다

- lib/core/permissions/permission_resources.dart와 그룹 권한/메뉴 마스터 모듈을 menu_code 기반 CRUD 및 Catalog 경로 정합성 검사로 전환하고 PermissionSynchronizer·PermissionBootstrapper를 확장했다

- test/helpers/test_permissions.dart, test/widgets/app_shell_test.dart 등 신규 구조를 반영하는 테스트·골든과 doc/frontend_menu_permission_tasks.md 문서를 보강했다
This commit is contained in:
JiWoong Sul
2025-11-12 18:29:03 +09:00
parent f767c44573
commit 753f76e952
72 changed files with 1914 additions and 704 deletions

View File

@@ -3,6 +3,7 @@ import 'package:superport_v2/core/network/failure.dart';
import 'package:superport_v2/core/common/models/paginated_result.dart';
import 'package:superport_v2/core/common/utils/pagination_utils.dart';
import '../../../../../core/navigation/menu_catalog.dart';
import '../../../../../core/permissions/permission_manager.dart';
import '../../../group/domain/entities/group.dart';
import '../../../group/domain/repositories/group_repository.dart';
@@ -21,15 +22,18 @@ class UserController extends ChangeNotifier {
required GroupRepository groupRepository,
GroupPermissionRepository? permissionRepository,
PermissionManager? permissionManager,
MenuCatalog? menuCatalog,
}) : _userRepository = userRepository,
_groupRepository = groupRepository,
_permissionRepository = permissionRepository,
_permissionManager = permissionManager;
_permissionManager = permissionManager,
_menuCatalog = menuCatalog;
final UserRepository _userRepository;
final GroupRepository _groupRepository;
final GroupPermissionRepository? _permissionRepository;
final PermissionManager? _permissionManager;
final MenuCatalog? _menuCatalog;
PaginatedResult<UserAccount>? _result;
bool _isLoading = false;
@@ -244,6 +248,7 @@ class UserController extends ChangeNotifier {
final synchronizer = PermissionSynchronizer(
repository: repository,
manager: manager,
menuCatalog: _menuCatalog,
);
await synchronizer.syncForGroup(groupId);
} catch (_) {