@instadapp/interop-x 0.0.0-dev.051cd4e
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.env.example +2 -0
- package/.github/workflows/publish-dev.yml +30 -0
- package/README.md +21 -0
- package/bin/interop-x +2 -0
- package/dist/package.json +72 -0
- package/dist/src/abi/erc20.json +350 -0
- package/dist/src/abi/gnosisSafe.json +747 -0
- package/dist/src/abi/index.js +15 -0
- package/dist/src/abi/interopBridgeToken.json +286 -0
- package/dist/src/abi/interopXGateway.json +184 -0
- package/dist/src/api/index.js +33 -0
- package/dist/src/config/index.js +22 -0
- package/dist/src/constants/addresses.js +20 -0
- package/dist/src/constants/index.js +19 -0
- package/dist/src/constants/itokens.js +13 -0
- package/dist/src/constants/tokens.js +107 -0
- package/dist/src/db/index.js +17 -0
- package/dist/src/db/models/index.js +17 -0
- package/dist/src/db/models/transaction.js +54 -0
- package/dist/src/db/sequelize.js +23 -0
- package/dist/src/index.js +103 -0
- package/dist/src/logger/index.js +138 -0
- package/dist/src/net/index.js +19 -0
- package/dist/src/net/peer/index.js +108 -0
- package/dist/src/net/pool/index.js +125 -0
- package/dist/src/net/protocol/dial/BaseDialProtocol.js +106 -0
- package/dist/src/net/protocol/dial/SignatureDialProtocol.js +56 -0
- package/dist/src/net/protocol/index.js +121 -0
- package/dist/src/tasks/AutoUpdateTask.js +45 -0
- package/dist/src/tasks/BaseTask.js +61 -0
- package/dist/src/tasks/InteropBridge/ProcessWithdrawEvents.js +147 -0
- package/dist/src/tasks/InteropBridge/SyncWithdrawEvents.js +70 -0
- package/dist/src/tasks/InteropXGateway/ProcessDepositEvents.js +150 -0
- package/dist/src/tasks/InteropXGateway/SyncDepositEvents.js +75 -0
- package/dist/src/tasks/index.js +42 -0
- package/dist/src/typechain/Erc20.js +2 -0
- package/dist/src/typechain/GnosisSafe.js +2 -0
- package/dist/src/typechain/InteropBridgeToken.js +2 -0
- package/dist/src/typechain/InteropXGateway.js +2 -0
- package/dist/src/typechain/common.js +2 -0
- package/dist/src/typechain/factories/Erc20__factory.js +367 -0
- package/dist/src/typechain/factories/GnosisSafe__factory.js +1174 -0
- package/dist/src/typechain/factories/InteropBridgeToken__factory.js +459 -0
- package/dist/src/typechain/factories/InteropXGateway__factory.js +265 -0
- package/dist/src/typechain/factories/index.js +14 -0
- package/dist/src/typechain/index.js +35 -0
- package/dist/src/types.js +21 -0
- package/dist/src/utils/index.js +228 -0
- package/package.json +72 -0
- package/patches/@ethersproject+properties+5.6.0.patch +13 -0
- package/src/abi/erc20.json +350 -0
- package/src/abi/gnosisSafe.json +747 -0
- package/src/abi/index.ts +11 -0
- package/src/abi/interopBridgeToken.json +286 -0
- package/src/abi/interopXGateway.json +184 -0
- package/src/api/index.ts +33 -0
- package/src/config/index.ts +32 -0
- package/src/constants/addresses.ts +17 -0
- package/src/constants/index.ts +3 -0
- package/src/constants/itokens.ts +10 -0
- package/src/constants/tokens.ts +104 -0
- package/src/db/index.ts +1 -0
- package/src/db/models/index.ts +1 -0
- package/src/db/models/transaction.ts +96 -0
- package/src/db/sequelize.ts +22 -0
- package/src/index.ts +123 -0
- package/src/logger/index.ts +157 -0
- package/src/net/index.ts +3 -0
- package/src/net/peer/index.ts +120 -0
- package/src/net/pool/index.ts +154 -0
- package/src/net/protocol/dial/BaseDialProtocol.ts +104 -0
- package/src/net/protocol/dial/SignatureDialProtocol.ts +71 -0
- package/src/net/protocol/index.ts +182 -0
- package/src/tasks/AutoUpdateTask.ts +54 -0
- package/src/tasks/BaseTask.ts +75 -0
- package/src/tasks/InteropBridge/ProcessWithdrawEvents.ts +233 -0
- package/src/tasks/InteropBridge/SyncWithdrawEvents.ts +121 -0
- package/src/tasks/InteropXGateway/ProcessDepositEvents.ts +245 -0
- package/src/tasks/InteropXGateway/SyncDepositEvents.ts +126 -0
- package/src/tasks/index.ts +41 -0
- package/src/typechain/Erc20.ts +491 -0
- package/src/typechain/GnosisSafe.ts +1728 -0
- package/src/typechain/InteropBridgeToken.ts +686 -0
- package/src/typechain/InteropXGateway.ts +407 -0
- package/src/typechain/common.ts +44 -0
- package/src/typechain/factories/Erc20__factory.ts +368 -0
- package/src/typechain/factories/GnosisSafe__factory.ts +1178 -0
- package/src/typechain/factories/InteropBridgeToken__factory.ts +466 -0
- package/src/typechain/factories/InteropXGateway__factory.ts +272 -0
- package/src/typechain/factories/index.ts +7 -0
- package/src/typechain/index.ts +12 -0
- package/src/types.ts +39 -0
- package/src/utils/index.ts +307 -0
- package/tsconfig.json +30 -0
@@ -0,0 +1,107 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.tokens = void 0;
|
4
|
+
exports.tokens = {
|
5
|
+
1: [
|
6
|
+
{
|
7
|
+
symbol: "ETH",
|
8
|
+
name: "Ethereum",
|
9
|
+
address: "0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE",
|
10
|
+
decimals: 18,
|
11
|
+
},
|
12
|
+
{
|
13
|
+
symbol: "DAI",
|
14
|
+
name: "DAI Stable",
|
15
|
+
address: "0x6B175474E89094C44Da98b954EedeAC495271d0F",
|
16
|
+
decimals: 18,
|
17
|
+
},
|
18
|
+
{
|
19
|
+
symbol: "USDC",
|
20
|
+
name: "USD Coin",
|
21
|
+
address: "0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48",
|
22
|
+
decimals: 6,
|
23
|
+
},
|
24
|
+
{
|
25
|
+
symbol: "USDT",
|
26
|
+
name: "Tether USD Coin",
|
27
|
+
address: "0xdAC17F958D2ee523a2206206994597C13D831ec7",
|
28
|
+
decimals: 6,
|
29
|
+
},
|
30
|
+
{
|
31
|
+
symbol: "WBTC",
|
32
|
+
name: "Wrapped BTC",
|
33
|
+
address: "0x2260FAC5E5542a773Aa44fBCfeDf7C193bc2C599",
|
34
|
+
decimals: 8,
|
35
|
+
},
|
36
|
+
],
|
37
|
+
137: [
|
38
|
+
{
|
39
|
+
symbol: "ETH",
|
40
|
+
name: "Ethereum",
|
41
|
+
address: "0x7ceB23fD6bC0adD59E62ac25578270cFf1b9f619",
|
42
|
+
decimals: 18,
|
43
|
+
},
|
44
|
+
{
|
45
|
+
symbol: "DAI",
|
46
|
+
name: "DAI Stable",
|
47
|
+
address: "0x8f3Cf7ad23Cd3CaDbD9735AFf958023239c6A063",
|
48
|
+
decimals: 18,
|
49
|
+
},
|
50
|
+
{
|
51
|
+
symbol: "USDC",
|
52
|
+
name: "USD Coin",
|
53
|
+
address: "0x2791Bca1f2de4661ED88A30C99A7a9449Aa84174",
|
54
|
+
decimals: 6,
|
55
|
+
},
|
56
|
+
{
|
57
|
+
symbol: "USDT",
|
58
|
+
name: "Tether USD Coin",
|
59
|
+
address: "0xc2132D05D31c914a87C6611C10748AEb04B58e8F",
|
60
|
+
decimals: 6,
|
61
|
+
},
|
62
|
+
{
|
63
|
+
symbol: "WBTC",
|
64
|
+
name: "Wrapped BTC",
|
65
|
+
address: "0x1BFD67037B42Cf73acF2047067bd4F2C47D9BfD6",
|
66
|
+
decimals: 8,
|
67
|
+
},
|
68
|
+
{
|
69
|
+
symbol: "AVAX",
|
70
|
+
name: "Avalanche Token",
|
71
|
+
address: "0x2C89bbc92BD86F8075d1DEcc58C7F4E0107f286b",
|
72
|
+
decimals: 18,
|
73
|
+
},
|
74
|
+
],
|
75
|
+
43114: [
|
76
|
+
{
|
77
|
+
symbol: "ETH",
|
78
|
+
name: "Ethereum",
|
79
|
+
address: "0x49D5c2BdFfac6CE2BFdB6640F4F80f226bc10bAB",
|
80
|
+
decimals: 18,
|
81
|
+
},
|
82
|
+
{
|
83
|
+
symbol: "DAI",
|
84
|
+
name: "DAI Stable",
|
85
|
+
address: "0xd586E7F844cEa2F87f50152665BCbc2C279D8d70",
|
86
|
+
decimals: 18,
|
87
|
+
},
|
88
|
+
{
|
89
|
+
symbol: "USDC",
|
90
|
+
name: "USD Coin",
|
91
|
+
address: "0xA7D7079b0FEaD91F3e65f86E8915Cb59c1a4C664",
|
92
|
+
decimals: 6,
|
93
|
+
},
|
94
|
+
{
|
95
|
+
symbol: "USDT",
|
96
|
+
name: "Tether USD Coin",
|
97
|
+
address: "0xc7198437980c041c805A1EDcbA50c1Ce5db95118",
|
98
|
+
decimals: 6,
|
99
|
+
},
|
100
|
+
{
|
101
|
+
symbol: "WBTC",
|
102
|
+
name: "Wrapped BTC",
|
103
|
+
address: "0x50b7545627a5162F82A992c33b87aDc75187B218",
|
104
|
+
decimals: 8,
|
105
|
+
},
|
106
|
+
],
|
107
|
+
};
|
@@ -0,0 +1,17 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
3
|
+
if (k2 === undefined) k2 = k;
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
7
|
+
}
|
8
|
+
Object.defineProperty(o, k2, desc);
|
9
|
+
}) : (function(o, m, k, k2) {
|
10
|
+
if (k2 === undefined) k2 = k;
|
11
|
+
o[k2] = m[k];
|
12
|
+
}));
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
15
|
+
};
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
17
|
+
__exportStar(require("./models"), exports);
|
@@ -0,0 +1,17 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
3
|
+
if (k2 === undefined) k2 = k;
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
7
|
+
}
|
8
|
+
Object.defineProperty(o, k2, desc);
|
9
|
+
}) : (function(o, m, k, k2) {
|
10
|
+
if (k2 === undefined) k2 = k;
|
11
|
+
o[k2] = m[k];
|
12
|
+
}));
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
15
|
+
};
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
17
|
+
__exportStar(require("./transaction"), exports);
|
@@ -0,0 +1,54 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.Transaction = void 0;
|
4
|
+
const sequelize_1 = require("@/db/sequelize");
|
5
|
+
const sequelize_2 = require("sequelize");
|
6
|
+
class Transaction extends sequelize_2.Model {
|
7
|
+
}
|
8
|
+
exports.Transaction = Transaction;
|
9
|
+
Transaction.init({
|
10
|
+
id: {
|
11
|
+
type: sequelize_2.DataTypes.INTEGER,
|
12
|
+
autoIncrement: true,
|
13
|
+
primaryKey: true
|
14
|
+
},
|
15
|
+
submitTransactionHash: sequelize_2.DataTypes.NUMBER,
|
16
|
+
submitBlockNumber: sequelize_2.DataTypes.NUMBER,
|
17
|
+
transactionHash: sequelize_2.DataTypes.STRING,
|
18
|
+
action: sequelize_2.DataTypes.STRING,
|
19
|
+
from: sequelize_2.DataTypes.STRING,
|
20
|
+
to: sequelize_2.DataTypes.STRING,
|
21
|
+
sourceChainId: sequelize_2.DataTypes.NUMBER,
|
22
|
+
sourceTransactionHash: sequelize_2.DataTypes.STRING,
|
23
|
+
sourceBlockNumber: sequelize_2.DataTypes.NUMBER,
|
24
|
+
sourceStatus: sequelize_2.DataTypes.STRING,
|
25
|
+
sourceErrors: {
|
26
|
+
type: sequelize_2.DataTypes.JSON,
|
27
|
+
// defaultValue: [],
|
28
|
+
},
|
29
|
+
sourceCreatedAt: {
|
30
|
+
type: sequelize_2.DataTypes.DATE,
|
31
|
+
defaultValue: Date.now()
|
32
|
+
},
|
33
|
+
sourceDelayUntil: sequelize_2.DataTypes.STRING,
|
34
|
+
targetChainId: sequelize_2.DataTypes.NUMBER,
|
35
|
+
targetTransactionHash: sequelize_2.DataTypes.STRING,
|
36
|
+
targetBlockNumber: sequelize_2.DataTypes.NUMBER,
|
37
|
+
targetStatus: sequelize_2.DataTypes.STRING,
|
38
|
+
targetErrors: {
|
39
|
+
type: sequelize_2.DataTypes.JSON,
|
40
|
+
// defaultValue: [],
|
41
|
+
},
|
42
|
+
targetCreatedAt: sequelize_2.DataTypes.DATE,
|
43
|
+
targetDelayUntil: sequelize_2.DataTypes.DATE,
|
44
|
+
submitEvent: sequelize_2.DataTypes.JSON,
|
45
|
+
sourceEvent: sequelize_2.DataTypes.JSON,
|
46
|
+
targetEvent: sequelize_2.DataTypes.JSON,
|
47
|
+
metadata: sequelize_2.DataTypes.JSON,
|
48
|
+
status: {
|
49
|
+
type: sequelize_2.DataTypes.STRING,
|
50
|
+
defaultValue: 'pending'
|
51
|
+
},
|
52
|
+
createdAt: sequelize_2.DataTypes.DATE,
|
53
|
+
updatedAt: sequelize_2.DataTypes.DATE,
|
54
|
+
}, { sequelize: sequelize_1.sequelize, tableName: 'transactions' });
|
@@ -0,0 +1,23 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
|
+
};
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
+
exports.sequelize = void 0;
|
7
|
+
//@ts-ignore
|
8
|
+
const config_1 = __importDefault(require("@/config"));
|
9
|
+
const expand_home_dir_1 = __importDefault(require("expand-home-dir"));
|
10
|
+
const sequelize_1 = require("sequelize");
|
11
|
+
const basePath = (0, expand_home_dir_1.default)(`~/.interop-x/data/${config_1.default.publicAddress}/${config_1.default.staging ? 'staging' : ''}`);
|
12
|
+
exports.sequelize = new sequelize_1.Sequelize({
|
13
|
+
dialect: 'sqlite',
|
14
|
+
storage: `${basePath}/localDB.sqlite`,
|
15
|
+
// dialectModulePath: '@journeyapps/sqlcipher',
|
16
|
+
logging: false,
|
17
|
+
});
|
18
|
+
exports.sequelize.sync({
|
19
|
+
alter: true
|
20
|
+
}).then(() => {
|
21
|
+
// sequelize.query('PRAGMA cipher_compatibility = 3');
|
22
|
+
// sequelize.query("PRAGMA key = 'your-encryption-key'");
|
23
|
+
});
|
@@ -0,0 +1,103 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
|
+
};
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
+
const module_alias_1 = __importDefault(require("module-alias"));
|
7
|
+
module_alias_1.default.addAliases({
|
8
|
+
"@/": __dirname + "/",
|
9
|
+
"@/logger": __dirname + "/logger",
|
10
|
+
"@/tasks": __dirname + "/tasks",
|
11
|
+
"@/utils": __dirname + "/utils",
|
12
|
+
"@/api": __dirname + "/api",
|
13
|
+
"@/net": __dirname + "/net",
|
14
|
+
"@/db": __dirname + "/db",
|
15
|
+
"@/config": __dirname + "/config",
|
16
|
+
"@/types": __dirname + "/types",
|
17
|
+
"@/abi": __dirname + "/abi",
|
18
|
+
"@/constants": __dirname + "/constants",
|
19
|
+
"@/typechain": __dirname + "/typechain"
|
20
|
+
});
|
21
|
+
(0, module_alias_1.default)();
|
22
|
+
const dotenv_1 = __importDefault(require("dotenv"));
|
23
|
+
const chalk_1 = __importDefault(require("chalk"));
|
24
|
+
const ethers_1 = require("ethers");
|
25
|
+
const package_json_1 = __importDefault(require("../package.json"));
|
26
|
+
dotenv_1.default.config();
|
27
|
+
const logger_1 = __importDefault(require("@/logger"));
|
28
|
+
const logger = new logger_1.default('Process');
|
29
|
+
const printUsage = () => {
|
30
|
+
console.log('Usage:');
|
31
|
+
console.log(' PRIVATE_KEY=abcd1234 interop-x');
|
32
|
+
console.log(' PRIVATE_KEY=abcd1234 STAGING=true interop-x');
|
33
|
+
console.log(' PRIVATE_KEY=abcd1234 AUTO_UPDATE=true interop-x');
|
34
|
+
console.log(' PRIVATE_KEY=abcd1234 API_HOST=0.0.0.0 API_PORT=8080 interop-x');
|
35
|
+
};
|
36
|
+
if (process.argv.at(-1) === 'help') {
|
37
|
+
printUsage();
|
38
|
+
process.exit(0);
|
39
|
+
}
|
40
|
+
const GIT_SHORT_HASH = '051cd4e';
|
41
|
+
if (process.argv.at(-1) === 'version') {
|
42
|
+
console.log(`Interop X Node (v${package_json_1.default.version} - rev.${GIT_SHORT_HASH})`);
|
43
|
+
process.exit(0);
|
44
|
+
}
|
45
|
+
if (!process.env.PRIVATE_KEY) {
|
46
|
+
console.error(chalk_1.default.bgRed.white.bold('Please provide a private key\n'));
|
47
|
+
printUsage();
|
48
|
+
process.exit(1);
|
49
|
+
}
|
50
|
+
try {
|
51
|
+
new ethers_1.ethers.Wallet(process.env.PRIVATE_KEY);
|
52
|
+
}
|
53
|
+
catch (e) {
|
54
|
+
console.error(chalk_1.default.bgRed.white('Invalid private key\n'));
|
55
|
+
printUsage();
|
56
|
+
process.exit(1);
|
57
|
+
}
|
58
|
+
logger.debug(`Starting Interop X Node (v${package_json_1.default.version} - rev.${GIT_SHORT_HASH})`);
|
59
|
+
const tasks_1 = require("@/tasks");
|
60
|
+
const net_1 = require("@/net");
|
61
|
+
const api_1 = require("@/api");
|
62
|
+
const db_1 = require("./db");
|
63
|
+
async function main() {
|
64
|
+
(0, net_1.startPeer)({});
|
65
|
+
const tasks = new tasks_1.Tasks();
|
66
|
+
tasks.start();
|
67
|
+
(0, api_1.startApiServer)();
|
68
|
+
net_1.protocol.on('TransactionStatus', async (payload) => {
|
69
|
+
if (!net_1.peerPool.isLeadNode(payload.peerId)) {
|
70
|
+
const peer = net_1.peerPool.getPeer(payload.peerId);
|
71
|
+
logger.info(`ignored transaction status from ${payload.peerId} ${peer === null || peer === void 0 ? void 0 : peer.publicAddress} `);
|
72
|
+
return;
|
73
|
+
}
|
74
|
+
const transaction = await db_1.Transaction.findOne({ where: { transactionHash: payload.data.transactionHash } });
|
75
|
+
if (!transaction) {
|
76
|
+
return;
|
77
|
+
}
|
78
|
+
transaction.sourceStatus = payload.data.sourceStatus;
|
79
|
+
transaction.sourceTransactionHash = payload.data.sourceTransactionHash;
|
80
|
+
transaction.sourceErrors = payload.data.sourceErrors;
|
81
|
+
transaction.targetStatus = payload.data.targetStatus;
|
82
|
+
transaction.targetTransactionHash = payload.data.targetTransactionHash;
|
83
|
+
transaction.targetErrors = payload.data.targetErrors;
|
84
|
+
transaction.status = payload.data.status;
|
85
|
+
await transaction.save();
|
86
|
+
});
|
87
|
+
}
|
88
|
+
main()
|
89
|
+
.then(() => {
|
90
|
+
}).catch(err => {
|
91
|
+
console.error(err);
|
92
|
+
});
|
93
|
+
process.on('SIGINT', () => {
|
94
|
+
logger.debug('received SIGINT signal. exiting.');
|
95
|
+
process.exit(0);
|
96
|
+
});
|
97
|
+
process.on('SIGTERM', () => {
|
98
|
+
logger.debug('received SIGTERM signal. exiting.');
|
99
|
+
process.exit(0);
|
100
|
+
});
|
101
|
+
process.on('unhandledRejection', (reason, p) => {
|
102
|
+
logger.error('unhandled rejection: promise:', p, 'reason:', reason);
|
103
|
+
});
|
@@ -0,0 +1,138 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
|
+
};
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
+
exports.setLogLevel = exports.LogLevels = void 0;
|
7
|
+
const chalk_1 = __importDefault(require("chalk"));
|
8
|
+
const luxon_1 = require("luxon");
|
9
|
+
var LogLevels;
|
10
|
+
(function (LogLevels) {
|
11
|
+
LogLevels[LogLevels["Critical"] = 0] = "Critical";
|
12
|
+
LogLevels[LogLevels["Error"] = 1] = "Error";
|
13
|
+
LogLevels[LogLevels["Warn"] = 2] = "Warn";
|
14
|
+
LogLevels[LogLevels["Info"] = 3] = "Info";
|
15
|
+
LogLevels[LogLevels["Log"] = 4] = "Log";
|
16
|
+
LogLevels[LogLevels["Debug"] = 5] = "Debug";
|
17
|
+
})(LogLevels = exports.LogLevels || (exports.LogLevels = {}));
|
18
|
+
const logLevelColors = {
|
19
|
+
[LogLevels.Critical]: 'red',
|
20
|
+
[LogLevels.Error]: 'red',
|
21
|
+
[LogLevels.Warn]: 'yellow',
|
22
|
+
[LogLevels.Info]: 'blue',
|
23
|
+
[LogLevels.Log]: 'white',
|
24
|
+
[LogLevels.Debug]: 'white'
|
25
|
+
};
|
26
|
+
let logLevel = LogLevels.Debug;
|
27
|
+
const setLogLevel = (_logLevel) => {
|
28
|
+
if (typeof _logLevel === 'string') {
|
29
|
+
const mapping = {
|
30
|
+
error: LogLevels.Error,
|
31
|
+
warn: LogLevels.Warn,
|
32
|
+
info: LogLevels.Info,
|
33
|
+
debug: LogLevels.Debug
|
34
|
+
};
|
35
|
+
_logLevel = mapping[_logLevel];
|
36
|
+
}
|
37
|
+
logLevel = _logLevel;
|
38
|
+
};
|
39
|
+
exports.setLogLevel = setLogLevel;
|
40
|
+
class Logger {
|
41
|
+
constructor(tag = '', opts = {
|
42
|
+
color: 'white'
|
43
|
+
}) {
|
44
|
+
var _a;
|
45
|
+
this.tag = '';
|
46
|
+
this.prefix = '';
|
47
|
+
this.options = {};
|
48
|
+
this.enabled = true;
|
49
|
+
this.critical = (...input) => {
|
50
|
+
if (!this.enabled)
|
51
|
+
return;
|
52
|
+
console.error(...this.headers(LogLevels.Critical), ...input);
|
53
|
+
};
|
54
|
+
this.debug = (...input) => {
|
55
|
+
if (!this.enabled)
|
56
|
+
return;
|
57
|
+
if (logLevel !== LogLevels.Debug) {
|
58
|
+
return;
|
59
|
+
}
|
60
|
+
console.debug(...this.headers(LogLevels.Debug), ...input);
|
61
|
+
};
|
62
|
+
this.error = (...input) => {
|
63
|
+
if (!this.enabled)
|
64
|
+
return;
|
65
|
+
console.error(...this.headers(LogLevels.Error), ...input);
|
66
|
+
};
|
67
|
+
this.info = (...input) => {
|
68
|
+
if (!this.enabled)
|
69
|
+
return;
|
70
|
+
if (!(logLevel === LogLevels.Debug || logLevel === LogLevels.Info)) {
|
71
|
+
return;
|
72
|
+
}
|
73
|
+
console.info(...this.headers(LogLevels.Info), ...input);
|
74
|
+
};
|
75
|
+
this.log = (...input) => {
|
76
|
+
if (!this.enabled)
|
77
|
+
return;
|
78
|
+
if (logLevel < LogLevels.Info) {
|
79
|
+
return;
|
80
|
+
}
|
81
|
+
console.log(...this.headers(LogLevels.Log), ...input);
|
82
|
+
};
|
83
|
+
this.warn = (...input) => {
|
84
|
+
if (!this.enabled)
|
85
|
+
return;
|
86
|
+
if (logLevel < LogLevels.Warn) {
|
87
|
+
return;
|
88
|
+
}
|
89
|
+
console.warn(...this.headers(LogLevels.Warn), ...input);
|
90
|
+
};
|
91
|
+
if (tag instanceof Object) {
|
92
|
+
opts = tag;
|
93
|
+
tag = (_a = opts.tag) !== null && _a !== void 0 ? _a : '';
|
94
|
+
}
|
95
|
+
if (opts.prefix) {
|
96
|
+
this.prefix = `<${opts.prefix}>`;
|
97
|
+
}
|
98
|
+
if (tag) {
|
99
|
+
if (opts.color) {
|
100
|
+
//@ts-ignore
|
101
|
+
this.tag = chalk_1.default[opts.color](`[${tag}]`);
|
102
|
+
}
|
103
|
+
else {
|
104
|
+
this.tag = `[${tag}]`;
|
105
|
+
}
|
106
|
+
}
|
107
|
+
if (process.env.DISABLE_LOGGER) {
|
108
|
+
this.enabled = false;
|
109
|
+
}
|
110
|
+
this.options = opts;
|
111
|
+
}
|
112
|
+
setEnabled(enabled) {
|
113
|
+
this.enabled = enabled;
|
114
|
+
}
|
115
|
+
create(additionalDataLabel) {
|
116
|
+
let label;
|
117
|
+
if (additionalDataLabel.id) {
|
118
|
+
label = `id: ${additionalDataLabel.id}`;
|
119
|
+
}
|
120
|
+
else {
|
121
|
+
label = `root: ${additionalDataLabel.root}`;
|
122
|
+
}
|
123
|
+
return new Logger(this.options.tag, Object.assign({}, this.options, {
|
124
|
+
prefix: `${this.options.prefix ? `${this.options.prefix} ` : ''}${label}`
|
125
|
+
}));
|
126
|
+
}
|
127
|
+
get timestamp() {
|
128
|
+
return luxon_1.DateTime.now().toISO();
|
129
|
+
}
|
130
|
+
headers(logLevelEnum) {
|
131
|
+
const keys = Object.keys(LogLevels);
|
132
|
+
const logLevelName = keys[logLevelEnum + keys.length / 2].toUpperCase();
|
133
|
+
//@ts-ignore
|
134
|
+
const coloredLogLevel = chalk_1.default[logLevelColors[logLevelEnum]](logLevelName.padEnd(5, ' '));
|
135
|
+
return [this.timestamp, coloredLogLevel, this.tag, this.prefix];
|
136
|
+
}
|
137
|
+
}
|
138
|
+
exports.default = Logger;
|
@@ -0,0 +1,19 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
3
|
+
if (k2 === undefined) k2 = k;
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
7
|
+
}
|
8
|
+
Object.defineProperty(o, k2, desc);
|
9
|
+
}) : (function(o, m, k, k2) {
|
10
|
+
if (k2 === undefined) k2 = k;
|
11
|
+
o[k2] = m[k];
|
12
|
+
}));
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
15
|
+
};
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
17
|
+
__exportStar(require("./peer"), exports);
|
18
|
+
__exportStar(require("./pool"), exports);
|
19
|
+
__exportStar(require("./protocol"), exports);
|
@@ -0,0 +1,108 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
|
+
};
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
+
exports.stopPeer = exports.startPeer = void 0;
|
7
|
+
const libp2p_1 = __importDefault(require("libp2p"));
|
8
|
+
const libp2p_tcp_1 = __importDefault(require("libp2p-tcp"));
|
9
|
+
//@ts-ignore
|
10
|
+
const libp2p_websockets_1 = __importDefault(require("libp2p-websockets"));
|
11
|
+
//@ts-ignore
|
12
|
+
const libp2p_mplex_1 = __importDefault(require("libp2p-mplex"));
|
13
|
+
const libp2p_noise_1 = require("libp2p-noise");
|
14
|
+
const logger_1 = __importDefault(require("@/logger"));
|
15
|
+
const libp2p_bootstrap_1 = __importDefault(require("libp2p-bootstrap"));
|
16
|
+
const waait_1 = __importDefault(require("waait"));
|
17
|
+
const libp2p_gossipsub_1 = __importDefault(require("@achingbrain/libp2p-gossipsub"));
|
18
|
+
//@ts-ignore
|
19
|
+
const libp2p_mdns_1 = __importDefault(require("libp2p-mdns"));
|
20
|
+
//@ts-ignore
|
21
|
+
const libp2p_kad_dht_1 = __importDefault(require("libp2p-kad-dht"));
|
22
|
+
//@ts-ignore
|
23
|
+
const libp2p_pubsub_peer_discovery_1 = __importDefault(require("libp2p-pubsub-peer-discovery"));
|
24
|
+
const net_1 = require("@/net");
|
25
|
+
const config_1 = __importDefault(require("@/config"));
|
26
|
+
const logger = new logger_1.default("Peer");
|
27
|
+
let node;
|
28
|
+
// Known peers addresses
|
29
|
+
const bootstrapMultiaddrs = [
|
30
|
+
'/ip4/164.92.249.133/tcp/15001/ws/p2p/QmVGmkqRn8FEw4PQz83L8Mun24ALxXB2fEyS5aEfT2gGqz',
|
31
|
+
'/ip4/164.92.249.133/tcp/15000/p2p/QmVGmkqRn8FEw4PQz83L8Mun24ALxXB2fEyS5aEfT2gGqz',
|
32
|
+
];
|
33
|
+
const startPeer = async ({}) => {
|
34
|
+
node = await libp2p_1.default.create({
|
35
|
+
addresses: {
|
36
|
+
listen: ["/ip4/0.0.0.0/tcp/0", "/ip4/0.0.0.0/tcp/0/ws"],
|
37
|
+
},
|
38
|
+
modules: {
|
39
|
+
transport: [libp2p_tcp_1.default, libp2p_websockets_1.default],
|
40
|
+
streamMuxer: [libp2p_mplex_1.default],
|
41
|
+
connEncryption: [libp2p_noise_1.NOISE],
|
42
|
+
peerDiscovery: [libp2p_mdns_1.default, libp2p_bootstrap_1.default, libp2p_pubsub_peer_discovery_1.default],
|
43
|
+
pubsub: libp2p_gossipsub_1.default,
|
44
|
+
dht: libp2p_kad_dht_1.default,
|
45
|
+
},
|
46
|
+
config: {
|
47
|
+
dht: {
|
48
|
+
enabled: true,
|
49
|
+
},
|
50
|
+
peerDiscovery: {
|
51
|
+
autoDial: true,
|
52
|
+
// The `tag` property will be searched when creating the instance of your Peer Discovery service.
|
53
|
+
// The associated object, will be passed to the service when it is instantiated.
|
54
|
+
[libp2p_bootstrap_1.default.tag]: {
|
55
|
+
enabled: true,
|
56
|
+
interval: 60e3,
|
57
|
+
list: bootstrapMultiaddrs, // provide array of multiaddrs
|
58
|
+
},
|
59
|
+
[libp2p_mdns_1.default.tag]: {
|
60
|
+
interval: 20e3,
|
61
|
+
enabled: true,
|
62
|
+
},
|
63
|
+
[libp2p_pubsub_peer_discovery_1.default.tag]: {
|
64
|
+
interval: 1000,
|
65
|
+
enabled: true,
|
66
|
+
},
|
67
|
+
},
|
68
|
+
relay: {
|
69
|
+
enabled: true,
|
70
|
+
autoRelay: {
|
71
|
+
enabled: true,
|
72
|
+
maxListeners: 10,
|
73
|
+
},
|
74
|
+
},
|
75
|
+
},
|
76
|
+
peerStore: {
|
77
|
+
persistence: true,
|
78
|
+
},
|
79
|
+
});
|
80
|
+
logger.info("Peer ID:", node.peerId.toB58String());
|
81
|
+
await node.start();
|
82
|
+
net_1.protocol.start({
|
83
|
+
libp2p: node
|
84
|
+
});
|
85
|
+
node.on("peer:discovery", (peer) => {
|
86
|
+
// logger.log(`Discovered peer ${peer}`)
|
87
|
+
}); // peer disc.
|
88
|
+
node.connectionManager.on("peer:connect", (connection) => {
|
89
|
+
// logger.log(`Connected to ${connection.remotePeer.toB58String()}`)
|
90
|
+
});
|
91
|
+
logger.log("Peer discovery started");
|
92
|
+
await (0, waait_1.default)(1000);
|
93
|
+
setInterval(() => net_1.protocol.sendPeerInfo({
|
94
|
+
publicAddress: config_1.default.wallet.address,
|
95
|
+
}), 5000);
|
96
|
+
};
|
97
|
+
exports.startPeer = startPeer;
|
98
|
+
const stopPeer = async () => {
|
99
|
+
if (node) {
|
100
|
+
// stop libp2p
|
101
|
+
await node.stop();
|
102
|
+
logger.log("libp2p has stopped");
|
103
|
+
}
|
104
|
+
process.exit(0);
|
105
|
+
};
|
106
|
+
exports.stopPeer = stopPeer;
|
107
|
+
process.on("SIGTERM", exports.stopPeer);
|
108
|
+
process.on("SIGINT", exports.stopPeer);
|