DnsZone is a tool for parsing and building dns zone file.
Available at nuget.org
Donations: bitcoin:12aM1SmiG6QmirQK3huSmPRhyPPQQvqkUv
Parse dns zone from existing string:
const string str = @" $ORIGIN example.com. ; designates the start of this zone file in the namespace $TTL 1h ; default expiration time of all resource records without their own TTL value example.com. IN SOA ns.example.com. username.example.com. ( 2007120710 1d 2h 4w 1h ) example.com. IN NS ns ; ns.example.com is a nameserver for example.com example.com. IN NS ns.somewhere.example. ; ns.somewhere.example is a backup nameserver for example.com example.com. IN MX 10 mail.example.com. ; mail.example.com is the mailserver for example.com @ IN MX 20 mail2.example.com. ; equivalent to above line, ""@"" represents zone origin @ IN MX 50 mail3 ; equivalent to above line, but using a relative host name example.com. IN A 192.0.2.1 ; IPv4 address for example.com IN AAAA 2001:db8:10::1 ; IPv6 address for example.com ns IN A 192.0.2.2 ; IPv4 address for ns.example.com IN AAAA 2001:db8:10::2 ; IPv6 address for ns.example.com www IN CNAME example.com. ; www.example.com is an alias for example.com wwwtest IN CNAME www ; wwwtest.example.com is another alias for www.example.com mail IN A 192.0.2.3 ; IPv4 address for mail.example.com mail2 IN A 192.0.2.4 ; IPv4 address for mail2.example.com mail3 IN A 192.0.2.5 ; IPv4 address for mail3.example.com"; var zone = DnsZoneFile.Parse(content);Alternatively your can load zone from external uri:
var zone = await DnsZoneFile.LoadAsync(uri)You can use regular ToString() method to produce zone file from DnsZoneFile object
var zone = new DnsZoneFile(); zone.Records.Add(new AResourceRecord { Name = "www.example.com", Class = "IN", Ttl = TimeSpan.FromMinutes(15), Address = IPAddress.Parse("127.0.0.1") }); zone.Records.Add(new AResourceRecord { Name = "ftp.example.com", Class = "IN", Ttl = TimeSpan.FromMinutes(15), Address = IPAddress.Parse("127.0.0.1") }); Console.Write(zone.ToString());This will generate following content:
;A records www.example.com. IN 15m A 127.0.0.1 ftp.example.com. IN 15m A 127.0.0.1 You can give a hint to the formatter which domain should be used as an origin to make output cleaner
Console.Write(zone.ToString("example.com"));This will generate following content
$ORIGIN example.com. ;A records www IN 15m A 127.0.0.1 ftp IN 15m A 127.0.0.1 RFC 1035 - Domain names - implementation and specification
RFC 1034 - Domain names - concepts and facilities
RFC 2782 - A DNS RR for specifying the location of services (DNS SRV)