Projekt

Obecné

Profil

Stáhnout (1.82 KB) Statistiky
| Větev: | Revize:
1
# default-gateway
2
[![](https://img.shields.io/npm/v/default-gateway.svg?style=flat)](https://www.npmjs.org/package/default-gateway) [![](https://img.shields.io/npm/dm/default-gateway.svg)](https://www.npmjs.org/package/default-gateway) [![](https://api.travis-ci.org/silverwind/default-gateway.svg?style=flat)](https://travis-ci.org/silverwind/default-gateway)
3

    
4
> Get the default network gateway, cross-platform.
5

    
6
Obtains the machine's default gateway through `exec` calls to OS routing interfaces. On Linux and Android, the `ip` command must be available (usually provided by the `iproute2` package). On IBM i, the `db2util` command must be available (provided by the `db2util` package).
7

    
8
## Installation
9

    
10
```
11
$ npm install default-gateway
12
```
13

    
14
## Example
15

    
16
```js
17
const defaultGateway = require('default-gateway');
18

    
19
defaultGateway.v4().then(result => {
20
  // result = {gateway: '1.2.3.4', interface: 'en1'}
21
});
22

    
23
defaultGateway.v6().then(result => {
24
  // result = {gateway: '2001:db8::1', interface: 'en2'}
25
});
26

    
27
const result = defaultGateway.v4.sync();
28
// result = {gateway: '1.2.3.4', interface: 'en1'}
29

    
30
const result = defaultGateway.v6.sync();
31
// result = {gateway: '2001:db8::1', interface: 'en2'}
32
```
33

    
34
## API
35
### defaultGateway.v4()
36
### defaultGateway.v6()
37
### defaultGateway.v4.sync()
38
### defaultGateway.v6.sync()
39

    
40
Returns: `result` *Object*
41
  - `gateway`: The IP address of the default gateway.
42
  - `interface`: The name of the interface. On Windows, this is the network adapter name.
43

    
44
The `.v{4,6}()` methods return a Promise while the `.v{4,6}.sync()` variants will return the result synchronously.
45

    
46
The `gateway` property will always be defined on success, while `interface` can be `null` if it cannot be determined. All methods reject/throw on unexpected conditions.
47

    
48
## License
49

    
50
© [silverwind](https://github.com/silverwind), distributed under BSD licence
(2-2/12)