3 unstable releases

0.1.0 May 8, 2024
0.0.2 Jan 25, 2024
0.0.1 Jan 25, 2024

#837 in Command line utilities

Download history 745/week @ 2024-01-25 2138/week @ 2024-02-01 219/week @ 2024-02-08 1127/week @ 2024-02-15 2301/week @ 2024-02-22 2624/week @ 2024-02-29 1550/week @ 2024-03-07 2611/week @ 2024-03-14 2445/week @ 2024-03-21 2416/week @ 2024-03-28 1326/week @ 2024-04-04 1455/week @ 2024-04-11 1638/week @ 2024-04-18 1678/week @ 2024-04-25 1420/week @ 2024-05-02 2624/week @ 2024-05-09

7,664 downloads per month

Apache-2.0

10KB

reqwest-hickory-resolver   Build Status Latest Version

reqwest-hickory-resolver is the resolver for reqwest based on hickory-dns.

Quick Start

Init client with HickoryResolver.

use std::sync::Arc;

use reqwest::ClientBuilder;
use reqwest_hickory_resolver::HickoryResolver;

fn init_with_hickory_resolver() -> reqwest::Result<()> {
    let mut builder = ClientBuilder::new();
    builder = builder.dns_resolver(Arc::new(HickoryResolver::default()));
    builder.build()?;
    Ok(())
}

HickoryResolver has cache support, we can share the same resolver across different client for better performance.

use std::sync::Arc;
use once_cell::sync::Lazy;
use reqwest::ClientBuilder;
use reqwest_hickory_resolver::HickoryResolver;

static GLOBAL_RESOLVER: Lazy<Arc<HickoryResolver>> =
    Lazy::new(|| Arc::new(HickoryResolver::default()));
    
fn init_with_hickory_resolver() -> reqwest::Result<()> {
    let mut builder = ClientBuilder::new();
    builder = builder.dns_resolver(GLOBAL_RESOLVER.clone());
    builder.build()?;
    Ok(())
}

Contributing

Check out the CONTRIBUTING.md guide for more details on getting started with contributing to this project.

Getting help

Submit issues for bug report or asking questions in discussion.

Acknowledgements

This project is based on reqwest's TrustDnsResolver.

License

Licensed under Apache License, Version 2.0.

Dependencies

~7–19MB
~286K SLoC