Skip to content

Conversation

@vanyasem
Copy link

@vanyasem vanyasem commented Jul 26, 2024

Motivation

The problem is reproducible on macOS/iOS/iPadOS with the dnssd backend.
Fixes #43 - more info there
Quoting https://kb.isc.org/docs/aa-00356: per RFC 4408 a TXT or SPF record is allowed to contain multiple strings, which should be concatenated together by the reading application
Currently concatenated TXT records are parsed incorrectly, leaving a reserved byte intended to indicate the length of the following content as part of the record's text.
Related: https://stackoverflow.com/questions/17330816/objective-c-dns-txt-record#comment25143465_17331454

Modifications

Implemented using readName method that reads the buffer's contents based on specified length.

Result

Concatenated TXT records are parsed correctly.

Test Plan

You can test the behaviour by creating a concatenated TXT entry (which would usually imply having a huge TXT entry), and observe a garbage byte appearing after 255th character

You can test the fix by querying the same TXT entry with the code from this PR, which would produce a correct result regardless of the TXT record's size / concatenation

Copy link

@Lukasa Lukasa left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This looks like a nice fix, thanks!

@Lukasa
Copy link

Lukasa commented Jul 26, 2024

@swift-server-bot test this please

@Lukasa
Copy link

Lukasa commented Jul 26, 2024

@ktoso I think I need you to approve this one

@PeterAdams-A
Copy link
Contributor

@swift-server-bot test this please

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

dnssd: Garbage characters in concatenated TXT records

3 participants