@libp2p/peer-store
Version:
Stores information about peers libp2p knows on the network
458 lines (381 loc) • 12 kB
text/typescript
/* 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)
}
}