refactor: initial implementation of separeted lib and bin
This commit is contained in:
		
					parent
					
						
							
								ec85b0bb28
							
						
					
				
			
			
				commit
				
					
						13e82035a8
					
				
			
		
					 37 changed files with 225 additions and 157 deletions
				
			
		
							
								
								
									
										72
									
								
								rpxy-lib/src/lib.rs
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										72
									
								
								rpxy-lib/src/lib.rs
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,72 @@ | |||
| mod backend; | ||||
| mod certs; | ||||
| mod constants; | ||||
| mod error; | ||||
| mod globals; | ||||
| mod handler; | ||||
| mod log; | ||||
| mod proxy; | ||||
| mod utils; | ||||
| 
 | ||||
| use crate::{error::*, handler::HttpMessageHandlerBuilder, log::*, proxy::ProxyBuilder}; | ||||
| use futures::future::select_all; | ||||
| use hyper::Client; | ||||
| // use hyper_trust_dns::TrustDnsResolver;
 | ||||
| use std::sync::Arc; | ||||
| 
 | ||||
| pub use crate::{ | ||||
|   backend::{ | ||||
|     Backend, BackendBuilder, Backends, ReverseProxy, Upstream, UpstreamGroup, UpstreamGroupBuilder, UpstreamOption, | ||||
|   }, | ||||
|   certs::{CertsAndKeys, CryptoSource}, | ||||
|   globals::{Globals, ProxyConfig}, // TODO: BackendConfigに変える
 | ||||
|   utils::{BytesName, PathNameBytesExp}, | ||||
| }; | ||||
| pub mod reexports { | ||||
|   pub use hyper::Uri; | ||||
|   pub use rustls::{Certificate, PrivateKey}; | ||||
| } | ||||
| 
 | ||||
| /// Entrypoint that creates and spawns tasks of reverse proxy services
 | ||||
| pub async fn entrypoint<T>(globals: Arc<Globals<T>>) -> Result<()> | ||||
| where | ||||
|   T: CryptoSource + Clone + Send + Sync + 'static, | ||||
| { | ||||
|   // let connector = TrustDnsResolver::default().into_rustls_webpki_https_connector();
 | ||||
|   let connector = hyper_rustls::HttpsConnectorBuilder::new() | ||||
|     .with_webpki_roots() | ||||
|     .https_or_http() | ||||
|     .enable_http1() | ||||
|     .enable_http2() | ||||
|     .build(); | ||||
| 
 | ||||
|   let msg_handler = HttpMessageHandlerBuilder::default() | ||||
|     .forwarder(Arc::new(Client::builder().build::<_, hyper::Body>(connector))) | ||||
|     .globals(globals.clone()) | ||||
|     .build()?; | ||||
| 
 | ||||
|   let addresses = globals.proxy_config.listen_sockets.clone(); | ||||
|   let futures = select_all(addresses.into_iter().map(|addr| { | ||||
|     let mut tls_enabled = false; | ||||
|     if let Some(https_port) = globals.proxy_config.https_port { | ||||
|       tls_enabled = https_port == addr.port() | ||||
|     } | ||||
| 
 | ||||
|     let proxy = ProxyBuilder::default() | ||||
|       .globals(globals.clone()) | ||||
|       .listening_on(addr) | ||||
|       .tls_enabled(tls_enabled) | ||||
|       .msg_handler(msg_handler.clone()) | ||||
|       .build() | ||||
|       .unwrap(); | ||||
| 
 | ||||
|     globals.runtime_handle.spawn(proxy.start()) | ||||
|   })); | ||||
| 
 | ||||
|   // wait for all future
 | ||||
|   if let (Ok(_), _, _) = futures.await { | ||||
|     error!("Some proxy services are down"); | ||||
|   }; | ||||
| 
 | ||||
|   Ok(()) | ||||
| } | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Jun Kurihara
				Jun Kurihara