70 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			70 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| # @leichtgewicht/ip-codec
 | |
| 
 | |
| Small package to encode or decode IP addresses from buffers to strings.
 | |
| Supports IPV4 and IPV6.
 | |
| 
 | |
| ## Usage
 | |
| 
 | |
| The basics are straigthforward
 | |
| 
 | |
| ```js
 | |
| import { encode, decode, sizeOf, familyOf } from '@leichtgewicht/ip-codec'
 | |
| 
 | |
| const uint8Array = encode("127.0.0.1")
 | |
| const str = decode(uint8Array)
 | |
| 
 | |
| try {
 | |
|   switch sizeOf(str) {
 | |
|     case 4: // IPv4
 | |
|     case 16: // IPv6
 | |
|   }
 | |
|   switch familyOf(str) {
 | |
|     case: 1: // IPv4
 | |
|     case: 2: // IPv6
 | |
|   }
 | |
| } catch (err) {
 | |
|   // Invalid IP
 | |
| }
 | |
| ```
 | |
| 
 | |
| By default the library will work with Uint8Array's but you can bring your own buffer:
 | |
| 
 | |
| ```js
 | |
| const buf = Buffer.alloc(4)
 | |
| encode('127.0.0.1', buf)
 | |
| ```
 | |
| 
 | |
| It is also possible to de-encode at a location inside a given buffer
 | |
| 
 | |
| ```js
 | |
| const buf = Buffer.alloc(10)
 | |
| encode('127.0.0.1', buf, 4)
 | |
| ```
 | |
| 
 | |
| Allocation of a buffer may be difficult if you don't know what type the buffer:
 | |
| you can pass in a generator to allocate it for you:
 | |
| 
 | |
| ```js
 | |
| encode('127.0.0.1', Buffer.alloc)
 | |
| ```
 | |
| 
 | |
| You can also de/encode ipv4 or ipv6 specifically:
 | |
| 
 | |
| ```js
 | |
| import { v4, v6 } from '@leichtgewicht/ip-codec'
 | |
| 
 | |
| v4.decode(v4.encode('127.0.0.1'))
 | |
| v6.decode(v6.encode('::'))
 | |
| ```
 | |
| 
 | |
| ## History
 | |
| 
 | |
| The code in this package was originally extracted from [node-ip](https://github.com/indutny/node-ip) and since improved.
 | |
| 
 | |
| Notable changes are the removal of the `Buffer` dependency and better support for detection of
 | |
| formats and allocation of buffers.
 | |
| 
 | |
| ## License
 | |
| 
 | |
| [MIT](./LICENSE)
 |