Skip to content

Commit

Permalink
Provide mutated Request by Middleware to ErrorMiddleware instead of o…
Browse files Browse the repository at this point in the history
…riginal one
  • Loading branch information
sukhrobkhakimov committed Sep 29, 2024
1 parent 0d18d48 commit d27a2b3
Showing 1 changed file with 56 additions and 47 deletions.
103 changes: 56 additions & 47 deletions Sources/HTTP/Server/Handler/RequestResponseHandler.swift
Original file line number Diff line number Diff line change
Expand Up @@ -57,37 +57,46 @@ extension RequestResponseHandler {
request: request,
response: response
)
future.whenSuccess { [weak self] request, response in
self?.write(
response: response as? Response ?? .init("\(response)"),
for: request,
in: context
)
}
future.whenFailure { [weak self] error in
guard let self else { return }
let future = processMiddleware(
server.errorMiddleware,
request: request,
response: response,
error: error
)
future.whenSuccess { [weak self] request, response in
self?.write(
response: response as? Response ?? .init("\(response)"),
for: request,
in: context
future.whenSuccess { [weak self] request, response, error in
if let error {
guard let self else { return }
let future = processMiddleware(
server.errorMiddleware,
request: request,
response: response,
error: error
)
}
future.whenFailure { [weak self] error in
self?.server.logger.error("Server error: \(error)")
future.whenSuccess { [weak self] request, response in
self?.write(
response: response as? Response ?? .init("\(response)"),
for: request,
in: context
)
}
future.whenFailure { [weak self] error in
self?.server.logger.error("Server error: \(error)")
self?.write(
response: .init(status: .internalServerError),
for: request,
in: context
)
}
} else {
self?.write(
response: .init(status: .internalServerError),
response: response as? Response ?? .init("\(response)"),
for: request,
in: context
)
}
}
future.whenFailure { [weak self] error in
self?.server.logger.error("Server error: \(error)")
self?.write(
response: .init(status: .internalServerError),
for: request,
in: context
)
}
}

private func write(
Expand Down Expand Up @@ -140,39 +149,39 @@ extension RequestResponseHandler {
request: Request,
response: Encodable,
nextIndex index: Int = 0
) -> EventLoopFuture<(Request, Encodable)> {
let promise = request.eventLoop.makePromise(of: (Request, Encodable).self)
) -> EventLoopFuture<(Request, Encodable, Error?)> {
let promise = request.eventLoop.makePromise(of: (Request, Encodable, Error?).self)
promise.completeWithTask { [weak self] in
guard let self else { return (request, response) }
guard let self else { return (request, response, nil) }
let lastIndex = middleware.count - 1

if index > lastIndex {
let response = try await handle(
request: request,
response: response
)
return (request, response)
}

let response = try await middleware[index].handle(request: request) { [weak self] request in
guard let self else { return response }

if index == lastIndex {
return try await handle(
do {
let response = try await handle(
request: request,
response: response
)
return (request, response, nil)
} catch {
return (request, response, error)
}

return try await processMiddleware(
middleware,
request: request,
response: response,
nextIndex: index + 1
).get().1
}

return (request, response)
do {
let response = try await middleware[index].handle(request: request) { [weak self] request in
guard let self else { return response }
return try await processMiddleware(
middleware,
request: request,
response: response,
nextIndex: index + 1
).get().1
}

return (request, response, nil)
} catch {
return (request, response, error)
}
}

return promise.futureResult
Expand Down

0 comments on commit d27a2b3

Please sign in to comment.