Add support for dnsseeds with option to filter by servicebits #8083

pull jonasschnelli wants to merge 1 commits into bitcoin:master from jonasschnelli:2016/05/dnsfilter changing 3 files +18 −4
  1. jonasschnelli commented at 9:59 pm on May 21, 2016: contributor

    Opposite part of https://github.com/sipa/bitcoin-seeder/pull/36. Including new testnet seed that supports filtering.

    Required for SW #7910.

  2. jonasschnelli added the label P2P on May 21, 2016
  3. petertodd commented at 8:30 pm on May 23, 2016: contributor
    Concept ACK, but I think it’d be simpler to have this be based on a bitmask rather than service-specific letters.
  4. jonasschnelli commented at 8:36 pm on May 23, 2016: contributor
    Yes. Agreed. Will change it to a bitmask. Maybe a hex representation of the uint64_t as subdomain.
  5. TheBlueMatt commented at 11:54 pm on May 23, 2016: member
    Do we actually connect to DNS Seeds, or is it only for Tor where we connect to them, get a list of addresses, and then immediately disonnect?
  6. sipa commented at 11:56 pm on May 23, 2016: member

    When on Tor, we connect to one of the seed’s results directly, and ask it for getaddr. This does not need filtering.

    When not on Tor, we read in the list of IPs returned by the seed, and add it to addrman, without any TCP involved.

  7. jonasschnelli force-pushed on May 24, 2016
  8. jonasschnelli commented at 7:50 pm on May 24, 2016: contributor

    Updated this PR and sipa/bitcoin-seeder#36 to support non-bitflags-to-string mapping. Now, node-filtering via dnsseed is possible with a bitmap-filter-hex-string as subdomain.

    Example: dig A 5.testnet-seed.bitcoin.jonasschnelli.ch (filter = 5 == 0101) will return only nodes with NODE_NETWORK and NODE_BLOOM service flags set. dig A d.testnet-seed.bitcoin.jonasschnelli.ch (filter = d == 1101) will return only nodes with NODE_NETWORK, NODE_BLOOM and NODE_WITNESS service flags set.

    A bar main domain query will still result with the default NODE_NETWORK filter: dig A testnet-seed.bitcoin.jonasschnelli.ch

  9. petertodd commented at 8:45 pm on May 24, 2016: contributor

    RBF nodes! dig A 4000001.testnet-seed.bitcoin.jonasschnelli.ch Cool!

    Something I noticed was you could also query 0000000004000001.testnet-seed.bitcoin.jonasschnelli.ch instead - it’d probably be a good idea to fail the query if there are any leading zeros, to maximally ensure that everyone uses the same queries whenever possible - better for privacy, and a few less bytes on the wire.

  10. gmaxwell commented at 10:11 pm on May 24, 2016: contributor
    RFC 952 did not permit hostnames to begin with a number. This has since been relaxed but many implementations still manage to screw this up (treating the names that begin with numbers as IP addresses), it might be better to begin the mask with a x, and also require it to be zero extended so that caching isn’t degraded by clients using x00000005 vs x5.
  11. arowser commented at 8:43 am on May 25, 2016: contributor
    Can one of the admins verify this patch?
  12. jonasschnelli force-pushed on May 25, 2016
  13. jonasschnelli commented at 12:03 pm on May 25, 2016: contributor

    @gmaxwell: Good point. I just force pushed a change that will require a leading x for the query subdomain. dig A x5.testnet-seed.bitcoin.jonasschnelli.ch for NODE_BLOOM, etc.

    leading zeros will be ignored: dig A x0005.testnet-seed.bitcoin.jonasschnelli.ch also results in a NODE_BLOOM filter.

  14. sipa commented at 12:08 pm on May 25, 2016: member
    @jonasschnelli Better to not allow multiple encodings for the same request, as that may interfere with caching (see @gmaxwell’s comment).
  15. jonasschnelli commented at 12:22 pm on May 25, 2016: contributor
    @sipa: Good point. Update the seeder PR to ignore/reject leading zeros. Rejecting = reply with standard NODE_NETWORK filter (same behavior as before this PR). https://github.com/sipa/bitcoin-seeder/pull/36/files#diff-118fcbaaba162ba17933c7893247df3aR263
  16. sipa commented at 12:39 pm on May 25, 2016: member

    How will you pass in the required flags to addrman?

    I was imagining something simpler here, where a DNSSeedData struct just has a hostname and a servicebits value. For hosts where it is supported, we use (“x9.seeder.host.tld”, 9), for others we use (“seeder.host.tld”, 1).

  17. Add support for dnsseeds with option to filter by servicebits 2d83013dc5
  18. jonasschnelli force-pushed on May 25, 2016
  19. jonasschnelli commented at 1:00 pm on May 25, 2016: contributor

    @sipa: Right. The code is currently pretty much unused. At the moment, what we want is filter for NODE_NETWORK (which is the default). This results in not using the x.seed filter.

    However, this will be required for SW and I though instead of extending the SW PR, try to get this into master because it can be useful anyways.

    This also adds a testnet seed (last weekend only one testnet seed was running).

  20. laanwj commented at 11:21 am on May 30, 2016: member

    utACK https://github.com/bitcoin/bitcoin/pull/8083/commits/2d83013dc54320b3f0c978475517da6156f7b50d

    what we want is filter for NODE_NETWORK (which is the default)

    I think there’s something (for consistency / future-proofness) to be said for always using filtering when the seed supports this, even to just request NODE_NETWORK, instead of relying on a default being the same server-side.

    Though this would remove the flexibility for the DNS seed operator to change the default and have everyone use that by default, if that turns out to be necessary - which has been discussed in the context of segwit. So I’m not sure.

  21. laanwj commented at 12:38 pm on June 8, 2016: member
    What is there to be done here?
  22. sipa commented at 12:49 pm on June 8, 2016: member
    utACK 2d83013dc54320b3f0c978475517da6156f7b50d
  23. sipa merged this on Jun 8, 2016
  24. sipa closed this on Jun 8, 2016

  25. sipa referenced this in commit cd0c5135ab on Jun 8, 2016
  26. codablock referenced this in commit 8b50b98c5b on Sep 16, 2017
  27. codablock referenced this in commit cc9999a4e5 on Sep 19, 2017
  28. codablock referenced this in commit b3e26cc757 on Dec 22, 2017
  29. andvgal referenced this in commit b5814c2778 on Jan 6, 2019
  30. Fuzzbawls referenced this in commit a86ee0f271 on Mar 27, 2020
  31. akshaynexus referenced this in commit 63ded2112c on Mar 30, 2020
  32. MarcoFalke locked this on Sep 8, 2021

github-metadata-mirror

This is a metadata mirror of the GitHub repository bitcoin/bitcoin. This site is not affiliated with GitHub. Content is generated from a GitHub metadata backup.
generated: 2025-01-22 09:12 UTC

This site is hosted by @0xB10C
More mirrored repositories can be found on mirror.b10c.me