Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

go-algorand 3.17.0-stable Release PR #5633

Merged
merged 114 commits into from
Aug 4, 2023
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
114 commits
Select commit Hold shift + click to select a range
8d73f00
test: skip flaky test `TestVotersReloadFromDiskPassRecoveryPeriod` (#…
ahangsu May 31, 2023
4106d22
AVM: Increase coverage by deleting a dead function and adding limit t…
jannotti May 31, 2023
25eb57c
Testing: Get rapid into the codebase (#5437)
jannotti Jun 1, 2023
6e245e7
lint: enable govet shadow linter and resolve linter warnings (#5261)
cce Jun 1, 2023
bad81ee
Algod: Simulation PC exposure for App approval/clear-state transactio…
ahangsu Jun 1, 2023
fd946dd
tools: txn replayer (#5420)
algorandskiy Jun 2, 2023
21dd74a
Algod: Add README file to state proof package (#5386)
id-ms Jun 2, 2023
76942c4
kv: add StorageEngine config
icorderi Jun 2, 2023
e249905
build: fix shadow linter in debug tools (#5442)
algorandskiy Jun 2, 2023
eac2c4f
Bookkeeping: improve block documentation since no-low-resources (#5383)
bbroder-algo Jun 2, 2023
3cbb422
config: make Tx dedupe cache maxSize configurable (#5419)
iansuvak Jun 2, 2023
7d8525e
cleanup: remove redundant method LookupAccountDataByAddress (#5216)
icorderi Jun 2, 2023
f66a404
sortition: use external sortition package (#5429)
cce Jun 2, 2023
490fd3b
AVM: Some error cleanup, and added coverage (#5441)
jannotti Jun 2, 2023
45cf9ab
lint: enable staticcheck for test code and fix issues (#5401)
cce Jun 3, 2023
47dec14
config: let go-generate to produce config-vXX.json files (#5446)
algorandskiy Jun 3, 2023
5faa4d0
typo: Fix typo in blockService_test.go (#5448)
eltociear Jun 3, 2023
913478a
block rpc: Memory counter for http block requests (#5428)
algonautshant Jun 5, 2023
4b70342
tools: EvalDelta and ConsensusParams x-repo type checks (#5381)
tzaffi Jun 5, 2023
1994341
api: Fix errFailedRetrievingStateDelta response. (#5452)
winder Jun 5, 2023
6b712a1
CI: don't use deprecated set-output in github actions (#5453)
tzaffi Jun 6, 2023
1230e9a
tools: bugfix block-generator to handle conduit's Init block requests…
tzaffi Jun 7, 2023
9f8cc8d
Algod: Leverage 2 SRV record providers for resolving relay addresses …
gmalouf Jun 7, 2023
3fbc4b6
netgoal: fix large db generation (#5445)
AlgoAxel Jun 7, 2023
78b0a81
build: remove boost dependency and internal sortition package (#5459)
cce Jun 8, 2023
fd60def
build: update falcon to v0.1.0 for new CFLAGS (#5460)
cce Jun 8, 2023
d5593a4
network: peer selector expansion and PeersPhonebookArchivalNodes (#5385)
algonautshant Jun 8, 2023
5ff0c22
tools: prepare block-generator for configuring apps (#5443)
tzaffi Jun 9, 2023
8ab4aad
genesis: add GenesisAccountData type for use in GenesisAllocation (#5…
cce Jun 13, 2023
9a644f6
AVM: proper cross product check for app put and del (#5467)
jannotti Jun 14, 2023
7b69c1b
flake: TestLedgerContinuesOnVotersCallbackFailure (#5454)
tzaffi Jun 14, 2023
79697d5
metrics: Add LedgerDBRound gauge (#5456)
cce Jun 14, 2023
9aee021
Build: Golang 1.20 upgrade. (#5462)
gmalouf Jun 15, 2023
4d6e50d
tools: block-generator applications. Part 1: create (#5450)
tzaffi Jun 15, 2023
96c9845
cmd/updater: add install directory to logging (#5466)
bbroder-algo Jun 15, 2023
05f1c72
encoding: Update go-codec version. (#5471)
winder Jun 16, 2023
2eb239b
Chore: Use strings.Cut for clarity (#5474)
jannotti Jun 16, 2023
07f9431
network: improve MsgOfInterest message handling (#5476)
cce Jun 16, 2023
ad03111
ledger: refactor store module interfaces before kv impl merge (#5451)
icorderi Jun 16, 2023
ae02370
tools: replace upload_metrics (#5470)
shiqizng Jun 16, 2023
b26c355
Merge remote-tracking branch 'origin/rel/stable' into relstable3.16.2…
Algo-devops-service Jun 20, 2023
9d425e3
Bump Version, Remove buildnumber.dat and genesistimestamp.dat files.
Algo-devops-service Jun 20, 2023
f83a656
network: discard unrequested or stale block messages (#5431)
iansuvak Jun 20, 2023
0824e4a
Build: Disable goexperiments in our builds due to issue present in Go…
gmalouf Jun 21, 2023
5f496cf
cleanup: remove indexer v1 from codebase (#5477)
gmalouf Jun 21, 2023
5d65abf
Merge pull request #5482 from Algo-devops-service/relstable3.16.2-rem…
algojohnlee Jun 21, 2023
b06de44
Build: Split nightly job into its own workflow. Remove ARM64 platform…
gmalouf Jun 21, 2023
227df93
api: Disable body limit middleware for admin endpoints. (#5486)
winder Jun 22, 2023
7a282c8
netdeploy: Add AdminAPIToken to network templates (#5473)
algorandskiy Jun 22, 2023
f5ad6a5
tests: flaky tests fixes (#5487)
algorandskiy Jun 22, 2023
21525f6
CI: Don't run tests during benchmark (#5491)
jasonpaulos Jun 22, 2023
91185ae
Chore: Use exp/slices and exp/maps to simplify some code (#5479)
jannotti Jun 22, 2023
f514d82
tests: fix flaky ledger stateproof and rpcs tests (#5494)
algorandskiy Jun 23, 2023
c547097
Chore: more deadcode (#5495)
jannotti Jun 23, 2023
f56b9bd
algocfg: Add EnableTxnEvalTracer to algocfg development profile. (#5481)
winder Jun 23, 2023
c223dbc
network: Limit message length based on Tag (#5388)
iansuvak Jun 23, 2023
e96d104
catchup: Add HEAD request to catchpoint service start (#5393)
Eric-Warehime Jun 24, 2023
68a4aba
Chore: Use generics to simplify some code in v2 (#5497)
ahangsu Jun 24, 2023
4f42233
Merge remote-tracking branch 'upstream/rel/stable' into onetechnical/…
onetechnical Jun 26, 2023
970d2a1
Fix: goal clerk rawsend print pending round rather than ptr to round …
ahangsu Jun 26, 2023
8dba54b
Merge pull request #5500 from onetechnical/onetechnical/relstable3.16…
algojohnlee Jun 26, 2023
df22f75
Chore: apply `golang.org/x/exp/constraints` to `overflow.go` (#5501)
ahangsu Jun 26, 2023
6d7913c
algocfg: Remove block validation override from participation profile.…
winder Jun 27, 2023
068b375
config: update MaxCatchpointDownloadDuration to 12h (#5503)
cce Jun 27, 2023
74b5f19
tools: block generator apps. Part 2: boxes (#5478)
tzaffi Jun 27, 2023
22e0e09
goal: account info with deleted asset suppress error and better outpu…
ahangsu Jun 28, 2023
533507a
tests: Fix catchpoint catchup tests to use relay for catchup (#5507)
Eric-Warehime Jun 28, 2023
68ebeb5
docker: fix slow docker container start up (#5513)
shiqizng Jun 28, 2023
11a180f
API: Allow DELETE calls (#5515)
AustP Jun 29, 2023
06fedda
follower: Use Buffered syncNow channel to correctly trigger sync in p…
algochoi Jun 29, 2023
0bc522d
network:ws block byte limiter (#5472)
iansuvak Jun 29, 2023
5ed50c4
tools: block generator inner transactions (#5506)
tzaffi Jun 30, 2023
dcafb65
tests: fix rawsend.sh nightly test failure (#5519)
ahangsu Jun 30, 2023
2f38415
docker: Start kmd in the background. (#5514)
winder Jun 30, 2023
83aee2e
bugfix: ensure blockservice callbacks are not nil (#5518)
iansuvak Jun 30, 2023
32466b9
tests: fix TestLedgerReloadStateProofVerificationTracker (#5520)
algorandskiy Jun 30, 2023
8c52ed0
fix: remove unnecessary bash scripts (#5524)
kehiy Jul 4, 2023
f54e7a7
tests: make TestSendMessageCallbacks deterministic (#5523)
iansuvak Jul 4, 2023
55bfa51
tests: reenable TestVotersReloadFromDiskPassRecoveryPeriod (#5496)
algorandskiy Jul 5, 2023
ec9e662
tracer: Default to ledger tracer when starting new evaluator (#5521)
Eric-Warehime Jul 5, 2023
cece133
docker: Additional private network options and container tweaks. (#5525)
winder Jul 6, 2023
3e80027
Chore: Small cleanups for clarity (#5526)
jannotti Jul 6, 2023
e215f6d
block-generator: conduit performance benchmark scenarios. (#5532)
winder Jul 8, 2023
9292c50
Chore: remove a redundant argument to maintain single source of truth…
jannotti Jul 10, 2023
a1569e5
ledger: fix catchpoint pending hashes locking (#5534)
icorderi Jul 10, 2023
217f791
Runtime: Add delete-if-exists check for the no longer used indexer.sq…
gmalouf Jul 10, 2023
4251297
test: Replace timer with counter loop in TestNodeTxHandlerRestart (#5…
algonautshant Jul 10, 2023
924087f
CICD: Update docker containers to newer versions (#5529)
onetechnical Jul 11, 2023
c38ff93
Update the Version, BuildNumber, genesistimestamp.data
Algo-devops-service Jul 11, 2023
c6f3769
Merge pull request #5541 from Algo-devops-service/relbeta3.17.0
algojohnlee Jul 11, 2023
fa0b354
tests: fix coder tester for TxType bound (#5536)
algorandskiy Jul 11, 2023
e21b905
CICD: Fix debian package error (#5552)
onetechnical Jul 11, 2023
80d0226
catchup: Catchup variable reuse (#5551)
Eric-Warehime Jul 12, 2023
aeef625
Algod: Simulate endpoint stack-change exposure (#5440)
ahangsu Jul 12, 2023
8db3d7a
CICD: Update ubuntu circleci image and orbs (#5564)
algobarb Jul 13, 2023
d316914
perf tests: use metrics for memory usage charts (#5565)
algorandskiy Jul 13, 2023
18a33c9
CICD: downgrade ubuntu to 20.04 and ensure ARM64 binaries are built s…
onetechnical Jul 14, 2023
279605a
docs: Fix broken markdown in follower documentation. (#5585)
winder Jul 20, 2023
be237d6
Algod: Simulate endpoint scratch-change exposure (#5563)
ahangsu Jul 20, 2023
bc9f126
tools: let catchpointdump to calculate and print data hashes (#5584)
algorandskiy Jul 20, 2023
0e0b26d
ledger: use single SP verification hash/data query for catchpoint tra…
cce Jul 20, 2023
17d4ebf
goal: support simulate scratch in exec trace (#5589)
ahangsu Jul 20, 2023
548399e
CircleCI: Update macos xcode versions (#5590)
algobarb Jul 20, 2023
1a46ceb
cli: clarify program source flag description (#5571)
kehiy Jul 21, 2023
4a5095e
chore: use string builder instead of string concatenation in catchup …
kehiy Jul 21, 2023
fbfbea1
build: remove sqlite from release configurations (#5562)
cce Jul 21, 2023
b4f6b1f
tools: Reorganize block generator scripts. (#5582)
winder Jul 21, 2023
0c6a328
catchpoint: use read connection for data retrieval for spver hash cal…
cce Jul 21, 2023
197bfb6
ledger: move MakeCatchpointReader back to the Reader interface (#5583)
icorderi Jul 21, 2023
8f4f71b
Merge branch 'rel/beta' into onetechnical/relbeta-remerge
onetechnical Jul 24, 2023
2258edd
Remove buildnumber.dat and genesistimestamp.dat files
onetechnical Jul 24, 2023
1d1fe0f
Merge pull request #5600 from onetechnical/onetechnical/relbeta-remerge
algojohnlee Jul 24, 2023
fbdcd05
Update the Version, BuildNumber, genesistimestamp.data
Algo-devops-service Jul 24, 2023
a0e31a7
Merge pull request #5601 from Algo-devops-service/relbeta3.17.0
algojohnlee Jul 25, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
network: peer selector expansion and PeersPhonebookArchivalNodes (#5385)
  • Loading branch information
algonautshant authored Jun 8, 2023
commit d5593a4426962543778a9a23d9cdeec66144dd02
20 changes: 15 additions & 5 deletions catchup/peerSelector.go
Original file line number Diff line number Diff line change
Expand Up @@ -47,12 +47,16 @@ const (
peerRank3LowBlockTime = 601
peerRank3HighBlockTime = 799

peerRankInitialFifthPriority = 800
peerRank4LowBlockTime = 801
peerRank4HighBlockTime = 999

// peerRankDownloadFailed is used for responses which could be temporary, such as missing files, or such that we don't
// have clear resolution
peerRankDownloadFailed = 900
peerRankDownloadFailed = 10000
// peerRankInvalidDownload is used for responses which are likely to be invalid - whether it's serving the wrong content
// or attempting to serve malicious content
peerRankInvalidDownload = 1000
peerRankInvalidDownload = 12000

// once a block is downloaded, the download duration is clamped into the range of [lowBlockDownloadThreshold..highBlockDownloadThreshold] and
// then mapped into the a ranking range.
Expand Down Expand Up @@ -383,8 +387,10 @@ func (ps *peerSelector) peerDownloadDurationToRank(psp *peerSelectorPeer, blockD
return downloadDurationToRank(blockDownloadDuration, lowBlockDownloadThreshold, highBlockDownloadThreshold, peerRank1LowBlockTime, peerRank1HighBlockTime)
case peerRankInitialThirdPriority:
return downloadDurationToRank(blockDownloadDuration, lowBlockDownloadThreshold, highBlockDownloadThreshold, peerRank2LowBlockTime, peerRank2HighBlockTime)
default: // i.e. peerRankInitialFourthPriority
case peerRankInitialFourthPriority:
return downloadDurationToRank(blockDownloadDuration, lowBlockDownloadThreshold, highBlockDownloadThreshold, peerRank3LowBlockTime, peerRank3HighBlockTime)
default: // i.e. peerRankInitialFifthPriority
return downloadDurationToRank(blockDownloadDuration, lowBlockDownloadThreshold, highBlockDownloadThreshold, peerRank4LowBlockTime, peerRank4HighBlockTime)
}
}

Expand Down Expand Up @@ -520,8 +526,10 @@ func lowerBound(class peerClass) int {
return peerRank1LowBlockTime
case peerRankInitialThirdPriority:
return peerRank2LowBlockTime
default: // i.e. peerRankInitialFourthPriority
case peerRankInitialFourthPriority:
return peerRank3LowBlockTime
default: // i.e. peerRankInitialFifthPriority
return peerRank4LowBlockTime
}
}

Expand All @@ -533,8 +541,10 @@ func upperBound(class peerClass) int {
return peerRank1HighBlockTime
case peerRankInitialThirdPriority:
return peerRank2HighBlockTime
default: // i.e. peerRankInitialFourthPriority
case peerRankInitialFourthPriority:
return peerRank3HighBlockTime
default: // i.e. peerRankInitialFifthPriority
return peerRank4HighBlockTime
}
}

Expand Down
50 changes: 42 additions & 8 deletions catchup/peerSelector_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -381,12 +381,12 @@ func TestPeersDownloadFailed(t *testing.T) {
if len(peerSelector.pools) == 2 {
b1orb2 := peerAddress(peerSelector.pools[0].peers[1].peer) == "b1" || peerAddress(peerSelector.pools[0].peers[1].peer) == "b2"
require.True(t, b1orb2)
require.Equal(t, peerSelector.pools[1].rank, 900)
require.Equal(t, peerSelector.pools[1].rank, peerRankDownloadFailed)
require.Equal(t, len(peerSelector.pools[1].peers), 3)
} else { // len(pools) == 3
b1orb2 := peerAddress(peerSelector.pools[1].peers[0].peer) == "b1" || peerAddress(peerSelector.pools[1].peers[0].peer) == "b2"
require.True(t, b1orb2)
require.Equal(t, peerSelector.pools[2].rank, 900)
require.Equal(t, peerSelector.pools[2].rank, peerRankDownloadFailed)
require.Equal(t, len(peerSelector.pools[2].peers), 3)
}

Expand Down Expand Up @@ -459,6 +459,7 @@ func TestPeerDownloadDurationToRank(t *testing.T) {
peers2 := []network.Peer{&mockHTTPPeer{address: "b1"}, &mockHTTPPeer{address: "b2"}}
peers3 := []network.Peer{&mockHTTPPeer{address: "c1"}, &mockHTTPPeer{address: "c2"}}
peers4 := []network.Peer{&mockHTTPPeer{address: "d1"}, &mockHTTPPeer{address: "b2"}}
peers5 := []network.Peer{&mockHTTPPeer{address: "e1"}, &mockHTTPPeer{address: "b2"}}

peerSelector := makePeerSelector(
makePeersRetrieverStub(func(options ...network.PeerOption) (peers []network.Peer) {
Expand All @@ -469,15 +470,18 @@ func TestPeerDownloadDurationToRank(t *testing.T) {
peers = append(peers, peers2...)
} else if opt == network.PeersConnectedOut {
peers = append(peers, peers3...)
} else {
} else if opt == network.PeersPhonebookArchivalNodes {
peers = append(peers, peers4...)
} else { // PeersConnectedIn
peers = append(peers, peers5...)
}
}
return
}), []peerClass{{initialRank: peerRankInitialFirstPriority, peerClass: network.PeersPhonebookArchivers},
{initialRank: peerRankInitialSecondPriority, peerClass: network.PeersPhonebookRelays},
{initialRank: peerRankInitialThirdPriority, peerClass: network.PeersConnectedOut},
{initialRank: peerRankInitialFourthPriority, peerClass: network.PeersConnectedIn}},
{initialRank: peerRankInitialFourthPriority, peerClass: network.PeersPhonebookArchivalNodes},
{initialRank: peerRankInitialFifthPriority, peerClass: network.PeersConnectedIn}},
)

_, err := peerSelector.getNextPeer()
Expand All @@ -490,7 +494,10 @@ func TestPeerDownloadDurationToRank(t *testing.T) {
require.Equal(t, downloadDurationToRank(500*time.Millisecond, lowBlockDownloadThreshold, highBlockDownloadThreshold, peerRank2LowBlockTime, peerRank2HighBlockTime),
peerSelector.peerDownloadDurationToRank(&peerSelectorPeer{peers3[0], network.PeersConnectedOut}, 500*time.Millisecond))
require.Equal(t, downloadDurationToRank(500*time.Millisecond, lowBlockDownloadThreshold, highBlockDownloadThreshold, peerRank3LowBlockTime, peerRank3HighBlockTime),
peerSelector.peerDownloadDurationToRank(&peerSelectorPeer{peers4[0], network.PeersConnectedIn}, 500*time.Millisecond))
peerSelector.peerDownloadDurationToRank(&peerSelectorPeer{peers4[0], network.PeersPhonebookArchivalNodes}, 500*time.Millisecond))
require.Equal(t, downloadDurationToRank(500*time.Millisecond, lowBlockDownloadThreshold, highBlockDownloadThreshold, peerRank4LowBlockTime, peerRank4HighBlockTime),
peerSelector.peerDownloadDurationToRank(&peerSelectorPeer{peers5[0], network.PeersConnectedIn}, 500*time.Millisecond))

}

func TestLowerUpperBounds(t *testing.T) {
Expand All @@ -499,23 +506,26 @@ func TestLowerUpperBounds(t *testing.T) {
classes := []peerClass{{initialRank: peerRankInitialFirstPriority, peerClass: network.PeersPhonebookArchivers},
{initialRank: peerRankInitialSecondPriority, peerClass: network.PeersPhonebookRelays},
{initialRank: peerRankInitialThirdPriority, peerClass: network.PeersConnectedOut},
{initialRank: peerRankInitialFourthPriority, peerClass: network.PeersConnectedIn}}
{initialRank: peerRankInitialFourthPriority, peerClass: network.PeersConnectedIn},
{initialRank: peerRankInitialFifthPriority, peerClass: network.PeersConnectedIn}}

require.Equal(t, peerRank0LowBlockTime, lowerBound(classes[0]))
require.Equal(t, peerRank1LowBlockTime, lowerBound(classes[1]))
require.Equal(t, peerRank2LowBlockTime, lowerBound(classes[2]))
require.Equal(t, peerRank3LowBlockTime, lowerBound(classes[3]))
require.Equal(t, peerRank4LowBlockTime, lowerBound(classes[4]))

require.Equal(t, peerRank0HighBlockTime, upperBound(classes[0]))
require.Equal(t, peerRank1HighBlockTime, upperBound(classes[1]))
require.Equal(t, peerRank2HighBlockTime, upperBound(classes[2]))
require.Equal(t, peerRank3HighBlockTime, upperBound(classes[3]))
require.Equal(t, peerRank4HighBlockTime, upperBound(classes[4]))
}

func TestFullResetRequestPenalty(t *testing.T) {
partitiontest.PartitionTest(t)

class := peerClass{initialRank: 10, peerClass: network.PeersPhonebookArchivers}
class := peerClass{initialRank: 0, peerClass: network.PeersPhonebookArchivers}
hs := makeHistoricStatus(10, class)
hs.push(5, 1, class)
require.Equal(t, 1, len(hs.requestGaps))
Expand All @@ -524,6 +534,30 @@ func TestFullResetRequestPenalty(t *testing.T) {
require.Equal(t, 0, len(hs.requestGaps))
}

// TesPenaltyBounds makes sure that the penalty does not demote the peer to a lower class,
// and resetting the penalty of a demoted peer does not promote it back
func TestPenaltyBounds(t *testing.T) {
partitiontest.PartitionTest(t)

class := peerClass{initialRank: peerRankInitialThirdPriority, peerClass: network.PeersPhonebookArchivers}
hs := makeHistoricStatus(peerHistoryWindowSize, class)
for x := 0; x < 65; x++ {
r0 := hs.push(peerRank2LowBlockTime+50, uint64(x+1), class)
require.LessOrEqual(t, peerRank2LowBlockTime, r0)
require.GreaterOrEqual(t, peerRank2HighBlockTime, r0)
}

r1 := hs.resetRequestPenalty(4, peerRankInitialThirdPriority, class)
r2 := hs.resetRequestPenalty(10, peerRankInitialThirdPriority, class)
r3 := hs.resetRequestPenalty(10, peerRankDownloadFailed, class)

// r2 is at a better rank than r1 because it has one penalty less
require.Greater(t, r1, r2)

// r3 is worse rank at peerRankDownloadFailed because it was demoted and resetRequestPenalty should not improve it
require.Equal(t, peerRankDownloadFailed, r3)
}

// TestClassUpperBound makes sure the peer rank does not exceed the class upper bound
// This was a bug where the resetRequestPenalty was not bounding the returned rank, and was having download failures.
// Initializing rankSamples to 0 makes this works, since the dropped value subtracts 0 from rankSum.
Expand Down Expand Up @@ -613,7 +647,7 @@ func TestEvictionAndUpgrade(t *testing.T) {
_, err := peerSelector.getNextPeer()
require.NoError(t, err)
for i := 0; i < 10; i++ {
if peerSelector.pools[len(peerSelector.pools)-1].rank == 900 {
if peerSelector.pools[len(peerSelector.pools)-1].rank == peerRankDownloadFailed {
require.Equal(t, 6, i)
break
}
Expand Down
40 changes: 24 additions & 16 deletions catchup/service.go
Original file line number Diff line number Diff line change
Expand Up @@ -816,30 +816,34 @@ func createPeerSelector(net network.GossipNode, cfg config.Local, pipelineFetch
if cfg.NetAddress != "" { // Relay node
peerClasses = []peerClass{
{initialRank: peerRankInitialFirstPriority, peerClass: network.PeersConnectedOut},
{initialRank: peerRankInitialSecondPriority, peerClass: network.PeersPhonebookArchivers},
{initialRank: peerRankInitialThirdPriority, peerClass: network.PeersPhonebookRelays},
{initialRank: peerRankInitialFourthPriority, peerClass: network.PeersConnectedIn},
{initialRank: peerRankInitialSecondPriority, peerClass: network.PeersPhonebookArchivalNodes},
{initialRank: peerRankInitialThirdPriority, peerClass: network.PeersPhonebookArchivers},
{initialRank: peerRankInitialFourthPriority, peerClass: network.PeersPhonebookRelays},
{initialRank: peerRankInitialFifthPriority, peerClass: network.PeersConnectedIn},
}
} else {
peerClasses = []peerClass{
{initialRank: peerRankInitialFirstPriority, peerClass: network.PeersPhonebookArchivers},
{initialRank: peerRankInitialSecondPriority, peerClass: network.PeersConnectedOut},
{initialRank: peerRankInitialThirdPriority, peerClass: network.PeersPhonebookRelays},
{initialRank: peerRankInitialFirstPriority, peerClass: network.PeersPhonebookArchivalNodes},
{initialRank: peerRankInitialSecondPriority, peerClass: network.PeersPhonebookArchivers},
{initialRank: peerRankInitialThirdPriority, peerClass: network.PeersConnectedOut},
{initialRank: peerRankInitialFourthPriority, peerClass: network.PeersPhonebookRelays},
}
}
} else {
if cfg.NetAddress != "" { // Relay node
peerClasses = []peerClass{
{initialRank: peerRankInitialFirstPriority, peerClass: network.PeersConnectedOut},
{initialRank: peerRankInitialSecondPriority, peerClass: network.PeersConnectedIn},
{initialRank: peerRankInitialThirdPriority, peerClass: network.PeersPhonebookRelays},
{initialRank: peerRankInitialFourthPriority, peerClass: network.PeersPhonebookArchivers},
{initialRank: peerRankInitialThirdPriority, peerClass: network.PeersPhonebookArchivalNodes},
{initialRank: peerRankInitialFourthPriority, peerClass: network.PeersPhonebookRelays},
{initialRank: peerRankInitialFifthPriority, peerClass: network.PeersPhonebookArchivers},
}
} else {
peerClasses = []peerClass{
{initialRank: peerRankInitialFirstPriority, peerClass: network.PeersConnectedOut},
{initialRank: peerRankInitialSecondPriority, peerClass: network.PeersPhonebookRelays},
{initialRank: peerRankInitialThirdPriority, peerClass: network.PeersPhonebookArchivers},
{initialRank: peerRankInitialSecondPriority, peerClass: network.PeersPhonebookArchivalNodes},
{initialRank: peerRankInitialThirdPriority, peerClass: network.PeersPhonebookRelays},
{initialRank: peerRankInitialFourthPriority, peerClass: network.PeersPhonebookArchivers},
}
}
}
Expand All @@ -848,26 +852,30 @@ func createPeerSelector(net network.GossipNode, cfg config.Local, pipelineFetch
if cfg.NetAddress != "" { // Relay node
peerClasses = []peerClass{
{initialRank: peerRankInitialFirstPriority, peerClass: network.PeersConnectedOut},
{initialRank: peerRankInitialSecondPriority, peerClass: network.PeersPhonebookRelays},
{initialRank: peerRankInitialThirdPriority, peerClass: network.PeersConnectedIn},
{initialRank: peerRankInitialSecondPriority, peerClass: network.PeersPhonebookArchivalNodes},
{initialRank: peerRankInitialThirdPriority, peerClass: network.PeersPhonebookRelays},
{initialRank: peerRankInitialFourthPriority, peerClass: network.PeersConnectedIn},
}
} else {
peerClasses = []peerClass{
{initialRank: peerRankInitialFirstPriority, peerClass: network.PeersConnectedOut},
{initialRank: peerRankInitialSecondPriority, peerClass: network.PeersPhonebookRelays},
{initialRank: peerRankInitialFirstPriority, peerClass: network.PeersPhonebookArchivalNodes},
{initialRank: peerRankInitialSecondPriority, peerClass: network.PeersConnectedOut},
{initialRank: peerRankInitialThirdPriority, peerClass: network.PeersPhonebookRelays},
}
}
} else {
if cfg.NetAddress != "" { // Relay node
peerClasses = []peerClass{
{initialRank: peerRankInitialFirstPriority, peerClass: network.PeersConnectedOut},
{initialRank: peerRankInitialSecondPriority, peerClass: network.PeersConnectedIn},
{initialRank: peerRankInitialThirdPriority, peerClass: network.PeersPhonebookRelays},
{initialRank: peerRankInitialThirdPriority, peerClass: network.PeersPhonebookArchivalNodes},
{initialRank: peerRankInitialFourthPriority, peerClass: network.PeersPhonebookRelays},
}
} else {
peerClasses = []peerClass{
{initialRank: peerRankInitialFirstPriority, peerClass: network.PeersConnectedOut},
{initialRank: peerRankInitialSecondPriority, peerClass: network.PeersPhonebookRelays},
{initialRank: peerRankInitialSecondPriority, peerClass: network.PeersPhonebookArchivalNodes},
{initialRank: peerRankInitialThirdPriority, peerClass: network.PeersPhonebookRelays},
}
}
}
Expand Down
Loading