dart_seq 0.0.1  dart_seq: ^0.0.1 copied to clipboard
dart_seq: ^0.0.1 copied to clipboard
A Dart logging client for (batched) Seq HTTP ingestion with automated retries.
dart_seq is a powerful and versatile logging solution for Dart, designed to simplify the process of sending log entries to a Seq server. It supports all platforms supported by Dart, including Windows, Android, iOS, macOS, and Web, making it a versatile choice for logging in various Dart applications.
Features #
- Logging to Seq Server: dart_seqseamlessly integrates with Seq servers, enabling you to send log entries directly to your Seq instance. This allows you to centralize and analyze logs efficiently, aiding in troubleshooting, debugging, and monitoring your Dart applications.
- Cross-Platform Support: With dart_seq, you can enjoy consistent logging capabilities across all Dart-supported platforms. It leverages the inherent cross-platform capabilities of Dart, making it easy to adopt and utilize in your applications, regardless of the target platform.
- Customizable Seq Client and Caching Implementations: dart_seqprovides an intuitive and flexible interface to customize your Seq client and caching implementations. This enables you to tailor the logging behavior to your specific requirements and preferences, adapting the library to various use cases and scenarios in your Dart applications.
- Batch Sending of Events: dart_seqoptimizes log transmission by sending events to Seq in batches. This helps minimize network overhead and improves overall logging performance, especially in high-traffic scenarios.
- Automatic Retry Mechanism: The library automatically retries failed requests to the Seq server, except in the case of 429 (Too Many Requests) responses. This built-in resilience ensures that log entries are reliably delivered, even in the face of intermittent network connectivity or temporary server unavailability.
- Minimum Log Level Enforcement: dart_seqkeeps track of the server-side configured minimum log level and discards events that fall below this threshold. This feature helps reduce unnecessary log entries and ensures that only relevant and significant events are forwarded to the Seq server.
With dart_seq, logging in your Dart applications becomes a breeze, ensuring that your logs are efficiently delivered to Seq servers across multiple platforms.
The library's batch sending, automatic retry, and minimum log level enforcement features enhance the logging experience and provide robustness and flexibility to your logging infrastructure.
Getting Started #
To start using dart_seq in your Dart application, follow these steps:
- Install the library using dart pub add dart_seq
- Import the package: import 'package:dart_seq/dart_seq.dart';
- Instantiate the SeqLoggerclass
- Start logging
Usage #
// configure your logger
final logger = SeqLogger.http(
  host: "http://localhost:5341",
  globalContext: {
    "Environment": Platform.environment,
  }
);
// add log events
logger.log(SeqLogLevel.information, "test, dart: {Dart}", {
"Dart": Platform.version,
});
// don't forget to flush your logs at the end!
logger.flush();
Additional information #
- Feature requests and bug reports should be reported using GitHub issues.
- Contributions are welcome! If you'd like to contribute, please follow the guidelines outlined in the CONTRIBUTING.md file.