|
|
@@ -33,78 +33,40 @@
|
|
|
//-{% endfor %}
|
|
|
|
|
|
/// Main server for generated service
|
|
|
-{{ access }} final class {{ .|server:file,service }} {
|
|
|
- private var address: String
|
|
|
- private var server: Server
|
|
|
- private var provider: {{ .|provider:file,service }}?
|
|
|
+{{ access }} final class {{ .|server:file,service }}: ServiceServer {
|
|
|
+ private var provider: {{ .|provider:file,service }}
|
|
|
|
|
|
- /// Create a server that accepts insecure connections.
|
|
|
- {{ access }} init(address:String,
|
|
|
- provider:{{ .|provider:file,service }}) {
|
|
|
- gRPC.initialize()
|
|
|
- self.address = address
|
|
|
+ {{ access }} init(address: String, provider: {{ .|provider:file,service }}) {
|
|
|
self.provider = provider
|
|
|
- self.server = Server(address:address)
|
|
|
+ super.init(address: address)
|
|
|
}
|
|
|
|
|
|
- /// Create a server that accepts secure connections.
|
|
|
- {{ access }} init?(address:String,
|
|
|
- certificateURL:URL,
|
|
|
- keyURL:URL,
|
|
|
- provider:{{ .|provider:file,service }}) {
|
|
|
- gRPC.initialize()
|
|
|
- self.address = address
|
|
|
+ {{ access }} init?(address: String, certificateURL: URL, keyURL: URL, provider: {{ .|provider:file,service }}) {
|
|
|
self.provider = provider
|
|
|
- guard
|
|
|
- let certificate = try? String(contentsOf: certificateURL, encoding: .utf8),
|
|
|
- let key = try? String(contentsOf: keyURL, encoding: .utf8)
|
|
|
- else {
|
|
|
- return nil
|
|
|
- }
|
|
|
- self.server = Server(address:address, key:key, certs:certificate)
|
|
|
+ super.init(address: address, certificateURL: certificateURL, keyURL: keyURL)
|
|
|
}
|
|
|
|
|
|
/// Start the server.
|
|
|
- {{ access }} func start(queue:DispatchQueue = DispatchQueue.global()) {
|
|
|
- guard let provider = self.provider else {
|
|
|
- fatalError() // the server requires a provider
|
|
|
- }
|
|
|
- server.run {(handler) in
|
|
|
- let unwrappedHost = handler.host ?? "(nil)"
|
|
|
- let unwrappedMethod = handler.method ?? "(nil)"
|
|
|
- let unwrappedCaller = handler.caller ?? "(nil)"
|
|
|
- print("Server received request to " + unwrappedHost
|
|
|
- + " calling " + unwrappedMethod
|
|
|
- + " from " + unwrappedCaller
|
|
|
- + " with " + handler.requestMetadata.description)
|
|
|
-
|
|
|
- do {
|
|
|
- switch unwrappedMethod {
|
|
|
- //-{% for method in service.methods %}
|
|
|
- case "{{ .|path:file,service,method }}":
|
|
|
- //-{% if method|methodIsUnary or method|methodIsServerStreaming %}
|
|
|
- try {{ .|session:file,service,method }}Impl(
|
|
|
- handler: handler,
|
|
|
- providerBlock: { try provider.{{ method|methodDescriptorName|lowercase }}(request: $0, session: $1 as! {{ .|session:file,service,method }}Impl) })
|
|
|
- .run(queue:queue)
|
|
|
- //-{% else %}
|
|
|
- try {{ .|session:file,service,method }}Impl(
|
|
|
- handler: handler,
|
|
|
- providerBlock: { try provider.{{ method|methodDescriptorName|lowercase }}(session: $0 as! {{ .|session:file,service,method }}Impl) })
|
|
|
- .run(queue:queue)
|
|
|
- //-{% endif %}
|
|
|
- //-{% endfor %}
|
|
|
- default:
|
|
|
- // handle unknown requests
|
|
|
- try handler.receiveMessage(initialMetadata:Metadata()) {(requestData) in
|
|
|
- try handler.sendResponse(statusCode:.unimplemented,
|
|
|
- statusMessage:"unknown method " + unwrappedMethod,
|
|
|
- trailingMetadata:Metadata())
|
|
|
- }
|
|
|
- }
|
|
|
- } catch (let error) {
|
|
|
- print("Server error: \(error)")
|
|
|
- }
|
|
|
+ {{ access }} override func handleMethod(_ method: String, handler: Handler, queue: DispatchQueue) throws -> Bool {
|
|
|
+ let provider = self.provider
|
|
|
+ switch method {
|
|
|
+ //-{% for method in service.methods %}
|
|
|
+ case "{{ .|path:file,service,method }}":
|
|
|
+ //-{% if method|methodIsUnary or method|methodIsServerStreaming %}
|
|
|
+ try {{ .|session:file,service,method }}Impl(
|
|
|
+ handler: handler,
|
|
|
+ providerBlock: { try provider.{{ method|methodDescriptorName|lowercase }}(request: $0, session: $1 as! {{ .|session:file,service,method }}Impl) })
|
|
|
+ .run(queue: queue)
|
|
|
+ //-{% else %}
|
|
|
+ try {{ .|session:file,service,method }}Impl(
|
|
|
+ handler: handler,
|
|
|
+ providerBlock: { try provider.{{ method|methodDescriptorName|lowercase }}(session: $0 as! {{ .|session:file,service,method }}Impl) })
|
|
|
+ .run(queue: queue)
|
|
|
+ //-{% endif %}
|
|
|
+ return true
|
|
|
+ //-{% endfor %}
|
|
|
+ default:
|
|
|
+ return false
|
|
|
}
|
|
|
}
|
|
|
}
|