Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
procd: make mDNS TXT record parsing more solid
mDNS broadcast can't accept empty TXT record and would fail registration. Current procd_add_mdns_service checks only if the first passed arg is empty but don't make any verification on the other args permittins insertion of empty values in TXT record. Example: procd_add_mdns "blah" \ "tcp" "50" \ "1" \ "" \ "3" Produce: { "blah_50": { "service": "_blah._tcp.local", "port": 50, "txt": [ "1", "", "3" ] } } The middle empty TXT record should never be included as it's empty. This can happen with scripts that make fragile parsing and include variables even if they are empty. Prevent this and make the TXT record more solid by checking every provided TXT record and include only the non-empty ones. The fixed JSON is the following: { "blah_50": { "service": "_blah._tcp.local", "port": 50, "txt": [ "1", "3" ] } } Fixes: b0d9dcf ("procd: update to latest git HEAD") Reported-by: Paul Donald <newtwen@gmail.com> Link: openwrt/openwrt#15331 Signed-off-by: Christian Marangi <ansuelsmth@gmail.com> (cherry picked from commit 4b04304)
- Loading branch information