Namecheap dynamic dns Not Updating
-
It may be due to how the update URL gets formed when using the "@" record.
Can you try this with an actual hostname under the domain rather than the @ record?
That's not possible with the domain in question.ย I could try adding one, but I can't until tonight.
(and ultimately it IS the @ record that needs to be updated, so even if this is the issue, I need it to work for the @ records.) -
Yes, I understand that, I'm just trying to make sure it's not a problem with your account in general, but one specific to the @ record handling.
I don't have a free @ record handy that I can tinker with at the moment, but I can try to free one up. All my Namecheap dyndns entries are traditional host.domain.tld format, no @ records.
-
Yes, I understand that, I'm just trying to make sure it's not a problem with your account in general, but one specific to the @ record handling.
I don't have a free @ record handy that I can tinker with at the moment, but I can try to free one up. All my Namecheap dyndns entries are traditional host.domain.tld format, no @ records.
I'll see if I can make an additional one during my lunch.
-
I was able to free up an @ on one of my domains for testing, and it worked for me. No errors, and the @ record updated as expected.
I used the @.domain.tld format and it updated as expected using the dyndns access key for the domain.
Maybe try to re-enable DynDNS for your domain and then use the new auth token they generate when it resets.
-
Oh, and that was on a 2.1 snapshot from Thursday.
-
Oh, and that was on a 2.1 snapshot from Thursday.
I'm not on a snapshot.ย I'm using the latest stable.
-
I pulled up a 2.0.3 VM and tried it there, worked the same, no problems. I even edited the IP in Namecheap's control panel to something bogus, then removed the cached IP from the pfSense VM and made it update again, worked fine.
-
I pulled up a 2.0.3 VM and tried it there, worked the same, no problems. I even edited the IP in Namecheap's control panel to something bogus, then removed the cached IP from the pfSense VM and made it update again, worked fine.
Does it work if the domain is one deeper, @.sub.domain.com?
(Also, how can I force it to update for testing)
(And you're leaving the username blank, right?) -
Username blank, yes.
You can force an update by removing the cache file from /conf and then saving on the page.
A subdomain is not considered an @ record in their DNS that I'm aware of. It would just be sub.domain.com where sub is just a hostname in that context.
IIRC their DNS does not split that into separate "true" zones that would contain an @ record.
-
Username blank, yes.
You can force an update by removing the cache file from /conf and then saving on the page.
A subdomain is not considered an @ record in their DNS that I'm aware of. It would just be sub.domain.com where sub is just a hostname in that context.
IIRC their DNS does not split that into separate "true" zones that would contain an @ record.
sub.domain.com is what is pointed to namecheap. ย domain.com is pointed elsewhere.
I need to update @.sub.domain.com for it to accept it.(I know this setup works as I came from a WRT54GL with Tomato firmware that had no issue updating)
-
OK. It's possible that their dyndns API has a problem with that particular setup then. I don't have anything even close to that setup to test.
I'd need to see the exact update URL used by tomato to know what might fix it.
-
OK. It's possible that their dyndns API has a problem with that particular setup then. I don't have anything even close to that setup to test.
I'd need to see the exact update URL used by tomato to know what might fix it.
// +opt +opt +opt sprintf(query, "/update?host=%s&domain=%s&password=%s", get_option_required("host"), get_option("user") ? : get_option_required("domain"), get_option_required("pass")); // +opt append_addr_option(query, "&ip=%s");
I took this from Tomato's source.
I'm not well versed in coding, but I'm pretty sure that's where it updates to.
so in my case, it would look like:update?host=@&domain=sub.domain.com&password=somethingcomplicated
-
I think I see where the problem might be, in our code, it assumes for .com (and most others) that the domain part is only domain.tld, so it's probably splitting that into @.sub for the host and domain.com for the domain.
Not sure if there will be any easy way around that, I'll have to dig at it a little.
-
I think I see where the problem might be, in our code, it assumes for .com (and most others) that the domain part is only domain.tld, so it's probably splitting that into @.sub for the host and domain.com for the domain.
Not sure if there will be any easy way around that, I'll have to dig at it a little.
That implementation looks like it could cause problems with many country tlds such as ".co.uk" or similar as "@.sub.domain.com" has the same separations as "@.domain.co.uk"
-
No, there is code specifically to handle domain.co.uk, there is a list in the client that knows how many levels deep TLDs go and sets exceptions based on the TLDs offered by Namecheap.
Might have to hack it so if you put in @ for the username and the actual sub.domain.com for the hostname then it would do the right thingโฆ might be a bit before I'd have a chance to take a crack at it, I haven't touched the dyndns code in a while, it's not terribly complex though.
-
No, there is code specifically to handle domain.co.uk, there is a list in the client that knows how many levels deep TLDs go and sets exceptions based on the TLDs offered by Namecheap.
Might have to hack it so if you put in @ for the username and the actual sub.domain.com for the hostname then it would do the right thingโฆ might be a bit before I'd have a chance to take a crack at it, I haven't touched the dyndns code in a while, it's not terribly complex though.
Since the "@" and the no username part only exists for namecheap, I can't imagine it being too difficult to do that with an if statement in general.
Other than the program the other person linked earlier, is there any interim solution I can do in the mean time?Is curl or wget installed by default?ย If so I imagine I could temporarily install the cron package and do it that way.
-
"fetch" is there, curl may or may not be there depending on the packages you have installed.
fetch is capable of grabbing/hitting a page, e.g.:
fetch -o /dev/null http://blah.blah/blah
That would make a page request and ignore the result.
-
"fetch" is there, curl may or may not be there depending on the packages you have installed.
fetch is capable of grabbing/hitting a page, e.g.:
fetch -o /dev/null http://blah.blah/blah
That would make a page request and ignore the result.
This look good (as I'm not quite familiar with fetch)
/usr/bin/nice -n20 fetch -o /dev/null https://dynamicdns.park-your-domain.com/update?host=@&domain=sub.domain.com&password=<password></password>
-
Be sure to enclose the URL in quotes, but otherwise, yeah I think it looks OK.
-
I have same issue. At one point I was able to update domain.net with @.domain.net under hostname but not subdomain.domain.net
Now nothing's updating. IP ADDRESS never updates and stays at 127.0.0.1 . I deleted multiple times everything. Chatted with support but their response is to use different client or manually update ip, how will I know if it will work once IP changes??My goal was to have unused domain for dynamic DNS.
My register is still godaddy.
If someone has it working with other service please share. I would be willing to transfer my domain there for about 10-15 per year.Here's some screenshots:
http://i.imgur.com/3mcVlNw.png
http://i.imgur.com/72hO7Li.png
http://i.imgur.com/KjLJeyh.png
http://i.imgur.com/Hwtf55P.png