forked from sindresorhus/is-reachable
-
Notifications
You must be signed in to change notification settings - Fork 0
/
index.d.ts
52 lines (39 loc) · 1.37 KB
/
index.d.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
declare namespace isReachable {
interface ErrorHandler {
(error: object): boolean
}
interface Options {
/**
Timeout in milliseconds after which a request is considered failed.
@default 5000
_Node.js only_
*/
readonly timeout?: number;
/**
Error handler function
*/
readonly errorHandler?: ErrorHandler;
}
}
/**
Check if servers are reachable.
The Node.js version will do a TCP handshake with the target's port. It attempts to detect cases where a router redirects the request to itself.
The browser version is limited by the fact that browsers cannot connect to arbitrary ports. It only supports HTTP and HTTPS and the check relies on the `/favicon.ico` path being present.
@param targets - One or more targets to check. Can either be `hostname:port`, a URL like `https://hostname:port` or even just `hostname`. `port` must be specified if protocol is not `http:` or `https:` and defaults to `443`. Protocols other than `http:` and `https:` are not supported.
@returns Whether any of the `targets` are reachable.
@example
```
import isReachable = require('is-reachable');
(async () => {
console.log(await isReachable('sindresorhus.com'));
//=> true
console.log(await isReachable('google.com:80'));
//=> true
})();
```
*/
declare function isReachable(
targets: string | readonly string[],
options?: isReachable.Options
): Promise<boolean>;
export = isReachable;