Skip to content
This repository


Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP

Maintain a TLD on localhost for all your projects

branch: master

Merge pull request #21 from demands/aliases_in_array

Are aliases meant to be an array?
latest commit 18123e12da
Jan Lehnardt janl authored

Local TLD

Local TLD maintains a local development top level domain that you can hook various projects into.

If you know pow, this is pow without the Rack part.

Mac OS X only, for the time being. Cross platform support desired, if you can contribute it! :)

Er what?

Here’s an example. What if you maintained two web projects A and B and have a local setup of both, and you’d like to work on the both at the same time, or switch easily, and you don’t want to mess with things like http://localhost:8888 because that is just annoying and ugly.

What if you could have these two nice addresses:

Yes, you can do that by messing with /etc/hosts, but it ain’t pretty, and you have to do it for every new project and it is ugly.


$ npm -g install local-tld
  # or for now git clone $thisrepo
$ $EDITOR ~/.local-tld.json
  "8000": {
    "name": "myfancyprojectA"
  "8001": {
    "name": "thatotherprojectB"

Dat it. /.local-tld.json maps the a subdomain to a TCP port. So if you have a httpd running on localhost:8000 you can now reach it by going to

I want my app to register itself with local-tld!


Ok cool, how does it work?

This uses a cool dynamic DNS system that is built into Mac OS X. Local TLD runs a minimal DNS lookup server that does the address translation magic.

I want subdomains!

Easy. Just make your configuration look like this:

  "8000": {
    "name": "myfancyprojectA",
    "aliases": ["subdomain1", "subdomain2"]

Now, you should be able to reach localhost:8000 from,, and!

No Original Work

This is all ripped out of pow, we don’t claim any credit.


Apache 2 License


(c) 2013 Jan Lehnardt

Something went wrong with that request. Please try again.