zoneparser

Crates.iozoneparser
lib.rszoneparser
version0.1.4
sourcesrc
created_at2024-09-06 06:21:39.187173
updated_at2024-11-14 06:44:28.090421
descriptionA fast zonefile parser
homepage
repositoryhttps://github.com/erikoest/zoneparser
max_upload_size
id1365578
size41,676
Erik Pihl Østlyngen (erikoest)

documentation

README

ZoneParser: A zonefile parser with good performance

The ZoneParser is a DNS zonefile parser. It has been designed to have a good performance with regards to cpu and memory consumption. It works well with large zonefiles. The code is in an early stage of development and still has a somewhat limited functionality.

Usage

The parser is constructed with a file as input. It then works as an iterator yielding the resource records of the zone. An example:

use zoneparser::ZoneParser;

fn main() {
  let file = File::open("my-zone.no").unwrap();
  let p = ZoneParser::new(&file);

  for rr in p {
    println!("{}", rr);
  }
}

For further examples, see the included command line tools zonecount and zonediff.

Bugs

  • Escaped characters and octal number representations in the zonefile are not well handled.

Missing features

  • Error handling is rather crude. Parse errors cause panic. Quoted strings are somewhat poorly handled, esp. with escaped content.
  • Only the common record fields are parsed. Content specific to the record types are returned as anonymous data fields. A later version might support parsing the data content as a secondary function call.
  • Relative names are not converted to absolute ones.

Contributing

The limited functionality very much reflects the needs I had when I wrote the library. If you find it useful, and miss some functionality, please let me know. It might motivate me to further development. Bug reports are always welcome.

Commit count: 20

cargo fmt