-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathbeacon_api.py
85 lines (70 loc) · 3.62 KB
/
beacon_api.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
import requests
import os
def estimate_entry_waiting_time():
response = requests.get('https://beaconcha.in/api/v1/validators/queue')
data = response.json()
beacon_entering = data["data"]["beaconchain_entering"]
active_validators = data["data"]["validatorscount"]
churn_limit = max(4, active_validators // 65536)
activation_rate_per_epoch = churn_limit # 4 validators per epoch (every 6.4 minutes) as a minimum
waiting_time_epochs = beacon_entering / activation_rate_per_epoch
waiting_time_seconds = waiting_time_epochs * 12 * 32 # 12 seconds per slot, 32 slots per epoch
waiting_time_minutes = waiting_time_seconds // 60
waiting_time_seconds = round(waiting_time_seconds % 60)
waiting_time_hours = waiting_time_minutes // 60
waiting_time_minutes = round(waiting_time_minutes % 60)
return waiting_time_hours, waiting_time_minutes, waiting_time_seconds, beacon_entering, active_validators
def estimate_exit_waiting_time():
validator_queue_url = "https://beaconcha.in/api/v1/validators/queue"
validator_queue_data = requests.get(validator_queue_url).json()
beacon_exiting = validator_queue_data["data"]["beaconchain_exiting"]
active_validators = validator_queue_data["data"]["validatorscount"]
churn_limit = max(4, active_validators // 65536)
waiting_time_epochs = beacon_exiting / churn_limit
waiting_time_seconds = waiting_time_epochs * 12 * 32 # 12 seconds per slot, 32 slots per epoch
waiting_time_minutes = waiting_time_seconds // 60
waiting_time_seconds = round(waiting_time_seconds % 60)
waiting_time_hours = waiting_time_minutes // 60
waiting_time_minutes = round(waiting_time_minutes % 60)
return waiting_time_hours, waiting_time_minutes, waiting_time_seconds, beacon_exiting, active_validators
def generate_html(entry_waiting_time_hours, entry_waiting_time_minutes, beacon_entering, exit_waiting_time_hours, exit_waiting_time_minutes, beacon_exiting, active_validators):
html_content = f"""<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Validator Queue</title>
<style>
body {{
font-family: Arial, sans-serif;
max-width: 800px;
margin: 0 auto;
background-color: #f4f4f4;
padding: 1rem;
}}
h1 {{
color: #333;
font-size: 2rem;
}}
p {{
font-size: 1.1rem;
color: #666;
margin-bottom: 1.5rem;
}}
</style>
</head>
<body>
<h1>Ethereum 2.0 Validator Queue</h1>
<p>Estimated waiting time for new validators: {entry_waiting_time_hours} hours and {entry_waiting_time_minutes} minutes</p>
<p>Pending validators (entry queue): {beacon_entering}</p>
<p>Estimated waiting time for exit queue: {exit_waiting_time_hours} hours and {exit_waiting_time_minutes} minutes</p>
<p>Pending validators (exit queue): {beacon_exiting}</p>
<p>Active validators: {active_validators}</p>
</body>
</html>"""
with open("index.html", "w") as f:
f.write(html_content)
entry_waiting_time_hours, entry_waiting_time_minutes, entry_waiting_time_seconds, beacon_entering, active_validators = estimate_entry_waiting_time()
exit_waiting_time_hours, exit_waiting_time_minutes, exit_waiting_time_seconds, beacon_exiting, active_validators = estimate_exit_waiting_time()
generate_html(entry_waiting_time_hours, entry_waiting_time_minutes, beacon_entering, exit_waiting_time_hours, exit_waiting_time_minutes, beacon_exiting, active_validators)