• Stars
    star
    8,024
  • Rank 4,649 (Top 0.1 %)
  • Language
    Go
  • License
    BSD 3-Clause "New...
  • Created over 14 years ago
  • Updated about 2 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

DNS library in Go

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 - [email protected] 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
  • 1183 - ISDN, X25 and other deprecated records
  • 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

More Repositories

1

gobook

A complete introduction into Go, superseded by https://github.com/miekg/learninggo
TeX
874
star
2

learninggo

Learning Go Book in mmark
Go
541
star
3

gitopper

Gitops for non-Kubernetes folks
Go
380
star
4

pkcs11

pkcs11 wrapper for Go
Go
375
star
5

exdns

Go DNS example programs
Go
299
star
6

lean

Pretty, minimal, one-line, fast ZSH prompt
Shell
154
star
7

rdup

The only backup program that doesn't make backups!
C
106
star
8

unbound

A Go wrapper for libunbound
Go
101
star
9

pandoc2rfc

Use pandoc to create XML suitable for xml2rfc
Python
81
star
10

dinit

An init for use inside Docker containers
Go
67
star
11

skydns2

Development is taking place: https://github.com/skynetservices/skydns2
Go
63
star
12

dnsv2

Go
44
star
13

bgp

BGP implementation in Go
Go
41
star
14

xds

command line interface for Envoy xDS endpoint
Go
35
star
15

block

Proof of concept CoreDNS plugin that implements a block list
Go
23
star
16

yamlfmt

Format YAML
Go
21
star
17

dnsfs

A DNS filesystem
Go
21
star
18

redis

CoreDNS plugin implementing a shared cache using Redis
Go
14
star
19

bitradix

A radix tree that branches on the bits in a key
Go
14
star
20

dnsrouter

Route DNS packets
Go
14
star
21

dreck

Bot to help with GitHub chores
Go
12
star
22

pgo

container gitops in a simple way
Go
11
star
23

rip

RIP protocol implementation in Go
Go
10
star
24

lg-dns

DNS Looking Glass
Go
9
star
25

mutfs

A filesystem where you can create, but not alter files, imMUTable FS.
Go
8
star
26

dnsfmt

Auto format DNS zone files
Go
7
star
27

ssd

Go
6
star
28

nxdomain

CoreDNS plugin: return NXDOMAIN for configured domains
Go
6
star
29

dump

dump all incoming request in coredns
Go
5
star
30

lboverlay

Go
5
star
31

local

CoreDNS plugin that answers "local" queries
Go
5
star
32

caddy-debian

Create debian package for Caddy
Makefile
5
star
33

access

why - explain why a user can or cannot access a file
Go
5
star
34

cf

CFEngine formatter
Go
4
star
35

nsec4

authenticated denial of existence
Shell
4
star
36

denialid

Authenticated Denial of Existence in the DNS
XSLT
4
star
37

ebpf

ebpf compiler in Go; Write Go, get ebpf
Go
4
star
38

debian

Small CI to create debian packages for various (Go) binaries
Shell
3
star
39

nlgids

caddy middleware for nlgids.london
Go
2
star
40

a

2
star
41

ssh2prom

Prometheus metrics from openssh
Go
2
star
42

mmark.nl

mmark.miek.nl website
HTML
2
star
43

dname

HTML
2
star
44

coderemarks

Annotate source code with remarks in LaTeX
2
star
45

rota

generate oncall rotations
Go
2
star
46

gompletely

completions generation
Go
1
star
47

kubeadam

TeX
1
star
48

xdoc

Go
1
star
49

corecheck

Utility to check Markdown files for valid Corefile snippets.
Go
1
star
50

signalds

1
star
51

caddy-user

Caddy module that changes to a different user before serving the request
Go
1
star