1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-03 12:58:54 -05:00

Use lazy_static for HttpsConnector

And rename net.rs to http.rs

Share HTTP connection.
This commit is contained in:
Ryan Dahl 2018-09-24 19:51:37 -04:00
parent 7fb2821937
commit 7c128df4a0
5 changed files with 30 additions and 11 deletions

View file

@ -47,6 +47,7 @@ main_extern = [
"$rust_build:hyper",
"$rust_build:hyper_rustls",
"$rust_build:futures",
"$rust_build:lazy_static",
"$rust_build:libc",
"$rust_build:log",
"$rust_build:ring",

View file

@ -4,7 +4,7 @@ use errors::DenoError;
use errors::DenoResult;
use errors::ErrorKind;
use fs as deno_fs;
use net;
use http;
use ring;
use std;
use std::fmt::Write;
@ -114,7 +114,7 @@ impl DenoDir {
let src = if self.reload || !p.exists() {
println!("Downloading {}", module_name);
let source = net::fetch_sync_string(module_name)?;
let source = http::fetch_sync_string(module_name)?;
match p.parent() {
Some(ref parent) => fs::create_dir_all(parent),
None => Ok(()),

View file

@ -147,7 +147,7 @@ fn permission_denied() -> DenoError {
fn not_implemented() -> DenoError {
DenoError::from(std::io::Error::new(
std::io::ErrorKind::Other,
"Not implemented"
"Not implemented",
))
}

View file

@ -1,21 +1,37 @@
// Copyright 2018 the Deno authors. All rights reserved. MIT license.
use errors::DenoResult;
use futures::Future;
use futures::Stream;
use hyper;
use hyper::rt::{Future, Stream};
use hyper::{Client, Uri};
use hyper::client::HttpConnector;
use hyper::Uri;
use hyper_rustls;
use tokio::runtime::current_thread::Runtime;
type Connector = hyper_rustls::HttpsConnector<HttpConnector>;
lazy_static! {
static ref CONNECTOR: Connector = {
let num_dns_threads = 4;
Connector::new(num_dns_threads)
};
}
pub fn get_client() -> Client<Connector, hyper::Body> {
// TODO use Hyper's connection pool.
let c = CONNECTOR.clone();
Client::builder().build(c)
}
// The CodeFetch message is used to load HTTP javascript resources and expects a
// synchronous response, this utility method supports that.
pub fn fetch_sync_string(module_name: &str) -> DenoResult<String> {
let url = module_name.parse::<Uri>().unwrap();
let https = hyper_rustls::HttpsConnector::new(4);
let client: Client<_, hyper::Body> = Client::builder().build(https);
let client = get_client();
// TODO Use Deno's RT
let mut rt = Runtime::new().unwrap();
let body = rt.block_on(
client
.get(url)

View file

@ -9,6 +9,8 @@ extern crate tempfile;
extern crate tokio;
extern crate url;
#[macro_use]
extern crate lazy_static;
#[macro_use]
extern crate log;
extern crate dirs;
extern crate hyper_rustls;
@ -20,9 +22,9 @@ mod errors;
mod flags;
mod fs;
pub mod handlers;
mod http;
mod isolate;
mod libdeno;
mod net;
mod version;
use isolate::Isolate;