echo.client.pb.swift 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303
  1. /*
  2. * DO NOT EDIT.
  3. *
  4. * Generated by the protocol buffer compiler.
  5. * Source: echo.proto
  6. *
  7. */
  8. /*
  9. *
  10. * Copyright 2016, Google Inc.
  11. * All rights reserved.
  12. *
  13. * Redistribution and use in source and binary forms, with or without
  14. * modification, are permitted provided that the following conditions are
  15. * met:
  16. *
  17. * * Redistributions of source code must retain the above copyright
  18. * notice, this list of conditions and the following disclaimer.
  19. * * Redistributions in binary form must reproduce the above
  20. * copyright notice, this list of conditions and the following disclaimer
  21. * in the documentation and/or other materials provided with the
  22. * distribution.
  23. * * Neither the name of Google Inc. nor the names of its
  24. * contributors may be used to endorse or promote products derived from
  25. * this software without specific prior written permission.
  26. *
  27. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  28. * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  29. * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
  30. * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
  31. * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  32. * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  33. * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  34. * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  35. * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  36. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  37. * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  38. *
  39. */
  40. import Foundation
  41. import gRPC
  42. /// Type for errors thrown from generated client code.
  43. public enum Echo_EchoClientError : Error {
  44. case endOfStream
  45. case invalidMessageReceived
  46. case error(c: CallResult)
  47. }
  48. // Get (Unary)
  49. public class Echo_EchoGetCall {
  50. private var call : Call
  51. /// Create a call.
  52. fileprivate init(_ channel: Channel) {
  53. self.call = channel.makeCall("/echo.Echo/Get")
  54. }
  55. /// Run the call. Blocks until the reply is received.
  56. fileprivate func run(request: Echo_EchoRequest,
  57. metadata: Metadata) throws -> Echo_EchoResponse {
  58. let latch = CountDownLatch(1)
  59. var callResult : CallResult!
  60. var response : Echo_EchoResponse?
  61. let requestData = try request.serializeProtobuf()
  62. try call.start(.unary,
  63. metadata:metadata,
  64. message:requestData)
  65. {(_callResult) in
  66. callResult = _callResult
  67. if let responseData = callResult.resultData {
  68. response = try? Echo_EchoResponse(protobuf:responseData)
  69. }
  70. latch.signal()
  71. }
  72. latch.wait()
  73. if let response = response {
  74. return response
  75. } else {
  76. throw Echo_EchoClientError.error(c: callResult)
  77. }
  78. }
  79. }
  80. // Expand (Server Streaming)
  81. public class Echo_EchoExpandCall {
  82. private var call : Call
  83. /// Create a call.
  84. fileprivate init(_ channel: Channel) {
  85. self.call = channel.makeCall("/echo.Echo/Expand")
  86. }
  87. // Call this once with the message to send.
  88. fileprivate func run(request: Echo_EchoRequest, metadata: Metadata) throws -> Echo_EchoExpandCall {
  89. let requestData = try request.serializeProtobuf()
  90. let latch = CountDownLatch(1)
  91. try call.start(.serverStreaming,
  92. metadata:metadata,
  93. message:requestData)
  94. {callResult in
  95. latch.signal()
  96. }
  97. latch.wait()
  98. return self
  99. }
  100. // Call this to wait for a result. Blocks.
  101. public func Receive() throws -> Echo_EchoResponse {
  102. var returnError : Echo_EchoClientError?
  103. var response : Echo_EchoResponse!
  104. let latch = CountDownLatch(1)
  105. do {
  106. try call.receiveMessage() {(responseData) in
  107. if let responseData = responseData {
  108. response = try? Echo_EchoResponse(protobuf:responseData)
  109. if response == nil {
  110. returnError = Echo_EchoClientError.invalidMessageReceived
  111. }
  112. } else {
  113. returnError = Echo_EchoClientError.endOfStream
  114. }
  115. latch.signal()
  116. }
  117. latch.wait()
  118. }
  119. if let returnError = returnError {
  120. throw returnError
  121. }
  122. return response
  123. }
  124. }
  125. // Collect (Client Streaming)
  126. public class Echo_EchoCollectCall {
  127. private var call : Call
  128. /// Create a call.
  129. fileprivate init(_ channel: Channel) {
  130. self.call = channel.makeCall("/echo.Echo/Collect")
  131. }
  132. // Call this to start a call.
  133. fileprivate func run(metadata:Metadata) throws -> Echo_EchoCollectCall {
  134. let latch = CountDownLatch(1)
  135. try self.call.start(.clientStreaming,
  136. metadata:metadata)
  137. {callResult in
  138. latch.signal()
  139. }
  140. latch.wait()
  141. return self
  142. }
  143. // Call this to send each message in the request stream.
  144. public func Send(_ message: Echo_EchoRequest) throws {
  145. let messageData = try message.serializeProtobuf()
  146. try call.sendMessage(data:messageData)
  147. }
  148. // Call this to close the connection and wait for a response. Blocks.
  149. public func CloseAndReceive() throws -> Echo_EchoResponse {
  150. var returnError : Echo_EchoClientError?
  151. var returnResponse : Echo_EchoResponse!
  152. let latch = CountDownLatch(1)
  153. do {
  154. try call.receiveMessage() {(responseData) in
  155. if let responseData = responseData,
  156. let response = try? Echo_EchoResponse(protobuf:responseData) {
  157. returnResponse = response
  158. } else {
  159. returnError = Echo_EchoClientError.invalidMessageReceived
  160. }
  161. latch.signal()
  162. }
  163. try call.close(completion:{})
  164. latch.wait()
  165. } catch (let error) {
  166. throw error
  167. }
  168. if let returnError = returnError {
  169. throw returnError
  170. }
  171. return returnResponse
  172. }
  173. }
  174. // Update (Bidirectional Streaming)
  175. public class Echo_EchoUpdateCall {
  176. private var call : Call
  177. /// Create a call.
  178. fileprivate init(_ channel: Channel) {
  179. self.call = channel.makeCall("/echo.Echo/Update")
  180. }
  181. fileprivate func run(metadata:Metadata) throws -> Echo_EchoUpdateCall {
  182. let latch = CountDownLatch(1)
  183. try self.call.start(.bidiStreaming,
  184. metadata:metadata)
  185. {callResult in
  186. latch.signal()
  187. }
  188. latch.wait()
  189. return self
  190. }
  191. public func Receive() throws -> Echo_EchoResponse {
  192. var returnError : Echo_EchoClientError?
  193. var returnMessage : Echo_EchoResponse!
  194. let latch = CountDownLatch(1)
  195. do {
  196. try call.receiveMessage() {(data) in
  197. if let data = data {
  198. returnMessage = try? Echo_EchoResponse(protobuf:data)
  199. if returnMessage == nil {
  200. returnError = Echo_EchoClientError.invalidMessageReceived
  201. }
  202. } else {
  203. returnError = Echo_EchoClientError.endOfStream
  204. }
  205. latch.signal()
  206. }
  207. latch.wait()
  208. }
  209. if let returnError = returnError {
  210. throw returnError
  211. }
  212. return returnMessage
  213. }
  214. public func Send(_ message:Echo_EchoRequest) throws {
  215. let messageData = try message.serializeProtobuf()
  216. try call.sendMessage(data:messageData)
  217. }
  218. public func CloseSend() throws {
  219. let latch = CountDownLatch(1)
  220. try call.close() {
  221. latch.signal()
  222. }
  223. latch.wait()
  224. }
  225. }
  226. // Call methods of this class to make API calls.
  227. public class Echo_EchoService {
  228. private var channel: Channel
  229. /// This metadata will be sent with all requests.
  230. public var metadata : Metadata
  231. /// This property allows the service host name to be overridden.
  232. /// For example, it can be used to make calls to "localhost:8080"
  233. /// appear to be to "example.com".
  234. public var host : String {
  235. get {
  236. return self.channel.host
  237. }
  238. set {
  239. self.channel.host = newValue
  240. }
  241. }
  242. /// Create a client that makes insecure connections.
  243. public init(address: String) {
  244. gRPC.initialize()
  245. channel = Channel(address:address)
  246. metadata = Metadata()
  247. }
  248. /// Create a client that makes secure connections.
  249. public init(address: String, certificates: String?, host: String?) {
  250. gRPC.initialize()
  251. channel = Channel(address:address, certificates:certificates, host:host)
  252. metadata = Metadata()
  253. }
  254. // Synchronous. Unary.
  255. public func get(_ request: Echo_EchoRequest) throws -> Echo_EchoResponse {
  256. return try Echo_EchoGetCall(channel).run(request:request, metadata:metadata)
  257. }
  258. // Asynchronous. Server-streaming.
  259. // Send the initial message.
  260. // Use methods on the returned object to get streamed responses.
  261. public func expand(_ request: Echo_EchoRequest) throws -> Echo_EchoExpandCall {
  262. return try Echo_EchoExpandCall(channel).run(request:request, metadata:metadata)
  263. }
  264. // Asynchronous. Client-streaming.
  265. // Use methods on the returned object to stream messages and
  266. // to close the connection and wait for a final response.
  267. public func collect() throws -> Echo_EchoCollectCall {
  268. return try Echo_EchoCollectCall(channel).run(metadata:metadata)
  269. }
  270. // Asynchronous. Bidirectional-streaming.
  271. // Use methods on the returned object to stream messages,
  272. // to wait for replies, and to close the connection.
  273. public func update() throws -> Echo_EchoUpdateCall {
  274. return try Echo_EchoUpdateCall(channel).run(metadata:metadata)
  275. }
  276. }