From 03cdb8179eddd5d09a31e75acb965a59ba014fad Mon Sep 17 00:00:00 2001 From: stefan draskovits Date: Mon, 18 Mar 2024 11:26:11 +0100 Subject: [PATCH] add timeout for resource & individual requests --- Sources/Fetch/Network/Resource.swift | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/Sources/Fetch/Network/Resource.swift b/Sources/Fetch/Network/Resource.swift index 66681c2..e52429b 100644 --- a/Sources/Fetch/Network/Resource.swift +++ b/Sources/Fetch/Network/Resource.swift @@ -40,6 +40,9 @@ open class Resource: CacheableResource { public let stubKey: ResourceStubKey public let decode: DecodingClosure public let encode: EncodingClosure + + /// If not set the timeout of the APIClient.Config is used + public let timeout: TimeInterval? /// The final `URL` used in a network request, using the base URL from the resource or from the `APIClient` and the path /// If path is an absolute URL, this URL is used without a base url @@ -101,7 +104,9 @@ open class Resource: CacheableResource { customValidation: DataRequest.Validation? = nil, stubKey: ResourceStubKey? = nil, decode: DecodingClosure? = nil, - encode: EncodingClosure? = nil) { + encode: EncodingClosure? = nil, + timeout: TimeInterval? = nil + ) { self.apiClient = apiClient self.headers = headers self.method = method @@ -117,6 +122,7 @@ open class Resource: CacheableResource { self.cacheExpiration = cacheExpiration self.multipartFormData = multipartFormData self.customValidation = customValidation + self.timeout = timeout if let decode = decode { self.decode = decode @@ -154,6 +160,10 @@ open class Resource: CacheableResource { urlRequest.httpMethod = method.rawValue urlRequest.allHTTPHeaderFields = headers + if let timeout { + urlRequest.timeoutInterval = timeout + } + // Body if let body = body { let (data, contentType) = try encode(body: body)