Skip to content

Latest commit

 

History

History
389 lines (247 loc) · 13.8 KB

File metadata and controls

389 lines (247 loc) · 13.8 KB

Changelog

All notable changes to this project will be documented in this file.

The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.

main

v10.5.2

Changed

  • Export get_pipeline/0,1 from erldns_pipeline

v10.5.1

Changed

  • Zone loading from zonefiles: records from dns_zone:parse_file/1 now load successfully.

v10.5.0

Added

  • Telemetry events to zone creation and deletion #344

Fixed

  • Record counters are correctly garbage collected #344

v10.4.4

Fixed

  • Fixes wrong zone reuse and a case_clause error when the delegated zone differed from the caller's zone #341
  • When following delegation chains, resolve_authoritative/7 keeps track of a recursion depth and stops after 32 steps with a SERVFAIL, preventing infinite loops #342
  • Simplify restart query operations on CNAME delegations #343

v10.4.3

Fixed

  • Upgrade dns_erlang

v10.4.2

Fixed

  • erldns_zone_cache:delete_zone_rrset/5 correctly returns ok | zone_not_found

v10.4.1

Fixed

  • Ensure records are normalised as FQDN when using the sync counter zone cache functionality

v10.4.0

Added

  • Zone cache: pre-reversed labels (used on every lookup), zone_name_existence and one-shot resolved lookups (#333)
  • Helper boolean filters for common record types (#332)
  • Error logging on request timeout (#332)
  • Log ingress and current timestamps when dropping a packet (#332)
  • Richer context on query timeouts (what query actually timed out) (#332)

Fixed

  • Zone cache and resolver: reworked for performance and correctness; fewer redundant computations at runtime (#333)
  • Optimised erldns_dnssec and erldns_resolver pipes (#333)
  • Logging and observability: connection idle timeout at debug level; TCP socket errors and ingress timeouts at notice/info; skip logging TCP killed when we killed it ourselves; use log_metadata helper; clearer TCP worker log naming (#332)
  • Resolver: tiny list processing improvement; async cancel timers for timers (#332)
  • Upgraded dns_erlang dependency with DNSSEC ECDSA fixes

v10.3.0

Added

  • Allow to use binary strings to specify listener IP
  • Allow to use binary strings to specify zones path

v10.2.1

Fixed

  • Updated changelog

v10.2.0

Added

  • Pipeline suspension for non-blocking async operations: pipes can return {suspend, Msg, Opts, AsyncFun} to run blocking work in a bounded worker pool so listener workers are not blocked (#327)

v10.1.1

Fixed

  • Upgraded dns_erlang, which fixes a series of bugs regarding SVCB params (#329)

v10.1.0

Added

  • Redesigned RFC compliant codecs for the Admin API (#325)

Fixed

  • Fixed spurious trailing dots in the admin API (#325)
  • Fixed badly formatted TXT records in the admin API (#325)

v10.0.0

Added

  • Better overload management (#301 #302 #306)
  • RFC7766 pipelining support for TCP/TLS with concurrent request processing (#300)
  • DNS over TLS (DoT) support per RFC 7858 (#300)
  • Configurable request timeout monitoring for TCP workers with SERVFAIL responses (#300)
  • Codec support for SVCB and HTTPS record types (#313)
  • Codec support for many new record types introduced in dns_erlang v4.9.0 (#312):
    • OPENPGPKEY (Type 61) — RFC 7929
    • SMIMEA (Type 53) — RFC 8162
    • URI (Type 256) — RFC 7553
    • WALLET (Type 262) — IANA Registration
    • EUI48 (Type 108) and EUI64 (Type 109) — RFC 7043
    • CSYNC (Type 62) — RFC 7477
    • DSYNC (Type 66) — RFC 9859
  • Add initial documentation regarding the Admin API (#316)

Changed

  • Move TCP and UDP ingress timeout configuration to per-listener opts map (#300)
  • Rename transport type both to standard for clarity (#300)
  • Upgrade dns_erlang dependency
    • Includes small performance optimisations
    • Adds support for many new record types
    • Adds dns:decode_query/1 for early stop of bad input

Removed

  • rfc_compliant_ent configuration option. RFC 4592 compliant empty non-terminal (ENT) handling is now always enabled (#308)
  • Global ingress_tcp_request_timeout and ingress_udp_request_timeout application environment variables are now configured per listener (#300)

v9.1.0

Added

  • Implement basic RFC8914 extended errors (#290)
  • Add support for standard DNS zone files (RFC-style) in addition to JSON format, this also improves loading times and initialisation (#291)
  • Admin API now adds extensibility points to include custom HTTP handlers and TLS configuration (#294)

Updated

  • Update root hints with current values and IPv6 records (#292)
  • Update dependencies (#299)

v9.0.0

Added

  • Add support for RFC6605: ECDSA for DNSSEC.
  • Add support for RFC8080: Ed22519/Ed448 for DNSSEC.
  • Add support for RFC9077: NSEC/NSEC3 TTLs.

Changed

  • Logic for handling DS type queries is changed to be RFC compliant, see: #285.

Removed

  • Support for encoding/decoding records of type SPF.

Fixed

  • Implement ENTs compliant with RFC4592

v8.1.0

Changed

  • Add ENT support for wildcard synthesis meeting RFC 4592 specification requirements (#279). The behaviour is currently opt-in using the rfc_compliant_ent option in erdns.zones config.

v8.0.0

This release has many optimisations, documentation and code quality improvements.

Changed

  • Rework erldns_zone_cache and erldns_resolver: algorithm is extensively optimised and now supports ENT correctly.
  • Rework erldns_handler: behaviour is now improved and clearly defined. Minimum supported handler version is now 2.
  • Split erldns_resolver pipe into more granular steps, adding erldns_resolver_recursive, erldns_dnssec, erldns_sorter, and erldns_section_counter.
  • Add erldns_questions questions filter to the packet pipeline.
  • Update dns_erlang to v4.3 and remove erldns_records:name_type/1.
  • Accept no SOA record if no RRSIG are required.
  • Documentation improvements (#267)
  • Separate edns payload size over UDP as a configurable pipe (#267)
  • Extend pipelines with halt and secondary pipelines (#268)

Added

  • [erldns, pipeline, questions] telemetry event with #{count => non_neg_integer()} where count is the number of questions removed.
  • Document some design decisions (#265)
  • Add TLSA record support (#270)

Deprecated

Fixed

  • Stop overwriting SOA RRSIG TTLs (#264)
  • Fix bug with SOA records not updating correctly (#266)

v7.0.0

This is a big release full of massive performance improvements and protocol compliance, but also of breaking changes. Read carefully the changelog and the documentation before migrating.

Changed

The application is now divided in three core subsystems, that is, listeners, packet pipelines, and zones, which are configured differently and will require migration. See m:erldns_listeners. m:erldns_pipeline and m:erldns_zones respectively for documentation on how to reconfigure.

Telemetry events, as well as logger events, are entirely scoped within these respective subsystems, that means, that the events are now prefixed with [erldns, request, _], for listener workers, and [erldns, pipeline] for pipeline processing. Similarly, logger events are tagged with domain => [erldns, admin | listeners | pipeline | zones] metadata, and all are structured.

Custom parsers and encoders

If you had any custom parser or encoder, you will need to update them to the new API, which unifies both into a single module. See m:erldns_zone_codec for more information on its callbacks. Note that the zone_to_erlang/1,2 callbacks are now decode/1 and zone_*/x callbacks are now encode/2, and they all take only maps as input and output respectively.

TXT and SPF record formats

TXT and SPF record formats have changed, from a single string, to an array, to support more complex DNS records & use cases, so that the following:

{
  ...
  "type": "TXT",
  "data": {
    "txt": "\"Hi, this is some text\" \"with extras\""
  }
},

becomes

{
  ...
  "type": "TXT",
  "data": {
    "txts": ["Hi, this is some text", "with extras"]
  }
},

A warning will be logged for each invalid record, but they will be skipped, and not loaded.

For more important changes, see:

  • Refactor the query processing pipeline #224
  • Reimplement the network stack #225
  • Rework zones loader #230
  • Rework zones codecs #231
  • Rework zones cache #232
  • Rework documentation and internals #233
  • Fix overriding packet size in optrr record #242
  • Upgrade dns_erlang to v4.
  • Use segmented_cache for the zone cache and the throttle modules.

Added

  • Support for OTP28 #220
  • Support for dns_erlang v4, which enforces strings as binaries and options as maps
  • Introduce domain tag in logger events #244
  • zone cache put_rrset_zone accepts zone records #243
  • Add statistic functionality to listeners #227

Removed

  • Support for TXT and SPF records with data as a single string, they must be a list of strings instead.
  • Support for the erldns_txt parser #248
  • Support for zone parsers taking input as lists #231

Fixed

  • Fix DNSSEC timestamps #234
  • Fix (C)DNS/(C)DNSKEY signing #235
  • Fix cache non-normalised match bug #241

Security

  • Introduce backpressure and load shedding #240

6.0.2

  • Add mailbox length telemetry events.
  • Keep the handlers state in an ets table and avoid the singleton gen_server call.

6.0.1

  • Add terminating context to telemetry span events

6.0.0

  • Instrument code using telemetry in a metrics agnostic way.

5.0.0

  • Introduce support for Logger
  • Remove lager
  • Remove the erldns_events singleton.

4.3.1

  • Export dnssec internal new API endpoint

4.3.0

  • Add support for NSEC compact denial of existence

4.2.4

  • Add support for zone records directory loading
  • Add the latest dnstest version fixing almost all tests

4.2.3

  • Update dns_erlang: fix EDNS0 compliance for truncated records and unsupported versions

4.2.2

  • Test admin API and fix bugs related to authentication and json encoding

4.2.1

  • Ensure supervision tree starts correctly

4.2.0

  • Merge admin and metrics APIs into this repository.

4.1.2

  • Hide SPF/TXT multipart handling behind a feature flag
  • Fix a bug mixing SPF and TXT records

4.1.1

  • Bugfix handling null in the zone parser json payloads

4.1.0

  • Introduce SPF/TXT multipart handling (#150)

4.0.0

  • Add ex_doc support
  • Remove support for OpenTelemetry.

3.0.0

Changed

Added

  • erlfmt
  • CONTRIBUTING.md
  • CHANGELOG.md
  • release process to hex.pm

2.2.0

  • ...