-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathglobal.tradeLogger.js
57 lines (43 loc) · 2 KB
/
global.tradeLogger.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
module.exports = class TradeLogger {
constructor() {
if(!Memory.tradeLogs) {
Memory.tradeLogs = {
lastTick: 0,
players: {}
}
}
this.memory = Memory.tradeLogs;
}
logTrades() {
let lastProcessedTick = 0;
for(let transaction of Game.market.incomingTransactions) {
if(transaction.time <= this.memory.lastTick) continue;
if(lastProcessedTick < transaction.time) lastProcessedTick = transaction.time;
let sender = transaction.sender && transaction.sender.username;
if(sender === "NobodysNightmare") continue;
if(transaction.order) sender = "Market";
if(!sender) continue;
if(!this.memory.players[sender]) {
this.memory.players[sender] = {}
}
let current = this.memory.players[sender][transaction.resourceType];
this.memory.players[sender][transaction.resourceType] = (current || 0) + transaction.amount;
}
for(let transaction of Game.market.outgoingTransactions) {
if(transaction.time <= this.memory.lastTick) continue;
if(lastProcessedTick < transaction.time) lastProcessedTick = transaction.time;
let recipient = transaction.recipient && transaction.recipient.username;
if(recipient === "NobodysNightmare") continue;
if(transaction.order) recipient = "Market";
if(!recipient) continue;
if(!this.memory.players[recipient]) {
this.memory.players[recipient] = {}
}
let current = this.memory.players[recipient][transaction.resourceType];
this.memory.players[recipient][transaction.resourceType] = (current || 0) - transaction.amount;
}
if(lastProcessedTick > this.memory.lastTick) this.memory.lastTick = lastProcessedTick;
}
}
const profiler = require("screeps-profiler");
profiler.registerClass(module.exports, 'TradeLogger');