From 2fe70bcfec1d951837b5b9098d057d3dd4e714a3 Mon Sep 17 00:00:00 2001 From: Matt Straathof Date: Tue, 19 Dec 2023 15:16:34 -0800 Subject: [PATCH 1/3] chore: add log level to topic configuration --- lib/client_sdk_dart.dart | 1 + lib/src/config/logger.dart | 27 ++++++++++++++++++++++++ lib/src/config/topic_configuration.dart | 20 ++++++++++++------ lib/src/config/topic_configurations.dart | 5 +++-- lib/src/topic_client.dart | 2 ++ 5 files changed, 47 insertions(+), 8 deletions(-) create mode 100644 lib/src/config/logger.dart diff --git a/lib/client_sdk_dart.dart b/lib/client_sdk_dart.dart index 6c393d2..df856ea 100644 --- a/lib/client_sdk_dart.dart +++ b/lib/client_sdk_dart.dart @@ -4,5 +4,6 @@ library; export 'src/topic_client.dart'; +export 'src/config/logger.dart' show LogLevel; // TODO: Export any libraries intended for clients of this package. diff --git a/lib/src/config/logger.dart b/lib/src/config/logger.dart new file mode 100644 index 0000000..715468f --- /dev/null +++ b/lib/src/config/logger.dart @@ -0,0 +1,27 @@ +import 'package:logging/logging.dart'; + +enum LogLevel { + trace, + debug, + info, + warn, + error, + fatal, +} + +Level determineLoggerLevel(LogLevel logLevel) { + switch (logLevel) { + case LogLevel.trace: + return Level.ALL; + case LogLevel.debug: + return Level.FINE; + case LogLevel.info: + return Level.INFO; + case LogLevel.warn: + return Level.WARNING; + case LogLevel.error: + return Level.SEVERE; + case LogLevel.fatal: + return Level.SHOUT; + } +} \ No newline at end of file diff --git a/lib/src/config/topic_configuration.dart b/lib/src/config/topic_configuration.dart index 9b9396a..d264b3a 100644 --- a/lib/src/config/topic_configuration.dart +++ b/lib/src/config/topic_configuration.dart @@ -1,3 +1,5 @@ +import 'package:client_sdk_dart/src/config/logger.dart'; + import 'transport/grpc_configuration.dart'; import 'transport/transport_strategy.dart'; @@ -5,8 +7,11 @@ abstract interface class TopicConfiguration { /// Configures low-level options for network interactions with the Momento service late TransportStrategy transportStrategy; + /// Configures the verbosity of the client-side logger + LogLevel logLevel; + /// Constructor for a TopicConfiguration - TopicConfiguration(this.transportStrategy); + TopicConfiguration(this.transportStrategy, this.logLevel); /// Copy constructor for overriding TransportStrategy TopicConfiguration withTransportStrategy(TransportStrategy transportStrategy); @@ -23,17 +28,20 @@ class TopicClientConfiguration implements TopicConfiguration { @override late TransportStrategy transportStrategy; - TopicClientConfiguration(this.transportStrategy); + @override + LogLevel logLevel; + + TopicClientConfiguration(this.transportStrategy, this.logLevel); @override TopicConfiguration withTransportStrategy( - TransportStrategy transportStrategy) { - return TopicClientConfiguration(transportStrategy); + TransportStrategy transportStrategy, {LogLevel logLevel = LogLevel.info}) { + return TopicClientConfiguration(transportStrategy, logLevel); } @override - TopicConfiguration withDeadline(Duration deadline) { + TopicConfiguration withDeadline(Duration deadline, {LogLevel logLevel = LogLevel.info}) { return TopicClientConfiguration( - StaticTransportStrategy(StaticGrpcConfiguration(deadline))); + StaticTransportStrategy(StaticGrpcConfiguration(deadline)), logLevel); } } diff --git a/lib/src/config/topic_configurations.dart b/lib/src/config/topic_configurations.dart index 2a8fea0..94835e9 100644 --- a/lib/src/config/topic_configurations.dart +++ b/lib/src/config/topic_configurations.dart @@ -1,3 +1,4 @@ +import 'logger.dart'; import 'topic_configuration.dart'; import 'transport/grpc_configuration.dart'; import 'transport/transport_strategy.dart'; @@ -11,8 +12,8 @@ class Mobile extends TopicClientConfigurations { return latest(); } - static TopicClientConfiguration latest() { + static TopicClientConfiguration latest({LogLevel logLevel = LogLevel.info}) { return TopicClientConfiguration(StaticTransportStrategy( - StaticGrpcConfiguration(Duration(seconds: 15)))); + StaticGrpcConfiguration(Duration(seconds: 15))), logLevel); } } diff --git a/lib/src/topic_client.dart b/lib/src/topic_client.dart index ae2bcb0..439aba2 100644 --- a/lib/src/topic_client.dart +++ b/lib/src/topic_client.dart @@ -1,4 +1,5 @@ import 'package:client_sdk_dart/src/auth/credential_provider.dart'; +import 'package:client_sdk_dart/src/config/logger.dart'; import 'package:logging/logging.dart'; import 'config/topic_configuration.dart'; import 'internal/pubsub_client.dart'; @@ -20,6 +21,7 @@ class TopicClient implements ITopicClient { TopicClient( CredentialProvider credentialProvider, TopicConfiguration configuration) : _pubsubClient = ClientPubsub(credentialProvider, configuration) { + _logger.level = determineLoggerLevel(configuration.logLevel); _logger.finest("initializing topic client"); } From e3bc173ec0701b2221530d523582cc8cd418e202 Mon Sep 17 00:00:00 2001 From: Matt Straathof Date: Tue, 19 Dec 2023 15:19:34 -0800 Subject: [PATCH 2/3] chore: add log level to cache configuration --- lib/src/config/cache_configuration.dart | 29 ++++++++++++++++-------- lib/src/config/cache_configurations.dart | 8 ++++--- lib/src/config/logger.dart | 2 +- lib/src/config/topic_configuration.dart | 13 +++++++---- lib/src/config/topic_configurations.dart | 5 ++-- 5 files changed, 37 insertions(+), 20 deletions(-) diff --git a/lib/src/config/cache_configuration.dart b/lib/src/config/cache_configuration.dart index 912dd67..6d03f8f 100644 --- a/lib/src/config/cache_configuration.dart +++ b/lib/src/config/cache_configuration.dart @@ -1,36 +1,47 @@ import 'package:client_sdk_dart/src/config/transport/grpc_configuration.dart'; import 'package:client_sdk_dart/src/config/transport/transport_strategy.dart'; +import '../../client_sdk_dart.dart'; + abstract interface class CacheConfiguration { /// Configures low-level options for network interactions with the Momento service late TransportStrategy transportStrategy; + /// Configures the verbosity of the client-side logger + LogLevel logLevel; + /// Constructor for a CacheConfiguration - CacheConfiguration(this.transportStrategy); + CacheConfiguration(this.transportStrategy, this.logLevel); /// Copy constructor for overriding TransportStrategy - CacheConfiguration withTransportStrategy(TransportStrategy transportStrategy); + CacheConfiguration withTransportStrategy(TransportStrategy transportStrategy, + {LogLevel logLevel = LogLevel.info}); /// Convenience copy constructor that updates the client-side /// timeout setting in the transport strategy - CacheConfiguration withDeadline(Duration deadline); + CacheConfiguration withDeadline(Duration deadline, + {LogLevel logLevel = LogLevel.info}); } class CacheClientConfiguration implements CacheConfiguration { @override late TransportStrategy transportStrategy; - CacheClientConfiguration(this.transportStrategy); + @override + LogLevel logLevel; + + CacheClientConfiguration(this.transportStrategy, this.logLevel); @override - CacheConfiguration withTransportStrategy( - TransportStrategy transportStrategy) { - return CacheClientConfiguration(transportStrategy); + CacheConfiguration withTransportStrategy(TransportStrategy transportStrategy, + {LogLevel logLevel = LogLevel.info}) { + return CacheClientConfiguration(transportStrategy, logLevel); } @override - CacheConfiguration withDeadline(Duration deadline) { + CacheConfiguration withDeadline(Duration deadline, + {LogLevel logLevel = LogLevel.info}) { return CacheClientConfiguration( - StaticTransportStrategy(StaticGrpcConfiguration(deadline))); + StaticTransportStrategy(StaticGrpcConfiguration(deadline)), logLevel); } } diff --git a/lib/src/config/cache_configurations.dart b/lib/src/config/cache_configurations.dart index 38d868b..fa515ff 100644 --- a/lib/src/config/cache_configurations.dart +++ b/lib/src/config/cache_configurations.dart @@ -1,6 +1,7 @@ import 'package:client_sdk_dart/src/config/transport/grpc_configuration.dart'; import 'package:client_sdk_dart/src/config/transport/transport_strategy.dart'; +import '../../client_sdk_dart.dart'; import 'cache_configuration.dart'; /// Prebuilt configurations for Momento Cache clients @@ -12,8 +13,9 @@ class Mobile extends CacheClientConfigurations { return latest(); } - static CacheClientConfiguration latest() { - return CacheClientConfiguration(StaticTransportStrategy( - StaticGrpcConfiguration(Duration(seconds: 15)))); + static CacheClientConfiguration latest({logLevel = LogLevel.info}) { + return CacheClientConfiguration( + StaticTransportStrategy(StaticGrpcConfiguration(Duration(seconds: 15))), + logLevel); } } diff --git a/lib/src/config/logger.dart b/lib/src/config/logger.dart index 715468f..49fd4fb 100644 --- a/lib/src/config/logger.dart +++ b/lib/src/config/logger.dart @@ -24,4 +24,4 @@ Level determineLoggerLevel(LogLevel logLevel) { case LogLevel.fatal: return Level.SHOUT; } -} \ No newline at end of file +} diff --git a/lib/src/config/topic_configuration.dart b/lib/src/config/topic_configuration.dart index d264b3a..c916216 100644 --- a/lib/src/config/topic_configuration.dart +++ b/lib/src/config/topic_configuration.dart @@ -14,11 +14,13 @@ abstract interface class TopicConfiguration { TopicConfiguration(this.transportStrategy, this.logLevel); /// Copy constructor for overriding TransportStrategy - TopicConfiguration withTransportStrategy(TransportStrategy transportStrategy); + TopicConfiguration withTransportStrategy(TransportStrategy transportStrategy, + {LogLevel logLevel = LogLevel.info}); /// Convenience copy constructor that updates the client-side /// timeout setting in the transport strategy - TopicConfiguration withDeadline(Duration deadline); + TopicConfiguration withDeadline(Duration deadline, + {LogLevel logLevel = LogLevel.info}); } /// Configuration options for Momento TopicClient. @@ -34,13 +36,14 @@ class TopicClientConfiguration implements TopicConfiguration { TopicClientConfiguration(this.transportStrategy, this.logLevel); @override - TopicConfiguration withTransportStrategy( - TransportStrategy transportStrategy, {LogLevel logLevel = LogLevel.info}) { + TopicConfiguration withTransportStrategy(TransportStrategy transportStrategy, + {LogLevel logLevel = LogLevel.info}) { return TopicClientConfiguration(transportStrategy, logLevel); } @override - TopicConfiguration withDeadline(Duration deadline, {LogLevel logLevel = LogLevel.info}) { + TopicConfiguration withDeadline(Duration deadline, + {LogLevel logLevel = LogLevel.info}) { return TopicClientConfiguration( StaticTransportStrategy(StaticGrpcConfiguration(deadline)), logLevel); } diff --git a/lib/src/config/topic_configurations.dart b/lib/src/config/topic_configurations.dart index 94835e9..39566a7 100644 --- a/lib/src/config/topic_configurations.dart +++ b/lib/src/config/topic_configurations.dart @@ -13,7 +13,8 @@ class Mobile extends TopicClientConfigurations { } static TopicClientConfiguration latest({LogLevel logLevel = LogLevel.info}) { - return TopicClientConfiguration(StaticTransportStrategy( - StaticGrpcConfiguration(Duration(seconds: 15))), logLevel); + return TopicClientConfiguration( + StaticTransportStrategy(StaticGrpcConfiguration(Duration(seconds: 15))), + logLevel); } } From 47ce4df618a32a985fa459fe5391cce57c7c415d Mon Sep 17 00:00:00 2001 From: Matt Straathof Date: Tue, 19 Dec 2023 15:28:11 -0800 Subject: [PATCH 3/3] chore: add readme instructions for using the logLevel property --- README.md | 19 +++++++++++++------ lib/src/config/cache_configurations.dart | 2 +- lib/src/config/logger.dart | 3 +++ 3 files changed, 17 insertions(+), 7 deletions(-) diff --git a/README.md b/README.md index 15b93e4..b97de40 100644 --- a/README.md +++ b/README.md @@ -47,13 +47,20 @@ const like = 'sample'; ## Logging -We use the [Dart logging package](https://github.com/dart-lang/logging) to create internal Loggers for producing Momento-related logs. The default logger does not do anything with the logs, so you must configure the logging level and handler at the beginning of your program: +There is a `LogLevel` enum that contains the following log levels: -``` -Logger.root.level = Level.ALL; // defaults to Level.INFO -Logger.root.onRecord.listen((record) { - print('${record.level.name}: ${record.time}: ${record.message}'); -}); +* `LogLevel.trace` +* `LogLevel.debug` +* `LogLevel.info` +* `LogLevel.warn` +* `LogLevel.error` +* `LogLevel.fatal` +* `LogLevel.off` + +This enum can be used to configure the logging level of the Momento package. By default, the logging level is set to `LogLevel.info`. To change the logging level, pass the desired level to the `Configuration` constructor: + +```dart +var config = Mobile.latest(logLevel: LogLevel.debug); ``` ## Additional information diff --git a/lib/src/config/cache_configurations.dart b/lib/src/config/cache_configurations.dart index fa515ff..af2e6a6 100644 --- a/lib/src/config/cache_configurations.dart +++ b/lib/src/config/cache_configurations.dart @@ -13,7 +13,7 @@ class Mobile extends CacheClientConfigurations { return latest(); } - static CacheClientConfiguration latest({logLevel = LogLevel.info}) { + static CacheClientConfiguration latest({LogLevel logLevel = LogLevel.info}) { return CacheClientConfiguration( StaticTransportStrategy(StaticGrpcConfiguration(Duration(seconds: 15))), logLevel); diff --git a/lib/src/config/logger.dart b/lib/src/config/logger.dart index 49fd4fb..2d897f3 100644 --- a/lib/src/config/logger.dart +++ b/lib/src/config/logger.dart @@ -7,6 +7,7 @@ enum LogLevel { warn, error, fatal, + off, } Level determineLoggerLevel(LogLevel logLevel) { @@ -23,5 +24,7 @@ Level determineLoggerLevel(LogLevel logLevel) { return Level.SEVERE; case LogLevel.fatal: return Level.SHOUT; + case LogLevel.off: + return Level.OFF; } }