Skip to content

Commit

Permalink
use ignore keys json parser
Browse files Browse the repository at this point in the history
  • Loading branch information
tonisives committed Jan 31, 2024
1 parent 63960fc commit 19d3741
Show file tree
Hide file tree
Showing 6 changed files with 32 additions and 25 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -66,7 +66,7 @@ internal class AccessCertificateRequests(
val response = call.await()

return tryParseResponse(response, HttpURLConnection.HTTP_CREATED) { body ->
val jsonResponse = Json.parseToJsonElement(body) as JsonObject
val jsonResponse = jsonIg.parseToJsonElement(body) as JsonObject
val certBytes = jsonResponse.jsonObject[apiDeviceCertKey]?.jsonPrimitive?.content
val cert = AccessCertificate(certBytes)
Response(cert, null)
Expand Down
2 changes: 1 addition & 1 deletion hmkit-fleet/src/main/kotlin/network/AuthTokenRequests.kt
Original file line number Diff line number Diff line change
Expand Up @@ -73,7 +73,7 @@ internal class AuthTokenRequests(

return try {
if (response.code == HttpURLConnection.HTTP_CREATED) {
cache.authToken = Json.decodeFromString(responseBody)
cache.authToken = jsonIg.decodeFromString(responseBody)
Response(cache.authToken)
} else {
parseError(responseBody)
Expand Down
18 changes: 9 additions & 9 deletions hmkit-fleet/src/main/kotlin/network/ClearanceRequests.kt
Original file line number Diff line number Diff line change
Expand Up @@ -69,11 +69,11 @@ internal class ClearanceRequests(
val response = call.await()

return tryParseResponse(response, HttpURLConnection.HTTP_OK) { responseBody ->
val jsonElement = Json.parseToJsonElement(responseBody) as JsonObject
val jsonElement = jsonIg.parseToJsonElement(responseBody) as JsonObject
val statuses = jsonElement["vehicles"] as JsonArray
for (statusElement in statuses) {
val status =
Json.decodeFromJsonElement<RequestClearanceResponse>(statusElement)
jsonIg.decodeFromJsonElement<RequestClearanceResponse>(statusElement)
if (status.vin == vin) {
return Response(status, null)
}
Expand All @@ -100,11 +100,11 @@ internal class ClearanceRequests(
val response = call.await()

return tryParseResponse(response, HttpURLConnection.HTTP_OK) { responseBody ->
val statuses = Json.parseToJsonElement(responseBody) as JsonArray
val statuses = jsonIg.parseToJsonElement(responseBody) as JsonArray

val builder = Array(statuses.size) {
val statusElement = statuses[it]
val status = Json.decodeFromJsonElement<ClearanceStatus>(statusElement)
val status = jsonIg.decodeFromJsonElement<ClearanceStatus>(statusElement)
status
}

Expand All @@ -130,7 +130,7 @@ internal class ClearanceRequests(
val response = call.await()

return tryParseResponse(response, HttpURLConnection.HTTP_OK) { responseBody ->
val status = Json.decodeFromString<ClearanceStatus>(responseBody)
val status = jsonIg.decodeFromString<ClearanceStatus>(responseBody)
Response(status)
}
}
Expand All @@ -154,7 +154,7 @@ internal class ClearanceRequests(
val response = call.await()

return tryParseResponse(response, HttpURLConnection.HTTP_OK) { responseBody ->
val status = Json.decodeFromString<RequestClearanceResponse>(responseBody)
val status = jsonIg.decodeFromString<RequestClearanceResponse>(responseBody)
Response(status)
}
}
Expand All @@ -166,14 +166,14 @@ internal class ClearanceRequests(
): RequestBody {
val vehicle = buildJsonObject {
put("vin", vin)
put("brand", Json.encodeToJsonElement(brand))
put("brand", jsonIg.encodeToJsonElement(brand))
if (controlMeasures != null) {
putJsonObject("control_measures") {
for (controlMeasure in controlMeasures) {
// polymorphism adds type key to child controlmeasure classes. remove with filter
val json = Json.encodeToJsonElement(controlMeasure)
val json = jsonIg.encodeToJsonElement(controlMeasure)
val valuesWithoutType = json.jsonObject.filterNot { it.key == "type" }
val jsonTrimmed = Json.encodeToJsonElement(valuesWithoutType)
val jsonTrimmed = jsonIg.encodeToJsonElement(valuesWithoutType)
put("odometer", jsonTrimmed)
}
}
Expand Down
21 changes: 14 additions & 7 deletions hmkit-fleet/src/main/kotlin/network/Requests.kt
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,15 @@ internal open class Requests(
val mediaType = "application/json; charset=utf-8".toMediaType()
val baseHeaders = Headers.Builder().add("Content-Type", "application/json").build()

protected val jsonIg = Json {
ignoreUnknownKeys = true
}

private val jsonIgPr = Json {
ignoreUnknownKeys = true
prettyPrint = true
}

inline fun <T> tryParseResponse(
response: Response,
expectedResponseCode: Int,
Expand All @@ -61,14 +70,12 @@ internal open class Requests(
}

fun printRequest(request: Request) {
val format = Json { prettyPrint = true }

// parse into json, so can log it out with pretty print
val body = request.bodyAsString()
var bodyInPrettyPrint = ""
if (!body.isNullOrBlank()) {
val jsonElement = format.decodeFromString<JsonElement>(body)
bodyInPrettyPrint = format.encodeToString(jsonElement)
val jsonElement = jsonIgPr.decodeFromString<JsonElement>(body)
bodyInPrettyPrint = jsonIgPr.encodeToString(jsonElement)
}

logger.debug(
Expand All @@ -85,14 +92,14 @@ internal open class Requests(
}

fun <T> parseError(responseBody: String): com.highmobility.hmkitfleet.network.Response<T> {
val json = Json.parseToJsonElement(responseBody)
val json = jsonIg.parseToJsonElement(responseBody)
if (json is JsonObject) {
// there are 3 error formats
val errors = json["errors"] as? JsonArray

return if (errors != null && errors.size > 0) {
val error =
Json.decodeFromJsonElement<Error>(errors.first())
jsonIg.decodeFromJsonElement<Error>(errors.first())
Response(null, error)
} else {
val error = Error(
Expand All @@ -104,7 +111,7 @@ internal open class Requests(
}
} else if (json is JsonArray) {
if (json.size > 0) {
val error = Json.decodeFromJsonElement<Error>(json.first())
val error = jsonIg.decodeFromJsonElement<Error>(json.first())

Check warning on line 114 in hmkit-fleet/src/main/kotlin/network/Requests.kt

View check run for this annotation

Codecov / codecov/patch

hmkit-fleet/src/main/kotlin/network/Requests.kt#L114

Added line #L114 was not covered by tests
return Response(null, error)
}
}
Expand Down
8 changes: 4 additions & 4 deletions hmkit-fleet/src/main/kotlin/network/TelematicsRequests.kt
Original file line number Diff line number Diff line change
Expand Up @@ -114,7 +114,7 @@ internal class TelematicsRequests(
val response = call.await()

return tryParseResponse(response, HttpURLConnection.HTTP_CREATED) { body ->
val jsonResponse = Json.parseToJsonElement(body) as JsonObject
val jsonResponse = jsonIg.parseToJsonElement(body) as JsonObject
val nonce = jsonResponse.jsonObject["nonce"]?.jsonPrimitive?.content
Response(nonce, null)
}
Expand Down Expand Up @@ -145,7 +145,7 @@ internal class TelematicsRequests(

val responseObject = try {
if (response.code == 200 || response.code == 400 || response.code == 404 || response.code == 408) {
val telematicsResponse = Json.decodeFromString<TelematicsCommandResponse>(responseBody)
val telematicsResponse = jsonIg.decodeFromString<TelematicsCommandResponse>(responseBody)

// Server only returns encrypted data if status is OK
val decryptedData = if (telematicsResponse.status == TelematicsCommandResponse.Status.OK) {
Expand All @@ -168,7 +168,7 @@ internal class TelematicsRequests(
} else {
// try to parse the normal server error format.
// it will throw and will be caught if server returned unknown format
TelematicsResponse(errors = Json.decodeFromString(responseBody))
TelematicsResponse(errors = jsonIg.decodeFromString(responseBody))
}
} catch (e: Exception) {
TelematicsResponse(errors = listOf(Error(title = "Unknown server response", detail = e.message)))
Expand Down Expand Up @@ -201,7 +201,7 @@ internal class TelematicsRequests(
val response = call.await()

Check warning on line 201 in hmkit-fleet/src/main/kotlin/network/TelematicsRequests.kt

View check run for this annotation

Codecov / codecov/patch

hmkit-fleet/src/main/kotlin/network/TelematicsRequests.kt#L200-L201

Added lines #L200 - L201 were not covered by tests

return tryParseResponse(response, HttpURLConnection.HTTP_OK) { body ->
val jsonResponse = Json.parseToJsonElement(body) as JsonObject
val jsonResponse = jsonIg.parseToJsonElement(body) as JsonObject
val encryptedResponseCommand =

Check warning on line 205 in hmkit-fleet/src/main/kotlin/network/TelematicsRequests.kt

View check run for this annotation

Codecov / codecov/patch

hmkit-fleet/src/main/kotlin/network/TelematicsRequests.kt#L203-L205

Added lines #L203 - L205 were not covered by tests
jsonResponse.jsonObject["response_data"]?.jsonPrimitive?.content
Response(Bytes(encryptedResponseCommand), null)

Check warning on line 207 in hmkit-fleet/src/main/kotlin/network/TelematicsRequests.kt

View check run for this annotation

Codecov / codecov/patch

hmkit-fleet/src/main/kotlin/network/TelematicsRequests.kt#L207

Added line #L207 was not covered by tests
Expand Down
6 changes: 3 additions & 3 deletions hmkit-fleet/src/main/kotlin/network/UtilityRequests.kt
Original file line number Diff line number Diff line change
Expand Up @@ -70,7 +70,7 @@ internal class UtilityRequests(
val response = call.await()

return tryParseResponse(response, HttpURLConnection.HTTP_OK) { responseBody ->
val eligibilityStatus = Json.decodeFromString<EligibilityStatus>(responseBody)
val eligibilityStatus = jsonIg.decodeFromString<EligibilityStatus>(responseBody)
if (eligibilityStatus.vin != vin) logger.warn("VIN in response does not match VIN in request")
Response(eligibilityStatus, null)
}
Expand All @@ -82,10 +82,10 @@ internal class UtilityRequests(
): RequestBody {
val vehicle = buildJsonObject {
put("vin", vin)
put("brand", Json.encodeToJsonElement(brand))
put("brand", jsonIg.encodeToJsonElement(brand))
}

val body = Json.encodeToString(vehicle).toRequestBody(mediaType)
val body = jsonIg.encodeToString(vehicle).toRequestBody(mediaType)
return body
}
}

0 comments on commit 19d3741

Please sign in to comment.