| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303 |
- /*
- * DO NOT EDIT.
- *
- * Generated by the protocol buffer compiler.
- * Source: echo.proto
- *
- */
- /*
- *
- * Copyright 2016, Google Inc.
- * All rights reserved.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions are
- * met:
- *
- * * Redistributions of source code must retain the above copyright
- * notice, this list of conditions and the following disclaimer.
- * * Redistributions in binary form must reproduce the above
- * copyright notice, this list of conditions and the following disclaimer
- * in the documentation and/or other materials provided with the
- * distribution.
- * * Neither the name of Google Inc. nor the names of its
- * contributors may be used to endorse or promote products derived from
- * this software without specific prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
- * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
- * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
- * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
- * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
- * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
- * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
- * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
- * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
- * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
- * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- *
- */
- import Foundation
- import gRPC
- /// Type for errors thrown from generated client code.
- public enum Echo_EchoClientError : Error {
- case endOfStream
- case invalidMessageReceived
- case error(c: CallResult)
- }
- // Get (Unary)
- public class Echo_EchoGetCall {
- private var call : Call
- /// Create a call.
- fileprivate init(_ channel: Channel) {
- self.call = channel.makeCall("/echo.Echo/Get")
- }
- /// Run the call. Blocks until the reply is received.
- fileprivate func run(request: Echo_EchoRequest,
- metadata: Metadata) throws -> Echo_EchoResponse {
- let latch = CountDownLatch(1)
- var callResult : CallResult!
- var response : Echo_EchoResponse?
- let requestData = try request.serializeProtobuf()
- try call.start(.unary,
- metadata:metadata,
- message:requestData)
- {(_callResult) in
- callResult = _callResult
- if let responseData = callResult.resultData {
- response = try? Echo_EchoResponse(protobuf:responseData)
- }
- latch.signal()
- }
- latch.wait()
- if let response = response {
- return response
- } else {
- throw Echo_EchoClientError.error(c: callResult)
- }
- }
- }
- // Expand (Server Streaming)
- public class Echo_EchoExpandCall {
- private var call : Call
- /// Create a call.
- fileprivate init(_ channel: Channel) {
- self.call = channel.makeCall("/echo.Echo/Expand")
- }
- // Call this once with the message to send.
- fileprivate func run(request: Echo_EchoRequest, metadata: Metadata) throws -> Echo_EchoExpandCall {
- let requestData = try request.serializeProtobuf()
- let latch = CountDownLatch(1)
- try call.start(.serverStreaming,
- metadata:metadata,
- message:requestData)
- {callResult in
- latch.signal()
- }
- latch.wait()
- return self
- }
- // Call this to wait for a result. Blocks.
- public func Receive() throws -> Echo_EchoResponse {
- var returnError : Echo_EchoClientError?
- var response : Echo_EchoResponse!
- let latch = CountDownLatch(1)
- do {
- try call.receiveMessage() {(responseData) in
- if let responseData = responseData {
- response = try? Echo_EchoResponse(protobuf:responseData)
- if response == nil {
- returnError = Echo_EchoClientError.invalidMessageReceived
- }
- } else {
- returnError = Echo_EchoClientError.endOfStream
- }
- latch.signal()
- }
- latch.wait()
- }
- if let returnError = returnError {
- throw returnError
- }
- return response
- }
- }
- // Collect (Client Streaming)
- public class Echo_EchoCollectCall {
- private var call : Call
- /// Create a call.
- fileprivate init(_ channel: Channel) {
- self.call = channel.makeCall("/echo.Echo/Collect")
- }
- // Call this to start a call.
- fileprivate func run(metadata:Metadata) throws -> Echo_EchoCollectCall {
- let latch = CountDownLatch(1)
- try self.call.start(.clientStreaming,
- metadata:metadata)
- {callResult in
- latch.signal()
- }
- latch.wait()
- return self
- }
- // Call this to send each message in the request stream.
- public func Send(_ message: Echo_EchoRequest) throws {
- let messageData = try message.serializeProtobuf()
- try call.sendMessage(data:messageData)
- }
- // Call this to close the connection and wait for a response. Blocks.
- public func CloseAndReceive() throws -> Echo_EchoResponse {
- var returnError : Echo_EchoClientError?
- var returnResponse : Echo_EchoResponse!
- let latch = CountDownLatch(1)
- do {
- try call.receiveMessage() {(responseData) in
- if let responseData = responseData,
- let response = try? Echo_EchoResponse(protobuf:responseData) {
- returnResponse = response
- } else {
- returnError = Echo_EchoClientError.invalidMessageReceived
- }
- latch.signal()
- }
- try call.close(completion:{})
- latch.wait()
- } catch (let error) {
- throw error
- }
- if let returnError = returnError {
- throw returnError
- }
- return returnResponse
- }
- }
- // Update (Bidirectional Streaming)
- public class Echo_EchoUpdateCall {
- private var call : Call
- /// Create a call.
- fileprivate init(_ channel: Channel) {
- self.call = channel.makeCall("/echo.Echo/Update")
- }
- fileprivate func run(metadata:Metadata) throws -> Echo_EchoUpdateCall {
- let latch = CountDownLatch(1)
- try self.call.start(.bidiStreaming,
- metadata:metadata)
- {callResult in
- latch.signal()
- }
- latch.wait()
- return self
- }
- public func Receive() throws -> Echo_EchoResponse {
- var returnError : Echo_EchoClientError?
- var returnMessage : Echo_EchoResponse!
- let latch = CountDownLatch(1)
- do {
- try call.receiveMessage() {(data) in
- if let data = data {
- returnMessage = try? Echo_EchoResponse(protobuf:data)
- if returnMessage == nil {
- returnError = Echo_EchoClientError.invalidMessageReceived
- }
- } else {
- returnError = Echo_EchoClientError.endOfStream
- }
- latch.signal()
- }
- latch.wait()
- }
- if let returnError = returnError {
- throw returnError
- }
- return returnMessage
- }
- public func Send(_ message:Echo_EchoRequest) throws {
- let messageData = try message.serializeProtobuf()
- try call.sendMessage(data:messageData)
- }
- public func CloseSend() throws {
- let latch = CountDownLatch(1)
- try call.close() {
- latch.signal()
- }
- latch.wait()
- }
- }
- // Call methods of this class to make API calls.
- public class Echo_EchoService {
- private var channel: Channel
- /// This metadata will be sent with all requests.
- public var metadata : Metadata
- /// This property allows the service host name to be overridden.
- /// For example, it can be used to make calls to "localhost:8080"
- /// appear to be to "example.com".
- public var host : String {
- get {
- return self.channel.host
- }
- set {
- self.channel.host = newValue
- }
- }
- /// Create a client that makes insecure connections.
- public init(address: String) {
- gRPC.initialize()
- channel = Channel(address:address)
- metadata = Metadata()
- }
- /// Create a client that makes secure connections.
- public init(address: String, certificates: String?, host: String?) {
- gRPC.initialize()
- channel = Channel(address:address, certificates:certificates, host:host)
- metadata = Metadata()
- }
- // Synchronous. Unary.
- public func get(_ request: Echo_EchoRequest) throws -> Echo_EchoResponse {
- return try Echo_EchoGetCall(channel).run(request:request, metadata:metadata)
- }
- // Asynchronous. Server-streaming.
- // Send the initial message.
- // Use methods on the returned object to get streamed responses.
- public func expand(_ request: Echo_EchoRequest) throws -> Echo_EchoExpandCall {
- return try Echo_EchoExpandCall(channel).run(request:request, metadata:metadata)
- }
- // Asynchronous. Client-streaming.
- // Use methods on the returned object to stream messages and
- // to close the connection and wait for a final response.
- public func collect() throws -> Echo_EchoCollectCall {
- return try Echo_EchoCollectCall(channel).run(metadata:metadata)
- }
- // Asynchronous. Bidirectional-streaming.
- // Use methods on the returned object to stream messages,
- // to wait for replies, and to close the connection.
- public func update() throws -> Echo_EchoUpdateCall {
- return try Echo_EchoUpdateCall(channel).run(metadata:metadata)
- }
- }
|