import pkg/questionable import pkg/stew/byteutils import pkg/libp2p import pkg/codexdht/discv5/node as dn import pkg/codexdht/discv5/routing_table as rt import ../sales import ../purchasing import ../utils/json import ../manifest export json type StorageRequestParams* = object duration* {.serialize.}: UInt256 proofProbability* {.serialize.}: UInt256 reward* {.serialize.}: UInt256 collateral* {.serialize.}: UInt256 expiry* {.serialize.}: ?UInt256 nodes* {.serialize.}: ?uint tolerance* {.serialize.}: ?uint RestPurchase* = object requestId* {.serialize.}: RequestId request* {.serialize.}: ?StorageRequest state* {.serialize.}: string error* {.serialize.}: ?string RestAvailability* = object totalSize* {.serialize.}: UInt256 duration* {.serialize.}: UInt256 minPrice* {.serialize.}: UInt256 maxCollateral* {.serialize.}: UInt256 freeSize* {.serialize.}: ?UInt256 RestSalesAgent* = object state* {.serialize.}: string requestId* {.serialize.}: RequestId slotIndex* {.serialize.}: UInt256 RestContent* = object cid* {.serialize.}: Cid manifest* {.serialize.}: Manifest RestContentList* = object content* {.serialize.}: seq[RestContent] RestNode* = object nodeId* {.serialize.}: RestNodeId peerId* {.serialize.}: PeerId record* {.serialize.}: SignedPeerRecord address* {.serialize.}: Option[dn.Address] seen* {.serialize.}: bool RestRoutingTable* = object localNode* {.serialize.}: RestNode nodes* {.serialize.}: seq[RestNode] RestPeerRecord* = object peerId* {.serialize.}: PeerId seqNo* {.serialize.}: uint64 addresses* {.serialize.}: seq[AddressInfo] RestNodeId* = object id*: NodeId RestRepoStore* = object totalBlocks* {.serialize.}: uint quotaMaxBytes* {.serialize.}: uint quotaUsedBytes* {.serialize.}: uint quotaReservedBytes* {.serialize.}: uint proc init*(_: type RestContentList, content: seq[RestContent]): RestContentList = RestContentList( content: content ) proc init*(_: type RestContent, cid: Cid, manifest: Manifest): RestContent = RestContent( cid: cid, manifest: manifest ) proc init*(_: type RestNode, node: dn.Node): RestNode = RestNode( nodeId: RestNodeId.init(node.id), peerId: node.record.data.peerId, record: node.record, address: node.address, seen: node.seen ) proc init*(_: type RestRoutingTable, routingTable: rt.RoutingTable): RestRoutingTable = var nodes: seq[RestNode] = @[] for bucket in routingTable.buckets: for node in bucket.nodes: nodes.add(RestNode.init(node)) RestRoutingTable( localNode: RestNode.init(routingTable.localNode), nodes: nodes ) proc init*(_: type RestPeerRecord, peerRecord: PeerRecord): RestPeerRecord = RestPeerRecord( peerId: peerRecord.peerId, seqNo: peerRecord.seqNo, addresses: peerRecord.addresses ) proc init*(_: type RestNodeId, id: NodeId): RestNodeId = RestNodeId( id: id ) proc `%`*(obj: StorageRequest | Slot): JsonNode = let jsonObj = newJObject() for k, v in obj.fieldPairs: jsonObj[k] = %v jsonObj["id"] = %(obj.id) return jsonObj proc `%`*(obj: RestNodeId): JsonNode = % $obj.id