import 'package:flutter/cupertino.dart'; import 'package:flutter/material.dart'; import 'package:flutter_bloc/flutter_bloc.dart'; import 'package:flutter_secure_storage/flutter_secure_storage.dart'; import 'package:syncrow_app/features/auth/model/login_with_email_model.dart'; import 'package:syncrow_app/features/auth/model/token.dart'; import 'package:syncrow_app/features/auth/model/user_model.dart'; import 'package:syncrow_app/navigation/navigation_service.dart'; import 'package:syncrow_app/navigation/routing_constants.dart'; import 'package:syncrow_app/services/api/authentication_api.dart'; import 'package:syncrow_app/services/api/network_exception.dart'; part 'auth_state.dart'; class AuthCubit extends Cubit { AuthCubit() : super(AuthInitial()) { getTokenAndValidate(); } static AuthCubit get(context) => BlocProvider.of(context); TextEditingController emailController = TextEditingController(); TextEditingController passwordController = TextEditingController(); bool isPasswordVisible = false; static GlobalKey formKey = GlobalKey(); void changePasswordVisibility() { isPasswordVisible = !isPasswordVisible; emit(AuthPasswordVisibilityChanged()); } bool agreeToTerms = false; void changeAgreeToTerms() { agreeToTerms = !agreeToTerms; emit(AuthAgreeToTermsChanged()); } static UserModel? user; static Token token = Token.emptyConstructor(); /////////////////////////////////////API CALLS///////////////////////////////////// login() async { emit(AuthLoginLoading()); try { token = await AuthenticationAPI.loginWithEmail( model: LoginWithEmailModel( email: emailController.text.toLowerCase(), password: passwordController.text, ), ); } catch (failure) { emit(AuthLoginError(message: failure.toString())); return; } if (token.accessTokenIsNotEmpty) { FlutterSecureStorage storage = const FlutterSecureStorage(); await storage.write( key: Token.loginAccessTokenKey, value: token.accessToken); const FlutterSecureStorage().write( key: UserModel.userUuidKey, value: Token.decodeToken(token.accessToken)['uuid'].toString()); user = UserModel.fromToken(token); emailController.clear(); passwordController.clear(); emit(AuthLoginSuccess()); } else { emit(AuthLoginError(message: 'Something went wrong')); } } logout() async { emit(AuthLogoutLoading()); try { FlutterSecureStorage storage = const FlutterSecureStorage(); await storage.delete(key: Token.loginAccessTokenKey); NavigationService.navigatorKey.currentState! .popAndPushNamed(Routes.authLogin); emit(AuthLogoutSuccess()); } catch (failure) { emit(AuthLogoutError(message: failure.toString())); return; } } getTokenAndValidate() async { emit(AuthTokenLoading()); final value = await const FlutterSecureStorage().read(key: Token.loginAccessTokenKey); if (value == null) { emit(AuthTokenError(message: "Token not found")); return; } final tokenData = Token.decodeToken(value); if (tokenData.containsKey('exp')) { final exp = tokenData['exp'] ?? 0; final currentTime = DateTime.now().millisecondsSinceEpoch ~/ 1000; if (currentTime < exp) { emit(AuthTokenSuccess()); } else { emit(AuthTokenError(message: "Token expired")); } } else { emit(AuthTokenError(message: "Something went wrong")); } } }