dio_speed_tracker 0.0.4 copy "dio_speed_tracker: ^0.0.4" to clipboard
dio_speed_tracker: ^0.0.4 copied to clipboard

A lightweight and extensible Dio interceptor for monitoring real-world network speed in Mbps, based on actual HTTP download performance

dio_speed_tracker #

A lightweight and extensible Dio interceptor that tracks real-world network download speeds in Mbps, using actual HTTP responses instead of ICMP pings.

This is a practical alternative to custom_ping, ideal for apps where ICMP (ping) is blocked or unreliable β€” or when you want real-world performance metrics rather than synthetic ones.


πŸ” Features #

  • βœ… Dio interceptor that measures network speed from actual downloads
  • πŸ“‰ Emits NetworkStatus.poor when average speed drops below a threshold
  • πŸ”„ Rolling average for smoothing out results
  • βš™οΈ Configurable sample size, duration, and thresholds
  • 🧩 No platform channels or native code needed
  • πŸ‘Œ Suitable for Flutter & Dart web/server apps alike

πŸ“¦ Installation #

Add this to your pubspec.yaml:

dependencies:
  dio: ^5.0.0
  collection: ^1.17.2
  dio_speed_tracker: ^0.0.3

πŸš€ Usage #

1. Create and attach the interceptor #

final speedController = NetworkSpeedController(
  maxSpeedSamples: 10,
  minResultsToCheck: 5,
  poorConnectionThreshold: 2.0, // Mbps
);

final dio = Dio();

dio.interceptors.add(
  SpeedInterceptor(
  speedController,
  minTrackableSize: 10 * 1024, // 10 KB
  minDuration: Duration(milliseconds: 20),
  ),
);

2. Listen for connection quality #

speedController.stream.listen((status) {
  if (status == NetworkStatus.poor) {
    print("🚨 Poor connection detected!");
    // Optionally show a UI warning or fallback
  }
});

3. Clean up #

Don't forget to dispose of the controller when no longer needed:

@override
void dispose() {
  speedController.dispose();
  super.dispose();
}

πŸ“Š How It Works #

  • The interceptor uses Dio's onReceiveProgress to measure how long a real HTTP download takes.
  • It calculates Mbps based on size and duration.
  • Speeds are stored in a rolling buffer, and the average is continuously evaluated.
  • When the average falls below the defined threshold, it emits NetworkStatus.poor on the stream.

πŸ†š Why Not custom_ping? #

Unlike custom_ping:

Feature dio_speed_tracker custom_ping
Real download-based speed βœ… ❌
Works without ICMP permissions βœ… ❌
Cross-platform compatible βœ… 🚫 (native)
Dio integration βœ… ❌
No extra request calls βœ… ❌
Single request evaluation ❌ (TBD) βœ…

πŸ§ͺ Testing #

This package includes full unit test coverage for:

  • Speed sample tracking and averaging
  • Rolling window logic
  • Threshold stream emission
  • Basic interceptor setup

Run tests: #

flutter test

You’ll find the test files in:

test/
β”œβ”€β”€ network_speed_controller_test.dart
└── speed_interceptor_test.dart

🧰 Requirements #

  • Dart 2.17+
  • Dio 5+
  • collection package for calculating averages

πŸ“‚ License #

MIT License β€” free for personal or commercial use.


πŸ™Œ Contributing #

Contributions and issues welcome!
If you have improvements or new ideas, feel free to open a PR or start a discussion.


4
likes
160
points
34
downloads

Publisher

unverified uploader

Weekly Downloads

A lightweight and extensible Dio interceptor for monitoring real-world network speed in Mbps, based on actual HTTP download performance

Repository (GitHub)
View/report issues

Topics

#network #dio #performance #connection #speed

Documentation

Documentation
API reference

License

MIT (license)

Dependencies

collection, dio, flutter, flutter_web_plugins, plugin_platform_interface, web

More

Packages that depend on dio_speed_tracker

Packages that implement dio_speed_tracker