/* * Copyright 2019, gRPC Authors All rights reserved. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ import Foundation import GRPC import RouteGuideModel import NIO import Logging import SwiftProtobuf // Quieten the logs. LoggingSystem.bootstrap { var handler = StreamLogHandler.standardOutput(label: $0) handler.logLevel = .critical return handler } /// Loads the features from `route_guide_db.json`, assumed to be in the directory above this file. func loadFeatures() throws -> [Routeguide_Feature] { let url = URL(fileURLWithPath: #file) .deletingLastPathComponent() // main.swift .deletingLastPathComponent() // Server/ .appendingPathComponent("route_guide_db.json") let data = try Data(contentsOf: url) return try Routeguide_Feature.array(fromJSONUTF8Data: data) } func main(args: [String]) throws { // Create an event loop group for the server to run on. let group = MultiThreadedEventLoopGroup(numberOfThreads: System.coreCount) defer { try! group.syncShutdownGracefully() } // Read the feature database. let features = try loadFeatures() // Create a provider using the features we read. let provider = RouteGuideProvider(features: features) // Tie these together in some configuration: let configuration = Server.Configuration( target: .hostAndPort("localhost", 0), eventLoopGroup: group, serviceProviders: [provider] ) // Start the server and print its address once it has started. let server = Server.start(configuration: configuration) server.map { $0.channel.localAddress }.whenSuccess { address in print("server started on port \(address!.port!)") } // Wait on the server's `onClose` future to stop the program from exiting. _ = try server.flatMap { $0.onClose }.wait() } try main(args: CommandLine.arguments)