dio_logging_interceptors.dart 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. import 'package:dio/dio.dart';
  2. import 'package:telnow_mobile_new/src/injector/injector.dart';
  3. import 'package:telnow_mobile_new/src/model/refreshtoken/refresh_token_body.dart';
  4. import 'package:telnow_mobile_new/src/model/token/token.dart';
  5. import 'package:telnow_mobile_new/src/layouts/components/template.dart';
  6. import 'package:telnow_mobile_new/src/storage/sharedpreferences/shared_preferences_manager.dart';
  7. import 'package:telnow_mobile_new/src/utils/u.dart';
  8. import 'package:event_bus/event_bus.dart';
  9. EventBus eventBus = EventBus();
  10. class DioLoggingInterceptors extends InterceptorsWrapper {
  11. final Dio _dio;
  12. final SharedPreferencesManager _sharedPreferencesManager = locator<SharedPreferencesManager>();
  13. DioLoggingInterceptors(this._dio);
  14. @override
  15. void onRequest(RequestOptions options, RequestInterceptorHandler handler) async {
  16. if (options.headers.containsKey('requirestoken')) {
  17. // await U.waitForRefreshAuth(); //bikin stuck
  18. // return;
  19. options.headers.remove('requirestoken');
  20. String? accessToken = _sharedPreferencesManager.getString(SharedPreferencesManager.keyAccessToken);
  21. options.headers.addAll({'Authorization': 'Bearer $accessToken'});
  22. }
  23. super.onRequest(options, handler);
  24. }
  25. @override
  26. void onResponse(Response response, ResponseInterceptorHandler handler) {
  27. super.onResponse(response,handler);
  28. }
  29. @override
  30. void onError(DioError dioError, ErrorInterceptorHandler handler) async {
  31. // print(dioError.response?.data.toString());
  32. // print(dioError.response?.realUri.toString());
  33. try {
  34. if (dioError.response?.statusCode == 401) {
  35. // print("auth error");
  36. bool? checkRefreshCount = _sharedPreferencesManager.isKeyExists(SharedPreferencesManager.keyCountRefreshToken);
  37. int? refreshCount = _sharedPreferencesManager.getInt(SharedPreferencesManager.keyCountRefreshToken);
  38. if(checkRefreshCount! && refreshCount! > 2){
  39. // handlingError(NavigationService.navigatorKey.currentContext, 3);
  40. eventBus.fire("logout");
  41. return;
  42. }
  43. // if (dioError.response!.data.toString().contains("Invalid refresh token")) {
  44. // handlingError(NavigationService.navigatorKey.currentContext, 3);
  45. // }
  46. if (dioError.response!.data.toString().contains("Access token expired")) {
  47. // print("token expired");
  48. String? refreshToken = _sharedPreferencesManager.getString(SharedPreferencesManager.keyRefreshToken)!;
  49. RefreshTokenBody? refreshTokenBody = RefreshTokenBody('refresh_token', refreshToken);
  50. Token? token = await U.refreshAuth(refreshTokenBody);
  51. if (token != null) {
  52. RequestOptions? options = dioError.response?.requestOptions;
  53. options?.headers.addAll({'requirestoken': true});
  54. try {
  55. var r = await _dio.fetch(options!);
  56. handler.resolve(r);
  57. await _sharedPreferencesManager.putInt(SharedPreferencesManager.keyCountRefreshToken, 0);
  58. return;
  59. } catch (error2) {
  60. print(error2);
  61. }
  62. }
  63. }
  64. await _sharedPreferencesManager.putInt(SharedPreferencesManager.keyCountRefreshToken, refreshCount!+1);
  65. }
  66. } catch (error) {
  67. print("Error dio: ${error.toString()}");
  68. eventBus.fire("logout");
  69. // handlingError(NavigationService.navigatorKey.currentContext, 3);
  70. }
  71. super.onError(dioError, handler);
  72. }
  73. }