ClientStreamingClientCall.swift 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. /*
  2. * Copyright 2019, gRPC Authors All rights reserved.
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. */
  16. import Foundation
  17. import SwiftProtobuf
  18. import NIO
  19. /// A client-streaming gRPC call.
  20. ///
  21. /// Messages should be sent via the `send` method; an `.end` message should be sent
  22. /// to indicate the final message has been sent.
  23. ///
  24. /// The following futures are available to the caller:
  25. /// - `initialMetadata`: the initial metadata returned from the server,
  26. /// - `response`: the response from the call,
  27. /// - `status`: the status of the gRPC call after it has ended,
  28. /// - `trailingMetadata`: any metadata returned from the server alongside the `status`.
  29. public class ClientStreamingClientCall<RequestMessage: Message, ResponseMessage: Message>: BaseClientCall<RequestMessage, ResponseMessage>, StreamingRequestClientCall, UnaryResponseClientCall {
  30. public let response: EventLoopFuture<ResponseMessage>
  31. private var messageQueue: EventLoopFuture<Void>
  32. public init(connection: GRPCClientConnection, path: String, callOptions: CallOptions) {
  33. let responsePromise: EventLoopPromise<ResponseMessage> = connection.channel.eventLoop.makePromise()
  34. self.response = responsePromise.futureResult
  35. self.messageQueue = connection.channel.eventLoop.makeSucceededFuture(())
  36. super.init(
  37. connection: connection,
  38. path: path,
  39. callOptions: callOptions,
  40. responseObserver: .succeedPromise(responsePromise))
  41. let requestHead = self.makeRequestHead(path: path, host: connection.host, callOptions: callOptions)
  42. self.messageQueue = self.messageQueue.flatMap {
  43. self.sendHead(requestHead)
  44. }
  45. }
  46. public func sendMessage(_ message: RequestMessage) -> EventLoopFuture<Void> {
  47. return self._sendMessage(message)
  48. }
  49. public func sendMessage(_ message: RequestMessage, promise: EventLoopPromise<Void>?) {
  50. self._sendMessage(message, promise: promise)
  51. }
  52. public func sendEnd() -> EventLoopFuture<Void> {
  53. return self._sendEnd()
  54. }
  55. public func sendEnd(promise: EventLoopPromise<Void>?) {
  56. self._sendEnd(promise: promise)
  57. }
  58. public func newMessageQueue() -> EventLoopFuture<Void> {
  59. return self.messageQueue
  60. }
  61. }