@dhedge/backend-flatcoin-core 0.2.16 → 0.2.18
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/dist/dto/index.d.ts +1 -0
- package/dist/dto/index.js +1 -0
- package/dist/dto/token-transfer.d.ts +9 -0
- package/dist/dto/token-transfer.js +6 -0
- package/dist/entity/flatcoin-pnl.d.ts +1 -0
- package/dist/entity/flatcoin-pnl.js +4 -0
- package/dist/service/blockscan.service.d.ts +8 -0
- package/dist/service/blockscan.service.js +53 -0
- package/dist/service/index.d.ts +1 -0
- package/dist/service/index.js +1 -0
- package/package.json +1 -1
package/dist/dto/index.d.ts
CHANGED
package/dist/dto/index.js
CHANGED
|
@@ -40,6 +40,10 @@ __decorate([
|
|
|
40
40
|
(0, typeorm_1.Column)({ name: 'unit_amount', type: 'bigint', precision: 30, transformer: utils_1.bigNumberTransformer }),
|
|
41
41
|
__metadata("design:type", ethers_1.BigNumber)
|
|
42
42
|
], FlatcoinPnl.prototype, "unitAmount", void 0);
|
|
43
|
+
__decorate([
|
|
44
|
+
(0, typeorm_1.Column)({ name: 'wallet_unit_amount', type: 'bigint', precision: 30, transformer: utils_1.bigNumberTransformer }),
|
|
45
|
+
__metadata("design:type", ethers_1.BigNumber)
|
|
46
|
+
], FlatcoinPnl.prototype, "walletUnitAmount", void 0);
|
|
43
47
|
__decorate([
|
|
44
48
|
(0, typeorm_1.Column)({ name: 'unit_average_buy_price', type: 'bigint', precision: 30, transformer: utils_1.bigNumberTransformer }),
|
|
45
49
|
__metadata("design:type", ethers_1.BigNumber)
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { Logger } from '@nestjs/common';
|
|
2
|
+
import { TokenTransfer } from '../dto';
|
|
3
|
+
export declare class BlockscanService {
|
|
4
|
+
private readonly logger;
|
|
5
|
+
private readonly blockscanUri;
|
|
6
|
+
constructor(logger: Logger);
|
|
7
|
+
getTokenTransfers(contractAddress: string, startBlock: number, endBlock: number): Promise<TokenTransfer[]>;
|
|
8
|
+
}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.BlockscanService = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const axios_1 = __importDefault(require("axios"));
|
|
18
|
+
const ethers_1 = require("ethers");
|
|
19
|
+
const dto_1 = require("../dto");
|
|
20
|
+
let BlockscanService = class BlockscanService {
|
|
21
|
+
constructor(logger) {
|
|
22
|
+
this.logger = logger;
|
|
23
|
+
if (process.env.BASE_BLOCKSCAN_URI) {
|
|
24
|
+
this.blockscanUri = process.env.BASE_BLOCKSCAN_URI;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
async getTokenTransfers(contractAddress, startBlock, endBlock) {
|
|
28
|
+
try {
|
|
29
|
+
const response = await axios_1.default.get(`${this.blockscanUri}&module=account&action=tokentx&contractaddress=${contractAddress}&startblock=${startBlock}&endblock=${endBlock}&page=1&offset=10000&sort=asc`);
|
|
30
|
+
const result = response.data.result.map((r) => {
|
|
31
|
+
const tokenTransfer = new dto_1.TokenTransfer();
|
|
32
|
+
tokenTransfer.blockNumber = +r.blockNumber;
|
|
33
|
+
tokenTransfer.to = r.to;
|
|
34
|
+
tokenTransfer.from = r.from;
|
|
35
|
+
tokenTransfer.txHash = r.hash;
|
|
36
|
+
tokenTransfer.contractAddress = r.contractAddress;
|
|
37
|
+
tokenTransfer.value = ethers_1.BigNumber.from(r.value);
|
|
38
|
+
return tokenTransfer;
|
|
39
|
+
});
|
|
40
|
+
this.logger.log(`fetched ${result.length} unit direct transfers`);
|
|
41
|
+
return result;
|
|
42
|
+
}
|
|
43
|
+
catch (error) {
|
|
44
|
+
this.logger.error('failed to fetch unit direct transfers', error);
|
|
45
|
+
throw error;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
};
|
|
49
|
+
exports.BlockscanService = BlockscanService;
|
|
50
|
+
exports.BlockscanService = BlockscanService = __decorate([
|
|
51
|
+
(0, common_1.Injectable)(),
|
|
52
|
+
__metadata("design:paramtypes", [common_1.Logger])
|
|
53
|
+
], BlockscanService);
|
package/dist/service/index.d.ts
CHANGED
package/dist/service/index.js
CHANGED
|
@@ -18,3 +18,4 @@ __exportStar(require("./app-price.service"), exports);
|
|
|
18
18
|
__exportStar(require("./graph-query.service"), exports);
|
|
19
19
|
__exportStar(require("./error.handler"), exports);
|
|
20
20
|
__exportStar(require("./notification.service"), exports);
|
|
21
|
+
__exportStar(require("./blockscan.service"), exports);
|