UNPKG

lightningdevkit

Version:
156 lines 5.86 kB
import { Result_NoneNoneZ } from '../structs/Result_NoneNoneZ.mjs'; import { CommonBase } from './CommonBase.mjs'; import * as bindings from '../bindings.mjs'; /** * Features used within an `offer`. */ export class OfferFeatures extends CommonBase { /* @internal */ constructor(_dummy, ptr) { super(ptr, bindings.OfferFeatures_free); } /** * Checks if two OfferFeaturess contain equal inner contents. * This ignores pointers and is_owned flags and looks at the values in fields. * Two objects with NULL inner values will be considered "equal" here. */ eq(b) { const ret = bindings.OfferFeatures_eq(this.ptr, CommonBase.get_ptr_of(b)); CommonBase.add_ref_from(this, b); return ret; } clone_ptr() { const ret = bindings.OfferFeatures_clone_ptr(this.ptr); return ret; } /** * Creates a copy of the OfferFeatures */ clone() { const ret = bindings.OfferFeatures_clone(this.ptr); const ret_hu_conv = new OfferFeatures(null, ret); CommonBase.add_ref_from(ret_hu_conv, this); return ret_hu_conv; } /** * Generates a non-cryptographic 64-bit hash of the OfferFeatures. */ hash() { const ret = bindings.OfferFeatures_hash(this.ptr); return ret; } /** * Create a blank Features with no features set */ static constructor_empty() { const ret = bindings.OfferFeatures_empty(); const ret_hu_conv = new OfferFeatures(null, ret); CommonBase.add_ref_from(ret_hu_conv, ret_hu_conv); return ret_hu_conv; } /** * Returns the feature set as a list of bytes, in little-endian. This is in reverse byte order * from most on-the-wire encodings. */ le_flags() { const ret = bindings.OfferFeatures_le_flags(this.ptr); const ret_conv = bindings.decodeUint8Array(ret); return ret_conv; } /** * Returns true if this `Features` has any optional flags set */ supports_any_optional_bits() { const ret = bindings.OfferFeatures_supports_any_optional_bits(this.ptr); return ret; } /** * Returns true if this `Features` object contains required features unknown by `other`. */ requires_unknown_bits_from(other) { const ret = bindings.OfferFeatures_requires_unknown_bits_from(this.ptr, CommonBase.get_ptr_of(other)); CommonBase.add_ref_from(this, other); return ret; } /** * Returns the set of required features unknown by `other`, as their bit position. */ required_unknown_bits_from(other) { const ret = bindings.OfferFeatures_required_unknown_bits_from(this.ptr, CommonBase.get_ptr_of(other)); const ret_conv = bindings.decodeUint64Array(ret); CommonBase.add_ref_from(this, other); return ret_conv; } /** * Returns true if this `Features` object contains unknown feature flags which are set as * \"required\". */ requires_unknown_bits() { const ret = bindings.OfferFeatures_requires_unknown_bits(this.ptr); return ret; } /** * Returns true if this `Features` supports any bits which we do not know of */ supports_unknown_bits() { const ret = bindings.OfferFeatures_supports_unknown_bits(this.ptr); return ret; } /** * Sets a required feature bit. Errors if `bit` is outside the feature range as defined * by [BOLT 9]. * * Note: Required bits are even. If an odd bit is given, then the corresponding even bit will * be set instead (i.e., `bit - 1`). * * [BOLT 9]: https://github.com/lightning/bolts/blob/master/09-features.md */ set_required_feature_bit(bit) { const ret = bindings.OfferFeatures_set_required_feature_bit(this.ptr, bit); const ret_hu_conv = Result_NoneNoneZ.constr_from_ptr(ret); return ret_hu_conv; } /** * Sets an optional feature bit. Errors if `bit` is outside the feature range as defined * by [BOLT 9]. * * Note: Optional bits are odd. If an even bit is given, then the corresponding odd bit will be * set instead (i.e., `bit + 1`). * * [BOLT 9]: https://github.com/lightning/bolts/blob/master/09-features.md */ set_optional_feature_bit(bit) { const ret = bindings.OfferFeatures_set_optional_feature_bit(this.ptr, bit); const ret_hu_conv = Result_NoneNoneZ.constr_from_ptr(ret); return ret_hu_conv; } /** * Sets a required custom feature bit. Errors if `bit` is outside the custom range as defined * by [bLIP 2] or if it is a known `T` feature. * * Note: Required bits are even. If an odd bit is given, then the corresponding even bit will * be set instead (i.e., `bit - 1`). * * [bLIP 2]: https://github.com/lightning/blips/blob/master/blip-0002.md#feature-bits */ set_required_custom_bit(bit) { const ret = bindings.OfferFeatures_set_required_custom_bit(this.ptr, bit); const ret_hu_conv = Result_NoneNoneZ.constr_from_ptr(ret); return ret_hu_conv; } /** * Sets an optional custom feature bit. Errors if `bit` is outside the custom range as defined * by [bLIP 2] or if it is a known `T` feature. * * Note: Optional bits are odd. If an even bit is given, then the corresponding odd bit will be * set instead (i.e., `bit + 1`). * * [bLIP 2]: https://github.com/lightning/blips/blob/master/blip-0002.md#feature-bits */ set_optional_custom_bit(bit) { const ret = bindings.OfferFeatures_set_optional_custom_bit(this.ptr, bit); const ret_hu_conv = Result_NoneNoneZ.constr_from_ptr(ret); return ret_hu_conv; } } //# sourceMappingURL=OfferFeatures.mjs.map