localhosedeprecated

Hose your hosts file for easier local web development

Usage no npm install needed!

<script type="module">
  import localhose from 'https://cdn.skypack.dev/localhose';
</script>

README

Localhose

Localhose is a node.js module that provides a simple API for dynamically adding hosts to the /etc/hosts file, to fool your web browser into thinking anydomain.com points to your local machine. This makes web development easier, since the local build and production build can now use identical URLs.

WARNING: This software requires superuser access, and will temporarily overwrite your hosts file. If you do not understand what that means, it's probably not a good tool for you.

Requirements

  • node.js, tested with 0.4.1
  • OS X, version 10.5 or later (soon, any OS with a hosts file)
  • superuser access to your machine

Install

$ npm install localhose

Module API

localhose = require( "localhose" )

Returns a global localhose object that keeps track of what domains are being rerouted.

localhose.set( host1, [host2], [etc] )

Adds one or more hosts to be routed to your local machine. The hosts are stored within the existing hosts file, like this:

# <localhose>
# The following have been added temporarily by Localhose
# For more information, see https://github.com/jed/localhose
127.0.0.1	yourdomain.com
127.0.0.1	yourdomain.net
# </localhose>

The path of the host file can be specified using the hostsPath property of the localhose.constructor.prototype object.

localhose.unset( [host1], [host2], [etc] )

Removes some or all of the hosts rerouted to your machine. If no arguments are specified, all currently hosts are unset. If no hosts remain after this is called, the # <localhose> ... # </localhose> section of the current hosts file is removed, leaving your file system as pristine as it was before.

localhose.domains()

Returns a list of domains currently being rerouted to 127.0.0.1

Command-line API

$ sudo localhose set host1 [host2] [etc]

Same as localhose.set, but for the command line.

$ sudo localhose unset [host1] [host2] [etc]

Same as localhose.unset, but for the command line.

Example

For an example rerouting nodejs.org to your machine, see test.js. Otherwise, usage is basically like this:

// sudo node ./someFile.js
localhose = require( "localhose" )

// resolve "google.com" and "google.org" to 127.0.0.1.
// note that you will be unable to use google while this is set.
localhose.set( "google.com", "google.org" )

localhose.domains() // [ "google.com", "google.org" ]

// remove all domains, and revert the `hosts` file to its original state
localhose.unset( "google.com" )

TODO

  • Add support for non-OS X systems if anyone's interested.

Copyright

Copyright (c) 2011 Jed Schmidt. See LICENSE.txt for details.

Send any questions or comments here.