| 
									
										
										
										
											2017-08-29 14:13:11 +03:00
										 |  |  | // Copyright 2017 The go-ethereum Authors | 
					
						
							|  |  |  | // This file is part of the go-ethereum library. | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // The go-ethereum library is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  | // it under the terms of the GNU Lesser General Public License as published by | 
					
						
							|  |  |  | // the Free Software Foundation, either version 3 of the License, or | 
					
						
							|  |  |  | // (at your option) any later version. | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // The go-ethereum library is distributed in the hope that it will be useful, | 
					
						
							|  |  |  | // but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | 
					
						
							|  |  |  | // GNU Lesser General Public License for more details. | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // You should have received a copy of the GNU Lesser General Public License | 
					
						
							|  |  |  | // along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | package params | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // These are network parameters that need to be constant between clients, but | 
					
						
							| 
									
										
										
										
											2018-08-28 15:08:16 +08:00
										 |  |  | // aren't necessarily consensus related. | 
					
						
							| 
									
										
										
										
											2017-08-29 14:13:11 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | const ( | 
					
						
							|  |  |  | 	// BloomBitsBlocks is the number of blocks a single bloom bit section vector | 
					
						
							| 
									
										
										
										
											2018-08-28 15:08:16 +08:00
										 |  |  | 	// contains on the server side. | 
					
						
							| 
									
										
										
										
											2017-08-29 14:13:11 +03:00
										 |  |  | 	BloomBitsBlocks uint64 = 4096 | 
					
						
							| 
									
										
										
										
											2018-08-28 15:08:16 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// BloomBitsBlocksClient is the number of blocks a single bloom bit section vector | 
					
						
							|  |  |  | 	// contains on the light client side | 
					
						
							|  |  |  | 	BloomBitsBlocksClient uint64 = 32768 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// BloomConfirms is the number of confirmation blocks before a bloom section is | 
					
						
							|  |  |  | 	// considered probably final and its rotated bits are calculated. | 
					
						
							|  |  |  | 	BloomConfirms = 256 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-05 17:40:03 +02:00
										 |  |  | 	// CHTFrequency is the block frequency for creating CHTs | 
					
						
							|  |  |  | 	CHTFrequency = 32768 | 
					
						
							| 
									
										
										
										
											2018-08-28 15:08:16 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	// BloomTrieFrequency is the block frequency for creating BloomTrie on both | 
					
						
							|  |  |  | 	// server/client sides. | 
					
						
							|  |  |  | 	BloomTrieFrequency = 32768 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// HelperTrieConfirmations is the number of confirmations before a client is expected | 
					
						
							|  |  |  | 	// to have the given HelperTrie available. | 
					
						
							|  |  |  | 	HelperTrieConfirmations = 2048 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// HelperTrieProcessConfirmations is the number of confirmations before a HelperTrie | 
					
						
							|  |  |  | 	// is generated | 
					
						
							|  |  |  | 	HelperTrieProcessConfirmations = 256 | 
					
						
							| 
									
										
										
										
											2019-05-15 14:33:33 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												all: on-chain oracle checkpoint syncing (#19543)
* all: implement simple checkpoint syncing
cmd, les, node: remove callback mechanism
cmd, node: remove callback definition
les: simplify the registrar
les: expose checkpoint rpc services in the light client
les, light: don't store untrusted receipt
cmd, contracts, les: discard stale checkpoint
cmd, contracts/registrar: loose restriction of registeration
cmd, contracts: add replay-protection
all: off-chain multi-signature contract
params: deploy checkpoint contract for rinkeby
cmd/registrar: add raw signing mode for registrar
cmd/registrar, contracts/registrar, les: fixed messages
* cmd/registrar, contracts/registrar: fix lints
* accounts/abi/bind, les: address comments
* cmd, contracts, les, light, params: minor checkpoint sync cleanups
* cmd, eth, les, light: move checkpoint config to config file
* cmd, eth, les, params: address comments
* eth, les, params: address comments
* cmd: polish up the checkpoint admin CLI
* cmd, contracts, params: deploy new version contract
* cmd/checkpoint-admin: add another flag for clef mode signing
* cmd, contracts, les: rename and regen checkpoint oracle with abigen
											
										 
											2019-06-28 15:34:02 +08:00
										 |  |  | 	// CheckpointFrequency is the block frequency for creating checkpoint | 
					
						
							|  |  |  | 	CheckpointFrequency = 32768 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// CheckpointProcessConfirmations is the number before a checkpoint is generated | 
					
						
							|  |  |  | 	CheckpointProcessConfirmations = 256 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-13 17:02:54 +08:00
										 |  |  | 	// FullImmutabilityThreshold is the number of blocks after which a chain segment is | 
					
						
							| 
									
										
										
										
											2019-05-15 14:33:33 +03:00
										 |  |  | 	// considered immutable (i.e. soft finality). It is used by the downloader as a | 
					
						
							|  |  |  | 	// hard limit against deep ancestors, by the blockchain against deep reorgs, by | 
					
						
							| 
									
										
										
										
											2020-05-25 16:21:28 +08:00
										 |  |  | 	// the freezer as the cutoff threshold and by clique as the snapshot trust limit. | 
					
						
							| 
									
										
										
										
											2020-07-13 17:02:54 +08:00
										 |  |  | 	FullImmutabilityThreshold = 90000 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// LightImmutabilityThreshold is the number of blocks after which a header chain | 
					
						
							|  |  |  | 	// segment is considered immutable for light client(i.e. soft finality). It is used by | 
					
						
							|  |  |  | 	// the downloader as a hard limit against deep ancestors, by the blockchain against deep | 
					
						
							|  |  |  | 	// reorgs, by the light pruner as the pruning validity guarantee. | 
					
						
							|  |  |  | 	LightImmutabilityThreshold = 30000 | 
					
						
							| 
									
										
										
										
											2017-08-29 14:13:11 +03:00
										 |  |  | ) |