optimus_network_inspector 1.0.3
optimus_network_inspector: ^1.0.3 copied to clipboard
Http inspector / logger for Http package. This package would allow you to log every Http request, response, and error from Http.
optimus_network_inspector #
A Flutter package for inspecting and debugging network requests.
Unlike the original network_inspector, this fork removes Dio client support and is designed exclusively for the http package.
Easy to use, http client class debugger & logger for multiple http client. This package contains a set of high-level functions and classes that make it easy to log / debug HTTP activities on the fly. It's also depend on Http package.
|
|
|
|
✨ Features #
- Intercept and log HTTP requests and responses (using the
httppackage). - View headers, body, and response times.
- Lightweight implementation without Dio dependencies.
Get Started #
add dependency
dependencies:
optimus_network_inspector: ^1.0.0
Initialize #
Initialize network inspector, call initialize method to init the local database sqlite. You can use WidgetsFlutterBinding.ensureInitialized(); to makesure widget flutter binding initialized before initialize network inspector.
void main() {
WidgetsFlutterBinding.ensureInitialized();
NetworkInspector.initialize();
runApp(const ExampleApp());
}
Http Users #
- Add interceptor class
HttpInterceptorfor http client. - Initialize
Clientto client class, then useclienton theHttpInterceptorconstructor - Create another Network Inspector class to used on the
HttpInterceptorconstructor. - Use
onHttpFinishas a callback when http activities is finish (Can be success/error)
HttpInterceptor get httpClient {
final networkInspector = NewtworkInspector();
final client = Client();
final interceptor = HttpInterceptor(
logIsAllowed: true, //Enable/Disable overall logging
client: client,
baseUrl: Uri.parse('http://192.168.1.3:8000/'),
networkInspector: networkInspector,
onHttpFinish: (hashCode, title, message) {
notifyActivity(
title: title,
message: message,
);
},
headers: {
'Content-type': 'application/json',
'Accept': 'application/json',
'Authorization': 'Bearer WEKLSSS'
},
);
return interceptor;
}
/// Use http client regularly
/// Every request, response & error will automatically fetched & stored by the network inspector.
/// And also if the properties of declared `HttpInterceptor` is not empty, it will set every properties as default.
await httpClient.post(url, body: {'name': 'doodle', 'color': 'blue'});
Acessing the UI #
We can use regular Navigator.push, we decide to use MaterialPageRoute instead of named route to avoid tightly coupled.
/// Use this on floating button / notification handler.
void goToActivityPage(BuildContext context){
await Navigator.push(
context,
MaterialPageRoute<void>(
builder: (context) => ActivityPage(),
),
);
}
Entry point from notification tap action #
If the entry point to http activity page is desired from notification tap action, create a class to store GlobalKey<NavigatorState> which we need to navigate to the http activity page, from anywhere add GlobalKey into the MaterialApp widget on the navigatorKey constructor.
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Network inspector',
theme: ThemeData(
primarySwatch: Colors.blue,
),
/// Put your navigation key into a class
/// In this case we put navigator key on
/// ```dart
/// class NavigationService{
/// static var navigatorKey = GlobalKey<NavigatorState>();
/// }
/// ```
navigatorKey: NavigationService.navigatorKey,
initialRoute: MainPage.routeName,
routes: NavigationService.routes,
),
}
Then you can use the global key to get the context for Navigator.push
/// Get the current context
var context = NavigationService.navigatorKey.currentContext;
/// Call the `goToActivityPage` method and Supply the context
goToActivityPage(context);
Credits #
This package is a fork of network_inspector.
It has been simplified to remove Dio support and is maintained as optimus_network_inspector by Gtech Digital.