Akkurate 0.11.0 Help

Ktor Client

Ktor Client is a framework for building asynchronous client-side applications. Akkurate provides an integration to automatically validate downloaded data.

A code example of the Ktor Client integration, used to showcase Akkurate on social networks.

Installation

Before using Akkurate with Ktor, you need to add the following dependency to your Gradle script:

Add the Akkurate plugin for Ktor

implementation("dev.nesk.akkurate:akkurate-ktor-client:0.11.0")

    Validate on deserialization

    We want to retrieve the latest releases of Akkurate, using GitHub's API:

    @Validate @Serializable data class Release(val name: String) suspend fun main() { val client = HttpClient(CIO) { install(ContentNegotiation) { json(Json { ignoreUnknownKeys = true }) } } val apiUrl = "https://api.github.com/repos/nesk/akkurate/releases" val response: HttpResponse = client.get(apiUrl) val data: List<Release> = response.body() println(data) }
    [ Release(name=Akkurate 0.10.0), Release(name=Akkurate 0.9.1), Release(name=Akkurate 0.9.0), ... ]

    Although this API is probably well maintained, we fear potential issues on the API side, like bugs or breaking changes. To protect ourselves, we want to validate the response body:

    val validateReleaseList = Validator<List<Release>> { each { name.isNotEmpty() } }

    And we register this validator in our client:

    install(Akkurate) { registerValidator(validateReleaseList) }

    Now, when deserializing the response body, the Release instances are automatically validated, and an exception is thrown when invalid:

    try { val data: List<Release> = response.body() println(data) } catch (exception: ValidationResult.Exception) { System.err.println("Invalid response: ${exception.violations}") }
    Last modified: 22 January 2025