kaspad/infrastructure/network/rpc/handle_get_peer_addresses.go
stasatdaglabs d14809694f
[NOD-1223] Reorganize directory structure (#874)
* [NOD-1223] Delete unused files/packages.

* [NOD-1223] Move signal and limits to the os package.

* [NOD-1223] Put database and dbaccess into the db package.

* [NOD-1223] Fold the logs package into the logger package.

* [NOD-1223] Rename domainmessage to appmessage.

* [NOD-1223] Rename to/from DomainMessage to AppMessage.

* [NOD-1223] Move appmessage to the app packge.

* [NOD-1223] Move protocol to the app packge.

* [NOD-1223] Move the network package to the infrastructure packge.

* [NOD-1223] Rename cmd to executables.

* [NOD-1223] Fix go.doc in the logger package.
2020-08-18 10:26:39 +03:00

71 lines
2.5 KiB
Go

package rpc
import (
"github.com/kaspanet/kaspad/infrastructure/network/addressmanager"
"github.com/kaspanet/kaspad/infrastructure/network/rpc/model"
)
// handleGetPeerAddresses handles getPeerAddresses commands.
func handleGetPeerAddresses(s *Server, cmd interface{}, closeChan <-chan struct{}) (interface{}, error) {
peersState, err := s.addressManager.PeersStateForSerialization()
if err != nil {
return nil, err
}
rpcPeersState := model.GetPeerAddressesResult{
Version: peersState.Version,
Key: peersState.Key,
Addresses: make([]*model.GetPeerAddressesKnownAddressResult, len(peersState.Addresses)),
NewBuckets: make(map[string]*model.GetPeerAddressesNewBucketResult),
NewBucketFullNodes: model.GetPeerAddressesNewBucketResult{},
TriedBuckets: make(map[string]*model.GetPeerAddressesTriedBucketResult),
TriedBucketFullNodes: model.GetPeerAddressesTriedBucketResult{},
}
for i, addr := range peersState.Addresses {
rpcPeersState.Addresses[i] = &model.GetPeerAddressesKnownAddressResult{
Addr: string(addr.Address),
Src: string(addr.SourceAddress),
SubnetworkID: addr.SubnetworkID,
Attempts: addr.Attempts,
TimeStamp: addr.TimeStamp,
LastAttempt: addr.LastAttempt,
LastSuccess: addr.LastSuccess,
IsBanned: addr.IsBanned,
BannedTime: addr.BannedTime,
}
}
for subnetworkID, bucket := range peersState.SubnetworkNewAddressBucketArrays {
rpcPeersState.NewBuckets[subnetworkID] = &model.GetPeerAddressesNewBucketResult{}
for i, addr := range bucket {
rpcPeersState.NewBuckets[subnetworkID][i] = convertAddressKeySliceToString(addr)
}
}
for i, addr := range peersState.FullNodeNewAddressBucketArray {
rpcPeersState.NewBucketFullNodes[i] = convertAddressKeySliceToString(addr)
}
for subnetworkID, bucket := range peersState.SubnetworkTriedAddressBucketArrays {
rpcPeersState.TriedBuckets[subnetworkID] = &model.GetPeerAddressesTriedBucketResult{}
for i, addr := range bucket {
rpcPeersState.TriedBuckets[subnetworkID][i] = convertAddressKeySliceToString(addr)
}
}
for i, addr := range peersState.FullNodeTriedAddressBucketArray {
rpcPeersState.TriedBucketFullNodes[i] = convertAddressKeySliceToString(addr)
}
return rpcPeersState, nil
}
func convertAddressKeySliceToString(addressKeys []addressmanager.AddressKey) []string {
strings := make([]string, len(addressKeys))
for j, addr := range addressKeys {
strings[j] = string(addr)
}
return strings
}