| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158 |
- /*
- * DO NOT EDIT.
- *
- * Generated by the protocol buffer compiler.
- * Source: {{ protoFile.name }}
- *
- */
- /*
- *
- * 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
- import Dispatch
- //-{% for service in protoFile.service %}
- /// Type for errors thrown from generated server code.
- public enum {{ .|servererror:protoFile,service }} : Error {
- case endOfStream
- }
- /// To build a server, implement a class that conforms to this protocol.
- public protocol {{ .|provider:protoFile,service }} {
- //-{% for method in service.method %}
- //-{% if not method.clientStreaming and not method.serverStreaming %}
- func {{ method.name|lowercase }}(request : {{ method|input }}, session : {{ .|session:protoFile,service,method }}) throws -> {{ method|output }}
- //-{% endif %}
- //-{% if not method.clientStreaming and method.serverStreaming %}
- func {{ method.name|lowercase }}(request : {{ method|input }}, session : {{ .|session:protoFile,service,method }}) throws
- //-{% endif %}
- //-{% if method.clientStreaming and not method.serverStreaming %}
- func {{ method.name|lowercase }}(session : {{ .|session:protoFile,service,method }}) throws
- //-{% endif %}
- //-{% if method.clientStreaming and method.serverStreaming %}
- func {{ method.name|lowercase }}(session : {{ .|session:protoFile,service,method }}) throws
- //-{% endif %}
- //-{% endfor %}
- }
- /// Common properties available in each service session.
- public class {{ .|service:protoFile,service }}Session {
- fileprivate var handler : gRPC.Handler
- public var requestMetadata : Metadata { return handler.requestMetadata }
- public var statusCode : Int = 0
- public var statusMessage : String = "OK"
- public var initialMetadata : Metadata = Metadata()
- public var trailingMetadata : Metadata = Metadata()
- fileprivate init(handler:gRPC.Handler) {
- self.handler = handler
- }
- }
- //-{% for method in service.method %}
- //-{% if not method.clientStreaming and not method.serverStreaming %}
- //-{% include "server-session-unary.swift" %}
- //-{% endif %}
- //-{% if not method.clientStreaming and method.serverStreaming %}
- //-{% include "server-session-serverstreaming.swift" %}
- //-{% endif %}
- //-{% if method.clientStreaming and not method.serverStreaming %}
- //-{% include "server-session-clientstreaming.swift" %}
- //-{% endif %}
- //-{% if method.clientStreaming and method.serverStreaming %}
- //-{% include "server-session-bidistreaming.swift" %}
- //-{% endif %}
- //-{% endfor %}
- /// Main server for generated service
- public class {{ .|server:protoFile,service }} {
- private var address: String
- private var server: gRPC.Server
- private var provider: {{ .|provider:protoFile,service }}?
- /// Create a server that accepts insecure connections.
- public init(address:String,
- provider:{{ .|provider:protoFile,service }}) {
- gRPC.initialize()
- self.address = address
- self.provider = provider
- self.server = gRPC.Server(address:address)
- }
- /// Create a server that accepts secure connections.
- public init?(address:String,
- certificateURL:URL,
- keyURL:URL,
- provider:{{ .|provider:protoFile,service }}) {
- gRPC.initialize()
- self.address = address
- self.provider = provider
- guard
- let certificate = try? String(contentsOf: certificateURL),
- let key = try? String(contentsOf: keyURL)
- else {
- return nil
- }
- self.server = gRPC.Server(address:address, key:key, certs:certificate)
- }
- /// Start the server.
- public func start(queue:DispatchQueue = DispatchQueue.global()) {
- guard let provider = self.provider else {
- assert(false) // the server requires a provider
- }
- server.run {(handler) in
- print("Server received request to " + handler.host
- + " calling " + handler.method
- + " from " + handler.caller
- + " with " + String(describing:handler.requestMetadata) )
- do {
- switch handler.method {
- //-{% for method in service.method %}
- case "{{ .|path:protoFile,service,method }}":
- try {{ .|session:protoFile,service,method }}(handler:handler, provider:provider).run(queue:queue)
- //-{% endfor %}
- default:
- break // handle unknown requests
- }
- } catch (let error) {
- print("Server error: \(error)")
- }
- }
- }
- }
- //-{% endfor %}
|