mirror of
https://github.com/embarklabs/subspace.git
synced 2025-01-11 06:47:03 +00:00
feat: use a single subscription/interval for calls
This commit is contained in:
parent
3425c1e851
commit
34ca4a7563
@ -9,14 +9,17 @@ const Web3Eth = require('web3-eth');
|
|||||||
|
|
||||||
class EventSyncer {
|
class EventSyncer {
|
||||||
|
|
||||||
constructor(provider, options, ) {
|
constructor(provider, options = {}) {
|
||||||
this.events = new Events();
|
this.events = new Events();
|
||||||
this.web3 = new Web3Eth(provider);
|
this.web3 = new Web3Eth(provider);
|
||||||
this.intervalTracker = [];
|
|
||||||
|
|
||||||
this.options = {};
|
this.options = {};
|
||||||
this.options.callInterval = options.callInterval || 0;
|
this.options.callInterval = options.callInterval || 0;
|
||||||
this.options.dbFilename = options.dbFilename || 'phoenix.db';
|
this.options.dbFilename = options.dbFilename || 'phoenix.db';
|
||||||
|
|
||||||
|
this.newBlocksSubscription = null;
|
||||||
|
this.intervalTracker = null;
|
||||||
|
this.callMethods = [];
|
||||||
}
|
}
|
||||||
|
|
||||||
init() {
|
init() {
|
||||||
@ -84,8 +87,35 @@ class EventSyncer {
|
|||||||
return sub;
|
return sub;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
_initNewBlocksSubscription() {
|
||||||
|
if(this.newBlocksSubscription != null || this.options.callInterval !== 0) return;
|
||||||
|
|
||||||
|
this.newBlocksSubscription = this.web3.subscribe('newBlockHeaders', (err, result) => {
|
||||||
|
if(err) {
|
||||||
|
sub.error(err);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.callMethods.forEach(fn => {
|
||||||
|
fn();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
_initCallInterval() {
|
||||||
|
if(this.intervalTracker != null || this.options.callInterval === 0) return;
|
||||||
|
|
||||||
|
this.intervalTracker = setInterval(() => {
|
||||||
|
this.callMethods.forEach(fn => {
|
||||||
|
fn();
|
||||||
|
});
|
||||||
|
}, this.options.callInterval);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
// TODO: should save value in database
|
// TODO: should save value in database
|
||||||
trackProperty(contractInstance, propName, methodArgs = [], callArgs = {}) {
|
trackProperty(contractInstance, propName, methodArgs = [], callArgs = {}) {
|
||||||
|
|
||||||
const sub = new ReplaySubject();
|
const sub = new ReplaySubject();
|
||||||
|
|
||||||
const method = contractInstance.methods[propName].apply(contractInstance.methods[propName], methodArgs)
|
const method = contractInstance.methods[propName].apply(contractInstance.methods[propName], methodArgs)
|
||||||
@ -101,24 +131,19 @@ class EventSyncer {
|
|||||||
|
|
||||||
callContractMethod();
|
callContractMethod();
|
||||||
|
|
||||||
if(this.options.callInterval > 0){
|
this._initNewBlocksSubscription();
|
||||||
this.intervalTracker.push(setInterval(callContractMethod, this.options.callInterval));
|
this._initCallInterval();
|
||||||
} else {
|
|
||||||
this.web3.subscribe('newBlockHeaders', (err, result) => {
|
this.callMethods.push(callContractMethod);
|
||||||
if(err) {
|
|
||||||
sub.error(err);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
callContractMethod();
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
return sub.pipe(distinctUntilChanged((a, b) => equal(a, b)));
|
return sub.pipe(distinctUntilChanged((a, b) => equal(a, b)));
|
||||||
}
|
}
|
||||||
|
|
||||||
clear(){
|
clear(){
|
||||||
this.intervalTracker.forEach(clearInterval);
|
clearInterval(this.intervalTracker);
|
||||||
this.intervalTracker = [];
|
this.newBlocksSubscription.unsubscribe();
|
||||||
|
this.intervalTracker = null;
|
||||||
|
this.callMethods = [];
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user