This repository has been archived by the owner on Jun 8, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathstats.py
78 lines (63 loc) · 2.71 KB
/
stats.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
import time
from statistics import mean,StatisticsError
import backoff
import requests
from utils import Utils
API_BASE = Utils.apiBase
API_EXPLORER_BASE = Utils.apiExplorerBase
ALPH_BASE = 10 ** 18
class Stats:
def __init__(self, unitName, watcherHandler,):
self.unitName = unitName
self.watcher = watcherHandler
@staticmethod
@backoff.on_exception(backoff.expo, (requests.exceptions.ConnectionError, requests.exceptions.Timeout), max_tries=Utils.BACKOFF_MAX_TRIES)
def avgHashrateAPI(timeSince=None, timeUntil=None):
if timeUntil is None:
timeUntil = time.time()
avgHashrate = list()
session = requests.Session()
try:
response = session.get(
f"{API_BASE}/infos/history-hashrate?fromTs={int(timeSince) * 1000}&toTs={int(timeUntil) * 1000}",
headers=Utils.apiKey,timeout=Utils.TIMEOUT_REQ)
except Exception as e:
print(e)
return 0
if response.json().get('hashrate'):
hashrate = float(response.json().get('hashrate').split(' ')[0].strip())
if hashrate > 0:
avgHashrate.append(hashrate)
else:
return 0
try:
return mean(list(map(int, avgHashrate)))
except StatisticsError:
return 0
@staticmethod
@backoff.on_exception(Utils.BACKOFF_ALGO, (requests.exceptions.ConnectionError, requests.exceptions.Timeout), max_tries=Utils.BACKOFF_MAX_TRIES)
def circulatingAlph():
try:
s = requests.Session()
response = s.get(f"{API_EXPLORER_BASE}/infos/supply/circulating-alph",headers=Utils.apiKey,timeout=Utils.TIMEOUT_REQ)
return "{:,.0f}".format(float(response.text)).replace(',', ' ')
except requests.exceptions as e:
print(e)
return ""
@staticmethod
@backoff.on_exception(Utils.BACKOFF_ALGO, (requests.exceptions.ConnectionError, requests.exceptions.Timeout), max_tries=Utils.BACKOFF_MAX_TRIES)
def rewardMining():
# from capito27
s = requests.Session()
try:
for block in s.get(f'{API_EXPLORER_BASE}/blocks').json()['blocks']:
transaction = s.get(f"{API_EXPLORER_BASE}/blocks/{block['hash']}/transactions",headers=Utils.apiKey,timeout=Utils.TIMEOUT_REQ).json()
for data in transaction:
if len(data['inputs']) <= 0 < len(data.get('outputs')):
return float(data['outputs'][0]['amount']) / ALPH_BASE
except Exception as e:
print(e)
return 0
def getNumberTransactions(self, start, end):
txs = self.watcher.getBlockTsTransactions(start, end)
return len(txs)