NewRelicLogStrategy class
A LogStrategy implementation that sends logs to New Relic.
This strategy provides integration with New Relic's logging service, allowing for centralized log management and analysis. It supports structured logging with metadata and context information.
Features:
- HTTP-based log transmission to New Relic
- Structured logging with metadata
- Batch processing for efficiency
- Error handling and retry logic
- Performance monitoring
Example:
var newrelicStrategy = NewRelicLogStrategy(
licenseKey: 'your-newrelic-license-key',
appName: 'my-app',
);
var logger = StrategicLogger(strategies: [newrelicStrategy]);
logger.log("Application started.");
- Inheritance
-
- Object
- LogStrategy
- NewRelicLogStrategy
Constructors
-
NewRelicLogStrategy.new({required String licenseKey, required String appName, String? host, String? environment, String newrelicUrl = 'https://log-api.newrelic.com/log/v1', int batchSize = 100, Duration batchTimeout = const Duration(seconds: 5), int maxRetries = 3, Duration retryDelay = const Duration(seconds: 1), LogLevel logLevel = LogLevel.none, List<
LogEvent> ? supportedEvents}) - Constructs a NewRelicLogStrategy.
Properties
- appName → String
-
final
- batchSize → int
-
final
- batchTimeout → Duration
-
final
- environment → String?
-
final
- hashCode → int
-
The hash code for this object.
no setterinherited
- host → String?
-
final
- licenseKey → String
-
final
- loggerLogLevel ↔ LogLevel
-
The log level set by the logger using this strategy. Used to determine if a message should be logged.
getter/setter pairinherited
- logLevel ↔ LogLevel
-
The minimum log level that this strategy handles for logging.
getter/setter pairinherited
- maxRetries → int
-
final
- newrelicUrl → String
-
final
- retryDelay → Duration
-
final
- runtimeType → Type
-
A representation of the runtime type of the object.
no setterinherited
-
supportedEvents
↔ List<
LogEvent> ? -
A list of specific LogEvent types that this strategy supports. If null, all events are considered supported.
getter/setter pairinherited
Methods
-
dispose(
) → void - Disposes the strategy and cleans up resources
-
error(
{dynamic error, StackTrace? stackTrace, LogEvent? event}) → Future< void> -
Logs an error to New Relic
override
-
fatal(
{dynamic error, StackTrace? stackTrace, LogEvent? event}) → Future< void> -
Logs a fatal error to New Relic
override
-
flush(
) → Future< void> - Forces sending of all pending logs
-
info(
{dynamic message, LogEvent? event}) → Future< void> -
Logs an info message to New Relic
override
-
log(
{dynamic message, LogEvent? event}) → Future< void> -
Logs a message or event to New Relic
override
-
noSuchMethod(
Invocation invocation) → dynamic -
Invoked when a nonexistent method or property is accessed.
inherited
-
shouldLog(
{LogEvent? event}) → bool -
Determines whether a log operation should proceed based on the event and log level.
inherited
-
toString(
) → String -
Provides a string representation of the strategy including its type and log level.
inherited
Operators
-
operator ==(
Object other) → bool -
The equality operator.
inherited