echo.client.pb.swift 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342
  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 done = NSCondition()
  59. var callResult : CallResult!
  60. var responseMessage : Echo_EchoResponse?
  61. let requestMessageData = try request.serializeProtobuf()
  62. try call.perform(message: requestMessageData,
  63. metadata: metadata)
  64. {(_callResult) in
  65. callResult = _callResult
  66. if let messageData = callResult.resultData {
  67. responseMessage = try? Echo_EchoResponse(protobuf:messageData)
  68. }
  69. done.lock()
  70. done.signal()
  71. done.unlock()
  72. }
  73. done.lock()
  74. done.wait()
  75. done.unlock()
  76. if let responseMessage = responseMessage {
  77. return responseMessage
  78. } else {
  79. throw Echo_EchoClientError.error(c: callResult)
  80. }
  81. }
  82. }
  83. // Expand (Server Streaming)
  84. public class Echo_EchoExpandCall {
  85. private var call : Call
  86. /// Create a call.
  87. fileprivate init(_ channel: Channel) {
  88. self.call = channel.makeCall("/echo.Echo/Expand")
  89. }
  90. // Call this once with the message to send.
  91. fileprivate func run(request: Echo_EchoRequest, metadata: Metadata) throws -> Echo_EchoExpandCall {
  92. let requestMessageData = try request.serializeProtobuf()
  93. try call.startServerStreaming(message: requestMessageData,
  94. metadata: metadata,
  95. completion:{(CallResult) in })
  96. return self
  97. }
  98. // Call this to wait for a result. Blocks.
  99. public func Receive() throws -> Echo_EchoResponse {
  100. var returnError : Echo_EchoClientError?
  101. var returnMessage : Echo_EchoResponse!
  102. let done = NSCondition()
  103. do {
  104. try call.receiveMessage() {(data) in
  105. if let data = data {
  106. returnMessage = try? Echo_EchoResponse(protobuf:data)
  107. if returnMessage == nil {
  108. returnError = Echo_EchoClientError.invalidMessageReceived
  109. }
  110. } else {
  111. returnError = Echo_EchoClientError.endOfStream
  112. }
  113. done.lock()
  114. done.signal()
  115. done.unlock()
  116. }
  117. done.lock()
  118. done.wait()
  119. done.unlock()
  120. }
  121. if let returnError = returnError {
  122. throw returnError
  123. }
  124. return returnMessage
  125. }
  126. }
  127. // Collect (Client Streaming)
  128. public class Echo_EchoCollectCall {
  129. private var call : Call
  130. /// Create a call.
  131. fileprivate init(_ channel: Channel) {
  132. self.call = channel.makeCall("/echo.Echo/Collect")
  133. }
  134. // Call this to start a call.
  135. fileprivate func run(metadata:Metadata) throws -> Echo_EchoCollectCall {
  136. try self.call.start(metadata: metadata, completion:{})
  137. return self
  138. }
  139. // Call this to send each message in the request stream.
  140. public func Send(_ message: Echo_EchoRequest) throws {
  141. let messageData = try message.serializeProtobuf()
  142. _ = call.sendMessage(data:messageData)
  143. }
  144. // Call this to close the connection and wait for a response. Blocks.
  145. public func CloseAndReceive() throws -> Echo_EchoResponse {
  146. var returnError : Echo_EchoClientError?
  147. var returnMessage : Echo_EchoResponse!
  148. let done = NSCondition()
  149. do {
  150. try self.receiveMessage() {(responseMessage) in
  151. if let responseMessage = responseMessage {
  152. returnMessage = responseMessage
  153. } else {
  154. returnError = Echo_EchoClientError.invalidMessageReceived
  155. }
  156. done.lock()
  157. done.signal()
  158. done.unlock()
  159. }
  160. try call.close(completion:{
  161. print("closed")
  162. })
  163. done.lock()
  164. done.wait()
  165. done.unlock()
  166. } catch (let error) {
  167. print("ERROR B: \(error)")
  168. }
  169. if let returnError = returnError {
  170. throw returnError
  171. }
  172. return returnMessage
  173. }
  174. // Call this to receive a message.
  175. // The callback will be called when a message is received.
  176. // call this again from the callback to wait for another message.
  177. fileprivate func receiveMessage(callback:@escaping (Echo_EchoResponse?) throws -> Void)
  178. throws {
  179. try call.receiveMessage() {(data) in
  180. guard let data = data else {
  181. try callback(nil)
  182. return
  183. }
  184. guard
  185. let responseMessage = try? Echo_EchoResponse(protobuf:data)
  186. else {
  187. return
  188. }
  189. try callback(responseMessage)
  190. }
  191. }
  192. }
  193. // Update (Bidirectional Streaming)
  194. public class Echo_EchoUpdateCall {
  195. private var call : Call
  196. /// Create a call.
  197. fileprivate init(_ channel: Channel) {
  198. self.call = channel.makeCall("/echo.Echo/Update")
  199. }
  200. fileprivate func run(metadata:Metadata) throws -> Echo_EchoUpdateCall {
  201. try self.call.start(metadata: metadata, completion:{})
  202. return self
  203. }
  204. fileprivate func receiveMessage(callback:@escaping (Echo_EchoResponse?) throws -> Void) throws {
  205. try call.receiveMessage() {(data) in
  206. if let data = data {
  207. if let responseMessage = try? Echo_EchoResponse(protobuf:data) {
  208. try callback(responseMessage)
  209. } else {
  210. try callback(nil) // error, bad data
  211. }
  212. } else {
  213. try callback(nil)
  214. }
  215. }
  216. }
  217. public func Receive() throws -> Echo_EchoResponse {
  218. var returnError : Echo_EchoClientError?
  219. var returnMessage : Echo_EchoResponse!
  220. let done = NSCondition()
  221. do {
  222. try call.receiveMessage() {(data) in
  223. if let data = data {
  224. returnMessage = try? Echo_EchoResponse(protobuf:data)
  225. if returnMessage == nil {
  226. returnError = Echo_EchoClientError.invalidMessageReceived
  227. }
  228. } else {
  229. returnError = Echo_EchoClientError.endOfStream
  230. }
  231. done.lock()
  232. done.signal()
  233. done.unlock()
  234. }
  235. done.lock()
  236. done.wait()
  237. done.unlock()
  238. }
  239. if let returnError = returnError {
  240. throw returnError
  241. }
  242. return returnMessage
  243. }
  244. public func Send(_ message:Echo_EchoRequest) throws {
  245. let messageData = try message.serializeProtobuf()
  246. _ = call.sendMessage(data:messageData)
  247. }
  248. public func CloseSend() throws {
  249. let done = NSCondition()
  250. try call.close() {
  251. done.lock()
  252. done.signal()
  253. done.unlock()
  254. }
  255. done.lock()
  256. done.wait()
  257. done.unlock()
  258. }
  259. }
  260. // Call methods of this class to make API calls.
  261. public class Echo_EchoService {
  262. private var channel: Channel
  263. /// This metadata will be sent with all requests.
  264. public var metadata : Metadata
  265. /// This property allows the service host name to be overridden.
  266. /// For example, it can be used to make calls to "localhost:8080"
  267. /// appear to be to "example.com".
  268. public var host : String {
  269. get {
  270. return self.channel.host
  271. }
  272. set {
  273. self.channel.host = newValue
  274. }
  275. }
  276. /// Create a client that makes insecure connections.
  277. public init(address: String) {
  278. gRPC.initialize()
  279. channel = Channel(address:address)
  280. metadata = Metadata()
  281. }
  282. /// Create a client that makes secure connections.
  283. public init(address: String, certificates: String?, host: String?) {
  284. gRPC.initialize()
  285. channel = Channel(address:address, certificates:certificates, host:host)
  286. metadata = Metadata()
  287. }
  288. // Synchronous. Unary.
  289. public func get(_ request: Echo_EchoRequest) throws -> Echo_EchoResponse {
  290. return try Echo_EchoGetCall(channel).run(request:request, metadata:metadata)
  291. }
  292. // Asynchronous. Server-streaming.
  293. // Send the initial message.
  294. // Use methods on the returned object to get streamed responses.
  295. public func expand(_ request: Echo_EchoRequest) throws -> Echo_EchoExpandCall {
  296. return try Echo_EchoExpandCall(channel).run(request:request, metadata:metadata)
  297. }
  298. // Asynchronous. Client-streaming.
  299. // Use methods on the returned object to stream messages and
  300. // to close the connection and wait for a final response.
  301. public func collect() throws -> Echo_EchoCollectCall {
  302. return try Echo_EchoCollectCall(channel).run(metadata:metadata)
  303. }
  304. // Asynchronous. Bidirectional-streaming.
  305. // Use methods on the returned object to stream messages,
  306. // to wait for replies, and to close the connection.
  307. public func update() throws -> Echo_EchoUpdateCall {
  308. return try Echo_EchoUpdateCall(channel).run(metadata:metadata)
  309. }
  310. }