From bdb58c2f9c427a280db183d1e567e17a9595dcf8 Mon Sep 17 00:00:00 2001 From: Tristan Lohman Date: Tue, 21 May 2024 10:27:33 -0700 Subject: [PATCH 1/3] correct info --- .../typelevel/log4cats/PagingSelfAwareStructuredLogger.scala | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/core/shared/src/main/scala/org/typelevel/log4cats/PagingSelfAwareStructuredLogger.scala b/core/shared/src/main/scala/org/typelevel/log4cats/PagingSelfAwareStructuredLogger.scala index 300f9280..8fd2ae93 100644 --- a/core/shared/src/main/scala/org/typelevel/log4cats/PagingSelfAwareStructuredLogger.scala +++ b/core/shared/src/main/scala/org/typelevel/log4cats/PagingSelfAwareStructuredLogger.scala @@ -120,12 +120,15 @@ object PagingSelfAwareStructuredLogger { ): F[(String, Map[String, String])] = randomUUID.map { uuid => val logSplitId = uuid.show + val msgLength = msg.length.show ( logSplitId, ctx .updated(logSplitIdN, logSplitId) .updated("page_size", s"${pageSizeK.show} Kib") - .updated("log_size", s"${msg.length.show} Byte") + .updated("log_size_bytes", msgLength) + // The following is deprecated + .updated("log_size", s"${msgLength} Byte") ) } From fdcaea5ded346f1aec9d317d29ef6c297d84821b Mon Sep 17 00:00:00 2001 From: Tristan Lohman Date: Tue, 21 May 2024 10:41:54 -0700 Subject: [PATCH 2/3] log bytes per page, with more attributes --- .../PagingSelfAwareStructuredLogger.scala | 30 ++++++++++++++----- 1 file changed, 22 insertions(+), 8 deletions(-) diff --git a/core/shared/src/main/scala/org/typelevel/log4cats/PagingSelfAwareStructuredLogger.scala b/core/shared/src/main/scala/org/typelevel/log4cats/PagingSelfAwareStructuredLogger.scala index 8fd2ae93..4d37b821 100644 --- a/core/shared/src/main/scala/org/typelevel/log4cats/PagingSelfAwareStructuredLogger.scala +++ b/core/shared/src/main/scala/org/typelevel/log4cats/PagingSelfAwareStructuredLogger.scala @@ -87,14 +87,15 @@ object PagingSelfAwareStructuredLogger { private val pageSize = pageSizeK * 1024 private def pagedLogging( - loggingOp: (=> String) => F[Unit], + logOpWithCtx: Map[String, String] => (=> String) => F[Unit], + ctx: Map[String, String], logSplitId: String, msg: => String ): F[Unit] = { val numOfPagesRaw = (msg.length - 1) / pageSize + 1 val numOfPages = Math.min(numOfPagesRaw, maxPageNeeded) if (numOfPages <= 1) - loggingOp(msg) + logOpWithCtx(addPageCtx(msg, 1, 1, ctx))(msg) else { val logSplitIdPart1 = logSplitId.split('-').head val pageHeaderTail = s"$numOfPages $logSplitIdPart1" @@ -105,16 +106,18 @@ object PagingSelfAwareStructuredLogger { val beginIndex = (pi - 1) * pageSize val pageContent = msg.slice(beginIndex, beginIndex + pageSize) - loggingOp(show"""Page $pi/$pageHeaderTail + val page = show"""Page $pi/$pageHeaderTail | |$pageContent | - |Page $pi/$pageFooterTail""".stripMargin) + |Page $pi/$pageFooterTail""".stripMargin + + logOpWithCtx(addPageCtx(page, pi, numOfPages, ctx))(page) } } } - private def addCtx( + private def addMsgCtx( msg: => String, ctx: Map[String, String] ): F[(String, Map[String, String])] = @@ -126,12 +129,23 @@ object PagingSelfAwareStructuredLogger { ctx .updated(logSplitIdN, logSplitId) .updated("page_size", s"${pageSizeK.show} Kib") - .updated("log_size_bytes", msgLength) + .updated("whole_message_size_bytes", msgLength) // The following is deprecated .updated("log_size", s"${msgLength} Byte") ) } + private def addPageCtx( + page: => String, + pageNum: => Int, + totalPages: => Int, + ctx: Map[String, String] + ): Map[String, String] = + ctx + .updated("total_pages", totalPages.show) + .updated("page_num", pageNum.show) + .updated("log_size_bytes", page.length.show) + private def doLogging( loggingLevelChk: => F[Boolean], logOpWithCtx: Map[String, String] => (=> String) => F[Unit], @@ -139,8 +153,8 @@ object PagingSelfAwareStructuredLogger { ctx: Map[String, String] = Map() ): F[Unit] = { loggingLevelChk.ifM( - addCtx(msg, ctx).flatMap { case (logSplitId, newCtx) => - pagedLogging(logOpWithCtx(newCtx), logSplitId, msg) + addMsgCtx(msg, ctx).flatMap { case (logSplitId, newCtx) => + pagedLogging(logOpWithCtx, newCtx, logSplitId, msg) }, Applicative[F].unit ) From b298fc8494381359c66cf9ddbd459e9deb7dad3c Mon Sep 17 00:00:00 2001 From: Tristan Lohman Date: Tue, 21 May 2024 11:15:04 -0700 Subject: [PATCH 3/3] prePR --- .../log4cats/PagingSelfAwareStructuredLogger.scala | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/core/shared/src/main/scala/org/typelevel/log4cats/PagingSelfAwareStructuredLogger.scala b/core/shared/src/main/scala/org/typelevel/log4cats/PagingSelfAwareStructuredLogger.scala index 4d37b821..5ab16662 100644 --- a/core/shared/src/main/scala/org/typelevel/log4cats/PagingSelfAwareStructuredLogger.scala +++ b/core/shared/src/main/scala/org/typelevel/log4cats/PagingSelfAwareStructuredLogger.scala @@ -87,8 +87,8 @@ object PagingSelfAwareStructuredLogger { private val pageSize = pageSizeK * 1024 private def pagedLogging( - logOpWithCtx: Map[String, String] => (=> String) => F[Unit], - ctx: Map[String, String], + logOpWithCtx: Map[String, String] => (=> String) => F[Unit], + ctx: Map[String, String], logSplitId: String, msg: => String ): F[Unit] = { @@ -136,10 +136,10 @@ object PagingSelfAwareStructuredLogger { } private def addPageCtx( - page: => String, - pageNum: => Int, - totalPages: => Int, - ctx: Map[String, String] + page: => String, + pageNum: => Int, + totalPages: => Int, + ctx: Map[String, String] ): Map[String, String] = ctx .updated("total_pages", totalPages.show)