UNPKG

@libp2p/peer-store

Version:

Stores information about peers libp2p knows on the network

458 lines (381 loc) 12 kB
/* eslint-disable import/export */ /* eslint-disable complexity */ /* eslint-disable @typescript-eslint/no-namespace */ /* eslint-disable @typescript-eslint/no-unnecessary-boolean-literal-compare */ /* eslint-disable @typescript-eslint/no-empty-interface */ import { type Codec, decodeMessage, type DecodeOptions, encodeMessage, MaxLengthError, MaxSizeError, message } from 'protons-runtime' import { alloc as uint8ArrayAlloc } from 'uint8arrays/alloc' import type { Uint8ArrayList } from 'uint8arraylist' export interface Peer { addresses: Address[] protocols: string[] publicKey?: Uint8Array peerRecordEnvelope?: Uint8Array metadata: Map<string, Uint8Array> tags: Map<string, Tag> updated?: number } export namespace Peer { export interface Peer$metadataEntry { key: string value: Uint8Array } export namespace Peer$metadataEntry { let _codec: Codec<Peer$metadataEntry> export const codec = (): Codec<Peer$metadataEntry> => { if (_codec == null) { _codec = message<Peer$metadataEntry>((obj, w, opts = {}) => { if (opts.lengthDelimited !== false) { w.fork() } if ((obj.key != null && obj.key !== '')) { w.uint32(10) w.string(obj.key) } if ((obj.value != null && obj.value.byteLength > 0)) { w.uint32(18) w.bytes(obj.value) } if (opts.lengthDelimited !== false) { w.ldelim() } }, (reader, length, opts = {}) => { const obj: any = { key: '', value: uint8ArrayAlloc(0) } const end = length == null ? reader.len : reader.pos + length while (reader.pos < end) { const tag = reader.uint32() switch (tag >>> 3) { case 1: { obj.key = reader.string() break } case 2: { obj.value = reader.bytes() break } default: { reader.skipType(tag & 7) break } } } return obj }) } return _codec } export const encode = (obj: Partial<Peer$metadataEntry>): Uint8Array => { return encodeMessage(obj, Peer$metadataEntry.codec()) } export const decode = (buf: Uint8Array | Uint8ArrayList, opts?: DecodeOptions<Peer$metadataEntry>): Peer$metadataEntry => { return decodeMessage(buf, Peer$metadataEntry.codec(), opts) } } export interface Peer$tagsEntry { key: string value?: Tag } export namespace Peer$tagsEntry { let _codec: Codec<Peer$tagsEntry> export const codec = (): Codec<Peer$tagsEntry> => { if (_codec == null) { _codec = message<Peer$tagsEntry>((obj, w, opts = {}) => { if (opts.lengthDelimited !== false) { w.fork() } if ((obj.key != null && obj.key !== '')) { w.uint32(10) w.string(obj.key) } if (obj.value != null) { w.uint32(18) Tag.codec().encode(obj.value, w) } if (opts.lengthDelimited !== false) { w.ldelim() } }, (reader, length, opts = {}) => { const obj: any = { key: '' } const end = length == null ? reader.len : reader.pos + length while (reader.pos < end) { const tag = reader.uint32() switch (tag >>> 3) { case 1: { obj.key = reader.string() break } case 2: { obj.value = Tag.codec().decode(reader, reader.uint32(), { limits: opts.limits?.value }) break } default: { reader.skipType(tag & 7) break } } } return obj }) } return _codec } export const encode = (obj: Partial<Peer$tagsEntry>): Uint8Array => { return encodeMessage(obj, Peer$tagsEntry.codec()) } export const decode = (buf: Uint8Array | Uint8ArrayList, opts?: DecodeOptions<Peer$tagsEntry>): Peer$tagsEntry => { return decodeMessage(buf, Peer$tagsEntry.codec(), opts) } } let _codec: Codec<Peer> export const codec = (): Codec<Peer> => { if (_codec == null) { _codec = message<Peer>((obj, w, opts = {}) => { if (opts.lengthDelimited !== false) { w.fork() } if (obj.addresses != null) { for (const value of obj.addresses) { w.uint32(10) Address.codec().encode(value, w) } } if (obj.protocols != null) { for (const value of obj.protocols) { w.uint32(18) w.string(value) } } if (obj.publicKey != null) { w.uint32(34) w.bytes(obj.publicKey) } if (obj.peerRecordEnvelope != null) { w.uint32(42) w.bytes(obj.peerRecordEnvelope) } if (obj.metadata != null && obj.metadata.size !== 0) { for (const [key, value] of obj.metadata.entries()) { w.uint32(50) Peer.Peer$metadataEntry.codec().encode({ key, value }, w) } } if (obj.tags != null && obj.tags.size !== 0) { for (const [key, value] of obj.tags.entries()) { w.uint32(58) Peer.Peer$tagsEntry.codec().encode({ key, value }, w) } } if (obj.updated != null) { w.uint32(64) w.uint64Number(obj.updated) } if (opts.lengthDelimited !== false) { w.ldelim() } }, (reader, length, opts = {}) => { const obj: any = { addresses: [], protocols: [], metadata: new Map<string, Uint8Array>(), tags: new Map<string, undefined>() } const end = length == null ? reader.len : reader.pos + length while (reader.pos < end) { const tag = reader.uint32() switch (tag >>> 3) { case 1: { if (opts.limits?.addresses != null && obj.addresses.length === opts.limits.addresses) { throw new MaxLengthError('Decode error - map field "addresses" had too many elements') } obj.addresses.push(Address.codec().decode(reader, reader.uint32(), { limits: opts.limits?.addresses$ })) break } case 2: { if (opts.limits?.protocols != null && obj.protocols.length === opts.limits.protocols) { throw new MaxLengthError('Decode error - map field "protocols" had too many elements') } obj.protocols.push(reader.string()) break } case 4: { obj.publicKey = reader.bytes() break } case 5: { obj.peerRecordEnvelope = reader.bytes() break } case 6: { if (opts.limits?.metadata != null && obj.metadata.size === opts.limits.metadata) { throw new MaxSizeError('Decode error - map field "metadata" had too many elements') } const entry = Peer.Peer$metadataEntry.codec().decode(reader, reader.uint32()) obj.metadata.set(entry.key, entry.value) break } case 7: { if (opts.limits?.tags != null && obj.tags.size === opts.limits.tags) { throw new MaxSizeError('Decode error - map field "tags" had too many elements') } const entry = Peer.Peer$tagsEntry.codec().decode(reader, reader.uint32(), { limits: { value: opts.limits?.tags$value } }) obj.tags.set(entry.key, entry.value) break } case 8: { obj.updated = reader.uint64Number() break } default: { reader.skipType(tag & 7) break } } } return obj }) } return _codec } export const encode = (obj: Partial<Peer>): Uint8Array => { return encodeMessage(obj, Peer.codec()) } export const decode = (buf: Uint8Array | Uint8ArrayList, opts?: DecodeOptions<Peer>): Peer => { return decodeMessage(buf, Peer.codec(), opts) } } export interface Address { multiaddr: Uint8Array isCertified?: boolean observed?: number } export namespace Address { let _codec: Codec<Address> export const codec = (): Codec<Address> => { if (_codec == null) { _codec = message<Address>((obj, w, opts = {}) => { if (opts.lengthDelimited !== false) { w.fork() } if ((obj.multiaddr != null && obj.multiaddr.byteLength > 0)) { w.uint32(10) w.bytes(obj.multiaddr) } if (obj.isCertified != null) { w.uint32(16) w.bool(obj.isCertified) } if (obj.observed != null) { w.uint32(24) w.uint64Number(obj.observed) } if (opts.lengthDelimited !== false) { w.ldelim() } }, (reader, length, opts = {}) => { const obj: any = { multiaddr: uint8ArrayAlloc(0) } const end = length == null ? reader.len : reader.pos + length while (reader.pos < end) { const tag = reader.uint32() switch (tag >>> 3) { case 1: { obj.multiaddr = reader.bytes() break } case 2: { obj.isCertified = reader.bool() break } case 3: { obj.observed = reader.uint64Number() break } default: { reader.skipType(tag & 7) break } } } return obj }) } return _codec } export const encode = (obj: Partial<Address>): Uint8Array => { return encodeMessage(obj, Address.codec()) } export const decode = (buf: Uint8Array | Uint8ArrayList, opts?: DecodeOptions<Address>): Address => { return decodeMessage(buf, Address.codec(), opts) } } export interface Tag { value: number expiry?: bigint } export namespace Tag { let _codec: Codec<Tag> export const codec = (): Codec<Tag> => { if (_codec == null) { _codec = message<Tag>((obj, w, opts = {}) => { if (opts.lengthDelimited !== false) { w.fork() } if ((obj.value != null && obj.value !== 0)) { w.uint32(8) w.uint32(obj.value) } if (obj.expiry != null) { w.uint32(16) w.uint64(obj.expiry) } if (opts.lengthDelimited !== false) { w.ldelim() } }, (reader, length, opts = {}) => { const obj: any = { value: 0 } const end = length == null ? reader.len : reader.pos + length while (reader.pos < end) { const tag = reader.uint32() switch (tag >>> 3) { case 1: { obj.value = reader.uint32() break } case 2: { obj.expiry = reader.uint64() break } default: { reader.skipType(tag & 7) break } } } return obj }) } return _codec } export const encode = (obj: Partial<Tag>): Uint8Array => { return encodeMessage(obj, Tag.codec()) } export const decode = (buf: Uint8Array | Uint8ArrayList, opts?: DecodeOptions<Tag>): Tag => { return decodeMessage(buf, Tag.codec(), opts) } }