diff --git a/src/main/kotlin/ru/kotlin/homework/network/NetworkLogger.kt b/src/main/kotlin/ru/kotlin/homework/network/NetworkLogger.kt index a5f33c5..39c06a8 100644 --- a/src/main/kotlin/ru/kotlin/homework/network/NetworkLogger.kt +++ b/src/main/kotlin/ru/kotlin/homework/network/NetworkLogger.kt @@ -15,9 +15,9 @@ sealed class ApiException(message: String) : Throwable(message) { data object UnknownException: ApiException("Unknown exception") } -class ErrorLogger { +class ErrorLogger { - val errors = mutableListOf>() + private val errors = mutableListOf>() fun log(response: NetworkResponse<*, E>) { if (response is Failure) { @@ -27,9 +27,13 @@ class ErrorLogger { fun dumpLog() { errors.forEach { (date, error) -> - println("Error at $date: ${error.message}") + println("Error at $date: ${error.toString()}") } } + + fun dump(): List> { + return errors + } } fun processThrowables(logger: ErrorLogger) { @@ -60,5 +64,10 @@ fun main() { println("Processing Api:") processApiErrors(logger) + + println("Getting error list:") + val list: List> = logger.dump() + list.forEach(){ (date, error) -> + println("Error at $date: ${error.toString()}")} } diff --git a/src/main/kotlin/ru/kotlin/homework/network/NetworkResponse.kt b/src/main/kotlin/ru/kotlin/homework/network/NetworkResponse.kt index 3018c40..f35dbc2 100644 --- a/src/main/kotlin/ru/kotlin/homework/network/NetworkResponse.kt +++ b/src/main/kotlin/ru/kotlin/homework/network/NetworkResponse.kt @@ -9,19 +9,19 @@ import java.time.LocalDateTime /** * Network result */ -sealed class NetworkResponse { +sealed class NetworkResponse { val responseDateTime: LocalDateTime = LocalDateTime.now() } /** * Network success */ -data class Success(val resp: T): NetworkResponse() +data class Success(val resp: T): NetworkResponse() /** * Network error */ -data class Failure(val error: R): NetworkResponse() +data class Failure(val error: R): NetworkResponse() val s1 = Success("Message") val r11: NetworkResponse = s1