-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathgenerate.js
79 lines (62 loc) · 2.05 KB
/
generate.js
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
var redis = require('./redis');
var config = require('./config');
var Stratum = require('./stratum');
// When I'm doing testing of other things, I don't need to bog down the pool server
exports.available = false;
exports.difficulty = 32;
if (!config.stratum.active) return;
// Set up some vars
var workEvents = [];
var validJobs = [];
var stratum = new Stratum(config.stratum, function() {
var stratum = this;
this.request('mining.subscribe', function(err, results) {
if (err) return console.log('mining.subscribe', 'error', err);
this.extraNonce1 = results[1];
this.extraNonce2Size = results[2];
this.request('mining.authorize', [stratum.config.username, stratum.config.password], function(err, results) {
if (err) return console.log('mining.authorize', 'error', err);
if (!results) return console.log('mining.authorize', 'failed');
});
});
});
stratum.on('mining.set_difficulty', function(message) {
exports.difficulty = message.params[0];
console.log('Difficulty Changed', exports.difficulty);
});
stratum.on('mining.notify', function(message) {
var p = message.params;
var work = {
jobId: p[0]
, previousHash: p[1]
, coinBase1: p[2]
, coinBase2: p[3]
, extraNonce: this.extraNonce1
, extraNonceSize: this.extraNonce2Size
, merkleBranch: p[4]
, version: p[5]
, bits: p[6]
, time: p[7]
, cleanJobs: p[8]
};
// Clean jobs, if we're told to
if (p[8]) validJobs.length = 0;
// Add it to the valid jobs array
if (validJobs.indexOf(p[0]) < 0) validJobs.push(p[0]);
// Notify listeners
for (var i = 0; i < workEvents.length; i += 1) {
(workEvents[i])(work);
}
});
function onWork(callback) {
workEvents.push(callback);
};
function submitWork(params, callback) {
// Don't bother if the job isn't valid anymore
if (config.rejectAssumedStales && (validJobs.indexOf(params[1]) < 0)) return (typeof callback === 'function' ? callback('Stale Job') : false);
stratum.request('mining.submit', params, callback);
};
exports.difficulty = 32;
exports.available = true;
exports.onWork = onWork;
exports.submitWork = submitWork;