ch4 is a DNS Client CLI tool built around rsdns.
ch4's primary goal is to expose rsdns's capabilities in a concise manner. It can be used as a simple substitute for dig, with which it tries to be mostly compatible.
ch4 by default uses the tokio async runtime and the
corresponding rsdns client. It can be built with all clients and async runtimes supported
by rsdns via the same set of features net-tokio
, net-async-std
, net-smol
and net-std
.
shell
cargo install ch4
ch4 currently doesn't provide pre-built binaries. See rustrup.rs for installation of cargo and the Rust toolchain.
Nameserver address can be specified with the @
prefix.
shell
$> ch4 @8.8.8.8 A docs.rs
```text
; <<>> ch4 0.6.0 git:2920672 <<>> @8.8.8.8 A docs.rs
;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 22978
;; flags: qr rd ra; QUERY: 1, ANSWER: 4, AUTHORITY: 0, ADDITIONAL: 0
;; QUESTION SECTION: ;docs.rs. IN A
;; ANSWER SECTION: docs.rs. 60 IN A 13.225.255.26 docs.rs. 60 IN A 13.225.255.46 docs.rs. 60 IN A 13.225.255.38 docs.rs. 60 IN A 13.225.255.105
;; Query time: 93.962405ms ;; SERVER: 8.8.8.8:53 ;; WHEN: Tue, 14 Sep 2021 23:17:06 +0300 ;; MSG SIZE rcvd: 89 ```
When nameserver is not specified, it is auto-detected from the OS configuration.
shell
$> ch4 crates.io ANY
```text
; <<>> ch4 0.6.0 git:2920672 <<>> ANY crates.io
;; ->>HEADER<<- opcode: QUERY, status: NOERROR, id: 11080
;; flags: qr rd ra; QUERY: 1, ANSWER: 12, AUTHORITY: 0, ADDITIONAL: 0
;; QUESTION SECTION: ;crates.io. IN ANY
;; ANSWER SECTION: crates.io. 300 IN TXT "v=spf1 include:mailgun.org ~all" crates.io. 300 IN MX 10 mxa.mailgun.org. crates.io. 300 IN MX 10 mxb.mailgun.org. crates.io. 900 IN SOA ns-1064.awsdns-05.org. awsdns-hostmaster.amazon.com. 1 7200 900 1209600 86400 crates.io. 60 IN A 13.225.255.26 crates.io. 60 IN A 13.225.255.29 crates.io. 60 IN A 13.225.255.54 crates.io. 60 IN A 13.225.255.16 crates.io. 60 IN NS ns-817.awsdns-38.net. crates.io. 60 IN NS ns-217.awsdns-27.com. crates.io. 60 IN NS ns-1064.awsdns-05.org. crates.io. 60 IN NS ns-1543.awsdns-00.co.uk.
;; Query time: 68.23977ms ;; SERVER: 127.0.0.53:53 ;; WHEN: Tue, 14 Sep 2021 23:17:50 +0300 ;; MSG SIZE rcvd: 384 ```
ch4's options follow the features exposed by rsdns.
The detailed list of options is shown via --help
flag.
shell
$> ch4 --help
```text
ch4 0.6.0 git:2920672
DNS Client
USAGE: ch4 [FLAGS] [OPTIONS] [positional]...
FLAGS: -h, --help Prints help information
--info
Prints build information
--list-nameservers
Lists system nameservers
-V, --version
Prints version information
OPTIONS:
-p, --port
-l, --query-lifetime <query-lifetime>
query lifetime (in msec). [default: 10000]
-t, --query-timeout <query-timeout>
query timeout (in msec). Use 0 to disable. [default: 2000]
-r, --read <read-path>
read responses from file
-s, --save <save-path>
save responses to file
ARGS:
Positional arguments may be specified without any particular order.
Arguments specified later take precedence.
Arguments that are not recognized as special are treated as names
to be queried.
@<nameserver> - specifies the nameserver IP address.
If not specified, the first nameserver from OS
configuration is used.
<qtype> - query type (A, AAAA, NS ...).
An argument matching any of the supported query types
is considered as query type. Trailing dot can be
used to disambiguate a query name (A.).
+udp - sets the Udp protocol strategy. UDP is used by default.
Truncated responses are retried using TCP.
+tcp - sets the Tcp protocol strategy.
Only TCP is used for all queries.
+notcp - sets NoTcp protocol strategy. Only UDP is used.
Truncated queries are returned as is, without retry.
+[no]rec - enables (disables) recursive query.
Queries are recursive by default.
+[no]short - enables (disables) short output.
When enabled, only record data is printed,
one record on a line.
+[no]rust - enables (disables) rust output.
When enabled, prints the response as a Rust array.
```
The list of operating system configured nameservers is shown via the --list-nameservers
flag.
shell
$> ch4 --list-nameservers
text
8.8.8.8
208.67.222.222
8.26.56.26
Build information is shown via --info
flag.
shell
C:\> ch4.exe --info
text
build time: Tue, 14 Sep 2021 20:23:15 +0000
ch4 semver: 0.6.0
git hash: n/a
compiler: rustc
rustc: rustc 1.54.0 (a178d0322 2021-07-26)
cargo features: default, net_tokio, tokio
cargo profile: debug
cargo target: x86_64-pc-windows-msvc
endianness: little
pointer width: 64
build system name: Windows
build os version: Windows Server 2019 Datacenter
build cpu vendor: GenuineIntel
build cpu brand: Intel(R) Xeon(R) Platinum 8272CL CPU @ 2.60GHz
The changelog is maintained in CHANGELOG.md
Licensed under either of
at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.