@rosen-bridge/address-extractor 5.0.7 → 6.0.0
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/actions/boxAction.d.ts +7 -29
- package/dist/actions/boxAction.d.ts.map +1 -1
- package/dist/actions/boxAction.js +16 -106
- package/dist/entities/boxEntity.d.ts +2 -9
- package/dist/entities/boxEntity.d.ts.map +1 -1
- package/dist/entities/boxEntity.js +4 -43
- package/dist/extractor/ergoUtxoExtractor.d.ts +3 -4
- package/dist/extractor/ergoUtxoExtractor.d.ts.map +1 -1
- package/dist/extractor/ergoUtxoExtractor.js +2 -6
- package/dist/interfaces/types.d.ts +0 -4
- package/dist/interfaces/types.d.ts.map +1 -1
- package/dist/interfaces/types.js +1 -1
- package/dist/migrations/index.d.ts.map +1 -1
- package/dist/migrations/index.js +13 -3
- package/dist/migrations/postgres/1737785465594-migration.d.ts +7 -0
- package/dist/migrations/postgres/1737785465594-migration.d.ts.map +1 -0
- package/dist/migrations/postgres/1737785465594-migration.js +39 -0
- package/dist/migrations/sqlite/1737532655167-migration.d.ts +7 -0
- package/dist/migrations/sqlite/1737532655167-migration.d.ts.map +1 -0
- package/dist/migrations/sqlite/1737532655167-migration.js +99 -0
- package/package.json +2 -2
|
@@ -1,39 +1,17 @@
|
|
|
1
1
|
import { DataSource } from 'typeorm';
|
|
2
2
|
import { AbstractLogger } from '@rosen-bridge/abstract-logger';
|
|
3
|
-
import { AbstractInitializableErgoExtractorAction,
|
|
3
|
+
import { AbstractInitializableErgoExtractorAction, BlockInfo } from '@rosen-bridge/abstract-extractor';
|
|
4
|
+
import { BoxEntity } from '../entities/boxEntity';
|
|
4
5
|
import { ExtractedBox } from '../interfaces/types';
|
|
5
|
-
export declare class BoxEntityAction extends AbstractInitializableErgoExtractorAction<ExtractedBox> {
|
|
6
|
-
private readonly datasource;
|
|
7
|
-
readonly logger: AbstractLogger;
|
|
8
|
-
private readonly repository;
|
|
6
|
+
export declare class BoxEntityAction extends AbstractInitializableErgoExtractorAction<ExtractedBox, BoxEntity> {
|
|
9
7
|
constructor(dataSource: DataSource, logger?: AbstractLogger);
|
|
10
8
|
/**
|
|
11
|
-
*
|
|
12
|
-
* @param boxes
|
|
13
|
-
* @param extractor
|
|
14
|
-
* @return success
|
|
9
|
+
* create the box entity from extracted data and block information
|
|
15
10
|
*/
|
|
16
|
-
|
|
11
|
+
createEntity: (boxes: ExtractedBox[], block: BlockInfo, extractor: string) => Omit<BoxEntity, 'id'>[];
|
|
17
12
|
/**
|
|
18
|
-
*
|
|
19
|
-
* chunk spendInfos to prevent large database queries
|
|
20
|
-
* @param spendInfos
|
|
21
|
-
* @param block
|
|
22
|
-
* @param extractor
|
|
13
|
+
* convert the database entity back to raw data
|
|
23
14
|
*/
|
|
24
|
-
|
|
25
|
-
/**
|
|
26
|
-
* remove all existing data for the extractor
|
|
27
|
-
* @param extractorId
|
|
28
|
-
*/
|
|
29
|
-
removeAllData: (extractorId: string) => Promise<void>;
|
|
30
|
-
/**
|
|
31
|
-
* delete extracted data from a specific block
|
|
32
|
-
* if a box is spend in this block mark it as unspent
|
|
33
|
-
* if a box is created in this block remove it from database
|
|
34
|
-
* @param block
|
|
35
|
-
* @param extractorId
|
|
36
|
-
*/
|
|
37
|
-
deleteBlockBoxes: (block: string, extractor: string) => Promise<void>;
|
|
15
|
+
convertEntityToData: (entities: BoxEntity[]) => ExtractedBox[];
|
|
38
16
|
}
|
|
39
17
|
//# sourceMappingURL=boxAction.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"boxAction.d.ts","sourceRoot":"","sources":["../../lib/actions/boxAction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,
|
|
1
|
+
{"version":3,"file":"boxAction.d.ts","sourceRoot":"","sources":["../../lib/actions/boxAction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAErC,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,EACL,wCAAwC,EACxC,SAAS,EACV,MAAM,kCAAkC,CAAC;AAE1C,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAEnD,qBAAa,eAAgB,SAAQ,wCAAwC,CAC3E,YAAY,EACZ,SAAS,CACV;gBACa,UAAU,EAAE,UAAU,EAAE,MAAM,CAAC,EAAE,cAAc;IAI3D;;OAEG;IACH,YAAY,UACH,YAAY,EAAE,SACd,SAAS,aACL,MAAM,KAChB,KAAK,SAAS,EAAE,IAAI,CAAC,EAAE,CASxB;IAEF;;OAEG;IACH,mBAAmB,aAAc,SAAS,EAAE,KAAG,YAAY,EAAE,CAI3D;CACH"}
|
|
@@ -1,118 +1,28 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import { DummyLogger } from '@rosen-bridge/abstract-logger';
|
|
4
|
-
import { AbstractInitializableErgoExtractorAction, DB_CHUNK_SIZE, } from '@rosen-bridge/abstract-extractor';
|
|
1
|
+
import { pick } from 'lodash-es';
|
|
2
|
+
import { AbstractInitializableErgoExtractorAction, } from '@rosen-bridge/abstract-extractor';
|
|
5
3
|
import { BoxEntity } from '../entities/boxEntity';
|
|
6
|
-
import { JsonBI } from '../utils';
|
|
7
4
|
export class BoxEntityAction extends AbstractInitializableErgoExtractorAction {
|
|
8
|
-
datasource;
|
|
9
|
-
logger;
|
|
10
|
-
repository;
|
|
11
5
|
constructor(dataSource, logger) {
|
|
12
|
-
super();
|
|
13
|
-
this.datasource = dataSource;
|
|
14
|
-
this.logger = logger ? logger : new DummyLogger();
|
|
15
|
-
this.repository = dataSource.getRepository(BoxEntity);
|
|
6
|
+
super(dataSource, BoxEntity, logger);
|
|
16
7
|
}
|
|
17
8
|
/**
|
|
18
|
-
*
|
|
19
|
-
* @param boxes
|
|
20
|
-
* @param extractor
|
|
21
|
-
* @return success
|
|
9
|
+
* create the box entity from extracted data and block information
|
|
22
10
|
*/
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
boxId:
|
|
11
|
+
createEntity = (boxes, block, extractor) => {
|
|
12
|
+
return boxes.map((box) => ({
|
|
13
|
+
address: box.address,
|
|
14
|
+
boxId: box.boxId,
|
|
15
|
+
block: block.hash,
|
|
16
|
+
height: block.height,
|
|
17
|
+
serialized: box.serialized,
|
|
27
18
|
extractor: extractor,
|
|
28
|
-
});
|
|
29
|
-
if (dbBoxes.length > 0)
|
|
30
|
-
this.logger.debug(`Found stored boxes with same boxId`, dbBoxes);
|
|
31
|
-
let success = true;
|
|
32
|
-
const queryRunner = this.datasource.createQueryRunner();
|
|
33
|
-
await queryRunner.connect();
|
|
34
|
-
await queryRunner.startTransaction();
|
|
35
|
-
const repository = await queryRunner.manager.getRepository(BoxEntity);
|
|
36
|
-
try {
|
|
37
|
-
for (const box of boxes) {
|
|
38
|
-
const entity = {
|
|
39
|
-
address: box.address,
|
|
40
|
-
boxId: box.boxId,
|
|
41
|
-
createBlock: box.blockId,
|
|
42
|
-
creationHeight: box.height,
|
|
43
|
-
spendBlock: box.spendBlock,
|
|
44
|
-
spendHeight: box.spendHeight,
|
|
45
|
-
serialized: box.serialized,
|
|
46
|
-
extractor: extractor,
|
|
47
|
-
};
|
|
48
|
-
const dbBox = dbBoxes.filter((item) => item.boxId === box.boxId);
|
|
49
|
-
if (dbBox.length > 0) {
|
|
50
|
-
this.logger.info(`Updating box ${box.boxId} and extractor ${extractor}`);
|
|
51
|
-
await repository.update({ id: dbBox[0].id }, entity);
|
|
52
|
-
this.logger.debug(`Updated entity is [${JsonBI.stringify(box)}], and stored similar box is [${JsonBI.stringify(dbBox)}]`);
|
|
53
|
-
}
|
|
54
|
-
else {
|
|
55
|
-
this.logger.info(`Storing box ${box.boxId}`);
|
|
56
|
-
await repository.insert(entity);
|
|
57
|
-
this.logger.debug(`Stored ${JsonBI.stringify(entity)}`);
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
await queryRunner.commitTransaction();
|
|
61
|
-
}
|
|
62
|
-
catch (e) {
|
|
63
|
-
this.logger.error(`An error occurred during store boxes action: ${e}`);
|
|
64
|
-
await queryRunner.rollbackTransaction();
|
|
65
|
-
success = false;
|
|
66
|
-
}
|
|
67
|
-
finally {
|
|
68
|
-
await queryRunner.release();
|
|
69
|
-
}
|
|
70
|
-
return success;
|
|
19
|
+
}));
|
|
71
20
|
};
|
|
72
21
|
/**
|
|
73
|
-
*
|
|
74
|
-
* chunk spendInfos to prevent large database queries
|
|
75
|
-
* @param spendInfos
|
|
76
|
-
* @param block
|
|
77
|
-
* @param extractor
|
|
22
|
+
* convert the database entity back to raw data
|
|
78
23
|
*/
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
for (const spendInfoChunk of spendInfoChunks) {
|
|
82
|
-
const boxIds = spendInfoChunk.map((info) => info.boxId);
|
|
83
|
-
const updateResult = await this.repository.update({ boxId: In(boxIds), extractor: extractor }, { spendBlock: block.hash, spendHeight: block.height });
|
|
84
|
-
if (updateResult.affected && updateResult.affected > 0) {
|
|
85
|
-
const spentRows = await this.repository.findBy({
|
|
86
|
-
boxId: In(boxIds),
|
|
87
|
-
spendBlock: block.hash,
|
|
88
|
-
});
|
|
89
|
-
for (const row of spentRows) {
|
|
90
|
-
this.logger.debug(`Spent box with boxId [${row.boxId}] at height ${block.height}`);
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
};
|
|
95
|
-
/**
|
|
96
|
-
* remove all existing data for the extractor
|
|
97
|
-
* @param extractorId
|
|
98
|
-
*/
|
|
99
|
-
removeAllData = async (extractorId) => {
|
|
100
|
-
await this.repository.delete({ extractor: extractorId });
|
|
101
|
-
};
|
|
102
|
-
/**
|
|
103
|
-
* delete extracted data from a specific block
|
|
104
|
-
* if a box is spend in this block mark it as unspent
|
|
105
|
-
* if a box is created in this block remove it from database
|
|
106
|
-
* @param block
|
|
107
|
-
* @param extractorId
|
|
108
|
-
*/
|
|
109
|
-
deleteBlockBoxes = async (block, extractor) => {
|
|
110
|
-
this.logger.info(`Deleting boxes in block ${block} and extractor ${extractor}`);
|
|
111
|
-
await this.repository.delete({
|
|
112
|
-
extractor: extractor,
|
|
113
|
-
createBlock: block,
|
|
114
|
-
});
|
|
115
|
-
await this.repository.update({ spendBlock: block, extractor: extractor }, { spendBlock: null, spendHeight: 0 });
|
|
24
|
+
convertEntityToData = (entities) => {
|
|
25
|
+
return entities.map((data) => pick(data, ['boxId', 'address', 'serialized']));
|
|
116
26
|
};
|
|
117
27
|
}
|
|
118
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"boxAction.js","sourceRoot":"","sources":["../../lib/actions/boxAction.ts"],"names":[],"mappings":"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","sourcesContent":["import { DataSource, In, Repository } from 'typeorm';\nimport { chunk } from 'lodash-es';\nimport { AbstractLogger, DummyLogger } from '@rosen-bridge/abstract-logger';\nimport {\n  AbstractInitializableErgoExtractorAction,\n  SpendInfo,\n  DB_CHUNK_SIZE,\n  BlockInfo,\n} from '@rosen-bridge/abstract-extractor';\n\nimport { BoxEntity } from '../entities/boxEntity';\nimport { ExtractedBox } from '../interfaces/types';\nimport { JsonBI } from '../utils';\n\nexport class BoxEntityAction extends AbstractInitializableErgoExtractorAction<ExtractedBox> {\n  private readonly datasource: DataSource;\n  readonly logger: AbstractLogger;\n  private readonly repository: Repository<BoxEntity>;\n\n  constructor(dataSource: DataSource, logger?: AbstractLogger) {\n    super();\n    this.datasource = dataSource;\n    this.logger = logger ? logger : new DummyLogger();\n    this.repository = dataSource.getRepository(BoxEntity);\n  }\n\n  /**\n   * insert all extracted box data in an atomic transaction\n   * @param boxes\n   * @param extractor\n   * @return success\n   */\n  insertBoxes = async (boxes: Array<ExtractedBox>, extractor: string) => {\n    const boxIds = boxes.map((item) => item.boxId);\n    const dbBoxes = await this.datasource.getRepository(BoxEntity).findBy({\n      boxId: In(boxIds),\n      extractor: extractor,\n    });\n    if (dbBoxes.length > 0)\n      this.logger.debug(`Found stored boxes with same boxId`, dbBoxes);\n    let success = true;\n    const queryRunner = this.datasource.createQueryRunner();\n    await queryRunner.connect();\n    await queryRunner.startTransaction();\n    const repository = await queryRunner.manager.getRepository(BoxEntity);\n    try {\n      for (const box of boxes) {\n        const entity = {\n          address: box.address,\n          boxId: box.boxId,\n          createBlock: box.blockId,\n          creationHeight: box.height,\n          spendBlock: box.spendBlock,\n          spendHeight: box.spendHeight,\n          serialized: box.serialized,\n          extractor: extractor,\n        };\n        const dbBox = dbBoxes.filter((item) => item.boxId === box.boxId);\n        if (dbBox.length > 0) {\n          this.logger.info(\n            `Updating box ${box.boxId} and extractor ${extractor}`\n          );\n          await repository.update({ id: dbBox[0].id }, entity);\n          this.logger.debug(\n            `Updated entity is [${JsonBI.stringify(\n              box\n            )}], and stored similar box is [${JsonBI.stringify(dbBox)}]`\n          );\n        } else {\n          this.logger.info(`Storing box ${box.boxId}`);\n          await repository.insert(entity);\n          this.logger.debug(`Stored ${JsonBI.stringify(entity)}`);\n        }\n      }\n      await queryRunner.commitTransaction();\n    } catch (e) {\n      this.logger.error(`An error occurred during store boxes action: ${e}`);\n      await queryRunner.rollbackTransaction();\n      success = false;\n    } finally {\n      await queryRunner.release();\n    }\n    return success;\n  };\n\n  /**\n   * update spending information of stored boxes\n   * chunk spendInfos to prevent large database queries\n   * @param spendInfos\n   * @param block\n   * @param extractor\n   */\n  spendBoxes = async (\n    spendInfos: Array<SpendInfo>,\n    block: BlockInfo,\n    extractor: string\n  ): Promise<void> => {\n    const spendInfoChunks = chunk(spendInfos, DB_CHUNK_SIZE);\n    for (const spendInfoChunk of spendInfoChunks) {\n      const boxIds = spendInfoChunk.map((info) => info.boxId);\n      const updateResult = await this.repository.update(\n        { boxId: In(boxIds), extractor: extractor },\n        { spendBlock: block.hash, spendHeight: block.height }\n      );\n\n      if (updateResult.affected && updateResult.affected > 0) {\n        const spentRows = await this.repository.findBy({\n          boxId: In(boxIds),\n          spendBlock: block.hash,\n        });\n        for (const row of spentRows) {\n          this.logger.debug(\n            `Spent box with boxId [${row.boxId}] at height ${block.height}`\n          );\n        }\n      }\n    }\n  };\n\n  /**\n   * remove all existing data for the extractor\n   * @param extractorId\n   */\n  removeAllData = async (extractorId: string) => {\n    await this.repository.delete({ extractor: extractorId });\n  };\n\n  /**\n   * delete extracted data from a specific block\n   * if a box is spend in this block mark it as unspent\n   * if a box is created in this block remove it from database\n   * @param block\n   * @param extractorId\n   */\n  deleteBlockBoxes = async (block: string, extractor: string) => {\n    this.logger.info(\n      `Deleting boxes in block ${block} and extractor ${extractor}`\n    );\n    await this.repository.delete({\n      extractor: extractor,\n      createBlock: block,\n    });\n    await this.repository.update(\n      { spendBlock: block, extractor: extractor },\n      { spendBlock: null, spendHeight: 0 }\n    );\n  };\n}\n"]}
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYm94QWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vbGliL2FjdGlvbnMvYm94QWN0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFFakMsT0FBTyxFQUNMLHdDQUF3QyxHQUV6QyxNQUFNLGtDQUFrQyxDQUFDO0FBRTFDLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUdsRCxNQUFNLE9BQU8sZUFBZ0IsU0FBUSx3Q0FHcEM7SUFDQyxZQUFZLFVBQXNCLEVBQUUsTUFBdUI7UUFDekQsS0FBSyxDQUFDLFVBQVUsRUFBRSxTQUFTLEVBQUUsTUFBTSxDQUFDLENBQUM7SUFDdkMsQ0FBQztJQUVEOztPQUVHO0lBQ0gsWUFBWSxHQUFHLENBQ2IsS0FBcUIsRUFDckIsS0FBZ0IsRUFDaEIsU0FBaUIsRUFDUSxFQUFFO1FBQzNCLE9BQU8sS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUMsQ0FBQztZQUN6QixPQUFPLEVBQUUsR0FBRyxDQUFDLE9BQU87WUFDcEIsS0FBSyxFQUFFLEdBQUcsQ0FBQyxLQUFLO1lBQ2hCLEtBQUssRUFBRSxLQUFLLENBQUMsSUFBSTtZQUNqQixNQUFNLEVBQUUsS0FBSyxDQUFDLE1BQU07WUFDcEIsVUFBVSxFQUFFLEdBQUcsQ0FBQyxVQUFVO1lBQzFCLFNBQVMsRUFBRSxTQUFTO1NBQ3JCLENBQUMsQ0FBQyxDQUFDO0lBQ04sQ0FBQyxDQUFDO0lBRUY7O09BRUc7SUFDSCxtQkFBbUIsR0FBRyxDQUFDLFFBQXFCLEVBQWtCLEVBQUU7UUFDOUQsT0FBTyxRQUFRLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FDM0IsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxDQUFDLENBQUMsQ0FDL0MsQ0FBQztJQUNKLENBQUMsQ0FBQztDQUNIIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGF0YVNvdXJjZSB9IGZyb20gJ3R5cGVvcm0nO1xuaW1wb3J0IHsgcGljayB9IGZyb20gJ2xvZGFzaC1lcyc7XG5pbXBvcnQgeyBBYnN0cmFjdExvZ2dlciB9IGZyb20gJ0Byb3Nlbi1icmlkZ2UvYWJzdHJhY3QtbG9nZ2VyJztcbmltcG9ydCB7XG4gIEFic3RyYWN0SW5pdGlhbGl6YWJsZUVyZ29FeHRyYWN0b3JBY3Rpb24sXG4gIEJsb2NrSW5mbyxcbn0gZnJvbSAnQHJvc2VuLWJyaWRnZS9hYnN0cmFjdC1leHRyYWN0b3InO1xuXG5pbXBvcnQgeyBCb3hFbnRpdHkgfSBmcm9tICcuLi9lbnRpdGllcy9ib3hFbnRpdHknO1xuaW1wb3J0IHsgRXh0cmFjdGVkQm94IH0gZnJvbSAnLi4vaW50ZXJmYWNlcy90eXBlcyc7XG5cbmV4cG9ydCBjbGFzcyBCb3hFbnRpdHlBY3Rpb24gZXh0ZW5kcyBBYnN0cmFjdEluaXRpYWxpemFibGVFcmdvRXh0cmFjdG9yQWN0aW9uPFxuICBFeHRyYWN0ZWRCb3gsXG4gIEJveEVudGl0eVxuPiB7XG4gIGNvbnN0cnVjdG9yKGRhdGFTb3VyY2U6IERhdGFTb3VyY2UsIGxvZ2dlcj86IEFic3RyYWN0TG9nZ2VyKSB7XG4gICAgc3VwZXIoZGF0YVNvdXJjZSwgQm94RW50aXR5LCBsb2dnZXIpO1xuICB9XG5cbiAgLyoqXG4gICAqIGNyZWF0ZSB0aGUgYm94IGVudGl0eSBmcm9tIGV4dHJhY3RlZCBkYXRhIGFuZCBibG9jayBpbmZvcm1hdGlvblxuICAgKi9cbiAgY3JlYXRlRW50aXR5ID0gKFxuICAgIGJveGVzOiBFeHRyYWN0ZWRCb3hbXSxcbiAgICBibG9jazogQmxvY2tJbmZvLFxuICAgIGV4dHJhY3Rvcjogc3RyaW5nXG4gICk6IE9taXQ8Qm94RW50aXR5LCAnaWQnPltdID0+IHtcbiAgICByZXR1cm4gYm94ZXMubWFwKChib3gpID0+ICh7XG4gICAgICBhZGRyZXNzOiBib3guYWRkcmVzcyxcbiAgICAgIGJveElkOiBib3guYm94SWQsXG4gICAgICBibG9jazogYmxvY2suaGFzaCxcbiAgICAgIGhlaWdodDogYmxvY2suaGVpZ2h0LFxuICAgICAgc2VyaWFsaXplZDogYm94LnNlcmlhbGl6ZWQsXG4gICAgICBleHRyYWN0b3I6IGV4dHJhY3RvcixcbiAgICB9KSk7XG4gIH07XG5cbiAgLyoqXG4gICAqIGNvbnZlcnQgdGhlIGRhdGFiYXNlIGVudGl0eSBiYWNrIHRvIHJhdyBkYXRhXG4gICAqL1xuICBjb252ZXJ0RW50aXR5VG9EYXRhID0gKGVudGl0aWVzOiBCb3hFbnRpdHlbXSk6IEV4dHJhY3RlZEJveFtdID0+IHtcbiAgICByZXR1cm4gZW50aXRpZXMubWFwKChkYXRhKSA9PlxuICAgICAgcGljayhkYXRhLCBbJ2JveElkJywgJ2FkZHJlc3MnLCAnc2VyaWFsaXplZCddKVxuICAgICk7XG4gIH07XG59XG4iXX0=
|
|
@@ -1,12 +1,5 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
import { AbstractErgoExtractorEntity } from '@rosen-bridge/abstract-extractor';
|
|
2
|
+
export declare class BoxEntity extends AbstractErgoExtractorEntity {
|
|
3
3
|
address: string;
|
|
4
|
-
boxId: string;
|
|
5
|
-
createBlock: string;
|
|
6
|
-
creationHeight: number;
|
|
7
|
-
serialized: string;
|
|
8
|
-
spendBlock?: string | null;
|
|
9
|
-
spendHeight?: number;
|
|
10
|
-
extractor: string;
|
|
11
4
|
}
|
|
12
5
|
//# sourceMappingURL=boxEntity.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"boxEntity.d.ts","sourceRoot":"","sources":["../../lib/entities/boxEntity.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"boxEntity.d.ts","sourceRoot":"","sources":["../../lib/entities/boxEntity.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,2BAA2B,EAAE,MAAM,kCAAkC,CAAC;AAG/E,qBACa,SAAU,SAAQ,2BAA2B;IAExD,OAAO,EAAE,MAAM,CAAC;CACjB"}
|
|
@@ -7,56 +7,17 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
7
7
|
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
8
8
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
9
9
|
};
|
|
10
|
-
import {
|
|
11
|
-
|
|
12
|
-
|
|
10
|
+
import { AbstractErgoExtractorEntity } from '@rosen-bridge/abstract-extractor';
|
|
11
|
+
import { Column, Entity } from 'typeorm';
|
|
12
|
+
let BoxEntity = class BoxEntity extends AbstractErgoExtractorEntity {
|
|
13
13
|
address;
|
|
14
|
-
boxId;
|
|
15
|
-
createBlock;
|
|
16
|
-
creationHeight;
|
|
17
|
-
serialized;
|
|
18
|
-
spendBlock;
|
|
19
|
-
spendHeight;
|
|
20
|
-
extractor;
|
|
21
14
|
};
|
|
22
|
-
__decorate([
|
|
23
|
-
PrimaryGeneratedColumn(),
|
|
24
|
-
__metadata("design:type", Number)
|
|
25
|
-
], BoxEntity.prototype, "id", void 0);
|
|
26
15
|
__decorate([
|
|
27
16
|
Column(),
|
|
28
17
|
__metadata("design:type", String)
|
|
29
18
|
], BoxEntity.prototype, "address", void 0);
|
|
30
|
-
__decorate([
|
|
31
|
-
Column(),
|
|
32
|
-
__metadata("design:type", String)
|
|
33
|
-
], BoxEntity.prototype, "boxId", void 0);
|
|
34
|
-
__decorate([
|
|
35
|
-
Column(),
|
|
36
|
-
__metadata("design:type", String)
|
|
37
|
-
], BoxEntity.prototype, "createBlock", void 0);
|
|
38
|
-
__decorate([
|
|
39
|
-
Column(),
|
|
40
|
-
__metadata("design:type", Number)
|
|
41
|
-
], BoxEntity.prototype, "creationHeight", void 0);
|
|
42
|
-
__decorate([
|
|
43
|
-
Column(),
|
|
44
|
-
__metadata("design:type", String)
|
|
45
|
-
], BoxEntity.prototype, "serialized", void 0);
|
|
46
|
-
__decorate([
|
|
47
|
-
Column({ nullable: true, type: 'text' }),
|
|
48
|
-
__metadata("design:type", Object)
|
|
49
|
-
], BoxEntity.prototype, "spendBlock", void 0);
|
|
50
|
-
__decorate([
|
|
51
|
-
Column({ nullable: true }),
|
|
52
|
-
__metadata("design:type", Number)
|
|
53
|
-
], BoxEntity.prototype, "spendHeight", void 0);
|
|
54
|
-
__decorate([
|
|
55
|
-
Column(),
|
|
56
|
-
__metadata("design:type", String)
|
|
57
|
-
], BoxEntity.prototype, "extractor", void 0);
|
|
58
19
|
BoxEntity = __decorate([
|
|
59
20
|
Entity('box_entity')
|
|
60
21
|
], BoxEntity);
|
|
61
22
|
export { BoxEntity };
|
|
62
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYm94RW50aXR5LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vbGliL2VudGl0aWVzL2JveEVudGl0eS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBQSxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUMvRSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxNQUFNLFNBQVMsQ0FBQztBQUd6QyxJQUFhLFNBQVMsR0FBdEIsTUFBYSxTQUFVLFNBQVEsMkJBQTJCO0lBRXhELE9BQU8sQ0FBUztDQUNqQixDQUFBO0FBREM7SUFEQyxNQUFNLEVBQUU7OzBDQUNPO0FBRkwsU0FBUztJQURyQixNQUFNLENBQUMsWUFBWSxDQUFDO0dBQ1IsU0FBUyxDQUdyQjtTQUhZLFNBQVMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBYnN0cmFjdEVyZ29FeHRyYWN0b3JFbnRpdHkgfSBmcm9tICdAcm9zZW4tYnJpZGdlL2Fic3RyYWN0LWV4dHJhY3Rvcic7XG5pbXBvcnQgeyBDb2x1bW4sIEVudGl0eSB9IGZyb20gJ3R5cGVvcm0nO1xuXG5ARW50aXR5KCdib3hfZW50aXR5JylcbmV4cG9ydCBjbGFzcyBCb3hFbnRpdHkgZXh0ZW5kcyBBYnN0cmFjdEVyZ29FeHRyYWN0b3JFbnRpdHkge1xuICBAQ29sdW1uKClcbiAgYWRkcmVzczogc3RyaW5nO1xufVxuIl19
|
|
@@ -4,7 +4,8 @@ import { AbstractLogger } from '@rosen-bridge/abstract-logger';
|
|
|
4
4
|
import { AbstractInitializableErgoExtractor, OutputBox, ErgoNetworkType } from '@rosen-bridge/abstract-extractor';
|
|
5
5
|
import { BoxEntityAction } from '../actions/boxAction';
|
|
6
6
|
import { ExtractedBox } from '../interfaces/types';
|
|
7
|
-
|
|
7
|
+
import { BoxEntity } from '../entities/boxEntity';
|
|
8
|
+
export declare class ErgoUTXOExtractor extends AbstractInitializableErgoExtractor<ExtractedBox, BoxEntity> {
|
|
8
9
|
readonly actions: BoxEntityAction;
|
|
9
10
|
private readonly id;
|
|
10
11
|
private readonly networkType;
|
|
@@ -24,10 +25,8 @@ export declare class ErgoUTXOExtractor extends AbstractInitializableErgoExtracto
|
|
|
24
25
|
/**
|
|
25
26
|
* extract box data to proper format (not including spending information)
|
|
26
27
|
* @param box
|
|
27
|
-
* @param blockId box inclusion block hash
|
|
28
|
-
* @param height box inclusion block height
|
|
29
28
|
* @return extracted data in proper format
|
|
30
29
|
*/
|
|
31
|
-
extractBoxData: (box: OutputBox
|
|
30
|
+
extractBoxData: (box: OutputBox) => ExtractedBox | undefined;
|
|
32
31
|
}
|
|
33
32
|
//# sourceMappingURL=ergoUtxoExtractor.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ergoUtxoExtractor.d.ts","sourceRoot":"","sources":["../../lib/extractor/ergoUtxoExtractor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AACrC,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAEhD,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,EACL,kCAAkC,EAClC,SAAS,EAET,eAAe,EAChB,MAAM,kCAAkC,CAAC;AAE1C,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAEvD,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"ergoUtxoExtractor.d.ts","sourceRoot":"","sources":["../../lib/extractor/ergoUtxoExtractor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AACrC,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAEhD,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,EACL,kCAAkC,EAClC,SAAS,EAET,eAAe,EAChB,MAAM,kCAAkC,CAAC;AAE1C,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAEvD,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,EAAE,SAAS,EAAE,MAAM,uBAAuB,CAAC;AAElD,qBAAa,iBAAkB,SAAQ,kCAAkC,CACvE,YAAY,EACZ,SAAS,CACV;IACC,QAAQ,CAAC,OAAO,EAAE,eAAe,CAAC;IAClC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAS;IAC5B,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAwB;IACpD,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAS;IACnC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAgB;gBAGrC,UAAU,EAAE,UAAU,EACtB,EAAE,EAAE,MAAM,EACV,WAAW,EAAE,OAAO,CAAC,aAAa,EAClC,GAAG,EAAE,MAAM,EACX,IAAI,EAAE,eAAe,EACrB,OAAO,EAAE,MAAM,EACf,MAAM,CAAC,EAAE,KAAK,CAAC,MAAM,CAAC,EACtB,MAAM,CAAC,EAAE,cAAc,EACvB,UAAU,UAAO;IAYnB;;OAEG;IACH,KAAK,eAAsB;IAE3B;;;;OAIG;IACH,OAAO,QAAS,SAAS,KAAG,OAAO,CAKjC;IAEF;;;;OAIG;IACH,cAAc,QAAS,SAAS,KAAG,YAAY,GAAG,SAAS,CAazD;CACH"}
|
|
@@ -35,19 +35,15 @@ export class ErgoUTXOExtractor extends AbstractInitializableErgoExtractor {
|
|
|
35
35
|
/**
|
|
36
36
|
* extract box data to proper format (not including spending information)
|
|
37
37
|
* @param box
|
|
38
|
-
* @param blockId box inclusion block hash
|
|
39
|
-
* @param height box inclusion block height
|
|
40
38
|
* @return extracted data in proper format
|
|
41
39
|
*/
|
|
42
|
-
extractBoxData = (box
|
|
40
|
+
extractBoxData = (box) => {
|
|
43
41
|
const ergoBox = ergoLib.ErgoBox.from_json(JsonBI.stringify(box));
|
|
44
42
|
return {
|
|
45
43
|
boxId: ergoBox.box_id().to_str(),
|
|
46
44
|
address: ergoLib.Address.recreate_from_ergo_tree(ergoLib.ErgoTree.from_base16_bytes(ergoBox.ergo_tree().to_base16_bytes())).to_base58(this.networkType),
|
|
47
45
|
serialized: Buffer.from(ergoBox.sigma_serialize_bytes()).toString('base64'),
|
|
48
|
-
blockId: blockId,
|
|
49
|
-
height: height,
|
|
50
46
|
};
|
|
51
47
|
};
|
|
52
48
|
}
|
|
53
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJnb1V0eG9FeHRyYWN0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9saWIvZXh0cmFjdG9yL2VyZ29VdHhvRXh0cmFjdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sS0FBSyxPQUFPLE1BQU0sc0JBQXNCLENBQUM7QUFDaEQsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLFFBQVEsQ0FBQztBQUVoQyxPQUFPLEVBQ0wsa0NBQWtDLEVBRWxDLFdBQVcsR0FFWixNQUFNLGtDQUFrQyxDQUFDO0FBRTFDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBSWxDLE1BQU0sT0FBTyxpQkFBa0IsU0FBUSxrQ0FHdEM7SUFDVSxPQUFPLENBQWtCO0lBQ2pCLEVBQUUsQ0FBUztJQUNYLFdBQVcsQ0FBd0I7SUFDbkMsUUFBUSxDQUFVO0lBQ2xCLE1BQU0sQ0FBZ0I7SUFFdkMsWUFDRSxVQUFzQixFQUN0QixFQUFVLEVBQ1YsV0FBa0MsRUFDbEMsR0FBVyxFQUNYLElBQXFCLEVBQ3JCLE9BQWUsRUFDZixNQUFzQixFQUN0QixNQUF1QixFQUN2QixVQUFVLEdBQUcsSUFBSTtRQUVqQixLQUFLLENBQUMsSUFBSSxFQUFFLEdBQUcsRUFBRSxPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsQ0FBQyxDQUFDO1FBQzlDLElBQUksQ0FBQyxFQUFFLEdBQUcsRUFBRSxDQUFDO1FBQ2IsSUFBSSxDQUFDLFdBQVcsR0FBRyxXQUFXLENBQUM7UUFDL0IsSUFBSSxDQUFDLFFBQVEsR0FBRyxPQUFPO1lBQ3JCLENBQUMsQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQyxZQUFZLEVBQUUsQ0FBQyxlQUFlLEVBQUU7WUFDdkUsQ0FBQyxDQUFDLFNBQVMsQ0FBQztRQUNkLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztRQUNuQyxJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksZUFBZSxDQUFDLFVBQVUsRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDOUQsQ0FBQztJQUVEOztPQUVHO0lBQ0gsS0FBSyxHQUFHLEdBQUcsRUFBRSxDQUFDLEdBQUcsSUFBSSxDQUFDLEVBQUUsRUFBRSxDQUFDO0lBRTNCOzs7O09BSUc7SUFDSCxPQUFPLEdBQUcsQ0FBQyxHQUFjLEVBQVcsRUFBRTtRQUNwQyxPQUFPLENBQ0wsQ0FBQyxDQUFDLElBQUksQ0FBQyxRQUFRLElBQUksR0FBRyxDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUMsUUFBUSxDQUFDO1lBQ2pELENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLElBQUksQ0FBQyxJQUFJLFdBQVcsQ0FBQyxHQUFHLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQzNELENBQUM7SUFDSixDQUFDLENBQUM7SUFFRjs7OztPQUlHO0lBQ0gsY0FBYyxHQUFHLENBQUMsR0FBYyxFQUE0QixFQUFFO1FBQzVELE1BQU0sT0FBTyxHQUFHLE9BQU8sQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztRQUNqRSxPQUFPO1lBQ0wsS0FBSyxFQUFFLE9BQU8sQ0FBQyxNQUFNLEVBQUUsQ0FBQyxNQUFNLEVBQUU7WUFDaEMsT0FBTyxFQUFFLE9BQU8sQ0FBQyxPQUFPLENBQUMsdUJBQXVCLENBQzlDLE9BQU8sQ0FBQyxRQUFRLENBQUMsaUJBQWlCLENBQ2hDLE9BQU8sQ0FBQyxTQUFTLEVBQUUsQ0FBQyxlQUFlLEVBQUUsQ0FDdEMsQ0FDRixDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDO1lBQzdCLFVBQVUsRUFBRSxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxxQkFBcUIsRUFBRSxDQUFDLENBQUMsUUFBUSxDQUMvRCxRQUFRLENBQ1Q7U0FDRixDQUFDO0lBQ0osQ0FBQyxDQUFDO0NBQ0giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEYXRhU291cmNlIH0gZnJvbSAndHlwZW9ybSc7XG5pbXBvcnQgKiBhcyBlcmdvTGliIGZyb20gJ2VyZ28tbGliLXdhc20tbm9kZWpzJztcbmltcG9ydCB7IEJ1ZmZlciB9IGZyb20gJ2J1ZmZlcic7XG5pbXBvcnQgeyBBYnN0cmFjdExvZ2dlciB9IGZyb20gJ0Byb3Nlbi1icmlkZ2UvYWJzdHJhY3QtbG9nZ2VyJztcbmltcG9ydCB7XG4gIEFic3RyYWN0SW5pdGlhbGl6YWJsZUVyZ29FeHRyYWN0b3IsXG4gIE91dHB1dEJveCxcbiAgYm94SGFzVG9rZW4sXG4gIEVyZ29OZXR3b3JrVHlwZSxcbn0gZnJvbSAnQHJvc2VuLWJyaWRnZS9hYnN0cmFjdC1leHRyYWN0b3InO1xuXG5pbXBvcnQgeyBCb3hFbnRpdHlBY3Rpb24gfSBmcm9tICcuLi9hY3Rpb25zL2JveEFjdGlvbic7XG5pbXBvcnQgeyBKc29uQkkgfSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQgeyBFeHRyYWN0ZWRCb3ggfSBmcm9tICcuLi9pbnRlcmZhY2VzL3R5cGVzJztcbmltcG9ydCB7IEJveEVudGl0eSB9IGZyb20gJy4uL2VudGl0aWVzL2JveEVudGl0eSc7XG5cbmV4cG9ydCBjbGFzcyBFcmdvVVRYT0V4dHJhY3RvciBleHRlbmRzIEFic3RyYWN0SW5pdGlhbGl6YWJsZUVyZ29FeHRyYWN0b3I8XG4gIEV4dHJhY3RlZEJveCxcbiAgQm94RW50aXR5XG4+IHtcbiAgcmVhZG9ubHkgYWN0aW9uczogQm94RW50aXR5QWN0aW9uO1xuICBwcml2YXRlIHJlYWRvbmx5IGlkOiBzdHJpbmc7XG4gIHByaXZhdGUgcmVhZG9ubHkgbmV0d29ya1R5cGU6IGVyZ29MaWIuTmV0d29ya1ByZWZpeDtcbiAgcHJpdmF0ZSByZWFkb25seSBlcmdvVHJlZT86IHN0cmluZztcbiAgcHJpdmF0ZSByZWFkb25seSB0b2tlbnM6IEFycmF5PHN0cmluZz47XG5cbiAgY29uc3RydWN0b3IoXG4gICAgZGF0YVNvdXJjZTogRGF0YVNvdXJjZSxcbiAgICBpZDogc3RyaW5nLFxuICAgIG5ldHdvcmtUeXBlOiBlcmdvTGliLk5ldHdvcmtQcmVmaXgsXG4gICAgdXJsOiBzdHJpbmcsXG4gICAgdHlwZTogRXJnb05ldHdvcmtUeXBlLFxuICAgIGFkZHJlc3M6IHN0cmluZyxcbiAgICB0b2tlbnM/OiBBcnJheTxzdHJpbmc+LFxuICAgIGxvZ2dlcj86IEFic3RyYWN0TG9nZ2VyLFxuICAgIGluaXRpYWxpemUgPSB0cnVlXG4gICkge1xuICAgIHN1cGVyKHR5cGUsIHVybCwgYWRkcmVzcywgbG9nZ2VyLCBpbml0aWFsaXplKTtcbiAgICB0aGlzLmlkID0gaWQ7XG4gICAgdGhpcy5uZXR3b3JrVHlwZSA9IG5ldHdvcmtUeXBlO1xuICAgIHRoaXMuZXJnb1RyZWUgPSBhZGRyZXNzXG4gICAgICA/IGVyZ29MaWIuQWRkcmVzcy5mcm9tX2Jhc2U1OChhZGRyZXNzKS50b19lcmdvX3RyZWUoKS50b19iYXNlMTZfYnl0ZXMoKVxuICAgICAgOiB1bmRlZmluZWQ7XG4gICAgdGhpcy50b2tlbnMgPSB0b2tlbnMgPyB0b2tlbnMgOiBbXTtcbiAgICB0aGlzLmFjdGlvbnMgPSBuZXcgQm94RW50aXR5QWN0aW9uKGRhdGFTb3VyY2UsIHRoaXMubG9nZ2VyKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBnZXQgSWQgZm9yIGN1cnJlbnQgZXh0cmFjdG9yXG4gICAqL1xuICBnZXRJZCA9ICgpID0+IGAke3RoaXMuaWR9YDtcblxuICAvKipcbiAgICogY2hlY2sgcHJvcGVyIGRhdGEgZm9ybWF0IGluIHRoZSBib3hcbiAgICogQHBhcmFtIGJveFxuICAgKiBAcmV0dXJuIHRydWUgaWYgdGhlIGJveCBoYXMgdGhlIHJlcXVpcmVkIGRhdGEgYW5kIGZhbHNlIG90aGVyd2lzZVxuICAgKi9cbiAgaGFzRGF0YSA9IChib3g6IE91dHB1dEJveCk6IGJvb2xlYW4gPT4ge1xuICAgIHJldHVybiAoXG4gICAgICAoIXRoaXMuZXJnb1RyZWUgfHwgYm94LmVyZ29UcmVlID09IHRoaXMuZXJnb1RyZWUpICYmXG4gICAgICAodGhpcy50b2tlbnMubGVuZ3RoID09IDAgfHwgYm94SGFzVG9rZW4oYm94LCB0aGlzLnRva2VucykpXG4gICAgKTtcbiAgfTtcblxuICAvKipcbiAgICogZXh0cmFjdCBib3ggZGF0YSB0byBwcm9wZXIgZm9ybWF0IChub3QgaW5jbHVkaW5nIHNwZW5kaW5nIGluZm9ybWF0aW9uKVxuICAgKiBAcGFyYW0gYm94XG4gICAqIEByZXR1cm4gZXh0cmFjdGVkIGRhdGEgaW4gcHJvcGVyIGZvcm1hdFxuICAgKi9cbiAgZXh0cmFjdEJveERhdGEgPSAoYm94OiBPdXRwdXRCb3gpOiBFeHRyYWN0ZWRCb3ggfCB1bmRlZmluZWQgPT4ge1xuICAgIGNvbnN0IGVyZ29Cb3ggPSBlcmdvTGliLkVyZ29Cb3guZnJvbV9qc29uKEpzb25CSS5zdHJpbmdpZnkoYm94KSk7XG4gICAgcmV0dXJuIHtcbiAgICAgIGJveElkOiBlcmdvQm94LmJveF9pZCgpLnRvX3N0cigpLFxuICAgICAgYWRkcmVzczogZXJnb0xpYi5BZGRyZXNzLnJlY3JlYXRlX2Zyb21fZXJnb190cmVlKFxuICAgICAgICBlcmdvTGliLkVyZ29UcmVlLmZyb21fYmFzZTE2X2J5dGVzKFxuICAgICAgICAgIGVyZ29Cb3guZXJnb190cmVlKCkudG9fYmFzZTE2X2J5dGVzKClcbiAgICAgICAgKVxuICAgICAgKS50b19iYXNlNTgodGhpcy5uZXR3b3JrVHlwZSksXG4gICAgICBzZXJpYWxpemVkOiBCdWZmZXIuZnJvbShlcmdvQm94LnNpZ21hX3NlcmlhbGl6ZV9ieXRlcygpKS50b1N0cmluZyhcbiAgICAgICAgJ2Jhc2U2NCdcbiAgICAgICksXG4gICAgfTtcbiAgfTtcbn1cbiJdfQ==
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../lib/interfaces/types.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,YAAY;IAC3B,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,CAAC;IAChB,UAAU,EAAE,MAAM,CAAC;
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../lib/interfaces/types.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,YAAY;IAC3B,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,CAAC;IAChB,UAAU,EAAE,MAAM,CAAC;CACpB"}
|
package/dist/interfaces/types.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9saWIvaW50ZXJmYWNlcy90eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBFeHRyYWN0ZWRCb3gge1xuICBib3hJZDogc3RyaW5nO1xuICBhZGRyZXNzOiBzdHJpbmc7XG4gIHNlcmlhbGl6ZWQ6IHN0cmluZztcbn1cbiJdfQ==
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../lib/migrations/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,oCAAoC,CAAC;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../lib/migrations/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,oCAAoC,CAAC;AAG5E,OAAO,EAAE,sBAAsB,EAAE,MAAM,kCAAkC,CAAC;AAI1E,eAAO,MAAM,UAAU;;;CAWtB,CAAC"}
|
package/dist/migrations/index.js
CHANGED
|
@@ -1,9 +1,19 @@
|
|
|
1
1
|
import { migration1688558553044 } from './postgres/1688558553044-migration';
|
|
2
2
|
import { migration1689151869889 } from './postgres/1689151869889-migration';
|
|
3
|
+
import { migration1737785465594 } from './postgres/1737785465594-migration';
|
|
3
4
|
import { migration1688555566662 } from './sqlite/1688555566662-migration';
|
|
4
5
|
import { migration1689143753142 } from './sqlite/1689143753142-migration';
|
|
6
|
+
import { migration1737532655167 } from './sqlite/1737532655167-migration';
|
|
5
7
|
export const migrations = {
|
|
6
|
-
sqlite: [
|
|
7
|
-
|
|
8
|
+
sqlite: [
|
|
9
|
+
migration1688555566662,
|
|
10
|
+
migration1689143753142,
|
|
11
|
+
migration1737532655167,
|
|
12
|
+
],
|
|
13
|
+
postgres: [
|
|
14
|
+
migration1688558553044,
|
|
15
|
+
migration1689151869889,
|
|
16
|
+
migration1737785465594,
|
|
17
|
+
],
|
|
8
18
|
};
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9saWIvbWlncmF0aW9ucy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUM1RSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUM1RSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUM1RSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUMxRSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUMxRSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUUxRSxNQUFNLENBQUMsTUFBTSxVQUFVLEdBQUc7SUFDeEIsTUFBTSxFQUFFO1FBQ04sc0JBQXNCO1FBQ3RCLHNCQUFzQjtRQUN0QixzQkFBc0I7S0FDdkI7SUFDRCxRQUFRLEVBQUU7UUFDUixzQkFBc0I7UUFDdEIsc0JBQXNCO1FBQ3RCLHNCQUFzQjtLQUN2QjtDQUNGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBtaWdyYXRpb24xNjg4NTU4NTUzMDQ0IH0gZnJvbSAnLi9wb3N0Z3Jlcy8xNjg4NTU4NTUzMDQ0LW1pZ3JhdGlvbic7XG5pbXBvcnQgeyBtaWdyYXRpb24xNjg5MTUxODY5ODg5IH0gZnJvbSAnLi9wb3N0Z3Jlcy8xNjg5MTUxODY5ODg5LW1pZ3JhdGlvbic7XG5pbXBvcnQgeyBtaWdyYXRpb24xNzM3Nzg1NDY1NTk0IH0gZnJvbSAnLi9wb3N0Z3Jlcy8xNzM3Nzg1NDY1NTk0LW1pZ3JhdGlvbic7XG5pbXBvcnQgeyBtaWdyYXRpb24xNjg4NTU1NTY2NjYyIH0gZnJvbSAnLi9zcWxpdGUvMTY4ODU1NTU2NjY2Mi1taWdyYXRpb24nO1xuaW1wb3J0IHsgbWlncmF0aW9uMTY4OTE0Mzc1MzE0MiB9IGZyb20gJy4vc3FsaXRlLzE2ODkxNDM3NTMxNDItbWlncmF0aW9uJztcbmltcG9ydCB7IG1pZ3JhdGlvbjE3Mzc1MzI2NTUxNjcgfSBmcm9tICcuL3NxbGl0ZS8xNzM3NTMyNjU1MTY3LW1pZ3JhdGlvbic7XG5cbmV4cG9ydCBjb25zdCBtaWdyYXRpb25zID0ge1xuICBzcWxpdGU6IFtcbiAgICBtaWdyYXRpb24xNjg4NTU1NTY2NjYyLFxuICAgIG1pZ3JhdGlvbjE2ODkxNDM3NTMxNDIsXG4gICAgbWlncmF0aW9uMTczNzUzMjY1NTE2NyxcbiAgXSxcbiAgcG9zdGdyZXM6IFtcbiAgICBtaWdyYXRpb24xNjg4NTU4NTUzMDQ0LFxuICAgIG1pZ3JhdGlvbjE2ODkxNTE4Njk4ODksXG4gICAgbWlncmF0aW9uMTczNzc4NTQ2NTU5NCxcbiAgXSxcbn07XG4iXX0=
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { MigrationInterface, QueryRunner } from 'typeorm';
|
|
2
|
+
export declare class migration1737785465594 implements MigrationInterface {
|
|
3
|
+
name: string;
|
|
4
|
+
up(queryRunner: QueryRunner): Promise<void>;
|
|
5
|
+
down(queryRunner: QueryRunner): Promise<void>;
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=1737785465594-migration.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"1737785465594-migration.d.ts","sourceRoot":"","sources":["../../../lib/migrations/postgres/1737785465594-migration.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAE1D,qBAAa,sBAAuB,YAAW,kBAAkB;IAC/D,IAAI,SAA4B;IAEnB,EAAE,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IAmB3C,IAAI,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;CAiB3D"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
export class migration1737785465594 {
|
|
2
|
+
name = 'Migration1737785465594';
|
|
3
|
+
async up(queryRunner) {
|
|
4
|
+
await queryRunner.query(`
|
|
5
|
+
ALTER TABLE "box_entity"
|
|
6
|
+
RENAME COLUMN "createBlock" TO "block"
|
|
7
|
+
`);
|
|
8
|
+
await queryRunner.query(`
|
|
9
|
+
ALTER TABLE "box_entity"
|
|
10
|
+
RENAME COLUMN "creationHeight" TO "height"
|
|
11
|
+
`);
|
|
12
|
+
await queryRunner.query(`
|
|
13
|
+
ALTER TABLE "box_entity"
|
|
14
|
+
ALTER COLUMN "spendBlock" TYPE character varying
|
|
15
|
+
`);
|
|
16
|
+
await queryRunner.query(`
|
|
17
|
+
ALTER TABLE "box_entity"
|
|
18
|
+
ADD CONSTRAINT "UQ_86fbe5bb307de1305cc22efa762" UNIQUE ("boxId", "extractor")
|
|
19
|
+
`);
|
|
20
|
+
}
|
|
21
|
+
async down(queryRunner) {
|
|
22
|
+
await queryRunner.query(`
|
|
23
|
+
ALTER TABLE "box_entity" DROP CONSTRAINT "UQ_86fbe5bb307de1305cc22efa762"
|
|
24
|
+
`);
|
|
25
|
+
await queryRunner.query(`
|
|
26
|
+
ALTER TABLE "box_entity"
|
|
27
|
+
ALTER COLUMN "spendBlock" TYPE text
|
|
28
|
+
`);
|
|
29
|
+
await queryRunner.query(`
|
|
30
|
+
ALTER TABLE "box_entity"
|
|
31
|
+
RENAME COLUMN "block" TO "createBlock"
|
|
32
|
+
`);
|
|
33
|
+
await queryRunner.query(`
|
|
34
|
+
ALTER TABLE "box_entity"
|
|
35
|
+
RENAME COLUMN "height" TO "creationHeight"
|
|
36
|
+
`);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTczNzc4NTQ2NTU5NC1taWdyYXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9saWIvbWlncmF0aW9ucy9wb3N0Z3Jlcy8xNzM3Nzg1NDY1NTk0LW1pZ3JhdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLE9BQU8sc0JBQXNCO0lBQ2pDLElBQUksR0FBRyx3QkFBd0IsQ0FBQztJQUV6QixLQUFLLENBQUMsRUFBRSxDQUFDLFdBQXdCO1FBQ3RDLE1BQU0sV0FBVyxDQUFDLEtBQUssQ0FBQzs7O1NBR25CLENBQUMsQ0FBQztRQUNQLE1BQU0sV0FBVyxDQUFDLEtBQUssQ0FBQzs7O1NBR25CLENBQUMsQ0FBQztRQUNQLE1BQU0sV0FBVyxDQUFDLEtBQUssQ0FBQzs7O1NBR25CLENBQUMsQ0FBQztRQUNQLE1BQU0sV0FBVyxDQUFDLEtBQUssQ0FBQzs7O1NBR25CLENBQUMsQ0FBQztJQUNULENBQUM7SUFFTSxLQUFLLENBQUMsSUFBSSxDQUFDLFdBQXdCO1FBQ3hDLE1BQU0sV0FBVyxDQUFDLEtBQUssQ0FBQzs7U0FFbkIsQ0FBQyxDQUFDO1FBQ1AsTUFBTSxXQUFXLENBQUMsS0FBSyxDQUFDOzs7U0FHbkIsQ0FBQyxDQUFDO1FBQ1AsTUFBTSxXQUFXLENBQUMsS0FBSyxDQUFDOzs7U0FHbkIsQ0FBQyxDQUFDO1FBQ1AsTUFBTSxXQUFXLENBQUMsS0FBSyxDQUFDOzs7U0FHbkIsQ0FBQyxDQUFDO0lBQ1QsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWlncmF0aW9uSW50ZXJmYWNlLCBRdWVyeVJ1bm5lciB9IGZyb20gJ3R5cGVvcm0nO1xuXG5leHBvcnQgY2xhc3MgbWlncmF0aW9uMTczNzc4NTQ2NTU5NCBpbXBsZW1lbnRzIE1pZ3JhdGlvbkludGVyZmFjZSB7XG4gIG5hbWUgPSAnTWlncmF0aW9uMTczNzc4NTQ2NTU5NCc7XG5cbiAgcHVibGljIGFzeW5jIHVwKHF1ZXJ5UnVubmVyOiBRdWVyeVJ1bm5lcik6IFByb21pc2U8dm9pZD4ge1xuICAgIGF3YWl0IHF1ZXJ5UnVubmVyLnF1ZXJ5KGBcbiAgICAgICAgICAgIEFMVEVSIFRBQkxFIFwiYm94X2VudGl0eVwiIFxuICAgICAgICAgICAgUkVOQU1FIENPTFVNTiBcImNyZWF0ZUJsb2NrXCIgVE8gXCJibG9ja1wiXG4gICAgICAgIGApO1xuICAgIGF3YWl0IHF1ZXJ5UnVubmVyLnF1ZXJ5KGBcbiAgICAgICAgICAgIEFMVEVSIFRBQkxFIFwiYm94X2VudGl0eVwiIFxuICAgICAgICAgICAgUkVOQU1FIENPTFVNTiBcImNyZWF0aW9uSGVpZ2h0XCIgVE8gXCJoZWlnaHRcIlxuICAgICAgICBgKTtcbiAgICBhd2FpdCBxdWVyeVJ1bm5lci5xdWVyeShgXG4gICAgICAgICAgICBBTFRFUiBUQUJMRSBcImJveF9lbnRpdHlcIiBcbiAgICAgICAgICAgIEFMVEVSIENPTFVNTiBcInNwZW5kQmxvY2tcIiBUWVBFIGNoYXJhY3RlciB2YXJ5aW5nXG4gICAgICAgIGApO1xuICAgIGF3YWl0IHF1ZXJ5UnVubmVyLnF1ZXJ5KGBcbiAgICAgICAgICAgIEFMVEVSIFRBQkxFIFwiYm94X2VudGl0eVwiXG4gICAgICAgICAgICBBREQgQ09OU1RSQUlOVCBcIlVRXzg2ZmJlNWJiMzA3ZGUxMzA1Y2MyMmVmYTc2MlwiIFVOSVFVRSAoXCJib3hJZFwiLCBcImV4dHJhY3RvclwiKVxuICAgICAgICBgKTtcbiAgfVxuXG4gIHB1YmxpYyBhc3luYyBkb3duKHF1ZXJ5UnVubmVyOiBRdWVyeVJ1bm5lcik6IFByb21pc2U8dm9pZD4ge1xuICAgIGF3YWl0IHF1ZXJ5UnVubmVyLnF1ZXJ5KGBcbiAgICAgICAgICAgIEFMVEVSIFRBQkxFIFwiYm94X2VudGl0eVwiIERST1AgQ09OU1RSQUlOVCBcIlVRXzg2ZmJlNWJiMzA3ZGUxMzA1Y2MyMmVmYTc2MlwiXG4gICAgICAgIGApO1xuICAgIGF3YWl0IHF1ZXJ5UnVubmVyLnF1ZXJ5KGBcbiAgICAgICAgICAgIEFMVEVSIFRBQkxFIFwiYm94X2VudGl0eVwiIFxuICAgICAgICAgICAgQUxURVIgQ09MVU1OIFwic3BlbmRCbG9ja1wiIFRZUEUgdGV4dFxuICAgICAgICBgKTtcbiAgICBhd2FpdCBxdWVyeVJ1bm5lci5xdWVyeShgXG4gICAgICAgICAgICBBTFRFUiBUQUJMRSBcImJveF9lbnRpdHlcIiBcbiAgICAgICAgICAgIFJFTkFNRSBDT0xVTU4gXCJibG9ja1wiIFRPIFwiY3JlYXRlQmxvY2tcIlxuICAgICAgICBgKTtcbiAgICBhd2FpdCBxdWVyeVJ1bm5lci5xdWVyeShgXG4gICAgICAgICAgICBBTFRFUiBUQUJMRSBcImJveF9lbnRpdHlcIiBcbiAgICAgICAgICAgIFJFTkFNRSBDT0xVTU4gXCJoZWlnaHRcIiBUTyBcImNyZWF0aW9uSGVpZ2h0XCJcbiAgICAgICAgYCk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { MigrationInterface, QueryRunner } from 'typeorm';
|
|
2
|
+
export declare class migration1737532655167 implements MigrationInterface {
|
|
3
|
+
name: string;
|
|
4
|
+
up(queryRunner: QueryRunner): Promise<void>;
|
|
5
|
+
down(queryRunner: QueryRunner): Promise<void>;
|
|
6
|
+
}
|
|
7
|
+
//# sourceMappingURL=1737532655167-migration.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"1737532655167-migration.d.ts","sourceRoot":"","sources":["../../../lib/migrations/sqlite/1737532655167-migration.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAE1D,qBAAa,sBAAuB,YAAW,kBAAkB;IAC/D,IAAI,SAA4B;IAEnB,EAAE,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;IA+C3C,IAAI,CAAC,WAAW,EAAE,WAAW,GAAG,OAAO,CAAC,IAAI,CAAC;CAiD3D"}
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
export class migration1737532655167 {
|
|
2
|
+
name = 'Migration1737532655167';
|
|
3
|
+
async up(queryRunner) {
|
|
4
|
+
await queryRunner.query(`
|
|
5
|
+
CREATE TABLE "temporary_box_entity" (
|
|
6
|
+
"id" integer PRIMARY KEY AUTOINCREMENT NOT NULL,
|
|
7
|
+
"boxId" varchar NOT NULL,
|
|
8
|
+
"height" integer NOT NULL,
|
|
9
|
+
"block" varchar NOT NULL,
|
|
10
|
+
"spendBlock" varchar,
|
|
11
|
+
"spendHeight" integer,
|
|
12
|
+
"address" varchar NOT NULL,
|
|
13
|
+
"extractor" varchar NOT NULL,
|
|
14
|
+
"serialized" varchar NOT NULL,
|
|
15
|
+
CONSTRAINT "UQ_86fbe5bb307de1305cc22efa762" UNIQUE ("boxId", "extractor")
|
|
16
|
+
)
|
|
17
|
+
`);
|
|
18
|
+
await queryRunner.query(`
|
|
19
|
+
INSERT INTO "temporary_box_entity"(
|
|
20
|
+
"id",
|
|
21
|
+
"address",
|
|
22
|
+
"boxId",
|
|
23
|
+
"serialized",
|
|
24
|
+
"spendBlock",
|
|
25
|
+
"extractor",
|
|
26
|
+
"spendHeight",
|
|
27
|
+
"block",
|
|
28
|
+
"height"
|
|
29
|
+
)
|
|
30
|
+
SELECT "id",
|
|
31
|
+
"address",
|
|
32
|
+
"boxId",
|
|
33
|
+
"serialized",
|
|
34
|
+
"spendBlock",
|
|
35
|
+
"extractor",
|
|
36
|
+
"spendHeight",
|
|
37
|
+
"createBlock",
|
|
38
|
+
"creationHeight"
|
|
39
|
+
FROM "box_entity"
|
|
40
|
+
`);
|
|
41
|
+
await queryRunner.query(`
|
|
42
|
+
DROP TABLE "box_entity"
|
|
43
|
+
`);
|
|
44
|
+
await queryRunner.query(`
|
|
45
|
+
ALTER TABLE "temporary_box_entity"
|
|
46
|
+
RENAME TO "box_entity"
|
|
47
|
+
`);
|
|
48
|
+
}
|
|
49
|
+
async down(queryRunner) {
|
|
50
|
+
await queryRunner.query(`
|
|
51
|
+
ALTER TABLE "box_entity"
|
|
52
|
+
RENAME TO "temporary_box_entity"
|
|
53
|
+
`);
|
|
54
|
+
await queryRunner.query(`
|
|
55
|
+
CREATE TABLE "box_entity" (
|
|
56
|
+
"id" integer PRIMARY KEY AUTOINCREMENT NOT NULL,
|
|
57
|
+
"address" varchar NOT NULL,
|
|
58
|
+
"boxId" varchar NOT NULL,
|
|
59
|
+
"serialized" varchar NOT NULL,
|
|
60
|
+
"spendBlock" text,
|
|
61
|
+
"extractor" varchar NOT NULL,
|
|
62
|
+
"spendHeight" integer,
|
|
63
|
+
"createBlock" varchar NOT NULL,
|
|
64
|
+
"creationHeight" integer NOT NULL
|
|
65
|
+
)
|
|
66
|
+
`);
|
|
67
|
+
await queryRunner.query(`
|
|
68
|
+
INSERT INTO "box_entity"(
|
|
69
|
+
"id",
|
|
70
|
+
"address",
|
|
71
|
+
"boxId",
|
|
72
|
+
"serialized",
|
|
73
|
+
"spendBlock",
|
|
74
|
+
"extractor",
|
|
75
|
+
"spendHeight",
|
|
76
|
+
"createBlock",
|
|
77
|
+
"creationHeight"
|
|
78
|
+
)
|
|
79
|
+
SELECT "id",
|
|
80
|
+
"address",
|
|
81
|
+
"boxId",
|
|
82
|
+
"serialized",
|
|
83
|
+
"spendBlock",
|
|
84
|
+
"extractor",
|
|
85
|
+
"spendHeight",
|
|
86
|
+
"block",
|
|
87
|
+
"height"
|
|
88
|
+
FROM "temporary_box_entity"
|
|
89
|
+
`);
|
|
90
|
+
await queryRunner.query(`
|
|
91
|
+
DROP TABLE "temporary_box_entity"
|
|
92
|
+
`);
|
|
93
|
+
await queryRunner.query(`
|
|
94
|
+
ALTER TABLE "box_entity"
|
|
95
|
+
RENAME TO "temporary_box_entity"
|
|
96
|
+
`);
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMTczNzUzMjY1NTE2Ny1taWdyYXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9saWIvbWlncmF0aW9ucy9zcWxpdGUvMTczNzUzMjY1NTE2Ny1taWdyYXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxPQUFPLHNCQUFzQjtJQUNqQyxJQUFJLEdBQUcsd0JBQXdCLENBQUM7SUFFekIsS0FBSyxDQUFDLEVBQUUsQ0FBQyxXQUF3QjtRQUN0QyxNQUFNLFdBQVcsQ0FBQyxLQUFLLENBQUM7Ozs7Ozs7Ozs7Ozs7U0FhbkIsQ0FBQyxDQUFDO1FBQ1AsTUFBTSxXQUFXLENBQUMsS0FBSyxDQUFDOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O1NBc0JuQixDQUFDLENBQUM7UUFDUCxNQUFNLFdBQVcsQ0FBQyxLQUFLLENBQUM7O1NBRW5CLENBQUMsQ0FBQztRQUNQLE1BQU0sV0FBVyxDQUFDLEtBQUssQ0FBQzs7O1NBR25CLENBQUMsQ0FBQztJQUNULENBQUM7SUFFTSxLQUFLLENBQUMsSUFBSSxDQUFDLFdBQXdCO1FBQ3hDLE1BQU0sV0FBVyxDQUFDLEtBQUssQ0FBQzs7O1NBR25CLENBQUMsQ0FBQztRQUNQLE1BQU0sV0FBVyxDQUFDLEtBQUssQ0FBQzs7Ozs7Ozs7Ozs7O1NBWW5CLENBQUMsQ0FBQztRQUNQLE1BQU0sV0FBVyxDQUFDLEtBQUssQ0FBQzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztTQXNCbkIsQ0FBQyxDQUFDO1FBQ1AsTUFBTSxXQUFXLENBQUMsS0FBSyxDQUFDOztTQUVuQixDQUFDLENBQUM7UUFDUCxNQUFNLFdBQVcsQ0FBQyxLQUFLLENBQUM7OztTQUduQixDQUFDLENBQUM7SUFDVCxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBNaWdyYXRpb25JbnRlcmZhY2UsIFF1ZXJ5UnVubmVyIH0gZnJvbSAndHlwZW9ybSc7XG5cbmV4cG9ydCBjbGFzcyBtaWdyYXRpb24xNzM3NTMyNjU1MTY3IGltcGxlbWVudHMgTWlncmF0aW9uSW50ZXJmYWNlIHtcbiAgbmFtZSA9ICdNaWdyYXRpb24xNzM3NTMyNjU1MTY3JztcblxuICBwdWJsaWMgYXN5bmMgdXAocXVlcnlSdW5uZXI6IFF1ZXJ5UnVubmVyKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgYXdhaXQgcXVlcnlSdW5uZXIucXVlcnkoYFxuICAgICAgICAgICAgQ1JFQVRFIFRBQkxFIFwidGVtcG9yYXJ5X2JveF9lbnRpdHlcIiAoXG4gICAgICAgICAgICAgICAgXCJpZFwiIGludGVnZXIgUFJJTUFSWSBLRVkgQVVUT0lOQ1JFTUVOVCBOT1QgTlVMTCxcbiAgICAgICAgICAgICAgICBcImJveElkXCIgdmFyY2hhciBOT1QgTlVMTCxcbiAgICAgICAgICAgICAgICBcImhlaWdodFwiIGludGVnZXIgTk9UIE5VTEwsXG4gICAgICAgICAgICAgICAgXCJibG9ja1wiIHZhcmNoYXIgTk9UIE5VTEwsXG4gICAgICAgICAgICAgICAgXCJzcGVuZEJsb2NrXCIgdmFyY2hhcixcbiAgICAgICAgICAgICAgICBcInNwZW5kSGVpZ2h0XCIgaW50ZWdlcixcbiAgICAgICAgICAgICAgICBcImFkZHJlc3NcIiB2YXJjaGFyIE5PVCBOVUxMLFxuICAgICAgICAgICAgICAgIFwiZXh0cmFjdG9yXCIgdmFyY2hhciBOT1QgTlVMTCxcbiAgICAgICAgICAgICAgICBcInNlcmlhbGl6ZWRcIiB2YXJjaGFyIE5PVCBOVUxMLFxuICAgICAgICAgICAgICAgIENPTlNUUkFJTlQgXCJVUV84NmZiZTViYjMwN2RlMTMwNWNjMjJlZmE3NjJcIiBVTklRVUUgKFwiYm94SWRcIiwgXCJleHRyYWN0b3JcIilcbiAgICAgICAgICAgIClcbiAgICAgICAgYCk7XG4gICAgYXdhaXQgcXVlcnlSdW5uZXIucXVlcnkoYFxuICAgICAgICAgICAgSU5TRVJUIElOVE8gXCJ0ZW1wb3JhcnlfYm94X2VudGl0eVwiKFxuICAgICAgICAgICAgICAgICAgICBcImlkXCIsXG4gICAgICAgICAgICAgICAgICAgIFwiYWRkcmVzc1wiLFxuICAgICAgICAgICAgICAgICAgICBcImJveElkXCIsXG4gICAgICAgICAgICAgICAgICAgIFwic2VyaWFsaXplZFwiLFxuICAgICAgICAgICAgICAgICAgICBcInNwZW5kQmxvY2tcIixcbiAgICAgICAgICAgICAgICAgICAgXCJleHRyYWN0b3JcIixcbiAgICAgICAgICAgICAgICAgICAgXCJzcGVuZEhlaWdodFwiLFxuICAgICAgICAgICAgICAgICAgICBcImJsb2NrXCIsXG4gICAgICAgICAgICAgICAgICAgIFwiaGVpZ2h0XCJcbiAgICAgICAgICAgICAgICApXG4gICAgICAgICAgICBTRUxFQ1QgXCJpZFwiLFxuICAgICAgICAgICAgICAgIFwiYWRkcmVzc1wiLFxuICAgICAgICAgICAgICAgIFwiYm94SWRcIixcbiAgICAgICAgICAgICAgICBcInNlcmlhbGl6ZWRcIixcbiAgICAgICAgICAgICAgICBcInNwZW5kQmxvY2tcIixcbiAgICAgICAgICAgICAgICBcImV4dHJhY3RvclwiLFxuICAgICAgICAgICAgICAgIFwic3BlbmRIZWlnaHRcIixcbiAgICAgICAgICAgICAgICBcImNyZWF0ZUJsb2NrXCIsXG4gICAgICAgICAgICAgICAgXCJjcmVhdGlvbkhlaWdodFwiXG4gICAgICAgICAgICBGUk9NIFwiYm94X2VudGl0eVwiXG4gICAgICAgIGApO1xuICAgIGF3YWl0IHF1ZXJ5UnVubmVyLnF1ZXJ5KGBcbiAgICAgICAgICAgIERST1AgVEFCTEUgXCJib3hfZW50aXR5XCJcbiAgICAgICAgYCk7XG4gICAgYXdhaXQgcXVlcnlSdW5uZXIucXVlcnkoYFxuICAgICAgICAgICAgQUxURVIgVEFCTEUgXCJ0ZW1wb3JhcnlfYm94X2VudGl0eVwiXG4gICAgICAgICAgICAgICAgUkVOQU1FIFRPIFwiYm94X2VudGl0eVwiXG4gICAgICAgIGApO1xuICB9XG5cbiAgcHVibGljIGFzeW5jIGRvd24ocXVlcnlSdW5uZXI6IFF1ZXJ5UnVubmVyKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgYXdhaXQgcXVlcnlSdW5uZXIucXVlcnkoYFxuICAgICAgICAgICAgQUxURVIgVEFCTEUgXCJib3hfZW50aXR5XCJcbiAgICAgICAgICAgICAgICBSRU5BTUUgVE8gXCJ0ZW1wb3JhcnlfYm94X2VudGl0eVwiXG4gICAgICAgIGApO1xuICAgIGF3YWl0IHF1ZXJ5UnVubmVyLnF1ZXJ5KGBcbiAgICAgICAgICAgIENSRUFURSBUQUJMRSBcImJveF9lbnRpdHlcIiAoXG4gICAgICAgICAgICAgICAgXCJpZFwiIGludGVnZXIgUFJJTUFSWSBLRVkgQVVUT0lOQ1JFTUVOVCBOT1QgTlVMTCxcbiAgICAgICAgICAgICAgICBcImFkZHJlc3NcIiB2YXJjaGFyIE5PVCBOVUxMLFxuICAgICAgICAgICAgICAgIFwiYm94SWRcIiB2YXJjaGFyIE5PVCBOVUxMLFxuICAgICAgICAgICAgICAgIFwic2VyaWFsaXplZFwiIHZhcmNoYXIgTk9UIE5VTEwsXG4gICAgICAgICAgICAgICAgXCJzcGVuZEJsb2NrXCIgdGV4dCxcbiAgICAgICAgICAgICAgICBcImV4dHJhY3RvclwiIHZhcmNoYXIgTk9UIE5VTEwsXG4gICAgICAgICAgICAgICAgXCJzcGVuZEhlaWdodFwiIGludGVnZXIsXG4gICAgICAgICAgICAgICAgXCJjcmVhdGVCbG9ja1wiIHZhcmNoYXIgTk9UIE5VTEwsXG4gICAgICAgICAgICAgICAgXCJjcmVhdGlvbkhlaWdodFwiIGludGVnZXIgTk9UIE5VTExcbiAgICAgICAgICAgIClcbiAgICAgICAgYCk7XG4gICAgYXdhaXQgcXVlcnlSdW5uZXIucXVlcnkoYFxuICAgICAgICAgICAgSU5TRVJUIElOVE8gXCJib3hfZW50aXR5XCIoXG4gICAgICAgICAgICAgICAgICAgIFwiaWRcIixcbiAgICAgICAgICAgICAgICAgICAgXCJhZGRyZXNzXCIsXG4gICAgICAgICAgICAgICAgICAgIFwiYm94SWRcIixcbiAgICAgICAgICAgICAgICAgICAgXCJzZXJpYWxpemVkXCIsXG4gICAgICAgICAgICAgICAgICAgIFwic3BlbmRCbG9ja1wiLFxuICAgICAgICAgICAgICAgICAgICBcImV4dHJhY3RvclwiLFxuICAgICAgICAgICAgICAgICAgICBcInNwZW5kSGVpZ2h0XCIsXG4gICAgICAgICAgICAgICAgICAgIFwiY3JlYXRlQmxvY2tcIixcbiAgICAgICAgICAgICAgICAgICAgXCJjcmVhdGlvbkhlaWdodFwiXG4gICAgICAgICAgICAgICAgKVxuICAgICAgICAgICAgU0VMRUNUIFwiaWRcIixcbiAgICAgICAgICAgICAgICBcImFkZHJlc3NcIixcbiAgICAgICAgICAgICAgICBcImJveElkXCIsXG4gICAgICAgICAgICAgICAgXCJzZXJpYWxpemVkXCIsXG4gICAgICAgICAgICAgICAgXCJzcGVuZEJsb2NrXCIsXG4gICAgICAgICAgICAgICAgXCJleHRyYWN0b3JcIixcbiAgICAgICAgICAgICAgICBcInNwZW5kSGVpZ2h0XCIsXG4gICAgICAgICAgICAgICAgXCJibG9ja1wiLFxuICAgICAgICAgICAgICAgIFwiaGVpZ2h0XCJcbiAgICAgICAgICAgIEZST00gXCJ0ZW1wb3JhcnlfYm94X2VudGl0eVwiXG4gICAgICAgIGApO1xuICAgIGF3YWl0IHF1ZXJ5UnVubmVyLnF1ZXJ5KGBcbiAgICAgICAgICAgIERST1AgVEFCTEUgXCJ0ZW1wb3JhcnlfYm94X2VudGl0eVwiXG4gICAgICAgIGApO1xuICAgIGF3YWl0IHF1ZXJ5UnVubmVyLnF1ZXJ5KGBcbiAgICAgICAgICAgIEFMVEVSIFRBQkxFIFwiYm94X2VudGl0eVwiXG4gICAgICAgICAgICAgICAgUkVOQU1FIFRPIFwidGVtcG9yYXJ5X2JveF9lbnRpdHlcIlxuICAgICAgICBgKTtcbiAgfVxufVxuIl19
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@rosen-bridge/address-extractor",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "6.0.0",
|
|
4
4
|
"description": "UTXO box extractor for any address or token.",
|
|
5
5
|
"author": "Rosen Team",
|
|
6
6
|
"license": "GPL-3.0",
|
|
@@ -20,7 +20,7 @@
|
|
|
20
20
|
},
|
|
21
21
|
"dependencies": {
|
|
22
22
|
"@rosen-bridge/abstract-logger": "^1.0.0",
|
|
23
|
-
"@rosen-bridge/abstract-extractor": "^0.
|
|
23
|
+
"@rosen-bridge/abstract-extractor": "^1.0.0",
|
|
24
24
|
"@rosen-clients/ergo-explorer": "^1.1.1",
|
|
25
25
|
"blakejs": "^1.2.1",
|
|
26
26
|
"ergo-lib-wasm-nodejs": "^0.24.1",
|