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

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