static int Run() { // Locate path to certificates folder in distribution. string rootDir = DllPathResolver.FindDistributionRootDir(); string certsDir = Path.Combine(rootDir, "certs"); // Initialize RCF. RCFProto.Init(); // Create server. RcfProtoServer server = new RcfProtoServer(); // Bind Protobuf service. SearchServiceImpl myService = new SearchServiceImpl(); server.BindService(myService); // Add the endpoints that this server will support. List <Endpoint> endpoints = new List <Endpoint>(); endpoints.Add(new TcpEndpoint(50001)); endpoints.Add(new HttpEndpoint(50002)); endpoints.Add(new HttpsEndpoint(50003)); endpoints.Add(new Win32NamedPipeEndpoint("DemoServerPipe")); foreach (Endpoint endpoint in endpoints) { server.AddEndpoint(endpoint); } // By default, the server serves clients on a single thread. Here, we are // configuring the server to use a thread pool with up to 10 threads. ThreadPool threadPool = new ThreadPool(1, 10); threadPool.SetThreadName("RCFProto Server"); server.SetThreadPool(threadPool); // Configure SSL certificate. // Load certificate from PFX format. string certPath = Path.Combine(certsDir, "certA.p12"); Certificate cert = new PfxCertificate(certPath, "", "localhost"); server.SetCertificate(cert); server.SetSslImplementation(SslImplementation.Schannel); // Start the server. server.Start(); // Wait for shutdown. SearchServiceImpl.ShutdownEvent.WaitOne(); System.Console.WriteLine("Shutting down server."); // Stop server. server.Stop(); return(0); }
static int Run(string[] args) { ParseCommandLine(args); // Locate path to certificates folder in distribution. string rootDir = DllPathResolver.FindDistributionRootDir(); string certsDir = Path.Combine(rootDir, "certs"); // Initialize RCFProto. RCFProto.Init(); // Build a search request. SearchRequest request = SearchRequest.CreateBuilder() .SetQuery("something to search for") .SetResultPerPage(10) .SetPageNumber(0) .Build(); // Call the server on each of its supported endpoints. List <Endpoint> endpoints = new List <Endpoint>(); endpoints.Add(new TcpEndpoint(50001)); endpoints.Add(new HttpEndpoint(50002)); endpoints.Add(new HttpsEndpoint(50003)); endpoints.Add(new Win32NamedPipeEndpoint("DemoServerPipe")); foreach (Endpoint endpoint in endpoints) { // Create channel. RcfProtoChannel channel = new RcfProtoChannel(endpoint); RcfProtoController rcfController = new RcfProtoController(); SearchService.Stub searchService = new SearchService.Stub(channel); // Set certificate validation callback, for SSL. channel.SetCertificateValidationCallback(OnValidateCertificate); { // Synchronous remote call. searchService.Search(null, request, null); SearchResponse response = (SearchResponse)channel.GetResponse(); } { // Asynchronous remote call. channel.SetAsynchronousRpcMode(true); Action <SearchResponse> done = delegate(SearchResponse response) { OnRpcDone(searchService, rcfController, request, response); }; searchService.Search(rcfController, request, done); while (gCallCompleted == false) { System.Threading.Thread.Sleep(500); } } } { // Create TCP channel. RcfProtoChannel channel = new RcfProtoChannel(endpoints[0]); RcfProtoController rcfController = new RcfProtoController(); SearchService.Stub searchService = new SearchService.Stub(channel); // Enable compression (requires zlib to be installed). //channel.SetEnableCompression(true); // Custom connection timeout (10s). channel.SetConnectTimeoutMs(10 * 1000); // Custom remote call timeout (60s). channel.SetRemoteCallTimeoutMs(60 * 1000); // Enable NTLM authentication and encryption. channel.SetTransportProtocol(TransportProtocol.Ntlm); // The channel will pick up the credentials of the user running the // program. Alternatively, we can set the credentials explicitly: //channel.setUsername("MyDomain\\MyUsername"); //channel.setPassword("MyPassword"); searchService.Search(null, request, null); SearchResponse response = (SearchResponse)channel.GetResponse(); // Enable SSL, with custom certificate validation callback. channel.SetTransportProtocol(TransportProtocol.Ssl); channel.SetCertificateValidationCallback(OnValidateCertificate); searchService.Search(null, request, null); response = (SearchResponse)channel.GetResponse(); // Enable SSL, with validation against Windows certificate root store. Requires Schannel. string certPath = Path.Combine(certsDir, "caCertA.p12"); // Open CA certificate. PfxCertificate caCert = new PfxCertificate(certPath, "", "RCF CA A"); // Add it to the root store of the local machine. caCert.AddToStore(Win32CertificateLocation.LocalMachine, Win32CertificateStore.Root); channel.SetEnableSchannelCertificateValidation("localhost"); channel.SetSslImplementation(SslImplementation.Schannel); // Disconnect so SSL handshake takes place again. channel.Disconnect(); searchService.Search(null, request, null); response = (SearchResponse)channel.GetResponse(); } return(0); }