ripple-binary-codec
Version:
XRP Ledger binary codec
123 lines (104 loc) • 3.35 kB
text/typescript
import { BytesList } from '../serdes/binary-serializer'
import { BinaryParser } from '../serdes/binary-parser'
import { XrplDefinitionsBase } from '../enums'
import { bytesToHex } from '@xrplf/isomorphic/utils'
type JSON = string | number | boolean | null | undefined | JSON[] | JsonObject
type JsonObject = { [key: string]: JSON }
/**
* The base class for all binary-codec types
*/
class SerializedType {
protected readonly bytes: Uint8Array = new Uint8Array(0)
constructor(bytes?: Uint8Array) {
this.bytes = bytes ?? new Uint8Array(0)
}
static fromParser(parser: BinaryParser, hint?: number): SerializedType {
throw new Error('fromParser not implemented')
return this.fromParser(parser, hint)
}
static from(value: SerializedType | JSON | bigint): SerializedType {
throw new Error('from not implemented')
return this.from(value)
}
/**
* Write the bytes representation of a SerializedType to a BytesList
*
* @param list The BytesList to write SerializedType bytes to
*/
toBytesSink(list: BytesList): void {
list.put(this.bytes)
}
/**
* Get the hex representation of a SerializedType's bytes
*
* @returns hex String of this.bytes
*/
toHex(): string {
return bytesToHex(this.toBytes())
}
/**
* Get the bytes representation of a SerializedType
*
* @returns A Uint8Array of the bytes
*/
toBytes(): Uint8Array {
if (this.bytes) {
return this.bytes
}
const bytes = new BytesList()
this.toBytesSink(bytes)
return bytes.toBytes()
}
/**
* Return the JSON representation of a SerializedType
*
* @param _definitions rippled definitions used to parse the values of transaction types and such.
* Unused in default, but used in STObject, STArray
* Can be customized for sidechains and amendments.
* @returns any type, if not overloaded returns hexString representation of bytes
*/
toJSON(_definitions?: XrplDefinitionsBase, _fieldName?: string): JSON {
return this.toHex()
}
/**
* @returns hexString representation of this.bytes
*/
toString(): string {
return this.toHex()
}
}
/**
* Base class for SerializedTypes that are comparable.
*
* @template T - What types you want to allow comparisons between. You must specify all types. Primarily used to allow
* comparisons between built-in types (like `string`) and SerializedType subclasses (like `Hash`).
*
* Ex. `class Hash extends Comparable<Hash | string>`
*/
class Comparable<T extends Object> extends SerializedType {
lt(other: T): boolean {
return this.compareTo(other) < 0
}
eq(other: T): boolean {
return this.compareTo(other) === 0
}
gt(other: T): boolean {
return this.compareTo(other) > 0
}
gte(other: T): boolean {
return this.compareTo(other) > -1
}
lte(other: T): boolean {
return this.compareTo(other) < 1
}
/**
* Overload this method to define how two Comparable SerializedTypes are compared
*
* @param other The comparable object to compare this to
* @returns A number denoting the relationship of this and other
*/
compareTo(other: T): number {
throw new Error(`cannot compare ${this.toString()} and ${other.toString()}`)
}
}
export { SerializedType, Comparable, JSON, JsonObject }