-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcryptoManager.js
114 lines (99 loc) · 4.69 KB
/
cryptoManager.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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
const DBO = require("./db/dbo");
const dao = new DBO("./db/db/web.sqlite");
const crypto_lib = require("provider-js/src/provider");
const user_manager = require("./userManager");
const proccess = require("process")
/**
* Add to database that user with uID has bought tour with tID
* @param {int} tID the tour id
* @param {int} uID the user id
*/
module.exports.userBoughtTour = async (tID, uID) => {
try {
await dao.run('INSERT INTO userTours(tourID, userID) VALUES(?,?)', [tID, uID]);
} catch (e) {
console.log("Error adding user to bought tours in database");
}
}
/**
* Lookup wallet id in user database
* @param {string} walledId the wallet id to find the user
* @returns {int} the user id of the user with the specified wallet (or -1 if not found or multiple users found)
*/
module.exports.walletToUser = async (walledId) => {
var user = await dao.get('SELECT uID from user WHERE walletID = ?', [walledId]);
if (user.length == 1) {
return user[0].uID;
}
return -1;
}
module.exports.connectBlockchain = async () => {
try {
var chain = proccess.env.CHAIN_PROVIDER_URL;
var network_id = proccess.env.CHAIN_NETWORK_ID;
console.log(`[CRYPTO]: Connecting to Chain at ${chain} with network id ${network_id}`)
crypto_lib.setProviderURL(chain);
crypto_lib.setNetworkId(network_id);
// TODO: add contract files after deploying to correct blockchain
crypto_lib.initTourTokenFactoryListener(__dirname + "/contracts/TourTokenFactory.json");
crypto_lib.initBFactoryListener(__dirname + "/contracts/BFactory.json");
// add all currently in db tours to watching
var tours = await dao.get("SELECT tokenAddress from tour");
for (i = 0; i < tours.length; i++) {
var tokenAddress = tours[i].tokenAddress;
if (tokenAddress == undefined || tokenAddress == "") continue;
console.log("[CRYPTO]: Startup - watch existing tour token at " + tokenAddress);
crypto_lib.addTT(__dirname + '/contracts/TourTokenTemplate.json', tokenAddress);
}
console.log("[CRYPTO]: Register TourTokenOrder callback...");
crypto_lib.registerCallback("TourTokenOrder", async (event) => {
console.log("[CRYPTO]: Someone bought a tour...", event);
var tourId = event.serviceId;
var userAddress = event.payer;
var uID = await user_manager.getUserIdFromAddress(userAddress);
if (uID == undefined) {
console.log(`[CRYPTO]: Tour payer with address ${userAddress} does not exist in Database`);
return;
}
console.log(`[CRYPTO]: User mit uID ${uID} hat die Tour ${event.serviceId} gekauft`);
await this.userBoughtTour(tourId, uID);
})
console.log("[CRYPTO]: Register TourTokenFactory callback...");
crypto_lib.registerCallback("TourTokenFactory", async (event) => {
try {
console.log("[CRYPTO]: Someone created a new TourToken");
// den neuen Token auch mit Überwachen
crypto_lib.addTT(__dirname + '/contracts/TourTokenTemplate.json', event.tokenAddress)
var address = event.tokenAddress;
var tourID = event.tokenName.split("Cryptour-ID:")[1];
await dao.run("UPDATE tour SET tokenAddress = ? WHERE tID = ?", [address, tourID]);
} catch (error) {
console.error("[CRYPTO-ERROR]:", e)
}
})
console.log("[CRYPTO]: Register BFactory callback...");
crypto_lib.registerCallback("BFactory", (event) => {
try {
console.log(`[CRYPTO]: Balancer Pool created at address ${event.pool}`);
// jemand hat einen balancer pool erstellt. Den jetzt überwachen
crypto_lib.addBPool(__dirname + '/contracts/BPool.json', event.pool)
} catch (error) {
console.error("[CRYPTO-ERROR]:", e)
}
})
console.log("[CRYPTO]: Register BPool callback...");
crypto_lib.registerCallback("BPool", async (event) => {
try {
console.log(`[CRYPTO]: Balancer Pool finalisiert`);
var poolAddress = event.pool;
// token 0 ist immer der Tausch-Token, also z.B. der Tour Token
var tokenAddress = event.tokens[1];
await dao.run("UPDATE tour SET bpoolAddress = ? WHERE tokenAddress = ?", [poolAddress, tokenAddress]);
} catch (error) {
console.error("[CRYPTO-ERROR]:", e)
}
})
} catch (e) {
console.log("Error connecting blockchain:", e);
}
}