Files
oc-discovery/docs/diagrams/05_indexer_get.puml

52 lines
1.8 KiB
Plaintext
Raw Normal View History

2026-02-24 14:31:37 +01:00
@startuml
2026-03-09 14:57:41 +01:00
title Indexer — Peer A discover Peer B (GetPeerRecord + handleNodeGet)
2026-02-24 14:31:37 +01:00
participant "NATS A" as NATSA
participant "DB Pair A (oc-lib)" as DBA
participant "Node A" as NodeA
participant "IndexerService (partagé)" as Indexer
participant "DHT Kademlia" as DHT
participant "NATS A (retour)" as NATSA2
2026-03-09 14:57:41 +01:00
note over NodeA: Trigger : NATS PB_SEARCH PEER\nor callback SubscribeToSearch
2026-02-24 14:31:37 +01:00
2026-03-09 14:57:41 +01:00
NodeA -> DBA: (PEER).Search(DID_B or PeerID_B)
DBA --> NodeA: Local Peer B (if known) → solve DID_B + PeerID_B\nor use search value
2026-02-24 14:31:37 +01:00
2026-03-09 14:57:41 +01:00
loop For every Peer A Binded Indexer
NodeA -> Indexer: TempStream /opencloud/record/get/1.0 -> streamAI
NodeA -> Indexer: streamAI.Encode(GetValue{Key: DID_B, PeerID: PeerID_B})
2026-02-24 14:31:37 +01:00
Indexer -> Indexer: key = "/node/" + DID_B
Indexer -> DHT: SearchValue(ctx 10s, "/node/"+DID_B)
DHT --> Indexer: channel de bytes (PeerRecord B)
2026-03-09 14:57:41 +01:00
loop Pour every results in DHT
Indexer -> Indexer: read → PeerRecord B
2026-02-24 14:31:37 +01:00
alt PeerRecord.PeerID == PeerID_B
Indexer -> Indexer: resp.Found=true, resp.Records[PeerID_B]=PeerRecord B
2026-03-09 14:57:41 +01:00
Indexer -> Indexer: StreamRecord B.LastSeen = now (if active heartbeat)
2026-02-24 14:31:37 +01:00
end
end
2026-03-09 14:57:41 +01:00
Indexer -> NodeA: streamAI.Encode(GetResponse{Found:true, Records:{PeerID_B: PeerRecord B}})
2026-02-24 14:31:37 +01:00
end
2026-03-09 14:57:41 +01:00
loop For every PeerRecord founded
NodeA -> NodeA: rec.Verify() → valid B signature
2026-02-24 14:31:37 +01:00
NodeA -> NodeA: rec.ExtractPeer(ourDID_A, DID_B, pubKey_B)
2026-03-09 14:57:41 +01:00
alt ourDID_A == DID_B (it's our proper entry)
note over NodeA: Republish to refresh TTL
2026-02-24 14:31:37 +01:00
NodeA -> Indexer: publishPeerRecord(rec) [refresh 2 min]
end
NodeA -> NATSA2: SetNATSPub(CREATE_RESOURCE, {PEER, Peer B JSON,\nSearchAttr:"peer_id"})
2026-03-09 14:57:41 +01:00
NATSA2 -> DBA: Upsert Peer B in DB A
2026-02-24 14:31:37 +01:00
DBA --> NATSA2: ok
end
NodeA --> NodeA: []*peer.Peer → [Peer B]
@enduml