StreamReceiving.swift 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. /*
  2. * Copyright 2018, 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 Dispatch
  17. import Foundation
  18. import SwiftProtobuf
  19. public protocol StreamReceiving {
  20. associatedtype ReceivedType: Message
  21. var call: Call { get }
  22. }
  23. extension StreamReceiving {
  24. public func receive(completion: @escaping (ResultOrRPCError<ReceivedType?>) -> Void) throws {
  25. try call.receiveMessage { callResult in
  26. guard let responseData = callResult.resultData else {
  27. if callResult.success {
  28. completion(.result(nil))
  29. } else {
  30. completion(.error(.callError(callResult)))
  31. }
  32. return
  33. }
  34. if let response = try? ReceivedType(serializedData: responseData) {
  35. completion(.result(response))
  36. } else {
  37. completion(.error(.invalidMessageReceived))
  38. }
  39. }
  40. }
  41. public func _receive(timeout: DispatchTime) throws -> ReceivedType? {
  42. var result: ResultOrRPCError<ReceivedType?>?
  43. let sem = DispatchSemaphore(value: 0)
  44. try receive {
  45. result = $0
  46. sem.signal()
  47. }
  48. if sem.wait(timeout: timeout) == .timedOut {
  49. throw RPCError.timedOut
  50. }
  51. switch result! {
  52. case .result(let response): return response
  53. case .error(let error): throw error
  54. }
  55. }
  56. }