34627840db
This PR contains the work done to: * update the header files of all the existing source files in the project with the Apache License; * update the main article of the `DocC` documentation catalog; * update the `README` file; * regenerate the Github Pages documentation from the `DocC` documentation catalog. Reviewed-on: #18 Co-authored-by: Javier Cicchelli <javier@rock-n-code.com> Co-committed-by: Javier Cicchelli <javier@rock-n-code.com>
43 lines
1.2 KiB
Swift
43 lines
1.2 KiB
Swift
// ===----------------------------------------------------------------------===
|
|
//
|
|
// This source file is part of the Amiibo Service open source project
|
|
//
|
|
// Copyright (c) 2025 Röck+Cöde VoF. and the Amiibo Service project authors
|
|
// Licensed under Apache license v2.0
|
|
//
|
|
// See LICENSE for license information
|
|
// See CONTRIBUTORS for the list of Amiibo Service project authors
|
|
//
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
//
|
|
// ===----------------------------------------------------------------------===
|
|
|
|
import Foundation
|
|
import OpenAPIRuntime
|
|
|
|
/// A type that allows the decoding and encoding of ISO timestamp dates, defined by the `yyyy-MM-dd'T'HH:mm:ss.SSSSSS` custom date format.
|
|
struct ISOTimestampTranscoder {
|
|
|
|
// MARK: Properties
|
|
|
|
/// A formatter to use to decode and encode ISO timestamps dates.
|
|
private let dateFormatter: DateFormatter = .isoTimestamp
|
|
|
|
}
|
|
|
|
// MARK: - DateTranscoder
|
|
|
|
extension ISOTimestampTranscoder: DateTranscoder {
|
|
|
|
// MARK: Functions
|
|
|
|
func encode(_ date: Date) throws -> String {
|
|
dateFormatter.string(from: date)
|
|
}
|
|
|
|
func decode(_ string: String) throws -> Date {
|
|
dateFormatter.date(from: string) ?? .init()
|
|
}
|
|
|
|
}
|