Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Thanks a lot! #16

Open
delneg opened this issue Aug 13, 2021 · 8 comments
Open

Thanks a lot! #16

delneg opened this issue Aug 13, 2021 · 8 comments

Comments

@delneg
Copy link

delneg commented Aug 13, 2021

Thanks a lot, with the help of you project I've been able (after some trial & error) to write my own DNS server implementation - altough I've decided to do it in C# (because that's what I'm learning right now) and not in Rust (also, copy-paste Rust code seemed too easy).
You can check it out at https://github.com/delneg/dns_server_csharp
There are also branches for each chapter, if you're interested

@EmilHernvall
Copy link
Owner

Glad you found it useful. Looks like a nice project, so well done. :) I'll consider adding a section for ports to other languages, and link to it.

@Schachte
Copy link
Contributor

@EmilHernvall Really enjoying this guide, it's been a lot of fun. Any plans for others like this?

@EmilHernvall
Copy link
Owner

Maybe. :) There are some other protocols that I'd like to try, like DHCP and SMTP, but not sure when I'll get to that.

@Schachte
Copy link
Contributor

Ooo SMTP would be great fun!

@exFalso
Copy link

exFalso commented Nov 15, 2023

Adding my thanks, this guide was extremely helpful in implementing a custom dns server. I particularly liked the progressive breakdown

@notthatjesus
Copy link

Just adding my thanks for this!
Started going through it, trying to build an ENUM (NAPTR records) server for Telephony purposes. This is being extremely helpful

Just a qq... I can see in the DnsHeader struct a boolean field called "checking_disabled" but I can't find anything in the RFC or the packet itself about it. What's its purpose?

@machsix
Copy link

machsix commented Dec 26, 2024

Just adding my thanks for this! It's educational and informative.

@v-tyan
Copy link

v-tyan commented Jan 4, 2025

@notthatjesus
> Just a qq... I can see in the DnsHeader struct a boolean field called "checking_disabled" but I can't find anything in the RFC or the packet itself about it. What's its purpose?

There were three reserved bits (Z) as per RFC 1035 originally. But, as mentioned in the guide, later on they were used for DNS Security Extensions (DNSSEC)
Thats where two new bits were added in plase of reserved ones, AD (authentic data) and CD (checking disabled).
You can check the new Header Structure in the RFC 2065 section-6.1

It seems that the author of the DNS guide implemented the new DNSSEC Header structure, but new bits were out of scope of the project and were never used.

P.S. i was confused too about those fields and only found your unanswered question.
Leaving this comment in case this might clear up someone elses doubts :)

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

No branches or pull requests

7 participants