marco.pms.mobileapp/lib/controller/permission_controller.dart
Vaibhav Surve e6d05e247e Refactor logging implementation across controllers and services
- Replaced instances of the Logger package with a custom appLogger for consistent logging.
- Introduced app_logger.dart to manage logging with file output and storage permissions.
- Updated all controllers (e.g., DashboardController, EmployeesScreenController, etc.) to use appLogger for logging messages.
- Ensured that logging messages are appropriately categorized (info, warning, error) throughout the application.
- Implemented a file logging mechanism to store logs in a designated directory.
- Cleaned up old log files to maintain only the most recent logs.
2025-06-24 13:11:22 +05:30

123 lines
3.5 KiB
Dart

import 'dart:async';
import 'dart:convert';
import 'package:get/get.dart';
import 'package:shared_preferences/shared_preferences.dart';
import 'package:marco/helpers/services/app_logger.dart';
import 'package:marco/helpers/services/permission_service.dart';
import 'package:marco/model/user_permission.dart';
import 'package:marco/model/employee_info.dart';
import 'package:marco/model/projects_model.dart';
class PermissionController extends GetxController {
var permissions = <UserPermission>[].obs;
var employeeInfo = Rxn<EmployeeInfo>();
var projectsInfo = <ProjectInfo>[].obs;
Timer? _refreshTimer;
@override
void onInit() {
super.onInit();
_loadDataFromAPI();
_startAutoRefresh();
}
Future<void> _storeData() async {
try {
final prefs = await SharedPreferences.getInstance();
await prefs.setString(
'user_permissions',
jsonEncode(permissions.map((e) => e.toJson()).toList()),
);
if (employeeInfo.value != null) {
await prefs.setString(
'employee_info',
jsonEncode(employeeInfo.value!.toJson()),
);
}
if (projectsInfo.isNotEmpty) {
await prefs.setString(
'projects_info',
jsonEncode(projectsInfo.map((e) => e.toJson()).toList()),
);
}
appLogger.i("User data successfully stored in SharedPreferences.");
} catch (e, stacktrace) {
appLogger.e("Error storing data", error: e, stackTrace: stacktrace);
}
}
Future<void> _loadDataFromAPI() async {
final token = await _getAuthToken();
if (token?.isNotEmpty ?? false) {
await loadData(token!);
} else {
appLogger.w("No token found for loading API data.");
}
}
Future<void> loadData(String token) async {
try {
final userData = await PermissionService.fetchAllUserData(token);
_updateState(userData);
await _storeData();
appLogger.i("Data loaded and state updated successfully.");
} catch (e, stacktrace) {
appLogger.e("Error loading data from API", error: e, stackTrace: stacktrace);
}
}
void _updateState(Map<String, dynamic> userData) {
try {
permissions.assignAll(userData['permissions']);
employeeInfo.value = userData['employeeInfo'];
projectsInfo.assignAll(userData['projects']);
appLogger.i("State updated with new user data.");
} catch (e, stacktrace) {
appLogger.e("Error updating state", error: e, stackTrace: stacktrace);
}
}
Future<String?> _getAuthToken() async {
try {
final prefs = await SharedPreferences.getInstance();
return prefs.getString('jwt_token');
} catch (e, stacktrace) {
appLogger.e("Error retrieving auth token", error: e, stackTrace: stacktrace);
return null;
}
}
void _startAutoRefresh() {
_refreshTimer = Timer.periodic(Duration(minutes: 30), (timer) async {
appLogger.i("Auto-refresh triggered.");
await _loadDataFromAPI();
});
}
bool hasPermission(String permissionId) {
final hasPerm = permissions.any((p) => p.id == permissionId);
appLogger.d("Checking permission $permissionId: $hasPerm");
return hasPerm;
}
bool isUserAssignedToProject(String projectId) {
final assigned = projectsInfo.any((project) => project.id == projectId);
appLogger.d("Checking project assignment for $projectId: $assigned");
return assigned;
}
@override
void onClose() {
_refreshTimer?.cancel();
appLogger.i("PermissionController disposed and timer cancelled.");
super.onClose();
}
}