DNS library in Go
Go to file
Dave Pifke 50fbccd204
Allow use of fs.FS for $INCLUDE and wrap errors (#1526)
* Allow use of fs.FS for $INCLUDE and wrap errors

This adds ZoneParser.SetIncludeAllowedFS, to specify an fs.FS when
enabling support for $INCLUDE, for reading included files from
somewhere other than the local filesystem.

I've also modified ParseError to support wrapping another error, such
as errors encountered while opening the $INCLUDE target.  This allows
for much more robust handling, using errors.Is() instead of testing
for particular strings (which may not be identical between fs.FS
implementations).

ParseError was being constructed in a lot of places using positional
instead of named members.  Updating ParseError initialization after
the new member field was added makes this change seem a lot larger
than it actually is.

The changes here should be completely backwards compatible.  The
ParseError change should be invisible to anyone not trying to unwrap
it, and ZoneParser will continue to use os.Open if the existing
SetIncludeAllowed method is called instead of the new
SetIncludeAllowedFS method.

* Don't duplicate SetIncludeAllowed; clarify edge cases

Rather than duplicate functionality between SetIncludeAllowed and
SetIncludeAllowedFS, have a method SetIncludeFS, which only sets the
fs.FS.

I've improved the documentation to point out some considerations for
users hoping to use fs.FS as a security boundary.

Per the fs.ValidPath documentation, fs.FS implementations must use
path (not filepath) semantics, with slash as a separator (even on
Windows).  Some, like os.DirFS, also require all paths to be relative.
I've clarified this in the documentation, made the includePath
manipulation more robust to edge cases, and added some additional
tests for relative and absolute paths.
2024-01-15 15:40:43 +01:00
.github Enable dependabot (#1483) 2023-09-19 08:34:45 +02:00
dnsutil Fix typos (#1413) 2023-01-14 08:19:09 +01:00
.codecov.yml Add codecov yaml to not fail the build (#600) 2017-12-06 10:36:23 +00:00
.gitignore gitignore update 2013-10-15 13:22:35 +00:00
acceptfunc_test.go Support generic net.PacketConn's for the Server (#1174) 2020-10-25 02:23:01 +10:30
acceptfunc.go Remove comment about checking zero bit. (#1491) 2023-11-02 13:34:35 +01:00
AUTHORS add AUTHOR file 2014-02-10 17:15:49 +00:00
client_test.go tests: skip unix socket tests for non *nix OSes (#1443) 2023-06-16 17:57:59 +02:00
client.go Make ExchangeWithConnContext public (#1459) 2023-06-19 16:05:20 +02:00
clientconfig_test.go chore: don't use deprecated ioutil package (#1445) 2023-03-19 14:01:37 +01:00
clientconfig.go Introduce a generic slice clone function (#1432) 2023-03-12 11:14:24 +01:00
CODEOWNERS Add CODEOWNERS (#1042) 2019-12-09 11:50:19 +00:00
CONTRIBUTORS Correctly set the Source IP to the received Destination IP (#524) 2017-09-29 10:38:26 +01:00
COPYRIGHT Remove all copyright notices 2014-09-11 20:57:37 +01:00
dane.go Improve performance by addressing some low hanging fruit. (#444) 2017-02-02 07:33:49 +00:00
defaults.go Cleanup IsRRSet (#1502) 2023-11-06 07:24:27 +01:00
dns_bench_test.go ZoneParser: error on parsing an IPv6 address in an A record (#923) 2019-03-09 09:02:18 +00:00
dns_test.go Improve IsFQDN performance (#1453) 2023-04-27 13:36:03 +02:00
dns.go Fix Rdlength related parsing bug in RFC3597 records (#1214) 2021-02-01 09:10:38 +01:00
dnssec_keygen.go Use ed25519 from Go standard lib (#1243) 2021-03-16 15:37:10 +01:00
dnssec_keyscan.go Allow use of fs.FS for $INCLUDE and wrap errors (#1526) 2024-01-15 15:40:43 +01:00
dnssec_privkey.go Use ed25519 from Go standard lib (#1243) 2021-03-16 15:37:10 +01:00
dnssec_test.go Fix RSAMD5 keytag calucation. (#1353) 2022-04-01 14:01:47 +02:00
dnssec.go Fix some lint checks by (go) staticcheck ./... (#1442) 2023-03-28 19:35:46 +02:00
doc.go Run gofmt -w -s *.go (#1408) 2023-01-05 07:53:57 +01:00
duplicate_generate.go Tweaks (#1425) 2023-03-02 18:56:59 +01:00
duplicate_test.go Implement SVCB (#1067) 2020-10-11 09:09:36 +02:00
duplicate.go Doc updates (#1075) 2020-02-14 22:47:21 +01:00
dyn_test.go Remove all copyright notices 2014-09-11 20:57:37 +01:00
edns_test.go Fix edns keepalive (#1317) 2021-12-23 09:45:02 +01:00
edns.go tweak SetDo doc (#1488) 2023-10-10 18:35:54 +02:00
example_test.go Fix examples by using net.JoinHostPort (#1368) 2022-04-15 10:13:08 +02:00
format_test.go Add checks on data length for A and AAAA records (#919) 2019-03-12 16:31:33 +00:00
format.go Add checks on data length for A and AAAA records (#919) 2019-03-12 16:31:33 +00:00
fuzz_test.go Spelling (#1222) 2021-02-25 17:08:05 +01:00
fuzz.go Run gofmt -w -s *.go (#1408) 2023-01-05 07:53:57 +01:00
generate_test.go chore: don't use deprecated ioutil package (#1445) 2023-03-19 14:01:37 +01:00
generate.go Allow use of fs.FS for $INCLUDE and wrap errors (#1526) 2024-01-15 15:40:43 +01:00
go.mod Bump golang.org/x/net from 0.15.0 to 0.17.0 (#1498) 2023-11-02 13:59:00 +01:00
go.sum Bump golang.org/x/net from 0.15.0 to 0.17.0 (#1498) 2023-11-02 13:59:00 +01:00
hash.go Add indentityHash for algos that don't need hashing (#1340) 2022-03-12 09:41:21 +01:00
issue_test.go tests: reduce timeouts and iterations (#1175) 2020-10-16 09:10:36 +02:00
labels_test.go CanonicalName should casefold non-US-ASCII chars (#1470) 2023-09-12 11:57:40 +02:00
labels.go Remove space between NextLabel func and doc comment (#1410) 2023-01-06 08:51:52 +01:00
leak_test.go Revert doh (#800) 2018-11-01 20:16:39 +00:00
length_test.go Make the 900 number lower in this test (#1176) 2020-10-16 11:55:29 +02:00
LICENSE Restructure license so Github will recognize it. (#1397) 2022-11-12 12:37:31 +01:00
listen_no_reuseport.go feat: add support for ReuseAddr (#1510) 2023-11-15 10:09:44 +01:00
listen_reuseport.go feat: add support for ReuseAddr (#1510) 2023-11-15 10:09:44 +01:00
Makefile.fuzz Add fuzzing framework (#580) 2017-11-23 09:34:31 +00:00
Makefile.release Spelling (#1222) 2021-02-25 17:08:05 +01:00
msg_generate.go Avoid using strings.Split (#1501) 2023-11-06 07:23:41 +01:00
msg_helpers_test.go Fix some lint checks by (go) staticcheck ./... (#1442) 2023-03-28 19:35:46 +02:00
msg_helpers.go Avoid using a goto loop in unpackDataOpt (#1505) 2023-11-06 07:26:49 +01:00
msg_test.go Add test for forward compression pointer (#1123) 2020-05-27 08:05:25 +00:00
msg_truncate_test.go Fix typos (#1413) 2023-01-14 08:19:09 +01:00
msg_truncate.go Update Truncate doc with compress behaviour (#1217) 2021-02-10 07:41:26 +01:00
msg.go Eliminate tmp buffer from packOctetString (#1503) 2023-11-06 07:25:03 +01:00
nsecx_test.go Add a HashName benchmark 2018-11-29 10:28:29 +10:30
nsecx.go Doc updates (#1075) 2020-02-14 22:47:21 +01:00
parse_test.go Use correct string format IPv4 encoded as IPv6 for for AAAA records (#1457) 2023-09-12 11:45:58 +02:00
privaterr_test.go refactor: remove ParseZone and parseZone (#1099) 2020-04-28 09:24:18 +02:00
privaterr.go Allow use of fs.FS for $INCLUDE and wrap errors (#1526) 2024-01-15 15:40:43 +01:00
README.md docs: added ninedos to readme (#1522) 2024-01-09 17:52:18 +01:00
reverse.go Move all reversed map creation into reverse.go (#889) 2019-01-04 08:10:15 +00:00
rr_test.go Eliminate lexer goroutines (#792) 2018-10-15 17:42:31 +10:30
sanitize_test.go Tests updates (#556) 2017-11-08 10:01:19 +00:00
sanitize.go Avoid calling RR.Header more than once per RR (#891) 2019-01-04 08:12:32 +00:00
scan_rr.go Allow use of fs.FS for $INCLUDE and wrap errors (#1526) 2024-01-15 15:40:43 +01:00
scan_test.go Allow use of fs.FS for $INCLUDE and wrap errors (#1526) 2024-01-15 15:40:43 +01:00
scan.go Allow use of fs.FS for $INCLUDE and wrap errors (#1526) 2024-01-15 15:40:43 +01:00
serve_mux_test.go Rework and optimise ServeMux (#754) 2018-09-27 07:48:02 +01:00
serve_mux.go answer queries with no matching handler with RcodeRefused (#1151) 2020-08-20 08:41:45 +02:00
server_test.go feat: add support for ReuseAddr (#1510) 2023-11-15 10:09:44 +01:00
server.go feat: add support for ReuseAddr (#1510) 2023-11-15 10:09:44 +01:00
sig0_test.go Add indentityHash for algos that don't need hashing (#1340) 2022-03-12 09:41:21 +01:00
sig0.go Add indentityHash for algos that don't need hashing (#1340) 2022-03-12 09:41:21 +01:00
smimea.go Simplify and unify various returns (#893) 2019-01-04 10:19:42 +00:00
svcb_test.go Properly parse alpn values in SVCB (#1363) 2022-05-10 18:40:09 +02:00
svcb.go Allow use of fs.FS for $INCLUDE and wrap errors (#1526) 2024-01-15 15:40:43 +01:00
tlsa.go Simplify and unify various returns (#893) 2019-01-04 10:19:42 +00:00
tmpdir_darwin_test.go tests: skip unix socket tests for non *nix OSes (#1443) 2023-06-16 17:57:59 +02:00
tmpdir_test.go tests: skip unix socket tests for non *nix OSes (#1443) 2023-06-16 17:57:59 +02:00
tools.go Run gofmt -w -s *.go (#1408) 2023-01-05 07:53:57 +01:00
tsig_test.go Make tsigGenerateProvider/TsigVerifyProvider public (#1382) 2022-06-21 10:37:36 +02:00
tsig.go Make tsigGenerateProvider/TsigVerifyProvider public (#1382) 2022-06-21 10:37:36 +02:00
types_generate.go Avoid using strings.Split (#1501) 2023-11-06 07:23:41 +01:00
types_test.go Updates to LOC type RFC1876 (#1440) 2023-03-18 12:57:18 +01:00
types.go Try explaining duplicate RCODEs 2023-12-13 10:04:56 +01:00
udp_test.go Run gofmt -w -s *.go (#1408) 2023-01-05 07:53:57 +01:00
udp_windows.go Correct TODO in udp_windows.go (#1433) 2023-03-12 11:14:37 +01:00
udp.go Run gofmt -w -s *.go (#1408) 2023-01-05 07:53:57 +01:00
update_test.go Use proper section names when producing dig-like output for UPDATEs (#1479) 2023-09-12 11:44:32 +02:00
update.go fix Msg.Used TTL must be zero (#1280) 2021-07-18 09:24:05 +02:00
version_test.go Doc updates (#1075) 2020-02-14 22:47:21 +01:00
version.go Release 1.1.57 2023-11-15 09:10:43 +00:00
xfr_test.go Support TsigProvider for Server and Transfer (#1331) 2022-02-05 00:23:49 +00:00
xfr.go Swap closing order in inAxfr and inIxfr (#1511) 2023-11-13 16:10:26 +01:00
zduplicate.go Add AMTRELAY and IPSECKEY RR types (#1402) 2023-02-26 12:26:39 +01:00
zmsg.go Add AMTRELAY and IPSECKEY RR types (#1402) 2023-02-26 12:26:39 +01:00
ztypes.go Introduce a generic slice clone function (#1432) 2023-03-12 11:14:24 +01:00

Build Status Code Coverage Go Report Card

Alternative (more granular) approach to a DNS library

Less is more.

Complete and usable DNS library. All Resource Records are supported, including the DNSSEC types. It follows a lean and mean philosophy. If there is stuff you should know as a DNS programmer there isn't a convenience function for it. Server side and client side programming is supported, i.e. you can build servers and resolvers with it.

We try to keep the "master" branch as sane as possible and at the bleeding edge of standards, avoiding breaking changes wherever reasonable. We support the last two versions of Go.

Goals

  • KISS;
  • Fast;
  • Small API. If it's easy to code in Go, don't make a function for it.

Users

A not-so-up-to-date-list-that-may-be-actually-current:

Send pull request if you want to be listed here.

Features

  • UDP/TCP queries, IPv4 and IPv6
  • RFC 1035 zone file parsing ($INCLUDE, $ORIGIN, $TTL and $GENERATE (for all record types) are supported
  • Fast
  • Server side programming (mimicking the net/http package)
  • Client side programming
  • DNSSEC: signing, validating and key generation for DSA, RSA, ECDSA and Ed25519
  • EDNS0, NSID, Cookies
  • AXFR/IXFR
  • TSIG, SIG(0)
  • DNS over TLS (DoT): encrypted connection between client and server over TCP
  • DNS name compression

Have fun!

Miek Gieben - 2010-2012 - miek@miek.nl DNS Authors 2012-

Building

This library uses Go modules and uses semantic versioning. Building is done with the go tool, so the following should work:

go get github.com/miekg/dns
go build github.com/miekg/dns

Examples

A short "how to use the API" is at the beginning of doc.go (this also will show when you call godoc github.com/miekg/dns).

Example programs can be found in the github.com/miekg/exdns repository.

Supported RFCs

all of them

  • 103{4,5} - DNS standard
  • 1348 - NSAP record (removed the record)
  • 1982 - Serial Arithmetic
  • 1876 - LOC record
  • 1995 - IXFR
  • 1996 - DNS notify
  • 2136 - DNS Update (dynamic updates)
  • 2181 - RRset definition - there is no RRset type though, just []RR
  • 2537 - RSAMD5 DNS keys
  • 2065 - DNSSEC (updated in later RFCs)
  • 2671 - EDNS record
  • 2782 - SRV record
  • 2845 - TSIG record
  • 2915 - NAPTR record
  • 2929 - DNS IANA Considerations
  • 3110 - RSASHA1 DNS keys
  • 3123 - APL record
  • 3225 - DO bit (DNSSEC OK)
  • 340{1,2,3} - NAPTR record
  • 3445 - Limiting the scope of (DNS)KEY
  • 3597 - Unknown RRs
  • 4025 - A Method for Storing IPsec Keying Material in DNS
  • 403{3,4,5} - DNSSEC + validation functions
  • 4255 - SSHFP record
  • 4343 - Case insensitivity
  • 4408 - SPF record
  • 4509 - SHA256 Hash in DS
  • 4592 - Wildcards in the DNS
  • 4635 - HMAC SHA TSIG
  • 4701 - DHCID
  • 4892 - id.server
  • 5001 - NSID
  • 5155 - NSEC3 record
  • 5205 - HIP record
  • 5702 - SHA2 in the DNS
  • 5936 - AXFR
  • 5966 - TCP implementation recommendations
  • 6605 - ECDSA
  • 6725 - IANA Registry Update
  • 6742 - ILNP DNS
  • 6840 - Clarifications and Implementation Notes for DNS Security
  • 6844 - CAA record
  • 6891 - EDNS0 update
  • 6895 - DNS IANA considerations
  • 6944 - DNSSEC DNSKEY Algorithm Status
  • 6975 - Algorithm Understanding in DNSSEC
  • 7043 - EUI48/EUI64 records
  • 7314 - DNS (EDNS) EXPIRE Option
  • 7477 - CSYNC RR
  • 7828 - edns-tcp-keepalive EDNS0 Option
  • 7553 - URI record
  • 7858 - DNS over TLS: Initiation and Performance Considerations
  • 7871 - EDNS0 Client Subnet
  • 7873 - Domain Name System (DNS) Cookies
  • 8080 - EdDSA for DNSSEC
  • 8499 - DNS Terminology
  • 8659 - DNS Certification Authority Authorization (CAA) Resource Record
  • 8777 - DNS Reverse IP Automatic Multicast Tunneling (AMT) Discovery
  • 8914 - Extended DNS Errors
  • 8976 - Message Digest for DNS Zones (ZONEMD RR)

Loosely Based Upon