Package Exports
- is-online
- is-online/browser
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (is-online) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
is-online 
Check if the internet connection is up
Works in Node.js, CLI and the browser (with browserify).
In the browser you have navigator.onLine
, but it's useless as it only tells you if there's a local connection, and not whether the internet is accessible.
Install
$ npm install --save is-online
Usage
var isOnline = require('is-online');
isOnline(function(err, online) {
console.log(online);
//=> true
});
Node API
isOnline(callback)
callback(error, online)
Required
Type: function
error
is there only by Node.js convention and is always null
.
Browser API
isOnline(callback)
callback(online)
Required
Type: function
CLI

$ npm install --global is-online
$ is-online --help
Example
is-online
✔︎ Online
How it works
In node, we first contact one of the thirteen root servers and ask them to direct us to the servers which host the .com
zone. If they answer us, we return an online status, if no answer is given within one second, we return an offline status. In the rare case where an firewall intercepts the packet and answers it on its behalf, a second check is run which tries to connect to a series of popular web sites on port 80. If one of these connects, we return online, otherwise offline status.
In the browser, a sophisticated check like in node is not possible because DNS and sockets are abstracted away. We use a check which requests an uncached favicon.ico
on a series of popular websites. If one of this checks succeeds, we return online status. If all the requests fail, we return offline status.
Contributors
License
MIT © Sindre Sorhus