Skip to content
Snippets Groups Projects

kr_ranked_rrarray*: avoid duplicate RRsets on wire

Merged Vladimír Čunát requested to merge duplicate-RR into master
All threads resolved!

Fixes https://gitlab.labs.nic.cz/knot/resolver/issues/198. We can't let multiple "matching RRsets" to the wire, and we can't just merge the sets from multiple queries either. The only way is to choose either of the sets and put it on the wire. ATM the last one wins.

Common ocurrence of the bug: if www.example.cz was a CNAME for example.cz and we ask for a non-existent type, we would get the SOA record twice in the final answer.

A few related changes:

  • don't just assert, also return error code if -DNDEBUG
  • kr_ranked_rrarray_set_wire: don't do full-content comparison anymore; see the first paragraph in this commit message for the reasons
  • minor refactoring of that code, more comments, etc.
Edited by Vladimír Čunát

Merge request reports

Pipeline #4410 canceled

Pipeline canceled for 8d79b517 on duplicate-RR

Approval is optional

Merged by avatar (Apr 3, 2025 5:08am UTC)

Merge details

Pipeline #4411 canceled

Pipeline canceled for c41d3c26 on master

Activity

Filter activity
  • Approvals
  • Assignees & reviewers
  • Comments (from bots)
  • Comments (from users)
  • Commits & branches
  • Edits
  • Labels
  • Lock status
  • Mentions
  • Merge request status
  • Tracking
  • Petr Špaček
  • Petr Špaček
  • I wonder if there is something which prevents people from sending multiple distincts RRsets in one answer. I mean: What RFC says that IN A 127.0.0.1 and IN A 192.0.2.1 must be always in a single RRset?

    I can see that things get complicated when we talk about signing, just thinking aloud...

  • @pspacek: RRs from the same answer do get merged by ranked_rrarray_add(). On wire each RR is "on its own" anyway, and we merge them even if the "set" isn't consecutive.

    The point here is that ranked_rr_array_t contains RRs from multiple packets, and it's forbidden to create such combinations.

  • Vladimír Čunát resolved all discussions

    resolved all discussions

  • Vladimír Čunát unmarked as a Work In Progress

    unmarked as a Work In Progress

  • Vladimír Čunát changed the description

    changed the description

  • added 3 commits

    • 58b7af80...4fa31008 - 2 commits from branch master
    • 8d79b517 - kr_ranked_rrarray*: avoid duplicate RRsets on wire

    Compare with previous version

  • mentioned in commit c41d3c26

  • Please register or sign in to reply
    Loading