@cardano-sdk/projection-typeorm 0.2.1-nightly.1 → 0.2.1
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/cjs/createDataSource.d.ts.map +1 -1
- package/dist/cjs/createDataSource.js +2 -5
- package/dist/cjs/createDataSource.js.map +1 -1
- package/dist/cjs/index.d.ts +1 -1
- package/dist/cjs/index.d.ts.map +1 -1
- package/dist/cjs/index.js +3 -2
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/operators/storeStakePoolMetadataJob.d.ts.map +1 -1
- package/dist/cjs/operators/storeStakePoolMetadataJob.js +5 -1
- package/dist/cjs/operators/storeStakePoolMetadataJob.js.map +1 -1
- package/dist/cjs/operators/withTypeormTransaction.js +1 -1
- package/dist/cjs/operators/withTypeormTransaction.js.map +1 -1
- package/dist/cjs/pgBoss.d.ts +7 -15
- package/dist/cjs/pgBoss.d.ts.map +1 -1
- package/dist/cjs/pgBoss.js +25 -28
- package/dist/cjs/pgBoss.js.map +1 -1
- package/dist/cjs/tsconfig.tsbuildinfo +1 -1
- package/dist/esm/createDataSource.d.ts.map +1 -1
- package/dist/esm/createDataSource.js +2 -5
- package/dist/esm/createDataSource.js.map +1 -1
- package/dist/esm/index.d.ts +1 -1
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +1 -1
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/operators/storeStakePoolMetadataJob.d.ts.map +1 -1
- package/dist/esm/operators/storeStakePoolMetadataJob.js +5 -1
- package/dist/esm/operators/storeStakePoolMetadataJob.js.map +1 -1
- package/dist/esm/operators/withTypeormTransaction.js +1 -1
- package/dist/esm/operators/withTypeormTransaction.js.map +1 -1
- package/dist/esm/pgBoss.d.ts +7 -15
- package/dist/esm/pgBoss.d.ts.map +1 -1
- package/dist/esm/pgBoss.js +23 -26
- package/dist/esm/pgBoss.js.map +1 -1
- package/dist/esm/tsconfig.tsbuildinfo +1 -1
- package/package.json +9 -9
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createDataSource.d.ts","sourceRoot":"","sources":["../../src/createDataSource.ts"],"names":[],"mappings":"AAAA,OAAO,kBAAkB,CAAC;
|
|
1
|
+
{"version":3,"file":"createDataSource.d.ts","sourceRoot":"","sources":["../../src/createDataSource.ts"],"names":[],"mappings":"AAAA,OAAO,kBAAkB,CAAC;AAC1B,OAAO,EAAE,UAAU,EAAE,iBAAiB,EAAkD,WAAW,EAAE,MAAM,SAAS,CAAC;AACrH,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAMhC,MAAM,WAAW,oBAAoB;IACnC,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB;AAED,aAAK,yBAAyB,GAAG,iBAAiB,GAAG;IAAE,IAAI,EAAE,UAAU,CAAA;CAAE,CAAC;AAE1E,oBAAY,kBAAkB,GAAG,IAAI,CACnC,yBAAyB,EACzB,MAAM,GAAG,MAAM,GAAG,UAAU,GAAG,UAAU,GAAG,UAAU,GAAG,KAAK,CAC/D,CAAC;AAEF,oBAAY,iBAAiB,GAAG,IAAI,CAAC,yBAAyB,EAAE,aAAa,GAAG,YAAY,CAAC,CAAC;AAE9F,oBAAY,cAAc,GAAG,IAAI,CAC/B,yBAAyB,EACvB,kBAAkB,GAClB,kBAAkB,GAClB,mBAAmB,GACnB,OAAO,GACP,uBAAuB,GACvB,UAAU,GACV,OAAO,GACP,eAAe,GACf,YAAY,CACf,GAAG,EAAE,CAAC;AAEP,MAAM,WAAW,qBAAqB;IACpC,QAAQ,EAAE,QAAQ,EAAE,CAAC;IACrB,gBAAgB,EAAE,kBAAkB,CAAC;IACrC,OAAO,CAAC,EAAE,cAAc,CAAC;IACzB,UAAU,CAAC,EAAE,iBAAiB,CAAC;IAC/B,UAAU,CAAC,EAAE,oBAAoB,CAAC;IAClC,MAAM,EAAE,MAAM,CAAC;CAChB;AAiDD,eAAO,MAAM,kBAAkB,gBAAuB,WAAW,qBAKhE,CAAC;AA8BF,eAAO,MAAM,gBAAgB,4EAO1B,qBAAqB,eAuBvB,CAAC"}
|
|
@@ -1,9 +1,8 @@
|
|
|
1
1
|
import 'reflect-metadata';
|
|
2
|
-
import { BossDb } from './pgBoss';
|
|
3
2
|
import { DataSource, DefaultNamingStrategy } from 'typeorm';
|
|
4
3
|
import { contextLogger, patchObject } from '@cardano-sdk/util';
|
|
4
|
+
import { createPgBoss } from './pgBoss';
|
|
5
5
|
import { typeormLogger } from './logger';
|
|
6
|
-
import PgBoss from 'pg-boss';
|
|
7
6
|
import snakeCase from 'lodash/snakeCase';
|
|
8
7
|
const toTableName = (tableOrName) => (typeof tableOrName === 'string' ? tableOrName : tableOrName.name).replace('_entity', '');
|
|
9
8
|
const namingOverrides = {
|
|
@@ -64,9 +63,7 @@ const initializePgBoss = async (dataSource, logger, usePgBoss, dropSchema) => {
|
|
|
64
63
|
if (!usePgBoss) {
|
|
65
64
|
return;
|
|
66
65
|
}
|
|
67
|
-
const boss =
|
|
68
|
-
db: new BossDb(queryRunner)
|
|
69
|
-
});
|
|
66
|
+
const boss = createPgBoss(queryRunner, logger);
|
|
70
67
|
await queryRunner.query('CREATE EXTENSION IF NOT EXISTS pgcrypto;');
|
|
71
68
|
await boss.start();
|
|
72
69
|
await boss.stop();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createDataSource.js","sourceRoot":"","sources":["../../src/createDataSource.ts"],"names":[],"mappings":"AAAA,OAAO,kBAAkB,CAAC;AAC1B,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"createDataSource.js","sourceRoot":"","sources":["../../src/createDataSource.ts"],"names":[],"mappings":"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"}
|
package/dist/esm/index.d.ts
CHANGED
|
@@ -5,5 +5,5 @@ export * from './entity';
|
|
|
5
5
|
export * from './operators';
|
|
6
6
|
export * from './TypeormStabilityWindowBuffer';
|
|
7
7
|
export * from './isRecoverableTypeormError';
|
|
8
|
-
export {
|
|
8
|
+
export { STAKE_POOL_METADATA_QUEUE, StakePoolMetadataJob as StakePoolMetadataTask, createPgBoss, createPgBossExtension } from './pgBoss';
|
|
9
9
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/esm/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,kBAAkB,CAAC;AAC1B,cAAc,oCAAoC,CAAC;AACnD,cAAc,oBAAoB,CAAC;AACnC,cAAc,UAAU,CAAC;AACzB,cAAc,aAAa,CAAC;AAC5B,cAAc,gCAAgC,CAAC;AAC/C,cAAc,6BAA6B,CAAC;AAC5C,OAAO,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,kBAAkB,CAAC;AAC1B,cAAc,oCAAoC,CAAC;AACnD,cAAc,oBAAoB,CAAC;AACnC,cAAc,UAAU,CAAC;AACzB,cAAc,aAAa,CAAC;AAC5B,cAAc,gCAAgC,CAAC;AAC/C,cAAc,6BAA6B,CAAC;AAC5C,OAAO,EACL,yBAAyB,EACzB,oBAAoB,IAAI,qBAAqB,EAC7C,YAAY,EACZ,qBAAqB,EACtB,MAAM,UAAU,CAAC"}
|
package/dist/esm/index.js
CHANGED
|
@@ -5,5 +5,5 @@ export * from './entity';
|
|
|
5
5
|
export * from './operators';
|
|
6
6
|
export * from './TypeormStabilityWindowBuffer';
|
|
7
7
|
export * from './isRecoverableTypeormError';
|
|
8
|
-
export {
|
|
8
|
+
export { STAKE_POOL_METADATA_QUEUE, createPgBoss, createPgBossExtension } from './pgBoss';
|
|
9
9
|
//# sourceMappingURL=index.js.map
|
package/dist/esm/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,kBAAkB,CAAC;AAC1B,cAAc,oCAAoC,CAAC;AACnD,cAAc,oBAAoB,CAAC;AACnC,cAAc,UAAU,CAAC;AACzB,cAAc,aAAa,CAAC;AAC5B,cAAc,gCAAgC,CAAC;AAC/C,cAAc,6BAA6B,CAAC;AAC5C,OAAO,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,kBAAkB,CAAC;AAC1B,cAAc,oCAAoC,CAAC;AACnD,cAAc,oBAAoB,CAAC;AACnC,cAAc,UAAU,CAAC;AACzB,cAAc,aAAa,CAAC;AAC5B,cAAc,gCAAgC,CAAC;AAC/C,cAAc,6BAA6B,CAAC;AAC5C,OAAO,EACL,yBAAyB,EAEzB,YAAY,EACZ,qBAAqB,EACtB,MAAM,UAAU,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"storeStakePoolMetadataJob.d.ts","sourceRoot":"","sources":["../../../src/operators/storeStakePoolMetadataJob.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,yBAAyB,CAAC;AAElD,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AAGtD,eAAO,MAAM,yBAAyB,
|
|
1
|
+
{"version":3,"file":"storeStakePoolMetadataJob.d.ts","sourceRoot":"","sources":["../../../src/operators/storeStakePoolMetadataJob.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,yBAAyB,CAAC;AAElD,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AAGtD,eAAO,MAAM,yBAAyB,8uBAuBrC,CAAC"}
|
|
@@ -13,7 +13,11 @@ export const storeStakePoolMetadataJob = typeormOperator(async ({ eventType, sta
|
|
|
13
13
|
poolRegistrationId: certificatePointerToId(source).toString()
|
|
14
14
|
}));
|
|
15
15
|
for (const task of tasks) {
|
|
16
|
-
await pgBoss.send(STAKE_POOL_METADATA_QUEUE, task, {
|
|
16
|
+
await pgBoss.send(STAKE_POOL_METADATA_QUEUE, task, {
|
|
17
|
+
retryDelay: 6 * 3600,
|
|
18
|
+
retryLimit: 1000000,
|
|
19
|
+
slot: header.slot
|
|
20
|
+
});
|
|
17
21
|
}
|
|
18
22
|
});
|
|
19
23
|
//# sourceMappingURL=storeStakePoolMetadataJob.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"storeStakePoolMetadataJob.js","sourceRoot":"","sources":["../../../src/operators/storeStakePoolMetadataJob.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AAEvD,OAAO,EAAE,yBAAyB,EAAwB,MAAM,WAAW,CAAC;AAE5E,OAAO,EAAE,sBAAsB,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC;AAEjE,MAAM,CAAC,MAAM,yBAAyB,GAAG,eAAe,CACtD,KAAK,EAAE,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE;IAC7D,IAAI,SAAS,KAAK,kBAAkB,CAAC,YAAY,EAAE;QAEjD,OAAO;KACR;IACD,MAAM,KAAK,GAAG,UAAU,CAAC,OAAO;SAC7B,MAAM,CAAC,CAAC,EAAE,cAAc,EAAE,EAAE,YAAY,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC;SAChE,GAAG,CACF,CAAC,EAAE,MAAM,EAAE,cAAc,EAAE,EAAE,EAAE,EAAE,YAAY,EAAE,EAAE,EAAwB,EAAE,CAAC,CAAC;QAC3E,YAAY,EAAE,YAAa;QAC3B,MAAM,EAAE,EAAE;QACV,kBAAkB,EAAE,sBAAsB,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE;KAC9D,CAAC,CACH,CAAC;IACJ,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE;QACxB,MAAM,MAAM,CAAC,IAAI,CAAC,yBAAyB,EAAE,IAAI,EAAE,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,
|
|
1
|
+
{"version":3,"file":"storeStakePoolMetadataJob.js","sourceRoot":"","sources":["../../../src/operators/storeStakePoolMetadataJob.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AAEvD,OAAO,EAAE,yBAAyB,EAAwB,MAAM,WAAW,CAAC;AAE5E,OAAO,EAAE,sBAAsB,EAAE,eAAe,EAAE,MAAM,QAAQ,CAAC;AAEjE,MAAM,CAAC,MAAM,yBAAyB,GAAG,eAAe,CACtD,KAAK,EAAE,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,EAAE;IAC7D,IAAI,SAAS,KAAK,kBAAkB,CAAC,YAAY,EAAE;QAEjD,OAAO;KACR;IACD,MAAM,KAAK,GAAG,UAAU,CAAC,OAAO;SAC7B,MAAM,CAAC,CAAC,EAAE,cAAc,EAAE,EAAE,YAAY,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC;SAChE,GAAG,CACF,CAAC,EAAE,MAAM,EAAE,cAAc,EAAE,EAAE,EAAE,EAAE,YAAY,EAAE,EAAE,EAAwB,EAAE,CAAC,CAAC;QAC3E,YAAY,EAAE,YAAa;QAC3B,MAAM,EAAE,EAAE;QACV,kBAAkB,EAAE,sBAAsB,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE;KAC9D,CAAC,CACH,CAAC;IACJ,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE;QACxB,MAAM,MAAM,CAAC,IAAI,CAAC,yBAAyB,EAAE,IAAI,EAAE;YACjD,UAAU,EAAE,CAAC,GAAG,IAAI;YACpB,UAAU,EAAE,OAAS;YACrB,IAAI,EAAE,MAAM,CAAC,IAAI;SAClB,CAAC,CAAC;KACJ;AACH,CAAC,CACF,CAAC"}
|
|
@@ -9,7 +9,7 @@ export function withTypeormTransaction({ dataSource$, logger }, extensions) {
|
|
|
9
9
|
const queryRunner = dataSource.createQueryRunner('master');
|
|
10
10
|
await queryRunner.connect();
|
|
11
11
|
if (extensions?.pgBoss) {
|
|
12
|
-
const pgBoss = createPgBossExtension(queryRunner);
|
|
12
|
+
const pgBoss = createPgBossExtension(queryRunner, logger);
|
|
13
13
|
return { pgBoss, queryRunner };
|
|
14
14
|
}
|
|
15
15
|
return { queryRunner };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"withTypeormTransaction.js","sourceRoot":"","sources":["../../../src/operators/withTypeormTransaction.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,KAAK,EAAc,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,EAAE,QAAQ,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AACtG,OAAO,EAAmB,qBAAqB,EAAE,MAAM,WAAW,CAAC;AACnE,OAAO,EAIL,gBAAgB,EAChB,iBAAiB,EAClB,MAAM,yBAAyB,CAAC;AAEjC,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAC5D,OAAO,IAAI,MAAM,aAAa,CAAC;AAgB/B,MAAM,2BAA2B,GAA8B,CAAC,aAAa,EAAE,uBAAuB,EAAE,QAAQ,CAAC,CAAC;AAkBlH,MAAM,UAAU,sBAAsB,CACpC,EAAE,WAAW,EAAE,MAAM,EAAsC,EAC3D,UAAiC;IAGjC,OAAO,CAAC,IAA0C,EAAE,EAAE,CACpD,IAAI,CAAC,IAAI,CACP,iBAAiB,CACf,KAAK,CAAC,GAAG,EAAE,CACT,WAAW,CAAC,IAAI,CACd,SAAS,CAAC,CAAC,UAAU,EAAE,EAAE,CACvB,MAAM,CACJ,IAAI,CACF,CAAC,KAAK,IAAI,EAAE;QACV,MAAM,WAAW,GAAG,UAAU,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC;QAC3D,MAAM,WAAW,CAAC,OAAO,EAAE,CAAC;QAC5B,IAAI,UAAU,EAAE,MAAM,EAAE;YACtB,MAAM,MAAM,GAAG,qBAAqB,CAAC,WAAW,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"withTypeormTransaction.js","sourceRoot":"","sources":["../../../src/operators/withTypeormTransaction.ts"],"names":[],"mappings":"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"}
|
package/dist/esm/pgBoss.d.ts
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
/// <reference types="node" />
|
|
2
1
|
import { Cardano } from '@cardano-sdk/core';
|
|
3
|
-
import { QueryRunner } from 'typeorm';
|
|
4
|
-
import
|
|
5
|
-
|
|
2
|
+
import { DataSource, QueryRunner } from 'typeorm';
|
|
3
|
+
import { Logger } from 'ts-log';
|
|
4
|
+
import PgBoss, { SendOptions } from 'pg-boss';
|
|
5
|
+
export declare const STAKE_POOL_METADATA_QUEUE = "pool-metadata";
|
|
6
6
|
export interface PgBossExtension {
|
|
7
|
-
send: <T extends object>(taskName: string, data: T, options: {
|
|
7
|
+
send: <T extends object>(taskName: string, data: T, options: SendOptions & {
|
|
8
8
|
slot: Cardano.Slot;
|
|
9
9
|
}) => Promise<string | null>;
|
|
10
10
|
}
|
|
@@ -13,14 +13,6 @@ export interface StakePoolMetadataJob {
|
|
|
13
13
|
poolId: Cardano.PoolId;
|
|
14
14
|
metadataJson: NonNullable<Cardano.StakePool['metadataJson']>;
|
|
15
15
|
}
|
|
16
|
-
export declare
|
|
17
|
-
|
|
18
|
-
opened: boolean;
|
|
19
|
-
constructor(queryRunner: QueryRunner);
|
|
20
|
-
executeSql(text: string, values: unknown[]): Promise<{
|
|
21
|
-
rowCount: number;
|
|
22
|
-
rows: any[];
|
|
23
|
-
}>;
|
|
24
|
-
}
|
|
25
|
-
export declare const createPgBossExtension: (queryRunner: QueryRunner) => PgBossExtension;
|
|
16
|
+
export declare const createPgBoss: (queryRunner: QueryRunner | null, logger: Logger, dataSource?: DataSource) => PgBoss;
|
|
17
|
+
export declare const createPgBossExtension: (queryRunner: QueryRunner, logger: Logger) => PgBossExtension;
|
|
26
18
|
//# sourceMappingURL=pgBoss.d.ts.map
|
package/dist/esm/pgBoss.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pgBoss.d.ts","sourceRoot":"","sources":["../../src/pgBoss.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"pgBoss.d.ts","sourceRoot":"","sources":["../../src/pgBoss.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAC5C,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAClD,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAIhC,OAAO,MAAM,EAAE,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAE9C,eAAO,MAAM,yBAAyB,kBAAkB,CAAC;AAEzD,MAAM,WAAW,eAAe;IAC9B,IAAI,EAAE,CAAC,CAAC,SAAS,MAAM,EACrB,QAAQ,EAAE,MAAM,EAChB,IAAI,EAAE,CAAC,EACP,OAAO,EAAE,WAAW,GAAG;QAAE,IAAI,EAAE,OAAO,CAAC,IAAI,CAAA;KAAE,KAC1C,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC;CAC7B;AAED,MAAM,WAAW,oBAAoB;IAInC,kBAAkB,EAAE,MAAM,CAAC;IAC3B,MAAM,EAAE,OAAO,CAAC,MAAM,CAAC;IACvB,YAAY,EAAE,WAAW,CAAC,OAAO,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC,CAAC;CAC9D;AAsCD,eAAO,MAAM,YAAY,gBAAiB,WAAW,GAAG,IAAI,UAAU,MAAM,eAAe,UAAU,WAQpG,CAAC;AA6JF,eAAO,MAAM,qBAAqB,gBAAiB,WAAW,UAAU,MAAM,KAAG,eAUhF,CAAC"}
|
package/dist/esm/pgBoss.js
CHANGED
|
@@ -1,34 +1,31 @@
|
|
|
1
|
-
|
|
2
|
-
if (kind === "m") throw new TypeError("Private method is not writable");
|
|
3
|
-
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
|
|
4
|
-
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
|
|
5
|
-
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
|
6
|
-
};
|
|
7
|
-
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
8
|
-
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
9
|
-
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
10
|
-
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
11
|
-
};
|
|
12
|
-
var _BossDb_queryRunner;
|
|
1
|
+
import { contextLogger } from '@cardano-sdk/util';
|
|
13
2
|
import { v4 } from 'uuid';
|
|
14
3
|
import Attorney from 'pg-boss/src/attorney';
|
|
15
|
-
import EventEmitter from 'events';
|
|
16
4
|
import PgBoss from 'pg-boss';
|
|
17
|
-
export const STAKE_POOL_METADATA_QUEUE = '
|
|
18
|
-
|
|
19
|
-
constructor(queryRunner) {
|
|
20
|
-
|
|
21
|
-
this.
|
|
22
|
-
|
|
23
|
-
__classPrivateFieldSet(this, _BossDb_queryRunner, queryRunner, "f");
|
|
5
|
+
export const STAKE_POOL_METADATA_QUEUE = 'pool-metadata';
|
|
6
|
+
class BossDb {
|
|
7
|
+
constructor(queryRunner, logger, dataSource) {
|
|
8
|
+
this.queryRunner = queryRunner;
|
|
9
|
+
this.logger = logger;
|
|
10
|
+
this.dataSource = dataSource;
|
|
24
11
|
}
|
|
25
12
|
async executeSql(text, values) {
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
13
|
+
this.logger.debug(text, values);
|
|
14
|
+
const queryRunner = this.dataSource ? this.dataSource.createQueryRunner() : this.queryRunner;
|
|
15
|
+
if (!queryRunner)
|
|
16
|
+
throw new Error('Provide a queryRunner or a dataSource');
|
|
17
|
+
const { records, affected } = await queryRunner.query(text, values, true);
|
|
18
|
+
if (this.dataSource)
|
|
19
|
+
await queryRunner.release();
|
|
20
|
+
return { rowCount: affected || 0, rows: records };
|
|
29
21
|
}
|
|
30
22
|
}
|
|
31
|
-
|
|
23
|
+
export const createPgBoss = (queryRunner, logger, dataSource) => {
|
|
24
|
+
logger = contextLogger(logger, 'pg-boss');
|
|
25
|
+
const pgBoss = new PgBoss({ db: new BossDb(queryRunner, logger, dataSource) });
|
|
26
|
+
pgBoss.on('error', (error) => logger.error(error));
|
|
27
|
+
return pgBoss;
|
|
28
|
+
};
|
|
32
29
|
async function createJob(name, data, options, singletonOffset = 0) {
|
|
33
30
|
const { db: wrapper, expireIn, priority, startAfter, keepUntil, singletonKey = null, singletonSeconds, retryBackoff, retryLimit, retryDelay, onComplete, slot } = options;
|
|
34
31
|
const id = v4();
|
|
@@ -147,8 +144,8 @@ async function send(...args) {
|
|
|
147
144
|
const { name, data, options } = Attorney.checkSendArgs(args, this.manager.config);
|
|
148
145
|
return await this.createJob(name, data, options);
|
|
149
146
|
}
|
|
150
|
-
export const createPgBossExtension = (queryRunner) => {
|
|
151
|
-
const boss =
|
|
147
|
+
export const createPgBossExtension = (queryRunner, logger) => {
|
|
148
|
+
const boss = createPgBoss(queryRunner, logger);
|
|
152
149
|
boss.insertJobCommand = insertJob('pgboss');
|
|
153
150
|
boss.send = send;
|
|
154
151
|
boss.createJob = createJob;
|
package/dist/esm/pgBoss.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pgBoss.js","sourceRoot":"","sources":["../../src/pgBoss.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"pgBoss.js","sourceRoot":"","sources":["../../src/pgBoss.ts"],"names":[],"mappings":"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"}
|