These docs are for Cribl Edge 4.4 and are no longer actively maintained.
See the latest version (4.14).
C.Decode and C.Encode - Encoding and Decoding
C.Decode – Data Decoding Methods
C.Decode.base64()
Decode.base64(val: string, resultEnc: string = 'utf8'): string | Buffer | undefinedPerforms base64 decoding of the given string.
Returns a string or Buffer, depending on the resultEnc value.
| Parameter | Type | Description | 
|---|---|---|
| val | string | Value to decode. | 
| resultEnc | 'utf8'|'utf8-valid'|'buffer' | Encoding to use to convert the binary data to a string. Use 'utf8‑valid'to validate that result is valid UTF8; use'buffer'if you need the binary data in a Buffer. Defaults to'utf8'. | 
Examples
To decode an encoded field and return the decoded value as a Buffer, use:
C.Decode.base64(encoded, 'buffer')C.Decode.gzip()
Decode.gzip(value: Buffer | string, encoding?: BufferEncoding) : stringGunzips the supplied value.
| Parameter | Type | Description | 
|---|---|---|
| value | any | Value to gunzip. | 
| encoding | string | Encoding of value, for example:'base64','hex','utf-8','binary'. Default is'base64'. If data is received as Buffer (from gzip with encoding:'none'), decoding is skipped. | 
Examples
To decode a hostname field which had been encoded using hex, run:
C.Decode.gzip(hostname, 'hex')C.Decode.hex()
Decode.hex(val: string): numberPerforms hex to number conversion.
Returns NaN if value cannot be converted to a number.
| Parameter | Type | Description | 
|---|---|---|
| val | string | Hex string to parse to a number (for example, “0xcafe”). | 
C.Decode.uri()
Decode.uri(val: string): stringPerforms URI-decoding of the given string.
| Parameter | Type | Description | 
|---|---|---|
| val | string | Value to decode. | 
C.Decode.inflate()
Decode.inflate(value: Buffer | string, encoding: BufferEncoding = 'base64', isRaw = false): stringInflates the supplied value.
| Parameter | Type | Description | 
|---|---|---|
| value | string | Buffer | The value to inflate. May be a Buffer or a string. | 
| encoding | string | If a string valueis provided, this specifies how it has been encoded. If noencodingis provided,base64is used. This parameter is ignored ifvalueis already a Buffer. | 
| isRaw | boolean | Indicates whether the data is in raw deflate format (without zlib headers). Default value is false. | 
Examples
To base64-decode and inflate the value contained in a _raw field, you can use:
C.Decode.inflate(_raw)To additionally specify a different encoding to use, run:
C.Decode.inflate(_raw, 'hex')C.Encode – Data Encoding Methods
C.Encode.base64()
Encode.base64(val: string | Buffer, trimTrailEq: boolean = false, encoding?: BufferEncoding): stringReturns a base64 representation of the given string or Buffer.
| Parameter | Type | Description | 
|---|---|---|
| val | any | Value to encode. | 
| trimTrailEq | boolean | Whether to trim any trailing =. | 
| encoding | string | Optional parameter that specifies the encoding of the value. Options include base64,hex,utf-8, andbinary. The default isutf-8. | 
Examples
To base64-encode the username field, and remove the trailing =, use:
C.Encode.base64(username, true)To base64-encode the hexValue field, where the value of the field is a hex string:
C.Encode.base64('4672616e6b7575757575', undefined, 'hex')C.Encode.gzip()
Encode.gzip(value: Buffer | string, encoding?: string) : string | Buffer
Gzips, and optionally base64-encodes, the supplied value.
| Parameter | Type | Description | 
|---|---|---|
| value | string | Value to gzip. | 
| encoding | string | Encoding of value, for example:'base64','hex','utf-8','binary','none'. Default is'base64'. If'none'is specified, data will be returned as a Buffer. | 
Examples
To encode the hostname field, for example using hex encoding, run:
C.Encode.gzip(hostname, 'hex')C.Encode.hex()
Encode.hex(val: string | number): stringRounds the number to an integer and returns its hex representation (lowercase). If a string is provided, it will be parsed into a number or NaN.
| Parameter | Type | Description | 
|---|---|---|
| val | string | number | Value to convert to hex. | 
C.Encode.uri()
Encode.uri(val: string): stringReturns the URI-encoded representation of the given string.
| Parameter | Type | Description | 
|---|---|---|
| val | string | Value to encode. | 
C.Encode.deflate()
Encode.deflate(value: Buffer | string, encoding: BufferEncoding | 'none' = 'base64', toRaw = false): string | BufferDeflates and optionally base64-encodes the supplied value.
| Parameter | Type | Description | 
|---|---|---|
| value | string | Buffer | Value to deflate. | 
| encoding | string | Encoding to apply to the deflated result, for example: base64,hex,utf-8,binary,none. Default isbase64. Ifnoneis specified, data will be returned as a Buffer. | 
| toRaw | boolean | Indicates whether to return the raw deflated data, without zlib headers. Default is false, which will prepend normal zlib header bytes to the returned value. | 
Examples
To deflate and hex-decode the value provided in an inflated field, run:
C.Encode.deflate(inflated, 'hex')