1
|
|
|
<?php |
2
|
|
|
$defflip = (!cfip()) ? exit(header('HTTP/1.1 401 Unauthorized')) : 1; |
3
|
|
|
|
4
|
|
|
|
5
|
|
|
/** |
6
|
|
|
* Our coin base class that we extend our other coins from |
7
|
|
|
* |
8
|
|
|
* We are implementing all basic coin methods into this class but it |
9
|
|
|
* must be extended for customized coins. |
10
|
|
|
**/ |
11
|
|
|
class CoinBase extends Base { |
12
|
|
|
// Our coins target bits |
13
|
|
|
protected $target_bits = NULL; |
14
|
|
|
|
15
|
|
|
// Our coins share difficulty precision |
16
|
|
|
protected $share_difficulty_precision = 0; |
17
|
|
|
|
18
|
|
|
// Our coin value precision, mostly used on frontend |
19
|
|
|
protected $coin_value_precision = 8; |
20
|
|
|
|
21
|
|
|
/** |
22
|
|
|
* Read our target bits |
23
|
|
|
**/ |
24
|
|
|
public function getTargetBits() { |
25
|
|
|
return $this->target_bits; |
26
|
|
|
} |
27
|
|
|
|
28
|
|
|
/** |
29
|
|
|
* Read our coin value precision |
30
|
|
|
**/ |
31
|
|
|
public function getCoinValuePrevision() { |
32
|
|
|
return $this->coin_value_precision; |
33
|
|
|
} |
34
|
|
|
|
35
|
|
|
/** |
36
|
|
|
* Read our share difficulty precision |
37
|
|
|
**/ |
38
|
|
|
public function getShareDifficultyPrecision() { |
39
|
|
|
return $this->share_difficulty_precision; |
40
|
|
|
} |
41
|
|
|
|
42
|
|
|
/** |
43
|
|
|
* Calculate the PPS value for this coin |
44
|
|
|
* WARNING: Get this wrong and you will over- or underpay your miners! |
45
|
|
|
**/ |
46
|
|
|
public function calcPPSValue($pps_reward, $dDifficulty) { |
47
|
|
|
return ($pps_reward / (pow(2, $this->target_bits) * $dDifficulty)); |
48
|
|
|
} |
49
|
|
|
|
50
|
|
|
/** |
51
|
|
|
* Calculate our hashrate based on shares inserted to DB |
52
|
|
|
* We use diff1 share values, not a baseline one |
53
|
|
|
**/ |
54
|
|
|
public function calcHashrate($shares, $interval) { |
55
|
|
|
return $shares * pow(2, $this->target_bits) / $interval / 1000; |
56
|
|
|
} |
57
|
|
|
|
58
|
|
|
/** |
59
|
|
|
* Calculate estimated shares of this coin, this is using baseline |
60
|
|
|
* according to our configuration difficulty |
61
|
|
|
**/ |
62
|
|
|
public function calcEstaimtedShares($dDifficulty) { |
63
|
|
|
return (float)round(pow(2, (32 - $this->target_bits)) * $dDifficulty, $this->share_difficulty_precision); |
64
|
|
|
} |
65
|
|
|
|
66
|
|
|
/** |
67
|
|
|
* Calculate our networks expected time per block |
68
|
|
|
**/ |
69
|
|
|
public function calcNetworkExpectedTimePerBlock($dDifficulty, $dNetworkHashrate) { |
70
|
|
|
if ($dNetworkHashrate > 0) { |
71
|
|
|
return pow(2, 32) * $dDifficulty / $dNetworkHashrate; |
72
|
|
|
} else { |
73
|
|
|
return 0; |
74
|
|
|
} |
75
|
|
|
} |
76
|
|
|
/** |
77
|
|
|
* Calculate next expected difficulty based on current difficulty |
78
|
|
|
**/ |
79
|
|
|
public function calcExpectedNextDifficulty($dDifficulty, $dNetworkHashrate) { |
80
|
|
|
$iExpectedTimePerBlock = $this->calcNetworkExpectedTimePerBlock($dDifficulty, $dNetworkHashrate); |
81
|
|
|
if (!empty($iExpectedTimePerBlock) && $iExpectedTimePerBlock > 0) { |
82
|
|
|
return round($dDifficulty * $this->config['cointarget'] / $iExpectedTimePerBlock, 8); |
|
|
|
|
83
|
|
|
} else { |
84
|
|
|
return 0; |
85
|
|
|
} |
86
|
|
|
} |
87
|
|
|
} |
88
|
|
|
|
In PHP it is possible to write to properties without declaring them. For example, the following is perfectly valid PHP code:
Generally, it is a good practice to explictly declare properties to avoid accidental typos and provide IDE auto-completion: