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); }