UNPKG

ripple-binary-codec

Version:
123 lines (104 loc) 3.35 kB
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 }