amiibo-service/Sources/Clients/AmiiboClient.swift
Javier Cicchelli 68acf82f9d [Feature] Client (#3)
This PR contains the work done to implement the `AmiiboClient` struct that conforms to the `Client` protocol coming from the **Communications** library of the [SwiftLibs package](https://github.com/rock-n-code/swift-libs)

To provide further detailks about the work done:
- [x] added the `parameters` property to all the existing endpoints;
- [x] implemented the `AmiiboClient` client and the `AmiiboClientError` error;
- [x] implemented some static formatters in the `DateFormatter+Formatter` extension;
- [x] updated the `SwiftLibs` package to its latest version.

Co-authored-by: Javier Cicchelli <javier@rock-n-code.com>
Reviewed-on: #3
2023-04-19 14:33:48 +00:00

67 lines
1.5 KiB
Swift

import Communications
import Foundation
struct AmiiboClient {
// MARK: Properties
private let session: URLSession
private let decoder = JSONDecoder()
private let makeURLRequest = MakeURLRequestUseCase()
// MARK: Initialisers
init(configuration: URLSessionConfiguration) {
session = .init(configuration: configuration)
}
// MARK: Functions
func setDateDecodingStrategy(_ dateDecodingStrategy: JSONDecoder.DateDecodingStrategy) {
decoder.dateDecodingStrategy = dateDecodingStrategy
}
}
// MARK: - Client
extension AmiiboClient: Client {
// MARK: Functions
func request<Model>(
endpoint: some Endpoint,
as model: Model.Type
) async throws -> Model where Model : Decodable {
let urlRequest = try makeURLRequest(endpoint: endpoint)
let (data, response) = try await session.data(for: urlRequest)
try check(response)
return try decoder.decode(model, from: data)
}
}
// MARK: - Helpers
private extension AmiiboClient {
// MARK: Functions
func check(_ response: URLResponse) throws {
guard
let urlResponse = response as? HTTPURLResponse,
let responseCode = HTTPResponseCode(rawValue: urlResponse.statusCode)
else {
throw AmiiboClientError.responseCodeNotFound
}
guard responseCode == .ok else {
throw AmiiboClientError.responseCode(responseCode.rawValue)
}
}
}