| 12345678910111213141516171819202122232425262728293031323334353637383940414243 |
- import Foundation
- import SwiftProtobuf
- import NIO
- import NIOHTTP1
- /// Handles unary calls. Calls the observer block with the request message.
- ///
- /// - The observer block is implemented by the framework user and returns a future containing the call result.
- /// - To return a response to the client, the framework user should complete that future
- /// (similar to e.g. serving regular HTTP requests in frameworks such as Vapor).
- public class UnaryCallHandler<RequestMessage: Message, ResponseMessage: Message>: BaseCallHandler<RequestMessage, ResponseMessage> {
- public typealias EventObserver = (RequestMessage) -> EventLoopFuture<ResponseMessage>
- private var eventObserver: EventObserver?
-
- private var context: UnaryResponseCallContext<ResponseMessage>?
-
- public init(channel: Channel, request: HTTPRequestHead, eventObserverFactory: (UnaryResponseCallContext<ResponseMessage>) -> EventObserver) {
- super.init()
- let context = UnaryResponseCallContextImpl<ResponseMessage>(channel: channel, request: request)
- self.context = context
- self.eventObserver = eventObserverFactory(context)
- context.responsePromise.futureResult.whenComplete {
- // When done, reset references to avoid retain cycles.
- self.eventObserver = nil
- self.context = nil
- }
- }
-
- public override func processMessage(_ message: RequestMessage) {
- guard let eventObserver = self.eventObserver,
- let context = self.context else {
- //! FIXME: Better handle this error?
- print("multiple messages received on unary call")
- return
- }
-
- let resultFuture = eventObserver(message)
- resultFuture
- // Fulfill the response promise with whatever response (or error) the framework user has provided.
- .cascade(promise: context.responsePromise)
- self.eventObserver = nil
- }
- }
|