Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hqarroum/is-online-emitter
:zap: Receive events about gain and loss of Internet connectivity.
https://github.com/hqarroum/is-online-emitter
connectivity detect event internet internet-connection nodejs online reachability
Last synced: 3 days ago
JSON representation
:zap: Receive events about gain and loss of Internet connectivity.
- Host: GitHub
- URL: https://github.com/hqarroum/is-online-emitter
- Owner: HQarroum
- License: mit
- Created: 2020-03-06T15:27:05.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2024-09-24T10:19:26.000Z (3 months ago)
- Last Synced: 2024-12-25T16:40:31.654Z (10 days ago)
- Topics: connectivity, detect, event, internet, internet-connection, nodejs, online, reachability
- Language: JavaScript
- Size: 384 KB
- Stars: 7
- Watchers: 4
- Forks: 1
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# is-online-emitter
> Emitter interface for gain and loss of Internet connectivity.[![Build Status](https://travis-ci.org/HQarroum/is-online-emitter.svg?branch=master)](https://travis-ci.org/HQarroum/is-online-emitter)
[![CodeFactor](https://www.codefactor.io/repository/github/hqarroum/is-online-emitter/badge)](https://www.codefactor.io/repository/github/hqarroum/is-online-emitter)Current version: **3.0.0**
## 📋 Table of contents
- [Installation](#-install)
- [Features](#-features)
- [Description](#-description)
- [Usage](#-usage)
- [See also](#-see-also)## 🚀 Install
```bash
npm install is-online-emitter --save
```## 🔖 Features
- Monitors Internet connectivity and notifies you of connectivity changes.
- Monitors for changes on network interfaces to automatically trigger connectivity checks.
- Uses fibonacci back-off to periodically check for Internet connectivity.
- Supports Internet connectivity checks using a HTTP(S) proxy.## 🔰 Description
This library enables developers and system administrators to be alerted upon connectivity changes to the public Internet. This can be useful if your applications is connectivity sensitive and needs to be alerted as soon as possible of a loss/gain of Internet connectivity. To do so, the `IsOnlineEmitter` class provided by this library implements an `EventEmitter` interface dedicated to the event delivery.
This project is based on the [`is-online`](https://github.com/sindresorhus/is-online) library and adds an event interface on top of it in order to asynchronously notify your applications of gain and loss of Internet connectivity.
> Note that it can take up to 10 seconds with the default parameters to receive a notification about an Internet connectivity change once it has effectively changed.
## 🛠Usage
In order to use this library you need to instantiate it, subscribe to the events you are interested in and start the connectivity montoring.
```js
import IsOnlineEmitter from 'is-online-emitter';// Creating a new instance of the emitter.
const emitter = new IsOnlineEmitter({});
// Listening to `connectivity.change` events.
emitter.on('connectivity.change', console.log);
// Starting the connectivity monitoring.
emitter.start();
```> See the [`examples`](./examples) directory for more information on how to use the library.
### Configuration
Different configuration variables can be passed to this library when instanciating it in order to customize its behavior. Below is a list of the defined variables associated with their description.
Variable | Type | Description
-------- | ---- | -----------
`backOffInitialDelay` | Number | The initial delay, in milliseconds, used by the used back-off strategy to trigger connectivity checks.
`backOffMaxDelay` | Number | The maximum delay, in milliseconds, used by the used back-off strategy to trigger connectivity checks.
`connectionTimeout` | Number | The connection timeout, in milliseconds, used when issuing requests to external services during the connectivity check.### Events
Different events are emitted by the `IsOnlineEmitter` class which are described below.
Event | Description
------------------------------ | -----------
`connectivity.change` | A change of state in Internet connectivity has been detected. Note that this event will be initially fired when you call the `.start()` method of the emitter.
`network.interface.change` | A change of state in the network interfaces of the host has been detected. The payload associated with this event provides details on the state change.
`connectivity.check.scheduled` | Fired when a connectivity check is being scheduled by the fibonacci back-off mechanism. The delay before the next check will be provided as a payload.### Proxy Support
To make it work through proxies, you need to set up [`global-agent`](https://github.com/gajus/global-agent).
> See the [`using-http-proxies`](./examples/using-http-proxies) directory for an example on how to use HTTP(S) proxies with the `is-online-emitter` library.
## 👀 See also
- The [is-online](https://github.com/sindresorhus/is-online) library on which this project is based.