shelf_limiter 1.0.1 copy "shelf_limiter: ^1.0.1" to clipboard
shelf_limiter: ^1.0.1 copied to clipboard

A powerful and highly customizable rate limiter for shelf library, allowing you to easily manage and control request rates in your Dart server.

shelf_limiter #

Dart Pub Version License


shelf_limiter is a powerful and highly customizable middleware package for the shelf library in Dart that enables efficient rate limiting. Protect your API from abuse and ensure fair usage with ease.

🌟 Features #

  • πŸ”§ Customizable Rate Limits: Effortlessly set the maximum number of requests and time window to suit your needs.
  • πŸ“œ Custom Headers: Add and manage custom headers in your responses to enhance control and transparency.
  • πŸš€ Custom Responses: Craft personalized responses when the rate limit is exceeded, improving user feedback.
  • πŸ”— Easy Integration: Integrate seamlessly into your existing Shelf pipeline with minimal setup, so you can focus on building features.

Installation #

Add shelf_limiter to your pubspec.yaml file:

dependencies:
  shelf_limiter: ^1.0.0

Then run:

dart pub get

Or simply run:

dart pub add shelf_limiter

Usage #

πŸ”§ Basic Usage #

Implement rate limiting in your Shelf application quickly and effectively. Here’s a straightforward example:

import 'package:shelf/shelf.dart';
import 'package:shelf/shelf_io.dart' as io;
import 'package:shelf_limiter/shelf_limiter.dart';

void main() async {
  final limiter = shelfLimiter(
    maxRequests: 5,
    windowSize: const Duration(minutes: 1),
  );

  final handler =
      const Pipeline().addMiddleware(limiter).addHandler(_echoRequest);

  var server = await io.serve(handler, 'localhost', 8080);
  print('Server listening on port ${server.port}');
}

Response _echoRequest(Request request) => Response.ok('Request received');

πŸ› οΈ Enhance Your API with Custom Headers #

Add extra details to your responses with custom headers. Here’s how:

import 'dart:convert';
import 'package:shelf/shelf.dart';
import 'package:shelf/shelf_io.dart' as io;
import 'package:shelf_limiter/shelf_limiter.dart';

void main() async {
  final options = RateLimiterOptions(
    headers: {
      'X-Custom-Header': 'Rate limited',
    },
  );

  final limiter = shelfLimiter(
    maxRequests: 5,
    windowSize: const Duration(minutes: 1),
    options: options,
  );

  final handler =
      const Pipeline().addMiddleware(limiter).addHandler(_echoRequest);

  var server = await io.serve(handler, 'localhost', 8080);
  print('Server listening on port ${server.port}');
}

Response _echoRequest(Request request) => Response.ok('Request received');

πŸ’‘ Customize Rate Limit Exceeded Responses #

Provide meaningful feedback by customizing the response when the rate limit is exceeded:

import 'dart:convert';
import 'package:shelf/shelf.dart';
import 'package:shelf/shelf_io.dart' as io;
import 'package:shelf_limiter/shelf_limiter.dart';

void main() async {
  final options = RateLimiterOptions(
    headers: {
      'X-Custom-Header': 'Rate limited',
    },
    onRateLimitExceeded: (request) async {
      return Response(
        429,
        body: jsonEncode({
          'status': false,
          'message': "Uh, hm! Wait a minute, that's a lot of request.",
        }),
        headers: {
          'Content-Type': 'application/json',
        },
      );
    },
  );

  final limiter = shelfLimiter(
    maxRequests: 5,
    windowSize: const Duration(minutes: 1),
    options: options,
  );

  final handler =
      const Pipeline().addMiddleware(limiter).addHandler(_echoRequest);

  var server = await io.serve(handler, 'localhost', 8080);
  print('Server listening on port ${server.port}');
}

Response _echoRequest(Request request) => Response.ok('Request received');

βš™οΈ Configuration #

Rate Limiter Options #

  • maxRequests: Maximum number of requests allowed within the specified window size.
  • windowSize: Duration of the time window for rate limiting.
  • headers: Custom headers to include in responses.
  • onRateLimitExceeded: Callback function to define custom behavior when the rate limit is exceeded.

πŸ§‘πŸ»β€πŸ’» Contributing #

We welcome contributions! Check out our GitHub repository to get started. Feel free to open issues, submit pull requests, or ask questions.

❀️ Support Us #

If shelf_limiter has been useful to you, consider supporting further development:

Thank you! #

4
likes
0
pub points
52%
popularity

Publisher

verified publisherxooniverse.com

A powerful and highly customizable rate limiter for shelf library, allowing you to easily manage and control request rates in your Dart server.

Repository (GitHub)
View/report issues

Topics

#shelf #throttle #rate-limiting #shelf-throttle #shelf-rate-limiter

Funding

Consider supporting this project:

buymeacoffee.com
paypal.me

License

unknown (license)

Dependencies

shelf

More

Packages that depend on shelf_limiter