selfprivacy.org.app/lib/logic/api_maps/api_map.dart

58 lines
1.4 KiB
Dart
Raw Normal View History

2021-01-06 19:35:57 +02:00
import 'package:dio/dio.dart';
2021-01-14 23:48:05 +02:00
import 'package:selfprivacy/config/get_it_config.dart';
import 'package:selfprivacy/logic/get_it/console.dart';
import 'package:selfprivacy/logic/models/message.dart';
2021-01-06 19:35:57 +02:00
abstract class ApiMap {
String rootAddress;
2021-01-14 23:48:05 +02:00
// Dio client = Dio();
Dio loggedClient = Dio()..interceptors.add(ConsoleInterceptor());
2021-01-06 19:35:57 +02:00
void close() {
2021-01-14 23:48:05 +02:00
loggedClient.close();
}
}
class ConsoleInterceptor extends InterceptorsWrapper {
void addMessage(Message message) {
getIt.get<ConsoleModel>().addMessage(message);
}
@override
Future onRequest(RequestOptions options) async {
addMessage(
Message(
text:
'request-uri: ${options.uri}\nheaders: ${options.headers}\ndata: ${options.data}',
),
);
return super.onRequest(options);
}
@override
Future onResponse(Response response) async {
addMessage(
Message(
text:
2021-01-18 12:21:55 +02:00
'response-uri: ${response.request.uri}\ncode: ${response.statusCode}\ndata: ${response.toString()}\n',
2021-01-14 23:48:05 +02:00
),
);
return super.onResponse(response);
}
@override
Future onError(DioError err) async {
2021-01-18 12:21:55 +02:00
var response = err.response;
addMessage(
Message.warn(
text:
'response-uri: ${response?.request?.uri}\ncode: ${response?.statusCode}\ndata: ${response?.toString()}\n',
),
);
2021-01-14 23:48:05 +02:00
return super.onError(err);
2021-01-06 19:35:57 +02:00
}
}