@libp2p/tcp 10.1.19-a02cb0461 → 10.1.19-e8398d97e

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,5 +1,5 @@
1
1
  import type { Multiaddr } from '@multiformats/multiaddr';
2
2
  import type { ListenOptions, IpcSocketConnectOpts, TcpSocketConnectOpts } from 'net';
3
3
  export type NetConfig = ListenOptions | (IpcSocketConnectOpts & TcpSocketConnectOpts);
4
- export declare function multiaddrToNetConfig(addr: Multiaddr, config?: NetConfig): NetConfig;
4
+ export declare function multiaddrToNetConfig(addr: Multiaddr, options?: NetConfig): NetConfig;
5
5
  //# sourceMappingURL=utils.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAA;AACxD,OAAO,KAAK,EAAE,aAAa,EAAE,oBAAoB,EAAE,oBAAoB,EAAE,MAAM,KAAK,CAAA;AAEpF,MAAM,MAAM,SAAS,GAAG,aAAa,GAAG,CAAC,oBAAoB,GAAG,oBAAoB,CAAC,CAAA;AAErF,wBAAgB,oBAAoB,CAAE,IAAI,EAAE,SAAS,EAAE,MAAM,GAAE,SAAc,GAAG,SAAS,CAqBxF"}
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAA;AACxD,OAAO,KAAK,EAAE,aAAa,EAAE,oBAAoB,EAAE,oBAAoB,EAAE,MAAM,KAAK,CAAA;AAEpF,MAAM,MAAM,SAAS,GAAG,aAAa,GAAG,CAAC,oBAAoB,GAAG,oBAAoB,CAAC,CAAA;AAErF,wBAAgB,oBAAoB,CAAE,IAAI,EAAE,SAAS,EAAE,OAAO,GAAE,SAAc,GAAG,SAAS,CA4BzF"}
package/dist/src/utils.js CHANGED
@@ -1,9 +1,16 @@
1
1
  import os from 'os';
2
2
  import path from 'path';
3
- export function multiaddrToNetConfig(addr, config = {}) {
4
- const listenPath = addr.getPath();
5
- // unix socket listening
6
- if (listenPath != null) {
3
+ import { InvalidParametersError } from '@libp2p/interface';
4
+ import { getNetConfig } from '@libp2p/utils';
5
+ import { CODE_UNIX } from '@multiformats/multiaddr';
6
+ import { Unix } from '@multiformats/multiaddr-matcher';
7
+ export function multiaddrToNetConfig(addr, options = {}) {
8
+ if (Unix.exactMatch(addr)) {
9
+ const listenPath = addr.getComponents().find(c => c.code === CODE_UNIX)?.value;
10
+ if (listenPath == null) {
11
+ throw new InvalidParametersError(`Multiaddr ${addr} was not a Unix address`);
12
+ }
13
+ // unix socket listening
7
14
  if (os.platform() === 'win32') {
8
15
  // Use named pipes on Windows systems.
9
16
  return { path: path.join('\\\\.\\pipe\\', listenPath) };
@@ -12,12 +19,15 @@ export function multiaddrToNetConfig(addr, config = {}) {
12
19
  return { path: listenPath };
13
20
  }
14
21
  }
15
- const options = addr.toOptions();
22
+ const config = getNetConfig(addr);
23
+ const host = config.host;
24
+ const port = config.port;
16
25
  // tcp listening
17
26
  return {
18
- ...config,
19
- ...options,
20
- ipv6Only: options.family === 6
27
+ host,
28
+ port,
29
+ ipv6Only: config.type === 'ip6',
30
+ ...options
21
31
  };
22
32
  }
23
33
  //# sourceMappingURL=utils.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,IAAI,CAAA;AACnB,OAAO,IAAI,MAAM,MAAM,CAAA;AAMvB,MAAM,UAAU,oBAAoB,CAAE,IAAe,EAAE,SAAoB,EAAE;IAC3E,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,EAAE,CAAA;IAEjC,wBAAwB;IACxB,IAAI,UAAU,IAAI,IAAI,EAAE,CAAC;QACvB,IAAI,EAAE,CAAC,QAAQ,EAAE,KAAK,OAAO,EAAE,CAAC;YAC9B,sCAAsC;YACtC,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,UAAU,CAAC,EAAE,CAAA;QACzD,CAAC;aAAM,CAAC;YACN,OAAO,EAAE,IAAI,EAAE,UAAU,EAAE,CAAA;QAC7B,CAAC;IACH,CAAC;IAED,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,EAAE,CAAA;IAEhC,gBAAgB;IAChB,OAAO;QACL,GAAG,MAAM;QACT,GAAG,OAAO;QACV,QAAQ,EAAE,OAAO,CAAC,MAAM,KAAK,CAAC;KAC/B,CAAA;AACH,CAAC"}
1
+ {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,IAAI,CAAA;AACnB,OAAO,IAAI,MAAM,MAAM,CAAA;AACvB,OAAO,EAAE,sBAAsB,EAAE,MAAM,mBAAmB,CAAA;AAC1D,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAA;AAC5C,OAAO,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAA;AACnD,OAAO,EAAE,IAAI,EAAE,MAAM,iCAAiC,CAAA;AAMtD,MAAM,UAAU,oBAAoB,CAAE,IAAe,EAAE,UAAqB,EAAE;IAC5E,IAAI,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;QAC1B,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,SAAS,CAAC,EAAE,KAAK,CAAA;QAE9E,IAAI,UAAU,IAAI,IAAI,EAAE,CAAC;YACvB,MAAM,IAAI,sBAAsB,CAAC,aAAa,IAAI,yBAAyB,CAAC,CAAA;QAC9E,CAAC;QAED,wBAAwB;QACxB,IAAI,EAAE,CAAC,QAAQ,EAAE,KAAK,OAAO,EAAE,CAAC;YAC9B,sCAAsC;YACtC,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,UAAU,CAAC,EAAE,CAAA;QACzD,CAAC;aAAM,CAAC;YACN,OAAO,EAAE,IAAI,EAAE,UAAU,EAAE,CAAA;QAC7B,CAAC;IACH,CAAC;IAED,MAAM,MAAM,GAAG,YAAY,CAAC,IAAI,CAAC,CAAA;IACjC,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAA;IACxB,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAA;IAExB,gBAAgB;IAChB,OAAO;QACL,IAAI;QACJ,IAAI;QACJ,QAAQ,EAAE,MAAM,CAAC,IAAI,KAAK,KAAK;QAC/B,GAAG,OAAO;KACX,CAAA;AACH,CAAC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@libp2p/tcp",
3
- "version": "10.1.19-a02cb0461",
3
+ "version": "10.1.19-e8398d97e",
4
4
  "description": "A TCP transport for libp2p",
5
5
  "license": "Apache-2.0 OR MIT",
6
6
  "homepage": "https://github.com/libp2p/js-libp2p/tree/main/packages/transport-tcp#readme",
@@ -53,10 +53,10 @@
53
53
  "test:electron-main": "aegir test -t electron-main"
54
54
  },
55
55
  "dependencies": {
56
- "@libp2p/interface": "2.11.0-a02cb0461",
57
- "@libp2p/utils": "6.7.2-a02cb0461",
58
- "@multiformats/multiaddr": "^12.5.1",
59
- "@multiformats/multiaddr-matcher": "^2.0.2",
56
+ "@libp2p/interface": "2.11.0-e8398d97e",
57
+ "@libp2p/utils": "6.7.2-e8398d97e",
58
+ "@multiformats/multiaddr": "^13.0.1",
59
+ "@multiformats/multiaddr-matcher": "^3.0.1",
60
60
  "@types/sinon": "^17.0.4",
61
61
  "main-event": "^1.0.1",
62
62
  "p-event": "^6.0.1",
@@ -64,8 +64,8 @@
64
64
  "uint8arraylist": "^2.4.8"
65
65
  },
66
66
  "devDependencies": {
67
- "@libp2p/logger": "5.2.0-a02cb0461",
68
- "aegir": "^47.0.21",
67
+ "@libp2p/logger": "5.2.0-e8398d97e",
68
+ "aegir": "^47.0.22",
69
69
  "delay": "^6.0.0",
70
70
  "p-defer": "^4.0.1",
71
71
  "p-wait-for": "^5.0.2",
package/src/utils.ts CHANGED
@@ -1,15 +1,23 @@
1
1
  import os from 'os'
2
2
  import path from 'path'
3
+ import { InvalidParametersError } from '@libp2p/interface'
4
+ import { getNetConfig } from '@libp2p/utils'
5
+ import { CODE_UNIX } from '@multiformats/multiaddr'
6
+ import { Unix } from '@multiformats/multiaddr-matcher'
3
7
  import type { Multiaddr } from '@multiformats/multiaddr'
4
8
  import type { ListenOptions, IpcSocketConnectOpts, TcpSocketConnectOpts } from 'net'
5
9
 
6
10
  export type NetConfig = ListenOptions | (IpcSocketConnectOpts & TcpSocketConnectOpts)
7
11
 
8
- export function multiaddrToNetConfig (addr: Multiaddr, config: NetConfig = {}): NetConfig {
9
- const listenPath = addr.getPath()
12
+ export function multiaddrToNetConfig (addr: Multiaddr, options: NetConfig = {}): NetConfig {
13
+ if (Unix.exactMatch(addr)) {
14
+ const listenPath = addr.getComponents().find(c => c.code === CODE_UNIX)?.value
10
15
 
11
- // unix socket listening
12
- if (listenPath != null) {
16
+ if (listenPath == null) {
17
+ throw new InvalidParametersError(`Multiaddr ${addr} was not a Unix address`)
18
+ }
19
+
20
+ // unix socket listening
13
21
  if (os.platform() === 'win32') {
14
22
  // Use named pipes on Windows systems.
15
23
  return { path: path.join('\\\\.\\pipe\\', listenPath) }
@@ -18,12 +26,15 @@ export function multiaddrToNetConfig (addr: Multiaddr, config: NetConfig = {}):
18
26
  }
19
27
  }
20
28
 
21
- const options = addr.toOptions()
29
+ const config = getNetConfig(addr)
30
+ const host = config.host
31
+ const port = config.port
22
32
 
23
33
  // tcp listening
24
34
  return {
25
- ...config,
26
- ...options,
27
- ipv6Only: options.family === 6
35
+ host,
36
+ port,
37
+ ipv6Only: config.type === 'ip6',
38
+ ...options
28
39
  }
29
40
  }