upvote
Very minor UX nit. Clicking "change password" in the dashboard sends an email with a reset link, but the reset page only shows up in a logged-out session.

If you're logged in, the link just redirects to the dashboard homepage. Since users will typically still be logged in when the email arrives (they just clicked the change password button from inside the dashboard), they'll need to logout first.

Either a "log out first" line in the email, or having the link end the current session before serving the reset page, would smooth this over.

reply
> because every DDNS service I tried was designed around 2010-era networks

I am not an expert in the domain of DDNS. Wanted to bring your attention to desec.io, in case you didn't knew about them. They offer a similar feature set like you mentioned (IPv6, DNSSEC, BYOD, ...). It is an open source project and they offer a very reliable free hosted service. As you said, they originated from the 2010-era (2014). I've used them for several years now and they bring everything to the table that I need.

For inspiration: They even have a feature that I use which I haven't spotted in your documentation (but maybe I just didn't looked close enough): Support for IPv6 prefix delegation. Routers that get assigned an IPv6 prefix from the ISP, can update the IPv6 prefix of arbitrary domains. In Europe this prefix is not static and rotated each time a new connection to the ISP is established. This feature allows the router to automatically update the IPv6 _prefix_ of selected domains. The host part of the IP is left untouched, but the network part is updated.

e.g.: /update?myipv6:nas.home.mydomain.tld=2003:e6:bee:affe::/56

reply
Hi, doing on mobile so short answer. To my knowledge they don't do RFC 2146 but rather base everything around a good api that they have. Like you say different types of records etc.

And really, dynip came to be from fortinet/fortigate that have excellent support via their genericDDNS setup and things keep of of grew from there to what you see today.

And the subnet ipv6 sounds really interesting. Will need to check that out, sounds like that could be a feature request

reply
i can vouch for desec.io for having the option to have TXT, NS, CNAME, etc dns entries on their free tier! (limited to 1 domain, up to 50 entries)

i really had a bad time trying to get a letsencrypt certificate through the regular auth because it does require ports 80 and 443 tcp that by ISP blocks.

(you can get a letsencrypt cert through a TXT entry too, but most free DDNS´s providers dont seem to offer that)

reply
Dynip.dev solves with dns challenge and you can download the full chain and key either via api or the dashboard. Check /docs
reply
FYI: Site does not work in firefox focus (android) unless i turn off tracking protection (which is default on).

Which was a bit confusing when I clicked the confirm-your-email link. No confirmation or status or anything.

reply
Thanks, I will put it on my issues list to look into.
reply
Trying to set it up with HOVER as a registrar - I get:

Nameserver [ns1.dynip.dev] doesn't exist at the registry (Code 480)

reply
Interesting, will do some digging on what sets them apart from the x amount of byod already precent. Thanks for letting me know!
reply
It has to do with the .dev root zone that needs to have these as records, I am on it but it might take a few days to get those records up. Or it could be fast. Glad that you reported and I will report back when we expect it to work
reply
thanks. shoot me an email ry@walledcity.org if you need a test subject
reply
For sure!
reply
Do you mind supporting L402 so that agents can potentially purchase the service?
reply
Wow, that sounds like a great idea. I wanted it to be easy with the paddle integration but even that was a pain. Will look into it for sure, thanks!
reply
you can scan your site with cloudflares tool https://isitagentready.com/ for all that new agent / web mcp type of goodness. love your service btw. I think im going to make the swap. there is one domain that I rely on for ddns and the service I use, while reliable, just really sucks for reasons you have already outlined
reply
How do the geo distributed secondaries work? How do they sync?

Also, is there anycasting?

reply
The geo sync updates are handled with distributed keys over internal api, here is the documentation for powerdns around it: https://doc.powerdns.com/authoritative/dnsupdate.html#dnsupd... so the updates are pushed and updated to primaries if the update is done over DNS and if done via API there is a normal replication function.

right now there is no anycast available, possible in the future

reply
Thanks for the answer. I use DB replicas (so all dns servers have a common backend), but only one accepts writes.

I still can not figure out any economical way to roll out anycast.

reply
Thanks for sharing!

How did you set up PowerDNS? Single/multiple instances? One DB shared by many or multiple authoritative with one hidden primary?

reply
There are multiple multiples :) both (hidden) primary and secondaries are multiple, snapshots every 20 minutes and forward-update functionality from the secondaries with replicated tsig over powerdns api every 120 seconds. since they are static they only need to replicate once.

if you register a zone and open the snippets quickly, there is a green notification saying tsig replication underway for x amount of seconds and until that happens RFC 2136 updates are not possible but the ones that use api are available right off the bat.

reply
Really cool stuff. Out of curiosity what made you select PowerDNS (and in general a commodity DNS server) vs. developing a custom DNS server integrating your logic (using https://github.com/miekg/dns for instance).
reply
Cool! How did you scale-out the hidden primary? Multiple instances communicating with a single postgres?
reply
The hidden primary has a passive node, so saying multiple multiple maybe is an overstatement :) and yes, using a single postgres container
reply
Well done. Would be nice to remove a bit more five eyes tracking from your stack, e.g. remove includes from 3rd party domains such as unpkg / tailwindcss.com and of course get rid of cloudflare.
reply
Yes, I have been thinking about that as well and have unpkg / tailwindcss.com in the backlog. good point, appreciated. Cloudflare is a bigger backlog item because of the current infrastructure build.
reply
Its unfortunate you didn't go for a EU-native stack right away. Bunny.net offers similar compute/serverless on the edge, close to Cloudflares offerings.
reply
Something to look into for sure. thnks
reply
> we accept RFC 1918 and CGNAT addresses in records

Doesn't that cause security issues by making it possible to put other people's private servers (that you want to do XSS-type attacks against) into your domains or something? I have a vague memory of it being a security no-no somehow.

reply
There are a few things to think about yes, I actually post in the fleet guide parts of it that it should be considered before posting. the dns rebind issue but that should be controlled by host header validation, CSRF, same-site cookies etc. Internal topology disclosure — real. but we dont post it. You can do the same in Cloudflare for example.
reply
Basically any DNS provider allows this (plus anybody can buy a domain and run their own DNS server).

The defense against this has to happen either on the resource you want to protect or in the browser.

reply
Skål! Looks like a huge effort-reliever, excited to try it out.
reply
Skål!
reply
Even if you've otherwise put in a lot of effort, presenting it with slop on the home page really sends a bad signal. My eye caught "No proprietary clients. No vendor lock-in." as an AI pattern and I'm immediately drawn to wonder whether the service will still be around even just a few weeks from now.
reply
Thanks for that, My intentions are to stick around for sure. It is genuinely difficult to get a point across in a very short amount of time that people that people will actually recognize. its like doom scrolling where you just get boored of it. Happy to take suggestions.

< is there anything else you would like me to answer or is that good enough - GenericAI answer>

But jokes aside, words are difficult and also not my first language

reply
I don't think any value would be lost in that case by simply deleting the text and not replacing it with anything. AI is particularly bad at inserting this kind of filler, it can sometimes be really hard to spot even though it's right in front of your eyes.

Just more hidden cost of AI.. it's sufficiently hard to avoid these kinds of structural smells that I've gone back to just writing my own copy everywhere.

reply
I also write my own copy. (You're absolutely right!) But this trend on HN of calling out everything as AI slop is a bit tiring.
reply
Reading so much of it on HN is presumably equally as tiring.
reply
I think the problem is that half the time the callouts are incorrect (edgelords trying to be clever) or irrelevant (non-native speakers using AI to translate or clarify).
reply
Sustained pushback helps define how the tool is used, and if it only takes a few years of complaints to permanently establish good social norms around it, I think we're better for it. At least, I much prefer this than a world where everyone is too polite to complain about slop until slop is all that is left..
reply
I agree. However, it's gotten so bad that people are calling out AI slop on things they just don't care for — or mistake human writing for AI — which paradoxically becomes its own red flag to ignore the comment, even if there are valid points within.

I just used the em dash twice, and have been doing so for 35 years. This is now supposedly a dead give-away for slop.

Call it slop when it's slop. When it's not total garbage, give it a rest.

reply
[dead]
reply
My first impression was "oh no, not another generic, vibe-coded service clone". But this is actually really good stuff under hood, and it's clearly coming from someone who has a deep understanding of networking.

Nice work, good luck.

reply
I mean, the comment you are replying to is absolutely AI-generated; I wouldn't say being able to prompt that is any direct evidence of deep understanding of networking.

The website is also vibecoded; at least partially - it has the exact same design choices like that purpleish blue colour scheme that Claude likes to spit out by default.

reply
Thanks, appreciate it!
reply
[dead]
reply